edit event

This commit is contained in:
Harini312821
2024-08-02 10:41:31 +08:00
parent d229ade9dd
commit bbb5d260bb
3 changed files with 70 additions and 13 deletions

View File

@@ -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"

View File

@@ -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;
}); });

View File

@@ -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(),
}); });