Tests, UX improvements.
This commit is contained in:
parent
4e6f5d36b8
commit
0ae18f495e
63 changed files with 1384 additions and 2330 deletions
|
|
@ -1,4 +1,5 @@
|
|||
import Event from "../../../models/event";
|
||||
import Member from "../../../models/member";
|
||||
import {
|
||||
sendEventCancellationEmail,
|
||||
sendWaitlistNotificationEmail,
|
||||
|
|
@ -56,19 +57,40 @@ export default defineEventHandler(async (event) => {
|
|||
$pull: { registrations: { email: registration.email } },
|
||||
$inc: { registeredCount: -1 },
|
||||
},
|
||||
{ runValidators: false }
|
||||
{ runValidators: false },
|
||||
);
|
||||
|
||||
// Send cancellation confirmation email
|
||||
// Log activity + send cancellation confirmation email
|
||||
const cancellingMember = await Member.findOne({
|
||||
email: registration.email,
|
||||
}).lean();
|
||||
|
||||
if (cancellingMember) {
|
||||
logActivity(cancellingMember._id, 'event_cancelled', {
|
||||
eventId: eventDoc._id,
|
||||
eventTitle: eventDoc.title,
|
||||
eventSlug: eventDoc.slug
|
||||
})
|
||||
}
|
||||
|
||||
try {
|
||||
const eventData = {
|
||||
title: eventDoc.title,
|
||||
slug: eventDoc.slug,
|
||||
_id: eventDoc._id,
|
||||
};
|
||||
await sendEventCancellationEmail(registration, eventData);
|
||||
const shouldSendCancellation =
|
||||
!cancellingMember || cancellingMember.notifications?.events !== false;
|
||||
if (shouldSendCancellation) {
|
||||
const eventData = {
|
||||
title: eventDoc.title,
|
||||
slug: eventDoc.slug,
|
||||
_id: eventDoc._id,
|
||||
};
|
||||
await sendEventCancellationEmail(registration, eventData);
|
||||
if (cancellingMember) {
|
||||
logActivity(cancellingMember._id, 'email_sent', {
|
||||
emailType: 'event_cancellation',
|
||||
subject: `Registration cancelled for ${eventDoc.title}`
|
||||
})
|
||||
}
|
||||
}
|
||||
} catch (emailError) {
|
||||
// Log error but don't fail the cancellation
|
||||
console.error("Failed to send cancellation email:", emailError);
|
||||
}
|
||||
|
||||
|
|
@ -89,18 +111,30 @@ export default defineEventHandler(async (event) => {
|
|||
|
||||
// Notify the first person on the waitlist who hasn't been notified yet
|
||||
const waitlistEntry = eventDoc.tickets.waitlist.entries.find(
|
||||
(entry) => !entry.notified
|
||||
(entry) => !entry.notified,
|
||||
);
|
||||
|
||||
if (waitlistEntry) {
|
||||
await sendWaitlistNotificationEmail(waitlistEntry, eventData);
|
||||
|
||||
// Mark as notified using findByIdAndUpdate to avoid re-validating the document
|
||||
const entryIndex = eventDoc.tickets.waitlist.entries.indexOf(waitlistEntry);
|
||||
const waitlistedMember = await Member.findOne({
|
||||
email: waitlistEntry.email,
|
||||
}).lean();
|
||||
const shouldNotifyWaitlist =
|
||||
!waitlistedMember ||
|
||||
waitlistedMember.notifications?.events !== false;
|
||||
if (shouldNotifyWaitlist) {
|
||||
await sendWaitlistNotificationEmail(waitlistEntry, eventData);
|
||||
}
|
||||
// Always mark as notified so we move on regardless
|
||||
const entryIndex =
|
||||
eventDoc.tickets.waitlist.entries.indexOf(waitlistEntry);
|
||||
await Event.findByIdAndUpdate(
|
||||
eventDoc._id,
|
||||
{ $set: { [`tickets.waitlist.entries.${entryIndex}.notified`]: true } },
|
||||
{ runValidators: false }
|
||||
{
|
||||
$set: {
|
||||
[`tickets.waitlist.entries.${entryIndex}.notified`]: true,
|
||||
},
|
||||
},
|
||||
{ runValidators: false },
|
||||
);
|
||||
}
|
||||
} catch (waitlistError) {
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue