auto-sync-1105

This commit is contained in:
opus
2026-04-22 11:05:01 +02:00
parent 814ba61691
commit 835e1f316b
8 changed files with 172 additions and 3 deletions

View File

@@ -0,0 +1,72 @@
<?php
header("Content-Type: application/json");
$path = "/var/www/html/wevia.html";
$c = @file_get_contents($path);
$orig = strlen($c);
// Find the done handler and augment it with mermaid rendering
// The anchor: 'else if (type === \'done\') {' to its closing brace
$anchor = "else if (type === 'done') {
finalFileUrl = data.file_url;";
if (strpos($c, $anchor) === false) {
echo json_encode(["error"=>"done handler anchor not found"]);
exit;
}
// Replace with enhanced version that renders mermaid when detected
$new = "else if (type === 'done') {
finalFileUrl = data.file_url;
// === AMBRE-V5-MERMAID-RENDER wave-263 ===
// If fullResponse contains mermaid code → render SVG inline
try {
var _mcode = null;
if (data.mermaid_code) _mcode = data.mermaid_code;
else if (fullResponse) {
// Detect mermaid patterns at start of response
var _fr = fullResponse.trim();
if (/^(sequenceDiagram|flowchart|graph\s+[A-Z]{1,2}|classDiagram|stateDiagram|erDiagram|gantt|pie|journey|gitGraph|mindmap|timeline)\b/.test(_fr)) {
_mcode = _fr;
} else {
// Search inside for ``` mermaid block
var _m = fullResponse.match(/```mermaid\\s*([\\s\\S]+?)```/);
if (_m) _mcode = _m[1].trim();
else {
// or raw mermaid after 'Schema Mermaid:' label
var _m2 = fullResponse.match(/(?:Schema Mermaid|Diagramme)[^\\n]*\\n([\\s\\S]+)$/i);
if (_m2 && /^(sequenceDiagram|flowchart|graph|classDiagram|stateDiagram)/.test(_m2[1].trim())) _mcode = _m2[1].trim();
}
}
}
if (_mcode && window.mermaid && currentPhaseEl) {
// Sanitize accents for mermaid parser
var _clean = _mcode.normalize ? _mcode.normalize('NFD').replace(/[\\u0300-\\u036f]/g, '') : _mcode;
var _svgId = 'wv-mermaid-' + Date.now() + '-' + Math.floor(Math.random()*999);
var _mContainer = document.createElement('div');
_mContainer.id = _svgId + '-wrap';
_mContainer.style.cssText = 'margin-top:12px;padding:16px;background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto';
currentPhaseEl.appendChild(_mContainer);
try {
window.mermaid.render(_svgId, _clean).then(function(r){
_mContainer.innerHTML = r.svg;
}).catch(function(err){
_mContainer.innerHTML = '<pre style=\"color:#b91c1c;font-size:11px\">Mermaid render error: ' + (err.message||err) + '\\n\\n' + _clean.replace(/</g,'&lt;') + '</pre>';
});
} catch(e) {
_mContainer.innerHTML = '<pre style=\"font-size:11px\">' + _clean.replace(/</g,'&lt;') + '</pre>';
}
}
} catch(eMermaid) { console.warn('[V5-MERMAID-RENDER]', eMermaid); }
// === END AMBRE-V5-MERMAID-RENDER ===";
$c = str_replace($anchor, $new, $c);
$backup = "/opt/wevads/vault/wevia.html.GOLD-" . date("Ymd-His") . "-wave263-mermaid";
@copy($path, $backup);
$wrote = @file_put_contents($path, $c);
echo json_encode([
"delta" => strlen($c) - $orig,
"wrote" => $wrote,
"backup" => basename($backup),
]);

15
api/ambre-sse2.php Normal file
View File

@@ -0,0 +1,15 @@
<?php
header("Content-Type: text/plain");
$c = @file_get_contents("/var/www/html/wevia.html");
echo "size: " . strlen($c) . "\n";
echo "Claude count: " . substr_count($c, "Claude") . "\n";
echo "WEVIA-pattern: " . preg_match_all("/WEVIA[- ]?[pP]attern/", $c) . "\n";
// Find around "phase" type handling
$pos = strpos($c, "type === 'header'");
if ($pos === false) $pos = strpos($c, 'type==="header"');
if ($pos === false) $pos = strpos($c, "'header'");
echo "header pos: $pos\n";
if ($pos !== false) {
echo substr($c, $pos, 2500);
}

11
api/ambre-sse3.php Normal file
View File

@@ -0,0 +1,11 @@
<?php
header("Content-Type: text/plain");
$c = @file_get_contents("/var/www/html/wevia.html");
// Find WEVIA-pattern header rendering - that's the SSE handler for 'header' type
$pos = strpos($c, "WEVIA-pattern");
echo "WEVIA-pattern 1st at: $pos\n\n";
if ($pos !== false) {
echo "=== Context (go back to find handler start) ===\n";
echo substr($c, max(0, $pos - 1500), 3000);
}

9
api/ambre-sse4.php Normal file
View File

@@ -0,0 +1,9 @@
<?php
header("Content-Type: text/plain");
$c = @file_get_contents("/var/www/html/wevia.html");
// Get the rest of handleEvent (from WEVIA-pattern onwards to end of function)
$pos = strpos($c, "WEVIA-pattern");
$end = strpos($c, "eventSource.close", $pos);
if ($end === false) $end = $pos + 6000;
echo "=== handleEvent from 96870 to " . ($pos + 6000) . " ===\n";
echo substr($c, $pos + 1800, 5000);

View File

@@ -1,5 +1,5 @@
{
"timestamp": "2026-04-22T10:30:13",
"timestamp": "2026-04-22T11:00:13",
"features": {
"total": 36,
"pass": 35
@@ -13,7 +13,7 @@
"score": 97.2,
"log": [
"=== UX AGENT v1.0 ===",
"Time: 2026-04-22 10:30:02",
"Time: 2026-04-22 11:00:01",
" core: 4/4",
" layout: 3/4",
" interaction: 6/6",

View File

@@ -1,7 +1,7 @@
{
"ok": true,
"version": "V83-business-kpi",
"ts": "2026-04-22T08:59:09+00:00",
"ts": "2026-04-22T09:04:29+00:00",
"summary": {
"total_categories": 8,
"total_kpis": 64,

BIN
screenshots/wave265-top.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 114 KiB

View File

@@ -1434,11 +1434,73 @@ function send() {
}
else if (type === 'done') {
finalFileUrl = data.file_url;
// === AMBRE-V5-MERMAID-RENDER wave-263 ===
// If fullResponse contains mermaid code → render SVG inline
try {
var _mcode = null;
if (data.mermaid_code) _mcode = data.mermaid_code;
else if (fullResponse) {
// Detect mermaid patterns at start of response
var _fr = fullResponse.trim();
if (/^(sequenceDiagram|flowchart|graph\s+[A-Z]{1,2}|classDiagram|stateDiagram|erDiagram|gantt|pie|journey|gitGraph|mindmap|timeline)\b/.test(_fr)) {
_mcode = _fr;
} else {
// Search inside for ``` mermaid block
var _m = fullResponse.match(/```mermaid\s*([\s\S]+?)```/);
if (_m) _mcode = _m[1].trim();
else {
// or raw mermaid after 'Schema Mermaid:' label
var _m2 = fullResponse.match(/(?:Schema Mermaid|Diagramme)[^\n]*\n([\s\S]+)$/i);
if (_m2 && /^(sequenceDiagram|flowchart|graph|classDiagram|stateDiagram)/.test(_m2[1].trim())) _mcode = _m2[1].trim();
}
}
}
if (_mcode && window.mermaid && currentPhaseEl) {
// Sanitize accents for mermaid parser
var _clean = _mcode.normalize ? _mcode.normalize('NFD').replace(/[\u0300-\u036f]/g, '') : _mcode;
var _svgId = 'wv-mermaid-' + Date.now() + '-' + Math.floor(Math.random()*999);
var _mContainer = document.createElement('div');
_mContainer.id = _svgId + '-wrap';
_mContainer.style.cssText = 'margin-top:12px;padding:16px;background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto';
currentPhaseEl.appendChild(_mContainer);
try {
window.mermaid.render(_svgId, _clean).then(function(r){
_mContainer.innerHTML = r.svg;
}).catch(function(err){
_mContainer.innerHTML = '<pre style="color:#b91c1c;font-size:11px">Mermaid render error: ' + (err.message||err) + '\n\n' + _clean.replace(/</g,'&lt;') + '</pre>';
});
} catch(e) {
_mContainer.innerHTML = '<pre style="font-size:11px">' + _clean.replace(/</g,'&lt;') + '</pre>';
}
}
} catch(eMermaid) { console.warn('[V5-MERMAID-RENDER]', eMermaid); }
// === END AMBRE-V5-MERMAID-RENDER ===
// Format final response with link if present
if (currentChunkEl && finalFileUrl) {
var _u = finalFileUrl; var linkHtml = fullResponse.split(_u).join('<a href="'+_u+'" target="_blank" style="color:#2563eb;font-weight:600">'+finalFileUrl+'</a>');
currentChunkEl.innerHTML = linkHtml;
}
// V168 mermaid-postprocess · si fullResponse contient mermaid code, rendre le SVG
try {
var _v168_mermaidRegex = /```mermaid\s*([\s\S]+?)```|((?:graph|flowchart|sequenceDiagram|classDiagram|stateDiagram|erDiagram|gantt|pie|mindmap)\s+[\s\S]+?)(?=\n\n|$)/i;
var _v168_m = _v168_mermaidRegex.exec(fullResponse);
if (_v168_m && currentChunkEl && window.mermaid) {
var _v168_code = (_v168_m[1] || _v168_m[2] || "").trim();
// Clean LLM wrapping (backticks, quotes)
_v168_code = _v168_code.replace(/^["'`]+|["'`]+$/g, "").trim();
if (_v168_code.length > 10 && /^(graph|flowchart|sequenceDiagram|classDiagram|stateDiagram|erDiagram|gantt|pie|mindmap|journey)/i.test(_v168_code)) {
var _v168_id = "v168-mermaid-" + Date.now();
var _v168_wrapper = document.createElement("div");
_v168_wrapper.style.cssText = "margin-top:12px;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px";
_v168_wrapper.innerHTML = "<div class=\"mermaid\" id=\"" + _v168_id + "\">" + _v168_code + "</div>";
currentChunkEl.parentNode.appendChild(_v168_wrapper);
setTimeout(function() {
try { window.mermaid.init(undefined, "#" + _v168_id); }
catch(e) { console.warn("V168 mermaid render err:", e); }
}, 50);
}
}
} catch(_v168_err) { console.warn("V168 mermaid-postprocess err:", _v168_err); }
var elapsed = ((performance.now() - startTime) / 1000).toFixed(1);
var footer = document.createElement('div');
footer.style.cssText = 'margin-top:12px;padding-top:10px;border-top:1px solid #eee;display:flex;gap:8px;flex-wrap:wrap;font-size:11px;color:#999';