0.1.3 ⢠Published 8 months ago
@kieng/just-chat v0.1.3
Universal Chat Popup
A lightweight, customizable chat widget that can be easily embedded into any website. Built with Web Components for maximum compatibility and style isolation.
Features
- šØ Customizable theme and appearance
- š¾ Local chat history persistence
- š Simple webhook integration
- šÆ Zero dependencies
- š”ļø Style isolation via Shadow DOM
- š± Responsive design
- āØļø Keyboard accessible
- š Message status indicators
- ā Request cancellation support
- š Secure by default
- š Cross-browser compatible
- š Small bundle size (~4KB gzipped)
Installation
Via CDN (Recommended)
<!-- Latest version -->
<script src="https://cdn.jsdelivr.net/npm/@kieng/just-chat/dist/just-chat.umd.js"
data-webhook-url="https://your-backend.com/chat"
data-theme-color="#1E40AF"
data-position="bottom-right"
data-title="Chat with us"
data-welcome-message="How can we help you today?"
data-history-enabled="true"
data-history-clear-button="true"
defer>
</script>
<!-- Specific version -->
<script src="https://cdn.jsdelivr.net/npm/@kieng/just-chat@0.1.2/dist/just-chat.umd.js"
data-webhook-url="https://your-backend.com/chat"
defer>
</script>Via NPM
# Using npm
npm install @kieng/just-chat
# Using pnpm
pnpm add @kieng/just-chat
# Using yarn
yarn add @kieng/just-chatimport { initChatPopup } from '@kieng/just-chat';
initChatPopup({
webhookUrl: 'https://your-backend.com/chat',
themeColor: '#1E40AF',
position: 'bottom-right',
title: 'Chat with us',
welcomeMessage: 'How can we help you today?',
history: {
enabled: true,
clearButton: true
}
});Configuration
| Option | Type | Default | Description |
|---|---|---|---|
| webhookUrl | string | - | (Required) Backend endpoint URL for processing messages |
| themeColor | string | '#1E40AF' | Primary color for UI elements |
| position | 'bottom-right' | 'bottom-left' | 'bottom-right' | Widget position on screen |
| title | string | 'Chat with us' | Chat window title |
| welcomeMessage | string | '' | Initial message shown when chat opens |
| history.enabled | boolean | true | Enable/disable chat history persistence |
| history.clearButton | boolean | true | Show/hide the clear history button |
Features in Detail
Message Status Indicators
Messages show their current status:
- š Sending: Message is being sent to the webhook
- ā Sent: Message was successfully delivered
- ā Error: Failed to send message
- āŖ Cancelled: User cancelled the message
History Management
Chat history is stored in LocalStorage:
- Persists across page reloads
- Separate storage per webhook URL
- Optional clear history button
- Automatic loading of previous messages
Webhook Integration
The widget sends POST requests to your webhook URL with the following JSON payload:
{
message: string; // User's message
timestamp: string; // ISO8601 timestamp
sessionId: string; // Unique session identifier
context: {
url: string; // Current page URL
};
history?: Array<{ // Last 10 messages (if any)
id: string;
text: string;
sender: 'user' | 'backend' | 'system';
timestamp: string;
}>;
}Expected response format:
{
response: string; // Text message to display to the user
}Security Features
- Content Security Policy (CSP) compatible
- No eval() or inline scripts
- XSS protection for message rendering
- CORS support for webhook requests
- Secure by default configuration
Browser Support
- Chrome (latest)
- Firefox (latest)
- Safari (latest)
- Edge (latest)
- Mobile browsers
Accessibility
- ARIA labels and roles
- Keyboard navigation
- Focus management
- Screen reader support
- High contrast support
Development
Prerequisites
- Node.js 18+
- pnpm (recommended) or npm
Setup
- Clone the repository
git clone https://github.com/draphonix/just-chat.git
cd just-chat- Install dependencies
pnpm install- Start development server
pnpm dev- Build for production
pnpm buildTesting the Widget
- Start the mock server
pnpm start- Open http://localhost:3000 in your browser
- Try the demo features:
- Send messages
- Cancel messages
- Clear history
- Change theme color
- Test responsiveness
Project Structure
just-chat/
āāā src/
ā āāā components/ # Web Components
ā ā āāā base-component.ts
ā ā āāā chat-widget.ts
ā ā āāā chat-launcher.ts
ā ā āāā chat-window.ts
ā āāā services/ # Core services
ā ā āāā storage.ts
ā ā āāā webhook.ts
ā āāā main.ts # Entry point
āāā dist/ # Built files
āāā mock-server.js # Test server
āāā package.jsonContributing
- Fork the repository
- Create your feature branch
- Commit your changes
- Push to the branch
- Create a Pull Request
License
MIT
Support
- GitHub Issues: Report a bug
- Email: hoang@kieng.io.vn
Credits
Built with:
- TypeScript
- Web Components
- Vite
- Express (mock server)# just-chat