adonisjs-server-stats 1.10.0 → 1.10.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/README.md +23 -14
  2. package/dist/core/config-utils.d.ts +8 -0
  3. package/dist/core/constants.d.ts +4 -0
  4. package/dist/core/dashboard-data-controller.d.ts +16 -0
  5. package/dist/core/dashboard-data-helpers.d.ts +12 -0
  6. package/dist/core/debug-data-controller.d.ts +4 -0
  7. package/dist/core/define-config-helpers.d.ts +25 -0
  8. package/dist/core/feature-detect-helpers.d.ts +36 -0
  9. package/dist/core/formatters-helpers.d.ts +23 -0
  10. package/dist/core/index.js +594 -509
  11. package/dist/core/log-utils-helpers.d.ts +13 -0
  12. package/dist/core/metrics.d.ts +3 -28
  13. package/dist/core/pagination.d.ts +0 -9
  14. package/dist/core/server-stats-controller.d.ts +6 -0
  15. package/dist/core/transmit-helpers.d.ts +7 -0
  16. package/dist/core/types-dashboard.d.ts +178 -0
  17. package/dist/core/types-diagnostics.d.ts +85 -0
  18. package/dist/core/types.d.ts +10 -442
  19. package/dist/react/{CacheSection-UCMptWyn.js → CacheSection-baMZotSn.js} +2 -2
  20. package/dist/react/CacheTab-2cw_rMzj.js +117 -0
  21. package/dist/react/{ConfigSection-DfFd-WRq.js → ConfigSection-DGgqjAal.js} +1 -1
  22. package/dist/react/{ConfigTab-Bdg8YMer.js → ConfigTab-H3OnYqmK.js} +1 -1
  23. package/dist/react/CustomPaneTab-B6r7ha0u.js +98 -0
  24. package/dist/react/{EmailsSection-CM7stSyh.js → EmailsSection-C-UZISG-.js} +2 -2
  25. package/dist/react/EmailsTab-DbK4Eobn.js +139 -0
  26. package/dist/react/{EventsSection-ByQ-9blq.js → EventsSection-C7RQW_LY.js} +2 -2
  27. package/dist/react/EventsTab-CfVr7AiM.js +57 -0
  28. package/dist/react/{FilterBar-DQRXpWrb.js → FilterBar-CQ7bD669.js} +15 -15
  29. package/dist/react/{JobsSection-DF3qEv9O.js → JobsSection-CQHNK_Ls.js} +2 -2
  30. package/dist/react/{JobsTab-BbrBWIOb.js → JobsTab-znzf6jzk.js} +54 -42
  31. package/dist/react/{LogsSection-DcFTZY7b.js → LogsSection-Dmm3rE2B.js} +9 -3
  32. package/dist/react/LogsTab-D8unMV5P.js +108 -0
  33. package/dist/react/{OverviewSection-C4T1ur51.js → OverviewSection-ABP9ueBo.js} +1 -1
  34. package/dist/react/{QueriesSection-PswteoF9.js → QueriesSection-CnmSkznA.js} +2 -2
  35. package/dist/react/{QueriesTab-osLUWd4L.js → QueriesTab-BQzcxEiW.js} +37 -40
  36. package/dist/react/{RelatedLogs-DFDOyUMr.js → RelatedLogs-3A8RuGKH.js} +15 -3
  37. package/dist/react/{RequestsSection-Nag30rEA.js → RequestsSection-kW79_M7k.js} +3 -3
  38. package/dist/react/{RoutesSection-BUSkM6PY.js → RoutesSection-BRhxrtjZ.js} +2 -2
  39. package/dist/react/RoutesTab-CpYH5lUw.js +68 -0
  40. package/dist/react/{TimelineTab-Covg5weo.js → TimelineTab-DjLR35Ce.js} +47 -53
  41. package/dist/react/index-CsImORX6.js +1121 -0
  42. package/dist/react/index.js +1 -1
  43. package/dist/react/react/components/{Dashboard/shared → shared}/FilterBar.d.ts +4 -3
  44. package/dist/react/react/hooks/useDashboardData.d.ts +4 -8
  45. package/dist/react/style.css +1 -1
  46. package/dist/src/collectors/app_collector.d.ts +0 -8
  47. package/dist/src/collectors/app_collector.js +45 -52
  48. package/dist/src/collectors/auto_detect.d.ts +0 -23
  49. package/dist/src/collectors/auto_detect.js +33 -55
  50. package/dist/src/collectors/db_pool_collector.d.ts +14 -16
  51. package/dist/src/collectors/db_pool_collector.js +72 -57
  52. package/dist/src/collectors/log_collector.d.ts +0 -47
  53. package/dist/src/collectors/log_collector.js +36 -65
  54. package/dist/src/collectors/queue_collector.d.ts +0 -20
  55. package/dist/src/collectors/queue_collector.js +60 -76
  56. package/dist/src/collectors/redis_collector.d.ts +10 -10
  57. package/dist/src/collectors/redis_collector.js +69 -66
  58. package/dist/src/config/deprecation_migration.d.ts +7 -0
  59. package/dist/src/config/deprecation_migration.js +201 -0
  60. package/dist/src/controller/debug_controller.d.ts +1 -1
  61. package/dist/src/controller/debug_controller.js +87 -81
  62. package/dist/src/dashboard/cache_handlers.d.ts +14 -0
  63. package/dist/src/dashboard/cache_handlers.js +52 -0
  64. package/dist/src/dashboard/chart_aggregator.d.ts +0 -7
  65. package/dist/src/dashboard/chart_aggregator.js +68 -50
  66. package/dist/src/dashboard/coalesce_cache.d.ts +25 -0
  67. package/dist/src/dashboard/coalesce_cache.js +47 -0
  68. package/dist/src/dashboard/dashboard_controller.d.ts +11 -37
  69. package/dist/src/dashboard/dashboard_controller.js +51 -544
  70. package/dist/src/dashboard/dashboard_page_assets.d.ts +17 -0
  71. package/dist/src/dashboard/dashboard_page_assets.js +51 -0
  72. package/dist/src/dashboard/dashboard_store.d.ts +19 -218
  73. package/dist/src/dashboard/dashboard_store.js +115 -1116
  74. package/dist/src/dashboard/dashboard_types.d.ts +83 -0
  75. package/dist/src/dashboard/dashboard_types.js +4 -0
  76. package/dist/src/dashboard/detail_queries.d.ts +19 -0
  77. package/dist/src/dashboard/detail_queries.js +98 -0
  78. package/dist/src/dashboard/email_event_builder.d.ts +8 -0
  79. package/dist/src/dashboard/email_event_builder.js +65 -0
  80. package/dist/src/dashboard/explain_query.d.ts +8 -0
  81. package/dist/src/dashboard/explain_query.js +22 -0
  82. package/dist/src/dashboard/filter_handlers.d.ts +23 -0
  83. package/dist/src/dashboard/filter_handlers.js +56 -0
  84. package/dist/src/dashboard/filtered_queries.d.ts +15 -0
  85. package/dist/src/dashboard/filtered_queries.js +155 -0
  86. package/dist/src/dashboard/flush_manager.d.ts +25 -0
  87. package/dist/src/dashboard/flush_manager.js +107 -0
  88. package/dist/src/dashboard/format_helpers.d.ts +126 -0
  89. package/dist/src/dashboard/format_helpers.js +140 -0
  90. package/dist/src/dashboard/inspector_manager.d.ts +36 -0
  91. package/dist/src/dashboard/inspector_manager.js +102 -0
  92. package/dist/src/dashboard/integrations/config_inspector.js +11 -13
  93. package/dist/src/dashboard/integrations/queue_inspector.d.ts +3 -3
  94. package/dist/src/dashboard/integrations/queue_inspector.js +13 -10
  95. package/dist/src/dashboard/jobs_handlers.d.ts +14 -0
  96. package/dist/src/dashboard/jobs_handlers.js +61 -0
  97. package/dist/src/dashboard/knex_factory.d.ts +18 -0
  98. package/dist/src/dashboard/knex_factory.js +91 -0
  99. package/dist/src/dashboard/migrator.js +30 -159
  100. package/dist/src/dashboard/migrator_tables.d.ts +19 -0
  101. package/dist/src/dashboard/migrator_tables.js +153 -0
  102. package/dist/src/dashboard/overview_queries.d.ts +66 -0
  103. package/dist/src/dashboard/overview_queries.js +155 -0
  104. package/dist/src/dashboard/overview_query_runners.d.ts +25 -0
  105. package/dist/src/dashboard/overview_query_runners.js +84 -0
  106. package/dist/src/dashboard/overview_store_queries.d.ts +40 -0
  107. package/dist/src/dashboard/overview_store_queries.js +69 -0
  108. package/dist/src/dashboard/paginate_helper.d.ts +12 -0
  109. package/dist/src/dashboard/paginate_helper.js +33 -0
  110. package/dist/src/dashboard/query_explain_handler.d.ts +10 -0
  111. package/dist/src/dashboard/query_explain_handler.js +80 -0
  112. package/dist/src/dashboard/read_queries.d.ts +32 -0
  113. package/dist/src/dashboard/read_queries.js +107 -0
  114. package/dist/src/dashboard/saved_filter_queries.d.ts +10 -0
  115. package/dist/src/dashboard/saved_filter_queries.js +24 -0
  116. package/dist/src/dashboard/storage_stats.d.ts +41 -0
  117. package/dist/src/dashboard/storage_stats.js +81 -0
  118. package/dist/src/dashboard/write_queue.d.ts +106 -0
  119. package/dist/src/dashboard/write_queue.js +225 -0
  120. package/dist/src/data/data_access.d.ts +2 -39
  121. package/dist/src/data/data_access.js +17 -193
  122. package/dist/src/data/data_access_helpers.d.ts +130 -0
  123. package/dist/src/data/data_access_helpers.js +212 -0
  124. package/dist/src/debug/debug_store.js +37 -32
  125. package/dist/src/debug/email_collector.d.ts +1 -10
  126. package/dist/src/debug/email_collector.js +78 -81
  127. package/dist/src/debug/event_collector.d.ts +0 -9
  128. package/dist/src/debug/event_collector.js +79 -62
  129. package/dist/src/debug/query_collector.js +23 -19
  130. package/dist/src/debug/route_inspector.d.ts +1 -5
  131. package/dist/src/debug/route_inspector.js +50 -51
  132. package/dist/src/debug/trace_collector.d.ts +9 -1
  133. package/dist/src/debug/trace_collector.js +21 -15
  134. package/dist/src/debug/types.d.ts +1 -1
  135. package/dist/src/define_config.d.ts +0 -65
  136. package/dist/src/define_config.js +93 -333
  137. package/dist/src/edge/client/dashboard.js +2 -2
  138. package/dist/src/edge/client/debug-panel-deferred.js +1 -1
  139. package/dist/src/edge/client/stats-bar.js +1 -1
  140. package/dist/src/edge/client-vue/dashboard.js +5 -5
  141. package/dist/src/edge/client-vue/debug-panel-deferred.js +3 -3
  142. package/dist/src/edge/client-vue/stats-bar.js +3 -3
  143. package/dist/src/edge/plugin.d.ts +0 -16
  144. package/dist/src/edge/plugin.js +57 -64
  145. package/dist/src/engine/request_metrics.d.ts +1 -0
  146. package/dist/src/engine/request_metrics.js +32 -42
  147. package/dist/src/middleware/request_tracking_middleware.d.ts +2 -8
  148. package/dist/src/middleware/request_tracking_middleware.js +65 -93
  149. package/dist/src/provider/auth_middleware_detector.d.ts +16 -0
  150. package/dist/src/provider/auth_middleware_detector.js +97 -0
  151. package/dist/src/provider/boot_helpers.d.ts +20 -0
  152. package/dist/src/provider/boot_helpers.js +91 -0
  153. package/dist/src/provider/boot_initializer.d.ts +28 -0
  154. package/dist/src/provider/boot_initializer.js +35 -0
  155. package/dist/src/provider/dashboard_init.d.ts +30 -0
  156. package/dist/src/provider/dashboard_init.js +138 -0
  157. package/dist/src/provider/dashboard_setup.d.ts +25 -0
  158. package/dist/src/provider/dashboard_setup.js +78 -0
  159. package/dist/src/provider/diagnostics.d.ts +134 -0
  160. package/dist/src/provider/diagnostics.js +127 -0
  161. package/dist/src/provider/email_bridge.d.ts +43 -0
  162. package/dist/src/provider/email_bridge.js +80 -0
  163. package/dist/src/provider/email_helpers.d.ts +13 -0
  164. package/dist/src/provider/email_helpers.js +68 -0
  165. package/dist/src/provider/pino_hook.d.ts +17 -0
  166. package/dist/src/provider/pino_hook.js +35 -0
  167. package/dist/src/provider/provider_helpers_extra.d.ts +47 -0
  168. package/dist/src/provider/provider_helpers_extra.js +177 -0
  169. package/dist/src/provider/server_stats_provider.d.ts +39 -85
  170. package/dist/src/provider/server_stats_provider.js +132 -951
  171. package/dist/src/provider/shutdown_helpers.d.ts +43 -0
  172. package/dist/src/provider/shutdown_helpers.js +70 -0
  173. package/dist/src/provider/toolbar_setup.d.ts +57 -0
  174. package/dist/src/provider/toolbar_setup.js +141 -0
  175. package/dist/src/routes/dashboard_routes.d.ts +14 -0
  176. package/dist/src/routes/dashboard_routes.js +197 -0
  177. package/dist/src/routes/debug_routes.d.ts +14 -0
  178. package/dist/src/routes/debug_routes.js +101 -0
  179. package/dist/src/routes/register_routes.d.ts +0 -78
  180. package/dist/src/routes/register_routes.js +22 -352
  181. package/dist/src/routes/stats_routes.d.ts +5 -0
  182. package/dist/src/routes/stats_routes.js +14 -0
  183. package/dist/src/styles/components.css +96 -0
  184. package/dist/src/styles/dashboard.css +8 -90
  185. package/dist/src/styles/debug-panel.css +1 -31
  186. package/dist/src/types.d.ts +305 -14
  187. package/dist/vue/{CacheSection-oFAJL3mo.js → CacheSection-ITqvpfH5.js} +1 -1
  188. package/dist/vue/{ConfigSection-BhfJ4KqL.js → ConfigSection-DTn3GslE.js} +1 -1
  189. package/dist/vue/{EmailsSection-BcNyhyHs.js → EmailsSection-DtLJ4XoS.js} +1 -1
  190. package/dist/vue/{EventsSection-r60Q5Lmu.js → EventsSection-BOYYz0Ty.js} +1 -1
  191. package/dist/vue/{JobsSection-BHL-hkQw.js → JobsSection-BazTxcJL.js} +1 -1
  192. package/dist/vue/{LogsSection-DRMGzJmg.js → LogsSection-D55PjTKX.js} +9 -3
  193. package/dist/vue/{LogsTab-Bg3o0Mm6.js → LogsTab-47zEK7jL.js} +4 -1
  194. package/dist/vue/{OverviewSection-CXh6Ja1B.js → OverviewSection-1uBKo-Tu.js} +1 -1
  195. package/dist/vue/{QueriesSection-IodIsCJ-.js → QueriesSection-rpoZ4ogd.js} +1 -1
  196. package/dist/vue/{RequestsSection-BPuMdmMc.js → RequestsSection-x7LvT0MC.js} +1 -1
  197. package/dist/vue/{RoutesSection-NKo3Rbq3.js → RoutesSection-CCD0zZqQ.js} +1 -1
  198. package/dist/vue/composables/useDashboardData.d.ts +12 -23
  199. package/dist/vue/index-C8MxnS7Q.js +1232 -0
  200. package/dist/vue/index.js +1 -1
  201. package/dist/vue/style.css +1 -1
  202. package/package.json +1 -1
  203. package/dist/react/CacheTab-CA8LB1J5.js +0 -123
  204. package/dist/react/CustomPaneTab-Bxtv_8Rw.js +0 -104
  205. package/dist/react/EmailsTab-BDhEiomM.js +0 -153
  206. package/dist/react/EventsTab-CMfY98Rl.js +0 -63
  207. package/dist/react/LogsTab-CicucmVk.js +0 -103
  208. package/dist/react/RoutesTab-DgVzd2PZ.js +0 -74
  209. package/dist/react/index-Cflz9Ebj.js +0 -1069
  210. package/dist/vue/index-Dtgysd26.js +0 -1229
@@ -1,77 +1,89 @@
1
1
  import { jsx as s, jsxs as t } from "react/jsx-runtime";
2
- import { useState as u, useMemo as T, useCallback as S } from "react";
3
- import { extractJobs as j, extractJobStats as D, JOB_STATUS_FILTERS as J, getJobStatusCssClass as C, formatDuration as R, timeAgo as $, formatTime as B } from "adonisjs-server-stats/core";
2
+ import { useState as b, useMemo as C, useCallback as j } from "react";
3
+ import { extractJobs as D, extractJobStats as F, JOB_STATUS_FILTERS as J, getJobStatusCssClass as $, formatDuration as B, timeAgo as L, formatTime as R } from "adonisjs-server-stats/core";
4
4
  import { u as k } from "./useDashboardApiBase-Bi36pJ2L.js";
5
- import { u as F, J as L } from "./index-Cflz9Ebj.js";
6
- import { u as P } from "./useResizableTable-CNJmACdt.js";
7
- function U({ options: i, dashboardPath: p }) {
8
- const { dashApiBase: c, resolvedOptions: N } = k(p, i), { data: d, isLoading: y, error: m } = F("jobs", N), [r, f] = u("all"), [h, b] = u(null), n = T(() => {
9
- const e = j(d);
10
- return r === "all" ? e : e.filter((a) => a.status === r);
11
- }, [d, r]), v = S(
5
+ import { u as P, J as _ } from "./index-CsImORX6.js";
6
+ import { u as E } from "./useResizableTable-CNJmACdt.js";
7
+ import { F as O } from "./FilterBar-CQ7bD669.js";
8
+ function W({ options: c, dashboardPath: f }) {
9
+ const { dashApiBase: h, resolvedOptions: y } = k(f, c), { data: i, isLoading: v, error: g } = P("jobs", y), [n, x] = b(""), [o, w] = b("all"), [u, p] = b(null), m = C(() => {
10
+ const e = D(i), a = o === "all" ? e : e.filter((d) => d.status === o);
11
+ if (!n) return a;
12
+ const l = n.toLowerCase();
13
+ return a.filter((d) => d.name?.toLowerCase().includes(l) || d.id?.toString().includes(l));
14
+ }, [i, o, n]), A = j(
12
15
  async (e) => {
13
- b(e);
16
+ p(e);
14
17
  try {
15
- const { baseUrl: a = "", authToken: o } = i || {}, A = c || i?.debugEndpoint || "/admin/api/debug", w = `${a}${A}/jobs/${e}/retry`, g = { Accept: "application/json" };
16
- o && (g.Authorization = `Bearer ${o}`), await fetch(w, {
18
+ const { baseUrl: a = "", authToken: l } = c || {}, d = h || c?.debugEndpoint || "/admin/api/debug", T = `${a}${d}/jobs/${e}/retry`, N = { Accept: "application/json" };
19
+ l && (N.Authorization = `Bearer ${l}`), await fetch(T, {
17
20
  method: "POST",
18
- headers: g,
19
- credentials: o ? "omit" : "same-origin"
21
+ headers: N,
22
+ credentials: l ? "omit" : "same-origin"
20
23
  });
21
24
  } catch {
22
25
  }
23
- b(null);
26
+ p(null);
24
27
  },
25
- [i, c]
26
- ), x = P([n]);
27
- if (!c)
28
+ [c, h]
29
+ ), S = E([m]);
30
+ if (!h)
28
31
  return /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "Queue inspector not available (no dashboard configured)" });
29
- if (y && !d)
32
+ if (v && !i)
30
33
  return /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "Loading jobs..." });
31
- if (m)
34
+ if (g)
32
35
  return /* @__PURE__ */ t("div", { className: "ss-dbg-empty", children: [
33
36
  "Error: ",
34
- m.message
37
+ g.message
35
38
  ] });
36
- if (!d)
39
+ if (!i)
37
40
  return /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "Queue inspector not available" });
38
- const l = D(d);
41
+ const r = F(i);
39
42
  return /* @__PURE__ */ t("div", { children: [
43
+ /* @__PURE__ */ s(
44
+ O,
45
+ {
46
+ search: n,
47
+ onSearchChange: x,
48
+ placeholder: "Filter jobs...",
49
+ summary: `${m.length} jobs`
50
+ }
51
+ ),
40
52
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stats-area", children: [
41
53
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stats", children: [
42
54
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stat", children: [
43
55
  /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-label", children: "Active:" }),
44
- /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: l?.active ?? 0 })
56
+ /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: r?.active ?? 0 })
45
57
  ] }),
46
58
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stat", children: [
47
59
  /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-label", children: "Waiting:" }),
48
- /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: l?.waiting ?? 0 })
60
+ /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: r?.waiting ?? 0 })
49
61
  ] }),
50
62
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stat", children: [
51
63
  /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-label", children: "Delayed:" }),
52
- /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: l?.delayed ?? 0 })
64
+ /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: r?.delayed ?? 0 })
53
65
  ] }),
54
66
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stat", children: [
55
67
  /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-label", children: "Completed:" }),
56
- /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: l?.completed ?? 0 })
68
+ /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value", children: r?.completed ?? 0 })
57
69
  ] }),
58
70
  /* @__PURE__ */ t("div", { className: "ss-dbg-job-stat", children: [
59
71
  /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-label", children: "Failed:" }),
60
- /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value ss-dbg-c-red", children: l?.failed ?? 0 })
72
+ /* @__PURE__ */ s("span", { className: "ss-dbg-job-stat-value ss-dbg-c-red", children: r?.failed ?? 0 })
61
73
  ] })
62
74
  ] }),
63
75
  /* @__PURE__ */ s("div", { className: "ss-dbg-log-filters", children: J.map((e) => /* @__PURE__ */ s(
64
76
  "button",
65
77
  {
66
78
  type: "button",
67
- className: `ss-dbg-job-filter ${r === e ? "ss-dbg-active" : ""}`,
68
- onClick: () => f(e),
79
+ className: `ss-dbg-job-filter ${o === e ? "ss-dbg-active" : ""}`,
80
+ onClick: () => w(e),
69
81
  children: e
70
82
  },
71
83
  e
72
84
  )) })
73
85
  ] }),
74
- n.length === 0 ? /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "No jobs found" }) : /* @__PURE__ */ t("table", { ref: x, className: "ss-dbg-table", children: [
86
+ m.length === 0 ? /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "No jobs found" }) : /* @__PURE__ */ t("table", { ref: S, className: "ss-dbg-table", children: [
75
87
  /* @__PURE__ */ t("colgroup", { children: [
76
88
  /* @__PURE__ */ s("col", { style: { width: "50px" } }),
77
89
  /* @__PURE__ */ s("col", { style: { width: "15%" } }),
@@ -92,14 +104,14 @@ function U({ options: i, dashboardPath: p }) {
92
104
  /* @__PURE__ */ s("th", { children: "Time" }),
93
105
  /* @__PURE__ */ s("th", {})
94
106
  ] }) }),
95
- /* @__PURE__ */ s("tbody", { children: n.map((e) => {
107
+ /* @__PURE__ */ s("tbody", { children: m.map((e) => {
96
108
  const a = e;
97
109
  return /* @__PURE__ */ t("tr", { children: [
98
110
  /* @__PURE__ */ s("td", { className: "ss-dbg-c-dim", children: e.id }),
99
111
  /* @__PURE__ */ s("td", { className: "ss-dbg-c-sql", title: e.name, children: e.name }),
100
- /* @__PURE__ */ s("td", { children: /* @__PURE__ */ s("span", { className: `ss-dbg-badge ${C(e.status)}`, children: e.status }) }),
112
+ /* @__PURE__ */ s("td", { children: /* @__PURE__ */ s("span", { className: `ss-dbg-badge ${$(e.status)}`, children: e.status }) }),
101
113
  /* @__PURE__ */ s("td", { children: /* @__PURE__ */ s(
102
- L,
114
+ _,
103
115
  {
104
116
  data: e.payload || e.data,
105
117
  maxPreviewLength: 60,
@@ -107,15 +119,15 @@ function U({ options: i, dashboardPath: p }) {
107
119
  }
108
120
  ) }),
109
121
  /* @__PURE__ */ s("td", { className: "ss-dbg-c-muted", style: { textAlign: "center" }, children: e.attempts || a.attemptsMade || 0 }),
110
- /* @__PURE__ */ s("td", { className: "ss-dbg-duration", children: e.duration !== null ? R(e.duration) : "-" }),
122
+ /* @__PURE__ */ s("td", { className: "ss-dbg-duration", children: e.duration !== null ? B(e.duration) : "-" }),
111
123
  /* @__PURE__ */ s(
112
124
  "td",
113
125
  {
114
126
  className: "ss-dbg-event-time",
115
- title: B(
127
+ title: R(
116
128
  e.timestamp || e.createdAt || a.processedAt || a.created_at
117
129
  ),
118
- children: $(
130
+ children: L(
119
131
  e.timestamp || e.createdAt || a.processedAt || a.created_at
120
132
  )
121
133
  }
@@ -125,9 +137,9 @@ function U({ options: i, dashboardPath: p }) {
125
137
  {
126
138
  type: "button",
127
139
  className: "ss-dbg-retry-btn",
128
- onClick: () => v(e.id),
129
- disabled: h === e.id,
130
- children: h === e.id ? "..." : "Retry"
140
+ onClick: () => A(e.id),
141
+ disabled: u === e.id,
142
+ children: u === e.id ? "..." : "Retry"
131
143
  }
132
144
  ) })
133
145
  ] }, e.id);
@@ -136,6 +148,6 @@ function U({ options: i, dashboardPath: p }) {
136
148
  ] });
137
149
  }
138
150
  export {
139
- U as JobsTab,
140
- U as default
151
+ W as JobsTab,
152
+ W as default
141
153
  };
@@ -1,8 +1,8 @@
1
1
  import { jsxs as a, jsx as s } from "react/jsx-runtime";
2
2
  import M, { useState as l, useCallback as c } from "react";
3
3
  import { LOG_LEVELS as U, resolveLogLevel as z, resolveLogMessage as H, resolveLogRequestId as Q, resolveLogTimestamp as W, getStructuredData as X, getLogLevelCssClass as Y, timeAgo as Z, formatTime as ee } from "adonisjs-server-stats/core";
4
- import { a as se, J as te } from "./index-Cflz9Ebj.js";
5
- import { F as ae } from "./FilterBar-DQRXpWrb.js";
4
+ import { a as se, J as te } from "./index-CsImORX6.js";
5
+ import { F as ae } from "./FilterBar-CQ7bD669.js";
6
6
  import { P as le } from "./Pagination-BkmzUDY8.js";
7
7
  function he({ options: D = {} }) {
8
8
  const [R, i] = l(1), [L, V] = l(""), [r, S] = l("all"), [n, v] = l(""), [p, f] = l(""), [N, k] = l([]), [b, A] = l("level"), [q, K] = l("equals"), [y, _] = l(""), [C, O] = l(null), o = {};
@@ -202,7 +202,13 @@ function he({ options: D = {} }) {
202
202
  children: h.slice(0, 8)
203
203
  }
204
204
  ) : /* @__PURE__ */ s("span", { className: "ss-dash-log-reqid-empty", children: "--" }),
205
- u ? /* @__PURE__ */ s("span", { className: `ss-dash-log-expand-icon${C === t ? " ss-dash-log-expand-icon-open" : ""}`, children: "▶" }) : /* @__PURE__ */ s("span", { style: { width: 14 } }),
205
+ u ? /* @__PURE__ */ s(
206
+ "span",
207
+ {
208
+ className: `ss-dash-log-expand-icon${C === t ? " ss-dash-log-expand-icon-open" : ""}`,
209
+ children: "▶"
210
+ }
211
+ ) : /* @__PURE__ */ s("span", { style: { width: 14 } }),
206
212
  /* @__PURE__ */ s("span", { className: "ss-dash-log-msg", children: F })
207
213
  ]
208
214
  }
@@ -0,0 +1,108 @@
1
+ import { jsx as s, jsxs as l } from "react/jsx-runtime";
2
+ import q, { useState as m, useMemo as I, useCallback as E } from "react";
3
+ import { filterLogsByLevel as S, resolveLogRequestId as y, resolveLogMessage as N, LOG_LEVELS as D, resolveLogLevel as R, resolveLogTimestamp as $, getStructuredData as A, getLogLevelCssClass as P, timeAgo as T, formatTime as j } from "adonisjs-server-stats/core";
4
+ import { u as B, J } from "./index-CsImORX6.js";
5
+ import { F as M } from "./FilterBar-CQ7bD669.js";
6
+ function _({ options: x }) {
7
+ const { data: r, isLoading: C, error: h } = B("logs", x), [p, w] = m("all"), [d, F] = m(""), [o, f] = m(""), [u, k] = m(null), b = I(() => {
8
+ let e = Array.isArray(r) ? r : r?.logs || r?.entries || [];
9
+ if (e = S(e, p), o) {
10
+ const t = o.toLowerCase();
11
+ e = e.filter((a) => y(a).toLowerCase().includes(t));
12
+ }
13
+ if (d) {
14
+ const t = d.toLowerCase();
15
+ e = e.filter((a) => N(a).toLowerCase().includes(t));
16
+ }
17
+ return e;
18
+ }, [r, p, d, o]), L = E((e) => {
19
+ f((t) => t === e ? "" : e);
20
+ }, []);
21
+ return C && !r ? /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "Loading logs..." }) : h ? /* @__PURE__ */ l("div", { className: "ss-dbg-empty", children: [
22
+ "Error: ",
23
+ h.message
24
+ ] }) : /* @__PURE__ */ l("div", { children: [
25
+ /* @__PURE__ */ l("div", { className: "ss-dbg-log-filters", children: [
26
+ D.map((e) => /* @__PURE__ */ s(
27
+ "button",
28
+ {
29
+ type: "button",
30
+ className: `ss-dbg-log-filter ${p === e ? "ss-dbg-active" : ""}`,
31
+ onClick: () => w(e),
32
+ children: e
33
+ },
34
+ e
35
+ )),
36
+ o && /* @__PURE__ */ l(
37
+ "button",
38
+ {
39
+ type: "button",
40
+ className: "ss-dbg-log-filter ss-dbg-active",
41
+ onClick: () => f(""),
42
+ children: [
43
+ "req: ",
44
+ o.slice(0, 8),
45
+ " x"
46
+ ]
47
+ }
48
+ ),
49
+ /* @__PURE__ */ l("span", { className: "ss-dbg-summary", style: { marginLeft: "auto" }, children: [
50
+ b.length,
51
+ " entries"
52
+ ] })
53
+ ] }),
54
+ /* @__PURE__ */ s(
55
+ M,
56
+ {
57
+ search: d,
58
+ onSearchChange: F,
59
+ placeholder: "Filter log messages..."
60
+ }
61
+ ),
62
+ /* @__PURE__ */ s("div", { style: { overflow: "auto", flex: 1 }, children: b.length === 0 ? /* @__PURE__ */ s("div", { className: "ss-dbg-empty", children: "No log entries" }) : b.slice(0, 200).map((e, t) => {
63
+ const a = R(e), v = N(e), c = $(e), n = y(e), i = A(e);
64
+ return /* @__PURE__ */ l(q.Fragment, { children: [
65
+ /* @__PURE__ */ l(
66
+ "div",
67
+ {
68
+ className: `ss-dbg-log-entry${i ? " ss-dbg-log-entry-expandable" : ""}`,
69
+ onClick: () => i && k(u === t ? null : t),
70
+ children: [
71
+ /* @__PURE__ */ s("span", { className: `ss-dbg-log-level ${P(a)}`, children: a.toUpperCase() }),
72
+ /* @__PURE__ */ s("span", { className: "ss-dbg-log-time", title: c ? j(c) : "", children: c ? T(c) : "-" }),
73
+ n ? /* @__PURE__ */ s(
74
+ "span",
75
+ {
76
+ className: "ss-dbg-log-reqid",
77
+ onClick: (g) => {
78
+ g.stopPropagation(), L(n);
79
+ },
80
+ role: "button",
81
+ tabIndex: 0,
82
+ title: n,
83
+ onKeyDown: (g) => {
84
+ g.key === "Enter" && (g.stopPropagation(), L(n));
85
+ },
86
+ children: n.slice(0, 8)
87
+ }
88
+ ) : /* @__PURE__ */ s("span", { className: "ss-dbg-log-reqid-empty", children: "-" }),
89
+ i ? /* @__PURE__ */ s(
90
+ "span",
91
+ {
92
+ className: `ss-dbg-log-expand-icon${u === t ? " ss-dbg-log-expand-icon-open" : ""}`,
93
+ children: "▶"
94
+ }
95
+ ) : /* @__PURE__ */ s("span", { style: { width: 14 } }),
96
+ /* @__PURE__ */ s("span", { className: "ss-dbg-log-msg", children: v })
97
+ ]
98
+ }
99
+ ),
100
+ u === t && i && /* @__PURE__ */ s("div", { className: "ss-dbg-log-detail", children: /* @__PURE__ */ s(J, { data: i, classPrefix: "ss-dbg", defaultExpanded: !0 }) })
101
+ ] }, t);
102
+ }) })
103
+ ] });
104
+ }
105
+ export {
106
+ _ as LogsTab,
107
+ _ as default
108
+ };
@@ -1,7 +1,7 @@
1
1
  import { jsx as s, jsxs as e } from "react/jsx-runtime";
2
2
  import { useState as E, useRef as X, useEffect as P, useCallback as z } from "react";
3
3
  import { formatDuration as $, timeAgo as ss, formatTime as es, durationSeverity as as } from "adonisjs-server-stats/core";
4
- import { a as B, S } from "./index-Cflz9Ebj.js";
4
+ import { a as B, S } from "./index-CsImORX6.js";
5
5
  const ls = [
6
6
  { value: "5m", label: "5m" },
7
7
  { value: "15m", label: "15m" },
@@ -1,9 +1,9 @@
1
1
  import { jsx as t, jsxs as r, Fragment as b } from "react/jsx-runtime";
2
2
  import { useState as y, useCallback as $, useEffect as V, useMemo as P } from "react";
3
3
  import { durationSeverity as _, timeAgo as B, formatTime as G, SLOW_DURATION_MS as X } from "adonisjs-server-stats/core";
4
- import { a as Y } from "./index-Cflz9Ebj.js";
4
+ import { a as Y } from "./index-CsImORX6.js";
5
5
  import { D as I } from "./DataTable-YyShr5B-.js";
6
- import { F as Z } from "./FilterBar-DQRXpWrb.js";
6
+ import { F as Z } from "./FilterBar-CQ7bD669.js";
7
7
  import { P as ee } from "./Pagination-BkmzUDY8.js";
8
8
  function K({ node: a, depth: d = 0 }) {
9
9
  if (!a) return null;
@@ -1,39 +1,36 @@
1
- import { jsx as e, jsxs as t } from "react/jsx-runtime";
2
- import { useState as m, useMemo as i, useCallback as v } from "react";
3
- import { filterQueries as C, countDuplicateQueries as D, computeQuerySummary as S, formatDuration as p, durationSeverity as g, timeAgo as Q, formatTime as T } from "adonisjs-server-stats/core";
4
- import { u as $ } from "./index-Cflz9Ebj.js";
5
- import { u as E } from "./useResizableTable-CNJmACdt.js";
6
- function R({ options: b }) {
7
- const { data: n, isLoading: y, error: u } = $("queries", b), [o, N] = m(""), [w, x] = m(null), d = i(() => n?.queries || [], [n]), a = i(() => C(d, o), [d, o]), l = i(() => D(d), [d]), r = i(
8
- () => S(d, l),
9
- [d, l]
10
- ), h = v((s) => {
1
+ import { jsx as e, jsxs as t, Fragment as v } from "react/jsx-runtime";
2
+ import { useState as h, useMemo as i, useCallback as C } from "react";
3
+ import { filterQueries as S, countDuplicateQueries as D, computeQuerySummary as Q, formatDuration as p, durationSeverity as g, timeAgo as T, formatTime as $ } from "adonisjs-server-stats/core";
4
+ import { u as E } from "./index-CsImORX6.js";
5
+ import { u as F } from "./useResizableTable-CNJmACdt.js";
6
+ import { F as L } from "./FilterBar-CQ7bD669.js";
7
+ function A({ options: b }) {
8
+ const { data: n, isLoading: y, error: u } = E("queries", b), [o, w] = h(""), [f, x] = h(null), d = i(() => n?.queries || [], [n]), r = i(() => S(d, o), [d, o]), a = i(() => D(d), [d]), l = i(
9
+ () => Q(d, a),
10
+ [d, a]
11
+ ), m = C((s) => {
11
12
  x((c) => c === s ? null : s);
12
- }, []), f = E([a]);
13
+ }, []), N = F([r]);
13
14
  return y && !n ? /* @__PURE__ */ e("div", { className: "ss-dbg-empty", children: "Loading queries..." }) : u ? /* @__PURE__ */ t("div", { className: "ss-dbg-empty", children: [
14
15
  "Error: ",
15
16
  u.message
16
17
  ] }) : /* @__PURE__ */ t("div", { children: [
17
- /* @__PURE__ */ t("div", { className: "ss-dbg-search-bar", children: [
18
- /* @__PURE__ */ e(
19
- "input",
20
- {
21
- type: "text",
22
- className: "ss-dbg-search",
23
- placeholder: "Filter queries...",
24
- value: o,
25
- onChange: (s) => N(s.target.value)
26
- }
27
- ),
28
- /* @__PURE__ */ t("span", { className: "ss-dbg-summary", children: [
29
- a.length,
30
- " queries",
31
- r.slowCount > 0 && ` | ${r.slowCount} slow`,
32
- r.dupCount > 0 && ` | ${r.dupCount} dup`,
33
- a.length > 0 && ` | avg ${p(r.avgDuration)}`
34
- ] })
35
- ] }),
36
- a.length === 0 ? /* @__PURE__ */ e("div", { className: "ss-dbg-empty", children: "No queries captured" }) : /* @__PURE__ */ t("table", { ref: f, className: "ss-dbg-table", children: [
18
+ /* @__PURE__ */ e(
19
+ L,
20
+ {
21
+ search: o,
22
+ onSearchChange: w,
23
+ placeholder: "Filter queries...",
24
+ summary: /* @__PURE__ */ t(v, { children: [
25
+ r.length,
26
+ " queries",
27
+ l.slowCount > 0 && ` | ${l.slowCount} slow`,
28
+ l.dupCount > 0 && ` | ${l.dupCount} dup`,
29
+ r.length > 0 && ` | avg ${p(l.avgDuration)}`
30
+ ] })
31
+ }
32
+ ),
33
+ r.length === 0 ? /* @__PURE__ */ e("div", { className: "ss-dbg-empty", children: "No queries captured" }) : /* @__PURE__ */ t("table", { ref: N, className: "ss-dbg-table", children: [
37
34
  /* @__PURE__ */ t("colgroup", { children: [
38
35
  /* @__PURE__ */ e("col", { style: { width: "50px" } }),
39
36
  /* @__PURE__ */ e("col", {}),
@@ -50,23 +47,23 @@ function R({ options: b }) {
50
47
  /* @__PURE__ */ e("th", { children: "Model" }),
51
48
  /* @__PURE__ */ e("th", { children: "Time" })
52
49
  ] }) }),
53
- /* @__PURE__ */ e("tbody", { children: a.map((s) => /* @__PURE__ */ t("tr", { children: [
50
+ /* @__PURE__ */ e("tbody", { children: r.map((s) => /* @__PURE__ */ t("tr", { children: [
54
51
  /* @__PURE__ */ e("td", { className: "ss-dbg-c-dim", style: { whiteSpace: "nowrap" }, children: s.id }),
55
52
  /* @__PURE__ */ t("td", { children: [
56
53
  /* @__PURE__ */ e(
57
54
  "span",
58
55
  {
59
- className: `ss-dbg-sql ${w === s.id ? "ss-dbg-expanded" : ""}`,
60
- onClick: () => h(s.id),
56
+ className: `ss-dbg-sql ${f === s.id ? "ss-dbg-expanded" : ""}`,
57
+ onClick: () => m(s.id),
61
58
  role: "button",
62
59
  tabIndex: 0,
63
- onKeyDown: (c) => c.key === "Enter" && h(s.id),
60
+ onKeyDown: (c) => c.key === "Enter" && m(s.id),
64
61
  children: s.sql
65
62
  }
66
63
  ),
67
- l[s.sql] > 1 && /* @__PURE__ */ t("span", { className: "ss-dbg-dup", children: [
64
+ a[s.sql] > 1 && /* @__PURE__ */ t("span", { className: "ss-dbg-dup", children: [
68
65
  " x",
69
- l[s.sql]
66
+ a[s.sql]
70
67
  ] }),
71
68
  s.inTransaction && /* @__PURE__ */ e("span", { className: "ss-dbg-dup", children: " TXN" })
72
69
  ] }),
@@ -79,12 +76,12 @@ function R({ options: b }) {
79
76
  ),
80
77
  /* @__PURE__ */ e("td", { children: /* @__PURE__ */ e("span", { className: `ss-dbg-method ss-dbg-method-${s.method.toLowerCase()}`, children: s.method }) }),
81
78
  /* @__PURE__ */ e("td", { className: "ss-dbg-c-muted", children: s.model || "-" }),
82
- /* @__PURE__ */ e("td", { className: "ss-dbg-event-time", title: T(s.timestamp), children: Q(s.timestamp) })
79
+ /* @__PURE__ */ e("td", { className: "ss-dbg-event-time", title: $(s.timestamp), children: T(s.timestamp) })
83
80
  ] }, s.id)) })
84
81
  ] })
85
82
  ] });
86
83
  }
87
84
  export {
88
- R as QueriesTab,
89
- R as default
85
+ A as QueriesTab,
86
+ A as default
90
87
  };
@@ -1,7 +1,7 @@
1
1
  import { jsxs as o, jsx as t } from "react/jsx-runtime";
2
2
  import g, { useState as h } from "react";
3
3
  import { resolveLogLevel as u, resolveLogMessage as $, resolveLogRequestId as v, resolveLogTimestamp as N, getStructuredData as L, getLogLevelCssClass as y, timeAgo as R, formatTime as q } from "adonisjs-server-stats/core";
4
- import { J as C } from "./index-Cflz9Ebj.js";
4
+ import { J as C } from "./index-CsImORX6.js";
5
5
  function J({ logs: s, classPrefix: e = "ss-dash" }) {
6
6
  const [r, p] = h(null);
7
7
  return s.length === 0 ? null : /* @__PURE__ */ o("div", { children: [
@@ -22,10 +22,22 @@ function J({ logs: s, classPrefix: e = "ss-dash" }) {
22
22
  className: `${e}-log-entry${a ? ` ${e}-log-entry-expandable` : ""}`,
23
23
  onClick: () => a && p(r === l ? null : l),
24
24
  children: [
25
- /* @__PURE__ */ t("span", { className: `${e}-log-level ${y(c, `${e}-log-level`)}`, children: c.toUpperCase() }),
25
+ /* @__PURE__ */ t(
26
+ "span",
27
+ {
28
+ className: `${e}-log-level ${y(c, `${e}-log-level`)}`,
29
+ children: c.toUpperCase()
30
+ }
31
+ ),
26
32
  /* @__PURE__ */ t("span", { className: `${e}-log-time`, title: d ? q(d) : "", children: d ? R(d) : "-" }),
27
33
  m ? /* @__PURE__ */ t("span", { className: `${e}-log-reqid`, title: m, children: m.slice(0, 8) }) : /* @__PURE__ */ t("span", { className: `${e}-log-reqid-empty`, children: "--" }),
28
- a ? /* @__PURE__ */ t("span", { className: `${e}-log-expand-icon${r === l ? ` ${e}-log-expand-icon-open` : ""}`, children: "▶" }) : /* @__PURE__ */ t("span", { style: { width: 14 } }),
34
+ a ? /* @__PURE__ */ t(
35
+ "span",
36
+ {
37
+ className: `${e}-log-expand-icon${r === l ? ` ${e}-log-expand-icon-open` : ""}`,
38
+ children: "▶"
39
+ }
40
+ ) : /* @__PURE__ */ t("span", { style: { width: 14 } }),
29
41
  /* @__PURE__ */ t("span", { className: `${e}-log-msg`, children: i })
30
42
  ]
31
43
  }
@@ -2,10 +2,10 @@ import { jsx as t, jsxs as r, Fragment as j } from "react/jsx-runtime";
2
2
  import { useMemo as q, useState as f, useEffect as M, useCallback as L, useRef as C } from "react";
3
3
  import { normalizeTraceFields as z, durationSeverity as _, timeAgo as W, formatTime as G, initSplitPane as I } from "adonisjs-server-stats/core";
4
4
  import { u as U } from "./useApiClient-BVtNCmnL.js";
5
- import { a as Y, M as D, b as A } from "./index-Cflz9Ebj.js";
6
- import { R as V } from "./RelatedLogs-DFDOyUMr.js";
5
+ import { a as Y, M as D, b as A } from "./index-CsImORX6.js";
6
+ import { R as V } from "./RelatedLogs-3A8RuGKH.js";
7
7
  import { D as H } from "./DataTable-YyShr5B-.js";
8
- import { F as J } from "./FilterBar-DQRXpWrb.js";
8
+ import { F as J } from "./FilterBar-CQ7bD669.js";
9
9
  import { P as K } from "./Pagination-BkmzUDY8.js";
10
10
  const F = {
11
11
  request: "#1e3a5f",
@@ -1,8 +1,8 @@
1
1
  import { jsxs as m, jsx as r, Fragment as p } from "react/jsx-runtime";
2
2
  import { useState as y } from "react";
3
- import { a as u, M as f } from "./index-Cflz9Ebj.js";
3
+ import { a as u, M as f } from "./index-CsImORX6.js";
4
4
  import { D as w } from "./DataTable-YyShr5B-.js";
5
- import { F as b } from "./FilterBar-DQRXpWrb.js";
5
+ import { F as b } from "./FilterBar-CQ7bD669.js";
6
6
  function A({ options: n = {} }) {
7
7
  const [s, i] = y(""), { data: l, isLoading: c, error: h } = u("routes", { ...n, search: s }), a = l, o = Array.isArray(a) ? a : a && Array.isArray(a.routes) ? a.routes : a && Array.isArray(a.data) ? a.data : [], t = {
8
8
  overflow: "hidden",
@@ -0,0 +1,68 @@
1
+ import { jsx as e, jsxs as d } from "react/jsx-runtime";
2
+ import { useState as g, useMemo as p } from "react";
3
+ import { u as b } from "./index-CsImORX6.js";
4
+ import { u as f } from "./useResizableTable-CNJmACdt.js";
5
+ import { F as w } from "./FilterBar-CQ7bD669.js";
6
+ function $({ options: i, currentPath: n }) {
7
+ const { data: o, isLoading: h, error: c } = b("routes", i), [a, m] = g(""), l = p(() => {
8
+ const s = o?.routes || [];
9
+ if (!a) return s;
10
+ const r = a.toLowerCase();
11
+ return s.filter(
12
+ (t) => t.pattern.toLowerCase().includes(r) || t.handler.toLowerCase().includes(r) || t.method.toLowerCase().includes(r) || t.name && t.name.toLowerCase().includes(r)
13
+ );
14
+ }, [o, a]), u = f([l]);
15
+ return h && !o ? /* @__PURE__ */ e("div", { className: "ss-dbg-empty", children: "Loading routes..." }) : c ? /* @__PURE__ */ d("div", { className: "ss-dbg-empty", children: [
16
+ "Error: ",
17
+ c.message
18
+ ] }) : /* @__PURE__ */ d("div", { children: [
19
+ /* @__PURE__ */ e(
20
+ w,
21
+ {
22
+ search: a,
23
+ onSearchChange: m,
24
+ placeholder: "Filter routes...",
25
+ summary: `${l.length} routes`
26
+ }
27
+ ),
28
+ l.length === 0 ? /* @__PURE__ */ e("div", { className: "ss-dbg-empty", children: "No routes found" }) : /* @__PURE__ */ d("table", { ref: u, className: "ss-dbg-table", children: [
29
+ /* @__PURE__ */ d("colgroup", { children: [
30
+ /* @__PURE__ */ e("col", { style: { width: "70px" } }),
31
+ /* @__PURE__ */ e("col", { style: { width: "25%" } }),
32
+ /* @__PURE__ */ e("col", { style: { width: "15%" } }),
33
+ /* @__PURE__ */ e("col", {}),
34
+ /* @__PURE__ */ e("col", { style: { width: "20%" } })
35
+ ] }),
36
+ /* @__PURE__ */ e("thead", { children: /* @__PURE__ */ d("tr", { children: [
37
+ /* @__PURE__ */ e("th", { children: "Method" }),
38
+ /* @__PURE__ */ e("th", { children: "Pattern" }),
39
+ /* @__PURE__ */ e("th", { children: "Name" }),
40
+ /* @__PURE__ */ e("th", { children: "Handler" }),
41
+ /* @__PURE__ */ e("th", { children: "Middleware" })
42
+ ] }) }),
43
+ /* @__PURE__ */ e("tbody", { children: l.map((s, r) => {
44
+ const t = n && (s.pattern === n || new RegExp("^" + s.pattern.replace(/:[^/]+/g, "[^/]+") + "$").test(
45
+ n
46
+ ));
47
+ return /* @__PURE__ */ d(
48
+ "tr",
49
+ {
50
+ className: t ? "ss-dbg-current-route" : "",
51
+ children: [
52
+ /* @__PURE__ */ e("td", { children: /* @__PURE__ */ e("span", { className: `ss-dbg-method ss-dbg-method-${s.method.toLowerCase()}`, children: s.method }) }),
53
+ /* @__PURE__ */ e("td", { className: "ss-dbg-c-text", children: s.pattern }),
54
+ /* @__PURE__ */ e("td", { className: "ss-dbg-c-muted", children: s.name || "-" }),
55
+ /* @__PURE__ */ e("td", { className: "ss-dbg-c-sql", children: s.handler }),
56
+ /* @__PURE__ */ e("td", { className: "ss-dbg-c-dim", style: { fontSize: "10px" }, children: s.middleware.length > 0 ? s.middleware.join(", ") : "-" })
57
+ ]
58
+ },
59
+ `${s.method}-${s.pattern}-${r}`
60
+ );
61
+ }) })
62
+ ] })
63
+ ] });
64
+ }
65
+ export {
66
+ $ as RoutesTab,
67
+ $ as default
68
+ };