Auto-deploy: 2026-01-13 13:03:43 | 1 arquivo(s) alterado(s)

This commit is contained in:
daivid.alves 2026-01-13 13:03:43 -03:00
parent 9656a9995a
commit cadd2c947f
1 changed files with 96 additions and 64 deletions

View File

@ -1,104 +1,136 @@
import React, { useState } from 'react'; import React, { useState } from 'react';
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs'; import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs';
import { Badge } from '@/components/ui/badge'; import { Card, CardContent } from '@/components/ui/card';
import { AlertCircle, CheckCircle2, ListFilter, Settings, Box, Terminal } from 'lucide-react'; import {
ArrowRightLeft,
Settings2,
ShieldCheck,
AlertCircle,
Plus,
ArrowUpCircle,
ArrowDownCircle,
Search
} from 'lucide-react';
import { DashboardKPICard } from '@/components/shared/DashboardKPICard/DashboardKPICard';
import ExcelTable from '@/features/prafrot/components/ExcelTable';
import { MOCK_PENDING_TRANSACTIONS } from '../mockData';
export const ReconciliationView = () => { export const ReconciliationView = () => {
const [activeTab, setActiveTab] = useState('pendencias'); const [activeTab, setActiveTab] = useState('pendencias');
const kpis = [
{ label: 'Saldo Bancário', value: 'R$ 152.430,12', color: 'green', icon: ArrowUpCircle },
{ label: 'A Conciliar hoje', value: 'R$ 12.850,00', color: 'orange', icon: AlertCircle },
{ label: 'Pendências Críticas', value: '03', color: 'red', icon: ShieldCheck },
{ label: 'Regras Ativas', value: '24', color: 'blue', icon: Settings2 },
];
return ( return (
<div className="workspace-theme space-y-6 p-6"> <div className="workspace-theme space-y-6 p-6">
<header className="flex justify-between items-center"> <header className="flex justify-between items-center">
<div> <div>
<h1 className="text-2xl font-black text-slate-800 dark:text-stone-100 uppercase tracking-tighter">Conciliação</h1> <h1 className="text-2xl font-black text-slate-800 dark:text-stone-100 uppercase tracking-tighter">Financeiro / Conciliação</h1>
<p className="text-slate-500 text-sm">Concilie transações bancárias e organize seu plano de contas</p> <p className="text-slate-500 text-sm">Cruzamento de extratos bancários com registros sistêmicos</p>
</div> </div>
<div className="flex gap-2"> <div className="flex gap-3">
<Badge variant="outline" className="bg-amber-50 text-amber-600 border-amber-200 gap-1 px-3 py-1"> <button className="flex items-center gap-2 bg-[var(--workspace-sec-3-light)] text-white px-4 py-2 rounded-xl font-bold text-sm shadow-lg hover:brightness-110 transition-all hover:scale-105 active:scale-95">
<AlertCircle size={14} /> <ArrowRightLeft size={18} />
17 Pendentes CONCILIAR AGORA
</Badge> </button>
</div> </div>
</header> </header>
<Card className="border-none shadow-sm bg-white dark:bg-[#1b1b1b] rounded-xl overflow-hidden"> {/* KPI Section */}
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-4">
{kpis.map((kpi, i) => (
<DashboardKPICard
key={i}
label={kpi.label}
value={kpi.value}
color={kpi.color}
icon={kpi.icon}
/>
))}
</div>
<Card className="border-none shadow-sm bg-white dark:bg-[#1b1b1b] rounded-2xl overflow-hidden border border-slate-100 dark:border-white/5">
<Tabs defaultValue="pendencias" className="w-full" onValueChange={setActiveTab}> <Tabs defaultValue="pendencias" className="w-full" onValueChange={setActiveTab}>
<div className="px-6 pt-2 border-b border-slate-100 dark:border-[#2a2a2a] bg-slate-50/30 dark:bg-[#1e1e1e]"> <div className="px-6 pt-4 border-b border-slate-100 dark:border-[#2a2a2a] flex justify-between items-center bg-slate-50/50 dark:bg-[#1e1e1e]/50">
<TabsList className="bg-transparent gap-8 h-14"> <TabsList className="bg-transparent gap-8 h-12">
<TabsTrigger <TabsTrigger
value="pendencias" value="pendencias"
className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-2-light)] rounded-none px-0 font-bold text-xs uppercase tracking-widest text-slate-400 data-[state=active]:text-[var(--workspace-sec-2-light)]" className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-3-light)] rounded-none px-0 font-bold text-xs uppercase tracking-[0.2em] text-slate-400 data-[state=active]:text-[var(--workspace-sec-3-light)] transition-all"
> >
<Terminal size={16} className="mr-2" /> <div className="flex items-center gap-2">
Pendências <AlertCircle size={16} />
Pendências
</div>
</TabsTrigger> </TabsTrigger>
<TabsTrigger <TabsTrigger
value="cruzamento" value="cruzamento"
className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-2-light)] rounded-none px-0 font-bold text-xs uppercase tracking-widest text-slate-400 data-[state=active]:text-[var(--workspace-sec-2-light)]" className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-3-light)] rounded-none px-0 font-bold text-xs uppercase tracking-[0.2em] text-slate-400 data-[state=active]:text-[var(--workspace-sec-3-light)] transition-all"
> >
<CheckCircle2 size={16} className="mr-2" /> <div className="flex items-center gap-2">
Cruzamento <ArrowRightLeft size={16} />
Cruzamento
</div>
</TabsTrigger> </TabsTrigger>
<TabsTrigger <TabsTrigger
value="config" value="config"
className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-2-light)] rounded-none px-0 font-bold text-xs uppercase tracking-widest text-slate-400 data-[state=active]:text-[var(--workspace-sec-2-light)]" className="data-[state=active]:bg-transparent data-[state=active]:shadow-none data-[state=active]:border-b-2 data-[state=active]:border-[var(--workspace-sec-3-light)] rounded-none px-0 font-bold text-xs uppercase tracking-[0.2em] text-slate-400 data-[state=active]:text-[var(--workspace-sec-3-light)] transition-all"
> >
<Settings size={16} className="mr-2" /> <div className="flex items-center gap-2">
Configurações <Settings2 size={16} />
Configurações
</div>
</TabsTrigger> </TabsTrigger>
</TabsList> </TabsList>
<div className="flex items-center gap-2 bg-white dark:bg-[#252525] px-3 py-1.5 rounded-xl border border-slate-200 dark:border-white/10 shadow-sm">
<Search size={14} className="text-slate-400" />
<input
type="text"
placeholder="Buscar transação..."
className="bg-transparent border-none text-xs focus:ring-0 w-48 text-slate-600 dark:text-stone-300"
/>
</div>
</div> </div>
<CardContent className="p-0"> <CardContent className="p-0">
<TabsContent value="pendencias" className="m-0 h-[600px] flex flex-col items-center justify-center text-slate-400"> <TabsContent value="pendencias" className="m-0 min-h-[400px]">
<AlertCircle size={48} className="mb-4 opacity-20" /> <div className="p-4">
<p className="text-sm font-medium">Apresentando transações não categorizadas...</p> <ExcelTable
<span className="text-[10px] uppercase mt-2 opacity-50 tracking-widest italic">Integração com ExcelTable pendente</span> columns={[
</TabsContent> { key: 'id', label: 'ID', width: '80px' },
{ key: 'data', label: 'Data', width: '120px' },
<TabsContent value="cruzamento" className="m-0 h-[600px]"> { key: 'descricao', label: 'Descrição da Transação', width: '350px' },
<div className="grid grid-cols-1 md:grid-cols-3 gap-6 p-6 h-full"> { key: 'valor', label: 'Valor', width: '150px', type: 'currency' },
{/* Coluna de Categorias */} { key: 'tipo', label: 'Tipo', width: '120px' },
<div className="bg-slate-50 dark:bg-[#202020] rounded-xl p-4 border border-slate-100 dark:border-[#2a2a2a]"> ]}
<h3 className="text-[10px] font-black uppercase text-slate-400 mb-4 tracking-widest flex items-center justify-between"> data={MOCK_PENDING_TRANSACTIONS}
Categorias />
<ListFilter size={14} />
</h3>
<div className="space-y-2">
{['Infraestrutura', 'Marketing', 'RH', 'Softwares'].map((cat, i) => (
<div key={i} className="bg-white dark:bg-[#252525] p-3 rounded-lg shadow-sm border border-slate-100 dark:border-[#333] cursor-pointer hover:border-[var(--workspace-sec-2-light)] transition-all flex items-center justify-between">
<span className="text-xs font-bold text-slate-600 dark:text-stone-300">{cat}</span>
<Badge variant="secondary" className="text-[10px]">R$ 1.500</Badge>
</div>
))}
</div>
</div>
{/* Coluna de Regras / Detalhamento */}
<div className="md:col-span-2 bg-white dark:bg-[#1b1b1b] rounded-xl border border-dashed border-slate-200 dark:border-[#333] flex flex-col items-center justify-center text-slate-300">
<p className="text-xs font-medium uppercase tracking-tighter">Selecione uma categoria para ver as regras e transações</p>
</div>
</div> </div>
</TabsContent> </TabsContent>
<TabsContent value="config" className="m-0 p-8"> <TabsContent value="cruzamento" className="m-0 min-h-[400px]">
<div className="grid grid-cols-1 md:grid-cols-3 gap-6"> <div className="p-12 text-center">
{/* Cards de CRUD */} <div className="w-16 h-16 bg-slate-50 dark:bg-white/5 rounded-full flex items-center justify-center mx-auto mb-4 border border-slate-100 dark:border-white/5">
{[ <ArrowRightLeft size={32} className="text-[var(--workspace-sec-3-light)]" />
{ title: 'Categorias', icon: <ListFilter size={24} />, count: 12 }, </div>
{ title: 'Regras', icon: <Terminal size={24} />, count: 45 }, <h3 className="text-lg font-black uppercase tracking-tight text-slate-700 dark:text-stone-200">Cruzamento Digital</h3>
{ title: 'Caixinhas', icon: <Box size={24} />, count: 5 }, <p className="text-slate-400 text-sm max-w-md mx-auto mt-2">
].map((item, i) => ( Algoritmo de IA para cruzamento automático de extratos bancários com contas a pagar e receber.
<Card key={i} className="hover:border-[var(--workspace-sec-2-light)] cursor-pointer transition-all border-slate-100 dark:border-[#2a2a2a] bg-slate-50/50 dark:bg-[#202020]"> </p>
<CardContent className="pt-6 flex flex-col items-center text-center"> </div>
<div className="w-12 h-12 rounded-full bg-white dark:bg-[#252525] flex items-center justify-center text-[var(--workspace-sec-2-light)] shadow-sm mb-4"> </TabsContent>
{item.icon}
</div> <TabsContent value="config" className="m-0 min-h-[400px]">
<h4 className="font-bold text-sm text-slate-700 dark:text-stone-200">{item.title}</h4> <div className="grid grid-cols-1 md:grid-cols-3 gap-4 p-6">
<p className="text-[10px] text-slate-400 uppercase mt-1 tracking-widest">{item.count} Itens Cadastrados</p> {['Categorias', 'Regras de Importação', 'Mapeamento de Caixas'].map(item => (
</CardContent> <Card key={item} className="p-6 bg-slate-50 dark:bg-white/5 border-none hover:bg-white dark:hover:bg-white/10 transition-all cursor-pointer group rounded-2xl border border-transparent hover:border-slate-200 dark:hover:border-white/10">
</Card> <h4 className="font-bold text-slate-700 dark:text-stone-200 mb-2">{item}</h4>
<p className="text-[10px] text-slate-400 uppercase tracking-widest">Gerenciar Parâmetros</p>
</Card>
))} ))}
</div> </div>
</TabsContent> </TabsContent>