{"version":3,"sources":["Assets/PartnerNewpluginsdkActivate/tim-ios-logo.png","Assets/Branding/itv_logo.png","Assets/Platforms/chrome.png","Assets/Branding/purple_kindred_icon.png","Assets/Branding/black_kindred_icon.png","Assets/Branding/new_kindred_icon.png","Assets/BrandLogos/nike.png","Assets/BrandLogos/john_lewis.png","Assets/BrandLogos/asos.png","Assets/BrandLogos/john_lewis_logo_white.png","Assets/BrandLogos/typewise.png","Assets/BrandLogos/couponsde.png","Assets/BrandLogos/eon.png","Assets/BrandLogos/popreach.png","Assets/BrandLogos/whitelabel.png","Assets/BrandLogos/o2.png","Assets/BrandLogos/unity.png","Assets/O2Logos/O2-bubble-3D-animations-04@05x 1.png","Assets/Branding/discounts-and-savings.png","Assets/KeyboardInstallationGuide/ios.png","Assets/KeyboardInstallationGuide/android.png","Assets/BrandLogos/aliexpress.png","Assets/BrandLogos/nike_logo_white.png","Assets/BrandLogos/asos_logo_white.png","Assets/BrandLogos/adscend.png","Assets/BrandLogos/teamo.png","Assets/PartnerpluginsdkActivate/settings activate kindred.png","Assets/PartnerpluginsdkActivate/settings menu.png","Assets/PartnerpluginsdkActivate/settings permission.png","Assets/KeyboardInstallationGuide/plugin-alpha-step2.jpg","Assets/KeyboardInstallationGuide/plugin-alpha-step3.jpg","Assets/KeyboardInstallationGuide/plugin-beta-step1.gif","Assets/KeyboardInstallationGuide/plugin-beta-step2.gif","Assets/KeyboardInstallationGuide/plugin-beta-step3.gif","Assets/Products/mobile.png","Assets/Products/unity.png","Assets/Products/dealsApi.png","Assets/Products/desktopExtension.png","Assets/Products/mobileKeyboard.png","Assets/Products/edge.png","Assets/Products/firefox.png","Assets/Products/safari.png","Assets/KeyboardInstallationGuide/android-guide1.png","Assets/KeyboardInstallationGuide/android-guide2.png","Assets/KeyboardInstallationGuide/android-guide3.png","Assets/Esg/reforestation.png","Assets/Esg/carbonOffset.png","Assets/Esg/donate.png","Assets/Revenue/increaseARPU.png","Assets/Revenue/lifetimeValue.png","Assets/Revenue/atNoCost.png","Assets/Loyalty/offers.png","Assets/Loyalty/inAppReward.png","Assets/Loyalty/esgSupport.png","Assets/About/ourMission1.png","Assets/About/ourMission2.png","Assets/About/ourMission3.png","Assets/Network/Brands/amazon.png","Assets/Network/Brands/levis.png","Assets/Network/Brands/adidas.png","Assets/Network/Brands/microsoft.png","Assets/Network/Brands/samsung.png","Assets/Network/Brands/macys.png","Assets/Network/Brands/gap.png","Assets/Network/Brands/target.png","Assets/Network/Brands/walmart.png","Assets/Network/Brands/tesco.png","Assets/Branding/white_kindred_icon.png","Assets/Icons/puzzlePiece.png","Assets/Icons/greenSwitch.png","Assets/PartnerNewpluginsdkActivate/safari-activation-steps.png","Assets/PartnerNewpluginsdkActivate/safari-settings-steps.png","Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-18.png","Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-aa.png","Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-aa-ar.png","Assets/PartnerpluginsdkActivate/tap-here.png","Assets/PartnerpluginsdkActivate/tap-here-ios-18.png","Assets/PartnerpluginsdkActivate/tap-here-ios-18-ar.png","Assets/PartnerpluginsdkActivate/tap-aa-here.png","Assets/PartnerpluginsdkActivate/tap-aa-here-ar.png","Assets/PartnerpluginsdkActivate/ios-18-plugin-icon.png","Assets/PartnerpluginsdkActivate/tap-here-sliide.png","Assets/PartnerpluginsdkActivate/tap-here-top-left.png","Assets/PartnerpluginsdkActivate/tap-here-bottom.png","Assets/PartnerpluginsdkActivate/tap-here-top-left-sliide.png","Assets/PartnerpluginsdkActivate/tap-here-bottom-sliide.png","Assets/PartnerNewpluginsdkActivate/tap-here-top-left-itvx.png","Assets/PartnerNewpluginsdkActivate/tap-here-bottom-itvx.png","Assets/PartnerNewpluginsdkActivate/tap-review-itvx.png","Assets/PartnerNewpluginsdkActivate/always-allow.png","Assets/PartnerpluginsdkActivate/be-sure-step1.png","Assets/PartnerpluginsdkActivate/be-sure-step2.png","Assets/PartnerpluginsdkActivate/be-sure-step3.png","Assets/PartnerpluginsdkActivate/be-sure-step4.png","Assets/PartnerpluginsdkActivate/be-sure-step5.png","Assets/PartnerpluginsdkActivate/be-sure-stepsliide1.png","Assets/PartnerpluginsdkActivate/be-sure-stepsliide2.png","Assets/PartnerpluginsdkActivate/be-sure-stepsliide3.png","Assets/PartnerpluginsdkActivate/be-sure-stepsliide4.png","Assets/PartnerpluginsdkActivate/be-sure-stepsliide5.png","Assets/PartnerpluginsdkActivate/brands.png","Assets/PartnerpluginsdkActivate/brandssliide.png","Assets/PartnerNewpluginsdkActivate/tim-ios-activation-review.gif","Assets/PartnerNewpluginsdkActivate/tim-ios-activation-aa.gif","Assets/PartnerNewpluginsdkActivate/tim-ios-activation-18.gif","Assets/PartnerNewpluginsdkActivate/tim-ios-partial-steps.png","Assets/PartnerNewpluginsdkActivate/tim-ios-union-icon.png","Assets/PartnerNewpluginsdkActivate/tim-ios-review-permissions.png","Assets/PartnerNewpluginsdkActivate/tim-ios-switch-icon.png","Assets/PartnerNewpluginsdkActivate/tim-ios-plugin-icon.png","Assets/PartnerNewpluginsdkActivate/tim-ios-18-icon.png","Assets/PartnerNewpluginsdkActivate/tim-ios-success-icon.png","Assets/PartnerNewpluginsdkActivate/tim-app-store-icon.png","Assets/PartnerNewpluginsdkActivate/tim-partial-logo.png","Assets/PartnerNewpluginsdkActivate/tim-safari-icon.png","Assets/PartnerNewpluginsdkActivate/safari-browser-logo.png","Assets/PartnerNewpluginsdkActivate/tim-settings-icon.png","Assets/PartnerNewpluginsdkActivate/tim-switch.png","Assets/PartnerNewpluginsdkActivate/tim-left-icon.png","Assets/SamsungActivation/samsung-deals-found.png","Assets/SamsungActivation/samsung-saved-so-far.png","Assets/SamsungActivation/samsung-you-saved.png","Assets/ITVLogos/itv@4x.png","Assets/ITVLogos/itvX@4x.png","Assets/ITVLogos/dominos@4x.png","Assets/BrandLogos/tim-viva-ticket-logo.png","Assets/BrandLogos/tim-asos-logo.png","Assets/BrandLogos/tim-air-bnb-logo.png","Assets/BrandLogos/sephora-logo.png","Assets/BrandLogos/tim-leroy-merlin-logo.png","Assets/BrandLogos/tim-decathlon-logo.png","Assets/BrandLogos/tim-euronics-logo.png","Assets/BrandLogos/tim-zalando-logo.png","Assets/OfferWall sync /^/.//.*/.png$","Assets/OfferWall/aldo.png","Assets/OfferWall/aliexpress.png","Assets/OfferWall/alsaadhome.png","Assets/OfferWall/amazon.png","Assets/OfferWall/asos.png","Assets/OfferWall/babyshop.png","Assets/OfferWall/basharacare.png","Assets/OfferWall/bathandbody.png","Assets/OfferWall/boots.png","Assets/OfferWall/boutiqaat.png","Assets/OfferWall/brandsforless.png","Assets/OfferWall/carrefour.png","Assets/OfferWall/centrepoint.png","Assets/OfferWall/chicpoint.png","Assets/OfferWall/cider.png","Assets/OfferWall/crocs.png","Assets/OfferWall/danubehome.png","Assets/OfferWall/desertcart.png","Assets/OfferWall/doduae.png","Assets/OfferWall/dyson.png","Assets/OfferWall/eyewa.png","Assets/OfferWall/farfetch.png","Assets/OfferWall/firstcry.png","Assets/OfferWall/fordeal.png","Assets/OfferWall/groupon.png","Assets/OfferWall/handm.png","Assets/OfferWall/hibobi.png","Assets/OfferWall/homebox.png","Assets/OfferWall/homecentre.png","Assets/OfferWall/homesrus.png","Assets/OfferWall/hudabeauty.png","Assets/OfferWall/iherb.png","Assets/OfferWall/letstango.png","Assets/OfferWall/levelshoes.png","Assets/OfferWall/lifepharmacy.png","Assets/OfferWall/lightinthebox.png","Assets/OfferWall/lulushopping.png","Assets/OfferWall/maxfashion.png","Assets/OfferWall/modanisa.png","Assets/OfferWall/mumzworld.png","Assets/OfferWall/namshi.png","Assets/OfferWall/next.png","Assets/OfferWall/nike.png","Assets/OfferWall/noon.png","Assets/OfferWall/ounass.png","Assets/OfferWall/ourshopee.png","Assets/OfferWall/puma.png","Assets/OfferWall/randbfashion.png","Assets/OfferWall/sephora.png","Assets/OfferWall/sharafdg.png","Assets/OfferWall/shein.png","Assets/OfferWall/sivvi.png","Assets/OfferWall/sixthstreet.png","Assets/OfferWall/smartbuyglasses.png","Assets/OfferWall/splashonline.png","Assets/OfferWall/storeus.png","Assets/OfferWall/styli.png","Assets/OfferWall/sunandsandsports.png","Assets/OfferWall/temu.png","Assets/OfferWall/toysrus.png","Assets/OfferWall/trendyol.png","Assets/OfferWall/underarmour.png","Assets/OfferWall/vogacloset.png","Assets/OfferWall/wish.png","Internationalization/index.ts","Routing/Paths.ts","Theming/colors.ts","Theming/breakpoints.ts","Theming/ITVTheme/colors.ts","Theming/index.ts","Routing/HashLinkPathIds.ts","Common/LoadingIndicator.tsx","Common/NotFound.tsx","Navigation/Components/DropDown/DropDownMenu.tsx","env.ts","Navigation/MainMenu.tsx","Common/Svg/Logos/KindredForBusinessLogo.tsx","Common/Svg/core.ts","Common/Svg/Logos/KindredSDKLogo.tsx","Common/Svg/Icons/ArrowHead.tsx","Common/Svg/Icons/ArrowInCircle.tsx","Common/Svg/Icons/Close.tsx","Common/Svg/Icons/BenefitOne.tsx","Common/Svg/Icons/BenefitThree.tsx","Common/Svg/Icons/BenefitTwo.tsx","Common/Svg/Icons/FacebookLogo.tsx","Common/Svg/Icons/Hamburger.tsx","Common/Svg/Icons/InstagramLogo.tsx","Common/Svg/Icons/HowItworksDeals.tsx","Common/Svg/Icons/HowItworksDesktop.tsx","Common/Svg/Icons/HowItworksKeyboard.tsx","Common/Svg/Icons/HowItworksMobile.tsx","Common/Svg/Icons/LinkedInLogo.tsx","Common/Svg/Icons/KeepDataSafe.tsx","Common/Svg/Icons/KeyBenefitsImprove.tsx","Common/Svg/Icons/TwitterLogo.tsx","Common/Buttons/UnstyledButton.tsx","Navigation/HamburgerMenu/MenuButton.tsx","Navigation/HamburgerMenu/MenuLink.tsx","Navigation/HamburgerMenu/MenuBody.tsx","Navigation/HamburgerMenu/index.tsx","Navigation/Header.tsx","Navigation/Footer/Components/Logos.tsx","Assets/Footer/iso-certificate.png","Assets/Footer/carbon-neutral.png","Assets/Footer/verified-carbon-standard-small.png","Assets/Footer/verified-carbon-standard.png","Assets/Footer/social-enterprise-uk-small.png","Assets/Footer/social-enterprise-uk.png","Common/Utils/scroller.ts","Navigation/Footer/Components/sharedStyles.ts","Navigation/Footer/Components/BenefitLinks.tsx","Common/Buttons/Links/ButtonLink.tsx","Common/SocialLinks.tsx","Navigation/Footer/Components/Connect.tsx","Assets/Footer/certified-badge.png","Navigation/Footer/Components/CompanyLinks.tsx","Navigation/Footer/Components/ProductLinks.tsx","Navigation/Footer/index.tsx","Routing/DefaultLayout.tsx","Theming/images.ts","Common/Icons/KindredIcon.tsx","Common/Layouts/Flex/index.tsx","Common/Layouts/Center/index.tsx","Common/Layouts/Text/index.tsx","Common/Hooks/useClickOutside.ts","Common/Hooks/useDisclosure.ts","Common/Hooks/useQuery.ts","Common/Hooks/useScrollTo.ts","Common/Analytics/partnerAnalytics.ts","Common/Analytics/utils.ts","Common/Hooks/usePageViewTracking.ts","Common/Icons/Close.tsx","Common/Icons/core.ts","Common/Modals/Modal.tsx","KeyboardInstallationGuide/Components/DescriptionModal.tsx","Common/Buttons/StyledButtons/StyledButton1.tsx","Common/Utils/platforms.ts","KeyboardInstallationGuide/Components/Description.tsx","KeyboardInstallationGuide/index.tsx","Common/Logos/KindredLogo.tsx","Common/Buttons/Buttons.tsx","AndroidKeyboardInstallationGuide/Images/AndroidGuideImages.tsx","AndroidKeyboardInstallationGuide/Components/Description.tsx","AndroidKeyboardInstallationGuide/index.tsx","PartnerpluginsdkActivate/Components/DescriptionWithiOS18Support.tsx","PartnerpluginsdkActivate/Components/DescriptionWithBrowserNotSupported.tsx","PartnerpluginsdkActivate/PartnerPluginActivateBase.tsx","Assets/Icons/discountsFavicon.png","PartnerpluginsdkActivate/Components/MultiStepActivationContainer.tsx","PartnerpluginsdkActivate/Components/InstructionStep.tsx","PartnerpluginsdkActivate/Components/TapHereAnimated.tsx","PartnerpluginsdkActivate/PartnerPluginActivateMultiStep.tsx","Common/Form/Common.tsx","Common/Utils/useLanguageUtm.ts","Common/Form/FormControl.tsx","Common/Form/FormSelect.tsx","Common/Form/FormInput.tsx","Common/PoweredByKindred/index.tsx","Common/Hooks/usePageTitle.ts","PartnerpluginsdkActivate/index.tsx","Common/ScrollToTop/ScrollToTop.tsx","Common/Utils/extensionSDK.ts","Samsung/utils.ts","Samsung/PostActivationPage/PostActivationSlide.tsx","Samsung/PostActivationPage/PostActivationPage.tsx","Samsung/SamsungActivation.tsx","Extension/Components/ExtensionInstallLink.tsx","Extension/Components/Separator.tsx","Extension/Components/MinimalHeader.tsx","Assets/how-it-works/shop.png","Assets/how-it-works/save.png","Assets/how-it-works/safe.png","Extension/Components/HowItWorks.tsx","Common/Utils/locations.ts","Firebase/index.tsx","PluginFeatures/index.tsx","Extension/ExtensionInstalled/index.tsx","PluginFeatures/helpers.ts","Extension/ExtensionUninstalled/index.tsx","Samsung/SamsungLanding.tsx","Common/Api/ApiRequest.ts","TreePlanting/TreeplantingContext.tsx","Common/Api/useApiGet.ts","Assets/TreePlanting/Cloud.png","Assets/TreePlanting/Iceburg.png","TreePlanting/Components/equivalentSection.tsx","Assets/TreePlanting/Car.png","Assets/TreePlanting/TreePlantingHero.png","Assets/TreePlanting/TreePlantingMobileHero.png","TreePlanting/Components/footer.tsx","Assets/TreePlanting/white_kindred_logo.png","TreePlanting/Components/hero.tsx","TreePlanting/Components/howDoesItWork.tsx","Assets/TreePlanting/MerchantIcon.png","Assets/TreePlanting/CommissionIcon.png","Assets/TreePlanting/TreeIcon.png","Assets/TreePlanting/Peru.png","Assets/TreePlanting/Tanzania.png","Assets/TreePlanting/Congo.png","TreePlanting/Components/recentProjects.tsx","Assets/TreePlanting/Tree.png","Assets/TreePlanting/Growth.png","Assets/TreePlanting/Deforestation.png","Assets/TreePlanting/TreeLocations.png","Assets/TreePlanting/DotsEco.png","Assets/TreePlanting/VerifiedCarbon.png","Assets/TreePlanting/Urs.png","TreePlanting/Components/whereAreTreesPlanted.tsx","Assets/TreePlanting/Kindred.png","Assets/TreePlanting/Cnb.png","Assets/TreePlanting/Earthmark.png","TreePlanting/v1/index.tsx","Assets/TreePlanting/TreesBackgroundDesktop.png","TreePlanting/v2/Hero.tsx","TreePlanting/v2/TreesFunded.tsx","Assets/TreePlanting/cloudBlack.png","TreePlanting/v2/EquivalentSection.tsx","Assets/TreePlanting/carBlack.png","TreePlanting/v2/HowItWorks.tsx","Assets/TreePlanting/houseBlack.png","Assets/TreePlanting/moneyBlack.png","Assets/TreePlanting/treesBlack.png","Assets/TreePlanting/treesFooter.png","TreePlanting/v2/Footer.tsx","TreePlanting/v2/index.tsx","TreePlanting/index.tsx","ChromeDesktopUTMTracking/ChromeDesktopUTMTracking.tsx","PartnerpluginsdkActivate/PartnerPluginActivateMultiStepAlwaysAllow.tsx","PartnerpluginsdkActivate/PartnerPluginActivateMultiStepAlmostThere.tsx","PartnerpluginsdkActivate/Components/BeSureToAllowSlide.tsx","PartnerpluginsdkActivate/PartnerPluginActivateMultiStepBeSureToAllow.tsx","PartnerpluginsdkActivate/PartnerPluginActivateMultiStepStartShopping.tsx","PartnerNewpluginsdkActivate/Components/MultiStepActivationContainer.tsx","PartnerNewpluginsdkActivate/Components/TapHereAnimated.tsx","PartnerNewpluginsdkActivate/PartnerPluginActivateMultiStep.tsx","PartnerNewpluginsdkActivate/index.tsx","Routing/LinkRedirect.tsx","PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepAlwaysAllow.tsx","PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepPartialPermissions.tsx","Common/PyramidGrid/PyramidGrid.tsx","ITVActivation/Components/CashSaverBrands.tsx","PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepAllDone.tsx","ITVActivation/Logos/ItvSquareLogo.tsx","PartnerPluginActivateV2/utils.ts","AndroidAccessibility/Components/Header.tsx","ITVActivation/Components/Button.tsx","AndroidAccessibility/Components/ActivationSteps.tsx","AndroidAccessibility/Components/ActivateNow.tsx","AndroidAccessibility/index.tsx","ITVActivation/Logos/ItvLogo.tsx","ITVActivation/Logos/DominosLogo.tsx","ITVActivation/ITVLayout/StandardHeader.tsx","ITVActivation/ITVLayout/CashSaverHeader.tsx","ITVActivation/ITVLayout/ITVLayout.tsx","ITVActivation/utils.ts","ITVActivation/Components/CashSaver.tsx","ITVActivation/Components/Faq.tsx","ITVActivation/Components/ButtonTextGroup.tsx","ITVActivation/Components/ActivationButtons.tsx","ITVActivation/Components/Footer.tsx","ITVActivation/index.tsx","PartnerPluginActivateV2/index.tsx","OfferWall/components/SearchIcon.tsx","OfferWall/components/CloseIcon.tsx","OfferWall/components/Search.tsx","OfferWall/components/CatetoryItem.tsx","OfferWall/components/Categories.tsx","OfferWall/components/Brands.tsx","OfferWall/utils.ts","OfferWall/index.tsx","Assets/TIM/puzzlePieceBackground.png","TIM/shared/PoweredByKindred.tsx","TIM/TimTopNavigation.tsx","TIM/index.tsx","TIM/KindredIOS.ts","TIM/shared/Download.tsx","TIM/shared/Toggle.tsx","TIM/AndroidAccessibility.tsx","TIM/KindredAndroid.ts","Theming/TIMTheme/colors.ts","PartnerNewpluginsdkActivateTim/Components/MultiStepActivationContainer.tsx","PartnerNewpluginsdkActivateTim/PartnerPluginActivateMultiStep.tsx","PartnerNewpluginsdkActivateTim/index.tsx","PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepAlwaysAllow.tsx","PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepPartialPermissions.tsx","PartnerNewpluginsdkActivateTim/Components/CashSaverBrands.tsx","PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepAllDone.tsx","Routing/Routes.tsx","Routing/index.ts","App.tsx","Common/ErrorBoundary/ErrorMessage.tsx","Common/ErrorBoundary/ErrorBoundary.tsx","index.tsx"],"names":["map","webpackContext","req","id","webpackContextResolve","__webpack_require__","o","e","Error","code","keys","Object","resolve","module","exports","resources","en","translation","translationEN","translationENGB","fr","translationFR","de","translationDE","es","translationES","hi","translationHI","it","translationIT","ja","translationJA","ko","translationKO","pt","translationPT","ru","translationRU","ar","translationAR","i18next","use","LanguageDetector","initReactI18next","init","fallbackLng","debug","process","interpolation","escapeValue","nsSeparator","Path","colors","semiTransparentBlack","black","white","smokeyWhite","greyWhite","lightestGrey","lightGrey","midLightGrey","midBlue","midGrey","grey","mediumGrey","darkGrey","veryDarkGrey","darkestGrey","purple","darkPurple","veryDarkPurple","blue","darkBlue","veryDarkBlue","customBlue","pink","darkPink","green","fernGreen","lightGreen","mediumGreen","darkGreen","veryDarkGreen","forestGreen","pastelGreen","darkestGreen","lilac","avoGreen","gray98","neutralBlack","smokeGrey","smokeBlack","successGreen","verizonRed","verizonGrey","discountsPurple","samsungActivationPillDarkGrey","semiDarkGrey","greyBackground","greyText","darkBackground","breakpoints","mobile","tablet","greenishBlue","gray","darkGray","lightGray","textGray","lemonGreen","useBreakPoints","useTheme","useState","entries","reduce","rv","curr","breakpointState","setBreakpointState","useEffect","subscriptions","breakpoint","match","window","matchMedia","handler","state","prev","matches","addListener","push","removeListener","forEach","x","mobileMediaQuery","theme","tabletMediaQuery","itvThemeColor","color","itvThemeColors","themeColor","accessibilityFocusStyleLight","styled","div","FullBleed","css","HashLinkPathsIds","animation","keyframes","Container","scale","SpinnerContainer","HeartLoadingIndicator","show","className","SpinnerLoadingIndicator","SkeletonLoadingIndicator","LoadingIndicator","type","delay","setShow","timeout","setTimeout","clearTimeout","Title","h1","Text","p","NotFound","t","useTranslation","to","Home","StyledTooltip","sharedStyling","StyledLink","Link","StyledDropdownLink","StyledDropdownContainer","DropdownContainer","DropDownMenu","items","children","showMenu","setShowMenu","onMouseEnter","onMouseLeave","item","key","link","text","env","__KINDRED__ENV","nav","StyledButtonLink","a","MainMenu","PRODUCTS_MENU_ITEMS","BENEFITS_MENU_ITEMS","Gaming","ABOUT_MENU_ITEMS","pathname","blog_link","target","href","RequestADemo","Revenue","Loyalty","ESG","ProductHome","ProductExtension","ProductDesktop","ProductApi","AboutUs","Network","KindredForBusinessLogo","width","height","fill","xmlns","viewBox","d","useDefaultColor","KindredSDKLogo","resolvedFillColor","resolvedStrokeColor","stroke","strokeWidth","strokeMiterlimit","transform","up","down","left","right","ArrowHead","style","direction","rotateDimensions","resolvedColor","swapWidthHeight","strokeLinecap","strokeLinejoin","TRANSFORM","ArrowInCircle","Close","svg","FacebookLogo","Hamburger","InstagramLogo","fillRule","clipRule","LinkedInLogo","TwitterLogo","UnstyledButton","button","attrs","props","visibility","StyledButton","MenuButton","onClick","hideArrow","arrowDirection","MenuLink","SpaceFiller","SubLink","SubLinks","ExpandingMenuItem","title","path","routeMatch","useRouteMatch","expanded","setExpanded","ProductsLevelLinks","BenefitsLevelLinks","AboutKindredLevelLinks","RootLevelLinks","MenuBody","NoScrollOnBody","createGlobalStyle","HamburgerButton","CloseButton","MenuContainer","ImageLink","MenuBodyContainer","LogoContainer","StyledLogo","HamburgerMenu","isOpen","setIsOpen","history","useHistory","listen","HeaderRoot","header","Header","headerRef","useRef","lastScrollY","scrollY","top","current","headerHeight","clientHeight","Math","min","max","addEventListener","passive","removeEventListener","ref","SocialEnterpriseUK","img","StyledVerifiedCarbon","StyledCarbonNeutral","StyledISOCert","Logos","src","alt","scrollWithOffset","element","yOffset","yCoordinate","getBoundingClientRect","pageYOffset","scrollTo","behavior","linkStyle","StyledA","StyledHashLink","HashLink","h6","BenefitLinks","handleOffset","scroll","elementId","Root","smooth","ButtonLink","SocialContainer","SocialLink","SOCIAL_LINKS","name","logo","linkedin_url","twitter_url","facebook_url","instagram_url","SocialLinks","s","rel","MAIL_TO_SDK_COMMERCIAL_TEAM","sdk_commercial_team_email","StyledKindredLogo","ButtonLinkSecondary","RowContainer","StyledBadge","StyledText","StyledRow","WrappedRow","Connect","get_api_key_url","CompanyLinks","sdk_documentation_url","UnderTheHood","privacy_policy_url","terms_and_conditions_url","ProductLinks","StyledFooter","footer","Top","Separator","Column","section","Company","ConnectContainer","SolutionsContainer","Bottom","Copyright","LogosContainer","Footer","year","getYear","Date","DefaultLayout","images","purple_kindred_icon","require","black_kindred_icon","new_kindred_icon","itv_logo","discounts_and_savings_icon","keyboard_installation_guide_ios","keyboard_installation_guide_android","nike_logo","aliexpress_logo","john_lewis_logo","asos_logo","nike_logo_white","john_lewis_logo_white","asos_logo_white","typewise","couponsde","eon","popreach","whitelabel","adscend","teamo","o2","unity","O2_logo","partnerpluginsdk_activate_settings_activate_kindred","partnerpluginsdk_activate_settings_menu","partnerpluginsdk_activate_settings_permission","plugin_alpha_step_2","plugin_alpha_step_3","plugin_beta_step_1","plugin_beta_step_2","plugin_beta_step_3","unity_logo","deals_api","desktop_extension","mobile_keyboard","edge_icon","chrome_icon","firefox_icon","safari_icon","android_guide_1","android_guide_2","android_guide_3","esg_icon_1","esg_icon_2","esg_icon_3","revenue_icon_1","revenue_icon_2","revenue_icon_3","loyalty_icon_1","loyalty_icon_2","loyalty_icon_3","our_mission_1","our_mission_2","our_mission_3","amazonRoundLogo","levisRoundLogo","adidasRoundLogo","microsoftRoundLogo","samsungRoundLogo","macysRoundLogo","gapRoundLogo","targetRoundLogo","walmartRoundLogo","tescoRoundLogo","white_kindred_icon","puzzle_icon","ios_checked_icon","partnerpluginsdk_safari_activation_steps","partnerpluginsdk_safari_settings_steps","partnerpluginsdk_safari_settings_steps_ios18","partnerpluginsdk_safari_settings_steps_ios_aa","partnerpluginsdk_safari_settings_steps_ios_aa_ar","partnerpluginsdk_tap_here","partnerpluginsdk_tap_here_ios_18","partnerpluginsdk_tap_here_ios_18_ar","partnerpluginsdk_tap_aa_here","partnerpluginsdk_tap_aa_here_ar","partnerpluginsdk_ios_18_plugin_icon","partnerpluginsdk_tap_here_sliide","partnerpluginsdk_tap_here_top_left","partnerpluginsdk_tap_here_bottom","partnerpluginsdk_tap_here_top_left_sliide","partnerpluginsdk_tap_here_bottom_sliide","partnerpluginsdk_tap_here_top_left_itvx","partnerpluginsdk_tap_here_bottom_itvx","partnerpluginsdk_tap_review_itvx","partnerpluginsdk_always_allow","partnerpluginsdk_be_sure_1","partnerpluginsdk_be_sure_2","partnerpluginsdk_be_sure_3","partnerpluginsdk_be_sure_4","partnerpluginsdk_be_sure_5","partnerpluginsdk_be_suresliide_1","partnerpluginsdk_be_suresliide_2","partnerpluginsdk_be_suresliide_3","partnerpluginsdk_be_suresliide_4","partnerpluginsdk_be_suresliide_5","partnerpluginsdk_start_shopping_brands","partnerpluginsdk_start_shopping_brands_sliide","partnerpluginsdk_activation_tim_review","partnerpluginsdk_activation_tim_aa","partnerpluginsdk_activation_tim_18","tim_ios_logo","tim_ios_partial_steps","tim_ios_union_icon","tim_ios_review_permissions","tim_ios_switch_icon","tim_ios_plugin_icon","tim_ios_18_icon","tim_ios_success_icon","tim_app_store_icon","tim_partial_logo","tim_safari_icon","safari_browser_logo","tim_settings_icon","tim_switch","tim_left_icon","samsung_activation_deals_found","samsung_activation_you_saved_so_far","samsung_activation_you_saved","Itv_logo","ItvX","dominos_logo","mockedLogos","mockedLogosTim","tim_viva_ticket_logo","tim_asos_logo","tim_air_bnb_logo","sephora_logo","tim_leroy_merlin_logo","tim_decathlon_logo","tim_euronics_logo","tim_zalando_logo","icons","new","discounts_and_savings","KindredIcon","default","defaultProps","minWidth","Flex","align","dir","rest","alignItems","flexDirection","display","Center","justifyContent","useClickOutside","useDisclosure","setOpen","onOpen","onClose","onToggle","useQuery","search","useLocation","React","useMemo","URLSearchParams","useScrollTo","reference","useCallback","scrollIntoView","trackPageAnnonymous","pageName","properties","partnerID","userAgent","navigator","userID","getLocalUserID","axios","post","api_url","Properties","UserAgent","PageName","trackActionAnnonymous","actionName","ActionName","USER_SESSION_ID","PartnerIDS","TIM","tim_partner_id","Kindred","kindred_partner_id","hasTrackedOnSession","pageViewSession","sessionTracked","sessionName","trackedPagesArray","sessionStorage","getItem","split","filter","Boolean","includes","setItem","join","localUserID","location","get","uuidv4","getPlatform","isMobile","isIOS","isTablet","getBrowserName","getOperatingSystem","os","agent","deviceDetect","getUA","osName","osVersion","getDevice","toLowerCase","mobileVendor","mobileModel","trim","browserName","getPartnersStandardProps","partner","Partner","Platform","OperatingSystem","Browser","Device","trackClickedActionEvent","query","label","trackPartnerActionEvent","Label","eventName","ksource","KSOURCE","Ksource","ANALYTICS_PAGE_NAMES","usePageViewTracking","entryTime","actionTrackedOnVisibility","setActionTrackedOnVisibility","trackTimeSpent","timeSpent","getTime","TimeSpent","toFixed","handleVisibilityChange","document","visibilityState","trackPageViewForPartner","StyledModal","CoreModal","Modal","onEscapeKeydown","onBackgroundClick","handleEscapeKeydown","handleBackgroundClick","Heading","StyledHeadingArrowInCircle","P","DescriptionModal","onHide","Button","Button1","disabled","borderRadius","padding","border","fontWeight","cursor","userAgentContains","str","RegExp","isAndroid","isMac","MOBILE_OS","platform","chrome","chrome_extension_store_url","browser","detect","BoldParagraph","ModalButton","ImageContainer","Description","hiddenInput","imgContainerRef","size","StyledButton1","focus","defaultValue","KeyboardInstallationGuide","KindredLogo","buttonColorTypes","buttonTypes","primary","secondary","CustomButton","colorType","backgroundColor","borderColor","Logo","step","AndroidGuideImages","guidStep","Input","input","List","ol","steps","useUrlParams","useParams","Number","setStep","openApp","appHost","appScheme","appPackage","handleIncrementStep","stepDetail","length","counterReset","fontSize","AndroidKeyboardInstallationGuide","StyledImage","IconContentContainer","IconContentDescription","WhatYouNeedText","ContentItem","BodyContentContainer","AllowBothText","bounce","StyledTapHereImage","FirstA","span","SecondA","DescriptionWithiOS18Support","overrideBackToAppButtonVisibility","supportsiOS18","parseInt","renderArabicVersion","language","showBackToApp","setShowBackToApp","origin","messageHandler","message","data","reload","Trans","i18nKey","getStepListImage","marginTop","clsx","getTapIconImage","DisclaimerSubText","DisclaimerSubTextContainer","StyledImageContainer","StyledButtonContainer","DescriptionWithBrowserNotSupported","copyToClipboard","alertMessage","clipboard","writeText","then","alert","tempInput","createElement","value","body","appendChild","select","execCommand","removeChild","boxShadow","fontFamily","HyperisePlaceholderContainer","fadeIn","PartnerPluginActivateBase","showNotSupportedWarning","setShowNotSupportedWarning","setOverrideBackToAppButtonVisibility","notSafariOverride","isSafari","gradient","OvalContainer","Body","BodyGradient","showBodyGradient","sliide","sliideSubtitle","HeaderText","textWidth","paddingTop","BoldText","SliideHeaderSubtitile","MultiStepActivationContainer","gradientBackground","headerText","headerTextTopPadding","headerTextColor","headerTextWidth","Helmet","sizes","sliideFavIcon","isCurrent","TAP_HERE_IMAGES","bottom","kindred","TapHereAnimated","showAtBottom","setShowBottom","image","imagesToShow","version","test","v","getiOSVersion","showAtTop","MultiStepHeaderText","h3","SubTitleTextContainer","SubTitleText","LinkText","TextTitleContainer","StrongText","strong","addSliideText","PartnerPluginActivateMultiStep","initialHeight","innerHeight","interval","setInterval","PluginActivationReviewPermissions","givenPermission","PluginActivationStartShopping","PluginActivationAllowPermissions","clearInterval","CommonInputCss","useLanguageUtm","alternate","url","URL","searchParams","has","append","StyledFlex","Paragraph","PoweredByKindred","hasInfo","showInfo","setShowInfo","usePageTitle","params","partnerTitle","hasSliideOrigin","PartnerpluginsdkActivate","hasExperimentOrigin","setHasExperimentOrigin","hasKindredOrigin","ScrollToTop","EXTENSION_SDK_RANDOM_USER_ID_NAME","KK_UTM_SOURCE","KK_UTM_COMPAIGN","KK_UTM_MEDIUM","getUtmParamsForChromeExtension","utmSource","localStorage","utmCampaign","utmMedium","getPartnerSamsungProps","result","JSON","parse","usePartnerSamsungQueryParamExtraction","partnerSamsungProps","partnerId","userId","userCurrency","userCountryCode","stringify","Slides","activeIndex","Slide","PillsContainer","Pill","active","SubTextContainer","SubText","maxWidth","PostActivationSlide","setActiveIndex","startX","setStartX","intervalRef","slides","prevIndex","onTouchStart","touches","clientX","onTouchEnd","deltaX","changedTouches","index","_","AllDone","SaveWhileDoingGood","ExperienceSavings","ContentContainer","imageStyle","PostActivationPage","SamsungActivation","set","usePartnerSamsungParams","ExtensionLink","ExtensionInstallLink","buttonText","LinearGradient","HeadingContainer","StyledExtensionInstallLink","MinimalHeader","uninstallHeading","TextContainer","StyledList","selectedIndex","itemsCount","ListItem","li","Screenshot","Item","Items","onItemClicked","i","HowItWorks","currentItemIndex","setCurrentItemIndex","getBrowserCountry","countryCode","getBrowserISOCountry","getLocationCurrency","currency","localeCurrency","getCurrency","knownCurrencies","timezone","Intl","DateTimeFormat","resolvedOptions","timeZone","country","ct","getCountryForTimezone","firebaseConfig","apiKey","firebase_api_key","authDomain","firebase_auth_domain","projectId","firebase_project_id","storageBucket","firebase_storage_bucket","messagingSenderId","appId","firebase_app_id","app","initializeApp","defaultState","wallet","autoActivation","offerwall","loading","FeaturesContext","createContext","defaultPartnerFeatureFlags","FeaturesProvider","setLoading","setAutoActivation","setOfferwall","setWallet","setFeatures","features","setter","feature","countries","getRemoteConfig","remoteConfig","settings","minimumFetchIntervalMillis","defaultConfig","ensureInitialized","fetchAndActivate","getValue","partner_features_remote_config","partnerFeatureFlagsStr","partnerFeatureFlags","asString","fetchRemoteConfig","Provider","MoreQuestions","howItWorksItems","shop","save","safe","ExtensionInstalled","useContext","utmParams","runtime","sendMessage","kindred_extension_id","sendExtensionInstalled","browserCountry","randomUserId","getRandomUserId","setKindredUser","error","sendPartnerFeatures","StyledTypeform","ExtensionUninstalled","typeformRef","typeformEmbed","extension_uninstall_typeform_id","hideFooter","hideHeaders","hideScrollbars","onSubmit","paddingLeft","onReady","SamsungLanding","samsung_plugin_install_link","marginBottom","apiGet","response","treesPlanted","tonnesOfCo2","squareMeteresOfIceSaved","milesDriven","showTreesPlantedByPartner","todaysTreePlantingTick","TreePlantingContext","useTreePlantedContext","TreePlantingContextProvider","pathSuffix","setData","setError","fetchData","useApiGet","totalNumberOfTreesPlanted","partnerLogo","parnerId","partnerName","InnerContentContainer","IconContainer","Icon","Value","EquivalentSection","getDecimal","isInteger","cloud","decimals","start","end","duration","iceburg","HeroContainer","HeroBottomContainer","HeroBottomRoundContainer","HeroImage","LogoImage","HeaderContainer","HeaderTextBold","TressAmountContainer","TreesPlantedText","TreesText","TreesPlantedAmount","Hero","bgImage","subText","imgSrc","cdn_url","kindredLogo","IconsContainer","HowDoesItWork","DescriptionHeader","DescriptionText","DescriptionContainer","DescriptionIcon","RecentProjects","Peru","Tanzania","Congo","PartnersContainer","TreeLocationsMap","StyledURSLogo","StyledVerifiedCarbonLogo","StyledCnbLogo","StyledDotsEcoLogo","StyledEarthmarkLogo","WhereAreTreesPlanted","treeLocations","urs","verifiedCarbon","dotsEco","TreePlanting","heroMobile","heroImage","TreesFunded","totalNumOfTrees","h2","marginRight","Image","trees","main","numOfTreesToday","partnerMapping","etisalat","etisalat_partner_id","urlParams","partnerDetails","renderTreePlantingContent","StyledLoadingIndicator","ChromeDesktopUTMTracking","utm_source","utm_campaign","utm_medium","ListContent","BorderedItem","PartnerPluginActivateMultiStepAlwaysAllow","analytics","getAnalytics","logEvent","permissions","MultiStepStyledButton","MultiStepStyledTransparentButton","PartnerPluginActivateMultiStepAlmostThere","PluginActivationUpdatePermissions","BeSureToAllowSlide","StyledContainer","PartnerPluginActivateMultiStepBeSureToAllow","PartnerPluginActivateMultiStepStartShopping","itvColors","bodyMarginTop","StyledBrandedIcon","itvIcon","itv","PluginActivationV2AlwaysAllow","PluginActivationV2StartShopping","itv_ios_appstore_link","PartnerNewpluginsdkActivate","LinkRedirect","kindred_website","AlwayAllowImage","PartnerNewPluginActivateMultiStepAlwaysAllow","PluginActivationV2PartialPermissions","PartnerNewPluginActivateMultiStepPartialPermissions","Row","itemWidth","itemHeight","PyramidGrid","numRows","maxItemsAtBase","renderItem","rows","itemIndex","rowItems","numItemsInRow","abs","j","MainText","CashSaverBrandsContainer","CashSaverBrands","mainText","mainTextClassName","headerTextClassName","noPaddingTop","sampleImages","values","Array","from","FrequentlyAskedQuestion","PartnerNewPluginActivateMultiStepAllDone","ItvSquareLogo","KK_UTM_KSOURCE","LogoTextContainer","DisclaimerContainer","Disclaimer","permissionsAgreed","disclaimerText","margin","StyledLoader","WhiteButton","Msg","StepsContainer","StepItem","StepTag","StepText","ActivationSteps","msg","ButtonsContainer","CashSaverMsg","FaqLink","ActivateNow","navigateToSettings","cashSaverPopUpMsg","close","BottomContent","AndroidAccessibility","KindredAndroid","ItvLogo","DominosLogo","LeftSection","RightSection","SponseredText","StandardHeader","Section","CloseIcon","CashSaverHeader","ITVLayout","showHeader","isEmbeddedInAndroid","getActivationButtonStatusMsg","getExtensionInstallMsg","getDesktopExtensionInstallButtonLink","safari_extension_store_url","DesktopDownloadContainer","DesktopDownloadText","StatusMsgContainer","StatusMsgContent","StatusMsg","Triangle","InfoIcon","CashSaver","desktopDownloadText","desktopDownloadButtonText","installExtensionLink","onInstallClick","FaqQuestionsContainer","FaqItem","FaqQuestion","FaqCircle","Faq","faqs","linkText","faq","question","ButtonTextGroup","ButtonContainer","DownloadAppMsg","buttonType","undefined","ActivateCashSaverInfoContainer","ActivateCashSaverInfo","ActivationButtons","buttonStatusMsg","PluginActivationReviewPermissionsV2","PluginActivationV2ActivatePlugin","PluginActivationV2","itv_android_appstore_link","TextContent","ColoredTextContent","FaqContainer","ITVActivation","answer","PartnerPluginActivateV2","utmKSource","handleKSourceUTMParameter","ITVAndroidAddUnit","ITVLP","usePluginActivationUTMQueryParamExtraction","renderContent","SearchIcon","TextInput","SearchIconContainer","Search","placeholder","onSearch","onChange","currentTarget","CatetoryItem","isSelected","setSelectedOption","option","getName","inline","Categories","options","selectedOption","containerRef","console","log","offsetWidth","BrandItem","Brands","brands","getUniqueList","list","Set","Main","OfferWall","documentDir","searchKey","setSearchKey","selectedCategory","setSelectedCategory","categories","setCategories","allBrands","flatMap","category","documentElement","initPageData","initPageDir","find","unshift","arabicName","brand","getBrandsToShow","uniqueBrands","sort","brand1","brand2","localeCompare","uniqueCategoryOptions","onCloseSearch","NavBar","BackIcon","TimTopNavigation","i18n","changeLanguage","back","MainContent","TitleText","KindredDisclaimerContainer","KindredDisclaimerContainerText","PolicyDisclaimer","TIMActivationHome","timIcon","PuzzlePieceBackground","tabIndex","TimPluginActivationActivatePlugin","webkit","messageHandlers","messageHandlerForiOS","postMessage","sendDataToiOS","payload","site","toString","couponCode","TIMAndroidActivationHome","toLocaleUpperCase","Download","y","rx","Toggle","cx","cy","r","DisclosureContainer","Disclosure","FooterTitle","ActivationStep","toggleIconStyle","downloadIconStyle","marginLeft","installationSteps","go","cloudBlue","darkCloudBlue","darkRoyalBlue","timColors","SubHeaderText","StyledBrandedImage","ImageWrapper","headerShadow","successPageView","subHeaderText","partialPageView","showRoyalBlueBackground","showSmallHeight","showSuccessPageHeight","shadow","whiteBackground","TapAATextContainer","FloatingUnionImage","currentHeight","difference","TimPluginActivationAlwaysAllow","TimPluginActivationStartShopping","TimPluginActivationPartialPermissions","PartnerNewpluginsdkActivateTim","PartnerNewPluginActivateTimMultiStepAlwaysAllow","PaddingLeft","PartnerNewPluginActivateTimMultiStepPartialPermissions","PartnerNewPluginActivateTimMultiStepAllDone","tim_app_scheme","Routes","fallback","exact","PluginActivation","TimPluginActivationAndroidStartShopping","TIMHomePage","EtisalatOfferWall","EtisalatOfferWallArabic","ChromeExtensionDownload","MobileGame","CharitiesWithAnApp","Cashback","MobileApp","MobileNetwork","Keyboard","App","hyperise","I18nextProvider","position","SUPPORT_TEAM_EMAIL","support_team_email","MAIL_TO","TextBlock","ErrorMessage","ErrorBoundary","hasError","this","Component","ReactDOM","render","getElementById","TagManager","initialize","gtmId","gtm_id"],"mappings":"iJAAA,OAAe,4mL,0wGCAf,OAAe,gnD,6BCAf,OAAe,ozR,sCCAf,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,gD,6BCAzC,OAAe,giP,6BCAf,OAAe,wwD,6BCAf,OAAe,cAA0B,wC,6BCAzC,OAAe,cAA0B,kC,6BCAzC,OAAe,oyC,6BCAf,OAAe,cAA0B,sC,6BCAzC,OAAe,woX,6BCAf,OAAe,wuP,6BCAf,OAAe,o/T,6BCAf,OAAe,gnO,6BCAf,OAAe,g/P,6BCAf,OAAe,cAA0B,mC,6BCAzC,OAAe,cAA0B,8D,u972CCAzC,OAAe,cAA0B,mD,6BCAzC,OAAe,cAA0B,iC,6BCAzC,OAAe,cAA0B,qC,6BCAzC,OAAe,cAA0B,wC,6BCAzC,OAAe,wzB,6BCAf,OAAe,w5C,6BCAf,OAAe,o3W,6BCAf,OAAe,cAA0B,mC,6BCAzC,OAAe,cAA0B,uD,6BCAzC,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,gD,6BCAzC,OAAe,cAA0B,gD,6BCAzC,OAAe,cAA0B,+C,6BCAzC,OAAe,cAA0B,+C,6BCAzC,OAAe,cAA0B,+C,6BCAzC,OAAe,cAA0B,oC,6BCAzC,OAAe,o1D,6BCAf,OAAe,cAA0B,sC,6BCAzC,OAAe,cAA0B,8C,6BCAzC,OAAe,cAA0B,4C,6BCAzC,OAAe,4zF,6BCAf,OAAe,omG,6BCAf,OAAe,o+G,6BCAf,OAAe,cAA0B,4C,6BCAzC,OAAe,cAA0B,4C,6BCAzC,OAAe,cAA0B,4C,6BCAzC,OAAe,o4I,6BCAf,OAAe,orG,6BCAf,OAAe,4lJ,6BCAf,OAAe,ogI,6BCAf,OAAe,4rG,6BCAf,OAAe,wtD,6BCAf,OAAe,wwG,6BCAf,OAAe,4iJ,6BCAf,OAAe,gnE,6BCAf,OAAe,cAA0B,yC,6BCAzC,OAAe,cAA0B,yC,6BCAzC,OAAe,cAA0B,yC,6BCAzC,OAAe,cAA0B,oC,6BCAzC,OAAe,cAA0B,mC,6BCAzC,OAAe,glT,6BCAf,OAAe,wxN,6BCAf,OAAe,wiQ,6BCAf,OAAe,opS,6BCAf,OAAe,40R,6BCAf,OAAe,41P,6BCAf,OAAe,ozS,6BCAf,OAAe,gwT,6BCAf,OAAe,orF,6BCAf,OAAe,wzC,6BCAf,OAAe,orC,6BCAf,OAAe,cAA0B,qD,6BCAzC,OAAe,cAA0B,mD,6BCAzC,OAAe,cAA0B,0D,6BCAzC,OAAe,cAA0B,0D,6BCAzC,OAAe,cAA0B,6D,6BCAzC,OAAe,wgH,6BCAf,OAAe,o9L,6BCAf,OAAe,cAA0B,gD,6BCAzC,OAAe,ogE,6BCAf,OAAe,4hQ,6BCAf,OAAe,g+E,6BCAf,OAAe,4yD,6BCAf,OAAe,owO,6BCAf,OAAe,w7G,6BCAf,OAAe,w2D,6BCAf,OAAe,glE,6BCAf,OAAe,ggF,6BCAf,OAAe,41F,6BCAf,OAAe,4zL,6BCAf,OAAe,wpO,6BCAf,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,2C,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,ovG,6BCAf,OAAe,cAA0B,0C,6BCAzC,OAAe,cAA0B,uD,6BCAzC,OAAe,cAA0B,mD,6BCAzC,OAAe,cAA0B,mD,6BCAzC,OAAe,cAA0B,mD,6BCAzC,OAAe,wpH,6BCAf,OAAe,wlV,6BCAf,OAAe,ovB,6BCAf,OAAe,orB,6BCAf,OAAe,gZ,6BCAf,OAAe,cAA0B,kD,6BCAzC,OAAe,wkE,6BCAf,OAAe,o8R,6BCAf,OAAe,cAA0B,6C,6BCAzC,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,+C,6BCAzC,OAAe,o/K,6BCAf,OAAe,owB,6BCAf,OAAe,cAA0B,iD,6BCAzC,OAAe,cAA0B,kD,6BCAzC,OAAe,cAA0B,+C,6BCAzC,OAAe,w7I,6BCAf,OAAe,4kL,6BCAf,OAAe,o9G,6BCAf,OAAe,g0F,6BCAf,OAAe,g7H,6BCAf,OAAe,gxI,6BCAf,OAAe,woC,6BCAf,OAAe,ouH,6BCAf,OAAe,g8F,6BCAf,OAAe,wyH,6BCAf,OAAe,otG,0BCAf,IAAIA,EAAM,CACT,aAAc,IACd,mBAAoB,IAC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","file":"static/js/main.4137e677.chunk.js","sourcesContent":["export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/purple_kindred_icon.4ffc1cb1.png\";","export default __webpack_public_path__ + \"static/media/black_kindred_icon.06299f94.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/john_lewis.e3c3b565.png\";","export default __webpack_public_path__ + \"static/media/asos.043feae0.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/typewise.357b9d33.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/unity.a03c74b7.png\";","export default __webpack_public_path__ + \"static/media/O2-bubble-3D-animations-04@05x 1.f5ae65dc.png\";","export default __webpack_public_path__ + \"static/media/discounts-and-savings.8f2adde9.png\";","export default __webpack_public_path__ + \"static/media/ios.1a573cac.png\";","export default __webpack_public_path__ + \"static/media/android.86fe336e.png\";","export default __webpack_public_path__ + \"static/media/aliexpress.e6d5e4a4.png\";","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/teamo.b06f096b.png\";","export default __webpack_public_path__ + \"static/media/settings activate kindred.d574b87e.png\";","export default __webpack_public_path__ + \"static/media/settings menu.77d85e4d.png\";","export default __webpack_public_path__ + \"static/media/settings permission.97b433c7.png\";","export default __webpack_public_path__ + \"static/media/plugin-alpha-step2.df3623af.jpg\";","export default __webpack_public_path__ + \"static/media/plugin-alpha-step3.2d3631e1.jpg\";","export default __webpack_public_path__ + \"static/media/plugin-beta-step1.24638bb1.gif\";","export default __webpack_public_path__ + \"static/media/plugin-beta-step2.5fc4285e.gif\";","export default __webpack_public_path__ + \"static/media/plugin-beta-step3.396c1e17.gif\";","export default __webpack_public_path__ + \"static/media/mobile.5557f733.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/dealsApi.af93875b.png\";","export default __webpack_public_path__ + \"static/media/desktopExtension.10030998.png\";","export default __webpack_public_path__ + \"static/media/mobileKeyboard.e123e576.png\";","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/android-guide1.9dcf3775.png\";","export default __webpack_public_path__ + \"static/media/android-guide2.2e1ca8ff.png\";","export default __webpack_public_path__ + \"static/media/android-guide3.485587a3.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/ourMission1.dc1bea68.png\";","export default __webpack_public_path__ + \"static/media/ourMission2.cce53f67.png\";","export default __webpack_public_path__ + \"static/media/ourMission3.5c5dbf6e.png\";","export default __webpack_public_path__ + \"static/media/amazon.3de9eb21.png\";","export default __webpack_public_path__ + \"static/media/levis.0d68f3cc.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/safari-activation-steps.f770b767.png\";","export default __webpack_public_path__ + \"static/media/safari-settings-steps.d11b8b80.png\";","export default __webpack_public_path__ + \"static/media/safari-settings-steps-ios-18.8c28d5a8.png\";","export default __webpack_public_path__ + \"static/media/safari-settings-steps-ios-aa.d98da881.png\";","export default __webpack_public_path__ + \"static/media/safari-settings-steps-ios-aa-ar.0b381ca5.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/tap-here-ios-18-ar.fb2d7ba7.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/be-sure-step1.aba417f2.png\";","export default __webpack_public_path__ + \"static/media/be-sure-step2.f09ddf8d.png\";","export default __webpack_public_path__ + \"static/media/be-sure-step3.efecc2df.png\";","export default __webpack_public_path__ + \"static/media/be-sure-step4.14473621.png\";","export default __webpack_public_path__ + \"static/media/be-sure-step5.c70b7507.png\";","export default __webpack_public_path__ + \"static/media/be-sure-stepsliide1.2bcc9415.png\";","export default __webpack_public_path__ + \"static/media/be-sure-stepsliide2.ec4c062c.png\";","export default __webpack_public_path__ + \"static/media/be-sure-stepsliide3.6cf1dc3e.png\";","export default __webpack_public_path__ + \"static/media/be-sure-stepsliide4.642e1e57.png\";","export default __webpack_public_path__ + \"static/media/be-sure-stepsliide5.48003ed7.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/brandssliide.95f0a7fd.png\";","export default __webpack_public_path__ + \"static/media/tim-ios-activation-review.1f20ad0b.gif\";","export default __webpack_public_path__ + \"static/media/tim-ios-activation-aa.7bca93d0.gif\";","export default __webpack_public_path__ + \"static/media/tim-ios-activation-18.10a1c8a9.gif\";","export default __webpack_public_path__ + \"static/media/tim-ios-partial-steps.8b3144ad.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/tim-ios-success-icon.92523e9e.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/tim-safari-icon.97783d3d.png\";","export default __webpack_public_path__ + \"static/media/safari-browser-logo.450e3a9c.png\";","export default __webpack_public_path__ + \"static/media/tim-settings-icon.b6c2dbbc.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/samsung-deals-found.e6b1320c.png\";","export default __webpack_public_path__ + \"static/media/samsung-saved-so-far.97d93f2e.png\";","export default __webpack_public_path__ + \"static/media/samsung-you-saved.d24658d3.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","var map = {\n\t\"./aldo.png\": 288,\n\t\"./aliexpress.png\": 289,\n\t\"./alsaadhome.png\": 290,\n\t\"./amazon.png\": 291,\n\t\"./asos.png\": 292,\n\t\"./babyshop.png\": 293,\n\t\"./basharacare.png\": 294,\n\t\"./bathandbody.png\": 295,\n\t\"./boots.png\": 296,\n\t\"./boutiqaat.png\": 297,\n\t\"./brandsforless.png\": 298,\n\t\"./carrefour.png\": 299,\n\t\"./centrepoint.png\": 300,\n\t\"./chicpoint.png\": 301,\n\t\"./cider.png\": 302,\n\t\"./crocs.png\": 303,\n\t\"./danubehome.png\": 304,\n\t\"./desertcart.png\": 305,\n\t\"./doduae.png\": 306,\n\t\"./dyson.png\": 307,\n\t\"./eyewa.png\": 308,\n\t\"./farfetch.png\": 309,\n\t\"./firstcry.png\": 310,\n\t\"./fordeal.png\": 311,\n\t\"./groupon.png\": 312,\n\t\"./handm.png\": 313,\n\t\"./hibobi.png\": 314,\n\t\"./homebox.png\": 315,\n\t\"./homecentre.png\": 316,\n\t\"./homesrus.png\": 317,\n\t\"./hudabeauty.png\": 318,\n\t\"./iherb.png\": 319,\n\t\"./letstango.png\": 320,\n\t\"./levelshoes.png\": 321,\n\t\"./lifepharmacy.png\": 322,\n\t\"./lightinthebox.png\": 323,\n\t\"./lulushopping.png\": 324,\n\t\"./maxfashion.png\": 325,\n\t\"./modanisa.png\": 326,\n\t\"./mumzworld.png\": 327,\n\t\"./namshi.png\": 328,\n\t\"./next.png\": 329,\n\t\"./nike.png\": 330,\n\t\"./noon.png\": 331,\n\t\"./ounass.png\": 332,\n\t\"./ourshopee.png\": 333,\n\t\"./puma.png\": 334,\n\t\"./randbfashion.png\": 335,\n\t\"./sephora.png\": 336,\n\t\"./sharafdg.png\": 337,\n\t\"./shein.png\": 338,\n\t\"./sivvi.png\": 339,\n\t\"./sixthstreet.png\": 340,\n\t\"./smartbuyglasses.png\": 341,\n\t\"./splashonline.png\": 342,\n\t\"./storeus.png\": 343,\n\t\"./styli.png\": 344,\n\t\"./sunandsandsports.png\": 345,\n\t\"./temu.png\": 346,\n\t\"./toysrus.png\": 347,\n\t\"./trendyol.png\": 348,\n\t\"./underarmour.png\": 349,\n\t\"./vogacloset.png\": 350,\n\t\"./wish.png\": 351\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 287;","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/alsaadhome.20acb3c7.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/babyshop.63c66880.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/desertcart.946e8339.png\";","export default __webpack_public_path__ + \"static/media/doduae.dacff909.png\";","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/firstcry.8c3c79e3.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/groupon.f2f8d989.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/hibobi.606b120d.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/letstango.9b0be795.png\";","export default __webpack_public_path__ + \"static/media/levelshoes.92a6f890.png\";","export default __webpack_public_path__ + \"static/media/lifepharmacy.3af3b3c0.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/lulushopping.619007ac.png\";","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/mumzworld.7da1f1aa.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/ourshopee.4c27116d.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/randbfashion.8765dec7.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/splashonline.4d989f19.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/styli.2cde7e29.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import i18next, { Resource } from 'i18next';\nimport translationEN from './translations/en.json';\nimport translationENGB from './translations/en-gb.json';\nimport translationFR from './translations/fr.json';\nimport translationDE from './translations/de.json';\nimport translationES from './translations/es.json';\nimport translationHI from './translations/hi.json';\nimport translationIT from './translations/it.json';\nimport translationJA from './translations/ja.json';\nimport translationKO from './translations/ko.json';\nimport translationPT from './translations/pt.json';\nimport translationRU from './translations/ru.json';\nimport translationAR from './translations/ar.json';\nimport { initReactI18next } from 'react-i18next';\nimport LanguageDetector from 'i18next-browser-languagedetector';\n\nconst debug = process.env.NODE_ENV === 'development';\n\nconst resources: Resource = {\n en: {\n translation: translationEN,\n },\n 'en-GB': {\n translation: translationENGB,\n },\n fr: {\n translation: translationFR,\n },\n de: {\n translation: translationDE,\n },\n es: {\n translation: translationES,\n },\n hi: {\n translation: translationHI,\n },\n it: {\n translation: translationIT,\n },\n ja: {\n translation: translationJA,\n },\n ko: {\n translation: translationKO,\n },\n pt: {\n translation: translationPT,\n },\n ru: {\n translation: translationRU,\n },\n ar: {\n translation: translationAR,\n },\n};\n\ni18next\n .use(LanguageDetector)\n .use(initReactI18next)\n .init({\n resources,\n fallbackLng: 'en',\n debug,\n interpolation: {\n escapeValue: false,\n },\n nsSeparator: false,\n });\n\nexport default i18next;\n","export enum Path {\n CharitiesWithAnApp = '/solutions/charitiesWithAnApp',\n FAQsBrands = '#brands',\n FAQsPartners = '#partners',\n FAQsUsers = '#users',\n FAQsCharities = '#charities',\n Home = '/',\n MobileApp = '/solutions/mobileApp',\n MobileGame = '/solutions/mobileGame',\n MobileNetwork = '/solutions/mobileNetwork',\n Keyboard = '/solutions/keyboard',\n Cashback = '/solutions/cashback',\n UnderTheHood = '/FAQ',\n Loyalty = '/loyalty',\n Revenue = '/revenue',\n ESG = '/esg',\n RequestADemo = '#requestADemo',\n RequestADemoHomepage = '/#requestADemo',\n Network = '/network',\n AboutUs = '/aboutUs',\n Gaming = '/gaming',\n ProductDesktop = '/product/desktop',\n ProductApi = '/product/api',\n GetAPIKey = '#',\n KeyboardInstallationGuide = '/keyboard-activation',\n PluginActivation = '/plugin-activation',\n O2PluginActivation = '/o2/plugin-activation',\n AndroidKeyboardInstallationGuide = '/android/keyboard-activation/:step',\n ProductHome = '/product/home',\n ProductExtension = '/product/extension',\n SamsungLanding = '/samsung',\n SamsungActivation = '/samsung/activation',\n ExtensionInstalled = '/extension-installed',\n ExtensionUninstalled = '/extension-uninstalled',\n TreePlanting = '/tree-planting/:partner?',\n PluginActivationV2 = '/v2/plugin-activation',\n EtisalatOfferWall = '/etisalat/wall',\n EtisalatOfferWallArabic = '/etisalat/wall/arabic',\n TIMActivationHome = '/tim/activation',\n TIMHomePage = '/tim',\n TIMAndroidActivationHome = '/tim/activation-android',\n PluginActivationReviewPermissionsV2 = '/v2/plugin-activation/review-permissions',\n ChromeExtensionDownload = '/chrome/extension-download',\n PluginActivationReviewPermissions = '/plugin-activation/review-permissions',\n PluginActivationUpdatePermissions = '/plugin-activation/update-permissions',\n PluginActivationAllowPermissions = '/plugin-activation/allow-permissions',\n PluginActivationStartShopping = '/plugin-activation/start-shopping',\n PluginActivationV2ActivatePlugin = '/v2/plugin-activation/activate-plugin',\n TimPluginActivationActivatePlugin = '/tim/activation-ios',\n TimPluginActivationAlwaysAllow = '/tim/activation-ios/permissions',\n TimPluginActivationPartialPermissions = '/tim/activation-ios/partial',\n TimPluginActivationStartShopping = '/tim/activation-ios/success',\n TimPluginActivationAndroidStartShopping = '/tim/activation-android/success',\n PluginActivationV2AlwaysAllow = '/v2/plugin-activation/always-allow',\n PluginActivationV2PartialPermissions = '/v2/plugin-activation/partial-permissions',\n PluginActivationV2StartShopping = '/v2/plugin-activation/start-shopping',\n}\n","const colors = {\n semiTransparentBlack: '#00000033',\n black: '#000000',\n white: '#FFFFFF',\n smokeyWhite: '#F1F1F1',\n greyWhite: '#F8F8F8',\n lightestGrey: '#EEEEEE',\n lightGrey: '#CCCCCC',\n midLightGrey: '#A4A4A8',\n midBlue: '#0073A8',\n midGrey: '#A0A0A0',\n grey: '#C4C4C4',\n mediumGrey: '#979797',\n darkGrey: '#767676',\n veryDarkGrey: '#231F20',\n darkestGrey: '#363636',\n purple: '#B6359C',\n darkPurple: '#3B00AD',\n veryDarkPurple: '#170645',\n blue: '#0779E4',\n darkBlue: '#1B2457',\n veryDarkBlue: '#0B1C2F',\n customBlue: '#3478f6',\n pink: '#DE1F70',\n darkPink: '#AC2F64',\n green: '#92E3A9',\n fernGreen: '#4B9A6D',\n lightGreen: '#89C8AA',\n mediumGreen: '#89C8AA',\n darkGreen: '#0E2C38',\n veryDarkGreen: '#0DAA04',\n forestGreen: '#285D49',\n pastelGreen: '#D5EEDE',\n darkestGreen: '#162C15',\n lilac: '#F9FAFF',\n avoGreen: '#89C8AA',\n gray98: '#FAFAFA',\n neutralBlack: '#0B0B0B',\n smokeGrey: '#F7F7F7',\n smokeBlack: '#323A68',\n successGreen: '#52AE67',\n verizonRed: '#F90016',\n verizonGrey: '#7B7777',\n discountsPurple: '#8A2387',\n samsungActivationPillDarkGrey: '#C1C1C1',\n semiDarkGrey: '#868686',\n greyBackground: '#F3F3ED',\n greyText: '#75717F',\n darkBackground: '#232323',\n};\n\nexport default colors;\n","const breakpoints = {\n mobile: 768,\n tablet: 1024,\n};\n\nexport default breakpoints;\n","const colors = {\n greenishBlue: '#102C3D',\n gray: '#D9D9D9',\n darkGray: '#2C2C2C',\n lightGray: '#E7E7E7',\n lightGreen: '#DEEB52',\n textGray: '#DFE1E3',\n lemonGreen: '#E8F753',\n};\n\nexport default colors;\n","import { useState, useEffect } from 'react';\nimport styled, { css, useTheme } from 'styled-components';\nimport colors from './colors';\nimport breakpoints from './breakpoints';\nimport itvThemeColors from './ITVTheme/colors';\n\nexport interface Theme {\n colors: typeof colors;\n breakpoints: typeof breakpoints;\n itvThemeColors: typeof itvThemeColors;\n}\n\ndeclare module 'styled-components' {\n // eslint-disable-next-line @typescript-eslint/no-empty-interface\n interface DefaultTheme extends Theme {}\n}\n\nconst useBreakPoints = () => {\n const { breakpoints } = useTheme();\n\n const [breakpointState, setBreakpointState] = useState(\n Object.entries(breakpoints).reduce(\n (rv, curr) => ({ ...rv, [curr[0]]: false }),\n {}\n ) as Record\n );\n\n useEffect(() => {\n const subscriptions: (() => void)[] = [];\n\n for (const breakpoint of Object.entries(breakpoints)) {\n const match = window.matchMedia(`(max-width: ${breakpoint[1]}px)`);\n\n const handler = (state: { matches: boolean }) => {\n setBreakpointState((prev) => ({\n ...prev,\n [breakpoint[0]]: state.matches,\n }));\n };\n\n match.addListener(handler);\n handler(match);\n\n subscriptions.push(() => match.removeListener(handler));\n }\n\n return () => subscriptions.forEach((x) => x());\n }, [breakpoints]);\n\n return breakpointState;\n};\n\ninterface ThemeProps {\n theme: Theme;\n}\n\nconst mobileMediaQuery = ({ theme }: ThemeProps) =>\n `@media (max-width: ${theme.breakpoints.mobile}px)`;\n\nconst tabletMediaQuery = ({ theme }: ThemeProps) =>\n `@media (max-width: ${theme.breakpoints.tablet}px)`;\n\ntype ColorName = keyof typeof colors;\n\ntype ITVThemeColorName = keyof typeof itvThemeColors;\n\nconst itvThemeColor =\n (color: ITVThemeColorName) =>\n ({ theme }: ThemeProps) =>\n theme.itvThemeColors[color];\n\nconst themeColor =\n (color: ColorName) =>\n ({ theme }: ThemeProps) =>\n theme.colors[color];\n\ninterface BoxShadowProps {\n offset: number;\n blur: number;\n opacity: number;\n spread: number;\n color: string;\n}\n\nconst boxShadow = ({\n offset = 3,\n blur = 7,\n opacity = 0.25,\n spread = 0,\n color,\n}: Partial = {}) => {\n return `box-shadow: ${offset}px ${offset}px ${blur}px ${spread}px ${\n color ?? `rgba(0, 0, 0, ${opacity})`\n };`;\n};\n\nexport const CustomSpacing = styled.div`\n margin-bottom: 100px;\n`;\n\nconst accessibilityFocusStyleLight = `\n&:focus-visible {\n outline: 3px solid #fff;\n text-decoration: none;\n}\n`;\n\nconst accessibilityFocusStyleDark = `\n&:focus-visible {\n outline: 3px solid #051C1C;\n text-decoration: none; \n}\n`;\n\nconst theme: Theme = {\n colors,\n breakpoints,\n itvThemeColors,\n};\n\nexport {\n theme,\n mobileMediaQuery,\n tabletMediaQuery,\n themeColor,\n useBreakPoints,\n boxShadow,\n itvThemeColor,\n accessibilityFocusStyleDark,\n accessibilityFocusStyleLight,\n};\n\nexport const FullBleed = css`\n box-shadow: 0 0 0 100vmax ${themeColor('darkBlue')};\n clip-path: inset(0 -100vmax);\n`;\n","export enum HashLinkPathsIds {\n FAQsPartners = 'partners',\n FAQsBrands = 'brands',\n FAQsUsers = 'users',\n FAQsCharities = 'charities',\n HowDoesItWork = 'howDoesItWork',\n OurSolutions = 'ourSolutions',\n RequestADemo = 'requestADemo',\n Root = 'root',\n}\n","import React, { useState, useEffect } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport Skeleton from 'react-loading-skeleton';\nimport { themeColor } from '../Theming';\n\nconst animation = keyframes`\n 0% {\n transform: scale(0.95);\n }\n 5% {\n transform: scale(1.1);\n }\n 39% {\n transform: scale(0.85);\n }\n 45% {\n transform: scale(1);\n }\n 60% {\n transform: scale(0.95);\n }\n 100% {\n transform: scale(0.9);\n }\n`;\n\nconst Container = styled.div`\n width: 100%;\n height: 100%;\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n\n & > div {\n display: inline-block;\n position: relative;\n width: 80px;\n height: 80px;\n transform: rotate(45deg);\n transform-origin: 40px 40px;\n\n & div {\n top: 32px;\n left: 32px;\n position: absolute;\n width: 32px;\n height: 32px;\n background: ${themeColor('purple')};\n animation: ${animation} 1.2s infinite cubic-bezier(0.215, 0.61, 0.355, 1);\n }\n & div:after,\n & div:before {\n content: ' ';\n position: absolute;\n display: block;\n width: 32px;\n height: 32px;\n background: ${themeColor('purple')};\n }\n & div:before {\n left: -24px;\n border-radius: 50% 0 0 50%;\n }\n & div:after {\n top: -24px;\n border-radius: 50% 50% 0 0;\n }\n }\n`;\nconst scale = keyframes`\n 0%,\n 20%,\n 80%,\n 100% {\n transform: scale(0.5);\n }\n 50% {\n transform: scale(1);\n }\n`;\n\nconst SpinnerContainer = styled.div`\n display: inline-block;\n position: relative;\n width: 40px;\n height: 40px;\n\n & div {\n position: absolute;\n width: 8px;\n height: 8px;\n background: ${themeColor('darkestGrey')};\n border-radius: 50%;\n animation: ${scale} 1s linear infinite;\n }\n & div:nth-child(1) {\n animation-delay: 0s;\n top: 2px;\n left: 16px;\n }\n & div:nth-child(2) {\n animation-delay: -0.125s;\n top: 6px;\n left: 6px;\n }\n & div:nth-child(3) {\n animation-delay: -0.25s;\n top: 16px;\n left: 2px;\n }\n & div:nth-child(4) {\n animation-delay: -0.375s;\n bottom: 6px;\n left: 6px;\n }\n & div:nth-child(5) {\n animation-delay: -0.5s;\n bottom: 2px;\n left: 16px;\n }\n & div:nth-child(6) {\n animation-delay: -0.625s;\n bottom: 6px;\n right: 6px;\n }\n & div:nth-child(7) {\n animation-delay: -0.75s;\n top: 16px;\n right: 2px;\n }\n & div:nth-child(8) {\n animation-delay: -0.875s;\n top: 6px;\n right: 6px;\n }\n`;\n\ninterface CoreLoadingIndicatorProps {\n show: boolean;\n className?: string;\n}\n\nconst HeartLoadingIndicator: React.FC = ({\n show,\n className,\n}) => {\n if (!show) {\n return null;\n }\n return (\n \n
\n
\n
\n
\n );\n};\n\nconst SpinnerLoadingIndicator: React.FC = ({\n show,\n className,\n}) => {\n if (!show) {\n return null;\n }\n return (\n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n );\n};\n\nconst SkeletonLoadingIndicator: React.FC = ({\n show,\n}) => (show ? : );\n\ninterface LoadingIndicatorProps {\n type?: 'heart' | 'skeleton' | 'spinner';\n delay?: number;\n className?: string;\n}\n\nconst LoadingIndicator: React.FC = ({\n type = 'heart',\n delay = 200,\n className,\n}) => {\n const [show, setShow] = useState(delay === 0);\n\n useEffect(() => {\n if (delay === 0) {\n return;\n }\n\n const timeout = setTimeout(() => {\n setShow(true);\n }, delay);\n\n return () => clearTimeout(timeout);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n switch (type) {\n case 'skeleton':\n return ;\n case 'spinner':\n return ;\n default:\n return ;\n }\n};\n\nexport default LoadingIndicator;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Link } from 'react-router-dom';\nimport styled from 'styled-components';\nimport { Path } from '../Routing';\n\nconst Container = styled.div`\n text-align: center;\n margin: 0 2vw;\n flex: 1;\n margin: 32px 0 80px;\n`;\n\nconst Title = styled.h1`\n font-size: 1.125rem;\n font-weight: bold;\n`;\n\nconst Text = styled.p`\n font-size: 0.875rem;\n text-align: center;\n padding: 20px 10px;\n`;\n\nconst NotFound: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n \n {t('notFound.title')}\n {t('notFound.text')}\n {t('notFound.clickHere')}\n {t('notFound.returnHome')}\n \n );\n};\n\nexport default NotFound;\n","import React, { FC, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Link } from 'react-router-dom';\nimport styled, { css } from 'styled-components';\nimport { themeColor } from '../../../Theming';\n\ninterface DropDownProps {\n items: DropDownItemProps[];\n}\n\nconst StyledTooltip = styled.div`\n width: 10px;\n height: 10px;\n border-top: 1px solid ${themeColor('lightGreen')};\n border-left: 1px solid ${themeColor('lightGreen')};\n background-color: ${themeColor('white')};\n position: absolute;\n top: -11px;\n left: 10px;\n transform-origin: 0 100%;\n transform: rotate(45deg);\n`;\n\nconst sharedStyling = css`\n color: ${themeColor('darkestGrey')};\n font-size: 0.875rem;\n line-height: 1.5rem;\n text-decoration: none;\n overflow: hidden;\n flex-shrink: 0;\n text-align: center;\n font-weight: 700;\n\n &.selected::after {\n content: '';\n width: 72px;\n height: 3px;\n border-radius: 1.5px;\n background: ${themeColor('darkestGrey')};\n margin: 10px auto 0;\n display: block;\n }\n &:focus {\n color: ${themeColor('darkestGrey')};\n text-decoration: none;\n }\n`;\n\nconst StyledLink = styled(Link)`\n ${sharedStyling}\n text-align: unset;\n`;\n\nconst StyledDropdownLink = styled(StyledLink)`\n padding: 5px 20px;\n font-weight: 400;\n`;\n\nconst StyledDropdownContainer = styled.div`\n color: ${themeColor('darkestGrey')};\n font-size: 0.875rem;\n line-height: 1.5rem;\n font-weight: 700;\n height: 90px;\n display: flex;\n align-items: center;\n cursor: pointer;\n\n &:hover {\n color: ${themeColor('lightGreen')};\n }\n`;\n\nconst DropdownContainer = styled.div`\n width: 177px;\n min-height: 30px;\n position: absolute;\n top: 76px;\n border: 1px solid ${themeColor('lightGreen')};\n display: flex;\n flex-direction: column;\n flex-wrap: wrap;\n border-radius: 4px;\n padding: 20px 0;\n background-color: ${themeColor('white')};\n`;\n\nexport interface DropDownItemProps {\n text: string;\n link: string;\n}\n\nconst DropDownMenu: FC = ({ items, children }) => {\n const { t } = useTranslation();\n const [showMenu, setShowMenu] = useState(false);\n\n const handleMouseEnter = () => {\n setShowMenu(true);\n };\n\n const handleMouseLeave = () => {\n setShowMenu(false);\n };\n\n return (\n \n {children}\n {showMenu && (\n \n {items.map((item, key) => (\n \n {t(item.text)}\n \n ))}\n \n \n )}\n \n );\n};\n\nexport default DropDownMenu;\n","const env = window.__KINDRED__ENV;\n\nexport default env;\n","import React from 'react';\nimport styled, { css } from 'styled-components';\nimport { useTranslation } from 'react-i18next';\nimport { Path } from '../Routing/Paths';\nimport { themeColor } from '../Theming';\nimport { Link } from 'react-router-dom';\nimport DropDownMenu, {\n DropDownItemProps,\n} from './Components/DropDown/DropDownMenu';\nimport env from '../env';\n\nconst Container = styled.nav`\n display: flex;\n justify-content: flex-end;\n gap: 0 50px;\n align-items: center;\n`;\n\nconst sharedStyling = css`\n color: ${themeColor('darkestGrey')};\n font-size: 0.875rem;\n line-height: 1.5rem;\n text-decoration: none;\n overflow: hidden;\n flex-shrink: 0;\n text-align: center;\n font-weight: 700;\n\n &.selected::after {\n content: '';\n width: 72px;\n height: 3px;\n border-radius: 1.5px;\n background: ${themeColor('darkestGrey')};\n margin: 10px auto 0;\n display: block;\n }\n &:focus {\n color: ${themeColor('darkestGrey')};\n text-decoration: none;\n }\n`;\n\nconst StyledLink = styled(Link)`\n ${sharedStyling}\n text-align: unset;\n\n &:hover {\n color: ${themeColor('lightGreen')};\n }\n`;\n\nconst StyledButtonLink = styled.a`\n ${sharedStyling}\n padding: 0 40px;\n background-color: ${themeColor('darkBlue')};\n color: ${themeColor('white')};\n height: 42.84px;\n border-radius: 29px;\n display: grid;\n place-items: center;\n margin-left: 6px;\n`;\n\ninterface MainMenuProps {\n className?: string;\n}\n\nconst MainMenu: React.FC = ({ className }) => {\n const { t } = useTranslation();\n\n return (\n \n \n {t('navigation.products')}\n \n \n {t('navigation.benefits')}\n \n {t('navigation.gaming')}\n \n {t('navigation.aboutKindred')}\n \n \n {t('navigation.blog')}\n \n \n {t('navigation.bookADemo')}\n \n \n );\n};\n\nexport default MainMenu;\n\nconst BENEFITS_MENU_ITEMS: DropDownItemProps[] = [\n {\n text: 'footer.monetization',\n link: Path.Revenue,\n },\n {\n text: 'navigation.loyalty',\n link: Path.Loyalty,\n },\n {\n text: 'navigation.esg',\n link: Path.ESG,\n },\n];\n\nconst PRODUCTS_MENU_ITEMS: DropDownItemProps[] = [\n {\n text: 'navigation.allProducts',\n link: Path.ProductHome,\n },\n {\n text: 'navigation.mobileExtension',\n link: Path.ProductExtension,\n },\n {\n text: 'navigation.desktopExtension',\n link: Path.ProductDesktop,\n },\n {\n text: 'navigation.dealsApi',\n link: Path.ProductApi,\n },\n];\n\nconst ABOUT_MENU_ITEMS: DropDownItemProps[] = [\n {\n text: 'navigation.aboutKindred',\n link: Path.AboutUs,\n },\n {\n text: 'navigation.ourNetwork',\n link: Path.Network,\n },\n];\n","import React from 'react';\nimport { SvgProps } from '../core';\n\nconst KindredForBusinessLogo: React.FC = ({\n width = 139,\n height = 53,\n className,\n color = '#231F20',\n}) => {\n return (\n \n \n \n \n \n \n \n \n );\n};\n\nexport default KindredForBusinessLogo;\n","import { useTheme } from 'styled-components';\nimport { Theme } from '../../Theming';\n\nexport interface SvgProps {\n className?: string;\n color?: string;\n height?: number;\n style?: React.CSSProperties;\n width?: number;\n strokeWidth?: number;\n}\n\nexport const useDefaultColor = (\n color?: string,\n key: keyof Theme['colors'] = 'darkestGrey'\n) => {\n const { colors } = useTheme();\n\n return color ?? colors[key];\n};\n\nexport interface QuotesSvgProps extends SvgProps {\n type: 'open' | 'closed';\n}\n","import React from 'react';\nimport { SvgProps, useDefaultColor } from '../core';\n\nconst KindredSDKLogo: React.FC = ({\n width = 206,\n height = 32,\n className,\n}) => {\n const resolvedFillColor = useDefaultColor('white');\n const resolvedStrokeColor = useDefaultColor('veryDarkGrey');\n\n return (\n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default KindredSDKLogo;\n","import React from 'react';\nimport { SvgProps, useDefaultColor } from '../core';\n\ninterface ArrowHeadProps extends SvgProps {\n direction?: 'left' | 'right' | 'up' | 'down';\n rotateDimensions?: boolean;\n}\n\nconst transform = {\n up: 'rotate(0deg)',\n down: 'rotate(180deg)',\n left: 'rotate(-90deg)',\n right: 'rotate(90deg)',\n};\n\nconst ArrowHead: React.FC = ({\n color,\n width,\n height,\n style,\n className,\n direction = 'right',\n rotateDimensions = false,\n}) => {\n const resolvedColor = useDefaultColor(color);\n const swapWidthHeight =\n !rotateDimensions && (direction === 'left' || direction === 'right');\n\n return (\n \n \n \n );\n};\n\nexport default ArrowHead;\n","import React from 'react';\nimport { SvgProps, useDefaultColor } from '../core';\n\nconst TRANSFORM = {\n up: 'rotate(180deg)',\n down: 'rotate(0deg)',\n left: 'rotate(90deg)',\n right: 'rotate(-90deg)',\n};\n\ninterface ArrowInCircleProps extends SvgProps {\n direction?: 'left' | 'right' | 'up' | 'down';\n rotateDimensions?: boolean;\n}\n\nconst ArrowInCircle: React.FC = ({\n color,\n width = 32,\n height = 32,\n style,\n className,\n direction = 'down',\n rotateDimensions = false,\n}) => {\n const resolvedColor = useDefaultColor(color);\n const swapWidthHeight =\n !rotateDimensions && (direction === 'left' || direction === 'right');\n\n return (\n \n \n \n );\n};\n\nexport default ArrowInCircle;\n","import React from 'react';\nimport { SvgProps, useDefaultColor } from '../core';\n\nconst Close: React.FC = ({\n color,\n width = 20,\n height = 20,\n style,\n className,\n strokeWidth = 1,\n}) => {\n const resolvedColor = useDefaultColor(color);\n\n return (\n \n \n \n \n \n \n );\n};\n\nexport default Close;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n color: ${themeColor('darkBlue')};\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst BenefitOne: React.FC = ({\n width = 156,\n height = 159,\n className,\n}) => {\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default BenefitOne;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n color: ${themeColor('darkBlue')};\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 109.74px;\n height: 109px;\n }\n`;\n\nconst BenefitThree: React.FC = ({\n width = 149,\n height = 148,\n className,\n}) => {\n return (\n \n \n \n \n \n \n \n );\n};\n\nexport default BenefitThree;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n color: ${themeColor('darkBlue')};\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 104px;\n height: 81.79px;\n }\n`;\n\nconst BenefitTwo: React.FC = ({\n width = 153,\n height = 114,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default BenefitTwo;\n","import React from 'react';\nimport { SvgProps } from '../core';\n\nconst FacebookLogo: React.FC = ({\n width = 13,\n height = 24,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default FacebookLogo;\n","import React from 'react';\nimport colors from '../../../Theming/colors';\nimport { SvgProps, useDefaultColor } from '../core';\n\nconst Hamburger: React.FC = ({\n color = colors.darkestGrey,\n width = 24,\n height = 24,\n style,\n className,\n}) => {\n const resolvedColor = useDefaultColor(color);\n\n return (\n \n \n \n );\n};\n\nexport default Hamburger;\n","import React from 'react';\nimport { SvgProps } from '../core';\n\nconst InstagramLogo: React.FC = ({\n width = 24,\n height = 24,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default InstagramLogo;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst HowItworksDeals: React.FC = ({\n width = 156,\n height = 159,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default HowItworksDeals;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst HowItworksDesktop: React.FC = ({\n width = 156,\n height = 159,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default HowItworksDesktop;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst HowItworksKeyboard: React.FC = ({\n width = 156,\n height = 159,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default HowItworksKeyboard;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst HowItworksMobile: React.FC = ({\n width = 156,\n height = 159,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default HowItworksMobile;\n","import React from 'react';\nimport colors from '../../../Theming/colors';\nimport { SvgProps, useDefaultColor } from '../core';\n\nconst LinkedInLogo: React.FC = ({\n width = 25,\n height = 25,\n className,\n color = colors.smokeyWhite,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default LinkedInLogo;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nconst StyledSVG = styled.svg`\n ${mobileMediaQuery} {\n margin-left: 25px;\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst KeepDataSafe: React.FC = ({\n width = 169,\n height = 204,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default KeepDataSafe;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../../../Theming';\nimport { SvgProps } from '../core';\n\nexport const StyledSVGKeyBenefits = styled.svg`\n ${mobileMediaQuery} {\n width: 105.16px;\n height: 112.19px;\n }\n`;\n\nconst KeyBenefitsImprove: React.FC = ({\n width = 100,\n height = 100,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default KeyBenefitsImprove;\n","import React from 'react';\nimport { SvgProps } from '../core';\n\nconst TwitterLogo: React.FC = ({\n width = 26,\n height = 21,\n className,\n}) => {\n return (\n \n \n \n );\n};\n\nexport default TwitterLogo;\n","import styled from 'styled-components';\n\ninterface UnstyledButtonProps {\n visibility?: string;\n}\n\nconst UnstyledButton = styled.button.attrs(({ type = 'button' }) => ({\n type,\n}))`\n appearance: none;\n border: none;\n background: none;\n cursor: pointer;\n font: inherit;\n padding: 0;\n margin: 0;\n visibility: ${(props) => (props.visibility ? props.visibility : 'visible')};\n\n &:disabled {\n opacity: 1;\n }\n`;\n\nexport default UnstyledButton;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { themeColor } from '../../Theming';\nimport { ArrowHead } from '../../Common/Svg/Icons';\nimport UnstyledButton from '../../Common/Buttons/UnstyledButton';\n\nconst StyledButton = styled(UnstyledButton)`\n border-top: 1px solid ${themeColor('lightestGrey')};\n color: ${themeColor('darkestGrey')};\n font-size: 1rem;\n padding: 16px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n text-transform: uppercase;\n width: 100%;\n`;\n\ninterface MenuButtonProps {\n onClick(): void;\n hideArrow?: boolean;\n arrowDirection?: 'up' | 'down' | 'right';\n}\n\nconst MenuButton: React.FC = ({\n children,\n onClick,\n hideArrow = false,\n arrowDirection = 'right',\n}) => {\n return (\n \n {children}\n {!hideArrow && (\n \n )}\n \n );\n};\n\nexport default MenuButton;\n","import React from 'react';\nimport styled, { css } from 'styled-components';\nimport { themeColor } from '../../Theming';\nimport { Link, LinkProps } from 'react-router-dom';\nimport { ArrowHead } from '../../Common/Svg/Icons';\n\nconst sharedStyling = css`\n border-top: 1px solid ${themeColor('lightestGrey')};\n color: ${themeColor('darkestGrey')};\n font-size: 1rem;\n padding: 16px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n text-decoration: none;\n text-transform: uppercase;\n`;\n\nconst StyledLink = styled(Link)`\n ${sharedStyling}\n`;\n\nexport const StyledMenuButton = styled.a`\n ${sharedStyling}\n`;\n\ninterface MenuLinkProps {\n to: string | LinkProps['to'];\n hideArrow?: boolean;\n target?: LinkProps['target'];\n}\n\nconst MenuLink: React.FC = ({\n children,\n to,\n hideArrow = false,\n target,\n}) => {\n return (\n \n {children}\n {!hideArrow && }\n \n );\n};\n\nexport default MenuLink;\n","import React, { useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { Path } from '../../Routing';\nimport { Link, useRouteMatch } from 'react-router-dom';\nimport MenuButton from './MenuButton';\nimport { themeColor } from '../../Theming';\nimport MenuLink from './MenuLink';\nimport env from '../../env';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n min-height: 100%;\n`;\n\nconst SpaceFiller = styled.div`\n flex: 1;\n`;\n\nconst SubLink = styled(Link)`\n color: ${themeColor('darkestGrey')};\n text-decoration: none;\n padding: 7.5px 0 7.5px 40px;\n\n &:hover {\n text-decoration: underline;\n }\n`;\n\nconst SubLinks = styled.div`\n display: flex;\n flex-direction: column;\n padding: 7.5px 0;\n border-top: 1px solid ${themeColor('lightestGrey')};\n`;\n\ninterface ExpandingMenuItemProps {\n title: string;\n path: string;\n}\n\nconst ExpandingMenuItem: React.FC = ({\n title,\n path,\n children,\n}) => {\n const routeMatch = useRouteMatch(path);\n const [expanded, setExpanded] = useState(routeMatch !== null);\n\n const handleClick = () => {\n setExpanded(!expanded);\n };\n\n return (\n <>\n \n {title}\n \n {expanded && {children}}\n \n );\n};\n\nconst ProductsLevelLinks: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <>\n {t('navigation.allProducts')}\n \n {t('navigation.mobileExtension')}\n \n \n {t('navigation.desktopExtension')}\n \n {t('navigation.dealsApi')}\n \n );\n};\n\nconst BenefitsLevelLinks: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <>\n {t('footer.monetization')}\n {t('navigation.loyalty')}\n {t('navigation.esg')}\n \n );\n};\n\nconst AboutKindredLevelLinks: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <>\n {t('navigation.aboutKindred')}\n {t('navigation.ourNetwork')}\n \n );\n};\n\nconst RootLevelLinks: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <>\n \n \n \n \n \n \n {t('navigation.gaming')}\n \n \n \n \n {t('navigation.blog')}\n \n \n );\n};\n\nconst MenuBody: React.FC = () => {\n return (\n \n \n \n \n );\n};\n\nexport default MenuBody;\n","import React, { useEffect, useState } from 'react';\nimport { useBreakPoints, themeColor } from '../../Theming';\nimport { Hamburger, Close } from '../../Common/Svg/Icons';\nimport styled, { createGlobalStyle } from 'styled-components';\nimport UnstyledButton from '../../Common/Buttons/UnstyledButton';\nimport MenuBody from './MenuBody';\nimport { useHistory, Link } from 'react-router-dom';\nimport KindredSDKLogo from '../../Common/Svg/Logos/KindredSDKLogo';\nimport { Path } from '../../Routing';\nimport { useTranslation } from 'react-i18next';\n\nconst NoScrollOnBody = createGlobalStyle`\n body {\n overflow: hidden;\n }\n`;\n\nconst HamburgerButton = styled(UnstyledButton)`\n padding: 0;\n grid-column: 2 / 3;\n justify-self: flex-end;\n`;\n\nconst CloseButton = styled(UnstyledButton)`\n grid-column: 1 / 1;\n padding: 0;\n justify-self: flex-end;\n width: 24px;\n height: 24px;\n`;\n\nconst MenuContainer = styled.div`\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background: ${themeColor('white')};\n z-index: 100;\n display: grid;\n grid-template-columns: 44px 1fr 44px;\n grid-template-rows: 65px 1fr;\n align-items: center;\n`;\n\nconst ImageLink = styled(Link)`\n grid-area: 1 / 2 / 2 / 3;\n justify-self: center;\n`;\n\nconst MenuBodyContainer = styled.div`\n grid-area: 2 / 1 / 3 / 4;\n padding-bottom: 20px;\n overflow-y: auto;\n align-self: stretch;\n justify-self: stretch;\n`;\n\nconst LogoContainer = styled.h1`\n justify-self: center;\n`;\n\nconst StyledLogo = styled(KindredSDKLogo)`\n width: auto;\n height: 22px;\n`;\n\nconst HamburgerMenu: React.FC = () => {\n const { mobile } = useBreakPoints();\n const [isOpen, setIsOpen] = useState(false);\n const { t } = useTranslation();\n\n useEffect(() => {\n if (!mobile) {\n setIsOpen(false);\n }\n }, [mobile]);\n\n const history = useHistory();\n\n useEffect(() => {\n return history.listen(() => {\n setIsOpen(false);\n });\n }, [history]);\n\n return (\n <>\n setIsOpen(true)}\n aria-label={t('navigation.showMenu')}\n >\n \n \n {isOpen && (\n \n \n setIsOpen(false)}\n aria-label={t('navigation.hideMenu')}\n >\n \n \n \n \n \n \n \n \n \n \n \n )}\n \n );\n};\n\nexport default HamburgerMenu;\n","import React, { useEffect, useRef } from 'react';\nimport styled from 'styled-components';\nimport MainMenu from './MainMenu';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../Theming';\nimport { Link } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport { KindredForBusinessLogo } from '../Common/Svg/Logos';\nimport HamburgerMenu from './HamburgerMenu';\n\nconst HeaderRoot = styled.header`\n background: ${themeColor('white')};\n z-index: 15;\n position: sticky;\n top: 0;\n`;\n\nconst Container = styled.div`\n display: grid;\n grid-template-columns: auto 1fr;\n display: flex;\n justify-content: space-between;\n padding: 25.32px 53px 25.32px 53px;\n width: 100%;\n align-items: center;\n height: 96px;\n max-width: 1440px;\n margin: 0 auto;\n\n ${mobileMediaQuery} {\n grid-template-columns: auto 1fr;\n align-items: center;\n padding: 15px 20px;\n margin: 0 0;\n }\n`;\n\nconst LogoContainer = styled.div`\n grid-column: 1 / 2;\n margin: 0;\n\n ${mobileMediaQuery} {\n grid-column: 1 / 2;\n }\n`;\n\nconst Header: React.FC = () => {\n const { tablet } = useBreakPoints();\n\n const headerRef = useRef(null);\n\n // This is for the sticky header effect, when scrolling upwards from the bottom of the page\n useEffect(() => {\n let lastScrollY = window.scrollY;\n let top = 0;\n\n const handler = () => {\n if (headerRef.current) {\n if (window.scrollY < lastScrollY) {\n if (top < 0) {\n const headerHeight = headerRef.current.clientHeight;\n\n top = Math.min(\n Math.max(-1 * headerHeight, top) + lastScrollY - window.scrollY,\n 0\n );\n }\n } else {\n top -= window.scrollY - lastScrollY;\n }\n\n headerRef.current.style.top = `${top}px`;\n }\n lastScrollY = window.scrollY;\n };\n\n window.addEventListener('scroll', handler, { passive: true });\n\n return () => {\n window.removeEventListener('scroll', handler);\n };\n }, [headerRef]);\n\n return (\n \n \n \n \n \n \n \n {tablet && }\n {!tablet && }\n \n \n );\n};\n\nexport default Header;\n","import React from 'react';\nimport styled from 'styled-components';\nimport {\n socialEnterpriseUK,\n verifiedCarbonStandard,\n carbonNeutral,\n isoCertificate,\n socialEnterpriseUKSmall,\n verifiedCarbonStandardSmall,\n} from '../../../Assets/Footer';\nimport { tabletMediaQuery, useBreakPoints } from '../../../Theming';\n\nconst SocialEnterpriseUK = styled.img`\n width: 110px;\n height: 110px;\n\n ${tabletMediaQuery} {\n width: 28px;\n height: 20px;\n }\n`;\n\nconst StyledVerifiedCarbon = styled.img`\n width: 80px;\n height: 22px;\n margin-right: 11px;\n\n ${tabletMediaQuery} {\n width: 24px;\n height: 25px;\n }\n`;\n\nconst StyledCarbonNeutral = styled.img`\n width: 24px;\n height: 37px;\n margin-right: 11px;\n\n ${tabletMediaQuery} {\n margin-right: 8px;\n }\n`;\n\nconst StyledISOCert = styled.img`\n width: 37px;\n height: 20px;\n margin-right: 11px;\n\n ${tabletMediaQuery} {\n margin-right: 8px;\n }\n`;\n\nconst Logos: React.FC = () => {\n const { tablet } = useBreakPoints();\n\n return (\n <>\n \n \n \n \n \n );\n};\n\nexport default Logos;\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export const scrollWithOffset = (element: Element, yOffset = -70) => {\n const yCoordinate = element.getBoundingClientRect().top + window.pageYOffset;\n window.scrollTo({ top: yCoordinate + yOffset, behavior: 'smooth' });\n};\n","import styled, { css } from 'styled-components';\nimport { HashLink } from 'react-router-hash-link';\nimport { mobileMediaQuery } from '../../../Theming';\n\nconst linkStyle = css`\n margin: 5px 0;\n font-size: 1rem;\n line-height: 1.0625rem;\n margin-bottom: 17px;\n letter-spacing: 0.5px;\n display: block;\n\n &:hover {\n text-decoration: underline;\n }\n`;\n\nexport const StyledA = styled.a`\n ${linkStyle}\n`;\n\nexport const StyledHashLink = styled(HashLink)`\n ${linkStyle}\n`;\n\nexport const Header = styled.h6`\n font-weight: bold;\n font-size: 1.25rem;\n line-height: 1.875rem;\n text-transform: uppercase;\n margin: 27px 0 55px;\n\n ${mobileMediaQuery} {\n margin-bottom: 10px;\n }\n`;\n","import React from 'react';\nimport { HashLinkPathsIds } from '../../../Routing/HashLinkPathIds';\nimport { useTranslation } from 'react-i18next';\nimport { scrollWithOffset } from '../../../Common/Utils/scroller';\nimport { Path } from '../../../Routing';\nimport { StyledHashLink, Header } from './sharedStyles';\n\nconst BenefitLinks: React.FC = () => {\n const { t } = useTranslation();\n\n const handleOffset = (element: Element) => scrollWithOffset(element, -200);\n\n return (\n <>\n
{t('footer.ourBenefits')}
\n \n {t('footer.monetization')}\n \n \n {t('footer.loyalty')}\n \n \n {t('footer.esg')}\n \n \n );\n};\n\nexport default BenefitLinks;\n","import styled from 'styled-components';\nimport { tabletMediaQuery, themeColor } from '../../../Theming';\n\nconst ButtonLink = styled.a`\n border-radius: 29px;\n width: 238px;\n font-size: 0.9375rem;\n line-height: 1.125rem;\n font-weight: bold;\n text-align: center;\n text-decoration: none;\n cursor: pointer;\n padding: 11px 0;\n color: ${themeColor('smokeyWhite')};\n border: 2px solid ${themeColor('smokeyWhite')};\n display: flex;\n justify-content: center;\n\n ${tabletMediaQuery} {\n width: 162px;\n }\n\n &:focus {\n text-decoration: none;\n }\n &:hover {\n box-shadow: 0 1px 6px 0 ${themeColor('smokeyWhite')};\n }\n &:active {\n border: 2px solid ${themeColor('grey')};\n color: ${themeColor('grey')};\n }\n`;\n\nexport default ButtonLink;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { SvgProps } from './Svg/core';\nimport {\n LinkedInLogo,\n TwitterLogo,\n FacebookLogo,\n InstagramLogo,\n} from './Svg/Icons';\nimport env from '../env';\n\nconst SocialContainer = styled.div`\n display: flex;\n align-items: center;\n column-gap: 10px;\n`;\n\nconst SocialLink = styled.a`\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n\n &:last-child {\n margin-right: 0;\n }\n`;\n\ninterface SocialLinkData {\n name: string;\n logo: React.FC;\n link: string;\n}\n\nconst SOCIAL_LINKS: SocialLinkData[] = [\n {\n name: 'LinkedIn',\n logo: LinkedInLogo,\n link: env.linkedin_url,\n },\n {\n name: 'Twitter',\n logo: TwitterLogo,\n link: env.twitter_url,\n },\n {\n name: 'Facebook',\n logo: FacebookLogo,\n link: env.facebook_url,\n },\n {\n name: 'Instagram',\n logo: InstagramLogo,\n link: env.instagram_url,\n },\n];\n\nconst SocialLinks: React.FC = () => {\n return (\n \n {SOCIAL_LINKS.map((s) => (\n \n \n \n ))}\n \n );\n};\n\nexport default SocialLinks;\n","import React from 'react';\nimport { KindredForBusinessLogo } from '../../../Common/Svg/Logos';\nimport SocialLinks from '../../../Common/SocialLinks';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../../Theming';\nimport styled, { useTheme } from 'styled-components';\nimport env from '../../../env';\nimport ButtonLink from '../../../Common/Buttons/Links/ButtonLink';\nimport { useTranslation } from 'react-i18next';\nimport { certifiedBadge } from '../../../Assets/Footer';\n\nexport const MAIL_TO_SDK_COMMERCIAL_TEAM =\n 'mailto:' + env.sdk_commercial_team_email;\n\nconst StyledKindredLogo = styled(KindredForBusinessLogo)`\n display: block;\n margin-bottom: 34px;\n\n ${mobileMediaQuery} {\n margin-bottom: 25px;\n }\n`;\n\nconst StyledButtonLink = styled(ButtonLink)`\n width: 180px;\n margin-top: 103px;\n`;\n\nconst ButtonLinkSecondary = styled(ButtonLink)`\n width: 180px;\n margin-top: 103px;\n background-color: ${themeColor('mediumGreen')};\n margin-left: 25px;\n border: 0px;\n\n ${mobileMediaQuery} {\n margin-top: 20px;\n width: 100%;\n }\n`;\n\nconst RowContainer = styled.div`\n display: flex;\n flex-direction: row;\n`;\n\nconst StyledBadge = styled.img`\n width: 148px;\n height: 85px;\n background-size: contain;\n margin-left: -23px;\n margin-top: -13.05px;\n\n ${mobileMediaQuery} {\n width: 87px;\n height: 54px;\n margin-left: -30px;\n margin-right: 20px;\n }\n`;\n\nconst StyledText = styled.p`\n margin: 5px 0;\n font-size: 1.25rem;\n line-height: 0.875rem;\n margin-bottom: 20px;\n letter-spacing: 0.5px;\n display: block;\n font-weight: 700;\n margin-left: -42px;\n width: 235px;\n line-height: 30px;\n margin-top: -5px;\n\n ${mobileMediaQuery} {\n font-size: 0.875rem;\n letter-spacing: normal;\n margin-bottom: 31px;\n }\n`;\n\nconst StyledRow = styled.div`\n display: flex;\n flex-direction: row;\n\n ${mobileMediaQuery} {\n margin-top: 31px;\n }\n`;\n\nconst WrappedRow = styled.div`\n display: flex;\n flex-direction: row;\n\n ${mobileMediaQuery} {\n flex-direction: column;\n }\n`;\n\nconst Connect: React.FC = () => {\n const { t } = useTranslation();\n const { colors } = useTheme();\n const { tablet } = useBreakPoints();\n return (\n <>\n \n \n \n \n {t('footer.carbonNetural')}\n \n \n \n {!tablet && (\n \n \n {t('footer.contactUs')}\n \n \n {t('footer.getAPIKey')}\n \n \n )}\n \n );\n};\n\nexport default Connect;\n","export default \"\"","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { scrollWithOffset } from '../../../Common/Utils/scroller';\nimport { Path } from '../../../Routing';\nimport env from '../../../env';\nimport { StyledA, StyledHashLink, Header } from './sharedStyles';\nimport { HashLinkPathsIds } from '../../../Routing/HashLinkPathIds';\nimport ButtonLink from '../../../Common/Buttons/Links/ButtonLink';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../../Theming';\nimport { MAIL_TO_SDK_COMMERCIAL_TEAM } from './Connect';\n\nconst StyledButtonLink = styled(ButtonLink)`\n width: 180px;\n margin-top: 103px;\n\n ${mobileMediaQuery} {\n margin-top: 40px;\n }\n`;\n\nconst ButtonLinkSecondary = styled(ButtonLink)`\n width: 180px;\n margin-top: 103px;\n background-color: ${themeColor('mediumGreen')};\n margin-left: 25px;\n border: 0px;\n\n ${mobileMediaQuery} {\n margin-top: 25px;\n margin-left: 0px;\n margin-bottom: 40px;\n }\n`;\n\nconst RowContainer = styled.div`\n display: flex;\n flex-direction: row;\n\n ${mobileMediaQuery} {\n flex-direction: column;\n }\n`;\nconst CompanyLinks: React.FC = () => {\n const { t } = useTranslation();\n const { tablet } = useBreakPoints();\n\n return (\n <>\n
{t('footer.company')}
\n \n {t('legal.about')}\n \n \n {t('legal.sdkDocumentation')}\n \n \n {t('legal.faqs')}\n \n \n {t('legal.privacyPolicy')}\n \n \n {t('legal.termsAndConditions')}\n \n\n {tablet && (\n \n \n {t('footer.contactUs')}\n \n \n {t('footer.getAPIKey')}\n \n \n )}\n \n );\n};\n\nexport default CompanyLinks;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { scrollWithOffset } from '../../../Common/Utils/scroller';\nimport { Path } from '../../../Routing';\nimport { HashLinkPathsIds } from '../../../Routing/HashLinkPathIds';\nimport { Header, StyledHashLink } from './sharedStyles';\n\nconst ProductLinks: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <>\n
{t('footer.ourProducts')}
\n \n {t('footer.mobileBrowserExtension')}\n \n \n {t('footer.desktopExtension')}\n \n \n {t('footer.dealsAPI')}\n \n \n );\n};\n\nexport default ProductLinks;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { useTranslation } from 'react-i18next';\nimport {\n themeColor,\n tabletMediaQuery,\n FullBleed,\n mobileMediaQuery,\n} from '../../Theming';\nimport { getYear } from 'date-fns';\nimport Logos from './Components/Logos';\nimport BenefitLinks from './Components/BenefitLinks';\nimport CompanyLinks from './Components/CompanyLinks';\nimport Connect from './Components/Connect';\nimport ProductLinks from './Components/ProductLinks';\n\nconst StyledFooter = styled.footer`\n background: ${themeColor('darkBlue')};\n display: flex;\n flex-direction: column;\n justify-content: center;\n color: ${themeColor('smokeyWhite')};\n overflow: hidden;\n width: 100%;\n max-width: 1440px;\n margin: 0 auto;\n ${FullBleed}\n\n ${mobileMediaQuery} {\n margin: 0 0;\n }\n\n & a {\n text-decoration: none;\n color: inherit;\n\n &:visited {\n color: inherit;\n }\n &:hover {\n color: inherit;\n }\n }\n`;\n\nconst Top = styled.div`\n display: flex;\n flex-direction: row;\n font-size: 0.75rem;\n margin: 0 6.25vw;\n height: 485px;\n padding-top: 60px;\n\n ${tabletMediaQuery} {\n flex-direction: column;\n height: auto;\n margin: 0 48px;\n padding-top: 30px;\n }\n`;\n\nconst Separator = styled.div`\n height: 1px;\n width: 100%;\n background: ${themeColor('grey')};\n opacity: 0.5;\n`;\n\nconst Column = styled.section`\n display: flex;\n flex-direction: column;\n margin: 15px 10px;\n\n &:first-child {\n margin-left: 0;\n }\n\n ${tabletMediaQuery} {\n margin: 15px 0;\n }\n`;\n\nconst Company = styled(Column)`\n flex-shrink: 0;\n`;\n\nconst ConnectContainer = styled(Column)`\n display: flex;\n flex-direction: column;\n flex-grow: 5;\n flex-shrink: 1;\n`;\n\nconst SolutionsContainer = styled(Column)`\n flex-shrink: 0;\n flex-grow: 1;\n margin-right: 75px;\n`;\n\nconst Bottom = styled.div`\n height: 80px;\n margin: 0 6.25vw;\n display: flex;\n align-items: center;\n\n ${tabletMediaQuery} {\n margin: 0 20px 20px;\n height: auto;\n flex-direction: row-reverse;\n }\n`;\n\nconst Copyright = styled.div`\n font-size: 0.8125rem;\n line-height: 0.9375rem;\n flex: 1;\n display: flex;\n align-items: center;\n\n ${tabletMediaQuery} {\n order: 2;\n font-size: 0.4375rem;\n }\n`;\n\nconst LogosContainer = styled.div`\n display: flex;\n align-items: center;\n justify-content: space-evenly;\n margin-right: 50px;\n\n ${tabletMediaQuery} {\n order: 1;\n justify-content: space-evenly;\n flex-wrap: wrap;\n margin: 10px 0;\n }\n`;\n\nconst Footer: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {t('legal.copyright', { year: getYear(new Date()) })}\n \n \n \n \n \n \n );\n};\n\nexport default Footer;\n","import React from 'react';\nimport Header from '../Navigation/Header';\nimport Footer from '../Navigation/Footer';\nimport styled from 'styled-components';\nimport { mobileMediaQuery } from '../Theming';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n max-width: 100%;\n margin: 0 auto;\n\n ${mobileMediaQuery} {\n margin: 0 0;\n }\n`;\n\nconst DefaultLayout: React.FC = ({ children }) => {\n return (\n <>\n
\n {children}\n
\n \n );\n};\n\nexport default DefaultLayout;\n","const images = {\n purple_kindred_icon: require('../Assets/Branding/purple_kindred_icon.png'),\n black_kindred_icon: require('../Assets/Branding/black_kindred_icon.png'),\n new_kindred_icon: require('../Assets/Branding/new_kindred_icon.png'),\n itv_logo: require('../Assets/Branding/itv_logo.png'),\n discounts_and_savings_icon: require('../Assets/Branding/discounts-and-savings.png'),\n keyboard_installation_guide_ios: require('../Assets/KeyboardInstallationGuide/ios.png'),\n keyboard_installation_guide_android: require('../Assets/KeyboardInstallationGuide/android.png'),\n nike_logo: require('../Assets/BrandLogos/nike.png'),\n aliexpress_logo: require('../Assets/BrandLogos/aliexpress.png'),\n john_lewis_logo: require('../Assets/BrandLogos/john_lewis.png'),\n asos_logo: require('../Assets/BrandLogos/asos.png'),\n nike_logo_white: require('../Assets/BrandLogos/nike_logo_white.png'),\n john_lewis_logo_white: require('../Assets/BrandLogos/john_lewis_logo_white.png'),\n asos_logo_white: require('../Assets/BrandLogos/asos_logo_white.png'),\n typewise: require('../Assets/BrandLogos/typewise.png'),\n couponsde: require('../Assets/BrandLogos/couponsde.png'),\n eon: require('../Assets/BrandLogos/eon.png'),\n popreach: require('../Assets/BrandLogos/popreach.png'),\n whitelabel: require('../Assets/BrandLogos/whitelabel.png'),\n adscend: require('../Assets/BrandLogos/adscend.png'),\n teamo: require('../Assets/BrandLogos/teamo.png'),\n o2: require('../Assets/BrandLogos/o2.png'),\n unity: require('../Assets/BrandLogos/unity.png'),\n O2_logo: require('../Assets/O2Logos/O2-bubble-3D-animations-04@05x 1.png'),\n partnerpluginsdk_activate_settings_activate_kindred: require('../Assets/PartnerpluginsdkActivate/settings activate kindred.png'),\n partnerpluginsdk_activate_settings_menu: require('../Assets/PartnerpluginsdkActivate/settings menu.png'),\n partnerpluginsdk_activate_settings_permission: require('../Assets/PartnerpluginsdkActivate/settings permission.png'),\n plugin_alpha_step_2: require('../Assets/KeyboardInstallationGuide/plugin-alpha-step2.jpg'),\n plugin_alpha_step_3: require('../Assets/KeyboardInstallationGuide/plugin-alpha-step3.jpg'),\n plugin_beta_step_1: require('../Assets/KeyboardInstallationGuide/plugin-beta-step1.gif'),\n plugin_beta_step_2: require('../Assets/KeyboardInstallationGuide/plugin-beta-step2.gif'),\n plugin_beta_step_3: require('../Assets/KeyboardInstallationGuide/plugin-beta-step3.gif'),\n mobile: require('../Assets/Products/mobile.png'),\n unity_logo: require('../Assets/Products/unity.png'),\n deals_api: require('../Assets/Products/dealsApi.png'),\n desktop_extension: require('../Assets/Products/desktopExtension.png'),\n mobile_keyboard: require('../Assets/Products/mobileKeyboard.png'),\n edge_icon: require('../Assets/Products/edge.png'),\n chrome_icon: require('../Assets/Platforms/chrome.png'),\n firefox_icon: require('../Assets/Products/firefox.png'),\n safari_icon: require('../Assets/Products/safari.png'),\n android_guide_1: require('../Assets/KeyboardInstallationGuide/android-guide1.png'),\n android_guide_2: require('../Assets/KeyboardInstallationGuide/android-guide2.png'),\n android_guide_3: require('../Assets/KeyboardInstallationGuide/android-guide3.png'),\n esg_icon_1: require('../Assets/Esg/reforestation.png'),\n esg_icon_2: require('../Assets/Esg/carbonOffset.png'),\n esg_icon_3: require('../Assets/Esg/donate.png'),\n revenue_icon_1: require('../Assets/Revenue/increaseARPU.png'),\n revenue_icon_2: require('../Assets/Revenue/lifetimeValue.png'),\n revenue_icon_3: require('../Assets/Revenue/atNoCost.png'),\n loyalty_icon_1: require('../Assets/Loyalty/offers.png'),\n loyalty_icon_2: require('../Assets/Loyalty/inAppReward.png'),\n loyalty_icon_3: require('../Assets/Loyalty/esgSupport.png'),\n our_mission_1: require('../Assets/About/ourMission1.png'),\n our_mission_2: require('../Assets/About/ourMission2.png'),\n our_mission_3: require('../Assets/About/ourMission3.png'),\n amazonRoundLogo: require('../Assets/Network/Brands/amazon.png'),\n levisRoundLogo: require('../Assets/Network/Brands/levis.png'),\n adidasRoundLogo: require('../Assets/Network/Brands/adidas.png'),\n microsoftRoundLogo: require('../Assets/Network/Brands/microsoft.png'),\n samsungRoundLogo: require('../Assets/Network/Brands/samsung.png'),\n macysRoundLogo: require('../Assets/Network/Brands/macys.png'),\n gapRoundLogo: require('../Assets/Network/Brands/gap.png'),\n targetRoundLogo: require('../Assets/Network/Brands/target.png'),\n walmartRoundLogo: require('../Assets/Network/Brands/walmart.png'),\n tescoRoundLogo: require('../Assets/Network/Brands/tesco.png'),\n white_kindred_icon: require('../Assets/Branding/white_kindred_icon.png'),\n puzzle_icon: require('../Assets/Icons/puzzlePiece.png'),\n ios_checked_icon: require('../Assets/Icons/greenSwitch.png'),\n partnerpluginsdk_safari_activation_steps: require('../Assets/PartnerNewpluginsdkActivate/safari-activation-steps.png'),\n partnerpluginsdk_safari_settings_steps: require('../Assets/PartnerNewpluginsdkActivate/safari-settings-steps.png'),\n partnerpluginsdk_safari_settings_steps_ios18: require('../Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-18.png'),\n partnerpluginsdk_safari_settings_steps_ios_aa: require('../Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-aa.png'),\n partnerpluginsdk_safari_settings_steps_ios_aa_ar: require('../Assets/PartnerpluginsdkActivate/safari-settings-steps-ios-aa-ar.png'),\n partnerpluginsdk_tap_here: require('../Assets/PartnerpluginsdkActivate/tap-here.png'),\n partnerpluginsdk_tap_here_ios_18: require('../Assets/PartnerpluginsdkActivate/tap-here-ios-18.png'),\n partnerpluginsdk_tap_here_ios_18_ar: require('../Assets/PartnerpluginsdkActivate/tap-here-ios-18-ar.png'),\n partnerpluginsdk_tap_aa_here: require('../Assets/PartnerpluginsdkActivate/tap-aa-here.png'),\n partnerpluginsdk_tap_aa_here_ar: require('../Assets/PartnerpluginsdkActivate/tap-aa-here-ar.png'),\n partnerpluginsdk_ios_18_plugin_icon: require('../Assets/PartnerpluginsdkActivate/ios-18-plugin-icon.png'),\n partnerpluginsdk_tap_here_sliide: require('../Assets/PartnerpluginsdkActivate/tap-here-sliide.png'),\n partnerpluginsdk_tap_here_top_left: require('../Assets/PartnerpluginsdkActivate/tap-here-top-left.png'),\n partnerpluginsdk_tap_here_bottom: require('../Assets/PartnerpluginsdkActivate/tap-here-bottom.png'),\n partnerpluginsdk_tap_here_top_left_sliide: require('../Assets/PartnerpluginsdkActivate/tap-here-top-left-sliide.png'),\n partnerpluginsdk_tap_here_bottom_sliide: require('../Assets/PartnerpluginsdkActivate/tap-here-bottom-sliide.png'),\n partnerpluginsdk_tap_here_top_left_itvx: require('../Assets/PartnerNewpluginsdkActivate/tap-here-top-left-itvx.png'),\n partnerpluginsdk_tap_here_bottom_itvx: require('../Assets/PartnerNewpluginsdkActivate/tap-here-bottom-itvx.png'),\n partnerpluginsdk_tap_review_itvx: require('../Assets/PartnerNewpluginsdkActivate/tap-review-itvx.png'),\n partnerpluginsdk_always_allow: require('../Assets/PartnerNewpluginsdkActivate/always-allow.png'),\n partnerpluginsdk_be_sure_1: require('../Assets/PartnerpluginsdkActivate/be-sure-step1.png'),\n partnerpluginsdk_be_sure_2: require('../Assets/PartnerpluginsdkActivate/be-sure-step2.png'),\n partnerpluginsdk_be_sure_3: require('../Assets/PartnerpluginsdkActivate/be-sure-step3.png'),\n partnerpluginsdk_be_sure_4: require('../Assets/PartnerpluginsdkActivate/be-sure-step4.png'),\n partnerpluginsdk_be_sure_5: require('../Assets/PartnerpluginsdkActivate/be-sure-step5.png'),\n partnerpluginsdk_be_suresliide_1: require('../Assets/PartnerpluginsdkActivate/be-sure-stepsliide1.png'),\n partnerpluginsdk_be_suresliide_2: require('../Assets/PartnerpluginsdkActivate/be-sure-stepsliide2.png'),\n partnerpluginsdk_be_suresliide_3: require('../Assets/PartnerpluginsdkActivate/be-sure-stepsliide3.png'),\n partnerpluginsdk_be_suresliide_4: require('../Assets/PartnerpluginsdkActivate/be-sure-stepsliide4.png'),\n partnerpluginsdk_be_suresliide_5: require('../Assets/PartnerpluginsdkActivate/be-sure-stepsliide5.png'),\n partnerpluginsdk_start_shopping_brands: require('../Assets/PartnerpluginsdkActivate/brands.png'),\n partnerpluginsdk_start_shopping_brands_sliide: require('../Assets/PartnerpluginsdkActivate/brandssliide.png'),\n partnerpluginsdk_activation_tim_review: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-activation-review.gif'),\n partnerpluginsdk_activation_tim_aa: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-activation-aa.gif'),\n partnerpluginsdk_activation_tim_18: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-activation-18.gif'),\n tim_ios_logo: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-logo.png'),\n tim_ios_partial_steps: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-partial-steps.png'),\n tim_ios_union_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-union-icon.png'),\n tim_ios_review_permissions: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-review-permissions.png'),\n tim_ios_switch_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-switch-icon.png'),\n tim_ios_plugin_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-plugin-icon.png'),\n tim_ios_18_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-18-icon.png'),\n tim_ios_success_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-ios-success-icon.png'),\n tim_app_store_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-app-store-icon.png'),\n tim_partial_logo: require('../Assets/PartnerNewpluginsdkActivate/tim-partial-logo.png'),\n tim_safari_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-safari-icon.png'),\n safari_browser_logo: require('../Assets/PartnerNewpluginsdkActivate/safari-browser-logo.png'),\n tim_settings_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-settings-icon.png'),\n tim_switch: require('../Assets/PartnerNewpluginsdkActivate/tim-switch.png'),\n tim_left_icon: require('../Assets/PartnerNewpluginsdkActivate/tim-left-icon.png'),\n samsung_activation_deals_found: require('../Assets/SamsungActivation/samsung-deals-found.png'),\n samsung_activation_you_saved_so_far: require('../Assets/SamsungActivation/samsung-saved-so-far.png'),\n samsung_activation_you_saved: require('../Assets/SamsungActivation/samsung-you-saved.png'),\n Itv_logo: require('../Assets/ITVLogos/itv@4x.png'),\n ItvX: require('../Assets/ITVLogos/itvX@4x.png'),\n dominos_logo: require('../Assets/ITVLogos/dominos@4x.png'),\n};\n\nexport const mockedLogos = {\n purple_kindred_icon: require('../Assets/Branding/purple_kindred_icon.png'),\n black_kindred_icon: require('../Assets/Branding/black_kindred_icon.png'),\n new_kindred_icon: require('../Assets/Branding/new_kindred_icon.png'),\n nike_logo: require('../Assets/BrandLogos/nike.png'),\n john_lewis_logo: require('../Assets/BrandLogos/john_lewis.png'),\n asos_logo: require('../Assets/BrandLogos/asos.png'),\n john_lewis_logo_white: require('../Assets/BrandLogos/john_lewis_logo_white.png'),\n typewise: require('../Assets/BrandLogos/typewise.png'),\n couponsde: require('../Assets/BrandLogos/couponsde.png'),\n eon: require('../Assets/BrandLogos/eon.png'),\n popreach: require('../Assets/BrandLogos/popreach.png'),\n whitelabel: require('../Assets/BrandLogos/whitelabel.png'),\n o2: require('../Assets/BrandLogos/o2.png'),\n unity: require('../Assets/BrandLogos/unity.png'),\n O2_logo: require('../Assets/O2Logos/O2-bubble-3D-animations-04@05x 1.png'),\n};\n\nexport const mockedLogosTim = {\n tim_viva_ticket_logo: require('../Assets/BrandLogos/tim-viva-ticket-logo.png'),\n tim_asos_logo: require('../Assets/BrandLogos/tim-asos-logo.png'),\n tim_air_bnb_logo: require('../Assets/BrandLogos/tim-air-bnb-logo.png'),\n sephora_logo: require('../Assets/BrandLogos/sephora-logo.png'),\n tim_leroy_merlin_logo: require('../Assets/BrandLogos/tim-leroy-merlin-logo.png'),\n tim_decathlon_logo: require('../Assets/BrandLogos/tim-decathlon-logo.png'),\n tim_euronics_logo: require('../Assets/BrandLogos/tim-euronics-logo.png'),\n tim_zalando_logo: require('../Assets/BrandLogos/tim-zalando-logo.png'),\n};\n\nexport default images;\n","import React from 'react';\nimport images from '../../Theming/images';\n\nconst icons = {\n purple: images.purple_kindred_icon,\n black: images.black_kindred_icon,\n white: images.white_kindred_icon,\n new: images.new_kindred_icon,\n discounts_and_savings: images.discounts_and_savings_icon,\n};\n\ntype IconProps = {\n color: keyof typeof icons;\n style?: React.CSSProperties;\n};\nconst KindredIcon: React.FC = ({ color, style }) => {\n return \"kindred;\n};\n\nKindredIcon.defaultProps = {\n style: {\n minWidth: '3rem',\n width: '7%',\n },\n};\n\nexport default KindredIcon;\n","import React from 'react';\n\nexport type FlexProps = {\n align?: 'flex-start' | 'flex-end' | 'center';\n dir?: 'column' | 'row';\n} & React.CSSProperties;\n\nconst Flex: React.FC = ({ children, align, dir, ...rest }) => {\n return (\n \n {children}\n \n );\n};\n\nexport default Flex;\n","import React from 'react';\nimport Flex, { FlexProps } from '../Flex';\n\nexport type CenterProps = FlexProps;\nconst Center: React.FC = ({ children, ...rest }) => {\n return {children};\n};\nCenter.defaultProps = {\n justifyContent: 'center',\n align: 'center',\n};\nexport default Center;\n","import React from 'react';\n\ntype TextProps = React.CSSProperties;\n\nconst Text: React.FC = ({ children, ...rest }) => {\n return

{children}

;\n};\n\nexport default Text;\n","import { useRef, useEffect } from 'react';\n\nfunction useClickOutside(\n func: () => void,\n shouldBind = true\n) {\n const ref = useRef(null);\n function handleClickOutside(event: MouseEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n func();\n }\n }\n\n useEffect(() => {\n if (shouldBind) {\n document.addEventListener('click', handleClickOutside);\n return () => {\n document.removeEventListener('click', handleClickOutside);\n };\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [shouldBind]);\n\n return { ref };\n}\n\nexport default useClickOutside;\n","import { useState } from 'react';\n\nconst useDisclosure = () => {\n const [isOpen, setOpen] = useState(false);\n const onClose = () => setOpen(false);\n const onOpen = () => setOpen(true);\n const onToggle = () => setOpen((prev) => !prev);\n\n return { isOpen, onOpen, onClose, onToggle };\n};\n\nexport default useDisclosure;\n","import React from 'react';\nimport { useLocation } from 'react-router-dom';\n\nconst useQuery = () => {\n const { search } = useLocation();\n\n return React.useMemo(() => new URLSearchParams(search), [search]);\n};\nexport default useQuery;\n","import { useCallback } from 'react';\n\nconst useScrollTo = (\n reference: React.RefObject<\n HTMLDivElement | HTMLButtonElement | HTMLImageElement | null\n >\n): (() => void) => {\n const executeScroll = useCallback(\n () => reference?.current?.scrollIntoView({ behavior: 'smooth' }),\n [reference]\n );\n\n return executeScroll;\n};\n\nexport default useScrollTo;\n","import axios from 'axios';\nimport { getLocalUserID } from './utils';\nimport env from '../../env';\n\nexport const trackPageAnnonymous = async (\n pageName: string,\n properties: Record = {},\n partnerID: string\n) => {\n const userAgent = navigator.userAgent;\n const userID = getLocalUserID();\n try {\n await axios.post(\n env.api_url +\n `/partners/analytics/Track/p/page?partnerId=${partnerID}&userId=${userID}`,\n {\n Properties: { ...properties, UserAgent: userAgent },\n PageName: pageName,\n }\n );\n } catch {\n // make sure we continue if any errors occur\n }\n};\n\nexport const trackActionAnnonymous = async (\n actionName: string,\n properties: Record = {},\n partnerID: string\n) => {\n const userAgent = navigator.userAgent;\n const userID = getLocalUserID();\n try {\n await axios.post(\n env.api_url +\n `/partners/analytics/Track/p/action?partnerId=${partnerID}&userId=${userID}`,\n {\n Properties: { ...properties, UserAgent: userAgent },\n ActionName: actionName,\n }\n );\n } catch {\n // make sure we continue if any errors occur\n }\n};\n","import { TFunction } from 'react-i18next';\n\nimport {\n isAndroid,\n isIOS,\n isMacOs,\n isSafari,\n isChrome,\n osVersion,\n isMobile,\n isTablet,\n getUA,\n mobileVendor,\n mobileModel,\n browserName,\n deviceDetect,\n} from 'react-device-detect';\nimport { v4 as uuidv4 } from 'uuid';\nimport env from '../../env';\nimport { trackActionAnnonymous, trackPageAnnonymous } from './partnerAnalytics';\nimport { KSOURCE } from '../Hooks/usePageViewTracking';\nconst USER_SESSION_ID = 'SessionTrackingID';\nconst TIME_SPENT_SESSION_TRACKING = 'TimeSpentSessionTracking';\nconst PAGE_VIEW_SESSION_TRACKING = 'PageViewSessionTracking';\n\nexport type PartnerNames = 'TIM' | 'Kindred';\n\nconst PartnerIDS: Record = {\n TIM: env.tim_partner_id,\n Kindred: env.kindred_partner_id,\n};\n\nexport const hasTrackedOnSession = (\n pageName: string,\n pageViewSession: boolean\n) => {\n let sessionTracked = true;\n const sessionName = pageViewSession\n ? PAGE_VIEW_SESSION_TRACKING\n : TIME_SPENT_SESSION_TRACKING;\n\n const trackedPages = sessionStorage.getItem(sessionName) || '';\n\n const trackedPagesArray = trackedPages.split(',').filter(Boolean);\n if (!trackedPagesArray.includes(pageName)) {\n sessionTracked = false;\n trackedPagesArray.push(pageName);\n sessionStorage.setItem(sessionName, trackedPagesArray.join(','));\n }\n\n return sessionTracked;\n};\n\nexport const getLocalUserID = () => {\n let localUserID = sessionStorage.getItem(USER_SESSION_ID);\n\n if (!localUserID) {\n const params = new URLSearchParams(window.location.search);\n // checking if a session Id was passed so we can use it as userID\n const sessionUserID = params.get('sessionID');\n\n localUserID = sessionUserID || (uuidv4() as string);\n sessionStorage.setItem(USER_SESSION_ID, localUserID);\n }\n return localUserID;\n};\n\nconst getPlatform = () => {\n if (isMobile) {\n return isIOS ? 'iOS' : 'Android';\n } else if (isTablet) {\n return 'tablet';\n } else {\n return `Desktop (${getBrowserName()})`;\n }\n};\n\nconst getOperatingSystem = () => {\n let os = 'unknown';\n const agent = deviceDetect(getUA);\n\n if ((agent.osName || agent.os) && agent.osVersion) {\n os = (agent.osName || agent.os) + ' ' + agent.osVersion;\n }\n\n return os;\n};\n\nconst getDevice = () => {\n let device = 'unknown';\n const userAgent = getUA.toLowerCase();\n if (userAgent.includes('windows')) {\n device = 'Windows';\n } else if (userAgent.includes('mac os') || userAgent.includes('macos')) {\n if (isMobile) {\n device = 'iPhone';\n } else if (isTablet) {\n device = 'iPad';\n } else {\n device = 'MacOS';\n }\n } else if (mobileVendor === 'none') {\n device = getOperatingSystem();\n } else {\n device = `${mobileVendor} ${mobileModel}`.trim() || 'Unknown';\n }\n return device;\n};\n\nconst getBrowserName = () => {\n if (browserName === 'Chrome') {\n if (isMobile) {\n return `Mobile ${browserName}`;\n } else if (isTablet) {\n return `Tablet ${browserName}`;\n }\n }\n return browserName;\n};\n\nconst getPartnersStandardProps = (partner = 'Kindred') => {\n return {\n Partner: partner,\n Platform: getPlatform(),\n OperatingSystem: getOperatingSystem(),\n Browser: getBrowserName(),\n Device: getDevice(),\n };\n};\nexport const trackPageViewForPartner = (\n pageName: string,\n partner: PartnerNames,\n ksource: string | null | undefined,\n properties: Record | undefined = {}\n) => {\n trackPageAnnonymous(\n pageName,\n {\n Ksource: ksource,\n ...getPartnersStandardProps(partner),\n ...properties,\n },\n PartnerIDS[partner]\n );\n};\n\nexport const trackClickedActionEvent = (\n query: URLSearchParams,\n partner: PartnerNames,\n label: string,\n pageName: string\n) => {\n trackPartnerActionEvent('clicked_action', partner, query, {\n Label: label,\n PageName: pageName,\n });\n};\n\nexport const trackPartnerActionEvent = (\n eventName: string,\n partner: PartnerNames,\n query: URLSearchParams,\n properties: Record | undefined = {}\n) => {\n const ksource = query.get(KSOURCE);\n trackActionAnnonymous(\n eventName,\n {\n Ksource: ksource,\n ...getPartnersStandardProps(partner),\n ...properties,\n },\n PartnerIDS[partner]\n );\n};\n\nexport const ANALYTICS_PAGE_NAMES = {\n activation_complete_page: 'activation_complete_page',\n accessibility_instructions_page: 'accessibility_instructions_page',\n additional_permissions_page: 'additional_permissions_page',\n partially_installed_page: 'partially_installed_page',\n activation_instructions_page: 'activation_instructions_page',\n landing_page: 'landing_page',\n extension_explainer: 'extension_explainer',\n mobile_disabled_page: 'mobile_disabled_page',\n kill_switch_active_page: 'kill_switch_active_page',\n safari_desktop_instructions_page: 'safari_desktop_instructions_page',\n safari_desktop_success_page: 'safari_desktop_success_page',\n chrome_desktop_success_page: 'chrome_desktop_success_page',\n};\n","import { useEffect, useState } from 'react';\nimport useQuery from './useQuery';\nimport {\n hasTrackedOnSession,\n PartnerNames,\n trackPageViewForPartner,\n trackPartnerActionEvent,\n} from '../Analytics/utils';\n\nexport const KSOURCE = 'ksource';\n\nconst usePageViewTracking = (pageName: string, partner: PartnerNames) => {\n const query = useQuery();\n const [entryTime] = useState(new Date());\n const [actionTrackedOnVisibility, setActionTrackedOnVisibility] =\n useState(false);\n\n useEffect(() => {\n const ksource = query.get(KSOURCE);\n\n const trackTimeSpent = () => {\n const exitTime = new Date();\n const timeSpent = (exitTime.getTime() - entryTime.getTime()) / 1000 / 60;\n if (timeSpent > 0.01 && !hasTrackedOnSession(pageName, false)) {\n trackPartnerActionEvent('time_spent', partner, query, {\n PageName: pageName,\n TimeSpent: timeSpent.toFixed(2),\n });\n }\n };\n\n const handleVisibilityChange = () => {\n if (document.visibilityState === 'hidden' && !actionTrackedOnVisibility) {\n setActionTrackedOnVisibility(true);\n trackTimeSpent();\n }\n };\n\n if (!hasTrackedOnSession(pageName, true)) {\n trackPageViewForPartner(pageName, partner, ksource);\n }\n\n document.addEventListener('visibilitychange', handleVisibilityChange);\n\n return () => {\n document.removeEventListener('visibilitychange', handleVisibilityChange);\n\n if (!actionTrackedOnVisibility && document.visibilityState !== 'hidden') {\n setActionTrackedOnVisibility(true);\n trackTimeSpent();\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [entryTime, pageName, query, actionTrackedOnVisibility]);\n};\n\nexport default usePageViewTracking;\n","import React from 'react';\nimport { IconProps, useDefaultColor } from './core';\n\nconst Close: React.FC = ({\n color,\n width = 20,\n height = 20,\n style,\n className,\n}) => {\n const resolvedColor = useDefaultColor(color);\n\n return (\n \n \n \n \n \n \n );\n};\n\nexport default Close;\n","import { useTheme } from 'styled-components';\nimport { Theme } from '../../Theming';\n\nexport interface IconProps {\n color?: string;\n width?: number;\n height?: number;\n style?: React.CSSProperties;\n className?: string;\n}\n\nexport const useDefaultColor = (\n color?: string,\n key: keyof Theme['colors'] = 'darkestGrey'\n) => {\n const { colors } = useTheme();\n\n return color ?? colors[key];\n};\n","import React from 'react';\nimport CoreModal, { ModalProps } from 'styled-react-modal';\nimport styled from 'styled-components';\nimport UnstyledButton from '../Buttons/UnstyledButton';\nimport { themeColor } from '../../Theming';\nimport { mobileMediaQuery } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\nimport Close from '../Icons/Close';\n\ninterface ModalWrapperProps extends ModalProps {\n mobileWidth?: number;\n mobileHeight?: number;\n onClose?(): void;\n}\n\nconst StyledModal = CoreModal.styled``;\n\nconst CloseButton = styled(UnstyledButton)`\n position: absolute;\n top: 20px;\n right: 20px;\n padding: 5px;\n ${mobileMediaQuery} {\n top: 5px;\n right: 5px;\n }\n`;\n\nconst Wrapper: React.FC = ({\n onClose,\n onEscapeKeydown,\n onBackgroundClick,\n ...props\n}) => {\n const handleEscapeKeydown = onEscapeKeydown ?? onClose;\n const handleBackgroundClick = onBackgroundClick ?? onClose;\n const { t } = useTranslation();\n\n return (\n \n {onClose && (\n \n \n \n )}\n {props.children}\n \n );\n};\n\nconst Modal = styled(Wrapper)`\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n background: ${themeColor('white')};\n border-radius: 4px;\n min-width: 300px;\n padding: 40px 40px 20px;\n ${mobileMediaQuery} {\n margin: 4px;\n }\n`;\n\nexport default Modal;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport Modal from '../../Common/Modals/Modal';\nimport { ArrowInCircle } from '../../Common/Svg/Icons';\n\nimport { mobileMediaQuery } from '../../Theming';\n\nconst StyledModal = styled(Modal)`\n max-width: 500px;\n padding-bottom: 0;\n\n ${mobileMediaQuery} {\n max-width: 100%;\n padding-right: 20px;\n padding-left: 20px;\n }\n`;\n\nconst Heading = styled.h1`\n justify-content: space-between;\n font-size: 2.5rem;\n line-height: 2.75rem;\n margin: 0;\n`;\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n max-height: 80vh;\n overflow-y: scroll;\n padding-bottom: 70px;\n\n -ms-overflow-style: none;\n scrollbar-width: none;\n &::-webkit-scrollbar {\n display: none;\n }\n`;\n\ntype DescriptionModalProps = {\n show: boolean;\n onHide(): void;\n};\nconst StyledHeadingArrowInCircle = styled(ArrowInCircle)`\n margin-left: 18px;\n`;\nconst P = styled.p`\n font-size: 1rem;\n`;\nconst DescriptionModal: React.FC = ({\n show,\n onHide,\n}) => {\n const { t } = useTranslation();\n return (\n \n \n \n {t('keyboardInstallationGuide.whatisfullaccess')}\n \n \n\n

{t('keyboardInstallationGuide.whatisfullaccessdescription')}

\n
\n
\n );\n};\nexport default DescriptionModal;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { themeColor } from '../../../Theming';\n\nconst Button = styled.button`\n transition: all 0.2s ease-in-out 0s;\n width: 300px;\n background-color: ${themeColor('green')};\n margin-bottom: 45px;\n box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);\n &:hover {\n opacity: 0.9;\n }\n\n &:disabled {\n background-color: ${themeColor('grey')};\n }\n`;\n\ntype Button1Props = {\n onClick?: React.MouseEventHandler;\n disabled?: boolean;\n className?: string;\n id?: string;\n} & React.CSSProperties;\n\nconst Button1: React.FC = ({\n onClick,\n disabled,\n children,\n id,\n ...rest\n}) => {\n return (\n \n );\n};\nButton1.defaultProps = {\n borderRadius: '1rem',\n padding: '.5rem 1.5rem',\n border: 'none',\n fontWeight: 'bold',\n cursor: 'pointer',\n};\nexport default Button1;\n","import { detect } from 'detect-browser';\nimport env from '../../env';\nimport chrome from '../../Assets/Platforms/chrome.png';\n\nconst userAgentContains = (str: string) =>\n navigator.userAgent.match(new RegExp(str, 'i'));\n\nconst isIOS = userAgentContains('iPad|iPhone|iPod');\nconst isAndroid = userAgentContains('android');\nconst isMac = userAgentContains('Macintosh|MacIntel|MacPPC|Mac68K');\nconst isPC = userAgentContains('Windows|Win32|Win64|WOW64');\n\nconst iosDownloadUrl = 'https://apps.apple.com/gb/app/kindred-app/id1468277090';\nconst androidDownloadUrl =\n 'https://play.google.com/store/apps/details?id=com.kindredsoul.kindredapp';\n\nconst MOBILE_OS = [\n 'iOS',\n 'Android OS',\n 'BlackBerry OS',\n 'Windows Mobile',\n 'Amazon OS',\n];\n\nconst platform = {\n platform: 'chrome',\n logo: chrome,\n link: env.chrome_extension_store_url,\n};\n\nconst isMobile = () => {\n const browser = detect();\n return !!browser?.os && MOBILE_OS.includes(browser?.os);\n};\n\nconst getBrowserName = () => {\n return detect()?.name;\n};\n\nexport const getPlatform = () => {\n return platform;\n};\n\nexport {\n isIOS,\n isAndroid,\n isMac,\n isPC,\n iosDownloadUrl,\n androidDownloadUrl,\n isMobile,\n getBrowserName,\n};\n","import React, { useRef } from 'react';\nimport styled from 'styled-components';\nimport { VscArrowDown, VscGlobe, VscSmiley } from 'react-icons/vsc';\nimport { FaKeyboard } from 'react-icons/fa';\nimport { useTranslation } from 'react-i18next';\n\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport { Flex } from '../../Common/Layouts';\nimport { useDisclosure, useScrollTo } from '../../Common/Hooks';\nimport DescriptionModal from './DescriptionModal';\nimport { StyledButton1 } from '../../Common/Buttons/StyledButtons';\nimport { isAndroid } from '../../Common/Utils/platforms';\nimport images from '../../Theming/images';\n\nconst Container = styled.div`\n align-items: center;\n width: 100%;\n max-width: 700px;\n padding: 0 1.5rem;\n position: relative;\n font-size: small;\n h4 {\n font-size: 1rem;\n text-align: left;\n }\n p {\n color: ${({ color }) => color};\n }\n ul {\n color: ${({ color }) => color};\n padding: 0;\n padding-left: 1rem;\n li:first-child {\n margin-left: -1rem;\n list-style: none;\n }\n }\n button {\n margin: 1rem 0;\n }\n ${mobileMediaQuery} {\n width: 100%;\n h4 {\n text-align: center;\n }\n button {\n width: 100%;\n }\n }\n span {\n margin: 0 0.5rem;\n display: inline;\n }\n`;\nconst BoldParagraph = styled.p`\n font-weight: bold;\n text-align: left;\n width: 100%;\n margin: 1rem 0;\n ${mobileMediaQuery} {\n text-align: center;\n }\n`;\nconst ModalButton = styled.p`\n text-decoration: underline;\n color: gray;\n display: inline-block;\n cursor: pointer;\n font-size: x-small;\n min-width: fit-content;\n align-self: flex-end;\n`;\n\nconst ImageContainer = styled.div`\n max-width: fit-content;\n position: relative;\n input[type='text'] {\n opacity: 0;\n position: absolute;\n top: 0;\n left: 0;\n }\n p {\n outline: none;\n position: absolute;\n width: ${isAndroid ? '8rem' : '4.1rem'};\n left: ${isAndroid ? '4rem' : '6.75rem'};\n top: ${isAndroid ? '5.4rem' : '5.6rem'};\n border: none;\n color: ${isAndroid ? 'black' : 'white'};\n font-size: small;\n text-align: ${isAndroid ? 'left' : 'center'};\n background-color: ${isAndroid ? 'white' : themeColor('customBlue')};\n padding: ${isAndroid ? '.1rem .3rem' : '0'};\n ${mobileMediaQuery} {\n padding: ${isAndroid ? '.1rem .2rem' : '0'};\n top: ${isAndroid ? '5rem' : '5.4rem'};\n width: ${isAndroid ? '8rem' : '3.8rem'};\n }\n }\n img {\n width: 20rem;\n object-fit: contain;\n ${mobileMediaQuery} {\n margin: auto;\n width: 100%;\n }\n }\n ${mobileMediaQuery} {\n margin: auto;\n width: 20rem;\n }\n`;\n\nconst Description = () => {\n const { t } = useTranslation();\n const { isOpen, onClose, onOpen } = useDisclosure();\n const hiddenInput = useRef(null);\n const imgContainerRef = useRef(null);\n const scrollTo = useScrollTo(imgContainerRef);\n\n const activateKeyboard = () => {\n hiddenInput?.current?.focus();\n scrollTo();\n };\n\n return (\n <>\n \n \n

{t('keyboardInstallationGuide.heading1')}

\n {isAndroid ? (\n

{t('keyboardInstallationGuide.androidGuide')}

\n ) : (\n <>\n
    \n
  • {t('keyboardInstallationGuide.iosGuideLi1')}
  • \n
  • {t('keyboardInstallationGuide.iosGuideLi2')}
  • \n
  • {t('keyboardInstallationGuide.iosGuideLi3')}
  • \n
\n \n {t('keyboardInstallationGuide.WhatSFullAccess')}\n \n \n )}\n
\n \n

{t('keyboardInstallationGuide.heading2')}

\n \n \n \n \n

\n {t('keyboardInstallationGuide.pPart1')}\n {isAndroid ? (\n \n \n \n ) : (\n <>\n \n \n \n or\n \n \n \n \n )}\n {t('keyboardInstallationGuide.pPart2')}\n

\n
\n\n \n {t('keyboardInstallationGuide.activateBtnContent')}\n \n
\n \n \n \n \n {/* Dynamic query paramater goes here */}\n

Kindred

\n
\n {t('keyboardInstallationGuide.footer')}\n
\n \n );\n};\n\nexport default Description;\n","import React from 'react';\nimport { KindredIcon } from '../Common/Icons';\nimport styled from 'styled-components';\nimport { Description } from './Components';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n min-height: 100vh;\n padding: 1rem 0.5rem;\n padding-bottom: 50vh;\n`;\nconst KeyboardInstallationGuide = () => {\n return (\n \n \n \n \n );\n};\n\nexport default KeyboardInstallationGuide;\n","import React from 'react';\nimport { useTheme } from 'styled-components';\nimport { IconProps } from '../Icons/core';\n\nconst KindredLogo: React.FC = ({\n color,\n width = 122,\n height = 26,\n className,\n}) => {\n const theme = useTheme();\n const resolvedColor = color ?? theme.colors.darkestGrey;\n\n return (\n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default KindredLogo;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { theme } from '../../Theming';\n\nconst Button = styled.button`\n padding: 1rem;\n font-weight: 600;\n letter-spacing: 0.5;\n cursor: pointer;\n transition: opacity 0.3s ease-in-out 0s;\n &:hover {\n opacity: 0.8;\n }\n`;\n\nconst buttonColorTypes = {\n 1: theme.colors.midBlue,\n 2: theme.colors.darkBlue,\n 3: theme.colors.black,\n};\nconst buttonTypes = {\n primary: {\n border: 'none',\n },\n secondary: { border: '1.5px solid' },\n};\n\ntype CustomButtonProps = React.CSSProperties & {\n type?: keyof typeof buttonTypes;\n colorType?: keyof typeof buttonColorTypes;\n onClick?: React.MouseEventHandler;\n};\n\nconst CustomButton: React.FC = ({\n children,\n type,\n colorType,\n onClick,\n ...rest\n}) => {\n const color = buttonColorTypes[colorType ?? 1];\n return (\n \n {children}\n \n );\n};\nCustomButton.defaultProps = {\n colorType: 1,\n type: 'primary',\n};\nexport default CustomButton;\n","import React from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\n\nconst Logo = styled.img`\n width: 280px;\n height: 280px;\n margin-top: 20px;\n`;\nconst step = [\n images.android_guide_1?.default,\n images.android_guide_2?.default,\n images.android_guide_3?.default,\n];\n\ninterface guidStepInterface {\n guidStep: number;\n}\n\nconst AndroidGuideImages: React.FC = ({ guidStep }) => {\n return ;\n};\n\nexport default AndroidGuideImages;\n","import React, { useCallback, useState, useMemo, useRef } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { VscArrowDown } from 'react-icons/vsc';\nimport styled from 'styled-components';\nimport { StyledButton } from '../../Common/Buttons';\nimport { Flex, Text } from '../../Common/Layouts';\nimport AndroidGuideImages from '../Images/AndroidGuideImages';\nimport { FaKeyboard } from 'react-icons/fa';\nimport { useQuery } from '../../Common/Hooks';\nimport { useParams } from 'react-router-dom';\n\nconst Input = styled.input`\n opacity: 0;\n`;\nconst List = styled.ol`\n list-style: none;\n padding: 0;\n\n counter-reset: item;\n li {\n position: relative;\n counter-increment: item;\n margin: 2rem 0;\n margin-left: 3.2rem;\n line-height: 19.2px;\n letter-spacing: 0.5px;\n font-size: 1rem;\n font-weight: 400;\n strong {\n font-weight: 600;\n }\n }\n li:before {\n content: counter(item);\n position: absolute;\n left: -3.2rem;\n top: 0;\n margin-right: 1rem;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n height: 1.9rem;\n }\n`;\n\ninterface urlProps {\n step: string;\n}\nconst steps = [\n 'androidKeyboardInstallationGuide.steps.toggleKeyboard',\n 'androidKeyboardInstallationGuide.steps.switchKeyboard',\n 'androidKeyboardInstallationGuide.steps.headToTheApp',\n];\n\nconst Description: React.FC = () => {\n const { t } = useTranslation();\n const useUrlParams = useParams();\n const [step, setStep] = useState(Number(useUrlParams.step));\n const hiddenInput = useRef(null);\n const query = useQuery();\n\n const activateKeyboard = () => {\n hiddenInput?.current?.focus();\n scrollTo();\n };\n\n const openApp = useCallback(() => {\n const appHost = query.get('host');\n const appScheme = query.get('scheme');\n const appPackage = query.get('package');\n if (appHost && appScheme && appPackage)\n window.location =\n `intent://${appHost}/#Intent;package=${appPackage};scheme=${appScheme};end;` as (\n | string\n | Location\n ) &\n Location;\n }, [query]);\n\n const handleIncrementStep = useCallback(() => {\n if (step === 2) {\n openApp();\n return;\n }\n setStep(step + 1);\n }, [openApp, step]);\n\n const stepDetail = useMemo(() => {\n if (step >= steps.length + 1) return null;\n return steps[step];\n }, [step]);\n\n return (\n <>\n \n {stepDetail && (\n
\n
  • \n \n {t(stepDetail + '.title')}\n \n {t(stepDetail + '.description')}\n \n
  • \n {step === 1 && (\n \n \n \n \n

    \n {t('androidKeyboardInstallationGuide.pPart1')}\n \n \n \n {t('androidKeyboardInstallationGuide.pPart2')}\n

    \n
    \n )}\n \n \n {t('androidKeyboardInstallationGuide.next')}\n \n
    \n )}\n
    \n \n );\n};\n\nexport default Description;\n","import React from 'react';\nimport O2Logo from '../Common/Logos/KindredLogo';\nimport styled from 'styled-components';\nimport { Description } from './Components';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n min-height: 100vh;\n padding: 1rem 0.5rem;\n padding-bottom: 50vh;\n`;\nconst AndroidKeyboardInstallationGuide = () => {\n return (\n \n \n \n \n );\n};\n\nexport default AndroidKeyboardInstallationGuide;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport { Trans, useTranslation } from 'react-i18next';\nimport styled, { keyframes } from 'styled-components';\nimport { StyledButton1 } from '../../Common/Buttons/StyledButtons';\nimport Center from '../../Common/Layouts/Center';\nimport { themeColor } from '../../Theming';\nimport { HyperisePlaceholderContainer } from '../index';\nimport images from '../../Theming/images';\nimport colors from '../../Theming/colors';\nimport { useQuery } from '../../Common/Hooks';\nimport { isIOS, osVersion } from 'react-device-detect';\nimport i18next from 'i18next';\nimport clsx from 'clsx';\n\nconst Container = styled.div`\n width: 100%;\n font-family: 'Fira Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI',\n 'Roboto', 'Palanquin', 'Oxygen', 'Ubuntu', 'Cantarell', 'Droid Sans',\n 'Helvetica Neue', sans-serif;\n\n ol {\n padding: 0;\n padding-left: 1rem;\n }\n ol > li {\n padding-bottom: 0.8rem;\n font-size: small;\n }\n img {\n flex: 1;\n object-fit: cover;\n margin-left: 0.2rem;\n }\n h6 {\n margin: 0.5rem 0;\n padding: 0;\n }\n h4 {\n color: ${themeColor('green')};\n }\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n flex: none !important;\n width: auto;\n height: 301px;\n`;\n\nconst IconContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n`;\n\nconst IconContentDescription = styled.div`\n color: ${themeColor('black')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n padding-top: 14px;\n`;\n\nconst WhatYouNeedText = styled.div`\n font-size: 26px;\n font-style: normal;\n font-weight: Bold;\n line-height: 35px;\n margin-bottom: 11px;\n text-align: center;\n`;\n\nconst ContentItem = styled.div`\n font-size: 18px;\n font-style: normal;\n font-weight: 400;\n line-height: normal;\n margin-bottom: 39px;\n width: 250px;\n display: flex;\n flex-direction: row;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n padding-left: 24px;\n padding-right: 24px;\n`;\n\nconst AllowBothText = styled.div`\n width: 175px;\n padding-left: 4px;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledTapHereImage = styled.img`\n position: fixed;\n bottom: 4px;\n\n animation: ${bounce} 2s infinite;\n\n &.left {\n left: 40px;\n }\n &.right {\n right: 40px;\n }\n`;\n\nexport const FirstA = styled.span`\n font-size: 14px;\n padding-top: 4px;\n padding-left: 3px;\n padding-right: 1px;\n`;\n\nexport const SecondA = styled.span`\n font-size: 18px;\n`;\n\ninterface DescriptionProps {\n overrideBackToAppButtonVisibility?: boolean;\n}\n\nconst DescriptionWithiOS18Support: React.FC = ({\n overrideBackToAppButtonVisibility,\n}) => {\n const { t } = useTranslation();\n const query = useQuery();\n const supportsiOS18 = isIOS && parseInt(osVersion) >= 18;\n const renderArabicVersion = i18next.language === 'ar';\n const [showBackToApp, setShowBackToApp] = useState(false);\n\n const openApp = useCallback(() => {\n const origin = query.get('origin');\n if (origin)\n window.location = `${origin}://` as (string | Location) & Location;\n }, [query]);\n\n const getStepListImage = (renderArabicVersion: boolean) => {\n return renderArabicVersion\n ? images.partnerpluginsdk_safari_settings_steps_ios_aa_ar\n : images.partnerpluginsdk_safari_settings_steps_ios_aa;\n };\n\n const getTapIconImage = (renderArabicVersion: boolean) => {\n if (renderArabicVersion) {\n return supportsiOS18\n ? images.partnerpluginsdk_tap_here_ios_18_ar\n : images.partnerpluginsdk_tap_aa_here_ar;\n } else {\n return supportsiOS18\n ? images.partnerpluginsdk_tap_here_ios_18\n : images.partnerpluginsdk_tap_aa_here;\n }\n };\n\n useEffect(() => {\n if (overrideBackToAppButtonVisibility) {\n setShowBackToApp(overrideBackToAppButtonVisibility);\n }\n }, [overrideBackToAppButtonVisibility]);\n\n useEffect(() => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message && message.data === '') {\n window.location.reload();\n } else if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n setShowBackToApp(true);\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => window.removeEventListener('message', messageHandler);\n }, []);\n\n return (\n \n \n \n \n \n \n \n \n 1.{' '}\n {!supportsiOS18 ? (\n \n A\n A\n \n ) : (\n t('PartnerpluginsdkActivate.tapToolIcon')\n )}\n \n \n 2. {t('PartnerpluginsdkActivate.tapManageExtension')}\n \n \n 3. {t('PartnerpluginsdkActivate.toggleOnTheExtension')}\n \n \n 4. {t('PartnerpluginsdkActivate.clickAlwaysAllow')}\n \n \n 5.\n \n {t('PartnerpluginsdkActivate.clickAlwaysAllowOnEverySite')}\n \n \n \n \n \n \n
    \n
    \n {showBackToApp && (\n \n {t('PartnerpluginsdkActivate.backToYourAppButton')}\n \n )}\n
    \n \n

    \n
    \n
    \n \n
    \n );\n};\n\nexport default DescriptionWithiOS18Support;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport { Trans, useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { StyledButton1 } from '../../Common/Buttons/StyledButtons';\nimport Center from '../../Common/Layouts/Center';\nimport { themeColor } from '../../Theming';\nimport colors from '../../Theming/colors';\nimport images from '../../Theming/images';\n\nconst Container = styled.div`\n width: 100%;\n font-family: 'Fira Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI',\n 'Roboto', 'Palanquin', 'Oxygen', 'Ubuntu', 'Cantarell', 'Droid Sans',\n 'Helvetica Neue', sans-serif;\n\n ol {\n padding: 0;\n padding-left: 1rem;\n }\n ol > li {\n padding-bottom: 0.8rem;\n font-size: small;\n }\n img {\n flex: 1;\n object-fit: cover;\n margin-left: 0.2rem;\n }\n h6 {\n margin: 0.5rem 0;\n padding: 0;\n }\n h4 {\n color: ${themeColor('green')};\n }\n`;\n\nconst WhatYouNeedText = styled.div`\n font-size: 24px;\n font-style: normal;\n font-weight: Bold;\n line-height: 35px;\n margin-bottom: 11px;\n text-align: center;\n margin-top: 52px;\n width: 100%;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n`;\n\nconst DisclaimerSubText = styled.p`\n text-align: center;\n font-size: 20px;\n font-style: normal;\n font-weight: 400;\n line-height: 120%;\n width: 334px;\n`;\n\nconst DisclaimerSubTextContainer = styled.div`\n width: 100%;\n margin-bottom: 124px;\n margin-top: -2px;\n display: flex;\n justify-content: center;\n`;\n\nconst StyledImage = styled.img`\n width: 91.813px;\n height: 91.311px;\n`;\n\nconst StyledImageContainer = styled.div`\n margin-top: 55px;\n`;\n\nconst StyledButtonContainer = styled.div`\n width: 100%;\n position: fixed;\n bottom: -10px;\n left: 50%;\n padding-left: 34px;\n padding-right: 34px;\n transform: translateX(-50%);\n max-width: 400px;\n`;\n\nconst DescriptionWithBrowserNotSupported: React.FC = () => {\n const { t } = useTranslation();\n\n const copyToClipboard = async () => {\n const alertMessage = t('PartnerpluginsdkActivate.linkCopied');\n try {\n navigator.clipboard.writeText(window.location.href).then(() => {\n alert(alertMessage);\n });\n } catch {\n // fallback for unsupported browsers\n const tempInput = document.createElement('textarea');\n tempInput.value = window.location.href;\n document.body.appendChild(tempInput);\n tempInput.select();\n document.execCommand('copy');\n document.body.removeChild(tempInput);\n alert(alertMessage);\n }\n };\n\n return (\n \n \n \n \n \n \n
    \n \n \n \n \n \n {t('PartnerpluginsdkActivate.iOSExtensionOnlyWorksOn')}\n \n \n \n \n {t('PartnerpluginsdkActivate.copyLink')}\n \n \n
    \n
    \n );\n};\n\nexport default DescriptionWithBrowserNotSupported;\n","import React, { useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport { isMobile, browserName, isSafari } from 'react-device-detect';\nimport DescriptionWithiOS18Support from './Components/DescriptionWithiOS18Support';\nimport images from '../Theming/images';\nimport DescriptionWithBrowserNotSupported from './Components/DescriptionWithBrowserNotSupported';\nimport { useQuery } from '../Common/Hooks';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n width: 100%;\n max-width: 700px;\n margin: 0 auto;\n padding: 1rem 1.5rem;\n font-family: 'Fira Sans';\n`;\n\nconst LogoContainer = styled.div`\n display: flex;\n justify-content: center;\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst fadeIn = keyframes`\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n`;\n\nconst StyledLogo = styled.img`\n min-width: 3rem;\n width: 7%;\n\n opacity: 0;\n animation: ${fadeIn} 1s ease-in forwards;\n animation-delay: 2s;\n`;\n\nconst PartnerPluginActivateBase = () => {\n const [showNotSupportedWarning, setShowNotSupportedWarning] = useState(false);\n const [\n overrideBackToAppButtonVisibility,\n setOverrideBackToAppButtonVisibility,\n ] = useState(false);\n const query = useQuery();\n\n useEffect(() => {\n // used if you want to edit not supported page on hyperise\n const notSafariOverride = query.get('notsafarioverride');\n // used if you want to edit back to app button styling on hyperise\n const backToAppButtonVisibility = query.get('backtoappbuttonvisibility');\n\n if (backToAppButtonVisibility) {\n setOverrideBackToAppButtonVisibility(true);\n }\n\n if ((isMobile && !isSafari) || notSafariOverride) {\n setShowNotSupportedWarning(true);\n }\n }, []);\n\n return (\n \n \n

    \n
    \n \n \n \n {!showNotSupportedWarning && (\n \n

    \n
    \n )}\n {!showNotSupportedWarning && (\n \n

    \n
    \n )}\n {showNotSupportedWarning ? (\n \n ) : (\n \n )}\n
    \n );\n};\n\nexport default PartnerPluginActivateBase;\n","export default __webpack_public_path__ + \"static/media/discountsFavicon.de8f7c4c.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport { Trans, useTranslation } from 'react-i18next';\nimport { themeColor } from '../../Theming';\nimport { KindredIcon } from '../../Common/Icons';\nimport colors from '../../Theming/colors';\nimport clsx from 'clsx';\nimport { Helmet } from 'react-helmet';\nimport sliideFavIcon from '../../Assets/Icons/discountsFavicon.png';\n\nconst Container = styled.div<{ backgroundColor?: string; gradient?: string }>`\n width: 100%;\n max-width: 700px;\n margin: 0 auto;\n background-color: ${(props) => props.backgroundColor ?? colors.smokeGrey};\n ${(props) => (props.gradient ? `background:${props.gradient};` : '')}\n`;\n\nconst OvalContainer = styled.div`\n width: 100%;\n max-width: 700px;\n border-radius: 50% / 60% 60% 0 0;\n height: 45px;\n background-color: ${themeColor('white')};\n`;\n\nconst Body = styled.div`\n background-color: ${themeColor('white')};\n margin-top: -23px;\n min-height: 400px;\n`;\n\nconst BodyGradient = styled.div<{ showBodyGradient?: boolean }>`\n ${(props) =>\n props.showBodyGradient\n ? ' background: linear-gradient( 0deg, #dee0e4 2.14%,rgba(222, 224, 228, 0) 96.73%);'\n : ''}\n margin-top: -23px;\n min-height: 400px;\n`;\n\nconst Header = styled.div<{ sliide?: boolean; sliideSubtitle?: string }>`\n height: ${(props) =>\n props.sliide ? (props.sliideSubtitle ? '240' : '200') : '292'}px;\n\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding-top: 89px;\n`;\n\nconst HeaderText = styled.div<{\n paddingTop?: number;\n color?: string;\n textWidth?: number;\n}>`\n text-align: center;\n font-style: normal;\n line-height: normal;\n font-weight: 400;\n font-size: 24px;\n color: ${(props) => props.color ?? colors.black};\n width: ${(props) => props.textWidth ?? 320}px;\n padding-top: ${(props) => props.paddingTop ?? 10}px;\n\n &.sliide {\n font-weight: 700;\n font-size: 30px;\n color: white;\n width: 320px;\n padding-top: 0;\n }\n`;\n\nconst BoldText = styled.div`\n font-weight: bold;\n`;\n\nconst SliideHeaderSubtitile = styled.div`\n color: white;\n text-align: center;\n font-size: 20px;\n font-style: normal;\n font-weight: 400;\n line-height: 35px;\n margin-top: 20px;\n`;\n\ninterface MultiStepContainerProps {\n backgroundColor?: string;\n gradientBackground?: string;\n headerText?: string;\n headerTextTopPadding?: number;\n headerTextColor?: string;\n headerTextWidth?: number;\n showBodyGradient?: boolean;\n sliide?: boolean;\n sliideSubtitle?: string;\n}\n\nconst MultiStepActivationContainer: React.FC = ({\n children,\n backgroundColor,\n gradientBackground,\n headerText,\n headerTextTopPadding,\n headerTextColor,\n headerTextWidth,\n showBodyGradient = false,\n sliide,\n sliideSubtitle,\n}) => {\n const { t } = useTranslation();\n\n return (\n \n {sliide && (\n \n \n Smart Discounts\n \n )}\n
    \n {!sliide && (\n \n )}\n \n \n AbsoluteText\n \n \n {sliide && sliideSubtitle && (\n {t(sliideSubtitle)}\n )}\n
    \n \n \n \n {children}\n \n \n \n );\n};\n\nexport default MultiStepActivationContainer;\n","import React from 'react';\nimport { Trans, useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { themeColor } from '../../Theming';\n\nconst Row = styled.div`\n display: flex;\n align-items: center;\n margin-bottom: 30px;\n`;\n\nconst StepNumber = styled.div<{ isCurrent?: boolean }>`\n min-width: 30px;\n min-height: 30px;\n max-width: 30px;\n max-height: 30px;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: ${({ isCurrent }) =>\n isCurrent ? themeColor('veryDarkGreen') : themeColor('mediumGrey')};\n border-radius: 30px;\n text-align: center;\n font-size: 0.938rem;\n margin-top: 8px;\n color: ${themeColor('white')};\n font-family: 'FrutigerLTStd-Light';\n margin-right: 0.5rem;\n`;\n\nconst TextContainer = styled.div<{ isCurrent: boolean }>`\n font-size: 0.875rem;\n color: ${({ isCurrent }) =>\n isCurrent ? themeColor('veryDarkBlue') : themeColor('mediumGrey')};\n margin-right: 16px;\n display: inline;\n`;\n\nexport const FirstA = styled.span`\n font-size: 12px;\n`;\n\nexport const SecondA = styled.span`\n font-size: 16px;\n`;\n\ntype ActivationStep = '1' | '2' | '3' | '4';\n\ninterface InstructionStepProps {\n step: ActivationStep;\n currentStep?: number;\n}\n\nconst InstructionStep: React.FC = ({\n step,\n currentStep = 1,\n}) => {\n const { t } = useTranslation();\n const isCurrent = currentStep >= Number(step);\n return (\n \n
    \n {step}\n
    \n
    \n \n \n A\n A\n \n \n
    \n
    \n );\n};\n\nexport default InstructionStep;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport clsx from 'clsx';\nimport images from '../../Theming/images';\nimport { MultiStepProps } from '../PartnerPluginActivateMultiStep';\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n animation: ${bounce} 2s infinite;\n\n &.showAtBottom {\n bottom: 4px;\n left: 40px;\n }\n\n &.showAtTop {\n top: 8px;\n left: 5px;\n }\n`;\n\nconst TAP_HERE_IMAGES = {\n sliide: {\n bottom: images.partnerpluginsdk_tap_here_bottom_sliide,\n top: images.partnerpluginsdk_tap_here_top_left_sliide,\n },\n kindred: {\n bottom: images.partnerpluginsdk_tap_here_bottom,\n top: images.partnerpluginsdk_tap_here_top_left,\n },\n};\n\nconst TapHereAnimated: React.FC = ({ sliide }) => {\n const [showAtBottom, setShowBottom] = useState(true);\n const image = useMemo(() => {\n const imagesToShow = sliide\n ? TAP_HERE_IMAGES.sliide\n : TAP_HERE_IMAGES.kindred;\n\n return showAtBottom ? imagesToShow.bottom : imagesToShow.top;\n }, [showAtBottom, sliide]);\n\n function getiOSVersion() {\n const userAgent = navigator.userAgent || '';\n if (/iP(hone|od|ad)/.test(userAgent)) {\n const v = userAgent.match(/OS (\\d+)_/);\n return v ? parseInt(v[1], 10) : null;\n }\n return null;\n }\n\n useEffect(() => {\n const version = getiOSVersion();\n\n if (version && version < 15) {\n setShowBottom(false);\n }\n }, []);\n\n return (\n \n );\n};\n\nexport default TapHereAnimated;\n","import React, { useEffect, useState } from 'react';\nimport { isIOS, osVersion } from 'react-device-detect';\nimport styled from 'styled-components';\nimport { useHistory } from 'react-router-dom';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { FirstA, SecondA } from './Components/InstructionStep';\nimport { Path } from '../Routing';\nimport TapHereAnimated from './Components/TapHereAnimated';\nimport env from '../env';\n\nexport const MultiStepHeaderText = styled.h3`\n color: ${(props) => themeColor(props.sliide ? 'black' : 'smokeBlack')};\n text-align: center;\n font-size: 22px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n`;\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 15px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n width: 310px;\n`;\n\nconst LinkText = styled.a`\n color: ${(props) => themeColor(props.sliide ? 'verizonRed' : 'blue')};\n text-decoration: none;\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 320px;\n min-height: 106px;\n margin-top: 33px;\n margin-left: 50px;\n`;\n\nconst IconContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n padding-bottom: 23px;\n`;\n\nconst IconContentDescription = styled.div`\n width: 253px;\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n margin-left: 15px;\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n`;\n\nconst TextTitleContainer = styled.div`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n line-height: 15px;\n align-items: center;\n`;\n\nconst StrongText = styled.strong`\n padding-left: 2px;\n padding-right: 2px;\n`;\n\nexport interface MultiStepProps {\n sliide?: boolean;\n}\n\nexport const addSliideText = (sliide: boolean | undefined) => {\n return sliide ? 'Sliide' : '';\n};\n\nconst PartnerPluginActivateMultiStep: React.FC = ({\n sliide,\n}) => {\n const { t } = useTranslation();\n const history = useHistory();\n const supportsiOS18 = isIOS && parseInt(osVersion) >= 18;\n\n useEffect(() => {\n const initialHeight = window.innerHeight;\n\n const interval = setInterval(() => {\n const currentHeight = window.innerHeight;\n\n if (currentHeight < initialHeight) {\n history.push({\n pathname: Path.PluginActivationReviewPermissions,\n search: location.search,\n });\n }\n }, 1500);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.PluginActivationStartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.PluginActivationAllowPermissions,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => {\n clearInterval(interval);\n window.removeEventListener('message', messageHandler);\n };\n }, [history]);\n\n return (\n \n \n \n {t(\n 'PartnerpluginsdkActivate.multiStep.enableKindred' +\n addSliideText(sliide)\n )}\n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n \n \n {!supportsiOS18 ? (\n \n A\n A\n \n ) : (\n \n \n {t('PartnerpluginsdkActivate.multiStep.tapTheAaPart1')}\n \n \n \n BoldText\n \n \n )}\n \n \n \n \n \n \n A\n \n \n \n \n \n );\n};\n\nexport default PartnerPluginActivateMultiStep;\n","import styled, { css } from 'styled-components';\nimport { themeColor } from '../../Theming';\n\nexport const Error = styled.span`\n display: inline-block;\n margin-top: 6px;\n color: ${themeColor('pink')};\n`;\n\nexport const CommonInputCss = css`\n display: block;\n width: 100%;\n background: none;\n border: none;\n border-bottom: 1px solid ${themeColor('black')};\n height: 35px;\n font-size: 1.125rem;\n`;\n\ndeclare type FormControlElement =\n | HTMLInputElement\n | HTMLSelectElement\n | HTMLTextAreaElement;\n\nexport interface FormControlProps {\n placeholder?: string;\n required?: boolean;\n disabled?: boolean;\n name?: string;\n value?: string | string[] | number;\n onChange?: React.ChangeEventHandler;\n type?: string;\n error?: string;\n touched?: boolean;\n}\n","import i18next from 'i18next';\nimport { useEffect } from 'react';\nimport { useHistory } from 'react-router-dom';\n\nexport const useLanguageUtm = () => {\n const history = useHistory();\n\n useEffect(() => {\n const url = new URL(window.location.href);\n if (!url.searchParams.has('utm_content')) {\n url.searchParams.append('utm_content', i18next.language);\n history.push(`${url.pathname}${url.search}`);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [i18next.language]);\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { CommonInputCss, Error, FormControlProps } from './Common';\n\nconst Container = styled.div`\n margin: 18px 0;\n`;\n\nconst Input = styled.input`\n ${CommonInputCss}\n`;\n\nconst FormControl: React.FC = ({\n placeholder,\n required,\n touched,\n error,\n ...props\n}) => {\n return (\n \n \n {touched && error && {error}}\n \n );\n};\n\nexport default FormControl;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { CommonInputCss, Error, FormControlProps } from './Common';\n\nconst Container = styled.div`\n margin: 18px 0;\n`;\n\nconst StyledSelect = styled.select`\n ${CommonInputCss}\n`;\n\nconst FormSelect: React.FC = ({\n placeholder,\n required,\n touched,\n error,\n children,\n ...props\n}) => {\n return (\n \n \n {children}\n \n {touched && error && {error}}\n \n );\n};\n\nexport default FormSelect;\n","import React, { ComponentProps } from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\n\ninterface FormInputType extends ComponentProps {\n placeholder: string;\n label: string;\n alt?: boolean;\n}\n\nconst Container = styled.div`\n display: block;\n font-size: 1rem;\n font-weight: 400;\n\n ${mobileMediaQuery} {\n width: 100%;\n }\n`;\n\nconst Input = styled.input<{ alternate?: boolean }>`\n height: 69px;\n margin-top: 10px;\n width: 371px;\n padding-left: 10px;\n display: block;\n border-radius: 5px;\n border-radius: ${({ alternate }) => (alternate ? '0px' : '5px')};\n border: 1px solid\n ${({ alternate }) =>\n alternate ? themeColor('darkestGrey') : themeColor('darkGrey')};\n -webkit-appearance: none;\n\n &:hover {\n -webkit-appearance: none;\n }\n\n ::-webkit-outer-spin-button,\n ::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n ${mobileMediaQuery} {\n border-radius: ${({ alternate }) => alternate && '5px'};\n padding: 0 12px;\n height: 46px;\n width: 100%;\n }\n`;\n\nconst Label = styled.label<{ alt?: boolean }>`\n color: ${({ alt }) =>\n alt ? themeColor('darkestGrey') : themeColor('darkGrey')};\n font-size: 1rem;\n`;\n\nconst FormInput: React.FC = ({\n placeholder,\n label,\n alt,\n ...props\n}) => {\n return (\n \n \n \n \n );\n};\n\nexport default FormInput;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { useTranslation } from 'react-i18next';\nimport { themeColor } from '../../Theming';\nimport KindredLogo from '../Logos/KindredLogo';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nconst StyledFlex = styled.div`\n display: flex;\n align-items: center;\n justify-content: space-evenly;\n width: fit-content;\n`;\n\nconst Text = styled.p`\n font-size: 0.875rem;\n margin-right: 5px;\n color: ${themeColor('veryDarkBlue')};\n`;\n\nconst Paragraph = styled.p`\n text-align: center;\n line-height: 1.25rem;\n font-size: 0.875rem;\n color: ${themeColor('veryDarkBlue')};\n padding: 0 26px;\n margin-bottom: 17px;\n`;\n\ninterface PoweredByKindredProps {\n hasInfo?: boolean;\n}\n\nconst PoweredByKindred: React.FC = ({ hasInfo }) => {\n const [showInfo, setShowInfo] = useState(false);\n\n const { t } = useTranslation();\n return (\n \n setShowInfo(!showInfo)}>\n {t('global.poweredBy')}\n \n \n {hasInfo && showInfo && {t('global.kindredInfo')}}\n \n );\n};\n\nexport default PoweredByKindred;\n","import { useEffect } from 'react';\n\nconst usePageTitle = (title?: string): void => {\n useEffect(() => {\n const params = new URLSearchParams(window.location.search);\n if (params.has('utm_campaign')) {\n const partnerTitle = params.get('utm_campaign');\n if (partnerTitle) {\n document.title = partnerTitle;\n }\n } else {\n if (title) {\n document.title = `Kindred for Business - ${title}`;\n } else {\n document.title = 'Kindred for Business';\n }\n }\n }, [title]);\n};\n\nexport default usePageTitle;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport PartnerPluginActivateBase from './PartnerPluginActivateBase';\nimport PartnerPluginActivateMultiStep from './PartnerPluginActivateMultiStep';\nimport { useLanguageUtm } from '../Common';\nimport usePageTitle from '../Common/Hooks/usePageTitle';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nexport const hasSliideOrigin = () => {\n return window.location.search.includes('utm_campaign=sliide');\n};\n\nconst PartnerpluginsdkActivate = () => {\n useLanguageUtm();\n usePageTitle();\n const [hasExperimentOrigin, setHasExperimentOrigin] = useState(false);\n const [sliide] = useState(hasSliideOrigin());\n\n useEffect(() => {\n const hasKindredOrigin = window.location.search.includes('origin=kindred');\n\n setHasExperimentOrigin(hasKindredOrigin || hasSliideOrigin());\n }, []);\n\n return hasExperimentOrigin ? (\n \n ) : (\n \n );\n};\n\nexport default PartnerpluginsdkActivate;\n","import { useEffect } from 'react';\nimport { useLocation } from 'react-router-dom';\n\nconst ScrollToTop = () => {\n const { pathname } = useLocation();\n\n useEffect(() => {\n window.scrollTo(0, 0);\n }, [pathname]);\n\n return null;\n};\n\nexport default ScrollToTop;\n","import { v4 as uuidv4 } from 'uuid';\n\nconst EXTENSION_SDK_RANDOM_USER_ID_NAME = 'KK_EXTENSION_SDK_USER';\nexport const KK_UTM_SOURCE = 'KKUtmSource';\nexport const KK_UTM_COMPAIGN = 'KKUtmCampaign';\nexport const KK_UTM_MEDIUM = 'KKUtmMedium';\n\nexport const getRandomUserId = () => {\n const userId = localStorage.getItem(EXTENSION_SDK_RANDOM_USER_ID_NAME);\n if (userId) {\n return userId;\n } else {\n const userId = uuidv4();\n localStorage.setItem(EXTENSION_SDK_RANDOM_USER_ID_NAME, userId);\n return userId;\n }\n};\n\nexport const getUtmParamsForChromeExtension = () => {\n return {\n utmSource: localStorage.getItem(KK_UTM_SOURCE),\n utmCampaign: localStorage.getItem(KK_UTM_COMPAIGN),\n utmMedium: localStorage.getItem(KK_UTM_MEDIUM),\n };\n};\n","import { useEffect } from 'react';\nimport { useHistory } from 'react-router-dom';\nimport env from '../env';\nimport {\n KK_UTM_SOURCE,\n KK_UTM_COMPAIGN,\n KK_UTM_MEDIUM,\n} from '../Common/Utils/extensionSDK';\n\nconst key = 'KINDRED_PARTNER_SAMSUNG';\n\ninterface PartnerSamsungProps {\n partnerId?: string | null;\n userId?: string | null;\n userCurrency?: string | null;\n userCountryCode?: string | null;\n}\n\nexport const setPartnerSamsungProps = (props: PartnerSamsungProps) => {\n localStorage.setItem(key, JSON.stringify(props));\n};\n\nexport const getPartnerSamsungProps = (): PartnerSamsungProps | null => {\n const result = localStorage.getItem(key);\n\n if (result) {\n return JSON.parse(result);\n }\n\n return null;\n};\n\nexport const usePartnerSamsungQueryParamExtraction = () => {\n useEffect(() => {\n const partnerSamsungProps = getPartnerSamsungProps() ?? {};\n\n const url = new URL(location.href);\n\n if (url.searchParams.has('partnerId')) {\n partnerSamsungProps.partnerId = url.searchParams.get('partnerId');\n }\n\n if (url.searchParams.has('userId')) {\n partnerSamsungProps.userId = url.searchParams.get('userId');\n }\n\n if (url.searchParams.has('userCurrency')) {\n partnerSamsungProps.userCurrency = url.searchParams.get('userCurrency');\n }\n\n if (url.searchParams.has('userCountryCode')) {\n partnerSamsungProps.userCountryCode =\n url.searchParams.get('userCountryCode');\n }\n\n setPartnerSamsungProps(partnerSamsungProps);\n }, []);\n};\n\nexport const usePartnerSamsungParams = () => {\n const history = useHistory();\n\n useEffect(() => {\n const params = getPartnerSamsungProps();\n\n const url = new URL(window.location.href);\n if (params?.partnerId) {\n url.searchParams.set('pid', params?.partnerId);\n }\n if (params?.userId) {\n url.searchParams.set('uid', params?.userId);\n }\n if (params?.userCurrency) {\n url.searchParams.set('uc', params?.userCurrency);\n }\n if (params?.userCountryCode) {\n url.searchParams.set('ucc', params?.userCountryCode);\n }\n\n history.push(`${url.pathname}${url.search}`);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n};\n\nexport const useChromeExtensionUTMQueryParamExtraction = () => {\n useEffect(() => {\n const url = new URL(location.href);\n\n if (url.searchParams.has('utm_source')) {\n const utm_source = url.searchParams.get('utm_source');\n localStorage.setItem(KK_UTM_SOURCE, utm_source as string);\n }\n\n if (url.searchParams.has('utm_campaign')) {\n const utm_campaign = url.searchParams.get('utm_campaign');\n localStorage.setItem(KK_UTM_COMPAIGN, utm_campaign as string);\n }\n\n if (url.searchParams.has('utm_medium')) {\n const utm_medium = url.searchParams.get('utm_medium');\n localStorage.setItem(KK_UTM_MEDIUM, utm_medium as string);\n }\n location.href = env.chrome_extension_store_url;\n }, []);\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n// SlideShow.js\nimport React, { useEffect, useState, useRef, Fragment } from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\nimport colors from '../../Theming/colors';\nimport { Trans, useTranslation } from 'react-i18next';\nimport { themeColor } from '../../Theming';\n\nconst Container = styled.div`\n width: 321px;\n overflow: hidden;\n position: relative;\n margin-top: 15px;\n`;\n\nconst Slides = styled.div<{ activeIndex: number }>`\n display: flex;\n transition: transform 0.3s;\n transform: translateX(${(props) => -props.activeIndex * 100}%);\n`;\n\nconst Slide = styled.div`\n min-width: 321px;\n mn-height: 247px;\n`;\n\nconst PillsContainer = styled.div`\n position: absolute;\n bottom: 20px;\n left: 50%;\n transform: translateX(-50%);\n display: flex;\n gap: 5px;\n`;\n\nconst Pill = styled.div<{ active: boolean; sliide?: boolean }>`\n width: 6px;\n height: 6px;\n border-radius: 50%;\n cursor: pointer;\n background-color: ${(props) =>\n props.active\n ? colors.discountsPurple\n : colors.samsungActivationPillDarkGrey};\n`;\n\nconst StyledImage = styled.img`\n width: 320px;\n`;\n\nconst SubTextContainer = styled.div`\n color: ${themeColor('black')};\n font-size: 13px;\n width: 321px;\n height: 45px;\n margin-top: -10px;\n display: flex;\n flex-direction: row;\n justify-content: center;\n font-style: normal;\n font-weight: 400;\n line-height: 18px;\n`;\n\nconst SubText = styled.p<{ maxWidth: number }>`\n max-width: ${(props) => props.maxWidth}px;\n`;\n\nconst PostActivationSlide: React.FC = () => {\n const { t } = useTranslation();\n const [activeIndex, setActiveIndex] = useState(0);\n const [startX, setStartX] = useState(0);\n const intervalRef = useRef(null);\n const slides = [\n images.samsung_activation_deals_found?.default,\n images.samsung_activation_you_saved_so_far?.default,\n images.samsung_activation_you_saved?.default,\n ];\n\n useEffect(() => {\n intervalRef.current = setInterval(() => {\n setActiveIndex((prevIndex) => (prevIndex + 1) % slides.length);\n }, 5000);\n\n return () => {\n if (intervalRef.current) {\n clearInterval(intervalRef.current);\n }\n };\n }, []);\n\n const handleTouchStart = (e: any) => {\n setStartX(e.touches[0].clientX);\n };\n\n const handleTouchEnd = (e: any) => {\n const endX = e.changedTouches[0].clientX;\n const deltaX = endX - startX;\n\n if (deltaX > 50 && activeIndex > 0) {\n setActiveIndex((prev) => prev - 1);\n } else if (deltaX < -50 && activeIndex < slides.length - 1) {\n setActiveIndex((prev) => prev + 1);\n }\n if (intervalRef.current) {\n clearInterval(intervalRef.current);\n }\n };\n\n return (\n
    \n \n \n {slides.map((img, index) => (\n \n \n \n ))}\n \n \n {slides.map((_, index) => (\n setActiveIndex(index)}\n />\n ))}\n \n \n \n \n {t('samsung.activation.slideStep' + (activeIndex + 1))\n .split('\\n')\n .map((item, key) => (\n \n {item}
    \n
    \n ))}\n
    \n
    \n
    \n );\n};\n\nexport default PostActivationSlide;\n","import React, { useEffect, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { ThemeProvider } from 'styled-components';\nimport { KindredIcon } from '../../Common/Icons';\nimport { themeColor } from '../../Theming';\nimport PostActivationSlide from './PostActivationSlide';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n width: 100%;\n max-width: 700px;\n margin: 0 auto;\n padding: 1rem 1.5rem;\n\n & > #description {\n text-align: center;\n }\n`;\n\nconst LogoContainer = styled.div`\n display: flex;\n justify-content: center;\n`;\n\nconst AllDone = styled.p`\n color: ${themeColor('black')};\n font-size: 22px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n margin-bottom: -5px;\n`;\n\nconst SaveWhileDoingGood = styled.p`\n color: ${themeColor('black')};\n font-size: 13px;\n max-width: 275px;\n font-style: normal;\n font-weight: 400;\n line-height: 18px;\n`;\n\nconst ExperienceSavings = styled.p`\n color: ${themeColor('black')};\n font-size: 19px;\n font-weight: bold;\n max-width: 275px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n margin-top: 25px;\n`;\n\nconst ContentContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: -20px;\n`;\n\nconst imageStyle = { width: 59, height: 59 };\n\nconst PostActivationPage: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n \n
    \n

    \n
    \n \n \n \n
    \n

    \n
    \n
    \n

    \n
    \n \n {t('samsung.activation.allDone')}\n \n {t('samsung.activation.saveWhileDoingGood')}\n \n \n \n {t('samsung.activation.experienceSavings')}\n \n \n
    \n

    \n
    \n
    \n );\n};\n\nexport default PostActivationPage;\n","import React, { useEffect, useState } from 'react';\nimport { useLanguageUtm } from '../Common';\nimport usePageTitle from '../Common/Hooks/usePageTitle';\nimport env from '../env';\nimport { usePartnerSamsungParams } from './utils';\nimport PostActivationPage from './PostActivationPage/PostActivationPage';\n\nconst SamsungActivation: React.FC = () => {\n usePartnerSamsungParams();\n useLanguageUtm();\n usePageTitle();\n\n return ;\n};\n\nexport default SamsungActivation;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { getPlatform } from '../../Common/Utils/platforms';\n\nconst ExtensionLink = styled.a`\n border: none;\n font-family: 'Fira Sans';\n font-style: normal;\n font-weight: 700;\n font-size: 40px;\n line-height: 45px;\n cursor: pointer;\n text-decoration: underline;\n`;\n\ninterface ExtensionInstallLinkProps {\n className?: string;\n browser?: string;\n buttonText?: string;\n onClick?(): void;\n}\n\nconst ExtensionInstallLink: React.FC = ({\n className,\n buttonText,\n onClick,\n}) => {\n const { t } = useTranslation();\n\n const platform = getPlatform();\n\n return (\n \n {buttonText ?? t('extension.referral.addButton')}\n \n );\n};\n\nexport default ExtensionInstallLink;\n","import * as React from 'react';\nimport styled from 'styled-components';\n\nexport const LinearGradient = styled.div`\n width: 100%;\n height: 2px;\n display: flex;\n width: 100%;\n background: linear-gradient(\n 90deg,\n #92e3a9 -0.7%,\n #de1f70 29%,\n #231f20 60.67%,\n #0b1c2f 90.06%\n );\n`;\n\nconst Separator: React.FC = () => {\n return ;\n};\n\nexport default Separator;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport KindredLogo from '../../Common/Logos/KindredLogo';\nimport { themeColor } from '../../Theming';\nimport ExtensionInstallLink from './ExtensionInstallLink';\nimport Separator from './Separator';\n\nconst Container = styled.div`\n margin-bottom: 0px;\n display: block;\n justify-content: center;\n width: 100%;\n`;\n\nconst LogoContainer = styled.div`\n padding-bottom: 30px;\n position: relative;\n`;\n\nconst HeadingContainer = styled.div`\n width: 100%;\n display: flex;\n justify-content: center;\n`;\n\nconst Heading = styled.h1`\n width: 90%;\n font-style: normal;\n font-weight: 700;\n font-size: 40px;\n line-height: 45px;\n text-align: center;\n`;\n\nconst StyledExtensionInstallLink = styled(ExtensionInstallLink)`\n color: ${themeColor('darkestGrey')};\n`;\n\ninterface MinimalHeaderProps {\n uninstallHeading?: boolean;\n}\n\nconst MinimalHeader: React.FC = ({ uninstallHeading }) => {\n const { t } = useTranslation();\n\n return (\n \n \n \n \n\n {uninstallHeading && (\n \n \n {t('extension.uninstalled.title')}{' '}\n {t('extension.uninstalled.uninstalledByAccident')}{' '}\n \n \n \n )}\n \n \n );\n};\n\nexport default MinimalHeader;\n","export default __webpack_public_path__ + \"static/media/shop.59ef4063.png\";","export default __webpack_public_path__ + \"static/media/save.52391c32.png\";","export default __webpack_public_path__ + \"static/media/safe.a0e44e41.png\";","import React, { useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../Theming';\n\nconst Container = styled.div`\n width: 100%;\n display: grid;\n grid-template-columns: 1fr 1fr;\n margin: 60px 0 0;\n align-items: center;\n ${mobileMediaQuery} {\n grid-template-columns: 1fr;\n margin: 0;\n }\n`;\n\nconst TextContainer = styled.div`\n width: 100%;\n align-items: center;\n`;\n\nconst Header = styled.h3`\n font-size: 2.5rem;\n font-weight: bold;\n margin: 0 0 60px 40px;\n ${mobileMediaQuery} {\n display: flex;\n justify-content: center;\n margin: 0 0 60px 0;\n font-size: 1.5rem;\n }\n`;\n\nconst StyledList = styled.ol<{ selectedIndex: number; itemsCount: number }>`\n list-style-position: inside;\n margin: 0;\n padding: 0 0 0 40px;\n position: relative;\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n width: 4px;\n border-radius: 4px;\n background-color: ${themeColor('lightestGrey')};\n }\n &::after {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n width: 4px;\n border-radius: 4px;\n background: linear-gradient(\n 180deg,\n #ff4f65 0.07%,\n #f7c945 34.39%,\n #4dcafe 69.76%,\n #536efe 99.93%\n );\n clip-path: ${({ selectedIndex, itemsCount }) =>\n `inset(${(selectedIndex * 100) / itemsCount}% 0 ${\n 100 - ((selectedIndex + 1) * 100) / itemsCount\n }% 0)`};\n transition: clip-path 0.15s ease-in-out;\n }\n`;\n\nconst ListItem = styled.li<{ active: boolean }>`\n cursor: pointer;\n color: ${({ active }) => themeColor(active ? 'darkestGrey' : 'darkGrey')};\n transition: color 0.15s ease-in-out;\n\n &::marker {\n font-weight: bold;\n }\n & h4 {\n font-size: 1rem;\n font-weight: bold;\n margin: 0;\n display: inline;\n }\n & p {\n font-size: 1rem;\n line-height: 150%;\n margin: 10px 0 30px;\n }\n`;\n\nconst Screenshot = styled.img`\n object-fit: cover;\n border: 1px solid ${themeColor('lightGrey')};\n border-radius: 6px;\n width: 100%;\n height: auto;\n max-width: 480px;\n max-height: 480px;\n`;\n\ninterface ItemProps {\n onClick(index: number): void;\n index: number;\n selectedIndex: number;\n}\n\nconst Item: React.FC = ({\n onClick,\n index,\n selectedIndex,\n children,\n}) => {\n return (\n onClick(index)}>\n {children}\n \n );\n};\n\nexport interface HowItWorksItem {\n i18nKey: string;\n image: string;\n}\n\ninterface ItemsProps {\n selectedIndex: number;\n items: HowItWorksItem[];\n onItemClicked(index: number): void;\n}\n\nconst Items: React.FC = ({\n items,\n selectedIndex,\n onItemClicked,\n}) => {\n const { t } = useTranslation();\n\n return (\n \n {items.map((item, i) => (\n \n

    {t(`${item.i18nKey}.title`)}

    \n

    {t(`${item.i18nKey}.text`)}

    \n \n ))}\n
    \n );\n};\n\ninterface HowItWorksProps {\n items: HowItWorksItem[];\n showAddButton?: boolean;\n buttonText?: string;\n}\n\nconst HowItWorks: React.FC = ({ items }) => {\n const { t } = useTranslation();\n const [currentItemIndex, setCurrentItemIndex] = useState(0);\n const { mobile } = useBreakPoints();\n\n return (\n \n {!mobile && }\n \n
    {t('extension.howItWorks.header')}
    \n setCurrentItemIndex(index)}\n />\n
    \n
    \n );\n};\n\nexport default HowItWorks;\n","import localeCurrency from 'locale-currency';\nimport ct from 'countries-and-timezones';\n\nexport const getBrowserCountry = (): string | null => {\n const countryCode = getBrowserISOCountry();\n\n // This is handling the GB/UK switcheroo we do\n return countryCode === 'GB' ? 'UK' : countryCode;\n};\n\nexport const getLocationCurrency = (location: string | null): string => {\n if (location === null) {\n location = 'GB';\n }\n\n // Use the correct ISO code\n if (location === 'UK') {\n location = 'GB';\n }\n\n const currency = localeCurrency.getCurrency(location);\n const knownCurrencies = ['USD', 'GBP', 'EUR'];\n\n return knownCurrencies.includes(currency) ? currency : knownCurrencies[0];\n};\n\nconst getBrowserISOCountry = () => {\n const timezone = Intl.DateTimeFormat()?.resolvedOptions()?.timeZone;\n if (!timezone) {\n return null;\n }\n\n const country = ct.getCountryForTimezone(timezone);\n\n if (country === null) {\n return null;\n }\n\n return country.id;\n};\n","// Import the functions you need from the SDKs you need\nimport { initializeApp } from 'firebase/app';\nimport env from '../env';\n\n// TODO: Add SDKs for Firebase products that you want to use\n// https://firebase.google.com/docs/web/setup#available-libraries\n// Your web app's Firebase configuration\n\nconst firebaseConfig = {\n apiKey: env.firebase_api_key,\n authDomain: env.firebase_auth_domain,\n projectId: env.firebase_project_id,\n storageBucket: env.firebase_storage_bucket,\n messagingSenderId: env.firebase_storage_bucket,\n appId: env.firebase_app_id,\n};\n\nconst app = initializeApp(firebaseConfig);\nexport default app;\n","import React, {\n createContext,\n PropsWithChildren,\n useContext,\n useEffect,\n useState,\n} from 'react';\nimport { getBrowserCountry } from '../Common/Utils/locations';\nimport {\n getValue,\n fetchAndActivate,\n getRemoteConfig,\n ensureInitialized,\n} from 'firebase/remote-config';\nimport app from '../Firebase';\nimport env from '../env';\n\ninterface IFeaturesState {\n wallet: boolean;\n autoActivation: boolean;\n offerwall: boolean;\n loading: boolean;\n}\n\nconst defaultState: IFeaturesState = {\n wallet: false,\n autoActivation: false,\n offerwall: false,\n loading: true,\n};\n\nconst FeaturesContext = createContext(defaultState);\n\nexport const useFeatures = () => useContext(FeaturesContext);\n\ninterface IFeatureFlagToggle {\n active: boolean;\n countries?: string[];\n}\n\ninterface IFeatureFlag {\n wallet: IFeatureFlagToggle;\n offerwall: IFeatureFlagToggle;\n autoActivation: IFeatureFlagToggle;\n [key: string]: IFeatureFlagToggle;\n}\n\ntype IPartnerFeatureFlags = Record;\n\nconst defaultPartnerFeatureFlags: IPartnerFeatureFlags = {\n default: {\n wallet: {\n active: true,\n },\n offerwall: {\n active: false,\n },\n autoActivation: {\n active: true,\n },\n },\n};\n\nexport const FeaturesProvider: React.FC> = ({\n children,\n}) => {\n const [loading, setLoading] = useState(true);\n const [autoActivation, setAutoActivation] = useState(false);\n const [offerwall, setOfferwall] = useState(false);\n const [wallet, setWallet] = useState(false);\n\n useEffect(() => {\n const setFeatures = async (features: IFeatureFlag) => {\n const countryCode = getBrowserCountry() ?? '';\n const keys = ['wallet', 'autoActivation', 'offerwall'];\n const setter: Record<\n string,\n React.Dispatch>\n > = {\n wallet: setWallet,\n autoActivation: setAutoActivation,\n offerwall: setOfferwall,\n };\n for (const key of keys) {\n const feature: IFeatureFlagToggle = features[key];\n if (\n feature &&\n (!feature.countries ||\n feature.countries.length === 0 ||\n feature.countries.includes(countryCode))\n ) {\n setter[key](feature.active);\n } else {\n setter[key](false);\n }\n }\n };\n\n const fetchRemoteConfig = async () => {\n const remoteConfig = await getRemoteConfig(app);\n remoteConfig.settings.minimumFetchIntervalMillis = 0;\n remoteConfig.defaultConfig = JSON.parse(\n JSON.stringify(defaultPartnerFeatureFlags)\n );\n\n await ensureInitialized(remoteConfig);\n await fetchAndActivate(remoteConfig);\n\n setLoading(true);\n const partnerFeatureFlagsStr = await getValue(\n remoteConfig,\n env.partner_features_remote_config\n );\n\n if (partnerFeatureFlagsStr) {\n const partnerFeatureFlags = JSON.parse(\n partnerFeatureFlagsStr.asString()\n );\n\n if (partnerFeatureFlags as IPartnerFeatureFlags) {\n const features = partnerFeatureFlags['default'];\n setFeatures(features);\n }\n }\n\n setLoading(false);\n };\n\n fetchRemoteConfig();\n }, []);\n\n return (\n \n {children}\n \n );\n};\n","import React, { useEffect } from 'react';\nimport styled from 'styled-components';\nimport MinimalHeader from '../Components/MinimalHeader';\nimport shop from '../../Assets/how-it-works/shop.png';\nimport save from '../../Assets/how-it-works/save.png';\nimport safe from '../../Assets/how-it-works/safe.png';\nimport { Trans, useTranslation } from 'react-i18next';\nimport usePageTitle from '../../Common/Hooks/usePageTitle';\nimport { themeColor } from '../../Theming';\nimport HowItWorks, { HowItWorksItem } from '../Components/HowItWorks';\nimport {\n getBrowserCountry,\n getLocationCurrency,\n} from '../../Common/Utils/locations';\nimport env from '../../env';\nimport {\n getRandomUserId,\n getUtmParamsForChromeExtension,\n} from '../../Common/Utils/extensionSDK';\nimport { useFeatures } from '../../PluginFeatures';\nimport { sendPartnerFeatures } from '../../PluginFeatures/helpers';\n\nconst Container = styled.div`\n width: 100%;\n padding: 60px 120px;\n`;\n\nconst Heading = styled.h1`\n text-align: center;\n margin: 60px 0 0;\n font-size: 2.5rem;\n`;\n\nconst MoreQuestions = styled.p`\n margin: 40px auto;\n max-width: 645px;\n text-align: center;\n font-size: 1rem;\n line-height: 150%;\n & a {\n color: ${themeColor('darkestGrey')};\n }\n`;\n\nconst howItWorksItems: HowItWorksItem[] = [\n { i18nKey: 'extension.howItWorks.brands', image: shop },\n { i18nKey: 'extension.howItWorks.easy', image: save },\n { i18nKey: 'extension.howItWorks.getStarted', image: safe },\n];\n\nexport const sendExtensionInstalled = (utmParams: Record) => {\n try {\n chrome.runtime.sendMessage(env.kindred_extension_id, {\n type: 'extensionInstalled',\n utmParams,\n });\n } catch {\n // do nothing\n }\n};\n\nconst ExtensionInstalled: React.FC = () => {\n usePageTitle('Extension Installed');\n const { t } = useTranslation();\n const { autoActivation, loading } = useFeatures();\n\n useEffect(() => {\n const utmParams = getUtmParamsForChromeExtension();\n sendExtensionInstalled(utmParams);\n\n const browserCountry = getBrowserCountry();\n const randomUserId = getRandomUserId();\n\n window.setKindredUser(env.kindred_extension_id, {\n id: randomUserId,\n currency: getLocationCurrency(browserCountry),\n countryCode: browserCountry,\n });\n }, []);\n\n useEffect(() => {\n if (!loading) {\n sendPartnerFeatures(autoActivation);\n }\n }, [loading, autoActivation]);\n\n return (\n \n \n {t('extension.installed.title')}\n \n \n \n Do you have any more questions? Feel free to visit our\n \n FAQs page\n \n . Here, you will find most of the the answers about Kindred to help to\n get the most out of it.\n \n \n \n );\n};\n\nexport default ExtensionInstalled;\n","import env from '../env';\n\nexport const sendPartnerFeatures = (autoActivation: boolean) => {\n try {\n chrome.runtime.sendMessage(env.kindred_extension_id, {\n type: 'partnerFeatures',\n autoActivation,\n });\n } catch (error) {\n //\n }\n};\n","import React, { useEffect, useRef } from 'react';\nimport styled from 'styled-components';\nimport * as typeformEmbed from '@typeform/embed';\nimport env from '../../env';\nimport usePageTitle from '../../Common/Hooks/usePageTitle';\nimport MinimalHeader from '../Components/MinimalHeader';\n\nconst Container = styled.div`\n width: 100%;\n padding: 60px 120px;\n`;\n\nconst StyledTypeform = styled.div`\n height: 135vh;\n width: 100%;\n`;\n\nconst ExtensionUninstalled: React.FC = () => {\n usePageTitle('Extension Uninstalled');\n\n const typeformRef = useRef(document.createElement('div'));\n\n useEffect(() => {\n typeformEmbed.makeWidget(\n typeformRef.current,\n `https://form.typeform.com/to/${env.extension_uninstall_typeform_id}?typeform-welcome=0`,\n {\n hideFooter: true,\n hideHeaders: true,\n hideScrollbars: true,\n onSubmit: () => {\n if (typeformRef) {\n typeformRef.current.style.height = '50vh';\n typeformRef.current.style.width = '100%';\n typeformRef.current.style.paddingLeft = '0';\n }\n },\n onReady: () => {\n if (typeformRef) {\n typeformRef.current.style.paddingLeft = '8%';\n typeformRef.current.style.marginTop = '0';\n }\n },\n }\n );\n }, [typeformRef]);\n\n return (\n \n \n \n \n );\n};\n\nexport default ExtensionUninstalled;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { StyledButton1 } from '../Common/Buttons/StyledButtons';\nimport { KindredIcon } from '../Common/Icons';\nimport { PoweredByKindred, useLanguageUtm } from '../Common';\nimport { useHistory } from 'react-router-dom';\nimport env from '../env';\nimport { useTranslation } from 'react-i18next';\nimport usePageTitle from '../Common/Hooks/usePageTitle';\nimport { usePartnerSamsungQueryParamExtraction } from './utils';\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n width: 100%;\n max-width: 700px;\n margin: 0 auto;\n padding: 1rem 1.5rem;\n\n & > #description {\n text-align: center;\n width: 100%;\n }\n`;\n\nconst Heading = styled.h3`\n margin: 5px 0;\n`;\n\nconst LogoContainer = styled.div`\n display: flex;\n justify-content: center;\n`;\n\nconst Description = styled.p`\n text-align: left;\n`;\n\nconst SamsungLanding: React.FC = () => {\n useLanguageUtm();\n usePageTitle();\n usePartnerSamsungQueryParamExtraction();\n\n const history = useHistory();\n const { t } = useTranslation();\n\n return (\n \n
    \n

    \n
    \n \n \n \n
    \n

    \n
    \n
    \n

    \n
    \n
    \n {t('samsung.landing.title')}\n {t('samsung.landing.description')}\n {\n if (env.samsung_plugin_install_link) {\n window.location.href = env.samsung_plugin_install_link;\n }\n }}\n borderRadius=\"0\"\n marginBottom={10}\n marginTop={20}\n padding=\"1rem\"\n >\n {t('samsung.landing.install')}\n \n \n
    \n
    \n

    \n
    \n
    \n );\n};\n\nexport default SamsungLanding;\n","import axios from 'axios';\n\nexport const apiGet = async (url: string) => {\n const response = await axios.get(url);\n return { data: response?.data as T };\n};\n","import React from 'react';\nimport { createContext, PropsWithChildren, useContext } from 'react';\nimport { useApiGet } from '../Common/Api/useApiGet';\nimport env from '../env';\n\nexport type Maybe = T | null | undefined;\n\nexport interface TreePlantingResponse {\n todaysTreePlantingTick?: number;\n totalNumberOfTreesPlanted: number;\n parnerId?: string;\n partnerName?: string;\n partnerLogo?: string;\n}\n\nexport interface TreePlantingContextProviderProps {\n partnerId?: string;\n}\n\nexport interface ITreePlantingContext {\n treesPlanted?: Maybe;\n tonnesOfCo2?: Maybe;\n squareMeteresOfIceSaved?: Maybe;\n milesDriven?: Maybe;\n parnerId?: string;\n partnerName?: string;\n partnerLogo?: string;\n showTreesPlantedByPartner?: boolean;\n todaysTreePlantingTick?: number;\n}\n\nconst defaultState: ITreePlantingContext = {\n treesPlanted: 0,\n tonnesOfCo2: 0,\n squareMeteresOfIceSaved: 0,\n milesDriven: 0,\n showTreesPlantedByPartner: false,\n todaysTreePlantingTick: 0,\n};\n\nexport const TreePlantingContext =\n createContext(defaultState);\n\nexport const useTreePlantedContext = () => useContext(TreePlantingContext);\n\nexport const TreePlantingContextProvider: React.FC<\n PropsWithChildren\n> = ({ children, partnerId }) => {\n const pathSuffix = partnerId ? `partner/${partnerId}` : 'all';\n\n const { data } = useApiGet(\n `${env.api_url}/partners/platform/Trees/${pathSuffix}`\n );\n\n /** tonnes of Co2 = total number of trees * 0.3 */\n const tonnesOfCo2 =\n data && +(data?.totalNumberOfTreesPlanted * 0.3).toFixed(2);\n /** 2481 miles = 1 tonne of Co2 emmissions */\n const milesDriven = tonnesOfCo2 && +(tonnesOfCo2 * 2481).toFixed(2);\n /** 0.3 meter squared of ice = 1 tonne of Co2 */\n const squareMeteresOfIceSaved =\n tonnesOfCo2 && +(tonnesOfCo2 * 0.3).toFixed(2);\n\n return (\n \n {children}\n \n );\n};\n","import { useEffect, useState } from 'react';\nimport { apiGet } from './ApiRequest';\n\nexport const useApiGet = (url: string) => {\n const [data, setData] = useState(null);\n const [error, setError] = useState(null);\n const [loading, setLoading] = useState(true);\n\n const fetchData = async () => {\n try {\n setLoading(true);\n const response = await apiGet(url);\n setLoading(false);\n setData(response.data);\n } catch (err: any) {\n setLoading(false);\n setError(err);\n }\n };\n\n useEffect(() => {\n fetchData();\n }, [url]);\n\n return { data, loading, error };\n};\n","export default __webpack_public_path__ + \"static/media/Cloud.05f8e1d3.png\";","export default __webpack_public_path__ + \"static/media/Iceburg.12049c52.png\";","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport car from '../../Assets/TreePlanting/Car.png';\nimport cloud from '../../Assets/TreePlanting/Cloud.png';\nimport iceburg from '../../Assets/TreePlanting/Iceburg.png';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport { useTreePlantedContext } from '../TreeplantingContext';\nimport CountUp from 'react-countup';\n\nconst Container = styled.div`\n width: 100%;\n height: auto;\n display: block;\n text-align: center;\n margin-top: 30px;\n margin-bottom: 40px;\n\n ${mobileMediaQuery} {\n margin-bottom: 0px;\n height: auto;\n }\n`;\n\nconst Header = styled.p`\n font-style: normal;\n font-weight: 700;\n font-size: 45px;\n line-height: 54px;\n text-align: center;\n color: ${themeColor('darkestGreen')};\n margin-bottom: 90px;\n\n ${mobileMediaQuery} {\n font-size: 28px;\n line-height: 34px;\n padding-left: 70px;\n padding-right: 70px;\n }\n`;\n\nconst ContentContainer = styled.div`\n width: 100%;\n height: 300px;\n display: flex;\n text-align: center;\n justify-content: space-evenly;\n align-items: center;\n\n ${mobileMediaQuery} {\n display: block;\n height: auto;\n }\n`;\n\nconst InnerContentContainer = styled.div`\n width: 355px;\n height: 300px;\n display: block;\n text-align: center;\n\n ${mobileMediaQuery} {\n width: 100%;\n }\n`;\n\nconst IconContainer = styled.div`\n width: 100%;\n height: 140px;\n display: flex;\n text-align: center;\n align-items: center;\n justify-content: center;\n`;\n\nconst Icon = styled.img`\n max-width: 180px;\n max-height: 140px;\n\n ${mobileMediaQuery} {\n max-width: 170px;\n max-height: 137px;\n }\n`;\n\nconst Description = styled.p`\n font-weight: 600;\n font-size: 23px;\n line-height: 25px;\n color: ${themeColor('forestGreen')};\n margin-top: 0px;\n\n ${mobileMediaQuery} {\n font-size: 20px;\n line-height: 26px;\n padding-left: 90px;\n padding-right: 90px;\n }\n`;\n\nconst Value = styled.p`\n font-style: normal;\n font-weight: 700;\n font-size: 34px;\n line-height: 41px;\n margin-bottom: 5px;\n margin-top: 20px;\n color: ${themeColor('darkestGreen')};\n\n ${mobileMediaQuery} {\n font-size: 28px;\n line-height: 34px;\n }\n`;\n\nconst EquivalentSection: React.FC = () => {\n const { t } = useTranslation();\n const { tonnesOfCo2, squareMeteresOfIceSaved, milesDriven } =\n useTreePlantedContext();\n\n /*if whole number don't add any decimal places */\n const getDecimal = (value: number) => (Number.isInteger(value) ? 0 : 2);\n\n return (\n \n
    {t('treePlanting.equivalent.heading')}
    \n \n \n \n \n \n\n \n \n \n {t('treePlanting.equivalent.co2')}\n \n \n \n \n \n\n \n \n \n {t('treePlanting.equivalent.ice')}\n \n \n \n \n \n\n \n \n \n {t('treePlanting.equivalent.miles')}\n \n \n
    \n );\n};\n\nexport default EquivalentSection;\n","export default \"\"","export default __webpack_public_path__ + \"static/media/TreePlantingHero.139fbef1.png\";","export default __webpack_public_path__ + \"static/media/TreePlantingMobileHero.88bf048a.png\";","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { tabletMediaQuery, themeColor, useBreakPoints } from '../../Theming';\n\nconst Container = styled.div`\n width: 100%;\n height: 135px;\n background-color: ${themeColor('fernGreen')};\n display: flex;\n text-align: center;\n justify-content: center;\n align-items: center;\n color: ${themeColor('white')};\n\n ${tabletMediaQuery} {\n display: block;\n padding: 50px 50px 0px 50px;\n position: relative;\n bottom: 0px;\n }\n`;\n\nconst Description = styled.p`\n font-style: normal;\n font-weight: 400;\n font-size: 18px;\n line-height: 17px;\n\n ${tabletMediaQuery} {\n font-size: 12px;\n line-height: 17px;\n margin-top: 0px;\n margin-bottom: 0px;\n }\n`;\n\nconst Footer: React.FC = () => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n\n return (\n \n {mobile ? (\n <>\n {t('treePlanting.poweredBy')}\n {t('treePlanting.poweredByPartners')}\n \n ) : (\n {t('treePlanting.poweredByFull')}\n )}\n \n );\n};\n\nexport default Footer;\n","export default __webpack_public_path__ + \"static/media/white_kindred_logo.9d506daf.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport heroImage from '../../Assets/TreePlanting/TreePlantingHero.png';\nimport heroMobile from '../../Assets/TreePlanting/TreePlantingMobileHero.png';\nimport kindredLogo from '../../Assets/TreePlanting/white_kindred_logo.png';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\nimport { useTreePlantedContext } from '../TreeplantingContext';\nimport env from '../../env';\nimport CountUp from 'react-countup';\n\nconst HeroContainer = styled.div`\n width: 100%;\n height: 860px;\n display: flex;\n text-align: center;\n justify-content: center;\n`;\n\nconst HeroBottomContainer = styled.div`\n width: 100%;\n height: 251px;\n background-color: ${themeColor('forestGreen')};\n z-index: 2;\n position: absolute;\n top: 595px;\n text-align: center;\n\n ${mobileMediaQuery} {\n padding-top: 50px;\n height: 300px;\n }\n`;\n\nconst HeroBottomRoundContainer = styled.div`\n position: absolute;\n width: 100%;\n height: 200px;\n top: 520px;\n background-color: ${themeColor('forestGreen')};\n z-index: 1;\n border-radius: 50%;\n\n ${mobileMediaQuery} {\n height: 60px;\n top: 570px;\n }\n`;\n\nconst HeroImage = styled.img`\n object-fit: cover;\n width: 100%;\n max-height: 800px;\n z-index: -1;\n\n ${mobileMediaQuery} {\n object-fit: cover;\n width: 100%;\n height: 100%;\n background-repeat: no-repeat;\n }\n`;\n\nconst LogoImage = styled.img`\n width: 276px;\n max-height: 87px;\n position: absolute;\n top: 172px;\n text-align: center;\n`;\n\nconst HeaderContainer = styled.div`\n width: 60%;\n height: 150px;\n z-index: 1;\n position: absolute;\n top: 300px;\n text-align: center;\n\n ${mobileMediaQuery} {\n width: 100%;\n top: 236px;\n max-width: 397px;\n margin-left: 20px;\n margin-right: 20px;\n }\n`;\n\nconst HeaderText = styled.p`\n font-style: normal;\n font-weight: 400;\n font-size: 38px;\n line-height: 54px;\n text-align: center;\n color: ${themeColor('white')};\n z-index: 1;\n margin-top: 0px;\n margin-bottom: 0px;\n\n ${mobileMediaQuery} {\n font-size: 21px;\n line-height: 38px;\n }\n`;\n\nconst HeaderTextBold = styled(HeaderText)`\n font-weight: 700;\n\n ${mobileMediaQuery} {\n font-size: 29px;\n line-height: 38px;\n }\n`;\n\nconst TressAmountContainer = styled.div`\n width: 100%;\n height: 150px;\n z-index: 1;\n display: flex;\n justify-content: center;\n\n ${mobileMediaQuery} {\n display: block;\n text-align: center;\n }\n`;\n\nconst TreesPlantedText = styled(HeaderText)`\n font-weight: 300;\n width: 100%;\n color: ${themeColor('white')};\n\n ${mobileMediaQuery} {\n font-size: 23px;\n }\n`;\n\nconst TreesText = styled(HeaderText)`\n font-weight: 700;\n font-size: 77px;\n line-height: 92px;\n\n ${mobileMediaQuery} {\n font-size: 50px;\n margin: 0px;\n line-height: 60px;\n }\n`;\n\nconst TreesPlantedAmount = styled(TreesText)`\n font-weight: 700;\n margin-right: 20px;\n color: ${themeColor('pastelGreen')};\n\n ${mobileMediaQuery} {\n margin: 0px;\n }\n`;\n\ninterface Props {\n bgImage?: string;\n headerText?: string;\n subText?: string;\n}\n\nconst Hero: React.FC = ({ bgImage, headerText, subText }) => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n\n const { treesPlanted, partnerLogo, showTreesPlantedByPartner } =\n useTreePlantedContext();\n\n const imgSrc = showTreesPlantedByPartner\n ? `${env.cdn_url}/${partnerLogo}`\n : kindredLogo;\n\n return (\n \n \n {!mobile && }\n \n {headerText}\n {subText}\n \n \n \n \n {t('treePlanting.hero.treesPlanted')}\n \n \n \n \n \n {t('treePlanting.hero.trees')}\n \n \n \n );\n};\n\nexport default Hero;\n","import React from 'react';\nimport styled from 'styled-components';\nimport merchantIcon from '../../Assets/TreePlanting/MerchantIcon.png';\nimport commissionIcon from '../../Assets/TreePlanting/CommissionIcon.png';\nimport treeIcon from '../../Assets/TreePlanting/TreeIcon.png';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n width: 100%;\n height: 614px;\n display: block;\n text-align: center;\n justify-content: center;\n align-items: center;\n background-color: ${themeColor('forestGreen')};\n margin-top: 50px;\n\n ${mobileMediaQuery} {\n width: 100%;\n height: auto;\n }\n`;\n\nconst ContentContainer = styled.div`\n width: 100%;\n height: 300px;\n display: flex;\n text-align: center;\n justify-content: space-evenly;\n align-items: center;\n margin-top: 100px;\n\n ${mobileMediaQuery} {\n display: block;\n justify-content: center;\n width: 100%;\n height: auto;\n margin-top: 50px;\n }\n`;\n\nconst InnerContentContainer = styled.div`\n width: 280px;\n height: 300px;\n display: block;\n text-align: center;\n\n ${mobileMediaQuery} {\n width: 100%;\n margin-bottom: 40px;\n margin-top: 0px;\n justify-content: center;\n align-items: center;\n }\n`;\n\nconst IconsContainer = styled.div`\n width: 221px;\n height: 221px;\n background-color: ${themeColor('white')};\n border-radius: 50%;\n display: flex;\n justify-content: center;\n align-items: center;\n margin: 0 auto 30px auto;\n\n ${mobileMediaQuery} {\n width: 174px;\n height: 174px;\n }\n`;\n\nconst HeaderText = styled.p`\n font-style: normal;\n font-weight: 700;\n font-size: 45px;\n line-height: 54px;\n text-align: center;\n margin-top: 60px;\n color: ${themeColor('white')};\n\n ${mobileMediaQuery} {\n font-size: 28px;\n line-height: 34px;\n margin-top: 40px;\n }\n`;\n\nconst Description = styled.p`\n font-weight: 400;\n font-size: 17px;\n line-height: 20px;\n color: ${themeColor('white')};\n\n ${mobileMediaQuery} {\n width: 280px;\n text-align: center;\n font-size: 15px;\n line-height: 18px;\n align-self: center;\n margin: 0 auto 30px auto;\n }\n`;\n\nconst Icon = styled.img`\n max-width: 190px;\n max-height: 130px;\n\n ${mobileMediaQuery} {\n max-width: 180px;\n max-height: 120px;\n }\n`;\n\nconst HowDoesItWork: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n \n {t('treePlanting.howDoesItWork.heading')}\n \n \n \n \n \n \n {t('treePlanting.howDoesItWork.descriptions.part1')}\n \n \n \n \n \n \n \n {t('treePlanting.howDoesItWork.descriptions.part2')}\n \n \n \n \n \n \n \n {t('treePlanting.howDoesItWork.descriptions.part3')}\n \n \n \n \n );\n};\n\nexport default HowDoesItWork;\n","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/Peru.fa533f34.png\";","export default __webpack_public_path__ + \"static/media/Tanzania.301e6392.png\";","export default __webpack_public_path__ + \"static/media/Congo.8d6b4480.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport Peru from '../../Assets/TreePlanting/Peru.png';\nimport Tanzania from '../../Assets/TreePlanting/Tanzania.png';\nimport Congo from '../../Assets/TreePlanting/Congo.png';\nimport tree from '../../Assets/TreePlanting/Tree.png';\nimport growth from '../../Assets/TreePlanting/Growth.png';\nimport deforestation from '../../Assets/TreePlanting/Deforestation.png';\nimport env from '../../env';\nimport {\n mobileMediaQuery,\n tabletMediaQuery,\n themeColor,\n useBreakPoints,\n} from '../../Theming';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n width: 100%;\n height: auto;\n display: block;\n text-align: center;\n justify-content: center;\n align-items: center;\n margin-top: 30px;\n margin-bottom: 50px;\n`;\n\nconst Header = styled.p`\n font-style: normal;\n font-weight: 700;\n font-size: 45px;\n line-height: 54px;\n text-align: center;\n color: ${themeColor('darkestGreen')};\n margin-bottom: 80px;\n\n ${mobileMediaQuery} {\n font-size: 28px;\n line-height: 34px;\n padding-left: 80px;\n padding-right: 80px;\n margin-bottom: 40px;\n }\n`;\n\nconst DescriptionHeader = styled(Header)`\n font-size: 36px;\n line-height: 36px;\n margin-top: 20px;\n margin-bottom: 0px;\n text-align: left;\n\n ${mobileMediaQuery} {\n font-size: 25px;\n line-height: 30px;\n padding-left: 0px;\n padding-right: 0px;\n }\n`;\n\nconst DescriptionText = styled(Header)`\n font-weight: 400;\n font-size: 18px;\n line-height: 29px;\n margin-bottom: 20px;\n text-align: left;\n\n ${mobileMediaQuery} {\n font-size: 15px;\n line-height: 25px;\n width: 100%;\n text-align: left;\n padding-left: 0px;\n padding-right: 0px;\n margin-bottom: 0px;\n }\n`;\n\nconst ContentContainer = styled.div`\n width: 100%;\n height: 520px;\n display: flex;\n\n ${mobileMediaQuery} {\n display: block;\n height: auto;\n }\n`;\n\nconst DescriptionContainer = styled.div`\n width: 50%;\n height: 520px;\n display: block;\n text-align: left;\n align-items: left;\n background-color: ${themeColor('greyWhite')};\n padding: 100px 85px 0px 85px;\n\n ${tabletMediaQuery} {\n width: 100%;\n padding: 40px 40px 50px 40px;\n height: auto;\n }\n`;\n\nconst StyledImage = styled.img`\n width: 50%;\n height: 520px;\n\n ${mobileMediaQuery} {\n width: 100%;\n height: 320px;\n }\n`;\n\nconst DescriptionIcon = styled.img`\n max-width: 55px;\n max-height: 55px;\n\n ${mobileMediaQuery} {\n max-width: 46px;\n max-height: 46px;\n }\n`;\n\nconst StyledLink = styled.a`\n color: ${themeColor('forestGreen')};\n font-weight: 400;\n font-size: 18px;\n line-height: 29px;\n\n ${mobileMediaQuery} {\n font-size: 13px;\n line-height: 29px;\n }\n`;\n\nconst RecentProjects: React.FC = () => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n\n return (\n \n
    {t('treePlanting.recentProjects.heading')}
    \n \n \n \n \n \n {t('treePlanting.recentProjects.restoringForests.heading')}\n \n \n {t('treePlanting.recentProjects.restoringForests.description')}\n \n \n \n \n {mobile && }\n \n \n \n {t('treePlanting.recentProjects.plantingForests.heading')}\n \n \n {t('treePlanting.recentProjects.plantingForests.description')}\n \n \n {!mobile && }\n \n \n \n \n \n \n {t('treePlanting.recentProjects.preventingDeforestation.heading')}\n \n \n {t(\n 'treePlanting.recentProjects.preventingDeforestation.description'\n )}\n \n \n \n
    \n );\n};\n\nexport default RecentProjects;\n","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/TreeLocations.41553dbe.png\";","export default __webpack_public_path__ + \"static/media/DotsEco.af76e163.png\";","export default __webpack_public_path__ + \"static/media/VerifiedCarbon.c8a2182f.png\";","export default __webpack_public_path__ + \"static/media/Urs.c175093f.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport treeLocations from '../../Assets/TreePlanting/TreeLocations.png';\nimport kindred from '../../Assets/TreePlanting/Kindred.png';\nimport dotsEco from '../../Assets/TreePlanting/DotsEco.png';\nimport earthmark from '../../Assets/TreePlanting/Earthmark.png';\nimport cnb from '../../Assets/TreePlanting/Cnb.png';\nimport verifiedCarbon from '../../Assets/TreePlanting/VerifiedCarbon.png';\nimport urs from '../../Assets/TreePlanting/Urs.png';\nimport { mobileMediaQuery, tabletMediaQuery, themeColor } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n width: 100%;\n height: auto;\n display: block;\n text-align: center;\n justify-content: center;\n align-items: center;\n background-color: ${themeColor('white')};\n margin-bottom: 30px;\n\n ${mobileMediaQuery} {\n width: 100%;\n height: 600px;\n margin-bottom: 0px;\n }\n`;\n\nconst PartnersContainer = styled.div`\n width: 100%;\n height: 110px;\n display: flex;\n text-align: center;\n justify-content: space-between;\n margin-top: 30px;\n padding-left: 230px;\n padding-right: 230px;\n\n ${tabletMediaQuery} {\n height: 150px;\n display: flex;\n flex-wrap: wrap;\n padding-left: 10px;\n padding-right: 10px;\n justify-content: center;\n align-items: start;\n }\n`;\n\nconst HeaderText = styled.p`\n font-style: normal;\n font-weight: 700;\n font-size: 45px;\n line-height: 54px;\n text-align: center;\n margin-top: 120px;\n\n ${mobileMediaQuery} {\n font-weight: 700;\n font-size: 26px;\n line-height: 31px;\n margin-top: 80px;\n padding-left: 40px;\n padding-right: 40px;\n }\n`;\n\nconst TreeLocationsMap = styled.img`\n width: 60%;\n margin-top: 0px;\n\n ${mobileMediaQuery} {\n width: 100%;\n padding-left: 20px;\n padding-right: 20px;\n }\n`;\n\nconst StyledLogo = styled.img`\n margin-top: 20px;\n max-width: 129px;\n max-height: 47px;\n\n ${mobileMediaQuery} {\n max-width: 100px;\n max-height: 36px;\n }\n`;\n\nconst StyledURSLogo = styled(StyledLogo)`\n margin-top: 0px;\n margin-right: 30px;\n max-width: 124px;\n max-height: 101px;\n\n ${mobileMediaQuery} {\n max-width: 95px;\n max-height: 78px;\n margin-right: 10px;\n margin-left: 0px;\n }\n`;\n\nconst StyledVerifiedCarbonLogo = styled(StyledLogo)`\n margin-top: 0px;\n margin-right: 40px;\n max-width: 147px;\n max-height: 83px;\n\n ${mobileMediaQuery} {\n max-width: 114px;\n max-height: 64px;\n margin-right: 10px;\n }\n`;\n\nconst StyledCnbLogo = styled(StyledLogo)`\n margin-top: 20px;\n margin-right: 40px;\n max-width: 53px;\n max-height: 66px;\n\n ${mobileMediaQuery} {\n max-width: 32px;\n max-height: 40px;\n margin-left: 15px;\n margin-right: 30px;\n }\n`;\n\nconst StyledDotsEcoLogo = styled(StyledLogo)`\n margin-top: 20px;\n margin-right: 40px;\n max-width: 93px;\n max-height: 63px;\n\n ${mobileMediaQuery} {\n max-width: 56px;\n max-height: 38px;\n margin-right: 20px;\n }\n`;\n\nconst StyledEarthmarkLogo = styled(StyledLogo)`\n margin-top: 35px;\n max-width: 167px;\n max-height: 24px;\n\n ${mobileMediaQuery} {\n max-width: 98px;\n max-height: 28px;\n }\n`;\nconst WhereAreTreesPlanted: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n \n {t('treePlanting.whereAreTreesBeingPlanted')}\n \n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default WhereAreTreesPlanted;\n","export default \"\"","export default \"\"","export default \"\"","import React from 'react';\nimport EquivalentSection from '../Components/equivalentSection';\nimport heroImage from '../../Assets/TreePlanting/TreePlantingHero.png';\nimport heroMobile from '../../Assets/TreePlanting/TreePlantingMobileHero.png';\nimport Footer from '../Components/footer';\nimport Hero from '../Components/hero';\nimport HowDoesItWork from '../Components/howDoesItWork';\nimport RecentProjects from '../Components/recentProjects';\nimport WhereAreTreesPlanted from '../Components/whereAreTreesPlanted';\nimport { useBreakPoints } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\n\nconst Container = styled.div``;\n\nconst TreePlanting: React.FC = () => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n\n return (\n \n \n \n \n \n \n
    \n \n );\n};\n\nexport default TreePlanting;\n","export default __webpack_public_path__ + \"static/media/TreesBackgroundDesktop.9afc518e.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport bgImage from '../../Assets/TreePlanting/TreesBackgroundDesktop.png';\n\nconst Container = styled.div``;\n\nconst ImageContainer = styled.div`\n border-radius: 14px;\n width: 100%;\n height: 377px;\n overflow: hidden;\n position: relative;\n\n ${mobileMediaQuery} {\n height: 184px;\n border-radius: 7px;\n }\n`;\n\nconst HeroImage = styled.div`\n background-image: url(${bgImage});\n background-repeat: no-repeat;\n background-size: cover;\n height: 100%;\n width: 100%;\n z-index: -1;\n background-position: 0px -80px;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n\n ${mobileMediaQuery} {\n background-size: cover;\n background-position: 0px -8px;\n }\n`;\n\nconst HeaderText = styled.p`\n font-weight: normal;\n font-size: 32px;\n text-align: center;\n color: ${themeColor('white')};\n z-index: 1;\n margin: 0;\n font-family: SuisseIntl-Medium;\n\n ${mobileMediaQuery} {\n font-size: 14px;\n font-family: SuisseIntl-Regular;\n }\n`;\n\nconst HeaderTextBold = styled(HeaderText)`\n font-size: 46px;\n font-family: SuisseIntl-Medium;\n font-weight: normal;\n\n ${mobileMediaQuery} {\n font-size: 20px;\n font-family: SuisseIntl-Bold;\n }\n`;\n\ninterface Props {\n headerText?: string;\n subText?: string;\n}\n\nconst Hero: React.FC = ({ headerText, subText }) => {\n return (\n \n \n \n {headerText}\n {subText}\n \n \n \n );\n};\n\nexport default Hero;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport { Maybe } from '../TreeplantingContext';\n\nconst Container = styled.section`\n background-color: ${themeColor('greyBackground')};\n padding: 50px 45px 50px 45px;\n margin-top: 40px;\n text-align: center;\n border-radius: 20px;\n height: 387px;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n\n ${mobileMediaQuery} {\n margin-top: 12px;\n padding: 12px 45px 12px 45px;\n border-radius: 6.11px;\n height: 130px;\n }\n`;\n\nconst Text = styled.p`\n font-family: SuisseIntl-Medium;\n margin: 0;\n padding: 0;\n font-size: 32px;\n font-weight: bold;\n font-weight: normal;\n\n ${mobileMediaQuery} {\n font-family: SuisseIntl-Regular;\n font-size: 12px;\n }\n`;\n\nconst BoldText = styled(Text)`\n font-family: SuisseIntl-Bold;\n font-size: 72px;\n line-height: 82px;\n\n ${mobileMediaQuery} {\n font-size: 28px;\n line-height: 30px;\n }\n`;\n\ninterface Props {\n numOfTreesToday?: Maybe;\n totalNumOfTrees?: Maybe;\n}\n\nconst TreesFunded: React.FC = ({ totalNumOfTrees = '1,043' }) => {\n const { t } = useTranslation();\n\n return (\n \n {t('treePlantingV2.treeFunding.treesFunded')}\n {`${totalNumOfTrees} ${t(\n 'treePlantingV2.treeFunding.trees'\n )}`}\n {t('treePlantingV2.treeFunding.acrossTheUAE')}\n \n );\n};\n\nexport default TreesFunded;\n","export default __webpack_public_path__ + \"static/media/cloudBlack.ab8b8dd5.png\";","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../Theming';\nimport CountUp from 'react-countup';\nimport cloud from '../../Assets/TreePlanting/cloudBlack.png';\nimport car from '../../Assets/TreePlanting/carBlack.png';\nimport { Maybe } from '../TreeplantingContext';\n\nconst Container = styled.section`\n margin: 72px 0 0 0;\n\n ${mobileMediaQuery} {\n margin: 32px 0 0 0;\n }\n`;\n\nconst Header = styled.h2`\n margin: 0 0 32px 0;\n padding: 0;\n font-weight: normal;\n font-family: SuisseIntl-Medium;\n text-align: center;\n font-size: 32px;\n\n ${mobileMediaQuery} {\n margin: 0 0 8px 0;\n font-size: 16px;\n line-height: 20px;\n }\n`;\n\nconst ContentContainer = styled.div`\n width: 100%;\n display: flex;\n text-align: center;\n justify-content: space-evenly;\n align-items: center;\n`;\n\nconst InnerContentContainer = styled.div<{ marginRight?: number }>`\n width: 100%;\n height: 277px;\n display: flex;\n flex-direction: column;\n justify-content: center;\n text-align: center;\n background-color: ${themeColor('greyBackground')};\n margin-right: ${(props) => props.marginRight}px;\n border-radius: 20px;\n\n ${mobileMediaQuery} {\n border-radius: 7px;\n height: 93px;\n }\n`;\n\nconst IconContainer = styled.div`\n width: 100%;\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nconst Icon = styled.img`\n width: 160px;\n height: 108px;\n margin: 20px 0 20px 0;\n ${mobileMediaQuery} {\n width: 37px;\n height: 25px;\n margin: 10px 0 15px 0;\n }\n`;\n\nconst Description = styled.p`\n font-size: 23px;\n line-height: 25px;\n color: ${themeColor('greyText')};\n margin-top: 0px;\n font-family: SuisseIntl-Medium;\n\n ${mobileMediaQuery} {\n font-size: 12px;\n line-height: 5px;\n }\n`;\n\nconst Value = styled.p`\n font-weight: normal;\n font-size: 34px;\n line-height: 24px;\n margin: 0 0 15px 0;\n color: ${themeColor('darkestGreen')};\n font-family: SuisseIntl-Bold;\n\n ${mobileMediaQuery} {\n font-size: 16px;\n line-height: 0px;\n }\n`;\n\ninterface Props {\n tonnesOfCo2?: Maybe;\n milesDriven?: Maybe;\n}\n\nconst EquivalentSection: React.FC = ({ tonnesOfCo2, milesDriven }) => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n\n /*if whole number don't add any decimal places */\n const getDecimal = (value: number) => (Number.isInteger(value) ? 0 : 2);\n return (\n \n
    {t('treePlantingV2.equivalent.heading')}
    \n \n \n \n \n \n\n \n \n \n {t('treePlanting.equivalent.co2')}\n \n\n \n \n \n \n\n \n \n \n {t('treePlanting.equivalent.miles')}\n \n \n
    \n );\n};\n\nexport default EquivalentSection;\n","export default \"\"","import React from 'react';\nimport styled from 'styled-components';\nimport { mobileMediaQuery, themeColor, useBreakPoints } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\nimport house from '../../Assets/TreePlanting/houseBlack.png';\nimport money from '../../Assets/TreePlanting/moneyBlack.png';\nimport trees from '../../Assets/TreePlanting/treesBlack.png';\n\nconst Container = styled.section`\n margin: 72px 0 0 0;\n\n ${mobileMediaQuery} {\n margin: 32px 0 0 0;\n }\n`;\n\nconst ContentContainer = styled.div`\n width: 100%;\n display: flex;\n text-align: center;\n justify-content: space-evenly;\n`;\n\nconst InnerContentContainer = styled.div<{ marginRight?: number }>`\n width: 100%;\n display: flex;\n margin-right: ${(props) => props.marginRight}px;\n flex-direction: column;\n text-align: left;\n`;\n\nconst IconContainer = styled.div`\n width: 100%;\n display: flex;\n align-items: center;\n justify-content: center;\n flex-direction: column;\n justify-content: center;\n text-align: center;\n background-color: ${themeColor('greyBackground')};\n border-radius: 20px;\n height: 180px;\n\n ${mobileMediaQuery} {\n border-radius: 7px;\n height: 55px;\n }\n`;\n\nconst Icon = styled.img`\n max-width: 91px;\n max-height: 100px;\n margin: 20px 0 20px 0;\n ${mobileMediaQuery} {\n max-width: 23px;\n max-height: 25px;\n margin: 10px 0 15px 0;\n }\n`;\n\nconst Description = styled.p`\n margin: 24px 0 0 0;\n font-size: 16px;\n font-family: SuisseIntl-Regular;\n\n ${mobileMediaQuery} {\n font-size: 12px;\n margin-top: 12px;\n }\n`;\n\nconst Header = styled.h2`\n margin: 0 0 32px 0;\n padding: 0;\n font-family: SuisseIntl-Medium;\n font-weight: normal;\n text-align: center;\n font-size: 32px;\n\n ${mobileMediaQuery} {\n margin: 0 0 8px 0;\n font-size: 16px;\n line-height: 20px;\n }\n`;\n\nconst HowItWorks = () => {\n const { t } = useTranslation();\n const { mobile } = useBreakPoints();\n return (\n \n
    {t('treePlantingV2.howDoesItWork.heading')}
    \n \n \n \n \n \n \n {t('treePlantingV2.howDoesItWork.descriptions.part1')}\n \n \n\n \n \n \n \n \n {t('treePlantingV2.howDoesItWork.descriptions.part2')}\n \n \n\n \n \n \n \n \n {t('treePlantingV2.howDoesItWork.descriptions.part3')}\n \n \n \n
    \n );\n};\n\nexport default HowItWorks;\n","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/treesFooter.14ba2fb0.png\";","import React from 'react';\nimport styled from 'styled-components';\nimport trees from '../../Assets/TreePlanting/treesFooter.png';\nimport { mobileMediaQuery, themeColor } from '../../Theming';\nimport { Trans, useTranslation } from 'react-i18next';\n\nconst Container = styled.footer`\n width: 100%;\n display: flex;\n justify-content: space-evenly;\n height: 482px;\n margin-top: 72px;\n border-radius: 14px;\n overflow: hidden;\n\n ${mobileMediaQuery} {\n flex-direction: column;\n height: auto;\n border-radius: 7px;\n margin-top: 40px;\n }\n`;\n\nconst Image = styled.img`\n width: 100%;\n height: 100%;\n object-fit: cover;\n\n ${mobileMediaQuery} {\n object-fit: contain;\n }\n`;\n\nconst TextContainer = styled.div`\n height: 100%;\n width: 100%;\n background-color: ${themeColor('darkBackground')};\n padding: 50px 64px 50px 42px;\n\n ${mobileMediaQuery} {\n padding: 20px 29px 24px 24px;\n }\n`;\n\nconst HeaderText = styled.h2`\n margin: 0 0 20px 0;\n font-family: SuisseIntl-Medium;\n font-weight: normal;\n color: ${themeColor('white')};\n font-size: 32px;\n\n ${mobileMediaQuery} {\n font-size: 20px;\n margin-bottom: 10px;\n }\n`;\n\nconst Description = styled.p`\n font-family: SuisseIntl-Regular;\n color: ${themeColor('white')};\n font-size: 16px;\n\n ${mobileMediaQuery} {\n font-size: 14px;\n }\n`;\n\nconst Footer = () => {\n const { t } = useTranslation();\n return (\n \n \n \n {t('treePlantingV2.footer.heading')}\n \n \n \n \n \n \n \n );\n};\n\nexport default Footer;\n","import React from 'react';\nimport { mobileMediaQuery } from '../../Theming';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport Hero from './Hero';\nimport TreesFunded from './TreesFunded';\nimport EquivalentSection from './EquivalentSection';\nimport HowItWorks from './HowItWorks';\nimport Footer from './Footer';\nimport { useTreePlantedContext } from '../TreeplantingContext';\n\nconst Container = styled.main`\n padding-inline: 50px;\n padding-block: 64px;\n margin: auto;\n max-width: 1400px;\n\n ${mobileMediaQuery} {\n padding-inline: 15px;\n padding-block: 24px;\n }\n`;\n\nconst TreePlanting: React.FC = () => {\n const { t } = useTranslation();\n const { treesPlanted, todaysTreePlantingTick, tonnesOfCo2, milesDriven } =\n useTreePlantedContext();\n\n return (\n \n \n \n \n \n
    \n \n );\n};\n\nexport default TreePlanting;\n","import React from 'react';\nimport { useParams } from 'react-router-dom';\nimport { TreePlantingContextProvider } from './TreeplantingContext';\nimport TreePlantingV1 from './v1/index';\nimport TreePlantingV2 from './v2/index';\nimport env from '../env';\n\ninterface urlParams {\n partner?: string;\n}\n\ninterface PartnerMapping {\n [partnerName: string]: {\n version: number;\n partnerId: string;\n };\n}\n\nconst partnerMapping: PartnerMapping = {\n etisalat: {\n version: 2,\n partnerId: env.etisalat_partner_id,\n },\n};\n\nconst TreePlanting: React.FC = () => {\n const urlParams = useParams();\n const partnerName = urlParams?.partner;\n const partnerDetails = partnerName ? partnerMapping[partnerName] : null;\n const partnerId = partnerDetails?.partnerId ?? env.kindred_partner_id;\n\n const renderTreePlantingContent = () => {\n switch (partnerDetails?.version) {\n case 1:\n return ;\n\n case 2:\n return ;\n\n default:\n return ;\n }\n };\n\n return (\n \n {renderTreePlantingContent()}\n \n );\n};\n\nexport default TreePlanting;\n","import React from 'react';\nimport { useChromeExtensionUTMQueryParamExtraction } from '../Samsung/utils';\nimport LoadingIndicator from '../Common/LoadingIndicator';\nimport styled from 'styled-components';\n\nconst StyledLoadingIndicator = styled(LoadingIndicator)`\n min-height: 100px;\n`;\n\nconst ChromeDesktopUTMTracking: React.FC = () => {\n useChromeExtensionUTMQueryParamExtraction();\n\n return ;\n};\n\nexport default ChromeDesktopUTMTracking;\n","import React, { useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport { logEvent, getAnalytics } from 'firebase/analytics';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { FirstA } from './Components/InstructionStep';\nimport { useHistory } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport { hasSliideOrigin } from '.';\nimport {\n MultiStepHeaderText,\n addSliideText,\n} from './PartnerPluginActivateMultiStep';\nimport app from '../Firebase';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 15px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n width: 310px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 320px;\n min-height: 106px;\n margin-top: 33px;\n margin-left: 35px;\n`;\n\nconst ListContent = styled.li`\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n margin-left: 15px;\n margin-bottom: 20px;\n`;\n\nconst BorderedItem = styled.strong`\n color: ${themeColor('blue')};\n border: 0.8px solid ${themeColor('blue')};\n padding: 3px;\n border-radius: 5px;\n margin-left: 3px;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n top: 8px;\n right: 10px;\n animation: ${bounce} 2s infinite;\n`;\n\nconst PartnerPluginActivateMultiStepAlwaysAllow = () => {\n const { t } = useTranslation();\n const history = useHistory();\n const [sliide] = useState(hasSliideOrigin());\n\n useEffect(() => {\n const analytics = getAnalytics(app);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n logEvent(analytics, 'activation_permissions', {\n permissions: message.data?.givenPermission ? 'Full' : 'Partial',\n partner: sliide ? 'Sliide' : 'Kindred',\n });\n\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.PluginActivationStartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.PluginActivationAllowPermissions,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => window.removeEventListener('message', messageHandler);\n }, [history]);\n\n return (\n \n \n \n {t('PartnerpluginsdkActivate.multiStep.alwaysAllow')}\n \n \n \n \n AbsoluteText\n \n \n \n \n
      \n \n \n A\n \n \n \n \n A\n \n \n \n \n A\n \n \n
    \n
    \n \n );\n};\n\nexport default PartnerPluginActivateMultiStepAlwaysAllow;\n","import React, { useCallback, useState } from 'react';\nimport styled from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport { useHistory } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport { hasSliideOrigin } from '.';\nimport {\n MultiStepHeaderText,\n addSliideText,\n} from './PartnerPluginActivateMultiStep';\nimport colors from '../Theming/colors';\nimport { useQuery } from '../Common/Hooks';\nimport clsx from 'clsx';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 15px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n width: 310px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 320px;\n min-height: 106px;\n margin-top: 33px;\n margin-left: 35px;\n display: flex;\n flex-direction: column;\n align-items: center;\n`;\n\nexport const MultiStepStyledButton = styled.button`\n flex-shrink: 0;\n color: ${themeColor('white')};\n font-size: 16px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n background-color: ${colors.successGreen};\n width: 260px;\n height: 40px;\n border-radius: 5px;\n\n &.sliide {\n background-color: ${colors.verizonRed};\n width: 308px;\n height: 40px;\n border-radius: 20px;\n margin-top: 10px;\n filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));\n }\n`;\n\nconst MultiStepStyledTransparentButton = styled.button`\n font-size: 13px;\n font-weight: 400;\n margin-top: 33px;\n color: ${colors.lightGrey};\n background-color: transparent;\n flex-shrink: 0;\n font-style: normal;\n line-height: normal;\n\n &.sliide {\n font-size: 14px;\n font-weight: 700;\n margin-top: 25px;\n color: ${colors.verizonGrey};\n }\n`;\n\nconst PartnerPluginActivateMultiStepAlmostThere = () => {\n const { t } = useTranslation();\n const query = useQuery();\n const history = useHistory();\n const [sliide] = useState(hasSliideOrigin());\n\n const handleUpdateNow = () => {\n history.push({\n pathname: Path.PluginActivationUpdatePermissions,\n search: location.search,\n });\n };\n\n const openApp = useCallback(() => {\n const origin = query.get('origin');\n if (origin)\n window.location = `${origin}://` as (string | Location) & Location;\n }, [query]);\n\n return (\n \n \n {t('PartnerpluginsdkActivate.multiStep.alwaysAllow')}\n \n \n \n \n AbsoluteText\n \n \n \n \n \n {t('PartnerpluginsdkActivate.multiStep.updateNow')}\n \n \n {t(\n 'PartnerpluginsdkActivate.multiStep.iWillDoItLater' +\n addSliideText(sliide)\n )}\n \n \n \n );\n};\n\nexport default PartnerPluginActivateMultiStepAlmostThere;\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n// SlideShow.js\nimport React, { useState } from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\nimport { MultiStepProps } from '../PartnerPluginActivateMultiStep';\nimport colors from '../../Theming/colors';\n\nconst Container = styled.div`\n width: 100%;\n overflow: hidden;\n position: relative;\n`;\n\nconst Slides = styled.div<{ activeIndex: number }>`\n display: flex;\n transition: transform 0.3s;\n transform: translateX(${(props) => -props.activeIndex * 100}%);\n`;\n\nconst Slide = styled.div`\n min-width: 100%;\n min-height: 230px;\n`;\n\nconst PillsContainer = styled.div`\n position: absolute;\n bottom: 0px;\n left: 50%;\n transform: translateX(-50%);\n display: flex;\n gap: 5px;\n`;\n\nconst Pill = styled.div<{ active: boolean; sliide?: boolean }>`\n width: 5px;\n height: 5px;\n border-radius: 50%;\n cursor: pointer;\n\n ${(props) =>\n props.sliide\n ? `\n background-color: ${props.active ? colors.grey : colors.verizonRed};\n `\n : `\n background-color: ${props.active ? colors.grey : colors.greyWhite};\n `}\n`;\n\nconst StyledImage = styled.img`\n width: 320px;\n`;\n\nconst BeSureToAllowSlide: React.FC = ({ sliide }) => {\n const [activeIndex, setActiveIndex] = useState(0);\n const [startX, setStartX] = useState(0);\n const slides = sliide\n ? [\n images.partnerpluginsdk_be_suresliide_1?.default,\n images.partnerpluginsdk_be_suresliide_2?.default,\n images.partnerpluginsdk_be_suresliide_3?.default,\n images.partnerpluginsdk_be_suresliide_4?.default,\n images.partnerpluginsdk_be_suresliide_5?.default,\n ]\n : [\n images.partnerpluginsdk_be_sure_1?.default,\n images.partnerpluginsdk_be_sure_2?.default,\n images.partnerpluginsdk_be_sure_3?.default,\n images.partnerpluginsdk_be_sure_4?.default,\n images.partnerpluginsdk_be_sure_5?.default,\n ];\n\n const handleTouchStart = (e: any) => {\n setStartX(e.touches[0].clientX);\n };\n\n const handleTouchEnd = (e: any) => {\n const endX = e.changedTouches[0].clientX;\n const deltaX = endX - startX;\n\n if (deltaX > 50 && activeIndex > 0) {\n setActiveIndex((prev) => prev - 1);\n } else if (deltaX < -50 && activeIndex < slides.length - 1) {\n setActiveIndex((prev) => prev + 1);\n }\n };\n\n return (\n \n \n {slides.map((img, index) => (\n \n \n \n ))}\n \n \n {slides.map((_, index) => (\n setActiveIndex(index)}\n />\n ))}\n \n \n );\n};\n\nexport default BeSureToAllowSlide;\n","import React, { useCallback, useState } from 'react';\nimport styled from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation } from 'react-i18next';\nimport BeSureToAllowSlide from './Components/BeSureToAllowSlide';\nimport { hasSliideOrigin } from '.';\nimport { useQuery } from '../Common/Hooks';\nimport { MultiStepStyledButton } from './PartnerPluginActivateMultiStepAlmostThere';\nimport { addSliideText } from './PartnerPluginActivateMultiStep';\nimport clsx from 'clsx';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 320px;\n margin-top: 21px;\n margin-left: 35px;\n min-height: 500px;\n`;\n\nconst StyledContainer = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n margin-bottom: 20px;\n margin-top: 20px;\n`;\n\nconst PartnerPluginActivateMultiStepBeSureToAllow = () => {\n const { t } = useTranslation();\n const query = useQuery();\n const [sliide] = useState(hasSliideOrigin());\n\n const openApp = useCallback(() => {\n const origin = query.get('origin');\n if (origin)\n window.location = `${origin}://` as (string | Location) & Location;\n }, [query]);\n\n return (\n \n \n \n \n \n {t('PartnerpluginsdkActivate.multiStep.goAppToApp')}\n \n \n \n \n );\n};\n\nexport default PartnerPluginActivateMultiStepBeSureToAllow;\n","import React, { useCallback, useState } from 'react';\nimport styled from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { hasSliideOrigin } from '.';\nimport { addSliideText } from './PartnerPluginActivateMultiStep';\nimport { MultiStepStyledButton } from './PartnerPluginActivateMultiStepAlmostThere';\nimport { useQuery } from '../Common/Hooks';\nimport clsx from 'clsx';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n line-height: normal;\n margin-top: 20px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n width: 310px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 320px;\n margin-top: 21px;\n margin-left: 35px;\n min-height: 500px;\n`;\n\nconst StyledImageContainer = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n margin-bottom: 20px;\n margin-top: 20px;\n`;\n\nconst StyledImage = styled.img`\n width: 280px;\n height: 32px;\n`;\n\nconst PartnerPluginActivateMultiStepStartShopping = () => {\n const { t } = useTranslation();\n const query = useQuery();\n const [sliide] = useState(hasSliideOrigin());\n\n const openApp = useCallback(() => {\n const origin = query.get('origin');\n if (origin)\n window.location = `${origin}://` as (string | Location) & Location;\n }, [query]);\n\n return (\n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n {t('PartnerpluginsdkActivate.multiStep.goAppToApp')}\n \n \n \n \n );\n};\n\nexport default PartnerPluginActivateMultiStepStartShopping;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { Trans, useTranslation } from 'react-i18next';\nimport { themeColor } from '../../Theming';\nimport colors from '../../Theming/colors';\nimport itvColors from '../../Theming/ITVTheme/colors';\nimport { Helmet } from 'react-helmet';\nimport itvIcon from '../../Assets/Branding/itv_logo.png';\nimport images from '../../Theming/images';\n\nconst Container = styled.div`\n width: 100%;\n max-width: 700px;\n margin: 0 auto;\n background-color: ${itvColors.greenishBlue};\n`;\n\nconst Body = styled.div<{ bodyMarginTop?: number }>`\n background-color: ${themeColor('white')};\n margin-top: ${(props) => (props.bodyMarginTop ? props.bodyMarginTop : -3)}px;\n min-height: 400px;\n padding-top: 1px;\n`;\n\nconst Header = styled.div`\n height: 245px;\n\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding-top: 80px;\n`;\n\nconst HeaderText = styled.div`\n text-align: center;\n font-family: Arial;\n font-size: 20px;\n font-style: normal;\n font-weight: 700;\n line-height: 130%;\n color: ${colors.white};\n width: 250px;\n padding-top: 24px;\n`;\n\nconst BoldText = styled.div`\n font-weight: bold;\n`;\n\nconst StyledBrandedIcon = styled.img`\n width: 60px;\n height: 60px;\n`;\ninterface MultiStepContainerProps {\n headerText?: string;\n headerTextWidth?: number;\n bodyMarginTop?: number;\n}\n\nconst MultiStepActivationContainer: React.FC = ({\n children,\n headerText,\n bodyMarginTop,\n}) => {\n const { t } = useTranslation();\n\n return (\n \n \n \n ITV Cash Saver\n \n
    \n \n \n \n AbsoluteText\n \n \n
    \n {children}\n
    \n );\n};\n\nexport default MultiStepActivationContainer;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport clsx from 'clsx';\nimport images from '../../Theming/images';\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n animation: ${bounce} 2s infinite;\n\n &.showAtBottom {\n bottom: 4px;\n left: 30px;\n }\n\n &.showAtTop {\n top: 8px;\n left: 5px;\n }\n`;\n\nconst TAP_HERE_IMAGES = {\n itv: {\n bottom: images.partnerpluginsdk_tap_here_bottom_itvx,\n top: images.partnerpluginsdk_tap_here_top_left_itvx,\n },\n};\n\nconst TapHereAnimated: React.FC = () => {\n const sliide = false;\n const [showAtBottom, setShowBottom] = useState(true);\n const image = useMemo(() => {\n const imagesToShow = TAP_HERE_IMAGES.itv;\n\n return showAtBottom ? imagesToShow.bottom : imagesToShow.top;\n }, [showAtBottom, sliide]);\n\n function getiOSVersion() {\n const userAgent = navigator.userAgent || '';\n if (/iP(hone|od|ad)/.test(userAgent)) {\n const v = userAgent.match(/OS (\\d+)_/);\n return v ? parseInt(v[1], 10) : null;\n }\n return null;\n }\n\n useEffect(() => {\n const version = getiOSVersion();\n\n if (version && version < 15) {\n setShowBottom(false);\n }\n }, []);\n\n return (\n \n );\n};\n\nexport default TapHereAnimated;\n","import React, { useEffect } from 'react';\nimport styled from 'styled-components';\nimport { useHistory } from 'react-router-dom';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { Path } from '../Routing';\nimport TapHereAnimated from './Components/TapHereAnimated';\nimport env from '../env';\n\nexport const MultiStepHeaderText = styled.h3`\n color: smokeBlack;\n text-align: center;\n font-size: 22px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n`;\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: 24px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 14px;\n font-style: normal;\n font-family: Arial;\n font-weight: 400;\n width: 272px;\n`;\n\nconst WhatYouNeedText = styled.div`\n font-family: Arial;\n font-size: 16px;\n font-style: normal;\n font-weight: 700;\n line-height: 20.8px;\n margin-bottom: 11px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('black')};\n text-decoration: underline;\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n min-height: 106px;\n margin-top: 33px;\n padding-left: 24px;\n padding-right: 24px;\n`;\n\nconst IconContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-bottom: 23px;\n`;\n\nconst IconContentDescription = styled.div`\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n padding-top: 10px;\n`;\n\nconst ContentItem = styled.div`\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: normal;\n margin-bottom: 37px;\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n`;\n\nconst PartnerPluginActivateMultiStep: React.FC = () => {\n const { t } = useTranslation();\n const history = useHistory();\n\n useEffect(() => {\n const initialHeight = window.innerHeight;\n\n const interval = setInterval(() => {\n const currentHeight = window.innerHeight;\n\n if (currentHeight < initialHeight) {\n history.push({\n pathname: Path.PluginActivationV2AlwaysAllow,\n search: location.search,\n });\n }\n }, 1500);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.PluginActivationV2StartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.PluginActivationV2AlwaysAllow,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => {\n clearInterval(interval);\n window.removeEventListener('message', messageHandler);\n };\n }, [history]);\n\n return (\n \n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n {t('PartnerNewpluginsdkActivate.hereWhatYouNeed')}\n \n \n \n \n 1. {t('PartnerNewpluginsdkActivate.tapAA')}\n \n \n 2. {t('PartnerNewpluginsdkActivate.tapManageExtension')}\n \n \n 3. {t('PartnerNewpluginsdkActivate.toggleOnItv')}\n \n \n \n \n \n \n );\n};\n\nexport default PartnerPluginActivateMultiStep;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PartnerPluginActivateMultiStep from './PartnerPluginActivateMultiStep';\nimport { useLanguageUtm } from '../Common';\nimport usePageTitle from '../Common/Hooks/usePageTitle';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nexport const hasSliideOrigin = () => {\n return window.location.search.includes('utm_campaign=sliide');\n};\n\nconst PartnerNewpluginsdkActivate = () => {\n useLanguageUtm();\n usePageTitle();\n\n return ;\n};\n\nexport default PartnerNewpluginsdkActivate;\n","import React from 'react';\nimport env from '../env';\n\ninterface LinkRedirectProps {\n path?: string;\n}\n\nconst LinkRedirect: React.FC = ({ path = '' }) => {\n window.location.href = env.kindred_website + path;\n\n return null;\n};\n\nexport default LinkRedirect;\n","import React, { useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport { logEvent, getAnalytics } from 'firebase/analytics';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { useHistory } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport { hasSliideOrigin } from '.';\nimport app from '../Firebase';\nimport { useQuery } from '../Common/Hooks';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: 24px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n width: 240px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n margin-top: 33px;\n display: flex;\n justify-content: center;\n`;\n\nconst ListContent = styled.li`\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n margin-left: 15px;\n margin-bottom: 20px;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n top: 8px;\n right: 20px;\n animation: ${bounce} 2s infinite;\n width: 163px;\n height: 46px;\n`;\n\nconst AlwayAllowImage = styled.img`\n width: auto;\n height: 169px;\n`;\n\nconst PartnerNewPluginActivateMultiStepAlwaysAllow = () => {\n const { t } = useTranslation();\n const history = useHistory();\n const query = useQuery();\n\n useEffect(() => {\n const analytics = getAnalytics(app);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n const origin = query.get('origin');\n logEvent(analytics, 'activation_permissions', {\n permissions: message.data?.givenPermission ? 'Full' : 'Partial',\n partner: origin,\n });\n\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.PluginActivationV2StartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.PluginActivationV2PartialPermissions,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => window.removeEventListener('message', messageHandler);\n }, [history]);\n\n return (\n \n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateMultiStepAlwaysAllow;\n","import React, { useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: 24px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n width: 220px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n margin-top: 33px;\n margin-top: 33px;\n padding-left: 24px;\n padding-right: 24px;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n`;\n\nconst IconContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding-bottom: 23px;\n`;\n\nconst IconContentDescription = styled.div`\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n padding-top: 15px;\n`;\n\nconst WhatYouNeedText = styled.div`\n font-family: Arial;\n font-size: 16px;\n font-style: normal;\n font-weight: 700;\n line-height: 20.8px;\n margin-bottom: 11px;\n`;\n\nconst ContentItem = styled.div`\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: normal;\n margin-bottom: 39px;\n width: 250px;\n display: flex;\n flex-direction: row;\n`;\n\nconst AllowBothText = styled.div`\n width: 170px;\n padding-left: 4px;\n`;\n\nconst PartnerNewPluginActivateMultiStepPartialPermissions = () => {\n const { t } = useTranslation();\n\n return (\n \n \n \n \n AbsoluteText\n \n \n \n \n \n {t('PartnerNewpluginsdkActivate.hereWhatYouNeed')}\n \n \n \n \n 1. {t('PartnerNewpluginsdkActivate.gotToSettings')}\n \n \n 2. {t('PartnerNewpluginsdkActivate.tapSafari')}\n \n \n 3. {t('PartnerNewpluginsdkActivate.scrollDownToExtensions')}\n \n \n 4. {t('PartnerNewpluginsdkActivate.selectItvX')}\n \n \n 5.\n \n {t('PartnerNewpluginsdkActivate.allowBothWebsites')}\n \n \n \n \n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateMultiStepPartialPermissions;\n","import React from 'react';\nimport styled from 'styled-components';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n overflow-x: hidden;\n padding-inline: 20px;\n`;\n\nconst Row = styled.div`\n display: flex;\n justify-content: center;\n padding-top: 15px;\n\n &:last-child {\n padding-bottom: 15px;\n }\n`;\n\nconst Item = styled.div<{ itemWidth?: number; itemHeight?: number }>`\n width: ${(props) => props.itemWidth ?? 109}px;\n height: ${(props) => props.itemHeight ?? 65}px;\n margin-right: 15px;\n display: flex;\n justify-content: center;\n align-items: center;\n box-shadow: 2px 2px 20px 2px rgba(0, 0, 0, 0.1);\n padding: 10px;\n\n &:last-child {\n margin-right: 0px;\n }\n`;\n\ninterface PyramidGridProps {\n items: ItemProps[];\n numRows: number;\n maxItemsAtBase: number;\n renderItem: (item: ItemProps) => React.ReactNode;\n itemWidth?: number;\n itemHeight?: number;\n}\n\nconst PyramidGrid = ({\n numRows,\n maxItemsAtBase,\n items,\n renderItem,\n itemWidth,\n itemHeight,\n}: PyramidGridProps) => {\n const rows = [];\n let itemIndex = 0;\n for (let i = 1; i <= numRows; i++) {\n const rowItems = [];\n const numItemsInRow = Math.min(\n maxItemsAtBase - Math.abs(numRows - i),\n items.length - itemIndex\n );\n for (let j = 0; j < numItemsInRow; j++) {\n rowItems.push(\n \n {renderItem(items[itemIndex])}\n \n );\n itemIndex++;\n }\n rows.push({rowItems});\n }\n\n return {rows};\n};\n\nexport default PyramidGrid;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PyramidGrid from '../../Common/PyramidGrid/PyramidGrid';\nimport { mockedLogos } from '../../Theming/images';\nimport { tabletMediaQuery } from '../../Theming';\nimport { isMobile } from '../../Common/Utils/platforms';\nimport { Trans } from 'react-i18next';\nimport clsx from 'clsx';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n`;\n\nconst TextContainer = styled.div`\n padding-inline: 24px;\n display: flex;\n flex-direction: column;\n\n justify-content: center;\n align-items: center;\n\n ${tabletMediaQuery} {\n justify-content: flex-start;\n align-items: flex-start;\n }\n`;\n\nconst HeaderText = styled.span`\n font-weight: bold;\n font-family: Arial;\n font-size: 30px;\n\n ${tabletMediaQuery} {\n font-size: 16px;\n }\n`;\n\nconst MainText = styled.span`\n font-weight: 400;\n font-family: Arial;\n font-size: 20px;\n margin-top: 7px;\n\n ${tabletMediaQuery} {\n font-size: 14px;\n }\n\n &.text-centered {\n text-align: center;\n }\n`;\n\nconst CashSaverBrandsContainer = styled.div`\n justify-content: center;\n align-items: center;\n display: flex;\n font-family: Arial;\n padding-top: 24px;\n\n &.noPaddingTop {\n padding-top: 0px;\n }\n`;\n\nconst LogoImage = styled.img`\n height: 30px;\n`;\n\ninterface CashSaverBrandProps {\n headerText?: string;\n mainText?: string;\n mainTextClassName?: string;\n headerTextClassName?: string;\n noPaddingTop?: boolean;\n}\n\nconst CashSaverBrands: React.FC = ({\n headerText,\n mainText,\n mainTextClassName,\n headerTextClassName,\n noPaddingTop,\n}) => {\n const sampleImages = Object.values(mockedLogos);\n const items = Array.from({ length: 27 }).map((_, i) => ({\n image: sampleImages[(i + 1) % sampleImages.length],\n }));\n\n return (\n \n \n \n {headerText}\n {mainText}\n \n \n\n \n }\n items={items}\n numRows={isMobile() ? 3 : 2}\n maxItemsAtBase={9}\n />\n \n \n );\n};\n\nexport default CashSaverBrands;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport { themeColor } from '../Theming';\nimport { useQuery } from '../Common/Hooks';\nimport CashSaverBrands from '../ITVActivation/Components/CashSaverBrands';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: 24px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n width: 220px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n`;\n\nconst ListContent = styled.li`\n color: ${themeColor('darkestGrey')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n margin-left: 15px;\n margin-bottom: 20px;\n`;\n\nconst BorderedItem = styled.strong`\n color: ${themeColor('blue')};\n border: 0.8px solid ${themeColor('blue')};\n padding: 3px;\n border-radius: 5px;\n margin-left: 3px;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n top: 8px;\n right: 20px;\n animation: ${bounce} 2s infinite;\n width: 163px;\n height: 46px;\n`;\n\nconst MultiStepStyledButton = styled.button`\n flex-shrink: 0;\n color: ${themeColor('white')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: normal;\n background-color: black;\n width: 254px;\n height: 42px;\n border-radius: 5px;\n`;\n\nconst CashSaverBrandsContainer = styled.div`\n width: 100%;\n padding-bottom: 20px;\n overflow-x: scroll; /* Enables horizontal scrolling */\n overflow-y: hidden;\n`;\n\nconst FrequentlyAskedQuestion = styled.div`\n color: #000;\n\n text-align: center;\n font-family: Arial;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 120%; /* 16.8px */\n text-decoration-line: underline;\n margin-top: 10px;\n`;\nconst PartnerNewPluginActivateMultiStepAllDone = () => {\n const { t } = useTranslation();\n const query = useQuery();\n\n const openApp = useCallback(() => {\n const origin = query.get('origin');\n if (origin)\n window.location = `${origin}://` as (string | Location) & Location;\n }, [query]);\n\n return (\n \n \n \n \n AbsoluteText\n \n \n \n \n \n \n \n \n {t('PartnerNewpluginsdkActivate.backToApp')}\n \n \n {t('PartnerNewpluginsdkActivate.frequentlyAskedQuestions')}\n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateMultiStepAllDone;\n","import React from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\n\nconst Logo = styled.img``;\n\nconst ItvSquareLogo: React.FC = ({ ...rest }) => {\n return (\n \n );\n};\n\nItvSquareLogo.defaultProps = {\n height: 15,\n};\nexport default ItvSquareLogo;\n","import { useEffect } from 'react';\n\nexport enum KK_UTM_KSOURCE {\n ITViOSAddUnit = 'itvxAppiOS',\n ITVAndroidAddUnit = 'itvxAppiOS',\n ITVTVAd = 'itvxTV',\n ITVVanityUrl = 'itvxShortUrl',\n ITVLP = 'itvxLP',\n}\n\nexport const usePluginActivationUTMQueryParamExtraction = (\n query: URLSearchParams\n) => {\n useEffect(() => {\n const utmKSource = query.get('ksource') as KK_UTM_KSOURCE;\n handleKSourceUTMParameter(utmKSource);\n }, []);\n\n const handleKSourceUTMParameter = (Ksource: KK_UTM_KSOURCE) => {\n if (\n Ksource === KK_UTM_KSOURCE.ITVAndroidAddUnit ||\n Ksource === KK_UTM_KSOURCE.ITVLP\n ) {\n location.href = '';\n }\n };\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport { itvThemeColor, themeColor } from '../../Theming';\nimport ItvSquareLogo from '../../ITVActivation/Logos/ItvSquareLogo';\nimport { Trans } from 'react-i18next';\n\nconst Container = styled.div`\n padding-top: 24px;\n padding-bottom: 20px;\n background-color: ${itvThemeColor('greenishBlue')};\n flex: 1;\n display: flex;\n flex-direction: column;\n justify-content: center;\n height: 400px;\n`;\n\nconst LogoTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n`;\n\nconst Title = styled.span`\n color: ${themeColor('white')};\n font-weight: Bold;\n font-family: Arial;\n padding-block: 16px;\n text-align: center;\n line-height: 25px;\n font-size: 20px;\n`;\n\nconst DisclaimerContainer = styled.div`\n background-color: ${themeColor('white')};\n margin-inline: 24px;\n border-radius: 10px;\n padding: 10px;\n overflow: auto;\n flex-grow: 1;\n`;\n\nconst Disclaimer = styled.span`\n font-family: Arial;\n font-size: 13px;\n line-height: 18px;\n color: ${themeColor('black')};\n`;\n\ninterface HeaderProps {\n title: string;\n permissionsAgreed?: boolean;\n disclaimerText?: string;\n}\n\nconst Header: React.FC = ({\n title,\n permissionsAgreed,\n disclaimerText,\n}) => {\n return (\n \n \n \n \n {title}\n \n \n {!permissionsAgreed && (\n \n {disclaimerText}\n \n )}\n \n );\n};\n\nexport default Header;\n","import React, { ButtonHTMLAttributes } from 'react';\nimport styled from 'styled-components';\nimport { themeColor } from '../../Theming';\nimport LoadingIndicator from '../../Common/LoadingIndicator';\n\nconst StyledButton = styled.button.attrs(({ type = 'button' }) => ({\n type,\n}))<{ height?: string; margin?: string }>`\n background-color: ${themeColor('darkestGrey')};\n color: ${themeColor('white')};\n text-transform: uppercase;\n font-weight: bold;\n border: none;\n padding: 8px;\n font-size: 1rem;\n width: 160px;\n cursor: pointer;\n position: relative;\n height: ${(props) => props.height};\n margin: ${(props) => props.margin};\n &:disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n &.blueTheme {\n width: 100%;\n text-transform: none;\n border-radius: 6px;\n padding: 12px;\n font-size: 0.875rem;\n max-width: 335px;\n margin-top: 10px;\n }\n &.itvTheme {\n width: 100%;\n font-weight: 400;\n font-family: Arial;\n border-radius: 4px;\n font-size: 14px;\n }\n`;\n\nconst StyledLoader = styled(LoadingIndicator)`\n transform: scale(0.5) translate(-50%, -50%);\n position: absolute;\n top: 50%;\n left: 50%;\n transform-origin: top left;\n & div {\n background: ${themeColor('white')};\n }\n`;\n\ninterface ButtonProps extends ButtonHTMLAttributes {\n loading?: boolean;\n height?: string;\n margin?: string;\n}\n\nconst Button: React.FC = ({\n loading = false,\n children,\n className,\n height,\n margin,\n ...rest\n}) => (\n \n {loading ? (\n <>\n ‌\n \n \n ) : (\n children\n )}\n \n);\n\nexport default Button;\n\nexport const WhiteButton = styled(Button)`\n text-transform: none;\n background-color: ${themeColor('white')};\n color: ${themeColor('darkestGrey')};\n border: 1px solid ${themeColor('black')};\n border-radius: 2px;\n width: fit-content;\n padding: 10px 20px;\n\n :hover {\n border-color: ${themeColor('darkestGrey')};\n }\n`;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { itvThemeColor } from '../../Theming';\nimport { Trans } from 'react-i18next';\n\nconst Container = styled.div`\n padding-inline: 24px;\n padding-top: 24px;\n`;\n\nconst Title = styled.span`\n font-family: Arial;\n font-weight: Bold;\n font-size: 16px;\n line-height: 30px;\n display: flex;\n`;\n\nconst Msg = styled.span`\n font-family: Arial;\n font-size: 14px;\n line-height: 20px;\n display: flex;\n`;\n\nconst StepsContainer = styled.div`\n padding-top: 20px;\n`;\n\nconst StepItem = styled.div`\n display: flex;\n flex-direction: row;\n height: 30px;\n align-items: center;\n`;\n\nconst StepTag = styled.div`\n height: 20px;\n width: 20px;\n border-radius: 20px;\n background-color: ${itvThemeColor('lightGreen')};\n font-size: 12px;\n font-weight: Bold;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nconst StepText = styled.span`\n font-family: Arial;\n font-size: 14px;\n line-height: 30px;\n margin-left: 10px;\n`;\n\ninterface ActivationStepsProps {\n steps?: string[];\n title?: string;\n msg?: string;\n}\n\nconst ActivationSteps: React.FC = ({\n steps,\n title,\n msg,\n}) => {\n return (\n \n {title}\n {msg}\n \n {steps?.map((item, index) => (\n \n {index}\n \n {item}\n \n \n ))}\n \n \n );\n};\n\nexport default ActivationSteps;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Button, { WhiteButton } from '../../ITVActivation/Components/Button';\nimport CashSaverBrands from '../../ITVActivation/Components/CashSaverBrands';\nimport ActivationSteps from './ActivationSteps';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n`;\n\nconst ButtonsContainer = styled.div`\n padding-top: 30px;\n padding-inline: 24px;\n display: flex;\n flex-direction: column;\n`;\n\nconst CashSaverMsg = styled.span`\n text-align: center;\n padding-inline: 50px;\n font-family: Arial;\n margin-top: 40px;\n font-size: 14px;\n`;\n\nconst FaqLink = styled.span`\n display: block;\n font-family: Arial;\n padding-top: 24px;\n font-size: 14px;\n text-decoration: underline;\n text-align: center;\n`;\n\ninterface ActivateNowProps {\n title?: string;\n msg?: string;\n steps?: string[];\n cashSaverPopUpMsg?: string;\n permissionsAgreed?: boolean;\n navigateToSettings?: () => void;\n close?: () => void;\n}\n\nconst ActivateNow: React.FC = ({\n title,\n msg,\n steps,\n permissionsAgreed,\n navigateToSettings,\n cashSaverPopUpMsg,\n close,\n}) => {\n const { t } = useTranslation();\n\n return (\n \n {permissionsAgreed ? (\n <>\n {cashSaverPopUpMsg}\n \n \n ) : (\n \n )}\n\n \n {permissionsAgreed ? (\n <>\n \n {t('extension.itvActivation.androidAccessibility.continue')}\n \n {t('extension.itvActivation.faq.faqLink')}\n \n ) : (\n <>\n \n {t('extension.itvActivation.androidAccessibility.agree')}\n \n \n {t('extension.itvActivation.androidAccessibility.disagree')}\n \n \n )}\n \n \n );\n};\n\nexport default ActivateNow;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Header from './Components/Header';\nimport { useTranslation } from 'react-i18next';\nimport ActivateNow from './Components/ActivateNow';\nimport { useQuery } from '../Common/Hooks';\n\ninterface AndroidInterface {\n navigateToSettings(): void;\n close(): void;\n}\n\ndeclare const KindredAndroid: AndroidInterface | undefined;\n\nconst Container = styled.div`\n flex-direction: column;\n justify-content: space-between;\n display: flex;\n flex: 1;\n`;\n\nconst BottomContent = styled.div`\n flex-direction: column;\n padding-bottom: 24px;\n`;\n\nconst AndroidAccessibility: React.FC = () => {\n const query = useQuery();\n const permissionsAgreed = (query.get('accepted') as string) === 'true';\n const { t } = useTranslation();\n\n const navigateToSettings = () => {\n if (\n typeof KindredAndroid !== 'undefined' &&\n KindredAndroid.navigateToSettings\n ) {\n KindredAndroid.navigateToSettings();\n }\n };\n\n const close = () => {\n if (typeof KindredAndroid !== 'undefined' && KindredAndroid.close) {\n KindredAndroid.close();\n }\n };\n\n return (\n \n \n \n \n \n \n );\n};\n\nexport default AndroidAccessibility;\n","import React from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\n\nconst Logo = styled.img``;\n\nconst ItvLogo: React.FC = ({ ...rest }) => {\n return (\n \n );\n};\n\nItvLogo.defaultProps = {\n height: 15,\n};\nexport default ItvLogo;\n","import React from 'react';\nimport styled from 'styled-components';\nimport images from '../../Theming/images';\n\nconst Logo = styled.img`\n height: 100%;\n width: 100%;\n`;\n\nconst DominosLogo: React.FC = ({ ...rest }) => {\n return (\n \n );\n};\n\nDominosLogo.defaultProps = {};\nexport default DominosLogo;\n","import React from 'react';\nimport {\n themeColor,\n itvThemeColor,\n tabletMediaQuery,\n mobileMediaQuery,\n} from '../../Theming';\nimport styled from 'styled-components';\nimport ItvLogo from '../Logos/ItvLogo';\nimport DominosLogo from '../Logos/DominosLogo';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: row;\n height: 64px;\n background-color: ${itvThemeColor('greenishBlue')};\n justify-content: space-between;\n padding-inline: 20px;\n\n ${tabletMediaQuery} {\n height: 48px;\n }\n`;\n\nconst LeftSection = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n`;\n\nconst RightSection = styled.span`\n display: flex;\n flex-direction: row;\n align-items: center;\n color: ${themeColor('white')};\n font-family: Arial;\n font-size: 16px;\n text-decoration: underline;\n cursor: pointer;\n\n ${tabletMediaQuery} {\n font-size: 12px;\n }\n`;\n\nconst SponseredText = styled.span`\n font-size: 21px;\n font-family: Arial;\n color: #aac0c8;\n padding-left: 12px;\n padding-right: 4px;\n\n ${tabletMediaQuery} {\n font-size: 10px;\n }\n`;\n\nconst LogoContainer = styled.div`\n height: 34px;\n width: 34px;\n margin-left: 5px;\n\n ${mobileMediaQuery} {\n height: 16px;\n width: 16px;\n margin-left: 2px;\n }\n`;\n\nconst StandardHeader: React.FC = () => {\n const { t } = useTranslation();\n return (\n \n \n \n \n {t('extension.itvActivation.header.sponsoredBy')}\n \n \n \n \n \n \n {t('extension.itvActivation.header.backToMainSite')}\n \n \n );\n};\n\nexport default StandardHeader;\n","import React from 'react';\nimport { itvThemeColor, tabletMediaQuery, themeColor } from '../../Theming';\nimport styled from 'styled-components';\nimport { Close } from '../../Common/Svg/Icons';\nimport { useTranslation } from 'react-i18next';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: row;\n height: 64px;\n background-color: ${itvThemeColor('greenishBlue')};\n justify-content: space-between;\n padding-inline: 20px;\n\n ${tabletMediaQuery} {\n height: 48px;\n }\n`;\n\nconst Section = styled.div`\n display: flex;\n flex-direction: column;\n font-weight: Bold;\n justify-content: center;\n font-family: Arial;\n padding-inline: 13px;\n flex: 1;\n\n &.aligned-center {\n align-items: center;\n flex: 2 !important;\n }\n\n &.aligned-right {\n align-items: flex-end;\n }\n`;\n\nconst Text = styled.span`\n font-size: 18px;\n color: ${themeColor('white')};\n`;\n\nconst CloseIcon = styled.div`\n cursor: pointer;\n`;\n\ninterface CashSaverHeaderProps {\n onClose?: () => void;\n}\n\nconst CashSaverHeader: React.FC = ({ onClose }) => {\n const { t } = useTranslation();\n return (\n \n
    \n
    \n {t('extension.itvActivation.header.cashSaver')}\n
    \n
    \n \n \n \n
    \n \n );\n};\n\nexport default CashSaverHeader;\n","import React, { PropsWithChildren } from 'react';\nimport styled from 'styled-components';\nimport StandardHeader from './StandardHeader';\nimport { Helmet } from 'react-helmet';\nimport CashSaverHeader from './CashSaverHeader';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n flex: 1;\n`;\n\ninterface ITVLayoutProps {\n showHeader?: boolean;\n isEmbeddedInAndroid?: boolean;\n onClose?: () => void;\n}\n\nconst ITVLayout: React.FC> = ({\n children,\n showHeader = true,\n isEmbeddedInAndroid,\n onClose,\n}) => {\n const renderHeader = () => {\n if (isEmbeddedInAndroid) {\n return ;\n }\n\n return ;\n };\n\n return (\n <>\n \n Kindred x itv\n \n \n \n {showHeader && renderHeader()}\n {children}\n \n \n );\n};\n\nexport default ITVLayout;\n","import { TFunction } from 'react-i18next';\nimport {\n getBrowserName,\n isIOS,\n isMac,\n isMobile,\n} from '../Common/Utils/platforms';\nimport env from '../env';\nimport { Path } from '../Routing';\n\nexport type ActivationButtonStatusMsg = {\n button: 'ACTIVATE' | 'DOWNLOAD';\n msg: string;\n};\n\nexport const isSafari = () => {\n return getBrowserName() === 'ios';\n};\n\nexport const isChrome = () => {\n return getBrowserName() === 'crios';\n};\n\nexport const getActivationButtonStatusMsg = (\n t: TFunction<'translation'>\n): ActivationButtonStatusMsg | undefined => {\n if (isIOS && !isSafari()) {\n if (isChrome()) {\n return {\n button: 'ACTIVATE',\n msg: t('extension.itvActivation.cashSaver.usingChromeMsg'),\n };\n }\n return {\n button: 'ACTIVATE',\n msg: t('extension.itvActivation.cashSaver.unsupportedBrowserMsg'),\n };\n }\n\n return {\n button: 'DOWNLOAD',\n msg: t('extension.itvActivation.cashSaver.downloadCompleteMsg'),\n };\n};\n\nexport const getExtensionInstallMsg = (t: TFunction<'translation'>) => {\n if (isMac) {\n return t('extension.itvActivation.cashSaver.unsupportedMacBrowserMsg');\n }\n\n return t('extension.itvActivation.cashSaver.unsupportedPCBrowserMsg');\n};\n\nexport const onActivateButtonClick = () => {\n return '';\n};\n\nexport const getActivateButtonLink = () => {\n if (isIOS) {\n return Path.PluginActivationV2ActivatePlugin;\n }\n\n return Path.PluginActivationV2;\n};\n\n/**\n * returns undefined if browser is not chrome or safari to disable the button\n */\nexport const getDesktopExtensionInstallButtonLink = () => {\n if (!isMobile()) {\n if (getBrowserName() === 'chrome') {\n return env.chrome_extension_store_url;\n }\n\n if (getBrowserName() === 'safari') {\n return env.safari_extension_store_url;\n }\n\n return undefined;\n }\n};\n\nexport const getDownloadButtonLink = () => {\n if (isIOS) {\n return env.itv_ios_appstore_link;\n }\n return env.itv_android_appstore_link;\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport {\n themeColor,\n itvThemeColor,\n tabletMediaQuery,\n mobileMediaQuery,\n} from '../../Theming';\nimport { isMobile } from '../../Common/Utils/platforms';\nimport Button from './Button';\nimport { getActivationButtonStatusMsg, getExtensionInstallMsg } from '../utils';\nimport { useTranslation } from 'react-i18next';\n\nconst gutter = 10;\nconst rowInlinePadding = `10rem`;\nconst columnInlinePadding = `6rem`;\n\nconst Container = styled.div`\n padding-top: 120px;\n flex-direction: column;\n background-color: ${itvThemeColor('gray')};\n padding-bottom: 94px;\n\n ${tabletMediaQuery} {\n padding-bottom: 24px;\n padding-top: 24px;\n background-color: ${themeColor('white')};\n }\n`;\n\nconst MainText = styled.span`\n font-family: Arial;\n font-size: 36px;\n font-weight: bold;\n color: ${themeColor('black')};\n text-align: left;\n display: in-line;\n line-height: 130%;\n display: block;\n\n ${mobileMediaQuery} {\n font-size: 20px;\n }\n`;\n\nconst SubText = styled.span`\n font-family: Arial;\n font-size: 20px;\n text-align: left;\n margin-top: 8px;\n line-height: 130%;\n display: block;\n\n ${mobileMediaQuery} {\n font-size: 16px;\n }\n`;\n\nconst ImageContainer = styled.div`\n height: 254px;\n background-color: ${itvThemeColor('lightGray')};\n width: 362px;\n\n ${tabletMediaQuery} {\n margin-top: 24px;\n width: 100%;\n }\n`;\n\nconst Row = styled.div`\n max-width: 100vw;\n margin: 0 auto;\n padding-inline: ${rowInlinePadding};\n\n &::after {\n content: '';\n display: table;\n clear: both;\n }\n\n ${tabletMediaQuery} {\n max-width: 130rem;\n padding-inline: 0px;\n }\n`;\n\nconst Column = styled.div`\n float: left;\n width: calc((100% - ${gutter}px) / 2);\n padding-inline: ${columnInlinePadding};\n\n ${tabletMediaQuery} {\n padding-inline: 24px;\n width: 100% !important;\n }\n\n &:not(:last-child) {\n margin-right: 10px;\n\n ${tabletMediaQuery} {\n margin-right: ${gutter}px;\n }\n }\n\n &:nth-child(2n) {\n margin-right: 0;\n }\n`;\n\nconst DesktopDownloadContainer = styled.div`\n display: flex;\n flex-direction: column;\n padding-top: 24px;\n width: 255px;\n`;\n\nconst DesktopDownloadText = styled.span`\n font-size: 20px;\n font-weight: bold;\n font-family: Arial;\n line-height: 130%;\n padding-bottom: 16px;\n`;\n\nconst StatusMsgContainer = styled.div`\n position: relative;\n margin-top: 27px;\n width: 70%;\n`;\n\nconst StatusMsgContent = styled.div`\n display: flex;\n flex-direction: row;\n padding-block: 8px;\n background-color: ${itvThemeColor('gray')};\n border-radius: 5px;\n`;\n\nconst StatusMsg = styled.span`\n display: block;\n font-family: Arial;\n font-size: 14px;\n line-height: 120%;\n padding-right: 10px;\n`;\n\nconst Triangle = styled.div`\n position: absolute;\n left: 50px;\n top: -20px;\n width: 0;\n height: 0;\n border-left: 20px solid transparent;\n border-right: 20px solid transparent;\n border-bottom: 30px solid ${itvThemeColor('gray')};\n`;\n\nconst InfoIcon = styled.span`\n margin-inline: 8px;\n`;\n\nconst Image = styled.img``;\n\ninterface CashSaverProps {\n mainText?: string;\n subText?: string;\n desktopDownloadText?: string;\n desktopDownloadButtonText?: string;\n installExtensionLink?: string;\n onInstallClick?: () => void;\n}\n\nconst CashSaver: React.FC = ({\n mainText,\n subText,\n desktopDownloadText,\n desktopDownloadButtonText,\n installExtensionLink,\n onInstallClick,\n}) => {\n const { t } = useTranslation();\n return (\n \n \n \n {mainText}\n {subText}\n\n {!isMobile() && (\n <>\n \n {desktopDownloadText}\n \n \n {desktopDownloadButtonText}\n \n \n \n {!installExtensionLink && (\n \n \n \n \n {getExtensionInstallMsg(t)}\n \n \n )}\n \n )}\n \n\n \n \n {/* */}\n \n \n \n \n );\n};\n\nexport default CashSaver;\n","import React, { useState } from 'react';\nimport styled from 'styled-components';\nimport { tabletMediaQuery } from '../../Theming';\n\nconst Container = styled.div``;\n\nconst TextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n\n ${tabletMediaQuery} {\n align-items: flex-start;\n justify-content: flex-start;\n }\n`;\n\nconst MainText = styled.span`\n font-family: Arial;\n font-size: 20px;\n line-heignt: 120%;\n margin-top: 15px;\n\n ${tabletMediaQuery} {\n font-size: 14px;\n }\n`;\n\nconst HeaderText = styled.span`\n font-family: Arial;\n font-size: 30px;\n line-heignt: 130%;\n font-weight: bold;\n\n ${tabletMediaQuery} {\n font-size: 16px;\n }\n`;\n\nconst FaqQuestionsContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding-top: 40px;\n\n ${tabletMediaQuery} {\n align-items: flex-start;\n justify-content: flex-start;\n }\n`;\n\nconst FaqItem = styled.div`\n width: 692px;\n height: 72px;\n border-bottom: 1px solid rgba(0, 0, 0, 0.5);\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n padding-inline: 10px;\n\n &:first-child {\n border-top: 1px solid rgba(0, 0, 0, 0.5);\n }\n\n ${tabletMediaQuery} {\n width: 100%;\n height: 50px;\n }\n`;\n\nconst FaqQuestion = styled.span`\n font-size: 20px;\n font-family: Arial;\n\n ${tabletMediaQuery} {\n font-size: 14px;\n }\n`;\n\nconst FaqCircle = styled.div`\n height: 24px;\n width: 24px;\n font-size: 24px;\n border: 2px solid rgba(0, 0, 0);\n border-radius: 20px;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nconst FaqLink = styled.span`\n text-align: center;\n justify-content: center;\n align-items: center;\n display: flex;\n padding-top: 40px;\n font-size: 20px;\n text-decoration: underline;\n font-family: Arial;\n\n ${tabletMediaQuery} {\n font-size: 16px;\n }\n`;\n\nconst FaqAnswerContainer = styled.div``;\nconst FaqAnswer = styled.span``;\n\ninterface Faq {\n question: string;\n answer: string;\n}\n\ninterface FaqProps {\n headerText?: string;\n mainText?: string;\n faqs?: Faq[];\n linkText?: string;\n}\n\nconst Faq: React.FC = ({ headerText, mainText, faqs, linkText }) => {\n return (\n \n \n {headerText}\n {mainText}\n \n\n \n {faqs?.map((faq, index) => {\n return (\n \n {faq.question}\n +\n \n );\n })}\n \n\n {linkText}\n \n );\n};\n\nexport default Faq;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Button from './Button';\n\ninterface ButtonTextGroupProps {\n title: string;\n buttonText: string;\n width?: any;\n href?: string;\n onClick?: () => void;\n className?: string;\n}\n\nconst Container = styled.div<{ width: number }>`\n display: flex;\n flex-direction: column;\n width: ${(props) => props.width};\n`;\n\nconst Title = styled.span`\n font-family: Arial;\n font-size: 16px;\n font-weight: bold;\n margin-bottom: 10px;\n`;\n\nconst ButtonTextGroup: React.FC = ({\n title,\n buttonText,\n width = '100%',\n href,\n onClick,\n}) => {\n return (\n \n {title}\n \n \n \n \n );\n};\n\nexport default ButtonTextGroup;\n","import React from 'react';\nimport styled from 'styled-components';\nimport Button from './Button';\nimport { Path } from '../../Routing';\nimport { Trans, useTranslation } from 'react-i18next';\nimport { itvThemeColor, themeColor } from '../../Theming';\nimport ButtonTextGroup from './ButtonTextGroup';\nimport {\n ActivationButtonStatusMsg,\n getActivateButtonLink,\n getActivationButtonStatusMsg,\n getDownloadButtonLink,\n onActivateButtonClick,\n} from '../utils';\n\nconst Container = styled.div``;\n\nconst ButtonsContainer = styled.div`\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n margin-top: 30px;\n padding-inline: 24px;\n`;\n\nconst ButtonContainer = styled.div`\n padding-inline: 24px;\n`;\n\nconst DownloadAppMsg = styled.span`\n color: ${themeColor('black')};\n font-size: 14px;\n line-height: 120%;\n font-family: Arial;\n padding-inline: 24px;\n display: flex;\n`;\n\nconst StatusMsgContainer = styled.div`\n position: relative;\n margin-top: 27px;\n padding-inline: 24px;\n`;\n\nconst StatusMsgContent = styled.div`\n display: flex;\n flex-direction: row;\n padding-block: 8px;\n background-color: ${itvThemeColor('gray')};\n border-radius: 5px;\n`;\n\nconst StatusMsg = styled.span`\n display: block;\n font-family: Arial;\n font-size: 14px;\n line-height: 120%;\n padding-right: 10px;\n`;\n\nconst Triangle = styled.div<{\n buttonType: ActivationButtonStatusMsg['button'];\n}>`\n position: absolute;\n right: ${(props) => (props?.buttonType === 'DOWNLOAD' ? '60px' : undefined)};\n left: ${(props) => (props?.buttonType === 'ACTIVATE' ? '60px' : undefined)};\n top: -20px;\n width: 0;\n height: 0;\n border-left: 20px solid transparent;\n border-right: 20px solid transparent;\n border-bottom: 30px solid ${itvThemeColor('gray')};\n`;\n\nconst InfoIcon = styled.span`\n margin-inline: 8px;\n`;\n\nconst ActivateCashSaverInfoContainer = styled.div`\n padding-left: 24px;\n padding-right: 10px;\n padding-top: 10px;\n`;\nconst ActivateCashSaverInfo = styled.span`\n font-family: Arial;\n font-size: 14px;\n line-height: 120%;\n\n &.cashsaver-info-underlined {\n text-decoration: underline;\n }\n`;\n\ninterface ActivationButtonsProps {\n isEmbeddedInAndroid?: boolean;\n}\nconst ActivationButtons: React.FC = ({\n isEmbeddedInAndroid,\n}) => {\n const { t } = useTranslation();\n const buttonStatusMsg = getActivationButtonStatusMsg(t);\n\n if (isEmbeddedInAndroid) {\n return (\n <>\n \n \n \n {t('extension.itvActivation.cashSaver.activateCashSaver')}\n \n \n \n\n \n \n \n \n \n \n \n \n );\n }\n return (\n \n \n {t('extension.itvActivation.cashSaver.downloadAppMsg')}\n \n\n \n \n \n \n\n {buttonStatusMsg?.button && (\n \n \n \n \n {buttonStatusMsg.msg}\n \n \n )}\n \n );\n};\n\nexport default ActivationButtons;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { itvThemeColor, mobileMediaQuery } from '../../Theming';\nimport ItvLogo from '../Logos/ItvLogo';\nimport { Trans, useTranslation } from 'react-i18next';\nimport env from '../../env';\nimport { getYear } from 'date-fns';\n\ninterface FooterProps {\n text?: string;\n}\n\nconst Container = styled.div`\n background-color: ${itvThemeColor('greenishBlue')};\n padding-top: 45px;\n padding-left: 19px;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n`;\n\nconst TextContent = styled.span`\n color: ${itvThemeColor('textGray')};\n font-family: Arial;\n font-size: 15px;\n line-height: 25px;\n width: 70%;\n`;\n\nconst ColoredTextContent = styled.a`\n color: ${itvThemeColor('lemonGreen')};\n cursor: pointer;\n text-decoration: none;\n`;\n\nconst LogoContainer = styled.div`\n padding-top: 48px;\n padding-bottom: 84px;\n\n ${mobileMediaQuery} {\n padding-top: 38px;\n padding-bottom: 36px;\n }\n`;\n\nexport const Footer: React.FC = ({ text }) => {\n const { t } = useTranslation();\n return (\n \n \n \n \n colored text\n \n \n \n \n \n \n \n );\n};\n","import React from 'react';\nimport styled from 'styled-components';\nimport CashSaver from './Components/CashSaver';\nimport { useTranslation } from 'react-i18next';\nimport CashSaverBrands from './Components/CashSaverBrands';\nimport { isMobile } from '../Common/Utils/platforms';\nimport Faq from './Components/Faq';\nimport ActivationButtons from './Components/ActivationButtons';\nimport { getDesktopExtensionInstallButtonLink } from './utils';\nimport { Footer } from './Components/Footer';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n`;\n\nconst CashSaverBrandsContainer = styled.div`\n margin-top: 30px;\n`;\n\nconst FaqContainer = styled.div`\n padding-block: 70px;\n padding-inline: 24px;\n`;\n\ninterface ITVActivationProps {\n isEmbeddedInAndroid?: boolean;\n}\n\nconst ITVActivation: React.FC = ({\n isEmbeddedInAndroid,\n}) => {\n const { t } = useTranslation();\n\n return (\n \n \n\n {isMobile() && (\n \n )}\n\n \n \n \n\n \n \n \n {!isEmbeddedInAndroid && (\n
    \n )}\n \n );\n};\n\nexport default ITVActivation;\n","import React from 'react';\nimport { usePluginActivationUTMQueryParamExtraction } from './utils';\nimport { getUtmParamsForChromeExtension } from '../Common/Utils/extensionSDK';\nimport { useQuery } from '../Common/Hooks';\nimport ITVLayout from '../ITVActivation/ITVLayout/ITVLayout';\nimport ITVActivation from '../ITVActivation';\n\ninterface AndroidInterface {\n navigateToSettings(): void;\n close(): void;\n}\n\ndeclare const KindredAndroid: AndroidInterface | undefined;\n\nconst PartnerPluginActivateV2: React.FC = () => {\n const query = useQuery();\n usePluginActivationUTMQueryParamExtraction(query);\n const utmParameters = getUtmParamsForChromeExtension();\n const utmSource = utmParameters.utmSource || query.get('utm_source');\n\n const isEmbeddedInAndroid = () => {\n return typeof KindredAndroid !== 'undefined';\n };\n\n const close = () => {\n if (typeof KindredAndroid !== 'undefined' && KindredAndroid.close) {\n KindredAndroid.close();\n }\n };\n\n const renderContent = () => {\n switch (utmSource) {\n case 'ITV':\n return (\n \n \n \n );\n\n default:\n return null;\n }\n };\n\n return renderContent();\n};\n\nexport default PartnerPluginActivateV2;\n","import React from 'react';\n\ninterface Props {\n fill?: string;\n}\n\nconst SearchIcon: React.FC = ({ fill = '#0A0A0A' }) => {\n return (\n \n \n \n \n );\n};\n\nexport default SearchIcon;\n","import React from 'react';\n\ninterface Props extends React.SVGProps {\n fill?: string;\n}\nconst CloseIcon: React.FC = ({ fill = '#000', ...rest }) => {\n return (\n \n \n \n );\n};\n\nexport default CloseIcon;\n","import React from 'react';\nimport styled from 'styled-components';\nimport SearchIcon from './SearchIcon';\nimport CloseIcon from './CloseIcon';\n\nconst Container = styled.div`\n background-color: #f3f3ed;\n height: 45px;\n border-radius: 8px;\n padding: 0 16px 0 23px;\n flex-direction: row;\n align-items: center;\n display: flex;\n margin-inline: 20px;\n -ms-overflow-style: none;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n`;\n\nconst TextInput = styled.input`\n outline: none;\n border: none;\n flex: 1;\n background-color: transparent;\n font-size: 16px;\n`;\n\nconst SearchIconContainer = styled.span`\n padding-right: 12px;\n margin-top: 3px;\n [dir='rtl'] & {\n transform: scaleX(-1);\n }\n`;\n\ninterface Props {\n text?: string;\n placeholder?: string;\n onSearch?: (text: string) => void;\n onClose?: () => void;\n}\n\nconst Search: React.FC = ({\n text,\n placeholder = 'Search',\n onSearch,\n onClose,\n}) => {\n return (\n \n {!text && (\n \n \n \n )}\n onSearch?.(e.currentTarget.value)}\n />\n {text && }\n \n );\n};\n\nexport default Search;\n","import React, { useEffect, useRef } from 'react';\nimport { CategoryOption } from './Categories';\nimport styled from 'styled-components';\n\nconst Container = styled.button`\n height: 40px;\n border-radius: 40px;\n margin-right: 15px;\n padding-inline: 24px;\n justify-content: center;\n align-items: center;\n border: 2px solid #0a0a0a66;\n background-color: white;\n font-size: 14px;\n\n &:focus {\n box-shadow: none;\n }\n\n &:focus-visible {\n outline: 2px solid #5e9ed6;\n text-decoration: none;\n }\n`;\n\ninterface Props extends React.ButtonHTMLAttributes {\n isSelected?: boolean;\n option: CategoryOption;\n setSelectedOption: ((option: CategoryOption) => void) | undefined;\n getName: ((option?: CategoryOption) => void) | undefined;\n}\n\nconst CatetoryItem: React.FC = ({\n isSelected,\n setSelectedOption,\n option,\n getName,\n ...rest\n}) => {\n const ref = useRef(null);\n useEffect(() => {\n if (isSelected) {\n ref.current?.scrollIntoView({\n behavior: 'smooth',\n inline: 'center',\n });\n }\n }, [isSelected]);\n return (\n setSelectedOption?.(option)} {...rest}>\n {getName?.(option) ?? option?.name}\n \n );\n};\n\nexport default CatetoryItem;\n","import React, { useRef } from 'react';\nimport styled from 'styled-components';\nimport CategoryItem from './CatetoryItem';\n\nconst Container = styled.div`\n flex-direction: row;\n width: 100%;\n overflow-x: scroll;\n white-space: nowrap;\n padding: 20px 5px 5px 20px;\n align-items: center;\n display: flex;\n background-color: #fff;\n\n &::-webkit-scrollbar {\n width: 0px;\n background: transparent;\n scrollbar-width: none;\n -ms-overflow-style: none;\n display: none;\n }\n`;\n\nexport interface CategoryOption {\n value: string;\n name?: string;\n arabicName?: string;\n}\ninterface Props {\n options: CategoryOption[];\n selectedOption?: CategoryOption;\n setSelectedOption?: (option: CategoryOption) => void;\n getName?: (option?: CategoryOption) => void;\n}\n\nconst Categories: React.FC = ({\n options,\n selectedOption,\n setSelectedOption,\n getName,\n}) => {\n const containerRef = useRef(null);\n\n return (\n \n {options.map((item, index) => {\n const isSelected = selectedOption?.value === item?.value;\n const key = `category-${index}`;\n\n return (\n {\n setSelectedOption?.(item);\n console.log('client', containerRef.current?.offsetWidth);\n }}\n />\n );\n })}\n \n );\n};\n\nexport default Categories;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { OfferWallBrands } from '../types';\n\nconst Container = styled.div`\n padding: 35px 24px 24px 24px;\n`;\n\nconst BrandItem = styled.div`\n flex-direction: row;\n display: flex;\n align-items: center;\n height: 72px;\n border-bottom: 1px solid #e7e7e7;\n`;\n\nconst Text = styled.p`\n padding-inline: 30px;\n margin: 0;\n font-size: 14px;\n`;\n\nconst Logo = styled.img`\n width: 65px;\n`;\n\ninterface Props {\n brands?: OfferWallBrands[];\n}\n\nconst Brands: React.FC = ({ brands }) => {\n return (\n \n {brands?.map((item, index) => {\n const key = `brand-${index}`;\n const id = item?.id;\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const image = require(`../../Assets/OfferWall/${id}.png`).default;\n return (\n \n \n {item?.name}\n \n );\n })}\n \n );\n};\n\nexport default Brands;\n","import { CategoryOption } from './components/Categories';\nimport { OfferWallBrands, OfferWallCategories } from './types';\n\nexport const getBrandsToShow = (\n categories: OfferWallCategories[],\n selectedCategory: CategoryOption,\n allBrands: OfferWallBrands[],\n searchKey: string\n) => {\n if (searchKey) {\n return allBrands.filter((brand) =>\n brand?.name?.trim().toLowerCase().includes(searchKey.trim().toLowerCase())\n );\n }\n return categories.find((item) => item?.id === selectedCategory.value)?.brands;\n};\n\nexport const getUniqueList = (list?: T[]) => {\n return Array.from(new Set(list)) as T[];\n};\n","import React, { useCallback, useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport Search from './components/Search';\nimport Categories, { CategoryOption } from './components/Categories';\nimport data from './data.json';\nimport { OfferWallBrands, OfferWallCategories } from './types';\nimport Brands from './components/Brands';\nimport { getBrandsToShow, getUniqueList } from './utils';\n\nconst Container = styled.div`\n padding-block: 20px;\n`;\n\nconst Header = styled.header`\n top: 0;\n position: fixed;\n width: 100%;\n background-color: white;\n padding-top: 20px;\n`;\n\nconst Main = styled.main`\n margin-top: 90px;\n`;\n\ntype DocumentDir = 'rtl' | 'ltr';\n\ninterface Props {\n documentDir?: DocumentDir;\n}\nconst OfferWall: React.FC = ({ documentDir }) => {\n const [searchKey, setSearchKey] = useState('');\n const [selectedCategory, setSelectedCategory] = useState({\n value: 'all',\n name: 'All',\n });\n const [categories, setCategories] = useState([]);\n const allBrands = data.categories.flatMap((category) => category.brands);\n const dir = (documentDir ?? document.documentElement.dir) as DocumentDir;\n\n useEffect(() => {\n initPageData();\n }, []);\n\n useEffect(() => {\n initPageDir();\n }, [document?.dir, dir]);\n\n const initPageDir = () => {\n if (dir) {\n document.dir = dir;\n }\n };\n\n const initPageData = () => {\n if (!data.categories.find((category) => category.id === 'all')) {\n data.categories.unshift({\n name: 'All',\n id: 'all',\n arabicName: 'الكل',\n brands: allBrands,\n });\n }\n setCategories(data.categories);\n };\n\n const options = categories.map((item) => ({\n value: item?.id,\n name: item?.name,\n arabicName: item.arabicName,\n }));\n\n const brands = getBrandsToShow(\n categories,\n selectedCategory,\n allBrands,\n searchKey\n );\n\n const uniqueBrands = getUniqueList(brands).sort(\n (brand1, brand2) => brand1.name.localeCompare(brand2.name)\n );\n const uniqueCategoryOptions = getUniqueList(options);\n\n const onSearch = useCallback((text: string) => {\n setSelectedCategory({\n value: 'all',\n name: 'All',\n arabicName: 'الكل',\n });\n setSearchKey(text);\n }, []);\n\n const onCloseSearch = useCallback(() => {\n setSearchKey('');\n }, []);\n\n return (\n \n
    \n \n setSelectedCategory(option)}\n getName={(option) =>\n dir === 'rtl' ? option?.arabicName : option?.name\n }\n />\n
    \n\n
    \n \n
    \n
    \n );\n};\n\nexport default OfferWall;\n","export default __webpack_public_path__ + \"static/media/puzzlePieceBackground.a574edbb.png\";","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport KindredLogo from '../../Common/Logos/KindredLogo';\n\nconst Container = styled.div`\n color: #fff;\n display: flex;\n align-items: flex-end;\n justify-content: center;\n\n & > p {\n font-size: 14px;\n font-weight: 400;\n text-align: center;\n padding: 0;\n margin: 0 5px 0 10px;\n }\n`;\nconst PoweredByKindred = () => {\n const { t } = useTranslation();\n return (\n \n

    {t('global.poweredBy')}

    \n \n
    \n );\n};\n\nexport default PoweredByKindred;\n","import React from 'react';\nimport styled from 'styled-components';\nimport { useTranslation } from 'react-i18next';\nimport i18n from 'i18next';\nimport images from '../Theming/images';\nimport '../Theming/Fonts/custom-fonts.css';\n\nconst NavBar = styled.div`\n display: flex;\n align-items: center;\n justify-content: space-between;\n background-color: #0033a1;\n padding: 10px 15px;\n height: 60px;\n position: fixed;\n font-family: TIMSans-Regular;\n z-index: 2;\n width: 100%;\n`;\n\nconst BackIcon = styled.div`\n display: flex;\n align-items: center;\n cursor: pointer;\n\n img {\n height: 24px;\n width: 24px;\n }\n`;\n\nconst Title = styled.div`\n flex: 1;\n text-align: center;\n font-size: 18px;\n color: white;\n`;\n\nconst TimTopNavigation = () => {\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n\n const handleBackClick = () => {\n if (window.history.length > 1) {\n window.history.back();\n }\n };\n\n return (\n \n \n \n \n {t('PartnerNewpluginsdkActivate.timTopNavigationTitle')}\n \n );\n};\n\nexport default TimTopNavigation;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PuzzlePieceBackground from '../Assets/TIM/puzzlePieceBackground.png';\nimport { Trans, useTranslation } from 'react-i18next';\nimport { Close } from '../Common/Svg/Icons';\nimport PoweredByKindred from './shared/PoweredByKindred';\nimport {\n ANALYTICS_PAGE_NAMES,\n trackClickedActionEvent,\n} from '../Common/Analytics/utils';\nimport { usePageViewTracking, useQuery } from '../Common/Hooks';\nimport { isIOS, isAndroid } from 'react-device-detect';\nimport { useHistory } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport { onClose } from './KindredAndroid';\nimport i18n from 'i18next';\nimport { accessibilityFocusStyleLight } from '../Theming';\nimport { Helmet } from 'react-helmet';\nimport timIcon from '../Assets/PartnerNewpluginsdkActivate/tim-ios-logo.png';\nimport { sendDataToiOS } from './KindredIOS';\nimport TimTopNavigation from './TimTopNavigation';\nimport '../Theming/Fonts/custom-fonts.css';\n\nconst Container = styled.div`\n background-color: #0164f2;\n display: flex;\n flex-direction: column;\n flex: 1;\n height: ${window.innerHeight + 60}px;\n position: relative;\n margin-top: 60px;\n font-family: TIMSans-Regular;\n`;\n\nconst ImageContainer = styled.div`\n position: absolute;\n display: flex;\n width: 100%;\n flex: 1;\n align-items: center;\n justify-content: center;\n`;\n\nconst Image = styled.img`\n width: 320px;\n z-index: 1;\n margin-top: -95px;\n\n @media (max-height: 600px) {\n width: 290px;\n }\n`;\n\nconst MainContent = styled.div`\n margin-top: 130px;\n\n @media (max-height: 600px) {\n margin-top: 100px;\n }\n`;\n\nconst TitleText = styled.p`\n margin: 0;\n padding: 0px 16px 0 16px;\n color: #fff;\n font-size: 20px;\n line-height: normal;\n font-weight: bold;\n text-align: center;\n`;\n\nconst Description = styled.p`\n margin: 0;\n padding: 8px 20px 0 20px;\n color: #fff;\n text-align: center;\n font-size: 16px;\n line-height: normal;\n`;\n\nconst KindredDisclaimerContainer = styled.div`\n margin-top: 20px;\n\n @media (max-height: 600px) {\n margin-top: 10px;\n }\n`;\n\nconst KindredDisclaimerContainerText = styled.p`\n margin: 10px 0 0 0;\n padding: 0 16px 0 16px;\n font-size: 11px;\n color: #fff;\n text-align: center;\n line-height: normal;\n`;\n\nconst Footer = styled.footer`\n display: flex;\n flex-direction: column;\n padding-inline: 16px;\n padding-bottom: 20px;\n position: fixed;\n left: 0;\n bottom: 0;\n width: 100%;\n\n @media (max-height: 600px) {\n padding-bottom: 10px;\n }\n`;\n\nconst Button = styled.button`\n height: 52px;\n background-color: #fff;\n border: none;\n margin-top: 16px;\n color: #fff;\n font-size: 16px;\n font-weight: bold;\n color: #0164f2;\n font-family: TIMSans-Regular;\n`;\n\nconst PolicyDisclaimer = styled.p`\n font-size: 11px;\n text-align: center;\n color: #fff;\n margin: 20px 0 0 0;\n padding: 0;\n line-height: normal;\n\n @media (max-height: 600px) {\n margin: 5px 0 0 0;\n }\n`;\n\nconst LinkText = styled.a`\n font-size: 11px;\n color: #fff;\n text-decoration: underline;\n cursor: pointer;\n text-align: center;\n\n ${accessibilityFocusStyleLight}\n`;\n\nconst FaqLink = styled.a`\n font-size: 18px;\n color: #fff;\n text-decoration: underline;\n cursor: pointer;\n text-align: center;\n\n ${accessibilityFocusStyleLight}\n`;\n\nconst TIMActivationHome = () => {\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n const history = useHistory();\n\n usePageViewTracking(ANALYTICS_PAGE_NAMES.extension_explainer, 'TIM');\n const query = useQuery();\n /**\n * TODO: Confirm and use logic to determine the activation message\n */\n const onActivateClick = () => {\n trackClickedActionEvent(\n query,\n 'TIM',\n 'activate',\n ANALYTICS_PAGE_NAMES.extension_explainer\n );\n\n if (isIOS) {\n const link = new URL(window.location.href);\n link.pathname = Path.TimPluginActivationActivatePlugin;\n\n sendDataToiOS({\n message: 'copyAndGo',\n payload: {\n site: link.toString(),\n couponCode: '',\n },\n });\n if (window?.history?.length > 1) {\n window?.history?.back();\n }\n } else {\n history.push({\n pathname: Path.TIMAndroidActivationHome,\n search: location.search,\n });\n }\n };\n\n const getButtonText = () => {\n if (isAndroid) {\n return t('tim.activateChromeExtension');\n } else {\n return t('tim.activateSafariExtension');\n }\n };\n\n const getDescriptionText = () => {\n if (isAndroid) {\n return t('tim.activateExtensionDescriptionChrome');\n } else {\n return t('tim.activateExtensionDescriptionSafari');\n }\n };\n\n const onFAQClick = () => {\n trackClickedActionEvent(\n query,\n 'TIM',\n 'faq',\n ANALYTICS_PAGE_NAMES.extension_explainer\n );\n };\n\n return (\n
    \n \n \n \n \n TIM Benefit\n \n \n \"discounts\n \n\n \n {t('tim.activateExtension')}\n {getDescriptionText()}\n\n \n \n \n {t('tim.disclaimer')}\n \n \n \n\n
    \n \n {t('tim.seeFaq')}\n \n \n \n \n informativa privacy\n \n \n termini e condizioni\n \n \n \n \n
    \n
    \n
    \n );\n};\n\nexport default TIMActivationHome;\n","export interface CouponData {\n couponCode?: string;\n site?: string;\n error?: any;\n}\nexport interface MessageStructure {\n message?: 'copyAndGo' | 'getToken' | 'dismissWebview';\n payload?: CouponData;\n}\n\nexport const sendDataToiOS = (data?: MessageStructure) => {\n if ((window as any)?.webkit) {\n (window as any)?.webkit?.messageHandlers?.messageHandlerForiOS?.postMessage(\n data\n );\n } else {\n console.log('iOS message handlers not available.');\n }\n};\n","import React from 'react';\n\ninterface Props extends React.SVGProps {\n width?: string | number;\n height?: string | number;\n fill?: string;\n}\nconst Download: React.FC = ({\n width = '24',\n height = '24',\n fill = 'white',\n ...rest\n}) => {\n return (\n \n \n \n \n \n );\n};\n\nexport default Download;\n","import React from 'react';\n\ninterface Props extends React.SVGProps {\n width?: string | number;\n height?: string | number;\n fill?: string;\n}\nconst Toggle: React.FC = ({\n width = '36',\n height = '24',\n fill = 'white',\n ...rest\n}) => {\n return (\n \n \n \n \n );\n};\n\nexport default Toggle;\n","import React from 'react';\nimport { Trans, useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport Download from './shared/Download';\nimport Toggle from './shared/Toggle';\nimport {\n ANALYTICS_PAGE_NAMES,\n trackClickedActionEvent,\n} from '../Common/Analytics/utils';\nimport { usePageViewTracking, useQuery } from '../Common/Hooks';\nimport { navigateToAndroidSettings, onClose } from './KindredAndroid';\nimport i18n from 'i18next';\nimport timIcon from '../Assets/PartnerNewpluginsdkActivate/tim-ios-logo.png';\nimport { Helmet } from 'react-helmet';\nimport '../Theming/Fonts/custom-fonts.css';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n flex: 1;\n background-color: #0033a1;\n padding: 27px 0 0 0;\n font-family: TIMSans-Regular;\n`;\n\nconst Header = styled.header`\n padding-inline: 42px;\n height: 40vh;\n padding-bottom: 30px;\n`;\n\nconst Title = styled.h1`\n font-size: 20px;\n font-weight: bold;\n text-align: left;\n color: #fff;\n margin-bottom: 40px;\n`;\n\nconst DisclosureContainer = styled.div`\n overflow: auto;\n height: 80%;\n -webkit-mask-image: -webkit-gradient(\n linear,\n left 70%,\n left bottom,\n from(rgba(0, 0, 0, 1)),\n to(rgba(0, 0, 0, 0))\n );\n scrollbar-color: #fff #fff;\n padding-bottom: 40px;\n`;\n\nconst Disclosure = styled.p`\n color: #fff;\n margin: 0;\n font-size: 16px;\n padding-bottom: 15px;\n`;\n\nconst Footer = styled.footer`\n display: flex;\n flex-direction: column;\n flex: 1;\n background-color: #0058ef;\n padding-block: 21px;\n padding-inline: 16px;\n justify-content: space-around;\n position: absolute;\n bottom: 0;\n height: 50%;\n width: 100%;\n`;\n\nconst FooterTitle = styled.p`\n margin: 0;\n text-align: center;\n color: #fff;\n font-size: 20px;\n font-weight: bold;\n`;\n\nconst ActivationStep = styled.div`\n text-align: center;\n font-size: 16px;\n color: #fff;\n align-items: center;\n justify-content: center;\n align-items: center;\n position: relative;\n`;\n\nconst ButtonsContainer = styled.div`\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n margin-top: 20px;\n`;\n\nconst Button = styled.button`\n height: 52px;\n font-size: 16px;\n font-weight: bold;\n font-family: TIMSans-Regular;\n\n &.white {\n background-color: #fff;\n border: none;\n color: #0164f2;\n }\n\n &.outlined {\n background-color: transparent;\n border: 3px solid #fff;\n color: #fff;\n margin-top: 8px;\n }\n`;\n\nconst AndroidAccessibility = () => {\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n const query = useQuery();\n\n usePageViewTracking(\n ANALYTICS_PAGE_NAMES.accessibility_instructions_page,\n 'TIM'\n );\n const installationSteps = [\n 'tim.tapAccept',\n 'tim.tapInstalledApps',\n 'tim.activateTimCoupon',\n ];\n\n const onAccept = () => {\n trackClickedActionEvent(\n query,\n 'TIM',\n 'agree',\n ANALYTICS_PAGE_NAMES.accessibility_instructions_page\n );\n navigateToAndroidSettings();\n };\n\n const onDecline = () => {\n trackClickedActionEvent(\n query,\n 'TIM',\n 'disagree',\n ANALYTICS_PAGE_NAMES.accessibility_instructions_page\n );\n if (window?.history?.length > 2) {\n window?.history?.go(-2);\n }\n };\n\n return (\n \n \n \n TIM Benefit\n \n
    \n {t('tim.enableAccessibilityPermissions')}\n \n \n \n \n \n \n \n
    \n
    \n {t('tim.howToActivate')}\n {installationSteps?.map((key, index) => (\n \n \n \n \n \n \n ))}\n \n \n \n \n
    \n
    \n );\n};\n\nconst toggleIconStyle: React.CSSProperties = {\n transform: 'translateY(25%)',\n};\n\nconst downloadIconStyle: React.CSSProperties = {\n marginLeft: 7,\n transform: 'translateY(25%)',\n};\n\nexport default AndroidAccessibility;\n","declare const KindredAndroid: AndroidInterface | undefined;\nexport interface AndroidInterface {\n navigateToSettings(): void;\n close(): void;\n openExternalURL(url: string): void;\n}\n\nexport const onExternalLinkClicked = (\n url: string,\n isEmbeddedInAndroid?: boolean\n) => {\n if (isEmbeddedInAndroid) {\n if (\n typeof KindredAndroid !== 'undefined' &&\n KindredAndroid.openExternalURL\n ) {\n KindredAndroid.openExternalURL(url);\n } else {\n window.location.href = url;\n }\n }\n};\n\nexport const onClose = () => {\n if (typeof KindredAndroid !== 'undefined' && KindredAndroid.close) {\n KindredAndroid.close();\n }\n};\n\nexport const navigateToAndroidSettings = () => {\n if (\n typeof KindredAndroid !== 'undefined' &&\n KindredAndroid.navigateToSettings\n ) {\n KindredAndroid.navigateToSettings();\n }\n};\n","const colors = {\n cloudBlue: '#2E7CF6',\n darkCloudBlue: '#0058EF',\n darkRoyalBlue: '#0033AA',\n};\n\nexport default colors;\n","import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components';\nimport { Trans, useTranslation } from 'react-i18next';\nimport i18n from 'i18next';\nimport colors from '../../Theming/colors';\nimport timColors from '../../Theming/TIMTheme/colors';\nimport { Helmet } from 'react-helmet';\nimport timIcon from '../../Assets/PartnerNewpluginsdkActivate/tim-ios-logo.png';\nimport clsx from 'clsx';\nimport '../../Theming/Fonts/custom-fonts.css';\n\nconst Container = styled.div`\n width: 100%;\n max-width: 700px;\n min-height: 700px;\n margin: 0 auto;\n font-family: TIMSans-Regular;\n background-color: ${timColors.darkCloudBlue};\n\n &.showRoyalBlueBackground {\n background-color: ${timColors.darkRoyalBlue};\n }\n`;\n\nconst Body = styled.div<{ bodyMarginTop?: number }>`\n margin-top: ${(props) => (props.bodyMarginTop ? props.bodyMarginTop : -3)}px;\n min-height: 500px;\n padding-top: 1px;\n\n &.whiteBackground {\n background-color: white;\n }\n`;\n\nconst Header = styled.div`\n height: 340px;\n position: relative;\n\n flex: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding-top: 10px;\n\n &.showSmallHeight {\n height: 200px;\n }\n\n &.showSuccessPageHeight {\n height: 243px;\n }\n`;\n\nconst HeaderText = styled.div`\n text-align: center;\n font-size: 20px;\n font-style: normal;\n font-weight: 700;\n line-height: 130%;\n color: ${colors.white};\n width: 250px;\n z-index: 2;\n padding-top: 30px;\n\n &.shadow {\n text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6);\n padding-top: 45px;\n }\n`;\n\nconst SubHeaderText = styled.div`\n text-align: center;\n font-size: 20px;\n font-style: normal;\n color: ${colors.white};\n z-index: 2;\n padding-top: 6px;\n`;\n\nconst BoldText = styled.div`\n font-weight: bold;\n`;\n\nconst StyledBrandedIcon = styled.img`\n width: 60px;\n height: 60px;\n\n &.successPageView {\n width: 357.4px;\n height: 93.56px;\n }\n\n &.partialPageView {\n width: 97.23px;\n height: 79.13px;\n }\n`;\n\nconst StyledBrandedImage = styled.img`\n width: 100%;\n height: 342px;\n\n object-fit: cover;\n margin-bottom: -2px;\n`;\n\nconst ImageWrapper = styled.div`\n overflow: hidden;\n display: inline-block;\n height: calc(100% - 2px);\n width: 100%;\n position: absolute;\n z-index: 1;\n top: 0;\n`;\n\ninterface MultiStepContainerProps {\n headerText?: string;\n headerTextWidth?: number;\n subHeaderText?: string;\n bodyMarginTop?: number;\n image?: string;\n logo?: string;\n headerShadow?: boolean;\n successPageView?: boolean;\n partialPageView?: boolean;\n}\n\nconst MultiStepActivationContainer: React.FC = ({\n children,\n headerText,\n bodyMarginTop,\n image,\n logo,\n headerShadow = false,\n successPageView = false,\n subHeaderText,\n partialPageView,\n}) => {\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation('');\n\n return (\n \n \n \n TIM Benefit\n \n \n {logo && (\n \n )}\n {headerText && (\n \n \n AbsoluteText\n \n \n )}\n {subHeaderText && (\n \n \n AbsoluteText\n \n \n )}\n {image && (\n \n \n \n )}\n
    \n \n {children}\n \n \n );\n};\n\nexport default MultiStepActivationContainer;\n","import React, { useEffect } from 'react';\nimport styled from 'styled-components';\nimport { useHistory } from 'react-router-dom';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport i18n from 'i18next';\nimport images from '../Theming/images';\nimport { Path } from '../Routing';\nimport { isIOS, osVersion } from 'react-device-detect';\nimport { ANALYTICS_PAGE_NAMES } from '../Common/Analytics/utils';\nimport { usePageViewTracking } from '../Common/Hooks';\n\nexport const MultiStepHeaderText = styled.h3`\n color: smokeBlack;\n text-align: center;\n font-size: 22px;\n font-style: normal;\n font-weight: 700;\n line-height: normal;\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n min-height: 106px;\n margin-top: 33px;\n padding-left: 24px;\n padding-right: 24px;\n display: flex;\n justify-content: center;\n`;\n\nconst IconContentDescription = styled.div`\n color: white;\n font-size: 18px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n padding-top: 10px;\n`;\n\nexport const FirstA = styled.span`\n font-size: 14px;\n`;\n\nexport const SecondA = styled.span`\n font-size: 18px;\n`;\n\nconst TapAATextContainer = styled.div`\n margin-bottom: 20px;\n display: flex;\n justify-content: center;\n`;\nconst TextTitleContainer = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n flex-wrap: wrap;\n line-height: 15px;\n margin-bottom: 20px;\n width: 100%;\n`;\n\nconst StrongText = styled.strong`\n padding-left: 2px;\n padding-right: 2px;\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n margin-left: 4px;\n margin-right: 4px;\n`;\n\nconst FloatingUnionImage = styled.img`\n position: absolute;\n top: 325px;\n left: 50%;\n transform: translateX(-50%);\n width: 33.47px;\n height: 30.5px;\n z-index: 2;\n`;\n\nconst PartnerPluginActivateMultiStep: React.FC = () => {\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n usePageViewTracking(ANALYTICS_PAGE_NAMES.activation_instructions_page, 'TIM');\n const history = useHistory();\n const supportsiOS18 = isIOS && parseInt(osVersion) >= 18;\n\n useEffect(() => {\n const initialHeight = window.innerHeight;\n\n const interval = setInterval(() => {\n const currentHeight = window.innerHeight;\n const difference = initialHeight - currentHeight;\n\n if (difference > 44 && difference < 61) {\n history.push({\n pathname: Path.TimPluginActivationAlwaysAllow,\n search: location.search,\n });\n }\n }, 1500);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message && message.data === '') {\n window.location.reload();\n } else if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.TimPluginActivationStartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.TimPluginActivationPartialPermissions,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => {\n clearInterval(interval);\n window.removeEventListener('message', messageHandler);\n };\n }, [history]);\n\n return (\n \n \n \n \n {!supportsiOS18 ? (\n \n
    \n \n A\n A\n \n
    \n
    \n ) : (\n \n \n {t(\n 'PartnerNewpluginsdkActivate.timLetsActivateTapTitle18Part1'\n )}\n \n \n \n BoldText\n \n \n )}\n\n \n \n {t(\n 'PartnerNewpluginsdkActivate.timLetsActivateSelectPluginPart1'\n )}\n \n \n \n BoldText\n \n \n \n \n {t(\n 'PartnerNewpluginsdkActivate.timLetsActivateTogglePluginPart1'\n )}\n \n \n \n BoldText\n \n \n
    \n
    \n \n );\n};\n\nexport default PartnerPluginActivateMultiStep;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PartnerPluginActivateMultiStep from './PartnerPluginActivateMultiStep';\nimport { useLanguageUtm } from '../Common';\nimport usePageTitle from '../Common/Hooks/usePageTitle';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst PartnerNewpluginsdkActivateTim = () => {\n useLanguageUtm();\n usePageTitle();\n\n return ;\n};\n\nexport default PartnerNewpluginsdkActivateTim;\n","import React, { useEffect } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport { logEvent, getAnalytics } from 'firebase/analytics';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport i18n from 'i18next';\nimport images from '../Theming/images';\nimport { useHistory } from 'react-router-dom';\nimport { Path } from '../Routing';\nimport app from '../Firebase';\nimport { usePageViewTracking, useQuery } from '../Common/Hooks';\nimport { ANALYTICS_PAGE_NAMES } from '../Common/Analytics/utils';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n margin-top: 33px;\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n`;\n\nconst bounce = keyframes`\n 0%, 20%, 50%, 80%, 100% {\n transform: translateY(0);\n }\n 40% {\n transform: translateY(-20px);\n }\n 60% {\n transform: translateY(-10px);\n }\n`;\n\nconst StyledImage = styled.img`\n position: fixed;\n top: 8px;\n right: 20px;\n animation: ${bounce} 2s infinite;\n width: 261px;\n height: 60px;\n z-index: 2;\n`;\n\nconst TextContainer = styled.div`\n color: white;\n font-size: 18px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n margin-bottom: 20px;\n`;\n\nconst PartnerNewPluginActivateTimMultiStepAlwaysAllow = () => {\n usePageViewTracking(ANALYTICS_PAGE_NAMES.additional_permissions_page, 'TIM');\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n const history = useHistory();\n const query = useQuery();\n\n useEffect(() => {\n const analytics = getAnalytics(app);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messageHandler = (message: any) => {\n if (message && message.data === '') {\n window.location.reload();\n } else if (message) {\n switch (message.data?.type) {\n case 'PluginEnabled': {\n const origin = query.get('origin');\n logEvent(analytics, 'activation_permissions', {\n permissions: message.data?.givenPermission ? 'Full' : 'Partial',\n partner: origin,\n });\n\n if (message.data?.givenPermission) {\n history.push({\n pathname: Path.TimPluginActivationStartShopping,\n search: location.search,\n });\n } else {\n history.push({\n pathname: Path.TimPluginActivationPartialPermissions,\n search: location.search,\n });\n }\n break;\n }\n }\n }\n };\n\n window.addEventListener('message', messageHandler);\n\n return () => window.removeEventListener('message', messageHandler);\n }, [history]);\n\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateTimMultiStepAlwaysAllow;\n","import React from 'react';\nimport styled from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport i18n from 'i18next';\nimport { themeColor } from '../Theming';\nimport images from '../Theming/images';\nimport { ANALYTICS_PAGE_NAMES } from '../Common/Analytics/utils';\nimport { usePageViewTracking } from '../Common/Hooks';\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n margin-top: 33px;\n margin-top: 33px;\n padding-left: 24px;\n padding-right: 24px;\n`;\n\nconst StyledImage = styled.img`\n margin-top: 5px;\n margin-left: 4px;\n`;\n\nconst IconContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: center;\n padding-bottom: 23px;\n`;\n\nconst IconContentDescription = styled.div`\n color: ${themeColor('white')};\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 21px;\n padding-top: 15px;\n`;\n\nconst WhatYouNeedText = styled.div`\n font-size: 20px;\n font-style: normal;\n font-weight: 700;\n line-height: 20.8px;\n margin-bottom: 11px;\n padding-top: 30px;\n text-align: center;\n color: ${themeColor('white')};\n`;\n\nconst ContentItem = styled.div`\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: normal;\n margin-bottom: 30px;\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n`;\n\nconst PaddingLeft = styled.div`\n padding-left: 2px;\n font-weight: bold;\n`;\n\nconst PartnerNewPluginActivateTimMultiStepPartialPermissions = () => {\n usePageViewTracking(ANALYTICS_PAGE_NAMES.partially_installed_page, 'TIM');\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n\n return (\n \n \n \n {t(\n 'PartnerNewpluginsdkActivate.timPartialPermissionsPartiallyInstalledTodo'\n )}\n \n \n \n \n \n \n \n \n \n \n {t(\n 'PartnerNewpluginsdkActivate.timPartialPermissionsPartiallyInstalledTapSafari'\n )}\n \n \n \n \n \n \n \n \n {t(\n 'PartnerNewpluginsdkActivate.timPartialPermissionsPartiallyInstalledSelectTim'\n )}\n \n \n \n {t(\n 'PartnerNewpluginsdkActivate.timPartialPermissionsPartiallyInstalledAllowAllWebsites'\n )}\n \n \n \n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateTimMultiStepPartialPermissions;\n","import React from 'react';\nimport styled from 'styled-components';\nimport PyramidGrid from '../../Common/PyramidGrid/PyramidGrid';\nimport { mockedLogosTim } from '../../Theming/images';\nimport { tabletMediaQuery } from '../../Theming';\nimport { isMobile } from '../../Common/Utils/platforms';\nimport { Trans } from 'react-i18next';\nimport clsx from 'clsx';\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n`;\n\nconst TextContainer = styled.div`\n padding-inline: 24px;\n display: flex;\n flex-direction: column;\n\n justify-content: center;\n align-items: center;\n\n ${tabletMediaQuery} {\n justify-content: flex-start;\n align-items: flex-start;\n }\n`;\n\nconst HeaderText = styled.span`\n font-weight: bold;\n font-family: Arial;\n font-size: 30px;\n\n ${tabletMediaQuery} {\n font-size: 16px;\n }\n`;\n\nconst MainText = styled.span`\n font-weight: 400;\n font-family: Arial;\n font-size: 20px;\n margin-top: 7px;\n\n ${tabletMediaQuery} {\n font-size: 14px;\n }\n\n &.text-centered {\n text-align: center;\n }\n`;\n\nconst CashSaverBrandsContainer = styled.div`\n justify-content: center;\n align-items: center;\n display: flex;\n font-family: Arial;\n padding-top: 24px;\n\n &.noPaddingTop {\n padding-top: 0px;\n }\n`;\n\nconst LogoImage = styled.img`\n height: auto;\n max-width: 60%;\n`;\n\ninterface CashSaverBrandProps {\n headerText?: string;\n mainText?: string;\n mainTextClassName?: string;\n headerTextClassName?: string;\n noPaddingTop?: boolean;\n}\n\nconst CashSaverBrands: React.FC = ({\n headerText,\n mainText,\n mainTextClassName,\n headerTextClassName,\n noPaddingTop,\n}) => {\n const sampleImages = Object.values(mockedLogosTim);\n const items = Array.from({ length: 8 }).map((_, i) => ({\n image: sampleImages[i % sampleImages.length],\n }));\n\n return (\n \n \n \n {headerText}\n {mainText}\n \n \n\n \n (\n \n )}\n items={items}\n numRows={isMobile() ? 5 : 2}\n maxItemsAtBase={8}\n itemHeight={51.13}\n itemWidth={99}\n />\n \n \n );\n};\n\nexport default CashSaverBrands;\n","import React, { useCallback, useEffect, useState } from 'react';\nimport styled, { keyframes } from 'styled-components';\nimport MultiStepActivationContainer from './Components/MultiStepActivationContainer';\nimport { useTranslation, Trans } from 'react-i18next';\nimport i18n from 'i18next';\nimport { themeColor } from '../Theming';\nimport timColors from '../Theming/TIMTheme/colors';\nimport { usePageViewTracking, useQuery } from '../Common/Hooks';\nimport CashSaverBrands from './Components/CashSaverBrands';\nimport images from '../Theming/images';\nimport {\n ANALYTICS_PAGE_NAMES,\n trackClickedActionEvent,\n} from '../Common/Analytics/utils';\nimport env from '../env';\n\nconst SubTitleTextContainer = styled.div`\n display: flex;\n flex-direction: column;\n align-items: center;\n margin-top: -20px;\n margin-bottom: 25px;\n`;\n\nconst SubTitleText = styled.div`\n color: ${themeColor('darkestGrey')};\n text-align: center;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n width: 343px;\n`;\n\nconst LinkText = styled.a`\n color: ${themeColor('blue')};\n`;\n\nexport const HyperisePlaceholderContainer = styled.div`\n width: 100%;\n height: fit-content;\n`;\n\nconst BodyContentContainer = styled.div`\n width: 100%;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n`;\n\nconst MultiStepStyledButton = styled.button`\n flex-shrink: 0;\n color: white;\n font-size: 16px;\n font-style: normal;\n font-weight: bold;\n line-height: normal;\n background-color: ${timColors.cloudBlue};\n width: 343px;\n height: 52px;\n border-width: 0px;\n font-family: TIMSans-Regular;\n`;\n\nconst CashSaverBrandsContainer = styled.div`\n width: 100%;\n padding-bottom: 0px;\n overflow-x: scroll; /* Enables horizontal scrolling */\n overflow-y: hidden;\n`;\n\ninterface Props {\n platform?: 'android' | 'ios';\n}\n\ninterface AndroidInterface {\n close(): void;\n}\n\ndeclare const KindredAndroid: AndroidInterface | undefined;\n\nconst PartnerNewPluginActivateTimMultiStepAllDone: React.FC = ({\n platform = 'ios',\n}) => {\n usePageViewTracking(ANALYTICS_PAGE_NAMES.activation_complete_page, 'TIM');\n if (i18n.language != 'it') {\n i18n.changeLanguage('it');\n }\n const { t } = useTranslation();\n const query = useQuery();\n\n const openApp = useCallback(() => {\n trackClickedActionEvent(\n query,\n 'TIM',\n 'back_to_app',\n ANALYTICS_PAGE_NAMES.activation_complete_page\n );\n\n if (platform === 'ios') {\n if (env.tim_app_scheme) {\n window.location = env.tim_app_scheme as (string | Location) & Location;\n }\n } else {\n if (typeof KindredAndroid !== 'undefined' && KindredAndroid.close) {\n KindredAndroid.close();\n }\n }\n }, [query]);\n\n return (\n \n \n \n \n \n \n \n \n AbsoluteText\n \n \n \n \n {t('PartnerNewpluginsdkActivate.timActivationSuccessBackToApp')}\n \n \n \n );\n};\n\nexport default PartnerNewPluginActivateTimMultiStepAllDone;\n","import React, { Suspense } from 'react';\nimport { Switch, Route, Redirect } from 'react-router-dom';\nimport { Path } from './Paths';\nimport LoadingIndicator from '../Common/LoadingIndicator';\nimport styled from 'styled-components';\nimport NotFound from '../Common/NotFound';\nimport DefaultLayout from './DefaultLayout';\nimport KeyboardInstallationGuide from '../KeyboardInstallationGuide';\nimport AndroidKeyboardInstallationGuide from '../AndroidKeyboardInstallationGuide';\nimport PartnerpluginsdkActivate from '../PartnerpluginsdkActivate';\nimport { ScrollToTop } from '../Common/ScrollToTop';\nimport { SamsungActivation } from '../Samsung';\nimport ExtensionInstalled from '../Extension/ExtensionInstalled';\nimport ExtensionUninstalled from '../Extension/ExtensionUninstalled';\nimport SamsungLanding from '../Samsung/SamsungLanding';\nimport TreePlanting from '../TreePlanting';\nimport ChromeDesktopUTMTracking from '../ChromeDesktopUTMTracking/ChromeDesktopUTMTracking';\nimport PartnerPluginActivateMultiStepAlwaysAllow from '../PartnerpluginsdkActivate/PartnerPluginActivateMultiStepAlwaysAllow';\nimport PartnerPluginActivateMultiStepAlmostThere from '../PartnerpluginsdkActivate/PartnerPluginActivateMultiStepAlmostThere';\nimport PartnerPluginActivateMultiStepBeSureToAllow from '../PartnerpluginsdkActivate/PartnerPluginActivateMultiStepBeSureToAllow';\nimport PartnerPluginActivateMultiStepStartShopping from '../PartnerpluginsdkActivate/PartnerPluginActivateMultiStepStartShopping';\nimport PartnerNewpluginsdkActivate from '../PartnerNewpluginsdkActivate';\nimport LinkRedirect from './LinkRedirect';\nimport PartnerNewPluginActivateMultiStepAlwaysAllow from '../PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepAlwaysAllow';\nimport PartnerNewPluginActivateMultiStepPartialPermissions from '../PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepPartialPermissions';\nimport PartnerNewPluginActivateMultiStepAllDone from '../PartnerNewpluginsdkActivate/PartnerNewPluginActivateMultiStepAllDone';\nimport AndroidAccessibility from '../AndroidAccessibility';\nimport PartnerPluginActivateV2 from '../PartnerPluginActivateV2';\nimport OfferWall from '../OfferWall';\nimport TIMActivationHome from '../TIM';\nimport TIMAndroidAccessibility from '../TIM/AndroidAccessibility';\nimport PartnerNewpluginsdkActivateTim from '../PartnerNewpluginsdkActivateTim';\nimport PartnerNewPluginActivateTimMultiStepAlwaysAllow from '../PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepAlwaysAllow';\nimport PartnerNewPluginActivateTimMultiStepPartialPermissions from '../PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepPartialPermissions';\nimport PartnerNewPluginActivateTimMultiStepAllDone from '../PartnerNewpluginsdkActivateTim/PartnerNewPluginActivateTimMultiStepAllDone';\n\nconst StyledLoadingIndicator = styled(LoadingIndicator)`\n min-height: 1500px;\n`;\n\nconst Routes = () => (\n }>\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n\n \n \n \n\n \n \n \n\n \n \n \n\n \n \n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n\n \n \n \n \n \n \n \n);\n\nexport default Routes;\n","import RoutesCore from './Routes';\nexport * from './Paths';\n\nexport const Routes = RoutesCore;\n","import React, { useEffect } from 'react';\nimport { I18nextProvider } from 'react-i18next';\nimport i18next from './Internationalization';\nimport { ThemeProvider } from 'styled-components';\nimport { theme } from './Theming';\nimport { Routes } from './Routing';\nimport { BrowserRouter as Router } from 'react-router-dom';\nimport { ModalProvider } from 'styled-react-modal';\nimport { ToastContainer } from 'react-toastify';\nimport 'react-toastify/dist/ReactToastify.css';\nimport { FeaturesProvider } from './PluginFeatures';\n\nconst App: React.FC = () => {\n useEffect(() => {\n if (window.hyperise) {\n window.hyperise.init();\n }\n // to allow content switching for languages that read from right to left\n const dir = i18next.dir(i18next.language);\n document.documentElement.dir = dir;\n }, []);\n\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n );\n};\n\nexport default App;\n","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styled from 'styled-components';\nimport UnstyledButton from '../Buttons/UnstyledButton';\nimport env from '../../env';\n\nconst SUPPORT_TEAM_EMAIL = env.support_team_email;\nconst MAIL_TO = 'mailto:' + SUPPORT_TEAM_EMAIL;\n\nconst Container = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n`;\n\nconst TextBlock = styled.div`\n margin-top: 20px;\n padding: 10px;\n background-color: #f5f5f5;\n width: 50%;\n margin-left: auto;\n margin-right: auto;\n`;\n\nconst StyledButton = styled(UnstyledButton)`\n color: blue;\n`;\n\nconst ErrorMessage: React.FC = () => {\n const { t } = useTranslation();\n\n const handleClick = () => {\n window.location.reload();\n };\n\n return (\n <>\n \n \n

    \n {t('errorMessage.somethingWentWrong')}\n \n {t('errorMessage.clickHere')}\n \n {t('errorMessage.toTryAgain')}\n

    \n

    \n {t('errorMessage.persists')}\n {SUPPORT_TEAM_EMAIL}.\n

    \n
    \n
    \n \n );\n};\n\nexport default ErrorMessage;\n","import React from 'react';\nimport ErrorMessage from './ErrorMessage';\n\ninterface State {\n hasError: boolean;\n}\n\nclass ErrorBoundary extends React.Component {\n state = { hasError: false };\n\n static getDerivedStateFromError() {\n return { hasError: true };\n }\n\n render() {\n if (this.state.hasError) {\n return ;\n }\n\n return this.props.children;\n }\n}\n\nexport default ErrorBoundary;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport './index.css';\nimport App from './App';\nimport ErrorBoundary from './Common/ErrorBoundary/ErrorBoundary';\nimport TagManager from 'react-gtm-module';\nimport env from './env';\nimport 'slick-carousel/slick/slick.css';\nimport 'slick-carousel/slick/slick-theme.css';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n\nTagManager.initialize({\n gtmId: env.gtm_id,\n});\n"],"sourceRoot":""}