feat(TAto): Implementa a listagem de atos para realizar o pedido de certidão
This commit is contained in:
parent
4561194b6b
commit
b5ea5a75a8
17 changed files with 753 additions and 52 deletions
|
|
@ -57,10 +57,6 @@ const data = {
|
||||||
title: 'Pedidos',
|
title: 'Pedidos',
|
||||||
url: '/servicos/pedidos/',
|
url: '/servicos/pedidos/',
|
||||||
},
|
},
|
||||||
{
|
|
||||||
title: 'Certidões',
|
|
||||||
url: '/servicos/certidoes/',
|
|
||||||
},
|
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -3,13 +3,13 @@ import { ArrowUpDownIcon } from 'lucide-react';
|
||||||
|
|
||||||
import { Button } from '@/components/ui/button';
|
import { Button } from '@/components/ui/button';
|
||||||
import { Checkbox } from '@/components/ui/checkbox';
|
import { Checkbox } from '@/components/ui/checkbox';
|
||||||
|
import TPessoaInterface from '@/packages/administrativo/interfaces/TPessoa/TPessoaInterface';
|
||||||
import { FormatCPF } from '@/shared/actions/CPF/FormatCPF';
|
import { FormatCPF } from '@/shared/actions/CPF/FormatCPF';
|
||||||
import { FormatDateTime } from '@/shared/actions/dateTime/FormatDateTime';
|
import { FormatDateTime } from '@/shared/actions/dateTime/FormatDateTime';
|
||||||
import { FormatPhone } from '@/shared/actions/phone/FormatPhone';
|
import { FormatPhone } from '@/shared/actions/phone/FormatPhone';
|
||||||
import GetNameInitials from '@/shared/actions/text/GetNameInitials';
|
import GetNameInitials from '@/shared/actions/text/GetNameInitials';
|
||||||
import empty from '@/shared/actions/validations/empty';
|
import empty from '@/shared/actions/validations/empty';
|
||||||
|
|
||||||
import TPessoaInterface from '@/packages/administrativo/interfaces/TPessoa/TPessoaInterface';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Função para criar a definição das colunas da tabela
|
* Função para criar a definição das colunas da tabela
|
||||||
|
|
|
||||||
|
|
@ -37,47 +37,92 @@ function TPessoaTableFormSubview({
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<Item variant="outline">
|
{data.pessoa && (
|
||||||
<ItemMedia>
|
<Item variant="outline">
|
||||||
<Avatar className="size-10">
|
<ItemMedia>
|
||||||
<AvatarImage src={``} />
|
<Avatar className="size-10">
|
||||||
<AvatarFallback>{GetNameInitials(data.pessoa?.nome)}</AvatarFallback>
|
<AvatarImage src={``} />
|
||||||
</Avatar>
|
<AvatarFallback>{GetNameInitials(data.pessoa?.nome)}</AvatarFallback>
|
||||||
</ItemMedia>
|
</Avatar>
|
||||||
<ItemContent>
|
</ItemMedia>
|
||||||
<ItemTitle>
|
<ItemContent>
|
||||||
{data.pessoa?.cpf_cnpj} - {data.pessoa?.nome}
|
<ItemTitle>
|
||||||
</ItemTitle>
|
{data.pessoa?.cpf_cnpj} - {data.pessoa?.nome}
|
||||||
<ItemDescription>{data.pessoa?.email || 'Email não informado'}</ItemDescription>
|
</ItemTitle>
|
||||||
{params
|
<ItemDescription>{data.pessoa?.email || 'Email não informado'}</ItemDescription>
|
||||||
.filter((param) => Number(param.valor) === data?.servico?.servico_tipo_id)
|
{params
|
||||||
.map((param) => (
|
.filter((param) => Number(param.valor) === data?.servico?.servico_tipo_id)
|
||||||
<TPessoaCartaoForm form={form} index={item_index} key={param.config_id} />
|
.map((param) => (
|
||||||
))}
|
<TPessoaCartaoForm form={form} index={item_index} key={param.config_id} />
|
||||||
</ItemContent>
|
))}
|
||||||
<ItemActions>
|
</ItemContent>
|
||||||
{data?.servico?.requer_biometria === 'S' && (
|
<ItemActions>
|
||||||
<BiometriaButton
|
{data?.servico?.requer_biometria === 'S' && (
|
||||||
status={statusBiometria}
|
<BiometriaButton
|
||||||
onCaptureSuccess={handleCaptureSuccess}
|
status={statusBiometria}
|
||||||
/>
|
onCaptureSuccess={handleCaptureSuccess}
|
||||||
)}
|
/>
|
||||||
{data?.servico?.requer_biometria && (
|
)}
|
||||||
<Button
|
{data?.servico?.requer_biometria && (
|
||||||
type="button"
|
<Button
|
||||||
size="icon-lg"
|
type="button"
|
||||||
variant="outline"
|
size="icon-lg"
|
||||||
className="cursor-pointer rounded-full"
|
variant="outline"
|
||||||
aria-label="Capturar imagem"
|
className="cursor-pointer rounded-full"
|
||||||
onClick={() => {
|
aria-label="Capturar imagem"
|
||||||
setIsWebCamOpenDialog(true);
|
onClick={() => {
|
||||||
}}
|
setIsWebCamOpenDialog(true);
|
||||||
>
|
}}
|
||||||
<WebcamIcon />
|
>
|
||||||
</Button>
|
<WebcamIcon />
|
||||||
)}
|
</Button>
|
||||||
</ItemActions>
|
)}
|
||||||
</Item>
|
</ItemActions>
|
||||||
|
</Item>
|
||||||
|
)}
|
||||||
|
{data.servico.tipo_item == 'C' && (
|
||||||
|
<Item variant="outline">
|
||||||
|
<ItemMedia>
|
||||||
|
<Avatar className="size-10">
|
||||||
|
<AvatarImage src={``} />
|
||||||
|
<AvatarFallback>{GetNameInitials(data.pessoa?.nome)}</AvatarFallback>
|
||||||
|
</Avatar>
|
||||||
|
</ItemMedia>
|
||||||
|
<ItemContent>
|
||||||
|
<ItemTitle>
|
||||||
|
{data.pessoa?.cpf_cnpj} - {data.pessoa?.nome}
|
||||||
|
</ItemTitle>
|
||||||
|
<ItemDescription>{data.pessoa?.email || 'Email não informado'}</ItemDescription>
|
||||||
|
{params
|
||||||
|
.filter((param) => Number(param.valor) === data?.servico?.servico_tipo_id)
|
||||||
|
.map((param) => (
|
||||||
|
<TPessoaCartaoForm form={form} index={item_index} key={param.config_id} />
|
||||||
|
))}
|
||||||
|
</ItemContent>
|
||||||
|
<ItemActions>
|
||||||
|
{data?.servico?.requer_biometria === 'S' && (
|
||||||
|
<BiometriaButton
|
||||||
|
status={statusBiometria}
|
||||||
|
onCaptureSuccess={handleCaptureSuccess}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
|
{data?.servico?.requer_biometria && (
|
||||||
|
<Button
|
||||||
|
type="button"
|
||||||
|
size="icon-lg"
|
||||||
|
variant="outline"
|
||||||
|
className="cursor-pointer rounded-full"
|
||||||
|
aria-label="Capturar imagem"
|
||||||
|
onClick={() => {
|
||||||
|
setIsWebCamOpenDialog(true);
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<WebcamIcon />
|
||||||
|
</Button>
|
||||||
|
)}
|
||||||
|
</ItemActions>
|
||||||
|
</Item>
|
||||||
|
)}
|
||||||
{isWebCamOpenDialog && (
|
{isWebCamOpenDialog && (
|
||||||
<WebCamDialog
|
<WebCamDialog
|
||||||
isOpen={isWebCamOpenDialog}
|
isOpen={isWebCamOpenDialog}
|
||||||
|
|
|
||||||
|
|
@ -25,6 +25,12 @@ export default function TServicoPedidoItemLocalPrepare(data, response) {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (data.servico_tipo.tipo_item === 'C') {
|
||||||
|
item.subview = {
|
||||||
|
servico: data.servico_tipo,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
return item
|
return item
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -0,0 +1,106 @@
|
||||||
|
import { ColumnDef } from '@tanstack/react-table';
|
||||||
|
import { ArrowUpDownIcon } from 'lucide-react';
|
||||||
|
|
||||||
|
import { Button } from '@/components/ui/button';
|
||||||
|
import { Checkbox } from '@/components/ui/checkbox';
|
||||||
|
import TPessoaInterface from '@/packages/administrativo/interfaces/TPessoa/TPessoaInterface';
|
||||||
|
import { FormatDateTime } from '@/shared/actions/dateTime/FormatDateTime';
|
||||||
|
|
||||||
|
export function TAtoTableFormColumnsDialog(
|
||||||
|
setSelectedTPessoa: React.Dispatch<React.SetStateAction<any | null>>,
|
||||||
|
): ColumnDef<TPessoaInterface>[] {
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
id: 'select',
|
||||||
|
header: '',
|
||||||
|
cell: ({ row, table }) => (
|
||||||
|
<Checkbox
|
||||||
|
checked={row.getIsSelected()}
|
||||||
|
onCheckedChange={(value) => {
|
||||||
|
// Limpa todas as seleções antes de selecionar uma nova
|
||||||
|
table.resetRowSelection();
|
||||||
|
row.toggleSelected(!!value);
|
||||||
|
setSelectedTPessoa(value ? row.original : null);
|
||||||
|
}}
|
||||||
|
aria-label="Select row"
|
||||||
|
/>
|
||||||
|
),
|
||||||
|
enableSorting: false,
|
||||||
|
enableHiding: false,
|
||||||
|
},
|
||||||
|
// ID
|
||||||
|
{
|
||||||
|
accessorKey: 'ato_id',
|
||||||
|
header: ({ column }) => (
|
||||||
|
<Button
|
||||||
|
variant="ghost"
|
||||||
|
onClick={() => column.toggleSorting(column.getIsSorted() === 'asc')}
|
||||||
|
>
|
||||||
|
# <ArrowUpDownIcon className="ml-1 h-4 w-4" />
|
||||||
|
</Button>
|
||||||
|
),
|
||||||
|
cell: ({ row }) => Number(row.getValue('ato_id')),
|
||||||
|
enableSorting: false,
|
||||||
|
},
|
||||||
|
|
||||||
|
// CPF
|
||||||
|
{
|
||||||
|
accessorKey: 'protocolo',
|
||||||
|
header: ({ column }) => (
|
||||||
|
<Button
|
||||||
|
variant="ghost"
|
||||||
|
onClick={() => column.toggleSorting(column.getIsSorted() === 'asc')}
|
||||||
|
>
|
||||||
|
Protocolo <ArrowUpDownIcon className="ml-1 h-4 w-4 cursor-pointer" />
|
||||||
|
</Button>
|
||||||
|
),
|
||||||
|
cell: ({ row }) => Number(row.getValue('protocolo')),
|
||||||
|
enableSorting: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
// Data LAvratura
|
||||||
|
{
|
||||||
|
accessorKey: 'data_lavratura',
|
||||||
|
header: ({ column }) => (
|
||||||
|
<Button
|
||||||
|
variant="ghost"
|
||||||
|
onClick={() => column.toggleSorting(column.getIsSorted() === 'asc')}
|
||||||
|
>
|
||||||
|
Lavratura <ArrowUpDownIcon className="ml-1 h-4 w-4 cursor-pointer" />
|
||||||
|
</Button>
|
||||||
|
),
|
||||||
|
cell: ({ row }) => FormatDateTime(row.getValue('data_lavratura')),
|
||||||
|
enableSorting: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
// Folha Inicial
|
||||||
|
{
|
||||||
|
accessorKey: 'folha_inicial',
|
||||||
|
header: ({ column }) => (
|
||||||
|
<Button
|
||||||
|
variant="ghost"
|
||||||
|
onClick={() => column.toggleSorting(column.getIsSorted() === 'asc')}
|
||||||
|
>
|
||||||
|
Fl. Inicial <ArrowUpDownIcon className="ml-1 h-4 w-4 cursor-pointer" />
|
||||||
|
</Button>
|
||||||
|
),
|
||||||
|
cell: ({ row }) => Number(row.getValue('folha_inicial')),
|
||||||
|
enableSorting: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
// Folha Final
|
||||||
|
{
|
||||||
|
accessorKey: 'folha_final',
|
||||||
|
header: ({ column }) => (
|
||||||
|
<Button
|
||||||
|
variant="ghost"
|
||||||
|
onClick={() => column.toggleSorting(column.getIsSorted() === 'asc')}
|
||||||
|
>
|
||||||
|
Fl. Inicial <ArrowUpDownIcon className="ml-1 h-4 w-4 cursor-pointer" />
|
||||||
|
</Button>
|
||||||
|
),
|
||||||
|
cell: ({ row }) => Number(row.getValue('folha_final')),
|
||||||
|
enableSorting: true,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,99 @@
|
||||||
|
'use client';
|
||||||
|
|
||||||
|
import { useEffect, useState } from 'react';
|
||||||
|
|
||||||
|
import { Button } from '@/components/ui/button';
|
||||||
|
import {
|
||||||
|
Dialog,
|
||||||
|
DialogClose,
|
||||||
|
DialogContent,
|
||||||
|
DialogDescription,
|
||||||
|
DialogFooter,
|
||||||
|
DialogHeader,
|
||||||
|
DialogTitle,
|
||||||
|
} from '@/components/ui/dialog';
|
||||||
|
import TPessoaInterface from '@/packages/administrativo/interfaces/TPessoa/TPessoaInterface';
|
||||||
|
import { useTAtoIndexHook } from '@/packages/servicos/hooks/TAto/useTAtoIndexHook';
|
||||||
|
import TAtoTableFormInterface from '@/packages/servicos/interfaces/TAto/TAtoTableFormInterface';
|
||||||
|
import { DataTable } from '@/shared/components/dataTable/DataTable';
|
||||||
|
import LoadingButton from '@/shared/components/loadingButton/LoadingButton';
|
||||||
|
|
||||||
|
import { TAtoTableFormColumnsDialog } from './TAtoTableFormColumnsDialog';
|
||||||
|
|
||||||
|
|
||||||
|
export default function TAtoTableFormDialog({
|
||||||
|
isOpen,
|
||||||
|
onClose,
|
||||||
|
onSave,
|
||||||
|
buttonIsLoading,
|
||||||
|
}: TAtoTableFormInterface) {
|
||||||
|
|
||||||
|
const { tAto, fetchTAto } = useTAtoIndexHook();
|
||||||
|
const [atos, setAtos] = useState<any>();
|
||||||
|
const [selectedTPessoa, setSelectedTPessoa] = useState<TPessoaInterface | null>(null);
|
||||||
|
|
||||||
|
// Executa o Hook de Acordo com o tipo de pessoa informado
|
||||||
|
const loadData = async () => {
|
||||||
|
await fetchTAto();
|
||||||
|
};
|
||||||
|
|
||||||
|
// Atualiza a variavel de pessoa quando tiver alteração na variavel de pessoas fisicas
|
||||||
|
useEffect(() => {
|
||||||
|
setAtos(tAto);
|
||||||
|
}, [tAto]);
|
||||||
|
|
||||||
|
// Executa o hook correspondente ao tipo de pessoa, sempre que o tipo pessoa mudar
|
||||||
|
useEffect(() => {
|
||||||
|
// Dispara o carregamento de informações
|
||||||
|
loadData();
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
const columns = TAtoTableFormColumnsDialog(setSelectedTPessoa);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Dialog
|
||||||
|
open={isOpen}
|
||||||
|
onOpenChange={(open) => {
|
||||||
|
if (!open) onClose(null, false);
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<DialogContent className="max-h-[70vh] w-full max-w-full overflow-auto p-6 sm:max-w-4xl md:max-w-6xl lg:max-w-6xl">
|
||||||
|
<DialogHeader>
|
||||||
|
<DialogTitle>Atos</DialogTitle>
|
||||||
|
<DialogDescription>Busque o Ato desejado</DialogDescription>
|
||||||
|
</DialogHeader>
|
||||||
|
<div className="max-h-[50vh] overflow-y-auto">
|
||||||
|
<DataTable
|
||||||
|
data={atos}
|
||||||
|
columns={columns}
|
||||||
|
filterColumn="nome_completo"
|
||||||
|
filterPlaceholder="Buscar por nome ou email..."
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
{/* Rodapé do Dialog */}
|
||||||
|
<DialogFooter className="mt-4">
|
||||||
|
<DialogClose asChild>
|
||||||
|
<Button
|
||||||
|
variant="outline"
|
||||||
|
type="button"
|
||||||
|
onClick={() => onClose(null, false)}
|
||||||
|
className="cursor-pointer"
|
||||||
|
>
|
||||||
|
Cancelar
|
||||||
|
</Button>
|
||||||
|
</DialogClose>
|
||||||
|
<LoadingButton
|
||||||
|
text="Selecionar"
|
||||||
|
textLoading="Aguarde..."
|
||||||
|
loading={buttonIsLoading}
|
||||||
|
type="button"
|
||||||
|
onClick={() => {
|
||||||
|
onSave(selectedTPessoa);
|
||||||
|
onClose(null, false);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</DialogFooter>
|
||||||
|
</DialogContent>
|
||||||
|
</Dialog>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,195 @@
|
||||||
|
|
||||||
|
import { useState } from 'react';
|
||||||
|
|
||||||
|
import { FormField, FormItem, FormLabel, FormMessage } from '@/components/ui/form';
|
||||||
|
import { Input } from '@/components/ui/input';
|
||||||
|
import TPessoaCartaoFormInterface from '@/packages/servicos/interfaces/TPessoaCartao/TPessoaCartaoFormInterface';
|
||||||
|
import ConfirmacaoSelect from '@/shared/components/confirmacao/ConfirmacaoSelect';
|
||||||
|
import TiposCertidoesSelect from '@/shared/components/tiposCertidoes/TiposCertidoesSelect';
|
||||||
|
import { TipoCertidaoEnum } from '@/shared/enums/TipoCertidoesEnum';
|
||||||
|
|
||||||
|
export default function TServicoPedidoCertidaoForm({ index, form }: TPessoaCartaoFormInterface) {
|
||||||
|
|
||||||
|
const [tipoCertidao, setTipoCertidao] = useState<TipoCertidaoEnum | null>(null);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div>
|
||||||
|
<div className="grid w-full grid-cols-12 gap-4">
|
||||||
|
{/* Tipo Certidão*/}
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-12">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Tipo de Certidão</FormLabel>
|
||||||
|
<TiposCertidoesSelect
|
||||||
|
field={{
|
||||||
|
...field,
|
||||||
|
onChange: (value: number) => {
|
||||||
|
field.onChange(value);
|
||||||
|
setTipoCertidao(value as TipoCertidaoEnum);
|
||||||
|
},
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
{/* Verifica o tipo de formulário que deve exibir */}
|
||||||
|
{tipoCertidao && (
|
||||||
|
<>
|
||||||
|
{tipoCertidao === 1 && (
|
||||||
|
<>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Protocolo</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Pedido</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Livro</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Folha Inicial</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-12">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Natureza</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Livro</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Fl. Inicial</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Fl. Final</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-3">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Lavratura</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-6">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Páginas</FormLabel>
|
||||||
|
<Input {...field} type="text" />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
<div className="col-span-12 sm:col-span-12 md:col-span-6">
|
||||||
|
<FormField
|
||||||
|
control={form.control}
|
||||||
|
name={`itens.${index}.tipo_certidao`}
|
||||||
|
render={({ field }) => (
|
||||||
|
<FormItem>
|
||||||
|
<FormLabel>Frente e Verso</FormLabel>
|
||||||
|
<ConfirmacaoSelect field={field} />
|
||||||
|
<FormMessage />
|
||||||
|
</FormItem>
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
@ -34,6 +34,8 @@ import {
|
||||||
} from '@/shared/components/step/stepNavigator';
|
} from '@/shared/components/step/stepNavigator';
|
||||||
import TipoPagamentoSelect from '@/shared/components/tipoPagamento/TipoPagamentoSelect';
|
import TipoPagamentoSelect from '@/shared/components/tipoPagamento/TipoPagamentoSelect';
|
||||||
|
|
||||||
|
import TAtoTableFormDialog from '../TAto/TAtoTableFormDialog';
|
||||||
|
|
||||||
export default function TServicoPedidoForm({ servico_pedido_id }: TServicoPedidoFormInterface) {
|
export default function TServicoPedidoForm({ servico_pedido_id }: TServicoPedidoFormInterface) {
|
||||||
|
|
||||||
const tServicoPedidoController = useTServicoPedidoFormControllerHook(servico_pedido_id)
|
const tServicoPedidoController = useTServicoPedidoFormControllerHook(servico_pedido_id)
|
||||||
|
|
@ -437,6 +439,16 @@ export default function TServicoPedidoForm({ servico_pedido_id }: TServicoPedido
|
||||||
buttonIsLoading={tServicoPedidoController.isSaving}
|
buttonIsLoading={tServicoPedidoController.isSaving}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
|
{/* Modal TAto */}
|
||||||
|
{tServicoPedidoController.isAtoFormOpen && (
|
||||||
|
<TAtoTableFormDialog
|
||||||
|
isOpen={tServicoPedidoController.isAtoFormOpen}
|
||||||
|
onClose={tServicoPedidoController.handleCloseAtoForm}
|
||||||
|
onSave={tServicoPedidoController.handleAddItemWithPessoa}
|
||||||
|
buttonIsLoading={tServicoPedidoController.isSaving}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
</Form>
|
</Form>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
||||||
13
src/packages/servicos/data/TAto/TAtoIndexData.ts
Normal file
13
src/packages/servicos/data/TAto/TAtoIndexData.ts
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
import { withClientErrorHandler } from '@/shared/actions/withClientErrorHandler/withClientErrorHandler';
|
||||||
|
import API from '@/shared/services/api/Api';
|
||||||
|
import { Methods } from '@/shared/services/api/enums/ApiMethodEnum';
|
||||||
|
|
||||||
|
async function executeTAtoIndexData() {
|
||||||
|
const api = new API();
|
||||||
|
return await api.send({
|
||||||
|
method: Methods.GET,
|
||||||
|
endpoint: `servicos/atos/t_ato/`,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export const TAtoIndexData = withClientErrorHandler(executeTAtoIndexData);
|
||||||
23
src/packages/servicos/hooks/TAto/useTAtoIndexHook.ts
Normal file
23
src/packages/servicos/hooks/TAto/useTAtoIndexHook.ts
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
import { useState } from 'react';
|
||||||
|
|
||||||
|
import TAtoInterface from '@/packages/servicos/interfaces/TAto/TAtoInterface';
|
||||||
|
import { TAtoIndexService } from '@/packages/servicos/services/TAto/TAtoIndexService';
|
||||||
|
import { useResponse } from '@/shared/components/response/ResponseContext';
|
||||||
|
|
||||||
|
export const useTAtoIndexHook = () => {
|
||||||
|
const { setResponse } = useResponse();
|
||||||
|
|
||||||
|
const [tAto, setTAto] = useState<TAtoInterface[]>([]);
|
||||||
|
|
||||||
|
const fetchTAto = async () => {
|
||||||
|
const response = await TAtoIndexService();
|
||||||
|
|
||||||
|
setTAto(response.data);
|
||||||
|
|
||||||
|
setResponse(response);
|
||||||
|
|
||||||
|
return response.data;
|
||||||
|
};
|
||||||
|
|
||||||
|
return { tAto, fetchTAto };
|
||||||
|
};
|
||||||
|
|
@ -16,7 +16,6 @@ import { TServicoPedidoFormValues } from '@/packages/servicos/schemas/TServicoPe
|
||||||
import { useResponse } from '@/shared/components/response/ResponseContext';
|
import { useResponse } from '@/shared/components/response/ResponseContext';
|
||||||
import { StepNavigatorRef } from '@/shared/components/step/stepNavigator';
|
import { StepNavigatorRef } from '@/shared/components/step/stepNavigator';
|
||||||
import { SituacoesEnum } from '@/shared/enums/SituacoesEnum';
|
import { SituacoesEnum } from '@/shared/enums/SituacoesEnum';
|
||||||
import { TipoPessoaEnum } from '@/shared/enums/TipoPessoaEnum';
|
|
||||||
|
|
||||||
export default function useTServicoPedidoFormControllerHook(servico_pedido_id?: number) {
|
export default function useTServicoPedidoFormControllerHook(servico_pedido_id?: number) {
|
||||||
|
|
||||||
|
|
@ -27,6 +26,7 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
const [isSaving, setIsSaving] = useState(false);
|
const [isSaving, setIsSaving] = useState(false);
|
||||||
const [isAdding, setIsAdding] = useState(false);
|
const [isAdding, setIsAdding] = useState(false);
|
||||||
const [isPessoaFormOpen, setIsPessoaFormOpen] = useState(false);
|
const [isPessoaFormOpen, setIsPessoaFormOpen] = useState(false);
|
||||||
|
const [isAtoFormOpen, setAtoFormOpen] = useState(false);
|
||||||
const [isSaveConfirmOpen, setIsSaveConfirmOpen] = useState(false);
|
const [isSaveConfirmOpen, setIsSaveConfirmOpen] = useState(false);
|
||||||
const [isCancelDialogOpen, setIsCancelDialogOpen] = useState(false);
|
const [isCancelDialogOpen, setIsCancelDialogOpen] = useState(false);
|
||||||
const [selectedPessoaTipo, setSelectedPessoaTipo] = useState('');
|
const [selectedPessoaTipo, setSelectedPessoaTipo] = useState('');
|
||||||
|
|
@ -36,10 +36,10 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
|
|
||||||
// Controles de formulário
|
// Controles de formulário
|
||||||
const handleClosePessoaForm = useCallback(() => setIsPessoaFormOpen(false), []);
|
const handleClosePessoaForm = useCallback(() => setIsPessoaFormOpen(false), []);
|
||||||
|
const handleCloseAtoForm = useCallback(() => setAtoFormOpen(false), []);
|
||||||
const handleOpenSaveConfirm = useCallback(() => setIsSaveConfirmOpen(true), []);
|
const handleOpenSaveConfirm = useCallback(() => setIsSaveConfirmOpen(true), []);
|
||||||
const handleCloseSaveConfirm = useCallback(() => setIsSaveConfirmOpen(false), []);
|
const handleCloseSaveConfirm = useCallback(() => setIsSaveConfirmOpen(false), []);
|
||||||
|
|
||||||
// Hooks
|
|
||||||
// const playSuccess = useSoundHook("/sounds/success.mp3");
|
// const playSuccess = useSoundHook("/sounds/success.mp3");
|
||||||
const { setResponse } = useResponse();
|
const { setResponse } = useResponse();
|
||||||
const { saveTServicoPedido } = useTServicoPedidoSaveHook();
|
const { saveTServicoPedido } = useTServicoPedidoSaveHook();
|
||||||
|
|
@ -213,11 +213,14 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
setIsPessoaFormOpen(true);
|
setIsPessoaFormOpen(true);
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
// Habilita o formulário de itens
|
||||||
|
const handleOpenAtoForm = useCallback(() => {
|
||||||
|
setAtoFormOpen(true);
|
||||||
|
}, []);
|
||||||
|
|
||||||
// Adiciona o item a tabela e verifica se deve ou não montar a subview da linha da tabela
|
// Adiciona o item a tabela e verifica se deve ou não montar a subview da linha da tabela
|
||||||
const handleSelectServicoTipo = useCallback(() => {
|
const handleSelectServicoTipo = useCallback(() => {
|
||||||
|
|
||||||
const tipoPessoa = [TipoPessoaEnum.FISICA, TipoPessoaEnum.JURIDICA]
|
|
||||||
|
|
||||||
// Verifica se o emolumento e o tipo de serviço foram selecionados
|
// Verifica se o emolumento e o tipo de serviço foram selecionados
|
||||||
if (!selectedServicoTipo || !selectedEmolumento) {
|
if (!selectedServicoTipo || !selectedEmolumento) {
|
||||||
setResponse({
|
setResponse({
|
||||||
|
|
@ -228,14 +231,20 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
}
|
}
|
||||||
|
|
||||||
// Verifica se deve selecionar pessoas
|
// Verifica se deve selecionar pessoas
|
||||||
switch (tipoPessoa.includes(selectedServicoTipo.tipo_pessoa)) {
|
switch (selectedServicoTipo.tipo_item) {
|
||||||
|
|
||||||
// Habilita o formulário
|
// Habilita o formulário
|
||||||
case true:
|
case 'R':
|
||||||
|
|
||||||
handleOpenPessoaForm(selectedServicoTipo.tipo_pessoa);
|
handleOpenPessoaForm(selectedServicoTipo.tipo_pessoa);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
// Habilita o formulário
|
||||||
|
case 'C':
|
||||||
|
|
||||||
|
handleOpenAtoForm()
|
||||||
|
break;
|
||||||
|
|
||||||
// Adiciona direto
|
// Adiciona direto
|
||||||
default:
|
default:
|
||||||
|
|
||||||
|
|
@ -335,6 +344,7 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
isSaving,
|
isSaving,
|
||||||
isAdding,
|
isAdding,
|
||||||
isPessoaFormOpen,
|
isPessoaFormOpen,
|
||||||
|
isAtoFormOpen,
|
||||||
isSaveConfirmOpen,
|
isSaveConfirmOpen,
|
||||||
isCancelDialogOpen,
|
isCancelDialogOpen,
|
||||||
shouldKeepFormOpen,
|
shouldKeepFormOpen,
|
||||||
|
|
@ -356,6 +366,7 @@ export default function useTServicoPedidoFormControllerHook(servico_pedido_id?:
|
||||||
handleConfirmCancel,
|
handleConfirmCancel,
|
||||||
handleCloseCancelDialog,
|
handleCloseCancelDialog,
|
||||||
handleClosePessoaForm,
|
handleClosePessoaForm,
|
||||||
|
handleCloseAtoForm,
|
||||||
handleAddItemWithPessoa,
|
handleAddItemWithPessoa,
|
||||||
handleOpenSaveConfirm,
|
handleOpenSaveConfirm,
|
||||||
handleChangeQtd
|
handleChangeQtd
|
||||||
|
|
|
||||||
83
src/packages/servicos/interfaces/TAto/TAtoInterface.ts
Normal file
83
src/packages/servicos/interfaces/TAto/TAtoInterface.ts
Normal file
|
|
@ -0,0 +1,83 @@
|
||||||
|
export default interface TAtoInterface {
|
||||||
|
ato_id?: string;
|
||||||
|
ato_tipo_id?: string;
|
||||||
|
escrevente_ato_id?: string;
|
||||||
|
escrevente_assina_id?: string;
|
||||||
|
livro_andamento_id?: string;
|
||||||
|
data_abertura?: string;
|
||||||
|
data_lavratura?: string;
|
||||||
|
usuario_id?: string;
|
||||||
|
protocolo?: string;
|
||||||
|
alienacao_data?: string;
|
||||||
|
qualificacao_imovel_id?: string;
|
||||||
|
folha_inicial?: string;
|
||||||
|
folha_final?: string;
|
||||||
|
folha_total?: string;
|
||||||
|
alienacao_forma?: string;
|
||||||
|
grs_numero?: string;
|
||||||
|
texto?: string;
|
||||||
|
texto_finalizacao?: string;
|
||||||
|
natureza_id?: string;
|
||||||
|
valor_pagamento?: string;
|
||||||
|
situacao_ato?: string;
|
||||||
|
texto_imovel_geral?: string;
|
||||||
|
texto_assinatura?: string;
|
||||||
|
cancelado_data?: string;
|
||||||
|
cancelado_motivo?: string;
|
||||||
|
cancelado_observacao?: string;
|
||||||
|
cancelado_usuario_id?: string;
|
||||||
|
data_cancelamento?: string;
|
||||||
|
alienacao_datalavratura?: string;
|
||||||
|
ato_antigo?: string;
|
||||||
|
folha_letra?: string;
|
||||||
|
qtd_imovel?: string;
|
||||||
|
minuta_protegida?: string;
|
||||||
|
havido_marcacao_id?: string;
|
||||||
|
observacao?: string;
|
||||||
|
selo_livro_id?: string;
|
||||||
|
usar_tabela_auxiliar?: string;
|
||||||
|
ato_antigo_ocorrencia?: string;
|
||||||
|
fonte_tamanho?: string;
|
||||||
|
selo_recuo?: string;
|
||||||
|
ato_antigo_protocolo?: string;
|
||||||
|
ato_anterior_origem?: string;
|
||||||
|
ato_anterior_livro?: string;
|
||||||
|
ato_anterior_finicial?: string;
|
||||||
|
ato_anterior_tb_cartorio_id?: string;
|
||||||
|
ato_anterior_outorgante?: string;
|
||||||
|
ato_anterior_observacao?: string;
|
||||||
|
ato_anterior_ato_id?: string;
|
||||||
|
ato_anterior_data?: string;
|
||||||
|
ato_anterior_anotacao_adicional?: string;
|
||||||
|
ato_anterior_ato_tipo_id?: string;
|
||||||
|
ato_anterior_valor_documento?: string;
|
||||||
|
cadastrar_imovel?: string;
|
||||||
|
filho_maior_qtd?: string;
|
||||||
|
filho_maior_descricao?: string;
|
||||||
|
filho_menor_qtd?: string;
|
||||||
|
filho_menor_descricao?: string;
|
||||||
|
casamento_data?: string;
|
||||||
|
casamento_tb_regime_id?: string;
|
||||||
|
ato_anterior_ffinal?: string;
|
||||||
|
resp_filhos_maiores?: string;
|
||||||
|
resp_filhos_menores?: string;
|
||||||
|
censec_naturezalitigio_id?: string;
|
||||||
|
censec_acordo?: string;
|
||||||
|
nlote?: string;
|
||||||
|
especie_pagamento?: string;
|
||||||
|
fora_cartorio?: string;
|
||||||
|
nfse_id?: string;
|
||||||
|
acao?: string;
|
||||||
|
data_protocolo?: string;
|
||||||
|
frente_verso?: string;
|
||||||
|
chave_importacao?: string;
|
||||||
|
lavratura_online?: string;
|
||||||
|
data_prevista_entrega?: string;
|
||||||
|
usuario_id_lavratura?: string;
|
||||||
|
ativo?: string;
|
||||||
|
convalidacao?: string;
|
||||||
|
lado_folha_fim?: string;
|
||||||
|
ato_oneroso?: string;
|
||||||
|
mne?: string;
|
||||||
|
eh_restrito?: string;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,6 @@
|
||||||
|
export default interface TAtoTableFormInterface {
|
||||||
|
isOpen: boolean;
|
||||||
|
onClose: (item: null, isFormStatus: boolean) => void;
|
||||||
|
onSave: (data: any) => void;
|
||||||
|
buttonIsLoading: boolean;
|
||||||
|
}
|
||||||
11
src/packages/servicos/services/TAto/TAtoIndexService.ts
Normal file
11
src/packages/servicos/services/TAto/TAtoIndexService.ts
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
'use server';
|
||||||
|
import { TAtoIndexData } from '@/packages/servicos/data/TAto/TAtoIndexData';
|
||||||
|
import { withClientErrorHandler } from '@/shared/actions/withClientErrorHandler/withClientErrorHandler';
|
||||||
|
|
||||||
|
|
||||||
|
async function executeTAtoIndexService() {
|
||||||
|
const response = await TAtoIndexData();
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const TAtoIndexService = withClientErrorHandler(executeTAtoIndexService);
|
||||||
|
|
@ -0,0 +1,80 @@
|
||||||
|
import { CheckIcon, ChevronsUpDownIcon } from 'lucide-react';
|
||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import { Button } from '@/components/ui/button';
|
||||||
|
import {
|
||||||
|
Command,
|
||||||
|
CommandEmpty,
|
||||||
|
CommandGroup,
|
||||||
|
CommandInput,
|
||||||
|
CommandItem,
|
||||||
|
CommandList,
|
||||||
|
} from '@/components/ui/command';
|
||||||
|
import { FormControl } from '@/components/ui/form';
|
||||||
|
import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/popover';
|
||||||
|
import { cn } from '@/lib/utils';
|
||||||
|
import { TipoCertidoesEnum } from '@/shared/enums/TipoCertidoesEnum';
|
||||||
|
|
||||||
|
import TiposCertidoesSelectInterface from './interfaces/TiposCertidoesSelectInterface';
|
||||||
|
|
||||||
|
export default function TiposCertidoesSelect({ field }: TiposCertidoesSelectInterface) {
|
||||||
|
|
||||||
|
const [open, setOpen] = React.useState(false);
|
||||||
|
|
||||||
|
const options = Object.entries(TipoCertidoesEnum).map(([key, label]) => ({
|
||||||
|
value: Number(key),
|
||||||
|
label,
|
||||||
|
}));
|
||||||
|
|
||||||
|
// Label exibida atualmente
|
||||||
|
const selectedLabel =
|
||||||
|
field.value !== undefined && field.value !== null
|
||||||
|
? options.find((item) => item.value === Number(field.value))?.label
|
||||||
|
: 'Selecione...';
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Popover open={open} onOpenChange={setOpen}>
|
||||||
|
<PopoverTrigger asChild>
|
||||||
|
<FormControl className="w-full">
|
||||||
|
<Button
|
||||||
|
variant="outline"
|
||||||
|
role="combobox"
|
||||||
|
aria-expanded={open}
|
||||||
|
className="justify-between"
|
||||||
|
>
|
||||||
|
{selectedLabel}
|
||||||
|
<ChevronsUpDownIcon className="ml-2 h-4 w-4 shrink-0 opacity-50" />
|
||||||
|
</Button>
|
||||||
|
</FormControl>
|
||||||
|
</PopoverTrigger>
|
||||||
|
<PopoverContent className="w-[var(--radix-popover-trigger-width)] p-0">
|
||||||
|
<Command>
|
||||||
|
<CommandInput placeholder="Buscar tipo de parte..." />
|
||||||
|
<CommandList>
|
||||||
|
<CommandEmpty>Nenhum resultado encontrado.</CommandEmpty>
|
||||||
|
<CommandGroup>
|
||||||
|
{options.map((item) => (
|
||||||
|
<CommandItem
|
||||||
|
key={item.value}
|
||||||
|
value={item.label.toLowerCase()}
|
||||||
|
onSelect={() => {
|
||||||
|
field.onChange(item.value); // envia número
|
||||||
|
setOpen(false);
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<CheckIcon
|
||||||
|
className={cn(
|
||||||
|
'mr-2 h-4 w-4',
|
||||||
|
Number(field.value) === item.value ? 'opacity-100' : 'opacity-0',
|
||||||
|
)}
|
||||||
|
/>
|
||||||
|
{item.label}
|
||||||
|
</CommandItem>
|
||||||
|
))}
|
||||||
|
</CommandGroup>
|
||||||
|
</CommandList>
|
||||||
|
</Command>
|
||||||
|
</PopoverContent>
|
||||||
|
</Popover>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,6 @@
|
||||||
|
export default interface TiposCertidoesSelectInterface {
|
||||||
|
field: {
|
||||||
|
value?: number | null;
|
||||||
|
onChange: (value: number) => void;
|
||||||
|
};
|
||||||
|
};
|
||||||
9
src/shared/enums/TipoCertidoesEnum.ts
Normal file
9
src/shared/enums/TipoCertidoesEnum.ts
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
export const TipoCertidoesEnum = {
|
||||||
|
1: 'Sistema',
|
||||||
|
2: 'Imagem',
|
||||||
|
3: 'Imagem Antiga',
|
||||||
|
4: 'Transcrever',
|
||||||
|
5: 'Negativa/Positiva',
|
||||||
|
} as const;
|
||||||
|
|
||||||
|
export type TipoCertidaoEnum = keyof typeof TipoCertidoesEnum;
|
||||||
Loading…
Add table
Reference in a new issue