Merge branch 'master' of http://128.199.30.231/possibillion/smellika-api
This commit is contained in:
commit
860f3e9551
6
app.js
6
app.js
@ -163,6 +163,8 @@ import SeoRoute from "./resources/SEO&Analytics/SEORouter.js";
|
|||||||
import AffiliateRoute from "./resources/Affiliate&Coupon/Affiliate/AffiliateRoute.js";
|
import AffiliateRoute from "./resources/Affiliate&Coupon/Affiliate/AffiliateRoute.js";
|
||||||
//Blog Routes
|
//Blog Routes
|
||||||
import BlogRoute from "./resources/Blog/BlogRoute.js";
|
import BlogRoute from "./resources/Blog/BlogRoute.js";
|
||||||
|
// Panel Routes
|
||||||
|
import PanelRoute from "./resources/Panels/PanelRoutes.js"
|
||||||
//Coupon Routes
|
//Coupon Routes
|
||||||
import CouponRoute from "./resources/Affiliate&Coupon/Coupon/CouponRoute.js";
|
import CouponRoute from "./resources/Affiliate&Coupon/Coupon/CouponRoute.js";
|
||||||
//short urls
|
//short urls
|
||||||
@ -222,6 +224,10 @@ app.use("/api/v1/affiliate", AffiliateRoute);
|
|||||||
app.use("/api/v1/coupon", CouponRoute);
|
app.use("/api/v1/coupon", CouponRoute);
|
||||||
//Blog
|
//Blog
|
||||||
app.use("/api/v1/blog", BlogRoute);
|
app.use("/api/v1/blog", BlogRoute);
|
||||||
|
// panels
|
||||||
|
app.use("/api/panel", PanelRoute);
|
||||||
|
|
||||||
|
|
||||||
//config specialty
|
//config specialty
|
||||||
// app.use("/api/config/specialty", SpecialtiesRouter);
|
// app.use("/api/config/specialty", SpecialtiesRouter);
|
||||||
//specialties
|
//specialties
|
||||||
|
@ -39,7 +39,7 @@ export const getAllOrder = async (req, res) => {
|
|||||||
export const getOrders = async (req, res) => {
|
export const getOrders = async (req, res) => {
|
||||||
try {
|
try {
|
||||||
const order = await Order.find({
|
const order = await Order.find({
|
||||||
payment_status: "success",
|
// payment_status: "success",
|
||||||
})
|
})
|
||||||
.populate({
|
.populate({
|
||||||
path: "user",
|
path: "user",
|
||||||
@ -149,11 +149,188 @@ export const updateOrderStatusById = async (req, res) => {
|
|||||||
const currentDate = new Date();
|
const currentDate = new Date();
|
||||||
body["status_timeline." + req.body.status] = currentDate;
|
body["status_timeline." + req.body.status] = currentDate;
|
||||||
// if (req.body?.package_weight) body.package_weight = req.body.package_weight;
|
// if (req.body?.package_weight) body.package_weight = req.body.package_weight;
|
||||||
const order = await Order.findById(req.params.id);
|
const order = await Order.findById(req.params.id).populate({
|
||||||
// console.log(order);
|
path: "user",
|
||||||
|
select: "name email -_id",
|
||||||
|
});
|
||||||
|
// console.log("order", order);
|
||||||
// const parentData = { email: order?.parent?.email };
|
// const parentData = { email: order?.parent?.email };
|
||||||
// if (body.status === "cancelled")
|
if (req.body.status === "cancelled") {
|
||||||
// await OrderCancelledEmail(parentData.email, order.order_id);
|
body["order_Cancelled_Reason"] = req.body?.ReasonforCancellation;
|
||||||
|
body["iscancelled"] = true;
|
||||||
|
await Order.findByIdAndUpdate(order._id, body);
|
||||||
|
await sendEmail({
|
||||||
|
to: `${order?.user?.email}`, // Change to your recipient
|
||||||
|
from: `${process.env.SEND_EMAIL_FROM}`, // Change to your verified sender
|
||||||
|
subject: `Order #${order?.orderID} Update: Cancellation and Refund Process`,
|
||||||
|
html: `<strong style="color: #1b03a3; font-size: 16px"> Hi ${
|
||||||
|
order?.shippingInfo?.first_Name
|
||||||
|
},</strong>
|
||||||
|
<h3 style="color: #333; font-family: Arial, sans-serif;">We hope this message finds you well. We're writing to inform you that your order ${
|
||||||
|
order?.orderID
|
||||||
|
} has been canceled. We understand that circumstances may change, and we're here to assist you throughout the process.</h3>
|
||||||
|
|
||||||
|
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;"> Items :</h4>
|
||||||
|
<table style="border-collapse: collapse; width: 100%;">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">S No.</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Product Name</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Image</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Quantity</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Price</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">GST Amount</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">SubTotal</th>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
${order?.orderItems
|
||||||
|
?.map(
|
||||||
|
(product, index) => `
|
||||||
|
<tr>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
index + 1
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.name
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;"><img src="${
|
||||||
|
product?.image[0]?.url
|
||||||
|
}" alt="${
|
||||||
|
product.name
|
||||||
|
}" style="max-width: 40px; height: auto;"></td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.quantity
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.price
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product?.gst_amount
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.product_Subtotal
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
`
|
||||||
|
)
|
||||||
|
.join("")}
|
||||||
|
<tr>
|
||||||
|
<th colspan="6" style="border: 1px solid #555; padding: 2px; text-align: right;">Total Amount :</th>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
order?.total_amount
|
||||||
|
}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Cancellation Reason : ${
|
||||||
|
req.body?.ReasonforCancellation
|
||||||
|
}</h4>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Refund Information: The amount from your canceled order will be processed for a refund. Please allow up to 7 working days for the amount to be transferred back to your original payment method.</h4>
|
||||||
|
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">If you have any concerns or further questions, please feel free to reply to this email. We appreciate your understanding and hope to serve you better in the future.
|
||||||
|
</h5>
|
||||||
|
<br/>
|
||||||
|
<span style="color: #555; font-size: 13px;">Best regards,</span><br/>
|
||||||
|
|
||||||
|
<span style="color: #555; font-size: 13px;">Team Smellika</span>`,
|
||||||
|
});
|
||||||
|
return res
|
||||||
|
.status(200)
|
||||||
|
.json({ status: "ok", message: "Order status updated successfully!" });
|
||||||
|
} else if (req.body.status === "processing") {
|
||||||
|
await Order.findByIdAndUpdate(order._id, body);
|
||||||
|
|
||||||
|
await sendEmail({
|
||||||
|
to: `${order?.user?.email}`, // Change to your recipient
|
||||||
|
from: `${process.env.SEND_EMAIL_FROM}`, // Change to your verified sender
|
||||||
|
subject: `Your Order #${order?.orderID} is in Processing!`,
|
||||||
|
html: ` <h3 style="color: #333; font-family: Arial, sans-serif;">Exciting news! Your order #${
|
||||||
|
order?.orderID
|
||||||
|
} has entered the processing phase. Our team is diligently preparing your items for dispatch. Rest assured, we're working hard to ensure everything is perfect for you.</h3>
|
||||||
|
<strong style="color: #1b03a3; font-size: 16px"> Hi ${
|
||||||
|
order?.shippingInfo?.first_Name
|
||||||
|
},</strong>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Order Status : Processing</h4>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Order Items :</h4>
|
||||||
|
<table style="border-collapse: collapse; width: 100%;">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">S No.</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Product Name</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Image</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Quantity</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Price</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">GST Amount</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">SubTotal</th>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
${order?.orderItems
|
||||||
|
?.map(
|
||||||
|
(product, index) => `
|
||||||
|
<tr>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
index + 1
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.name
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;"><img src="${
|
||||||
|
product?.image[0]?.url
|
||||||
|
}" alt="${
|
||||||
|
product.name
|
||||||
|
}" style="max-width: 40px; height: auto;"></td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.quantity
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.price
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product?.gst_amount
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.product_Subtotal
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
`
|
||||||
|
)
|
||||||
|
.join("")}
|
||||||
|
<tr>
|
||||||
|
<th colspan="6" style="border: 1px solid #555; padding: 2px; text-align: right;">Total Amount :</th>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
order?.total_amount
|
||||||
|
}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">We'll send you another email with the tracking details as soon as your order is dispatched. If you have any questions or need assistance, feel free to reply to this email.</h5>
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">Thank you for choosing Smellika!</h5>
|
||||||
|
<br/>
|
||||||
|
<span style="color: #555; font-size: 13px;">Best regards,</span><br/>
|
||||||
|
|
||||||
|
<span style="color: #555; font-size: 13px;">Team Smellika</span>`,
|
||||||
|
});
|
||||||
|
return res
|
||||||
|
.status(200)
|
||||||
|
.json({ status: "ok", message: "Order status updated successfully!" });
|
||||||
|
}
|
||||||
// else if (body.status === "dispatched") {
|
// else if (body.status === "dispatched") {
|
||||||
// const noBalanceRemaining =
|
// const noBalanceRemaining =
|
||||||
// order?.sales_items?.filter((e) => Number(e?.balance_quantity) > 0)
|
// order?.sales_items?.filter((e) => Number(e?.balance_quantity) > 0)
|
||||||
@ -176,20 +353,94 @@ export const updateOrderStatusById = async (req, res) => {
|
|||||||
// { status: body.status, "status_timeline.delivered": currentDate }
|
// { status: body.status, "status_timeline.delivered": currentDate }
|
||||||
// );
|
// );
|
||||||
// }
|
// }
|
||||||
if (req.body.status === "dispatched") {
|
else if (req.body.status === "dispatched") {
|
||||||
body["courier_name"] = req.body.courierName;
|
body["courier_name"] = req.body.courierName;
|
||||||
body["courier_tracking_id"] = req.body.TrackingID;
|
body["courier_tracking_id"] = req.body.TrackingID;
|
||||||
await Order.findByIdAndUpdate(order._id, body);
|
await Order.findByIdAndUpdate(order._id, body);
|
||||||
await sendEmail({
|
await sendEmail({
|
||||||
to: `${req.body.sendemail}`, // Change to your recipient
|
to: `${order?.user?.email}`, // Change to your recipient
|
||||||
|
|
||||||
from: `${process.env.SEND_EMAIL_FROM}`, // Change to your verified sender
|
from: `${process.env.SEND_EMAIL_FROM}`, // Change to your verified sender
|
||||||
|
subject: `Your Order #${order?.orderID} is On Its Way!`,
|
||||||
|
html: `<strong style="color: #1b03a3; font-size: 16px"> Hi ${
|
||||||
|
order?.shippingInfo?.first_Name
|
||||||
|
},</strong>
|
||||||
|
<h3 style="color: #333; font-family: Arial, sans-serif;">Exciting news! Your order #${
|
||||||
|
order?.orderID
|
||||||
|
} has been dispatched and is en route to you. 🚚 Here are the details:</h3>
|
||||||
|
|
||||||
subject: `Your Order is On Its Way!`,
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Courier Name : ${
|
||||||
html: ` <h1 style="color: #333; text-align: center; font-family: Arial, sans-serif;">Welcome to Smellika - Let the Shopping Begin!</h1>
|
req.body.courierName
|
||||||
<strong style="color: #1b03a3; font-size: 16px"> Hi ${req.body?.customerName},</strong>
|
} </h4>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Courier Tracking ID : ${
|
||||||
|
req.body.TrackingID
|
||||||
|
}</h4>
|
||||||
|
|
||||||
<p style="color: #555; font-size: 15px;">Great news! Your order has been confirmed. Here are the details</p>
|
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;"> Items :</h4>
|
||||||
|
<table style="border-collapse: collapse; width: 100%;">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">S No.</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Product Name</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Image</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Quantity</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Price</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">GST Amount</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">SubTotal</th>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
${order?.orderItems
|
||||||
|
?.map(
|
||||||
|
(product, index) => `
|
||||||
|
<tr>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
index + 1
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.name
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;"><img src="${
|
||||||
|
product?.image[0]?.url
|
||||||
|
}" alt="${
|
||||||
|
product.name
|
||||||
|
}" style="max-width: 40px; height: auto;"></td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.quantity
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.price
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product?.gst_amount
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.product_Subtotal
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
`
|
||||||
|
)
|
||||||
|
.join("")}
|
||||||
|
<tr>
|
||||||
|
<th colspan="6" style="border: 1px solid #555; padding: 2px; text-align: right;">Total Amount :</th>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
order?.total_amount
|
||||||
|
}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<h3 style="color: #333; font-family: Arial, sans-serif;">Order Status : Dispatched</h3>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">If you have any questions or need assistance, feel free to reply to this email.
|
||||||
|
</h4>
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">Thanks for choosing Smellika! We hope you enjoy your purchase.
|
||||||
|
</h5>
|
||||||
<br/>
|
<br/>
|
||||||
<span style="color: #555; font-size: 13px;">Best regards,</span><br/>
|
<span style="color: #555; font-size: 13px;">Best regards,</span><br/>
|
||||||
|
|
||||||
@ -202,11 +453,97 @@ export const updateOrderStatusById = async (req, res) => {
|
|||||||
body["isDelivered"] = true;
|
body["isDelivered"] = true;
|
||||||
body["DeliveredDate"] = req.body.DDate;
|
body["DeliveredDate"] = req.body.DDate;
|
||||||
await Order.findByIdAndUpdate(order._id, body);
|
await Order.findByIdAndUpdate(order._id, body);
|
||||||
|
await sendEmail({
|
||||||
|
to: `${order?.user?.email}`, // Change to your recipient
|
||||||
|
from: `${process.env.SEND_EMAIL_FROM}`, // Change to your verified sender
|
||||||
|
subject: `Your Order #${order?.orderID} Has Been Delivered!`,
|
||||||
|
html: `<strong style="color: #1b03a3; font-size: 16px"> Hi ${
|
||||||
|
order?.shippingInfo?.first_Name
|
||||||
|
},</strong>
|
||||||
|
<h3 style="color: #333; font-family: Arial, sans-serif;">Great news! Your order #${
|
||||||
|
order?.orderID
|
||||||
|
} has been successfully delivered to your doorstep. We hope everything is just as you expected!</h3>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;"> Items :</h4>
|
||||||
|
<table style="border-collapse: collapse; width: 100%;">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">S No.</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Product Name</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Image</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Quantity</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">Price</th>
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">GST Amount</th>
|
||||||
|
|
||||||
|
<th style="border: 1px solid #555; padding: 2px; text-align: center;">SubTotal</th>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
${order?.orderItems
|
||||||
|
?.map(
|
||||||
|
(product, index) => `
|
||||||
|
<tr>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
index + 1
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.name
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;"><img src="${
|
||||||
|
product?.image[0]?.url
|
||||||
|
}" alt="${
|
||||||
|
product.name
|
||||||
|
}" style="max-width: 40px; height: auto;"></td>
|
||||||
|
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">${
|
||||||
|
product.quantity
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.price
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product?.gst_amount
|
||||||
|
}</td>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
product.product_Subtotal
|
||||||
|
}</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
`
|
||||||
|
)
|
||||||
|
.join("")}
|
||||||
|
<tr>
|
||||||
|
<th colspan="6" style="border: 1px solid #555; padding: 2px; text-align: right;">Total Amount :</th>
|
||||||
|
<td style="border: 1px solid #555; padding: 2px; text-align: center;">₹${
|
||||||
|
order?.total_amount
|
||||||
|
}</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
<h3 style="color: #333; font-family: Arial, sans-serif;">Delivery Date: ${
|
||||||
|
req.body.DDate
|
||||||
|
}</h3>
|
||||||
|
<h4 style="color: #333; font-family: Arial, sans-serif;">Your satisfaction is our priority, and we'd love to hear about your experience. Please take a moment to share your thoughts by leaving a review. Your feedback is invaluable to us!
|
||||||
|
</h4>
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">If you have any questions or concerns about your order, feel free to reply to this email.
|
||||||
|
</h5>
|
||||||
|
<h5 style="color: #333; font-family: Arial, sans-serif;">Thank you for choosing Smellika! We hope to serve you again soon.
|
||||||
|
|
||||||
|
</h5>
|
||||||
|
<br/>
|
||||||
|
<span style="color: #555; font-size: 13px;">Best regards,</span><br/>
|
||||||
|
|
||||||
|
<span style="color: #555; font-size: 13px;">Team Smellika</span>`,
|
||||||
|
});
|
||||||
|
|
||||||
return res
|
return res
|
||||||
.status(200)
|
.status(200)
|
||||||
.json({ status: "ok", message: "Order status updated successfully!" });
|
.json({ status: "ok", message: "Order status updated successfully!" });
|
||||||
} else {
|
} else {
|
||||||
await Order.findByIdAndUpdate(order._id, body);
|
// await Order.findByIdAndUpdate(order._id, body);
|
||||||
// console.log(order);
|
// console.log(order);
|
||||||
res
|
res
|
||||||
.status(200)
|
.status(200)
|
||||||
|
@ -155,6 +155,13 @@ const orderSchema = new mongoose.Schema(
|
|||||||
cancelled: { type: Date },
|
cancelled: { type: Date },
|
||||||
returned: { type: Date },
|
returned: { type: Date },
|
||||||
},
|
},
|
||||||
|
iscancelled: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
|
order_Cancelled_Reason: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
courier_name: { type: String },
|
courier_name: { type: String },
|
||||||
courier_tracking_id: { type: String },
|
courier_tracking_id: { type: String },
|
||||||
},
|
},
|
||||||
|
@ -51,7 +51,9 @@ router
|
|||||||
.route("/getAll/")
|
.route("/getAll/")
|
||||||
.get(isAuthenticatedUser, authorizeRoles("admin"), getOrders);
|
.get(isAuthenticatedUser, authorizeRoles("admin"), getOrders);
|
||||||
router.route("/getOne/:id").get(isAuthenticatedUser, getSingleOrder);
|
router.route("/getOne/:id").get(isAuthenticatedUser, getSingleOrder);
|
||||||
router.route("/change/status/:id").patch(updateOrderStatusById);
|
router
|
||||||
|
.route("/change/status/:id")
|
||||||
|
.patch(isAuthenticatedUser, authorizeRoles("admin"), updateOrderStatusById);
|
||||||
|
|
||||||
router
|
router
|
||||||
.route("/delete/:id")
|
.route("/delete/:id")
|
||||||
|
38
resources/Panels/Panel1Model.js
Normal file
38
resources/Panels/Panel1Model.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import mongoose from "mongoose";
|
||||||
|
const { Schema, model } = mongoose;
|
||||||
|
|
||||||
|
const panel1Schema = new Schema(
|
||||||
|
{
|
||||||
|
title: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
content: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
image: {
|
||||||
|
public_id: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
url: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
addedBy: {
|
||||||
|
type: mongoose.Schema.ObjectId,
|
||||||
|
ref: "User",
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
displayPanel: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
export const Panel1 = model(
|
||||||
|
"Panel1",
|
||||||
|
panel1Schema
|
||||||
|
);
|
38
resources/Panels/Panel2Model.js
Normal file
38
resources/Panels/Panel2Model.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import mongoose from "mongoose";
|
||||||
|
const { Schema, model } = mongoose;
|
||||||
|
|
||||||
|
const panel2Schema = new Schema(
|
||||||
|
{
|
||||||
|
title: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
content: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
image: {
|
||||||
|
public_id: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
url: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
addedBy: {
|
||||||
|
type: mongoose.Schema.ObjectId,
|
||||||
|
ref: "User",
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
displayPanel: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
export const Panel2 = model(
|
||||||
|
"Panel2",
|
||||||
|
panel2Schema
|
||||||
|
);
|
38
resources/Panels/Panel3Model.js
Normal file
38
resources/Panels/Panel3Model.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import mongoose from "mongoose";
|
||||||
|
const { Schema, model } = mongoose;
|
||||||
|
|
||||||
|
const panel3Schema = new Schema(
|
||||||
|
{
|
||||||
|
title: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
content: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
image: {
|
||||||
|
public_id: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
url: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
addedBy: {
|
||||||
|
type: mongoose.Schema.ObjectId,
|
||||||
|
ref: "User",
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
displayPanel: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
export const Panel3 = model(
|
||||||
|
"Panel3",
|
||||||
|
panel3Schema
|
||||||
|
);
|
38
resources/Panels/Panel4Model.js
Normal file
38
resources/Panels/Panel4Model.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
import mongoose from "mongoose";
|
||||||
|
const { Schema, model } = mongoose;
|
||||||
|
|
||||||
|
const panel4Schema = new Schema(
|
||||||
|
{
|
||||||
|
title: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
content: {
|
||||||
|
type: String,
|
||||||
|
default: ''
|
||||||
|
},
|
||||||
|
image: {
|
||||||
|
public_id: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
url: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
addedBy: {
|
||||||
|
type: mongoose.Schema.ObjectId,
|
||||||
|
ref: "User",
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
displayPanel: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
export const Panel4 = model(
|
||||||
|
"Panel4",
|
||||||
|
panel4Schema
|
||||||
|
);
|
547
resources/Panels/PanelController.js
Normal file
547
resources/Panels/PanelController.js
Normal file
@ -0,0 +1,547 @@
|
|||||||
|
import cloudinary from "../../Utils/cloudinary.js";
|
||||||
|
import { Panel1 } from "./Panel1Model.js";
|
||||||
|
import { Panel2 } from "./Panel2Model.js";
|
||||||
|
import { Panel3 } from "./Panel3Model.js";
|
||||||
|
import { Panel4 } from "./Panel4Model.js";
|
||||||
|
|
||||||
|
|
||||||
|
export const AddPanel1 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
req.body.user = req.user._id;
|
||||||
|
const { content,title,displayPanel} = req.body;
|
||||||
|
let image; // To store Cloudinary image details
|
||||||
|
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
const imageFile = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
imageFile.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the blog post
|
||||||
|
const panel1 = await Panel1.create({
|
||||||
|
title,
|
||||||
|
image,
|
||||||
|
content,
|
||||||
|
displayPanel,
|
||||||
|
addedBy: req.user._id,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
res.status(201).json({
|
||||||
|
success: true,
|
||||||
|
panel1,
|
||||||
|
message: "Added successfully",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getPanel1 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
// if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
const panel1 = await Panel1.find();
|
||||||
|
|
||||||
|
res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
panel1,
|
||||||
|
message: "Found successfully ",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const updatePanel1 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
|
||||||
|
// Check if the user is authenticated
|
||||||
|
if (!req.user) {
|
||||||
|
return res.status(400).json({ message: "Please login!" });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Destructure request body
|
||||||
|
const { title, content,displayPanel } = req.body;
|
||||||
|
|
||||||
|
// Prepare an object for the updated testimonial data
|
||||||
|
const updatedPanel1Data = {
|
||||||
|
title,
|
||||||
|
content,
|
||||||
|
displayPanel
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check if files are uploaded
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
// If image file is uploaded, upload it to cloudinary
|
||||||
|
const uploadedImage = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
uploadedImage.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prepare the image object with public_id and url
|
||||||
|
const image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Assign the uploaded image to the Blog's image field
|
||||||
|
updatedPanel1Data.image = image;
|
||||||
|
}
|
||||||
|
const modifiedPanel = await Panel1.findOneAndUpdate(
|
||||||
|
{ _id: req.params.id },
|
||||||
|
{ $set: updatedPanel1Data },
|
||||||
|
{ new: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
return res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
ModifyBlog: modifiedPanel,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
export const AddPanel2 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
req.body.user = req.user._id;
|
||||||
|
const { content,title,displayPanel} = req.body;
|
||||||
|
let image; // To store Cloudinary image details
|
||||||
|
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
const imageFile = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
imageFile.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the blog post
|
||||||
|
const panel2 = await Panel2.create({
|
||||||
|
title,
|
||||||
|
image,
|
||||||
|
content,
|
||||||
|
displayPanel,
|
||||||
|
addedBy: req.user._id,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
res.status(201).json({
|
||||||
|
success: true,
|
||||||
|
panel2,
|
||||||
|
message: "Added successfully",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getPanel2 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
// if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
const panel2 = await Panel2.find();
|
||||||
|
|
||||||
|
res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
panel2,
|
||||||
|
message: "Found successfully ",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const updatePanel2 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
|
||||||
|
// Check if the user is authenticated
|
||||||
|
if (!req.user) {
|
||||||
|
return res.status(400).json({ message: "Please login!" });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Destructure request body
|
||||||
|
const { title, content,displayPanel } = req.body;
|
||||||
|
|
||||||
|
// Prepare an object for the updated testimonial data
|
||||||
|
const updatedPanel2Data = {
|
||||||
|
title,
|
||||||
|
content,
|
||||||
|
displayPanel
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check if files are uploaded
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
// If image file is uploaded, upload it to cloudinary
|
||||||
|
const uploadedImage = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
uploadedImage.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prepare the image object with public_id and url
|
||||||
|
const image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Assign the uploaded image to the Blog's image field
|
||||||
|
updatedPanel2Data.image = image;
|
||||||
|
}
|
||||||
|
const modifiedPanel = await Panel2.findOneAndUpdate(
|
||||||
|
{ _id: req.params.id },
|
||||||
|
{ $set: updatedPanel2Data },
|
||||||
|
{ new: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
return res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
ModifyBlog: modifiedPanel,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
export const AddPanel3 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
req.body.user = req.user._id;
|
||||||
|
const { content,title,displayPanel} = req.body;
|
||||||
|
let image; // To store Cloudinary image details
|
||||||
|
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
const imageFile = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
imageFile.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the blog post
|
||||||
|
const panel3 = await Panel3.create({
|
||||||
|
title,
|
||||||
|
image,
|
||||||
|
content,
|
||||||
|
displayPanel,
|
||||||
|
addedBy: req.user._id,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
res.status(201).json({
|
||||||
|
success: true,
|
||||||
|
panel3,
|
||||||
|
message: "Added successfully",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getPanel3 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
// if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
const panel3 = await Panel3.find();
|
||||||
|
|
||||||
|
res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
panel3,
|
||||||
|
message: "Found successfully ",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const updatePanel3 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
|
||||||
|
// Check if the user is authenticated
|
||||||
|
if (!req.user) {
|
||||||
|
return res.status(400).json({ message: "Please login!" });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Destructure request body
|
||||||
|
const { title, content,displayPanel } = req.body;
|
||||||
|
|
||||||
|
// Prepare an object for the updated testimonial data
|
||||||
|
const updatedPanel3Data = {
|
||||||
|
title,
|
||||||
|
content,
|
||||||
|
displayPanel
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check if files are uploaded
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
// If image file is uploaded, upload it to cloudinary
|
||||||
|
const uploadedImage = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
uploadedImage.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prepare the image object with public_id and url
|
||||||
|
const image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Assign the uploaded image to the Blog's image field
|
||||||
|
updatedPanel3Data.image = image;
|
||||||
|
}
|
||||||
|
const modifiedPanel = await Panel3.findOneAndUpdate(
|
||||||
|
{ _id: req.params.id },
|
||||||
|
{ $set: updatedPanel3Data },
|
||||||
|
{ new: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
return res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
ModifyBlog: modifiedPanel,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
export const AddPanel4 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
req.body.user = req.user._id;
|
||||||
|
const { content,title,displayPanel} = req.body;
|
||||||
|
let image; // To store Cloudinary image details
|
||||||
|
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
const imageFile = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
imageFile.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the blog post
|
||||||
|
const panel4 = await Panel4.create({
|
||||||
|
title,
|
||||||
|
image,
|
||||||
|
content,
|
||||||
|
displayPanel,
|
||||||
|
addedBy: req.user._id,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
res.status(201).json({
|
||||||
|
success: true,
|
||||||
|
panel4,
|
||||||
|
message: "Added successfully",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getPanel4 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
// if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
// console.log(req?.user)
|
||||||
|
|
||||||
|
const panel4 = await Panel4.find();
|
||||||
|
|
||||||
|
res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
panel4,
|
||||||
|
message: "Found successfully ",
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const updatePanel4 = async (req, res) => {
|
||||||
|
try {
|
||||||
|
if (!req?.user) return res.status(400).json({ message: "please login !" });
|
||||||
|
|
||||||
|
// Check if the user is authenticated
|
||||||
|
if (!req.user) {
|
||||||
|
return res.status(400).json({ message: "Please login!" });
|
||||||
|
}
|
||||||
|
|
||||||
|
// Destructure request body
|
||||||
|
const { title, content,displayPanel } = req.body;
|
||||||
|
|
||||||
|
// Prepare an object for the updated testimonial data
|
||||||
|
const updatePanel4Data = {
|
||||||
|
title,
|
||||||
|
content,
|
||||||
|
displayPanel
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check if files are uploaded
|
||||||
|
if (req.files && req.files.image) {
|
||||||
|
// If image file is uploaded, upload it to cloudinary
|
||||||
|
const uploadedImage = req.files.image;
|
||||||
|
const result = await cloudinary.v2.uploader.upload(
|
||||||
|
uploadedImage.tempFilePath,
|
||||||
|
{
|
||||||
|
folder: "smellica/blog",
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prepare the image object with public_id and url
|
||||||
|
const image = {
|
||||||
|
public_id: result.public_id,
|
||||||
|
url: result.secure_url,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Assign the uploaded image to the Blog's image field
|
||||||
|
updatePanel4Data.image = image;
|
||||||
|
}
|
||||||
|
const modifiedPanel = await Panel4.findOneAndUpdate(
|
||||||
|
{ _id: req.params.id },
|
||||||
|
{ $set: updatePanel4Data },
|
||||||
|
{ new: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
return res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
ModifyBlog: modifiedPanel,
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
message: error.message ? error.message : "Something went Wrong",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const deleteImageFromCloudinary = async (req, res) => {
|
||||||
|
const { public_id } = req.params;
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (!public_id) {
|
||||||
|
return res.status(400).json({
|
||||||
|
success: false,
|
||||||
|
msg: "Please Provide Product ID!",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
const response = await cloudinary.v2.uploader.destroy(public_id);
|
||||||
|
if (response) {
|
||||||
|
res.status(200).json({
|
||||||
|
success: true,
|
||||||
|
msg: "Deleted Successfully!!",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
res.status(500).json({
|
||||||
|
success: false,
|
||||||
|
msg: error.message ? error.message : "Something went wrong!",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
59
resources/Panels/PanelRoutes.js
Normal file
59
resources/Panels/PanelRoutes.js
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
import express from "express";
|
||||||
|
|
||||||
|
import { isAuthenticatedUser, authorizeRoles } from "../../middlewares/auth.js";
|
||||||
|
import { AddPanel1, AddPanel2, AddPanel3, AddPanel4, deleteImageFromCloudinary, getPanel1, getPanel2, getPanel3, getPanel4, updatePanel1, updatePanel2, updatePanel3, updatePanel4 } from "./PanelController.js";
|
||||||
|
|
||||||
|
const router = express.Router();
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel1/add")
|
||||||
|
.post(isAuthenticatedUser, authorizeRoles("admin"), AddPanel1);
|
||||||
|
router
|
||||||
|
.route("/panel1/get")
|
||||||
|
.get(getPanel1);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel1/update/:id")
|
||||||
|
.patch(isAuthenticatedUser, authorizeRoles("admin"), updatePanel1);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel2/add")
|
||||||
|
.post(isAuthenticatedUser, authorizeRoles("admin"), AddPanel2);
|
||||||
|
router
|
||||||
|
.route("/panel2/get")
|
||||||
|
.get(getPanel2);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel2/update/:id")
|
||||||
|
.patch(isAuthenticatedUser, authorizeRoles("admin"), updatePanel2);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel3/add")
|
||||||
|
.post(isAuthenticatedUser, authorizeRoles("admin"), AddPanel3);
|
||||||
|
router
|
||||||
|
.route("/panel3/get")
|
||||||
|
.get(getPanel3);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel3/update/:id")
|
||||||
|
.patch(isAuthenticatedUser, authorizeRoles("admin"), updatePanel3);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel4/add")
|
||||||
|
.post(isAuthenticatedUser, authorizeRoles("admin"), AddPanel4);
|
||||||
|
router
|
||||||
|
.route("/panel4/get")
|
||||||
|
.get(getPanel4);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/panel4/update/:id")
|
||||||
|
.patch(isAuthenticatedUser, authorizeRoles("admin"), updatePanel4);
|
||||||
|
|
||||||
|
router
|
||||||
|
.route("/deleteImage/jatinMor/panel/:public_id")
|
||||||
|
.delete(
|
||||||
|
isAuthenticatedUser,
|
||||||
|
authorizeRoles("admin"),
|
||||||
|
deleteImageFromCloudinary
|
||||||
|
);
|
||||||
|
export default router;
|
@ -80,7 +80,7 @@ export const getAllProductsDevicesFirst = async (req, res) => {
|
|||||||
try {
|
try {
|
||||||
// we want products with category name Device to be displayed first, so i have first found the products with category name Devices then made another request to find all products and filtered products with category devices , then merged both arrays so we get devices first then all other categories
|
// we want products with category name Device to be displayed first, so i have first found the products with category name Devices then made another request to find all products and filtered products with category devices , then merged both arrays so we get devices first then all other categories
|
||||||
|
|
||||||
const categoryName = 'Devices';
|
const categoryName = "Devices";
|
||||||
// Find the category object by name first
|
// Find the category object by name first
|
||||||
const category = await CategoryModel.findOne({ categoryName });
|
const category = await CategoryModel.findOne({ categoryName });
|
||||||
|
|
||||||
@ -88,7 +88,9 @@ export const getAllProductsDevicesFirst = async (req, res) => {
|
|||||||
throw new Error("Category not found");
|
throw new Error("Category not found");
|
||||||
}
|
}
|
||||||
// products with device category
|
// products with device category
|
||||||
const deviceProducts = await Product.find({ category: category._id }).populate('category');
|
const deviceProducts = await Product.find({
|
||||||
|
category: category._id,
|
||||||
|
}).populate("category");
|
||||||
|
|
||||||
// all products
|
// all products
|
||||||
const allProducts = await Product.find()
|
const allProducts = await Product.find()
|
||||||
@ -100,10 +102,12 @@ export const getAllProductsDevicesFirst = async (req, res) => {
|
|||||||
createdAt: -1,
|
createdAt: -1,
|
||||||
});
|
});
|
||||||
// filtering out products with device category
|
// filtering out products with device category
|
||||||
const filteredProducts = allProducts.filter((ele) => { return ele.category?.categoryName !== categoryName })
|
const filteredProducts = allProducts.filter((ele) => {
|
||||||
|
return ele.category?.categoryName !== categoryName;
|
||||||
|
});
|
||||||
|
|
||||||
// merging both deviceProcuts and filtered products
|
// merging both deviceProcuts and filtered products
|
||||||
const product = deviceProducts.concat(filteredProducts)
|
const product = deviceProducts.concat(filteredProducts);
|
||||||
if (product) {
|
if (product) {
|
||||||
return res.status(200).json({
|
return res.status(200).json({
|
||||||
success: true,
|
success: true,
|
||||||
@ -240,10 +244,10 @@ export const updateProduct = async (req, res) => {
|
|||||||
category,
|
category,
|
||||||
image,
|
image,
|
||||||
gst_amount,
|
gst_amount,
|
||||||
|
product_Status,
|
||||||
gst,
|
gst,
|
||||||
total_amount,
|
total_amount,
|
||||||
} = req.body;
|
} = req.body;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// Prepare an array for the images
|
// Prepare an array for the images
|
||||||
const jsonArray = JSON.parse(image);
|
const jsonArray = JSON.parse(image);
|
||||||
@ -286,6 +290,7 @@ export const updateProduct = async (req, res) => {
|
|||||||
$set: {
|
$set: {
|
||||||
name,
|
name,
|
||||||
description,
|
description,
|
||||||
|
product_Status,
|
||||||
price,
|
price,
|
||||||
category,
|
category,
|
||||||
image: updatedImages,
|
image: updatedImages,
|
||||||
@ -388,7 +393,9 @@ export const getProductsByCategory = async (req, res) => {
|
|||||||
if (!category) {
|
if (!category) {
|
||||||
throw new Error("Category not found");
|
throw new Error("Category not found");
|
||||||
}
|
}
|
||||||
const products = await Product.find({ category: category._id }).populate('category');
|
const products = await Product.find({ category: category._id }).populate(
|
||||||
|
"category"
|
||||||
|
);
|
||||||
// console.log(products);
|
// console.log(products);
|
||||||
|
|
||||||
if (products && products.length > 0) {
|
if (products && products.length > 0) {
|
||||||
|
@ -51,6 +51,11 @@ const productSchema = new Schema(
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
product_Status: {
|
||||||
|
type: String,
|
||||||
|
enum: ["Active", "Inactive"],
|
||||||
|
default: "Active",
|
||||||
|
},
|
||||||
addedBy: {
|
addedBy: {
|
||||||
type: Schema.Types.ObjectId,
|
type: Schema.Types.ObjectId,
|
||||||
ref: "User",
|
ref: "User",
|
||||||
|
Loading…
Reference in New Issue
Block a user