"use client"; import { useState } from "react"; import { CommentComposer } from "@/components/chat-comments/comment-composer/comment-composer"; import { MemberMentionPicker } from "@/components/chat-comments/member-mention-picker/member-mention-picker"; import type { MemberOption } from "@/components/chat-comments/member-mention-picker/types"; const fakeMembersData: MemberOption[] = [ { id: "550e8400-e29b-41d4-a716-446655440001", displayName: "Alice Smith", email: "alice@example.com", avatarUrl: null, }, { id: "550e8400-e29b-41d4-a716-446655440002", displayName: "Bob Johnson", email: "bob.johnson@example.com", avatarUrl: null, }, { id: "550e8400-e29b-41d4-a716-446655440003", displayName: "Charlie Brown", email: "charlie@example.com", avatarUrl: null, }, { id: "550e8400-e29b-41d4-a716-446655440004", displayName: null, email: "david.wilson@example.com", avatarUrl: null, }, { id: "550e8400-e29b-41d4-a716-446655440005", displayName: "Emma Davis", email: "emma@example.com", avatarUrl: null, }, ]; export default function ChatCommentsPreviewPage() { const [highlightedIndex, setHighlightedIndex] = useState(0); const [selectedMember, setSelectedMember] = useState(null); const [submittedContent, setSubmittedContent] = useState(null); return (

Chat Comments UI Preview

Preview page for chat comments components with fake data

{/* Comment Composer Section */}

Comment Composer

Type @ to trigger mention picker. Use Tab/Shift+Tab/Arrow keys to navigate, Enter to select.

setSubmittedContent(content)} onCancel={() => setSubmittedContent(null)} autoFocus />
{submittedContent && (
Submitted content: {submittedContent}
)}
{/* Member Mention Picker Section */}

Member Mention Picker (Standalone)

After typing @

Shows all members

setSelectedMember(member)} onHighlightChange={setHighlightedIndex} />
{selectedMember && (
Selected: @[{selectedMember.id.slice(0, 8)}...]
)}

After typing @ali

Filtered to matching members

{}} onHighlightChange={() => {}} />

Loading State

While fetching members

{}} onHighlightChange={() => {}} />

No Results

After typing @xyz (no match)

{}} onHighlightChange={() => {}} />
); }