summaryrefslogtreecommitdiff
path: root/ui/routes/(swatch)/.swatch/swatch
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/routes/(swatch)/.swatch/swatch
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/routes/(swatch)/.swatch/swatch')
-rw-r--r--ui/routes/(swatch)/.swatch/swatch/EventLog/+page.svelte38
1 files changed, 38 insertions, 0 deletions
diff --git a/ui/routes/(swatch)/.swatch/swatch/EventLog/+page.svelte b/ui/routes/(swatch)/.swatch/swatch/EventLog/+page.svelte
new file mode 100644
index 0000000..a751ca3
--- /dev/null
+++ b/ui/routes/(swatch)/.swatch/swatch/EventLog/+page.svelte
@@ -0,0 +1,38 @@
+<script>
+ import EventCapture from '$lib/swatch/event-capture.svelte.js';
+ import { json } from '$lib/swatch/derive.js';
+
+ import EventLog from '$lib/components/swatch/EventLog.svelte';
+
+ let eventsInput = $state(
+ JSON.stringify(
+ [{ event: 'example', args: ['argument a', 'argument b'] }],
+ /* replacer */ null,
+ /* space */ 2,
+ ),
+ );
+ let events = $derived(json(eventsInput));
+
+ let capture = $state(new EventCapture());
+ const clear = capture.on('clear');
+</script>
+
+<h1><code>swatch/EventLog</code></h1>
+
+<nav><p><a href="..">Back to swatches</a></p></nav>
+
+<h2>properties</h2>
+
+<div class="component-properties">
+ <label>events (json) <textarea bind:value={eventsInput}></textarea></label>
+</div>
+
+<h2>rendered</h2>
+
+<div class="component-preview">
+ <EventLog {events} {clear} />
+</div>
+
+<h2>events</h2>
+
+<EventLog events={capture.events} clear={capture.clear.bind(capture)} />