import { render, screen } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; import { describe, expect, it, vi } from 'vitest'; import type { LeadReadDto } from '@/lib/leads-api'; import { LeadDetailDialog } from '../lead-detail-dialog'; // Mock hooks const mockUpdateMutate = vi.fn(); const mockDeleteMutate = vi.fn(); vi.mock('@/lib/hooks/use-leads', () => ({ useUpdateLeadStatus: () => ({ mutate: mockUpdateMutate, isPending: false, }), useDeleteLead: () => ({ mutate: mockDeleteMutate, isPending: false, }), })); // Mock Dialog components vi.mock('@/components/ui/dialog', () => ({ Dialog: ({ children, open }: { children: React.ReactNode; open: boolean }) => open ?
{children}
: null, DialogContent: ({ children }: { children: React.ReactNode }) =>
{children}
, DialogHeader: ({ children }: { children: React.ReactNode }) =>
{children}
, DialogTitle: ({ children }: { children: React.ReactNode }) =>

{children}

, DialogDescription: ({ children }: { children: React.ReactNode }) =>

{children}

, DialogFooter: ({ children }: { children: React.ReactNode }) =>
{children}
, })); const mockLead: LeadReadDto = { id: 'lead-1', agentId: 'agent-1', name: 'Trần Thị B', phone: '0987654321', email: 'tran@example.com', source: 'website', score: 75, notes: { text: 'Quan tâm căn hộ Quận 7' }, status: 'NEW', createdAt: '2026-01-15T10:00:00Z', updatedAt: '2026-01-16T14:00:00Z', }; describe('LeadDetailDialog', () => { beforeEach(() => { mockUpdateMutate.mockClear(); mockDeleteMutate.mockClear(); }); it('returns null when lead is null', () => { const { container } = render( , ); expect(container.firstChild).toBeNull(); }); it('renders dialog title', () => { render(); expect(screen.getByText('Chi tiết lead')).toBeInTheDocument(); }); it('renders lead name', () => { render(); // Name appears in both the description and the contact card expect(screen.getAllByText('Trần Thị B').length).toBeGreaterThanOrEqual(1); }); it('renders phone number', () => { render(); expect(screen.getByText(/0987654321/)).toBeInTheDocument(); }); it('renders email when present', () => { render(); expect(screen.getByText(/tran@example.com/)).toBeInTheDocument(); }); it('renders score', () => { render(); expect(screen.getByText('75/100')).toBeInTheDocument(); }); it('renders notes', () => { render(); expect(screen.getByText('Quan tâm căn hộ Quận 7')).toBeInTheDocument(); }); it('renders quick contact links', () => { render(); // Emoji prefixed text const content = document.body.textContent; expect(content).toContain('Gọi điện'); expect(content).toContain('Zalo'); }); it('renders Zalo link with correct phone format', () => { render(); const links = document.querySelectorAll('a[href*="zalo.me"]'); expect(links.length).toBeGreaterThan(0); expect(links[0]).toHaveAttribute('href', 'https://zalo.me/84987654321'); }); it('renders delete button', () => { render(); expect(screen.getByText('Xóa lead')).toBeInTheDocument(); }); it('shows confirmation on first delete click', async () => { const user = userEvent.setup(); render(); await user.click(screen.getByText('Xóa lead')); expect(screen.getByText('Xác nhận xóa?')).toBeInTheDocument(); }); it('renders close button', () => { render(); expect(screen.getByText('Đóng')).toBeInTheDocument(); }); it('renders status change select', () => { render(); expect(screen.getByText('Chuyển trạng thái')).toBeInTheDocument(); }); it('renders timeline section', () => { render(); expect(screen.getByText('Lịch sử')).toBeInTheDocument(); }); it('hides email contact when email is null', () => { const leadNoEmail = { ...mockLead, email: null }; render(); const content = document.body.textContent; expect(content).not.toContain('tran@example.com'); }); });