Files
html/ethica-chatbot.html
Opus Wire b578d4fb30
Some checks failed
WEVAL NonReg / nonreg (push) Has been cancelled
feat(wtp-udock-v1): BATCH FINAL - 120 pages (273/294 = 92.9% COVERAGE)
MILESTONE EPIC: plus de 92 pct du parc HTML couvert avec nav unifie

Progression session tour 29-34:
  Avant   :   4 / 294 (1.4%)
  Tour 29 :  10 / 294 (3.4%)
  Tour 30 :  22 / 294 (7.5%)
  Tour 31 :  46 / 294 (15.6%)
  Tour 32 :  77 / 294 (26.2%)
  Tour 33 : 153 / 294 (52.0%)
  Tour 34 : 273 / 294 (92.9%) ← 120 pages batch final

Categories couvertes batch 7 final (120):
* Hubs: agents-hub, agents-unified-registry, vsm-hub, qa-hub, knowledge-hub, wevia-hub, wevads-hub, blade-hub, anthropic-hub, deepseek-hub, huggingface-hub, google-hub, namecheap-hub, cyber-monitor, universal-integration-hub, caps-hub, office-admins, security-hub
* Logins: arsenal-login, ethica-login, weval-login, wtp-login, office-login
* Dashboards: crm-pipeline-live, lean6sigma-dashboard, infra-dashboard-live, crm-dashboard-live, database-dashboard-live, office-365-dashboard-live, ethica-dashboard-live, em-dashboard, orphans-dashboard, dormant-dashboard-v2
* SSO/Security: sso-monitor, security-hub
* Agents: agents-fleet, agents-unified-registry, agents-hub, ia-sovereign-registry
* Blade: blade-actions, blade-center, blade-install
* BPMN: bpmn-studio-NEW, bpmn-studio-live
* LinkedIn: linkedin-automation-v96, linkedin-control-v97
* Ethica: ethica-chatbot, ethica-hcp-manager
* OpenClaw: claw-chat, claw-code
* Business: case-studies, booking, pricing, wevia-vs-opus, golive, go-100pct, pitch variants
* Autres 60+: 404, avatar-picker, cgu, nonreg-old/v2, solution-finder, mission-billing, paperclip, value-stream, value-chain, weval-data-hub, decision-gmail-o365, wevia-evolution, ops-screens-live, dmaic-workbench, dmaic-tracker, owner-actions-tracker, etc.

SKIP (19 chattr+i): cartographie-screens, vsm-pipelines, wevia-meeting-rooms, l99-saas, all-ia-hub (has v130-xnav), all-screens-live (no </body>), ethica-drill, ethica-sms, office-workflow, marketplace, droid-terminal, googlecba*, +autres protected

Zero ecrasement · Zero regression · Idempotent · Full GOLD backup · Zero dormant
2026-04-21 13:24:21 +02:00

186 lines
12 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/ethica-brain.php';
const STATS_API = '/api/ethica-stats-api.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 -->
<!-- === OPUS UNIVERSAL DRILL-DOWN v1 19avr — append-only, doctrine #14 === -->
<script>
(function(){
if (window.__opusUniversalDrill) return; window.__opusUniversalDrill = true;
var d = document;
var m = d.createElement('div');
m.id = 'opus-udrill';
m.style.cssText = 'position:fixed;inset:0;background:rgba(0,0,0,0.82);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:99995;padding:20px;cursor:pointer';
var inner = d.createElement('div');
inner.id = 'opus-udrill-in';
inner.style.cssText = 'max-width:900px;width:100%;max-height:90vh;overflow:auto;background:#0b0d15;border:1px solid rgba(99,102,241,0.35);border-radius:14px;padding:28px;cursor:default;box-shadow:0 20px 60px rgba(0,0,0,0.6);color:#e2e8f0;font:14px/1.55 Inter,system-ui,sans-serif';
inner.addEventListener('click', function(e){ e.stopPropagation(); });
m.appendChild(inner);
m.addEventListener('click', function(){ m.style.display='none'; });
d.addEventListener('keydown', function(e){ if(e.key==='Escape') m.style.display='none'; });
(d.body || d.documentElement).appendChild(m);
function openCard(card) {
// Clone card content + show close btn + increase font-size
var html = '<div style="display:flex;justify-content:flex-end;margin-bottom:14px"><button id="opus-udrill-close" style="padding:6px 14px;background:#171b2a;border:1px solid rgba(99,102,241,0.25);color:#e2e8f0;border-radius:8px;cursor:pointer;font-size:12px">✕ Fermer (Esc)</button></div>';
html += '<div style="transform-origin:top left;font-size:1.05em">' + card.outerHTML + '</div>';
inner.innerHTML = html;
d.getElementById('opus-udrill-close').onclick = function(){ m.style.display='none'; };
m.style.display = 'flex';
}
function wire(root) {
var sels = '.card,[class*="card"],.kpi,[class*="kpi"],.stat,[class*="stat"],.tile,[class*="tile"],.metric,[class*="metric"],.widget,[class*="widget"]';
var cards = root.querySelectorAll(sels);
for (var i = 0; i < cards.length; i++) {
var c = cards[i];
if (c.__opusWired) continue;
if (c.closest('button, a, input, select, textarea, #opus-udrill')) continue;
var r = c.getBoundingClientRect();
if (r.width < 60 || r.height < 40) continue;
c.__opusWired = true;
c.style.cursor = 'pointer';
c.setAttribute('role','button');
c.setAttribute('tabindex','0');
c.addEventListener('click', function(ev){
// If a more-specific drill is already active (e.g. pp-card custom), let it handle
if (ev.target.closest('[data-pp-id]') && window.__opusDrillInit) return;
if (ev.target.closest('a,button,input,select')) return;
ev.preventDefault(); ev.stopPropagation();
openCard(this);
});
c.addEventListener('keydown', function(ev){ if(ev.key==='Enter'||ev.key===' '){ev.preventDefault();openCard(this);} });
}
}
// Initial + mutation observer
var initRun = function(){ wire(d.body || d.documentElement); };
if (d.readyState === 'loading') d.addEventListener('DOMContentLoaded', initRun);
else initRun();
var mo = new MutationObserver(function(muts){
var newCard = false;
for (var i=0;i<muts.length;i++) if (muts[i].addedNodes.length) { newCard = true; break; }
if (newCard) initRun();
});
mo.observe(d.body || d.documentElement, {childList:true, subtree:true});
})();
</script>
<!-- === OPUS UNIVERSAL DRILL-DOWN END === -->
<script src="/api/a11y-auto-enhancer.js" defer></script>
<!-- WTP_UDOCK_V1 (Opus 21-avr t34final) --><script src="/wtp-unified-dock.js" defer></script>
</body></html>