Skip to content

Commit

Permalink
Merge pull request #951 from IkkiOcean/admin-dashboard
Browse files Browse the repository at this point in the history
Implement Return Panel for Managing Return and Refund Requests
  • Loading branch information
manikumarreddyu authored Nov 9, 2024
2 parents 34a8dd4 + 863dd43 commit c0d93a4
Show file tree
Hide file tree
Showing 9 changed files with 394 additions and 55 deletions.
4 changes: 3 additions & 1 deletion frontend/src/AgroShopAI/components/Pages/Admin-Dashboard.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand All @@ -13,14 +14,15 @@ export default function AdminDashboard() {
};

return (
<div className="flex h-fit bg-gray-100 pt-15 mt-10">
<div className="flex h-fit bg-gray-100 pt-15 mt-20">
<Sidebar onViewChange={handleViewChange} activeView={activeView} />
<main className="flex-1 p-8">
<Header />
{/* Render content based on active view */}
{activeView === "dashboard" && <DashboardStats />}
{activeView === "grievances" && <GrievanceList />}
{activeView === "analytics" && <StatisticComponent />}
{activeView === "return" && <ReturnPanel/>}
</main>
</div>
);
Expand Down
93 changes: 39 additions & 54 deletions frontend/src/AgroShopAI/components/Pages/ReturnPage.jsx
Original file line number Diff line number Diff line change
@@ -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);
Expand Down Expand Up @@ -34,16 +34,18 @@ export default function ReturnPage() {
setComment("");
setHistory([
...history,
{ ...selectedProduct, returnDate: new Date().toLocaleString(), comment }
{ ...selectedProduct, returnDate: new Date().toLocaleString(), comment },
]);
};

const handleSort = (option) => {
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);
Expand Down Expand Up @@ -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."],
},
];
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import React from "react";

export default function ReturnFilter({ filter, setFilter }) {
return (
<div className="flex items-center">
<label htmlFor="filter" className="mr-4 text-green-700">
Filter by Status:
</label>
<select
id="filter"
value={filter}
onChange={(e) => setFilter(e.target.value)}
className="p-2 border rounded"
>
<option value="All">All</option>
<option value="Eligible">Eligible</option>
<option value="Pending">Pending</option>
<option value="Returned">Returned</option>
</select>
</div>
);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import React from "react";

export default function ReturnHeader() {
return (
<header className="bg-green-700 text-white p-4">
<h1 className="text-3xl font-bold">Return Rented Equipment</h1>
</header>
);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import React from "react";

export default function ReturnHistory({ history }) {
return (
<div className="mt-8">
<h3 className="text-2xl font-semibold text-green-800 mb-4">
Return History
</h3>
<ul>
{history.map((item, index) => (
<li
key={index}
className="mb-4 p-4 border rounded bg-white shadow-md"
>
<p className="font-semibold">{item.name}</p>
<p className="text-sm text-gray-600">
Returned on: {item.returnDate}
</p>
<p className="text-sm text-gray-600">Condition: {item.condition}</p>
<p className="text-sm text-gray-600">Comment: {item.comment}</p>
</li>
))}
</ul>
</div>
);
}
Original file line number Diff line number Diff line change
@@ -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 (
<div className="fixed inset-0 flex items-center justify-center bg-gray-700 bg-opacity-50">
<div className="bg-white p-6 rounded shadow-lg max-w-md w-full">
<h2 className="text-xl font-semibold mb-4">
Return {selectedProduct.name}
</h2>
<form onSubmit={handleSubmitReturn}>
<div className="mb-4">
<label htmlFor="returnDate" className="block text-sm text-gray-700">
Return Date:
</label>
<input
type="date"
id="returnDate"
value={returnDate}
onChange={(e) => setReturnDate(e.target.value)}
className="w-full p-2 border rounded"
/>
</div>
<div className="mb-4">
<label htmlFor="condition" className="block text-sm text-gray-700">
Condition:
</label>
<select
id="condition"
value={condition}
onChange={(e) => setCondition(e.target.value)}
className="w-full p-2 border rounded"
>
<option value="Good">Good</option>
<option value="Damaged">Damaged</option>
<option value="Broken">Broken</option>
</select>
</div>
<div className="mb-4">
<label htmlFor="comment" className="block text-sm text-gray-700">
Comment:
</label>
<textarea
id="comment"
value={comment}
onChange={(e) => setComment(e.target.value)}
className="w-full p-2 border rounded"
/>
</div>
<div className="flex justify-between">
<button
type="button"
onClick={() => setIsModalOpen(false)}
className="px-4 py-2 bg-gray-500 text-white rounded"
>
Cancel
</button>
<button
type="submit"
className="px-4 py-2 bg-green-600 text-white rounded"
>
Submit Return
</button>
</div>
</form>
</div>
</div>
);
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import React from "react";

export default function ReturnProductCard({ product, handleReturn }) {
return (
<div className="border p-4 rounded shadow-lg bg-white">
<img src={product.image} alt={product.name} className="w-full h-32 object-cover mb-4" />
<h3 className="text-xl font-semibold">{product.name}</h3>
<p className="text-sm text-gray-600">{product.model}</p>
<div className="mt-4 flex justify-between">
<span className="text-sm text-gray-500">Status: {product.status}</span>
<button
onClick={() => handleReturn(product)}
className="px-4 py-2 bg-green-600 text-white rounded"
>
Return
</button>
</div>
</div>
);
}
Loading

0 comments on commit c0d93a4

Please sign in to comment.