{"version":3,"file":"static/js/975.chunk.js","mappings":"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","sources":["Components/Booking/BookingButton/BookingButton.tsx","Components/Booking/Components/Card/Card.tsx","Components/Booking/Components/DateTime/Datepicker/helpers/dateConstants.ts","Components/Booking/Components/DateTime/Datepicker/helpers/dateLibUtils.ts","Components/Booking/Components/DateTime/Datepicker/Calendar/CalendarComps/BookingDateIndicator.tsx","Components/Booking/Components/DateTime/Datepicker/helpers/date-utils.ts","Components/Booking/Components/DateTime/Datepicker/Calendar/BookingCalendar.tsx","Components/Booking/Components/DateTime/Timepicker/Timepicker.tsx","Components/Booking/Components/DateTime/Datepicker/BookingDatepicker.tsx","Components/Booking/Components/DateTime/Datepicker/LimitedDatePicker.tsx","Components/Booking/Components/DateTime/TodayOrTomorrow.tsx","Components/Booking/Components/DateTime/DatesAvailable.tsx","Components/Shared/Tooltip/Tooltip.tsx","Components/Booking/Components/AddTickets/AddTickets.tsx","Components/Booking/Components/HomeSummary/TicketsSummary.tsx","Components/Booking/Components/HomeSummary/TicketsTotalPrice.tsx","Components/Booking/Components/HomeSummary/HomeSummary.tsx","Components/Booking/Features/AddressEdit/AddressEditInputs.tsx","Components/Booking/Features/AddressEdit/NewAddressFinder.tsx","Components/Booking/Features/AddressEdit/AddressEdit.tsx","Components/Booking/BookingPages/ExtraPages/AddressPage.tsx","Components/Booking/BookingPages/ExtraPages/ImportantInformation.tsx","Components/Booking/BookingPages/ExtraPages/BookingProtect.tsx","Components/Booking/BookingPages/ExtraPages/Questions.tsx","Components/Booking/BookingPages/ExtraPages/QuestionsPage.tsx","Components/Booking/BookingPages/ExtraPages/TermsAndConditions.tsx","Components/Booking/BookingPages/ExtraPages/ExtraError.tsx","Screens/AccountPages/AccountDataMissing.tsx","Components/Booking/BookingPages/PageContainer.tsx","Components/Booking/Components/TypeComponent/Seatpicker/SelectedSeatDisplay.tsx","Components/Booking/Components/TypeComponent/Seatpicker/SeatSelectionFooter.tsx","Components/Booking/Components/TypeComponent/Seatpicker/SeatPicker.tsx","Components/Booking/Components/TypeComponent/Seatpicker/SeatPickerMulti.tsx","Components/Shared/QuantityPicker/AddSubtractQuantity.tsx","Components/Shared/QuantityPicker/QuantityPicker.tsx","Components/Booking/Components/TypeComponent/Seatpicker/EncoreWidget/WidgetDisplay.tsx","Components/Booking/Components/TypeComponent/Seatpicker/EncoreWidget/EncoreSeatWidget.tsx","Components/Booking/Components/TicketType/TicketType.tsx","Components/Booking/BookingScreens/TicketsHome/TicketsHome.tsx","Components/Shared/Widget/MobileContain.tsx","Components/Booking/Booking.tsx","Components/Booking/Components/Countdown/TicketCountdown.tsx","Components/Booking/Features/GiftAid/GiftAidModal.tsx","Components/Shared/Checkbox/Checkbox.tsx","Components/Booking/Features/GiftAid/GiftAid.tsx","Components/NavBarGeneral/NavBarGeneral.tsx","Components/Shared/ErrorHandler/ErrorHandler.tsx","Components/Shared/Modal/ReusableModal.tsx","Helpers/pageVariants.ts","Screens/AccountPages/AccountInfo/ContactInfo/ContactInfo.tsx","axios/AccountAPI.ts"],"sourcesContent":["import './booking-button.css'\r\nimport React, { useContext, useEffect } from 'react'\r\nimport { GlobalContext } from '../../../Context/GlobalContext'\r\n\r\ninterface IProps {\r\n    clickHandler: () => void\r\n}\r\n\r\nconst CSS_CLASSNAME = 'booking__button'\r\n\r\nconst BookingButton = (props: IProps) => {\r\n    const global = useContext(GlobalContext)\r\n    const bookingButtonRef = React.useRef<HTMLDivElement>(null)\r\n    const [classNames, setClassNames] = React.useState<string>(CSS_CLASSNAME)\r\n\r\n    useEffect(() => {\r\n        const handleScroll = () => {\r\n            if (window.scrollY > 200) {\r\n                setClassNames(`${CSS_CLASSNAME} ${CSS_CLASSNAME}--fixed`)\r\n            } else {\r\n                setClassNames(CSS_CLASSNAME)\r\n            }\r\n        }\r\n\r\n        // Add scroll listener\r\n        window.addEventListener('scroll', handleScroll)\r\n\r\n        // Cleanup a scroll listener on a component unmount\r\n        return () => {\r\n            window.removeEventListener('scroll', handleScroll)\r\n        }\r\n    }, [])\r\n\r\n    return (\r\n        <div className={classNames} ref={bookingButtonRef}>\r\n            <button className=\"btn\" onClick={props.clickHandler}>\r\n                {`Book`}\r\n                {global.fromPrice && global.originalPrice ? (\r\n                    <span>\r\n                        from <span>{global.originalPrice}</span>{' '}\r\n                        {global.fromPrice}\r\n                    </span>\r\n                ) : global.fromPrice ? (\r\n                    <span>from {global.fromPrice}</span>\r\n                ) : null}\r\n            </button>\r\n        </div>\r\n    )\r\n}\r\nexport default BookingButton\r\n","import React from \"react\";\r\nimport \"./Card.css\";\r\n\r\ninterface ICardProps {\r\n    image?: string;\r\n    title?: string;\r\n    content?: string;\r\n    ikBase?: string;\r\n}\r\n\r\nconst Card: React.FC<ICardProps> = ({ image, title, content, ikBase }: ICardProps): JSX.Element => {\r\n    return (\r\n        <div className=\"card rCard\">\r\n            {ikBase && image &&\r\n                <div className=\"card__left\">\r\n                    <img\r\n                        src={ikBase + image}\r\n                        alt={title}\r\n                        // onError={(e) => {\r\n                        //     e.target.onerror = null;\r\n                        //     e.target.src =\r\n                        //         \"\";\r\n                        // }}\r\n                    />\r\n\r\n                </div>\r\n            }\r\n            { title && content && \r\n            <div className=\"card__right\">\r\n                <h3 className=\"rCard__title\">{title}</h3>\r\n                <p>{content}</p>\r\n            </div>\r\n            }\r\n        </div>\r\n    );\r\n};\r\n\r\nexport default Card;\r\n","const weekdays = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\r\n\r\nconst monthsFull = [\r\n    \"January\",\r\n    \"February\",\r\n    \"March\",\r\n    \"April\",\r\n    \"May\",\r\n    \"June\",\r\n    \"July\",\r\n    \"August\",\r\n    \"September\",\r\n    \"October\",\r\n    \"November\",\r\n    \"December\",\r\n];\r\n\r\nconst monthsShort = [\r\n    \"Jan\",\r\n    \"Feb\",\r\n    \"Mar\",\r\n    \"Apr\",\r\n    \"May\",\r\n    \"Jun\",\r\n    \"Jul\",\r\n    \"Aug\",\r\n    \"Sep\",\r\n    \"Oct\",\r\n    \"Nov\",\r\n    \"Dec\",\r\n];\r\n\r\nconst totalDatesPerMonthView = 42; // 6 rows, 7 days a week...\r\n\r\nexport { weekdays, monthsFull, monthsShort, totalDatesPerMonthView };\r\n","import { getYear, getMonth, getDate, format, parse } from 'date-fns'\r\nimport { zonedTimeToUtc } from 'date-fns-tz'\r\n\r\nimport {\r\n    bookingLocale as defaultBookingLocale,\r\n    timeZone as defaultTimeZone,\r\n} from '../../../../../../Helpers/constants'\r\n\r\nexport const getSpecificDate = (\r\n    month: number,\r\n    dayOfMonth: number,\r\n    year: number\r\n): Date => {\r\n    // convert string to date then format\r\n\r\n    return parse(\r\n        `${month}-${dayOfMonth}-${year} 12:00`,\r\n        'M-d-yyyy HH:mm',\r\n        new Date()\r\n    )\r\n}\r\n\r\nexport const getDayOfMonth = (date: Date): number => {\r\n    return getDate(date)\r\n}\r\n\r\nexport const getTheMonth = (date: Date): number => {\r\n    return getMonth(date) + 1\r\n}\r\n\r\nexport const getTheYear = (date: Date): number => getYear(date)\r\n\r\n// for timezones sake seperating these out - gets the date in the current users location\r\nexport const getUserLocalToday = (): Date => new Date()\r\n\r\nexport const getEventLocalToday = (\r\n    locale = defaultBookingLocale,\r\n    timeZone = defaultTimeZone\r\n): Date => {\r\n    const date = getUserLocalToday().toLocaleDateString(locale, {\r\n        timeZone: timeZone,\r\n        dateStyle: 'short',\r\n    })\r\n\r\n    return parse(date, 'dd/MM/yyyy', new Date())\r\n}\r\n\r\nexport const formatToDateObjToLocation = (\r\n    date: Date,\r\n    timeZone = defaultTimeZone\r\n): Date => {\r\n    return zonedTimeToUtc(new Date(date), timeZone)\r\n}\r\n\r\nexport const getReadableWeekday = (date: Date): string => format(date, 'EEEE')\r\n\r\nexport const getReadableMonthDate = (date: Date): string =>\r\n    format(date, 'MMMM do')\r\n\r\nexport const getMonthDayYear = (date: Date | string): string => {\r\n    if (typeof date === 'string') {\r\n        date = new Date(date)\r\n    }\r\n\r\n    return format(date, 'yyyy-MM-dd')\r\n}\r\n","import React from 'react'\r\nimport { getDatesInMonthDisplay } from '../../helpers/date-utils'\r\nimport {\r\n    getTheMonth,\r\n    getTheYear,\r\n    getDayOfMonth,\r\n    getMonthDayYear,\r\n} from '../../helpers/dateLibUtils'\r\n\r\nimport { addYears, addMonths } from 'date-fns'\r\nimport {\r\n    IDateSessions,\r\n    IDateTracker,\r\n    ISessionTime,\r\n} from '../../../../../../../interfaces/interfaces'\r\n\r\ninterface IDateIndicatorProps {\r\n    month: number\r\n    year: number\r\n    todaysDate: Date\r\n    activeDates: IDateSessions //React.MutableRefObject<{}>;\r\n    selectDate: Date\r\n    openTimes: (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        type: ISessionTime\r\n    ) => void\r\n}\r\n\r\nconst BookingDateIndicator: React.FC<IDateIndicatorProps> = ({\r\n    month,\r\n    year,\r\n    todaysDate,\r\n    activeDates,\r\n    selectDate,\r\n    openTimes,\r\n}: IDateIndicatorProps): JSX.Element => {\r\n    const onChangeDate = (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        isActive: boolean,\r\n        dataDate: Date,\r\n        dataTime: string\r\n    ): void => {\r\n        if (!isActive) {\r\n            return\r\n        }\r\n\r\n        const date = new Date(dataDate)\r\n\r\n        const dataTimeData = JSON.parse(dataTime) as IDateTracker\r\n\r\n        const type = {\r\n            session: {\r\n                sessionId: dataTimeData.session[0],\r\n                date: date,\r\n                time: date.getTime().toString(), // TODO: this needs to be properly set as time string if used anywhere\r\n            },\r\n            date: date,\r\n        } as ISessionTime\r\n\r\n        openTimes(e, type)\r\n    }\r\n\r\n    const datesInMonth = getDatesInMonthDisplay(\r\n        getTheMonth(addMonths(todaysDate, month)),\r\n        getTheYear(addYears(todaysDate, year))\r\n    )\r\n    const monthDates = datesInMonth.map((i, key) => {\r\n        const selected = getMonthDayYear(selectDate) === getMonthDayYear(i.date)\r\n\r\n        if (activeDates[getMonthDayYear(i.date)]) {\r\n            i.time = JSON.stringify(activeDates[getMonthDayYear(i.date)])\r\n        }\r\n\r\n        const active =\r\n            activeDates && activeDates[getMonthDayYear(i.date)] ? true : false\r\n\r\n        return (\r\n            <div className=\"calendarTickets__outer-date\" key={key}>\r\n                <button\r\n                    className={`date-icon ${selected && active ? 'selected' : ''} ${active ? 'active' : 'calendarTickets__crossed'}`}\r\n                    data-active-month={i.currentMonth}\r\n                    data-date={i.date.toString()}\r\n                    data-time={i.time && i.time}\r\n                    onClick={(e) => onChangeDate(e, active, i.date, i.time)}\r\n                >\r\n                    {getDayOfMonth(i.date)}\r\n                </button>\r\n            </div>\r\n        )\r\n    })\r\n\r\n    return <div className=\"calendarTickets__date\">{monthDates}</div>\r\n}\r\n\r\nexport default BookingDateIndicator\r\n","import { getDaysInMonth, startOfMonth, getDay, parse } from 'date-fns'\r\nimport {\r\n    bookingLocale as defaultBookingLocale,\r\n    timeZone as defaultTimeZone,\r\n} from '../../../../../../Helpers/constants'\r\n\r\nimport { totalDatesPerMonthView } from './dateConstants'\r\nimport {\r\n    getSpecificDate,\r\n    getMonthDayYear,\r\n    getTheMonth,\r\n    getTheYear,\r\n} from './dateLibUtils'\r\nimport { ITime, IDateSessions } from '../../../../../../interfaces/interfaces'\r\n\r\nconst getPrevMonthYear = (\r\n    month: number,\r\n    year: number\r\n): { month: number; year: number } => {\r\n    if (month === 1) {\r\n        return {\r\n            month: 12,\r\n            year,\r\n        }\r\n    } else {\r\n        return {\r\n            month: month - 1,\r\n            year,\r\n        }\r\n    }\r\n}\r\n\r\nconst getNextMonthYear = (\r\n    month: number,\r\n    year: number\r\n): { month: number; year: number } => {\r\n    if (month === 12) {\r\n        return {\r\n            month: 1,\r\n            year: year + 1,\r\n        }\r\n    } else {\r\n        return {\r\n            month: month + 1,\r\n            year,\r\n        }\r\n    }\r\n}\r\n\r\ninterface IDatesOfMonth {\r\n    currentMonth: boolean\r\n    date: Date\r\n    time: string\r\n}\r\n\r\nconst getDatesInMonthDisplay = (\r\n    month: number,\r\n    year: number\r\n): IDatesOfMonth[] => {\r\n    const monthYear = parse(`${month}-01-${year}`, 'M-dd-yyyy', new Date())\r\n\r\n    const daysInMonth = getDaysInMonth(monthYear)\r\n    const firstWeekday = getDay(startOfMonth(monthYear))\r\n    const result = []\r\n\r\n    // Based on index number of firstWeekday, add number of previous month's overflow dates\r\n    const prevMonthYear = getPrevMonthYear(month, year)\r\n    const prevDaysInMonth = getDaysInMonth(\r\n        parse(\r\n            `${prevMonthYear.month}-01-${prevMonthYear.year}`,\r\n            'M-dd-yyyy',\r\n            new Date()\r\n        )\r\n    )\r\n\r\n    for (let i = firstWeekday - 1; i >= 0; i--) {\r\n        result.push({\r\n            currentMonth: false,\r\n            date: getSpecificDate(\r\n                prevMonthYear.month,\r\n                prevDaysInMonth - i,\r\n                prevMonthYear.year\r\n            ),\r\n            time: '',\r\n        })\r\n    }\r\n\r\n    // Add all current month dates\r\n    for (let j = 1; j <= daysInMonth; j++) {\r\n        result.push({\r\n            currentMonth: true,\r\n            date: getSpecificDate(month, j, year),\r\n            time: '',\r\n        })\r\n    }\r\n\r\n    // Overflow dates for next month to meet totalDatesPerMonthView requirement\r\n    if (result.length < totalDatesPerMonthView) {\r\n        let daysToAdd = totalDatesPerMonthView - result.length\r\n\r\n        if (daysToAdd > 6) {\r\n            daysToAdd = daysToAdd - 7\r\n        }\r\n\r\n        const nextMonthYear = getNextMonthYear(month, year)\r\n\r\n        for (let k = 1; k <= daysToAdd; k++) {\r\n            result.push({\r\n                currentMonth: false,\r\n                date: getSpecificDate(\r\n                    nextMonthYear.month,\r\n                    k,\r\n                    nextMonthYear.year\r\n                ),\r\n                time: '',\r\n            })\r\n        }\r\n    }\r\n\r\n    return result\r\n}\r\n\r\nconst getMonthSet = (selectDate: Date): { prev: Date; next: Date } => {\r\n    const month = getTheMonth(selectDate)\r\n    const result = {\r\n        current: selectDate,\r\n        prev: getSpecificDate(month - 1, 1, getTheYear(selectDate)),\r\n        next: getSpecificDate(month + 1, 1, getTheYear(selectDate)),\r\n    }\r\n\r\n    if (month === 1) {\r\n        result.prev = getSpecificDate(12, 1, getTheYear(selectDate) - 1)\r\n    }\r\n\r\n    if (month === 12) {\r\n        result.next = getSpecificDate(1, 1, getTheYear(selectDate) + 1)\r\n    }\r\n\r\n    return result\r\n}\r\n\r\nconst presetDateTracker = (\r\n    dates: ITime[],\r\n    timeZone: string = defaultTimeZone,\r\n    bookingLocale: string = defaultBookingLocale\r\n): IDateSessions => {\r\n    const eventLocalTime = new Date().toLocaleTimeString(bookingLocale, {\r\n        timeZone: timeZone,\r\n        timeStyle: 'short',\r\n    })\r\n\r\n    const result = {} as IDateSessions\r\n\r\n    dates.forEach((date) => {\r\n        const dateStr = getMonthDayYear(`${date.date}T${eventLocalTime}`)\r\n\r\n        if (!result[dateStr]) {\r\n            result[dateStr] = {\r\n                slots: 1,\r\n                session: [date.sessionId],\r\n                date: date.date,\r\n            }\r\n        } else {\r\n            result[dateStr].slots += 1\r\n            result[dateStr].session.push(date.sessionId)\r\n        }\r\n    })\r\n\r\n    return result\r\n}\r\n\r\nexport { getDatesInMonthDisplay, getMonthSet, presetDateTracker }\r\n","import React, { useRef } from 'react'\r\nimport {\r\n    getTheMonth,\r\n    getTheYear,\r\n    getEventLocalToday,\r\n} from '../helpers/dateLibUtils'\r\n\r\nimport BookingDateIndicator from './CalendarComps/BookingDateIndicator'\r\nimport { presetDateTracker } from '../helpers/date-utils'\r\nimport { monthsFull } from '../helpers/dateConstants'\r\nimport './Calendar.css'\r\nimport { addYears } from 'date-fns'\r\nimport { bookingLocale, timeZone } from '../../../../../../Helpers/constants'\r\nimport { ITime, ISessionTime } from '../../../../../../interfaces/interfaces'\r\n\r\ninterface ICalendarProps {\r\n    openTimes: (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        type: ISessionTime\r\n    ) => void\r\n    selectedDate?: Date\r\n    activeDates?: ITime[]\r\n}\r\n\r\nconst BookingCalendar: React.FC<ICalendarProps> = ({\r\n    selectedDate,\r\n    activeDates,\r\n    openTimes,\r\n}: ICalendarProps): JSX.Element => {\r\n    const presetActiveDates = useRef(\r\n        activeDates\r\n            ? presetDateTracker(activeDates, timeZone, bookingLocale)\r\n            : {}\r\n    )\r\n    const todaysDate = getEventLocalToday()\r\n\r\n    let monthLong\r\n    let yearLong\r\n    let year = 0\r\n\r\n    return (\r\n        <div className=\"calendarTickets\">\r\n            <div className=\"calendarTickets__container\">\r\n                {monthsFull.map((month, i) => {\r\n                    if (getTheMonth(todaysDate) + i - 1 > 11) {\r\n                        i = i - 12\r\n                        year = 1\r\n                        monthLong =\r\n                            monthsFull[\r\n                                getTheMonth(addYears(todaysDate, 1)) + i - 1\r\n                            ]\r\n                    } else {\r\n                        monthLong = monthsFull[getTheMonth(todaysDate) + i - 1]\r\n                    }\r\n\r\n                    yearLong = getTheYear(todaysDate) + year\r\n\r\n                    return (\r\n                        <div key={i} className=\"calendarTickets__month\">\r\n                            <span className=\"calendarTickets__monthTitle\">\r\n                                {monthLong} {yearLong}\r\n                            </span>\r\n                            <BookingDateIndicator\r\n                                month={i}\r\n                                year={year}\r\n                                todaysDate={todaysDate}\r\n                                activeDates={presetActiveDates.current}\r\n                                selectDate={\r\n                                    selectedDate ? selectedDate : todaysDate\r\n                                }\r\n                                openTimes={openTimes}\r\n                            />\r\n                        </div>\r\n                    )\r\n                })}\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default BookingCalendar\r\n","import React, { useEffect, useState } from 'react'\r\nimport './Timepicker.css'\r\nimport { setSession, reserveDates } from '../../../../../redux/ticketSlice'\r\nimport Loader from '../../../../Shared/Loader/Loader'\r\nimport { ITime } from '../../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../../redux/store'\r\n\r\ninterface ITimepickerProps {\r\n    peakTimes?: boolean\r\n}\r\n\r\nconst Timepicker: React.FC<ITimepickerProps> = ({\r\n    peakTimes = undefined,\r\n}: ITimepickerProps): JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n    const bookingObject = useAppSelector((state) => state.tickets.bookingObject)\r\n    const [loading, setLoading] = useState<boolean>(false)\r\n    const [indexActive, setIndexActive] = useState<number | undefined>(\r\n        undefined\r\n    )\r\n    const [iSelect, setISelect] = useState<number | undefined>(undefined)\r\n\r\n    const selectTime = (timeObject: ITime, i: number): void => {\r\n        if (iSelect === i) {\r\n            setISelect(undefined)\r\n        } else {\r\n            setISelect(i)\r\n        }\r\n\r\n        const selected = {\r\n            date: bookingObject.sessionSelected.date || null,\r\n            time: timeObject.time,\r\n            sessionId: timeObject.sessionId,\r\n        }\r\n\r\n        completeDateTimeSelection(selected)\r\n    }\r\n\r\n    const completeDateTimeSelection = (selected: ITime): void => {\r\n        const ticketTypeObj = {\r\n            sessionId: selected.sessionId,\r\n            ids: bookingObject.ids,\r\n        }\r\n        dispatch(reserveDates(ticketTypeObj))\r\n        dispatch(setSession(selected))\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (!bookingObject.times || !bookingObject.times[0]) {\r\n            setLoading(true)\r\n        } else {\r\n            setLoading(false)\r\n        }\r\n    }, [bookingObject.times])\r\n\r\n    return (\r\n        <div className=\"datepicker\">\r\n            {loading && <Loader messages={['Fetching time slots...']} />}\r\n            <div className=\"timepicker\">\r\n                <div>\r\n                    <h3 className=\"picker__prompt\">Select your time:</h3>\r\n                    {peakTimes && (\r\n                        <>\r\n                            <div className=\"timepicker__peakSelectTitles\">\r\n                                <div className=\"timepicker__peakSelectTitle\">\r\n                                    <div\r\n                                        className=\"timepicker__circle\"\r\n                                        style={{\r\n                                            backgroundColor: 'var(--highlight)',\r\n                                        }}\r\n                                    />\r\n                                    Outside of peak\r\n                                </div>\r\n                                <div className=\"timepicker__peakSelectTitle\">\r\n                                    <div\r\n                                        className=\"timepicker__circle\"\r\n                                        style={{\r\n                                            backgroundColor: 'var(--amber)',\r\n                                        }}\r\n                                    />\r\n                                    Peak times\r\n                                </div>\r\n                                <div className=\"timepicker__peakSelectTitle\">\r\n                                    <div\r\n                                        className=\"timepicker__circle\"\r\n                                        style={{\r\n                                            backgroundColor: 'var(--middle)',\r\n                                        }}\r\n                                    />\r\n                                    Sold out\r\n                                </div>\r\n                            </div>{' '}\r\n                        </>\r\n                    )}\r\n                    {bookingObject.times && bookingObject.times.length <= 5 ? (\r\n                        <div className=\"timepicker__calender\">\r\n                            {bookingObject.times &&\r\n                                bookingObject.times.map((time, i) => {\r\n                                    return (\r\n                                        <div key={i}>\r\n                                            {iSelect === i ? (\r\n                                                <button\r\n                                                    id=\"selectTime\"\r\n                                                    onClick={() => {\r\n                                                        setIndexActive(i)\r\n                                                        selectTime(time, i)\r\n                                                    }}\r\n                                                    key={i}\r\n                                                    className={`btn ${\r\n                                                        indexActive === i\r\n                                                            ? 'primary-btn timepicker__time'\r\n                                                            : 'primary-btn-white timepicker__time'\r\n                                                    }`}\r\n                                                >\r\n                                                    {time.time}\r\n                                                </button>\r\n                                            ) : (\r\n                                                <button\r\n                                                    id=\"selectTime\"\r\n                                                    onClick={() => {\r\n                                                        selectTime(time, i)\r\n                                                    }}\r\n                                                    key={i}\r\n                                                    className={`btn ${\r\n                                                        indexActive === i\r\n                                                            ? 'primary-btn timepicker__time'\r\n                                                            : 'primary-btn-white timepicker__time'\r\n                                                    }`}\r\n                                                >\r\n                                                    {time.time}\r\n                                                </button>\r\n                                            )}\r\n                                        </div>\r\n                                    )\r\n                                })}\r\n                        </div>\r\n                    ) : (\r\n                        <div className=\"calendar\">\r\n                            <div className=\"timepicker__content\">\r\n                                <div className=\"timepicker__cContainer\">\r\n                                    <div className=\"timepicker__times\">\r\n                                        {bookingObject.times &&\r\n                                            bookingObject.times.map(\r\n                                                (time, i) => {\r\n                                                    return (\r\n                                                        <div\r\n                                                            key={i}\r\n                                                            className=\"timepicker__timeBox\"\r\n                                                        >\r\n                                                            <div\r\n                                                                onClick={() => {\r\n                                                                    setIndexActive(\r\n                                                                        i\r\n                                                                    )\r\n                                                                    selectTime(\r\n                                                                        time,\r\n                                                                        i\r\n                                                                    )\r\n                                                                }}\r\n                                                                className={`btn ${\r\n                                                                    indexActive ===\r\n                                                                    i\r\n                                                                        ? 'primary-btn timepicker__time'\r\n                                                                        : 'primary-btn-white timepicker__time'\r\n                                                                }`}\r\n                                                            >\r\n                                                                {time.time}\r\n                                                                <div\r\n                                                                    className={`timepicker__topBit ${time.peak}`}\r\n                                                                />\r\n                                                            </div>\r\n                                                        </div>\r\n                                                    )\r\n                                                }\r\n                                            )}\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    )}\r\n                </div>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default Timepicker\r\n","import React, { useEffect, useState } from 'react'\r\n\r\nimport './DatePicker.css'\r\nimport { weekdays } from './helpers/dateConstants'\r\n\r\nimport BookingCalendar from './Calendar/BookingCalendar'\r\nimport Timepicker from '../Timepicker/Timepicker'\r\nimport {\r\n    setDatePickerOpen,\r\n    setTimepickerOpen,\r\n    reserveDates,\r\n    setSession,\r\n    getTimes,\r\n} from '../../../../../redux/ticketSlice'\r\n\r\nimport Modal from '../../../../Shared/Modal/ReusableModal'\r\nimport { useAppDispatch, useAppSelector } from '../../../../../redux/store'\r\nimport {\r\n    ITime,\r\n    IBookingIDs,\r\n    ISessionTime,\r\n    SessionType,\r\n} from '../../../../../interfaces/interfaces'\r\n\r\nimport { formatDate } from '../../../../../Helpers/utils'\r\nimport { getEventLocalToday } from './helpers/dateLibUtils'\r\n\r\nexport interface ISelectedDate {\r\n    ids: IBookingIDs\r\n    date: Date\r\n    sessions: ITime\r\n}\r\n\r\nconst BookingDatepicker: React.FC = (): JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n    const { bookingObject, isTimePickerOpen } = useAppSelector(\r\n        (state) => state.tickets\r\n    )\r\n\r\n    const [selectedDateObject, setSelectedDateObject] = useState<\r\n        ISelectedDate | undefined\r\n    >(undefined)\r\n\r\n    const closeDatepicker = (): void => {\r\n        dispatch(setDatePickerOpen(false))\r\n    }\r\n\r\n    const openTime = (date: Date, session: ITime): void => {\r\n        if (session && bookingObject.sessionType === SessionType.DateAndTime) {\r\n            dispatch(setTimepickerOpen(true))\r\n        } else if (\r\n            session &&\r\n            bookingObject.sessionType === SessionType.DateOnly\r\n        ) {\r\n            const temp = {\r\n                date: date,\r\n                sessionId: null,\r\n                time: null,\r\n            }\r\n            const ticketTypeObj = {\r\n                sessionId: session.sessionId,\r\n                ids: bookingObject.ids,\r\n            }\r\n\r\n            void dispatch(reserveDates(ticketTypeObj))\r\n            dispatch(setSession(temp))\r\n            closeDatepicker()\r\n        }\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (bookingObject.timesResponse && selectedDateObject) {\r\n            openTime(selectedDateObject.date, selectedDateObject.sessions)\r\n        }\r\n    }, [bookingObject.timesResponse, selectedDateObject])\r\n\r\n    const openPreTime = (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        type: ISessionTime\r\n    ): void => {\r\n        const callProps = {\r\n            ids: bookingObject.ids,\r\n            sessions: type.session,\r\n            date: type.date,\r\n        }\r\n\r\n        setSelectedDateObject(callProps)\r\n\r\n        if (bookingObject.sessionType === SessionType.DateAndTime) {\r\n            void dispatch(\r\n                getTimes({\r\n                    ids: bookingObject.ids,\r\n                    date: formatDate(type.date),\r\n                })\r\n            )\r\n            dispatch(setTimepickerOpen(true))\r\n        } else {\r\n            openTime(callProps.date, callProps.sessions)\r\n        }\r\n    }\r\n\r\n    const closeTimepicker = (): void => {\r\n        dispatch(setTimepickerOpen(false))\r\n        dispatch(setDatePickerOpen(true))\r\n    }\r\n\r\n    const ticketContainer = document.querySelector('.ticket__container')\r\n\r\n    const todaysDate = getEventLocalToday()\r\n    return (\r\n        <Modal\r\n            element={ticketContainer ? ticketContainer : new DocumentFragment()}\r\n            onGoBack={isTimePickerOpen ? closeTimepicker : undefined}\r\n            onClose={closeDatepicker}\r\n            additionalClasses={'booking-datepicker'}\r\n        >\r\n            <div className=\"datepickerTickets__container\">\r\n                {isTimePickerOpen ? (\r\n                    <Timepicker />\r\n                ) : (\r\n                    <>\r\n                        <h3 className=\"picker__prompt\">Select your date:</h3>\r\n                        <div className=\"datepickerTickets__calenderHead\">\r\n                            {weekdays.map((day, i) => (\r\n                                <span\r\n                                    key={i}\r\n                                    className=\"datepickerTickets__column\"\r\n                                >\r\n                                    {day}\r\n                                </span>\r\n                            ))}\r\n                        </div>\r\n                        <BookingCalendar\r\n                            openTimes={openPreTime}\r\n                            selectedDate={\r\n                                bookingObject.sessionSelected.date || todaysDate\r\n                            }\r\n                            activeDates={\r\n                                bookingObject && bookingObject.sessions\r\n                            }\r\n                        />\r\n                    </>\r\n                )}\r\n            </div>\r\n        </Modal>\r\n    )\r\n}\r\n\r\nexport default BookingDatepicker\r\n","import React from 'react'\r\n\r\n// UTILS\r\nimport { formatInTimeZone } from 'date-fns-tz'\r\nimport { dateFormatStringDOW, timeZone } from '../../../../../Helpers/constants'\r\n\r\n// STORE\r\nimport { useAppSelector } from '../../../../../redux/store'\r\nimport { ticketsBookingObjectSessionSelectedDate } from '../../../../../redux/ticketSlice'\r\n\r\n// INTERFACES\r\nimport { ITime } from '../../../../../interfaces/interfaces'\r\n\r\ninterface iProps {\r\n    sessions: ITime[]\r\n    clickHandler: (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        available: ITime\r\n    ) => void\r\n}\r\n\r\nexport default function LimitedDatePicker(props: iProps): React.JSX.Element {\r\n    const selectedDate = useAppSelector(ticketsBookingObjectSessionSelectedDate)\r\n    const { sessions, clickHandler } = props\r\n    return (\r\n        <>\r\n            {sessions.map((available, i) => (\r\n                <div key={i}>\r\n                    <button\r\n                        data-testid=\" limited-date-picker-button\"\r\n                        className={`btn primary-btn-white btn-large ${selectedDate === available.date ? 'btn-border' : ''}`}\r\n                        onClick={(e) => {\r\n                            clickHandler(e, available)\r\n                        }}\r\n                    >\r\n                        <>\r\n                            {formatInTimeZone(\r\n                                new Date(available.date),\r\n                                timeZone,\r\n                                dateFormatStringDOW\r\n                            )}\r\n                        </>\r\n                    </button>\r\n                </div>\r\n            ))}\r\n        </>\r\n    )\r\n}\r\n","import React, { useMemo } from 'react'\r\n\r\ninterface ITodayOrTomorrowProps {\r\n    date: Date\r\n}\r\n\r\nconst TodayOrTomorrow: React.FC<ITodayOrTomorrowProps> = (\r\n    props: ITodayOrTomorrowProps\r\n): React.JSX.Element | null => {\r\n    const dayTitle = useMemo(() => {\r\n        const today = new Date().setHours(0, 0, 0, 0)\r\n        const tomorrow = new Date()\r\n        tomorrow.setDate(tomorrow.getDate() + 1)\r\n        const inputDate = new Date(props.date.valueOf()).setHours(0, 0, 0, 0)\r\n\r\n        return inputDate === today\r\n            ? 'Today'\r\n            : inputDate === tomorrow.setHours(0, 0, 0, 0)\r\n              ? 'Tomorrow'\r\n              : ''\r\n    }, [props.date])\r\n\r\n    return dayTitle ? (\r\n        <span className=\"date-picker__day\">{dayTitle}</span>\r\n    ) : null\r\n}\r\n\r\nexport default TodayOrTomorrow\r\n","import React, { useEffect, useState } from 'react'\r\nimport './DatesAvailable.css'\r\nimport {\r\n    setDatePickerOpen,\r\n    setTimepickerOpen,\r\n    getTimes,\r\n    clearTicketState,\r\n    reserveDates,\r\n    setSession,\r\n} from '../../../../redux/ticketSlice'\r\nimport BookingDatepicker from './Datepicker/BookingDatepicker'\r\nimport { formatInTimeZone } from 'date-fns-tz'\r\n\r\nimport { dateFormatStringDOW, timeZone } from '../../../../Helpers/constants'\r\nimport { AnimatePresence } from 'framer-motion'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\nimport { ITime, SessionType } from '../../../../interfaces/interfaces'\r\nimport LimitedDatePicker from './Datepicker/LimitedDatePicker'\r\nimport { formatDate } from '../../../../Helpers/utils'\r\nimport TodayOrTomorrow from './TodayOrTomorrow'\r\n\r\nconst DatesAvailable: React.FC = (): React.JSX.Element => {\r\n    const {\r\n        bookingObject,\r\n        isDatePickerOpen: isOpen,\r\n        dateNumberBeforeShowDatepicker: datepickerShow,\r\n    } = useAppSelector((state) => state.tickets)\r\n    const [shortListShow, setShortListShow] = useState<boolean>(true)\r\n    const dispatch = useAppDispatch()\r\n\r\n    // this will need to be dynamic eventually as it will need to contain the code for where the booking is happening. This ensures that when times are not included, the date is still correct and doesn't default to next previous day with 00\r\n    useEffect(() => {\r\n        dispatch(setTimepickerOpen(false))\r\n    }, [dispatch])\r\n\r\n    const openDatePicker = (): void => {\r\n        if (bookingObject.sessions.length <= datepickerShow) {\r\n            setShortListShow(true)\r\n        } else {\r\n            dispatch(setTimepickerOpen(false))\r\n            dispatch(setDatePickerOpen(true))\r\n        }\r\n    }\r\n\r\n    const openTimePicker = (): void => {\r\n        dispatch(setDatePickerOpen(true))\r\n        dispatch(setTimepickerOpen(true))\r\n        setShortListShow(false)\r\n    }\r\n\r\n    const handleClick = (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        available: ITime\r\n    ): void => {\r\n        e.preventDefault()\r\n        dispatch(clearTicketState())\r\n        const callProps = {\r\n            ids: bookingObject.ids,\r\n            date: formatDate(available.date),\r\n        }\r\n\r\n        if (bookingObject.sessionType === SessionType.DateAndTime) {\r\n            void dispatch(getTimes(callProps))\r\n            openDatePicker()\r\n            openTimePicker()\r\n        } else {\r\n            const temp = {\r\n                date: available.date,\r\n                sessionId: undefined,\r\n                time: undefined,\r\n            }\r\n            const ticketTypeObj = {\r\n                sessionId: available.sessionId,\r\n                ids: bookingObject.ids,\r\n            }\r\n\r\n            void dispatch(reserveDates(ticketTypeObj))\r\n            dispatch(setSession(temp))\r\n        }\r\n    }\r\n\r\n    return (\r\n        <>\r\n            {bookingObject.sessionType !== SessionType.NoDate && (\r\n                <div className=\"datesAvailable\">\r\n                    <p>You have chosen:</p>\r\n                    {bookingObject &&\r\n                    bookingObject.sessions &&\r\n                    bookingObject.sessions.length <= datepickerShow &&\r\n                    shortListShow ? (\r\n                        <div>\r\n                            {bookingObject.sessions.length > 0 ? (\r\n                                <LimitedDatePicker\r\n                                    sessions={bookingObject.sessions}\r\n                                    clickHandler={(e, available) =>\r\n                                        handleClick(e, available)\r\n                                    }\r\n                                />\r\n                            ) : (\r\n                                <button className=\"btn primary-btn-white-disabled btn-large\">\r\n                                    <span>\r\n                                        We are sorry, there are no available\r\n                                        tickets for this event\r\n                                    </span>\r\n                                </button>\r\n                            )}\r\n                        </div>\r\n                    ) : (\r\n                        <div>\r\n                            {bookingObject.sessionSelected &&\r\n                            bookingObject.sessionSelected.date ? (\r\n                                <>\r\n                                    <button\r\n                                        className=\"date-picker btn primary-btn-white btn-large btn-border\"\r\n                                        id=\"openDatePicker\"\r\n                                        onClick={openDatePicker}\r\n                                    >\r\n                                        <TodayOrTomorrow\r\n                                            date={\r\n                                                bookingObject.sessionSelected\r\n                                                    .date\r\n                                            }\r\n                                        />\r\n                                        {formatInTimeZone(\r\n                                            new Date(\r\n                                                bookingObject.sessionSelected.date\r\n                                            ),\r\n                                            timeZone,\r\n                                            dateFormatStringDOW\r\n                                        )}\r\n                                        <span className=\"date-picker__change\">\r\n                                            Change\r\n                                        </span>\r\n                                    </button>\r\n                                    {bookingObject.sessionType &&\r\n                                        bookingObject.sessionSelected.time && (\r\n                                            <button\r\n                                                className=\"date-picker btn primary-btn-white btn-large btn-border\"\r\n                                                id=\"openTimePicker\"\r\n                                                onClick={openTimePicker}\r\n                                            >\r\n                                                {\r\n                                                    bookingObject\r\n                                                        .sessionSelected.time\r\n                                                }\r\n                                                <div className=\"date-picker__change\">\r\n                                                    Change\r\n                                                </div>\r\n                                            </button>\r\n                                        )}\r\n                                </>\r\n                            ) : (\r\n                                <button\r\n                                    className=\"btn primary-btn-white btn-large\"\r\n                                    id=\"openDatePicker\"\r\n                                    onClick={openDatePicker}\r\n                                >\r\n                                    Select your date &amp; time\r\n                                </button>\r\n                            )}\r\n                        </div>\r\n                    )}\r\n                    <AnimatePresence>\r\n                        {isOpen && <BookingDatepicker key=\"datepicker\" />}\r\n                    </AnimatePresence>\r\n                </div>\r\n            )}\r\n        </>\r\n    )\r\n}\r\n\r\nexport default DatesAvailable\r\n","import React, { useEffect, useRef, useState } from 'react'\r\n\r\nimport './tooltip.css'\r\n\r\ntype TooltipArrowPosition = 'LEFT' | 'RIGHT' | 'TOP' | 'BOTTOM'\r\n\r\nexport const TOOLTIP_ARROW_POSITION: {\r\n    [key in TooltipArrowPosition]: TooltipArrowPosition\r\n} = {\r\n    TOP: 'TOP',\r\n    LEFT: 'LEFT',\r\n    RIGHT: 'RIGHT',\r\n    BOTTOM: 'BOTTOM',\r\n}\r\n\r\ninterface ITooltip {\r\n    children: React.JSX.Element\r\n    displayedText: string\r\n    position: keyof typeof TOOLTIP_ARROW_POSITION\r\n}\r\n\r\nexport default function Tooltip(props: ITooltip): React.JSX.Element {\r\n    const [show, setShow] = useState(false)\r\n    const [positionStyles, setPositionStyles] = React.useState({})\r\n    const [arrowPosition, setArrowPosition] = React.useState('')\r\n    const toolTipRef = useRef<HTMLDivElement>(null)\r\n    const toolTipMessageRef = useRef<HTMLDivElement>(null)\r\n    const arrowSizeRef = useRef({ height: 10, width: 6 })\r\n\r\n    useEffect(() => {\r\n        if (toolTipRef.current && toolTipMessageRef.current) {\r\n            switch (props.position) {\r\n                case TOOLTIP_ARROW_POSITION.TOP:\r\n                case TOOLTIP_ARROW_POSITION.BOTTOM: {\r\n                    const left =\r\n                        (toolTipRef.current.clientWidth -\r\n                            toolTipMessageRef.current.clientWidth) /\r\n                        2\r\n                    const valueVertical =\r\n                        toolTipRef.current.clientHeight +\r\n                        arrowSizeRef.current.height\r\n                    const positionVertical =\r\n                        props.position === TOOLTIP_ARROW_POSITION.TOP\r\n                            ? 'bottom'\r\n                            : 'top'\r\n                    setArrowPosition(`tooltip__arrow--${positionVertical}`)\r\n\r\n                    setPositionStyles({\r\n                        [positionVertical]: `${valueVertical}px`,\r\n                        left: `${left}px`,\r\n                    })\r\n                    break\r\n                }\r\n\r\n                case TOOLTIP_ARROW_POSITION.LEFT:\r\n                case TOOLTIP_ARROW_POSITION.RIGHT: {\r\n                    const top =\r\n                        (toolTipRef.current.clientHeight -\r\n                            toolTipMessageRef.current.clientHeight) /\r\n                        2\r\n                    const valueHorizontal =\r\n                        toolTipRef.current.clientWidth +\r\n                        arrowSizeRef.current.height\r\n                    const positionHorizontal =\r\n                        props.position === TOOLTIP_ARROW_POSITION.LEFT\r\n                            ? 'right'\r\n                            : 'left'\r\n                    setArrowPosition(`tooltip__arrow--${positionHorizontal}`)\r\n\r\n                    setPositionStyles({\r\n                        [positionHorizontal]: `${valueHorizontal}px`,\r\n                        top: `${top}px`,\r\n                    })\r\n                    break\r\n                }\r\n                default:\r\n            }\r\n        }\r\n    }, [show, props.position])\r\n\r\n    return (\r\n        <div\r\n            ref={toolTipRef}\r\n            style={\r\n                {\r\n                    '--arrow-height': `${arrowSizeRef.current.height}px`,\r\n                    '--arrow-width': `${arrowSizeRef.current.width}px`,\r\n                } as React.CSSProperties\r\n            }\r\n            className=\"tooltip\"\r\n            onMouseEnter={() => setShow(true)}\r\n            onMouseLeave={() => setShow(false)}\r\n        >\r\n            {props.children}\r\n            <div\r\n                style={positionStyles}\r\n                ref={toolTipMessageRef}\r\n                className={`tooltip__message${show ? ' tooltip__message--show' : ''}`}\r\n            >\r\n                {props.displayedText}\r\n                <div className={`tooltip__arrow ${arrowPosition}`}></div>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n","import React, { useContext, useRef, useState } from 'react'\r\nimport './AddTickets.css'\r\nimport {\r\n    incrementTickets,\r\n    resetChildTickets,\r\n    ticketsBookingObject,\r\n    ticketsBookingObjectTicketObjectMinPartySize,\r\n    ticketsBookingObjectTicketObjectMaxPartySize,\r\n} from '../../../../redux/ticketSlice'\r\nimport { motion } from 'framer-motion'\r\nimport minus from '../../../../assets/Minus.png'\r\nimport plus from '../../../../assets/Add.png'\r\nimport {\r\n    IBookingTicketState,\r\n    ITicketType,\r\n} from '../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\nimport { GiftAidStatusEnum } from '../../Features/GiftAid/GiftAid'\r\nimport { cloneObj } from '../../../../Helpers/utils'\r\nimport { GlobalContext } from '../../../../Context/GlobalContext'\r\nimport Tooltip, {\r\n    TOOLTIP_ARROW_POSITION,\r\n} from '../../../../Components/Shared/Tooltip/Tooltip'\r\n\r\nconst animateVariants = {\r\n    initial: {\r\n        y: -60,\r\n        opacity: 0,\r\n        scaleY: 0.5,\r\n    },\r\n    in: {\r\n        y: 0,\r\n        opacity: 1,\r\n        scaleY: 1,\r\n        transition: { duration: 0.23, ease: 'easeInOut' },\r\n    },\r\n    out: {\r\n        y: -20,\r\n        opacity: 0,\r\n        scaleY: 0.5,\r\n        transition: { duration: 0.4 },\r\n    },\r\n}\r\n\r\ninterface IAddTicketsProps {\r\n    addTickets: IBookingTicketState\r\n    giftAidStatus: number\r\n}\r\n\r\nconst AddTickets: React.FC<IAddTicketsProps> = ({\r\n    addTickets,\r\n    giftAidStatus,\r\n}: IAddTicketsProps): JSX.Element => {\r\n    const global = useContext(GlobalContext)\r\n    const scrollRef = useRef(null)\r\n    const dispatch = useAppDispatch()\r\n    const bookingObject = useAppSelector(ticketsBookingObject)\r\n    const minPartySize = useAppSelector(\r\n        ticketsBookingObjectTicketObjectMinPartySize\r\n    )\r\n    const maxPartySize = useAppSelector(\r\n        ticketsBookingObjectTicketObjectMaxPartySize\r\n    )\r\n    const [ticketsShow, setTicketsShow] = useState(true)\r\n    const [size, setSize] = useState(0)\r\n    const [showChildren, setShowChildren] = useState<number | undefined>(\r\n        undefined\r\n    )\r\n\r\n    const currencyFormat = (num: number): string =>\r\n        `£${(num / 100).toFixed(2).replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')}`\r\n\r\n    const isGiftAidChecked = (ticketType: ITicketType): boolean => {\r\n        return (\r\n            giftAidStatus === GiftAidStatusEnum.giftAid &&\r\n            ticketType.giftAidPennies > 0\r\n        )\r\n    }\r\n\r\n    const handleParent = (i: number, parent: boolean): void => {\r\n        const tempBookingObject = cloneObj(bookingObject.ticketObject)\r\n\r\n        if (parent) {\r\n            for (let p = 0; p < tempBookingObject.ticketTypes.length; p++) {\r\n                for (\r\n                    let c = 0;\r\n                    c < tempBookingObject.ticketTypes[p].childTickets.length;\r\n                    c++\r\n                ) {\r\n                    tempBookingObject.ticketTypes[p].childTickets[c].quantity =\r\n                        0\r\n                    tempBookingObject.ticketTypes[p].childTickets[\r\n                        c\r\n                    ].totalPricePennies = 0\r\n                }\r\n            }\r\n\r\n            if (parent) {\r\n                setSize(0)\r\n            }\r\n\r\n            dispatch(resetChildTickets(tempBookingObject))\r\n            setShowChildren(i)\r\n        }\r\n    }\r\n\r\n    const handleClick = (\r\n        i: number,\r\n        modifier: string,\r\n        relation: boolean,\r\n        type: ITicketType,\r\n        index?: number\r\n    ): void => {\r\n        const tempType = cloneObj(type)\r\n        let newSize = size\r\n        let direction = 0\r\n        let tempTicket\r\n\r\n        if (relation && index !== undefined) {\r\n            tempTicket = cloneObj(\r\n                bookingObject.ticketObject.ticketTypes[i].childTickets[index]\r\n            )\r\n        } else {\r\n            tempTicket = cloneObj(bookingObject.ticketObject.ticketTypes[i])\r\n        }\r\n\r\n        if (!tempTicket.totalPrice) {\r\n            tempTicket.totalPrice = 0\r\n        }\r\n\r\n        if (!tempType.quantity) {\r\n            tempType.quantity = 0\r\n        }\r\n\r\n        if (\r\n            modifier === 'increment' &&\r\n            size < bookingObject.ticketObject.maxPartySize &&\r\n            tempType.quantity < tempType.maxQuantity\r\n        ) {\r\n            if (type.validQuantities && type.validQuantities.length > 0) {\r\n                const arrayIndex = type.validQuantities.indexOf(\r\n                    tempType.quantity\r\n                )\r\n\r\n                if (arrayIndex !== -1) {\r\n                    const previousItem = type.validQuantities[arrayIndex]\r\n                    const newItem =\r\n                        type.validQuantities[arrayIndex + 1] ??\r\n                        type.validQuantities[type.validQuantities.length - 1]\r\n\r\n                    newSize += newItem - previousItem\r\n                    direction = newItem - previousItem\r\n                } else {\r\n                    newSize += type.validQuantities[0]\r\n                    direction = type.validQuantities[0]\r\n                }\r\n            } else if (\r\n                tempTicket.minQuantity > 0 &&\r\n                tempTicket.quantity === 0\r\n            ) {\r\n                newSize += tempTicket.minQuantity\r\n                direction = tempTicket.minQuantity\r\n            } else {\r\n                newSize += 1\r\n                direction = 1\r\n            }\r\n\r\n            setSize(newSize)\r\n\r\n            dispatch(\r\n                incrementTickets({\r\n                    direction: direction,\r\n                    ticket: i,\r\n                    relation: relation,\r\n                    child: index,\r\n                    giftAidStatus,\r\n                })\r\n            )\r\n        } else if (\r\n            modifier === 'decrement' &&\r\n            size > 0 &&\r\n            tempTicket.quantity > 0\r\n        ) {\r\n            if (type.validQuantities && type.validQuantities.length > 0) {\r\n                const arrayIndex = type.validQuantities.indexOf(\r\n                    tempType.quantity\r\n                )\r\n\r\n                if (arrayIndex !== -1) {\r\n                    const previousItem = type.validQuantities[arrayIndex]\r\n                    const newItem = type.validQuantities[arrayIndex - 1] ?? 0\r\n                    newSize += newItem - previousItem\r\n                    direction = newItem - previousItem\r\n                }\r\n            } else if (\r\n                tempTicket.minQuantity > 0 &&\r\n                tempTicket.quantity === tempTicket.minQuantity\r\n            ) {\r\n                newSize -= tempTicket.minQuantity\r\n                direction = -tempTicket.minQuantity\r\n            } else {\r\n                newSize -= 1\r\n                direction = -1\r\n            }\r\n\r\n            setSize(newSize)\r\n            dispatch(\r\n                incrementTickets({\r\n                    direction: direction,\r\n                    ticket: i,\r\n                    relation: relation,\r\n                    child: index,\r\n                    giftAidStatus,\r\n                })\r\n            )\r\n        }\r\n    }\r\n\r\n    return (\r\n        <div className=\"addTickets\">\r\n            <section>\r\n                <span>Add your tickets:</span>\r\n                {global.ticketingInfo && (\r\n                    <Tooltip\r\n                        displayedText={global.ticketingInfo}\r\n                        position={TOOLTIP_ARROW_POSITION.LEFT}\r\n                    >\r\n                        <svg width={30} height={30}>\r\n                            <use href=\"#info\"></use>\r\n                        </svg>\r\n                    </Tooltip>\r\n                )}\r\n            </section>\r\n            {minPartySize ? (\r\n                <p>\r\n                    {`You must order a minimum of ${minPartySize} tickets to proceed`}\r\n                </p>\r\n            ) : (\r\n                <></>\r\n            )}\r\n            {maxPartySize ? (\r\n                <p>{`The maximum party size is ${maxPartySize}`}</p>\r\n            ) : (\r\n                <></>\r\n            )}\r\n            {ticketsShow ? (\r\n                <div className=\"addTickets__lowHolder\" ref={scrollRef}>\r\n                    {bookingObject.ticketObject &&\r\n                        Object.keys(bookingObject.ticketObject).length !== 0 &&\r\n                        bookingObject.ticketObject.ticketTypes.map(\r\n                            (type, i) => {\r\n                                const isValidQuantity =\r\n                                    type.validQuantities &&\r\n                                    type.validQuantities.length > 0\r\n                                const ticketPricePennies = isGiftAidChecked(\r\n                                    type\r\n                                )\r\n                                    ? type.giftAidPennies\r\n                                    : type.pricePennies\r\n\r\n                                return (\r\n                                    <div key={i}>\r\n                                        <>\r\n                                            <div className=\"addTickets__container\">\r\n                                                <div\r\n                                                    className=\"addTickets__title\"\r\n                                                    onClick={() =>\r\n                                                        handleParent(\r\n                                                            i,\r\n                                                            type.isParent\r\n                                                        )\r\n                                                    }\r\n                                                >\r\n                                                    <div className=\"addTickets__buttonRow\">\r\n                                                        {type.isParent && (\r\n                                                            <span\r\n                                                                style={\r\n                                                                    showChildren ===\r\n                                                                    i\r\n                                                                        ? {\r\n                                                                              backgroundColor:\r\n                                                                                  'var(--color-primary)',\r\n                                                                              cursor: 'pointer',\r\n                                                                          }\r\n                                                                        : {}\r\n                                                                }\r\n                                                                className=\"addTickets__circle\"\r\n                                                            />\r\n                                                        )}\r\n                                                        <span>\r\n                                                            {type.friendlyName ||\r\n                                                                type.name}{' '}\r\n                                                            {isGiftAidChecked(\r\n                                                                type\r\n                                                            ) && '(Gift Aid)'}\r\n                                                        </span>\r\n                                                    </div>\r\n                                                    {type.note && (\r\n                                                        <span className=\"addTickets__subTitle note\">\r\n                                                            {type.note}\r\n                                                        </span>\r\n                                                    )}\r\n                                                </div>\r\n                                                {!type.isParent && (\r\n                                                    <div className=\"addTickets__right\">\r\n                                                        <span>\r\n                                                            {currencyFormat(\r\n                                                                isValidQuantity\r\n                                                                    ? ticketPricePennies *\r\n                                                                          type\r\n                                                                              .validQuantities[0]\r\n                                                                    : ticketPricePennies\r\n                                                            )}\r\n                                                        </span>\r\n                                                        <div className=\"addTickets__modifierContain\">\r\n                                                            <button\r\n                                                                className=\"btn primary-btn-white addTickets__modifier\"\r\n                                                                id=\"subtractTickets\"\r\n                                                                onClick={() => {\r\n                                                                    handleClick(\r\n                                                                        i,\r\n                                                                        'decrement',\r\n                                                                        false,\r\n                                                                        type\r\n                                                                    )\r\n                                                                }}\r\n                                                            >\r\n                                                                <img\r\n                                                                    className=\"addTickets__iconMinus\"\r\n                                                                    src={minus}\r\n                                                                    alt=\"Decrease Tickets\"\r\n                                                                />\r\n                                                            </button>\r\n                                                            <span>\r\n                                                                {type.quantity ||\r\n                                                                    0}{' '}\r\n                                                            </span>\r\n                                                            <button\r\n                                                                className=\"btn primary-btn-white addTickets__modifier\"\r\n                                                                id=\"incrementTickets\"\r\n                                                                onClick={() => {\r\n                                                                    handleClick(\r\n                                                                        i,\r\n                                                                        'increment',\r\n                                                                        false,\r\n                                                                        type\r\n                                                                    )\r\n                                                                }}\r\n                                                            >\r\n                                                                <img\r\n                                                                    className=\"addTickets__iconPlus\"\r\n                                                                    src={plus}\r\n                                                                    alt=\"Increase Tickets\"\r\n                                                                />\r\n                                                            </button>\r\n                                                        </div>\r\n                                                    </div>\r\n                                                )}\r\n                                            </div>\r\n                                            {showChildren !== null &&\r\n                                                showChildren === i && (\r\n                                                    <motion.div\r\n                                                        initial=\"initial\"\r\n                                                        animate=\"in\"\r\n                                                        exit=\"out\"\r\n                                                        variants={\r\n                                                            animateVariants\r\n                                                        }\r\n                                                        className=\"addTickets__children\"\r\n                                                    >\r\n                                                        {type.childTickets.map(\r\n                                                            (child, index) => {\r\n                                                                const smallName =\r\n                                                                    child.friendlyName.split(\r\n                                                                        '- '\r\n                                                                    )[1] ||\r\n                                                                    child.friendlyName\r\n                                                                const isValidQuantity =\r\n                                                                    child.validQuantities &&\r\n                                                                    child\r\n                                                                        .validQuantities\r\n                                                                        .length >\r\n                                                                        0\r\n                                                                const childTicketPricePennies =\r\n                                                                    isGiftAidChecked(\r\n                                                                        type\r\n                                                                    )\r\n                                                                        ? child.giftAidPennies\r\n                                                                        : child.pricePennies\r\n\r\n                                                                return (\r\n                                                                    <div\r\n                                                                        className=\"addTickets__child\"\r\n                                                                        key={\r\n                                                                            index\r\n                                                                        }\r\n                                                                    >\r\n                                                                        <div className=\"addTickets__childLeft\">\r\n                                                                            <span>\r\n                                                                                {\r\n                                                                                    smallName\r\n                                                                                }{' '}\r\n                                                                                {isGiftAidChecked(\r\n                                                                                    child\r\n                                                                                ) &&\r\n                                                                                    '(Gift Aid)'}\r\n                                                                            </span>\r\n                                                                            <span>\r\n                                                                                {currencyFormat(\r\n                                                                                    isValidQuantity\r\n                                                                                        ? childTicketPricePennies *\r\n                                                                                              type\r\n                                                                                                  .validQuantities[0]\r\n                                                                                        : childTicketPricePennies\r\n                                                                                )}\r\n                                                                            </span>\r\n                                                                        </div>\r\n                                                                        <div className=\"addTickets__right\">\r\n                                                                            <div className=\"addTickets__modifierContain\">\r\n                                                                                <button\r\n                                                                                    className=\"btn primary-btn-white addTickets__modifier\"\r\n                                                                                    id=\"subtractTickets\"\r\n                                                                                    onClick={() => {\r\n                                                                                        handleClick(\r\n                                                                                            i,\r\n                                                                                            'decrement',\r\n                                                                                            true,\r\n                                                                                            child,\r\n                                                                                            index\r\n                                                                                        )\r\n                                                                                    }}\r\n                                                                                >\r\n                                                                                    <img\r\n                                                                                        className=\"addTickets__iconMinus\"\r\n                                                                                        src={\r\n                                                                                            minus\r\n                                                                                        }\r\n                                                                                        alt=\"Decrease Tickets\"\r\n                                                                                    />\r\n                                                                                </button>\r\n                                                                                <span>\r\n                                                                                    {\r\n                                                                                        child.quantity\r\n                                                                                    }\r\n                                                                                </span>\r\n                                                                                <button\r\n                                                                                    className=\"btn primary-btn-white addTickets__modifier addTickets__modifierPlus\"\r\n                                                                                    id=\"incrementTickets\"\r\n                                                                                    onClick={() => {\r\n                                                                                        handleClick(\r\n                                                                                            i,\r\n                                                                                            'increment',\r\n                                                                                            true,\r\n                                                                                            child,\r\n                                                                                            index\r\n                                                                                        )\r\n                                                                                    }}\r\n                                                                                >\r\n                                                                                    <img\r\n                                                                                        className=\"addTickets__iconPlus\"\r\n                                                                                        src={\r\n                                                                                            plus\r\n                                                                                        }\r\n                                                                                        alt=\"Increase Tickets\"\r\n                                                                                    />\r\n                                                                                </button>\r\n                                                                            </div>\r\n                                                                        </div>\r\n                                                                    </div>\r\n                                                                )\r\n                                                            }\r\n                                                        )}\r\n                                                    </motion.div>\r\n                                                )}\r\n                                        </>\r\n                                    </div>\r\n                                )\r\n                            }\r\n                        )}\r\n                </div>\r\n            ) : addTickets.ticketTypes && addTickets.ticketTypes[0] ? (\r\n                <button\r\n                    className=\"btn primary-btn-white btn-large\"\r\n                    id=\"selectTicketType\"\r\n                    onClick={() => {\r\n                        setTicketsShow(true)\r\n                    }}\r\n                >\r\n                    Select\r\n                </button>\r\n            ) : (\r\n                <button className=\"btn primary-btn-white-disabled btn-large\">\r\n                    Please select a ticket type first\r\n                </button>\r\n            )}\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default AddTickets\r\n","import React from 'react'\r\nimport { useAppSelector } from '../../../../redux/store'\r\nimport { ticketsBookingObjectTicketsCompleteTicketTypes } from '../../../../redux/ticketSlice'\r\nimport { GiftAidStatusValues } from '../../Features/GiftAid/GiftAid'\r\nimport { ITicketType } from '../../../../interfaces/interfaces'\r\n\r\ninterface IProps {\r\n    giftAidStatus: GiftAidStatusValues\r\n}\r\n\r\nfunction calculateTicketTotal(\r\n    ticket: ITicketType,\r\n    giftAidStatus: GiftAidStatusValues\r\n) {\r\n    const pennies =\r\n        giftAidStatus === 2 ? ticket.giftAidPennies : ticket.pricePennies\r\n\r\n    const total = (pennies / 100) * ticket.quantity\r\n    return total.toFixed(2)\r\n}\r\n\r\nexport default function TicketsSummary(props: IProps) {\r\n    const ticketTypes = useAppSelector(\r\n        ticketsBookingObjectTicketsCompleteTicketTypes\r\n    )\r\n\r\n    return (\r\n        <div>\r\n            <p>Tickets:</p>\r\n            <div className=\"homeSummary__seatColumn\">\r\n                {ticketTypes\r\n                    .filter((ticket) => ticket.quantity)\r\n                    .map((ticket, i) => (\r\n                        <div key={`ticket-${i}`} className=\"homeSummary__row\">\r\n                            <p>\r\n                                {ticket.quantity || ticket.quantity} x{' '}\r\n                                {ticket.friendlyName || ticket.name}\r\n                            </p>\r\n                            <div className=\"homeSummary__fee\">\r\n                                <p>\r\n                                    {`£ ${calculateTicketTotal(ticket, props.giftAidStatus)}`}\r\n                                </p>\r\n                                {!!ticket.inclusionBookingFeePennies &&\r\n                                    ticket.inclusionBookingFeePennies > 0 && (\r\n                                        <span className=\"note homeSummary__note\">\r\n                                            {`inc £ ${((ticket.inclusionBookingFeePennies / 100) * ticket.quantity).toFixed(2)} booking fee`}\r\n                                        </span>\r\n                                    )}\r\n                            </div>\r\n                        </div>\r\n                    ))}\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n","import React, { useMemo } from 'react'\r\nimport { useAppSelector } from '../../../../redux/store'\r\nimport {\r\n    OrderBookingFee,\r\n    ticketsBookingObjectDiscountValue,\r\n    ticketsBookingObjectTicketsCompleteTicketTypes,\r\n} from '../../../../redux/ticketSlice'\r\nimport { GiftAidStatusValues } from '../../Features/GiftAid/GiftAid'\r\n\r\ninterface IProps {\r\n    giftAidStatus: GiftAidStatusValues\r\n}\r\n\r\nconst TicketsTotalPrice = (props: IProps) => {\r\n    const ticketTypes = useAppSelector(\r\n        ticketsBookingObjectTicketsCompleteTicketTypes\r\n    )\r\n    const orderBookingFee = useAppSelector(OrderBookingFee)\r\n    const discountValue = useAppSelector(ticketsBookingObjectDiscountValue)\r\n\r\n    const totalPrice = useMemo(() => {\r\n        return ticketTypes.reduce((total: number, ticket): number => {\r\n            const pennies: number =\r\n                props.giftAidStatus === 2\r\n                    ? ticket.giftAidPennies\r\n                    : ticket.pricePennies\r\n            const bookingFeePennies = ticket.bookingFeePennies\r\n                ? ticket.bookingFeePennies\r\n                : 0\r\n\r\n            const ticketsTotal: number =\r\n                (pennies * ticket.quantity + bookingFeePennies) / 100\r\n            return total + ticketsTotal\r\n        }, 0)\r\n    }, [props.giftAidStatus, ticketTypes])\r\n\r\n    return (\r\n        <div className=\"homeSummary__row homeSummary__summary\">\r\n            {totalPrice ? (\r\n                <>\r\n                    <span className=\"homeSummary__left\">\r\n                        <h1>Total:</h1>\r\n                    </span>\r\n                    <span className=\"homeSummary__right\">\r\n                        <h1>{`£${(totalPrice - discountValue + orderBookingFee / 100).toFixed(2)}`}</h1>\r\n                    </span>\r\n                </>\r\n            ) : (\r\n                <></>\r\n            )}\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default TicketsTotalPrice\r\n","import React, { useEffect, useState, useContext } from 'react'\r\nimport Cookies from 'js-cookie'\r\nimport { format } from 'date-fns'\r\nimport { formatToDateObjToLocation } from '../DateTime/Datepicker/helpers/dateLibUtils'\r\nimport './HomeSummary.css'\r\nimport {\r\n    isDatePickerOpen,\r\n    createReservation,\r\n    setBookingProgress,\r\n    setPromoCodeInput,\r\n    setPromoCodeAmount,\r\n    ticketsBookingObject,\r\n} from '../../../../redux/ticketSlice'\r\n\r\nimport { GiftAidStatusEnum } from '../../Features/GiftAid/GiftAid'\r\nimport API from '../../../../axios/API'\r\nimport Loader from '../../../Shared/Loader/Loader'\r\nimport {\r\n    bookingLocale,\r\n    dateFormatStringDOW,\r\n} from '../../../../Helpers/constants'\r\nimport TicketCountdown from '../Countdown/TicketCountdown'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\nimport { GlobalContext } from '../../../../Context/GlobalContext'\r\nimport { featureFlagsAffiliateTrackingCode } from '../../../../redux/feature-flags/feature-flags-selectors'\r\nimport TicketsSummary from './TicketsSummary'\r\nimport TicketsTotalPrice from './TicketsTotalPrice'\r\nimport {\r\n    bookingFunctions,\r\n    cloneObj,\r\n    currencyFormat,\r\n} from '../../../../Helpers/utils'\r\n\r\ninterface IHomeSummary {\r\n    giftAidStatus: number\r\n}\r\n\r\nconst HomeSummary: React.FC<IHomeSummary> = ({\r\n    giftAidStatus,\r\n}: IHomeSummary): JSX.Element => {\r\n    const global = useContext(GlobalContext)\r\n    const dispatch = useAppDispatch()\r\n    const bookingObject = useAppSelector(ticketsBookingObject)\r\n    const IsDatePickerOpen = useAppSelector(isDatePickerOpen)\r\n    const affiliateTrackingCodeFlag = useAppSelector(\r\n        featureFlagsAffiliateTrackingCode\r\n    )\r\n    const [loadingTwo, setLoadingTwo] = useState<boolean>(false)\r\n    const [promoValidateButtonState, setPromoValidateButtonState] =\r\n        useState<boolean>(false)\r\n    const [promoCode, setPromoCode] = useState<string>('')\r\n    const [promoCodeInvalid, setPromoCodeInvalid] = useState<boolean>(false)\r\n    const [promoCodeError, setPromoCodeError] = useState<string | undefined>(\r\n        undefined\r\n    )\r\n    const [extraContinueCondition, setExtraContinueCondition] =\r\n        useState<boolean>(true)\r\n    const [thisDone, setThisDone] = useState<boolean>(false)\r\n    const [message, setMessage] = useState<string>('')\r\n    const [discountMessage, setDiscountMessage] = useState<string>('')\r\n\r\n    const checkQuestions = (): void => {\r\n        const booking = cloneObj(bookingObject)\r\n        const encodedAffiliateCode = Cookies.get('wa')\r\n\r\n        if (affiliateTrackingCodeFlag) {\r\n            const affiliateTrackingCode = Cookies.get('wf')\r\n            if (affiliateTrackingCode) {\r\n                booking.affiliateTrackingCode = window.atob(\r\n                    affiliateTrackingCode\r\n                )\r\n            }\r\n        }\r\n\r\n        if (encodedAffiliateCode) {\r\n            booking.affiliateCode = window.atob(encodedAffiliateCode)\r\n        }\r\n\r\n        const tempAnalyticsData = bookingFunctions.createTixInfoArray(\r\n            booking.ticketComplete.ticketTypes,\r\n            booking.ticketObject.eventName,\r\n            booking.attractionName\r\n        )\r\n\r\n        window.dataLayer.push({ ecommerce: undefined })\r\n        window.dataLayer.push({\r\n            event: 'add__to__cart',\r\n            eventProps: {\r\n                category: 'Booking',\r\n                action: 'Add to cart',\r\n            },\r\n            ecommerce: {\r\n                currency: 'GBP',\r\n                value:\r\n                    (bookingObject.price +\r\n                        (bookingObject.orderBookingFee / 100 || 0) -\r\n                        (bookingObject.discountValue || 0)) /\r\n                    100,\r\n                items: tempAnalyticsData.complete,\r\n            },\r\n        })\r\n\r\n        if (bookingObject.showGiftAid === true) {\r\n            booking.ticketComplete.giftAidStatus =\r\n                giftAidStatus ?? GiftAidStatusEnum.giftAid\r\n        }\r\n\r\n        booking.ticketComplete.ticketTypes = tempAnalyticsData.tickets\r\n        void dispatch(createReservation(booking))\r\n    }\r\n\r\n    useEffect(() => {\r\n        setDiscountMessage(\r\n            global.partnerId ? `Your member discount` : `Promotion discount`\r\n        )\r\n    }, [global.partnerId])\r\n\r\n    useEffect(() => {\r\n        if (!thisDone) {\r\n            if (\r\n                bookingObject.reserveResponse &&\r\n                bookingObject.reserveResponse.orderIdentifier\r\n            ) {\r\n                setThisDone(true)\r\n                dispatch(setBookingProgress('notes'))\r\n            }\r\n        }\r\n    }, [bookingObject.reserveResponse, dispatch, thisDone])\r\n\r\n    useEffect(() => {\r\n        /* this is for the bounty/caravan whitelabel change to add\r\n    discount to tickets as soon as ticket numbers are changed\r\n\r\n    so check to see if it's the relevant whitelabels, check that\r\n    tickets are selected and if both are true, execute the discount\r\n    process in the background without the promotion box\r\n    */\r\n\r\n        if (\r\n            bookingObject.ticketComplete?.ticketTypes?.length > 0 &&\r\n            bookingObject.ticketObject.promotionalMessage\r\n        ) {\r\n            validatePromoCode()\r\n        }\r\n    }, [bookingObject.ticketComplete.ticketTypes])\r\n\r\n    const handlePromoCode = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        const promoCode = e.target.value\r\n\r\n        if (promoCode.length > 0) {\r\n            setExtraContinueCondition(false)\r\n        } else {\r\n            setExtraContinueCondition(true)\r\n        }\r\n\r\n        setPromoCode(promoCode)\r\n        dispatch(setPromoCodeInput(promoCode))\r\n\r\n        if (promoCode.length > 4 && promoCode.match(/^[0-9a-zA-Z-]+$/)) {\r\n            setPromoValidateButtonState(true)\r\n        }\r\n    }\r\n\r\n    const handleValidatePromoCode = (\r\n        e: React.MouseEvent<HTMLButtonElement>\r\n    ): void => {\r\n        e.preventDefault()\r\n        validatePromoCode()\r\n        setDiscountMessage(`Promotion discount`)\r\n    }\r\n\r\n    const validatePromoCode = (): void => {\r\n        setExtraContinueCondition(true)\r\n\r\n        const promoReq = {\r\n            input: bookingObject.promoCodeInput,\r\n            ids: bookingObject.ids,\r\n            totalPrice: bookingObject.price,\r\n        }\r\n\r\n        setLoadingTwo(true)\r\n\r\n        void API.validatePromoCode(promoReq).then(\r\n            (res) => {\r\n                if (res.isValid) {\r\n                    window.dataLayer.push({\r\n                        event: 'promoCode',\r\n                        eventProps: {\r\n                            category: 'Promo Validated',\r\n                            action: 'Click',\r\n                            label: 'Promo is valid',\r\n                        },\r\n                    })\r\n                    setPromoCodeError(undefined)\r\n                    setPromoCodeInvalid(false)\r\n\r\n                    if (bookingObject.promoCodeInput.startsWith('REF')) {\r\n                        setMessage(res.rewardSentence)\r\n                    } else {\r\n                        dispatch(setPromoCodeAmount(res.discountPennies))\r\n                    }\r\n                } else {\r\n                    window.dataLayer.push({\r\n                        event: 'promoCode',\r\n                        eventProps: {\r\n                            category: 'Promo Fail',\r\n                            action: 'Click',\r\n                            label: 'Promo is not valid',\r\n                        },\r\n                    })\r\n                    dispatch(setPromoCodeInput(''))\r\n                    setPromoCodeInvalid(true)\r\n\r\n                    if (global.partnerId) {\r\n                        setDiscountMessage(`Your member discount`)\r\n                    }\r\n                    if (res.friendlyErrorMessage) {\r\n                        setPromoCodeError(res.friendlyErrorMessage)\r\n                    }\r\n                }\r\n\r\n                setLoadingTwo(false)\r\n            },\r\n            () => {\r\n                setPromoCodeError(undefined)\r\n                setLoadingTwo(false)\r\n                setPromoCodeInvalid(true)\r\n            }\r\n        )\r\n    }\r\n\r\n    return (\r\n        <>\r\n            {bookingObject.numTickets > 0 &&\r\n                bookingObject.sessionSelected.minSize &&\r\n                bookingObject.numTickets <\r\n                    bookingObject.sessionSelected.minSize && (\r\n                    <div className=\"homeSummary__minBox\">\r\n                        You must book at least{' '}\r\n                        {bookingObject.sessionSelected.minSize} tickets for this\r\n                        event\r\n                    </div>\r\n                )}\r\n            {!IsDatePickerOpen && (\r\n                <div className=\"homeSummary\">\r\n                    {loadingTwo && (\r\n                        <Loader messages={['Checking discount code']} />\r\n                    )}\r\n                    {bookingObject.sessionSelected &&\r\n                        bookingObject.sessionSelected.startDate && (\r\n                            <div className=\"homeSummary__row\">\r\n                                <span className=\"homeSummary__left\">\r\n                                    <p>\r\n                                        Date\r\n                                        {bookingObject.sessionSelected\r\n                                            .showTimePicker && (\r\n                                            <span>/Time</span>\r\n                                        )}\r\n                                        :\r\n                                    </p>\r\n                                </span>\r\n                                <span className=\"homeSummary__right\">\r\n                                    <p>\r\n                                        {format(\r\n                                            formatToDateObjToLocation(\r\n                                                bookingObject.sessionSelected\r\n                                                    .startDate,\r\n                                                bookingLocale\r\n                                            ),\r\n                                            dateFormatStringDOW\r\n                                        )}\r\n                                        {bookingObject.sessionSelected\r\n                                            .showTimePicker && (\r\n                                            <span>\r\n                                                {\r\n                                                    bookingObject\r\n                                                        .sessionSelected\r\n                                                        .startTime\r\n                                                }\r\n                                            </span>\r\n                                        )}\r\n                                    </p>\r\n                                </span>\r\n                            </div>\r\n                        )}\r\n                    {bookingObject.price !== 0 &&\r\n                        bookingObject.ticketComplete.ticketTypes &&\r\n                        bookingObject.ticketComplete.ticketTypes[0] && (\r\n                            <>\r\n                                <TicketsSummary giftAidStatus={giftAidStatus} />\r\n                                <div>\r\n                                    {bookingObject.orderBookingFee > 0 && (\r\n                                        <>\r\n                                            <p>Order Charges:</p>\r\n                                            <div className=\"homeSummary__seatColumn\">\r\n                                                <div className=\"homeSummary__row\">\r\n                                                    <p>Booking Fee</p>\r\n                                                    <span className=\"homeSummary__fee\">\r\n                                                        <p>\r\n                                                            {currencyFormat(\r\n                                                                bookingObject.orderBookingFee\r\n                                                            )}\r\n                                                        </p>\r\n                                                    </span>\r\n                                                </div>\r\n                                            </div>\r\n                                        </>\r\n                                    )}\r\n                                    {bookingObject.ticketComplete.ticketTypes[0]\r\n                                        .bookingFeePennies > 0 && (\r\n                                        <>\r\n                                            <div className=\"homeSummary__seatColumn\">\r\n                                                <div className=\"homeSummary__row\">\r\n                                                    <p>\r\n                                                        Booking Fee per Ticket\r\n                                                    </p>\r\n                                                    <span className=\"homeSummary__fee\">\r\n                                                        <p>\r\n                                                            {currencyFormat(\r\n                                                                bookingObject\r\n                                                                    .ticketComplete\r\n                                                                    .ticketTypes[0]\r\n                                                                    .bookingFeePennies\r\n                                                            )}\r\n                                                        </p>\r\n                                                    </span>\r\n                                                </div>\r\n                                            </div>\r\n                                        </>\r\n                                    )}\r\n                                </div>\r\n                            </>\r\n                        )}\r\n\r\n                    {bookingObject.discountValue !== 0 && (\r\n                        <>\r\n                            <div className=\"homeSummary__row homeSummary__summary homeSummary__discount\">\r\n                                <h3>{discountMessage}</h3>\r\n                                <h3>\r\n                                    -{' '}\r\n                                    {currencyFormat(\r\n                                        bookingObject.discountValue\r\n                                    )}\r\n                                </h3>\r\n                            </div>\r\n                        </>\r\n                    )}\r\n                    <TicketsTotalPrice giftAidStatus={giftAidStatus} />\r\n                    <div className=\"homeSummary__row homeSummary__summary homeSummary__promoContainer\">\r\n                        {!!bookingObject.price && (\r\n                            <>\r\n                                <div className=\"checkoutSummary__promoInputContain\">\r\n                                    <label htmlFor=\"promoInput\">\r\n                                        Got a promo or referral code?\r\n                                    </label>\r\n                                    <div className=\"promo-code__inputs\">\r\n                                        <input\r\n                                            value={promoCode}\r\n                                            onChange={handlePromoCode}\r\n                                            className=\"input\"\r\n                                            id=\"promoInput\"\r\n                                            name=\"Promo Code Input\"\r\n                                            type=\"text\"\r\n                                        />\r\n                                        {promoValidateButtonState ? (\r\n                                            <button\r\n                                                id=\"promoCodeValidateButton\"\r\n                                                onClick={\r\n                                                    handleValidatePromoCode\r\n                                                }\r\n                                                className=\"btn primary-btn validate-btn\"\r\n                                            >\r\n                                                Validate\r\n                                            </button>\r\n                                        ) : (\r\n                                            <button className=\"btn primary-btn-disabled validate-btn\">\r\n                                                Validate\r\n                                            </button>\r\n                                        )}\r\n                                    </div>\r\n                                    {(promoCodeInvalid || message) && (\r\n                                        <p className=\"checkoutSummary__promoError\">\r\n                                            {promoCodeError && !message\r\n                                                ? promoCodeError\r\n                                                : message\r\n                                                  ? message\r\n                                                  : 'This voucher code is not valid for this order'}\r\n                                        </p>\r\n                                    )}\r\n                                </div>\r\n                            </>\r\n                        )}\r\n                    </div>\r\n\r\n                    {bookingObject.showTime && <TicketCountdown />}\r\n\r\n                    {extraContinueCondition &&\r\n                    bookingObject.ticketsSelected &&\r\n                    bookingObject.numTickets >=\r\n                        (bookingObject.ticketObject.minPartySize || 1) ? (\r\n                        <button\r\n                            id=\"reservationCall\"\r\n                            onClick={checkQuestions}\r\n                            className=\"btn primary-btn btn-large btn-shorter\"\r\n                        >\r\n                            Select\r\n                        </button>\r\n                    ) : (\r\n                        <button className=\"btn primary-btn-disabled btn-large btn-shorter\">\r\n                            Select\r\n                        </button>\r\n                    )}\r\n                </div>\r\n            )}\r\n        </>\r\n    )\r\n}\r\n\r\nexport default HomeSummary\r\n","import React from 'react'\r\nimport {\r\n    IAddresErrorStateObj,\r\n    IAddressObj,\r\n} from '../../../../interfaces/interfaces'\r\n\r\ninterface IAddressEditInputsProps {\r\n    handleChangeAddress: (\r\n        e: React.ChangeEvent<HTMLInputElement>,\r\n        key: string\r\n    ) => void\r\n    address: IAddressObj\r\n    valueKey: string\r\n    label: string\r\n    hasError?: IAddresErrorStateObj\r\n    errorShow?: boolean\r\n    required: boolean\r\n}\r\n\r\nconst AddressEditInputs: React.FC<IAddressEditInputsProps> = ({\r\n    handleChangeAddress,\r\n    address,\r\n    valueKey,\r\n    label,\r\n    hasError,\r\n    errorShow,\r\n    required,\r\n}: IAddressEditInputsProps): JSX.Element => {\r\n    return (\r\n        <div className=\"editAddress__input\">\r\n            <div className=\"input-container\">\r\n                <label className=\"inputTitle\">{label}</label>\r\n                <input\r\n                    value={address[valueKey as keyof IAddressObj]}\r\n                    onChange={(e) => {\r\n                        handleChangeAddress(e, valueKey)\r\n                    }}\r\n                    className={`input ${\r\n                        hasError &&\r\n                        hasError[valueKey as keyof IAddresErrorStateObj] &&\r\n                        errorShow\r\n                            ? 'editAddress__inputError'\r\n                            : ''\r\n                    }`}\r\n                    name={valueKey}\r\n                    type=\"text\"\r\n                    required={required}\r\n                />\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default AddressEditInputs\r\n","import React, { useEffect, useState } from 'react'\r\nimport axios from 'axios'\r\nimport { setBillingAddress } from '../../../../redux/stripeSlice'\r\nimport { motion } from 'framer-motion'\r\nimport countryList from 'react-select-country-list'\r\nimport './newAddressFinder.css'\r\nimport { IAddressObj, ILocation } from '../../../../interfaces/interfaces'\r\nimport { useAppDispatch } from '../../../../redux/store'\r\n\r\nconst finderVariants = {\r\n    initial: {\r\n        opacity: 0,\r\n        scaleY: 0,\r\n        height: 0,\r\n    },\r\n    in: {\r\n        opacity: 1,\r\n        scaleY: 1,\r\n        height: 'auto',\r\n        transition: { duration: 0.3 },\r\n    },\r\n    out: {\r\n        opacity: 0,\r\n        scaleY: 0,\r\n        height: 0,\r\n    },\r\n}\r\n\r\ninterface IAddressSearchSuggestions {\r\n    address: string\r\n    url: string\r\n    id: string\r\n}\r\n\r\ninterface IAddressSearchResult {\r\n    country: string\r\n    thoroughfare: string\r\n    building_name: string\r\n    sub_building_name: string\r\n    sub_building_number: string\r\n    building_number: string\r\n    line_1: string\r\n    line_2: string\r\n    line_3: string\r\n    line_4: string\r\n    locality: string\r\n    town_or_city: string\r\n    county: string\r\n    district: string\r\n    postcode: string\r\n    latitude: number\r\n    longitude: number\r\n}\r\n\r\ninterface INewAddressFinderProps {\r\n    setAddress: React.Dispatch<React.SetStateAction<IAddressObj>>\r\n    setManual: React.Dispatch<React.SetStateAction<boolean>>\r\n    queryType: string\r\n    setSendManual: React.Dispatch<React.SetStateAction<boolean>>\r\n}\r\n\r\nconst NewAddressFinder: React.FC<INewAddressFinderProps> = ({\r\n    setAddress,\r\n    setManual,\r\n    queryType,\r\n    setSendManual,\r\n}: INewAddressFinderProps): JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n\r\n    const [location, setLocation] = useState<ILocation>({} as ILocation)\r\n    const [searchTerm, updateSearchTerm] = useState<string>('')\r\n    const [searchResults, updateSearchResults] = useState<\r\n        IAddressSearchSuggestions[]\r\n    >([])\r\n    const [displayResults, updateDisplayResults] = useState(false)\r\n\r\n    const resetSearch = (): void => {\r\n        updateSearchResults([])\r\n    }\r\n\r\n    useEffect(() => {\r\n        if ('geolocation' in navigator) {\r\n            navigator.geolocation.getCurrentPosition(function (position) {\r\n                setLocation({\r\n                    latitude: position.coords.latitude,\r\n                    longitude: position.coords.longitude,\r\n                })\r\n            })\r\n        }\r\n    }, [])\r\n\r\n    const searchResultsView = (): JSX.Element => {\r\n        if (displayResults) {\r\n            const handleSelection = (\r\n                suggestion: IAddressSearchSuggestions\r\n            ): void => {\r\n                axios({\r\n                    method: 'GET',\r\n                    url:\r\n                        'https://api.getAddress.io/get/' +\r\n                        suggestion.id +\r\n                        '?api-key=V8kX55fwXEiGHqjKIYM0Fw31226',\r\n                }).then((addressRes) => {\r\n                    updateSearchResults([])\r\n                    const addressResult =\r\n                        addressRes.data as IAddressSearchResult\r\n\r\n                    if (\r\n                        addressResult.country ===\r\n                        ('England' || 'Wales' || 'Scotland' || 'Ireland')\r\n                    ) {\r\n                        addressResult.country = 'United Kingdom'\r\n                    }\r\n\r\n                    setSendManual(false)\r\n\r\n                    const resObject = {\r\n                        thoroughfare: addressResult.thoroughfare,\r\n                        buildingname: addressResult.building_name,\r\n                        subbuildingname: addressResult.sub_building_name,\r\n                        subbuildingnumber: addressResult.sub_building_number,\r\n                        buildingnumber: addressResult.building_number,\r\n                        line1: addressResult.line_1,\r\n                        line2: addressResult.line_2,\r\n                        line3: addressResult.line_3,\r\n                        line4: addressResult.line_4,\r\n                        locality: addressResult.locality,\r\n                        townOrCity: addressResult.town_or_city,\r\n                        county: addressResult.county,\r\n                        district: addressResult.district,\r\n                        countryId: 'GB',\r\n                        postcode: addressResult.postcode,\r\n                        latitude: addressResult.latitude,\r\n                        longitude: addressResult.longitude,\r\n                        addressType: queryType === 'shippingAddress' ? 1 : 2,\r\n                        isPrimary: true,\r\n                    } as IAddressObj\r\n\r\n                    const resultObject = {\r\n                        line1: addressResult.line_1,\r\n                        line2: addressResult.line_2,\r\n                        line3: addressResult.town_or_city,\r\n                        line4: addressResult.county,\r\n                        postcode: addressResult.postcode,\r\n                        country: {\r\n                            value: countryList().getValue(\r\n                                addressResult.country\r\n                            ),\r\n                            label: addressResult.country,\r\n                        },\r\n                        primary: false,\r\n                    }\r\n\r\n                    if (queryType === 'shippingAddress') {\r\n                        setAddress(resObject)\r\n                    } else {\r\n                        dispatch(setBillingAddress(resultObject))\r\n                    }\r\n\r\n                    setManual(true)\r\n                })\r\n            }\r\n\r\n            return (\r\n                <div className=\"search-results\">\r\n                    {searchResults.map((suggestion, index) => {\r\n                        return (\r\n                            <button\r\n                                id=\"addressFinderSelectAddress\"\r\n                                className=\"btn button newAddressFinder__button\"\r\n                                key={index}\r\n                                onClick={() => {\r\n                                    handleSelection(suggestion)\r\n                                }}\r\n                            >\r\n                                {suggestion.address}\r\n                            </button>\r\n                        )\r\n                    })}\r\n                </div>\r\n            )\r\n        } else return <></>\r\n    }\r\n\r\n    const updateSearch = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        updateSearchTerm(e.target.value)\r\n\r\n        if (e.target.value.length < 3) {\r\n            updateDisplayResults(false)\r\n\r\n            return\r\n        } else {\r\n            updateDisplayResults(true)\r\n        }\r\n\r\n        axios({\r\n            method: 'POST',\r\n            url:\r\n                'https://api.getAddress.io/autocomplete/' +\r\n                e.target.value +\r\n                '?api-key=V8kX55fwXEiGHqjKIYM0Fw31226',\r\n            data: {\r\n                location: location, // This is the body part\r\n            },\r\n        }).then((addressProp) => {\r\n            updateSearchResults(addressProp.data.suggestions)\r\n        })\r\n    }\r\n\r\n    return (\r\n        <motion.section\r\n            initial=\"initial\"\r\n            animate=\"in\"\r\n            exit=\"out\"\r\n            variants={finderVariants}\r\n            className=\"search\"\r\n        >\r\n            <div className=\"search-inner\">\r\n                <div className=\"input-container\">\r\n                    <label className=\"inputTitle\">Address Finder</label>\r\n                    <input\r\n                        className=\"input\"\r\n                        name=\"addressFinder\"\r\n                        type=\"text\"\r\n                        value={searchTerm}\r\n                        onClick={resetSearch}\r\n                        placeholder=\"Start typing to search for your address...\"\r\n                        onChange={updateSearch}\r\n                    />\r\n                </div>\r\n\r\n                {searchResultsView()}\r\n            </div>\r\n        </motion.section>\r\n    )\r\n}\r\n\r\nexport default NewAddressFinder\r\n","import React, { useState } from 'react'\r\nimport './AddressEdit.css'\r\nimport { motion } from 'framer-motion'\r\n\r\nimport AddressEditInputs from './AddressEditInputs'\r\nimport NewAddressFinder from './NewAddressFinder'\r\nimport AccountAPI from '../../../../axios/AccountAPI'\r\nimport { INewAddressRequest } from '../../../../axios/interfacesAPI'\r\nimport {\r\n    IAddresErrorStateObj,\r\n    IAddressDetails,\r\n    IAddressObj,\r\n} from '../../../../interfaces/interfaces'\r\n\r\nconst capitalizeName = (name: string): string => {\r\n    return name.replace(/\\b(\\w)/g, (s) => s.toUpperCase())\r\n}\r\n\r\nconst showVariants = {\r\n    initial: {\r\n        y: 90,\r\n        opacity: 0,\r\n        height: 0,\r\n    },\r\n    in: {\r\n        y: 0,\r\n        opacity: 1,\r\n        height: 'auto',\r\n        transition: { duration: 0.6 },\r\n    },\r\n    out: {\r\n        y: 30,\r\n        opacity: 0,\r\n        height: 0,\r\n    },\r\n}\r\n\r\nexport const arrangedAddress = (address: IAddressObj): string | undefined => {\r\n    const fullAddress = [\r\n        address.line1,\r\n        address.line2,\r\n        address.line3,\r\n        address.line4,\r\n        address.townOrCity,\r\n        address.county,\r\n        address.postcode,\r\n    ]\r\n    const newAddr = fullAddress\r\n        .filter((x) => x && x !== '' && x !== null)\r\n        .join(', ')\r\n\r\n    return newAddr\r\n}\r\n\r\nconst validatePostcode = (postcode: string): boolean => {\r\n    if (!postcode || postcode === '') {\r\n        return false\r\n    }\r\n\r\n    const trimmedPostcode = postcode.replace(/\\s/g, '')\r\n    const re =\r\n        /^([Gg][Ii][Rr]\\s?0[Aa]{2})|((([A-Za-z][0-9]{1,2})|(([A-Za-z][A-Ha-hJ-Yj-y][0-9]{1,2})|(([A-Za-z][0-9][A-Za-z])|([A-Za-z][A-Ha-hJ-Yj-y][0-9]?[A-Za-z]))))\\s?[0-9][A-Za-z]{2})$/i\r\n\r\n    return re.test(String(trimmedPostcode))\r\n}\r\n\r\nconst formatPostcode = (postcode: string): string | undefined => {\r\n    if (postcode !== undefined && postcode !== '') {\r\n        const newPostcode = postcode\r\n            .replace(/\\s/g, '')\r\n            .replace(/^(.*)(\\d)/, '$1 $2')\r\n\r\n        return newPostcode\r\n    } else return undefined\r\n}\r\n\r\ninterface IAddressEditProps {\r\n    setManualInput: React.Dispatch<React.SetStateAction<boolean>>\r\n    manualInput: boolean\r\n    handleAddAddress: () => void\r\n    handleAddAddressClose: () => void\r\n    jwt: string\r\n}\r\n\r\nconst AddressEdit: React.FC<IAddressEditProps> = ({\r\n    setManualInput,\r\n    manualInput,\r\n    handleAddAddress,\r\n    handleAddAddressClose,\r\n    jwt,\r\n}: IAddressEditProps): JSX.Element => {\r\n    const [address, setAddress] = useState<IAddressDetails>(\r\n        {} as IAddressDetails\r\n    )\r\n    const [sendManual, setSendManual] = useState<boolean>(false)\r\n    const [errorShow, setErrorShow] = useState<boolean>(false)\r\n    const [hasError, setHasError] = useState<IAddresErrorStateObj>({\r\n        line1: true,\r\n        townOrCity: true,\r\n        postcode: true,\r\n    })\r\n\r\n    const onAddressChange = (\r\n        e: React.ChangeEvent<HTMLInputElement>,\r\n        key: string\r\n    ): void => {\r\n        setSendManual(true)\r\n\r\n        if (\r\n            e.target.value === '' &&\r\n            hasError[key as keyof IAddresErrorStateObj]\r\n        ) {\r\n            setHasError({ ...hasError, [key]: true })\r\n        } else if (hasError[key as keyof IAddresErrorStateObj]) {\r\n            setHasError({ ...hasError, [key]: false })\r\n        }\r\n\r\n        setAddress((address) => ({\r\n            ...address,\r\n            [key]: capitalizeName(e.target.value),\r\n        }))\r\n\r\n        if (key === 'postcode') {\r\n            if (validatePostcode(e.target.value) === false) {\r\n                setHasError({ ...hasError, [key]: true })\r\n            } else {\r\n                setHasError({ ...hasError, [key]: false })\r\n            }\r\n        }\r\n    }\r\n\r\n    const saveAddress = (): void => {\r\n        setErrorShow(true)\r\n\r\n        if (sendManual) {\r\n            if (Object.values(hasError).every((v) => v === true)) {\r\n                return\r\n            }\r\n        }\r\n\r\n        let shippingAddress\r\n\r\n        if (!sendManual) {\r\n            shippingAddress = {\r\n                address: {\r\n                    ...address,\r\n                },\r\n                jwt: jwt,\r\n            }\r\n        } else {\r\n            shippingAddress = {\r\n                address: {\r\n                    ...address,\r\n                    postcode: formatPostcode(address.postcode),\r\n                    countryId: 'GB', // check this....\r\n                    addressType: 1,\r\n                    isPrimary: true,\r\n                },\r\n                jwt: jwt,\r\n            } as INewAddressRequest\r\n        }\r\n\r\n        AccountAPI.setNewAddress(shippingAddress).then(() => {\r\n            handleAddAddressClose()\r\n            handleAddAddress()\r\n        })\r\n    }\r\n\r\n    const onAddAddressClose = (): void => {\r\n        handleAddAddressClose()\r\n    }\r\n\r\n    return (\r\n        <div className=\"AddressEdit__contain\">\r\n            <div className=\"AddressEdit\">\r\n                <div onClick={onAddAddressClose} className=\"AddressEdit__close\">\r\n                    <button id=\"editAddressClose\" className=\"navBar__close\">\r\n                        <svg\r\n                            xmlns=\"http://www.w3.org/2000/svg\"\r\n                            viewBox=\"0 0 21 21\"\r\n                        >\r\n                            <path\r\n                                d=\"M17.6 2.7l.7.7c.4.4.4 1 0 1.4l-5.7 5.7 5.7 5.7c.4.4.4 1 0 1.4l-.7.7c-.4.4-1 .4-1.4 0l-5.7-5.7-5.7 5.7c-.4.4-1 .4-1.4 0l-.7-.7c-.4-.4-.4-1 0-1.4l5.7-5.7-5.7-5.7c-.4-.4-.4-1 0-1.4l.7-.7c.4-.4 1-.4 1.4 0l5.7 5.7 5.7-5.7c.3-.4 1-.4 1.4 0z\"\r\n                                fillRule=\"evenodd\"\r\n                                clipRule=\"evenodd\"\r\n                            />\r\n                        </svg>\r\n                    </button>\r\n                </div>\r\n                <div>\r\n                    <div className=\"editAddress__billTitle\">\r\n                        <h2>Shipping address</h2>\r\n                    </div>\r\n                    {manualInput ? (\r\n                        <motion.div\r\n                            initial=\"initial\"\r\n                            animate=\"in\"\r\n                            exit=\"out\"\r\n                            variants={showVariants}\r\n                            className=\"editAddress__showInputs\"\r\n                        >\r\n                            <button\r\n                                type=\"button\"\r\n                                id=\"useAddressFinder\"\r\n                                onClick={(e) => {\r\n                                    e.preventDefault()\r\n                                    setManualInput(false)\r\n                                }}\r\n                                className=\"btn editAddress__manualBtn\"\r\n                            >\r\n                                Use address finder\r\n                            </button>\r\n\r\n                            <div>\r\n                                <AddressEditInputs\r\n                                    address={address}\r\n                                    handleChangeAddress={onAddressChange}\r\n                                    valueKey=\"line1\"\r\n                                    label=\"Address line 1*\"\r\n                                    required={true}\r\n                                    hasError={hasError}\r\n                                    errorShow={errorShow}\r\n                                />\r\n                            </div>\r\n                            <AddressEditInputs\r\n                                address={address}\r\n                                handleChangeAddress={onAddressChange}\r\n                                valueKey=\"line2\"\r\n                                label=\"Address line 2\"\r\n                                required={false}\r\n                            />\r\n                            <AddressEditInputs\r\n                                address={address}\r\n                                handleChangeAddress={onAddressChange}\r\n                                valueKey=\"line3\"\r\n                                label=\"Address line 3\"\r\n                                required={true}\r\n                            />\r\n                            <AddressEditInputs\r\n                                address={address}\r\n                                handleChangeAddress={onAddressChange}\r\n                                valueKey=\"townOrCity\"\r\n                                label=\"City*\"\r\n                                required={true}\r\n                                hasError={hasError}\r\n                                errorShow={errorShow}\r\n                            />\r\n                            <AddressEditInputs\r\n                                address={address}\r\n                                handleChangeAddress={onAddressChange}\r\n                                valueKey=\"county\"\r\n                                label=\"County\"\r\n                                required={true}\r\n                            />\r\n                            <AddressEditInputs\r\n                                address={address}\r\n                                handleChangeAddress={onAddressChange}\r\n                                valueKey=\"postcode\"\r\n                                label=\"Post code*\"\r\n                                required={true}\r\n                                hasError={hasError}\r\n                                errorShow={errorShow}\r\n                            />\r\n                            <div className=\"editAddress__input\">\r\n                                <div className=\"input-container\">\r\n                                    <label className=\"inputTitle\">\r\n                                        Country\r\n                                    </label>\r\n                                    <input\r\n                                        disabled\r\n                                        value=\"United Kingdom\"\r\n                                        className=\"input\"\r\n                                        type=\"text\"\r\n                                    />\r\n                                </div>\r\n                            </div>\r\n                        </motion.div>\r\n                    ) : (\r\n                        <>\r\n                            <NewAddressFinder\r\n                                setManual={setManualInput}\r\n                                setAddress={setAddress}\r\n                                queryType=\"shippingAddress\"\r\n                                setSendManual={setSendManual}\r\n                            />\r\n                            <button\r\n                                type=\"button\"\r\n                                id=\"useManualAddress\"\r\n                                onClick={() => {\r\n                                    setManualInput(true)\r\n                                    setAddress({} as IAddressObj)\r\n                                }}\r\n                                className=\"btn editAddress__manualBtn\"\r\n                            >\r\n                                Enter address manually\r\n                            </button>\r\n                        </>\r\n                    )}\r\n\r\n                    <div className=\"mt-30\">\r\n                        <button\r\n                            id=\"saveAddress\"\r\n                            onClick={saveAddress}\r\n                            className=\"btn primary-btn btn-shorter btn-large\"\r\n                        >\r\n                            Save address\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default AddressEdit\r\n","import React, { useEffect, useState } from 'react'\r\nimport AccountAPI from '../../../../axios/AccountAPI'\r\nimport './Pages.css'\r\nimport API from '../../../../axios/API'\r\nimport { TrashCan } from '../../../../assets/svg/Svg-Exports'\r\nimport {\r\n    IQuestion,\r\n    IQuestionValues,\r\n    IUserAddress,\r\n} from '../../../../interfaces/interfaces'\r\nimport { useAppSelector } from '../../../../redux/store'\r\nimport AddressEdit, {\r\n    arrangedAddress,\r\n} from '../../Features/AddressEdit/AddressEdit'\r\n\r\nimport { cloneObj } from '../../../../Helpers/utils'\r\n\r\ninterface IAddressPageProps {\r\n    jwt: string\r\n    deliveryQuestion: IQuestion\r\n    handlePages: (error?: string) => void\r\n}\r\n\r\nconst getAddresses = async (jwt: string): Promise<IUserAddress[]> => {\r\n    const addr = await AccountAPI.getAddresses(jwt).then((data) => {\r\n        return data.addresses\r\n    })\r\n\r\n    return addr\r\n}\r\n\r\nconst AddressPage: React.FC<IAddressPageProps> = ({\r\n    jwt,\r\n    deliveryQuestion,\r\n    handlePages,\r\n}: IAddressPageProps): JSX.Element => {\r\n    const bookingObj = useAppSelector((state) => state.tickets.bookingObject)\r\n    const [addresses, setAddresses] = useState<IUserAddress[]>([])\r\n    const [allowContinue, setAllowContinue] = useState<boolean>(false)\r\n    const [answer, setAnswer] = useState<IQuestionValues | undefined>(undefined)\r\n    const [manualInput, setManualInput] = useState<boolean>(false)\r\n    const [showAddAddress, setShowAddAddress] = useState<boolean>(false)\r\n    const [showQuestion, setShowQuestion] = useState<boolean>(false)\r\n\r\n    const question = bookingObj.reserveResponse?.deliveryQuestion\r\n\r\n    const saveAddresstoDB = async (\r\n        answerVar?: IQuestionValues\r\n    ): Promise<void> => {\r\n        await API.sendDeliveryInfo(\r\n            bookingObj,\r\n            jwt,\r\n            deliveryQuestion.externalId,\r\n            answerVar\r\n        ).then((response) => {\r\n            if (!response.success) {\r\n                handlePages(response.friendlyErrorMessage)\r\n            } else {\r\n                handlePages()\r\n            }\r\n        })\r\n    }\r\n\r\n    const handleContinueClick = (receivedAnswer?: IQuestionValues): void => {\r\n        const answerVar = receivedAnswer ? receivedAnswer : answer\r\n        void saveAddresstoDB(answerVar)\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (deliveryQuestion.values.length === 1) {\r\n            handleSingleSelect()\r\n        } else {\r\n            setShowQuestion(true)\r\n        }\r\n    }, [deliveryQuestion])\r\n\r\n    const handleSingleSelect = (\r\n        e?: React.ChangeEvent<HTMLSelectElement>\r\n    ): void => {\r\n        const selectedVal = e ? parseInt(e.target.value) : undefined\r\n\r\n        if (!selectedVal) {\r\n            if (question) {\r\n                setAnswer(question.values[0])\r\n\r\n                if (question.values[0].captureAddress === false) {\r\n                    handleContinueClick(question.values[0])\r\n                }\r\n            }\r\n        } else {\r\n            if (question) {\r\n                setAnswer(question.values[selectedVal])\r\n\r\n                if (!question.values[selectedVal].captureAddress) {\r\n                    setAllowContinue(true)\r\n                } else {\r\n                    if (addresses.filter((address) => address.isPrimary)[0]) {\r\n                        setAllowContinue(true)\r\n                    } else {\r\n                        setAllowContinue(false)\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (jwt) {\r\n            getAddresses(jwt).then((a) => setAddresses(a))\r\n        }\r\n    }, [])\r\n\r\n    const onDeleteClick = (\r\n        e: React.MouseEvent<HTMLButtonElement>,\r\n        address: IUserAddress,\r\n        i: number\r\n    ): void => {\r\n        e.stopPropagation()\r\n        const tempAddresses = cloneObj(addresses)\r\n        tempAddresses.splice(i, 1)\r\n        setAddresses(tempAddresses)\r\n        AccountAPI.deleteAddress(address.addressId, jwt).then((response) => {\r\n            if (response.data.success) {\r\n                console.log('address successfully removed')\r\n            } else {\r\n                console.error(response.data.friendlyErrorMessage)\r\n            }\r\n        })\r\n    }\r\n\r\n    const onAddressAdd = (): void => {\r\n        setShowAddAddress(true)\r\n    }\r\n\r\n    const handleAddAddressClose = (): void => {\r\n        setShowAddAddress(false)\r\n    }\r\n\r\n    const handleAddAddress = (): void => {\r\n        if (jwt) {\r\n            getAddresses(jwt).then((a) => setAddresses(a))\r\n        }\r\n\r\n        setAllowContinue(true)\r\n    }\r\n\r\n    const handleAddressClick = (\r\n        e: React.MouseEvent<HTMLDivElement>,\r\n        address: IUserAddress,\r\n        i: number\r\n    ): void => {\r\n        e.stopPropagation()\r\n\r\n        const tempAddresses = cloneObj(addresses)\r\n\r\n        tempAddresses.forEach(function (key, index) {\r\n            tempAddresses[index].isPrimary = false\r\n        })\r\n\r\n        tempAddresses[i].isPrimary = true\r\n        setAddresses(tempAddresses)\r\n        AccountAPI.makePrimary(address.addressId, 1, jwt)\r\n\r\n        setAllowContinue(true)\r\n    }\r\n\r\n    return (\r\n        <>\r\n            {deliveryQuestion.values && deliveryQuestion.values.length > 1 && (\r\n                <div className=\"Page\">\r\n                    <h1>Address options</h1>\r\n                    {deliveryQuestion && showQuestion && (\r\n                        <>\r\n                            <div className=\"questionColumn AddressPage__question selectArea\">\r\n                                <label className=\"questionText\">\r\n                                    {deliveryQuestion.questionTitle}\r\n                                </label>\r\n                                <select\r\n                                    className=\"input selectBackground questionSelectArea\"\r\n                                    onChange={handleSingleSelect}\r\n                                >\r\n                                    <option key={0} value={99}>\r\n                                        Please select an option\r\n                                    </option>\r\n                                    {deliveryQuestion.values.map(\r\n                                        (option, i) => (\r\n                                            <option\r\n                                                key={option.id + 1}\r\n                                                value={i}\r\n                                            >\r\n                                                {option.option}\r\n                                            </option>\r\n                                        )\r\n                                    )}\r\n                                </select>\r\n                            </div>\r\n                            {answer && answer.option && (\r\n                                <div className=\"AddressPage__selected\">\r\n                                    <h2>Selected: {answer.option}</h2>\r\n                                </div>\r\n                            )}\r\n                        </>\r\n                    )}\r\n                    {((answer &&\r\n                        answer.option &&\r\n                        answer.captureAddress === true) ||\r\n                        !deliveryQuestion) && (\r\n                        <>\r\n                            {addresses\r\n                                .sort((first) => {\r\n                                    return !first.isPrimary ? 1 : -1\r\n                                })\r\n                                .map((address, i) => (\r\n                                    <div key={i}>\r\n                                        {address.addressType === 1 && (\r\n                                            <div\r\n                                                onClick={(e) =>\r\n                                                    handleAddressClick(\r\n                                                        e,\r\n                                                        address,\r\n                                                        i\r\n                                                    )\r\n                                                }\r\n                                                className={`AddressPage__Card ${address.isPrimary ? 'AddressPage__primary' : ''}`}\r\n                                            >\r\n                                                {!address.isPrimary && (\r\n                                                    <div className=\"AddressPage__icons\">\r\n                                                        <button\r\n                                                            id=\"deleteShippingAddress\"\r\n                                                            className=\"btn AddressPage__iconButton AddressPage__deleteButton iconOff\"\r\n                                                            onClick={(e) =>\r\n                                                                onDeleteClick(\r\n                                                                    e,\r\n                                                                    address,\r\n                                                                    i\r\n                                                                )\r\n                                                            }\r\n                                                        >\r\n                                                            <TrashCan />\r\n                                                        </button>\r\n                                                    </div>\r\n                                                )}\r\n\r\n                                                {\r\n                                                    <span>\r\n                                                        {arrangedAddress(\r\n                                                            address\r\n                                                        )}\r\n                                                    </span>\r\n                                                }\r\n                                            </div>\r\n                                        )}\r\n                                    </div>\r\n                                ))}\r\n                            <div className=\"mt-30\">\r\n                                <button\r\n                                    id=\"addShippingAddress\"\r\n                                    onClick={onAddressAdd}\r\n                                    className=\"btn primary-btn-white btn-shorter btn-large\"\r\n                                >\r\n                                    Add address\r\n                                </button>\r\n                            </div>\r\n                            {showAddAddress && (\r\n                                <div className=\"AddressPage__addressEdit\">\r\n                                    <AddressEdit\r\n                                        setManualInput={setManualInput}\r\n                                        manualInput={manualInput}\r\n                                        handleAddAddress={handleAddAddress}\r\n                                        handleAddAddressClose={\r\n                                            handleAddAddressClose\r\n                                        }\r\n                                        // setAllowContinue={setAllowContinue}\r\n                                        jwt={jwt}\r\n                                    />\r\n                                </div>\r\n                            )}\r\n                        </>\r\n                    )}\r\n                    {allowContinue ? (\r\n                        <div className=\"mt-30 confirmation__button\">\r\n                            <button\r\n                                id=\"addressPageContinue\"\r\n                                onClick={() => handleContinueClick()}\r\n                                className=\"btn primary-btn btn-shorter btn-large btn-border text-pop\"\r\n                            >\r\n                                Continue\r\n                            </button>\r\n                        </div>\r\n                    ) : (\r\n                        <div className=\"mt-30 confirmation__button\">\r\n                            <button className=\"btn primary-btn-disabled btn-large btn-shorter btn-border text-pop\">\r\n                                Continue\r\n                            </button>\r\n                        </div>\r\n                    )}\r\n                </div>\r\n            )}\r\n        </>\r\n    )\r\n}\r\n\r\nexport default AddressPage\r\n","import React, { useEffect, useState } from 'react'\r\nimport './Pages.css'\r\nimport { IReservationNote, Pages } from '../../../../interfaces/interfaces'\r\nimport { currencyFormat } from '../../../../Helpers/utils'\r\n\r\ninterface IImportantInformationProps {\r\n    reservationNote: IReservationNote\r\n    selectPage: (pageNumber: number, data: IReservationNote) => void\r\n}\r\n\r\ninterface ITextObj {\r\n    title: string\r\n    text: string | ITextObj[]\r\n}\r\n\r\nconst ImportantInformation: React.FC<IImportantInformationProps> = ({\r\n    reservationNote,\r\n    selectPage,\r\n}: IImportantInformationProps): JSX.Element => {\r\n    const [text, setText] = useState<ITextObj[]>([])\r\n\r\n    useEffect(() => {\r\n        if (\r\n            !reservationNote.importantInformation.alternativeSeating &&\r\n            !reservationNote.importantInformation.message\r\n        ) {\r\n            selectPage(Pages.ImportantInformation, reservationNote)\r\n        }\r\n\r\n        const tempWorks = [] as ITextObj[]\r\n\r\n        if (reservationNote.importantInformation.message) {\r\n            reservationNote.importantInformation.message.forEach((msg) => {\r\n                const parsed = [] as ITextObj[]\r\n\r\n                if (msg.text.includes('[{')) {\r\n                    const parsedTxt = JSON.parse(msg.text)\r\n\r\n                    for (let i = 0; i < parsed.length; i++) {\r\n                        parsed[i].text = parsedTxt[i].text\r\n                            .replaceAll('<li>', '')\r\n                            .replaceAll('</li>', '')\r\n                            .split('|')\r\n                        parsed[i].title = parsedTxt[i].title\r\n                    }\r\n                } else {\r\n                    parsed[0] = { text: msg.text, title: msg.title }\r\n                }\r\n\r\n                tempWorks.push({\r\n                    title: msg.title,\r\n                    text: parsed,\r\n                })\r\n            })\r\n        }\r\n\r\n        setText(tempWorks)\r\n    }, [])\r\n\r\n    return (\r\n        <div className=\"ImportantInformation\">\r\n            <h2>Important Information</h2>\r\n            <div className=\"ImportantInformation__messages\">\r\n                {reservationNote.importantInformation.alternativeSeating &&\r\n                    reservationNote.importantInformation.alternativeSeating\r\n                        .length > 0 && (\r\n                        <>\r\n                            <h3>\r\n                                {`Due to high demand we can’t always guarantee you’ll get your\r\n                            chosen seats, but not to worry, you’re sure to get the next best\r\n                            available!`}\r\n                            </h3>\r\n                            <h3>Check your seats below.</h3>\r\n                        </>\r\n                    )}\r\n                {reservationNote.importantInformation.alternativeSeating &&\r\n                    reservationNote.importantInformation.alternativeSeating.map(\r\n                        (message, i) => (\r\n                            <div key={i}>\r\n                                <div className=\"ImportantInformation__seats\">\r\n                                    <span>{message.rowId}</span>\r\n                                    <span>\r\n                                        {currencyFormat(message.pricePennies)}\r\n                                    </span>\r\n                                </div>\r\n                                <span>\r\n                                    {message.specialInfo && (\r\n                                        <>{message.specialInfo}</>\r\n                                    )}\r\n                                </span>\r\n                                <span>\r\n                                    {message.restrictedView && (\r\n                                        <>This has a restricted view</>\r\n                                    )}\r\n                                </span>\r\n                            </div>\r\n                        )\r\n                    )}\r\n            </div>\r\n            <div className=\"ImportantInformation__messages\">\r\n                {text &&\r\n                    text.map((section, i) => {\r\n                        return (\r\n                            <div key={i}>\r\n                                <h2>{section.title}</h2>\r\n\r\n                                {typeof section.text === 'string' ? (\r\n                                    <>{section.text}</>\r\n                                ) : (\r\n                                    <>\r\n                                        {section.text.map(\r\n                                            (subSection, index) => {\r\n                                                return (\r\n                                                    <div key={index}>\r\n                                                        <h3>\r\n                                                            {subSection.title}\r\n                                                        </h3>\r\n\r\n                                                        {typeof subSection.text ===\r\n                                                        'string' ? (\r\n                                                            <>\r\n                                                                {\r\n                                                                    subSection.text\r\n                                                                }\r\n                                                            </>\r\n                                                        ) : (\r\n                                                            <>\r\n                                                                {\r\n                                                                    subSection\r\n                                                                        .text[0]\r\n                                                                }\r\n                                                                {subSection.text.map(\r\n                                                                    (\r\n                                                                        sectionText,\r\n                                                                        i\r\n                                                                    ) => {\r\n                                                                        if (\r\n                                                                            i ===\r\n                                                                            0\r\n                                                                        ) {\r\n                                                                            return false\r\n                                                                        }\r\n\r\n                                                                        typeof sectionText.text ===\r\n                                                                            'string' && (\r\n                                                                            <li\r\n                                                                                key={\r\n                                                                                    i\r\n                                                                                }\r\n                                                                            >\r\n                                                                                {\r\n                                                                                    sectionText.text\r\n                                                                                }\r\n                                                                            </li>\r\n                                                                        )\r\n                                                                    }\r\n                                                                )}\r\n                                                            </>\r\n                                                        )}\r\n                                                    </div>\r\n                                                )\r\n                                            }\r\n                                        )}\r\n                                    </>\r\n                                )}\r\n                            </div>\r\n                        )\r\n                    })}\r\n            </div>\r\n            <div className=\"mt-30 confirmation__button\">\r\n                <button\r\n                    id=\"ImportantInformationContinue\"\r\n                    onClick={() =>\r\n                        selectPage(Pages.ImportantInformation, reservationNote)\r\n                    }\r\n                    className=\"btn primary-btn btn-shorter btn-large btn-border text-pop\"\r\n                >\r\n                    Continue\r\n                </button>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default ImportantInformation\r\n","import React from 'react'\r\nimport './Pages.css'\r\nimport { setBookingProtect } from '../../../../redux/ticketSlice'\r\nimport { Tick } from '../../../../assets/svg/Svg-Exports'\r\n// import trustpilotLogo from '../../../../assets/images/XCoverTrustpilot.png'\r\nimport { IBookingProtection, Pages } from '../../../../interfaces/interfaces'\r\nimport { useAppDispatch } from '../../../../redux/store'\r\n\r\ninterface IBookingProtectProps {\r\n    bp: IBookingProtection\r\n    selectPage: (val: number) => void\r\n}\r\n\r\nconst BookingProtect: React.FC<IBookingProtectProps> = ({\r\n    bp,\r\n    selectPage,\r\n}: IBookingProtectProps): JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n\r\n    const changePage = (bookingProtectEnabled: boolean = false): void => {\r\n        if (bookingProtectEnabled) {\r\n            window.dataLayer.push({ ecommerce: undefined })\r\n            window.dataLayer.push({\r\n                event: 'add__booking__protect',\r\n                eventProps: {\r\n                    category: 'Booking',\r\n                    action: 'AddBookingProtect',\r\n                },\r\n                ecommerce: {\r\n                    currency: 'GBP',\r\n                    value: bp.premium / 100,\r\n                    items: [\r\n                        {\r\n                            item_name: 'Booking Refund Protection',\r\n                            item_brand: 'XCover',\r\n                            item_category: 'Charges',\r\n                            price: bp.premium / 100,\r\n                            quantity: 1,\r\n                        },\r\n                    ],\r\n                },\r\n            })\r\n        }\r\n\r\n        selectPage(Pages.Summary)\r\n    }\r\n\r\n    const changeSelection = (isProtected: boolean): void => {\r\n        dispatch(setBookingProtect(isProtected))\r\n        changePage(isProtected)\r\n    }\r\n\r\n    return (\r\n        <div className=\"Pages\">\r\n            <div className=\"TicketInsurance__header\">\r\n                <h3>\r\n                    You could lose money if your tickets aren’t protected...\r\n                </h3>\r\n            </div>\r\n            <p className=\"TicketInsurance__sales-intro\">\r\n                Many of our partner attractions{' '}\r\n                <strong>do not give refunds</strong> for{' '}\r\n                <strong>any reason</strong>.\r\n            </p>\r\n            <p className=\"TicketInsurance__sales-intro\">\r\n                For <strong>just &pound;{(bp.premium / 100).toFixed(2)}</strong>{' '}\r\n                you can protect your tickets in case of the unexpected.\r\n            </p>\r\n            <p className=\"TicketInsurance__sales-intro\">\r\n                {`With our award-winning partner XCover, you'll be covered against:`}\r\n            </p>\r\n            <span className=\"TicketInsurance__card-details\">\r\n                <Tick />\r\n                <p>Injury or illness (e.g. COVID-19)</p>\r\n            </span>\r\n            <span className=\"TicketInsurance__card-details\">\r\n                <Tick />\r\n                <p>{`Injury or illness of you/your ticketholder's close relatives (e.g. COVID-19)`}</p>\r\n            </span>\r\n            <span className=\"TicketInsurance__card-details\">\r\n                <Tick />\r\n                <p>\r\n                    Accidents, jury duty, military service and other unforeseen\r\n                    events\r\n                </p>\r\n            </span>\r\n            <div className=\"TicketInsurance__Logo\">\r\n                <a\r\n                    className=\"link\"\r\n                    href={bp.termsAndConditionsUrl}\r\n                    target=\"_blank\"\r\n                    rel=\"noopener noreferrer\"\r\n                >\r\n                    View more info on\r\n                    <img src={bp.logoUrl} alt=\"XCover logo\" />\r\n                </a>\r\n                {/*<img*/}\r\n                {/*    alt=\"Trustpilot Logo\"*/}\r\n                {/*    className=\"TicketInsurance__ReviewsLogo\"*/}\r\n                {/*    src={trustpilotLogo}*/}\r\n                {/*/>*/}\r\n            </div>\r\n            <div className=\"TicketInsurance__body\">\r\n                <p>\r\n                    We <strong>strongly recommend</strong> you protect your\r\n                    tickets.\r\n                </p>\r\n                <button\r\n                    className=\"TicketInsurance__card protected\"\r\n                    id=\"refundable\"\r\n                    onClick={() => changeSelection(true)}\r\n                >\r\n                    Protect your ticket(s)\r\n                </button>\r\n                <button\r\n                    className=\"TicketInsurance__card not_protected\"\r\n                    id=\"nonRefundable\"\r\n                    onClick={() => changeSelection(false)}\r\n                >\r\n                    I understand the risk, continue without protection\r\n                </button>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default BookingProtect\r\n","import React, { useEffect, useState } from 'react'\r\nimport {\r\n    addToOrderAnswers,\r\n    addToTicketAnswers,\r\n    setOrderAnswers,\r\n    setTicketAnswers,\r\n} from '../../../../redux/ticketSlice'\r\nimport { isValid } from 'date-fns'\r\nimport { IAnswer, IQuestion } from '../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\nimport { cloneObj, formatDate } from '../../../../Helpers/utils'\r\n\r\ninterface IQuestionsProps {\r\n    question: IQuestion\r\n    type: string\r\n    showErrors: boolean\r\n    handleNeedsAnswer: (\r\n        questionId: string,\r\n        type: string,\r\n        value: boolean\r\n    ) => void\r\n}\r\n\r\nconst Questions: React.FC<IQuestionsProps> = ({\r\n    question,\r\n    type,\r\n    showErrors,\r\n    handleNeedsAnswer,\r\n}: IQuestionsProps): JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n    const bookingObject = useAppSelector((state) => state.tickets.bookingObject)\r\n    const [checked, setChecked] = useState<boolean>(false)\r\n    const [amount, setAmount] = useState<number | undefined>(undefined)\r\n\r\n    const setAnswers = (answer: IAnswer): void => {\r\n        if (type === 'order') {\r\n            const orderAnswers = cloneObj(bookingObject.extraPages.orderAnswers)\r\n            let orderFound = -1\r\n\r\n            if (orderAnswers && orderAnswers.length > 0) {\r\n                orderFound = orderAnswers.findIndex(\r\n                    (order) => order.externalId === question.externalId\r\n                )\r\n            }\r\n\r\n            if (orderFound === -1) {\r\n                orderAnswers.push(answer)\r\n            } else {\r\n                orderAnswers[orderFound] = answer\r\n            }\r\n\r\n            dispatch(setOrderAnswers(orderAnswers))\r\n        } else {\r\n            const questionAnswers = cloneObj(\r\n                bookingObject.extraPages.ticketAnswers\r\n            )\r\n            // answer.id = index;\r\n            //Update the object of the changed field\r\n            //groupName is used in the conditional as groupId can still be the same accross different tickets eg Adult 1 and Child 1\r\n            //questionTitle is used to differentiate what field is updated in the group\r\n\r\n            const answerFound = questionAnswers.findIndex(\r\n                (a) =>\r\n                    a.groupId === question.groupId &&\r\n                    a.groupName === question.groupName &&\r\n                    a.externalId === question.externalId &&\r\n                    a.questionType === question.questionType\r\n            )\r\n\r\n            if (answerFound === -1) {\r\n                questionAnswers.push(answer)\r\n            } else {\r\n                questionAnswers[answerFound] = cloneObj(answer)\r\n            }\r\n\r\n            dispatch(setTicketAnswers(questionAnswers))\r\n        }\r\n    }\r\n\r\n    const createAnswerObj = (value: string | number): IAnswer => {\r\n        const answer = {\r\n            externalId: question.externalId,\r\n            questionType: question.questionType,\r\n            value: value,\r\n        } as IAnswer\r\n\r\n        if (question.hasAdditionalPrice) {\r\n            answer.hasAdditionalPrice = question.hasAdditionalPrice\r\n            answer.additionalPrice = question.additionalPrice\r\n        }\r\n\r\n        if (type === 'ticket') {\r\n            answer.groupName = question.groupName\r\n            answer.groupId = question.groupId\r\n        }\r\n\r\n        return answer\r\n    }\r\n\r\n    useEffect(() => {\r\n        let answer\r\n\r\n        switch (question.questionType) {\r\n            case 1:\r\n                const value = checked\r\n                    ? question.values[0].id\r\n                    : question.values[1].id\r\n                answer = createAnswerObj(value)\r\n                break\r\n            case 2:\r\n            case 3:\r\n            case 4:\r\n            case 5:\r\n            case 6:\r\n                answer = createAnswerObj('')\r\n                break\r\n            case 7:\r\n                answer = createAnswerObj('0')\r\n                break\r\n            default:\r\n                return\r\n        }\r\n\r\n        if (type === 'order') {\r\n            dispatch(addToOrderAnswers(answer))\r\n        } else {\r\n            dispatch(addToTicketAnswers(answer))\r\n        }\r\n    }, [])\r\n\r\n    const handleChecked = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        let answer\r\n\r\n        if (!checked && e.target.checked) {\r\n            setChecked(true)\r\n\r\n            handleNeedsAnswer(question.externalId, type, false)\r\n            answer = createAnswerObj(question.values[0].id)\r\n        } else {\r\n            if (question.required) {\r\n                handleNeedsAnswer(question.externalId, type, true)\r\n            }\r\n\r\n            setChecked(false)\r\n            answer = createAnswerObj(question.values[1].id)\r\n        }\r\n\r\n        setAnswers(answer)\r\n    }\r\n\r\n    const handleTextArea = (\r\n        e: React.ChangeEvent<HTMLTextAreaElement>\r\n    ): void => {\r\n        if (e.target.value.length < 1) {\r\n            if (question.required) {\r\n                handleNeedsAnswer(question.externalId, type, true)\r\n            }\r\n        } else {\r\n            handleNeedsAnswer(question.externalId, type, false)\r\n        }\r\n\r\n        const answer = createAnswerObj(e.target.value)\r\n        setAnswers(answer)\r\n    }\r\n\r\n    const handleInputTextChange = (\r\n        e: React.ChangeEvent<HTMLInputElement>\r\n    ): void => {\r\n        if (e.target.value !== '') {\r\n            const answer = createAnswerObj(e.target.value)\r\n            setAnswers(answer)\r\n\r\n            if (question.required) {\r\n                handleNeedsAnswer(question.externalId, type, false)\r\n            }\r\n        }\r\n    }\r\n\r\n    const handleIntChange = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        const num = e.target.value === '' ? '0' : e.target.value\r\n\r\n        if (question.required) {\r\n            handleNeedsAnswer(question.externalId, type, false)\r\n        }\r\n\r\n        const answer = createAnswerObj(num)\r\n        setAmount(Number(num))\r\n        setAnswers(answer)\r\n    }\r\n\r\n    const handleDateChange = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        const { value } = e.target\r\n        const date = new Date(value)\r\n        const isDateValid = isValid(date)\r\n\r\n        handleNeedsAnswer(question.externalId, type, false)\r\n\r\n        if (question.required || value.length > 0) {\r\n            if (!isDateValid) {\r\n                handleNeedsAnswer(question.externalId, type, true)\r\n            }\r\n        }\r\n\r\n        const dateFormatted = formatDate(date)\r\n\r\n        const answer = createAnswerObj(isDateValid ? dateFormatted : '')\r\n        setAnswers(answer)\r\n    }\r\n\r\n    const handleSingleSelect = (\r\n        e: React.ChangeEvent<HTMLSelectElement>\r\n    ): void => {\r\n        const ticketAnswers = cloneObj(bookingObject.extraPages.ticketAnswers)\r\n        const orderAnswers = cloneObj(bookingObject.extraPages.orderAnswers)\r\n\r\n        if (e.target.value === 'none') {\r\n            if (question.required) {\r\n                handleNeedsAnswer(question.externalId, type, true)\r\n            }\r\n\r\n            if (type !== 'order') {\r\n                const ticketFound2 = ticketAnswers.findIndex(\r\n                    (ticket) =>\r\n                        ticket.groupId === question.groupId &&\r\n                        ticket.groupName === question.groupName &&\r\n                        ticket.externalId === question.externalId // && answer.questionTitle === question.questionTitle\r\n                )\r\n\r\n                if (ticketFound2 !== -1) {\r\n                    ticketAnswers.splice(ticketFound2, 1)\r\n                }\r\n\r\n                dispatch(setTicketAnswers(ticketAnswers))\r\n            } else {\r\n                const orderFound2 = orderAnswers.findIndex(\r\n                    (order) => order.externalId === question.externalId\r\n                )\r\n\r\n                if (orderFound2 !== -1) {\r\n                    orderAnswers.splice(orderFound2, 1)\r\n                }\r\n\r\n                dispatch(setOrderAnswers(orderAnswers))\r\n            }\r\n\r\n            return\r\n        }\r\n\r\n        if (question.required) {\r\n            handleNeedsAnswer(question.externalId, type, false)\r\n        }\r\n\r\n        const answerVal = parseInt(e.target.value)\r\n\r\n        const answer = createAnswerObj(question.values[answerVal].id)\r\n        setAnswers(answer)\r\n    }\r\n\r\n    const returnInputTypeDetails = (question: IQuestion): JSX.Element => {\r\n        const { hasAdditionalPrice, additionalPrice, priceType } = question\r\n        let totalPrice = 0\r\n        let totalPriceFixed = '0.00'\r\n        let totalPriceStr = ''\r\n        let price = 0\r\n        const quantity = amount ?? 0\r\n\r\n        if (hasAdditionalPrice && additionalPrice && additionalPrice !== 0) {\r\n            price = additionalPrice\r\n\r\n            if (priceType === 1) {\r\n                price /= 100\r\n\r\n                totalPrice = price * quantity\r\n                totalPriceFixed = totalPrice.toFixed(2)\r\n                totalPriceStr = '£' + totalPriceFixed\r\n            } else {\r\n                totalPrice = price\r\n                totalPriceStr = totalPrice + '%'\r\n            }\r\n        }\r\n\r\n        return (\r\n            <label className=\"questionText\">\r\n                {hasAdditionalPrice && totalPrice !== 0 && (\r\n                    <span className=\"question__totalPrice\">\r\n                        {totalPriceStr}\r\n                    </span>\r\n                )}\r\n                <span>\r\n                    {question.questionTitle}\r\n                    {question.required && <span className=\"text-pop\">*</span>}\r\n                </span>\r\n                {hasAdditionalPrice && priceType === 1 && (\r\n                    <span className=\"question__price\">(£{price})</span>\r\n                )}\r\n\r\n                {question.questionNote && (\r\n                    <div className=\"note\" style={{ whiteSpace: 'pre-wrap' }}>\r\n                        {question.questionNote}\r\n                    </div>\r\n                )}\r\n            </label>\r\n        )\r\n    }\r\n\r\n    const returnInputType = (question: IQuestion): JSX.Element => {\r\n        switch (question.questionType) {\r\n            case 0:\r\n                return (\r\n                    <div className=\"questionColumn\">\r\n                        {returnInputTypeDetails(question)}\r\n                    </div>\r\n                )\r\n            case 1:\r\n                // Checkbox 1 // One answer - e.g: yes/no\r\n                return (\r\n                    <>\r\n                        <div className=\"questionRow\">\r\n                            <label className=\"checkbox\">\r\n                                <span className=\"checkbox__input\">\r\n                                    <input\r\n                                        className=\"checkbox-input\"\r\n                                        type=\"checkbox\"\r\n                                        checked={checked}\r\n                                        onChange={handleChecked}\r\n                                        aria-labelledby=\"checkbox-label\"\r\n                                    />\r\n                                    <input type=\"checkbox\" name=\"checkbox\" />\r\n\r\n                                    <span\r\n                                        className={`checkbox__control ${\r\n                                            question.needsAnAnswer && showErrors\r\n                                                ? 'question__needsAnAnswer'\r\n                                                : ''\r\n                                        }`}\r\n                                    >\r\n                                        <svg\r\n                                            id=\"prefix__Layer_1\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\"\r\n                                            x={0}\r\n                                            y={0}\r\n                                            viewBox=\"0 0 21 21\"\r\n                                            xmlSpace=\"preserve\"\r\n                                        >\r\n                                            <g id=\"prefix__icon_x2F_tick\">\r\n                                                <g id=\"prefix__Mask\">\r\n                                                    <path\r\n                                                        id=\"prefix__path-1_1_\"\r\n                                                        d=\"M7.7 17.7L2 12c-.4-.4-.4-1 0-1.4l.7-.7c.4-.4 1-.4 1.4 0l1.4 1.4c1.2 1.2 3.1 1.2 4.2 0l7.1-7.1c.4-.4 1-.4 1.4 0l.8.8c.4.4.4 1 0 1.4L7.7 17.7z\"\r\n                                                        fill={\r\n                                                            checked\r\n                                                                ? '#2B2D42FF'\r\n                                                                : 'rgba(187,188,194,0.5)'\r\n                                                        }\r\n                                                    />\r\n                                                </g>\r\n                                            </g>\r\n                                        </svg>\r\n                                    </span>\r\n                                </span>\r\n                            </label>\r\n                            {returnInputTypeDetails(question)}\r\n                        </div>\r\n                        {question.isParent && checked && (\r\n                            <div className=\"question__children\">\r\n                                {question.childQuestions.map((child, index) => {\r\n                                    return (\r\n                                        <Questions\r\n                                            key={index}\r\n                                            question={child}\r\n                                            type={type}\r\n                                            showErrors={showErrors}\r\n                                            handleNeedsAnswer={\r\n                                                handleNeedsAnswer\r\n                                            }\r\n                                        />\r\n                                    )\r\n                                })}\r\n                            </div>\r\n                        )}\r\n                    </>\r\n                )\r\n            case 2:\r\n                // DropDownBox 2 // One answer from a list\r\n                return (\r\n                    <div className=\"questionColumn selectArea\">\r\n                        {returnInputTypeDetails(question)}\r\n                        <select\r\n                            className={`input selectBackground questionSelectArea ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                            onChange={handleSingleSelect}\r\n                        >\r\n                            <option key={0} value={'none'}>\r\n                                Please select an option\r\n                            </option>\r\n                            {question.values.map((option, i) => (\r\n                                <option key={option.id + 1} value={i}>\r\n                                    {option.option}\r\n                                </option>\r\n                            ))}\r\n                        </select>\r\n                    </div>\r\n                )\r\n            case 3:\r\n                // MultiSelect 3 // More than one answer from a list\r\n                return (\r\n                    <div className=\"questionColumn selectArea\">\r\n                        {returnInputTypeDetails(question)}\r\n                        <select\r\n                            className={`input questionTextArea ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                            multiple\r\n                        >\r\n                            {question.values.map((option) => (\r\n                                <option key={option.id} value={option.id}>\r\n                                    {option.option}\r\n                                </option>\r\n                            ))}\r\n                        </select>\r\n                    </div>\r\n                )\r\n            case 4:\r\n                // Datepicker 4 // Datepicker\r\n                return (\r\n                    <div className=\"questionColumn\">\r\n                        {returnInputTypeDetails(question)}\r\n                        <input\r\n                            type=\"date\"\r\n                            className={`input questionTextArea ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                            onChange={handleDateChange}\r\n                        />\r\n                    </div>\r\n                )\r\n            case 5:\r\n                // ShortText 5 // TextBox\r\n                return (\r\n                    <div className=\"questionColumn\">\r\n                        {returnInputTypeDetails(question)}\r\n                        <input\r\n                            type=\"text\"\r\n                            className={`input questionTextArea ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                            onChange={handleInputTextChange}\r\n                        />\r\n                    </div>\r\n                )\r\n            case 6:\r\n                // TextArea 6 // TextArea\r\n                return (\r\n                    <div className=\"questionColumn\">\r\n                        {returnInputTypeDetails(question)}\r\n                        <textarea\r\n                            className={`input questionTextArea ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                            onChange={(e) => {\r\n                                handleTextArea(e)\r\n                            }}\r\n                        />\r\n                    </div>\r\n                )\r\n            case 7:\r\n                // Int 7 // Number or Count\r\n                return (\r\n                    <div className=\"questionRow questionRow--spacing\">\r\n                        {returnInputTypeDetails(question)}\r\n\r\n                        <input\r\n                            onChange={handleIntChange}\r\n                            type=\"number\"\r\n                            min={0}\r\n                            placeholder=\"0\"\r\n                            className={`input inputInt ${\r\n                                question.needsAnAnswer && showErrors\r\n                                    ? 'question__needsAnAnswer'\r\n                                    : ''\r\n                            }`}\r\n                        />\r\n                    </div>\r\n                )\r\n            default:\r\n                return <></>\r\n        }\r\n    }\r\n\r\n    return <div className=\"Questions\">{returnInputType(question)}</div>\r\n}\r\n\r\nexport default Questions\r\n","import React, { useEffect, useState } from 'react'\r\nimport Questions from './Questions'\r\nimport {\r\n    IQuestion,\r\n    IReservationNote,\r\n    Pages,\r\n} from '../../../../interfaces/interfaces'\r\n\r\nimport { cloneObj } from '../../../../Helpers/utils'\r\n\r\ninterface IQuestionPageProps {\r\n    selectPage: (pageNumber?: Pages, data?: IReservationNote) => void\r\n    orderQuestionsProp: IQuestion[]\r\n    ticketQuestionsProp: IQuestion[]\r\n}\r\n\r\nconst QuestionsPage: React.FC<IQuestionPageProps> = ({\r\n    selectPage,\r\n    orderQuestionsProp,\r\n    ticketQuestionsProp,\r\n}: IQuestionPageProps): JSX.Element => {\r\n    const [orderQuestions, setOrderQuestions] = useState<IQuestion[]>([])\r\n    const [ticketQuestions, setTicketQuestions] = useState<Array<IQuestion[]>>(\r\n        []\r\n    )\r\n    const [showErrors, setShowErrors] = useState(false)\r\n\r\n    const catalogueRequires = (): void => {\r\n        const findValue =\r\n            orderQuestions.length > 0\r\n                ? orderQuestions.find(\r\n                      (val) => val.required && val.needsAnAnswer\r\n                  )\r\n                : undefined\r\n\r\n        let findTicketValue\r\n\r\n        if (ticketQuestions.length > 0) {\r\n            ticketQuestions.map((questions) => {\r\n                findTicketValue = questions.find(\r\n                    (val) => val.required && val.needsAnAnswer\r\n                )\r\n            })\r\n        }\r\n\r\n        if (orderQuestions.length > 0 && ticketQuestions.length > 0) {\r\n            if (!findValue && !findTicketValue) {\r\n                selectPage(Pages.Summary)\r\n            }\r\n        } else if (orderQuestions.length > 0 && !findValue) {\r\n            selectPage(Pages.Summary)\r\n        } else if (ticketQuestions.length > 0 && !findTicketValue) {\r\n            selectPage(Pages.Summary)\r\n        } else {\r\n            setShowErrors(true)\r\n        }\r\n    }\r\n\r\n    const handleNeedsAnswer = (\r\n        questionId: string,\r\n        type: string,\r\n        value: boolean\r\n    ): void => {\r\n        if (type === 'order') {\r\n            const oQ = cloneObj(orderQuestions)\r\n\r\n            oQ.map((question) => {\r\n                if (question.externalId === questionId) {\r\n                    question.needsAnAnswer = value\r\n                }\r\n            })\r\n\r\n            setOrderQuestions(oQ)\r\n        }\r\n\r\n        if (type === 'ticket') {\r\n            const tQ = cloneObj(ticketQuestions)\r\n\r\n            tQ.map((x) => {\r\n                x.map((question) => {\r\n                    if (question.externalId === questionId) {\r\n                        question.needsAnAnswer = value\r\n                    }\r\n                })\r\n            })\r\n\r\n            setTicketQuestions(tQ)\r\n        }\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (orderQuestionsProp[0]) {\r\n            const oQ = cloneObj(orderQuestionsProp)\r\n\r\n            oQ.map((question) => {\r\n                if (question.required) {\r\n                    question.needsAnAnswer = true\r\n                }\r\n\r\n                if (question.questionType === 1) {\r\n                    question.values[0].checked = false\r\n                    question.values[1].checked = true\r\n                }\r\n            })\r\n            setOrderQuestions(oQ)\r\n        }\r\n\r\n        if (ticketQuestionsProp[0]) {\r\n            const tQ = cloneObj(ticketQuestionsProp)\r\n            //Separate ticket questions into multiple groups based on groupName and groupId - i.e. Adult1/Child2 etc\r\n            const sortedtQ = tQ.reduce<Record<string, IQuestion[]>>(\r\n                (previousQuestion, currentQuestion) => {\r\n                    const index = `${currentQuestion.groupName}${currentQuestion.groupId}`\r\n\r\n                    if (!previousQuestion[index]) {\r\n                        previousQuestion[index] = []\r\n                    }\r\n\r\n                    previousQuestion[index].push(currentQuestion)\r\n\r\n                    return previousQuestion\r\n                },\r\n                {}\r\n            )\r\n\r\n            const sortedArr = Object.values(sortedtQ)\r\n\r\n            sortedArr.map((x) => {\r\n                x.map((question) => {\r\n                    if (question.required) {\r\n                        question.needsAnAnswer = true\r\n                    }\r\n\r\n                    if (question.questionType === 1) {\r\n                        question.values[0].checked = false\r\n                        question.values[1].checked = true\r\n                    }\r\n                })\r\n            })\r\n\r\n            setTicketQuestions(sortedArr)\r\n        }\r\n    }, [])\r\n\r\n    return (\r\n        <div className=\"QuestionsPage\">\r\n            {orderQuestions.length > 0 && (\r\n                <>\r\n                    <h2 className=\"QuestionsPage__h2\">Order questions</h2>\r\n                    {orderQuestions.map((question, index) => {\r\n                        return (\r\n                            <div key={index}>\r\n                                <Questions\r\n                                    question={question}\r\n                                    showErrors={showErrors}\r\n                                    handleNeedsAnswer={handleNeedsAnswer}\r\n                                    type=\"order\"\r\n                                />\r\n                            </div>\r\n                        )\r\n                    })}\r\n                </>\r\n            )}\r\n            {ticketQuestions.length > 0 && (\r\n                <>\r\n                    <h2 className=\"QuestionsPage__h2\">Ticket questions</h2>\r\n                    {ticketQuestions.map((questions, index) => {\r\n                        return (\r\n                            <div key={index}>\r\n                                <div className=\"QuestionsPage__ticketQuestionContain\">\r\n                                    <h3>\r\n                                        {`Ticket type: ${questions[0].friendlyName || questions[0].groupName} ${questions[0].groupId}`}\r\n                                    </h3>\r\n                                    {questions.map((question, index) => {\r\n                                        return (\r\n                                            <Questions\r\n                                                key={index}\r\n                                                question={question}\r\n                                                type=\"ticket\"\r\n                                                showErrors={showErrors}\r\n                                                handleNeedsAnswer={\r\n                                                    handleNeedsAnswer\r\n                                                }\r\n                                            />\r\n                                        )\r\n                                    })}\r\n                                </div>\r\n                            </div>\r\n                        )\r\n                    })}\r\n                </>\r\n            )}\r\n            <div className=\"confirmation__button\">\r\n                <button\r\n                    id=\"questionsPageContinue\"\r\n                    onClick={catalogueRequires}\r\n                    className=\"btn primary-btn btn-shorter btn-large btn-border text-pop\"\r\n                >\r\n                    Continue\r\n                </button>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default QuestionsPage\r\n","import React from 'react'\r\nimport './Pages.css'\r\nimport { IReservationNote, Pages } from '../../../../interfaces/interfaces'\r\n\r\ninterface ITermsAndConditionsProps {\r\n    reservationNote: IReservationNote\r\n    selectPage: (pageNumber: number, data: IReservationNote) => void\r\n}\r\n\r\nconst TermsAndConditions: React.FC<ITermsAndConditionsProps> = ({\r\n    reservationNote,\r\n    selectPage,\r\n}: ITermsAndConditionsProps): JSX.Element => {\r\n    return (\r\n        <div className=\"ImportantInformation\">\r\n            <div className=\"ImportantInformation__messages\">\r\n                {reservationNote.termsAndConditions &&\r\n                    reservationNote.termsAndConditions.map((message, i) => (\r\n                        <div key={i}>\r\n                            <h2>{message.title}</h2>\r\n                            <span>{message.text}</span>\r\n                        </div>\r\n                    ))}\r\n            </div>\r\n            <div className=\"mt-30 confirmation__button\">\r\n                <button\r\n                    onClick={() =>\r\n                        selectPage(Pages.TermsAndConditions, reservationNote)\r\n                    }\r\n                    id=\"termsAndConditionsPage\"\r\n                    className=\"btn primary-btn btn-shorter btn-large btn-border text-pop\"\r\n                >\r\n                    Continue\r\n                </button>\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default TermsAndConditions\r\n","import React from \"react\";\r\n\r\ninterface IExtraError{\r\n    error: string;\r\n}\r\n\r\nconst ExtraError: React.FC<IExtraError> = ({ error }: IExtraError): JSX.Element => {\r\n    \r\n    const handleClick = (): void => {\r\n        const currentPage = window.location.href;\r\n        window.location.href = currentPage;\r\n    };\r\n\r\n    return (\r\n        <div className=\"ExtraError\">\r\n            <h2>{error}</h2>\r\n            <button\r\n                onClick={handleClick}\r\n                id=\"errorHandled\"\r\n                className=\"btn primary-btn-white btn-shorter btn-large btn-border text-pop\"\r\n            >\r\n                Continue\r\n            </button>\r\n        </div>\r\n    );\r\n};\r\n\r\nexport default ExtraError;\r\n","import React, { useEffect, useState } from 'react'\r\nimport { alphaValidator, validateEmail } from '../../Helpers/validators'\r\nimport Loader from '../../Components/Shared/Loader/Loader'\r\nimport { AxiosResponse } from 'axios'\r\nimport { IUserAccountInfo, MessageType } from '../../interfaces/interfaces'\r\nimport Alert from '../../Components/Shared/Alert/Alert'\r\nimport ContactInfo from './AccountInfo/ContactInfo/ContactInfo'\r\nimport AccountAPI from '../../axios/AccountAPI'\r\nimport { useAppSelector } from '../../redux/store'\r\nimport { isPhoneValid } from '../../Components/AccountScreens/FormInputs/PhoneFormField/PhoneFormField'\r\n\r\nexport interface IAccountDataMissingProps {\r\n    handleSave: () => void\r\n    retrievedJwt: string\r\n}\r\n\r\nexport interface IEditedContactDetails {\r\n    firstName?: boolean\r\n    lastName?: boolean\r\n    phone?: boolean\r\n    email?: boolean\r\n}\r\n\r\nconst AccountDataMissing: React.FC<IAccountDataMissingProps> = (\r\n    props: IAccountDataMissingProps\r\n): JSX.Element => {\r\n    const userVars = useAppSelector((state) => state.user.user)\r\n    const [successMessage, setSuccessMessage] = useState<string>()\r\n    const [resendTimeout, setResendTimeout] = useState<number>(0)\r\n    const [mainDetails, setMainDetails] = useState<\r\n        IUserAccountInfo | undefined\r\n    >(undefined)\r\n    const [error, setError] = useState<string | undefined>()\r\n    const [contactDetailsValid, setContactDetailsValid] =\r\n        useState<IEditedContactDetails>()\r\n    const [contactDetailsEdited, setContactDetailsEdited] =\r\n        useState<IEditedContactDetails>()\r\n    const [isLoading, setIsLoading] = useState<boolean>(true)\r\n    const [formValid, setFormValid] = useState<boolean>(true)\r\n\r\n    useEffect((): (() => void) => {\r\n        const timer =\r\n            resendTimeout &&\r\n            setInterval(() => setResendTimeout(resendTimeout - 1), 1000)\r\n\r\n        return (): void => clearInterval(timer)\r\n    }, [resendTimeout])\r\n\r\n    useEffect(() => {\r\n        if (\r\n            contactDetailsValid &&\r\n            Object.keys(contactDetailsValid).length > 0\r\n        ) {\r\n            const invalidFound = Object.values(contactDetailsValid).every(\r\n                (v) => v === true\r\n            )\r\n\r\n            if (invalidFound) {\r\n                setFormValid(false)\r\n            } else setFormValid(true)\r\n        } else setFormValid(true)\r\n    }, [contactDetailsValid, contactDetailsEdited])\r\n\r\n    const serveResponse = (response: AxiosResponse<any>): void => {\r\n        if (response.data.success) {\r\n            setSuccessMessage('Your details successfully updated')\r\n            props.handleSave()\r\n        }\r\n\r\n        if (response.data.errorMessage || response.data.friendlyErrorMessage) {\r\n            if (response.data.friendlyErrorMessage) {\r\n                setError(response.data.friendlyErrorMessage)\r\n            } else {\r\n                setError(response.data.errorMessage)\r\n                console.error(response.data.errorMessage)\r\n            }\r\n        }\r\n    }\r\n\r\n    const updateContactDetails = async (): Promise<void> => {\r\n        if (\r\n            contactDetailsValid &&\r\n            Object.keys(contactDetailsValid).length > 0\r\n        ) {\r\n            return\r\n        }\r\n\r\n        if (mainDetails) {\r\n            if (\r\n                contactDetailsValid &&\r\n                Object.keys(contactDetailsValid).length === 0\r\n            ) {\r\n                try {\r\n                    if (props.retrievedJwt && mainDetails.phone) {\r\n                        const response = await AccountAPI.updateCustomerDetails(\r\n                            mainDetails,\r\n                            props.retrievedJwt\r\n                        )\r\n                        serveResponse(response)\r\n                    }\r\n                } catch (error) {\r\n                    console.error(error)\r\n                }\r\n            }\r\n        }\r\n\r\n        setContactDetailsEdited(undefined)\r\n    }\r\n\r\n    const validation = (name: string, value: string): boolean => {\r\n        // returns true if valid and false if not valid\r\n        if (value && value !== null && value.length > 0) {\r\n            switch (name) {\r\n                case 'firstName':\r\n                case 'lastName':\r\n                    return alphaValidator(value) && value.length >= 1\r\n                case 'email':\r\n                    return validateEmail(value)\r\n            }\r\n        } else {\r\n            return false\r\n        }\r\n\r\n        return false\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (userVars) {\r\n            setIsLoading(false)\r\n        }\r\n    }, [])\r\n\r\n    useEffect(() => {\r\n        setMainDetails({\r\n            firstName: userVars && userVars.firstName ? userVars.firstName : '',\r\n            lastName: userVars && userVars.lastName ? userVars.lastName : '',\r\n            email: userVars && userVars.email ? userVars.email : '',\r\n            phone: userVars && userVars.phone ? userVars.phone : '',\r\n        })\r\n    }, [userVars])\r\n\r\n    useEffect(() => {\r\n        if (mainDetails) {\r\n            const keys = Object.keys(mainDetails)\r\n            const itemsInvalid = {} as IEditedContactDetails\r\n\r\n            for (const key of keys) {\r\n                const originalItem =\r\n                    (userVars && userVars[key as keyof IUserAccountInfo]) ?? ''\r\n\r\n                let updatedItem\r\n                let isInputValid\r\n\r\n                if (key !== 'phone') {\r\n                    updatedItem = mainDetails[\r\n                        key as keyof IUserAccountInfo\r\n                    ] as string\r\n                    isInputValid = validation(key, updatedItem)\r\n                } else if (key === 'phone') {\r\n                    if (mainDetails.phone) {\r\n                        isInputValid = isPhoneValid(mainDetails.phone)\r\n                    } else {\r\n                        isInputValid = false\r\n                    }\r\n                }\r\n\r\n                if (isInputValid === false) {\r\n                    itemsInvalid[key as keyof IEditedContactDetails] = true\r\n                } else if (\r\n                    isInputValid === true &&\r\n                    itemsInvalid[key as keyof IEditedContactDetails]\r\n                ) {\r\n                    itemsInvalid[key as keyof IEditedContactDetails] = false\r\n                }\r\n\r\n                if (\r\n                    key === 'phone' &&\r\n                    userVars &&\r\n                    userVars.phone !== null &&\r\n                    mainDetails.phone === userVars.phone\r\n                ) {\r\n                    continue\r\n                } else if (updatedItem === originalItem) {\r\n                    continue\r\n                }\r\n            }\r\n\r\n            setContactDetailsValid(itemsInvalid)\r\n        }\r\n    }, [mainDetails, userVars])\r\n\r\n    const handleInput = (\r\n        event: React.ChangeEvent<HTMLInputElement | HTMLSelectElement>\r\n    ): void => {\r\n        const { name, value } = event.target\r\n        handleDataChange(name, value)\r\n    }\r\n\r\n    const handleDataChange = (name: string, value: string): void => {\r\n        setError(undefined)\r\n\r\n        if (\r\n            mainDetails &&\r\n            mainDetails[name as keyof IUserAccountInfo] !== value\r\n        ) {\r\n            const updatedDetails = {\r\n                ...mainDetails,\r\n                [name]: value,\r\n            }\r\n\r\n            setContactDetailsEdited((prev) => {\r\n                return { ...prev, [name]: true }\r\n            })\r\n            setMainDetails(updatedDetails)\r\n        }\r\n    }\r\n\r\n    return (\r\n        <>\r\n            {isLoading && <Loader position=\"fixed\" messages={['Loading']} />}\r\n\r\n            <div>\r\n                <h1 className=\"account-landing__details-title\">\r\n                    Please update your info\r\n                </h1>\r\n                {successMessage && (\r\n                    <Alert\r\n                        type={MessageType.success}\r\n                        message={successMessage}\r\n                    />\r\n                )}\r\n\r\n                <>\r\n                    {error && (\r\n                        <Alert type={MessageType.error} message={error} />\r\n                    )}\r\n\r\n                    {mainDetails && userVars && (\r\n                        <ContactInfo\r\n                            firstName={mainDetails.firstName}\r\n                            lastName={mainDetails.lastName}\r\n                            email={mainDetails.email}\r\n                            phone={\r\n                                mainDetails.phone && mainDetails.phone !== null\r\n                                    ? mainDetails.phone\r\n                                    : ''\r\n                            }\r\n                            handleChange={handleInput}\r\n                            handlePhoneChange={handleDataChange}\r\n                            validation={contactDetailsValid}\r\n                        />\r\n                    )}\r\n\r\n                    <div className=\"mt-30 accountLanding__dualBtns\">\r\n                        <button\r\n                            id=\"accountUpdateContactDetails\"\r\n                            onClick={updateContactDetails}\r\n                            className={`btn btn-large btn-shorter ${formValid ? 'primary-btn' : 'primary-btn-disabled'}`}\r\n                        >\r\n                            Save\r\n                        </button>\r\n                    </div>\r\n                </>\r\n            </div>\r\n        </>\r\n    )\r\n}\r\n\r\nexport default AccountDataMissing\r\n","import React, { useCallback, useEffect, useState } from 'react'\r\nimport './PageContainer.css'\r\nimport { setBookingProgress, setExtraObject } from '../../../redux/ticketSlice'\r\nimport { CHECK_TIMESTAMP } from '../../../Helpers/AUTH.resource'\r\nimport AddressPage from './ExtraPages/AddressPage'\r\nimport API from '../../../axios/API'\r\nimport ImportantInformation from './ExtraPages/ImportantInformation'\r\nimport BookingProtect from './ExtraPages/BookingProtect'\r\nimport QuestionsPage from './ExtraPages/QuestionsPage'\r\nimport Loader from '../../Shared/Loader/Loader'\r\nimport TermsAndConditions from './ExtraPages/TermsAndConditions'\r\nimport ExtraError from './ExtraPages/ExtraError'\r\nimport { IReservationNote, Pages } from '../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../redux/store'\r\nimport AccountScreens from '../../AccountScreens/AccountScreens'\r\nimport AccountDataMissing from '../../../Screens/AccountPages/AccountDataMissing'\r\nimport { getUserInfo } from '../../../redux/userSlice'\r\n\r\nconst PageContainer: React.FC = (): React.JSX.Element => {\r\n    const dispatch = useAppDispatch()\r\n    const { user } = useAppSelector((state) => state.user)\r\n    const bookingObject = useAppSelector((state) => state.tickets.bookingObject)\r\n\r\n    const [loading, setLoading] = useState<string[] | undefined>(undefined)\r\n    const [loggedIn, setLoggedIn] = useState<boolean>(true)\r\n    const [dataMissing, setDataMissing] = useState<boolean | undefined>(\r\n        undefined\r\n    )\r\n    const [showAddressPage, setShowAddressPage] = useState<boolean | undefined>(\r\n        false\r\n    )\r\n    const [retrievedJwt, setRetrievedJwt] = useState<string | undefined>(\r\n        undefined\r\n    )\r\n    const [extraPages, setExtraPages] = useState<React.JSX.Element | undefined>(\r\n        undefined\r\n    )\r\n\r\n    const getUserData = useCallback(() => {\r\n        void CHECK_TIMESTAMP(true).then((jwt) => {\r\n            if (!jwt) {\r\n                setLoggedIn(false)\r\n                return\r\n            } else {\r\n                void dispatch(getUserInfo(jwt)).then(() => {\r\n                    setLoggedIn(true)\r\n                    setRetrievedJwt(jwt)\r\n                })\r\n            }\r\n        })\r\n    }, [dispatch])\r\n\r\n    useEffect(() => getUserData(), [getUserData])\r\n\r\n    useEffect(() => {\r\n        if (user !== undefined && retrievedJwt !== undefined) {\r\n            if (\r\n                user.phone === null ||\r\n                user.lastName === null ||\r\n                user.firstName === null ||\r\n                user.email === null\r\n            ) {\r\n                setDataMissing(true)\r\n                setShowAddressPage(false)\r\n            } else {\r\n                setDataMissing(false)\r\n                handleDelivery()\r\n            }\r\n        }\r\n    }, [retrievedJwt, user])\r\n\r\n    const handleSave = (): void => {\r\n        setDataMissing(false)\r\n        handleDelivery()\r\n    }\r\n\r\n    const handleDelivery = (): void => {\r\n        if (bookingObject.reserveResponse?.hasDelivery) {\r\n            window.dataLayer.push({\r\n                event: 'booking__vpv',\r\n                eventProps: {\r\n                    category: 'Booking',\r\n                    action: 'Address Page',\r\n                    label: 'Address Page',\r\n                    page: 'address-page',\r\n                },\r\n            })\r\n\r\n            if (retrievedJwt) {\r\n                setShowAddressPage(true)\r\n            }\r\n        } else {\r\n            setShowAddressPage(false)\r\n            void handlePages()\r\n        }\r\n    }\r\n\r\n    const handlePages = async (\r\n        error: string | undefined = undefined\r\n    ): Promise<void> => {\r\n        setShowAddressPage(false)\r\n        if (error) {\r\n            window.dataLayer.push({\r\n                event: 'booking__vpv',\r\n                eventProps: {\r\n                    category: 'Booking',\r\n                    action: 'Error Page',\r\n                    label: 'Error Page',\r\n                    page: 'error-page',\r\n                },\r\n            })\r\n            setExtraPages(<ExtraError error={error} />)\r\n\r\n            return\r\n        }\r\n\r\n        if (retrievedJwt) {\r\n            setLoading(['Retrieving extra information'])\r\n            await API.getNotes(bookingObject, retrievedJwt).then((response) => {\r\n                dispatch(\r\n                    setExtraObject({\r\n                        order: bookingObject,\r\n                        res: response,\r\n                    })\r\n                )\r\n                const arrangedData = response\r\n                arrangedData.pages = arrangedData.pages.sort(function (a, b) {\r\n                    return a - b\r\n                })\r\n                setTimeout(() => {\r\n                    setLoading(undefined)\r\n                    selectPage(arrangedData.pages[0], arrangedData)\r\n                }, 0)\r\n            })\r\n        } else {\r\n            setLoggedIn(false)\r\n        }\r\n    }\r\n\r\n    const selectPage = (pageNumber?: Pages, data?: IReservationNote): void => {\r\n        if (data && pageNumber) {\r\n            const nextPage =\r\n                data.pages[data.pages.indexOf(pageNumber) + 1] || Pages.Summary\r\n            const datalayerObj = {\r\n                event: 'booking__vpv',\r\n                eventProps: {\r\n                    category: 'Booking',\r\n                    action: '',\r\n                    label: '',\r\n                    page: '',\r\n                },\r\n            }\r\n\r\n            switch (pageNumber) {\r\n                case Pages.ImportantInformation:\r\n                    setExtraPages(\r\n                        <ImportantInformation\r\n                            reservationNote={data}\r\n                            selectPage={() => selectPage(nextPage, data)}\r\n                        />\r\n                    )\r\n                    datalayerObj.eventProps.action =\r\n                        'Important Information Page'\r\n                    datalayerObj.eventProps.page = 'important-information-page'\r\n                    break\r\n                case Pages.Questions:\r\n                    setExtraPages(\r\n                        <QuestionsPage\r\n                            orderQuestionsProp={data.orderQuestions}\r\n                            ticketQuestionsProp={data.ticketQuestions}\r\n                            selectPage={() => selectPage(nextPage, data)}\r\n                        />\r\n                    )\r\n                    datalayerObj.eventProps.action = 'Questions Page'\r\n                    datalayerObj.eventProps.page = 'questions-page'\r\n                    break\r\n                case Pages.TermsAndConditions:\r\n                    setExtraPages(\r\n                        <TermsAndConditions\r\n                            reservationNote={data}\r\n                            selectPage={() => selectPage(nextPage, data)}\r\n                        />\r\n                    )\r\n                    datalayerObj.eventProps.action = 'Terms And Conditions Page'\r\n                    datalayerObj.eventProps.page = 'tsandcs-page'\r\n                    break\r\n                case Pages.Insurance:\r\n                    setExtraPages(\r\n                        <BookingProtect\r\n                            bp={data.bookingProtect}\r\n                            selectPage={() => selectPage(nextPage, data)}\r\n                        />\r\n                    )\r\n                    datalayerObj.eventProps.action = 'Booking Protect Page'\r\n                    datalayerObj.eventProps.page = 'booking-protection'\r\n                    break\r\n                case Pages.Summary:\r\n                    dispatch(setBookingProgress('summary'))\r\n                    break\r\n                default:\r\n                    dispatch(setBookingProgress('summary'))\r\n                    break\r\n            }\r\n\r\n            if (datalayerObj.eventProps.action !== null) {\r\n                datalayerObj.eventProps.label = datalayerObj.eventProps.action\r\n                window.dataLayer.push(datalayerObj)\r\n            }\r\n        } else if (pageNumber && !data) {\r\n            // TODO: check and remove else if breaking\r\n            dispatch(setBookingProgress('summary'))\r\n        }\r\n    }\r\n\r\n    return (\r\n        <div className=\"tickets-home\">\r\n            {loading && <Loader messages={loading} />}\r\n            {!loggedIn ? (\r\n                <AccountScreens\r\n                    onSuccess={() => getUserData()}\r\n                    embeded={true}\r\n                />\r\n            ) : (\r\n                <>\r\n                    {dataMissing && retrievedJwt ? (\r\n                        <AccountDataMissing\r\n                            handleSave={handleSave}\r\n                            retrievedJwt={retrievedJwt}\r\n                        />\r\n                    ) : !dataMissing &&\r\n                      showAddressPage &&\r\n                      retrievedJwt &&\r\n                      bookingObject.reserveResponse ? (\r\n                        <AddressPage\r\n                            jwt={retrievedJwt}\r\n                            deliveryQuestion={\r\n                                bookingObject.reserveResponse.deliveryQuestion\r\n                            }\r\n                            handlePages={() => void handlePages()}\r\n                        />\r\n                    ) : (\r\n                        <>{extraPages}</>\r\n                    )}\r\n                </>\r\n            )}\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default PageContainer\r\n","import React from 'react'\r\nimport './selectedseatdisplay.css'\r\nimport { ISeat } from '../../../../../interfaces/interfaces'\r\n\r\ninterface ISelectedSeatDisplayProps {\r\n    selectedTickets: ISeat[]\r\n}\r\n\r\nconst SelectedSeatDisplay: React.FC<ISelectedSeatDisplayProps> = ({\r\n    selectedTickets,\r\n}: ISelectedSeatDisplayProps): JSX.Element => {\r\n    return (\r\n        <div className=\"SelectedSeatDisplay\">\r\n            <div className=\"SelectedSeatDisplay__scrollInner\">\r\n                {selectedTickets.map((selection, i) => {\r\n                    return (\r\n                        <p key={i} className=\"SelectedSeatDisplay_selectedSeat\">\r\n                            {selection.friendlyName || selection.name}\r\n                            <div\r\n                                className=\"SelectedSeatDisplay__priceDot\"\r\n                                style={{ backgroundColor: selection.colour }}\r\n                            />\r\n                        </p>\r\n                    )\r\n                })}\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default SelectedSeatDisplay\r\n","import React from \"react\";\r\nimport \"./SeatPicker.css\";\r\n\r\ninterface ISeatSelectionFooterProps {\r\n    isSelected: boolean;\r\n    selectAction: () => void;\r\n}\r\n\r\nconst SeatSelectionFooter: React.FC<ISeatSelectionFooterProps> = ({ isSelected, selectAction }: ISeatSelectionFooterProps): JSX.Element => {\r\n    return (\r\n        <div className=\"seatpicker__footer\">\r\n            {isSelected ? (\r\n                <button\r\n                    id=\"seatsSelected\"\r\n                    className=\"btn primary-btn btn-large\"\r\n                    onClick={selectAction}\r\n                >\r\n                    Select\r\n                </button>\r\n            ) : (\r\n                <button className=\"btn primary-btn-disabled btn-large\">\r\n                    Choose your selection\r\n                </button>\r\n            )}\r\n        </div>\r\n    );\r\n};\r\n\r\nexport default SeatSelectionFooter;\r\n","import React, { useEffect, useRef, useState } from 'react'\r\nimport './SeatPicker.css'\r\nimport { useGesture } from '@use-gesture/react'\r\nimport { useSpring, animated } from 'react-spring'\r\nimport { motion } from 'framer-motion'\r\nimport {\r\n    incrementTickets,\r\n    setTypeComponentOpen,\r\n    ticketsBookingObject,\r\n} from '../../../../../redux/ticketSlice'\r\nimport { isDesktop } from 'react-device-detect'\r\nimport minus from '../../../../../assets/Minus.png'\r\nimport plus from '../../../../../assets/Add.png'\r\nimport SelectedSeatDisplay from './SelectedSeatDisplay'\r\nimport SeatSelectionFooter from './SeatSelectionFooter'\r\nimport { SEAT_COLOURS } from '../../../../../Helpers/constants'\r\nimport {\r\n    IBookingTicketState,\r\n    ISeat,\r\n    ISeatPickerLabels,\r\n    ISeatPickerShapes,\r\n} from '../../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../../redux/store'\r\nimport { cloneObj, currencyFormat } from '../../../../../Helpers/utils'\r\n\r\ndocument.addEventListener('gesturestart', (e) => e.preventDefault())\r\ndocument.addEventListener('gesturechange', (e) => e.preventDefault())\r\n\r\ninterface ISeatPickerProps {\r\n    ticketPayload: IBookingTicketState\r\n}\r\n\r\nexport interface ISeatPriceColour {\r\n    colour: string\r\n    price: number\r\n}\r\n\r\nexport interface ISeatPriceColourMap {\r\n    [key: string]: ISeatPriceColour\r\n}\r\n\r\nconst SeatPicker: React.FC<ISeatPickerProps> = ({\r\n    ticketPayload,\r\n}: ISeatPickerProps): JSX.Element => {\r\n    const seatPickerRef = useRef<HTMLDivElement>(null)\r\n    const bookingObject = useAppSelector(ticketsBookingObject)\r\n    const maxPeople = bookingObject.ticketObject.maxPartySize\r\n    const dispatch = useAppDispatch()\r\n\r\n    const [seats, setSeats] = useState<ISeat[]>([])\r\n    const [labels, setLabels] = useState<ISeatPickerLabels[]>([])\r\n    const [colourPicked, setColourPicked] = useState<string | undefined>(\r\n        undefined\r\n    )\r\n    const [shapes, setShapes] = useState<ISeatPickerShapes[]>([])\r\n    const [colourArray, setColourArray] = useState<ISeatPriceColour[]>([])\r\n    const [selectQ, setSelectQ] = useState<number>(99999)\r\n    const [selectedTickets, setSelectedTickets] = useState<ISeat[]>([])\r\n    const [seatMessage, setSeatMessage] = useState<string[]>([])\r\n    const [maxMessage, setMaxMessage] = useState<string>('')\r\n    const [widthDivide, setWidthDivide] = useState<number>(0)\r\n    const [heightDivide, setHeightDivide] = useState<number>(0)\r\n    const [selectTindex, setSelectTindex] = useState<number>(0)\r\n\r\n    useEffect(() => {\r\n        if (!seatPickerRef) {\r\n            return\r\n        }\r\n\r\n        const ticketCoords = ticketPayload.seats.map((o) => ({\r\n            x: o.x,\r\n            y: o.y,\r\n        }))\r\n        const yHeight = Math.max(...ticketCoords.map((c) => c.y))\r\n        const xWidth = Math.max(...ticketCoords.map((c) => c.x))\r\n\r\n        const seatPickerCurrentRef = seatPickerRef.current\r\n\r\n        if (seatPickerCurrentRef !== null) {\r\n            setWidthDivide(seatPickerCurrentRef.offsetWidth / xWidth)\r\n            setHeightDivide((seatPickerCurrentRef.offsetHeight - 280) / yHeight)\r\n        }\r\n    }, [seatPickerRef])\r\n\r\n    const handleZoom = (event: string): void => {\r\n        if (event === 'out') {\r\n            setWidthDivide((widthDivide) => widthDivide + 0.05)\r\n            setHeightDivide((heightDivide) => heightDivide + 0.05)\r\n        } else {\r\n            setWidthDivide((widthDivide) => widthDivide - 0.05)\r\n            setHeightDivide((heightDivide) => heightDivide - 0.05)\r\n        }\r\n    }\r\n\r\n    const handleDropDown = (tIndex: number, i: number): void => {\r\n        setSelectTindex(tIndex)\r\n\r\n        seats[i].externalId = seats[i].ticketTypes[tIndex].externalId\r\n        seats[i].inclusionBookingFeePennies =\r\n            seats[i].ticketTypes[tIndex].inclusionBookingFeePennies\r\n        seats[i].pricePennies = seats[i].ticketTypes[tIndex].pricePennies\r\n        seats[i].friendlyName = seats[i].ticketTypes[tIndex].friendlyName\r\n        seats[i].name = seats[i].ticketTypes[tIndex].name\r\n        seats[i].note = seats[i].ticketTypes[tIndex].note\r\n    }\r\n\r\n    const [style, api] = useSpring(() => ({\r\n        x: 10,\r\n        y: 0,\r\n        scale: 0.96,\r\n    }))\r\n\r\n    const ref = React.useRef(null)\r\n\r\n    useGesture(\r\n        {\r\n            onHover: () => undefined,\r\n            onDrag: ({ pinching, cancel, offset: [x, y] }) => {\r\n                if (pinching) return cancel()\r\n                api.start({ x, y })\r\n            },\r\n        },\r\n        {\r\n            target: ref,\r\n            drag: { from: () => [style.x.get(), style.y.get()] },\r\n        }\r\n    )\r\n\r\n    const handleClick = (\r\n        e: React.MouseEvent<HTMLDivElement>,\r\n        i: number\r\n    ): void => {\r\n        e.preventDefault()\r\n\r\n        if (seats[i].ticketTypes.length > 1 && !seats[i].selected) {\r\n            setSelectQ(i)\r\n        } else {\r\n            setSelectQ(99999)\r\n        }\r\n\r\n        setSeatMessage([])\r\n        setMaxMessage('')\r\n\r\n        const message = []\r\n        const seatRow = seats[i].seatLetter\r\n        const seatNumber = JSON.parse(seats[i].seatNumber)\r\n\r\n        if (ticketPayload.allowDiscontiguousSeats === false) {\r\n            let allowed = false\r\n\r\n            if (selectedTickets.length > 0) {\r\n                if (seats[i].selected) {\r\n                    allowed = true\r\n\r\n                    for (let k = 0; k < selectedTickets.length; k++) {\r\n                        const selectednumber = JSON.parse(\r\n                            selectedTickets[k].seatNumber\r\n                        )\r\n\r\n                        if (seatNumber - 1 === selectednumber) {\r\n                            allowed = false\r\n                        }\r\n                    }\r\n\r\n                    if (allowed === false) {\r\n                        for (let k = 0; k < selectedTickets.length; k++) {\r\n                            const selectednumber = JSON.parse(\r\n                                selectedTickets[k].seatNumber\r\n                            )\r\n\r\n                            if (seatNumber + 1 === selectednumber) {\r\n                                setMaxMessage(\r\n                                    'Seats must be next to each other.'\r\n                                )\r\n\r\n                                return\r\n                            }\r\n                        }\r\n                    } else {\r\n                        allowed = true\r\n                    }\r\n                }\r\n\r\n                if (seatRow !== selectedTickets[0].seatLetter) {\r\n                    setMaxMessage('Seats must be next to each other.')\r\n\r\n                    return\r\n                }\r\n\r\n                allowed = false\r\n\r\n                for (let k = 0; k < selectedTickets.length; k++) {\r\n                    const selectednumber = JSON.parse(\r\n                        selectedTickets[k].seatNumber\r\n                    )\r\n\r\n                    if (\r\n                        seatNumber + 1 === selectednumber ||\r\n                        seatNumber - 1 === selectednumber ||\r\n                        seatNumber === selectednumber\r\n                    ) {\r\n                        allowed = true\r\n                    }\r\n                }\r\n            } else {\r\n                allowed = true\r\n            }\r\n\r\n            if (!allowed) {\r\n                setMaxMessage('Seats must be next to each other.')\r\n\r\n                return\r\n            }\r\n        }\r\n\r\n        let tempSelected = [] as ISeat[]\r\n\r\n        if (selectedTickets.length === maxPeople && !seats[i].selected) {\r\n            setMaxMessage('Max seats selected')\r\n\r\n            return\r\n        } else {\r\n            setMaxMessage('')\r\n        }\r\n\r\n        seats[i].selected = !seats[i].selected\r\n\r\n        if (seats[i].restrictedView) {\r\n            message.push('This seat has a restricted view.')\r\n        }\r\n\r\n        if (seats[i].sold) {\r\n            message.push('We are sorry, this seat has been sold.')\r\n        }\r\n\r\n        if (seats[i].specialInfo) {\r\n            message.push(seats[i].specialInfo)\r\n        }\r\n\r\n        setSeatMessage(message)\r\n\r\n        if (selectedTickets.includes(seats[i])) {\r\n            seats[i].quantity = 0\r\n            tempSelected = selectedTickets.filter(function (item) {\r\n                return item !== seats[i]\r\n            })\r\n        } else {\r\n            seats[i].quantity = 1\r\n            tempSelected = [...selectedTickets, seats[i]]\r\n        }\r\n\r\n        setSelectedTickets(tempSelected)\r\n    }\r\n\r\n    const selectTickets = (): void => {\r\n        const tempTickets = []\r\n\r\n        if (bookingObject.ticketObject.allowLeavingSingleSeats === true) {\r\n            const found = seats.filter(\r\n                (element) =>\r\n                    element.seatLetter === selectedTickets[0].seatLetter\r\n            )\r\n\r\n            const availableInFound = found.filter(\r\n                (element) => element.sold === false\r\n            )\r\n            availableInFound.sort((a, b) => a.pricePennies - b.pricePennies) // OC: not sure which param to sort on, used pricePennies\r\n\r\n            const availableNumArray = []\r\n\r\n            for (let k = 0; k < availableInFound.length; k++) {\r\n                const selectedTicketNumber = parseInt(\r\n                    availableInFound[k].seatNumber\r\n                )\r\n                availableNumArray.push(selectedTicketNumber)\r\n            }\r\n\r\n            const minNum = Math.min(...availableNumArray)\r\n            const maxNum = Math.max(...availableNumArray)\r\n            let allowedSeats = false\r\n\r\n            for (let k = 0; k < selectedTickets.length; k++) {\r\n                const splitSeatNameProp = JSON.parse(\r\n                    selectedTickets[k].seatNumber\r\n                )\r\n\r\n                if (\r\n                    splitSeatNameProp === minNum ||\r\n                    splitSeatNameProp === maxNum\r\n                ) {\r\n                    allowedSeats = true\r\n                }\r\n            }\r\n\r\n            const sortedSelected = selectedTickets.sort((a, b) => {\r\n                const nameA = a.name.replace(/^\\D+/g, ''),\r\n                    nameB = b.name.replace(/^\\D+/g, '')\r\n\r\n                return nameA > nameB ? 1 : 0\r\n            })\r\n\r\n            if (!allowedSeats) {\r\n                const splitSeatNamePropMin = JSON.parse(\r\n                    sortedSelected[0].seatNumber\r\n                )\r\n                const splitSeatNamePropMax = JSON.parse(\r\n                    sortedSelected[selectedTickets.length - 1].seatNumber\r\n                )\r\n                let right = false\r\n                let left = false\r\n\r\n                if (\r\n                    availableNumArray.includes(splitSeatNamePropMin - 1) &&\r\n                    availableNumArray.includes(splitSeatNamePropMin - 2)\r\n                ) {\r\n                    left = true\r\n                } else {\r\n                    if (!availableNumArray.includes(splitSeatNamePropMin - 1)) {\r\n                        left = true\r\n                    } else {\r\n                        left = false\r\n                    }\r\n                }\r\n\r\n                if (\r\n                    availableNumArray.includes(splitSeatNamePropMax + 1) &&\r\n                    availableNumArray.includes(splitSeatNamePropMax + 2)\r\n                ) {\r\n                    right = true\r\n                } else {\r\n                    right = !availableNumArray.includes(\r\n                        splitSeatNamePropMax + 1\r\n                    )\r\n                }\r\n\r\n                allowedSeats = !(!right || !left)\r\n            }\r\n\r\n            if (!allowedSeats) {\r\n                setMaxMessage('Please do not leave a single seat!')\r\n\r\n                return\r\n            }\r\n        }\r\n\r\n        for (let i = 0; i < selectedTickets.length; i++) {\r\n            tempTickets[i] = {\r\n                name: selectedTickets[i].name,\r\n                friendlyName: selectedTickets[i].friendlyName,\r\n                quantity: selectedTickets[i].quantity,\r\n                externalId: selectedTickets[i].externalId,\r\n                pricePennies: selectedTickets[i].pricePennies,\r\n                InclusionBookingFeePennies:\r\n                    selectedTickets[i].inclusionBookingFeePennies,\r\n            }\r\n        }\r\n\r\n        const tempSelectedTickets = {\r\n            attractionId: ticketPayload.attractionId,\r\n            eventId: ticketPayload.eventId,\r\n            sessionId: ticketPayload.sessionId,\r\n            ticketTypes: tempTickets,\r\n            hasSeatpicker: true,\r\n            promotionalMessage: ticketPayload.promotionalMessage,\r\n        }\r\n\r\n        dispatch(incrementTickets(tempSelectedTickets))\r\n        dispatch(setTypeComponentOpen(false))\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (!ticketPayload) {\r\n            return\r\n        }\r\n\r\n        if (!ticketPayload.width) {\r\n            return\r\n        }\r\n\r\n        const tempSeats = cloneObj(ticketPayload.seats)\r\n        const shape = cloneObj(ticketPayload.shapes)\r\n        setShapes(shape)\r\n\r\n        const tempDatalabels = cloneObj(ticketPayload.labels)\r\n        const priceArray = {} as ISeatPriceColourMap\r\n\r\n        for (let i = 0; i < tempSeats.length; i++) {\r\n            if (tempSeats[i].pricePennies) {\r\n                const seatColour =\r\n                    SEAT_COLOURS[Math.floor(tempSeats[i].pricePennies / 1000)]\r\n                tempSeats[i].colour = seatColour\r\n\r\n                priceArray[seatColour] = {\r\n                    colour: seatColour,\r\n                    price: tempSeats[i].pricePennies,\r\n                } as ISeatPriceColour\r\n            }\r\n        }\r\n\r\n        const colourResult = Object.keys(priceArray).map(\r\n            (key) => priceArray[key]\r\n        ) as ISeatPriceColour[]\r\n\r\n        setColourArray(colourResult)\r\n\r\n        setLabels(tempDatalabels)\r\n        setSeats(tempSeats)\r\n    }, [ticketPayload])\r\n\r\n    const handleColourClick = (colour?: string): void => {\r\n        if (colour) {\r\n            setColourPicked(colour)\r\n        }\r\n    }\r\n\r\n    return (\r\n        <div\r\n            ref={seatPickerRef}\r\n            className={`seatpicker ${isDesktop ? 'seatpicker__modal' : ''}`}\r\n        >\r\n            <div className=\"seatpicker__zHeader\">\r\n                <h3 className=\"picker__prompt\">Choose your seats:</h3>\r\n                <div className=\"seatpicker__colours__contain\">\r\n                    <div className=\"seatpicker__colours\">\r\n                        <div\r\n                            onClick={() => {\r\n                                handleColourClick(undefined)\r\n                            }}\r\n                            className=\"seatpicker__priceShow\"\r\n                        >\r\n                            <span\r\n                                className=\"seatpicker__colourShow\"\r\n                                style={{ backgroundColor: '#444' }}\r\n                            />\r\n                            <span>ALL </span>\r\n                        </div>\r\n                        {colourArray\r\n                            .sort((a, b) => b.price - a.price)\r\n                            .map((colour, i) => {\r\n                                return (\r\n                                    <div\r\n                                        onClick={() => {\r\n                                            handleColourClick(colour.colour)\r\n                                        }}\r\n                                        className=\"seatpicker__priceShow\"\r\n                                        key={i}\r\n                                    >\r\n                                        <span\r\n                                            className=\"seatpicker__colourShow\"\r\n                                            style={{\r\n                                                backgroundColor: colour.colour,\r\n                                            }}\r\n                                        />\r\n                                        <span key={i}>\r\n                                            {`£${(colour.price / 100).toFixed(2)}`}\r\n                                        </span>\r\n                                    </div>\r\n                                )\r\n                            })}\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div className=\"seatpicker__modifierContain\">\r\n                <button\r\n                    id=\"seatPickerZoomIn\"\r\n                    className=\"btn primary-btn-white seatpicker__modifier\"\r\n                    onClick={() => {\r\n                        handleZoom('in')\r\n                    }}\r\n                >\r\n                    <img\r\n                        className=\"addTickets__iconMinus\"\r\n                        src={minus}\r\n                        alt=\"Decrease Tickets\"\r\n                    />\r\n                </button>\r\n\r\n                <button\r\n                    className=\"btn primary-btn-white seatpicker__modifier\"\r\n                    id=\"seatPickerZoomOut\"\r\n                    onClick={() => {\r\n                        handleZoom('out')\r\n                    }}\r\n                >\r\n                    <img\r\n                        className=\"addTickets__iconPlus\"\r\n                        src={plus}\r\n                        alt=\"Increase Tickets\"\r\n                    />\r\n                </button>\r\n            </div>\r\n            <div\r\n                className=\"seatpicker__container\"\r\n                style={{\r\n                    transform: `scale(1)`,\r\n                }}\r\n            >\r\n                <animated.div\r\n                    className=\"seatPicker__card\"\r\n                    ref={ref}\r\n                    style={style}\r\n                >\r\n                    <div className=\"seatpicker__minified\">\r\n                        {labels &&\r\n                            labels.map((prop, i) => (\r\n                                <div\r\n                                    className=\"testlabels\"\r\n                                    style={{\r\n                                        position: 'absolute',\r\n                                        scale: 1,\r\n                                        fontSize:\r\n                                            prop.label.length > 3\r\n                                                ? 11 + 'px'\r\n                                                : 9 + 'px',\r\n                                        top:\r\n                                            prop.label === 'STAGE'\r\n                                                ? prop.y * heightDivide -\r\n                                                  7 +\r\n                                                  'px'\r\n                                                : prop.y * heightDivide -\r\n                                                  1 +\r\n                                                  'px',\r\n                                        left:\r\n                                            prop.label.length > 3\r\n                                                ? prop.x * widthDivide -\r\n                                                  9 +\r\n                                                  'px'\r\n                                                : prop.x * widthDivide -\r\n                                                  1 +\r\n                                                  'px',\r\n                                        color: '#0f0823',\r\n                                    }}\r\n                                    key={i}\r\n                                >\r\n                                    {prop.label === 'STAGE' ? (\r\n                                        <span\r\n                                            style={{\r\n                                                fontSize: '12px',\r\n                                                fontWeight: '600',\r\n                                                lineHeight: '19px',\r\n                                            }}\r\n                                        >\r\n                                            {prop.label}\r\n                                        </span>\r\n                                    ) : (\r\n                                        <span>{prop.label}</span>\r\n                                    )}\r\n                                </div>\r\n                            ))}\r\n                        {shapes &&\r\n                            shapes.map((shape, i) => {\r\n                                return (\r\n                                    <div\r\n                                        key={i}\r\n                                        style={{\r\n                                            position: 'absolute',\r\n                                            borderRadius:\r\n                                                shape.shapeBorderRadius + 'px',\r\n                                            width:\r\n                                                shape.width * widthDivide +\r\n                                                'px',\r\n                                            height:\r\n                                                shape.height * heightDivide +\r\n                                                'px',\r\n                                            top:\r\n                                                shape.y * heightDivide -\r\n                                                shape.height *\r\n                                                    widthDivide *\r\n                                                    0.5 -\r\n                                                3 +\r\n                                                'px',\r\n                                            left:\r\n                                                shape.x * widthDivide -\r\n                                                shape.width *\r\n                                                    widthDivide *\r\n                                                    0.5 +\r\n                                                3 +\r\n                                                'px',\r\n                                        }}\r\n                                        className=\"seatpicker__shape\"\r\n                                    />\r\n                                )\r\n                            })}\r\n                        {seats.map((prop, i) => {\r\n                            return (\r\n                                <div key={i}>\r\n                                    {!prop.sold === false && (\r\n                                        <div\r\n                                            className=\"seatpicker__unavailable\"\r\n                                            style={{\r\n                                                position: 'absolute',\r\n                                                minWidth: '3px',\r\n                                                minHeight: '4px',\r\n                                                width: widthDivide * 10 + 'px',\r\n                                                height: heightDivide * 9 + 'px',\r\n                                                top:\r\n                                                    prop.y * heightDivide +\r\n                                                    'px',\r\n                                                left:\r\n                                                    prop.x * widthDivide + 'px',\r\n                                            }}\r\n                                        />\r\n                                    )}\r\n                                    {!prop.sold === true && (\r\n                                        <div\r\n                                            className={`seatpicker__available ${prop.selected && 'ticketSelected'}`}\r\n                                            style={{\r\n                                                position: 'absolute',\r\n                                                minWidth: '5px',\r\n                                                minHeight: '6px',\r\n                                                width: widthDivide * 11 + 'px',\r\n                                                height:\r\n                                                    heightDivide * 11 + 'px',\r\n                                                top:\r\n                                                    prop.y * heightDivide -\r\n                                                    1 +\r\n                                                    'px',\r\n                                                left:\r\n                                                    prop.x * widthDivide -\r\n                                                    1 +\r\n                                                    'px',\r\n                                                backgroundColor:\r\n                                                    !colourPicked ||\r\n                                                    prop.colour === colourPicked\r\n                                                        ? prop.colour\r\n                                                        : 'var(--middle)',\r\n                                            }}\r\n                                            onClick={(e) => handleClick(e, i)}\r\n                                        />\r\n                                    )}\r\n                                    {selectQ === i && (\r\n                                        <motion.div\r\n                                            initial=\"hidden\"\r\n                                            animate=\"visible\"\r\n                                            variants={{\r\n                                                hidden: { opacity: 0 },\r\n                                                visible: { opacity: 1 },\r\n                                            }}\r\n                                        >\r\n                                            <div\r\n                                                style={{\r\n                                                    position: 'absolute',\r\n                                                    top:\r\n                                                        prop.y * heightDivide +\r\n                                                        19 +\r\n                                                        'px',\r\n                                                    left:\r\n                                                        prop.x * widthDivide -\r\n                                                        1 +\r\n                                                        'px',\r\n                                                }}\r\n                                                className=\"seatpicker__boxArrow\"\r\n                                            />\r\n                                            <div\r\n                                                style={{\r\n                                                    position: 'absolute',\r\n                                                    top:\r\n                                                        prop.y * heightDivide +\r\n                                                        29 +\r\n                                                        'px',\r\n                                                    left:\r\n                                                        prop.x * widthDivide -\r\n                                                        35 +\r\n                                                        'px',\r\n                                                }}\r\n                                                onMouseLeave={() => {\r\n                                                    setTimeout(() => {\r\n                                                        setSelectTindex(0)\r\n                                                        setSelectQ(99999)\r\n                                                    }, 150)\r\n                                                }}\r\n                                                className=\"seatpicker__selectQ\"\r\n                                            >\r\n                                                {prop.ticketTypes\r\n                                                    .sort((a, b) =>\r\n                                                        a.pricePennies <\r\n                                                        b.pricePennies\r\n                                                            ? 1\r\n                                                            : -1\r\n                                                    )\r\n                                                    .map((t, tIndex) => {\r\n                                                        return (\r\n                                                            <div\r\n                                                                key={tIndex}\r\n                                                                onClick={() =>\r\n                                                                    handleDropDown(\r\n                                                                        tIndex,\r\n                                                                        i\r\n                                                                    )\r\n                                                                }\r\n                                                            >\r\n                                                                {tIndex ===\r\n                                                                selectTindex ? (\r\n                                                                    <div className=\"seatpicker__seatsCirc seatpicker__seatsCircOn\" />\r\n                                                                ) : (\r\n                                                                    <div className=\"seatpicker__seatsCirc\" />\r\n                                                                )}\r\n                                                                <span className=\"seatpicker__seatPrices\">\r\n                                                                    {currencyFormat(\r\n                                                                        t.pricePennies\r\n                                                                    )}\r\n                                                                </span>\r\n\r\n                                                                <div className=\"seatpicker__seatChoiceText\" />\r\n                                                                {t.friendlyName}\r\n                                                            </div>\r\n                                                        )\r\n                                                    })}\r\n                                            </div>\r\n                                        </motion.div>\r\n                                    )}\r\n                                </div>\r\n                            )\r\n                        })}\r\n                    </div>\r\n                </animated.div>\r\n            </div>\r\n            {selectedTickets && (\r\n                <SelectedSeatDisplay selectedTickets={selectedTickets} />\r\n            )}\r\n            <div className=\"seatpicker__messageContainer\">\r\n                {seatMessage &&\r\n                    seatMessage[0] &&\r\n                    seatMessage.map((selection, i) => {\r\n                        return (\r\n                            <div\r\n                                className=\"seatpicker__messageSelected\"\r\n                                key={i}\r\n                            >\r\n                                <p className=\"seatpicker__selectedMessageDisplay\">\r\n                                    {selection}\r\n                                </p>\r\n                            </div>\r\n                        )\r\n                    })}\r\n                {maxMessage && maxMessage !== '' && (\r\n                    <p className=\"seatpicker__selectedMessageDisplay\">\r\n                        {maxMessage}\r\n                    </p>\r\n                )}\r\n            </div>\r\n            <SeatSelectionFooter\r\n                isSelected={selectedTickets && selectedTickets.length > 0}\r\n                selectAction={selectTickets}\r\n            />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default SeatPicker\r\n","import React, { useEffect, useRef, useState } from 'react'\r\nimport './SeatPicker.css'\r\nimport { useGesture } from '@use-gesture/react'\r\nimport { useSpring, animated } from 'react-spring'\r\nimport { motion } from 'framer-motion'\r\nimport {\r\n    incrementTickets,\r\n    setTypeComponentOpen,\r\n    ticketsBookingObject,\r\n} from '../../../../../redux/ticketSlice'\r\nimport { isDesktop } from 'react-device-detect'\r\nimport minus from '../../../../../assets/Minus.png'\r\nimport plus from '../../../../../assets/Add.png'\r\nimport SelectedSeatDisplay from './SelectedSeatDisplay'\r\nimport SeatSelectionFooter from './SeatSelectionFooter'\r\nimport { SEAT_COLOURS } from '../../../../../Helpers/constants'\r\nimport {\r\n    IBookingTicketState,\r\n    ISeat,\r\n    ISeatPickerShapes,\r\n} from '../../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../../redux/store'\r\nimport { ISeatPriceColour, ISeatPriceColourMap } from './SeatPicker'\r\n\r\nimport { cloneObj } from '../../../../../Helpers/utils'\r\n\r\ndocument.addEventListener('gesturestart', (e) => e.preventDefault())\r\ndocument.addEventListener('gesturechange', (e) => e.preventDefault())\r\n\r\ninterface ISeatPickerMultiProps {\r\n    ticketPayload: IBookingTicketState\r\n}\r\n\r\nconst SeatPickerMulti: React.FC<ISeatPickerMultiProps> = ({\r\n    ticketPayload,\r\n}: ISeatPickerMultiProps): JSX.Element => {\r\n    const seatPickerRef = useRef<HTMLDivElement>(null)\r\n    const bookingObject = useAppSelector(ticketsBookingObject)\r\n    const maxPeople = bookingObject.ticketObject.maxPartySize\r\n    const dispatch = useAppDispatch()\r\n\r\n    const [seats, setSeats] = useState<ISeat[]>([])\r\n    const [shapes, setShapes] = useState<ISeatPickerShapes[]>([])\r\n    const [colourPicked, setColourPicked] = useState<string | undefined>(\r\n        undefined\r\n    )\r\n    const [selectQ, setSelectQ] = useState<number>(99999)\r\n    const [colourArray, setColourArray] = useState<ISeatPriceColour[]>([])\r\n    const [selectedTickets, setSelectedTickets] = useState<ISeat[]>([])\r\n    const [seatMessage, setSeatMessage] = useState<string[]>([])\r\n    const [maxMessage, setMaxMessage] = useState<string>('')\r\n    const [widthDivide, setWidthDivide] = useState<number>(0)\r\n    const [heightDivide, setHeightDivide] = useState<number>(0)\r\n\r\n    useEffect(() => {\r\n        if (!seatPickerRef) {\r\n            return\r\n        }\r\n\r\n        const seatPickerCurrentRef = seatPickerRef.current\r\n\r\n        if (\r\n            seatPickerCurrentRef !== null &&\r\n            ticketPayload.width &&\r\n            ticketPayload.height\r\n        ) {\r\n            setWidthDivide(\r\n                seatPickerCurrentRef.offsetWidth / ticketPayload.width / 1.1\r\n            )\r\n            setHeightDivide(\r\n                (seatPickerCurrentRef.offsetHeight - 200) / ticketPayload.height\r\n            )\r\n        }\r\n    }, [seatPickerRef])\r\n\r\n    const handleZoom = (event: string): void => {\r\n        if (event === 'out') {\r\n            setWidthDivide((widthDivide) => widthDivide + 0.05)\r\n            setHeightDivide((heightDivide) => heightDivide + 0.05)\r\n        } else {\r\n            setWidthDivide((widthDivide) => widthDivide - 0.05)\r\n            setHeightDivide((heightDivide) => heightDivide - 0.05)\r\n        }\r\n    }\r\n\r\n    const [style, api] = useSpring(() => ({\r\n        x: 10,\r\n        y: 0,\r\n        scale: 1,\r\n        height: ticketPayload.height + 'px',\r\n    }))\r\n\r\n    const ref = React.useRef(null)\r\n\r\n    useGesture(\r\n        {\r\n            onDrag: ({ pinching, cancel, offset: [x, y] }) => {\r\n                if (pinching) return cancel()\r\n                api.start({ x, y })\r\n            },\r\n        },\r\n        {\r\n            target: ref,\r\n            drag: { from: () => [style.x.get(), style.y.get()] },\r\n        }\r\n    )\r\n\r\n    const handleClick = (\r\n        e: React.MouseEvent<HTMLDivElement>,\r\n        i: number\r\n    ): void => {\r\n        e.preventDefault()\r\n        setSeatMessage([])\r\n\r\n        if (seats[i].note && seats[i].note !== '' && !seats[i].selected) {\r\n            setSelectQ(i)\r\n        } else {\r\n            setSelectQ(99999)\r\n        }\r\n\r\n        const message = []\r\n        setMaxMessage('')\r\n        const seatRow = seats[i].seatLetter\r\n        const seatNumber = JSON.parse(seats[i].seatNumber)\r\n\r\n        if (ticketPayload.allowDiscontiguousSeats === false) {\r\n            let allowed = false\r\n\r\n            if (selectedTickets.length > 0) {\r\n                if (seats[i].selected) {\r\n                    allowed = true\r\n\r\n                    for (let k = 0; k < selectedTickets.length; k++) {\r\n                        const selectednumber = JSON.parse(\r\n                            selectedTickets[k].seatNumber\r\n                        )\r\n\r\n                        if (seatNumber - 1 === selectednumber) {\r\n                            allowed = false\r\n                        }\r\n                    }\r\n\r\n                    if (allowed === false) {\r\n                        for (let k = 0; k < selectedTickets.length; k++) {\r\n                            const selectednumber = JSON.parse(\r\n                                selectedTickets[k].seatNumber\r\n                            )\r\n\r\n                            if (seatNumber + 1 === selectednumber) {\r\n                                setMaxMessage(\r\n                                    'Seats must be next to each other.'\r\n                                )\r\n\r\n                                return\r\n                            }\r\n                        }\r\n                    } else {\r\n                        allowed = true\r\n                    }\r\n                }\r\n\r\n                if (seatRow !== selectedTickets[0].seatLetter) {\r\n                    setMaxMessage('Seats must be next to each other.')\r\n\r\n                    return\r\n                }\r\n\r\n                allowed = false\r\n\r\n                for (let k = 0; k < selectedTickets.length; k++) {\r\n                    const selectednumber = JSON.parse(\r\n                        selectedTickets[k].seatNumber\r\n                    )\r\n\r\n                    if (\r\n                        seatNumber + 1 === selectednumber ||\r\n                        seatNumber - 1 === selectednumber ||\r\n                        seatNumber === selectednumber\r\n                    ) {\r\n                        allowed = true\r\n                    }\r\n                }\r\n            } else {\r\n                allowed = true\r\n            }\r\n\r\n            if (!allowed) {\r\n                setMaxMessage('Seats must be next to each other.')\r\n\r\n                return\r\n            }\r\n        }\r\n\r\n        let tempSelected = [] as ISeat[]\r\n\r\n        if (selectedTickets.length === maxPeople && !seats[i].selected) {\r\n            setMaxMessage('Max seats selected')\r\n\r\n            return\r\n        } else {\r\n            setMaxMessage('')\r\n        }\r\n\r\n        seats[i].selected = !seats[i].selected\r\n\r\n        if (seats[i].restrictedView) {\r\n            message.push('This seat has a restricted view.')\r\n        }\r\n\r\n        if (seats[i].sold) {\r\n            message.push('We are sorry, this seat has been sold.')\r\n        }\r\n\r\n        if (seats[i].specialInfo) {\r\n            message.push(seats[i].specialInfo)\r\n        }\r\n\r\n        setSeatMessage(message)\r\n\r\n        if (selectedTickets.includes(seats[i])) {\r\n            seats[i].quantity = 0\r\n            tempSelected = selectedTickets.filter(function (item) {\r\n                return item !== seats[i]\r\n            })\r\n        } else {\r\n            seats[i].quantity = 1\r\n            tempSelected = [...selectedTickets, seats[i]]\r\n        }\r\n\r\n        setSelectedTickets(tempSelected)\r\n    }\r\n\r\n    const selectTickets = (): void => {\r\n        const tempTickets = []\r\n\r\n        if (bookingObject.ticketObject.allowLeavingSingleSeats === true) {\r\n            const found = seats.filter(\r\n                (element) =>\r\n                    element.seatLetter === selectedTickets[0].seatLetter\r\n            )\r\n\r\n            const availableInFound = found.filter(\r\n                (element) => element.sold === false\r\n            )\r\n\r\n            availableInFound.sort((a, b) => a.pricePennies - b.pricePennies) // OC: not sure which param to sort on, used pricePennies\r\n\r\n            const availableNumArray = []\r\n\r\n            for (let k = 0; k < availableInFound.length; k++) {\r\n                const selectedTicketNumber = parseInt(\r\n                    availableInFound[k].seatNumber\r\n                )\r\n                availableNumArray.push(selectedTicketNumber)\r\n            }\r\n\r\n            const minNum = Math.min(...availableNumArray)\r\n            const maxNum = Math.max(...availableNumArray)\r\n            let allowedSeats = false\r\n\r\n            for (let k = 0; k < selectedTickets.length; k++) {\r\n                const splitSeatNameProp = JSON.parse(\r\n                    selectedTickets[k].seatNumber\r\n                )\r\n\r\n                if (\r\n                    splitSeatNameProp === minNum ||\r\n                    splitSeatNameProp === maxNum\r\n                ) {\r\n                    allowedSeats = true\r\n                }\r\n            }\r\n\r\n            const sortedSelected = selectedTickets.sort(function (a, b) {\r\n                const nameA = a.name.replace(/^\\D+/g, ''),\r\n                    nameB = b.name.replace(/^\\D+/g, '')\r\n\r\n                return nameA > nameB ? 1 : 0\r\n            })\r\n\r\n            if (!allowedSeats) {\r\n                const splitSeatNamePropMin = JSON.parse(\r\n                    sortedSelected[0].seatNumber\r\n                )\r\n                const splitSeatNamePropMax = JSON.parse(\r\n                    sortedSelected[selectedTickets.length - 1].seatNumber\r\n                )\r\n                let right = false\r\n                let left = false\r\n\r\n                if (\r\n                    availableNumArray.includes(splitSeatNamePropMin - 1) &&\r\n                    availableNumArray.includes(splitSeatNamePropMin - 2)\r\n                ) {\r\n                    left = true\r\n                } else {\r\n                    if (!availableNumArray.includes(splitSeatNamePropMin - 1)) {\r\n                        left = true\r\n                    } else {\r\n                        left = false\r\n                    }\r\n                }\r\n\r\n                if (\r\n                    availableNumArray.includes(splitSeatNamePropMax + 1) &&\r\n                    availableNumArray.includes(splitSeatNamePropMax + 2)\r\n                ) {\r\n                    right = true\r\n                } else {\r\n                    right = !availableNumArray.includes(\r\n                        splitSeatNamePropMax + 1\r\n                    )\r\n                }\r\n\r\n                allowedSeats = !(!right || !left)\r\n            }\r\n\r\n            if (!allowedSeats) {\r\n                setMaxMessage('Please do not leave a single seat!')\r\n\r\n                return\r\n            }\r\n        }\r\n\r\n        for (let i = 0; i < selectedTickets.length; i++) {\r\n            tempTickets[i] = {\r\n                name: selectedTickets[i].name,\r\n                friendlyName: selectedTickets[i].friendlyName,\r\n                quantity: selectedTickets[i].quantity,\r\n                externalId: selectedTickets[i].externalId,\r\n                pricePennies: selectedTickets[i].pricePennies,\r\n                InclusionBookingFeePennies:\r\n                    selectedTickets[i].inclusionBookingFeePennies,\r\n            }\r\n        }\r\n\r\n        const tempSelectedTickets = {\r\n            attractionId: ticketPayload.attractionId,\r\n            eventId: ticketPayload.eventId,\r\n            sessionId: ticketPayload.sessionId,\r\n            ticketTypes: tempTickets,\r\n            hasSeatpicker: true,\r\n        }\r\n\r\n        dispatch(incrementTickets(tempSelectedTickets))\r\n        dispatch(setTypeComponentOpen(false))\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (!ticketPayload) {\r\n            return\r\n        }\r\n\r\n        if (!ticketPayload.width) {\r\n            return\r\n        }\r\n\r\n        const ticketPayloadTemp = cloneObj(ticketPayload)\r\n        let tempStart = [] as ISeat[]\r\n\r\n        if (ticketPayloadTemp.seats[0].isParent) {\r\n            for (let i = 0; i < ticketPayloadTemp.seats.length; i++) {\r\n                ticketPayloadTemp.seats[i].childSeats.forEach(\r\n                    (seats, index) => {\r\n                        ticketPayloadTemp.seats[i].childSeats[index].y =\r\n                            ticketPayloadTemp.seats[i].childSeats[index].y +\r\n                            ticketPayloadTemp.seats[i].sectionTopRightY\r\n\r\n                        ticketPayloadTemp.seats[i].childSeats[index].x =\r\n                            ticketPayloadTemp.seats[i].childSeats[index].x +\r\n                            ticketPayloadTemp.seats[i].sectionTopLeftX\r\n\r\n                        /*       seats.sectionTopRightY = seats.sectionTopLeftX + */\r\n                    }\r\n                )\r\n                tempStart = [\r\n                    ...tempStart,\r\n                    ...ticketPayloadTemp.seats[i].childSeats,\r\n                ]\r\n            }\r\n        }\r\n\r\n        const tempSeats = cloneObj(tempStart)\r\n        const shape = cloneObj(ticketPayload.shapes)\r\n\r\n        setShapes(shape)\r\n\r\n        const priceArray = {} as ISeatPriceColourMap\r\n\r\n        for (let i = 0; i < tempSeats.length; i++) {\r\n            if (tempSeats[i].pricePennies) {\r\n                const seatColour =\r\n                    SEAT_COLOURS[Math.floor(tempSeats[i].pricePennies / 1000)]\r\n                tempSeats[i].colour = seatColour\r\n\r\n                priceArray[seatColour] = {\r\n                    colour: seatColour,\r\n                    price: tempSeats[i].pricePennies,\r\n                } as ISeatPriceColour\r\n            }\r\n        }\r\n\r\n        const colourResult = Object.keys(priceArray).map(\r\n            (key) => priceArray[key]\r\n        )\r\n\r\n        setColourArray(colourResult)\r\n\r\n        setSeats(tempSeats)\r\n    }, [ticketPayload])\r\n\r\n    const handleColourClick = (colour?: string): void => {\r\n        setColourPicked(colour)\r\n    }\r\n\r\n    return (\r\n        <div\r\n            ref={seatPickerRef}\r\n            className={`seatpicker ${isDesktop ? 'seatpicker__modal' : ''}`}\r\n        >\r\n            <div className=\"seatpicker__zHeader\">\r\n                <h3 className=\"picker__prompt\">Choose your seats:</h3>\r\n                <div className=\"seatpicker__colours__contain\">\r\n                    <div className=\"seatpicker__colours\">\r\n                        <div\r\n                            onClick={() => handleColourClick(undefined)}\r\n                            className=\"seatpicker__priceShow\"\r\n                        >\r\n                            <span\r\n                                className=\"seatpicker__colourShow\"\r\n                                style={{ backgroundColor: '#444' }}\r\n                            />\r\n                            <span>ALL </span>\r\n                        </div>\r\n                        {colourArray\r\n                            .sort((a, b) => b.price - a.price)\r\n                            .map((colour, i) => {\r\n                                return (\r\n                                    <div\r\n                                        onClick={() => {\r\n                                            handleColourClick(colour.colour)\r\n                                        }}\r\n                                        className=\"seatpicker__priceShow\"\r\n                                        key={i}\r\n                                    >\r\n                                        <span\r\n                                            className=\"seatpicker__colourShow\"\r\n                                            style={{\r\n                                                backgroundColor: colour.colour,\r\n                                            }}\r\n                                        />\r\n                                        <span key={i}>\r\n                                            {`£${(colour.price / 100).toFixed(2)}`}\r\n                                        </span>\r\n                                    </div>\r\n                                )\r\n                            })}\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div className=\"seatpicker__modifierContain\">\r\n                <button\r\n                    id=\"seatPickerZoomIn\"\r\n                    className=\"btn primary-btn-white seatpicker__modifier\"\r\n                    onClick={() => {\r\n                        handleZoom('in')\r\n                    }}\r\n                >\r\n                    <img\r\n                        className=\"addTickets__iconMinus\"\r\n                        src={minus}\r\n                        alt=\"Decrease Tickets\"\r\n                    />\r\n                </button>\r\n\r\n                <button\r\n                    id=\"seatPickerZoomOut\"\r\n                    className=\"btn primary-btn-white seatpicker__modifier\"\r\n                    onClick={() => {\r\n                        handleZoom('out')\r\n                    }}\r\n                >\r\n                    <img\r\n                        className=\"addTickets__iconPlus\"\r\n                        src={plus}\r\n                        alt=\"Increase Tickets\"\r\n                    />\r\n                </button>\r\n            </div>\r\n\r\n            <div\r\n                className={\r\n                    selectedTickets\r\n                        ? `seatpicker__container seatpicker__container--selectedActive`\r\n                        : `seatpicker__container`\r\n                }\r\n            >\r\n                <animated.div\r\n                    className=\"seatPicker__card\"\r\n                    ref={ref}\r\n                    style={style}\r\n                >\r\n                    <div className=\"seatpicker__minified\">\r\n                        {shapes &&\r\n                            shapes.map((shape, i) => {\r\n                                const left = shape.x * widthDivide\r\n                                const leftSubtract = 0\r\n\r\n                                return (\r\n                                    <div\r\n                                        key={i}\r\n                                        style={{\r\n                                            position: 'absolute',\r\n                                            borderRadius:\r\n                                                shape.shapeBorderRadius + 'px',\r\n                                            width:\r\n                                                (shape.width * widthDivide) /\r\n                                                    2 +\r\n                                                'px',\r\n                                            height:\r\n                                                shape.height * heightDivide +\r\n                                                'px',\r\n                                            top: shape.y * heightDivide + 'px',\r\n                                            left: left - leftSubtract + 'px',\r\n                                        }}\r\n                                        className=\"seatpicker__shape\"\r\n                                    ></div>\r\n                                )\r\n                            })}\r\n                        {seats.map((prop, i) => {\r\n                            return (\r\n                                <div key={i}>\r\n                                    {!prop.sold === false && (\r\n                                        <div\r\n                                            className=\"seatpicker__unavailable\"\r\n                                            style={{\r\n                                                position: 'absolute',\r\n                                                minWidth: '3px',\r\n                                                minHeight: '4px',\r\n                                                width: widthDivide * 10 + 'px',\r\n                                                height: heightDivide * 9 + 'px',\r\n                                                top:\r\n                                                    prop.y * heightDivide +\r\n                                                    'px',\r\n                                                left:\r\n                                                    prop.x * widthDivide + 'px',\r\n                                            }}\r\n                                        />\r\n                                    )}\r\n                                    {!prop.sold === true && (\r\n                                        <div\r\n                                            className={`seatpicker__available ${prop.selected && 'ticketSelected'}`}\r\n                                            style={{\r\n                                                position: 'absolute',\r\n                                                minWidth: '4px',\r\n                                                minHeight: '5px',\r\n                                                width: widthDivide * 12 + 'px',\r\n                                                height:\r\n                                                    heightDivide * 11 + 'px',\r\n                                                top:\r\n                                                    prop.y * heightDivide +\r\n                                                    'px',\r\n                                                left:\r\n                                                    prop.x * widthDivide + 'px',\r\n                                                backgroundColor:\r\n                                                    !colourPicked ||\r\n                                                    prop.colour === colourPicked\r\n                                                        ? prop.colour\r\n                                                        : 'var(--middle)',\r\n                                            }}\r\n                                            onClick={(e) => {\r\n                                                handleClick(e, i)\r\n                                            }}\r\n                                        />\r\n                                    )}\r\n                                    {selectQ === i && (\r\n                                        <motion.div\r\n                                            initial=\"hidden\"\r\n                                            animate=\"visible\"\r\n                                            variants={{\r\n                                                hidden: { opacity: 0 },\r\n                                                visible: { opacity: 1 },\r\n                                            }}\r\n                                        >\r\n                                            <div\r\n                                                style={{\r\n                                                    position: 'absolute',\r\n                                                    top:\r\n                                                        prop.y * heightDivide +\r\n                                                        19 +\r\n                                                        'px',\r\n                                                    left:\r\n                                                        prop.x * widthDivide -\r\n                                                        1 +\r\n                                                        'px',\r\n                                                }}\r\n                                                className=\"seatpicker__boxArrow\"\r\n                                            />\r\n                                            <div\r\n                                                style={{\r\n                                                    position: 'absolute',\r\n                                                    top:\r\n                                                        prop.y * heightDivide +\r\n                                                        29 +\r\n                                                        'px',\r\n                                                    left:\r\n                                                        prop.x * widthDivide -\r\n                                                        35 +\r\n                                                        'px',\r\n                                                }}\r\n                                                className=\"seatpicker__selectQ seatpicker__selectQWidth\"\r\n                                            >\r\n                                                {prop.note}\r\n                                            </div>\r\n                                        </motion.div>\r\n                                    )}\r\n                                </div>\r\n                            )\r\n                        })}\r\n                    </div>\r\n                </animated.div>\r\n            </div>\r\n            {selectedTickets && (\r\n                <SelectedSeatDisplay selectedTickets={selectedTickets} />\r\n            )}\r\n            <div className=\"seatpicker__messageContainer\">\r\n                {seatMessage &&\r\n                    seatMessage[0] &&\r\n                    seatMessage.map((selection, i) => {\r\n                        return (\r\n                            <div\r\n                                className=\"seatpicker__messageSelected\"\r\n                                key={i}\r\n                            >\r\n                                <p className=\"seatpicker__selectedMessageDisplay\">\r\n                                    {selection}\r\n                                </p>\r\n                            </div>\r\n                        )\r\n                    })}\r\n                {maxMessage && maxMessage !== '' && (\r\n                    <p className=\"seatpicker__selectedMessageDisplay\">\r\n                        {maxMessage}\r\n                    </p>\r\n                )}\r\n            </div>\r\n            <SeatSelectionFooter\r\n                isSelected={selectedTickets && selectedTickets.length > 0}\r\n                selectAction={selectTickets}\r\n            />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default SeatPickerMulti\r\n","import React from \"react\";\r\n\r\nimport minus from \"../../../assets/Minus.png\";\r\nimport plus from \"../../../assets/Add.png\";\r\n\r\nimport \"./addsubtractquantity.css\";\r\n\r\ninterface IAddSubtractQuantityProps {\r\n    changeQuantityFunction: (increase: boolean) => void;\r\n    quantity?: number;\r\n}\r\n\r\nconst AddSubtractQuantity: React.FC<IAddSubtractQuantityProps> = ({ changeQuantityFunction, quantity = 0 }: IAddSubtractQuantityProps): JSX.Element => {\r\n    return (\r\n        <div className=\"AddSubtractQuantity\">\r\n            <button\r\n                className=\"btn primary-btn-white AddSubtractQuantity__button\"\r\n                id=\"Decrease\"\r\n                onClick={() => {\r\n                    changeQuantityFunction(false);\r\n                }}\r\n            >\r\n                <img\r\n                    className=\"AddSubtractQuantity__iconMinus\"\r\n                    src={minus}\r\n                    alt=\"Decrease\"\r\n                />\r\n            </button>\r\n            <span>{quantity}</span>\r\n            <button\r\n                className=\"btn primary-btn-white AddSubtractQuantity__button addTickets__modifierPlus\"\r\n                id=\"Increase\"\r\n                onClick={() => {\r\n                    changeQuantityFunction(true);\r\n                }}\r\n            >\r\n                <img\r\n                    className=\"AddSubtractQuantity__iconPlus\"\r\n                    src={plus}\r\n                    alt=\"Increase\"\r\n                />\r\n            </button>\r\n        </div>\r\n    );\r\n};\r\n\r\nexport default AddSubtractQuantity;\r\n","import React, { useState } from 'react'\r\n\r\nimport AddSubtractQuantity from './AddSubtractQuantity'\r\nimport './quantitypicker.css'\r\nimport { ITicketQuantityInfo } from '../../../interfaces/interfaces'\r\nimport { currencyFormat } from '../../../Helpers/utils'\r\n\r\ninterface IQuantityPickerProps {\r\n    ticketQuantityInfo: ITicketQuantityInfo\r\n    changeQuantityFunction: (increase: boolean) => void\r\n    changeDisabled?: boolean\r\n}\r\n\r\nconst QuantityPicker: React.FC<IQuantityPickerProps> = ({\r\n    ticketQuantityInfo,\r\n    changeQuantityFunction,\r\n    changeDisabled = false,\r\n}: IQuantityPickerProps): JSX.Element => {\r\n    const [showChildren, setShowChildren] = useState<boolean>(false)\r\n\r\n    const handleParentSelect = (): void => {\r\n        if (ticketQuantityInfo.children) {\r\n            setShowChildren(true)\r\n        } else {\r\n            return\r\n        }\r\n    }\r\n\r\n    return !changeDisabled ? (\r\n        <div className=\"QuantityPicker\">\r\n            <div\r\n                className=\"QuantityPicker__description\"\r\n                onClick={() => handleParentSelect()}\r\n            >\r\n                <div className=\"QuantityPicker__title\">\r\n                    {ticketQuantityInfo.children &&\r\n                        ticketQuantityInfo.children.length > 0 && (\r\n                            <span\r\n                                className={`QuantityPicker__circle${showChildren && ` QuantityPicker__childIndicator`}`}\r\n                            />\r\n                        )}\r\n                    <span>{ticketQuantityInfo.name}</span>\r\n                </div>\r\n                {ticketQuantityInfo.note && (\r\n                    <span className=\"QuantityPicker__subTitle\">\r\n                        {ticketQuantityInfo.note}\r\n                    </span>\r\n                )}\r\n            </div>\r\n            {(!ticketQuantityInfo.children ||\r\n                ticketQuantityInfo.children?.length === 0) && (\r\n                <div className=\"QuantityPicker__data\">\r\n                    {ticketQuantityInfo.price && (\r\n                        <span>{currencyFormat(ticketQuantityInfo.price)}</span>\r\n                    )}\r\n\r\n                    <AddSubtractQuantity\r\n                        changeQuantityFunction={changeQuantityFunction}\r\n                        quantity={ticketQuantityInfo.quantity}\r\n                    />\r\n                </div>\r\n            )}\r\n        </div>\r\n    ) : (\r\n        <></>\r\n    )\r\n}\r\n\r\nexport default QuantityPicker\r\n","import React, { useEffect } from 'react'\r\nimport './encoreseatwidget.css'\r\n\r\nimport { bookingLocale } from '../../../../../../Helpers/constants'\r\nimport { IWidgetData } from '../../../../../../interfaces/interfaces'\r\n\r\ninterface IWidgetDisplay {\r\n    widgetData: IWidgetData\r\n    quantity: number\r\n}\r\n\r\nconst WidgetDisplay: React.FC<IWidgetDisplay> = ({\r\n    widgetData,\r\n    quantity,\r\n}: IWidgetDisplay): React.JSX.Element => {\r\n    useEffect(() => {\r\n        const venueScript = document.createElement('script')\r\n        venueScript.src = `${widgetData.url}/v4/js/venue-app.js`\r\n        document.head.appendChild(venueScript)\r\n        return () => {\r\n            document.head.removeChild(venueScript)\r\n        }\r\n    }, [widgetData.url])\r\n\r\n    const widgetGetDateTime = (): { eventDate: string; eventTime: string } => {\r\n        const dateTimeArray = widgetData.sessionDateTime.split('T')\r\n\r\n        return {\r\n            eventDate: dateTimeArray[0],\r\n            eventTime: dateTimeArray[1].split(':').slice(0, 2).join(':'),\r\n        }\r\n    }\r\n\r\n    return (\r\n        <div className=\"EncoreSeatWidget__widget\">\r\n            <div\r\n                data-app=\"venue-app\"\r\n                data-view-name=\"seat-plan\"\r\n                data-channel-id={`${widgetData.channelId}`}\r\n                data-product-id={`${widgetData.eventId}`}\r\n                data-product-type=\"show\"\r\n                data-performance-type=\"A\"\r\n                data-performance-date={`${widgetGetDateTime().eventDate}`}\r\n                data-performance-time={`${widgetGetDateTime().eventTime}`}\r\n                data-quantity={quantity}\r\n                data-api-path={widgetData.url}\r\n                data-user-locale={bookingLocale}\r\n                data-suppress-addtobasket={true}\r\n                data-venue-api-url={`${widgetData.url}/v4`}\r\n                data-labels-config='{ \"seatSummary\":{ \"addToBasket\":{ \"en-GB\":\"Add seats to order\"}}}'\r\n            ></div>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default WidgetDisplay\r\n","import React, { useEffect, useState } from 'react'\r\nimport './encoreseatwidget.css'\r\nimport QuantityPicker from '../../../../../Shared/QuantityPicker/QuantityPicker'\r\nimport WidgetDisplay from './WidgetDisplay'\r\nimport {\r\n    incrementTickets,\r\n    setTypeComponentOpen,\r\n} from '../../../../../../redux/ticketSlice'\r\nimport {\r\n    IEncoreSeatWidgetBookingData,\r\n    IWidgetData,\r\n} from '../../../../../../interfaces/interfaces'\r\nimport { useAppDispatch } from '../../../../../../redux/store'\r\n\r\ninterface ISelectedWidgetSeat {\r\n    id: string\r\n    groupName: string\r\n    row: string\r\n    number: string\r\n    aggregateReference: string //?\r\n    salePrice: number\r\n    decimalPlaces: number // ?\r\n    currency: string\r\n    orderFee: {\r\n        value: number\r\n        decimalPlaces: number // ?\r\n        currency: string\r\n    }\r\n}\r\n\r\nexport interface ISelectedSeat {\r\n    seatId: string\r\n    name: string\r\n    friendlyName: string\r\n    quantity: number\r\n    externalId: string\r\n    pricePennies: number\r\n    inclusionBookingFeePennies: number\r\n}\r\n\r\ninterface IEncoreSeatWidgetProps {\r\n    widgetData: IWidgetData\r\n    maxQuantity: number\r\n    ticketBookingData: IEncoreSeatWidgetBookingData\r\n}\r\n\r\nconst EncoreSeatWidget: React.FC<IEncoreSeatWidgetProps> = ({\r\n    widgetData,\r\n    maxQuantity,\r\n    ticketBookingData,\r\n}: IEncoreSeatWidgetProps): JSX.Element => {\r\n    /*\r\n  Widget data should include\r\n  venueId\r\n  eventId\r\n  performanceId\r\n  sessionDateTime\r\n  */\r\n\r\n    const [selectedSeats, setSelectedSeats] = useState<\r\n        ISelectedSeat[] | undefined\r\n    >(undefined)\r\n    const [ticketQuantityForSelection, setTicketQuantityForSelection] =\r\n        useState<number>(1)\r\n    const [quantityChosen, setTicketquantityChosen] = useState<boolean>(false)\r\n\r\n    const dispatch = useAppDispatch()\r\n\r\n    const ticketQuantityInfo = {\r\n        quantity: ticketQuantityForSelection,\r\n        name: 'Number of Tickets',\r\n        note: `Choose the number of seats/tickets you want to pick (max ${maxQuantity})`,\r\n    }\r\n\r\n    const convertCurrency = (\r\n        conversionValue: number,\r\n        dp: number,\r\n        currencyCode: string\r\n    ): number => {\r\n        // this may need to be added as reusable elsewhere, but putting this here\r\n        // for not to deal with conversion from pounds to pennies.\r\n\r\n        //converts returned value into base fractional units i.e. pounds into pennies\r\n\r\n        if (conversionValue > 0) {\r\n            switch (currencyCode) {\r\n                case 'GBP':\r\n                    if (dp === 2) {\r\n                        return conversionValue * 100\r\n                    } else {\r\n                        return conversionValue\r\n                    }\r\n\r\n                default:\r\n                    return 0\r\n            }\r\n        } else {\r\n            return 0\r\n        }\r\n    }\r\n\r\n    useEffect(() => {\r\n        function addToBasket(e: Event) {\r\n            e.preventDefault()\r\n\r\n            const selectedSeatDetails = (e as CustomEvent).detail\r\n                .selectedElement as ISelectedWidgetSeat[]\r\n\r\n            if (selectedSeatDetails && selectedSeatDetails.length > 0) {\r\n                const seatDetails = selectedSeatDetails.map((selectedSeat) => {\r\n                    let alreadySelected = undefined\r\n\r\n                    if (selectedSeats) {\r\n                        alreadySelected = selectedSeats.find(\r\n                            (seatAlreadySelected) =>\r\n                                seatAlreadySelected.seatId === selectedSeat.id\r\n                        ) as ISelectedSeat\r\n\r\n                        return alreadySelected\r\n                    } else {\r\n                        return {\r\n                            name: selectedSeat.id,\r\n                            friendlyName: `${selectedSeat.groupName} Row ${selectedSeat.row} Seat ${selectedSeat.number}`,\r\n                            quantity: 1,\r\n                            externalId: selectedSeat.aggregateReference,\r\n                            pricePennies: convertCurrency(\r\n                                selectedSeat.salePrice,\r\n                                selectedSeat.decimalPlaces,\r\n                                selectedSeat.currency\r\n                            ),\r\n                            inclusionBookingFeePennies: convertCurrency(\r\n                                selectedSeat.orderFee.value,\r\n                                selectedSeat.orderFee.decimalPlaces,\r\n                                selectedSeat.orderFee.currency\r\n                            ),\r\n                            seatId: selectedSeat.id,\r\n                        }\r\n                    }\r\n                })\r\n\r\n                if (seatDetails) {\r\n                    setSelectedSeats(seatDetails)\r\n\r\n                    const tempSelectedTickets = {\r\n                        attractionId: ticketBookingData.attractionId,\r\n                        eventId: ticketBookingData.eventId,\r\n                        sessionId: ticketBookingData.sessionId,\r\n                        ticketTypes: seatDetails,\r\n                        hasSeatpicker: true,\r\n                        promotionalMessage:\r\n                            ticketBookingData.promotionalMessage,\r\n                    }\r\n                    dispatch(incrementTickets(tempSelectedTickets))\r\n                    dispatch(setTypeComponentOpen(false))\r\n                }\r\n            }\r\n        }\r\n\r\n        window.addEventListener(\r\n            'venue-app_selected-seats-summary-on-addtobasket',\r\n            addToBasket\r\n        )\r\n        return () => {\r\n            window.removeEventListener(\r\n                'venue-app_selected-seats-summary-on-addtobasket',\r\n                addToBasket\r\n            )\r\n        }\r\n    }, [])\r\n\r\n    const changeWidgetTicketQuantity = (increase: boolean): void => {\r\n        //increase is true its increment and not its decrement\r\n        if (increase && ticketQuantityForSelection + 1 <= maxQuantity) {\r\n            setTicketQuantityForSelection(ticketQuantityForSelection + 1)\r\n        } else if (!increase && ticketQuantityForSelection > 1) {\r\n            setTicketQuantityForSelection(ticketQuantityForSelection - 1)\r\n        }\r\n    }\r\n\r\n    const changeChoosingQuanity = (): void => {\r\n        setTicketquantityChosen(!quantityChosen)\r\n    }\r\n\r\n    return (\r\n        <>\r\n            <div className=\"EncoreSeatWidget\">\r\n                <QuantityPicker\r\n                    ticketQuantityInfo={ticketQuantityInfo}\r\n                    changeQuantityFunction={changeWidgetTicketQuantity}\r\n                    changeDisabled={quantityChosen}\r\n                />\r\n\r\n                <button\r\n                    onClick={changeChoosingQuanity}\r\n                    className=\"btn primary-btn btn-small\"\r\n                >\r\n                    {quantityChosen\r\n                        ? 'Change Ticket Quantity'\r\n                        : 'Confirm Quantity Required'}\r\n                </button>\r\n\r\n                {quantityChosen && (\r\n                    <WidgetDisplay\r\n                        widgetData={widgetData}\r\n                        quantity={ticketQuantityForSelection}\r\n                    />\r\n                )}\r\n            </div>\r\n        </>\r\n    )\r\n}\r\n\r\nexport default EncoreSeatWidget\r\n","import React, { useEffect, useState } from 'react'\r\nimport { setTypeComponentOpen } from '../../../../redux/ticketSlice'\r\nimport SeatPicker from '../TypeComponent/Seatpicker/SeatPicker'\r\nimport SeatPickerMulti from '../TypeComponent/Seatpicker/SeatPickerMulti'\r\nimport Modal from '../../../Shared/Modal/ReusableModal'\r\nimport { AnimatePresence } from 'framer-motion'\r\nimport EncoreSeatWidget from '../TypeComponent/Seatpicker/EncoreWidget/EncoreSeatWidget'\r\nimport { IBookingTicketState } from '../../../../interfaces/interfaces'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\n\r\ninterface ITicketTypeProps {\r\n    ticketPayload: IBookingTicketState\r\n}\r\n\r\nconst TicketType: React.FC<ITicketTypeProps> = ({\r\n    ticketPayload,\r\n}: ITicketTypeProps): JSX.Element => {\r\n    const { bookingObject, ticketTypeSelected } = useAppSelector(\r\n        (state) => state.tickets\r\n    )\r\n    const dispatch = useAppDispatch()\r\n    const [timeoutFix, setTimeoutFix] = useState(false)\r\n\r\n    useEffect(() => {\r\n        if (\r\n            bookingObject.ticketObject.seats &&\r\n            bookingObject.ticketObject.seats[0]\r\n        ) {\r\n            setTimeout(() => {\r\n                setTimeoutFix(true)\r\n            }, 0)\r\n\r\n            return\r\n        }\r\n\r\n        if (\r\n            bookingObject.sessionSelected.sessionId &&\r\n            !bookingObject.ticketObject.timeout\r\n        ) {\r\n            setTimeout(() => {\r\n                setTimeoutFix(true)\r\n            }, 0)\r\n        }\r\n    }, [bookingObject.sessionSelected, bookingObject.ticketObject])\r\n\r\n    const encoreWidgetAndData = (): JSX.Element => {\r\n        const relevantData = {\r\n            attractionId: ticketPayload.attractionId,\r\n            eventId: ticketPayload.eventId,\r\n            sessionId: ticketPayload.sessionId,\r\n            promotionalMessage: ticketPayload.promotionalMessage,\r\n        }\r\n\r\n        return (\r\n            <EncoreSeatWidget\r\n                widgetData={ticketPayload.widgetDetails}\r\n                maxQuantity={ticketPayload.maxPartySize}\r\n                ticketBookingData={relevantData}\r\n            />\r\n        )\r\n    }\r\n\r\n    return (\r\n        <div className=\"ticketType\">\r\n            <p>Where would you like to sit?</p>\r\n            {bookingObject.sessionSelected.date && timeoutFix ? (\r\n                <button\r\n                    id=\"whereWouldYoulikeToSit\"\r\n                    onClick={() => {\r\n                        dispatch(setTypeComponentOpen(true))\r\n                    }}\r\n                    className={`btn ${\r\n                        ticketTypeSelected ||\r\n                        (bookingObject.ticketComplete &&\r\n                            bookingObject.ticketComplete.ticketTypes &&\r\n                            bookingObject.ticketComplete.ticketTypes.length > 0)\r\n                            ? 'primary-btn-white btn-border'\r\n                            : 'primary-btn-white'\r\n                    } btn-large`}\r\n                >\r\n                    {ticketTypeSelected ? (\r\n                        <>{ticketTypeSelected.type}</>\r\n                    ) : (\r\n                        <>\r\n                            <>\r\n                                {bookingObject.ticketComplete &&\r\n                                bookingObject.ticketComplete.ticketTypes &&\r\n                                bookingObject.ticketComplete.ticketTypes\r\n                                    .length > 0 ? (\r\n                                    <>Change </>\r\n                                ) : (\r\n                                    <>Select </>\r\n                                )}\r\n                            </>\r\n                            your{' '}\r\n                            {!bookingObject.usesSeatPicker ? (\r\n                                <>ticket type</>\r\n                            ) : (\r\n                                <>seats</>\r\n                            )}\r\n                        </>\r\n                    )}\r\n                </button>\r\n            ) : (\r\n                <button className=\"btn primary-btn-white-disabled btn-large\">\r\n                    Please select a date first\r\n                </button>\r\n            )}\r\n            <AnimatePresence>\r\n                {bookingObject.usesSeatPicker && (\r\n                    <Modal\r\n                        noScroll={false}\r\n                        element={\r\n                            document.querySelector('.ticket__container') ||\r\n                            undefined\r\n                        }\r\n                        onClose={() => dispatch(setTypeComponentOpen(false))}\r\n                    >\r\n                        {ticketPayload.useWidget ? (\r\n                            encoreWidgetAndData()\r\n                        ) : ticketPayload.seats &&\r\n                          ticketPayload.seats[0].isParent ? (\r\n                            <SeatPickerMulti ticketPayload={ticketPayload} />\r\n                        ) : (\r\n                            <SeatPicker ticketPayload={ticketPayload} />\r\n                        )}\r\n                    </Modal>\r\n                )}\r\n            </AnimatePresence>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default TicketType\r\n","import React, { lazy, Suspense, useContext, useEffect, useState } from 'react'\r\nimport { useNavigate } from 'react-router'\r\nimport { AnimatePresence, motion } from 'framer-motion'\r\nimport './TicketsHome.css'\r\nimport Card from '../../Components/Card/Card'\r\nimport DatesAvailable from '../../Components/DateTime/DatesAvailable'\r\nimport AddTickets from '../../Components/AddTickets/AddTickets'\r\nimport HomeSummary from '../../Components/HomeSummary/HomeSummary'\r\n\r\nimport {\r\n    apiLoading,\r\n    setBookingProgress,\r\n    setTimeLeft,\r\n    setUsesSeatPicker,\r\n} from '../../../../redux/ticketSlice'\r\n\r\nimport Variants from '../../../../Helpers/pageVariants'\r\nimport ErrorHandler from '../../../Shared/ErrorHandler/ErrorHandler'\r\nimport Loader from '../../../Shared/Loader/Loader'\r\nimport PageContainer from '../../BookingPages/PageContainer'\r\nimport { isDesktop } from 'react-device-detect'\r\nimport { CHECK_TIMESTAMP } from '../../../../Helpers/AUTH.resource'\r\nimport TicketType from '../../Components/TicketType/TicketType'\r\nimport API from '../../../../axios/API'\r\nimport { LogoSVGComponent } from '../../../Shared/SVG/logoSVG'\r\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store'\r\nimport GiftAid, { GiftAidStatusEnum } from '../../Features/GiftAid/GiftAid'\r\nimport ReusableModal from '../../../Shared/Modal/ReusableModal'\r\nimport NavBarGeneral from '../../../NavBarGeneral/NavBarGeneral'\r\nimport { GlobalContext } from '../../../../Context/GlobalContext'\r\n\r\nconst OrderComplete = lazy(() => import('../OrderComplete/OrderComplete'))\r\nconst Confirmation = lazy(() => import('../Confirmation/Confirmation'))\r\n\r\nconst pageVariants = Variants.defaultPageVariants\r\n\r\ninterface ITicketsHomeProps {\r\n    sessionsAvailable: boolean\r\n}\r\n\r\nconst TicketsHome: React.FC<ITicketsHomeProps> = ({\r\n    sessionsAvailable,\r\n}: ITicketsHomeProps): React.JSX.Element => {\r\n    const global = useContext(GlobalContext)\r\n    const dispatch = useAppDispatch()\r\n    const history = useNavigate()\r\n    const Loading = useAppSelector(apiLoading)\r\n    const bookingObject = useAppSelector((state) => state.tickets.bookingObject)\r\n\r\n    // const trustpilotRef = useRef<HTMLDivElement>(null)\r\n\r\n    const [showBookingError, setShowBookingError] = useState<boolean>(false)\r\n    const [showCloseConfirmation, setShowCloseConfirmation] =\r\n        useState<boolean>(false)\r\n    const [giftAidStatus, setGiftAidStatus] = useState<number>(\r\n        GiftAidStatusEnum.none\r\n    )\r\n\r\n    const attractionName = global.attractionName ?? global.name ?? ''\r\n\r\n    const zeroPad = (num: number, places: number): string =>\r\n        String(num).padStart(places, '0')\r\n\r\n    const refreshPage = (): void => {\r\n        const currentPage = window.location.href\r\n        window.location.href = currentPage\r\n    }\r\n\r\n    // useEffect(() => {\r\n    //     if (window.trustpilot && trustpilotRef.current !== null) {\r\n    //         window.trustpilot.loadFromElement(trustpilotRef.current, true)\r\n    //     }\r\n    // }, [trustpilotRef])\r\n\r\n    useEffect(() => {\r\n        if (bookingObject.ticketObjectDeepCopy.giftAidDefault) {\r\n            setGiftAidStatus(GiftAidStatusEnum.giftAid)\r\n        }\r\n    }, [bookingObject.ticketObjectDeepCopy.giftAidDefault])\r\n\r\n    useEffect(() => {\r\n        if (\r\n            bookingObject.errorObject &&\r\n            bookingObject.errorObject.status !== undefined\r\n        ) {\r\n            setShowBookingError(true)\r\n        }\r\n    }, [bookingObject.errorObject])\r\n\r\n    useEffect(() => {\r\n        if (!bookingObject.showTime || !bookingObject.timeLeft) {\r\n            return\r\n        }\r\n\r\n        let t = bookingObject.timeLeft * 60000\r\n\r\n        switch (bookingObject.timeoutTimeUnit) {\r\n            case 4:\r\n                t *= 7\r\n                break\r\n            case 3:\r\n                t *= 24\r\n                break\r\n            case 2:\r\n                t *= 60\r\n                break\r\n        }\r\n\r\n        const timeToCompleteMS = new Date(Date.now() + t)\r\n\r\n        ;(function timer() {\r\n            const now = new Date()\r\n            const dist = timeToCompleteMS.valueOf() - now.valueOf()\r\n            let seconds = Math.floor(dist / 1000)\r\n            let minutes = Math.floor(seconds / 60)\r\n            const hours = Math.floor(minutes / 60)\r\n\r\n            minutes %= 60\r\n            seconds %= 60\r\n\r\n            dispatch(\r\n                setTimeLeft([\r\n                    zeroPad(hours, 2),\r\n                    zeroPad(minutes, 2),\r\n                    zeroPad(seconds, 2),\r\n                ])\r\n            )\r\n\r\n            if (dist > 0) {\r\n                setTimeout(timer, 1000)\r\n            } else {\r\n                dispatch(setBookingProgress('ticket-expired'))\r\n            }\r\n        })()\r\n    }, [\r\n        bookingObject.showTime,\r\n        bookingObject.timeLeft,\r\n        bookingObject.timeoutTimeUnit,\r\n        dispatch,\r\n    ])\r\n\r\n    useEffect(() => {\r\n        if (\r\n            bookingObject.bookingProgress === 'ticket-expired' &&\r\n            bookingObject.reserveResponse\r\n        ) {\r\n            void CHECK_TIMESTAMP(true).then((jwt) => {\r\n                if (jwt && bookingObject.reserveResponse) {\r\n                    void API.cancelBooking(\r\n                        bookingObject.reserveResponse,\r\n                        55,\r\n                        jwt\r\n                    )\r\n                }\r\n            })\r\n        }\r\n    }, [bookingObject.bookingProgress, bookingObject.reserveResponse])\r\n\r\n    const closeAction = (): void => {\r\n        if (bookingObject.reserveResponse) {\r\n            void CHECK_TIMESTAMP(true).then((jwt) => {\r\n                if (jwt && bookingObject.reserveResponse) {\r\n                    void API.cancelBooking(\r\n                        bookingObject.reserveResponse,\r\n                        55,\r\n                        jwt\r\n                    ).then(() => {\r\n                        history(0)\r\n                    })\r\n                } else {\r\n                    history(0)\r\n                }\r\n            })\r\n        } else history(0)\r\n    }\r\n\r\n    const ticketContain =\r\n        bookingObject?.ticketObjectDeepCopy?.useWidget &&\r\n        bookingObject?.usesSeatPicker\r\n            ? 'ticket__container usesWidget'\r\n            : 'ticket__container'\r\n\r\n    return (\r\n        <>\r\n            <div className={ticketContain}>\r\n                {showCloseConfirmation && (\r\n                    <ReusableModal full={false} headerTitle=\"Exit booking?\">\r\n                        <span>\r\n                            <button\r\n                                id=\"exitBooking\"\r\n                                onClick={() => setShowCloseConfirmation(false)}\r\n                                className=\"btn primary-btn-white btn-large btn-border btn-shorter btn-fontLarger\"\r\n                            >\r\n                                Cancel\r\n                            </button>\r\n                            <button\r\n                                id=\"cancelExitBooking\"\r\n                                onClick={closeAction}\r\n                                className=\"btn primary-btn btn-border btn-large btn-shorter btn-fontLarger\"\r\n                            >\r\n                                Exit\r\n                            </button>\r\n                        </span>\r\n                    </ReusableModal>\r\n                )}\r\n                {bookingObject.bookingProgress === 'complete' || isDesktop || (\r\n                    <NavBarGeneral\r\n                        logoUrl={global.logoUrl}\r\n                        onClose={() => setShowCloseConfirmation(true)}\r\n                        showLogo={false}\r\n                    />\r\n                )}\r\n                <div className=\"ticket__containerBody\">\r\n                    {Loading && <Loader messages={Loading} />}\r\n                    {showBookingError ? (\r\n                        <ErrorHandler errorObject={bookingObject.errorObject} />\r\n                    ) : (\r\n                        <>\r\n                            {bookingObject.bookingProgress === 'home' ? (\r\n                                <div className=\"tickets-home\">\r\n                                    <AnimatePresence>\r\n                                        <motion.div\r\n                                            initial=\"initial\"\r\n                                            animate=\"in\"\r\n                                            exit=\"out\"\r\n                                            variants={pageVariants}\r\n                                            style={\r\n                                                isDesktop\r\n                                                    ? { minHeight: '860px' }\r\n                                                    : { minHeight: 'auto' }\r\n                                            }\r\n                                        >\r\n                                            <>\r\n                                                <Card\r\n                                                    image={global.image}\r\n                                                    title={global.name}\r\n                                                    content={global.summary}\r\n                                                    ikBase={global.urlMedia}\r\n                                                />\r\n                                                {sessionsAvailable ? (\r\n                                                    <>\r\n                                                        <DatesAvailable />\r\n                                                        {bookingObject?.usesSeatPicker && (\r\n                                                            <TicketType\r\n                                                                ticketPayload={\r\n                                                                    bookingObject.ticketObjectDeepCopy\r\n                                                                }\r\n                                                            />\r\n                                                        )}\r\n                                                        {bookingObject\r\n                                                            ?.ticketObjectDeepCopy\r\n                                                            ?.ticketTypes &&\r\n                                                            !bookingObject\r\n                                                                ?.ticketObjectDeepCopy\r\n                                                                ?.useWidget && (\r\n                                                                <>\r\n                                                                    <AddTickets\r\n                                                                        giftAidStatus={\r\n                                                                            giftAidStatus\r\n                                                                        }\r\n                                                                        // ticketsShow\r\n                                                                        // setTicketsShow\r\n                                                                        addTickets={\r\n                                                                            bookingObject.ticketObjectDeepCopy\r\n                                                                        }\r\n                                                                    />\r\n                                                                    {bookingObject\r\n                                                                        .ticketObjectDeepCopy\r\n                                                                        .showGiftAid && (\r\n                                                                        <GiftAid\r\n                                                                            status={\r\n                                                                                giftAidStatus\r\n                                                                            }\r\n                                                                            setStatus={\r\n                                                                                setGiftAidStatus\r\n                                                                            }\r\n                                                                        />\r\n                                                                    )}\r\n                                                                </>\r\n                                                            )}\r\n                                                        {bookingObject.ticketComplete &&\r\n                                                            !bookingObject?.usesSeatPicker &&\r\n                                                            bookingObject\r\n                                                                ?.ticketObjectDeepCopy\r\n                                                                ?.useWidget && (\r\n                                                                <button\r\n                                                                    onClick={() =>\r\n                                                                        dispatch(\r\n                                                                            setUsesSeatPicker(\r\n                                                                                true\r\n                                                                            )\r\n                                                                        )\r\n                                                                    }\r\n                                                                    className=\"btn primary-btn btn-large btn-shorter\"\r\n                                                                >\r\n                                                                    Choose\r\n                                                                    Different\r\n                                                                    Seats\r\n                                                                </button>\r\n                                                            )}\r\n\r\n                                                        <HomeSummary\r\n                                                            giftAidStatus={\r\n                                                                giftAidStatus\r\n                                                            }\r\n                                                        />\r\n                                                    </>\r\n                                                ) : (\r\n                                                    <div className=\"TicketsHome__noTickets\">\r\n                                                        There are no tickets\r\n                                                        available for this event\r\n                                                    </div>\r\n                                                )}\r\n                                            </>\r\n                                        </motion.div>\r\n                                    </AnimatePresence>\r\n                                </div>\r\n                            ) : (\r\n                                <>\r\n                                    <Suspense\r\n                                        fallback={\r\n                                            <Loader\r\n                                                messages={['Loading']}\r\n                                            ></Loader>\r\n                                        }\r\n                                    >\r\n                                        {bookingObject.bookingProgress ===\r\n                                            'notes' && <PageContainer />}\r\n                                        {bookingObject.bookingProgress ===\r\n                                            'summary' && <Confirmation />}\r\n                                        {bookingObject.bookingProgress ===\r\n                                            'complete' && <OrderComplete />}\r\n                                        {bookingObject.bookingProgress ===\r\n                                            'ticket-expired' && (\r\n                                            <div className=\"tickets-home text-center\">\r\n                                                <h1>Reservation expired</h1>\r\n                                                <p>\r\n                                                    This reservation has\r\n                                                    expired, please book again\r\n                                                </p>\r\n                                                <br />\r\n                                                <button\r\n                                                    id=\"expiredReservationRefreshButton\"\r\n                                                    className=\"btn primary-btn btn-large btn-shorter\"\r\n                                                    onClick={refreshPage}\r\n                                                >\r\n                                                    Continue\r\n                                                </button>\r\n                                            </div>\r\n                                        )}\r\n                                    </Suspense>\r\n                                </>\r\n                            )}\r\n                        </>\r\n                    )}\r\n                </div>\r\n                {bookingObject.bookingProgress === 'complete' ||\r\n                    (global.partnerId ? (\r\n                        <div className=\"ticket__footer\">\r\n                            <p className=\"ticket__poweredBy\">\r\n                                Powered by{' '}\r\n                                <LogoSVGComponent showStrapline={false} />\r\n                            </p>\r\n                        </div>\r\n                    ) : (\r\n                        <div className=\"ticket__footer ticket__footer--accent\">\r\n                            {/*<div*/}\r\n                            {/*    ref={trustpilotRef}*/}\r\n                            {/*    className=\"trustpilot-widget\"*/}\r\n                            {/*    data-locale=\"en-GB\"*/}\r\n                            {/*    data-template-id=\"5419b6a8b0d04a076446a9ad\"*/}\r\n                            {/*    data-businessunit-id=\"61f964fddf56a5eafedb714e\"*/}\r\n                            {/*    data-style-height=\"24px\"*/}\r\n                            {/*    data-style-width=\"100%\"*/}\r\n                            {/*    data-theme=\"dark\"*/}\r\n                            {/*    data-min-review-count=\"10\"*/}\r\n                            {/*>*/}\r\n                            {/*    <a*/}\r\n                            {/*        href=\"https://uk.trustpilot.com/review/lovetovisit.com\"*/}\r\n                            {/*        target=\"_blank\"*/}\r\n                            {/*        rel=\"noreferrer\"*/}\r\n                            {/*    >*/}\r\n                            {/*        Trustpilot*/}\r\n                            {/*    </a>*/}\r\n                            {/*</div>*/}\r\n                        </div>\r\n                    ))}\r\n            </div>\r\n        </>\r\n    )\r\n}\r\n\r\nexport default TicketsHome\r\n","import React from \"react\";\r\nimport \"./Widget.css\";\r\n\r\ninterface IMobileContainProps{\r\n    children: string | JSX.Element | JSX.Element[];\r\n}\r\n\r\nconst MobileContain: React.FC<IMobileContainProps> = ({ children }: IMobileContainProps): JSX.Element => {\r\n    return <div className=\"MobileContain\">{children}</div>;\r\n};\r\n\r\nexport default MobileContain;\r\n","import './booking.css'\r\nimport React, { useContext, useEffect, useState } from 'react'\r\nimport { isDesktop, isTablet } from 'react-device-detect'\r\n\r\n// STORE\r\nimport { useAppDispatch, useAppSelector } from '../../redux/store'\r\nimport { getDates, reserveDates, setSession } from '../../redux/ticketSlice'\r\n\r\n// CONTEXT\r\nimport { GlobalContext } from '../../Context/GlobalContext'\r\n\r\n// COMPONENTS\r\nimport BookingButton from './BookingButton/BookingButton'\r\nimport TicketsHome from './BookingScreens/TicketsHome/TicketsHome'\r\nimport MobileContain from '../Shared/Widget/MobileContain'\r\n\r\n// INTERFACES\r\nimport { IReserveDates } from '../../interfaces/interfaces'\r\n\r\nconst Booking: React.FC = (): React.JSX.Element => {\r\n    const global = useContext(GlobalContext)\r\n    const dispatch = useAppDispatch()\r\n    const bookingObject = useAppSelector((state) => state.tickets.bookingObject)\r\n\r\n    const [showMobileBooking, setShowMobileBooking] = useState<boolean>(false)\r\n    const [sessionsAvailable] = useState<boolean>(true)\r\n\r\n    useEffect(() => {\r\n        if (isDesktop || isTablet || global.bookingOnly !== undefined) {\r\n            setShowMobileBooking(true)\r\n        }\r\n    }, [global.bookingOnly])\r\n\r\n    useEffect(() => {\r\n        if (bookingObject.sessionSelected.date) {\r\n            return\r\n        }\r\n\r\n        void dispatch(getDates(global))\r\n    }, [bookingObject.sessionSelected.date, dispatch, global])\r\n\r\n    const continueSession = (\r\n        date?: string | null,\r\n        time?: string | null,\r\n        sessionId?: number | null\r\n    ): void => {\r\n        if (sessionId === null || bookingObject.sessions.length === 0) {\r\n            return\r\n        }\r\n\r\n        let temp = {\r\n            date: date,\r\n            sessionId: sessionId,\r\n            time: time,\r\n        }\r\n        const ticketTypeObj = {\r\n            sessionId: sessionId,\r\n            ids: bookingObject.ids,\r\n        } as IReserveDates\r\n        void dispatch(reserveDates(ticketTypeObj))\r\n        dispatch(setSession(temp))\r\n    }\r\n\r\n    useEffect(() => {\r\n        if (\r\n            bookingObject.sessions === null ||\r\n            bookingObject.sessions.length === 0\r\n        ) {\r\n            return\r\n        }\r\n\r\n        let sessionId = null\r\n        let date = null\r\n        let time = null\r\n\r\n        const sessionData = sessionStorage.getItem('basketSession')\r\n\r\n        if (sessionData !== null) {\r\n            const parsedSessionData = JSON.parse(sessionData)\r\n            sessionId = parseInt(parsedSessionData.sessionId)\r\n            date = parsedSessionData.sessionDate\r\n            time = parsedSessionData.sessionTime\r\n\r\n            sessionStorage.removeItem('basketSession')\r\n        } else if (bookingObject.sessionType === 3) {\r\n            sessionId = bookingObject.sessions[0].sessionId\r\n        }\r\n\r\n        continueSession(date, time, sessionId)\r\n    }, [bookingObject.sessions])\r\n\r\n    return isDesktop || isTablet ? (\r\n        <TicketsHome sessionsAvailable={sessionsAvailable} />\r\n    ) : (\r\n        <>\r\n            {showMobileBooking ? (\r\n                <MobileContain>\r\n                    <TicketsHome sessionsAvailable={sessionsAvailable} />\r\n                </MobileContain>\r\n            ) : (\r\n                <BookingButton\r\n                    clickHandler={() => setShowMobileBooking(true)}\r\n                />\r\n            )}\r\n        </>\r\n    )\r\n}\r\n\r\nexport default Booking\r\n","import React from 'react'\r\nimport './ticketcountdown.css'\r\nimport { useAppSelector } from '../../../../redux/store'\r\n\r\nconst TicketCountdown: React.FC = (): JSX.Element => {\r\n    const countdown = useAppSelector((state) => state.tickets.countdown)\r\n\r\n    return (\r\n        <div className=\"TicketCountdown\">\r\n            <p className=\"note\">\r\n                These tickets will be reserved for {countdown}\r\n            </p>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default TicketCountdown\r\n","import React from 'react'\r\nimport Modal from '../../../Shared/Modal/ReusableModal'\r\n\r\ninterface IGiftAidLabelProps {\r\n    className: string\r\n}\r\n\r\ninterface IGiftAidModal {\r\n    labelText?: string\r\n    labelProps?: IGiftAidLabelProps\r\n}\r\n\r\nexport const GiftAidModal: React.FC<IGiftAidModal> = (\r\n    props: IGiftAidModal\r\n): React.JSX.Element => {\r\n    const { labelText = 'Gift Aid', labelProps } = props\r\n    const [showMoreInfo, setShowMoreInfo] = React.useState<boolean>(false)\r\n\r\n    return (\r\n        <>\r\n            {showMoreInfo && (\r\n                <Modal\r\n                    element={document.querySelector('.gift-aid') ?? undefined}\r\n                    headerTitle=\"About Gift Aid\"\r\n                    onClose={() => setShowMoreInfo(false)}\r\n                >\r\n                    <p>{`If you are a UK tax payer, you can help to support our charitable work by choosing to Gift Aid your admission.`}</p>\r\n                    <p>\r\n                        {`Some of our tickets contain a small, suggested donation to the charity. You can choose not to pay this donation if you wish,\r\n                        but without it we cannot claim Gift Aid. With it, we can claim back the tax on the whole amount of your admission from Government,\r\n                        which works out to an extra 25p for every £1 you spend.`}\r\n                    </p>\r\n                    <p>\r\n                        {`There's no need to complete any forms, we'll just ask for a few details when you pay.\r\n                        If you are purchasing tickets online, you can simply tick the certification box.`}\r\n                    </p>\r\n                    <p>\r\n                        {`Please note that in choosing a Gift Aid payment you acknowledge that you pay sufficient income or capital gains\r\n                        tax over the year to cover the donation you have made today.`}\r\n                    </p>\r\n                    <p className=\"text-center\">Thank you</p>\r\n                </Modal>\r\n            )}\r\n            <h3 {...labelProps}>\r\n                {labelText} -{' '}\r\n                <button\r\n                    className=\"btn link\"\r\n                    onClick={() => {\r\n                        window.scrollTo({ top: 0, behavior: 'smooth' })\r\n                        setShowMoreInfo(true)\r\n                    }}\r\n                >\r\n                    more information\r\n                </button>\r\n            </h3>\r\n        </>\r\n    )\r\n}\r\n","import React, { useEffect, useState } from 'react'\r\nimport './Checkbox.css'\r\n\r\nexport enum Sizes {\r\n    small = 'sm',\r\n    medium = 'md',\r\n    large = 'lg',\r\n}\r\n\r\ninterface ICheckbox {\r\n    isChecked: boolean\r\n    handleChanged: (isChecked: boolean) => void\r\n    label: string\r\n    size?: Sizes\r\n}\r\n\r\nconst Checkbox: React.FC<ICheckbox> = ({\r\n    isChecked,\r\n    handleChanged,\r\n    label,\r\n    size = Sizes.medium,\r\n}: ICheckbox): JSX.Element => {\r\n    const [checked, setChecked] = useState<boolean>(false)\r\n\r\n    useEffect(() => {\r\n        setChecked(isChecked)\r\n    }, [isChecked])\r\n\r\n    const onChange = (e: React.ChangeEvent<HTMLInputElement>): void => {\r\n        const { checked } = e.target\r\n        setChecked(checked)\r\n        handleChanged(checked)\r\n    }\r\n\r\n    //TODO: Proper CSS naming\r\n    return (\r\n        <label className={`styled-checkbox styled-checkbox--${size}`}>\r\n            <input\r\n                className=\"styled-checkbox-input\"\r\n                type=\"checkbox\"\r\n                checked={checked}\r\n                onChange={onChange}\r\n                aria-labelledby=\"styled-checkbox-label\"\r\n            />\r\n            <span className=\"styled-checkbox-control\">\r\n                {checked && (\r\n                    <svg\r\n                        className=\"styled-checkbox-check-icon\"\r\n                        id=\"prefix__Layer_1\"\r\n                        xmlns=\"http://www.w3.org/2000/svg\"\r\n                        x={0}\r\n                        y={0}\r\n                        viewBox=\"0 0 21 21\"\r\n                        xmlSpace=\"preserve\"\r\n                    >\r\n                        <g id=\"prefix__icon_x2F_tick\">\r\n                            <g id=\"prefix__Mask\">\r\n                                <path\r\n                                    id=\"prefix__path-1_1_\"\r\n                                    d=\"M7.7 17.7L2 12c-.4-.4-.4-1 0-1.4l.7-.7c.4-.4 1-.4 1.4 0l1.4 1.4c1.2 1.2 3.1 1.2 4.2 0l7.1-7.1c.4-.4 1-.4 1.4 0l.8.8c.4.4.4 1 0 1.4L7.7 17.7z\"\r\n                                />\r\n                            </g>\r\n                        </g>\r\n                    </svg>\r\n                )}\r\n            </span>\r\n            <p className=\"styled-checkbox-label\">{label}</p>\r\n        </label>\r\n    )\r\n}\r\n\r\nexport default Checkbox\r\n","import './gift-aid.css'\r\nimport React from 'react'\r\nimport { GiftAidModal } from './GiftAidModal'\r\nimport Checkbox from '../../../Shared/Checkbox/Checkbox'\r\n\r\nexport const GiftAidStatusEnum = {\r\n    none: 1,\r\n    giftAid: 2,\r\n    giftAidConfirmation: 3,\r\n}\r\n\r\nexport type GiftAidStatusValues =\r\n    (typeof GiftAidStatusEnum)[keyof typeof GiftAidStatusEnum]\r\n\r\ninterface IGiftAidProps {\r\n    status: GiftAidStatusValues\r\n    setStatus?: React.Dispatch<React.SetStateAction<GiftAidStatusValues>>\r\n}\r\n\r\nexport const GiftAid: React.FC<IGiftAidProps> = (\r\n    props: IGiftAidProps\r\n): React.JSX.Element => {\r\n    const { status, setStatus = () => {} } = props\r\n    return (\r\n        <div className=\"gift-aid\">\r\n            {status === GiftAidStatusEnum.none && (\r\n                <button\r\n                    className={'btn link'}\r\n                    onClick={() => setStatus(GiftAidStatusEnum.giftAid)}\r\n                >\r\n                    Show tickets with Gift Aid\r\n                </button>\r\n            )}\r\n            {status === GiftAidStatusEnum.giftAid && (\r\n                <button\r\n                    className={'btn link'}\r\n                    onClick={() => setStatus(GiftAidStatusEnum.none)}\r\n                >\r\n                    Show standard tickets\r\n                </button>\r\n            )}\r\n            {status === GiftAidStatusEnum.giftAid && (\r\n                <>\r\n                    <GiftAidModal />\r\n                    <Checkbox\r\n                        label=\"I certify I am an eligible UK tax payer and wish to Gift Aid my payment\"\r\n                        isChecked={status === GiftAidStatusEnum.giftAid}\r\n                        handleChanged={(isChecked: boolean): void => {\r\n                            setStatus(\r\n                                isChecked\r\n                                    ? GiftAidStatusEnum.giftAid\r\n                                    : GiftAidStatusEnum.none\r\n                            )\r\n                        }}\r\n                    />\r\n                </>\r\n            )}\r\n            {status === GiftAidStatusEnum.giftAidConfirmation && (\r\n                <GiftAidModal\r\n                    labelText=\"Gift Aid is applied\"\r\n                    labelProps={{\r\n                        className: 'font-bold confirmation__giftAid',\r\n                    }}\r\n                />\r\n            )}\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default GiftAid\r\n","import React from 'react'\r\nimport './NavBarGeneral.css'\r\nimport { motion } from 'framer-motion'\r\nimport IconSvg, { ICON_TYPE } from '../Shared/SVG/iconSvg'\r\nimport { LogoSVGComponent } from '../Shared/SVG/logoSVG'\r\n\r\nconst navVariants = {\r\n    initial: {\r\n        opacity: 0,\r\n    },\r\n    in: {\r\n        opacity: 1,\r\n        transition: { duration: 0.3 },\r\n    },\r\n    out: {\r\n        opacity: 0,\r\n    },\r\n}\r\n\r\ninterface INavBarProps {\r\n    logoUrl?: string\r\n    showBackButton?: boolean\r\n    onGoBack?: () => void\r\n    onClose?: () => void\r\n    showLogo?: boolean\r\n    homePagePath?: string\r\n    headingLabel?: string\r\n}\r\n\r\nconst NavBarGeneral: React.FC<INavBarProps> = ({\r\n    logoUrl,\r\n    showBackButton,\r\n    onGoBack,\r\n    onClose,\r\n    showLogo,\r\n    homePagePath,\r\n    headingLabel,\r\n}: INavBarProps): JSX.Element => {\r\n    const handleBack = (): void => {\r\n        if (onGoBack) {\r\n            onGoBack()\r\n        } else {\r\n            window.history.back()\r\n        }\r\n    }\r\n\r\n    const showModal = (): void => {\r\n        if (onClose) {\r\n            onClose()\r\n        } else {\r\n            if (homePagePath) {\r\n                window.location.href = homePagePath\r\n            } else {\r\n                window.location.href = '/'\r\n            }\r\n        }\r\n    }\r\n\r\n    return (\r\n        <motion.div\r\n            initial=\"initial\"\r\n            animate=\"in\"\r\n            exit=\"out\"\r\n            variants={navVariants}\r\n            className=\"navBar\"\r\n        >\r\n            <div className=\"navBar__contents\">\r\n                {(showBackButton || onGoBack) && (\r\n                    <button\r\n                        id=\"navBarBack\"\r\n                        className=\"navBar__backArrow  btn primary-btn-white\"\r\n                        onClick={handleBack}\r\n                    >\r\n                        <IconSvg type={ICON_TYPE.Back} />\r\n                    </button>\r\n                )}\r\n                {showLogo && (\r\n                    <div className=\"navBar__logo\">\r\n                        <LogoSVGComponent logoUrl={logoUrl} showMobile={true} />\r\n                    </div>\r\n                )}\r\n                {headingLabel && (\r\n                    <div className=\"navBar__title\">\r\n                        <h2>{headingLabel}</h2>\r\n                    </div>\r\n                )}\r\n                {onClose && (\r\n                    <button\r\n                        id=\"navBarClose\"\r\n                        aria-label=\"Close\"\r\n                        className=\"navBar__close btn primary-btn-white\"\r\n                        onClick={showModal}\r\n                    >\r\n                        <IconSvg type={ICON_TYPE.Close} />\r\n                    </button>\r\n                )}\r\n            </div>\r\n        </motion.div>\r\n    )\r\n}\r\n\r\nexport default NavBarGeneral\r\n","import React from 'react'\r\nimport './ErrorHandler.css'\r\nimport { IErrorObject } from '../../../interfaces/interfaces'\r\n\r\ninterface IErrorHandlerProps {\r\n    errorObject: IErrorObject\r\n    extraMessage?: string\r\n}\r\n\r\nconst ErrorHandler: React.FC<IErrorHandlerProps> = ({\r\n    errorObject,\r\n    extraMessage = undefined,\r\n}: IErrorHandlerProps) => {\r\n    const goHome = (): void => {\r\n        const currentPage = window.location.href\r\n        window.location.href = currentPage\r\n    }\r\n\r\n    return (\r\n        <div className=\"errorHandler\">\r\n            <h1>{`Uh oh... It looks like there's a problem booking these tickets.`}</h1>\r\n            <p className=\"errorHandlerText\">\r\n                {errorObject.newFriendlyErrorMessage &&\r\n                errorObject.newFriendlyErrorMessage !== '' ? (\r\n                    <span\r\n                        dangerouslySetInnerHTML={{\r\n                            __html: errorObject.newFriendlyErrorMessage,\r\n                        }}\r\n                    />\r\n                ) : (\r\n                    <>\r\n                        {extraMessage ? (\r\n                            <>\r\n                                Your card may have been charged, but there was a\r\n                                problem completing your order - please contact\r\n                                us to confirm the status of your booking.\r\n                            </>\r\n                        ) : (\r\n                            <>\r\n                                Please go back and try changing the dates and\r\n                                times.\r\n                            </>\r\n                        )}\r\n                    </>\r\n                )}\r\n            </p>\r\n            <button\r\n                type=\"submit\"\r\n                onClick={goHome}\r\n                className=\"btn primary-btn btn-large btn-shorter btn-fontLarger button-top-margin\"\r\n            >\r\n                Continue\r\n            </button>\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default ErrorHandler\r\n","import './reusableModal.css'\r\nimport React, { useEffect, useState } from 'react'\r\n\r\nimport { motion } from 'framer-motion'\r\nimport { createPortal } from 'react-dom'\r\nimport NavBarGeneral from '../../NavBarGeneral/NavBarGeneral'\r\n\r\nconst variants = {\r\n    initial: {\r\n        y: '100%',\r\n    },\r\n    in: {\r\n        y: 0,\r\n    },\r\n    out: {\r\n        y: '100%',\r\n    },\r\n}\r\n\r\ninterface IModal {\r\n    children: JSX.Element | JSX.Element[]\r\n    onGoBack?: () => void\r\n    onClose?: () => void\r\n    headerTitle?: string\r\n    element?: Element | DocumentFragment | null\r\n    full?: boolean\r\n    additionalClasses?: string\r\n    noScroll?: boolean\r\n}\r\n\r\nconst ReusableModal: React.FC<IModal> = ({\r\n    children,\r\n    onGoBack,\r\n    onClose,\r\n    headerTitle,\r\n    element,\r\n    full = true,\r\n    additionalClasses,\r\n    noScroll = false,\r\n}: IModal): JSX.Element => {\r\n    let navbarVisible = false\r\n\r\n    if (onGoBack || onClose || headerTitle) {\r\n        navbarVisible = true\r\n    }\r\n\r\n    const [docFragment, setDocFragment] = useState<Element | DocumentFragment>(\r\n        document.body\r\n    )\r\n\r\n    useEffect(() => {\r\n        if (element) setDocFragment(element)\r\n        if (noScroll) document.body.classList.add('no-scroll')\r\n\r\n        return () => {\r\n            if (noScroll) document.body.classList.remove('no-scroll')\r\n        }\r\n    }, [element])\r\n\r\n    // add additional classes to the modal to identify specific handled sections/Components when needed\r\n    let modalClasses = `${full ? 'Modal__full' : 'Modal'}`\r\n    modalClasses = additionalClasses\r\n        ? `${modalClasses} ${additionalClasses}`\r\n        : modalClasses\r\n\r\n    return createPortal(\r\n        <div className={modalClasses}>\r\n            <motion.div\r\n                className=\"Modal__container\"\r\n                variants={variants}\r\n                initial=\"initial\"\r\n                animate=\"in\"\r\n                exit=\"out\"\r\n                transition={{ duration: 0.3 }}\r\n                data-testid=\"reusable-modal\"\r\n            >\r\n                {navbarVisible && (\r\n                    <NavBarGeneral\r\n                        headingLabel={headerTitle}\r\n                        onGoBack={onGoBack}\r\n                        onClose={onClose}\r\n                    />\r\n                )}\r\n\r\n                <div\r\n                    className={`Modal__body ${navbarVisible ? '' : 'Modal__body--fullheight'}`}\r\n                >\r\n                    {children}\r\n                </div>\r\n            </motion.div>\r\n        </div>,\r\n        docFragment\r\n    )\r\n}\r\n\r\nexport default ReusableModal\r\n","const Variants = {\r\n    defaultPageVariants: {\r\n        initial: {\r\n            y: 200,\r\n            opacity: 0,\r\n        },\r\n        in: {\r\n            y: 0,\r\n            opacity: 1,\r\n        },\r\n        out: {\r\n            y: 200,\r\n            opacity: 0,\r\n        },\r\n    },\r\n    searchPageVariants: {\r\n        initial: {\r\n            y: -60,\r\n            opacity: 0,\r\n        },\r\n        in: {\r\n            y: 0,\r\n            opacity: 1,\r\n        },\r\n        out: {\r\n            y: 0,\r\n            opacity: 0,\r\n            duration: 30,\r\n        },\r\n    },\r\n};\r\n\r\nexport default Variants;\r\n","import React from 'react'\r\nimport { Tick } from '../../../../assets/svg/Svg-Exports'\r\nimport { IEditedContactDetails } from '../../AccountDataMissing'\r\nimport PhoneFormField from '../../../../Components/AccountScreens/FormInputs/PhoneFormField/PhoneFormField'\r\n\r\ninterface IContactInfo {\r\n    firstName: string | null\r\n    lastName: string | null\r\n    email: string | null\r\n    phone: string | null\r\n    handleChange: (\r\n        event: React.ChangeEvent<HTMLInputElement | HTMLSelectElement>\r\n    ) => void\r\n    handlePhoneChange: (name: string, value: string) => void\r\n    validation?: IEditedContactDetails\r\n}\r\n\r\nconst ContactInfo: React.FC<IContactInfo> = ({\r\n    firstName,\r\n    lastName,\r\n    email,\r\n    phone,\r\n    handleChange,\r\n    handlePhoneChange,\r\n    validation,\r\n}: IContactInfo): JSX.Element => {\r\n    return (\r\n        <div>\r\n            <fieldset className=\"fieldset\">\r\n                <label className=\"fieldset_label\" htmlFor=\"firstName\">\r\n                    First name\r\n                </label>\r\n                <div className=\"fieldset_field\">\r\n                    <input\r\n                        className=\"input\"\r\n                        name=\"firstName\"\r\n                        value={firstName ? firstName : ''}\r\n                        onChange={handleChange}\r\n                    />\r\n                    <div className=\"fieldset_validation\">\r\n                        {(validation && validation.firstName) || <Tick />}\r\n                    </div>\r\n                </div>\r\n            </fieldset>\r\n            <fieldset className=\"fieldset\">\r\n                <label className=\"fieldset_label\" htmlFor=\"lastName\">\r\n                    Last name\r\n                </label>\r\n                <div className=\"fieldset_field\">\r\n                    <input\r\n                        className=\"input\"\r\n                        name=\"lastName\"\r\n                        value={lastName ? lastName : ''}\r\n                        onChange={handleChange}\r\n                    />\r\n                    <div className=\"fieldset_validation\">\r\n                        {(validation && validation.lastName) || <Tick />}\r\n                    </div>\r\n                </div>\r\n            </fieldset>\r\n            <fieldset className=\"fieldset\">\r\n                <label className=\"fieldset_label\" htmlFor=\"email\">\r\n                    Email\r\n                </label>\r\n                <div className=\"fieldset_field\">\r\n                    <input\r\n                        className=\"input\"\r\n                        name=\"email\"\r\n                        value={email ? email : ''}\r\n                        onChange={handleChange}\r\n                    />\r\n                    <div className=\"fieldset_validation\">\r\n                        {(validation && validation.email) || <Tick />}\r\n                    </div>\r\n                </div>\r\n            </fieldset>\r\n\r\n            <PhoneFormField\r\n                fieldID={'phone'}\r\n                initialPhoneValue={phone ? phone : ''}\r\n                onChangeHandler={handlePhoneChange}\r\n                isValid={validation ? !validation.phone : false}\r\n                labelText=\"Mobile number\"\r\n            />\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default ContactInfo\r\n","import axios, { AxiosRequestConfig, AxiosResponse } from 'axios'\r\n\r\nimport { setPartnerId } from '../Helpers/api-helpers'\r\nimport {\r\n    IBooking,\r\n    IGetCountryDataResponse,\r\n    ILoyaltyAccount,\r\n    IUserAccountInfo,\r\n} from '../interfaces/interfaces'\r\nimport {\r\n    IContactUsRequest,\r\n    IGetAddressesResponse,\r\n    IGetReferralCodeResponse,\r\n    ILoyaltyActivityResponse,\r\n    ILoyaltyUpdateRequest,\r\n    INewAddressRequest,\r\n    INewsletterSignUpRequest,\r\n    INewsletterSignUpResponse,\r\n    IStandardResponse,\r\n    IUpdateOrderRequest,\r\n} from './interfacesAPI'\r\nimport { apiRequest } from './apiRequestHelper'\r\nimport {\r\n    IAccountMarketingPreferencesGetResponse,\r\n    IAccountMarketingPreferencesPutResponse,\r\n    IAccountMarketingUserPreferences,\r\n} from './account-api.interfaces'\r\nimport UMBRACO_CONFIG from '../Helpers/umbraco-config'\r\nimport { cloneObj } from '../Helpers/utils'\r\nimport { IAccountBooking } from '../redux/account/account-interfaces'\r\n\r\nconst instance = axios.create({\r\n    baseURL: UMBRACO_CONFIG.urlApi,\r\n})\r\n\r\nsetPartnerId(instance)\r\n\r\nconst AccountAPI = {\r\n    getVirtualCart: async (token: string): Promise<IBooking[]> => {\r\n        const raw = 'Bearer ' + token\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'account/virtual-cart',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        }\r\n\r\n        return await apiRequest<IBooking[]>(instance, config)\r\n    },\r\n    getBookings: async (token: string) => {\r\n        const raw = 'Bearer ' + token\r\n\r\n        return instance({\r\n            method: 'GET',\r\n            url: `account/orders`,\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    updateCustomerDetails: async (req: IUserAccountInfo, token: string) => {\r\n        const raw = 'Bearer ' + token\r\n        const tempObj = cloneObj(req)\r\n\r\n        const updateReq = {\r\n            firstName: tempObj.firstName,\r\n            lastName: tempObj.lastName,\r\n            email: tempObj.email,\r\n            phoneNumber: tempObj.phone,\r\n        }\r\n\r\n        return instance({\r\n            method: 'PUT',\r\n            url: 'user/update-customer-details',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify(updateReq),\r\n        })\r\n    },\r\n    getPreferences: async (\r\n        token: string\r\n    ): Promise<IAccountMarketingPreferencesGetResponse> => {\r\n        const raw = 'Bearer ' + token\r\n\r\n        return instance({\r\n            method: 'GET',\r\n            url: 'account/marketing-preference',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    updatePreferences: async (\r\n        userPreferences: IAccountMarketingUserPreferences[],\r\n        token: string\r\n    ): Promise<IAccountMarketingPreferencesPutResponse> => {\r\n        const raw = 'Bearer ' + token\r\n        const tempObj = userPreferences.slice()\r\n        const tempArr = [] as Partial<IAccountMarketingUserPreferences>[]\r\n\r\n        tempObj.forEach((tempItem) => {\r\n            tempArr.push({\r\n                marketingPreferenceId: tempItem.marketingPreferenceId,\r\n                active: tempItem.active,\r\n            })\r\n        })\r\n\r\n        const tempReq = {\r\n            userMarketingPreferences: tempArr,\r\n        }\r\n\r\n        return instance({\r\n            method: 'PUT',\r\n            url: 'account/marketing-preference',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify(tempReq),\r\n        })\r\n    },\r\n    cancelReservation: async (req: IAccountBooking | IBooking) => {\r\n        const tempReq = {\r\n            attractionId: req.attractionId,\r\n            eventId: req.eventId,\r\n            sessionId: req.sessionId,\r\n            orderIdentifier: req.orderIdentifier,\r\n        }\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'payment/refund',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(tempReq),\r\n        })\r\n    },\r\n    cancelBookingProtect: async (orderIdentifier: string, token: string) => {\r\n        const raw = 'Bearer ' + token\r\n        const tempReq = {\r\n            orderIdentifier: orderIdentifier,\r\n        }\r\n\r\n        return instance({\r\n            method: 'DELETE',\r\n            url: 'account/cancel-insurance',\r\n            headers: {\r\n                Authorization: raw,\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(tempReq),\r\n        })\r\n    },\r\n    makeLove: async (id: number, token: string, type: number) => {\r\n        const raw = 'Bearer ' + token\r\n\r\n        const req = {\r\n            lovedType: type,\r\n            id: typeof id === 'string' ? id : JSON.stringify(id),\r\n        }\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'account/toggle-loved',\r\n            headers: {\r\n                Authorization: raw,\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(req),\r\n        })\r\n    },\r\n    contactUs: async (req: IContactUsRequest): Promise<IStandardResponse> => {\r\n        const config: AxiosRequestConfig = {\r\n            method: 'POST',\r\n            url: 'contact/contact-us-form',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(req),\r\n        }\r\n\r\n        return await apiRequest<IStandardResponse>(instance, config)\r\n    },\r\n    getLoved: async (token: string) => {\r\n        const raw = 'Bearer ' + token\r\n\r\n        return instance({\r\n            method: 'GET',\r\n            url: 'account/get-loved',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    resetPassword: async (userId: string, password: string, code: string) => {\r\n        const reqRes = {\r\n            userId,\r\n            password,\r\n            code,\r\n        }\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'user/reset-password',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(reqRes),\r\n        })\r\n    },\r\n    getAddresses: async (jwtToken: string): Promise<IGetAddressesResponse> => {\r\n        const raw = 'Bearer ' + jwtToken\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'account/get-addresses',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        }\r\n\r\n        return await apiRequest<IGetAddressesResponse>(instance, config)\r\n    },\r\n    makePrimary: async (id: number, type: number, jwtToken: string) => {\r\n        const raw = 'Bearer ' + jwtToken\r\n        const req = {\r\n            addressId: id,\r\n            addressType: type,\r\n        }\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'account/set-primary/',\r\n            data: JSON.stringify(req),\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    deleteAddress: async (id: number, jwtToken: string) => {\r\n        const raw = 'Bearer ' + jwtToken\r\n        const req = {\r\n            addressId: id,\r\n        }\r\n\r\n        return instance({\r\n            method: 'DELETE',\r\n            url: 'account/delete-address/',\r\n            data: JSON.stringify(req),\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    newsLetterSignup: async (\r\n        req: INewsletterSignUpRequest\r\n    ): Promise<AxiosResponse<INewsletterSignUpResponse>> => {\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'account/subscribe-newsletter',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n            },\r\n            data: JSON.stringify(req),\r\n        })\r\n    },\r\n    setNewAddress: async (address: INewAddressRequest) => {\r\n        const raw = 'Bearer ' + address.jwt\r\n\r\n        const tempAddress = cloneObj(address)\r\n\r\n        if (!tempAddress.address.addressType) {\r\n            tempAddress.address.addressType = 2\r\n        }\r\n\r\n        // delete address.jwt;\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'account/create-address',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify({ Address: tempAddress.address }),\r\n        })\r\n    },\r\n    // TODO: is this needed? Not being used anywhere\r\n    // setShippingAddress: async (address: any) => {\r\n    //     const raw = \"Bearer \" + address.jwt;\r\n    //     delete address.jwt;\r\n\r\n    //     return instance({\r\n    //         method: \"POST\",\r\n    //         url: \"account/create-address\",\r\n    //         headers: {\r\n    //             \"Content-Type\": \"application/json\",\r\n    //             Authorization: raw,\r\n    //         },\r\n    //         data: JSON.stringify(address),\r\n    //     });\r\n    // },\r\n    updateOrder: async (request: IUpdateOrderRequest, jwt: string) => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        return instance({\r\n            method: 'POST',\r\n            url: 'account/update-order',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify(request),\r\n        })\r\n    },\r\n    getCountryData: async (): Promise<IGetCountryDataResponse> => {\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'lookup/countries',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n            },\r\n        }\r\n\r\n        return await apiRequest<IGetCountryDataResponse>(instance, config)\r\n    },\r\n    deleteAccount: async (jwt: string) => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        return instance({\r\n            method: 'DELETE',\r\n            url: 'user/delete-account',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        })\r\n    },\r\n    getLoyaltyAccount: async (jwt: string): Promise<ILoyaltyAccount> => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'rewards/loyalty-account',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        }\r\n\r\n        return await apiRequest<ILoyaltyAccount>(instance, config)\r\n    },\r\n    getLoyaltyActivity: async (\r\n        jwt: string\r\n    ): Promise<ILoyaltyActivityResponse> => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'rewards/loyalty-activity',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        }\r\n\r\n        return await apiRequest<ILoyaltyActivityResponse>(instance, config)\r\n    },\r\n    getReferralCode: async (jwt: string): Promise<IGetReferralCodeResponse> => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'GET',\r\n            url: 'rewards/referral-code',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n        }\r\n\r\n        return await apiRequest<IGetReferralCodeResponse>(instance, config)\r\n    },\r\n    updateLoyaltyAccount: async (\r\n        jwt: string,\r\n        request: ILoyaltyUpdateRequest\r\n    ): Promise<IStandardResponse> => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'PUT',\r\n            url: 'rewards/loyalty-update',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify(request),\r\n        }\r\n\r\n        return await apiRequest<IStandardResponse>(instance, config)\r\n    },\r\n    claimReward: async (\r\n        jwt: string,\r\n        loyaltyCardNumber: string\r\n    ): Promise<IStandardResponse> => {\r\n        const raw = 'Bearer ' + jwt\r\n\r\n        const config: AxiosRequestConfig = {\r\n            method: 'POST',\r\n            url: 'rewards/redeem',\r\n            headers: {\r\n                'Content-Type': 'application/json',\r\n                Authorization: raw,\r\n            },\r\n            data: JSON.stringify({ loyaltyCardNumber: loyaltyCardNumber }),\r\n        }\r\n\r\n        return await apiRequest<IStandardResponse>(instance, config)\r\n    },\r\n}\r\n\r\nexport default AccountAPI\r\n"],"names":["CSS_CLASSNAME","props","global","useContext","GlobalContext","bookingButtonRef","React","classNames","setClassNames","useEffect","handleScroll","window","scrollY","concat","addEventListener","removeEventListener","_jsx","className","ref","children","_jsxs","onClick","clickHandler","fromPrice","originalPrice","_ref","image","title","content","ikBase","src","alt","weekdays","monthsFull","getSpecificDate","month","dayOfMonth","year","parse","Date","getTheMonth","date","getMonth","getTheYear","getYear","getEventLocalToday","locale","arguments","length","undefined","defaultBookingLocale","timeZone","defaultTimeZone","toLocaleDateString","dateStyle","formatToDateObjToLocation","zonedTimeToUtc","getMonthDayYear","format","todaysDate","activeDates","selectDate","openTimes","datesInMonth","getDatesInMonthDisplay","monthYear","daysInMonth","getDaysInMonth","firstWeekday","getDay","startOfMonth","result","prevMonthYear","getPrevMonthYear","prevDaysInMonth","i","push","currentMonth","time","j","daysToAdd","nextMonthYear","getNextMonthYear","k","addMonths","addYears","monthDates","map","key","selected","JSON","stringify","active","toString","e","onChangeDate","isActive","dataDate","dataTime","type","session","sessionId","getTime","getDate","selectedDate","presetActiveDates","useRef","dates","bookingLocale","eventLocalTime","toLocaleTimeString","timeStyle","forEach","dateStr","slots","presetDateTracker","monthLong","yearLong","BookingDateIndicator","current","peakTimes","dispatch","useAppDispatch","bookingObject","useAppSelector","state","tickets","loading","setLoading","useState","indexActive","setIndexActive","iSelect","setISelect","selectTime","timeObject","sessionSelected","completeDateTimeSelection","ticketTypeObj","ids","reserveDates","setSession","times","Loader","messages","_Fragment","style","backgroundColor","id","peak","BookingDatepicker","isTimePickerOpen","selectedDateObject","setSelectedDateObject","closeDatepicker","setDatePickerOpen","openTime","sessionType","SessionType","DateAndTime","setTimepickerOpen","DateOnly","temp","timesResponse","sessions","ticketContainer","document","querySelector","Modal","element","DocumentFragment","onGoBack","closeTimepicker","onClose","additionalClasses","Timepicker","day","BookingCalendar","openPreTime","callProps","getTimes","formatDate","LimitedDatePicker","ticketsBookingObjectSessionSelectedDate","available","formatInTimeZone","dateFormatStringDOW","dayTitle","useMemo","today","setHours","tomorrow","setDate","inputDate","valueOf","DatesAvailable","isDatePickerOpen","isOpen","dateNumberBeforeShowDatepicker","datepickerShow","shortListShow","setShortListShow","openDatePicker","openTimePicker","NoDate","handleClick","preventDefault","clearTicketState","TodayOrTomorrow","AnimatePresence","TOOLTIP_ARROW_POSITION","Tooltip","show","setShow","positionStyles","setPositionStyles","arrowPosition","setArrowPosition","toolTipRef","toolTipMessageRef","arrowSizeRef","height","width","position","left","clientWidth","valueVertical","clientHeight","positionVertical","top","valueHorizontal","positionHorizontal","onMouseEnter","onMouseLeave","displayedText","animateVariants","initial","y","opacity","scaleY","in","transition","duration","ease","out","addTickets","giftAidStatus","scrollRef","ticketsBookingObject","minPartySize","ticketsBookingObjectTicketObjectMinPartySize","maxPartySize","ticketsBookingObjectTicketObjectMaxPartySize","ticketsShow","setTicketsShow","size","setSize","showChildren","setShowChildren","currencyFormat","num","toFixed","replace","isGiftAidChecked","ticketType","GiftAidStatusEnum","giftAid","giftAidPennies","modifier","relation","index","tempType","cloneObj","tempTicket","newSize","direction","ticketObject","ticketTypes","childTickets","totalPrice","quantity","maxQuantity","validQuantities","arrayIndex","indexOf","_type$validQuantities","previousItem","newItem","minQuantity","incrementTickets","ticket","child","_type$validQuantities2","ticketingInfo","href","Object","keys","isValidQuantity","ticketPricePennies","pricePennies","handleParent","parent","tempBookingObject","p","c","totalPricePennies","resetChildTickets","isParent","cursor","friendlyName","name","note","minus","plus","motion","div","animate","exit","variants","smallName","split","childTicketPricePennies","calculateTicketTotal","TicketsSummary","ticketsBookingObjectTicketsCompleteTicketTypes","filter","inclusionBookingFeePennies","orderBookingFee","OrderBookingFee","discountValue","ticketsBookingObjectDiscountValue","reduce","total","pennies","bookingFeePennies","IsDatePickerOpen","affiliateTrackingCodeFlag","featureFlagsAffiliateTrackingCode","loadingTwo","setLoadingTwo","promoValidateButtonState","setPromoValidateButtonState","promoCode","setPromoCode","promoCodeInvalid","setPromoCodeInvalid","promoCodeError","setPromoCodeError","extraContinueCondition","setExtraContinueCondition","thisDone","setThisDone","message","setMessage","discountMessage","setDiscountMessage","partnerId","reserveResponse","orderIdentifier","setBookingProgress","_bookingObject$ticket","_bookingObject$ticket2","ticketComplete","promotionalMessage","validatePromoCode","promoReq","input","promoCodeInput","price","API","then","res","isValid","dataLayer","event","eventProps","category","action","label","startsWith","rewardSentence","setPromoCodeAmount","discountPennies","setPromoCodeInput","friendlyErrorMessage","numTickets","minSize","startDate","showTimePicker","startTime","TicketsTotalPrice","htmlFor","value","onChange","target","match","showTime","TicketCountdown","ticketsSelected","checkQuestions","booking","encodedAffiliateCode","Cookies","get","affiliateTrackingCode","atob","affiliateCode","tempAnalyticsData","bookingFunctions","createTixInfoArray","eventName","attractionName","ecommerce","currency","items","complete","showGiftAid","createReservation","handleChangeAddress","address","valueKey","hasError","errorShow","required","finderVariants","setAddress","setManual","queryType","setSendManual","location","setLocation","searchTerm","updateSearchTerm","searchResults","updateSearchResults","displayResults","updateDisplayResults","navigator","geolocation","getCurrentPosition","latitude","coords","longitude","section","resetSearch","placeholder","axios","method","url","data","addressProp","suggestions","searchResultsView","handleSelection","suggestion","addressRes","addressResult","country","resObject","thoroughfare","buildingname","building_name","subbuildingname","sub_building_name","subbuildingnumber","sub_building_number","buildingnumber","building_number","line1","line_1","line2","line_2","line3","line_3","line4","line_4","locality","townOrCity","town_or_city","county","district","countryId","postcode","addressType","isPrimary","resultObject","countryList","getValue","primary","setBillingAddress","showVariants","arrangedAddress","x","join","formatPostcode","setManualInput","manualInput","handleAddAddress","handleAddAddressClose","jwt","sendManual","setErrorShow","setHasError","onAddressChange","_objectSpread","s","toUpperCase","trimmedPostcode","test","String","validatePostcode","onAddAddressClose","xmlns","viewBox","d","fillRule","clipRule","AddressEditInputs","disabled","NewAddressFinder","saveAddress","values","every","v","shippingAddress","AccountAPI","setNewAddress","getAddresses","async","addresses","_bookingObj$reserveRe","deliveryQuestion","handlePages","bookingObj","setAddresses","allowContinue","setAllowContinue","answer","setAnswer","showAddAddress","setShowAddAddress","showQuestion","setShowQuestion","question","handleContinueClick","receivedAnswer","sendDeliveryInfo","externalId","answerVar","response","success","saveAddresstoDB","handleSingleSelect","selectedVal","parseInt","captureAddress","a","questionTitle","option","sort","first","handleAddressClick","stopPropagation","tempAddresses","makePrimary","addressId","onDeleteClick","splice","deleteAddress","console","log","error","TrashCan","onAddressAdd","AddressEdit","reservationNote","selectPage","text","setText","importantInformation","alternativeSeating","Pages","ImportantInformation","tempWorks","msg","parsed","includes","parsedTxt","replaceAll","rowId","specialInfo","restrictedView","subSection","sectionText","bp","changeSelection","isProtected","setBookingProtect","premium","item_name","item_brand","item_category","Summary","changePage","Tick","termsAndConditionsUrl","rel","logoUrl","Questions","showErrors","handleNeedsAnswer","checked","setChecked","amount","setAmount","setAnswers","orderAnswers","extraPages","orderFound","findIndex","order","setOrderAnswers","questionAnswers","ticketAnswers","answerFound","groupId","groupName","questionType","setTicketAnswers","createAnswerObj","hasAdditionalPrice","additionalPrice","addToOrderAnswers","addToTicketAnswers","handleChecked","handleTextArea","handleInputTextChange","handleIntChange","Number","handleDateChange","isDateValid","dateFormatted","ticketFound2","orderFound2","answerVal","returnInputTypeDetails","priceType","totalPriceFixed","totalPriceStr","questionNote","whiteSpace","needsAnAnswer","xmlSpace","fill","childQuestions","multiple","min","returnInputType","orderQuestionsProp","ticketQuestionsProp","orderQuestions","setOrderQuestions","ticketQuestions","setTicketQuestions","setShowErrors","questionId","oQ","tQ","sortedtQ","previousQuestion","currentQuestion","sortedArr","questions","catalogueRequires","findValue","find","val","findTicketValue","termsAndConditions","TermsAndConditions","currentPage","userVars","user","successMessage","setSuccessMessage","resendTimeout","setResendTimeout","mainDetails","setMainDetails","setError","contactDetailsValid","setContactDetailsValid","contactDetailsEdited","setContactDetailsEdited","isLoading","setIsLoading","formValid","setFormValid","timer","setInterval","clearInterval","invalidFound","validation","alphaValidator","validateEmail","firstName","lastName","email","phone","itemsInvalid","updatedItem","isInputValid","isPhoneValid","handleDataChange","updatedDetails","prev","Alert","MessageType","ContactInfo","handleChange","handlePhoneChange","retrievedJwt","handleSave","errorMessage","serveResponse","updateCustomerDetails","PageContainer","loggedIn","setLoggedIn","dataMissing","setDataMissing","showAddressPage","setShowAddressPage","setRetrievedJwt","setExtraPages","getUserData","useCallback","CHECK_TIMESTAMP","getUserInfo","handleDelivery","_bookingObject$reserv","hasDelivery","page","ExtraError","getNotes","setExtraObject","arrangedData","pages","b","setTimeout","pageNumber","nextPage","datalayerObj","QuestionsPage","Insurance","BookingProtect","bookingProtect","AccountDataMissing","AddressPage","AccountScreens","onSuccess","embeded","selectedTickets","selection","colour","isSelected","selectAction","ticketPayload","seatPickerRef","maxPeople","seats","setSeats","labels","setLabels","colourPicked","setColourPicked","shapes","setShapes","colourArray","setColourArray","selectQ","setSelectQ","setSelectedTickets","seatMessage","setSeatMessage","maxMessage","setMaxMessage","widthDivide","setWidthDivide","heightDivide","setHeightDivide","selectTindex","setSelectTindex","ticketCoords","o","yHeight","Math","max","xWidth","seatPickerCurrentRef","offsetWidth","offsetHeight","handleZoom","api","useSpring","scale","useGesture","onHover","onDrag","_ref2","pinching","cancel","offset","start","drag","from","tempSeats","shape","tempDatalabels","priceArray","seatColour","SEAT_COLOURS","floor","colourResult","handleColourClick","isDesktop","transform","animated","prop","fontSize","color","fontWeight","lineHeight","borderRadius","shapeBorderRadius","sold","minWidth","minHeight","seatRow","seatLetter","seatNumber","allowDiscontiguousSeats","allowed","selectednumber","tempSelected","item","hidden","visible","t","tIndex","handleDropDown","SelectedSeatDisplay","SeatSelectionFooter","selectTickets","tempTickets","allowLeavingSingleSeats","availableInFound","availableNumArray","selectedTicketNumber","minNum","maxNum","allowedSeats","splitSeatNameProp","sortedSelected","splitSeatNamePropMin","splitSeatNamePropMax","right","InclusionBookingFeePennies","tempSelectedTickets","attractionId","eventId","hasSeatpicker","setTypeComponentOpen","ticketPayloadTemp","tempStart","childSeats","sectionTopRightY","sectionTopLeftX","changeQuantityFunction","_ticketQuantityInfo$c","ticketQuantityInfo","changeDisabled","AddSubtractQuantity","widgetData","venueScript","createElement","head","appendChild","removeChild","widgetGetDateTime","dateTimeArray","sessionDateTime","eventDate","eventTime","slice","channelId","ticketBookingData","selectedSeats","setSelectedSeats","ticketQuantityForSelection","setTicketQuantityForSelection","quantityChosen","setTicketquantityChosen","convertCurrency","conversionValue","dp","currencyCode","addToBasket","selectedSeatDetails","detail","selectedElement","seatDetails","selectedSeat","alreadySelected","seatAlreadySelected","seatId","row","number","aggregateReference","salePrice","decimalPlaces","orderFee","QuantityPicker","increase","changeChoosingQuanity","WidgetDisplay","ticketTypeSelected","timeoutFix","setTimeoutFix","timeout","usesSeatPicker","noScroll","useWidget","encoreWidgetAndData","relevantData","EncoreSeatWidget","widgetDetails","SeatPickerMulti","SeatPicker","OrderComplete","lazy","Confirmation","pageVariants","Variants","defaultPageVariants","_global$attractionNam","_bookingObject$ticket3","_bookingObject$ticket4","sessionsAvailable","history","useNavigate","Loading","apiLoading","showBookingError","setShowBookingError","showCloseConfirmation","setShowCloseConfirmation","setGiftAidStatus","none","zeroPad","places","padStart","ticketObjectDeepCopy","giftAidDefault","errorObject","status","timeLeft","timeoutTimeUnit","timeToCompleteMS","now","dist","seconds","minutes","hours","setTimeLeft","bookingProgress","cancelBooking","ticketContain","ReusableModal","full","headerTitle","closeAction","NavBarGeneral","showLogo","ErrorHandler","Card","summary","urlMedia","TicketType","AddTickets","GiftAid","setStatus","setUsesSeatPicker","HomeSummary","Suspense","fallback","refreshPage","LogoSVGComponent","showStrapline","Booking","showMobileBooking","setShowMobileBooking","isTablet","bookingOnly","getDates","sessionData","sessionStorage","getItem","parsedSessionData","sessionDate","sessionTime","removeItem","continueSession","TicketsHome","MobileContain","BookingButton","countdown","GiftAidModal","_document$querySelect","labelText","labelProps","showMoreInfo","setShowMoreInfo","scrollTo","behavior","Sizes","isChecked","handleChanged","medium","giftAidConfirmation","Checkbox","navVariants","showBackButton","homePagePath","headingLabel","handleBack","back","IconSvg","ICON_TYPE","Back","showMobile","showModal","Close","extraMessage","newFriendlyErrorMessage","dangerouslySetInnerHTML","__html","goHome","navbarVisible","docFragment","setDocFragment","body","classList","add","remove","modalClasses","createPortal","searchPageVariants","PhoneFormField","fieldID","initialPhoneValue","onChangeHandler","instance","create","baseURL","UMBRACO_CONFIG","urlApi","setPartnerId","getVirtualCart","config","headers","Authorization","token","apiRequest","getBookings","req","raw","tempObj","updateReq","phoneNumber","getPreferences","updatePreferences","userPreferences","tempArr","tempItem","marketingPreferenceId","tempReq","userMarketingPreferences","cancelReservation","cancelBookingProtect","makeLove","lovedType","contactUs","getLoved","resetPassword","userId","password","code","reqRes","jwtToken","newsLetterSignup","tempAddress","Address","updateOrder","request","getCountryData","deleteAccount","getLoyaltyAccount","getLoyaltyActivity","getReferralCode","updateLoyaltyAccount","claimReward","loyaltyCardNumber"],"sourceRoot":""}