summaryrefslogtreecommitdiff
path: root/ui/lib/components/swatch/EventLog.svelte
diff options
context:
space:
mode:
authorOwen Jacobson <owen@grimoire.ca>2025-07-08 01:35:28 -0400
committerOwen Jacobson <owen@grimoire.ca>2025-07-08 01:58:25 -0400
commitc631c8fc855b1854f14fc7fbf1d8afedaa37a0db (patch)
treee14698c4a26382461f3290564212e77fdaca5d1e /ui/lib/components/swatch/EventLog.svelte
parentaeb159c401ef446e6564e5a3643027560a3e22f4 (diff)
Event capture and display tools.
This is meant to be used in swatches, to display the events and callbacks generated by a component as part of the swatch. The usage pattern is described in the comments (in both places). Naturally, this has its own swatch.
Diffstat (limited to 'ui/lib/components/swatch/EventLog.svelte')
-rw-r--r--ui/lib/components/swatch/EventLog.svelte37
1 files changed, 37 insertions, 0 deletions
diff --git a/ui/lib/components/swatch/EventLog.svelte b/ui/lib/components/swatch/EventLog.svelte
new file mode 100644
index 0000000..2d8c5c0
--- /dev/null
+++ b/ui/lib/components/swatch/EventLog.svelte
@@ -0,0 +1,37 @@
+<script>
+ /*
+ * The interface exposed by this component is designed to be compatible with the interface
+ * exposed by the `EventCapture` class, so that you can do this:
+ *
+ * let capture = $state(new EventCapture());
+ * const someEvent = capture.on('someEvent');
+ *
+ * // …
+ *
+ * <EventLog events={capture.events} clear={capture.clear.bind(capture)} />
+ */
+
+ let { events, clear = () => {} } = $props();
+
+ function onclick() {
+ clear();
+ }
+</script>
+
+<button {onclick}>clear</button>
+<table>
+ <thead>
+ <tr>
+ <th>event</th>
+ <th>arguments</th>
+ </tr>
+ </thead>
+ <tbody>
+ {#each events as { event, args }}
+ <tr>
+ <td>{event}</td>
+ <td><code>{JSON.stringify(args)}</code></td>
+ </tr>
+ {/each}
+ </tbody>
+</table>