edit event
This commit is contained in:
@@ -54,7 +54,10 @@ const EditEventsPage = () => {
|
|||||||
const fetchEvent = async () => {
|
const fetchEvent = async () => {
|
||||||
try {
|
try {
|
||||||
const response = await axios.get(`${config.serverAddress}/events/${id}`);
|
const response = await axios.get(`${config.serverAddress}/events/${id}`);
|
||||||
setInitialValues(response.data);
|
// Convert the date to the correct format for the input field
|
||||||
|
const event = response.data;
|
||||||
|
event.date = new Date(event.date).toISOString().split('T')[0];
|
||||||
|
setInitialValues(event);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Failed to fetch event data:", error);
|
console.error("Failed to fetch event data:", error);
|
||||||
}
|
}
|
||||||
@@ -157,13 +160,6 @@ const EditEventsPage = () => {
|
|||||||
placeholder="Enter slots available"
|
placeholder="Enter slots available"
|
||||||
labelPlacement="inside"
|
labelPlacement="inside"
|
||||||
/>
|
/>
|
||||||
<NextUIFormikInput
|
|
||||||
label="Image URL"
|
|
||||||
name="imageUrl"
|
|
||||||
type="text"
|
|
||||||
placeholder="Enter image URL"
|
|
||||||
labelPlacement="inside"
|
|
||||||
/>
|
|
||||||
<div className="flex flex-row-reverse border">
|
<div className="flex flex-row-reverse border">
|
||||||
<Button
|
<Button
|
||||||
type="submit"
|
type="submit"
|
||||||
|
|||||||
@@ -77,7 +77,12 @@ const EventsPage: React.FC = () => {
|
|||||||
const matchTownCouncil = selectedTownCouncil
|
const matchTownCouncil = selectedTownCouncil
|
||||||
? event.location === selectedTownCouncil
|
? event.location === selectedTownCouncil
|
||||||
: true;
|
: true;
|
||||||
const matchTime = selectedTime ? event.time === selectedTime : true;
|
const matchTime = selectedTime
|
||||||
|
? event.time.toLowerCase().trim() === selectedTime.toLowerCase().trim()
|
||||||
|
: true;
|
||||||
|
|
||||||
|
console.log('Event Time:', event.time);
|
||||||
|
console.log(`Filtering: ${event.title} | Category: ${matchCategory} | Town Council: ${matchTownCouncil} | Time: ${matchTime}`);
|
||||||
|
|
||||||
return matchCategory && matchTownCouncil && matchTime;
|
return matchCategory && matchTownCouncil && matchTime;
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -9,6 +9,55 @@ const sharp = require("sharp");
|
|||||||
|
|
||||||
const upload = multer({ storage: multer.memoryStorage() });
|
const upload = multer({ storage: multer.memoryStorage() });
|
||||||
|
|
||||||
|
router.get("/", async (req, res) => {
|
||||||
|
try {
|
||||||
|
// Extract filter criteria from query parameters
|
||||||
|
const { category, townCouncil, time } = req.query;
|
||||||
|
|
||||||
|
// Log incoming parameters
|
||||||
|
console.log("Filter Parameters:", { category, townCouncil, time });
|
||||||
|
|
||||||
|
// Map time to category
|
||||||
|
const timeToCategory = (time) => {
|
||||||
|
if (!time) return null;
|
||||||
|
const hour = new Date(time).getHours();
|
||||||
|
if (hour < 12) return 'Morning';
|
||||||
|
if (hour < 18) return 'Afternoon';
|
||||||
|
return 'Evening';
|
||||||
|
};
|
||||||
|
|
||||||
|
// Convert the time query parameter to a category
|
||||||
|
const timeCategory = timeToCategory(time);
|
||||||
|
|
||||||
|
// Construct the filter object
|
||||||
|
let filter = {};
|
||||||
|
if (category) filter.category = category;
|
||||||
|
if (townCouncil) filter.townCouncil = townCouncil;
|
||||||
|
if (timeCategory) filter.timeCategory = timeCategory;
|
||||||
|
|
||||||
|
// Log constructed filter object
|
||||||
|
console.log("Constructed Filter Object:", filter);
|
||||||
|
|
||||||
|
// Fetch filtered events from the database
|
||||||
|
const filteredEvents = await Events.findAll({
|
||||||
|
where: {
|
||||||
|
[Op.and]: [
|
||||||
|
category ? { category } : {},
|
||||||
|
townCouncil ? { townCouncil } : {},
|
||||||
|
timeCategory ? { timeCategory } : {}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Respond with the filtered events
|
||||||
|
res.json(filteredEvents);
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error fetching events:", error);
|
||||||
|
res.status(500).json({ message: "Internal Server Error" });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
router.post("/", upload.fields([
|
router.post("/", upload.fields([
|
||||||
{ name: 'evtPicture', maxCount: 1 },
|
{ name: 'evtPicture', maxCount: 1 },
|
||||||
]), async (req, res) => {
|
]), async (req, res) => {
|
||||||
@@ -30,9 +79,16 @@ router.post("/", upload.fields([
|
|||||||
data = await validationSchema.validate(data, { abortEarly: false });
|
data = await validationSchema.validate(data, { abortEarly: false });
|
||||||
|
|
||||||
// Process valid data
|
// Process valid data
|
||||||
let evtPicture = files.evtPicture[0].buffer;
|
let evtPicture = files.evtPicture ? files.evtPicture[0].buffer : null;
|
||||||
|
|
||||||
let result = await Events.create({ ...data, evtPicture });
|
if (evtPicture) {
|
||||||
|
evtPicture = await sharp(evtPicture)
|
||||||
|
.resize(800, 600)
|
||||||
|
.jpeg()
|
||||||
|
.toBuffer();
|
||||||
|
}
|
||||||
|
|
||||||
|
let result = await Events.create({ ...data, evtPicture});
|
||||||
|
|
||||||
res.json(result);
|
res.json(result);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@@ -46,6 +102,7 @@ router.post("/", upload.fields([
|
|||||||
let list = await Events.findAll({
|
let list = await Events.findAll({
|
||||||
order: [['createdAt', 'DESC']],
|
order: [['createdAt', 'DESC']],
|
||||||
});
|
});
|
||||||
|
|
||||||
res.json(list);
|
res.json(list);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Error fetching events:", error);
|
console.error("Error fetching events:", error);
|
||||||
@@ -92,7 +149,6 @@ router.put("/:id", async (req, res) => {
|
|||||||
time: yup.string(),
|
time: yup.string(),
|
||||||
location: yup.string(),
|
location: yup.string(),
|
||||||
category: yup.string(),
|
category: yup.string(),
|
||||||
imageUrl: yup.string(),
|
|
||||||
slotsAvailable: yup.number().integer(),
|
slotsAvailable: yup.number().integer(),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user