Auto-deploy: 2026-01-13 13:03:43 | 1 arquivo(s) alterado(s)
This commit is contained in:
parent
9656a9995a
commit
cadd2c947f
|
|
@ -1,104 +1,136 @@
|
|||
import React, { useState } from 'react';
|
||||
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
|
||||
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs';
|
||||
import { Badge } from '@/components/ui/badge';
|
||||
import { AlertCircle, CheckCircle2, ListFilter, Settings, Box, Terminal } from 'lucide-react';
|
||||
import { Card, CardContent } from '@/components/ui/card';
|
||||
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 = () => {
|
||||
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 (
|
||||
<div className="workspace-theme space-y-6 p-6">
|
||||
<header className="flex justify-between items-center">
|
||||
<div>
|
||||
<h1 className="text-2xl font-black text-slate-800 dark:text-stone-100 uppercase tracking-tighter">Conciliação</h1>
|
||||
<p className="text-slate-500 text-sm">Concilie transações bancárias e organize seu plano de contas</p>
|
||||
<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">Cruzamento de extratos bancários com registros sistêmicos</p>
|
||||
</div>
|
||||
<div className="flex gap-2">
|
||||
<Badge variant="outline" className="bg-amber-50 text-amber-600 border-amber-200 gap-1 px-3 py-1">
|
||||
<AlertCircle size={14} />
|
||||
17 Pendentes
|
||||
</Badge>
|
||||
<div className="flex gap-3">
|
||||
<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">
|
||||
<ArrowRightLeft size={18} />
|
||||
CONCILIAR AGORA
|
||||
</button>
|
||||
</div>
|
||||
</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}>
|
||||
<div className="px-6 pt-2 border-b border-slate-100 dark:border-[#2a2a2a] bg-slate-50/30 dark:bg-[#1e1e1e]">
|
||||
<TabsList className="bg-transparent gap-8 h-14">
|
||||
<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-12">
|
||||
<TabsTrigger
|
||||
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" />
|
||||
Pendências
|
||||
<div className="flex items-center gap-2">
|
||||
<AlertCircle size={16} />
|
||||
Pendências
|
||||
</div>
|
||||
</TabsTrigger>
|
||||
<TabsTrigger
|
||||
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" />
|
||||
Cruzamento
|
||||
<div className="flex items-center gap-2">
|
||||
<ArrowRightLeft size={16} />
|
||||
Cruzamento
|
||||
</div>
|
||||
</TabsTrigger>
|
||||
<TabsTrigger
|
||||
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" />
|
||||
Configurações
|
||||
<div className="flex items-center gap-2">
|
||||
<Settings2 size={16} />
|
||||
Configurações
|
||||
</div>
|
||||
</TabsTrigger>
|
||||
</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>
|
||||
|
||||
<CardContent className="p-0">
|
||||
<TabsContent value="pendencias" className="m-0 h-[600px] flex flex-col items-center justify-center text-slate-400">
|
||||
<AlertCircle size={48} className="mb-4 opacity-20" />
|
||||
<p className="text-sm font-medium">Apresentando transações não categorizadas...</p>
|
||||
<span className="text-[10px] uppercase mt-2 opacity-50 tracking-widest italic">Integração com ExcelTable pendente</span>
|
||||
</TabsContent>
|
||||
|
||||
<TabsContent value="cruzamento" className="m-0 h-[600px]">
|
||||
<div className="grid grid-cols-1 md:grid-cols-3 gap-6 p-6 h-full">
|
||||
{/* Coluna de Categorias */}
|
||||
<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">
|
||||
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>
|
||||
<TabsContent value="pendencias" className="m-0 min-h-[400px]">
|
||||
<div className="p-4">
|
||||
<ExcelTable
|
||||
columns={[
|
||||
{ key: 'id', label: 'ID', width: '80px' },
|
||||
{ key: 'data', label: 'Data', width: '120px' },
|
||||
{ key: 'descricao', label: 'Descrição da Transação', width: '350px' },
|
||||
{ key: 'valor', label: 'Valor', width: '150px', type: 'currency' },
|
||||
{ key: 'tipo', label: 'Tipo', width: '120px' },
|
||||
]}
|
||||
data={MOCK_PENDING_TRANSACTIONS}
|
||||
/>
|
||||
</div>
|
||||
</TabsContent>
|
||||
|
||||
<TabsContent value="config" className="m-0 p-8">
|
||||
<div className="grid grid-cols-1 md:grid-cols-3 gap-6">
|
||||
{/* Cards de CRUD */}
|
||||
{[
|
||||
{ title: 'Categorias', icon: <ListFilter size={24} />, count: 12 },
|
||||
{ title: 'Regras', icon: <Terminal size={24} />, count: 45 },
|
||||
{ title: 'Caixinhas', icon: <Box size={24} />, count: 5 },
|
||||
].map((item, i) => (
|
||||
<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]">
|
||||
<CardContent className="pt-6 flex flex-col items-center text-center">
|
||||
<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">
|
||||
{item.icon}
|
||||
</div>
|
||||
<h4 className="font-bold text-sm text-slate-700 dark:text-stone-200">{item.title}</h4>
|
||||
<p className="text-[10px] text-slate-400 uppercase mt-1 tracking-widest">{item.count} Itens Cadastrados</p>
|
||||
</CardContent>
|
||||
</Card>
|
||||
<TabsContent value="cruzamento" className="m-0 min-h-[400px]">
|
||||
<div className="p-12 text-center">
|
||||
<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)]" />
|
||||
</div>
|
||||
<h3 className="text-lg font-black uppercase tracking-tight text-slate-700 dark:text-stone-200">Cruzamento Digital</h3>
|
||||
<p className="text-slate-400 text-sm max-w-md mx-auto mt-2">
|
||||
Algoritmo de IA para cruzamento automático de extratos bancários com contas a pagar e receber.
|
||||
</p>
|
||||
</div>
|
||||
</TabsContent>
|
||||
|
||||
<TabsContent value="config" className="m-0 min-h-[400px]">
|
||||
<div className="grid grid-cols-1 md:grid-cols-3 gap-4 p-6">
|
||||
{['Categorias', 'Regras de Importação', 'Mapeamento de Caixas'].map(item => (
|
||||
<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">
|
||||
<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>
|
||||
</TabsContent>
|
||||
|
|
|
|||
Loading…
Reference in New Issue