{"version":3,"file":"static/js/57258.b5a1b15b.chunk.js","mappings":"4MAaO,MAAMA,EAAeC,IAMa,IANZ,MAC3BC,EAAK,QACLC,EAAO,SACPC,EAAQ,UACRC,EAAS,SACTC,GACmBL,EACnB,OACEM,EAAAA,EAAAA,MAAA,OAAKC,UAAU,oBAAmBC,SAAA,EAChCF,EAAAA,EAAAA,MAAA,OAAKC,UAAU,mCAAkCC,SAAA,EAC/CC,EAAAA,EAAAA,KAACC,EAAAA,EAAU,CACTC,IAAKT,EACLU,KAAMT,EACNU,MAAOT,EACPU,KAAMC,EAAAA,GAAUC,IAChBT,UAAU,6BAEZE,EAAAA,EAAAA,KAAA,QAAMF,UAAU,2BAA0BC,SAAEP,QAG9CQ,EAAAA,EAAAA,KAACC,EAAAA,EAAU,CACTC,IAAI,UACJC,KAAK,QACLC,MAAM,UACNC,KAAMC,EAAAA,GAAUE,IAChBV,UAAU,oBACVW,QAASb,MAEP,E,qECgCH,MAAMc,EAAQnB,IA6BO,IA7BN,MACpBC,EAAK,MACLmB,EAAK,SACLZ,EAAQ,OACRa,EAAM,MACNC,EAAQ,OAAM,SACdC,EAAWC,EAAAA,GAAWC,SAAQ,QAC9BC,EAAO,eACPC,EAAc,UACdC,EAAS,MACTC,EAAK,UACLC,EAAS,QACTC,EAAO,qBACPC,GAAuB,EAAK,WAC5BC,EAAU,eACVC,GAAiB,EAAI,QACrBC,GAAU,EAAI,aACdC,EAAY,eACZC,EAAc,cACdC,EAAa,aACbC,EAAY,wBACZC,EAAuB,UACvBC,EAAS,SACTC,EAAQ,OACRC,EAAM,UACNC,EAAS,aACTC,EAAY,eACZC,KACGC,GACG/C,EACN,MAAMgD,GAAWC,EAAAA,EAAAA,MACXC,GAAeC,EAAAA,EAAAA,IAAYC,EAAAA,IAC3BC,GAAOF,EAAAA,EAAAA,IAAYG,EAAAA,IACnBC,GAAUC,EAAAA,EAAAA,SAAOC,EAAAA,EAAAA,OACjB,SAAEC,IAAaC,EAAAA,EAAAA,KAEfC,GAAwBC,EAAAA,EAAAA,UAAQ,MAEhCH,GACFR,EAAapC,KAAO,GACnBuC,IAAQS,EAAAA,EAAAA,MACT9B,GAED,CAAC0B,EAAUR,EAAapC,KAAMuC,EAAMrB,KAEvC+B,EAAAA,EAAAA,GAAsBhC,EAAS6B,EAAuBzB,GAEtD,MAAM6B,EAAqBC,IACzB,GAAIf,EAAapC,KAAM,CACrB,MAAMoD,EAAmB,IAAIC,IAAIjB,GACjCgB,EAAiBD,GAAYV,EAAQa,SACrCpB,GAASqB,EAAAA,EAAAA,IAAgBH,GAC3B,GAaF,OAVAI,EAAAA,EAAAA,YAAU,KACR,GAAIvC,EAGF,OAFAiC,EAAkB,OAEX,KACLA,EAAkB,SAAS,CAE/B,GACC,CAACjC,KAGFzB,EAAAA,EAAAA,MAACiE,EAAAA,EAAW,IACNxB,EACJd,WAAYA,IAAc,EAC1BK,cAAeA,GAAiB,GAChCjB,OAAQA,GAAU,EAClBwB,aAAcA,EACdtB,SAAUA,GAAY,GACtBW,eAAgBA,IAAkB,EAClCK,aAAcA,GAAgB,GAC9BZ,eAAgBa,EAChBC,UAAWA,EACXC,SAAUA,EACVL,eAAgBD,EAAe,EAAIC,GAAkC,EACrEM,OAAQA,EACRC,UAAWA,EACXhB,UACEA,GAAa,CACXF,QAAS,GAAGU,EAAe,EAAW,OAAPV,QAAO,IAAPA,EAAAA,EAAW8C,EAAAA,EAAaC,cACvDC,UAAWpD,GAGfO,MACEA,GAAS,CACPgB,aAAc,OACdnB,QAAS,GAAiB,OAAdC,QAAc,IAAdA,EAAAA,EAAkB6C,EAAAA,EAAaG,eAG/C7C,UACEA,IACErB,EAAAA,EAAAA,KAACC,EAAAA,EAAU,CACTC,IAAI,UACJC,KAAK,YACLC,MAAM,UACNC,KAAMC,EAAAA,GAAUC,IAChBT,UAAU,sBAIhBwB,QAASA,EACTe,eAAgBA,EAAetC,SAAA,CAE9B4B,IACC3B,EAAAA,EAAAA,KAACV,EAAY,CACXI,SAAUiC,EAAajC,SACvBC,UAAWgC,EAAahC,UACxBF,QAASkC,EAAalC,QACtBD,MAAOmC,EAAanC,MACpBI,SAAUA,KACJ+B,EAAawC,SACfxC,EAAawC,SACf,IAILxD,IACCX,EAAAA,EAAAA,KAAA,OAAKF,UAAU,oBAAmBC,UAChCC,EAAAA,EAAAA,KAACC,EAAAA,EAAU,CACTC,IAAKS,EAAMT,IACXC,KAAMQ,EAAMR,KACZC,MAAOO,EAAMP,MACbC,KAAMM,EAAMN,KAAOM,EAAMN,KAAOC,EAAAA,GAAU8D,IAC1CC,MAAO1D,EAAM0D,MACbvE,UAAU,oBAIbN,IAASQ,EAAAA,EAAAA,KAAA,OAAKF,UAAU,cAAaC,SAAEP,KAC1CQ,EAAAA,EAAAA,KAAA,OAAKF,UAAU,cAAaC,SAAEA,MAClB,EAILuE,EAAeC,IASP,IATQ,UAC3BC,EAAY,MAAK,SACjBzE,EAAQ,UACRD,KACG2E,GAKJF,EACC,OACEvE,EAAAA,EAAAA,KAAA,OACEF,UAAW,iBAAiBA,IAC5BsB,MAAO,CAAEsD,cAAeF,MACpBC,EAAK1E,SAERA,GACG,C","sources":["components/Modal/CustomHeader/index.tsx","components/Modal/index.tsx"],"sourcesContent":["import { ReactElement } from 'react';\nimport { EIconSize } from 'utils/constants/app/ui';\nimport { GlobalIcon } from 'components/GlobalIcon';\nimport './index.less';\n\ntype TCustomHeaderProps = {\n title: string;\n iconLib: string;\n iconName: string;\n iconTheme: string;\n onCancel?: () => void;\n};\n\nexport const CustomHeader = ({\n title,\n iconLib,\n iconName,\n iconTheme,\n onCancel\n}: TCustomHeaderProps): ReactElement => {\n return (\n
\n
\n \n {title}\n
\n\n \n
\n );\n};\n","import React, {\n CSSProperties,\n ReactElement,\n useEffect,\n useMemo,\n useRef\n} from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { ModalFuncProps } from 'antd';\nimport { v4 as uuidv4 } from 'uuid';\nimport { EIconSize, ModalPadding, ModalWidth } from 'utils/constants/app/ui';\nimport { isMobile } from 'utils/is-mobile';\nimport { CustomHeader } from './CustomHeader';\nimport { GlobalIcon } from 'components/GlobalIcon';\nimport { CustomModal } from 'newcomponents/UI/CustomModal';\nimport { usePopupScrollDisable } from 'hooks/usePopupScrollDisable';\nimport { useSearchParams } from 'hooks/useSearchParams';\nimport { setOpenedModals } from 'store/actions/app-data';\nimport { getOpenedModals } from 'store/selectors/app-data';\nimport { getBetslipOpen } from 'store/selectors/betslip';\nimport './index.less';\n\ntype Props = ModalFuncProps & {\n title?: string | React.ReactNode | null;\n visible: boolean;\n closable?: boolean;\n onCancel?: (arg0: React.UIEvent) => void;\n image?:\n | {\n lib: string;\n name: string;\n theme: string;\n size?: number;\n color?: string;\n }\n | false;\n children: React.ReactNode;\n closeIcon?: React.ReactNode;\n maxWidth?: number | string;\n align?: 'left' | 'center' | 'right';\n maskClosable?: boolean;\n padding?: number;\n wrapperPadding?: number;\n width?: number | string;\n centered?: boolean;\n bodyStyle?: Record;\n style?: Record;\n maskStyle?: Record;\n zIndex?: number;\n contentPadding?: number | string;\n className?: string;\n renderInBody?: boolean;\n preventScrollDisable?: boolean;\n hideBorder?: boolean;\n destroyOnClose?: boolean;\n getContainer?: string | false;\n wrapperContainerPadding?: string;\n placement?: 'top' | 'bottom' | 'left' | 'right';\n fullPage?: boolean;\n borderRadius?: string;\n footer?: ReactElement | null;\n closeIconStyle?: CSSProperties;\n fixBody?: boolean;\n renderCloseIconInMask?: boolean;\n customHeader?: {\n title: string;\n iconLib: string;\n iconName: string;\n iconTheme: string;\n onClose: () => void;\n };\n};\n\nexport const Modal = ({\n title,\n image,\n children,\n zIndex,\n align = 'left',\n maxWidth = ModalWidth.MAX_1272,\n padding,\n wrapperPadding,\n bodyStyle,\n style,\n closeIcon,\n visible,\n preventScrollDisable = false,\n hideBorder,\n destroyOnClose = true,\n fixBody = true,\n customHeader,\n contentPadding,\n wrapClassName,\n getContainer,\n wrapperContainerPadding,\n placement,\n fullPage,\n footer,\n maskStyle,\n borderRadius,\n closeIconStyle,\n ...rest\n}: Props): ReactElement => {\n const dispatch = useDispatch();\n const openedModals = useSelector(getOpenedModals);\n const open = useSelector(getBetslipOpen);\n const modalId = useRef(uuidv4());\n const { accounts } = useSearchParams();\n\n const _preventScrollDisable = useMemo(() => {\n return (\n !!accounts ||\n openedModals.size > 0 ||\n (open && isMobile()) ||\n preventScrollDisable\n );\n }, [accounts, openedModals.size, open, preventScrollDisable]);\n\n usePopupScrollDisable(visible, _preventScrollDisable, fixBody);\n\n const updateOpenedModal = (updateType: 'add' | 'delete') => {\n if (openedModals.size) {\n const openedModalsCopy = new Set(openedModals);\n openedModalsCopy[updateType](modalId.current);\n dispatch(setOpenedModals(openedModalsCopy));\n }\n };\n\n useEffect(() => {\n if (visible) {\n updateOpenedModal('add');\n\n return () => {\n updateOpenedModal('delete');\n };\n }\n }, [visible]);\n\n return (\n \n )\n }\n visible={visible}\n closeIconStyle={closeIconStyle}\n >\n {customHeader && (\n {\n if (customHeader.onClose) {\n customHeader.onClose();\n }\n }}\n />\n )}\n {image && (\n
\n \n
\n )}\n {!!title &&
{title}
}\n
{children}
\n \n );\n};\n\nexport const ModalButtons = ({\n direction = 'row',\n children,\n className,\n ...props\n}: {\n direction?: 'row' | 'column';\n children: React.ReactNode;\n className?: string;\n}): ReactElement => {\n return (\n \n {children}\n \n );\n};\n"],"names":["CustomHeader","_ref","title","iconLib","iconName","iconTheme","onCancel","_jsxs","className","children","_jsx","GlobalIcon","lib","name","theme","size","EIconSize","_24","_20","onClick","Modal","image","zIndex","align","maxWidth","ModalWidth","MAX_1272","padding","wrapperPadding","bodyStyle","style","closeIcon","visible","preventScrollDisable","hideBorder","destroyOnClose","fixBody","customHeader","contentPadding","wrapClassName","getContainer","wrapperContainerPadding","placement","fullPage","footer","maskStyle","borderRadius","closeIconStyle","rest","dispatch","useDispatch","openedModals","useSelector","getOpenedModals","open","getBetslipOpen","modalId","useRef","uuidv4","accounts","useSearchParams","_preventScrollDisable","useMemo","isMobile","usePopupScrollDisable","updateOpenedModal","updateType","openedModalsCopy","Set","current","setOpenedModals","useEffect","CustomModal","ModalPadding","MOBILE_12","textAlign","WRAPPER_8","onClose","_72","color","ModalButtons","_ref2","direction","props","flexDirection"],"sourceRoot":""}