Files
lettersoup-online/002_source/cms/src/app/dashboard/chat/layout.tsx
louiscklaw 6c931c1fe8 build ok,
2025-04-14 09:26:24 +08:00

212 lines
6.3 KiB
TypeScript

import * as React from 'react';
import { dayjs } from '@/lib/dayjs';
import { ChatProvider } from '@/components/dashboard/chat/chat-context';
import { ChatView } from '@/components/dashboard/chat/chat-view';
import type { Contact, Message, Thread } from '@/components/dashboard/chat/types';
const contacts = [
{
id: 'USR-010',
name: 'Alcides Antonio',
avatar: '/assets/avatar-10.png',
isActive: false,
lastActivity: dayjs().subtract(1, 'hour').toDate(),
},
{
id: 'USR-003',
name: 'Carson Darrin',
avatar: '/assets/avatar-3.png',
isActive: false,
lastActivity: dayjs().subtract(15, 'minute').toDate(),
},
{ id: 'USR-005', name: 'Fran Perez', avatar: '/assets/avatar-5.png', isActive: true, lastActivity: dayjs().toDate() },
{ id: 'USR-006', name: 'Iulia Albu', avatar: '/assets/avatar-6.png', isActive: true, lastActivity: dayjs().toDate() },
{ id: 'USR-008', name: 'Jie Yan', avatar: '/assets/avatar-8.png', isActive: true, lastActivity: dayjs().toDate() },
{
id: 'USR-009',
name: 'Marcus Finn',
avatar: '/assets/avatar-9.png',
isActive: false,
lastActivity: dayjs().subtract(2, 'hour').toDate(),
},
{
id: 'USR-001',
name: 'Miron Vitold',
avatar: '/assets/avatar-1.png',
isActive: true,
lastActivity: dayjs().toDate(),
},
{
id: 'USR-007',
name: 'Nasimiyu Danai',
avatar: '/assets/avatar-7.png',
isActive: true,
lastActivity: dayjs().toDate(),
},
{
id: 'USR-011',
name: 'Omar Darobe',
avatar: '/assets/avatar-11.png',
isActive: true,
lastActivity: dayjs().toDate(),
},
{
id: 'USR-004',
name: 'Penjani Inyene',
avatar: '/assets/avatar-4.png',
isActive: false,
lastActivity: dayjs().subtract(6, 'hour').toDate(),
},
{
id: 'USR-002',
name: 'Siegbert Gottfried',
avatar: '/assets/avatar-2.png',
isActive: true,
lastActivity: dayjs().toDate(),
},
] satisfies Contact[];
const threads = [
{
id: 'TRD-004',
type: 'direct',
participants: [
{ id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
{ id: 'USR-003', name: 'Carson Darrin', avatar: '/assets/avatar-3.png' },
],
unreadCount: 0,
},
{
id: 'TRD-003',
type: 'direct',
participants: [
{ id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
{ id: 'USR-005', name: 'Fran Perez', avatar: '/assets/avatar-5.png' },
],
unreadCount: 1,
},
{
id: 'TRD-002',
type: 'group',
participants: [
{ id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
{ id: 'USR-007', name: 'Nasimiyu Danai', avatar: '/assets/avatar-7.png' },
{ id: 'USR-001', name: 'Miron Vitold', avatar: '/assets/avatar-1.png' },
],
unreadCount: 0,
},
{
id: 'TRD-001',
type: 'direct',
participants: [
{ id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
{ id: 'USR-010', name: 'Alcides Antonio', avatar: '/assets/avatar-10.png' },
],
unreadCount: 2,
},
] satisfies Thread[];
const messages = [
{
id: 'MSG-011',
threadId: 'TRD-004',
type: 'text',
content: 'Hi, how are you?',
author: { id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
createdAt: dayjs().subtract(10, 'minute').toDate(),
},
{
id: 'MSG-010',
threadId: 'TRD-003',
type: 'text',
content: 'Are you available for a call?',
author: { id: 'USR-005', name: 'Fran Perez', avatar: '/assets/avatar-5.png' },
createdAt: dayjs().subtract(5, 'minute').subtract(1, 'hour').toDate(),
},
{
id: 'MSG-009',
threadId: 'TRD-002',
type: 'text',
content: 'Hello everyone 😀',
author: { id: 'USR-001', name: 'Miron Vitold', avatar: '/assets/avatar-1.png' },
createdAt: dayjs().subtract(56, 'minute').subtract(2, 'hour').toDate(),
},
{
id: 'MSG-008',
threadId: 'TRD-002',
type: 'text',
content: 'Hi!',
author: { id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
createdAt: dayjs().subtract(51, 'minute').subtract(3, 'hour').toDate(),
},
{
id: 'MSG-007',
threadId: 'TRD-002',
type: 'text',
content: 'Hey, would you like to collaborate?',
author: { id: 'USR-007', name: 'Nasimiyu Danai', avatar: '/assets/avatar-7.png' },
createdAt: dayjs().subtract(46, 'minute').subtract(5, 'hour').toDate(),
},
{
id: 'MSG-006',
threadId: 'TRD-001',
type: 'image',
content: '/assets/image-abstract-1.png',
author: { id: 'USR-010', name: 'Alcides Antonio', avatar: '/assets/avatar-10.png' },
createdAt: dayjs().subtract(1, 'hour').subtract(2, 'day').toDate(),
},
{
id: 'MSG-005',
threadId: 'TRD-001',
type: 'text',
content: 'Ok, I will think about it. Thanks!',
author: { id: 'USR-010', name: 'Alcides Antonio', avatar: '/assets/avatar-10.png' },
createdAt: dayjs().subtract(2, 'hour').subtract(2, 'day').toDate(),
},
{
id: 'MSG-004',
threadId: 'TRD-001',
type: 'text',
content: "I'm sorry, I can't go lower than $45.",
author: { id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
createdAt: dayjs().subtract(3, 'hour').subtract(3, 'day').toDate(),
},
{
id: 'MSG-003',
threadId: 'TRD-001',
type: 'text',
content: "Can't you make it $40? I'm on a tight budget.",
author: { id: 'USR-010', name: 'Alcides Antonio', avatar: '/assets/avatar-10.png' },
createdAt: dayjs().subtract(5, 'hour').subtract(3, 'day').toDate(),
},
{
id: 'MSG-002',
threadId: 'TRD-001',
type: 'text',
content: 'Sure, it is $50 per hour.',
author: { id: 'USR-000', name: 'Sofia Rivers', avatar: '/assets/avatar.png' },
createdAt: dayjs().subtract(2, 'hour').subtract(4, 'day').toDate(),
},
{
id: 'MSG-001',
threadId: 'TRD-001',
type: 'text',
content: "I'm interested in your services, can you tell me more about your hourly rate?",
author: { id: 'USR-010', name: 'Alcides Antonio', avatar: '/assets/avatar-10.png' },
createdAt: dayjs().subtract(5, 'hour').subtract(4, 'day').toDate(),
},
] satisfies Message[];
interface LayoutProps {
children: React.ReactNode;
}
export default function Layout({ children }: LayoutProps): React.JSX.Element {
return (
<ChatProvider contacts={contacts} messages={messages} threads={threads}>
<ChatView>{children}</ChatView>
</ChatProvider>
);
}