@eventlook/sdk 1.4.49-beta.4 → 1.4.49-beta.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/form/PaymentOverviewBox.js +5 -4
- package/dist/cjs/form/PaymentOverviewBox.js.map +1 -1
- package/dist/cjs/form/PaymentOverviewDrawer.js +220 -60
- package/dist/cjs/form/PaymentOverviewDrawer.js.map +1 -1
- package/dist/cjs/form/Shipping.js +13 -10
- package/dist/cjs/form/Shipping.js.map +1 -1
- package/dist/cjs/form/TicketForm.js +5 -8
- package/dist/cjs/form/TicketForm.js.map +1 -1
- package/dist/cjs/form/product/ProductCard.js +45 -38
- package/dist/cjs/form/product/ProductCard.js.map +1 -1
- package/dist/cjs/form/product/ProductVariantsDialog.js +13 -4
- package/dist/cjs/form/product/ProductVariantsDialog.js.map +1 -1
- package/dist/cjs/form/style.js +6 -1
- package/dist/cjs/form/style.js.map +1 -1
- package/dist/cjs/form/tickets/TicketQuantityControl.js +5 -3
- package/dist/cjs/form/tickets/TicketQuantityControl.js.map +1 -1
- package/dist/cjs/hooks/useScrollToFirstError.js +19 -10
- package/dist/cjs/hooks/useScrollToFirstError.js.map +1 -1
- package/dist/cjs/locales/cs.js +7 -0
- package/dist/cjs/locales/cs.js.map +1 -1
- package/dist/cjs/locales/en.js +7 -0
- package/dist/cjs/locales/en.js.map +1 -1
- package/dist/cjs/locales/es.js +7 -0
- package/dist/cjs/locales/es.js.map +1 -1
- package/dist/cjs/locales/pl.js +7 -0
- package/dist/cjs/locales/pl.js.map +1 -1
- package/dist/cjs/locales/sk.js +7 -0
- package/dist/cjs/locales/sk.js.map +1 -1
- package/dist/cjs/locales/uk.js +7 -0
- package/dist/cjs/locales/uk.js.map +1 -1
- package/dist/esm/form/PaymentOverviewBox.js +5 -4
- package/dist/esm/form/PaymentOverviewBox.js.map +1 -1
- package/dist/esm/form/PaymentOverviewDrawer.js +220 -60
- package/dist/esm/form/PaymentOverviewDrawer.js.map +1 -1
- package/dist/esm/form/Shipping.js +13 -10
- package/dist/esm/form/Shipping.js.map +1 -1
- package/dist/esm/form/TicketForm.js +6 -9
- package/dist/esm/form/TicketForm.js.map +1 -1
- package/dist/esm/form/product/ProductCard.js +46 -39
- package/dist/esm/form/product/ProductCard.js.map +1 -1
- package/dist/esm/form/product/ProductVariantsDialog.js +13 -4
- package/dist/esm/form/product/ProductVariantsDialog.js.map +1 -1
- package/dist/esm/form/style.js +6 -1
- package/dist/esm/form/style.js.map +1 -1
- package/dist/esm/form/tickets/TicketQuantityControl.js +5 -3
- package/dist/esm/form/tickets/TicketQuantityControl.js.map +1 -1
- package/dist/esm/hooks/useScrollToFirstError.js +19 -10
- package/dist/esm/hooks/useScrollToFirstError.js.map +1 -1
- package/dist/esm/locales/cs.js +7 -0
- package/dist/esm/locales/cs.js.map +1 -1
- package/dist/esm/locales/en.js +7 -0
- package/dist/esm/locales/en.js.map +1 -1
- package/dist/esm/locales/es.js +7 -0
- package/dist/esm/locales/es.js.map +1 -1
- package/dist/esm/locales/pl.js +7 -0
- package/dist/esm/locales/pl.js.map +1 -1
- package/dist/esm/locales/sk.js +7 -0
- package/dist/esm/locales/sk.js.map +1 -1
- package/dist/esm/locales/uk.js +7 -0
- package/dist/esm/locales/uk.js.map +1 -1
- package/package.json +1 -3
- package/rollup.config.mjs +0 -1
- package/src/form/PaymentOverviewBox.tsx +19 -13
- package/src/form/PaymentOverviewDrawer.tsx +314 -106
- package/src/form/Shipping.tsx +19 -16
- package/src/form/TicketForm.tsx +7 -8
- package/src/form/product/ProductCard.tsx +75 -70
- package/src/form/product/ProductVariantsDialog.tsx +19 -2
- package/src/form/style.ts +7 -1
- package/src/form/tickets/TicketQuantityControl.tsx +6 -0
- package/src/hooks/useScrollToFirstError.ts +22 -17
- package/src/locales/cs.tsx +7 -0
- package/src/locales/en.tsx +7 -0
- package/src/locales/es.tsx +7 -0
- package/src/locales/pl.tsx +7 -0
- package/src/locales/sk.tsx +7 -0
- package/src/locales/uk.tsx +7 -0
- package/src/hooks/useConsentScrollOnDrawerOpen.ts +0 -73
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PaymentOverviewDrawer.js","sources":["../../../src/form/PaymentOverviewDrawer.tsx"],"sourcesContent":["import { Box, Button, SwipeableDrawer, Typography } from '@mui/material';\nimport React, { useEffect } from 'react';\nimport { useRef, useState } from 'react';\nimport PaymentOverviewBox from './PaymentOverviewBox';\nimport { IEvent } from '@utils/types/event.type';\nimport useGlobal from '@hooks/useGlobal';\nimport { fCurrency } from '@utils/formatNumber';\nimport { EVENTLOOK_ORDER_FORM_ID } from '@utils/data/global.ts';\n\ninterface Props {\n event: IEvent;\n totalPrice: number;\n onOpenChange?: (open: boolean) => void;\n}\n\nconst swipeAreaWidth = 56;\n\nconst PaymentOverviewDrawer: React.FC<Props> = ({ event, totalPrice, onOpenChange }) => {\n const { t, lang } = useGlobal();\n const [openDrawer, setOpenDrawer] = useState(false);\n const touchStartYRef = useRef<number | null>(null);\n\n const sentinelRef = useRef<HTMLDivElement>(null);\n const prevYRef = useRef<number>(Number.POSITIVE_INFINITY);\n\n // Opens drawer when scrolling down\n useEffect(() => {\n const sentinel = sentinelRef.current;\n if (!sentinel) return;\n\n const observer = new IntersectionObserver(\n (entries) => {\n entries.forEach((entry) => {\n if (totalPrice <= 0) return;\n const currentY = entry.boundingClientRect.y;\n const isScrollingDown = currentY < prevYRef.current;\n\n if (entry.isIntersecting && isScrollingDown) {\n openDrawerHandler();\n }\n\n prevYRef.current = currentY;\n });\n },\n {\n threshold: 0,\n rootMargin: '0px 0px 0px 0px',\n }\n );\n\n observer.observe(sentinel);\n\n return () => {\n observer.unobserve(sentinel);\n };\n }, [totalPrice]);\n\n const toggleDrawer = () => {\n setOpenDrawer((prev) => {\n const next = !prev;\n onOpenChange?.(next);\n return next;\n });\n };\n\n const openDrawerHandler = () => {\n setOpenDrawer(true);\n onOpenChange?.(true);\n };\n\n const closeDrawerHandler = () => {\n setOpenDrawer(false);\n onOpenChange?.(false);\n };\n\n const handleClosedTabTouchStart = (event: React.TouchEvent<HTMLDivElement>) => {\n touchStartYRef.current = event.touches[0]?.clientY ?? null;\n };\n\n const handleClosedTabTouchEnd = (event: React.TouchEvent<HTMLDivElement>) => {\n const startY = touchStartYRef.current;\n const endY = event.changedTouches[0]?.clientY;\n\n if (startY === null || typeof endY !== 'number') {\n touchStartYRef.current = null;\n return;\n }\n\n const swipeDistance = startY - endY;\n if (swipeDistance > 24) {\n openDrawerHandler();\n }\n\n touchStartYRef.current = null;\n };\n\n return (\n <Box sx={{ display: { md: 'none' } }}>\n {/* Sentinel element for intersection observer */}\n <Box ref={sentinelRef} sx={{ height: 1, visibility: 'hidden' }} />\n\n {/* Drawer Tab */}\n {!openDrawer && (\n <Box\n onTouchStart={handleClosedTabTouchStart}\n onTouchEnd={handleClosedTabTouchEnd}\n sx={{\n position: 'fixed',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: (theme) => theme.palette.background.paper,\n borderTopLeftRadius: 16,\n borderTopRightRadius: 16,\n boxShadow: '0 -8px 10px 2px rgba(0,0,0,0.2)',\n zIndex: 1300,\n }}\n >\n <Box\n role=\"button\"\n aria-label={t('form.labels.payment_overview_open')}\n onClick={toggleDrawer}\n sx={{\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n cursor: 'pointer',\n width: '100%',\n py: 1,\n }}\n >\n <Box\n sx={{\n width: 30,\n height: 6,\n backgroundColor: (theme) => theme.palette.grey[300],\n borderRadius: 3,\n }}\n />\n </Box>\n <Box\n sx={{\n width: '100%',\n px: 2,\n pb: 2,\n }}\n >\n <Typography\n sx={{\n fontWeight: 'bold',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n }}\n >\n <span>{t('form.labels.total')}:</span>\n <span>{fCurrency(totalPrice, lang, event.currency)}</span>\n </Typography>\n\n <Button\n type=\"submit\"\n form={EVENTLOOK_ORDER_FORM_ID}\n variant=\"contained\"\n size=\"large\"\n fullWidth\n sx={{ mt: 1, height: { xs: 36, md: 40 } }}\n >\n {t('buy')}\n </Button>\n </Box>\n </Box>\n )}\n\n {/* Drawer Content */}\n <SwipeableDrawer\n anchor=\"bottom\"\n open={openDrawer}\n onClose={closeDrawerHandler}\n onOpen={openDrawerHandler}\n swipeAreaWidth={swipeAreaWidth}\n disableSwipeToOpen={false}\n keepMounted\n sx={{ display: { md: 'none' } }}\n ModalProps={{\n disableScrollLock: true,\n keepMounted: false,\n BackdropProps: {\n sx: { background: 'linear-gradient(to top, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 100%)' },\n onClick: (event: React.MouseEvent<HTMLDivElement>) => {\n event.stopPropagation();\n },\n },\n }}\n PaperProps={{\n sx: {\n borderTopLeftRadius: 16,\n borderTopRightRadius: 16,\n boxShadow: '0 -8px 10px 2px rgba(0,0,0,0.2)',\n overflow: 'hidden',\n },\n }}\n >\n <Box\n role=\"button\"\n aria-label={t('form.labels.payment_overview_close')}\n onClick={toggleDrawer}\n sx={{\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor: (theme) => theme.palette.background.paper,\n cursor: 'pointer',\n py: 1,\n }}\n >\n <Box\n sx={{\n width: 30,\n height: 6,\n backgroundColor: (theme) => theme.palette.grey[300],\n borderRadius: 3,\n }}\n />\n </Box>\n <Box\n sx={{\n height: '100%',\n overflow: 'auto',\n }}\n >\n <PaymentOverviewBox event={event} />\n </Box>\n </SwipeableDrawer>\n </Box>\n );\n};\n\nexport default PaymentOverviewDrawer;\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"PaymentOverviewDrawer.js","sources":["../../../src/form/PaymentOverviewDrawer.tsx"],"sourcesContent":["import { Box, Button, SwipeableDrawer, Typography } from '@mui/material';\nimport React, { useEffect } from 'react';\nimport { useRef, useState } from 'react';\nimport PaymentOverviewBox from './PaymentOverviewBox';\nimport { IEvent } from '@utils/types/event.type';\nimport useGlobal from '@hooks/useGlobal';\nimport { fCurrency } from '@utils/formatNumber';\nimport { EVENTLOOK_ORDER_FORM_ID } from '@utils/data/global.ts';\n\ninterface Props {\n event: IEvent;\n totalPrice: number;\n termsAndConditionsRef?: React.RefObject<HTMLElement | null>;\n onOpenChange?: (open: boolean) => void;\n}\n\nconst swipeAreaWidth = 120;\n\nconst clearResetPulledPastTimeout = (timeoutRef: { current: number | null }) => {\n if (timeoutRef.current !== null) {\n window.clearTimeout(timeoutRef.current);\n timeoutRef.current = null;\n }\n};\n\nconst PaymentOverviewDrawer: React.FC<Props> = ({\n event,\n totalPrice,\n termsAndConditionsRef,\n onOpenChange,\n}) => {\n const { t, lang } = useGlobal();\n const [isDrawerOpened, setIsDrawerOpened] = useState(false);\n const [isOpeningGesture, setIsOpeningGesture] = useState(false);\n const [hasPulledPastClosedTabHeight, setHasPulledPastClosedTabHeight] = useState(false);\n const [isDrawerHidden, setIsDrawerHidden] = useState(false);\n const [closedTabHeight, setClosedTabHeight] = useState(0);\n const openingTouchStartYRef = useRef<number | null>(null);\n const openDrawerRef = useRef(false);\n const isOpeningGestureRef = useRef(false);\n const shouldReopenOnScrollUpRef = useRef(false);\n const lastScrollYRef = useRef(0);\n const isScrollingDownRef = useRef(false);\n const wasAtPageBottomRef = useRef(false);\n const resetPulledPastTimeoutRef = useRef<number | null>(null);\n const closedTabRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n openDrawerRef.current = isDrawerOpened;\n }, [isDrawerOpened]);\n\n useEffect(() => {\n isOpeningGestureRef.current = isOpeningGesture;\n }, [isOpeningGesture]);\n\n // reopens the drawer when user scrolls up and the drawer was closed by scrolling down to the bottom of the page\n useEffect(() => {\n if (typeof window === 'undefined') {\n return;\n }\n\n const atBottomThreshold = 8;\n lastScrollYRef.current = window.scrollY;\n isScrollingDownRef.current = false;\n wasAtPageBottomRef.current =\n window.innerHeight + window.scrollY >=\n document.documentElement.scrollHeight - atBottomThreshold;\n\n const handleScroll = () => {\n const currentY = window.scrollY;\n const isScrollingUp = currentY < lastScrollYRef.current;\n const isScrollingDown = currentY > lastScrollYRef.current;\n const isAtPageBottom =\n window.innerHeight + currentY >= document.documentElement.scrollHeight - atBottomThreshold;\n\n isScrollingDownRef.current = isScrollingDown;\n\n if (\n isScrollingUp &&\n wasAtPageBottomRef.current &&\n shouldReopenOnScrollUpRef.current &&\n !openDrawerRef.current\n ) {\n shouldReopenOnScrollUpRef.current = false;\n setIsDrawerHidden(false);\n openDrawerHandler();\n }\n\n wasAtPageBottomRef.current = isAtPageBottom;\n lastScrollYRef.current = currentY;\n };\n\n window.addEventListener('scroll', handleScroll, { passive: true });\n\n return () => {\n window.removeEventListener('scroll', handleScroll);\n };\n }, []);\n\n useEffect(() => {\n const closedTab = closedTabRef.current;\n if (!closedTab) return;\n\n const updateClosedTabHeight = () => {\n setClosedTabHeight(closedTab.offsetHeight);\n };\n\n updateClosedTabHeight();\n\n const resizeObserver = new ResizeObserver(() => {\n updateClosedTabHeight();\n });\n\n resizeObserver.observe(closedTab);\n\n return () => {\n resizeObserver.disconnect();\n };\n }, []);\n\n useEffect(\n () => () => {\n clearResetPulledPastTimeout(resetPulledPastTimeoutRef);\n },\n []\n );\n\n useEffect(() => {\n const termsAndConditionsElement = termsAndConditionsRef?.current;\n if (!termsAndConditionsElement) {\n return;\n }\n\n if (!('IntersectionObserver' in window)) {\n return;\n }\n\n const observer = new IntersectionObserver(\n (entries) => {\n const entry = entries[0];\n const hasReachedTermsSection = entry?.isIntersecting ?? false;\n const shouldAutoCloseDrawer = hasReachedTermsSection;\n const shouldHideDrawerTab =\n hasReachedTermsSection && !openDrawerRef.current && !isOpeningGestureRef.current;\n setIsDrawerHidden(shouldHideDrawerTab);\n\n if (shouldAutoCloseDrawer && openDrawerRef.current && isScrollingDownRef.current) {\n closeDrawerHandler({ shouldReopenOnScrollUp: true });\n setIsDrawerHidden(true);\n }\n },\n {\n root: null,\n threshold: 0,\n rootMargin: '0px 0px -40% 0px',\n }\n );\n\n observer.observe(termsAndConditionsElement);\n\n return () => {\n observer.disconnect();\n };\n }, [termsAndConditionsRef]);\n\n const toggleDrawer = () => {\n if (openDrawerRef.current) {\n closeDrawerHandler();\n return;\n }\n\n openDrawerHandler();\n };\n\n const openDrawerHandler = () => {\n clearResetPulledPastTimeout(resetPulledPastTimeoutRef);\n setIsOpeningGesture(false);\n setHasPulledPastClosedTabHeight(false);\n openingTouchStartYRef.current = null;\n shouldReopenOnScrollUpRef.current = false;\n setIsDrawerOpened(true);\n onOpenChange?.(true);\n };\n\n const closeDrawerHandler = ({\n shouldReopenOnScrollUp = false,\n }: { shouldReopenOnScrollUp?: boolean } = {}) => {\n clearResetPulledPastTimeout(resetPulledPastTimeoutRef);\n setIsOpeningGesture(false);\n setHasPulledPastClosedTabHeight(false);\n openingTouchStartYRef.current = null;\n shouldReopenOnScrollUpRef.current = shouldReopenOnScrollUp;\n setIsDrawerOpened(false);\n onOpenChange?.(false);\n };\n\n const scheduleResetPulledPastTimeout = () => {\n clearResetPulledPastTimeout(resetPulledPastTimeoutRef);\n resetPulledPastTimeoutRef.current = window.setTimeout(() => {\n if (!openDrawerRef.current) {\n setHasPulledPastClosedTabHeight(false);\n }\n }, 180);\n };\n\n const handleGestureStart = (startY: number | null) => {\n openingTouchStartYRef.current = startY;\n setIsOpeningGesture(true);\n setHasPulledPastClosedTabHeight(false);\n };\n\n const handleGestureMove = (currentY?: number) => {\n if (!isOpeningGestureRef.current) return;\n\n const startY = openingTouchStartYRef.current;\n if (startY === null || typeof currentY !== 'number') return;\n\n const pullDistance = startY - currentY;\n const currentClosedTabHeight = closedTabRef.current?.offsetHeight ?? 0;\n setHasPulledPastClosedTabHeight(\n currentClosedTabHeight > 0 && pullDistance >= currentClosedTabHeight\n );\n };\n\n const handleGestureCancel = () => {\n openingTouchStartYRef.current = null;\n setIsOpeningGesture(false);\n setHasPulledPastClosedTabHeight(false);\n };\n\n const handleGestureEnd = ({\n shouldResetTouchStart = false,\n }: { shouldResetTouchStart?: boolean } = {}) => {\n if (shouldResetTouchStart) {\n openingTouchStartYRef.current = null;\n }\n\n if (!isDrawerOpened) {\n setIsOpeningGesture(false);\n scheduleResetPulledPastTimeout();\n }\n };\n\n return (\n <Box sx={{ display: { md: 'none' } }}>\n {/* Drawer Tab */}\n <Box\n ref={closedTabRef}\n sx={{\n position: 'fixed',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: (theme) => theme.palette.background.paper,\n borderTopLeftRadius: isOpeningGesture || isDrawerOpened ? 0 : 16,\n borderTopRightRadius: isOpeningGesture || isDrawerOpened ? 0 : 16,\n boxShadow:\n isOpeningGesture || isDrawerOpened ? 'none' : '0 -8px 10px 2px rgba(0,0,0,0.2)',\n zIndex: (theme) => theme.zIndex.drawer + 1,\n opacity: isDrawerHidden ? 0 : 1,\n transform: isDrawerHidden ? 'translateY(calc(100% + 12px))' : 'translateY(0)',\n transition:\n 'opacity 180ms ease, transform 180ms ease, border-radius 120ms ease, box-shadow 120ms ease',\n pointerEvents: 'none',\n }}\n >\n {!isDrawerOpened && (\n <Box\n sx={{\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n width: '100%',\n py: 1,\n }}\n >\n <Box\n sx={{\n width: 80,\n height: 6,\n backgroundColor: (theme) => theme.palette.grey[300],\n borderRadius: 3,\n opacity: isOpeningGesture ? 0 : 1,\n transition: 'opacity 120ms ease',\n }}\n />\n </Box>\n )}\n <Box\n role=\"button\"\n aria-label={t('form.labels.payment_overview_open')}\n onClick={toggleDrawer}\n onTouchStart={(event: React.TouchEvent<HTMLDivElement>) => {\n handleGestureStart(event.touches[0]?.clientY ?? null);\n }}\n onMouseDown={() => {\n handleGestureStart(null);\n }}\n onTouchMove={(event: React.TouchEvent<HTMLDivElement>) => {\n handleGestureMove(event.touches[0]?.clientY);\n }}\n onTouchCancel={handleGestureCancel}\n onTouchEnd={() => {\n handleGestureEnd({ shouldResetTouchStart: true });\n }}\n onMouseUp={() => {\n handleGestureEnd();\n }}\n sx={{\n width: '100%',\n px: 2,\n pb: 2,\n pointerEvents: isDrawerOpened || isDrawerHidden ? 'none' : 'auto',\n cursor: 'pointer',\n }}\n >\n <Typography\n sx={{\n fontWeight: 'bold',\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n }}\n >\n <span>{t('form.labels.total')}:</span>\n <span>{fCurrency(totalPrice, lang, event.currency)}</span>\n </Typography>\n\n <Button\n type=\"submit\"\n form={EVENTLOOK_ORDER_FORM_ID}\n onClick={(event) => {\n event.stopPropagation();\n }}\n variant=\"contained\"\n size=\"large\"\n fullWidth\n sx={{ mt: 1, height: { xs: 36, md: 40 } }}\n >\n {t('buy')}\n </Button>\n </Box>\n </Box>\n\n {/* Drawer Content */}\n <SwipeableDrawer\n anchor=\"bottom\"\n open={isDrawerOpened}\n onClose={() => closeDrawerHandler()}\n onOpen={() => openDrawerHandler()}\n swipeAreaWidth={swipeAreaWidth}\n allowSwipeInChildren\n disableSwipeToOpen={isDrawerHidden}\n keepMounted\n SwipeAreaProps={{\n onTouchStart: (event: React.TouchEvent<HTMLDivElement>) => {\n handleGestureStart(event.touches[0]?.clientY ?? null);\n },\n onMouseDown: () => {\n handleGestureStart(null);\n },\n onTouchMove: (event: React.TouchEvent<HTMLDivElement>) => {\n handleGestureMove(event.touches[0]?.clientY);\n },\n onTouchCancel: handleGestureCancel,\n onTouchEnd: () => {\n handleGestureEnd({ shouldResetTouchStart: true });\n },\n onMouseUp: () => {\n handleGestureEnd();\n },\n }}\n sx={{\n display: { md: 'none' },\n pointerEvents: isDrawerOpened ? 'none' : 'auto',\n '& .MuiDrawer-paper': {\n pointerEvents: 'auto',\n },\n '& .MuiSwipeArea-root': {\n pointerEvents: 'auto',\n },\n }}\n ModalProps={{\n disableScrollLock: true,\n keepMounted: false,\n disableAutoFocus: true,\n disableRestoreFocus: true,\n disableEnforceFocus: true,\n BackdropProps: {\n sx: {\n background: 'none',\n pointerEvents: 'none',\n },\n },\n }}\n PaperProps={{\n sx: {\n borderTopLeftRadius: 16,\n borderTopRightRadius: 16,\n boxShadow: '0 -8px 10px 2px rgba(0,0,0,0.2)',\n overflow: 'hidden',\n mb:\n isDrawerOpened ||\n (!isDrawerOpened && (isOpeningGesture || hasPulledPastClosedTabHeight))\n ? `${closedTabHeight}px`\n : 0,\n transition: 'none',\n },\n }}\n >\n <Box\n role=\"button\"\n aria-label={t('form.labels.payment_overview_close')}\n onClick={toggleDrawer}\n sx={{\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n backgroundColor: (theme) => theme.palette.background.paper,\n cursor: 'pointer',\n py: 1,\n }}\n >\n <Box\n sx={{\n width: 80,\n height: 6,\n backgroundColor: (theme) => theme.palette.grey[300],\n borderRadius: 3,\n }}\n />\n </Box>\n <Box\n sx={{\n height: '100%',\n overflow: 'auto',\n }}\n >\n <PaymentOverviewBox event={event} hideBuyButton />\n </Box>\n </SwipeableDrawer>\n </Box>\n );\n};\n\nexport default PaymentOverviewDrawer;\n"],"names":[],"mappings":"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"}
|
|
@@ -89,20 +89,23 @@ const Shipping = ({ event }) => {
|
|
|
89
89
|
if (selectedShippingMethod?.type === ShippingTypes.PACKETA) {
|
|
90
90
|
openPacketaWidget();
|
|
91
91
|
}
|
|
92
|
-
} }, filteredShippingMethods.map((shippingMethod) => (React.createElement(ShippingMethodItem, { key: shippingMethod.id, active: Number(shippingMethodId) === shippingMethod.id, hasError: !!error
|
|
92
|
+
} }, filteredShippingMethods.map((shippingMethod) => (React.createElement(ShippingMethodItem, { key: shippingMethod.id, active: Number(shippingMethodId) === shippingMethod.id, hasError: !!error, sx: {
|
|
93
|
+
'& .MuiFormControlLabel-labelPlacementEnd': {
|
|
94
|
+
mr: 0,
|
|
95
|
+
width: '100%',
|
|
96
|
+
},
|
|
97
|
+
} },
|
|
93
98
|
React.createElement(FormControlLabel, { value: shippingMethod.id, control: React.createElement(Radio, null), label: React.createElement(Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", width: "100%" },
|
|
94
|
-
React.createElement(Stack, { direction: "
|
|
95
|
-
React.createElement(
|
|
96
|
-
marginRight: 2,
|
|
97
|
-
} },
|
|
99
|
+
React.createElement(Stack, { direction: "column" },
|
|
100
|
+
React.createElement(Stack, { direction: "row", alignItems: "center", spacing: 1 },
|
|
98
101
|
React.createElement(Typography, { sx: { lineHeight: 1.2 } }, t(`shipping_method.types.${shippingMethod.type}`)),
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
102
|
+
paymentImages[shippingMethod.type]),
|
|
103
|
+
displayBranchName &&
|
|
104
|
+
shippingMethod.type === ShippingTypes.PACKETA &&
|
|
105
|
+
shippingMethod.id === Number(shippingMethodId) && (React.createElement(Typography, { variant: "caption", sx: { lineHeight: 1 } }, displayBranchName))),
|
|
103
106
|
shippingMethod.type === ShippingTypes.PACKETA &&
|
|
104
107
|
shippingMethod.id === Number(shippingMethodId) && (React.createElement(Box, null,
|
|
105
|
-
React.createElement(Button, { onClick: handleChangeBranch, variant: "outlined", size: "small" }, t('
|
|
108
|
+
React.createElement(Button, { onClick: handleChangeBranch, variant: "outlined", size: "small", sx: { px: 1, whiteSpace: 'nowrap' } }, t('event.tickets.shipping.choose_address'))))), sx: {
|
|
106
109
|
'&:not(:last-of-type)': {
|
|
107
110
|
mb: 0,
|
|
108
111
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Shipping.js","sources":["../../../src/form/Shipping.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport useEventShippingMethods from '@hooks/data/useEventShippingMethods';\nimport { IEvent } from '@utils/types/event.type';\nimport ShippingSkeleton from '@form/shipping/ShippingSkeleton';\nimport {\n Box,\n Button,\n FormControl,\n FormControlLabel,\n FormHelperText,\n Radio,\n RadioGroup,\n Stack,\n Typography,\n} from '@mui/material';\nimport { ShippingMethodItem } from '@form/style';\nimport { Iconify } from '@components/iconify';\nimport { Controller, useFormContext, useWatch } from 'react-hook-form';\nimport { ITicketForm, ITicketFormTicket } from '@utils/types/ticket.type';\nimport { ShippingTypes } from '@utils/data/shipping-method';\nimport useGlobal from '@hooks/useGlobal';\nimport ScriptLoader from '@form/ScriptLoader';\nimport { IEventProductForm } from '@utils/types/product.type';\n\ninterface Props {\n event: IEvent;\n}\n\nconst Shipping: React.FC<Props> = ({ event }) => {\n const { t, lang, options } = useGlobal();\n const { data: shippingMethods, isLoading } = useEventShippingMethods(event.id, {\n currency: event.currency,\n });\n const { control, watch, setValue } = useFormContext<ITicketForm>();\n const tickets: Record<string, ITicketFormTicket[]> = useWatch({\n name: 'tickets',\n defaultValue: {},\n });\n const flatTickets: ITicketFormTicket[] = useMemo(() => Object.values(tickets).flat(), [tickets]);\n const products: Record<string, IEventProductForm[]> = useWatch({\n name: 'products',\n defaultValue: {},\n });\n const flatProducts: IEventProductForm[] = useMemo(\n () => Object.values(products).flat(),\n [products]\n );\n const shippingMethodId = watch('shipping.shippingMethodId');\n const [displayBranchName, setDisplayBranchName] = useState<string | null>(null);\n const [firstRender, setFirstRender] = useState<boolean>(true);\n const filteredShippingMethods = useMemo(\n () =>\n shippingMethods?.filter(\n (shippingMethod) =>\n !flatProducts?.find((product) =>\n product.excludedShippingMethodIds?.includes(shippingMethod?.id)\n ) &&\n !flatTickets.find((ticket) =>\n ticket.products.find((product) =>\n product.excludedShippingMethodIds?.includes(shippingMethod?.id)\n )\n )\n ),\n [shippingMethods, shippingMethodId, flatTickets, flatProducts]\n );\n\n const paymentImages = {\n [ShippingTypes.PACKETA]: (\n <Iconify icon=\"arcticons:packeta\" color=\"rgb(186,27,2)\" width={32} height={32} />\n ),\n [ShippingTypes.PICK_UP]: <Iconify icon=\"flowbite:store-solid\" width={32} height={32} />,\n };\n\n const onSelectBranch = (branch: any) => {\n if (branch) {\n setValue('shipping.branchId', branch.id);\n setDisplayBranchName(branch.name);\n } else {\n setValue('shipping.shippingMethodId', null);\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n }\n };\n\n const openPacketaWidget = () => {\n const interval = setInterval(() => {\n if (window.Packeta && window.Packeta.Widget) {\n clearInterval(interval);\n window.Packeta.Widget.pick(options?.packetaApiKey, onSelectBranch, {\n language: lang,\n });\n }\n }, 100);\n };\n\n const handleChangeBranch = () => {\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n openPacketaWidget();\n };\n\n useEffect(() => {\n if (firstRender && filteredShippingMethods.length === 1) {\n setValue('shipping.shippingMethodId', filteredShippingMethods[0].id);\n setFirstRender(false);\n }\n }, [firstRender, filteredShippingMethods]);\n\n useEffect(() => {\n const selectedShippingMethod = shippingMethods.find(\n (method) => method.id === Number(shippingMethodId)\n );\n\n if (selectedShippingMethod) {\n setValue('shipping.price', selectedShippingMethod.price);\n\n if (selectedShippingMethod.type !== ShippingTypes.PACKETA) {\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n }\n } else {\n setValue('shipping.price', 0);\n }\n }, [shippingMethodId, shippingMethods]);\n\n return (\n <>\n <ScriptLoader />\n <div>\n {isLoading ? (\n <ShippingSkeleton />\n ) : (\n <>\n {filteredShippingMethods.length === 0 ? (\n <Typography variant=\"h4\" color=\"error\">\n {t('event.tickets.stepper.5.error')}\n </Typography>\n ) : (\n <>\n <Controller\n name=\"shipping.shippingMethodId\"\n control={control}\n render={({ field, fieldState: { error } }) => (\n <FormControl component=\"fieldset\" sx={{ width: '100%' }}>\n <RadioGroup\n {...field}\n onChange={(event, value) => {\n field.onChange(event);\n const selectedShippingMethod = filteredShippingMethods.find(\n (method) => method.id === Number(value)\n );\n\n if (selectedShippingMethod?.type === ShippingTypes.PACKETA) {\n openPacketaWidget();\n }\n }}\n >\n {filteredShippingMethods.map((shippingMethod) => (\n <ShippingMethodItem\n key={shippingMethod.id}\n active={Number(shippingMethodId) === shippingMethod.id}\n hasError={!!error}\n >\n <FormControlLabel\n value={shippingMethod.id}\n control={<Radio />}\n label={\n <Stack\n direction=\"row\"\n justifyContent=\"space-between\"\n alignItems=\"center\"\n width=\"100%\"\n >\n <Stack direction=\"row\" alignItems=\"center\">\n <Box\n sx={{\n marginRight: 2,\n }}\n >\n <Typography sx={{ lineHeight: 1.2 }}>\n {t(`shipping_method.types.${shippingMethod.type}`)}\n </Typography>\n {displayBranchName &&\n shippingMethod.type === ShippingTypes.PACKETA &&\n shippingMethod.id === Number(shippingMethodId) && (\n <Typography variant=\"caption\" sx={{ lineHeight: 1 }}>\n {displayBranchName}\n </Typography>\n )}\n </Box>\n {paymentImages[shippingMethod.type]}\n </Stack>\n {shippingMethod.type === ShippingTypes.PACKETA &&\n shippingMethod.id === Number(shippingMethodId) && (\n <Box>\n <Button\n onClick={handleChangeBranch}\n variant=\"outlined\"\n size=\"small\"\n >\n {t('change')}\n </Button>\n </Box>\n )}\n </Stack>\n }\n sx={{\n '&:not(:last-of-type)': {\n mb: 0,\n },\n '& .MuiFormControlLabel-label': {\n width: '100%',\n mr: 0,\n },\n }}\n />\n </ShippingMethodItem>\n ))}\n </RadioGroup>\n\n {!!error && (\n <FormHelperText error={!!error} sx={{ mx: 0 }}>\n {error?.message}\n </FormHelperText>\n )}\n </FormControl>\n )}\n />\n </>\n )}\n </>\n )}\n </div>\n </>\n );\n};\n\nexport default Shipping;\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Shipping.js","sources":["../../../src/form/Shipping.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport useEventShippingMethods from '@hooks/data/useEventShippingMethods';\nimport { IEvent } from '@utils/types/event.type';\nimport ShippingSkeleton from '@form/shipping/ShippingSkeleton';\nimport {\n Box,\n Button,\n FormControl,\n FormControlLabel,\n FormHelperText,\n Radio,\n RadioGroup,\n Stack,\n Typography,\n} from '@mui/material';\nimport { ShippingMethodItem } from '@form/style';\nimport { Iconify } from '@components/iconify';\nimport { Controller, useFormContext, useWatch } from 'react-hook-form';\nimport { ITicketForm, ITicketFormTicket } from '@utils/types/ticket.type';\nimport { ShippingTypes } from '@utils/data/shipping-method';\nimport useGlobal from '@hooks/useGlobal';\nimport ScriptLoader from '@form/ScriptLoader';\nimport { IEventProductForm } from '@utils/types/product.type';\n\ninterface Props {\n event: IEvent;\n}\n\nconst Shipping: React.FC<Props> = ({ event }) => {\n const { t, lang, options } = useGlobal();\n const { data: shippingMethods, isLoading } = useEventShippingMethods(event.id, {\n currency: event.currency,\n });\n const { control, watch, setValue } = useFormContext<ITicketForm>();\n const tickets: Record<string, ITicketFormTicket[]> = useWatch({\n name: 'tickets',\n defaultValue: {},\n });\n const flatTickets: ITicketFormTicket[] = useMemo(() => Object.values(tickets).flat(), [tickets]);\n const products: Record<string, IEventProductForm[]> = useWatch({\n name: 'products',\n defaultValue: {},\n });\n const flatProducts: IEventProductForm[] = useMemo(\n () => Object.values(products).flat(),\n [products]\n );\n const shippingMethodId = watch('shipping.shippingMethodId');\n const [displayBranchName, setDisplayBranchName] = useState<string | null>(null);\n const [firstRender, setFirstRender] = useState<boolean>(true);\n const filteredShippingMethods = useMemo(\n () =>\n shippingMethods?.filter(\n (shippingMethod) =>\n !flatProducts?.find((product) =>\n product.excludedShippingMethodIds?.includes(shippingMethod?.id)\n ) &&\n !flatTickets.find((ticket) =>\n ticket.products.find((product) =>\n product.excludedShippingMethodIds?.includes(shippingMethod?.id)\n )\n )\n ),\n [shippingMethods, shippingMethodId, flatTickets, flatProducts]\n );\n\n const paymentImages = {\n [ShippingTypes.PACKETA]: (\n <Iconify icon=\"arcticons:packeta\" color=\"rgb(186,27,2)\" width={32} height={32} />\n ),\n [ShippingTypes.PICK_UP]: <Iconify icon=\"flowbite:store-solid\" width={32} height={32} />,\n };\n\n const onSelectBranch = (branch: any) => {\n if (branch) {\n setValue('shipping.branchId', branch.id);\n setDisplayBranchName(branch.name);\n } else {\n setValue('shipping.shippingMethodId', null);\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n }\n };\n\n const openPacketaWidget = () => {\n const interval = setInterval(() => {\n if (window.Packeta && window.Packeta.Widget) {\n clearInterval(interval);\n window.Packeta.Widget.pick(options?.packetaApiKey, onSelectBranch, {\n language: lang,\n });\n }\n }, 100);\n };\n\n const handleChangeBranch = () => {\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n openPacketaWidget();\n };\n\n useEffect(() => {\n if (firstRender && filteredShippingMethods.length === 1) {\n setValue('shipping.shippingMethodId', filteredShippingMethods[0].id);\n setFirstRender(false);\n }\n }, [firstRender, filteredShippingMethods]);\n\n useEffect(() => {\n const selectedShippingMethod = shippingMethods.find(\n (method) => method.id === Number(shippingMethodId)\n );\n\n if (selectedShippingMethod) {\n setValue('shipping.price', selectedShippingMethod.price);\n\n if (selectedShippingMethod.type !== ShippingTypes.PACKETA) {\n setValue('shipping.branchId', null);\n setDisplayBranchName(null);\n }\n } else {\n setValue('shipping.price', 0);\n }\n }, [shippingMethodId, shippingMethods]);\n\n return (\n <>\n <ScriptLoader />\n <div>\n {isLoading ? (\n <ShippingSkeleton />\n ) : (\n <>\n {filteredShippingMethods.length === 0 ? (\n <Typography variant=\"h4\" color=\"error\">\n {t('event.tickets.stepper.5.error')}\n </Typography>\n ) : (\n <>\n <Controller\n name=\"shipping.shippingMethodId\"\n control={control}\n render={({ field, fieldState: { error } }) => (\n <FormControl component=\"fieldset\" sx={{ width: '100%' }}>\n <RadioGroup\n {...field}\n onChange={(event, value) => {\n field.onChange(event);\n const selectedShippingMethod = filteredShippingMethods.find(\n (method) => method.id === Number(value)\n );\n\n if (selectedShippingMethod?.type === ShippingTypes.PACKETA) {\n openPacketaWidget();\n }\n }}\n >\n {filteredShippingMethods.map((shippingMethod) => (\n <ShippingMethodItem\n key={shippingMethod.id}\n active={Number(shippingMethodId) === shippingMethod.id}\n hasError={!!error}\n sx={{\n '& .MuiFormControlLabel-labelPlacementEnd': {\n mr: 0,\n width: '100%',\n },\n }}\n >\n <FormControlLabel\n value={shippingMethod.id}\n control={<Radio />}\n label={\n <Stack\n direction=\"row\"\n justifyContent=\"space-between\"\n alignItems=\"center\"\n width=\"100%\"\n >\n <Stack direction=\"column\">\n <Stack direction=\"row\" alignItems=\"center\" spacing={1}>\n <Typography sx={{ lineHeight: 1.2 }}>\n {t(`shipping_method.types.${shippingMethod.type}`)}\n </Typography>\n {paymentImages[shippingMethod.type]}\n </Stack>\n {displayBranchName &&\n shippingMethod.type === ShippingTypes.PACKETA &&\n shippingMethod.id === Number(shippingMethodId) && (\n <Typography variant=\"caption\" sx={{ lineHeight: 1 }}>\n {displayBranchName}\n </Typography>\n )}\n </Stack>\n {shippingMethod.type === ShippingTypes.PACKETA &&\n shippingMethod.id === Number(shippingMethodId) && (\n <Box>\n <Button\n onClick={handleChangeBranch}\n variant=\"outlined\"\n size=\"small\"\n sx={{ px: 1, whiteSpace: 'nowrap' }}\n >\n {t('event.tickets.shipping.choose_address')}\n </Button>\n </Box>\n )}\n </Stack>\n }\n sx={{\n '&:not(:last-of-type)': {\n mb: 0,\n },\n '& .MuiFormControlLabel-label': {\n width: '100%',\n mr: 0,\n },\n }}\n />\n </ShippingMethodItem>\n ))}\n </RadioGroup>\n\n {!!error && (\n <FormHelperText error={!!error} sx={{ mx: 0 }}>\n {error?.message}\n </FormHelperText>\n )}\n </FormControl>\n )}\n />\n </>\n )}\n </>\n )}\n </div>\n </>\n );\n};\n\nexport default Shipping;\n"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@ import OrderSuccess from './OrderSuccess.js';
|
|
|
2
2
|
import PaymentSuccess from './PaymentSuccess.js';
|
|
3
3
|
import React, { useState, useRef, useEffect, useMemo } from 'react';
|
|
4
4
|
import { useForm } from 'react-hook-form';
|
|
5
|
-
import { Box, Stack, Typography, Grid, Stepper, Step, StepLabel, StepContent, Link } from '@mui/material';
|
|
5
|
+
import { Box, Stack, Typography, Grid, Stepper, Step, StepLabel, StepContent, Divider, Link } from '@mui/material';
|
|
6
6
|
import { RHFCheckbox } from '../components/hook-form/RHFCheckbox.js';
|
|
7
7
|
import FormProvider from '../components/hook-form/FormProvider.js';
|
|
8
8
|
import dayjs from 'dayjs';
|
|
@@ -27,7 +27,6 @@ import useErrors from '../hooks/useErrors.js';
|
|
|
27
27
|
import { EventType } from '../utils/data/event.js';
|
|
28
28
|
import TimeslotSelection from './TimeslotSelection.js';
|
|
29
29
|
import useGlobal from '../hooks/useGlobal.js';
|
|
30
|
-
import useConsentScrollOnDrawerOpen from '../hooks/useConsentScrollOnDrawerOpen.js';
|
|
31
30
|
import useScrollToFirstError from '../hooks/useScrollToFirstError.js';
|
|
32
31
|
import { Trans } from '../components/Trans.js';
|
|
33
32
|
import { EVENTLOOK_ORDER_FORM_CONTAINER_ID, EVENTLOOK_ORDER_FORM_ID } from '../utils/data/global.js';
|
|
@@ -62,10 +61,6 @@ const TicketForm = ({ event, hasGopayIdSsr, selectedReleaseId, isIframe, isInlin
|
|
|
62
61
|
const hasFiredBeginCheckout = useRef(false);
|
|
63
62
|
const hasFiredPaymentMethod = useRef(false);
|
|
64
63
|
const termsAndConditionsRef = useRef(null);
|
|
65
|
-
useConsentScrollOnDrawerOpen({
|
|
66
|
-
isDrawerOpen: isPaymentOverviewDrawerOpen,
|
|
67
|
-
consentRef: termsAndConditionsRef,
|
|
68
|
-
});
|
|
69
64
|
const item = {
|
|
70
65
|
currency: event.currency,
|
|
71
66
|
items: [
|
|
@@ -493,9 +488,11 @@ const TicketForm = ({ event, hasGopayIdSsr, selectedReleaseId, isIframe, isInlin
|
|
|
493
488
|
0: React.createElement(CustomLink, { key: 2, href: links.termsAndConditions, target: "_blank" }),
|
|
494
489
|
1: React.createElement(CustomLink, { key: 1, href: links.gdpr, target: "_blank" }),
|
|
495
490
|
} }) }))),
|
|
496
|
-
React.createElement(Grid, { item: true, xs: 12,
|
|
497
|
-
React.createElement(
|
|
498
|
-
|
|
491
|
+
React.createElement(Grid, { item: true, xs: 12, sx: { display: { xs: 'block', md: 'none' } } },
|
|
492
|
+
React.createElement(Divider, { sx: { borderStyle: 'dashed' } })),
|
|
493
|
+
React.createElement(Grid, { item: true, xs: 12, md: 4, mt: { xs: 0, md: 0 } },
|
|
494
|
+
React.createElement(PaymentOverviewBox, { event: event, withoutPadding: true }))),
|
|
495
|
+
React.createElement(PaymentOverviewDrawer, { event: event, totalPrice: values.total, termsAndConditionsRef: termsAndConditionsRef, onOpenChange: setIsPaymentOverviewDrawerOpen }),
|
|
499
496
|
React.createElement(EmailConfirmation, { open: formStep === 2 && !isIframe, onClose: () => setFormStep(1),
|
|
500
497
|
// @ts-ignore
|
|
501
498
|
onConfirm: methods.handleSubmit(onSubmit, onInvalid) })))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TicketForm.js","sources":["../../../src/form/TicketForm.tsx"],"sourcesContent":["import OrderSuccess from '@form/OrderSuccess';\nimport PaymentSuccess from '@form/PaymentSuccess';\nimport FormProvider, { RHFCheckbox } from '@components/hook-form';\nimport {\n Box,\n Grid,\n Link,\n LinkProps,\n Stack,\n Step,\n StepContent,\n StepLabel,\n Stepper,\n Typography,\n} from '@mui/material';\nimport dayjs from 'dayjs';\nimport TicketSelection from '@form/tickets/TicketSelection';\nimport ContactPerson from '@form/ContactPerson';\nimport Payment from '@form/Payment';\nimport EmailConfirmation from '@form/EmailConfirmation';\nimport React, { useEffect, useMemo, useRef, useState } from 'react';\nimport { PropsWithChildren } from '@utils/types/global.type';\nimport { getSearchParamsInObject } from '@utils/url';\nimport { ITicketBody, ITicketForm, ITicketFormTicket } from '@utils/types/ticket.type';\nimport * as Yup from 'yup';\nimport { useForm } from 'react-hook-form';\nimport { yupResolver } from '@hookform/resolvers/yup';\nimport { postOrder } from '@modules/order';\nimport { IEvent } from '@utils/types/event.type';\nimport PaymentOverviewBox from '@form/PaymentOverviewBox';\nimport { IEcommerce, IPixels } from '@utils/types/gtm.type';\nimport {\n getGtmAddPaymentInfo,\n getGtmBeginCheckout,\n getGtmPageView,\n getGtmPurchase,\n getGtmViewCart,\n gtmAddPaymentInfo,\n gtmBeginCheckout,\n gtmPurchase,\n gtmViewCart,\n mapUserToUserData,\n} from '@utils/gtm';\nimport ReleaseCountdown from '@form/ReleaseCountdown';\nimport { cloneObject } from '@utils/global';\nimport PaymentPending from '@form/PaymentPending';\nimport MerchandiseSelection from '@form/merchandise/MerchandiseSelection';\nimport TicketWithMerchandiseSelection from '@form/tickets/TicketWithMerchandiseSelection';\nimport useActiveEventProducts from '@hooks/data/useActiveEventProducts';\nimport Shipping from '@form/Shipping';\nimport useErrors from '@hooks/useErrors';\nimport { EventType } from '@utils/data/event';\nimport TimeslotSelection from '@form/TimeslotSelection';\nimport useGlobal from '@hooks/useGlobal';\nimport useConsentScrollOnDrawerOpen from '@hooks/useConsentScrollOnDrawerOpen';\nimport useScrollToFirstError from '@hooks/useScrollToFirstError';\nimport { Trans } from '@components/Trans';\nimport { EVENTLOOK_ORDER_FORM_ID, EVENTLOOK_ORDER_FORM_CONTAINER_ID } from '@utils/data/global.ts';\nimport ChildEventSection from './ChildEvents';\nimport TicketSelectionMap from '@form/tickets/TicketSelectionMap';\nimport PaymentOverviewDrawer from './PaymentOverviewDrawer';\nimport { getPlaceAsString } from '@utils/place';\nimport Services from '@form/services';\n\ninterface Props {\n event: IEvent;\n hasGopayIdSsr: boolean;\n selectedReleaseId?: number;\n isIframe?: boolean;\n isInline?: boolean;\n headerSlot?: React.ReactNode;\n}\n\nconst getCartUniqueItemCount = (formValues: ITicketForm) => {\n const flatTickets = Object.values(formValues.tickets ?? {}).flat();\n const ticketsCount = flatTickets.reduce(\n (sum, ticket) => sum + (Number(ticket.quantity) > 0 ? 1 : 0),\n 0\n );\n const ticketsWithProductsCount = flatTickets.reduce(\n (sum, ticket) => sum + ((ticket.products?.length ?? 0) > 0 ? 1 : 0),\n 0\n );\n const productsCount = Object.values(formValues.products ?? {})\n .flat()\n .reduce((sum, product) => sum + (Number(product.quantity) || 0), 0);\n\n return ticketsCount + ticketsWithProductsCount + productsCount;\n};\n\nconst TicketForm: React.FC<Props> = ({\n event,\n hasGopayIdSsr,\n selectedReleaseId,\n isIframe,\n isInline,\n headerSlot,\n}) => {\n const { t, setGlobal, callbacks, links, user, options, showSnackbar, content, seatingIframeUrl } =\n useGlobal();\n const { transformErrors } = useErrors(t('event.tickets.error.order'));\n const { data: eventProducts, isLoading } = useActiveEventProducts(event.id);\n const [paymentRedirect, setPaymentRedirect] = useState<string | null>(null);\n const [hasGopayId, setHasGopayId] = useState<boolean>(hasGopayIdSsr);\n const [isPaying, setIsPaying] = useState<boolean>(false);\n const [formStep, setFormStep] = useState<number>(1);\n const [isPaymentOverviewDrawerOpen, setIsPaymentOverviewDrawerOpen] = useState<boolean>(false);\n const [showReleaseDate, setShowReleaseDate] = useState(\n dayjs(event.releaseDate).diff(dayjs()) > 0\n );\n const [matchIsValidTel, setMatchIsValidTel] = useState<(text: string) => boolean>(() => false);\n const isNotReleased = dayjs(event.releaseDate).diff(dayjs()) > 0;\n const hasFiredViewCart = useRef(false);\n const hasFiredBeginCheckout = useRef(false);\n const hasFiredPaymentMethod = useRef(false);\n const termsAndConditionsRef = useRef<HTMLDivElement | null>(null);\n\n useConsentScrollOnDrawerOpen({\n isDrawerOpen: isPaymentOverviewDrawerOpen,\n consentRef: termsAndConditionsRef,\n });\n\n const item: IEcommerce = {\n currency: event.currency,\n items: [\n {\n item_id: `event_${event.id}`,\n item_name: event.name,\n quantity: 1,\n },\n ],\n };\n const pixels: IPixels = {\n fb_pixel_id: event.facebookPixel?.facebookId,\n tiktok_pixel_id: event.tiktokPixel?.tiktokId,\n };\n\n useEffect(() => {\n import('mui-tel-input').then((mod) => {\n setMatchIsValidTel(() => mod.matchIsValidTel);\n });\n }, []);\n\n useEffect(() => {\n setGlobal({\n options: {\n isIframe: isIframe === undefined ? false : isIframe,\n },\n });\n if (\n !isIframe &&\n event &&\n (isNotReleased ||\n (!!event.releaseEndDate && dayjs(event.releaseEndDate).isBefore(dayjs())) ||\n dayjs(event.endDate).isBefore(dayjs()) ||\n event.isSoldout ||\n event.dateUnknown ||\n event.isCanceled)\n ) {\n callbacks.detail();\n }\n\n if (event && !hasGopayId && !hasFiredViewCart.current) {\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPageView(location.href),\n },\n '*'\n );\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmViewCart(item, pixels),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmViewCart(item, pixels);\n }\n hasFiredViewCart.current = true;\n }\n if (!hasFiredPaymentMethod.current) {\n const item = {\n currency: event.currency,\n value: 0,\n payment_type: 'PAYMENT_CARD',\n items: [],\n };\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmAddPaymentInfo(item, pixels, user ? mapUserToUserData(user) : undefined),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmAddPaymentInfo(item, pixels);\n }\n hasFiredPaymentMethod.current = true;\n }\n }, [event]);\n\n const defaultValues: ITicketForm = useMemo(() => {\n const makeTicket = (overrides: Partial<ITicketFormTicket> = {}): ITicketFormTicket => ({\n releaseId: '',\n quantity: '',\n itemName: '',\n price: 0,\n products: [],\n extraFields: [],\n ...overrides,\n });\n\n const tickets: Record<string, ITicketFormTicket[]> = {\n [String(event.id)]: [\n makeTicket({\n releaseId: (selectedReleaseId as number) ?? '',\n }),\n ],\n };\n\n event.children?.forEach((child) => {\n tickets[String(child.id)] = [makeTicket()];\n });\n\n return {\n uuid: null,\n eventId: event.id,\n tickets,\n total: 0,\n originalPrice: 0,\n firstName: user?.firstName || '',\n lastName: user?.lastName || '',\n email: user?.email || '',\n phone: user?.phone || '',\n birthdate: user?.birthdate ? dayjs(user.birthdate) : null,\n gender: user?.gender || '',\n callback: '',\n paymentMethodId: null,\n paymentMethodOptionId: null,\n termsAndConditions: false,\n ticketInsurance: false,\n ticketInsurancePrice: 0,\n ticketInsurancePricePerUnit: 0,\n smsNotification: false,\n smsNotificationPrice: 0,\n iframeCampaignId: undefined,\n promoCodes: [],\n products: {},\n shipping: {\n shippingMethodId: null,\n branchId: null,\n price: 0,\n },\n extraFields:\n event?.extraFields.map((field) => ({\n eventExtraFieldId: field.id,\n value: '',\n })) || [],\n selectedDate: null,\n eventTimeslotId: null,\n isPaymentVerify: false,\n };\n }, [user]);\n\n const ValidationSchema = Yup.object().shape({\n firstName: Yup.string().required(t('form.validation.required')),\n lastName: Yup.string().required(t('form.validation.required')),\n email: Yup.string().email(t('form.validation.email')).required(t('form.validation.required')),\n phone: Yup.string()\n .required(t('form.validation.required'))\n .test('phone-checker', t('form.validation.phone'), (value) =>\n value ? matchIsValidTel(value) : false\n ),\n birthdate: Yup.object()\n .nullable()\n .default(null)\n .when([], {\n is: () => !content?.form?.disableBirthDate,\n then: (s) => s.required(t('form.validation.required')),\n otherwise: (s) => s.notRequired(),\n }),\n gender: Yup.string().when([], {\n is: () => !content?.form?.disableGender,\n then: (schema) => schema.required(t('form.validation.required')),\n otherwise: (schema) => schema.notRequired(),\n }),\n // tickets: Yup.object().test('tickets-validation', function (tickets) {\n // if (!tickets || typeof tickets !== 'object') return false;\n\n // for (const key of Object.keys(tickets)) {\n // const arr = tickets[key];\n // if (!Array.isArray(arr)) return false;\n // for (const t of arr) {\n // if (!t.releaseId || !t.quantity) {\n // return this.createError({ message: 'Invalid ticket selection' });\n // }\n // }\n // }\n // return true;\n // }),\n shipping: Yup.object()\n .shape({\n shippingMethodId: Yup.number().nullable(),\n branchId: Yup.string().nullable(),\n price: Yup.number(),\n })\n .test('shipping-method-required', t('form.validation.required'), function (value) {\n if (!event.hasMerchandise) {\n return true;\n }\n\n const formValues = this.parent as ITicketForm;\n const hasProducts = Object.values(formValues.products ?? {}).some((arr) => arr.length > 0);\n const allTickets = Object.values(formValues.tickets ?? {}).flat();\n const hasTicketProducts = allTickets.some((ticket) => (ticket.products?.length ?? 0) > 0);\n const requiresShipping = hasProducts || hasTicketProducts;\n\n if (!requiresShipping) {\n return true;\n }\n\n if (value?.shippingMethodId !== null && value?.shippingMethodId !== undefined) {\n return true;\n }\n\n return this.createError({\n path: 'shipping.shippingMethodId',\n message: t('form.validation.required'),\n });\n }),\n paymentMethodId: Yup.number().nullable().required(t('form.validation.required')),\n paymentMethodOptionId: Yup.number().nullable(),\n termsAndConditions: Yup.boolean().isTrue(t('form.validation.terms_and_conditions')),\n ticketInsurance: Yup.boolean(),\n smsNotification: Yup.boolean(),\n extraFields: Yup.array().of(\n Yup.object().shape({\n value: Yup.string().test('is-required', function (value) {\n const options = this.options as { index: number };\n\n if (event.extraFields[options.index].required && !value) {\n return this.createError({\n message: t('form.validation.required'),\n });\n }\n return true;\n }),\n })\n ),\n });\n\n const methods = useForm<ITicketForm>({\n // @ts-ignore\n resolver: yupResolver(ValidationSchema),\n defaultValues,\n });\n const values = methods.watch();\n const cartItemCount = getCartUniqueItemCount(values);\n const onInvalid = useScrollToFirstError(methods);\n\n const onSubmit = async (values: ITicketForm) => {\n if (cartItemCount <= 0) {\n showSnackbar(t('form.validation.count_tickets_or_products'), {\n variant: 'error',\n });\n return;\n }\n\n if (formStep === 1 && !isIframe) {\n setFormStep(2);\n } else {\n try {\n const data: ITicketBody = cloneObject(values);\n data.paymentMethodId = Number(values.paymentMethodId);\n data.promoCodeIds = values.promoCodes?.map((item) => item.id);\n const urlParams = new URLSearchParams(window.location.search);\n const iframeCallback = urlParams.get('callback');\n data.callback = isIframe && iframeCallback ? String(iframeCallback) : window.location.href;\n data.tickets = Object.entries(values.tickets).reduce(\n (acc, [eventId, items]) => {\n acc[Number(eventId)] = items\n .filter((item) => !!item.quantity && !!item.releaseId)\n .map((item) => ({\n releaseId: Number(item.releaseId),\n quantity: Number(item.quantity),\n price: Number(item.price),\n itemName: item.itemName,\n products: item.products,\n extraFields: item.extraFields,\n eventTimeslotId: item.eventTimeslotId,\n location: item.location,\n }));\n return acc;\n },\n {} as Record<number, ITicketFormTicket[]>\n );\n const { data: orderData } = await postOrder(data);\n localStorage.removeItem('cartToken');\n const items = [\n ...orderData.tickets.map((ticket) => ({\n item_id: ticket.number,\n item_name: `${orderData.orderEntity.event.name} - ${ticket.releaseCategoryName} - ${ticket.releaseName}`,\n price: ticket.price,\n quantity: 1,\n })),\n ];\n\n if (orderData.orderEntity.extraFee) {\n items.push({\n item_id: 'service_fee',\n item_name: `Service fee`,\n price: orderData.orderEntity.extraFee,\n quantity: 1,\n });\n }\n\n const item = {\n uuid: values.uuid,\n currency: orderData.orderEntity.currency,\n value: orderData.orderEntity.totalPrice,\n tax: 0,\n payment_type: orderData.orderEntity.paymentType,\n transaction_id: String(orderData.orderEntity.number),\n coupon: orderData?.orderEntity?.promoCodes?.map((p) => p.code) || [],\n items,\n };\n const userData = {\n fn: orderData.customer.firstName,\n ln: orderData.customer.lastName,\n em: orderData.customer.email,\n ph: orderData.customer.phone,\n };\n if (isIframe) {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPurchase(null),\n },\n '*'\n );\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPurchase(item, pixels, userData),\n },\n '*'\n );\n } else {\n gtmPurchase(null);\n gtmPurchase(item, pixels, userData);\n }\n setPaymentRedirect(orderData.gwUrl);\n methods.reset();\n } catch (err: any) {\n transformErrors(err.message);\n }\n }\n };\n\n const showShippingMethods = () => {\n const hasProducts = Object.values(values.products ?? {}).some((arr) => arr.length > 0);\n\n const ticketArrays = Object.values(values.tickets ?? {});\n const allTickets = ticketArrays.flat();\n\n const hasTicketProducts = allTickets.some((t) => (t.products?.length ?? 0) > 0);\n\n const showShippingMethods = hasProducts || hasTicketProducts;\n\n if (values.shipping.shippingMethodId !== null && !showShippingMethods) {\n methods.setValue('shipping', { shippingMethodId: null, branchId: null, price: 0 });\n }\n\n return showShippingMethods;\n };\n\n useEffect(() => {\n methods.reset(defaultValues);\n }, [user, defaultValues]);\n\n useEffect(() => {\n const searchParams = getSearchParamsInObject(window.location.search);\n const paymentId = searchParams.id;\n const iframeCampaignId = Number(searchParams.iframeCampaignId);\n setHasGopayId(!!paymentId);\n if (!isNaN(iframeCampaignId)) {\n methods.setValue('iframeCampaignId', iframeCampaignId);\n }\n }, [window.location.search]);\n\n useEffect(() => {\n const subscription = methods.watch((value) => {\n if (\n JSON.stringify(defaultValues) !== JSON.stringify(value) &&\n !hasFiredBeginCheckout.current\n ) {\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmBeginCheckout(item, pixels),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmBeginCheckout(item, pixels, user ? mapUserToUserData(user) : undefined);\n }\n hasFiredBeginCheckout.current = true;\n }\n });\n return () => subscription.unsubscribe();\n }, [methods.watch, defaultValues]);\n\n useEffect(() => {\n if (hasGopayId || isPaying || paymentRedirect) {\n if (options?.autoscrollAfterViewChange) {\n const orderForm = document.getElementById(EVENTLOOK_ORDER_FORM_CONTAINER_ID);\n if (orderForm) {\n orderForm.scrollIntoView({ behavior: 'smooth' });\n }\n }\n }\n }, [hasGopayId, isPaying, paymentRedirect]);\n\n if (isIframe && isNotReleased && showReleaseDate)\n return <ReleaseCountdown event={event} setShowReleaseDate={setShowReleaseDate} />;\n\n return (\n <Box id={EVENTLOOK_ORDER_FORM_CONTAINER_ID}>\n {hasGopayId ? (\n <PaymentSuccess setIsPaying={setIsPaying} isIframe={isIframe} pixels={pixels} />\n ) : isPaying ? (\n <PaymentPending />\n ) : paymentRedirect ? (\n <OrderSuccess\n gwUrl={paymentRedirect}\n isIframe={isIframe}\n setIsPaying={setIsPaying}\n isInline={isInline}\n />\n ) : (\n <FormProvider\n methods={methods}\n // @ts-ignore\n onSubmit={methods.handleSubmit(onSubmit, onInvalid)}\n formId={EVENTLOOK_ORDER_FORM_ID}\n >\n <Stack\n className=\"overview-card__event-info\"\n display={{ md: 'none' }}\n sx={{\n mb: 2,\n }}\n >\n <Typography variant=\"h3\" component=\"h1\">\n {event.name}\n </Typography>\n <Typography variant=\"h5\" component=\"h2\">\n {dayjs(event.startDate).format('DD.MM.YYYY HH:mm')}\n </Typography>\n <Typography variant=\"body2\" mt={1}>\n {getPlaceAsString(event.place)}\n </Typography>\n {headerSlot ? <>{headerSlot}</> : null}\n </Stack>\n <Grid\n container\n spacing={2}\n sx={{\n pb: {\n xs: isPaymentOverviewDrawerOpen ? cartItemCount * 4 + 18 : 0,\n md: 0,\n },\n }}\n >\n <Grid item xs={12} md={8}>\n <Stepper\n orientation=\"vertical\"\n sx={(theme) => ({\n [theme.breakpoints.down('sm')]: {\n '& .MuiStepContent-root': {\n borderLeftWidth: 0,\n paddingLeft: 0,\n marginLeft: 0,\n },\n '& .MuiStepConnector-line': { borderLeftWidth: 0 },\n },\n })}\n >\n {event.type === EventType.RECURRING && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.6.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <TimeslotSelection event={event} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.1.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n {event.mapId && seatingIframeUrl ? (\n <TicketSelectionMap event={event} />\n ) : event.hasMerchandise ? (\n <TicketWithMerchandiseSelection event={event} />\n ) : (\n <TicketSelection event={event} />\n )}\n </StepContent>\n </Step>\n {event.hasMerchandise && eventProducts.length && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.4.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <MerchandiseSelection\n eventProducts={eventProducts}\n eventId={event.id}\n isLoading={isLoading}\n />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.8.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Services event={event} />\n </StepContent>\n </Step>\n {event.children.length && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.7.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <ChildEventSection events={event.children} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.2.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <ContactPerson event={event} />\n </StepContent>\n </Step>\n {event.hasMerchandise && showShippingMethods() && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.5.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Shipping event={event} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>\n {t(\n `event.tickets.stepper.3.${values.isPaymentVerify ? 'title_verify' : 'title'}`\n )}\n </StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Payment event={event} />\n </StepContent>\n </Step>\n </Stepper>\n <Stack\n ref={termsAndConditionsRef}\n mt={2}\n ml={{ xs: 1, md: 4 }}\n sx={{ scrollMarginBottom: { xs: 220, md: 0 } }}\n >\n <RHFCheckbox\n name=\"termsAndConditions\"\n label={\n <Trans\n text=\"event.tickets.terms_and_conditions\"\n values={{\n termsAndConditionsCompanies: options?.termsAndConditionsCompanies\n ? options.termsAndConditionsCompanies.join(t('and'))\n : ['Eventlook', 'GoPay'].join(` ${t('and')} `),\n }}\n components={{\n 0: <CustomLink key={2} href={links.termsAndConditions} target=\"_blank\" />,\n 1: <CustomLink key={1} href={links.gdpr} target=\"_blank\" />,\n }}\n />\n }\n />\n </Stack>\n </Grid>\n <Grid item xs={12} md={4} sx={{ display: { xs: 'none', md: 'block' } }}>\n <PaymentOverviewBox event={event} />\n </Grid>\n </Grid>\n\n <PaymentOverviewDrawer\n event={event}\n totalPrice={values.total}\n onOpenChange={setIsPaymentOverviewDrawerOpen}\n />\n\n <EmailConfirmation\n open={formStep === 2 && !isIframe}\n onClose={() => setFormStep(1)}\n // @ts-ignore\n onConfirm={methods.handleSubmit(onSubmit, onInvalid)}\n />\n </FormProvider>\n )}\n </Box>\n );\n};\n\nconst CustomLink: React.FC<PropsWithChildren<LinkProps>> = ({ href = '', children, ...other }) => (\n <Link href={href} {...other} sx={{ color: 'inherit', textDecoration: 'underline' }}>\n {children}\n </Link>\n);\n\nexport default TicketForm;\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TicketForm.js","sources":["../../../src/form/TicketForm.tsx"],"sourcesContent":["import OrderSuccess from '@form/OrderSuccess';\nimport PaymentSuccess from '@form/PaymentSuccess';\nimport FormProvider, { RHFCheckbox } from '@components/hook-form';\nimport {\n Box,\n Divider,\n Grid,\n Link,\n LinkProps,\n Stack,\n Step,\n StepContent,\n StepLabel,\n Stepper,\n Typography,\n} from '@mui/material';\nimport dayjs from 'dayjs';\nimport TicketSelection from '@form/tickets/TicketSelection';\nimport ContactPerson from '@form/ContactPerson';\nimport Payment from '@form/Payment';\nimport EmailConfirmation from '@form/EmailConfirmation';\nimport React, { useEffect, useMemo, useRef, useState } from 'react';\nimport { PropsWithChildren } from '@utils/types/global.type';\nimport { getSearchParamsInObject } from '@utils/url';\nimport { ITicketBody, ITicketForm, ITicketFormTicket } from '@utils/types/ticket.type';\nimport * as Yup from 'yup';\nimport { useForm } from 'react-hook-form';\nimport { yupResolver } from '@hookform/resolvers/yup';\nimport { postOrder } from '@modules/order';\nimport { IEvent } from '@utils/types/event.type';\nimport PaymentOverviewBox from '@form/PaymentOverviewBox';\nimport { IEcommerce, IPixels } from '@utils/types/gtm.type';\nimport {\n getGtmAddPaymentInfo,\n getGtmBeginCheckout,\n getGtmPageView,\n getGtmPurchase,\n getGtmViewCart,\n gtmAddPaymentInfo,\n gtmBeginCheckout,\n gtmPurchase,\n gtmViewCart,\n mapUserToUserData,\n} from '@utils/gtm';\nimport ReleaseCountdown from '@form/ReleaseCountdown';\nimport { cloneObject } from '@utils/global';\nimport PaymentPending from '@form/PaymentPending';\nimport MerchandiseSelection from '@form/merchandise/MerchandiseSelection';\nimport TicketWithMerchandiseSelection from '@form/tickets/TicketWithMerchandiseSelection';\nimport useActiveEventProducts from '@hooks/data/useActiveEventProducts';\nimport Shipping from '@form/Shipping';\nimport useErrors from '@hooks/useErrors';\nimport { EventType } from '@utils/data/event';\nimport TimeslotSelection from '@form/TimeslotSelection';\nimport useGlobal from '@hooks/useGlobal';\nimport useScrollToFirstError from '@hooks/useScrollToFirstError';\nimport { Trans } from '@components/Trans';\nimport { EVENTLOOK_ORDER_FORM_ID, EVENTLOOK_ORDER_FORM_CONTAINER_ID } from '@utils/data/global.ts';\nimport ChildEventSection from './ChildEvents';\nimport TicketSelectionMap from '@form/tickets/TicketSelectionMap';\nimport PaymentOverviewDrawer from './PaymentOverviewDrawer';\nimport { getPlaceAsString } from '@utils/place';\nimport Services from '@form/services';\n\ninterface Props {\n event: IEvent;\n hasGopayIdSsr: boolean;\n selectedReleaseId?: number;\n isIframe?: boolean;\n isInline?: boolean;\n headerSlot?: React.ReactNode;\n}\n\nconst getCartUniqueItemCount = (formValues: ITicketForm) => {\n const flatTickets = Object.values(formValues.tickets ?? {}).flat();\n const ticketsCount = flatTickets.reduce(\n (sum, ticket) => sum + (Number(ticket.quantity) > 0 ? 1 : 0),\n 0\n );\n const ticketsWithProductsCount = flatTickets.reduce(\n (sum, ticket) => sum + ((ticket.products?.length ?? 0) > 0 ? 1 : 0),\n 0\n );\n const productsCount = Object.values(formValues.products ?? {})\n .flat()\n .reduce((sum, product) => sum + (Number(product.quantity) || 0), 0);\n\n return ticketsCount + ticketsWithProductsCount + productsCount;\n};\n\nconst TicketForm: React.FC<Props> = ({\n event,\n hasGopayIdSsr,\n selectedReleaseId,\n isIframe,\n isInline,\n headerSlot,\n}) => {\n const { t, setGlobal, callbacks, links, user, options, showSnackbar, content, seatingIframeUrl } =\n useGlobal();\n const { transformErrors } = useErrors(t('event.tickets.error.order'));\n const { data: eventProducts, isLoading } = useActiveEventProducts(event.id);\n const [paymentRedirect, setPaymentRedirect] = useState<string | null>(null);\n const [hasGopayId, setHasGopayId] = useState<boolean>(hasGopayIdSsr);\n const [isPaying, setIsPaying] = useState<boolean>(false);\n const [formStep, setFormStep] = useState<number>(1);\n const [isPaymentOverviewDrawerOpen, setIsPaymentOverviewDrawerOpen] = useState<boolean>(false);\n const [showReleaseDate, setShowReleaseDate] = useState(\n dayjs(event.releaseDate).diff(dayjs()) > 0\n );\n const [matchIsValidTel, setMatchIsValidTel] = useState<(text: string) => boolean>(() => false);\n const isNotReleased = dayjs(event.releaseDate).diff(dayjs()) > 0;\n const hasFiredViewCart = useRef(false);\n const hasFiredBeginCheckout = useRef(false);\n const hasFiredPaymentMethod = useRef(false);\n const termsAndConditionsRef = useRef<HTMLDivElement | null>(null);\n\n const item: IEcommerce = {\n currency: event.currency,\n items: [\n {\n item_id: `event_${event.id}`,\n item_name: event.name,\n quantity: 1,\n },\n ],\n };\n const pixels: IPixels = {\n fb_pixel_id: event.facebookPixel?.facebookId,\n tiktok_pixel_id: event.tiktokPixel?.tiktokId,\n };\n\n useEffect(() => {\n import('mui-tel-input').then((mod) => {\n setMatchIsValidTel(() => mod.matchIsValidTel);\n });\n }, []);\n\n useEffect(() => {\n setGlobal({\n options: {\n isIframe: isIframe === undefined ? false : isIframe,\n },\n });\n if (\n !isIframe &&\n event &&\n (isNotReleased ||\n (!!event.releaseEndDate && dayjs(event.releaseEndDate).isBefore(dayjs())) ||\n dayjs(event.endDate).isBefore(dayjs()) ||\n event.isSoldout ||\n event.dateUnknown ||\n event.isCanceled)\n ) {\n callbacks.detail();\n }\n\n if (event && !hasGopayId && !hasFiredViewCart.current) {\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPageView(location.href),\n },\n '*'\n );\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmViewCart(item, pixels),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmViewCart(item, pixels);\n }\n hasFiredViewCart.current = true;\n }\n if (!hasFiredPaymentMethod.current) {\n const item = {\n currency: event.currency,\n value: 0,\n payment_type: 'PAYMENT_CARD',\n items: [],\n };\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmAddPaymentInfo(item, pixels, user ? mapUserToUserData(user) : undefined),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmAddPaymentInfo(item, pixels);\n }\n hasFiredPaymentMethod.current = true;\n }\n }, [event]);\n\n const defaultValues: ITicketForm = useMemo(() => {\n const makeTicket = (overrides: Partial<ITicketFormTicket> = {}): ITicketFormTicket => ({\n releaseId: '',\n quantity: '',\n itemName: '',\n price: 0,\n products: [],\n extraFields: [],\n ...overrides,\n });\n\n const tickets: Record<string, ITicketFormTicket[]> = {\n [String(event.id)]: [\n makeTicket({\n releaseId: (selectedReleaseId as number) ?? '',\n }),\n ],\n };\n\n event.children?.forEach((child) => {\n tickets[String(child.id)] = [makeTicket()];\n });\n\n return {\n uuid: null,\n eventId: event.id,\n tickets,\n total: 0,\n originalPrice: 0,\n firstName: user?.firstName || '',\n lastName: user?.lastName || '',\n email: user?.email || '',\n phone: user?.phone || '',\n birthdate: user?.birthdate ? dayjs(user.birthdate) : null,\n gender: user?.gender || '',\n callback: '',\n paymentMethodId: null,\n paymentMethodOptionId: null,\n termsAndConditions: false,\n ticketInsurance: false,\n ticketInsurancePrice: 0,\n ticketInsurancePricePerUnit: 0,\n smsNotification: false,\n smsNotificationPrice: 0,\n iframeCampaignId: undefined,\n promoCodes: [],\n products: {},\n shipping: {\n shippingMethodId: null,\n branchId: null,\n price: 0,\n },\n extraFields:\n event?.extraFields.map((field) => ({\n eventExtraFieldId: field.id,\n value: '',\n })) || [],\n selectedDate: null,\n eventTimeslotId: null,\n isPaymentVerify: false,\n };\n }, [user]);\n\n const ValidationSchema = Yup.object().shape({\n firstName: Yup.string().required(t('form.validation.required')),\n lastName: Yup.string().required(t('form.validation.required')),\n email: Yup.string().email(t('form.validation.email')).required(t('form.validation.required')),\n phone: Yup.string()\n .required(t('form.validation.required'))\n .test('phone-checker', t('form.validation.phone'), (value) =>\n value ? matchIsValidTel(value) : false\n ),\n birthdate: Yup.object()\n .nullable()\n .default(null)\n .when([], {\n is: () => !content?.form?.disableBirthDate,\n then: (s) => s.required(t('form.validation.required')),\n otherwise: (s) => s.notRequired(),\n }),\n gender: Yup.string().when([], {\n is: () => !content?.form?.disableGender,\n then: (schema) => schema.required(t('form.validation.required')),\n otherwise: (schema) => schema.notRequired(),\n }),\n // tickets: Yup.object().test('tickets-validation', function (tickets) {\n // if (!tickets || typeof tickets !== 'object') return false;\n\n // for (const key of Object.keys(tickets)) {\n // const arr = tickets[key];\n // if (!Array.isArray(arr)) return false;\n // for (const t of arr) {\n // if (!t.releaseId || !t.quantity) {\n // return this.createError({ message: 'Invalid ticket selection' });\n // }\n // }\n // }\n // return true;\n // }),\n shipping: Yup.object()\n .shape({\n shippingMethodId: Yup.number().nullable(),\n branchId: Yup.string().nullable(),\n price: Yup.number(),\n })\n .test('shipping-method-required', t('form.validation.required'), function (value) {\n if (!event.hasMerchandise) {\n return true;\n }\n\n const formValues = this.parent as ITicketForm;\n const hasProducts = Object.values(formValues.products ?? {}).some((arr) => arr.length > 0);\n const allTickets = Object.values(formValues.tickets ?? {}).flat();\n const hasTicketProducts = allTickets.some((ticket) => (ticket.products?.length ?? 0) > 0);\n const requiresShipping = hasProducts || hasTicketProducts;\n\n if (!requiresShipping) {\n return true;\n }\n\n if (value?.shippingMethodId !== null && value?.shippingMethodId !== undefined) {\n return true;\n }\n\n return this.createError({\n path: 'shipping.shippingMethodId',\n message: t('form.validation.required'),\n });\n }),\n paymentMethodId: Yup.number().nullable().required(t('form.validation.required')),\n paymentMethodOptionId: Yup.number().nullable(),\n termsAndConditions: Yup.boolean().isTrue(t('form.validation.terms_and_conditions')),\n ticketInsurance: Yup.boolean(),\n smsNotification: Yup.boolean(),\n extraFields: Yup.array().of(\n Yup.object().shape({\n value: Yup.string().test('is-required', function (value) {\n const options = this.options as { index: number };\n\n if (event.extraFields[options.index].required && !value) {\n return this.createError({\n message: t('form.validation.required'),\n });\n }\n return true;\n }),\n })\n ),\n });\n\n const methods = useForm<ITicketForm>({\n // @ts-ignore\n resolver: yupResolver(ValidationSchema),\n defaultValues,\n });\n const values = methods.watch();\n const cartItemCount = getCartUniqueItemCount(values);\n const onInvalid = useScrollToFirstError(methods);\n\n const onSubmit = async (values: ITicketForm) => {\n if (cartItemCount <= 0) {\n showSnackbar(t('form.validation.count_tickets_or_products'), {\n variant: 'error',\n });\n return;\n }\n\n if (formStep === 1 && !isIframe) {\n setFormStep(2);\n } else {\n try {\n const data: ITicketBody = cloneObject(values);\n data.paymentMethodId = Number(values.paymentMethodId);\n data.promoCodeIds = values.promoCodes?.map((item) => item.id);\n const urlParams = new URLSearchParams(window.location.search);\n const iframeCallback = urlParams.get('callback');\n data.callback = isIframe && iframeCallback ? String(iframeCallback) : window.location.href;\n data.tickets = Object.entries(values.tickets).reduce(\n (acc, [eventId, items]) => {\n acc[Number(eventId)] = items\n .filter((item) => !!item.quantity && !!item.releaseId)\n .map((item) => ({\n releaseId: Number(item.releaseId),\n quantity: Number(item.quantity),\n price: Number(item.price),\n itemName: item.itemName,\n products: item.products,\n extraFields: item.extraFields,\n eventTimeslotId: item.eventTimeslotId,\n location: item.location,\n }));\n return acc;\n },\n {} as Record<number, ITicketFormTicket[]>\n );\n const { data: orderData } = await postOrder(data);\n localStorage.removeItem('cartToken');\n const items = [\n ...orderData.tickets.map((ticket) => ({\n item_id: ticket.number,\n item_name: `${orderData.orderEntity.event.name} - ${ticket.releaseCategoryName} - ${ticket.releaseName}`,\n price: ticket.price,\n quantity: 1,\n })),\n ];\n\n if (orderData.orderEntity.extraFee) {\n items.push({\n item_id: 'service_fee',\n item_name: `Service fee`,\n price: orderData.orderEntity.extraFee,\n quantity: 1,\n });\n }\n\n const item = {\n uuid: values.uuid,\n currency: orderData.orderEntity.currency,\n value: orderData.orderEntity.totalPrice,\n tax: 0,\n payment_type: orderData.orderEntity.paymentType,\n transaction_id: String(orderData.orderEntity.number),\n coupon: orderData?.orderEntity?.promoCodes?.map((p) => p.code) || [],\n items,\n };\n const userData = {\n fn: orderData.customer.firstName,\n ln: orderData.customer.lastName,\n em: orderData.customer.email,\n ph: orderData.customer.phone,\n };\n if (isIframe) {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPurchase(null),\n },\n '*'\n );\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmPurchase(item, pixels, userData),\n },\n '*'\n );\n } else {\n gtmPurchase(null);\n gtmPurchase(item, pixels, userData);\n }\n setPaymentRedirect(orderData.gwUrl);\n methods.reset();\n } catch (err: any) {\n transformErrors(err.message);\n }\n }\n };\n\n const showShippingMethods = () => {\n const hasProducts = Object.values(values.products ?? {}).some((arr) => arr.length > 0);\n\n const ticketArrays = Object.values(values.tickets ?? {});\n const allTickets = ticketArrays.flat();\n\n const hasTicketProducts = allTickets.some((t) => (t.products?.length ?? 0) > 0);\n\n const showShippingMethods = hasProducts || hasTicketProducts;\n\n if (values.shipping.shippingMethodId !== null && !showShippingMethods) {\n methods.setValue('shipping', { shippingMethodId: null, branchId: null, price: 0 });\n }\n\n return showShippingMethods;\n };\n\n useEffect(() => {\n methods.reset(defaultValues);\n }, [user, defaultValues]);\n\n useEffect(() => {\n const searchParams = getSearchParamsInObject(window.location.search);\n const paymentId = searchParams.id;\n const iframeCampaignId = Number(searchParams.iframeCampaignId);\n setHasGopayId(!!paymentId);\n if (!isNaN(iframeCampaignId)) {\n methods.setValue('iframeCampaignId', iframeCampaignId);\n }\n }, [window.location.search]);\n\n useEffect(() => {\n const subscription = methods.watch((value) => {\n if (\n JSON.stringify(defaultValues) !== JSON.stringify(value) &&\n !hasFiredBeginCheckout.current\n ) {\n if (isIframe) {\n setTimeout(() => {\n parent.postMessage(\n {\n type: 'eventlookFrameGtm',\n item: getGtmBeginCheckout(item, pixels),\n },\n '*'\n );\n }, 1000);\n } else {\n gtmBeginCheckout(item, pixels, user ? mapUserToUserData(user) : undefined);\n }\n hasFiredBeginCheckout.current = true;\n }\n });\n return () => subscription.unsubscribe();\n }, [methods.watch, defaultValues]);\n\n useEffect(() => {\n if (hasGopayId || isPaying || paymentRedirect) {\n if (options?.autoscrollAfterViewChange) {\n const orderForm = document.getElementById(EVENTLOOK_ORDER_FORM_CONTAINER_ID);\n if (orderForm) {\n orderForm.scrollIntoView({ behavior: 'smooth' });\n }\n }\n }\n }, [hasGopayId, isPaying, paymentRedirect]);\n\n if (isIframe && isNotReleased && showReleaseDate)\n return <ReleaseCountdown event={event} setShowReleaseDate={setShowReleaseDate} />;\n\n return (\n <Box id={EVENTLOOK_ORDER_FORM_CONTAINER_ID}>\n {hasGopayId ? (\n <PaymentSuccess setIsPaying={setIsPaying} isIframe={isIframe} pixels={pixels} />\n ) : isPaying ? (\n <PaymentPending />\n ) : paymentRedirect ? (\n <OrderSuccess\n gwUrl={paymentRedirect}\n isIframe={isIframe}\n setIsPaying={setIsPaying}\n isInline={isInline}\n />\n ) : (\n <FormProvider\n methods={methods}\n // @ts-ignore\n onSubmit={methods.handleSubmit(onSubmit, onInvalid)}\n formId={EVENTLOOK_ORDER_FORM_ID}\n >\n <Stack\n className=\"overview-card__event-info\"\n display={{ md: 'none' }}\n sx={{\n mb: 2,\n }}\n >\n <Typography variant=\"h3\" component=\"h1\">\n {event.name}\n </Typography>\n <Typography variant=\"h5\" component=\"h2\">\n {dayjs(event.startDate).format('DD.MM.YYYY HH:mm')}\n </Typography>\n <Typography variant=\"body2\" mt={1}>\n {getPlaceAsString(event.place)}\n </Typography>\n {headerSlot ? <>{headerSlot}</> : null}\n </Stack>\n <Grid\n container\n spacing={2}\n sx={{\n pb: {\n xs: isPaymentOverviewDrawerOpen ? cartItemCount * 4 + 18 : 0,\n md: 0,\n },\n }}\n >\n <Grid item xs={12} md={8}>\n <Stepper\n orientation=\"vertical\"\n sx={(theme) => ({\n [theme.breakpoints.down('sm')]: {\n '& .MuiStepContent-root': {\n borderLeftWidth: 0,\n paddingLeft: 0,\n marginLeft: 0,\n },\n '& .MuiStepConnector-line': { borderLeftWidth: 0 },\n },\n })}\n >\n {event.type === EventType.RECURRING && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.6.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <TimeslotSelection event={event} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.1.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n {event.mapId && seatingIframeUrl ? (\n <TicketSelectionMap event={event} />\n ) : event.hasMerchandise ? (\n <TicketWithMerchandiseSelection event={event} />\n ) : (\n <TicketSelection event={event} />\n )}\n </StepContent>\n </Step>\n {event.hasMerchandise && eventProducts.length && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.4.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <MerchandiseSelection\n eventProducts={eventProducts}\n eventId={event.id}\n isLoading={isLoading}\n />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.8.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Services event={event} />\n </StepContent>\n </Step>\n {event.children.length && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.7.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <ChildEventSection events={event.children} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>{t('event.tickets.stepper.2.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <ContactPerson event={event} />\n </StepContent>\n </Step>\n {event.hasMerchandise && showShippingMethods() && (\n <Step active>\n <StepLabel>{t('event.tickets.stepper.5.title')}</StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Shipping event={event} />\n </StepContent>\n </Step>\n )}\n <Step active>\n <StepLabel>\n {t(\n `event.tickets.stepper.3.${values.isPaymentVerify ? 'title_verify' : 'title'}`\n )}\n </StepLabel>\n <StepContent sx={{ pr: { xs: 0 } }}>\n <Payment event={event} />\n </StepContent>\n </Step>\n </Stepper>\n <Stack\n ref={termsAndConditionsRef}\n mt={2}\n ml={{ xs: 1, md: 4 }}\n sx={{ scrollMarginBottom: { xs: 220, md: 0 } }}\n >\n <RHFCheckbox\n name=\"termsAndConditions\"\n label={\n <Trans\n text=\"event.tickets.terms_and_conditions\"\n values={{\n termsAndConditionsCompanies: options?.termsAndConditionsCompanies\n ? options.termsAndConditionsCompanies.join(t('and'))\n : ['Eventlook', 'GoPay'].join(` ${t('and')} `),\n }}\n components={{\n 0: <CustomLink key={2} href={links.termsAndConditions} target=\"_blank\" />,\n 1: <CustomLink key={1} href={links.gdpr} target=\"_blank\" />,\n }}\n />\n }\n />\n </Stack>\n </Grid>\n <Grid item xs={12} sx={{ display: { xs: 'block', md: 'none' } }}>\n <Divider sx={{ borderStyle: 'dashed' }} />\n </Grid>\n <Grid item xs={12} md={4} mt={{ xs: 0, md: 0 }}>\n <PaymentOverviewBox event={event} withoutPadding />\n </Grid>\n </Grid>\n\n <PaymentOverviewDrawer\n event={event}\n totalPrice={values.total}\n termsAndConditionsRef={termsAndConditionsRef}\n onOpenChange={setIsPaymentOverviewDrawerOpen}\n />\n\n <EmailConfirmation\n open={formStep === 2 && !isIframe}\n onClose={() => setFormStep(1)}\n // @ts-ignore\n onConfirm={methods.handleSubmit(onSubmit, onInvalid)}\n />\n </FormProvider>\n )}\n </Box>\n );\n};\n\nconst CustomLink: React.FC<PropsWithChildren<LinkProps>> = ({ href = '', children, ...other }) => (\n <Link href={href} {...other} sx={{ color: 'inherit', textDecoration: 'underline' }}>\n {children}\n </Link>\n);\n\nexport default TicketForm;\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Stack, IconButton, Box, Button, Card, Typography, Link, Dialog, DialogTitle, DialogContent, DialogActions } from '@mui/material';
|
|
2
2
|
import Image from '../../components/Image.js';
|
|
3
|
+
import Iconify from '../../components/iconify/Iconify.js';
|
|
3
4
|
import React, { useState, useMemo } from 'react';
|
|
4
5
|
import ProductVariantsDialog from './ProductVariantsDialog.js';
|
|
5
6
|
import { useFormContext, useWatch } from 'react-hook-form';
|
|
@@ -80,6 +81,44 @@ const ProductCard = ({ eventProduct, eventId, isOnlyMerchandise }) => {
|
|
|
80
81
|
excludedShippingMethodIds: eventProduct.excludedShippingMethods.map((method) => method.id),
|
|
81
82
|
});
|
|
82
83
|
};
|
|
84
|
+
const simpleProductQuantityControl = simpleProductQuantity > 0 ? (React.createElement(Stack, { direction: "row", spacing: 1, alignItems: "center", width: "100%" },
|
|
85
|
+
React.createElement(IconButton, { onClick: () => onChangeSimpleProductQuantity(simpleProductQuantity - 1), disabled: simpleProductQuantity <= 0, sx: {
|
|
86
|
+
flex: '1 1 0',
|
|
87
|
+
height: 36,
|
|
88
|
+
p: 0,
|
|
89
|
+
borderRadius: 1,
|
|
90
|
+
border: '1px solid',
|
|
91
|
+
borderColor: 'grey.300',
|
|
92
|
+
display: 'flex',
|
|
93
|
+
alignItems: 'center',
|
|
94
|
+
justifyContent: 'center',
|
|
95
|
+
} },
|
|
96
|
+
React.createElement(Iconify, { icon: "eva:minus-fill", width: 18, height: 18 })),
|
|
97
|
+
React.createElement(Box, { sx: {
|
|
98
|
+
flex: '1 1 0',
|
|
99
|
+
height: 36,
|
|
100
|
+
borderRadius: 1,
|
|
101
|
+
border: '1px solid',
|
|
102
|
+
borderColor: 'grey.300',
|
|
103
|
+
display: 'flex',
|
|
104
|
+
alignItems: 'center',
|
|
105
|
+
justifyContent: 'center',
|
|
106
|
+
fontWeight: 700,
|
|
107
|
+
} }, simpleProductQuantity),
|
|
108
|
+
React.createElement(IconButton, { onClick: () => onChangeSimpleProductQuantity(simpleProductQuantity + 1), disabled: simpleProductQuantity >= 10 || simpleProductMaxAvailable <= 0, sx: {
|
|
109
|
+
flex: '1 1 0',
|
|
110
|
+
height: 36,
|
|
111
|
+
p: 0,
|
|
112
|
+
borderRadius: 1,
|
|
113
|
+
bgcolor: 'primary.main',
|
|
114
|
+
color: 'primary.contrastText',
|
|
115
|
+
'&:hover': { bgcolor: 'primary.dark' },
|
|
116
|
+
'&.Mui-disabled': {
|
|
117
|
+
bgcolor: 'action.disabledBackground',
|
|
118
|
+
color: 'action.disabled',
|
|
119
|
+
},
|
|
120
|
+
} },
|
|
121
|
+
React.createElement(Iconify, { icon: "eva:plus-fill", width: 18, height: 18 })))) : (React.createElement(Button, { variant: "contained", onClick: () => onChangeSimpleProductQuantity(1), disabled: simpleProductMaxAvailable <= 0, fullWidth: true }, t('add')));
|
|
83
122
|
return (React.createElement(React.Fragment, null,
|
|
84
123
|
React.createElement(Card, { sx: {
|
|
85
124
|
p: 0,
|
|
@@ -95,39 +134,7 @@ const ProductCard = ({ eventProduct, eventId, isOnlyMerchandise }) => {
|
|
|
95
134
|
? fCurrency(eventProduct.product.priceWithVat, lang, eventProduct.product.currency)
|
|
96
135
|
: t('free')),
|
|
97
136
|
isSimpleProduct && (React.createElement(Link, { onClick: () => setOpenSimpleProductDialog(true), color: "inherit", underline: "always", fontSize: 12 }, t('more_info')))),
|
|
98
|
-
isSimpleProduct ? (
|
|
99
|
-
React.createElement(IconButton, { onClick: () => onChangeSimpleProductQuantity(simpleProductQuantity - 1), disabled: simpleProductQuantity <= 0, sx: {
|
|
100
|
-
flex: '1 1 0',
|
|
101
|
-
height: 36,
|
|
102
|
-
p: 0,
|
|
103
|
-
borderRadius: 1,
|
|
104
|
-
border: '1px solid',
|
|
105
|
-
borderColor: 'grey.300',
|
|
106
|
-
} }, "-"),
|
|
107
|
-
React.createElement(Box, { sx: {
|
|
108
|
-
flex: '1 1 0',
|
|
109
|
-
height: 36,
|
|
110
|
-
borderRadius: 1,
|
|
111
|
-
border: '1px solid',
|
|
112
|
-
borderColor: 'grey.300',
|
|
113
|
-
display: 'flex',
|
|
114
|
-
alignItems: 'center',
|
|
115
|
-
justifyContent: 'center',
|
|
116
|
-
fontWeight: 700,
|
|
117
|
-
} }, simpleProductQuantity),
|
|
118
|
-
React.createElement(IconButton, { onClick: () => onChangeSimpleProductQuantity(simpleProductQuantity + 1), disabled: simpleProductQuantity >= 10 || simpleProductMaxAvailable <= 0, sx: {
|
|
119
|
-
flex: '1 1 0',
|
|
120
|
-
height: 36,
|
|
121
|
-
p: 0,
|
|
122
|
-
borderRadius: 1,
|
|
123
|
-
bgcolor: 'primary.main',
|
|
124
|
-
color: 'primary.contrastText',
|
|
125
|
-
'&:hover': { bgcolor: 'primary.dark' },
|
|
126
|
-
'&.Mui-disabled': {
|
|
127
|
-
bgcolor: 'action.disabledBackground',
|
|
128
|
-
color: 'action.disabled',
|
|
129
|
-
},
|
|
130
|
-
} }, "+"))) : (React.createElement(Button, { variant: "contained", onClick: () => onChangeSimpleProductQuantity(1), disabled: simpleProductMaxAvailable <= 0, fullWidth: true }, t('add')))) : (React.createElement(Button, { variant: eventNotEmpty ? 'contained' : 'outlined', onClick: () => setOpenVariantDialog(true), fullWidth: true, sx: {
|
|
137
|
+
isSimpleProduct ? (simpleProductQuantityControl) : (React.createElement(Button, { variant: eventNotEmpty ? 'contained' : 'outlined', onClick: () => setOpenVariantDialog(true), fullWidth: true, sx: {
|
|
131
138
|
color: eventNotEmpty ? (theme) => theme.palette.common.white : 'inherit',
|
|
132
139
|
borderColor: (theme) => theme.palette.grey[300],
|
|
133
140
|
} }, eventNotEmpty
|
|
@@ -149,11 +156,11 @@ const ProductCard = ({ eventProduct, eventId, isOnlyMerchandise }) => {
|
|
|
149
156
|
: t('free')))),
|
|
150
157
|
React.createElement(DialogActions, { sx: { px: 3, pb: 3 } },
|
|
151
158
|
React.createElement(Stack, { spacing: 1, width: "100%" },
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
159
|
+
simpleProductQuantityControl,
|
|
160
|
+
React.createElement(Button, { variant: "outlined", onClick: () => setOpenSimpleProductDialog(false), fullWidth: true, sx: {
|
|
161
|
+
color: 'inherit',
|
|
162
|
+
borderColor: (theme) => theme.palette.grey[300],
|
|
163
|
+
} }, t('close')))))));
|
|
157
164
|
};
|
|
158
165
|
|
|
159
166
|
export { ProductCard as default };
|