Files
html/ethica-chatbot.html
2026-04-17 17:05:02 +02:00

118 lines
8.2 KiB
HTML

<!DOCTYPE html><html lang="fr"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1">
<title>Ethica — AI Chat HCP & Campagnes</title>
<link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=JetBrains+Mono:wght@400&display=swap" rel="stylesheet">
<style>
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#050a12;--bg2:#0c1424;--bg3:#132030;--tx:#d8e4f0;--tx2:#607890;--acc:#00c9a7;--acc2:#0ea5e9;--user:#0f2a40;--bot:#0a1828;--border:#1a3050}
body{background:var(--bg);color:var(--tx);font-family:'DM Sans',sans-serif;height:100vh;display:flex;flex-direction:column}
header{background:linear-gradient(135deg,#0a1830,#081428);padding:14px 20px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--border)}
header .logo{font-size:28px}
header h1{font-size:17px;font-weight:700;color:var(--acc)}
header .sub{font-size:11px;color:var(--tx2)}
header .stats{margin-left:auto;display:flex;gap:12px}
header .st{text-align:center;padding:4px 12px;background:var(--bg2);border-radius:6px;border:1px solid var(--border)}
header .st .n{font-size:14px;font-weight:700;color:var(--acc);font-family:'JetBrains Mono',monospace}
header .st .l{font-size:9px;color:var(--tx2);text-transform:uppercase}
.chips{padding:10px 20px;display:flex;gap:8px;overflow-x:auto;background:var(--bg2);border-bottom:1px solid var(--border)}
.chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg);font-size:12px;color:var(--tx2);cursor:pointer;white-space:nowrap;transition:.2s}
.chip:hover{border-color:var(--acc);color:var(--acc);background:rgba(0,201,167,.05)}
.chat{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:80%;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.6;animation:fadeIn .3s}
.msg.bot{background:var(--bot);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:2px}
.msg.user{background:var(--user);align-self:flex-end;border-bottom-right-radius:2px}
.msg pre{background:var(--bg);padding:8px 12px;border-radius:6px;margin:8px 0;overflow-x:auto;font-family:'JetBrains Mono',monospace;font-size:12px}
.msg code{font-family:'JetBrains Mono',monospace;font-size:12px;background:rgba(0,201,167,.1);padding:1px 4px;border-radius:3px}
.input-bar{padding:12px 20px;background:var(--bg2);border-top:1px solid var(--border);display:flex;gap:10px}
.input-bar input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px 16px;color:var(--tx);font-size:14px;font-family:'DM Sans',sans-serif;outline:none}
.input-bar input:focus{border-color:var(--acc)}
.input-bar button{background:var(--acc);color:#000;border:none;border-radius:8px;padding:12px 20px;font-weight:700;cursor:pointer;font-size:14px}
.input-bar button:hover{opacity:.9}
.typing{color:var(--tx2);font-size:12px;padding:4px 16px;font-style:italic}
.links{padding:8px 20px;background:var(--bg);display:flex;gap:12px;border-top:1px solid var(--border)}
.links a{color:var(--tx2);font-size:11px;text-decoration:none;padding:4px 10px;border:1px solid var(--border);border-radius:4px}
.links a:hover{color:var(--acc);border-color:var(--acc)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(max-width:768px){header .stats{display:none}.msg{max-width:95%}}
</style></head><body>
<header>
<span class="logo">💊</span>
<div><h1>Ethica AI — HCP Intelligence & Campagnes</h1><div class="sub">IA souveraine spécialisée pharma · Emailing · Marketing B2B</div></div>
<div class="stats" id="hdr-stats"></div>
</header>
<div class="chips" id="chips">
<div class="chip" data-q="Combien de HCPs par pays">📊 HCPs par pays</div>
<div class="chip" data-q="Quelles spécialités médicales sont couvertes">🩺 Spécialités</div>
<div class="chip" data-q="État des campagnes email Ethica">📧 Campagnes</div>
<div class="chip" data-q="Taux d'ouverture et de clic email">📈 Taux ouverture</div>
<div class="chip" data-q="Combien de senders actifs">✉️ Senders</div>
<div class="chip" data-q="Stratégie warmup email B2B pharma">🔥 Warmup</div>
<div class="chip" data-q="Réglementation RGPD données santé Maroc">⚖️ RGPD Santé</div>
<div class="chip" data-q="Comment améliorer la délivrabilité email pharma">📬 Délivrabilité</div>
<div class="chip" data-q="Analyse concurrentielle plateforme HCP Maghreb">🔍 Concurrence</div>
<div class="chip" data-q="Pricing campagne email HCP 3 paliers">💰 Pricing</div>
</div>
<div class="chat" id="chat">
<div class="msg bot">Bonjour ! Je suis <strong>Ethica AI</strong>, votre assistant spécialisé en intelligence HCP et campagnes email pharma B2B.<br><br>Je connais vos <strong id="hcp-count">131K+</strong> contacts médecins au Maghreb, les spécialités couvertes, et je peux vous aider sur la stratégie emailing, warmup, délivrabilité, RGPD santé et pricing.<br><br>Posez une question ou cliquez un raccourci ci-dessus.</div>
</div>
<div class="input-bar">
<input type="text" id="input" placeholder="Posez votre question pharma / emailing..." autocomplete="off">
<button onclick="send()">Envoyer</button>
</div>
<div class="links">
<a href="/ethica-hub.html">Hub Ethica</a>
<a href="/arsenal-proxy/ethica-dashboard.html">Dashboard</a>
<a href="/ethica-hcp-manager.html">HCP Manager</a>
<a href="/ethica-drill.html">Drill Analytics</a>
<a href="/ethica-pipeline.html">Pipeline</a>
<a href="/ethica-sms.html">SMS</a>
</div>
<script>
const API = '/api/opus5-weval-ia-fast-safe.php';
const STATS_API = '/api/ethica-stats.php';
const ETHICA_PREFIX = '[CONTEXTE: Tu es Ethica AI, expert pharma B2B Maghreb. Spécialisé HCP (médecins, pharmaciens, dentistes), campagnes email marketing santé, warmup, délivrabilité, RGPD santé, pricing. Base: 131K+ HCPs validés (DZ 69%, MA 15%, TN 14%). 14 spécialités. 10 senders. Réponds en expert pharma/emailing concis et actionnable.] ';
const chat = document.getElementById('chat');
const input = document.getElementById('input');
// Load live stats
fetch(STATS_API).then(r=>r.text().then(t=>{/* HTML_GUARD_V2_BATCH */var q=(t||"").trim();if(q.startsWith("<!DOCTYPE")||q.startsWith("<html")){return{error:"[HTTP "+r.status+"]",isHtmlError:true}}try{return JSON.parse(q)}catch(e){return{error:"JSON "+e.message}}})).then(d=>{
const t = d.total || d.count || '131K+';
document.getElementById('hcp-count').textContent = t.toLocaleString ? t.toLocaleString('fr') : t;
document.getElementById('hdr-stats').innerHTML = `
<div class="st"><div class="n">${typeof t==='number'?t.toLocaleString('fr'):t}</div><div class="l">HCPs</div></div>
<div class="st"><div class="n">${d.countries||3}</div><div class="l">Pays</div></div>
<div class="st"><div class="n">${d.specialties||14}</div><div class="l">Spécialités</div></div>
`;
}).catch(()=>{});
// Chips
document.querySelectorAll('.chip').forEach(c=>c.onclick=()=>{input.value=c.dataset.q;send()});
// Enter key
input.addEventListener('keydown',e=>{if(e.key==='Enter'&&!e.shiftKey){e.preventDefault();send()}});
function addMsg(text, cls){
const d=document.createElement('div');d.className='msg '+cls;
d.innerHTML=text.replace(/```(\w+)?\n([\s\S]*?)```/g,'<pre>$2</pre>').replace(/\*\*(.*?)\*\*/g,'<strong>$1</strong>').replace(/`(.*?)`/g,'<code>$1</code>').replace(/\n/g,'<br>');
chat.appendChild(d);chat.scrollTop=chat.scrollHeight;return d;
}
async function send(){
const q=input.value.trim();if(!q)return;
addMsg(q,'user');input.value='';
const typing=document.createElement('div');typing.className='typing';typing.textContent='Ethica AI réfléchit...';chat.appendChild(typing);chat.scrollTop=chat.scrollHeight;
try{
const r=await fetch(API,{method:'POST',headers:{'Content-Type':'application/json'},body:JSON.stringify({message:ETHICA_PREFIX+q})});
/* HTML_GUARD_V2_BATCH */ const _t_d=await r.text(); let d=null; {var _q=(_t_d||"").trim();if(_q.startsWith("<!DOCTYPE")||_q.startsWith("<html")){d={error:"[HTTP "+(r.status||"?")+"] Backend indisponible",isHtmlError:true};}else{try{d=JSON.parse(_q)}catch(e){d={error:"[JSON] "+e.message}}}}
typing.remove();
addMsg(d.response||d.content||d.error||'Erreur','bot');
}catch(e){typing.remove();addMsg('Erreur de connexion','bot')}
}
</script>
<!-- CARTO_REMOVED -->
</body></html>