about summary refs log tree commit diff
path: root/bskyembed/src/container.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'bskyembed/src/container.tsx')
-rw-r--r--bskyembed/src/container.tsx32
1 files changed, 32 insertions, 0 deletions
diff --git a/bskyembed/src/container.tsx b/bskyembed/src/container.tsx
new file mode 100644
index 000000000..0d120e1b7
--- /dev/null
+++ b/bskyembed/src/container.tsx
@@ -0,0 +1,32 @@
+import {ComponentChildren, h} from 'preact'
+import {useRef} from 'preact/hooks'
+
+import {Link} from './link'
+
+export function Container({
+  children,
+  href,
+}: {
+  children: ComponentChildren
+  href: string
+}) {
+  const ref = useRef<HTMLDivElement>(null)
+  return (
+    <div
+      ref={ref}
+      className="w-full bg-white hover:bg-neutral-50 relative transition-colors max-w-[550px] min-w-[300px] flex border rounded-xl px-4 pt-3 pb-2.5"
+      onClick={() => {
+        if (ref.current) {
+          // forwardRef requires preact/compat - let's keep it simple
+          // to keep the bundle size down
+          const anchor = ref.current.querySelector('a')
+          if (anchor) {
+            anchor.click()
+          }
+        }
+      }}>
+      <Link href={href} />
+      {children}
+    </div>
+  )
+}