---
name: libchat
description: >
libchat - Chat web components library. ChatClient provides composed client for
authentication, API communication, and state management. ChatDrawerElement and
ChatPageElement are custom elements for embedding chat interfaces.
Framework-agnostic using Web Components standard. Use for building chat UIs,
embedding conversational AI in websites, and creating dedicated chat pages.
---
# libchat Skill
## When to Use
- Embedding chat interfaces in web applications
- Building dedicated chat page experiences
- Adding conversational AI to existing websites
- Creating custom chat UI with authentication
## Key Concepts
**ChatClient**: Composed client managing auth state, API communication, and
conversation persistence via localStorage.
**ChatDrawerElement**: Collapsible drawer component for unobtrusive chat
integration on any page.
**ChatPageElement**: Full-page chat component for dedicated chat experiences.
## Usage Patterns
### Pattern 1: Embed chat drawer
```javascript
import { ChatClient, ChatDrawerElement } from "@copilot-ld/libchat";
const client = new ChatClient({
chatUrl: "/web/api/chat",
auth: { url: "http://localhost:9999", anonKey: "key" },
});
document.querySelector("chat-drawer").client = client;
```
### Pattern 2: Full-page chat
```html
```
## Integration
Used by the UI extension. Communicates with Web extension chat API.