summaryrefslogtreecommitdiffhomepage
path: root/src/features/surface-host/ui/Button.svelte
diff options
context:
space:
mode:
Diffstat (limited to 'src/features/surface-host/ui/Button.svelte')
-rw-r--r--src/features/surface-host/ui/Button.svelte21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/features/surface-host/ui/Button.svelte b/src/features/surface-host/ui/Button.svelte
new file mode 100644
index 0000000..62d7acf
--- /dev/null
+++ b/src/features/surface-host/ui/Button.svelte
@@ -0,0 +1,21 @@
+<script lang="ts">
+ import type { InvokeMessage } from "@dispatch/ui-contract";
+ import type { ButtonFieldView } from "../logic/types";
+
+ let {
+ field,
+ surfaceId,
+ onInvoke,
+ }: { field: ButtonFieldView; surfaceId: string; onInvoke: (msg: InvokeMessage) => void } =
+ $props();
+
+ function handleClick() {
+ onInvoke({
+ type: "invoke",
+ surfaceId,
+ actionId: field.action.actionId,
+ });
+ }
+</script>
+
+<button onclick={handleClick}>{field.label}</button>