aboutsummaryrefslogtreecommitdiffstats
path: root/packages/web/components/ui/imageCard.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'packages/web/components/ui/imageCard.tsx')
-rw-r--r--packages/web/components/ui/imageCard.tsx56
1 files changed, 56 insertions, 0 deletions
diff --git a/packages/web/components/ui/imageCard.tsx b/packages/web/components/ui/imageCard.tsx
new file mode 100644
index 00000000..1394ae08
--- /dev/null
+++ b/packages/web/components/ui/imageCard.tsx
@@ -0,0 +1,56 @@
+import * as React from "react";
+
+import { cn } from "@/lib/utils";
+
+export function ImageCard({
+ children,
+ image,
+ className,
+ ...props
+}: React.HTMLAttributes<HTMLDivElement> & { image?: string }) {
+ return (
+ <div
+ className={cn("h-96 rounded-lg overflow-hidden shadow-md", className)}
+ {...props}
+ >
+ <div
+ className="h-3/5 bg-cover bg-center"
+ style={{
+ backgroundImage: image ? `url(${image})` : undefined,
+ }}
+ ></div>
+ <div className="flex flex-col h-2/5 p-2">{children}</div>
+ </div>
+ );
+}
+
+export function ImageCardTitle({
+ className,
+ ...props
+}: React.HTMLAttributes<HTMLDivElement>) {
+ return (
+ <div
+ className={cn("order-first flex-none font-bold text-lg", className)}
+ {...props}
+ />
+ );
+}
+
+export function ImageCardBody({
+ className,
+ ...props
+}: React.HTMLAttributes<HTMLDivElement>) {
+ return (
+ <div
+ className={cn("grow order-1 font-bold text-lg", className)}
+ {...props}
+ />
+ );
+}
+
+export function ImageCardFooter({
+ className,
+ ...props
+}: React.HTMLAttributes<HTMLDivElement>) {
+ return <div className={cn("order-last", className)} {...props} />;
+}