aboutsummaryrefslogtreecommitdiff
path: root/examples/with-nanostores/src/components/AddToCartForm.tsx
diff options
context:
space:
mode:
authorGravatar Ben Holmes <hey@bholmes.dev> 2022-07-11 15:42:10 -0400
committerGravatar GitHub <noreply@github.com> 2022-07-11 15:42:10 -0400
commitfaf3f3a8d111b543c0aca12432fe1a2ee5e2d726 (patch)
treea754bd03b9db417a5dfeb1a4a50236b858884ec1 /examples/with-nanostores/src/components/AddToCartForm.tsx
parentbf5d1cc1e71da38a14658c615e9481f2145cc6e7 (diff)
downloadastro-faf3f3a8d111b543c0aca12432fe1a2ee5e2d726.tar.gz
astro-faf3f3a8d111b543c0aca12432fe1a2ee5e2d726.tar.zst
astro-faf3f3a8d111b543c0aca12432fe1a2ee5e2d726.zip
Update `with-nanostores` example to match docs walkthrough (#3840)
* feat: replace with-nanostores with new example * docs: update README with docs call-out * chore: small formatting inconsistencies * nit: standardize to spaces :'( * nit: standardize to tabs! * refactor: use html "hidden" property * nit: beta.66 for sanity
Diffstat (limited to 'examples/with-nanostores/src/components/AddToCartForm.tsx')
-rw-r--r--examples/with-nanostores/src/components/AddToCartForm.tsx22
1 files changed, 22 insertions, 0 deletions
diff --git a/examples/with-nanostores/src/components/AddToCartForm.tsx b/examples/with-nanostores/src/components/AddToCartForm.tsx
new file mode 100644
index 000000000..2f1befb9f
--- /dev/null
+++ b/examples/with-nanostores/src/components/AddToCartForm.tsx
@@ -0,0 +1,22 @@
+import { isCartOpen, addCartItem } from '../cartStore';
+import type { CartItemDisplayInfo } from '../cartStore';
+import type { ComponentChildren } from 'preact';
+
+type Props = {
+ item: CartItemDisplayInfo;
+ children: ComponentChildren;
+}
+
+export default function AddToCartForm({ item, children }: Props) {
+ function addToCart(e: SubmitEvent) {
+ e.preventDefault();
+ isCartOpen.set(true);
+ addCartItem(item);
+ }
+
+ return (
+ <form onSubmit={addToCart}>
+ {children}
+ </form>
+ )
+}