// Client Portal Module function ClientPortal() { const [activeTab, setActiveTab] = React.useState('status'); const [message, setMessage] = React.useState(''); const [messages, setMessages] = React.useState([ { from: 'team', name: 'Ana Lima', text: 'Olá! Seu evento está confirmado para o dia 28. A equipe está montando tudo com carinho.', time: '10:23', date: 'Hoje' }, { from: 'client', name: 'Marcelo Andrade', text: 'Ótimo! Podemos confirmar o número de convidados VIP? Serão 45 pessoas.', time: '10:47', date: 'Hoje' }, { from: 'team', name: 'Ana Lima', text: 'Confirmado! Já estamos ajustando os assentos da área VIP para 45 pessoas. Qualquer dúvida estamos à disposição.', time: '11:02', date: 'Hoje' }, ]); const [toast, setToast] = React.useState(null); const showToast = (msg) => { setToast({ msg }); setTimeout(() => setToast(null), 3000); }; const event = { name: 'Congresso Tech 2026', date: '28–29 de Abril de 2026', location: 'Centro de Convenções Anhembi, São Paulo', status: 'Confirmado', progress: 72, }; const timeline = [ { label: 'Proposta enviada', date: '10 Abr', done: true }, { label: 'Orçamento aprovado', date: '14 Abr', done: true }, { label: 'Briefing finalizado', date: '18 Abr', done: true }, { label: 'Montagem e preparação', date: '26–27 Abr', done: false, active: true }, { label: 'Dia do evento', date: '28–29 Abr', done: false }, { label: 'Relatório pós-evento', date: '05 Mai', done: false }, ]; const budgetItems = [ { desc: 'Locação de espaço', value: 45000 }, { desc: 'Equipamento AV', value: 28000 }, { desc: 'Decoração', value: 22000 }, { desc: 'Buffet (200 pessoas)', value: 36000 }, { desc: 'Equipe de apoio', value: 9000 }, { desc: 'Coordenação geral', value: 5000 }, ]; const total = budgetItems.reduce((s, i) => s + i.value, 0); const sendMessage = () => { if (!message.trim()) return; setMessages(m => [...m, { from: 'client', name: 'Você', text: message, time: new Date().toLocaleTimeString('pt-BR', { hour: '2-digit', minute: '2-digit' }), date: 'Hoje' }]); setMessage(''); setTimeout(() => { setMessages(m => [...m, { from: 'team', name: 'Ana Lima', text: 'Recebemos sua mensagem! Em breve retornaremos.', time: new Date().toLocaleTimeString('pt-BR', { hour: '2-digit', minute: '2-digit' }), date: 'Hoje' }]); }, 1500); }; const tabs = [{ id: 'status', label: 'Status', icon: 'zap' }, { id: 'budget', label: 'Orçamento', icon: 'budget' }, { id: 'schedule', label: 'Cronograma', icon: 'calendar' }, { id: 'messages', label: 'Mensagens', icon: 'message' }]; return (
Visão do cliente — TechCorp Brasil
| {h} | ))}|
|---|---|
| {item.desc} | R$ {item.value.toLocaleString('pt-BR')} |