{"version":3,"file":"static/js/977.c0acbe51.chunk.js","mappings":"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","sources":["components/button/button.tsx","components/button/button-group.tsx","assets/icons/chevron.svg","components/button/button-with-chevron.tsx","components/button/icon-button.tsx","components/react-portal.tsx","assets/icons/close.svg","helpers/hooks/useResponsive.ts","components/modal.tsx","components/side-modal/side-modal.tsx","components/slide-modal/side-modal-close.tsx","components/slide-modal/slide-modal.tsx","components/access-denied-animation.tsx","components/sanction-access-denied/sanction-access-denied.tsx","helpers/services/storage.ts","helpers/services/http/api-client.ts","api/auth.ts","context/senction-context-provider.tsx"],"sourcesContent":["import { twMerge } from \"tailwind-merge\";\nimport { motion } from \"framer-motion\";\nimport cns from \"classnames\";\ntype SizeProps = \"sm\" | \"base\" | \"lg\" | \"xl\";\nconst Button = ({\n children,\n className = \"\",\n variant = \"primary\",\n loading = false,\n size = \"base\",\n reset,\n disbaleanimation,\n ...rest\n}: {\n children: React.ReactNode;\n variant:\n | \"primary\"\n | \"primary-outline\"\n | \"secondary\"\n | \"link\"\n | \"danger\"\n | \"success\"\n | \"warning\"\n | \"info\"\n | \"none\";\n loading?: boolean;\n className?: string;\n size?: SizeProps;\n reset?: boolean;\n disbaleanimation?: boolean;\n [key: string]: any;\n}) => {\n const classes = {\n primary: \"text-white bg-primary-600 hover:bg-primary-700 focus:ring-4\",\n secondary: \"text-gray-900 bg-white focus:ring-4 focus:ring-gray-200 \",\n link: \"\",\n info: \"text-primary-600 bg-primary-100\",\n \"primary-outline\":\n \"bg-white text-primary-600 border border-primary-600 hover:bg-primary-600 hover:text-white focus:ring-4 focus:ring-primary-600\",\n success: \"bg-[#E2FFEC] text-[#009C20]\",\n none: \"\",\n };\n const sizes = {\n sm: \"px-5 py-2 text-sm\",\n base: \"px-8 py-4 text-base\",\n lg: \"px-6 py-5 text-lg\",\n xl: \"px-8 py-6 text-xl\",\n };\n return (\n \n {children}\n {loading && (\n
\n \n \n \n \n
\n )}\n \n );\n};\n\nexport default Button;\n","import cns from \"classnames\";\n\nconst ButtonGroup = ({\n className,\n children,\n}: {\n children: React.ReactNode;\n className?: string;\n}) =>
{children}
;\n\nexport default ButtonGroup;\n","var _path;\nfunction _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }\nimport * as React from \"react\";\nfunction SvgChevron(_ref, svgRef) {\n let {\n title,\n titleId,\n ...props\n } = _ref;\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 25,\n viewBox: \"0 0 24 25\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 15.5L12 9.5L18 15.5\",\n strokeWidth: 2,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n })));\n}\nconst ForwardRef = /*#__PURE__*/React.forwardRef(SvgChevron);\nexport default __webpack_public_path__ + \"static/media/chevron.fa3628eda639beb595377a4f3532a8c1.svg\";\nexport { ForwardRef as ReactComponent };","import { ReactComponent as Chevron } from \"assets/icons/chevron.svg\";\nimport Button from \"./button\";\nimport { twMerge } from \"tailwind-merge\";\n\nconst ButtonWithChevron = ({ className = \"\", children, ...rest }) => {\n return (\n \n );\n};\nexport default ButtonWithChevron;\n","import cns from \"classnames\";\n\nconst IconButton = ({\n className,\n children,\n onClick,\n ...rest\n}: {\n className?: string;\n children: React.ReactNode;\n onClick?: () => void;\n}) => {\n return (\n \n {children}\n \n );\n};\n\nexport default IconButton;\n","import React from \"react\";\nimport { createPortal } from \"react-dom\";\n\nfunction createWrapperAndAppendToBody(wrapperId) {\n const wrapperElement = document.createElement(\"div\");\n wrapperElement.setAttribute(\"id\", wrapperId);\n document.body.appendChild(wrapperElement);\n return wrapperElement;\n}\n\n// Also, set a default value for wrapperId prop if none provided\nfunction ReactPortal({ children, wrapperId = \"react-portal-wrapper\" }) {\n const [wrapperElement, setWrapperElement] =\n React.useState(null);\n\n React.useLayoutEffect(() => {\n let element = document.getElementById(wrapperId);\n let systemCreated = false;\n\n // if element is not found with wrapperId or wrapperId is not provided,\n // create and append to body\n if (!element) {\n systemCreated = true;\n element = createWrapperAndAppendToBody(wrapperId);\n }\n setWrapperElement(element);\n return () => {\n if (systemCreated && element && element.parentNode) {\n element.parentNode.removeChild(element);\n }\n };\n }, [wrapperId]);\n\n // wrapperElement state will be null on the very first render.\n if (wrapperElement === null) return null;\n return createPortal(children, wrapperElement);\n}\n\nexport default ReactPortal;\n","var _path, _path2;\nfunction _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }\nimport * as React from \"react\";\nfunction SvgClose(_ref, svgRef) {\n let {\n title,\n titleId,\n ...props\n } = _ref;\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 24,\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M18 6L6 18\",\n strokeWidth: 2.5,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 6L18 18\",\n strokeWidth: 2.5,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n })));\n}\nconst ForwardRef = /*#__PURE__*/React.forwardRef(SvgClose);\nexport default __webpack_public_path__ + \"static/media/close.7e53b7d6b144e078568887bb276ab801.svg\";\nexport { ForwardRef as ReactComponent };","import { useMediaQuery } from \"react-responsive\";\n\nfunction useResponsive() {\n const isDesktop = useMediaQuery({ minWidth: 992 });\n const isTablet = useMediaQuery({ minWidth: 768, maxWidth: 991 });\n const isMobile = useMediaQuery({ maxWidth: 767 });\n const isNotMobile = useMediaQuery({ minWidth: 768 });\n const isIpadPro = useMediaQuery({ minWidth: 991, maxWidth: 1250 });\n return {\n isDesktop,\n isTablet,\n isMobile,\n isNotMobile,\n isIpadPro,\n };\n}\n\nexport const mediaQuery = {\n mobile: \"(max-width: 767px)\",\n tablet: \"(min-width: 768px) and (max-width: 991px)\",\n};\n\nexport default useResponsive;\n","import styled from \"styled-components\";\nimport React from \"react\";\nimport ReactPortal from \"./react-portal\";\nimport { ReactComponent as Close } from \"assets/icons/close.svg\";\nimport { twMerge } from \"tailwind-merge\";\nimport cns from \"classnames\";\nimport useResponsive from \"../helpers/hooks/useResponsive\";\nimport { AnimatePresence, motion } from \"framer-motion\";\n\nconst Wrapper = styled(motion.div)``;\ninterface Props {\n isFull?: boolean;\n id?: string;\n open: boolean;\n toggle: () => void;\n containerClassName?: string;\n wrapperClassName?: string;\n children: React.ReactNode;\n footer?: React.ReactNode;\n header?: React.ReactNode | string;\n size?: \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\" | \"3xl\" | \"4xl\" | \"5xl\" | \"6xl\";\n hideClose?: boolean;\n customStyles?: React.CSSProperties;\n disableBackdrop?: boolean;\n enableFooterShadow?: boolean;\n centered?: boolean;\n zIndex?: number;\n contentWrapperClass?: string;\n dialogWrapperClass?: string;\n isMeeting?: boolean;\n}\n\nfunction Modal({\n isFull = false,\n id = \"modal-portal-wrapper\",\n open,\n toggle,\n children,\n footer,\n header,\n containerClassName,\n wrapperClassName,\n size = \"md\",\n hideClose = false,\n customStyles = {},\n disableBackdrop = false,\n enableFooterShadow = false,\n centered = false,\n zIndex = 100,\n contentWrapperClass = \"\",\n dialogWrapperClass = \"\",\n isMeeting = false,\n}: Props) {\n const { isMobile } = useResponsive();\n // if (!open) return null;\n const sizes = {\n sm: \"384px\",\n md: \"28rem\",\n lg: \"32rem\",\n xl: \"36rem\",\n \"2xl\": \"42rem\",\n \"3xl\": \"48rem\",\n \"4xl\": \"56rem\",\n \"5xl\": \"64rem\",\n \"6xl\": \"72rem\",\n };\n const modalAnimation = {\n hidden: {\n opacity: 0,\n scale: 0.8,\n },\n visible: {\n opacity: 1,\n scale: 1,\n transition: {\n type: \"tween\",\n // stiffness: 500, // Adjust the stiffness for bounce effect\n damping: 5, // Adjust the damping for bounce effect\n duration: 0.1,\n },\n },\n exit: {\n opacity: 0,\n scale: 0.85, // Slightly smaller when exiting\n transition: {\n type: \"spring\",\n stiffness: 300, // You can adjust these values for the exit animation\n damping: 20, // to control the smoothness and bounce during exit\n },\n },\n };\n if (isMeeting && isMobile) {\n return (\n \n \n {open && (\n \n {/* modal body starts */}\n
\n {/* modal title */}\n {typeof header === \"string\" ? (\n

{header}

\n ) : (\n header\n )}\n {children}\n
\n {/* modal body ends */}\n\n \n \n Close modal\n \n \n )}\n
\n
\n );\n }\n return (\n \n \n {open && (\n \n {!disableBackdrop && (\n \n )}\n \n \n \n {/* modal body starts */}\n
\n {/* modal title */}\n
\n {typeof header === \"string\" ? (\n

{header}

\n ) : (\n header\n )}\n
\n \n {children}\n
\n {/* modal footer */}\n {!!footer && (\n \n {footer}\n \n )}\n \n {/* modal body ends */}\n \n {!hideClose && (\n \n \n Close modal\n \n )}\n \n \n \n )}\n
\n
\n );\n}\n\nexport default Modal;\n","import { AnimatePresence, motion } from \"framer-motion\";\nimport styled from \"styled-components\";\nimport { ReactComponent as Close } from \"assets/icons/close.svg\";\n\nconst sideVariants = {\n closed: {\n transition: {\n staggerChildren: 0.2,\n staggerDirection: -1,\n },\n },\n open: {\n transition: {\n staggerChildren: 0.2,\n staggerDirection: 1,\n },\n },\n};\nconst Wrapper = styled.div`\n position: fixed;\n right: 0;\n top: 0;\n left: 0;\n bottom: 0;\n background-color: rgba(0, 0, 0, 0.3);\n backdrop-filter: blur(5px);\n z-index: 999;\n main {\n display: flex;\n justify-content: flex-end;\n }\n aside {\n background-color: white;\n width: 18.75rem;\n height: 100vh;\n position: relative;\n }\n .container {\n margin: 4.5rem 1.4rem;\n }\n .btn-container {\n position: fixed;\n }\n .container a {\n color: #f9fafb;\n text-decoration: none;\n font-size: 1.75rem;\n font-weight: 600;\n display: block;\n margin: 20px;\n }\n`;\nfunction SideMenu({\n show,\n toggle,\n title,\n children,\n width = 540,\n customHeader,\n}: {\n show: boolean;\n toggle: () => void;\n title?: string | React.ReactNode;\n children: React.ReactNode;\n width?: string | number;\n customHeader?: React.ReactNode;\n}) {\n return (\n \n {show && (\n \n
\n {show && (\n e.stopPropagation()}\n initial={{ width: 0 }}\n animate={{\n width: width,\n }}\n exit={{\n width: 0,\n transition: { duration: 0.3 },\n }}\n >\n \n {customHeader ? (\n customHeader\n ) : (\n
\n

{title}

\n \n
\n )}\n {children}\n \n \n )}\n
\n
\n )}\n
\n );\n}\n\nexport default SideMenu;\n","import { motion, useAnimation } from \"framer-motion\";\nimport { ReactComponent as CloseIcon } from \"assets/icons/close.svg\";\nimport { useEffect } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nfunction SideModalClose({ onClick, className = \"\", closeStroke = \"#000\" }) {\n const controls = useAnimation();\n const handleClose = () => {\n controls.start({\n opacity: 1,\n transition: { duration: 0.1 },\n });\n onClick();\n };\n useEffect(() => {\n controls.start({\n opacity: 1,\n transition: { duration: 0.5 },\n });\n }, [controls]);\n\n useEffect(() => {\n const handleEscKey = (event: KeyboardEvent) => {\n if (event.key === \"Escape\") {\n onClick();\n }\n };\n document.addEventListener(\"keydown\", handleEscKey);\n return () => {\n document.removeEventListener(\"keydown\", handleEscKey);\n };\n }, [onClick]);\n\n return (\n \n \n \n );\n}\n\nexport default SideModalClose;\n","import React, { useEffect } from \"react\";\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport SideModalClose from \"./side-modal-close\";\nimport { twMerge } from \"tailwind-merge\";\n\n// TODO: add slide in and out animation\nfunction SlideModal({\n close,\n children,\n styles = {},\n open,\n className = \"\",\n dialogClassName = \"\",\n closeClassName = \"\",\n closeStroke = \"#000\",\n headerClassName = \"\",\n}) {\n useEffect(() => {\n document.body.style.overflow = \"hidden\";\n return () => {\n document.body.style.overflow = \"auto\";\n };\n }, []);\n const modalAnimation = {\n hidden: {\n y: \"100%\",\n },\n visible: {\n y: \"0%\",\n },\n exit: {\n y: \"100%\",\n },\n };\n return (\n <>\n \n {open && (\n \n \n {/* \n \n */}\n \n \n <>{children}\n \n \n )}\n \n \n );\n}\n\nexport default React.memo(SlideModal);\n","import React from \"react\";\nimport Lottie from \"lottie-react\";\nimport accessDeniedAnimation from \"helpers/constants/access-denied-lottie.json\";\n\nfunction AccessDeniedAnimation() {\n const lottieRef = React.useRef(null);\n React.useEffect(() => {\n lottieRef.current?.setSpeed(0.7);\n }, []);\n return (\n \n \n \n );\n}\nexport default AccessDeniedAnimation;\n","import AccessDeniedAnimation from \"components/access-denied-animation\";\nimport styled from \"styled-components\";\n\nconst WrapperDiv = styled.div`\n width: 331px;\n`;\n\nconst BlurDiv = styled.div`\n top: 0;\n position: absolute;\n height: 87px;\n border-radius: 1508px;\n opacity: 0.21;\n background: #3444da;\n filter: blur(141.4550018310547px);\n opacity: 0.6;\n`;\n\nconst BottomBlurDiv = styled.div`\n border-radius: 1508px;\n opacity: 0.21;\n background: #3444da;\n filter: blur(141.4550018310547px);\n width: 1508px;\n height: 180px;\n flex-shrink: 0;\n position: absolute;\n bottom: 0;\n`;\n\nfunction SanctionAccessDenied() {\n return (\n \n
\n \n \n \n
\n

\n We're Sorry!\n

\n

\n micro1 is currently not available\n in your region. We hope to serve you in the future.\n

\n
\n
\n \n
\n \n );\n}\n\nexport default SanctionAccessDenied;\n","const setToken = (token: string) => {\n localStorage.setItem(\"token\", token);\n};\nconst getToken = () => {\n return localStorage.getItem(\"token\");\n};\n\nconst removeToken = () => {\n localStorage.removeItem(\"token\");\n};\n\nexport const setStorage = (key: string, value: any) => {\n localStorage.setItem(key, JSON.stringify(value));\n};\n\nexport const removeStorage = (key: string) => {\n localStorage.removeItem(key);\n};\n\nexport const getStorage = (key: string) => {\n if (!key) return;\n const value = localStorage.getItem(key);\n return value ? JSON.parse(value) : null;\n};\n\nexport { setToken, getToken, removeToken };\n","import axios, { AxiosError, AxiosResponse } from \"axios\";\nimport { getToken } from \"helpers/services/storage\";\n// import toast from 'react-hot-toast';\nconst onResponse = (response: AxiosResponse): AxiosResponse => {\n // console.info(`[response] [${JSON.stringify(response)}]`);\n return response;\n};\n\nconst onResponseError = (error: AxiosError): Promise => {\n console.error(`[response error] [${JSON.stringify(error)}]`);\n if (error.response?.status === 401) {\n localStorage.removeItem(\"token\");\n // toast.error('Session expired. Please login again.');\n window.location.replace(\"/login\");\n }\n return Promise.reject(error);\n};\n\nconst apiClient = axios.create({\n baseURL:\n process.env.REACT_APP_BACKEND_API ||\n \"https://ctp33czl12.execute-api.us-west-1.amazonaws.com/dev\",\n});\nexport const apiClientWithoutInterceptor = axios.create({\n baseURL:\n process.env.REACT_APP_BACKEND_API ||\n \"https://ctp33czl12.execute-api.us-west-1.amazonaws.com/dev\",\n});\napiClient.interceptors.request.use(\n (config: any) => {\n const token = getToken();\n if (token) {\n config.headers[\"Authorization\"] = \"Bearer \" + token;\n }\n return config;\n },\n (error) => {\n return Promise.reject(error);\n }\n);\n\napiClient.interceptors.response.use(onResponse, onResponseError);\n\nexport default apiClient;\n","import apiClient, {\n apiClientWithoutInterceptor,\n} from \"helpers/services/http/api-client\";\n\nexport const auth = {\n checkAuthAccess: () => {\n return apiClientWithoutInterceptor\n .get(\"/auth/check/access\")\n .then((r) => r.data);\n },\n};\n\nexport default auth;\n","import { useEffect } from \"react\";\nimport { api } from \"root\";\n\nfunction SenctionContextProvider({ children }: { children: React.ReactNode }) {\n const checkAuth = async () => {\n try {\n const currentPath = window.location.pathname;\n const publicPaths = [\"/access-denied\"];\n if (publicPaths.includes(currentPath)) {\n console.log(\"skipping auth check\");\n return;\n }\n const response = await api.auth.checkAuthAccess();\n if (!response.status) {\n window.location.href = \"/access-denied\";\n }\n } catch (error) {}\n };\n\n useEffect(() => {\n checkAuth();\n }, []);\n return
{children}
;\n}\n\nexport default SenctionContextProvider;\n"],"names":["_ref","children","className","variant","loading","size","reset","disbaleanimation","rest","_jsxs","motion","button","type","whileHover","scale","disabled","transition","duration","whileTap","twMerge","cns","primary","secondary","link","info","success","none","sm","base","lg","xl","_jsx","role","viewBox","fill","xmlns","d","_path","_extends","Object","assign","bind","n","e","arguments","length","t","r","hasOwnProperty","call","apply","SvgChevron","svgRef","title","titleId","props","width","height","ref","id","strokeWidth","strokeLinecap","strokeLinejoin","ForwardRef","Button","Chevron","stroke","onClick","wrapperId","wrapperElement","setWrapperElement","React","element","document","getElementById","systemCreated","createElement","setAttribute","body","appendChild","createWrapperAndAppendToBody","parentNode","removeChild","createPortal","_path2","SvgClose","isDesktop","useMediaQuery","minWidth","isTablet","maxWidth","isMobile","isNotMobile","isIpadPro","Wrapper","styled","div","isFull","open","toggle","footer","header","containerClassName","wrapperClassName","hideClose","customStyles","disableBackdrop","enableFooterShadow","centered","zIndex","contentWrapperClass","dialogWrapperClass","isMeeting","useResponsive","ReactPortal","AnimatePresence","tabIndex","style","Close","initial","backgroundColor","backdropFilter","animate","exit","md","variants","hidden","opacity","visible","damping","stiffness","maxHeight","overflowY","boxShadow","transform","sideVariants","closed","staggerChildren","staggerDirection","show","customHeader","aside","stopPropagation","closeStroke","controls","useAnimation","useEffect","start","handleEscKey","event","key","addEventListener","removeEventListener","handleClose","CloseIcon","SlideModal","close","styles","dialogClassName","closeClassName","headerClassName","overflow","_Fragment","SideModalClose","y","lottieRef","_lottieRef$current","current","setSpeed","Lottie","animationData","accessDeniedAnimation","loop","autoplay","margin","WrapperDiv","BlurDiv","BottomBlurDiv","AccessDeniedAnimation","apiClient","axios","create","baseURL","process","REACT_APP_BACKEND_API","apiClientWithoutInterceptor","interceptors","request","use","config","token","localStorage","getItem","headers","error","Promise","reject","response","_error$response","console","JSON","stringify","status","removeItem","window","location","replace","checkAuthAccess","get","then","data","async","currentPath","pathname","includes","log","api","href","checkAuth"],"sourceRoot":""}