From 884afa621636f11f86c14108b79ad973d5d52fe5 Mon Sep 17 00:00:00 2001 From: Lola Date: Tue, 14 May 2024 16:21:33 -0500 Subject: [PATCH] improve registrations overview adds infoboxes to students who have dietary restrictions, need to leave overnight, or have requested a laptop add "survey response breakdown" component, displaying statistics on how students filled out the post-registration survey --- src/components/RegistrationGraph.js | 1 - src/components/Ticket.gql | 2 + src/components/Ticket.js | 6 +- src/components/TicketSurveyBreakdown.gql | 6 ++ src/components/TicketSurveyBreakdown.js | 69 ++++++++++++++++++++++ src/pages/events/[event]/tickets/index.gql | 2 + src/pages/events/[event]/tickets/index.js | 7 ++- 7 files changed, 89 insertions(+), 4 deletions(-) create mode 100644 src/components/TicketSurveyBreakdown.gql create mode 100644 src/components/TicketSurveyBreakdown.js diff --git a/src/components/RegistrationGraph.js b/src/components/RegistrationGraph.js index a84a737..010a41e 100644 --- a/src/components/RegistrationGraph.js +++ b/src/components/RegistrationGraph.js @@ -13,7 +13,6 @@ export default function RegistrationGraph({ event, children, ...props }) { const graphStart = now.clone().subtract(DAYS, 'days'); const data = []; const ticketsWithDate = event.tickets.map((e) => ({ ...e, createdAt: moment(e.createdAt) })); - for (let current = graphStart.clone(); current < now; current = current.add({ day: 1 })) { data.push({ x: -1 * Math.floor(now.diff(current, 'days')), diff --git a/src/components/Ticket.gql b/src/components/Ticket.gql index 78ce186..b078b0d 100644 --- a/src/components/Ticket.gql +++ b/src/components/Ticket.gql @@ -13,11 +13,13 @@ fragment Ticket on ClearTicket { checkedIn checkedOut vaccineVerified: getMetadata(key: "vaccineVerified") + surveyResponses promoCode { code } event { id + overnightMinAge } } diff --git a/src/components/Ticket.js b/src/components/Ticket.js index 34deef8..7f4b1e8 100644 --- a/src/components/Ticket.js +++ b/src/components/Ticket.js @@ -5,7 +5,7 @@ import {Box, Button, Text} from "@codeday/topo/Atom"; import {useToasts} from '@codeday/topo/utils'; import {checkin, checkout, sendWaiverReminder} from './Ticket.gql'; import Badge from "./Badge"; -import Alert, {GoodAlert} from "./Alert"; +import Alert, {GoodAlert, InfoAlert} from "./Alert"; import {useFetcher} from '../fetch'; import InfoBox from "./InfoBox"; import * as Icon from "@codeday/topocons/Icon"; @@ -92,6 +92,10 @@ export default function Ticket({ticket, eventId, ...props}) {
)} + {(ticket.surveyResponses?.dietary || 'none') !== 'none' && Dietary restrictions: {ticket.surveyResponses.dietary}} + {ticket.surveyResponses?.laptop == 'yes' && Requested laptop} + {(ticket.event.overnightMinAge && ticket.age < ticket.event.overnightMinAge) && Can't stay overnight} +
{session && (