Add HTML5 project panel SSE updates
CI / python (push) Has been cancelled
CI / rust (push) Has been cancelled

This commit is contained in:
2026-05-17 02:46:21 +03:00
parent fb66cfba6f
commit 8a1c0da0ea
3 changed files with 34 additions and 9 deletions
+8 -6
View File
@@ -284,6 +284,7 @@ def render_html5_flowchart(
normalized_depth = min(max(depth, 1), 3)
hx_url = _flowchart_url(project_id, focus, normalized_depth)
oob_attr = ' hx-swap-oob="outerHTML"' if oob else ""
live_attr = ' sse-swap="project-flowchart"' if focus is None else ""
if flowchart is None:
return f"""
<div
@@ -293,6 +294,7 @@ def render_html5_flowchart(
hx-trigger="load"
hx-swap="outerHTML"
{oob_attr}
{live_attr}
>
<div class="panel-title">Карта связей</div>
<p class="muted padded">Сервер собирает граф проекта.</p>
@@ -311,7 +313,7 @@ def render_html5_flowchart(
class="flowchart-panel"
data-html5-flowchart
hx-get="{hx_url}"
hx-trigger="every 30s"
{live_attr}
hx-swap="outerHTML"
{oob_attr}
>
@@ -336,6 +338,7 @@ def render_html5_project_report(project_id: str, report: dict | None) -> str:
data-html5-project-report
hx-get="/html5/projects/{quote(project_id)}/report"
hx-trigger="load"
sse-swap="project-report"
hx-swap="outerHTML"
>
<div class="panel-title">Отчет проекта</div>
@@ -357,7 +360,7 @@ def render_html5_project_report(project_id: str, report: dict | None) -> str:
class="report-panel"
data-html5-project-report
hx-get="/html5/projects/{quote(project_id)}/report"
hx-trigger="every 15s"
sse-swap="project-report"
hx-swap="outerHTML"
>
<div class="panel-title">Отчет проекта</div>
@@ -424,9 +427,6 @@ def render_html5_object_report(
<div
class="report-panel"
data-html5-project-report
hx-get="/html5/projects/{quote(project_id)}/report"
hx-trigger="every 15s"
hx-swap="outerHTML"
{oob_attr}
>
<div class="panel-title">Отчет объекта</div>
@@ -487,6 +487,7 @@ def render_html5_review(
oob: bool = False,
) -> str:
oob_attr = ' hx-swap-oob="outerHTML"' if oob else ""
live_attr = ' sse-swap="project-review"' if title == "Review" and not oob else ""
if findings is None:
return f"""
<div
@@ -494,6 +495,7 @@ def render_html5_review(
data-html5-review
hx-get="/html5/projects/{quote(project_id)}/review"
hx-trigger="load"
{live_attr}
hx-swap="outerHTML"
{oob_attr}
>
@@ -510,7 +512,7 @@ def render_html5_review(
class="review-panel"
data-html5-review
hx-get="/html5/projects/{quote(project_id)}/review"
hx-trigger="every 20s"
{live_attr}
hx-swap="outerHTML"
{oob_attr}
>
+16 -3
View File
@@ -1,8 +1,9 @@
from __future__ import annotations
import json
import asyncio
import base64
import hashlib
import json
import os
import re
import shutil
@@ -1694,21 +1695,33 @@ async def html5_project_editor(project_id: str, q: str = "") -> Response:
@app.get("/html5/projects/{project_id}/events")
async def html5_project_events(project_id: str, once: bool = False) -> StreamingResponse:
def stream_status():
async def stream_status():
while True:
try:
snapshot = _project_snapshot_or_404(project_id)
fragment = render_html5_status(project_id, snapshot)
report = await project_report(project_id)
findings = await get_review(project_id)
flowchart = await project_flowchart(project_id, focus=None, depth=1, limit=80)
except HTTPException as error:
fragment = f'<span>project: {project_id}</span><span>error: {error.detail}</span>'
report = None
findings = None
flowchart = None
yield _html5_sse_event("status", fragment)
yield _html5_sse_event(
"authoring-changes",
render_html5_authoring_changes(project_id, _authoring_change_summaries(project_id)),
)
if report is not None:
yield _html5_sse_event("project-report", render_html5_project_report(project_id, report))
if findings is not None:
yield _html5_sse_event("project-review", render_html5_review(project_id, findings))
if flowchart is not None:
yield _html5_sse_event("project-flowchart", render_html5_flowchart(project_id, flowchart))
if once:
break
time.sleep(5)
await asyncio.sleep(5)
return StreamingResponse(
stream_status(),