57 lines
8.6 KiB
HTML
Executable File
57 lines
8.6 KiB
HTML
Executable File
<!DOCTYPE html><html lang="fr"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>Smart Report | Arsenal</title><link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet"><style>*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#060a14;--s:#0c1220;--c:#111827;--b:#1e293b;--cy:#22d3ee;--gn:#10b981;--rd:#ef4444;--or:#f59e0b;--pu:#a78bfa;--pk:#ec4899;--t:#e2e8f0;--d:#64748b;--f:"DM Sans",sans-serif;--m:"JetBrains Mono",monospace}body{font-family:var(--f);background:var(--bg);color:var(--t);min-height:100vh}.app{max-width:1440px;margin:0 auto;padding:24px}.hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--b)}.hdr h1{font-size:22px;font-weight:700}.hdr h1 span{color:var(--cy)}.btns{display:flex;gap:8px}.btn{padding:8px 18px;border:none;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;color:#fff;transition:.2s}.btn-p{background:linear-gradient(135deg,var(--cy),#0891b2)}.btn-s{background:var(--c);border:1px solid var(--b);color:var(--t)}.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}.g{display:grid;gap:16px;margin-bottom:20px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:1fr 1fr}.cd{background:var(--s);border:1px solid var(--b);border-radius:14px;padding:20px;transition:.2s}.cd:hover{border-color:rgba(34,211,238,.2)}.st{text-align:center;padding:16px}.sv{font-family:var(--m);font-size:26px;font-weight:700;line-height:1}.sl{font-size:10px;color:var(--d);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.ct{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--d);margin-bottom:14px;display:flex;align-items:center;gap:6px}table{width:100%;border-collapse:collapse;font-size:12px}th{text-align:left;padding:10px 12px;color:var(--d);font-size:10px;text-transform:uppercase;border-bottom:1px solid var(--b);letter-spacing:.5px}td{padding:10px 12px;border-bottom:1px solid rgba(30,41,59,.3)}.badge{padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;display:inline-block}.b-ok{background:rgba(16,185,129,.12);color:var(--gn)}.b-w{background:rgba(245,158,11,.12);color:var(--or)}.b-err{background:rgba(239,68,68,.12);color:var(--rd)}.b-info{background:rgba(34,211,238,.12);color:var(--cy)}.b-pu{background:rgba(167,139,250,.12);color:var(--pu)}.bar{height:6px;border-radius:3px;background:var(--c);overflow:hidden;flex:1}.bar-fill{height:100%;border-radius:3px;transition:.3s}.log{font-family:var(--m);font-size:11px;background:var(--bg);border:1px solid var(--b);border-radius:8px;padding:12px;max-height:200px;overflow-y:auto;line-height:1.8}.log .ts{color:var(--d)}.log .ok{color:var(--gn)}.log .er{color:var(--rd)}.log .inf{color:var(--cy)}.tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--b);padding-bottom:8px}.tab{padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;border-radius:8px 8px 0 0;background:transparent;color:var(--d);border:none}.tab.a{background:var(--s);color:var(--cy);border-bottom:2px solid var(--cy)}.tab:hover{color:var(--t)}.empty{text-align:center;padding:40px;color:var(--d);font-size:13px}@media(max-width:900px){.g4,.g3{grid-template-columns:1fr 1fr}} .report-card{background:var(--c);border:1px solid var(--b);border-radius:10px;padding:16px;margin-bottom:12px;cursor:pointer;transition:.2s}.report-card:hover{border-color:var(--cy);transform:translateY(-2px)}.report-title{font-weight:600;font-size:14px;margin-bottom:4px}.report-desc{font-size:11px;color:var(--d)}.report-meta{display:flex;gap:12px;margin-top:8px;font-size:10px;color:var(--d)}.preview{background:var(--bg);border:1px solid var(--b);border-radius:10px;padding:20px;font-family:var(--m);font-size:12px;line-height:1.8;white-space:pre-wrap;max-height:400px;overflow-y:auto}</style></head><body><div class="app">
|
|
<div class="hdr"><h1>📊 <span>Smart</span> Report</h1><div class="btns"><button class="btn btn-p" onclick="generateAll()">📝 Générer Rapport Complet</button></div></div>
|
|
<div class="g g4">
|
|
<div class="cd st"><div class="sv" style="color:var(--cy)" id="kSources">—</div><div class="sl">Sources de Données</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--gn)" id="kReports">4</div><div class="sl">Rapports Dispo</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--or)" id="kLast">—</div><div class="sl">Dernier Rapport</div></div>
|
|
<div class="cd st"><div class="sv" style="color:var(--pu)" id="kMetrics">—</div><div class="sl">Métriques Collectées</div></div>
|
|
</div>
|
|
<div class="g g2">
|
|
<div class="cd"><div class="ct">📋 Rapports Disponibles</div>
|
|
<div class="report-card" onclick="generate('infra')"><div class="report-title">🏗️ Infrastructure Report</div><div class="report-desc">Serveurs MTA, VMTAs, providers cloud, état des services</div><div class="report-meta"><span>⏱ ~5s</span><span>📊 MTA + N8N + Cloud</span></div></div>
|
|
<div class="report-card" onclick="generate('offers')"><div class="report-title">🎯 Offers & Revenue Report</div><div class="report-desc">54 offres, payouts, répartition par pays et type</div><div class="report-meta"><span>⏱ ~3s</span><span>📊 Affiliate Networks</span></div></div>
|
|
<div class="report-card" onclick="generate('brain')"><div class="report-title">🧠 Brain Engine Report</div><div class="report-desc">Configs gagnantes, taux inbox, optimisations</div><div class="report-meta"><span>⏱ ~4s</span><span>📊 Brain Configs + Results</span></div></div>
|
|
<div class="report-card" onclick="generate('accounts')"><div class="report-title">📧 Accounts Report</div><div class="report-desc">1352 comptes O365, statuts, warmup, rotation</div><div class="report-meta"><span>⏱ ~6s</span><span>📊 Office Accounts</span></div></div>
|
|
</div>
|
|
<div class="cd"><div class="ct">📝 Aperçu du Rapport</div><div id="preview" class="preview">Sélectionnez un rapport à générer...</div></div>
|
|
</div>
|
|
</div><script>
|
|
async function generate(type){
|
|
const p=document.getElementById('preview');p.textContent='⏳ Génération en cours...';
|
|
try{
|
|
let report='═══════════════════════════════════════════\n';
|
|
report+=' WEVADS ARSENAL — '+type.toUpperCase()+' REPORT\n';
|
|
report+=' Date: '+new Date().toLocaleString('fr')+'\n';
|
|
report+='═══════════════════════════════════════════\n\n';
|
|
if(type==='offers'||type==='all'){
|
|
const r=await fetch('/api/offer-engine.php?action=stats');const d=await r.json();const s=d.data||{};
|
|
report+='📊 OFFERS OVERVIEW\n';
|
|
report+=' Total offres: '+s.total_offers+'\n Actives: '+s.active_offers+'\n Pays: '+s.countries+'\n Sponsors: '+s.networks+'\n\n';
|
|
const r2=await fetch('/api/offer-engine.php?action=countries');const d2=await r2.json();
|
|
report+='🌍 PAR PAYS\n';(d2.data||[]).forEach(c=>{report+=' '+c.country_code+': '+c.cnt+' offres (avg $'+parseFloat(c.avg_payout).toFixed(2)+')\n'});report+='\n';
|
|
}
|
|
if(type==='infra'||type==='all'){
|
|
const r=await fetch('/api/mta.php?action=stats');const d=await r.json();
|
|
report+='🏗️ INFRASTRUCTURE\n';report+=' '+JSON.stringify(d.data||d,null,2)+'\n\n';
|
|
}
|
|
if(type==='brain'||type==='all'){
|
|
const r=await fetch('/api/brain-combo.php?action=stats');const d=await r.json();
|
|
report+='🧠 BRAIN ENGINE\n';report+=' '+JSON.stringify(d.data||d,null,2)+'\n\n';
|
|
}
|
|
if(type==='accounts'||type==='all'){
|
|
const r=await fetch('/api/account-creator.php?action=stats');const d=await r.json();
|
|
report+='📧 ACCOUNTS\n';report+=' '+JSON.stringify(d.data||d,null,2)+'\n\n';
|
|
}
|
|
report+='═══════════════════════════════════════════\n';
|
|
report+=' Fin du rapport — Généré automatiquement\n';
|
|
report+='═══════════════════════════════════════════';
|
|
p.textContent=report;
|
|
document.getElementById('kLast').textContent=new Date().toLocaleTimeString('fr');
|
|
document.getElementById('kSources').textContent=type==='all'?'4':'1';
|
|
}catch(e){p.textContent='❌ Erreur: '+e.message}
|
|
}
|
|
function generateAll(){generate('all');document.getElementById('kSources').textContent='4'}
|
|
document.getElementById('kSources').textContent='4';document.getElementById('kMetrics').textContent='20+';
|
|
</script>
|
|
</body></html>
|