diff --git a/frontend/src/AgroShopAI/components/Pages/Admin-Dashboard.jsx b/frontend/src/AgroShopAI/components/Pages/Admin-Dashboard.jsx index 3691fc58..c35d0fc1 100644 --- a/frontend/src/AgroShopAI/components/Pages/Admin-Dashboard.jsx +++ b/frontend/src/AgroShopAI/components/Pages/Admin-Dashboard.jsx @@ -4,6 +4,7 @@ import { GrievanceList } from "./components/GrievanceList"; import { DashboardStats } from "./components/DashboardStats"; import { useState } from "react"; import StatisticComponent from "./components/StatisticComponent"; +import ReturnPanel from "./components/ReturnPage"; export default function AdminDashboard() { const [activeView, setActiveView] = useState("dashboard"); // Track active view @@ -13,7 +14,7 @@ export default function AdminDashboard() { }; return ( -
+
@@ -21,6 +22,7 @@ export default function AdminDashboard() { {activeView === "dashboard" && } {activeView === "grievances" && } {activeView === "analytics" && } + {activeView === "return" && }
); diff --git a/frontend/src/AgroShopAI/components/Pages/ReturnPage.jsx b/frontend/src/AgroShopAI/components/Pages/ReturnPage.jsx index bfcdea92..16d8de78 100644 --- a/frontend/src/AgroShopAI/components/Pages/ReturnPage.jsx +++ b/frontend/src/AgroShopAI/components/Pages/ReturnPage.jsx @@ -1,9 +1,9 @@ import { useState } from "react"; -import ReturnHeader from "./components/ReturnHeader"; -import ReturnFilter from "./components/ReturnFilter"; -import ReturnProductCard from "./components/ReturnProductCard"; -import ReturnModal from "./components/ReturnModal"; -import ReturnHistory from "./components/ReturnHistory"; +import ReturnHeader from "./components/ReturnAdminHeader"; +import ReturnFilter from "./components/ReturnAdminFilter"; +import ReturnProductCard from "./components/ReturnAdminProductCard"; +import ReturnModal from "./components/ReturnAdminModal"; +import ReturnHistory from "./components/ReturnAdminHistory"; export default function ReturnPage() { const [products, setProducts] = useState(dummyProducts); @@ -34,7 +34,7 @@ export default function ReturnPage() { setComment(""); setHistory([ ...history, - { ...selectedProduct, returnDate: new Date().toLocaleString(), comment } + { ...selectedProduct, returnDate: new Date().toLocaleString(), comment }, ]); }; @@ -42,8 +42,10 @@ export default function ReturnPage() { setSortOption(option); const sortedProducts = [...products].sort((a, b) => { if (option === "Name") return a.name.localeCompare(b.name); - if (option === "Start Date") return new Date(a.startDate) - new Date(b.startDate); - if (option === "End Date") return new Date(a.endDate) - new Date(b.endDate); + if (option === "Start Date") + return new Date(a.startDate) - new Date(b.startDate); + if (option === "End Date") + return new Date(a.endDate) - new Date(b.endDate); return 0; }); setProducts(sortedProducts); @@ -104,60 +106,43 @@ export default function ReturnPage() { ); } - const dummyProducts = [ { id: 1, - name: "Tractor", - model: "John Deere 5075E", - startDate: "2023-05-01", - endDate: "2023-05-31", - status: "Eligible", - image: "https://www.tafetribe.com/pub/media/catalog/product/cache/343ef2803f1a27d8d77b5e62acabb37c/m/f/mf-dynatrak_toy_tractor.jpg", + user: { name: "John Doe", email: "john@example.com", phone: "+1234567890" }, + orderId: "ORD-001", + product: { name: "Organic Fertilizer", quantity: 2, price: 29.99 }, + reason: "Received wrong product", + submissionDate: "2023-06-01", + status: "pending", + comments: [], }, { id: 2, - name: "Harvester", - model: "Case IH 250", - startDate: "2023-04-15", - endDate: "2023-05-15", - status: "Pending", - image: "https://s3.toolsvilla.com/products-minipetrolharvester/1708773710976/1708773724856-watmrkA.webp", + user: { + name: "Jane Smith", + email: "jane@example.com", + phone: "+1987654321", + }, + orderId: "ORD-002", + product: { name: "Heirloom Tomato Seeds", quantity: 1, price: 14.99 }, + reason: "Product damaged during shipping", + submissionDate: "2023-05-28", + status: "approved", + comments: ["Approved for return. Please send return label to customer."], }, { id: 3, - name: "Seeder", - model: "Kinze 3600", - startDate: "2023-05-10", - endDate: "2023-06-10", - status: "Eligible", - image: "https://pre-live-admin.balwaan.com/uploads/media/2023/1_(4)1.jpg", - }, - { - id: 4, - name: "Sprayer", - model: "John Deere R4045", - startDate: "2023-03-01", - endDate: "2023-04-01", - status: "Returned", - image: "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSPWYzHIpFSFN_mUgVWV_Ubc1Id1AaUifhlwg&s", - }, - { - id: 5, - name: "Plow", - model: "Kuhn Multi-Leader", - startDate: "2023-05-05", - endDate: "2023-06-05", - status: "Eligible", - image: "https://www.shutterstock.com/image-photo/hand-plow-on-field-plowing-600nw-1075430750.jpg", - }, - { - id: 6, - name: "Cultivator", - model: "Case IH Tiger-Mate 255", - startDate: "2023-04-20", - endDate: "2023-05-20", - status: "Eligible", - image: "", + user: { + name: "Bob Johnson", + email: "bob@example.com", + phone: "+1122334455", + }, + orderId: "ORD-003", + product: { name: "Drip Irrigation Kit", quantity: 1, price: 89.99 }, + reason: "Changed mind", + submissionDate: "2023-05-25", + status: "rejected", + comments: ["Return window has expired."], }, ]; diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminFilter.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminFilter.jsx new file mode 100644 index 00000000..0a219ed4 --- /dev/null +++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminFilter.jsx @@ -0,0 +1,22 @@ +import React from "react"; + +export default function ReturnFilter({ filter, setFilter }) { + return ( +
+ + +
+ ); +} diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHeader.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHeader.jsx new file mode 100644 index 00000000..6def142e --- /dev/null +++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHeader.jsx @@ -0,0 +1,9 @@ +import React from "react"; + +export default function ReturnHeader() { + return ( +
+

Return Rented Equipment

+
+ ); +} diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHistory.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHistory.jsx new file mode 100644 index 00000000..c43f4c29 --- /dev/null +++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminHistory.jsx @@ -0,0 +1,26 @@ +import React from "react"; + +export default function ReturnHistory({ history }) { + return ( +
+

+ Return History +

+ +
+ ); +} diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminModal.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminModal.jsx new file mode 100644 index 00000000..cc81d367 --- /dev/null +++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminModal.jsx @@ -0,0 +1,81 @@ +import React from "react"; + +export default function ReturnModal({ + isModalOpen, + setIsModalOpen, + selectedProduct, + handleSubmitReturn, + returnDate, + setReturnDate, + condition, + setCondition, + comment, + setComment, +}) { + if (!isModalOpen || !selectedProduct) return null; + + return ( +
+
+

+ Return {selectedProduct.name} +

+
+
+ + setReturnDate(e.target.value)} + className="w-full p-2 border rounded" + /> +
+
+ + +
+
+ +