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 (
+
+ );
+}
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}
+
+
+
+
+ );
+}
diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminProductCard.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminProductCard.jsx
new file mode 100644
index 00000000..268bbec0
--- /dev/null
+++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnAdminProductCard.jsx
@@ -0,0 +1,20 @@
+import React from "react";
+
+export default function ReturnProductCard({ product, handleReturn }) {
+ return (
+
+
+
{product.name}
+
{product.model}
+
+ Status: {product.status}
+
+
+
+ );
+}
diff --git a/frontend/src/AgroShopAI/components/Pages/components/ReturnPage.jsx b/frontend/src/AgroShopAI/components/Pages/components/ReturnPage.jsx
new file mode 100644
index 00000000..c3abda42
--- /dev/null
+++ b/frontend/src/AgroShopAI/components/Pages/components/ReturnPage.jsx
@@ -0,0 +1,182 @@
+
+import React, { useState } from 'react'
+
+
+
+export default function ReturnPanel() {
+ const [requests, setRequests] = useState(dummyRequests)
+ const [filterStatus, setFilterStatus] = useState('all')
+ const [sortBy, setSortBy] = useState('date')
+ const [newComment, setNewComment] = useState('')
+
+ const filteredRequests = requests.filter(request =>
+ filterStatus === 'all' ? true : request.status === filterStatus
+ ).sort((a, b) =>
+ sortBy === 'date'
+ ? new Date(b.submissionDate).getTime() - new Date(a.submissionDate).getTime()
+ : a.status.localeCompare(b.status)
+ )
+
+ const handleStatusChange = (id, newStatus) => {
+ setRequests(requests.map(request =>
+ request.id === id ? { ...request, status: newStatus } : request
+ ))
+ }
+
+ const handleAddComment = (id) => {
+ if (newComment.trim()) {
+ setRequests(requests.map(request =>
+ request.id === id
+ ? { ...request, comments: [...request.comments, newComment.trim()] }
+ : request
+ ))
+ setNewComment('')
+ }
+ }
+
+ return (
+
+
AgroShop Return Panel
+
+
+
+
+
+
+
+
+
+
+
+
+ {filteredRequests.map(request => (
+
+
+
+
{request.user.name}
+
{request.user.email} | {request.user.phone}
+
+
+ {request.status.charAt(0).toUpperCase() + request.status.slice(1)}
+
+
+
+
+
Order ID: {request.orderId}
+
Product: {request.product.name}
+
Quantity: {request.product.quantity}
+
Price: ${request.product.price.toFixed(2)}
+
Reason: {request.reason}
+
Submission Date: {request.submissionDate}
+
+
+
+
Comments:
+ {request.comments.map((comment, index) => (
+
{comment}
+ ))}
+
+ setNewComment(e.target.value)}
+ />
+
+
+
+
+
+ {request.status === 'pending' && (
+ <>
+
+
+ >
+ )}
+ {request.status === 'approved' && (
+
+ )}
+
+
+ ))}
+
+ )
+}
+
+
+const dummyRequests = [
+ {
+ id: 1,
+ 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,
+ 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,
+ 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.']
+ }
+ ]
\ No newline at end of file
diff --git a/frontend/src/AgroShopAI/components/Pages/components/Sidebar.jsx b/frontend/src/AgroShopAI/components/Pages/components/Sidebar.jsx
index cd4363f0..92487471 100644
--- a/frontend/src/AgroShopAI/components/Pages/components/Sidebar.jsx
+++ b/frontend/src/AgroShopAI/components/Pages/components/Sidebar.jsx
@@ -5,6 +5,7 @@ import {
Settings,
Users,
TrendingUp,
+ CornerDownLeft
} from "lucide-react";
export const Sidebar = ({ onViewChange, activeView }) => {
@@ -71,6 +72,17 @@ export const Sidebar = ({ onViewChange, activeView }) => {
Sales
+
+ onViewChange("return")}
+ className={`flex items-center py-2 px-4 hover:bg-green-700 rounded ${
+ activeView === "return" ? "bg-green-700" : ""
+ }`}
+ >
+ Return
+
+