{"version":3,"sources":["assets/images/icons/IconFeasttt.png","assets/images/icons/IconChef.png","assets/images/icons/logo.png","assets/images/icons/LogoRed.png","assets/images/icons/LogoWhite.png","assets/images/icons/icon_features-1.png","assets/images/icons/icon_features-2.png","assets/images/icons/icon_features-3.png","assets/images/icons/icon_features-4.png","assets/images/icons/icon_features-5.png","assets/images/icons/icon_features-6.png","assets/images/icons/icon_features-7.png","assets/images/icons/icon_features-8.png","assets/images/icons/icon_foodie.png","assets/images/icons/icon_restaurant.png","assets/images/icons/blog_active.png","assets/images/icons/blog_inactive.png","assets/images/icons/careers_active.png","assets/images/icons/careers_inactive.png","assets/images/icons/contact_active.png","assets/images/icons/contact_inactive.png","assets/images/icons/home_active.png","assets/images/icons/home_inactive.png","assets/images/icons/icon_hamburger.png","assets/images/LogoMobile.svg","assets/images/CareersHero.png","assets/images/CareersHeroMobile.png","assets/images/customer/BgHomeHeader.png","assets/images/customer/HeaderPhone.png","assets/images/customer/HeaderPhoneMobile.png","assets/images/customer/HandPhone.svg","assets/images/customer/HowTo1.png","assets/images/customer/HowTo2.png","assets/images/customer/HowTo3.png","assets/images/customer/MobileGroup.png","assets/images/customer/MobileGroupMobile.png","assets/images/customer/BgModalHeader.png","assets/images/customer/BgModalThankyou.png","assets/images/restaurants/RestaurantHeader.png","assets/images/restaurants/GetTheApp.png","assets/images/restaurants/GetTheAppMobile.png","assets/images/restaurants/MobileWeb.png","assets/images/restaurants/FeaturesLeft.png","assets/images/restaurants/GetNotifiedRight.png","assets/images/restaurants/SliderImg1.png","assets/images/restaurants/SliderImg2.png","assets/images/restaurants/SliderImg3.png","assets/images/restaurants/Map.png","assets/images/restaurants/Map-mobile.png","assets/images/restaurants/FeaturesMobile.png","assets/images/restaurants/GetNotifiedMobile.png","assets/images/restaurants/RestaurantHow1.png","assets/images/restaurants/RestaurantHow2.png","assets/images/restaurants/RestaurantHow3.png","assets/images/restaurants/RestaurantHeaderMobile.png","theme/index.js","theme/globalStyle.js","layouts/Footer/style.js","service/index.js","layouts/Footer/index.js","layouts/style.js","layouts/Topbar/style.js","layouts/Topbar/index.js","layouts/index.js","service/MyRoute.js","containers/Customers/style.js","containers/Customers/CustomerHeader/style.js","containers/Customers/CustomerHeader/index.js","containers/Restaurants/HowToFeasttt/style.js","containers/Customers/HowToFeasttt/index.js","containers/Customers/DineOut/style.js","containers/Customers/DineOut/index.js","containers/Customers/Download/style.js","components/Elements/MyInput/style.js","components/Elements/MyInput/index.js","components/Elements/MyPhoneInput/style.js","components/Elements/MyPhoneInput/index.js","containers/Customers/Download/index.js","components/sections/GetNotifiedForm/style.js","components/sections/GetNotifiedForm/index.js","components/sections/GetNotified/style.js","components/sections/GetNotified/index.js","containers/Customers/index.js","containers/Restaurants/Features/style.js","containers/Restaurants/Features/index.js","containers/Restaurants/HowToFeasttt/index.js","containers/Restaurants/RestaurantHeader/style.js","containers/Restaurants/RestaurantHeader/index.js","containers/Restaurants/SectionSlider/style.js","containers/Restaurants/SectionSlider/index.js","containers/Restaurants/style.js","containers/Restaurants/index.js","containers/Blog/style.js","containers/Blog/index.js","containers/BlogDetail/style.js","containers/BlogDetail/index.js","containers/Careers/style.js","containers/Careers/CareersHeader/style.js","containers/Careers/CareersHeader/index.js","containers/Careers/OpenPositions/style.js","containers/Careers/OpenPositions/index.js","containers/Careers/index.js","containers/CareerDetail/style.js","containers/CareerDetail/ApplyJob/style.js","components/Elements/MyTextarea/style.js","components/Elements/MyTextarea/index.js","containers/CareerDetail/ApplyJob/index.js","containers/CareerDetail/CareerContent/style.js","containers/CareerDetail/CareerContent/index.js","containers/CareerDetail/index.js","containers/Contact/style.js","containers/Contact/ContactHeader/style.js","containers/Contact/ContactHeader/index.js","containers/Contact/ContactInfo/style.js","containers/Contact/ContactInfo/index.js","containers/Contact/index.js","containers/Privacy/style.js","containers/Privacy/index.js","App.js","serviceWorker.js","index.js"],"names":["module","exports","fonts","colors","mixins","GlobalStyle","createGlobalStyle","FooterContainer","styled","div","showNotification","type","msg","className","onClose","message","open","top","duration","maxCount","content","Container","size","color","onClick","recaptchasitekey","process","links_home","title","link","links_pages","mobile_links","iconActive","IconHomeActive","iconInactive","IconHomeInactive","IconCareersActive","IconCareersInactive","IconContactActive","IconContactInactive","Footer","location","useLocation","map","_link","_i","key","to","pathname","moment","format","href","rel","target","PageLayoutContainer","props","homepage","TopbarContainer","bg","Topbar","scrolled","history","useHistory","useState","expanded","setExpanded","visible","setVisible","isShowBtnsOnMobile","includes","isMobile","useMediaQuery","isWhite","onClickNavLink","push","collapseOnSelect","expand","fixed","onToggle","id","Image","src","IconHamburger","width","LogoRed","placement","closable","getContainer","document","getElementById","LogoMobile","filter","PageLayout","children","scrollRef","useRef","setScrolled","useEffect","current","scrollToTop","ref","autoHide","style","flex","onScrollFrame","e","scrollTop","MyRoute","Component","component","rest","render","CustomersContainer","CustomerHeaderContainer","header","CustomerHeader","onClickComing","md","xs","Button","HeaderPhoneMobile","HeaderPhone","HowToFeastttContainer","HowToFeasttt","fluid","IconFeasttt","justify","gutter","sm","HowTo1","HowTo2","HowTo3","DineOutContainer","DineOut","MobileGroupMobile","MobileGroup","alt","IconChef","DownloadContainer","GetTheApp","GetTheAppMobile","MyInputContainer","Input","MyInput","placeholder","onChange","MyPhoneInputContainer","PhoneInput","MyPhoneFormInputContainer","MyPhoneInput","defaultCountry","userTypes","value","img","IconFoodie","IconRestaurant","Download","recaptchaRef","Form","useForm","form","showModalDownload","setShowModalDownload","showModalThankyou","setShowModalThankyou","valReCaptcha","setValReCaptcha","activeUser","setActiveUser","url","setUrl","submitting","setSubmitting","onFinish","values","formData","FormData","append","email","name","phone","axios","post","result","data","status","window","reset","resetFields","wrapClassName","footer","centered","maskClosable","onCancel","BgModalHeader","_type","layout","initialValues","Item","label","rules","required","hasFeedback","sitekey","margin","console","log","onExpired","disabled","BgModalThankyou","GetNotifiedFormContainer","GetNotifiedForm","recaptchaRefEmail","recaptchaRefPhone","formEmail","formPhone","selectedTab","setSelectedTab","phoneNumber","setPhoneNumber","setEmail","valReCaptchaEmail","setValReCaptchaEmail","valReCaptchaPhone","setValReCaptchaPhone","onFinishFailed","errorFields","outOfDate","errors","onFinishEmail","fetch","method","body","response","json","onFinishPhone","Tab","defaultActiveKey","activeKey","Content","Pane","eventKey","GetNotifiedContainer","isIn","GetNotified","GetRestaurants","GetCustomers","Customers","scrollIntoView","behavior","block","FeaturesContainer","FeaturesLeft","features","icon","IconFeature7","IconFeature5","IconFeature4","IconFeature3","IconFeature6","IconFeature1","Features","FeaturesMobile","lg","_feature","RestaurantHow1","RestaurantHow2","RestaurantHow3","RestaurantHeaderContainer","BgRestaurantHeader","RestaurantHeader","onClickLearn","RestaurantHeaderMobile","SectionSliderContainer","activeIndex","leftPadding","SectionSlider","setActiveIndex","inView","otherProps","threshold","triggerOnce","React","useInViewInit","useInView","error","Sentry","category","level","rootMargin","onSlide","direction","Carousel","slide","interval","nextIcon","prevIcon","SliderImg1","SliderImg2","height","SliderImg3","RestaurantsContainer","Restaurants","blogImg","Blog","BlogDetail","CareersContainer","CareersHeaderContainer","CareersHero","CareersHeader","CareersHeroMobile","OpenPositionsContainer","OpenPositions","isLoading","setIsLoading","openPositions","setOpenPositions","origin","then","posts","setTimeout","active","length","_position","Careers","CareerDetailContainer","ApplyJobContainer","MyTextareaContainer","TextArea","MyTextarea","rows","Dragger","Upload","ApplyJob","detail","uploading","uploadedFile","setUploadedFile","full_name","letter","linkedin","github","portfolioLink","replaceAll","valuePropName","getValueFromEvent","Array","isArray","fileList","multiple","listType","beforeUpload","file","CareerContentContainer","CareerContent","foreword","expectations","_expectation","offer","_propos","requestedLevel","industry","employmentType","CareerDetail","useParams","setDetail","find","_post","ContactContainer","ContactHeaderContainer","ContactHeader","thoughts","ContactInfoContainer","Map","MapMobile","ContactInfo","Contact","PrivacyContainer","Privacy","data-target","class","App","exact","path","Boolean","hostname","match","ReactDOM","navigator","serviceWorker","ready","registration","unregister","catch"],"mappings":";+GAAAA,EAAOC,QAAU,spF,kBCAjBD,EAAOC,QAAU,04D,kBCAjBD,EAAOC,QAAU,0rG,kBCAjBD,EAAOC,QAAU,kiR,kBCAjBD,EAAOC,QAAU,klR,kBCAjBD,EAAOC,QAAU,08G,kBCAjBD,EAAOC,QAAU,87G,kBCAjBD,EAAOC,QAAU,04G,kBCAjBD,EAAOC,QAAU,05H,kBCAjBD,EAAOC,QAAU,sxH,kBCAjBD,EAAOC,QAAU,82H,kBCAjBD,EAAOC,QAAU,8zH,kBCAjBD,EAAOC,QAAU,0xG,kBCAjBD,EAAOC,QAAU,k9I,kBCAjBD,EAAOC,QAAU,kjG,kBCAjBD,EAAOC,QAAU,k9F,kBCAjBD,EAAOC,QAAU,09F,kBCAjBD,EAAOC,QAAU,02F,kBCAjBD,EAAOC,QAAU,85F,kBCAjBD,EAAOC,QAAU,0tM,kBCAjBD,EAAOC,QAAU,swM,kBCAjBD,EAAOC,QAAU,szG,kBCAjBD,EAAOC,QAAU,kyG,kBCAjBD,EAAOC,QAAU,smD,oBCAjBD,EAAOC,QAAU,IAA0B,wC,oBCA3CD,EAAOC,QAAU,IAA0B,yC,oBCA3CD,EAAOC,QAAU,IAA0B,+C,oBCA3CD,EAAOC,QAAU,IAA0B,0C,oBCA3CD,EAAOC,QAAU,IAA0B,yC,oBCA3CD,EAAOC,QAAU,IAA0B,+C,oBCA3CD,EAAOC,QAAU,IAA0B,uC,oBCA3CD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,oC,oBCA3CD,EAAOC,QAAU,IAA0B,yC,oBCA3CD,EAAOC,QAAU,IAA0B,+C,kBCA3CD,EAAOC,QAAU,srT,kBCAjBD,EAAOC,QAAU,kkQ,oBCAjBD,EAAOC,QAAU,IAA0B,8C,oBCA3CD,EAAOC,QAAU,IAA0B,uC,oBCA3CD,EAAOC,QAAU,IAA0B,6C,oBCA3CD,EAAOC,QAAU,IAA0B,uC,oBCA3CD,EAAOC,QAAU,IAA0B,0C,oBCA3CD,EAAOC,QAAU,IAA0B,8C,oBCA3CD,EAAOC,QAAU,IAA0B,wC,oBCA3CD,EAAOC,QAAU,IAA0B,wC,oBCA3CD,EAAOC,QAAU,IAA0B,wC,oBCA3CD,EAAOC,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ACE,2BACE,2CADF,4BAIF,4BACE,2BACE,oDADF,wVAUF,4BACE,2BACE,8CADF,+KAOF,4BACE,2BACE,2CADF,sCAC8D,IAC5D,uBACEzU,KAAK,sBACLC,IAAI,sBACJC,OAAO,UAHT,iBASJ,4BACE,2BACE,uCADF,sLAQJ,uEACA,uDACA,6CACA,0PAMA,4BACE,4BACE,6CAEF,4BACE,wDAEF,4BACE,4CAEF,4BACE,+EAEF,4BACE,2CAGJ,0CACA,4FACA,iUAOA,iZAQA,mLAKA,iEACA,2TAOA,4BACE,4BACE,+DADF,4VASA,4BACE,kDADF,gbAQyB,IACvB,uBACEF,KAAK,wKACLC,IAAI,sBACJC,OAAO,UAHT,0KAQF,4BACE,gDADF,saAWF,4QAI8C,IAC5C,uBACEF,KAAK,kDACLC,IAAI,sBACJC,OAAO,UAHT,6BALF,KAcA,yGAIA,4BACE,4BACE,2BACE,kEAEF,oDACA,kDACA,6YAUF,4BACE,2BACE,+EAEF,uDACA,kDACA,yHAKF,4BACE,2BACE,0DAEF,uDACA,kDACA,0VAUJ,8LAKA,yDACA,4FACA,4BACE,4BACE,2BACE,uEADF,qDAKF,4BACE,2BACE,2DADF,yMAOF,4BACE,2BACE,sEADF,uLAQF,4BACE,2BACE,mDADF,qWAUF,4BACE,2BACE,kDADF,gPAQF,4BACE,2BACE,4DADF,+CAKF,4BACE,2BACE,2DADF,uWAUF,4BACE,2BACE,sDADF,+PASJ,kGAIA,4BACE,4BACE,2DADF,iIAKA,4BACE,2DADF,4NAOA,4BACE,oDADF,0SAQA,4BACE,2DADF,oHAKA,4BACE,qDADF,yLAMA,4BACE,qDADF,yFAKF,+DACA,yZAQA,uVAOA,8DACA,2cASA,8JAIA,iXAQA,gEACA,qDACA,2PAMA,+CACA,gPAMA,wDACA,qIAIA,4BACE,8DACA,wFACA,yGAIA,iGAIA,gEAEF,8DACA,mUAOA,kDACA,8eAUA,+OAMA,uDACA,6QAMA,wKAKA,8DACA,oKAIA,oNAKA,0LAKA,0CACA,uGAIA,4BACE,4BACE,6DAEF,4BACE,mEACwC,IACtC,uBACEF,KAAK,8BACLC,IAAI,sBACJC,OAAO,UAHT,uCCleHwU,OAzBf,WACE,OACE,yBAAKhX,UAAU,OACb,kBAAC,EAAD,MACA,kBAAC,IAAD,KACE,kBAAC,IAAD,KACE,kBAAC,IAAD,CACEiX,OAAK,EACLC,KAAK,IACLhR,OAAQ,kBAAM,kBAAC,IAAD,CAAUhE,GAAG,uBAE7B,kBAAC,GAAD,CAAS+U,OAAK,EAACC,KAAK,kBAAkBlR,UAAW0I,KACjD,kBAAC,GAAD,CAASuI,OAAK,EAACC,KAAK,oBAAoBlR,UAAWiM,KAGnD,kBAAC,GAAD,CAASgF,OAAK,EAACC,KAAK,WAAWlR,UAAWuN,KAC1C,kBAAC,GAAD,CAAS0D,OAAK,EAACC,KAAK,eAAelR,UAAW8P,KAC9C,kBAAC,GAAD,CAASmB,OAAK,EAACC,KAAK,WAAWlR,UAAW2Q,KAC1C,kBAAC,GAAD,CAASM,OAAK,EAACC,KAAK,WAAWlR,UAAW6Q,SC3BhCM,QACW,cAA7BtM,OAAOjJ,SAASwV,UAEe,UAA7BvM,OAAOjJ,SAASwV,UAEhBvM,OAAOjJ,SAASwV,SAASC,MACvB,2DCZNC,IAASpR,OACL,kBAAC,GAAD,MACFvB,SAASC,eAAe,SD2HpB,kBAAmB2S,WACrBA,UAAUC,cAAcC,MACrBxE,MAAK,SAAAyE,GACJA,EAAaC,gBAEdC,OAAM,SAAA5G,GACLhF,QAAQgF,MAAMA,EAAM9Q,c","file":"static/js/main.9f118a4e.chunk.js","sourcesContent":["module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/LogoMobile.231b5bc7.svg\";","module.exports = __webpack_public_path__ + \"static/media/CareersHero.685c7392.png\";","module.exports = __webpack_public_path__ + \"static/media/CareersHeroMobile.402e3ff5.png\";","module.exports = __webpack_public_path__ + \"static/media/BgHomeHeader.b6b28545.png\";","module.exports = __webpack_public_path__ + \"static/media/HeaderPhone.2593c174.png\";","module.exports = __webpack_public_path__ + \"static/media/HeaderPhoneMobile.119fb51c.png\";","module.exports = __webpack_public_path__ + \"static/media/HandPhone.94fb885a.svg\";","module.exports = __webpack_public_path__ + \"static/media/HowTo1.a91b7799.png\";","module.exports = __webpack_public_path__ + \"static/media/HowTo2.0ab64a6f.png\";","module.exports = __webpack_public_path__ + \"static/media/HowTo3.c96b23d7.png\";","module.exports = __webpack_public_path__ + \"static/media/MobileGroup.e75a6c23.png\";","module.exports = __webpack_public_path__ + \"static/media/MobileGroupMobile.aa53edf7.png\";","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/RestaurantHeader.11024a43.png\";","module.exports = __webpack_public_path__ + \"static/media/GetTheApp.599233a1.png\";","module.exports = __webpack_public_path__ + \"static/media/GetTheAppMobile.cf606d4d.png\";","module.exports = __webpack_public_path__ + \"static/media/MobileWeb.fa7bfc9a.png\";","module.exports = __webpack_public_path__ + \"static/media/FeaturesLeft.e84645a2.png\";","module.exports = __webpack_public_path__ + \"static/media/GetNotifiedRight.e277588f.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImg1.b2c4b139.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImg2.b19a249d.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImg3.7154ad90.png\";","module.exports = __webpack_public_path__ + \"static/media/Map.c1eb1cf0.png\";","module.exports = __webpack_public_path__ + \"static/media/Map-mobile.123dcf72.png\";","module.exports = __webpack_public_path__ + \"static/media/FeaturesMobile.daacd87a.png\";","module.exports = __webpack_public_path__ + \"static/media/GetNotifiedMobile.d02adf6f.png\";","module.exports = __webpack_public_path__ + \"static/media/RestaurantHow1.9ae10630.png\";","module.exports = __webpack_public_path__ + \"static/media/RestaurantHow2.693259d2.png\";","module.exports = __webpack_public_path__ + \"static/media/RestaurantHow3.2f936e0a.png\";","module.exports = __webpack_public_path__ + \"static/media/RestaurantHeaderMobile.10608e0f.png\";","export const fonts = {\n roboto: 'Roboto',\n pt: \"PT Sans\",\n nunito: 'Nunito',\n main: 'Montserrat',\n}\n\nexport const colors = {\n white: '#fff',\n white5: 'rgba(255, 255, 255, 0.5)',\n white8: 'rgba(255, 255, 255, 0.08)',\n green: 'green',\n grayDark: '#151617',\n grayLight: '#D1D1D1',\n gray: '#191919',\n red: '#ed2626',\n dark5: 'rgba(0, 0, 0, 0.5)',\n pink6: `rgba(237, 38, 38, 0.06)`\n}\n\nexport const mixins = {\n sm: 575,\n md: 767,\n mobileNavbarH: 146,\n}","import { createGlobalStyle } from \"styled-components\";\nimport { colors, fonts, mixins } from \"theme\";\n\nconst GlobalStyle = createGlobalStyle`\n body {\n font-family: ${fonts.main};\n margin: 0;\n height: 100%;\n }\n .App {\n height: 100vh;\n }\n .cursor {\n cursor: pointer;\n }\n h1 {\n font-size: 56px !important;\n font-family: ${fonts.main};\n font-weight: 700;\n }\n h2 {\n font-size: 46px !important;\n font-family: ${fonts.main};\n font-weight: 700;\n }\n h3 {\n font-size: 36px !important;\n font-family: ${fonts.main};\n }\n h5 {\n font-size: 24px !important;\n }\n h6 {\n font-size: 20px !important;\n font-family: ${fonts.main};\n }\n p {\n font-size: 14px !important;\n font-family: ${fonts.main};\n }\n .flex1 {\n flex: 1;\n }\n .section-wrapper {\n min-height: 200px;\n }\n .text-red-gra {\n background-image: linear-gradient(104deg, #ed2626, #ff7878);\n font-stretch: normal;\n font-style: normal;\n line-height: 1.13;\n letter-spacing: -1.92px;\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n }\n .btn-red {\n background: ${colors.red};\n color: ${colors.white};\n &:active, &:hover, &:focus {\n background-color: ${colors.red} !important;\n color: ${colors.white} !important;\n }\n }\n .btn-white {\n background: ${colors.white};\n color: ${colors.red};\n &:active, &:hover, &:focus {\n background-color: ${colors.white} !important;\n color: ${colors.red} !important;\n }\n }\n .btn-gray {\n background: ${colors.grayLight};\n color: #000;\n &:active, &:hover, &:focus {\n background-color: ${colors.grayLight} !important;\n color: #000 !important;\n }\n }\n .text-white5 {\n color: ${colors.white5};\n }\n .text-dark5 {\n color: ${colors.dark5};\n }\n .text-red {\n color: ${colors.red};\n }\n .text-bold {\n font-weight: bold;\n }\n .bg-dark5 {\n background-color: ${colors.dark5};\n }\n .bg-red {\n background-color: ${colors.red};\n }\n button, .btn {\n font-family: ${fonts.main};\n font-weight: 700;\n border: none;\n border-radius: 100px;\n transition: opacity .45s cubic-bezier(0.25, 1, 0.33, 1), transform .45s cubic-bezier(0.25, 1, 0.33, 1), border-color .45s cubic-bezier(0.25, 1, 0.33, 1), color .45s cubic-bezier(0.25, 1, 0.33, 1), background-color .45s cubic-bezier(0.25, 1, 0.33, 1), box-shadow .45s cubic-bezier(0.25, 1, 0.33, 1);\n &:focus {\n outline: none;\n }\n &:hover {\n box-shadow: 0px 6px 24px rgba(0, 0, 0, 0.16);\n transform: translateY(-3px);\n }\n &.disabled:hover {\n transform: unset;\n }\n }\n .ant-message {\n top: 0;\n .ant-message-notice {\n padding: 0;\n .ant-message-notice-content {\n width: 100%;\n height: 112px;\n display: flex;\n justify-content: center;\n align-items: center;\n .ant-message-custom-content {\n width: 100%;\n .anticon-close-circle {\n display: none;\n }\n }\n }\n }\n }\n .modal-download {\n .ant-modal-content {\n border-radius: 44px;\n .ant-modal-body {\n padding: 0;\n .download-form {\n padding: 30px 60px 22px;\n @media (max-width: ${mixins.md}px) {\n padding: 30px 15px 22px;\n }\n .download-title {\n font-size: 36px !important;\n font-weight: bold;\n }\n .download-description {\n font-size: 20px !important;\n margin-bottom: 40px;\n }\n .user-type {\n margin-bottom: 30px;\n label {\n font-size: 16px !important;\n font-weight: bold;\n }\n .user-cards-wrapper {\n .user-card {\n flex: 1;\n min-height: 106px;\n border-radius: 6px;\n border: solid 2px rgba(0, 0, 0, 0.15);\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n transition: all 0.5s ease;\n &.selected {\n border: solid 2px #ed2626;\n }\n p {\n font-size: 16px;\n font-weight: 600;\n margin-bottom: 0;\n margin-top: 5px;\n }\n }\n }\n }\n .ant-form {\n .recaptcha-wrapper {\n margin-top: 30px;\n div {\n margin: 0 auto;\n }\n }\n .ant-form-item {\n margin-bottom: 11px;\n .ant-form-item-label {\n label {\n width: 100%;\n font-size: 16px !important;\n font-weight: bold;\n &::before {\n display: none;\n }\n span {\n margin: 0;\n &.optional {\n opacity: 0.6;\n }\n }\n }\n }\n .btn-submit {\n width: 100%;\n height: 50px;\n margin-top: 28px;\n }\n .btn-cancel {\n width: 100%;\n height: 50px;\n }\n }\n .icon-close-modal {\n width: 50px;\n height: 50px;\n box-shadow: 0 2px 33px 0 rgb(0 0 0 / 30%);\n border-radius: 50%;\n justify-content: center;\n align-items: center;\n }\n }\n }\n }\n }\n }\n .modal-thankyou {\n .ant-modal {\n width: 600px !important;\n .ant-modal-content {\n border-radius: 50px;\n .ant-modal-body {\n padding: 0;\n .download-form {\n padding: 30px 60px 22px;\n @media (max-width: ${mixins.md}px) {\n padding: 30px 15px 22px;\n }\n .download-title {\n font-size: 36px !important;\n font-weight: bold;\n }\n .download-description {\n font-size: 24px !important;\n margin-bottom: 20px;\n }\n .down-again {\n font-size: 16px !important;\n text-align: center;\n }\n .btn-submit {\n width: 100%;\n height: 50px;\n margin-top: 20px;\n }\n }\n }\n }\n }\n }\n`;\n\nexport default GlobalStyle;\n","import styled from \"styled-components\";\nimport { colors, fonts, mixins } from \"theme\";\n\nexport const FooterContainer = styled.div`\n width: 100%;\n height: 234px;\n background: ${colors.grayDark};\n display: flex;\n justify-content: center;\n align-items: center;\n color: ${colors.white};\n /* border-radius: 40px 40px 0 0; */\n .footer-row {\n display: flex;\n justify-content: space-between;\n align-items: center;\n &.links {\n margin-bottom: 40px;\n }\n .navbar-link {\n color: ${colors.white5};\n font-size: 16px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: normal;\n &:hover {\n color: ${colors.white};\n }\n }\n p {\n color: ${colors.white5};\n font-family: ${fonts.nunito};\n font-size: 16px !important;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: normal;\n }\n .group-link {\n .navbar-link {\n margin-right: 40px;\n }\n }\n .btns-switch {\n height: 50px;\n width: 300px;\n display: flex;\n padding: 6px;\n border-radius: 25px;\n background-color: ${colors.white8};\n .navbar-link {\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 38px;\n font-size: 14px !important;\n &.active {\n color: ${colors.white};\n border-radius: 25px;\n background-color: #ed2626;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n border-radius: 0;\n height: unset;\n padding: 40px 0;\n .footer-row {\n flex-direction: column-reverse;\n &.links {\n margin-bottom: 0px;\n }\n .group-link {\n margin-bottom: 40px;\n width: 100%;\n display: flex;\n justify-content: space-around;\n .navbar-link {\n margin-right: 0;\n }\n }\n .btns-switch {\n margin-bottom: 40px;\n width: 100%;\n .navbar-link {\n flex: 1;\n }\n }\n .group-social {\n margin-bottom: 40px;\n width: 100%;\n display: flex;\n justify-content: center;\n }\n }\n }\n`;\n","import React from \"react\";\nimport { message } from \"antd\";\nimport { Container } from \"react-bootstrap\";\nimport { FaCheck, FaInfoCircle, FaTimes } from \"react-icons/fa\";\nimport { colors } from \"theme\";\nimport {\n IconBlogActive,\n IconBlogInactive,\n IconCareersActive,\n IconCareersInactive,\n IconContactActive,\n IconContactInactive,\n IconHomeActive,\n IconHomeInactive,\n} from \"assets/images/icons\";\nimport { useInView } from \"react-intersection-observer\";\nimport * as Sentry from \"@sentry/react\";\n\nexport const showNotification = (\n type = \"error\",\n msg,\n className = \"\",\n onClose = () => {}\n) => {\n message.open({\n top: 0,\n duration: 10,\n maxCount: 1,\n content: (\n <Container className=\"d-flex justify-content-between align-items-center\">\n {type === \"error\" ? (\n <FaInfoCircle size={18} color={colors.red} />\n ) : (\n <FaCheck size={18} color={colors.green} />\n )}\n <h6 className=\"mb-0 ml-2 text-gray text-bold\">{msg}</h6>\n <FaTimes\n className=\"ml-auto\"\n size={19}\n color={colors.gray}\n onClick={onClose}\n />\n </Container>\n ),\n className: className,\n // content:\n onClose: onClose,\n });\n};\n\nexport const recaptchasitekey = process.env.REACT_APP_RECAPTCHA_SITE_KEY;\n\nexport function useInViewInit(otherProps) {\n let props = {\n ...otherProps,\n threshold: 1,\n triggerOnce: true,\n };\n let inView = true;\n let ref = React.useRef();\n\n try {\n const useInViewInit = useInView(props);\n inView = useInViewInit.inView;\n ref = useInViewInit.ref;\n } catch (error) {\n Sentry.addBreadcrumb({\n category: \"app\",\n message: \"Intersection observer not available\",\n level: \"info\",\n });\n }\n\n return { inView, ref };\n}\n\nexport const links_home = [\n {\n title: \"For Foodies\",\n link: \"/home/customers\",\n },\n {\n title: \"For Restaurants\",\n link: \"/home/restaurants\",\n },\n];\nexport const links_pages = [\n // {\n // title: \"Blog\",\n // link: \"/blog\",\n // },\n {\n title: \"Careers\",\n link: \"/careers\",\n },\n {\n title: \"Contact\",\n link: \"/contact\",\n },\n {\n title: \"Privacy Policy\",\n link: \"/privacy\",\n },\n];\n\nexport const mobile_links = [\n {\n title: \"Home\",\n link: \"/home\",\n iconActive: IconHomeActive,\n iconInactive: IconHomeInactive,\n },\n // {\n // title: \"Blog\",\n // link: \"/blog\",\n // iconActive: IconBlogActive,\n // iconInactive: IconBlogInactive,\n // },\n {\n title: \"Careers\",\n link: \"/careers\",\n iconActive: IconCareersActive,\n iconInactive: IconCareersInactive,\n },\n {\n title: \"Contact\",\n link: \"/contact\",\n iconActive: IconContactActive,\n iconInactive: IconContactInactive,\n },\n];\n","import React from \"react\";\nimport { Container } from \"react-bootstrap\";\nimport { Link, useLocation } from \"react-router-dom\";\nimport { FaInstagram, FaTwitter, FaFacebook } from \"react-icons/fa\";\nimport { FooterContainer } from \"./style\";\nimport { colors } from \"theme\";\nimport { links_home, links_pages } from \"service\";\nimport { Space } from \"antd\";\nimport moment from \"moment\";\n\nfunction Footer() {\n const location = useLocation();\n\n return (\n <FooterContainer>\n <Container>\n <div className=\"footer-row links\">\n <div className=\"group-link\">\n {links_pages.map((_link, _i) => (\n <Link key={_i} to={_link.link} className=\"navbar-link\">\n {_link.title}\n </Link>\n ))}\n </div>\n <div className=\"btns-switch\">\n {links_home.map((_link, _i) => (\n <Link\n key={_i}\n to={_link.link}\n className={`${\n _link.link === location.pathname && \"active\"\n } navbar-link`}\n >\n {_link.title}\n </Link>\n ))}\n </div>\n </div>\n <div className=\"footer-row\">\n <p className=\"mb-0\">© {moment().format(\"YYYY\")} Foodie Ave Inc</p>\n <Space size={30} className=\"group-social\">\n <a\n href=\"https://www.instagram.com/feastttapp/\"\n className=\"soc-link\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n <FaInstagram\n size={24}\n color={colors.white5}\n className=\"icon-social\"\n />\n </a>\n <a\n href=\"https://twitter.com/feastttapp\"\n className=\"soc-link\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n <FaTwitter\n size={24}\n color={colors.white5}\n className=\"icon-social\"\n />\n </a>\n <a\n href=\"https://www.linkedin.com/company/feasttt\"\n className=\"soc-link\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n <FaFacebook\n size={24}\n color={colors.white5}\n className=\"icon-social\"\n />\n </a>\n </Space>\n </div>\n </Container>\n </FooterContainer>\n );\n}\n\nexport default Footer;\n","import styled from \"styled-components\";\nimport { mixins } from \"theme\";\n\nexport const PageLayoutContainer = styled.div`\n position: relative;\n width: 100%;\n min-height: calc(100vh);\n /* height: 100%; */\n display: flex;\n justify-content: space-between;\n flex-direction: column;\n align-items: flex-start;\n .page-content {\n flex: 1;\n width: 100%;\n display: flex;\n flex-direction: column;\n header {\n padding-top: 80px;\n }\n }\n @media (max-width: ${mixins.md}px) {\n .page-content {\n header {\n /* padding-top: ${props => props.homepage ? '146px' : '100px'}; */\n padding-top: 80px;\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const TopbarContainer = styled.div`\n position: fixed;\n top: 0;\n width: 100%;\n min-height: 80px;\n background: ${(props) => (props.bg === \"white\" ? \"#fff\" : \"transparent\")};\n align-items: flex-start;\n transition: all 0.5s ease;\n display: flex;\n align-items: center;\n z-index: 20;\n box-shadow: ${(props) =>\n props.bg === \"white\" ? \"0 2px 4px 0 rgba(0, 0, 0, 0.1)\" : \"unset\"};\n .container {\n .navbar-wrapper {\n display: flex;\n justify-content: space-between;\n min-height: 80px;\n align-items: center;\n .logo-img {\n display: flex;\n align-items: center;\n img {\n width: 170px;\n }\n }\n .navbar-link {\n font-size: 16px !important;\n font-weight: 700;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: normal;\n margin-left: 40px;\n &:hover {\n color: #000;\n }\n }\n .btns-switch {\n height: 50px;\n width: 300px;\n display: flex;\n padding: 6px;\n border-radius: 25px;\n background-color: ${(props) =>\n props.bg === \"white\" ? \"rgba(237, 38, 38, 0.1)\" : colors.white};\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);\n .navbar-link {\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 38px;\n font-size: 14px !important;\n color: ${colors.red};\n &.active {\n color: ${colors.white};\n border-radius: 25px;\n background-color: ${colors.red};\n }\n }\n }\n }\n .navbar-wrapper-sm {\n position: relative;\n .icon-hamburger {\n position: absolute;\n }\n .ant-drawer {\n .ant-drawer-content-wrapper {\n .ant-drawer-content {\n .ant-drawer-wrapper-body {\n .ant-drawer-body {\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n align-items: center;\n background-color: ${colors.pink6};\n padding: 40px 0;\n @media (max-height: 765px) {\n padding: 40px 0 10px;\n }\n .navbar-sm-content {\n width: 100%;\n margin-top: 25px;\n .sm-link {\n height: 82px;\n width: 100%;\n display: flex;\n align-items: center;\n .link-icon {\n width: 100px;\n }\n .link-title {\n flex: 1;\n height: 100%;\n display: flex;\n justify-content: flex-start;\n align-items: center;\n border-bottom: solid 1px #e4dada;\n h5 {\n font-size: 20px;\n font-weight: 600;\n margin-bottom: 0;\n }\n }\n }\n }\n .btns-switch-sm {\n height: 50px;\n width: 300px;\n display: flex;\n margin-top: 40px;\n @media (max-height: 765px) {\n margin-top: 20px;\n }\n padding: 6px;\n border-radius: 25px;\n background-color: ${(props) =>\n props.bg === \"white\"\n ? \"rgba(237, 38, 38, 0.1)\"\n : colors.white};\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.1);\n .navbar-link {\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 38px;\n font-size: 14px !important;\n color: ${colors.red};\n margin-bottom: 0;\n &.active {\n color: ${colors.white};\n border-radius: 25px;\n background-color: ${colors.red};\n }\n }\n }\n .close-icon {\n width: 60px;\n height: 60px;\n min-height: 60px;\n box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2);\n border: solid 1px rgba(255, 255, 255, 0.12);\n background-color: #d3d3d3;\n border-radius: 50%;\n justify-content: center;\n align-items: center;\n }\n }\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n min-height: 60px;\n }\n`;\n","import { IconHamburger, LogoRed } from \"assets/images/icons\";\nimport React, { useState } from \"react\";\nimport { Drawer } from \"antd\";\nimport { Image, Container } from \"react-bootstrap\";\nimport { FaTimes } from \"react-icons/fa\";\nimport { Link, useHistory, useLocation } from \"react-router-dom\";\nimport { links_home, links_pages, mobile_links } from \"service\";\nimport { mixins } from \"theme\";\nimport useMediaQuery from \"use-mediaquery\";\nimport { TopbarContainer } from \"./style\";\nimport { LogoMobile } from \"assets/images\";\n\nfunction Topbar({ scrolled }) {\n const history = useHistory();\n const location = useLocation();\n const [expanded, setExpanded] = useState(false);\n const [visible, setVisible] = useState(false);\n const showDrawer = () => {\n setVisible(true);\n };\n\n const isShowBtnsOnMobile = location.pathname.includes(\"home\");\n const isMobile = useMediaQuery(`(max-width: ${mixins.md}px)`);\n const isWhite = !location.pathname.includes(\"home\");\n\n const onClickNavLink = (link) => {\n if (link === \"/home\") {\n history.push(\"/home/customers\");\n } else {\n history.push(link);\n }\n setVisible(false);\n };\n return (\n <TopbarContainer\n className={`${expanded ? \"expanded-nav\" : \"collapsed-nav\"}`}\n collapseOnSelect\n expand=\"md\"\n fixed=\"top\"\n bg={expanded || scrolled || isWhite ? \"white\" : \"transparent\"}\n expanded={expanded}\n onToggle={() => setExpanded(!expanded)}\n >\n <Container>\n {isMobile ? (\n <div\n id=\"navbar-wrapper-sm\"\n className=\"navbar-wrapper-sm d-flex justify-content-between align-items-center\"\n >\n <Image\n src={IconHamburger}\n className=\"icon-hamburger\"\n width={30}\n onClick={showDrawer}\n />\n <Link\n to=\"/\"\n className=\"logo-img flex1 d-flex justify-content-center align-items-center\"\n >\n <Image src={LogoRed} width={136} />\n </Link>\n <Drawer\n title={false}\n placement=\"right\"\n closable={false}\n onClose={() => setVisible(false)}\n visible={visible}\n width=\"100%\"\n getContainer={() => document.getElementById(\"navbar-wrapper-sm\")}\n >\n <Image src={LogoMobile} width={150} />\n <div className=\"navbar-sm-content\">\n {mobile_links\n .filter((_link, _i) => _link.link !== \"/privacy\")\n .map((_link, _i) => (\n <div\n className=\"sm-link\"\n onClick={() => onClickNavLink(_link.link)}\n >\n <div className=\"link-icon d-flex justify-content-center align-items-center\">\n {/* <FaCircle\n size={30}\n color={\n location.pathname.includes(_link.link)\n ? colors.red\n : colors.dark5\n }\n /> */}\n <Image\n src={\n location.pathname.includes(_link.link)\n ? _link.iconActive\n : _link.iconInactive\n }\n width={30}\n />\n </div>\n <div className=\"link-title\">\n <h5\n key={_i}\n to={_link.link}\n className={`navbar-link ${\n location.pathname.includes(_link.link)\n ? \"text-red\"\n : \"text-dark5\"\n }`}\n onClick={() => setExpanded(false)}\n >\n {_link.title}\n </h5>\n </div>\n </div>\n ))}\n </div>\n <div\n className={`btns-switch-sm ${\n !isShowBtnsOnMobile && isMobile && \"d-none\"\n }`}\n >\n {links_home.map((_link, _i) => (\n <h5\n key={_i}\n to={_link.link}\n className={`${\n _link.link === location.pathname && \"active\"\n } navbar-link ml-auto`}\n onClick={() => onClickNavLink(_link.link)}\n >\n {_link.title}\n </h5>\n ))}\n </div>\n <div\n className=\"d-md-none d-flex close-icon mx-auto mt-auto\"\n onClick={() => setVisible(false)}\n >\n <FaTimes size={22} />\n </div>\n </Drawer>\n </div>\n ) : (\n <div className=\"navbar-wrapper\">\n <Link to=\"/\" className=\"logo-img\">\n <Image src={LogoRed} />\n </Link>\n {links_pages\n .filter((_link, _i) => _link.link !== \"/privacy\")\n .map((_link, _i) => (\n <Link\n key={_i}\n to={_link.link}\n className={`navbar-link text-dark5`}\n onClick={() => setExpanded(false)}\n >\n {_link.title}\n </Link>\n ))}\n <div\n className={`btns-switch ml-auto ${\n !isShowBtnsOnMobile && isMobile && \"d-none\"\n }`}\n >\n {links_home.map((_link, _i) => (\n <Link\n key={_i}\n to={_link.link}\n className={`${\n _link.link === location.pathname && \"active\"\n } navbar-link ml-auto`}\n >\n {_link.title}\n </Link>\n ))}\n </div>\n </div>\n )}\n </Container>\n </TopbarContainer>\n );\n}\n\nexport default Topbar;\n","/* eslint-disable react-hooks/exhaustive-deps */\n/* eslint-disable array-callback-return */\nimport React, { useEffect, useRef, useState } from \"react\";\nimport Scrollbars from \"react-custom-scrollbars\";\nimport { useHistory } from \"react-router\";\nimport Footer from \"./Footer\";\nimport { PageLayoutContainer } from \"./style\";\nimport Topbar from \"./Topbar\";\n\nfunction PageLayout({ children }) {\n const history = useHistory();\n const scrollRef = useRef(null);\n const [scrolled, setScrolled] = useState(false);\n\n const handleScroll = (e) => {\n setScrolled(e.scrollTop > 100);\n };\n\n useEffect(() => {\n scrollRef.current.scrollToTop();\n }, [history.location.pathname]);\n return (\n <Scrollbars\n ref={scrollRef}\n autoHide\n style={{ flex: 1 }}\n onScrollFrame={handleScroll}\n >\n <PageLayoutContainer homepage={history.location.pathname.includes('home')}>\n <Topbar scrolled={scrolled} />\n <div className=\"page-content\">{children}</div>\n <Footer />\n </PageLayoutContainer>\n </Scrollbars>\n );\n}\n\nexport default PageLayout;\n","import React from 'react'\nimport { Route } from 'react-router-dom';\n// import PropTypes from 'prop-types';\nimport PageLayout from 'layouts';\n\nconst MyRoute = ({ component: Component, ...rest }) => {\n\n return (\n <Route {...rest} render={(props) => (\n <PageLayout><Component {...props} /></PageLayout>\n )} />\n )\n}\n\n// MyRoute.propTypes = {\n// component: PropTypes.func.isRequired,\n// };\n\nexport default MyRoute;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const CustomersContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const CustomerHeaderContainer = styled.header`\n width: 100%;\n height: 861px;\n background-color: ${colors.pink6};\n display: flex;\n align-items: center;\n .container {\n height: 100%;\n .btn-get-the-app-sm {\n width: 100%;\n height: 80px;\n font-size: 26px;\n }\n .header-left {\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n .header-description {\n margin-bottom: 50px;\n background-image: linear-gradient(113deg, #ed2626, #ff7878);\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n span {\n font-weight: normal;\n }\n }\n .btn-get-the-app {\n width: 315px;\n height: 80px;\n font-size: 26px;\n }\n }\n .header-right {\n display: flex;\n align-items: flex-end;\n .header-image {\n /* width: 332px; */\n height: 80%;\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n max-height: unset;\n flex-direction: column;\n height: fit-content;\n .container {\n padding-top: 48px;\n .header-left {\n align-items: center;\n h3 {\n font-size: 20px !important;\n font-weight: 500;\n }\n .header-description {\n font-size: 40px !important;\n margin-bottom: 50px;\n text-align: center;\n }\n }\n .header-right {\n margin-top: 53px;\n .header-image {\n width: 100%;\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { Col, Row } from \"antd\";\nimport React from \"react\";\nimport { Button, Container, Image } from \"react-bootstrap\";\nimport useMediaQuery from \"use-mediaquery\";\nimport { CustomerHeaderContainer } from \"./style\";\nimport { HeaderPhone, HeaderPhoneMobile } from \"assets/images/customer\";\nimport { mixins } from \"theme\";\n\nfunction CustomerHeader({\n onClickComing = () => {}\n}) {\n\n const isMobile = useMediaQuery(`(max-width: ${mixins.md}px)`);\n\n return (\n <CustomerHeaderContainer className='animate__animated animate__fadeIn'>\n <Container className='flex1'>\n <Row className='align-items-stretch h-100'>\n <Col md={12} xs={24}>\n <div className=\"header-left\">\n <h1 className=\"header-description\">\n A dining <br className='d-md-none' /> experience\n <br />\n <span>as</span> unique<br className='d-md-none' /> as you.\n </h1>\n <Button className=\"btn-get-the-app btn-red\" onClick={onClickComing}>Coming Soon</Button>\n </div>\n </Col>\n <Col md={12} xs={24} className='h-100'>\n <div className=\"header-right text-right h-100\">\n <Image src={isMobile ? HeaderPhoneMobile : HeaderPhone} className='header-image' />\n </div>\n </Col>\n </Row>\n {/* <Button className=\"btn-get-the-app-sm btn-red d-md-none\">Coming Soon</Button> */}\n </Container>\n </CustomerHeaderContainer>\n );\n}\n\nexport default CustomerHeader;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const HowToFeastttContainer = styled.div`\n width: 100%;\n padding: 150px 0 100px;\n .container-fluid {\n .img-howto {\n width: 73px;\n }\n h1 {\n font-size: 100px !important;\n font-weight: bold;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: -2.4px;\n text-align: center;\n color: ${colors.grayLight};\n margin-bottom: 100px;\n }\n .cards-wrapper {\n max-width: 1580px;\n .how-card {\n display: flex;\n flex-direction: column;\n align-items: center;\n h5 {\n text-align: center;\n font-weight: bold;\n margin-bottom: 60px;\n line-height: 1.42;\n letter-spacing: -0.76px;\n }\n img {\n width: 100%;\n margin-bottom: 60px;\n }\n .how-card-description {\n color: ${colors.gray};\n opacity: 0.6;\n line-height: 1.6;\n letter-spacing: normal;\n text-align: center;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 100px 0;\n .container-fluid {\n .img-howto {\n width: 46px;\n }\n h1 {\n font-size: 36px !important;\n margin-bottom: 60px;\n letter-spacing: -0.86px;\n }\n .cards-wrapper {\n .how-card {\n h5 {\n font-size: 20px !important;\n margin-bottom: 25px;\n line-height: 1.5;\n letter-spacing: normal;\n }\n img {\n margin-bottom: 0px;\n }\n .how-card-description {\n font-size: 14px !important;\n margin-bottom: 30px;\n line-height: 1.86;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Col, Row } from \"antd\";\nimport React from \"react\";\nimport { Container, Image } from \"react-bootstrap\";\nimport { HowTo1, HowTo2, HowTo3 } from \"assets/images/customer\";\nimport { IconFeasttt } from \"assets/images/icons\";\nimport { HowToFeastttContainer } from \"containers/Restaurants/HowToFeasttt/style\";\n\nfunction HowToFeasttt() {\n // const inView = useInViewInit({\n // rootMargin: \"-130px\",\n // threshold: 1,\n // triggerOnce: true,\n // });\n\n return (\n <HowToFeastttContainer>\n <Container className=\"d-flex flex-column align-items-center\" fluid>\n <Image src={IconFeasttt} className=\"img-howto mx-auto mb-2\" />\n <h1 className=\"how-to-feasttt\">How to Feasttt.</h1>\n <div className=\"cards-wrapper\">\n <Row justify=\"center\" gutter={[{ sm: 0, md: 100 }, 40]}>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Arrive and check in at <br />\n the restaurant.\n </h5>\n <Image src={HowTo1} />\n <h6 className=\"how-card-description\">\n Download the Feasttt app to find your new favorite dine-in\n restaurant then check in when you arrive to{\" \"}\n <b>unlock your personalized dining experience.</b>\n </h6>\n </div>\n </Col>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Order food, request refills\n <br />\n and more with a tap.\n </h5>\n <Image src={HowTo2} />\n <h6 className=\"how-card-description\">\n Browse menus and reviews from other foodies and customize your\n order to your heart’s content.{\" \"}\n <b>Hungry? Thirsty? Everything is just a tap away.</b>\n </h6>\n </div>\n </Col>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Pay, split the bill\n <br />\n and rate your feast.\n </h5>\n <Image src={HowTo3} />\n <h6 className=\"how-card-description\">\n After a <b>wonderful feast</b> you can pay and tip right in\n the app, invite friends to split the bill and rate your meal\n and server to help future guests.\n </h6>\n </div>\n </Col>\n </Row>\n </div>\n </Container>\n </HowToFeastttContainer>\n );\n}\n\nexport default HowToFeasttt;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const DineOutContainer = styled.div`\n background-color: ${colors.pink6};\n max-height: 1200px;\n display: flex;\n align-items: center;\n position: relative;\n overflow: hidden;\n .left-part {\n flex: 1;\n .mobile-phones-img {\n width: 100%;\n position: relative;\n left: -100px;\n }\n }\n .right-part {\n flex: 1;\n // padding-right: 100px;\n h1 {\n font-size: 90px !important;\n font-weight: bold;\n background-image: linear-gradient(111deg, #ed2626, #ff7878 100%);\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n margin: 0;\n margin-bottom: 80px;\n letter-spacing: -1.92px;\n }\n .small-menues {\n .menu-item {\n display: flex;\n align-items: center;\n padding-bottom: 30px;\n .icon-wrapper {\n width: 50px;\n height: 50px;\n min-width: 50px;\n border-radius: 50%;\n background-image: linear-gradient(291deg, #ff6767, #ed2626);\n margin-right: 30px;\n display: flex;\n justify-content: center;\n align-items: center;\n .chef-cap-ico {\n width: 18px;\n }\n i {\n font-size: 18px !important;\n color: ${colors.white};\n }\n }\n p {\n font-size: 24px !important;\n font-weight: bold;\n color: ${colors.gray};\n margin: 0;\n max-width: 500px;\n letter-spacing: -0.58px;\n text-shadow: 0px 0px 10px rgba(255, 255, 255, 0.55);\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n max-height: unset;\n flex-direction: column-reverse;\n .left-part {\n padding: 0 15px;\n .mobile-phones-img {\n left: 0;\n }\n }\n .right-part {\n padding: 80px 30px;\n width: 100%;\n h1 {\n font-size: 45px !important;\n margin-bottom: 40px;\n letter-spacing: normal;\n }\n .small-menues {\n .menu-item {\n display: flex;\n padding-bottom: 21px;\n .icon-wrapper {\n .chef-cap-ico {\n width: 16px;\n }\n i {\n font-size: 16px !important;\n }\n }\n p {\n font-size: 14px !important;\n letter-spacing: -0.34px;\n line-height: 1.86;\n text-shadow: 0px 0px 10px rgba(255, 255, 255, 0.55);\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import React from \"react\";\nimport { DineOutContainer } from \"./style\";\nimport useMediaQuery from \"use-mediaquery\";\nimport { MobileGroup, MobileGroupMobile } from \"assets/images/customer\";\nimport { IconChef } from \"assets/images/icons\";\nimport { Image } from \"react-bootstrap\";\nimport { mixins } from \"theme\";\n\nfunction DineOut() {\n const isMobile = useMediaQuery(`(max-width: ${mixins.md}px)`);\n\n return (\n <DineOutContainer>\n <div className=\"left-part\">\n {/* <Parallax className=\"img-container\" y={[-10, 20]} tagOuter=\"figure\"> */}\n <Image\n src={isMobile ? MobileGroupMobile : MobileGroup}\n alt=\"mobile-rain\"\n className=\"mobile-phones-img\"\n />\n {/* </Parallax> */}\n </div>\n <div className=\"right-part\">\n <h1>\n Dine out <br /> with Feasttt.\n </h1>\n <div className=\"small-menues\">\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <img className=\"chef-cap-ico\" src={IconChef} alt=\"chef\" />{\" \"}\n </div>\n <p>\n Find restaurants by craving, dietary preferences, budget or\n rating.\n </p>\n </div>\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <i className=\"fas fa-star\" />{\" \"}\n </div>\n <p>Browse visual menus and foodie reviews.</p>\n </div>\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <i className=\"fas fa-utensils\" />{\" \"}\n </div>\n <p>Food and drinks made to order.</p>\n </div>\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <i className=\"fas fa-sync-alt\"></i>{\" \"}\n </div>\n <p>Fast and easy refills and returns.</p>\n </div>\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <i className=\"fas fa-credit-card\" />{\" \"}\n </div>\n <p>Contactless payments and tips.</p>\n </div>\n <div className=\"menu-item\">\n <div className=\"icon-wrapper\">\n <i className=\"fas fa-users\" />\n </div>\n <p>Split the bill without the headache.</p>\n </div>\n </div>\n </div>\n </DineOutContainer>\n );\n}\n\nexport default DineOut;\n","import { GetTheApp, GetTheAppMobile } from \"assets/images/restaurants\";\nimport styled from \"styled-components\";\nimport { mixins } from \"theme\";\n\nexport const DownloadContainer = styled.div`\n width: 100%;\n padding: 150px 0 300px;\n .join-overlay {\n display: flex;\n justify-content: center;\n .join-content-wrapper {\n width: 1580px;\n height: 430px;\n background: url(${GetTheApp});\n background-repeat: no-repeat;\n background-size: auto 100%;\n background-position: center;\n display: flex;\n justify-content: flex-end;\n .join-content {\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n align-items: flex-start;\n width: 40%;\n h5 {\n font-size: 24px !important;\n margin-bottom: 35px;\n line-height: 1.5;\n width: 90%;\n }\n .btn-join {\n width: 315px;\n height: 80px;\n border-radius: 100px;\n font-size: 26px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: -0.62px;\n margin-bottom: 40px;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 30px 0 120px;\n .join-overlay {\n display: flex;\n justify-content: center;\n .join-content-wrapper {\n flex-direction: column;\n width: 100%;\n height: unset;\n border-radius: 63px;\n background: linear-gradient(\n 156deg,\n rgba(255, 127, 127, 0.53) -118%,\n #ff7f7f -60%,\n #fe7979 -17%,\n #ee2c2c 43%,\n #ed2626 100%\n );\n .join-content {\n width: 100%;\n align-items: center;\n padding: 46px 0 76px;\n h5 {\n font-size: 18px !important;\n margin-bottom: 45px;\n text-align: center;\n line-height: 1.56;\n max-width: 83%;\n }\n .btn-join {\n margin-bottom: 0;\n }\n }\n .join-content-right {\n width: 100%;\n height: fit-content;\n /* background: url(${GetTheAppMobile});\n background-repeat: no-repeat;\n background-size: auto 100%;\n background-position: center; */\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Input } from \"antd\";\nimport styled from \"styled-components\";\nimport { mixins } from \"theme\";\n\nexport const MyInputContainer = styled(Input)`\n width: 100%;\n height: 50px;\n padding: 10px 10px 10px 18px;\n border-radius: 8px;\n background-color: #fafafa;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import React from \"react\";\nimport { MyInputContainer } from \"./style\";\n\nfunction MyInput({\n className = \"\",\n type = \"text\",\n placeholder = \"\",\n onChange = () => {},\n}) {\n return (\n <MyInputContainer\n type={type}\n className={className}\n placeholder={placeholder}\n onChange={onChange}\n />\n );\n}\n\nexport default MyInput;\n","import styled from \"styled-components\";\nimport { mixins } from \"theme\";\nimport PhoneInput from \"react-phone-number-input\";\nimport \"react-phone-number-input/style.css\";\n\nexport const MyPhoneInputContainer = styled(PhoneInput)`\n width: 100%;\n border-bottom: solid 2px #000;\n height: 40px;\n input {\n border: none;\n padding-bottom: 0;\n background-color: transparent;\n }\n input:focus {\n outline: none;\n }\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\nexport const MyPhoneFormInputContainer = styled(PhoneInput)`\n width: 100%;\n height: 50px;\n padding: 10px 10px 10px 18px;\n border-radius: 8px;\n background-color: #fafafa;\n border: 1px solid #d9d9d9;\n input {\n border: none;\n background-color: #fafafa;\n }\n input:focus {\n outline: none;\n }\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import React from \"react\";\nimport { MyPhoneInputContainer, MyPhoneFormInputContainer } from \"./style\";\n\nfunction MyPhoneInput({ type = \"field\", onChange = () => {} }) {\n return type === \"field\" ? (\n <MyPhoneInputContainer\n className=\"writable-input-phone\"\n type={type}\n placeholder=\"Enter your mobile number\"\n defaultCountry=\"US\"\n onChange={onChange}\n />\n ) : (\n <MyPhoneFormInputContainer\n className=\"writable-input-phone\"\n type={type}\n placeholder=\"Enter your mobile number\"\n defaultCountry=\"US\"\n onChange={onChange}\n />\n );\n}\n\nexport default MyPhoneInput;\n","import { GetTheAppMobile } from \"assets/images/restaurants\";\nimport { BgModalHeader, BgModalThankyou } from \"assets/images/customer\";\nimport { Modal, Form } from \"antd\";\nimport React, { useRef, useState } from \"react\";\nimport { Button, Container, Image } from \"react-bootstrap\";\nimport { DownloadContainer } from \"./style\";\nimport MyInput from \"components/Elements/MyInput\";\nimport MyPhoneInput from \"components/Elements/MyPhoneInput\";\nimport ReCAPTCHA from \"react-google-recaptcha\";\nimport { recaptchasitekey, showNotification } from \"service\";\nimport axios from \"axios\";\nimport { FaTimes } from \"react-icons/fa\";\nimport { IconRestaurant, IconFoodie } from \"assets/images/icons\";\n\nconst userTypes = [\n {\n value: 1,\n img: IconFoodie,\n title: \"Foodie\",\n },\n {\n value: 2,\n img: IconRestaurant,\n title: \"Restaurant\",\n },\n];\nfunction Download() {\n const recaptchaRef = useRef();\n const [form] = Form.useForm();\n const [showModalDownload, setShowModalDownload] = useState(false);\n const [showModalThankyou, setShowModalThankyou] = useState(false);\n const [valReCaptcha, setValReCaptcha] = useState(\"\");\n const [activeUser, setActiveUser] = useState(1);\n const [url, setUrl] = useState();\n const [submitting, setSubmitting] = useState(false);\n\n const onVerifyCaptcha = (value) => {\n setValReCaptcha(value);\n console.log({ value });\n };\n\n const onFinish = async (values) => {\n if (!valReCaptcha) {\n showNotification(\"error\", \"Please, verify captcha.\");\n return;\n }\n setSubmitting(true);\n const formData = new FormData();\n formData.append(\"email\", values.email);\n formData.append(\"name\", values.name);\n formData.append(\"phone\", values.phone);\n formData.append(\"utype\", activeUser);\n formData.append(\"captchaResponse\", valReCaptcha);\n const result = await axios.post(\n \"https://code-room.com/feastdocs/getpdf.php\",\n formData\n );\n if (result.data.status === \"success\") {\n window.open(result.data.url, \"_blank\");\n setUrl(result.data.url);\n recaptchaRef.current.reset();\n form.resetFields();\n setShowModalDownload(false);\n setShowModalThankyou(true);\n } else {\n showNotification(\"error\", \"Something went wrong\");\n }\n setSubmitting(false);\n };\n return (\n <DownloadContainer>\n <Container className=\"d-flex flex-column\" fluid>\n <div className=\"join-overlay\">\n <div className=\"join-content-wrapper\">\n <div className=\"join-content\">\n <h5 className=\"join-title text-white\">\n <b>Download our white paper</b> to take a deep dive into the\n Feasttt experience and see how we help restaurants increase\n revenue.\n </h5>\n <Button\n className=\"btn-join btn-white\"\n onClick={() => setShowModalDownload(true)}\n >\n Download\n </Button>\n </div>\n <div className=\"join-content-right d-md-none\">\n <Image src={GetTheAppMobile} className=\"d-md-none\" width=\"100%\" />\n </div>\n </div>\n </div>\n </Container>\n <Modal\n wrapClassName=\"modal-download\"\n title={null}\n footer={null}\n visible={showModalDownload}\n centered\n closable={false}\n maskClosable={true}\n onCancel={() => setShowModalDownload(false)}\n >\n <div className=\"modal-header-img\">\n <Image src={BgModalHeader} width=\"100%\" />\n </div>\n <div className=\"download-form\">\n <h3 className=\"download-title text-center\">Get the white paper.</h3>\n <div className=\"user-type\">\n <label>Which best describes you?</label>\n <div className=\"user-cards-wrapper d-flex\">\n {userTypes.map((_type, _i) => (\n <div\n key={_i}\n className={`user-card cursor ${_i === 0 ? \"mr-3\" : \"\"} ${\n activeUser === _type.value && \"selected\"\n }`}\n onClick={() => setActiveUser(_type.value)}\n >\n <Image src={_type.img} width={45} />\n <p>{_type.title}</p>\n </div>\n ))}\n </div>\n </div>\n <Form\n className=\"header-right\"\n layout=\"vertical\"\n form={form}\n initialValues={{\n phone: \"\",\n }}\n onFinish={onFinish}\n >\n <Form.Item\n name=\"name\"\n label=\"Full Name\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Share your full name\" />\n </Form.Item>\n <Form.Item\n name=\"email\"\n label=\"Email\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n {\n type: \"email\",\n message: \"Invalid Email!\",\n },\n ]}\n hasFeedback\n >\n <MyInput type=\"email\" placeholder=\"Enter your e-mail\" />\n </Form.Item>\n <Form.Item\n name=\"phone\"\n label={\n <div className=\"w-100 d-flex justify-content-between\">\n <span>Phone Number</span>\n <span className=\"optional\">Optional</span>\n </div>\n }\n // rules={[\n // {\n // required: true,\n // message: \"Required Field!\",\n // },\n // ]}\n hasFeedback\n >\n <MyPhoneInput type=\"form\" placeholder=\"Enter your phone number\" />\n </Form.Item>\n <div className=\"recaptcha-wrapper\">\n <ReCAPTCHA\n ref={recaptchaRef}\n sitekey={recaptchasitekey}\n style={{ margin: \"0px auto\" }}\n onChange={onVerifyCaptcha}\n onExpired={() => setValReCaptcha(\"\")}\n />\n </div>\n <div className=\"btns-wrapper\">\n <Form.Item>\n <Button\n type=\"submit\"\n className=\"btn-red btn-submit\"\n disabled={submitting}\n >\n Continue\n </Button>\n </Form.Item>\n <Form.Item>\n <Button\n className=\"btn-gray btn-cancel\"\n onClick={() => setShowModalDownload(false)}\n >\n Cancel\n </Button>\n </Form.Item>\n </div>\n <div\n className=\"d-md-none d-flex icon-close-modal mx-auto\"\n onClick={() => setShowModalDownload(false)}\n >\n <FaTimes size={18} />\n </div>\n </Form>\n </div>\n </Modal>\n <Modal\n wrapClassName=\"modal-thankyou\"\n title={null}\n footer={null}\n visible={showModalThankyou}\n centered\n closable={false}\n onCancel={() => setShowModalThankyou(false)}\n >\n <div className=\"modal-header-img\">\n <Image src={BgModalThankyou} width=\"100%\" />\n </div>\n <div className=\"download-form\">\n <h3 className=\"download-title text-center\">Thank you!</h3>\n <p className=\"download-description text-center\">\n Your download will begin shortly. Please click “Allow†if prompted\n by your browser.\n </p>\n <p className=\"down-again\">\n If your download does not start, please click below:\n </p>\n <a href={url} target=\"_blank\" rel=\"noopener noreferrer\">\n <Button className=\"btn-red btn-submit\">Download</Button>\n </a>\n <Button\n className=\"btn-gray btn-submit\"\n onClick={() => setShowModalThankyou(false)}\n >\n Close\n </Button>\n </div>\n </Modal>\n </DownloadContainer>\n );\n}\n\nexport default Download;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const GetNotifiedFormContainer = styled.div`\n h5.comming-soon {\n font-weight: 600;\n }\n h1 {\n font-size: 90px !important;\n font-stretch: normal;\n font-style: normal;\n line-height: 1.11;\n letter-spacing: -2.16px;\n }\n .tab-switcher-container {\n color: #fff;\n width: 350px;\n display: flex;\n align-items: center;\n border-radius: 25px;\n background-color: rgba(0, 0, 0, 0.1);\n margin: 32px 0;\n padding: 5px;\n .tab-switcher-item {\n flex: 1 1 50%;\n display: flex;\n justify-content: center;\n padding: 8px 0;\n cursor: pointer;\n font-size: 20px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: -0.48px;\n text-align: center;\n color: ${colors.dark5};\n &.active {\n color: ${colors.red};\n border-radius: 20px;\n background-color: ${colors.white};\n }\n }\n }\n .tab-content {\n width: 350px;\n .notified-form {\n .notified-form-input {\n margin-bottom: 45px;\n }\n }\n .content-title {\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: 1.5;\n letter-spacing: -0.48px;\n }\n .writable-input-email {\n width: 100%;\n border: none;\n border-bottom: solid 2px #000;\n height: 40px;\n background-color: transparent;\n &:active, &:focus {\n box-shadow: none;\n outline: none;\n }\n }\n .btn-submit {\n height: 50px;\n margin-top: 45px;\n }\n }\n @media (max-width: ${mixins.md}px) {\n h5.comming-soon {\n font-size: 20px !important;\n font-weight: 600;\n }\n h1 {\n font-size: 45px !important;\n font-stretch: normal;\n font-style: normal;\n line-height: 1.11;\n letter-spacing: -1.08px;\n margin-bottom: 40px;\n }\n .tab-switcher-container {\n color: #fff;\n width: 100%;\n display: flex;\n align-items: center;\n border-radius: 25px;\n background-color: rgba(0, 0, 0, 0.1);\n margin: 20px 0;\n padding: 5px;\n .tab-switcher-item {\n flex: 1 1 50%;\n display: flex;\n justify-content: center;\n padding: 8px 0;\n cursor: pointer;\n font-size: 20px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: -0.48px;\n text-align: center;\n color: ${colors.dark5};\n &.active {\n color: ${colors.red};\n border-radius: 20px;\n background-color: ${colors.white};\n }\n }\n }\n .tab-content {\n width: 100%;\n .btn-submit {\n margin-top: 45px;\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Form, Input } from \"antd\";\nimport ReCAPTCHA from \"react-google-recaptcha\";\nimport MyPhoneInput from \"components/Elements/MyPhoneInput\";\nimport React, { useRef, useState } from \"react\";\nimport { Button, Tab } from \"react-bootstrap\";\nimport { recaptchasitekey, showNotification } from \"service\";\nimport { GetNotifiedFormContainer } from \"./style\";\n\nfunction GetNotifiedForm({ onChange = () => {} }) {\n const recaptchaRefEmail = useRef();\n const recaptchaRefPhone = useRef();\n const [formEmail] = Form.useForm();\n const [formPhone] = Form.useForm();\n const [selectedTab, setSelectedTab] = useState(\"mobile\");\n const [phoneNumber, setPhoneNumber] = useState(\"\");\n const [email, setEmail] = useState(\"\");\n const [valReCaptchaEmail, setValReCaptchaEmail] = useState(\"\");\n const [valReCaptchaPhone, setValReCaptchaPhone] = useState(\"\");\n\n const onChangePhoneNumber = (value) => {\n setPhoneNumber(value);\n };\n\n const onChangeEmail = (e) => {\n setEmail(e.target.value);\n };\n\n const onVerifyCaptchaEmail = (value) => {\n setValReCaptchaEmail(value);\n };\n const onVerifyCaptchaPhone = (value) => {\n setValReCaptchaPhone(value);\n };\n\n const onFinishFailed = ({ values, errorFields, outOfDate }) => {\n showNotification(\"error\", errorFields[0].errors[0]);\n };\n\n const onFinishEmail = async (values) => {\n if (!valReCaptchaEmail) {\n showNotification(\"error\", \"Please, verify captcha.\");\n return;\n }\n const formData = new FormData();\n formData.append(\"emailvalue\", email);\n formData.append(\"contactType\", \"email\");\n formData.append(\"captchaResponse\", valReCaptchaEmail);\n const response = await fetch(\"https://code-room.com/subscribe2.php\", {\n method: \"POST\",\n body: formData,\n });\n const result = await response.json();\n if (result && result.status === \"ok\") {\n showNotification(\"success\", \"Thanks, we’ll let you know when we launch!\");\n } else {\n showNotification(\"error\", \"Error occurred. Please try again later.\");\n }\n recaptchaRefEmail.current.reset();\n formEmail.resetFields();\n };\n const onFinishPhone = async (values) => {\n if (!valReCaptchaPhone) {\n showNotification(\"error\", \"Please, verify captcha.\");\n return;\n }\n const formData = new FormData();\n formData.append(\"phvalue\", phoneNumber);\n formData.append(\"contactType\", \"phone\");\n formData.append(\"captchaResponse\", valReCaptchaPhone);\n const response = await fetch(\"https://code-room.com/subscribe2.php\", {\n method: \"POST\",\n body: formData,\n });\n const result = await response.json();\n if (result && result.status === \"ok\") {\n showNotification(\"success\", \"Thanks, we’ll let you know when we launch!\");\n } else {\n showNotification(\"error\", \"Error occurred. Please try again later.\");\n }\n recaptchaRefPhone.current.reset();\n formPhone.resetFields();\n };\n\n return (\n <GetNotifiedFormContainer className='get-notified-form'>\n <h5 className=\"comming-soon text-bold text-red text-uppercase\">\n Coming Soon\n </h5>\n <h1 className=\"text-red\">\n Get notified\n <br />\n at launch.\n </h1>\n <Tab.Container\n id=\"tabs-bootstrap\"\n defaultActiveKey=\"mobile\"\n activeKey={selectedTab}\n >\n <div className=\"tab-switcher-container\">\n <div\n className={`tab-switcher-item ${\n selectedTab === \"mobile\" ? \"active\" : \"\"\n }`}\n onClick={() => setSelectedTab(\"mobile\")}\n >\n Mobile\n </div>\n <div\n className={`tab-switcher-item ${\n selectedTab === \"email\" ? \"active\" : \"\"\n }`}\n onClick={() => setSelectedTab(\"email\")}\n >\n Email\n </div>\n </div>\n <Tab.Content>\n <Tab.Pane eventKey=\"mobile\" className=\"pane-mobile\">\n <h6 className=\"text-bold content-title\">\n We can text you the link.\n </h6>\n <Form\n className=\"notified-form\"\n layout=\"vertical\"\n form={formPhone}\n onFinish={onFinishPhone}\n onFinishFailed={onFinishFailed}\n >\n <Form.Item\n name=\"phone\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n className='notified-form-input'\n hasFeedback\n >\n <MyPhoneInput\n className=\"writable-input-phone\"\n placeholder=\"Enter your mobile number\"\n defaultCountry=\"US\"\n onChange={onChangePhoneNumber}\n />\n </Form.Item>\n <ReCAPTCHA\n ref={recaptchaRefPhone}\n sitekey={recaptchasitekey}\n onChange={onVerifyCaptchaPhone}\n onExpired={() => setValReCaptchaPhone(\"\")}\n />\n <Form.Item>\n <Button type=\"submit\" className=\"btn-red w-100 btn-submit\">\n Get notified\n </Button>\n </Form.Item>\n </Form>\n </Tab.Pane>\n <Tab.Pane eventKey=\"email\" className=\"pane-email\">\n <h6 className=\"text-bold content-title\">\n We can email you the link.\n </h6>\n <Form\n className=\"notified-form\"\n layout=\"vertical\"\n form={formEmail}\n onFinish={onFinishEmail}\n onFinishFailed={onFinishFailed}\n >\n <Form.Item\n name=\"email\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n {\n type: \"email\",\n message: \"Invalid Email!\",\n },\n ]}\n className='notified-form-input'\n hasFeedback\n >\n <Input\n className=\"writable-input-email\"\n placeholder=\"Enter your email address\"\n onChange={onChangeEmail}\n />\n </Form.Item>\n <ReCAPTCHA\n ref={recaptchaRefEmail}\n sitekey={recaptchasitekey}\n onChange={onVerifyCaptchaEmail}\n onExpired={() => setValReCaptchaEmail(\"\")}\n />\n <Form.Item>\n <Button type=\"submit\" className=\"btn-red w-100 btn-submit\">\n Coming Soon\n </Button>\n </Form.Item>\n </Form>\n </Tab.Pane>\n </Tab.Content>\n </Tab.Container>\n </GetNotifiedFormContainer>\n );\n}\n\nexport default GetNotifiedForm;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const GetNotifiedContainer = styled.div`\n position: relative;\n padding: 50px 0;\n background: ${colors.white};\n display: flex;\n align-items: flex-start;\n padding: 200px 0;\n .container {\n max-width: 1400px;\n .get-notified-parts {\n display: flex;\n align-items: center;\n .get-notified-part {\n width: 50%;\n .form-wrapper {\n display: flex;\n justify-content: center;\n }\n .img-wrapper {\n display: flex;\n justify-content: center;\n align-items: center;\n height: 100%;\n margin-left: 100px;\n .img-notified {\n max-width: ${(props) =>\n props.isIn === \"restaurants\" ? 834 : 596}px;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 100px 0;\n flex-direction: column;\n .container {\n .get-notified-parts {\n flex-direction: column;\n .get-notified-part {\n width: 100%;\n .form-wrapper {\n display: unset;\n padding-top: 0px;\n .get-notified-form {\n width: 100%;\n }\n }\n .img-wrapper {\n margin-left: 0;\n margin-top: 50px;\n .img-notified {\n width: 80%;\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { GetCustomers } from \"assets/images/customer\";\nimport { GetRestaurants } from \"assets/images/restaurants\";\nimport GetNotifiedForm from \"components/sections/GetNotifiedForm\";\nimport React from \"react\";\nimport { Container, Image } from \"react-bootstrap\";\nimport { GetNotifiedContainer } from \"./style\";\n\nfunction GetNotified({ isIn = \"restaurants\" }) {\n return (\n <GetNotifiedContainer isIn={isIn}>\n <Container>\n <div className=\"get-notified-parts\">\n <div className=\"get-notified-part\">\n <div className=\"form-wrapper\">\n <GetNotifiedForm />\n </div>\n </div>\n <div className=\"get-notified-part\">\n <div className=\"img-wrapper\">\n <Image\n src={isIn === \"restaurants\" ? GetRestaurants : GetCustomers}\n className=\"img-notified\"\n />\n </div>\n </div>\n </div>\n </Container>\n </GetNotifiedContainer>\n );\n}\n\nexport default GetNotified;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport React, { useRef } from \"react\";\nimport { CustomersContainer } from \"./style\";\nimport CustomerHeader from \"./CustomerHeader\";\nimport HowToFeasttt from \"./HowToFeasttt\";\nimport DineOut from \"./DineOut\";\nimport Download from \"./Download\";\nimport GetNotified from \"components/sections/GetNotified\";\n\nfunction Customers() {\n const ref = useRef(null);\n\n const onClickComing = () => {\n ref.current.scrollIntoView({ behavior: 'smooth', block: 'start' });\n };\n return (\n <CustomersContainer>\n <CustomerHeader onClickComing={onClickComing} />\n <HowToFeasttt />\n <Download />\n <DineOut />\n <div ref={ref}>\n <GetNotified isIn=\"customers\" />\n </div>\n </CustomersContainer>\n );\n}\n\nexport default Customers;\n","import { FeaturesLeft } from \"assets/images/restaurants\";\nimport styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const FeaturesContainer = styled.div`\n width: 100%;\n .features-wrapper {\n display: flex;\n justify-content: center;\n .features-card {\n width: 100%;\n background-color: ${colors.pink6};\n display: flex;\n .card-left {\n flex: 1;\n background: url(${FeaturesLeft});\n background-size: 100% auto;\n background-repeat: no-repeat;\n background-position: left;\n }\n .card-right {\n flex: 1;\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 150px 0;\n .features-content {\n width: 80%;\n h5.title {\n background-image: linear-gradient(102deg, #ed2626, #ff7878);\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: normal;\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n }\n h1.subtitle {\n background-image: linear-gradient(99deg, #ed2626, #ff7878);\n font-size: 80px !important;\n font-weight: bold;\n font-stretch: normal;\n font-style: normal;\n line-height: normal;\n letter-spacing: -1.92px;\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n margin-bottom: 60px;\n }\n .feature-item {\n img {\n width: 48px;\n }\n h6 {\n line-height: 1.6;\n color: ${colors.gray};\n white-space: nowrap;\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 0;\n .features-wrapper {\n .features-card {\n flex-direction: column-reverse;\n height: unset;\n .card-left {\n background: transparent;\n }\n .card-right {\n padding: 75px 15px;\n .features-content {\n margin-right: 0;\n width: 100%;\n h5.title {\n font-size: 20px !important;\n margin-bottom: 20px;\n text-align: center;\n }\n h1.subtitle {\n font-size: 32px !important;\n margin-bottom: 45px;\n text-align: left;\n letter-spacing: normal;\n }\n .feature-item {\n h6 {\n font-size: 14px !important;\n font-weight: bold;\n color: ${colors.gray};\n }\n img {\n width: 36px;\n }\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Col, Row } from \"antd\";\nimport {\n IconFeature1,\n IconFeature3,\n IconFeature4,\n IconFeature5,\n IconFeature6,\n IconFeature7,\n} from \"assets/images/icons\";\nimport { FeaturesMobile } from \"assets/images/restaurants\";\nimport React from \"react\";\nimport { Image } from \"react-bootstrap\";\nimport { FeaturesContainer } from \"./style\";\n\nconst features = [\n {\n icon: IconFeature7,\n title: \"Fast & Easy Customer Check-In\",\n },\n {\n icon: IconFeature5,\n title: \"Incoming Orders & Requests\",\n },\n {\n icon: IconFeature4,\n title: \"Menus & Add-Ons\",\n },\n {\n icon: IconFeature3,\n title: \"Tables & Availability\",\n },\n {\n icon: IconFeature6,\n title: \"Staff Accounts\",\n },\n {\n icon: IconFeature1,\n title: \"Web and Mobile Apps\",\n },\n];\nfunction Features() {\n return (\n <FeaturesContainer>\n <div className=\"d-flex flex-column\">\n <div className=\"features-wrapper\">\n <div className=\"features-card\">\n <div className=\"card-left\">\n <Image src={FeaturesMobile} className=\"d-md-none\" width=\"100%\" />\n </div>\n <div className=\"card-right\">\n <div className=\"features-content\">\n <h1 className=\"subtitle\">\n Everything you\n <br />\n need to manage\n <br />\n your restaurant.\n </h1>\n <Row\n gutter={[\n { xs: 0, lg: 0 },\n { xs: 22, lg: 30 },\n ]}\n >\n {features.map((_feature, _i) => (\n <Col key={_i} xs={24} md={24}>\n <div className=\"feature-item d-flex align-items-center\">\n <Image src={_feature.icon} />\n <h6 className=\"mb-0 ml-3\">{_feature.title}</h6>\n </div>\n </Col>\n ))}\n </Row>\n </div>\n </div>\n </div>\n </div>\n </div>\n </FeaturesContainer>\n );\n}\n\nexport default Features;\n","import { Col, Row } from \"antd\";\nimport React from \"react\";\nimport { Container, Image } from \"react-bootstrap\";\nimport { HowToFeastttContainer } from \"./style\";\nimport { IconFeasttt } from \"assets/images/icons\";\nimport {\n RestaurantHow1,\n RestaurantHow2,\n RestaurantHow3,\n} from \"assets/images/restaurants\";\n\nfunction HowToFeasttt() {\n return (\n <HowToFeastttContainer>\n <Container className=\"d-flex flex-column align-items-center\" fluid>\n <Image src={IconFeasttt} className=\"img-howto mx-auto mb-2\" />\n <h1 className=\"how-to-feasttt\">How to Feasttt.</h1>\n <div className=\"cards-wrapper\">\n <Row justify=\"center\" gutter={[{sm: 0, md: 100}, 40]}>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Customer arrives and checks in at your restaurant using a\n code.\n </h5>\n <Image src={RestaurantHow1} />\n </div>\n </Col>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Customer can invite guests, order, request refills, and more\n with a tap.\n </h5>\n <Image src={RestaurantHow2} />\n </div>\n </Col>\n <Col md={8} xs={24}>\n <div className=\"how-card\">\n <h5>\n Customer can pay, split the bill, and rate their feast at the\n end.\n </h5>\n <Image src={RestaurantHow3} />\n </div>\n </Col>\n </Row>\n </div>\n </Container>\n </HowToFeastttContainer>\n );\n}\n\nexport default HowToFeasttt;\n","import { BgRestaurantHeader } from \"assets/images/restaurants\";\nimport styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const RestaurantHeaderContainer = styled.header`\n width: 100%;\n min-height: 864px;\n background-color: ${colors.pink6};\n background-image: url(${BgRestaurantHeader});\n background-position: right;\n background-size: auto 100%;\n background-repeat: no-repeat;\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n .header-wrapper {\n position: relative;\n flex: 1;\n width: 100%;\n display: flex;\n .container {\n .header-left {\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n .header-description {\n font-size: 60px !important;\n margin-bottom: 50px;\n background-image: linear-gradient(119deg, #ed2626, #ff7878 100%);\n font-weight: bold;\n font-stretch: normal;\n font-style: normal;\n line-height: 1.33;\n letter-spacing: -1.44px;\n -webkit-background-clip: text;\n background-clip: text;\n -webkit-text-fill-color: transparent;\n span {\n font-weight: normal;\n }\n }\n .btn-get-the-app {\n width: 315px;\n height: 80px;\n font-size: 26px !important;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding-bottom: 0px;\n min-height: unset;\n background-image: unset;\n .header-wrapper {\n flex-direction: column;\n padding-top: 35px;\n .container {\n padding: 0;\n .header-left {\n padding: 50px 15px 0;\n .header-description {\n font-size: 40px !important;\n text-align: center;\n margin-bottom: 43px;\n margin-left: auto;\n margin-right: auto;\n }\n .btn-get-the-app {\n width: 100%;\n }\n }\n .img-wrapper {\n margin-top: 50px;\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { Col, Row } from \"antd\";\nimport { RestaurantHeaderMobile } from \"assets/images/restaurants\";\nimport React from \"react\";\nimport { Button, Container, Image } from \"react-bootstrap\";\nimport { RestaurantHeaderContainer } from \"./style\";\n\nfunction RestaurantHeader({ onClickLearn = () => {} }) {\n return (\n <RestaurantHeaderContainer className=\"animate__animated animate__fadeIn\">\n <div className=\"header-wrapper\">\n <Container className=\"my-auto\">\n <Row>\n <Col lg={10} xs={24}>\n <div className=\"header-left\">\n <h1 className=\"text-red header-description\">\n Boost your\n <br /> average order\n <br /> <span>with</span> Feasttt.\n </h1>\n <Button\n className=\"btn-get-the-app btn-red\"\n onClick={onClickLearn}\n >\n Learn how\n </Button>\n </div>\n </Col>\n <Col lg={14} xs={24} className=\"d-md-none\">\n <div className=\"img-wrapper\">\n <Image src={RestaurantHeaderMobile} width=\"100%\" />\n </div>\n </Col>\n </Row>\n </Container>\n </div>\n </RestaurantHeaderContainer>\n );\n}\n\nexport default RestaurantHeader;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nconst leftPadding = 120;\n\nexport const SectionSliderContainer = styled.div`\n width: 100%;\n padding: 200px 0 150px;\n .slider-wrapper {\n display: flex;\n justify-content: center;\n align-items: center;\n height: 700px;\n .carousel {\n width: 1580px;\n .carousel-indicators {\n bottom: unset;\n top: 120px;\n margin-left: ${leftPadding}px;\n justify-content: flex-start;\n align-items: center;\n li {\n width: 12px;\n height: 12px;\n margin: 0 10px;\n box-shadow: 3px 5px 31px 0 rgb(245 111 111 / 80%);\n background-color: ${(props) =>\n props.activeIndex === 0 ? colors.white : colors.red};\n border-radius: 50%;\n border-top: unset;\n border-bottom: unset;\n transition: all 0.5s ease;\n &:first-of-type {\n margin-left: 0;\n }\n &.active {\n width: 23px;\n height: 23px;\n }\n }\n }\n .carousel-control-prev,\n .carousel-control-next {\n width: fit-content;\n height: fit-content;\n top: unset;\n bottom: 120px;\n .icon-arrow {\n width: 50px;\n height: 50px;\n background: white;\n border-radius: 50px;\n color: red;\n display: flex;\n justify-content: center;\n align-items: center;\n box-shadow: 3px 5px 35px 0 rgba(245, 111, 111, 0.4);\n }\n }\n .carousel-control-prev {\n left: ${leftPadding}px;\n }\n .carousel-control-next {\n right: unset;\n left: ${leftPadding + 80}px;\n }\n .carousel-inner {\n .carousel-item {\n .slide-item {\n position: relative;\n height: 700px;\n padding: 50px 0;\n h1 {\n font-size: 80px !important;\n }\n .img-wrapper {\n position: absolute;\n right: 0;\n top: 0;\n width: 50%;\n display: flex;\n justify-content: flex-end;\n img {\n height: 700px;\n }\n }\n .slide-bg {\n border-radius: 50px;\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n /* box-shadow: 13px 15px 45px 0 rgba(245, 111, 111, 0.18); */\n .slide-left {\n width: 60%;\n padding-left: ${leftPadding}px;\n h1 {\n font-stretch: normal;\n font-style: normal;\n line-height: 1.13;\n letter-spacing: -1.92px;\n span {\n font-weight: normal;\n }\n }\n h6 {\n font-style: normal;\n line-height: 1.6;\n &.subtitle {\n color: ${colors.red};\n }\n }\n }\n .slide-right {\n width: 40%;\n position: relative;\n display: flex;\n align-items: center;\n }\n }\n &.slide1 {\n .slide-bg {\n background: linear-gradient(\n 90deg,\n rgba(237, 38, 38, 1) 0%,\n rgba(255, 127, 127, 1) 100%\n );\n .slide-left {\n h6 {\n color: ${colors.white};\n }\n }\n }\n }\n &.slide2 {\n .img-wrapper {\n justify-content: center;\n }\n .slide-bg {\n background: #fff3f3;\n .slide-left {\n color: ${colors.dark5};\n }\n }\n }\n &.slide3 {\n .slide-bg {\n background: #ededed;\n .slide-left {\n color: ${colors.dark5};\n }\n }\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) and (max-width: ${mixins.md}px) {\n padding: 60px 0;\n .slider-sm-wrapper {\n display: flex;\n justify-content: center;\n align-items: center;\n .carousel {\n width: 100%;\n .carousel-indicators {\n align-items: center;\n margin-bottom: 3em;\n li {\n width: 9px;\n height: 9px;\n margin-right: 8px;\n margin-left: 8px;\n border-top: 0;\n border-bottom: 0;\n border-radius: 50px;\n background-color: ${(props) =>\n props.activeIndex === 0 ? colors.white : colors.red};\n &.active {\n width: 17px;\n height: 17px;\n }\n &:first-of-type {\n /* margin-left: 10px; */\n }\n }\n }\n .carousel-control-prev,\n .carousel-control-next {\n width: fit-content;\n height: fit-content;\n top: unset;\n bottom: 120px;\n .icon-arrow {\n width: 35px;\n height: 35px;\n background: white;\n border-radius: 50px;\n color: red;\n display: flex;\n justify-content: center;\n align-items: center;\n box-shadow: 0 4px 15px 0 rgba(245, 111, 111, 0.2);\n svg {\n width: 10px;\n }\n }\n }\n .carousel-control-prev {\n left: calc(50% - 45px);\n bottom: 87px;\n }\n .carousel-control-next {\n left: calc(50% + 10px);\n bottom: 87px;\n }\n .carousel-inner {\n border-radius: 50px;\n .carousel-item {\n .slide-item {\n height: 780px;\n padding: 40px 15px;\n box-shadow: 13px 15px 45px 0 rgba(245, 111, 111, 0.18);\n h6 {\n color: white;\n opacity: 0.7;\n text-align: center;\n margin-bottom: 30px;\n max-width: 90%;\n margin-left: auto;\n margin-right: auto;\n }\n h3 {\n font-size: 32px !important;\n font-weight: bold;\n text-align: center;\n span {\n font-weight: normal;\n }\n }\n p {\n color: white;\n opacity: 0.7;\n font-weight: bold;\n line-height: 1.5;\n text-align: center;\n }\n .img-wrapper {\n top: unset;\n bottom: 0;\n width: 100%;\n display: flex;\n justify-content: center;\n margin-bottom: 5px;\n img {\n height: 348px;\n width: auto;\n }\n }\n &.slide1 {\n background-image: linear-gradient(to right, #ed2727, #fba1a1);\n .slide-bg {\n background: linear-gradient(\n 154deg,\n rgba(255, 127, 127, 0.53) 3%,\n #ff7f7f 24%,\n #fe7979 40%,\n #ee2c2c 63%,\n #ed2626 84%\n );\n .slide-left {\n h6 {\n color: ${colors.white};\n }\n }\n }\n }\n &.slide2 {\n background: ${colors.pink6};\n h6 {\n color: ${colors.red};\n }\n p {\n color: ${colors.dark5};\n }\n }\n &.slide3 {\n background: ${colors.pink6};\n h6 {\n color: ${colors.red};\n }\n p {\n color: ${colors.dark5};\n }\n }\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { SliderImg1, SliderImg2, SliderImg3 } from \"assets/images/restaurants\";\nimport React, { useState } from \"react\";\nimport { Carousel, Container, Image } from \"react-bootstrap\";\nimport { FaChevronLeft, FaChevronRight } from \"react-icons/fa\";\nimport { useInViewInit } from \"service\";\nimport { SectionSliderContainer } from \"./style\";\n\nfunction SectionSlider() {\n const [activeIndex, setActiveIndex] = useState(0);\n const inView = useInViewInit({\n rootMargin: \"-130px\",\n });\n\n const onSlide = (key, direction) => {\n setActiveIndex(key);\n };\n return (\n <div ref={inView.ref}>\n {inView.inView ? (\n <SectionSliderContainer activeIndex={activeIndex}>\n <Container className=\"d-flex flex-column\" fluid>\n <div className=\"slider-wrapper d-none d-md-flex\">\n <Carousel\n slide\n interval={inView.inView ? 4000 : null}\n onSlide={onSlide}\n nextIcon={\n <div className=\"icon-arrow\">\n <FaChevronRight size={25} />\n </div>\n }\n prevIcon={\n <div className=\"icon-arrow\">\n <FaChevronLeft className=\"icon-left\" size={25} />\n </div>\n }\n >\n <Carousel.Item>\n <div className=\"slide1 slide-item\">\n <div className=\"slide-bg\">\n <div className=\"slide-left\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <h1 className=\"text-white\">\n Customers order\n <br /> more <span>in app.</span>\n </h1>\n <h6 className=\"description\">\n Customers ordering through the app are more likely to\n add more items than they would ordering directly\n through a server.\n </h6>\n </div>\n <div className=\"slide-right\"></div>\n </div>\n <div className=\"img-wrapper\">\n <Image src={SliderImg1} />\n </div>\n </div>\n </Carousel.Item>\n <Carousel.Item>\n <div className=\"slide2 slide-item\">\n <div className=\"slide-bg\">\n <div className=\"slide-left\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <h1 className=\"text-red-gra\">\n Customizations\n <br /> <span>and</span> add-ons.\n </h1>\n <h6 className=\"description\">\n Offer your customers add-ons, side dishes, and other\n preferences so they can build an order that’s\n completely personalized to them.\n </h6>\n </div>\n <div className=\"slide-right\"></div>\n </div>\n <div className=\"img-wrapper\">\n <Image src={SliderImg2} height={700} />\n </div>\n </div>\n </Carousel.Item>\n <Carousel.Item>\n <div className=\"slide3 slide-item\">\n <div className=\"slide-bg\">\n <div className=\"slide-left\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <h1 className=\"text-red-gra\">\n Orders <span>and</span> refills <br /> on-demand.\n </h1>\n <h6 className=\"description\">\n Customers can continue adding to their order at any\n time throughout the dining experience without waiting\n for a server to come by.\n </h6>\n </div>\n <div className=\"slide-right\"></div>\n </div>\n <div className=\"img-wrapper\">\n <Image src={SliderImg3} height={700} />\n </div>\n </div>\n </Carousel.Item>\n </Carousel>\n </div>\n <div className=\"slider-sm-wrapper d-md-none\">\n <Carousel\n slide\n interval={4000}\n onSlide={onSlide}\n nextIcon={\n <div className=\"icon-arrow\">\n <FaChevronRight size={25} />\n </div>\n }\n prevIcon={\n <div className=\"icon-arrow\">\n <FaChevronLeft className=\"icon-left\" size={25} />\n </div>\n }\n >\n <Carousel.Item>\n <div className=\"slide1 slide-item\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <div className=\"img-wrapper\">\n <Image src={SliderImg1} />\n </div>\n <h3 className=\"text-white\">\n Customers order\n <br /> more <span>in app.</span>\n </h3>\n <p className=\"description\">\n Customers ordering through the app are more likely to add\n more items than they would ordering directly through a\n server.\n </p>\n </div>\n </Carousel.Item>\n <Carousel.Item>\n <div className=\"slide2 slide-item\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <div className=\"img-wrapper\">\n <Image src={SliderImg2} />\n </div>\n <h3 className=\"text-red-gra\">\n Customizations\n <br /> <span>and</span> add-ons.\n </h3>\n <p className=\"description\">\n Offer your customers add-ons, side dishes, and other\n preferences so they can build an order that’s completely\n personalized to them.\n </p>\n </div>\n </Carousel.Item>\n <Carousel.Item>\n <div className=\"slide3 slide-item\">\n <h6 className=\"subtitle\">\n How Feasttt boosts your average order.\n </h6>\n <div className=\"img-wrapper\">\n <Image src={SliderImg3} />\n </div>\n <h3 className=\"text-red-gra\">\n Orders <span>and</span> refills <br /> on-demand.\n </h3>\n <p className=\"description\">\n Customers can continue adding to their order at any time\n throughout the dining experience without waiting for a\n server to come by.\n </p>\n </div>\n </Carousel.Item>\n </Carousel>\n </div>\n </Container>\n </SectionSliderContainer>\n ) : (\n <div />\n )}\n </div>\n );\n}\n\nexport default SectionSlider;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const RestaurantsContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport Download from \"containers/Customers/Download\";\nimport React, { useRef } from \"react\";\nimport Features from \"./Features\";\nimport GetNotified from \"../../components/sections/GetNotified\";\nimport HowToFeasttt from \"./HowToFeasttt\";\nimport RestaurantHeader from \"./RestaurantHeader\";\nimport SectionSlider from \"./SectionSlider\";\nimport { RestaurantsContainer } from \"./style\";\n\nfunction Restaurants() {\n const ref = useRef(null);\n\n const onClickLearn = () => {\n ref.current.scrollIntoView({ behavior: \"smooth\", block: \"start\" });\n };\n\n return (\n <RestaurantsContainer>\n <RestaurantHeader onClickLearn={onClickLearn} />\n <div ref={ref}>\n <SectionSlider />\n </div>\n <HowToFeasttt />\n <Download />\n <Features />\n <GetNotified isIn=\"restaurants\" />\n </RestaurantsContainer>\n );\n}\n\nexport default Restaurants;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const BlogContainer = styled.header`\n position: relative;\n width: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n align-items: center;\n .blog-overlay {\n padding-top: 100px;\n padding-bottom: 100px;\n .container {\n .all-posts {\n font-size: 32px !important;\n color: #989898;\n font-weight: 600;\n margin-top: 100px;\n margin-bottom: 40px;\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n .blog-overlay {\n padding-top: 0;\n .container.featured {\n padding: 0;\n }\n .container {\n .all-posts {\n margin-top: 60px;\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n\nexport const FeaturedContainer = styled.div`\n background: url(${(props) => props.bg});\n background-repeat: no-repeat;\n background-size: cover;\n .featured-content {\n /* position: absolute; */\n width: 100%;\n height: 100%;\n top: 0;\n padding: 30px;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n min-height: 590px;\n background-repeat: no-repeat;\n .featured-mark {\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: rgba(0, 0, 0, 0.5);\n border-radius: 21.5px;\n color: #fff;\n font-size: 18px;\n font-weight: 700;\n width: 151px;\n height: 43px;\n }\n .featured-description {\n color: ${colors.white};\n }\n }\n @media (max-width: ${mixins.md}px) {\n .featured-content {\n min-height: 400px;\n .featured-description {\n font-size: 36px !important;\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n\nexport const BlogCardContainer = styled.div`\n .blog-card-img {\n height: 200px;\n width: 100%;\n background: url(${(props) => props.blogImg});\n background-size: cover;\n background-repeat: no-repeat;\n }\n h3 {\n font-size: 28px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: 1.29;\n letter-spacing: -0.67px;\n margin-top: 30px;\n }\n @media (max-width: ${mixins.md}px) {\n margin-bottom: 50px;\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { Col, Row, Skeleton } from \"antd\";\nimport React, { Fragment, useEffect, useState } from \"react\";\nimport { Container } from \"react-bootstrap\";\nimport { useHistory } from \"react-router\";\nimport { Link } from \"react-router-dom\";\nimport { BlogContainer, FeaturedContainer, BlogCardContainer } from \"./style\";\n\nfunction Blog() {\n const history = useHistory();\n const [isLoading, setIsLoading] = useState(true);\n const [blogs, setBlogs] = useState([]);\n\n const getBlogs = () => {\n setIsLoading(true);\n fetch(`${window.location.origin}/posts.json`).then((response) => {\n response.json().then((posts) => {\n setBlogs(posts);\n setTimeout(() => setIsLoading(false), 1000);\n });\n });\n };\n\n useEffect(() => {\n getBlogs();\n }, [history.location.pathname]);\n\n return (\n <BlogContainer>\n <div className=\"blog-overlay w-100\">\n <Container className=\"featured\">\n {isLoading ? (\n <Fragment>\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n </Fragment>\n ) : (\n <Row>\n <FeaturedContainer\n className=\"featured-blog w-100\"\n bg={blogs[0].featured_media_url}\n >\n <div className=\"featured-content\">\n <h6 className=\"featured-mark\">FEATURED</h6>\n <h1 className=\"featured-description\">\n <div\n dangerouslySetInnerHTML={{\n __html: blogs[0]?.title?.rendered,\n }}\n />\n </h1>\n </div>\n </FeaturedContainer>\n </Row>\n )}\n </Container>\n <Container className=\"posts-container\">\n {isLoading ? (\n <Fragment>\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n </Fragment>\n ) : (\n <Fragment>\n <h3 className=\"all-posts\">All posts</h3>\n <Row gutter={[{sm: 0, md: 80}, 80]}>\n {blogs.map((_blog, _i) => (\n <Col key={_i} lg={8} md={12} sm={24} xs={24}>\n <Link to={`/blog-detail/${_blog.id}`}>\n <BlogCardContainer\n className=\"blog-card\"\n blogImg={_blog.featured_media_url}\n >\n <div className=\"blog-card-img\" />\n <h3>\n <div\n dangerouslySetInnerHTML={{\n __html: _blog?.title?.rendered,\n }}\n />\n </h3>\n </BlogCardContainer>\n </Link>\n </Col>\n ))}\n </Row>\n </Fragment>\n )}\n </Container>\n </div>\n </BlogContainer>\n );\n}\n\nexport default Blog;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const BlogDetailContainer = styled.header`\n position: relative;\n width: 100%;\n background-color: ${colors.white};\n display: flex;\n align-items: center;\n .detail-overlay {\n padding-top: 50px;\n padding-bottom: 100px;\n .container {\n .detail-navigation {\n color: ${colors.gray};\n font-size: 20px !important;\n margin-bottom: 30px;\n a,\n i {\n text-decoration: none;\n color: #989898;\n }\n i {\n margin: 0 5px;\n }\n }\n .detail-navigation-mobile {\n display: none;\n }\n .item-content {\n h1 {\n font-size: 60px !important;\n }\n h1.item-title {\n margin-bottom: 60px;\n margin-top: 80px;\n }\n h2 {\n font-size: 36px !important;\n }\n p {\n font-size: 24px !important;\n }\n ul li {\n font-size: 24px !important;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n .detail-overlay {\n padding-top: 30px;\n padding-bottom: 60px;\n .container {\n &.img-container {\n padding: 0;\n }\n .detail-navigation {\n display: none;\n }\n .detail-navigation-mobile {\n display: initial;\n padding-left: 25px;\n a {\n font-size: 16px !important;\n color: #989898;\n }\n }\n .item-content {\n margin-top: 20px;\n h1.item-title {\n margin-bottom: 40px;\n margin-top: 40px;\n font-size: 36px !important;\n }\n p, ul li {\n font-size: 19px !important;\n }\n h2 {\n font-size: 30px !important;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n\nexport const RecommendsContainer = styled.div`\n background: #f6f6f6;\n width: 100%;\n height: 772px;\n display: flex;\n align-items: center;\n h3.recommend-title {\n color: #989898;\n font-size: 32px !important;\n font-weight: 600;\n font-stretch: normal;\n font-style: normal;\n line-height: 0.94;\n letter-spacing: -0.77px;\n margin-bottom: 30px;\n }\n @media (max-width: ${mixins.md}px) {\n height: unset;\n padding: 60px 0;\n }\n`;\n","/* eslint-disable eqeqeq */\n/* eslint-disable react-hooks/exhaustive-deps */\nimport { Col, Row, Skeleton, Space } from \"antd\";\nimport { BlogCardContainer } from \"containers/Blog/style\";\nimport React, { Fragment, useEffect, useState } from \"react\";\nimport { Container, Image } from \"react-bootstrap\";\nimport { FaFacebook, FaLink, FaPinterest, FaTwitter } from \"react-icons/fa\";\nimport { useHistory, useParams } from \"react-router\";\nimport { Link } from \"react-router-dom\";\nimport { colors } from \"theme\";\nimport { BlogDetailContainer, RecommendsContainer } from \"./style\";\n\nfunction BlogDetail() {\n const history = useHistory();\n const { id } = useParams();\n const [isLoading, setIsLoading] = useState(true);\n const [recommends, setRecommends] = useState([]);\n const [detail, setDetail] = useState({});\n\n const getBlogDetail = () => {\n setIsLoading(true);\n fetch(`${window.location.origin}/posts.json`).then((response) => {\n response.json().then((posts) => {\n setRecommends(posts.filter((_post, _i) => _i < 3));\n setDetail(posts.find((_post) => _post.id == id));\n setTimeout(() => setIsLoading(false), 1000);\n });\n });\n };\n\n useEffect(() => {\n getBlogDetail();\n }, [history.location.pathname]);\n\n return (\n <Fragment>\n <BlogDetailContainer>\n <div className=\"detail-overlay w-100\">\n {isLoading ? (\n <Container>\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n </Container>\n ) : (\n <Fragment>\n <Container className=\"img-container\">\n <div className=\"detail-navigation\">\n <Link to=\"/blog\">Blog</Link>{\" \"}\n <i className=\"fas fa-angle-right\" /> {detail.title.rendered}\n </div>\n <div className=\"detail-navigation-mobile\">\n <Link to=\"/blog\">\n <i className=\"fas fa-angle-left\" /> Back to the Blog\n </Link>\n </div>\n <Image\n src={detail.featured_media_url}\n className=\"mt-3\"\n width=\"100%\"\n />\n </Container>\n <Container>\n <div className=\"item-content\">\n <h1 className=\"item-title\">\n <div\n dangerouslySetInnerHTML={{\n __html: detail?.title?.rendered,\n }}\n />\n </h1>\n <div\n className=\"main-content-body\"\n dangerouslySetInnerHTML={{\n __html: detail?.content?.rendered,\n }}\n />\n <Space size={30} className=\"group-social\">\n <FaTwitter\n size={24}\n color={colors.dark5}\n className=\"icon-social\"\n />\n <FaFacebook\n size={24}\n color={colors.dark5}\n className=\"icon-social\"\n />\n <FaPinterest\n size={24}\n color={colors.dark5}\n className=\"icon-social\"\n />\n <FaLink\n size={24}\n color={colors.dark5}\n className=\"icon-social\"\n />\n </Space>\n </div>\n </Container>\n </Fragment>\n )}\n </div>\n </BlogDetailContainer>\n <RecommendsContainer className=\"recommend-section\">\n {isLoading ? (\n <div>Loading...</div>\n ) : (\n <Container>\n <h3 className=\"recommend-title\">Recommended for you.</h3>\n <Row gutter={80}>\n {recommends.map((_blog, _i) => (\n <Col key={_i} md={8}>\n <Link to={`/blog-detail/${_blog.id}`}>\n <BlogCardContainer\n className=\"blog-card\"\n blogImg={_blog.featured_media_url}\n >\n <div className=\"blog-card-img\" />\n <h3>\n <div\n dangerouslySetInnerHTML={{\n __html: _blog?.title?.rendered,\n }}\n />\n </h3>\n </BlogCardContainer>\n </Link>\n </Col>\n ))}\n </Row>\n </Container>\n )}\n </RecommendsContainer>\n </Fragment>\n );\n}\n\nexport default BlogDetail;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const CareersContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n background-image: linear-gradient(\n 117deg,\n rgba(0, 0, 0, 0),\n rgba(0, 0, 0, 0.1) 100%\n );\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { CareersHero } from \"assets/images\";\nimport styled from \"styled-components\";\nimport { mixins } from \"theme\";\n\nexport const CareersHeaderContainer = styled.header`\n padding-top: 0 !important;\n position: relative;\n width: 100%;\n /* background-image: url(${CareersHero}); */\n background-size: 100% auto;\n background-repeat: no-repeat;\n background-position: bottom;\n display: flex;\n justify-content: center;\n align-items: flex-end;\n .hero-img {\n width: 100%;\n min-width: 100%;\n min-height: 400px;\n }\n .content-wrapper {\n position: absolute;\n width: 100%;\n bottom: 22%;\n .header-content {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n h1 {\n font-size: 70px !important;\n }\n h5 {\n margin-bottom: 0;\n word-break: keep-all;\n }\n }\n }\n @media (max-width: 1000px) {\n .hero-img {\n min-width: unset;\n min-height: 400px;\n max-height: 400px;\n }\n .content-wrapper {\n .header-content {\n h1 {\n font-size: 45px !important;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n justify-content: center;\n .hero-img {\n width: 100%;\n min-height: unset;\n max-height: unset;\n }\n .content-wrapper {\n bottom: 55%;\n .header-content {\n align-items: flex-start;\n h1 {\n font-size: 32px !important;\n }\n h5 {\n font-size: 20px !important;\n width: 80%;\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { CareersHero, CareersHeroMobile } from \"assets/images\";\nimport React from \"react\";\nimport { Container, Image } from \"react-bootstrap\";\nimport { mixins } from \"theme\";\nimport useMediaQuery from \"use-mediaquery\";\nimport { CareersHeaderContainer } from \"./style\";\n\nfunction CareersHeader() {\n const isMobile = useMediaQuery(`(max-width: ${mixins.md}px)`);\n\n return (\n <CareersHeaderContainer>\n <Image\n src={isMobile ? CareersHeroMobile : CareersHero}\n className=\"hero-img\"\n />\n <div className=\"content-wrapper\">\n <Container>\n <div className=\"header-content\">\n <h1 className=\"text-white\">Careers</h1>\n <h5 className=\"text-white\">\n Join the fast-growing <br className='d-md-none' /> Feasttt team.\n </h5>\n </div>\n </Container>\n </div>\n </CareersHeaderContainer>\n );\n}\n\nexport default CareersHeader;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const OpenPositionsContainer = styled.div`\n width: 100%;\n padding: 200px 0;\n .open-left {\n h1 {\n font-size: 90px !important;\n color: ${colors.red};\n line-height: 1.11;\n letter-spacing: -2.16px;\n }\n }\n .open-right {\n .position-item {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 26px 43px 23px;\n border-bottom: solid 1px #c5c5c5;\n &:last-child {\n border-bottom: none;\n }\n .position-right {\n h6 {\n color: ${colors.red};\n font-weight: bold;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 50px 0;\n .open-left {\n h1 {\n font-size: 45px !important;\n }\n }\n .open-right {\n .position-item {\n padding: 26px 0px 23px;\n }\n h6 {\n font-size: 18px !important;\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Col, Row, Skeleton } from \"antd\";\nimport React, { Fragment, useEffect, useState } from \"react\";\nimport { Container } from \"react-bootstrap\";\nimport { useHistory } from \"react-router\";\nimport { Link } from \"react-router-dom\";\nimport { OpenPositionsContainer } from \"./style\";\n\nfunction OpenPositions() {\n const history = useHistory();\n const [isLoading, setIsLoading] = useState(true);\n const [openPositions, setOpenPositions] = useState([]);\n\n const getOpenPositions = () => {\n setIsLoading(true);\n fetch(`${window.location.origin}/open-positions.json`).then((response) => {\n response.json().then((posts) => {\n setOpenPositions(posts);\n setTimeout(() => setIsLoading(false), 1000);\n });\n });\n };\n\n useEffect(() => {\n getOpenPositions();\n }, [history.location.pathname]);\n\n return (\n <OpenPositionsContainer>\n <Container className=\"d-flex flex-column\">\n {isLoading ? (\n <Fragment>\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n </Fragment>\n ) : (\n <Row justify=\"center\" gutter={[30, 40]}>\n <Col lg={12} md={24} xs={24}>\n <div className=\"open-left\">\n <h1>\n Open <br />\n positions.\n </h1>\n </div>\n </Col>\n <Col lg={12} md={24} xs={24}>\n <div className=\"open-right\">\n {openPositions.length > 0 &&\n openPositions.map((_position, _i) => {\n return (\n <div key={_i} className=\"position-item\">\n <div className=\"position-left\">\n <h6 className=\"text-bold\">{_position.name}</h6>\n <h6 className=\"mb-0\">{_position.location}</h6>\n </div>\n <div className=\"position-right\">\n <Link key={_i} to={`/careers/${_position.id}`}>\n <h6 className=\"mb-0\">\n View <i className=\"fas fa-angle-right\" />\n </h6>\n </Link>\n </div>\n </div>\n );\n })}\n </div>\n </Col>\n </Row>\n )}\n </Container>\n </OpenPositionsContainer>\n );\n}\n\nexport default OpenPositions;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport React from \"react\";\nimport { CareersContainer } from \"./style\";\nimport CareersHeader from \"./CareersHeader\";\nimport OpenPositions from \"./OpenPositions\";\n\nfunction Careers() {\n return (\n <CareersContainer>\n <CareersHeader />\n <OpenPositions />\n </CareersContainer>\n );\n}\n\nexport default Careers;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const CareerDetailContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const ApplyJobContainer = styled.div`\n width: 100%;\n padding: 200px 0;\n background-image: linear-gradient(\n 117deg,\n rgba(0, 0, 0, 0),\n rgba(0, 0, 0, 0.1) 100%\n );\n .container {\n display: flex;\n align-items: flex-start;\n .apply-left {\n width: 40%;\n h1 {\n font-size: 90px !important;\n line-height: 1.11;\n letter-spacing: -2.16px;\n }\n }\n .apply-right {\n width: 60%;\n .ant-col {\n label {\n opacity: 0.5;\n font-family: Montserrat;\n font-size: 14px !important;\n font-weight: 500;\n font-stretch: normal;\n font-style: normal;\n line-height: 2.14;\n letter-spacing: -0.34px;\n color: ${colors.gray};\n }\n }\n .btns-wrapper {\n display: flex;\n justify-content: space-between;\n align-items: center;\n .btn {\n width: 300px;\n height: 50px;\n }\n }\n .file-upload {\n width: 100%;\n border-radius: 4px;\n .ant-upload {\n &.ant-upload-drag {\n background: #f3f3f3;\n border: 1px dashed #d4d4d4;\n border-radius: 8px;\n &:hover {\n border: 1px dashed ${colors.green};\n }\n }\n .ant-upload-btn {\n padding: 0;\n .uploader-container {\n width: 100%;\n height: 152px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n .uploader-icon {\n width: 100%;\n margin-bottom: 10px;\n i {\n font-size: 20px;\n }\n }\n p {\n font-size: 14px;\n }\n span {\n font-size: 12px;\n /* opacity: 0.4; */\n &.ant-spin-dot {\n opacity: 1;\n font-size: 36px;\n }\n }\n }\n }\n }\n .ant-upload-list {\n .ant-upload-list-text-container {\n .ant-upload-list-item {\n height: 50px;\n .ant-upload-list-item-info {\n padding: 0 20px;\n .ant-upload-list-item-name {\n opacity: 0.7;\n font-family: Montserrat;\n font-size: 14px;\n font-weight: 500;\n font-stretch: normal;\n font-style: normal;\n line-height: 2.14;\n letter-spacing: -0.34px;\n color: #191919;\n }\n }\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 50px 0;\n .container {\n flex-direction: column;\n .apply-left {\n width: 100%;\n h1 {\n font-size: 45px !important;\n line-height: 1.22;\n letter-spacing: -1.08px;\n margin-bottom: 50px;\n }\n }\n .apply-right {\n width: 100%;\n .btns-wrapper {\n flex-direction: column;\n margin-top: 30px;\n .ant-row {\n width: 100%;\n .btn {\n width: 100%;\n margin-top: 30px;\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import { Input } from \"antd\";\nimport styled from \"styled-components\";\nimport { mixins } from \"theme\";\n\nexport const MyTextareaContainer = styled(Input.TextArea)`\n width: 100%;\n height: 50px;\n padding: 10px 10px 10px 18px;\n border-radius: 8px;\n background-color: #fafafa;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import React from \"react\";\nimport { MyTextareaContainer } from \"./style\";\n\nfunction MyTextarea({ className = \"\", placeholder = \"\", onChange = () => {} }) {\n return (\n <MyTextareaContainer\n className={className}\n placeholder={placeholder}\n rows={4}\n onChange={onChange}\n />\n );\n}\n\nexport default MyTextarea;\n","/* eslint-disable no-useless-escape */\n/* eslint-disable eqeqeq */\nimport { Col, Form, Row, Spin, Upload } from \"antd\";\nimport React, { useRef, useState } from \"react\";\nimport ReCAPTCHA from \"react-google-recaptcha\";\nimport { Button, Container } from \"react-bootstrap\";\nimport { ApplyJobContainer } from \"./style\";\nimport MyInput from \"components/Elements/MyInput\";\nimport MyPhoneInput from \"components/Elements/MyPhoneInput\";\nimport MyTextarea from \"components/Elements/MyTextarea\";\nimport { FaUpload } from \"react-icons/fa\";\nimport { recaptchasitekey, showNotification } from \"service\";\n\nconst { Dragger } = Upload;\n\nfunction ApplyJob({ detail = {} }) {\n const recaptchaRef = useRef();\n const [form] = Form.useForm();\n const [valReCaptcha, setValReCaptcha] = useState(\"\");\n const [uploading] = useState(false);\n const [uploadedFile, setUploadedFile] = useState(null)\n\n const onVerifyCaptcha = (value) => {\n setValReCaptcha(value);\n };\n\n const onFinishFailed = () => {\n showNotification(\n \"error\",\n \"Please complete the entire application before submitting.\"\n );\n };\n const onFinish = async (values) => {\n if (!valReCaptcha) {\n showNotification(\"error\", \"Please, verify captcha.\");\n return;\n }\n const formData = new FormData();\n formData.append(\"name\", values.full_name);\n formData.append(\"phone\", values.phone);\n formData.append(\"email\", values.email);\n formData.append(\"letter\", values.letter);\n formData.append(\"linkedin\", values.linkedin);\n formData.append(\"github\", values.github);\n formData.append(\"portfolioLink\", values.portfolioLink);\n formData.append(\"uploadedFile\", uploadedFile);\n formData.append(\"captchaResponse\", valReCaptcha);\n formData.append(\n \"positionName\",\n detail.name.replaceAll(/[`~!@#$%^&*()_|+\\-=?;:'\",.<>\\{\\}\\[\\]\\\\\\/]/gi, \"\")\n );\n const response = await fetch(\"https://code-room.com/careers2.php\", {\n method: \"POST\",\n body: formData,\n });\n const result = await response.json();\n if (result && result.status === \"ok\") {\n showNotification(\"success\", \"Thank you for submitting your application.\");\n } else {\n showNotification(\"error\", \"Error occurred. Please try again later.\");\n }\n recaptchaRef.current.reset();\n form.resetFields();\n };\n\n const normFile = (e) => {\n if (Array.isArray(e)) {\n return e;\n }\n return e && e.fileList;\n };\n\n const beforeUpload = (file) => {\n if (file.type !== \"image/png\") {\n showNotification(\"error\", `${file.name} is not a png file`);\n return false;\n } else {\n setUploadedFile(file);\n // const reader = new FileReader();\n // // reader.readAsDataURL(file);\n // reader.readAsText(file);\n // reader.onload = async (e) => {};\n // return false;\n }\n return false;\n };\n return (\n <ApplyJobContainer id=\"applyJob\">\n <Container>\n <div className=\"apply-left\">\n <h1 className=\"text-red-gra\">\n Apply <br />\n for job.\n </h1>\n </div>\n <div className=\"apply-right\">\n <Form\n className=\"header-right\"\n layout=\"vertical\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={onFinishFailed}\n >\n <Row\n gutter={[\n { lg: 48, xs: 0 },\n { lg: 24, xs: 0 },\n ]}\n >\n <Col xs={24} md={12}>\n <Form.Item\n name=\"full_name\"\n label=\"Full Name\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your full name\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={12}>\n <Form.Item\n name=\"email\"\n label=\"Email\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n {\n type: \"email\",\n message: \"Invalid Email!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your e-mail\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={12}>\n <Form.Item\n name=\"phone\"\n label=\"Phone\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyPhoneInput type=\"form\" placeholder=\"Enter your phone number\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={12}>\n <Form.Item\n name=\"linkedin\"\n label=\"LinkedIn Profile (if any)\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your Linkedin URL\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={12}>\n <Form.Item\n name=\"github\"\n label=\"Github Profile (if any)\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your Github URL\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={12}>\n <Form.Item\n name=\"portfolioLink\"\n label=\"Portfolio Link (if any)\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your Portfolio URL\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={24}>\n <Form.Item\n name=\"letter\"\n label=\"Cover Letter\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n >\n <MyTextarea placeholder=\"Write your cover letter here…\" />\n </Form.Item>\n </Col>\n <Col xs={24} md={24}>\n <div className=\"file-upload\">\n <Form.Item\n name=\"files\"\n valuePropName=\"fileList\"\n getValueFromEvent={normFile}\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n >\n <Dragger\n name=\"files\"\n multiple={false}\n listType=\"text\"\n // previewFile={false}\n beforeUpload={beforeUpload}\n // fileList={false}\n >\n <div className=\"uploader-container\">\n {uploading ? (\n <Spin size=\"large\" />\n ) : (\n <>\n <div className=\"uploader-icon d-flex justify-content-center align-items-center\">\n <FaUpload />\n <span className=\"text-red ml-2\">\n Upload Files\n </span>\n </div>\n <p className=\"text-blue mb-0\">\n You can upload doc, docx or pdf\n </p>\n </>\n )}\n </div>\n </Dragger>\n </Form.Item>\n </div>\n </Col>\n <Col xs={24} md={24}>\n <div className=\"btns-wrapper\">\n <ReCAPTCHA\n ref={recaptchaRef}\n sitekey={recaptchasitekey}\n onChange={onVerifyCaptcha}\n onExpired={() => setValReCaptcha(\"\")}\n />\n <Form.Item>\n <Button type=\"submit\" className=\"btn-red\">\n Submit\n </Button>\n </Form.Item>\n </div>\n </Col>\n </Row>\n </Form>\n </div>\n </Container>\n </ApplyJobContainer>\n );\n}\n\nexport default ApplyJob;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const CareerContentContainer = styled.div`\n width: 100%;\n padding: 140px 0;\n .detail-wrapper {\n max-width: 1140px;\n margin: auto;\n .detail-navigation {\n color: ${colors.gray};\n font-size: 20px !important;\n margin-bottom: 50px;\n a,\n i {\n text-decoration: none;\n color: #989898;\n }\n i {\n margin: 0 5px;\n }\n }\n .detail-navigation-mobile {\n display: none;\n }\n .job-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n border-top: solid 1px ${colors.gray};\n border-bottom: solid 1px ${colors.gray};\n padding: 40px 0;\n margin-bottom: 40px;\n .left-part {\n h3 {\n margin: 0;\n font-size: 60px !important;\n font-weight: 900;\n color: ${colors.red};\n }\n }\n .right-part {\n h6 {\n display: none;\n }\n .apply-button {\n cursor: pointer;\n display: flex;\n justify-content: center;\n align-items: center;\n text-decoration: none;\n\n width: 200px;\n height: 50px;\n border-radius: 100px;\n background-color: ${colors.red};\n\n font-size: 18px !important;\n font-weight: 600;\n color: #ffffff;\n\n border: none;\n }\n }\n }\n .job-body {\n display: flex;\n align-items: baseline;\n\n .left-part {\n flex: 1 1 60%;\n h6 {\n margin: 0;\n margin-bottom: 30px;\n font-size: 24px !important;\n font-weight: 600;\n color: rgba(21, 21, 21, 0.5);\n }\n p {\n margin: 0;\n font-size: 24px !important;\n color: ${colors.gray};\n margin-bottom: 50px;\n }\n h4 {\n margin: 0;\n color: ${colors.red};\n font-size: 40px !important;\n font-weight: 900;\n margin-bottom: 30px;\n }\n ul {\n padding-left: 20px;\n list-style: disc;\n margin-bottom: 50px;\n li {\n position: relative;\n margin-bottom: 20px;\n font-size: 24px !important;\n color: rgba(21, 21, 21, 1);\n &::marker {\n color: ${colors.red};\n }\n }\n li::before {\n content: \"\";\n position: absolute;\n color: ${colors.red};\n font-size: 50px !important;\n font-weight: bold;\n display: inline-block;\n top: -20px;\n width: 1em;\n margin-left: -1em;\n }\n }\n }\n .right-part {\n flex: 1 1 40%;\n padding-left: 100px;\n .description-block {\n margin-bottom: 25px;\n b {\n font-size: 24px !important;\n }\n p {\n font-size: 24px !important;\n color: ${colors.gray};\n margin: 0;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n padding: 50px 0;\n .detail-wrapper {\n .detail-navigation {\n display: none;\n }\n .detail-navigation-mobile {\n display: initial;\n a {\n font-size: 16px !important;\n color: #989898;\n }\n }\n .job-header {\n border-top: none;\n border-bottom: none;\n padding: 30px 0;\n margin-bottom: 0px;\n flex-direction: column;\n .left-part {\n h3 {\n font-size: 32px !important;\n }\n }\n .right-part {\n // display: none;\n width: 100%;\n padding-top: 20px;\n h6 {\n display: initial;\n font-size: 16px !important;\n font-weight: 600;\n color: rgba(21, 21, 21, 0.5);\n }\n .apply-button {\n width: 100%;\n height: 40px;\n font-size: 16px !important;\n margin-top: 40px;\n }\n }\n }\n\n .job-body {\n flex-direction: column-reverse;\n padding-top: 30px;\n .right-part {\n padding-left: 0;\n padding-bottom: 40px;\n .description-block {\n b,\n p {\n font-size: 16px !important;\n }\n }\n }\n\n .left-part {\n h6 {\n display: none;\n font-size: 16px !important;\n margin-bottom: 20px;\n }\n p {\n font-size: 16px !important;\n margin-bottom: 60px;\n }\n ul {\n margin-bottom: 60px;\n padding-left: 20px;\n list-style: disc;\n li {\n font-size: 16px !important;\n margin-bottom: 15px;\n }\n li:before {\n content: \"\";\n position: absolute;\n color: #ed2626;\n font-size: 30px !important;\n font-weight: bold;\n display: inline-block;\n top: -12px;\n width: 1em;\n margin-left: -20px;\n }\n }\n h4 {\n font-size: 18px !important;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\n/* eslint-disable eqeqeq */\nimport { Skeleton } from \"antd\";\nimport React, { Fragment } from \"react\";\nimport { Container } from \"react-bootstrap\";\nimport { Link } from \"react-router-dom\";\nimport { CareerContentContainer } from \"./style\";\n\nfunction CareerContent({ detail, isLoading = true }) {\n return (\n <CareerContentContainer>\n <Container className=\"d-flex flex-column\">\n {isLoading ? (\n <Fragment>\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n <Skeleton active />\n </Fragment>\n ) : (\n <div className=\"detail-wrapper\">\n <div className=\"detail-navigation\">\n <Link to=\"/careers\">Careers</Link>{\" \"}\n <i className=\"fas fa-angle-right\" /> {detail.name}\n </div>\n\n <div className=\"detail-navigation-mobile\">\n <Link to=\"/careers\">\n <i className=\"fas fa-angle-left\" /> Back to the Careers\n </Link>\n </div>\n\n <div className=\"job-header\">\n <div className=\"left-part\">\n <h3>{detail.name}</h3>\n </div>\n <div className=\"right-part\">\n <h6>{detail.location}</h6>\n <a href=\"#applyJob\" className=\"apply-button btn btn-red\">\n Apply\n </a>\n </div>\n </div>\n <div className=\"job-body\">\n <div className=\"left-part\">\n <h6 className=\"text-bold\">{detail.location}</h6>\n <p>{detail.foreword}</p>\n\n <h4>What you’ll do</h4>\n <ul>\n {detail.expectations &&\n detail.expectations.map((_expectation, _i) => {\n return <li key={_i}>{_expectation}</li>;\n })}\n </ul>\n\n <h4>We offer</h4>\n <ul>\n {detail.offer &&\n detail.offer.map((_propos, _i) => {\n return <li key={_i}>{_propos}</li>;\n })}\n </ul>\n </div>\n <div className=\"right-part\">\n <div className=\"description-block\">\n <b>Seniority Level</b>\n <p>{detail.requestedLevel}</p>\n </div>\n <div className=\"description-block\">\n <b>Industry</b>\n <p>{detail.industry}</p>\n </div>\n <div className=\"description-block\">\n <b>Employment Type</b>\n <p>{detail.employmentType}</p>\n </div>\n </div>\n </div>\n </div>\n )}\n </Container>\n </CareerContentContainer>\n );\n}\n\nexport default CareerContent;\n","/* eslint-disable eqeqeq */\n/* eslint-disable react-hooks/exhaustive-deps */\nimport React, { useEffect, useState } from \"react\";\nimport { CareerDetailContainer } from \"./style\";\nimport ApplyJob from \"./ApplyJob\";\nimport CareersHeader from \"containers/Careers/CareersHeader\";\nimport CareerContent from \"./CareerContent\";\nimport { useHistory, useParams } from \"react-router\";\n\nfunction CareerDetail() {\n const history = useHistory();\n const { id } = useParams();\n const [isLoading, setIsLoading] = useState(true);\n const [detail, setDetail] = useState({});\n\n const getOpenPositions = () => {\n setIsLoading(true);\n fetch(`${window.location.origin}/open-positions.json`).then((response) => {\n response.json().then((posts) => {\n setDetail(posts.find((_post) => _post.id == id));\n setTimeout(() => setIsLoading(false), 1000);\n });\n });\n };\n\n useEffect(() => {\n getOpenPositions();\n }, [history.location.pathname]);\n\n return (\n <CareerDetailContainer>\n <CareersHeader />\n <CareerContent detail={detail} isLoading={isLoading} />\n <ApplyJob detail={detail} />\n </CareerDetailContainer>\n );\n}\n\nexport default CareerDetail;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const ContactContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n display: flex;\n flex-direction: column;\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const ContactHeaderContainer = styled.header`\n width: 100%;\n display: flex;\n align-items: center;\n background-image: linear-gradient(\n 117deg,\n rgba(0, 0, 0, 0),\n rgba(0, 0, 0, 0.3) 100%\n );\n .header-content {\n padding: 200px 0;\n .header-left {\n h1 {\n font-size: 90px !important;\n line-height: 1.11;\n letter-spacing: -2.16px;\n }\n }\n .header-right {\n .btns-wrapper {\n display: flex;\n justify-content: space-between;\n align-items: center;\n .btn {\n width: 300px;\n height: 50px;\n }\n }\n .ant-col {\n label {\n opacity: 0.5;\n font-family: Montserrat;\n font-size: 14px !important;\n font-weight: 500;\n font-stretch: normal;\n font-style: normal;\n line-height: 2.14;\n letter-spacing: -0.34px;\n color: ${colors.gray};\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n max-height: unset;\n flex-direction: column;\n background-size: 100%;\n background-position: top;\n .header-content {\n padding: 45px 0;\n .header-left {\n margin-bottom: 40px;\n h1 {\n font-size: 45px !important;\n }\n h6 {\n font-size: 16px !important;\n }\n }\n .header-right {\n .btns-wrapper {\n flex-direction: column;\n margin-top: 30px;\n .ant-row {\n width: 100%;\n .btn {\n width: 100%;\n margin-top: 30px;\n }\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { Col, Form, Row } from \"antd\";\nimport ReCAPTCHA from \"react-google-recaptcha\";\nimport MyInput from \"components/Elements/MyInput\";\nimport MyPhoneInput from \"components/Elements/MyPhoneInput\";\nimport MyTextarea from \"components/Elements/MyTextarea\";\nimport React, { useRef, useState } from \"react\";\nimport { Button, Container } from \"react-bootstrap\";\nimport { ContactHeaderContainer } from \"./style\";\nimport { recaptchasitekey, showNotification } from \"service\";\n\nfunction ContactHeader() {\n const recaptchaRef = useRef();\n const [form] = Form.useForm();\n const [valReCaptcha, setValReCaptcha] = useState(\"\");\n\n const formItemLayout = null;\n const onVerifyCaptcha = (value) => {\n setValReCaptcha(value);\n };\n\n const onFinishFailed = ({ values, errorFields, outOfDate }) => {\n showNotification('error', errorFields[0].errors[0])\n };\n\n const onFinish = async (values) => {\n if (!valReCaptcha) {\n showNotification(\"error\", \"Please, verify captcha.\");\n return;\n }\n const formData = new FormData();\n formData.append(\"name\", values.full_name);\n formData.append(\"phone\", values.phone);\n formData.append(\"email\", values.email);\n formData.append(\"thoughts\", values.thoughts);\n formData.append(\"captchaResponse\", valReCaptcha);\n const response = await fetch(\"https://code-room.com/contact2.php\", {\n method: \"POST\",\n body: formData,\n });\n const result = await response.json();\n if (result && result.status === 'ok') {\n showNotification('success', 'We’ve got your thoughts. We’ll contact you soon! ')\n } else {\n showNotification('error', 'Error occurred. Please try again later.')\n }\n recaptchaRef.current.reset();\n form.resetFields();\n };\n\n return (\n <ContactHeaderContainer>\n <Container>\n <div className=\"header-content\">\n <Row>\n <Col xs={24} md={10}>\n <div className=\"header-left\">\n <h1 className=\"text-red\">\n Get in\n <br className=\"d-none d-md-block\" /> touch.\n </h1>\n <h6>Typically replies within 24 hours.</h6>\n </div>\n </Col>\n <Col xs={24} md={14}>\n <Form\n {...formItemLayout}\n className=\"header-right\"\n layout=\"vertical\"\n form={form}\n onFinish={onFinish}\n onFinishFailed={onFinishFailed}\n >\n <Form.Item\n name=\"full_name\"\n label=\"Full Name\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Share your full name\" />\n </Form.Item>\n <Form.Item\n name=\"phone\"\n label=\"Phone\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n hasFeedback\n >\n <MyPhoneInput type=\"form\" placeholder=\"Enter your phone number\" />\n </Form.Item>\n <Form.Item\n name=\"email\"\n label=\"Email\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n {\n type: \"email\",\n message: \"Invalid Email!\",\n },\n ]}\n hasFeedback\n >\n <MyInput placeholder=\"Enter your e-mail\" />\n </Form.Item>\n <Form.Item\n name=\"thoughts\"\n label=\"Your thoughts\"\n rules={[\n {\n required: true,\n message: \"Required Field!\",\n },\n ]}\n >\n <MyTextarea placeholder=\"Share your thoughts here…\" />\n </Form.Item>\n <div className=\"btns-wrapper\">\n <ReCAPTCHA\n ref={recaptchaRef}\n sitekey={recaptchasitekey}\n onChange={onVerifyCaptcha}\n onExpired={() => setValReCaptcha(\"\")}\n />\n <Form.Item>\n <Button type=\"submit\" className=\"btn-red\">\n Submit\n </Button>\n </Form.Item>\n </div>\n </Form>\n </Col>\n </Row>\n </div>\n </Container>\n </ContactHeaderContainer>\n );\n}\n\nexport default ContactHeader;\n","import { Map, MapMobile } from \"assets/images/restaurants\";\nimport styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const ContactInfoContainer = styled.div`\n width: 100%;\n height: 527px;\n background: linear-gradient(\n 316deg,\n rgba(58, 60, 64, 1) 7%,\n rgba(24, 24, 24, 1) 56%\n );\n .contact-info-wrapper {\n width: 100%;\n height: 100%;\n display: flex;\n .contact-info-left {\n width: 60%;\n background: url(${Map});\n background-size: 100% 100%;\n }\n .contact-info-right {\n width: 40%;\n height: 100%;\n flex: 1 1 50%;\n padding-left: 150px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n .contact-item {\n margin-bottom: 25px;\n color: #fff;\n .upper {\n margin: 0;\n margin-bottom: 10px;\n font-size: 18px !important;\n i {\n margin-right: 10px;\n text-shadow: 0px 0px 10px rgba(255, 255, 255, 0.55);\n }\n span {\n color: rgba(255, 255, 255, 0.8);\n }\n }\n .bottom {\n margin: 0;\n font-size: 18px !important;\n font-weight: 500;\n color: ${colors.white};\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n height: unset;\n .contact-info-wrapper {\n flex-direction: column-reverse;\n .contact-info-left {\n width: 100%;\n height: 376px;\n background: url(${MapMobile});\n background-size: 100% 100%;\n }\n .contact-info-right {\n width: 100%;\n padding: 80px 0;\n padding-left: 0px;\n align-items: center;\n .contact-item {\n p {\n text-align: center;\n }\n }\n }\n }\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","import React from \"react\";\nimport { ContactInfoContainer } from \"./style\";\n\nfunction ContactInfo() {\n return (\n <ContactInfoContainer>\n <div className=\"contact-info-wrapper\">\n <div className=\"contact-info-left\"></div>\n <div className=\"contact-info-right\">\n <div className=\"contact-item\">\n <p className=\"upper\">\n <i className=\"fas fa-phone\" />\n <span>PHONE</span>\n </p>\n <p className=\"bottom\">+9 927 138 37 15</p>\n </div>\n\n <div className=\"contact-item\">\n <p className=\"upper\">\n <i className=\"far fa-envelope\" />\n <span>E-MAIL</span>\n </p>\n <p className=\"bottom\">contactus@feasttt.com</p>\n </div>\n\n <div className=\"contact-item\">\n <p className=\"upper\">\n <i className=\"fas fa-map-marker-alt\" />\n <span>HEADQUARTERS</span>\n </p>\n <p className=\"bottom\">New York City, NY</p>\n </div>\n </div>\n </div>\n </ContactInfoContainer>\n );\n}\n\nexport default ContactInfo;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport React from \"react\";\nimport { ContactContainer } from \"./style\";\nimport ContactHeader from \"./ContactHeader\";\nimport ContactInfo from \"./ContactInfo\";\n\nfunction Contact() {\n return (\n <ContactContainer>\n <ContactHeader />\n <ContactInfo />\n </ContactContainer>\n );\n}\n\nexport default Contact;\n","import styled from \"styled-components\";\nimport { colors, mixins } from \"theme\";\n\nexport const PrivacyContainer = styled.div`\n flex: 1;\n width: 100%;\n height: 100%;\n background-color: ${colors.white};\n padding: 100px 0;\n .privacy-wrapper {\n padding-top: 50px;\n word-wrap: break-word;\n h1 {\n font-size: 2.125rem !important;\n margin-top: 25px;\n margin-bottom: 15px;\n }\n h2 {\n font-size: 1.65rem !important;\n margin-top: 20px;\n margin-bottom: 10px;\n }\n h3 {\n font-size: 1.35rem !important;\n font-weight: 700;\n margin-top: 20px;\n margin-bottom: 10px;\n }\n p {\n font-size: 1rem !important;\n }\n ul {\n font-size: 1rem !important;\n line-height: 2;\n li {\n p {\n margin-top: 0;\n margin-bottom: 10px;\n }\n }\n }\n }\n @media (max-width: ${mixins.md}px) {\n }\n @media (max-width: ${mixins.sm}px) {\n }\n`;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport React from \"react\";\nimport { Container } from \"react-bootstrap\";\nimport { PrivacyContainer } from \"./style\";\n\nfunction Privacy() {\n return (\n <PrivacyContainer>\n <Container>\n <div className=\"privacy-wrapper\">\n <div id=\"md_en\" data-target=\"out_en\" class=\"agreement_md\">\n <h1>Privacy Policy</h1>\n <p>Last updated: April 30, 2021</p>\n <p>\n This Privacy Policy describes Our policies and procedures on the\n collection, use and disclosure of Your information when You use\n the Service and tells You about Your privacy rights and how the\n law protects You.\n </p>\n <p>\n We use Your Personal data to provide and improve the Service. By\n using the Service, You agree to the collection and use of\n information in accordance with this Privacy Policy.\n </p>\n <h1>Interpretation and Definitions</h1>\n <h2>Interpretation</h2>\n <p>\n The words of which the initial letter is capitalized have meanings\n defined under the following conditions. The following definitions\n shall have the same meaning regardless of whether they appear in\n singular or in plural.\n </p>\n <h2>Definitions</h2>\n <p>For the purposes of this Privacy Policy:</p>\n <ul>\n <li>\n <p>\n <strong>Account</strong> means a unique account created for\n You to access our Service or parts of our Service.\n </p>\n </li>\n <li>\n <p>\n <strong>Company</strong> (referred to as either \"the Company\",\n \"We\", \"Us\" or \"Our\" in this Agreement) refers to <b>Foodie Ave\n Inc</b>, <u>475 Brickell Ave. 5009 Miami, FL, 33131</u>.\n </p>\n </li>\n <li>\n <p>\n <strong>Cookies</strong> are small files that are placed on\n Your computer, mobile device or any other device by a website,\n containing the details of Your browsing history on that\n website among its many uses.\n </p>\n </li>\n <li>\n <p>\n <strong>Country</strong> refers to: Florida, United States\n </p>\n </li>\n <li>\n <p>\n <strong>Device</strong> means any device that can access the\n Service such as a computer, a cellphone or a digital tablet.\n </p>\n </li>\n <li>\n <p>\n <strong>Personal Data</strong> is any information that relates\n to an identified or identifiable individual.\n </p>\n </li>\n <li>\n <p>\n <strong>Service</strong> refers to the Website.\n </p>\n </li>\n <li>\n <p>\n <strong>Service Provider</strong> means any natural or legal\n person who processes the data on behalf of the Company. It\n refers to third-party companies or individuals employed by the\n Company to facilitate the Service, to provide the Service on\n behalf of the Company, to perform services related to the\n Service or to assist the Company in analyzing how the Service\n is used.\n </p>\n </li>\n <li>\n <p>\n <strong>Usage Data</strong> refers to data collected\n automatically, either generated by the use of the Service or\n from the Service infrastructure itself (for example, the\n duration of a page visit).\n </p>\n </li>\n <li>\n <p>\n <strong>Website</strong> refers to Feasttt, accessible from{\" \"}\n <a\n href=\"https://feasttt.com\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n feasttt.com\n </a>\n </p>\n </li>\n <li>\n <p>\n <strong>You</strong> means the individual accessing or using\n the Service, or the company, or other legal entity on behalf\n of which such individual is accessing or using the Service, as\n applicable.\n </p>\n </li>\n </ul>\n <h1>Collecting and Using Your Personal Data</h1>\n <h2>Types of Data Collected</h2>\n <h3>Personal Data</h3>\n <p>\n While using Our Service, We may ask You to provide Us with certain\n personally identifiable information that can be used to contact or\n identify You. Personally identifiable information may include, but\n is not limited to:\n </p>\n <ul>\n <li>\n <p>Email address</p>\n </li>\n <li>\n <p>First name and last name</p>\n </li>\n <li>\n <p>Phone number</p>\n </li>\n <li>\n <p>Address, State, Province, ZIP/Postal code, City</p>\n </li>\n <li>\n <p>Usage Data</p>\n </li>\n </ul>\n <h3>Usage Data</h3>\n <p>Usage Data is collected automatically when using the Service.</p>\n <p>\n Usage Data may include information such as Your Device's Internet\n Protocol address (e.g. IP address), browser type, browser version,\n the pages of our Service that You visit, the time and date of Your\n visit, the time spent on those pages, unique device identifiers\n and other diagnostic data.\n </p>\n <p>\n When You access the Service by or through a mobile device, We may\n collect certain information automatically, including, but not\n limited to, the type of mobile device You use, Your mobile device\n unique ID, the IP address of Your mobile device, Your mobile\n operating system, the type of mobile Internet browser You use,\n unique device identifiers and other diagnostic data.\n </p>\n <p>\n We may also collect information that Your browser sends whenever\n You visit our Service or when You access the Service by or through\n a mobile device.\n </p>\n <h3>Tracking Technologies and Cookies</h3>\n <p>\n We use Cookies and similar tracking technologies to track the\n activity on Our Service and store certain information. Tracking\n technologies used are beacons, tags, and scripts to collect and\n track information and to improve and analyze Our Service. The\n technologies We use may include:\n </p>\n <ul>\n <li>\n <strong>Cookies or Browser Cookies.</strong> A cookie is a small\n file placed on Your Device. You can instruct Your browser to\n refuse all Cookies or to indicate when a Cookie is being sent.\n However, if You do not accept Cookies, You may not be able to\n use some parts of our Service. Unless you have adjusted Your\n browser setting so that it will refuse Cookies, our Service may\n use Cookies.\n </li>\n <li>\n <strong>Flash Cookies.</strong> Certain features of our Service\n may use local stored objects (or Flash Cookies) to collect and\n store information about Your preferences or Your activity on our\n Service. Flash Cookies are not managed by the same browser\n settings as those used for Browser Cookies. For more information\n on how You can delete Flash Cookies, please read \"Where can I\n change the settings for disabling, or deleting local shared\n objects?\" available at{\" \"}\n <a\n href=\"https://helpx.adobe.com/flash-player/kb/disable-local-shared-objects-flash.html#main_Where_can_I_change_the_settings_for_disabling__or_deleting_local_shared_objects_\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n https://helpx.adobe.com/flash-player/kb/disable-local-shared-objects-flash.html#main_Where_can_I_change_the_settings_for_disabling__or_deleting_local_shared_objects_\n </a>\n </li>\n <li>\n <strong>Web Beacons.</strong> Certain sections of our Service\n and our emails may contain small electronic files known as web\n beacons (also referred to as clear gifs, pixel tags, and\n single-pixel gifs) that permit the Company, for example, to\n count users who have visited those pages or opened an email and\n for other related website statistics (for example, recording the\n popularity of a certain section and verifying system and server\n integrity).\n </li>\n </ul>\n <p>\n Cookies can be \"Persistent\" or \"Session\" Cookies. Persistent\n Cookies remain on Your personal computer or mobile device when You\n go offline, while Session Cookies are deleted as soon as You close\n Your web browser. Learn more about cookies:{\" \"}\n <a\n href=\"https://www.freeprivacypolicy.com/blog/cookies/\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n Cookies: What Do They Do?\n </a>\n .\n </p>\n <p>\n We use both Session and Persistent Cookies for the purposes set\n out below:\n </p>\n <ul>\n <li>\n <p>\n <strong>Necessary / Essential Cookies</strong>\n </p>\n <p>Type: Session Cookies</p>\n <p>Administered by: Us</p>\n <p>\n Purpose: These Cookies are essential to provide You with\n services available through the Website and to enable You to\n use some of its features. They help to authenticate users and\n prevent fraudulent use of user accounts. Without these\n Cookies, the services that You have asked for cannot be\n provided, and We only use these Cookies to provide You with\n those services.\n </p>\n </li>\n <li>\n <p>\n <strong>Cookies Policy / Notice Acceptance Cookies</strong>\n </p>\n <p>Type: Persistent Cookies</p>\n <p>Administered by: Us</p>\n <p>\n Purpose: These Cookies identify if users have accepted the use\n of cookies on the Website.\n </p>\n </li>\n <li>\n <p>\n <strong>Functionality Cookies</strong>\n </p>\n <p>Type: Persistent Cookies</p>\n <p>Administered by: Us</p>\n <p>\n Purpose: These Cookies allow us to remember choices You make\n when You use the Website, such as remembering your login\n details or language preference. The purpose of these Cookies\n is to provide You with a more personal experience and to avoid\n You having to re-enter your preferences every time You use the\n Website.\n </p>\n </li>\n </ul>\n <p>\n For more information about the cookies we use and your choices\n regarding cookies, please visit our Cookies Policy or the Cookies\n section of our Privacy Policy.\n </p>\n <h2>Use of Your Personal Data</h2>\n <p>The Company may use Personal Data for the following purposes:</p>\n <ul>\n <li>\n <p>\n <strong>To provide and maintain our Service</strong>,\n including to monitor the usage of our Service.\n </p>\n </li>\n <li>\n <p>\n <strong>To manage Your Account:</strong> to manage Your\n registration as a user of the Service. The Personal Data You\n provide can give You access to different functionalities of\n the Service that are available to You as a registered user.\n </p>\n </li>\n <li>\n <p>\n <strong>For the performance of a contract:</strong> the\n development, compliance and undertaking of the purchase\n contract for the products, items or services You have\n purchased or of any other contract with Us through the\n Service.\n </p>\n </li>\n <li>\n <p>\n <strong>To contact You:</strong> To contact You by email,\n telephone calls, SMS, or other equivalent forms of electronic\n communication, such as a mobile application's push\n notifications regarding updates or informative communications\n related to the functionalities, products or contracted\n services, including the security updates, when necessary or\n reasonable for their implementation.\n </p>\n </li>\n <li>\n <p>\n <strong>To provide You</strong> with news, special offers and\n general information about other goods, services and events\n which we offer that are similar to those that you have already\n purchased or enquired about unless You have opted not to\n receive such information.\n </p>\n </li>\n <li>\n <p>\n <strong>To manage Your requests:</strong> To attend and manage\n Your requests to Us.\n </p>\n </li>\n <li>\n <p>\n <strong>For business transfers:</strong> We may use Your\n information to evaluate or conduct a merger, divestiture,\n restructuring, reorganization, dissolution, or other sale or\n transfer of some or all of Our assets, whether as a going\n concern or as part of bankruptcy, liquidation, or similar\n proceeding, in which Personal Data held by Us about our\n Service users is among the assets transferred.\n </p>\n </li>\n <li>\n <p>\n <strong>For other purposes</strong>: We may use Your\n information for other purposes, such as data analysis,\n identifying usage trends, determining the effectiveness of our\n promotional campaigns and to evaluate and improve our Service,\n products, services, marketing and your experience.\n </p>\n </li>\n </ul>\n <p>\n We may share Your personal information in the following\n situations:\n </p>\n <ul>\n <li>\n <strong>With Service Providers:</strong> We may share Your\n personal information with Service Providers to monitor and\n analyze the use of our Service, to contact You.\n </li>\n <li>\n <strong>For business transfers:</strong> We may share or\n transfer Your personal information in connection with, or during\n negotiations of, any merger, sale of Company assets, financing,\n or acquisition of all or a portion of Our business to another\n company.\n </li>\n <li>\n <strong>With Affiliates:</strong> We may share Your information\n with Our affiliates, in which case we will require those\n affiliates to honor this Privacy Policy. Affiliates include Our\n parent company and any other subsidiaries, joint venture\n partners or other companies that We control or that are under\n common control with Us.\n </li>\n <li>\n <strong>With business partners:</strong> We may share Your\n information with Our business partners to offer You certain\n products, services or promotions.\n </li>\n <li>\n <strong>With other users:</strong> when You share personal\n information or otherwise interact in the public areas with other\n users, such information may be viewed by all users and may be\n publicly distributed outside.\n </li>\n <li>\n <strong>With Your consent</strong>: We may disclose Your\n personal information for any other purpose with Your consent.\n </li>\n </ul>\n <h2>Retention of Your Personal Data</h2>\n <p>\n The Company will retain Your Personal Data only for as long as is\n necessary for the purposes set out in this Privacy Policy. We will\n retain and use Your Personal Data to the extent necessary to\n comply with our legal obligations (for example, if we are required\n to retain your data to comply with applicable laws), resolve\n disputes, and enforce our legal agreements and policies.\n </p>\n <p>\n The Company will also retain Usage Data for internal analysis\n purposes. Usage Data is generally retained for a shorter period of\n time, except when this data is used to strengthen the security or\n to improve the functionality of Our Service, or We are legally\n obligated to retain this data for longer time periods.\n </p>\n <h2>Transfer of Your Personal Data</h2>\n <p>\n Your information, including Personal Data, is processed at the\n Company's operating offices and in any other places where the\n parties involved in the processing are located. It means that this\n information may be transferred to — and maintained on — computers\n located outside of Your state, province, country or other\n governmental jurisdiction where the data protection laws may\n differ than those from Your jurisdiction.\n </p>\n <p>\n Your consent to this Privacy Policy followed by Your submission of\n such information represents Your agreement to that transfer.\n </p>\n <p>\n The Company will take all steps reasonably necessary to ensure\n that Your data is treated securely and in accordance with this\n Privacy Policy and no transfer of Your Personal Data will take\n place to an organization or a country unless there are adequate\n controls in place including the security of Your data and other\n personal information.\n </p>\n <h2>Disclosure of Your Personal Data</h2>\n <h3>Business Transactions</h3>\n <p>\n If the Company is involved in a merger, acquisition or asset sale,\n Your Personal Data may be transferred. We will provide notice\n before Your Personal Data is transferred and becomes subject to a\n different Privacy Policy.\n </p>\n <h3>Law enforcement</h3>\n <p>\n Under certain circumstances, the Company may be required to\n disclose Your Personal Data if required to do so by law or in\n response to valid requests by public authorities (e.g. a court or\n a government agency).\n </p>\n <h3>Other legal requirements</h3>\n <p>\n The Company may disclose Your Personal Data in the good faith\n belief that such action is necessary to:\n </p>\n <ul>\n <li>Comply with a legal obligation</li>\n <li>Protect and defend the rights or property of the Company</li>\n <li>\n Prevent or investigate possible wrongdoing in connection with\n the Service\n </li>\n <li>\n Protect the personal safety of Users of the Service or the\n public\n </li>\n <li>Protect against legal liability</li>\n </ul>\n <h2>Security of Your Personal Data</h2>\n <p>\n The security of Your Personal Data is important to Us, but\n remember that no method of transmission over the Internet, or\n method of electronic storage is 100% secure. While We strive to\n use commercially acceptable means to protect Your Personal Data,\n We cannot guarantee its absolute security.\n </p>\n <h1>Children's Privacy</h1>\n <p>\n Our Service does not address anyone under the age of 13. We do not\n knowingly collect personally identifiable information from anyone\n under the age of 13. If You are a parent or guardian and You are\n aware that Your child has provided Us with Personal Data, please\n contact Us. If We become aware that We have collected Personal\n Data from anyone under the age of 13 without verification of\n parental consent, We take steps to remove that information from\n Our servers.\n </p>\n <p>\n If We need to rely on consent as a legal basis for processing Your\n information and Your country requires consent from a parent, We\n may require Your parent's consent before We collect and use that\n information.\n </p>\n <h1>Links to Other Websites</h1>\n <p>\n Our Service may contain links to other websites that are not\n operated by Us. If You click on a third party link, You will be\n directed to that third party's site. We strongly advise You to\n review the Privacy Policy of every site You visit.\n </p>\n <p>\n We have no control over and assume no responsibility for the\n content, privacy policies or practices of any third party sites or\n services.\n </p>\n <h1>Changes to this Privacy Policy</h1>\n <p>\n We may update Our Privacy Policy from time to time. We will notify\n You of any changes by posting the new Privacy Policy on this page.\n </p>\n <p>\n We will let You know via email and/or a prominent notice on Our\n Service, prior to the change becoming effective and update the\n \"Last updated\" date at the top of this Privacy Policy.\n </p>\n <p>\n You are advised to review this Privacy Policy periodically for any\n changes. Changes to this Privacy Policy are effective when they\n are posted on this page.\n </p>\n <h1>Contact Us</h1>\n <p>\n If you have any questions about this Privacy Policy, You can\n contact us:\n </p>\n <ul>\n <li>\n <p>By email: contact@feasttt.com</p>\n </li>\n <li>\n <p>\n By visiting this page on our website:{\" \"}\n <a\n href=\"https://feasttt.com/contact\"\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n >\n https://feasttt.com/contact\n </a>\n </p>\n </li>\n </ul>\n </div>\n </div>\n </Container>\n </PrivacyContainer>\n );\n}\n\nexport default Privacy;\n","import React from \"react\";\nimport {\n BrowserRouter as Router,\n Redirect,\n Route,\n Switch,\n} from \"react-router-dom\";\nimport GlobalStyle from \"theme/globalStyle\";\nimport \"assets/css/fontawesome.min.css\";\nimport \"bootstrap/dist/css/bootstrap.min.css\";\nimport \"antd/dist/antd.css\";\nimport MyRoute from \"service/MyRoute\";\nimport Customers from \"containers/Customers\";\nimport Restaurants from \"containers/Restaurants\";\nimport Blog from \"containers/Blog\";\nimport BlogDetail from \"containers/BlogDetail\";\nimport Careers from \"containers/Careers\";\nimport CareerDetail from \"containers/CareerDetail\";\nimport Contact from \"containers/Contact\";\nimport Privacy from \"containers/Privacy\";\n\nfunction App() {\n return (\n <div className=\"App\">\n <GlobalStyle />\n <Router>\n <Switch>\n <Route\n exact\n path=\"/\"\n render={() => <Redirect to=\"/home/customers\" />}\n />\n <MyRoute exact path=\"/home/customers\" component={Customers} />\n <MyRoute exact path=\"/home/restaurants\" component={Restaurants} />\n {/*<MyRoute exact path=\"/blog\" component={Blog} />*/}\n {/*<MyRoute exact path=\"/blog-detail/:id\" component={BlogDetail} />*/}\n <MyRoute exact path=\"/careers\" component={Careers} />\n <MyRoute exact path=\"/careers/:id\" component={CareerDetail} />\n <MyRoute exact path=\"/contact\" component={Contact} />\n <MyRoute exact path=\"/privacy\" component={Privacy} />\n </Switch>\n </Router>\n </div>\n );\n}\n\nexport default App;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' },\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready\n .then(registration => {\n registration.unregister();\n })\n .catch(error => {\n console.error(error.message);\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\n\nReactDOM.render(\n <App />,\n document.getElementById('root')\n);\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n"],"sourceRoot":""}