Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -1,218 +1,274 @@
|
|
1 |
import os
|
2 |
import gradio as gr
|
3 |
from huggingface_hub import InferenceClient
|
|
|
|
|
4 |
|
5 |
-
|
6 |
-
|
7 |
-
|
8 |
-
|
9 |
-
|
10 |
-
|
11 |
-
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
|
18 |
-
|
19 |
-
|
20 |
-
"
|
21 |
-
|
22 |
-
|
23 |
-
"O acusado, [Nome do Cliente], é um cidadão brasileiro, nascido em [Data de Nascimento] no município de [Local de Nascimento], "
|
24 |
-
"titular do documento de identidade [Tipo de Documento de Identidade] no número [Número do Documento de Identidade], "
|
25 |
-
"efetivo domiciliado na [Endereço de Domicílio do Cliente].",
|
26 |
-
"DOS FATOS\n"
|
27 |
-
"A Polícia de [Local do Crime] detém o acusado desde [Data da Detenção], por motivos de suposto furto qualificado, "
|
28 |
-
"cometido no dia [Data do Crime] às [Horas do Crime], no local de [Local do Crime]. "
|
29 |
-
"Entretanto, há provas documentais e testemunha ocular que comprovam a presença do acusado na cidade distante [Local Distante do Crime] no momento do crime.",
|
30 |
-
"DO DIREITO\n"
|
31 |
-
"O artigo 5º LXVIII da Constituição Federal dispõe que 'toda pessoa pode ser presa quando há fundamentos razoáveis para acreditar que ela cometeu ou está prestes a cometer um crime'. "
|
32 |
-
"O Código de Processo Penal estabelece, nos artigos 647 e 648, que 'a prisão não pode ser imposta a menos que haja fundamentos razoáveis...'",
|
33 |
-
"DO CONSTRANGIMENTO ILEGAL\n"
|
34 |
-
"A prisão do acusado, sem a devida fundamentação, caracteriza constrangimento ilegal, uma vez que há evidências de sua inocência.",
|
35 |
-
"DA MEDIDA LIMINAR\n"
|
36 |
-
"Requer-se a concessão de medida liminar para a liberdade do paciente.",
|
37 |
-
"DOS PEDIDOS\n"
|
38 |
-
"Diante do exposto, requer-se a concessão do habeas corpus.",
|
39 |
-
"PROVAS E DOCUMENTOS\n"
|
40 |
-
"Anexamos documentos que comprovam a inocência do acusado.",
|
41 |
-
"FECHAMENTO\n"
|
42 |
-
"Nestes termos, pede deferimento."
|
43 |
-
],
|
44 |
-
"max_tokens": 500
|
45 |
-
},
|
46 |
-
# Outros templates podem ser adicionados aqui
|
47 |
-
}
|
48 |
-
|
49 |
-
template = templates.get(tipo_peca.lower())
|
50 |
-
if not template:
|
51 |
-
return "Tipo de peça não suportado."
|
52 |
-
|
53 |
-
# Preencher os campos da peça jurídica com base nas informações do caso
|
54 |
-
informacoes = {
|
55 |
-
"Nome do Cliente": "João da Silva", # Exemplo
|
56 |
-
"Data de Nascimento": "01/01/1990", # Exemplo
|
57 |
-
"Local de Nascimento": "São Paulo",
|
58 |
-
"Tipo de Documento de Identidade": "RG",
|
59 |
-
"Número do Documento de Identidade": "123456789",
|
60 |
-
"Endereço de Domicílio do Cliente": "Rua Exemplo, 123, São Paulo - SP",
|
61 |
-
"Local do Crime": "São Paulo",
|
62 |
-
"Data da Detenção": "15/12/2023",
|
63 |
-
"Data do Crime": "14/12/2023",
|
64 |
-
"Horas do Crime": "14:00",
|
65 |
-
"Local Distante do Crime": "Campinas",
|
66 |
-
"VARA": "1ª Vara Criminal", # Exemplo
|
67 |
-
"COMARCA": "São Paulo" # Exemplo
|
68 |
-
}
|
69 |
-
|
70 |
-
# Montar o texto da peça jurídica
|
71 |
-
texto_final = "\n\n".join([
|
72 |
-
linha.replace(placeholder, informacoes[placeholder])
|
73 |
-
for linha in template["estrutura"]
|
74 |
-
for placeholder in informacoes.keys()
|
75 |
-
if placeholder in linha
|
76 |
-
])
|
77 |
-
|
78 |
-
# Realizar a requisição única para aprimoramento
|
79 |
-
try:
|
80 |
-
mensagens = [
|
81 |
-
{
|
82 |
-
"role": "system",
|
83 |
-
"content": (
|
84 |
-
f"Como advogado criminalista, redija um {tipo_peca} técnica seguindo:\n"
|
85 |
-
f"1. Estrutura formal\n"
|
86 |
-
f"2. Linguagem jurídica\n"
|
87 |
-
f"3. Fundamentação precisa\n"
|
88 |
-
f"4. Formatação correta\n"
|
89 |
-
f"5. Considere as informações do caso: {informacoes_caso}"
|
90 |
-
)
|
91 |
-
},
|
92 |
-
{
|
93 |
-
"role": "user",
|
94 |
-
"content": texto_final
|
95 |
-
}
|
96 |
-
]
|
97 |
|
98 |
-
|
99 |
-
|
100 |
-
|
101 |
-
max_tokens=template['max_tokens'],
|
102 |
-
temperature=0.7
|
103 |
-
)
|
104 |
|
105 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
106 |
|
107 |
-
except Exception as e:
|
108 |
-
return f"Erro ao gerar a peça: {str(e)}"
|
109 |
-
|
110 |
-
# Função para redefinir os campos
|
111 |
-
def redefinir_campos():
|
112 |
-
return "", "", ""
|
113 |
-
|
114 |
-
# Função para exportar a peça jurídica gerada
|
115 |
-
def exportar_peca(peca_texto):
|
116 |
-
"""
|
117 |
-
Exporta a peça jurídica gerada para um arquivo .txt.
|
118 |
-
|
119 |
-
Parâmetros:
|
120 |
-
peca_texto (str): Texto da peça jurídica gerada.
|
121 |
-
|
122 |
-
Retorna:
|
123 |
-
str: Caminho do arquivo exportado.
|
124 |
-
"""
|
125 |
-
arquivo_nome = "peca_juridica_gerada.txt"
|
126 |
-
with open(arquivo_nome, "w", encoding="utf-8") as arquivo:
|
127 |
-
arquivo.write(peca_texto)
|
128 |
-
return f"Arquivo salvo como: {arquivo_nome}"
|
129 |
-
|
130 |
-
# Configuração do app Gradio com funcionalidades adicionais
|
131 |
-
def gerar_interface_gradio():
|
132 |
-
"""
|
133 |
-
Configura a interface do Gradio para gerar peças jurídicas com exemplos pré-definidos e funcionalidades adicionais.
|
134 |
-
"""
|
135 |
with gr.Blocks() as interface:
|
136 |
gr.Markdown("# Gerador de Peças Jurídicas Criminais")
|
137 |
-
gr.Markdown(
|
138 |
-
"### Preencha os campos abaixo ou escolha um exemplo, e selecione o tipo de peça jurídica que deseja gerar."
|
139 |
-
)
|
140 |
|
141 |
-
with gr.
|
142 |
-
|
143 |
label="Informações do Caso",
|
144 |
-
placeholder="Descreva o caso detalhadamente
|
145 |
lines=5
|
146 |
)
|
147 |
-
|
148 |
-
|
149 |
-
label="Exemplos de Casos",
|
150 |
choices=[
|
151 |
-
"
|
152 |
-
"
|
153 |
-
"
|
154 |
-
|
155 |
-
|
156 |
-
interactive=True
|
157 |
)
|
158 |
-
|
159 |
-
|
160 |
-
|
161 |
-
|
162 |
-
|
163 |
-
)
|
164 |
-
|
165 |
-
|
166 |
-
|
167 |
-
|
168 |
-
|
169 |
-
|
170 |
-
|
171 |
-
|
172 |
-
|
173 |
-
|
174 |
-
|
175 |
-
|
176 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
177 |
with gr.Row():
|
178 |
-
|
179 |
-
|
180 |
-
|
181 |
-
saida_texto = gr.Textbox(
|
182 |
-
label="Peça Jurídica Gerada",
|
183 |
-
lines=15,
|
184 |
-
placeholder="A peça jurídica gerada aparecerá aqui."
|
185 |
-
)
|
186 |
|
187 |
-
|
188 |
-
|
189 |
-
|
190 |
-
|
191 |
)
|
192 |
|
193 |
-
|
194 |
-
|
195 |
-
|
196 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
197 |
)
|
198 |
-
|
199 |
-
|
200 |
-
|
201 |
-
|
202 |
-
|
203 |
-
|
204 |
-
|
205 |
-
|
206 |
-
|
207 |
-
|
208 |
-
exportar_peca,
|
209 |
-
inputs=saida_texto,
|
210 |
-
outputs=saida_arquivo
|
211 |
)
|
212 |
-
|
213 |
return interface
|
214 |
|
215 |
-
# Executa o app
|
216 |
if __name__ == "__main__":
|
217 |
-
|
218 |
-
|
|
|
1 |
import os
|
2 |
import gradio as gr
|
3 |
from huggingface_hub import InferenceClient
|
4 |
+
from datetime import datetime
|
5 |
+
from typing import Dict, Optional
|
6 |
|
7 |
+
class LegalDocumentGenerator:
|
8 |
+
def __init__(self):
|
9 |
+
self.api_key = os.getenv("HF_API_KEY")
|
10 |
+
if not self.api_key:
|
11 |
+
raise EnvironmentError("HF_API_KEY não configurada")
|
12 |
+
self.client = InferenceClient(api_key=self.api_key)
|
13 |
+
|
14 |
+
def generate_section(self, messages: list, section: str) -> str:
|
15 |
+
try:
|
16 |
+
response = self.client.chat.completions.create(
|
17 |
+
model="mistralai/Mistral-7B-Instruct-v0.3",
|
18 |
+
messages=[*messages, {"role": "user", "content": f"Gere a seção {section}"}],
|
19 |
+
max_tokens=500,
|
20 |
+
temperature=0.3
|
21 |
+
)
|
22 |
+
return response.choices[0].message["content"]
|
23 |
+
except Exception as e:
|
24 |
+
raise Exception(f"Erro na geração da seção {section}: {str(e)}")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
25 |
|
26 |
+
def generate_document(self, case_info: str, doc_type: str, client_data: Dict) -> str:
|
27 |
+
if not all([case_info, doc_type, client_data]):
|
28 |
+
return "Erro: Dados incompletos"
|
|
|
|
|
|
|
29 |
|
30 |
+
templates = {
|
31 |
+
"habeas corpus": self._get_habeas_corpus_template(),
|
32 |
+
"defesa prévia": self._get_defesa_previa_template(),
|
33 |
+
"apelação criminal": self._get_apelacao_template(),
|
34 |
+
"petição inicial": self._get_peticao_inicial_template()
|
35 |
+
}
|
36 |
+
|
37 |
+
template = templates.get(doc_type.lower())
|
38 |
+
if not template:
|
39 |
+
return "Erro: Tipo de documento não suportado"
|
40 |
+
|
41 |
+
try:
|
42 |
+
messages = [
|
43 |
+
{
|
44 |
+
"role": "system",
|
45 |
+
"content": (
|
46 |
+
"Você é um advogado criminalista especializado. Gere uma peça jurídica observando:\n"
|
47 |
+
"1. Formalidade e técnica jurídica\n"
|
48 |
+
"2. Fundamentação legal precisa e atualizada\n"
|
49 |
+
"3. Jurisprudência relevante\n"
|
50 |
+
"4. Adequação ao caso concreto\n"
|
51 |
+
f"Tipo de peça: {doc_type}\n"
|
52 |
+
f"Informações do caso: {case_info}"
|
53 |
+
)
|
54 |
+
}
|
55 |
+
]
|
56 |
+
|
57 |
+
sections = {}
|
58 |
+
for section in template["required_sections"]:
|
59 |
+
sections[section] = self.generate_section(messages, section)
|
60 |
+
|
61 |
+
document = template["structure"].format(
|
62 |
+
**sections,
|
63 |
+
**client_data,
|
64 |
+
data=datetime.now().strftime("%d/%m/%Y")
|
65 |
+
)
|
66 |
+
|
67 |
+
return document
|
68 |
+
|
69 |
+
except Exception as e:
|
70 |
+
return f"Erro na geração do documento: {str(e)}"
|
71 |
+
|
72 |
+
def _get_habeas_corpus_template(self):
|
73 |
+
return {
|
74 |
+
"structure": (
|
75 |
+
"EXCELENTÍSSIMO(A) SENHOR(A) DOUTOR(A) JUIZ(A) DE DIREITO DA {vara} DA {comarca}\n\n"
|
76 |
+
"HABEAS CORPUS COM PEDIDO LIMINAR\n\n"
|
77 |
+
"QUALIFICAÇÃO DO PACIENTE\n{qualificacao}\n\n"
|
78 |
+
"DOS FATOS\n{fatos}\n\n"
|
79 |
+
"DO DIREITO\n{fundamentacao}\n\n"
|
80 |
+
"DO CONSTRANGIMENTO ILEGAL\n{constrangimento}\n\n"
|
81 |
+
"DA MEDIDA LIMINAR\n{liminar}\n\n"
|
82 |
+
"DOS PEDIDOS\n{pedidos}\n\n"
|
83 |
+
"PROVAS E DOCUMENTOS\n{provas}\n\n"
|
84 |
+
"{comarca}, {data}\n\n"
|
85 |
+
"{advogado}\n"
|
86 |
+
"OAB/{estado} {numero_oab}"
|
87 |
+
),
|
88 |
+
"required_sections": [
|
89 |
+
"qualificacao", "fatos", "fundamentacao",
|
90 |
+
"constrangimento", "liminar", "pedidos", "provas"
|
91 |
+
]
|
92 |
+
}
|
93 |
+
|
94 |
+
def _get_defesa_previa_template(self):
|
95 |
+
return {
|
96 |
+
"structure": (
|
97 |
+
"EXCELENTÍSSIMO(A) SENHOR(A) DOUTOR(A) JUIZ(A) DE DIREITO DA {vara} DA {comarca}\n\n"
|
98 |
+
"DEFESA PRÉVIA\n\n"
|
99 |
+
"Autos nº {numero_processo}\n\n"
|
100 |
+
"QUALIFICAÇÃO DO ACUSADO\n{qualificacao}\n\n"
|
101 |
+
"DOS FATOS\n{fatos}\n\n"
|
102 |
+
"DO DIREITO\n{fundamentacao}\n\n"
|
103 |
+
"DAS PRELIMINARES\n{preliminares}\n\n"
|
104 |
+
"DO MÉRITO\n{merito}\n\n"
|
105 |
+
"DAS PROVAS\n{provas}\n\n"
|
106 |
+
"DOS PEDIDOS\n{pedidos}\n\n"
|
107 |
+
"{comarca}, {data}\n\n"
|
108 |
+
"{advogado}\n"
|
109 |
+
"OAB/{estado} {numero_oab}"
|
110 |
+
),
|
111 |
+
"required_sections": [
|
112 |
+
"qualificacao", "fatos", "fundamentacao", "preliminares",
|
113 |
+
"merito", "provas", "pedidos"
|
114 |
+
]
|
115 |
+
}
|
116 |
+
|
117 |
+
def _get_apelacao_template(self):
|
118 |
+
return {
|
119 |
+
"structure": (
|
120 |
+
"EXCELENTÍSSIMO(A) SENHOR(A) DOUTOR(A) DESEMBARGADOR(A) RELATOR(A) DO TRIBUNAL DE JUSTIÇA DO ESTADO DE {estado}\n\n"
|
121 |
+
"RAZÕES DE APELAÇÃO\n\n"
|
122 |
+
"Autos nº {numero_processo}\n\n"
|
123 |
+
"QUALIFICAÇÃO DO APELANTE\n{qualificacao}\n\n"
|
124 |
+
"DOS FATOS\n{fatos}\n\n"
|
125 |
+
"DAS PRELIMINARES\n{preliminares}\n\n"
|
126 |
+
"DO MÉRITO\n{merito}\n\n"
|
127 |
+
"DO DIREITO\n{fundamentacao}\n\n"
|
128 |
+
"DOS PEDIDOS\n{pedidos}\n\n"
|
129 |
+
"{comarca}, {data}\n\n"
|
130 |
+
"{advogado}\n"
|
131 |
+
"OAB/{estado} {numero_oab}"
|
132 |
+
),
|
133 |
+
"required_sections": [
|
134 |
+
"qualificacao", "fatos", "preliminares", "merito",
|
135 |
+
"fundamentacao", "pedidos"
|
136 |
+
]
|
137 |
+
}
|
138 |
+
|
139 |
+
def _get_peticao_inicial_template(self):
|
140 |
+
return {
|
141 |
+
"structure": (
|
142 |
+
"EXCELENTÍSSIMO(A) SENHOR(A) DOUTOR(A) JUIZ(A) DE DIREITO DA {vara} DA {comarca}\n\n"
|
143 |
+
"PETIÇÃO INICIAL\n\n"
|
144 |
+
"QUALIFICAÇÃO DO AUTOR\n{qualificacao}\n\n"
|
145 |
+
"DOS FATOS\n{fatos}\n\n"
|
146 |
+
"DO DIREITO\n{fundamentacao}\n\n"
|
147 |
+
"DO PEDIDO LIMINAR\n{liminar}\n\n"
|
148 |
+
"DOS PEDIDOS\n{pedidos}\n\n"
|
149 |
+
"DAS PROVAS\n{provas}\n\n"
|
150 |
+
"DO VALOR DA CAUSA\n{valor_causa}\n\n"
|
151 |
+
"{comarca}, {data}\n\n"
|
152 |
+
"{advogado}\n"
|
153 |
+
"OAB/{estado} {numero_oab}"
|
154 |
+
),
|
155 |
+
"required_sections": [
|
156 |
+
"qualificacao", "fatos", "fundamentacao", "liminar",
|
157 |
+
"pedidos", "provas", "valor_causa"
|
158 |
+
]
|
159 |
+
}
|
160 |
+
|
161 |
+
def create_interface():
|
162 |
+
generator = LegalDocumentGenerator()
|
163 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
164 |
with gr.Blocks() as interface:
|
165 |
gr.Markdown("# Gerador de Peças Jurídicas Criminais")
|
|
|
|
|
|
|
166 |
|
167 |
+
with gr.Tab("Dados do Caso"):
|
168 |
+
case_info = gr.Textbox(
|
169 |
label="Informações do Caso",
|
170 |
+
placeholder="Descreva o caso detalhadamente",
|
171 |
lines=5
|
172 |
)
|
173 |
+
doc_type = gr.Dropdown(
|
174 |
+
label="Tipo de Peça",
|
|
|
175 |
choices=[
|
176 |
+
"habeas corpus",
|
177 |
+
"defesa prévia",
|
178 |
+
"apelação criminal",
|
179 |
+
"petição inicial"
|
180 |
+
]
|
|
|
181 |
)
|
182 |
+
|
183 |
+
with gr.Tab("Dados do Cliente"):
|
184 |
+
with gr.Row():
|
185 |
+
client_name = gr.Textbox(label="Nome")
|
186 |
+
client_nationality = gr.Textbox(label="Nacionalidade")
|
187 |
+
with gr.Row():
|
188 |
+
client_profession = gr.Textbox(label="Profissão")
|
189 |
+
client_id = gr.Textbox(label="RG")
|
190 |
+
with gr.Row():
|
191 |
+
client_address = gr.Textbox(label="Endereço")
|
192 |
+
client_city = gr.Textbox(label="Cidade")
|
193 |
+
with gr.Row():
|
194 |
+
client_state = gr.Textbox(label="Estado")
|
195 |
+
client_zip = gr.Textbox(label="CEP")
|
196 |
+
|
197 |
+
with gr.Tab("Dados Processuais"):
|
198 |
+
with gr.Row():
|
199 |
+
court = gr.Textbox(label="Vara")
|
200 |
+
jurisdiction = gr.Textbox(label="Comarca")
|
201 |
+
with gr.Row():
|
202 |
+
process_number = gr.Textbox(label="Número do Processo")
|
203 |
+
lawyer_name = gr.Textbox(label="Nome do Advogado")
|
204 |
+
with gr.Row():
|
205 |
+
lawyer_oab = gr.Textbox(label="Número OAB")
|
206 |
+
lawyer_state = gr.Textbox(label="Estado OAB")
|
207 |
+
|
208 |
with gr.Row():
|
209 |
+
generate_btn = gr.Button("Gerar Documento")
|
210 |
+
clear_btn = gr.Button("Limpar Campos")
|
|
|
|
|
|
|
|
|
|
|
|
|
211 |
|
212 |
+
output = gr.Textbox(
|
213 |
+
label="Documento Gerado",
|
214 |
+
lines=20,
|
215 |
+
placeholder="O documento gerado aparecerá aqui"
|
216 |
)
|
217 |
|
218 |
+
def generate(
|
219 |
+
case_info, doc_type,
|
220 |
+
name, nationality, profession, id_num,
|
221 |
+
address, city, state, zip_code,
|
222 |
+
court, jurisdiction, process_num,
|
223 |
+
lawyer_name, lawyer_oab, lawyer_state
|
224 |
+
):
|
225 |
+
client_data = {
|
226 |
+
"nome": name,
|
227 |
+
"nacionalidade": nationality,
|
228 |
+
"profissao": profession,
|
229 |
+
"rg": id_num,
|
230 |
+
"endereco": address,
|
231 |
+
"cidade": city,
|
232 |
+
"estado": state,
|
233 |
+
"cep": zip_code,
|
234 |
+
"vara": court,
|
235 |
+
"comarca": jurisdiction,
|
236 |
+
"numero_processo": process_num,
|
237 |
+
"advogado": lawyer_name,
|
238 |
+
"numero_oab": lawyer_oab,
|
239 |
+
"estado_oab": lawyer_state
|
240 |
+
}
|
241 |
+
|
242 |
+
return generator.generate_document(case_info, doc_type, client_data)
|
243 |
+
|
244 |
+
def clear_fields():
|
245 |
+
return [""] * 16
|
246 |
+
|
247 |
+
generate_btn.click(
|
248 |
+
generate,
|
249 |
+
inputs=[
|
250 |
+
case_info, doc_type,
|
251 |
+
client_name, client_nationality, client_profession, client_id,
|
252 |
+
client_address, client_city, client_state, client_zip,
|
253 |
+
court, jurisdiction, process_number,
|
254 |
+
lawyer_name, lawyer_oab, lawyer_state
|
255 |
+
],
|
256 |
+
outputs=output
|
257 |
)
|
258 |
+
|
259 |
+
clear_btn.click(
|
260 |
+
clear_fields,
|
261 |
+
outputs=[
|
262 |
+
case_info, doc_type,
|
263 |
+
client_name, client_nationality, client_profession, client_id,
|
264 |
+
client_address, client_city, client_state, client_zip,
|
265 |
+
court, jurisdiction, process_number,
|
266 |
+
lawyer_name, lawyer_oab, lawyer_state
|
267 |
+
]
|
|
|
|
|
|
|
268 |
)
|
269 |
+
|
270 |
return interface
|
271 |
|
|
|
272 |
if __name__ == "__main__":
|
273 |
+
interface = create_interface()
|
274 |
+
interface.launch()
|