From 6ecb39e84175a9c30f2c5b5f8013c8a8d073fd91 Mon Sep 17 00:00:00 2001
From: ZeroWave022 <36341766+ZeroWave022@users.noreply.github.com>
Date: Thu, 29 Aug 2024 17:53:00 +0200
Subject: [PATCH] feat: Add shopping cart page with a table
---
messages/en.json | 8 ++
messages/no.json | 8 ++
.../(default)/storage/shopping-cart/page.tsx | 51 ++++++++
src/components/ui/Table.tsx | 117 ++++++++++++++++++
src/lib/config.ts | 4 +
5 files changed, 188 insertions(+)
create mode 100644 src/app/[locale]/(default)/storage/shopping-cart/page.tsx
create mode 100644 src/components/ui/Table.tsx
diff --git a/messages/en.json b/messages/en.json
index 316e4ba..0feefc8 100644
--- a/messages/en.json
+++ b/messages/en.json
@@ -74,6 +74,14 @@
},
"tooltips": {
"viewShoppingCart": "View shopping cart"
+ },
+ "shoppingCart": {
+ "title": "Shopping Cart",
+ "productId": "Product id",
+ "productName": "Product Name",
+ "location": "Location",
+ "unitsAvailable": "Units available",
+ "tableDescription": "A list of your shopping cart items."
}
}
}
diff --git a/messages/no.json b/messages/no.json
index 79286cb..edd79a6 100644
--- a/messages/no.json
+++ b/messages/no.json
@@ -74,6 +74,14 @@
},
"tooltips": {
"viewShoppingCart": "Vis handlekurv"
+ },
+ "shoppingCart": {
+ "title": "Handlekurv",
+ "productId": "Produkt id",
+ "productName": "Produktnavn",
+ "location": "Plass",
+ "unitsAvailable": "Stk tilgjengelig",
+ "tableDescription": "En liste over handlekurven din."
}
}
}
diff --git a/src/app/[locale]/(default)/storage/shopping-cart/page.tsx b/src/app/[locale]/(default)/storage/shopping-cart/page.tsx
new file mode 100644
index 0000000..08c3d51
--- /dev/null
+++ b/src/app/[locale]/(default)/storage/shopping-cart/page.tsx
@@ -0,0 +1,51 @@
+import { useTranslations } from 'next-intl';
+
+import {
+ Table,
+ TableBody,
+ TableCaption,
+ TableCell,
+ TableHead,
+ TableHeader,
+ TableRow,
+} from '@/components/ui/Table';
+
+export default function StorageShoppingCartPage() {
+ const t = useTranslations('storage.shoppingCart');
+ return (
+ <>
+
{t('title')}
+
+ {t('tableDescription')}
+
+
+ {t('productId')}
+ {t('productName')}
+ {t('location')}
+ {t('unitsAvailable')}
+
+
+
+
+ 01
+ Laptop
+ Storage Room A
+ 15
+
+
+ 01
+ Laptop
+ Storage Room A
+ 15
+
+
+ 01
+ Laptop
+ Storage Room A
+ 15
+
+
+
+ >
+ );
+}
diff --git a/src/components/ui/Table.tsx b/src/components/ui/Table.tsx
new file mode 100644
index 0000000..4d00f59
--- /dev/null
+++ b/src/components/ui/Table.tsx
@@ -0,0 +1,117 @@
+import * as React from 'react';
+
+import { cx } from '@/lib/utils';
+
+const Table = React.forwardRef<
+ HTMLTableElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+
+));
+Table.displayName = 'Table';
+
+const TableHeader = React.forwardRef<
+ HTMLTableSectionElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+
+));
+TableHeader.displayName = 'TableHeader';
+
+const TableBody = React.forwardRef<
+ HTMLTableSectionElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+
+));
+TableBody.displayName = 'TableBody';
+
+const TableFooter = React.forwardRef<
+ HTMLTableSectionElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+ tr]:last:border-b-0',
+ className,
+ )}
+ {...props}
+ />
+));
+TableFooter.displayName = 'TableFooter';
+
+const TableRow = React.forwardRef<
+ HTMLTableRowElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+
+));
+TableRow.displayName = 'TableRow';
+
+const TableHead = React.forwardRef<
+ HTMLTableCellElement,
+ React.ThHTMLAttributes
+>(({ className, ...props }, ref) => (
+ |
+));
+TableHead.displayName = 'TableHead';
+
+const TableCell = React.forwardRef<
+ HTMLTableCellElement,
+ React.TdHTMLAttributes
+>(({ className, ...props }, ref) => (
+ |
+));
+TableCell.displayName = 'TableCell';
+
+const TableCaption = React.forwardRef<
+ HTMLTableCaptionElement,
+ React.HTMLAttributes
+>(({ className, ...props }, ref) => (
+
+));
+TableCaption.displayName = 'TableCaption';
+
+export {
+ Table,
+ TableHeader,
+ TableBody,
+ TableFooter,
+ TableHead,
+ TableRow,
+ TableCell,
+ TableCaption,
+};
diff --git a/src/lib/config.ts b/src/lib/config.ts
index 1ea67ef..25b8b97 100644
--- a/src/lib/config.ts
+++ b/src/lib/config.ts
@@ -30,6 +30,10 @@ const pathnames = {
en: '/storage',
no: '/lager',
},
+ '/storage/shopping-cart': {
+ en: '/storage/shopping-cart',
+ no: '/lager/handlekurv',
+ },
'/about': {
en: '/about',
no: '/om-oss',