5 Commits

2 changed files with 28 additions and 17 deletions

View File

@@ -381,11 +381,11 @@ export default function Datastage() {
<tr key={item.id} className="hover:bg-slate-50 transition-colors">
<td className="border px-2 py-2 text-center">{item.id}</td>
<td className="border px-2 py-2 max-w-xs truncate">
{item.archivo ? (
{item.download_url ? (
<span className="flex items-center gap-1 text-xs text-gray-700 truncate font-mono">
{(() => {
try {
const url = new URL(item.archivo);
const url = new URL(item.download_url);
return decodeURIComponent(url.pathname.split('/').pop() || '');
} catch {
return '';
@@ -399,7 +399,7 @@ export default function Datastage() {
item.id,
(() => {
try {
const url = new URL(item.archivo);
const url = new URL(item.download_url);
return decodeURIComponent(url.pathname.split('/').pop() || '');
} catch {
return '';
@@ -507,16 +507,16 @@ export default function Datastage() {
</span>
</div>
<div className="flex items-center gap-1 text-xs text-gray-700 break-all font-mono mb-1">
{item.archivo ? (
{item.download_url ? (
<span className="flex items-center gap-1">
{(() => { try { const url = new URL(item.archivo); return decodeURIComponent(url.pathname.split('/').pop() || ''); } catch { return ''; } })()}
{(() => { try { const url = new URL(item.download_url); return decodeURIComponent(url.pathname.split('/').pop() || ''); } catch { return ''; } })()}
<button
type="button"
className="inline-flex items-center justify-center w-6 h-6 rounded bg-blue-100 border border-blue-200 text-blue-700 hover:bg-blue-200 hover:border-blue-300 transition-all duration-200 focus:outline-none focus:ring-2 focus:ring-blue-400 ml-1"
title="Descargar archivo"
onClick={() => downloadDatastageFile(
item.id,
(() => { try { const url = new URL(item.archivo); return decodeURIComponent(url.pathname.split('/').pop() || ''); } catch { return ''; } })()
(() => { try { const url = new URL(item.download_url); return decodeURIComponent(url.pathname.split('/').pop() || ''); } catch { return ''; } })()
)}
>
<svg className="w-4 h-4" fill="none" stroke="currentColor" viewBox="0 0 24 24">
@@ -803,7 +803,7 @@ export default function Datastage() {
<div className="fixed inset-0 z-50 flex items-center justify-center bg-black bg-opacity-40">
<div className="bg-white rounded-xl shadow-2xl border border-blue-200 p-8 max-w-sm w-full flex flex-col animate-fade-in">
<h3 className="text-lg font-bold mb-2 text-blue-900">Detalle de Datastage #{selected.id}</h3>
<div className="mb-1"><b>Archivo:</b> {selected.archivo ? <a href={selected.archivo} target="_blank" rel="noopener noreferrer" className="text-blue-600 underline break-all">Descargar</a> : <span className="text-gray-400">Sin archivo</span>}</div>
{/* <div className="mb-1"><b>Archivo:</b> {selected.download_url ? <a href={selected.download_url} target="_blank" rel="noopener noreferrer" className="text-blue-600 underline break-all">Descargar</a> : <span className="text-gray-400">Sin archivo</span>}</div> */}
<div className="mb-1"><b>Contribuyente:</b> {selected.contribuyente}</div>
<div className="mb-1"><b>Procesado:</b> <span className={selected.procesado ? 'bg-green-100 text-green-700 px-2 py-0.5 rounded-full text-xs' : 'bg-yellow-100 text-yellow-700 px-2 py-0.5 rounded-full text-xs'}>{selected.procesado ? 'Sí' : 'No'}</span></div>
<div className="mb-1"><b>Organización:</b> {selected.organizacion}</div>

View File

@@ -412,6 +412,7 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
// La API devuelve un array directamente, no un objeto con results
const credenciales = Array.isArray(data) ? data : (data.results || []);
console.log('credenciales >>>> ', credenciales);
return credenciales;
}
return [];
@@ -459,8 +460,10 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
password: credencial.password,
efirma: credencial.efirma,
// Convertir URLs completas a rutas relativas
key: credencial.key ? credencial.key.split('/').slice(-2).join('/') : '',
cer: credencial.cer ? credencial.cer.split('/').slice(-2).join('/') : '',
key: credencial.key_download_url,
cer: credencial.cer_download_url,
// key: credencial.key ? credencial.key.split('/').slice(-2).join('/') : '',
// cer: credencial.cer ? credencial.cer.split('/').slice(-2).join('/') : '',
is_active: credencial.is_active,
organizacion: credencial.organizacion
}
@@ -2005,8 +2008,10 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
user: credencial.usuario,
password: credencial.password,
efirma: credencial.efirma,
key: credencial.key,
cer: credencial.cer,
key: credencial.key_download_url,
cer: credencial.cer_download_url,
// key: credencial.key,
// cer: credencial.cer,
is_active: credencial.is_active,
organizacion: credencial.organizacion
}
@@ -2078,8 +2083,10 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
user: credencial.usuario,
password: credencial.password,
efirma: credencial.efirma,
key: credencial.key,
cer: credencial.cer,
key: credencial.key_download_url,
cer: credencial.cer_download_url,
// key: credencial.key,
// cer: credencial.cer,
is_active: credencial.is_active,
organizacion: credencial.organizacion
}
@@ -2152,8 +2159,10 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
user: credencial.usuario,
password: credencial.password,
efirma: credencial.efirma,
key: credencial.key,
cer: credencial.cer,
key: credencial.key_download_url,
cer: credencial.cer_download_url,
// key: credencial.key,
// cer: credencial.cer,
is_active: credencial.is_active,
organizacion: credencial.organizacion
}
@@ -2226,8 +2235,10 @@ const handleDeleteSelectedPedimentoDocuments = async () => {
user: credencial.usuario,
password: credencial.password,
efirma: credencial.efirma,
key: credencial.key,
cer: credencial.cer,
key: credencial.key_download_url,
cer: credencial.cer_download_url,
// key: credencial.key,
// cer: credencial.cer,
is_active: credencial.is_active,
organizacion: credencial.organizacion
}