4 tablas migradas a data_table::render con CellRenderers Fase 1 (Badge, Duration).
Linux build: app es Windows-only (CMakeLists return() en Linux, no genera target).
Windows build: OK, 16MB, desplegado a Desktop/apps/navegator_dashboard/.
fn doctor cpp-apps: OK (0 BeginTable inline restantes).
- ##browsers: 6 data cols with Mode Badge (#headless=#f59e0b, visible=#22c55e); actions as inline button list
- ##tabs: 5 data cols with Type Badge + Attached Badge; actions as inline button list
- ##wsframes: 4 cols with Dir Badge (send=#3b82f6, recv=#22c55e) + Op Badge (text/binary/close/ping/pong)
- ##requests: 7 cols with Status Badge (2xx/3xx/4xx/5xx), Method Badge (GET/POST/PUT/DELETE/PATCH), Time Duration renderer; Waterfall col omitted (requires custom ImDrawList, not a Fase-1 renderer)
- CMakeLists.txt: add fn_table_viz linkage (guarded by TARGET check for lua-absent builds)
- app.md: add 12 uses_functions IDs for fn_table_viz stack
- fn doctor cpp-apps: navegator_dashboard now OK (0 inline BeginTable remaining)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Bug: al cargar un layout guardado, paneles que estaban dockeados a la
ventana principal aparecian flotantes. Causa: drain_layout_pending()
(que llama ImGui::LoadIniSettingsFromMemory) corria mid-frame dentro
de render(), DESPUES de menubar y de auto-dockspace. ImGui requiere
que el load suceda ANTES de cualquier Begin() del frame para que las
dock-nodes guardadas se restauren correctamente.
Fix:
- Mover drain_layout_pending al hook cfg.pre_frame del framework, que
se ejecuta entre NewFrame y menubar (orden correcto). Requiere el
commit asociado en cpp/framework/app_base.{h,cpp} que añade el hook.
- Eliminar la llamada redundante a ImGui::DockSpaceOverViewport en
render(): el framework ya la hace via cfg.auto_dockspace=true.
dashboard_state.h: declara render() para que tests puedan referenciarla
con `extern "C"`-like visibility (consistente con resto del API).
tests/: 7/7 siguen pasando.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Bug reportado: tabla Network vacia. Causa real: sin actividad de red en la
pestaña no hay eventos Network.* — la tabla solo se llena cuando el browser
realmente hace peticiones. Faltaba un boton para forzar Page.reload desde la
UI y un overview visual de actividad.
NetworkSession::reload_page(ignore_cache) — envia Page.reload por la WS CDP
activa. Equivalente a F5 / Ctrl+Shift+R.
NetworkSession::ws_frames_in/bytes_in/bytes_out — accessors a stats del CDP
WebSocket subyacente, expuestos para diagnostico vivo.
Network panel toolbar:
- Boton "Reload" (TI_REFRESH) — invoca reload_page().
- Checkbox "Bypass cache" — controla el flag ignoreCache.
- Toggle "Histogram" (TI_CHART_HISTOGRAM) — muestra/oculta overview.
Histograma overview (ImPlot::PlotHistogram):
- Eje X: tiempo de inicio (s) desde apertura de la sesion.
- Eje Y: requests por bin (30 bins por defecto, AutoFit).
- Marcadores TagX: DOMContentLoaded (DCL) y Load (L) tomados de Page.* events.
- Altura fija 100px, sin titulo/menu/box-select.
Status bar:
- Reemplaza placeholder "WS bytes 0/0" por estado real:
- "CDP: alive" en verde si frames_in>0, "CDP: no events" en warning si 0.
- Cuenta de frames + bytes in/out humanizados.
Util para diagnosticar: si "CDP: alive" pero tabla vacia → eventos llegan
pero no estan disparando peticiones nuevas → dale a Reload. Si "no events"
→ WS rota o pestaña no enganchada — investigar la conexion.
Tests: 6/6 siguen pasando (no se tocan los hooks de layouts).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Bug: al pulsar un layout guardado el dock layout se aplicaba pero los paneles
ocultos quedaban con dock node vacio. Causa: el INI de ImGui solo guarda
posicion/dock; la visibilidad (`show_*` bools) es estado puro de la app y no
se restauraba al apply.
Fix:
- Tomar control del menu Layouts (cfg.auto_layouts=false). Abrir LayoutStorage
propio + segunda tabla `panel_visibility` en la misma layouts.db (CREATE
TABLE IF NOT EXISTS, aditivo, no rompe layouts existentes).
- on_save: capture_panel_state() serializa show_* a JSON y se persiste junto
al INI bajo el mismo nombre.
- on_apply: marca pending INI + carga state JSON pendiente.
- on_reset: clear INI + open_all_panels (reabre Browsers/Tabs/TabDetail/Network).
- on_delete: borra fila imgui_layouts + sidecar.
- drain_layout_pending() (llamado desde render() cada frame) aplica
LoadIniSettingsFromMemory + apply_panel_state. Fallback: si layout no tiene
sidecar (back-compat con layouts antiguos) abre todos los paneles.
Refactor:
- main.cpp: render() ya no es static — necesario para que el test harness
reuse la misma funcion. int main() guardado tras `#ifndef FN_TEST_BUILD`.
- show_* bools y k_panels movidos al namespace navegator (extern para tests).
- dashboard_state.h: nuevo header expone show_*, setup_layouts(),
teardown_layouts(), capture/apply_panel_state, open_all_panels y los
hooks layout_save/apply/delete/reset + drain_layout_pending para tests.
Tests (Dear ImGui Test Engine, opt-in via -DFN_BUILD_TESTS=ON):
tests/navegator_dashboard_tests.cpp — 6 tests, todos pasan:
1. panel_state_roundtrip — capture/apply JSON simetrico.
2. open_all_panels_marks_main_visible.
3. save_hide_apply_restores_visibility (FIX BUG).
4. two_layouts_swap_visibility — minimal vs full.
5. reset_opens_all_main_panels.
6. legacy_layout_fallback_opens_all — sin sidecar.
Build/run:
cmake -B cpp/build/windows_tests -S cpp \
-DCMAKE_TOOLCHAIN_FILE=$(pwd)/cpp/toolchains/mingw-w64.cmake \
-DFN_BUILD_TESTS=ON
cmake --build cpp/build/windows_tests --target navegator_dashboard_tests
Deploy + run via cmd.exe -> 6/6 tests passed.
CMakeLists.txt: añade target navegator_dashboard_tests bajo if(FN_BUILD_TESTS),
linka mismas libs que prod + define FN_TEST_BUILD para que main.cpp no
duplique main(). WIN32_EXECUTABLE FALSE para ver stdout en consola.
Issue 0003 (sub-issue del roadmap navegator_dashboard 0001).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>