Fix WhatsApp instance detection
Centralize instance check, remove debug, and fix UI.
This commit is contained in:
parent
ec9c883bf0
commit
7fbce3ca0b
@ -19,30 +19,29 @@ export const useExistingInstanceCheck = (userEmail: string) => {
|
||||
setCheckingExistingInstance(true);
|
||||
|
||||
try {
|
||||
console.log('🔍 [EXISTING_INSTANCE] Verificando se usuário já tem instância CONECTADA:', userEmail);
|
||||
console.log('🔍 [EXISTING_INSTANCE] Verificando instância para:', userEmail);
|
||||
const existingInstance = await getUserWhatsAppInstance(userEmail);
|
||||
|
||||
console.log('📋 [EXISTING_INSTANCE] Dados da instância encontrados:', existingInstance);
|
||||
console.log('📋 [EXISTING_INSTANCE] Dados retornados:', existingInstance);
|
||||
|
||||
// Verificação SIMPLES e DIRETA: instancia_zap deve existir E status deve ser 'conectado'
|
||||
const hasValidConnectedInstance = !!(
|
||||
// Verificação DIRETA: se existe instancia_zap E status é 'conectado'
|
||||
const hasValidInstance = !!(
|
||||
existingInstance &&
|
||||
existingInstance.instancia_zap &&
|
||||
existingInstance.status_instancia === 'conectado'
|
||||
);
|
||||
|
||||
console.log('✅ [EXISTING_INSTANCE] Resultado final da verificação:', {
|
||||
console.log('✅ [EXISTING_INSTANCE] Resultado:', {
|
||||
hasValidInstance,
|
||||
instancia_zap: existingInstance?.instancia_zap,
|
||||
status_instancia: existingInstance?.status_instancia,
|
||||
userEmail: userEmail,
|
||||
hasValidConnectedInstance: hasValidConnectedInstance
|
||||
status_instancia: existingInstance?.status_instancia
|
||||
});
|
||||
|
||||
setHasExistingInstance(hasValidConnectedInstance);
|
||||
setExistingInstanceData(hasValidConnectedInstance ? existingInstance : null);
|
||||
setHasExistingInstance(hasValidInstance);
|
||||
setExistingInstanceData(hasValidInstance ? existingInstance : null);
|
||||
|
||||
} catch (error) {
|
||||
console.error('❌ [EXISTING_INSTANCE] Erro ao verificar instância existente:', error);
|
||||
console.error('❌ [EXISTING_INSTANCE] Erro:', error);
|
||||
setHasExistingInstance(false);
|
||||
setExistingInstanceData(null);
|
||||
} finally {
|
||||
@ -54,9 +53,8 @@ export const useExistingInstanceCheck = (userEmail: string) => {
|
||||
checkExistingInstance();
|
||||
}, [userEmail]);
|
||||
|
||||
// Função para forçar re-verificação
|
||||
const recheckInstance = () => {
|
||||
console.log('🔄 [EXISTING_INSTANCE] Forçando re-verificação da instância');
|
||||
console.log('🔄 [EXISTING_INSTANCE] Re-verificação manual');
|
||||
checkExistingInstance();
|
||||
};
|
||||
|
||||
|
||||
@ -50,7 +50,7 @@ const WhatsApp = () => {
|
||||
|
||||
const userEmail = (localStorage.getItem('userEmail') || '').toLowerCase();
|
||||
|
||||
// USAR APENAS O HOOK CENTRALIZADO para verificação de instância existente
|
||||
// Hook centralizado para verificação de instância existente
|
||||
const {
|
||||
hasExistingInstance,
|
||||
checkingExistingInstance,
|
||||
@ -67,7 +67,7 @@ const WhatsApp = () => {
|
||||
addInstance(newInstance);
|
||||
setInstanceFound(true);
|
||||
|
||||
// Atualizar o estado do hook centralizado
|
||||
// Atualizar estado do hook centralizado
|
||||
setHasExistingInstance(true);
|
||||
setExistingInstanceData({
|
||||
instancia_zap: newInstance.instanceName,
|
||||
@ -83,7 +83,6 @@ const WhatsApp = () => {
|
||||
setTimeout(async () => {
|
||||
try {
|
||||
await checkAllInstancesStatus();
|
||||
// Forçar re-verificação após status check
|
||||
recheckInstance();
|
||||
} catch (error) {
|
||||
console.error("Error checking status after instance creation:", error);
|
||||
@ -92,7 +91,7 @@ const WhatsApp = () => {
|
||||
};
|
||||
|
||||
const handleDeleteInstanceWrapper = (instanceId: string) => {
|
||||
console.log(`🗑️ [WHATSAPP] Solicitação de exclusão da instância ID: ${instanceId}`);
|
||||
console.log(`🗑️ [WHATSAPP] Excluindo instância ID: ${instanceId}`);
|
||||
const instanceToDelete = instances.find(i => i.instanceId === instanceId);
|
||||
if (instanceToDelete) {
|
||||
handleDeleteInstance(instanceId, instanceToDelete.instanceName);
|
||||
@ -102,14 +101,12 @@ const WhatsApp = () => {
|
||||
setHasExistingInstance(false);
|
||||
setExistingInstanceData(null);
|
||||
}
|
||||
} else {
|
||||
console.error(`❌ [WHATSAPP] Instância com ID ${instanceId} não encontrada para exclusão`);
|
||||
}
|
||||
};
|
||||
|
||||
const hasInstances = Array.isArray(instances) && instances.length > 0;
|
||||
|
||||
// Mostrar loading enquanto verifica instância existente
|
||||
// Loading enquanto verifica instância
|
||||
if (checkingExistingInstance || isLoading) {
|
||||
return (
|
||||
<Layout>
|
||||
@ -118,14 +115,6 @@ const WhatsApp = () => {
|
||||
);
|
||||
}
|
||||
|
||||
console.log('🔍 [WHATSAPP] Estado atual da verificação FINAL:', {
|
||||
userEmail,
|
||||
hasExistingInstance,
|
||||
existingInstanceData,
|
||||
checkingExistingInstance,
|
||||
'Deve mostrar formulário?': !hasExistingInstance
|
||||
});
|
||||
|
||||
return (
|
||||
<Layout>
|
||||
<div className="space-y-6">
|
||||
@ -147,29 +136,12 @@ const WhatsApp = () => {
|
||||
className="flex items-center gap-2"
|
||||
>
|
||||
<RefreshCw className={`h-4 w-4 ${checkingExistingInstance ? 'animate-spin' : ''}`} />
|
||||
Verificar Instância
|
||||
</Button>
|
||||
|
||||
<Button
|
||||
variant="outline"
|
||||
onClick={refreshInstances}
|
||||
disabled={isRefreshing}
|
||||
className="flex items-center gap-2"
|
||||
>
|
||||
<RefreshCw className={`h-4 w-4 ${isRefreshing ? 'animate-spin' : ''}`} />
|
||||
{isRefreshing ? 'Atualizando...' : 'Atualizar Lista'}
|
||||
Atualizar
|
||||
</Button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{/* DEBUG: Mostrar estado atual */}
|
||||
<div className="bg-gray-100 p-2 rounded text-xs">
|
||||
<strong>DEBUG:</strong> hasExistingInstance = {hasExistingInstance.toString()},
|
||||
status = {existingInstanceData?.status_instancia || 'N/A'},
|
||||
instancia = {existingInstanceData?.instancia_zap || 'N/A'}
|
||||
</div>
|
||||
|
||||
{/* Mostra formulário APENAS se NÃO tiver instância conectada */}
|
||||
{/* Formulário de criação - APENAS se NÃO tiver instância conectada */}
|
||||
{!hasExistingInstance && (
|
||||
<CreateInstanceForm
|
||||
onInstanceCreated={handleInstanceCreated}
|
||||
@ -177,7 +149,7 @@ const WhatsApp = () => {
|
||||
/>
|
||||
)}
|
||||
|
||||
{/* Mensagem informativa quando já possui instância conectada */}
|
||||
{/* Mensagem quando já tem instância conectada */}
|
||||
{hasExistingInstance && existingInstanceData && (
|
||||
<div className="bg-green-50 border border-green-200 rounded-lg p-4">
|
||||
<div className="flex items-center">
|
||||
|
||||
Loading…
Reference in New Issue
Block a user