{"version":3,"sources":["webpack:///./src/stories/Components/Content/WYSIWYG/WYSIWYG.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared.styles.ts","webpack:///./src/hooks/useMedia.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/InfoIcon/InfoIcon.styles.ts","webpack:///./src/hoc/withMotionMax.tsx","webpack:///./src/stories/Components/Global/Typography/Heading.styles.ts","webpack:///./src/helpers/mediaComponent.tsx","webpack:///./src/stories/Components/Global/Typography/Paragraph.styles.ts","webpack:///./src/img/ysp/ys-no-strapline.png","webpack:///./src/helpers/global.ts","webpack:///./src/img/icons/chevron-down.svg","webpack:///./src/stories/Components/Misc/Loader/Loader.styles.ts","webpack:///./src/img/icons/chevron-right.svg","webpack:///./src/hoc/withMotion.tsx","webpack:///./src/helpers/fonts.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Context/types.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Context/reducer.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Context/YSContext.tsx","webpack:///./src/img/ysp/icon-cross.svg","webpack:///./src/img/ysp/ysp-header-logo.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepFooter/StepFooter.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Modal/EngineerCheck/EngineerCheck.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Modal/EngineerCheck/EngineerCheck.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Modal/Modal.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Modal/Modal.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepHeader/StepHeader.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepHeader/StepHeader.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepPicker/StepPicker.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepPicker/StepPicker.tsx","webpack:///./src/img/ysp/icon-info.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Loading/Loading.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Loading/Loading.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepLoading/StepLoading.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepLoading/StepLoading.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Radios/Radios.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Radios/Radios.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/Form.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/InfoIcon/InfoIcon.tsx","webpack:///./src/img/ysp/groundwater-ground.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/Groundwater/Groundwater.styles.ts","webpack:///./src/img/ysp/groundwater-water.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/Groundwater/Groundwater.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/GroundwaterDepth/GroundwaterDepth.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/InlineNumericalInput/InlineNumericalInput.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/InlineNumericalInput/InlineNumericalInput.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/GroundwaterDepth/GroundwaterDepth.tsx","webpack:///./src/img/ysp/materials/loose-ground.png","webpack:///./src/img/ysp/materials/soft-clay.png","webpack:///./src/img/ysp/materials/loose-sand.png","webpack:///./src/img/ysp/materials/peat.png","webpack:///./src/img/ysp/materials/silt.png","webpack:///./src/img/ysp/materials/loose-gravel.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/ProblematicGround/ProblematicGround.tsx","webpack:///./src/img/ysp/materials/road.png","webpack:///./src/img/ysp/materials/dense-sand.png","webpack:///./src/img/ysp/materials/rock.png","webpack:///./src/img/ysp/materials/cohesive-fill.png","webpack:///./src/img/ysp/materials/stiff-clay.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Conditions/SoilTypes/SoilTypes.tsx","webpack:///./src/img/ysp/icon-point.svg","webpack:///./src/img/ysp/icon-check.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Depth/Depth.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Checkbox/Checkbox.styles.ts","webpack:///./src/img/icons/close-white.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Checkbox/Checkbox.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Toggle/Toggle.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Toggle/Toggle.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilInfoTable/SoilInfoTable.styles.ts","webpack:///./src/img/ysp/reset-thick.svg","webpack:///./src/img/icons/plus-thick.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/YSButton/YSButton.styles.ts","webpack:///./src/img/ysp/icon-check-circle-fill.svg","webpack:///./src/img/ysp/icon-phone.svg","webpack:///./src/img/ysp/icon-mail.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/YSButton/YSButton.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/NumberInput/NumberInput.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/NumberInput/NumberInput.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilInfoTable/SoilInfoTable.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Depth/Depth.tsx","webpack:///./src/img/ysp/icon-avatar.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Textbox/Textbox.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Details/Details.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Details/Details.tsx","webpack:///./src/img/ysp/icon-grass.svg","webpack:///./src/img/icons/map.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Dimensions/Dimensions.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Dimensions/Dimensions.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Landing/Landing.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Landing/Landing.tsx","webpack:///./src/img/ysp/icon-watercourse.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Location/Location.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/NoSolutions/NoSolutions.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/NoSolutions/NoSolutions.tsx","webpack:///./src/helpers/ysToYsp.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/Solutions.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/Solutions.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Boxes/Boxes.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Boxes/Boxes.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Support/SheetedSolution/SheetedSolution.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Support/System/System.tsx","webpack:///./src/img/ysp/icon-slope.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/AdjacentWater/AdjacentWater.tsx","webpack:///./src/img/ysp/surcharges/embankments.png","webpack:///./src/img/ysp/surcharges/building.png","webpack:///./src/img/ysp/surcharges/crane.png","webpack:///./src/img/ysp/surcharges/railway.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/LargeSurcharges/LargeSurcharges.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/SlopingGround/SlopingGround.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Type/Type.tsx","webpack:///./src/img/ysp/endsafe.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/EndSafePanels/EndSafePanels.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/EndSafeSides/EndSafeSides.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Modal/ConfirmModal.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilTypeDropdown/SoilTypeDropdown.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilProfiles.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilTypeDropdown/SoilTypeDropdown.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilVisualiser/SoilVisualiser.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilVisualiser/SoilVisualiser.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilProfiles.tsx","webpack:///./src/img/ysp/tick-unbound.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Dropdown/Dropdown.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilSource/SoilSource.styles.ts","webpack:///./src/img/ysp/warning-unbound.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Controls/Dropdown/Dropdown.tsx","webpack:///./src/img/icons/caret.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/SoilProfiles/SoilSource/SoilSource.tsx","webpack:///./src/img/ysp/icon-check-circle.svg","webpack:///./src/img/ysp/restart.svg","webpack:///./src/img/ysp/tick.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Graph/Graph.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Chart/Chart.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Chart/Chart.tsx","webpack:///./src/img/ysp/zoom.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Graph/Graph.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/ZoomImage/ZoomImage.styles.ts","webpack:///./src/img/ysp/zoom-out.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/ZoomImage/ZoomImage.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Solution/Solution.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Summary/Summary.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Solution/Solution.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/Summary/Summary.tsx","webpack:///./src/img/ysp/warning.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/YSPSolutions.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Solutions/YSP/YSPSolutions.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/SurchargeDetails/SurchargeDetails.styles.ts","webpack:///./src/img/ysp/edit.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/SurchargeDetails/SurchargesTable/SurchargesTable.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/SurchargeDetails/SurchargesTable/SurchargesTable.tsx","webpack:///./src/img/ysp/surcharges/road.svg","webpack:///./src/img/ysp/surcharges/building.svg","webpack:///./src/img/ysp/surcharges/crane.svg","webpack:///./src/img/ysp/surcharges/material.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/Surcharges/SurchargeDetails/SurchargeDetails.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/TermsAndConditions/TermsAndConditions.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Steps/TermsAndConditions/TermsAndConditions.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepRouter/dummy.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepRouter/StepRouter.tsx","webpack:///./src/img/ysp/ysp-bg.svg","webpack:///./src/img/icons/restart.svg","webpack:///./src/stories/Widgets/YourSolution/YS/YourSolution.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/BackToMainSite/BackToMainSite.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/BackToMainSite/BackToMainSite.tsx","webpack:///./src/img/ysp/home.svg","webpack:///./src/stories/Widgets/YourSolution/YS/Components/StepFooter/StepFooter.tsx","webpack:///./src/img/ysp/ys-strapline.png","webpack:///./src/img/ysp/ysp-header-logo-crop.png","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Tabs/Tabs.styles.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Tabs/Tabs.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/YourSolution.tsx","webpack:///./src/stories/Widgets/YourSolution/YS/YourSolutionRoot.widget.tsx","webpack:///./src/stories/Components/Misc/Loader/Loader.tsx","webpack:///./src/helpers/cloudinary.ts","webpack:///./src/stories/Widgets/YourSolution/YS/Components/Shared/Step.styles.ts","webpack:///./src/helpers/srOnly.ts"],"names":["WYSIWYGStyles","Wrapper","styled","div","HeadingStyles","H5Styles","brand","primary","alt","ParagraphStyles","RegularStyles","grey","grey35","grey96","from","Device","DesktopLarge","black","grey44","fonts","DaxPro","Bold","white","Box","figure","Tablet","invalid","css","BoxInner","red","base","active","light","BoxState","BoxMedia","BoxLabel","label","grey20","ButtonStyles","Regular","TabletLarge","until","grey40","Button","button","attrs","type","restart","prev","next","Question","m","section","initial","animate","exit","variants","hidden","opacity","visible","transition","duration","Avatar","BoxInfo","Materials","desktop","mobile","MaterialContainer","Material","MaterialMedia","large","MaterialLabel","MaterialTitle","Icon","CenterText","p","TitleWithInfoIcon","InfoIconStyles","Container","SharedStyles","useMedia","queries","values","defaultValue","isSSR","mediaQueryLists","map","query","window","matchMedia","getValue","index","findIndex","mql","matches","useState","value","setValue","useEffect","handler","forEach","addListener","removeListener","InfoIcon","whileTap","whileHover","tap","scale","hover","withMotionMax","WrappedComponent","displayName","name","ComponentWithMotionMax","props","React","createElement","LazyMotion","features","domMax","strict","H1Styles","H2Styles","H3Styles","H4Styles","DesktopSmall","H6Styles","Heading","h1","visual","MediaComponentStyles","$mobile","$desktop","MediaComponent","children","rest","LargeStyles","SmallStyles","Paragraph","isLatestNewsWidget","align","size","ButtonReset","_path","_extends","Object","assign","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","SvgChevronDown","xmlns","viewBox","d","fill","stroke","strokeLinecap","strokeLinejoin","strokeWidth","loadAnimation","keyframes","Loader","LoaderStyles","ContainerInner","SvgChevronRight","withMotion","ComponentWithMotion","domAnimation","BoldItalic","Medium","SlightlyLessThanMedium","RegularItalic","Light","SupportType","SolutionType","SolutionSubType","SoilType","StepID","SupportStepID","ConditionStepID","SurchargeStepID","DimensionsStepID","SoilGroundConditionsStepID","OptionalType","Tab","EndSafeSide","SoilInfoSource","YourSolutionProgression","id","step","Landing","title","Details","Location","Depth","Dimensions","System","SheetedSolution","optional","Type","ProblematicGround","GroundWater","GroundWaterDepth","Groundwater","LargeSurcharge","SlopingGround","AdjacentWater","Solutions","YourSolutionPlusProgression","TermsAndConditions","Size","EndSafePanels","EndSafeSides","EndSafe","SoilProfiles","SoilInformationSource","GroundwaterDepth","ZoneOfInfluence","Surcharges","SelectedSolution","getInitialState","initialState","cultureCode","technicalLibraryUrl","yourSolutionUrl","modal","undefined","steps","conditionStep","surchargeStep","supportStep","dimensionsStep","soilGroundConditionsStep","loading","labels","form","depth","width","subType","None","groundwaterDepth","soilDisclaimer","surchargeProfiles","errors","stepFooter","nextDisabled","tab","YourSolution","globalStep","progress","scrollLocked","soilProfiles","surcharges","loadingResults","formDirtyAfterSolutionsFetch","hasChangedSelectedSolution","zoomModalOpen","soilModalOpen","hasAddedDefaultSurcharge","fetchingNewSolutions","email","authenticatedUser","userName","telephone","companyName","phoneRegex","RegExp","emailRegex","postcodeRegex","determineStep","state","direction","currentStep","checkStep","groundwaterPresent","endSafePanelsRequired","largeSurcharges","filter","x","surchargePreselected","surcharge","push","supportType","Frame","newStep","Support","Conditions","SoilsGroundConditions","reducer","action","newState","keys","beforeNext","results","selectedSolutionName","selectedSolutionIterator","targetStep","payload","copy","foundSteps","indexOf","resetStepsIfNeeded","selectedSolution","stepsWithTitles","slice","YourSolutionPlus","responseAny","result","isEqual","field","invalidatedFields","match","confirmEmail","toLowerCase","schemeName","siteName","recaptchaToken","postCode","soilType","problematicGround","slopingGround","adjacentWater","sheetedSolutionType","yspResults","_g","YSContext","createContext","YSContextProvider","useReducer","dispatch","Provider","useYSPContext","contextValue","useContext","setFormField","SvgIconCross","isLandingPage","ButtonMotionWrapper","y","footerPrevious","footerNext","inverse","ButtonSmall","MobileButton","StepFooterStyles","h3","EngineerCheckStyles","SuccessText","EngineerCheck","comment","setComment","file","setFile","submitting","setSubmitting","success","setSuccess","handleSubmit","ApiService","request","controller","slug","method","isMultipartFormData","files","params","designRef","designReference","response","S","dangerouslySetInnerHTML","__html","Fragment","htmlFor","onChange","e","currentTarget","rows","accept","disabled","onClick","BoxModal","delay","small","BoxModalInner","fullWidth","BoxModalClose","BoxModalMedia","BoxModalCopy","ResetButton","ConfirmText","Buttons","divisionTags","sandhurst","ModalStyles","Modal","modalScrollable","ref","Close","imageUrl","src","style","objectFit","engineerCheckLabels","heading","content","description","display","StepHeaderStyles","Step","hideEnd","StepBackground","ease","dark","StepHeader","stepsWithTitle","useMemo","AnimatePresence","Items","BlurLine","SelectedStep","isOpen","height","overflow","ItemsInner","completed","grey89","StepPickerStyles","_path2","StepPicker","setIsOpen","filteredSteps","currentGlobalStep","current","handleWindowClick","addEventListener","removeEventListener","stopPropagation","preventDefault","Chevron","Text","FadeTextWrapper","TopText","LoadingStyles","Letter","animation","repeat","Infinity","colour","last","split","StepLoadingStyles","StepLoading","layout","Item","Value","MobileMedium","BottomEffect","Label","RadiosStyles","defaultOptions","error","options","AnimateSharedLayout","layoutId","Form","FormRow","wide","xCentered","FormControl","restrictWidth","center","FormError","FormErrorHidden","FormSub","span","FormSplit","FormStyles","SvgIconInfo","Info","GroundwaterStyles","Ground","Water","hasAnimatedIn","ripple","ExcavationOverlay","Arrow","SvgGroundwaterGround","strokeMiterlimit","SvgGroundwaterWater","setHasAnimatedIn","setTimeout","Radios","GroundwaterDepthStyles","Input","input","grey55","InlineNumericalInputStyles","EndSection","InlineNumericalInput","unit","min","max","lock","absoluteBounds","hasFocus","setHasFocus","onFocus","onBlur","toString","includes","Decimal","add","toNumber","sub","readOnly","Math","v","floatValue","parseFloat","backgroundImage","LooseGround","SoftClay","LooseSand","Peat","Silt","LooseGravel","SoilTypes","Granular","Cohesive","Road","DenseSand","Rock","CohesiveFill","StiffClay","DepthStyles","Indicator","Point","CheckboxStyles","Check","SvgIconCheck","ToggleStyles","ToggleWrapper","ToggleBall","Toggle","ColumnWrapper","WideColumnWrapper","HeaderWrapper","Header","bold","HeaderInner","SmallHeader","LargeHeader","FieldRow","FieldInput","bg","ysp","TopSection","Title","Disclaimer","ModalInner","ModalTitle","ModalText","BlankRows","Reset","LastRowWrapper","SoilInfoTableStyles","SvgCloseWhite","SvgResetThick","fillRule","YSButtonStyles","lighten","darken","accent","orange","LinkWrapper","a","SvgPlusThick","SvgIconCheckCircleFill","SvgIconPhone","SvgIconMail","YSButton","icon","hideOnDesktop","hideOnMobile","iconPosition","Plus","CheckCircle","Email","Phone","getIcon","YSLinkButton","href","NumberInputStyles","NumberInput","n","alignment","onKeyPress","event","charCode","SoilInfoTable","layers","update","setTargetedLayer","acceptedSoilModification","editSoilParameters","setEditSoilParameters","showEditModal","setShowEditModal","hasAccepted","setHasAccepted","determineClick","changeHandler","callback","toggleLocked","b","Checkbox","layer","bgl","soilDensity","saturatedDensity","angleOfFriction","wallFrictionFactor","soilCohesion","wallAdhesion","number","svgDepth","_svgDepth","transform","SvgIconAvatar","Textbox","placeholder","uniqueId","DetailsStyles","TechnicalLibraryLogin","FullWidth","setField","nextActive","setNextActive","recaptcha","setRecaptcha","handleNext","checkContinue","StepStyles","Grid","Containers","Default","User","encodeURI","marginTop","className","Recaptcha","shouldLoad","siteKey","token","DimensionsStyles","Grass","Outer","Inner","handleSet","isWidth","isNaN","ratio","actualHeight","actualWidth","toFixed","Intro","IntroTitleWrapper","TitleAndPlusWrapper","LandingStyles","PleaseSelectText","WelcomeText","CenteredDiv","tooltipText","centered","SvgMap","Map","NoSolutionsStyles","SwapToYSP","OrLabel","NoSolutions","responseMessage","telNo","emailAddress","SolutionsStyles","Copy","CopyInner","Media","MediaInner","solutions","url","tableData","media","srcSet","desktopImage","mobileImage","technicalMessage","BoxesStyles","singleQuestion","Boxes","boxes","activeBox","find","handleSetModalActive","SingleFrame","TwoFrame","SvgIconWatercourse","Watercourse","LargeSurcharges","hasTooltip","Embankments","Building","Crane","Railway","SvgIconSlope","Slope","TrenchBox","ManholeBox","Lightweight","SheetsAndManholeBrace","SheetsAndWalers","endSafeSides","One","Both","text","noText","yesText","onNo","onYes","onClose","DropdownWrapper","BorderWrapper","Dropdown","DropdownOption","SoilImage","background","SelectedOption","SoilTypeDropdownStyles","SoilProfilesStyles","TopStep","LayerOptions","LayerWrapper","LayerName","ButtonWrapper","DeleteWrapper","ResetAllWrapper","GridWrapper","offsetPadding","SoilTypeDropdown","expanded","setExpanded","useRef","useClickAway","option","SoilVisualiserStyles","SoilVisualiser","SoilLayer","minHeight","isLast","containerRef","excavationRef","soilLayersToDisplay","soilLayers","excavationHeight","lastPopulatedLayer","soilProfileOptions","reduce","acc","cur","image","getHeightForLayer","l","layerPercentage","getBoundingClientRect","soilTypeId","clientHeight","Layer","position","previousDepth","nextDepth","updatedValue","soilLayer","Cross","contentRef","targetedLayer","modalMode","setModalMode","modalOpen","setModalOpen","isOverflown","scrollHeight","modalLabels","yes","no","setLayers","mergedLayers","merged","modifyLayer","clone","matchingSoil","omit","layersClone","splice","pos","some","addLayer","checked","ConfirmModal","soilInfo","resetLayer","resetAll","DropdownStyles","short","SoilSourceStyles","Centered","SvgTickUnbound","SvgWarningUnbound","selectable","Tick","Warning","SoilSource","soilInfoSource","soilInfoSourceRef","soilInfoSourceCompany","Verbal","BoreholeLog","SvgCaret","SvgIconCheckCircle","SvgRestart","SvgTick","ActualDesktop","GraphWrapper","GraphContainer","Graph","ground","ProportionalContent","excavation","offset","GraphStyles","LeftContent","RightContent","BGLLabel","side","SoilContainer","top","GroundwaterLevel","ChartStyles","ChartJS","register","LinearScale","PointElement","LineElement","Chart","chart","chartData","Scatter","responsive","padding","left","scales","data","datasets","showLine","pointStyle","borderColor","colorHex","borderWidth","contentOffset","solution","graphs","boxHeading","toDecimalPlaces","graphic","ZoomIcon","ZoomImageStyles","Image","img","ModalBackground","ModalContent","ZoomedImage","ControlsBar","Control","SvgZoom","SvgZoomOut","zoomRef","Zoom","TransformWrapper","centerOnInit","TransformComponent","zoomIn","zoomOut","ZoomOut","resetTransform","selected","LeftSection","RightSection","Description","SolutionTag","LongSmallButton","Scrollbars","TableContainer","Column","isPassFailColumn","HeaderSection","grey75","Cell","SolutionStyles","PassFail","pass","TableHeader","StrutsTableWrapper","Blank","FailText","FailBoxWrapper","FailTopRow","FailNumber","FailDescription","MobileImage","DescriptionAndTable","TopContent","BackButton","ButtonContainer","RestartButton","Solution","DesignReference","Table","Row","MobileSolutionTag","SummaryStyles","TableContainers","TableWrapper","GraphsWrapper","Wide","ImageWrapper","MomentsTable","moments","moment","allowable","actual","StrutsTable","struts","strut","level","loadAllow","loadActual","useInView","threshold","inView","isSelected","ZoomImage","boxInfo","info","item1","item2","Summary","setLoading","sendToEngineer","replaceAll","Caret","confirm","Restart","designDoc","horizontalPressure","shearForce","kickingMoments","YSPSolutionsStyles","NoSolutionsTitle","NoSolutionsSubtitle","NoSolutionsGetInTouch","NoSolutionsDetails","SvgWarning","setSelectedSolution","matchingSolution","document","querySelector","scrollIntoView","behavior","dropdownOptions","s","territoryManager","noSolutionHeading","noSolutionText","contactText","DimensionsWrapper","SurchargesWrapper","IconContainer","IconWrapper","SurchargeWrapper","SurchargeName","getIconAnimation","SurchargeIcon","Rail","BaseHidden","BaseVisible","SurchargeDetailsStyles","MotionWrapper","SvgEdit","DescriptionWrapper","lightBackground","VariableHeader","isNull","FieldBase","SurchargesTableStyles","SurchargesTable","typeOptions","SurchargeType","Number","t","k","Blanket","Strip","Area","Line","Trap","Edit","surchargeDescription","surchargeType","surchargeMagnitude","surchargeDepth","surchargeOffset","surchargeWidth","surchargeLength","surchargeMagnitudeB","_style","SvgBuilding","shapeRendering","textRendering","_g2","_g3","SvgCrane","SvgMaterial","offsetPath","offsetRotate","SurchargeSource","Surcharge","removeSurcharge","dropdownPlaceholder","iconSrc","Plant","surchargeIcon","CraneAnimated","BuildingAnimated","MaterialAnimated","preselectedSurcharges","setSurcharges","surchargeOptions","valIndex","retypedClone","matchingSurchargeType","surchargesClone","TermsAndConditionsStyles","TextContainer","textboxRef","attachedListener","setAttachedListener","hasScrolledToBottom","setHasScrolledToBottom","debouncedTrackScroll","debounce","el","inRange","scrollTop","trackScrollHandler","ev","acceptedTs","Thin","dummyData","surchargeSource","getYSPStep","StepRouter","initialLoad","setInitialLoad","culture","soilRequest","status","surchargeRequest","questionnaireID","firstReason","message","successful","returnNoResults","fetchStep","submit","selectSolution","exitBeforeEnter","SurchargeDetails","Loading","YSPSolutions","getComponent","MainHeaderContentWrapper","YourSolutionStyles","ModalHeader","Content","locked","BackgroundImage","BackgroundImageSVG","MobileHeader","BackToMainSiteStyles","Return","BackToMainSite","closeModal","history","back","SvgHome","StepFooter","nextStep","isLoadingSolutions","isNotOnYSSolutions","hasYSPSolutions","Home","BottomLine","TabsStyles","BackgroundEffect","TabEnum","BackToMainSiteMobile","Tabs","YSLogoNoText","YSPLogo","YSLogo","stateRef","scrollableArea","modalKey","JSON","stringify","isMobile","URLSearchParams","location","search","get","bodyElement","existingStyleAttribute","getAttribute","setAttribute","replace","handleUnload","controllerName","stepId","lastStep","useLayoutEffect","disableBodyScroll","enableBodyScroll","withWidget","hydrate","HydrateOption","Always","showLoader","setShowLoader","handle","clearTimeout","container","cl","Cloudinary","cloud","cloudName","secure","publicId","rawTransformation","transformation","addTransformation","FormatRegEx","test","toURL","delivery","format","fAuto","quality","qAuto","MotionBase","srOnly"],"mappings":"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","file":"default~SiteHeader~YourSolutionRoot-12921cdceba4c59201f8.js","sourcesContent":["import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport HeadingStyles from '@stories/Components/Global/Typography/Heading.styles';\r\nimport ParagraphStyles from '@stories/Components/Global/Typography/Paragraph.styles';\r\nimport styled from 'styled-components';\r\nconst Wrapper = styled.div `\r\n // Needed for the horizontal scroll table\r\n overflow: auto;\r\n line-height: normal;\r\n\r\n h1,\r\n h2 {\r\n ${HeadingStyles.H5Styles};\r\n color: ${brand.primary.alt};\r\n }\r\n\r\n p {\r\n ${ParagraphStyles.RegularStyles};\r\n }\r\n\r\n a {\r\n color: ${brand.primary.alt};\r\n }\r\n\r\n table {\r\n table-layout: fixed;\r\n min-width: 700px;\r\n width: 100%;\r\n\r\n thead {\r\n tr {\r\n background: ${brand.grey.grey35};\r\n }\r\n }\r\n\r\n tbody {\r\n tr {\r\n background-color: ${brand.grey.grey96};\r\n\r\n &:nth-child(odd) {\r\n background-color: rgba(102, 153, 0, 0.12);\r\n }\r\n }\r\n }\r\n\r\n th,\r\n td {\r\n padding: 12px 20px;\r\n width: 216px;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n padding: 12px 34px;\r\n }\r\n }\r\n\r\n td {\r\n color: ${brand.black};\r\n\r\n border-right: 1px solid ${brand.grey.grey44};\r\n &:last-child {\r\n border-right: none;\r\n }\r\n }\r\n\r\n th {\r\n ${fonts.DaxPro.Bold};\r\n color: ${brand.white};\r\n font-size: 20px;\r\n }\r\n }\r\n\r\n &[data-hidden=\"true\"]{\r\n display: none;\r\n }\r\n`;\r\nexport const WYSIWYGStyles = {\r\n Wrapper,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { InfoIconStyles } from './InfoIcon/InfoIcon.styles';\r\nconst Box = styled.figure `\r\n flex: 0 0 auto;\r\n padding: 8px 8px 8px 40px;\r\n position: relative;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 8px 8px 60px 8px;\r\n width: 33%;\r\n }\r\n\r\n ${({ invalid }) => invalid &&\r\n css `\r\n ${() => BoxInner} {\r\n border: 1px solid ${brand.red.base};\r\n }\r\n `}\r\n\r\n ${({ active }) => active &&\r\n css `\r\n ${() => BoxInner} {\r\n border: 1px solid ${brand.primary.light};\r\n border-bottom: 7px solid ${brand.primary.light};\r\n }\r\n\r\n ${() => BoxState}:before {\r\n content: '';\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n width: 14px;\r\n height: 14px;\r\n border-radius: 50%;\r\n transform: translate(-50%, -50%);\r\n background-color: ${brand.primary.light};\r\n\r\n @media ${from(Device.Tablet)} {\r\n width: 20px;\r\n height: 20px;\r\n }\r\n }\r\n `}\r\n`;\r\nconst BoxInner = styled.div `\r\n border: 1px solid #d5d5d5;\r\n padding: 20px 12px;\r\n cursor: pointer;\r\n display: flex;\r\n flex-direction: row;\r\n flex-wrap: nowrap;\r\n align-items: center;\r\n height: 100%;\r\n\r\n @media ${from(Device.Tablet)} {\r\n flex-direction: column;\r\n padding: 12px;\r\n }\r\n`;\r\nconst BoxMedia = styled.div `\r\n position: relative;\r\n flex: 0 0 auto;\r\n max-width: 40%;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin-bottom: 16px;\r\n max-width: 100%;\r\n }\r\n\r\n img {\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n font-family: 'object-fit: cover';\r\n }\r\n`;\r\nconst BoxLabel = styled.label `\r\n text-align: center;\r\n font-weight: normal;\r\n font-size: 17px;\r\n display: block;\r\n flex: 1 1 auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n flex: 1 0 auto;\r\n margin-bottom: 50px;\r\n }\r\n`;\r\nconst BoxState = styled.div `\r\n width: 24px;\r\n height: 24px;\r\n border: 1px solid ${brand.grey.grey20};\r\n border-radius: 50%;\r\n position: relative;\r\n flex: 0 0 auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin: 0 auto 20px auto;\r\n width: 30px;\r\n height: 30px;\r\n }\r\n`;\r\nconst ButtonStyles = css `\r\n outline: none;\r\n border: none;\r\n padding: 8px 28px 8px 28px;\r\n background-color: ${brand.primary.light};\r\n display: inline-block;\r\n font-size: 20px;\r\n color: ${brand.white};\r\n ${fonts.DaxPro.Regular};\r\n border-radius: 8px;\r\n position: relative;\r\n cursor: pointer;\r\n user-select: none;\r\n transition: background-color 0.25s ease-in-out;\r\n z-index: 10;\r\n\r\n &:hover {\r\n color: ${brand.white};\r\n background-color: ${brand.primary.light};\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 22px;\r\n }\r\n\r\n &:disabled {\r\n @media ${until(Device.TabletLarge)} {\r\n opacity: 0.4;\r\n }\r\n @media ${from(Device.TabletLarge)} {\r\n background-color: ${brand.grey.grey40};\r\n }\r\n cursor: not-allowed;\r\n }\r\n`;\r\nconst Button = styled.button.attrs(() => ({\r\n type: 'button',\r\n})) `\r\n ${ButtonStyles}\r\n\r\n ${({ restart }) => restart &&\r\n css `\r\n padding: 8px 50px 8px 28px;\r\n\r\n svg {\r\n position: absolute;\r\n right: 16px;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n width: 19px;\r\n height: 19px;\r\n fill: ${brand.white};\r\n stroke: ${brand.white};\r\n }\r\n `};\r\n\r\n ${({ prev }) => prev &&\r\n css `\r\n padding: 8px 28px 8px 50px;\r\n\r\n svg {\r\n position: absolute;\r\n left: 16px;\r\n top: 50%;\r\n transform: translateY(-50%) rotate(180deg);\r\n width: 25px;\r\n height: 20px;\r\n }\r\n `}\r\n\r\n ${({ next }) => next &&\r\n css `\r\n padding: 8px 50px 8px 28px;\r\n\r\n svg {\r\n position: absolute;\r\n right: 16px;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n width: 25px;\r\n height: 20px;\r\n }\r\n `}\r\n`;\r\nexport const WYSIWYGStyles = css `\r\n // Need to do h3 because thats what HTML comes out of api..\r\n h2,\r\n h3 {\r\n font-size: 25px;\r\n text-align: center;\r\n color: ${brand.grey.grey20};\r\n ${fonts.DaxPro.Bold};\r\n margin: 0 0 20px 0;\r\n line-height: 1.1;\r\n margin-bottom: 20px;\r\n }\r\n\r\n ol,\r\n ul {\r\n list-style: inside;\r\n }\r\n\r\n a {\r\n color: ${brand.primary.light};\r\n text-decoration: underline;\r\n }\r\n\r\n strong {\r\n ${fonts.DaxPro.Bold};\r\n }\r\n\r\n p {\r\n font-size: 17px;\r\n margin-bottom: 0px;\r\n color: #333333;\r\n }\r\n`;\r\nconst Question = styled(m.section).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n },\r\n visible: {\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.35,\r\n },\r\n})) `\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: flex-start;\r\n align-items: center;\r\n min-height: 100%;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n margin-right: 15px;\r\n }\r\n\r\n ${WYSIWYGStyles};\r\n`;\r\nconst Avatar = styled.div `\r\n svg {\r\n fill: ${brand.primary.light};\r\n width: 60px;\r\n height: 60px;\r\n display: block;\r\n align-self: center;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n width: 45px;\r\n height: 45px;\r\n }\r\n }\r\n`;\r\nconst BoxInfo = styled.div `\r\n position: absolute;\r\n left: 15px;\r\n bottom: 50%;\r\n transform: translate(-50%, 50%);\r\n\r\n @media ${from(Device.Tablet)} {\r\n left: 50%;\r\n bottom: 30px;\r\n }\r\n`;\r\nconst Materials = styled.div `\r\n width: 100%;\r\n display: flex;\r\n flex-direction: column;\r\n margin-bottom: 30px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n border-top: 1px solid ${brand.grey.grey44};\r\n padding-top: 25px;\r\n margin-top: 20px;\r\n }\r\n\r\n ${({ desktop }) => desktop &&\r\n css `\r\n @media ${until(Device.Tablet)} {\r\n display: none;\r\n }\r\n `}\r\n\r\n ${({ mobile }) => mobile &&\r\n css `\r\n display: flex;\r\n @media ${from(Device.Tablet)} {\r\n display: none;\r\n }\r\n `}\r\n\r\n\r\n @media ${from(Device.Tablet)} {\r\n flex-direction: row;\r\n flex-wrap: wrap;\r\n justify-content: space-between;\r\n }\r\n`;\r\nconst MaterialContainer = styled.div `\r\n ${() => Material} {\r\n width: 100%;\r\n }\r\n`;\r\nconst Material = styled.div `\r\n display: flex;\r\n flex-direction: row;\r\n flex-wrap: nowrap;\r\n align-items: center;\r\n margin-bottom: 12px;\r\n\r\n @media ${from(Device.Tablet)} {\r\n width: 45%;\r\n }\r\n`;\r\nconst MaterialMedia = styled.div `\r\n width: 32px;\r\n height: 32px;\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: 50% 50%;\r\n margin-right: 17px;\r\n flex: 0 0 32px;\r\n\r\n ${({ large }) => large &&\r\n css `\r\n width: 80px;\r\n height: auto;\r\n flex: 0 0 auto;\r\n `}\r\n`;\r\nconst MaterialLabel = styled.div `\r\n font-size: 15px;\r\n`;\r\nconst MaterialTitle = styled.div `\r\n font-size: 15px;\r\n color: ${brand.black};\r\n font-weight: 700;\r\n padding-bottom: 10px;\r\n`;\r\nconst Icon = styled.div `\r\n width: 300px;\r\n margin-bottom: 25px;\r\n\r\n svg {\r\n width: 100%;\r\n }\r\n`;\r\nconst CenterText = styled.p `\r\n text-align: center;\r\n`;\r\nconst TitleWithInfoIcon = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n margin-bottom: 15px;\r\n align-items: center;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n margin-bottom: 25px;\r\n ${() => InfoIconStyles.Container} {\r\n margin-bottom: 15px;\r\n }\r\n }\r\n\r\n h2 {\r\n margin-bottom: 0 !important;\r\n }\r\n`;\r\nexport const SharedStyles = {\r\n Box,\r\n BoxInner,\r\n BoxMedia,\r\n BoxLabel,\r\n BoxState,\r\n Button,\r\n Question,\r\n Avatar,\r\n BoxInfo,\r\n Materials,\r\n Material,\r\n MaterialMedia,\r\n MaterialLabel,\r\n MaterialContainer,\r\n MaterialTitle,\r\n Icon,\r\n CenterText,\r\n TitleWithInfoIcon,\r\n};\r\n","import { isSSR } from '@helpers/ssr';\r\nimport { useEffect, useState } from 'react';\r\n/**\r\n * Store a value in state based on the specified media queries.\r\n * @param {Array} queries\r\n * @param {Array} values\r\n * @param {T} defaultValue\r\n */\r\nfunction useMedia(queries, values, defaultValue) {\r\n // Avoid error with SSR.\r\n if (isSSR()) {\r\n return defaultValue;\r\n }\r\n // Array containing a media query list for each query\r\n const mediaQueryLists = queries.map((query) => window.matchMedia(query));\r\n // Function that gets value based on matching media query\r\n const getValue = () => {\r\n // Get index of first media query that matches\r\n const index = mediaQueryLists.findIndex((mql) => mql.matches);\r\n // Return related value or defaultValue if none\r\n return typeof values[index] !== 'undefined' ? values[index] : defaultValue;\r\n };\r\n // State and setter for matched value\r\n const [value, setValue] = useState(getValue);\r\n useEffect(() => {\r\n // Event listener callback\r\n // Note: By defining getValue outside of useEffect we ensure that it has ...\r\n // ... current values of hook args (as this hook callback is created once on mount).\r\n const handler = () => setValue(getValue);\r\n // Set a listener for each media query with above handler as callback.\r\n mediaQueryLists.forEach((mql) => mql.addListener(handler));\r\n // Remove listeners on cleanup\r\n return () => mediaQueryLists.forEach((mql) => mql.removeListener(handler));\r\n }, []); // Empty array ensures effect is only run on mount and unmount\r\n return value;\r\n}\r\nexport default useMedia;\r\n","import brand from '@helpers/brand';\r\nimport { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div ``;\r\nconst InfoIcon = styled(m.div).attrs(() => ({\r\n whileTap: 'tap',\r\n whileHover: 'hover',\r\n variants: {\r\n tap: {\r\n scale: 0.95,\r\n },\r\n hover: {\r\n scale: 1.05,\r\n },\r\n },\r\n transition: {\r\n duration: 0.25,\r\n },\r\n})) `\r\n position: relative;\r\n width: 25px;\r\n height: 25px;\r\n cursor: pointer;\r\n color: ${brand.grey.grey35};\r\n\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n`;\r\nexport const InfoIconStyles = {\r\n Container,\r\n InfoIcon,\r\n};\r\n","import { domMax, LazyMotion } from 'framer-motion';\r\nimport React from 'react';\r\nexport function withMotionMax(WrappedComponent) {\r\n const displayName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\r\n const ComponentWithMotionMax = (props) => {\r\n return (React.createElement(LazyMotion, { features: domMax, strict: true },\r\n React.createElement(WrappedComponent, { ...props })));\r\n };\r\n ComponentWithMotionMax.displayName = `withMotionMax(${displayName})`;\r\n return ComponentWithMotionMax;\r\n}\r\n","import { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nconst H1Styles = css `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 45px;\r\n letter-spacing: 0.02em;\r\n line-height: 48px;\r\n margin-bottom: 16px;\r\n text-transform: uppercase;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n font-size: 70px;\r\n line-height: 70px;\r\n }\r\n`;\r\nconst H2Styles = css `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 38px;\r\n letter-spacing: 0.02em;\r\n line-height: 40px;\r\n margin-bottom: 16px;\r\n text-transform: uppercase;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n font-size: 60px;\r\n line-height: 60px;\r\n }\r\n`;\r\nconst H3Styles = css `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 35px;\r\n letter-spacing: 0.02em;\r\n line-height: 42px;\r\n margin-bottom: 16px;\r\n text-transform: uppercase;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n font-size: 50px;\r\n line-height: 60px;\r\n }\r\n`;\r\nconst H4Styles = css `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 22px;\r\n letter-spacing: 0.02em;\r\n line-height: 24px;\r\n margin-bottom: 16px;\r\n text-transform: uppercase;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n font-size: 40px;\r\n line-height: 40px;\r\n }\r\n`;\r\nconst H5Styles = css `\r\n ${fonts.DaxPro.Regular};\r\n font-size: 24px;\r\n margin-bottom: 12px;\r\n line-height: 22px;\r\n\r\n @media ${from(Device.DesktopSmall)} {\r\n font-size: 35px;\r\n line-height: 38px;\r\n margin-bottom: 16px;\r\n }\r\n`;\r\nconst H6Styles = css `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 16px;\r\n letter-spacing: 0.02em;\r\n line-height: 20px;\r\n margin-bottom: 16px;\r\n text-transform: uppercase;\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n font-size: 20px;\r\n line-height: 28px;\r\n }\r\n`;\r\nconst Heading = styled.h1 `\r\n ${({ visual }) => {\r\n switch (visual) {\r\n case 'h1':\r\n return H1Styles;\r\n case 'h2':\r\n return H2Styles;\r\n case 'h3':\r\n return H3Styles;\r\n case 'h4':\r\n return H4Styles;\r\n case 'h5':\r\n return H5Styles;\r\n case 'h6':\r\n return H6Styles;\r\n default:\r\n break;\r\n }\r\n}}\r\n`;\r\nexport default {\r\n // H1Styles,\r\n // H2Styles,\r\n H3Styles,\r\n H4Styles,\r\n H5Styles,\r\n // H6Styles,\r\n Heading,\r\n};\r\n","import React from \"react\";\r\nimport styled, { css } from \"styled-components\";\r\nimport { Device, from, until } from \"./media\";\r\nconst MediaComponentStyles = styled.div `\r\n display: contents;\r\n\r\n ${({ $mobile: mobile }) => mobile &&\r\n css `\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n `}\r\n\r\n ${({ $desktop: desktop }) => desktop &&\r\n css `\r\n @media ${until(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n `}\r\n`;\r\nexport const MediaComponent = ({ children, ...rest }) => {\r\n return (React.createElement(MediaComponentStyles, { \"$desktop\": rest.desktop, \"$mobile\": rest.mobile }, children));\r\n};\r\n","import { fonts } from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\n/**\r\n * 20px / 28px\r\n */\r\nexport const LargeStyles = css `\r\n ${fonts.DaxPro.Regular};\r\n font-size: 20px;\r\n letter-spacing: normal;\r\n line-height: 28px;\r\n margin-bottom: 16px;\r\n`;\r\n/**\r\n * 18px / 28px\r\n */\r\nexport const RegularStyles = css `\r\n ${fonts.DaxPro.Regular};\r\n font-size: 18px;\r\n letter-spacing: normal;\r\n line-height: 28px;\r\n margin-bottom: 16px;\r\n`;\r\n/**\r\n * 16px / 26px\r\n */\r\nexport const SmallStyles = css `\r\n ${fonts.DaxPro.Regular};\r\n font-size: 16px;\r\n letter-spacing: normal;\r\n line-height: 26px;\r\n margin-bottom: 16px;\r\n`;\r\nconst Paragraph = styled.p `\r\n ${({ isLatestNewsWidget }) => isLatestNewsWidget\r\n ? css `\r\n min-height: 104px;\r\n `\r\n : null}\r\n \r\n ${({ align }) => align\r\n ? css `\r\n text-align: ${align};\r\n `\r\n : null}\r\n\r\n ${({ size }) => {\r\n switch (size) {\r\n case 'large':\r\n return LargeStyles;\r\n case 'regular':\r\n return RegularStyles;\r\n case 'small':\r\n return SmallStyles;\r\n default:\r\n break;\r\n }\r\n}}\r\n`;\r\nexport default {\r\n Paragraph,\r\n SmallStyles,\r\n RegularStyles,\r\n LargeStyles,\r\n};\r\n","export default __webpack_public_path__ + \"20d3e6ef96e5a405f30429d6d92b83e2.png\";","import { css } from 'styled-components';\r\nexport default {\r\n navHeight: 107,\r\n navHeightTablet: 80,\r\n navHeightMobile: 59,\r\n};\r\nexport const ButtonReset = css `\r\n border: none;\r\n outline: none;\r\n padding: 0px;\r\n background: none;\r\n border-radius: 0px;\r\n`;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgChevronDown(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 13.953 7.977\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 460\",\n d: \"M12.539 1.415L6.977 6.977 1.415 1.415\",\n fill: \"none\",\n stroke: \"currentcolor\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n strokeWidth: 2\n })));\n}\n\nexport default __webpack_public_path__ + \"ab65ba123437ec9096ced875de645192.svg\";\nexport { SvgChevronDown as ReactComponent };","import brand from '@helpers/brand';\r\nimport { from, Device } from '@helpers/media';\r\nimport styled, { keyframes } from 'styled-components';\r\nconst width = 10;\r\nconst size = 70;\r\nconst loadAnimation = keyframes `\r\n 0% {\r\n -webkit-transform: rotate(0deg);\r\n transform: rotate(0deg);\r\n }\r\n 100% {\r\n -webkit-transform: rotate(360deg);\r\n transform: rotate(360deg);\r\n }\r\n`;\r\nconst Loader = styled.div `\r\n margin: 60px auto;\r\n font-size: 10px;\r\n position: relative;\r\n text-indent: -9999em;\r\n border-top: ${width}px solid rgba(0, 0, 0, 0.1);\r\n border-right: ${width}px solid rgba(0, 0, 0, 0.1);\r\n border-bottom: ${width}px solid rgba(0, 0, 0, 0.1);\r\n border-left: ${width}px solid ${brand.grey['grey20']};\r\n transform: translateZ(0);\r\n animation: ${loadAnimation} 1.1s infinite linear;\r\n border-radius: 50%;\r\n width: ${size}px;\r\n height: ${size}px;\r\n\r\n &:after {\r\n content: '';\r\n border-radius: 50%;\r\n width: ${size}px;\r\n height: ${size}px;\r\n }\r\n`;\r\nconst Wrapper = styled.div ``;\r\nconst Container = styled.section `\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n align-items: center;\r\n background: rgba(0, 0, 0, 0.4);\r\n height: 100vh;\r\n justify-content: center;\r\n text-align: center;\r\n width: 100%;\r\n /* Higher index than header container */\r\n z-index: 8002;\r\n display: flex;\r\n`;\r\nconst ContainerInner = styled.div `\r\n position: relative;\r\n display: block;\r\n background: #fff;\r\n border: 1px solid #b9b9b9;\r\n max-height: 100%;\r\n max-width: 665px;\r\n overflow-y: auto;\r\n padding: 24px 16px 24px;\r\n width: 100%;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 32px 108px 48px;\r\n }\r\n`;\r\nexport const LoaderStyles = {\r\n Wrapper,\r\n Loader,\r\n Container,\r\n ContainerInner,\r\n};\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgChevronRight(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 7.257 11.686\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 48\",\n d: \"M.707.707l5.136 5.136-5.136 5.136\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 2\n })));\n}\n\nexport default __webpack_public_path__ + \"6973e4a6f707c58d2376f688ccfb4a95.svg\";\nexport { SvgChevronRight as ReactComponent };","import { domAnimation, LazyMotion } from 'framer-motion';\r\nimport React from 'react';\r\nexport function withMotion(WrappedComponent) {\r\n const displayName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\r\n const ComponentWithMotion = (props) => {\r\n return (React.createElement(LazyMotion, { features: domAnimation, strict: true },\r\n React.createElement(WrappedComponent, { ...props })));\r\n };\r\n ComponentWithMotion.displayName = `withMotion(${displayName})`;\r\n return ComponentWithMotion;\r\n}\r\n","import { css } from 'styled-components';\r\nexport const fonts = {\r\n DaxPro: {\r\n Bold: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: normal;\r\n font-weight: 700;\r\n `,\r\n BoldItalic: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: italic;\r\n font-weight: 700;\r\n `,\r\n Medium: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: normal;\r\n font-weight: 600;\r\n `,\r\n SlightlyLessThanMedium: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: normal;\r\n font-weight: 500;\r\n `,\r\n Regular: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: normal;\r\n font-weight: 400;\r\n `,\r\n RegularItalic: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: italic;\r\n font-weight: 400;\r\n `,\r\n Light: css `\r\n font-family: 'ff-dax-pro', Arial, sans-serif;\r\n font-style: normal;\r\n font-weight: 200;\r\n `,\r\n },\r\n};\r\n","export var SupportType;\r\n(function (SupportType) {\r\n SupportType[\"Box\"] = \"BOX\";\r\n SupportType[\"Frame\"] = \"FRAME\";\r\n})(SupportType || (SupportType = {}));\r\nexport var SolutionType;\r\n(function (SolutionType) {\r\n SolutionType[\"SheetsAndManholeBrace\"] = \"B\";\r\n SolutionType[\"SheetsAndWalers\"] = \"W\";\r\n SolutionType[\"ManholeBox\"] = \"MB\";\r\n SolutionType[\"TrenchBox\"] = \"TB\";\r\n SolutionType[\"Lightweight\"] = \"LW\";\r\n})(SolutionType || (SolutionType = {}));\r\nexport var SolutionSubType;\r\n(function (SolutionSubType) {\r\n SolutionSubType[\"None\"] = \"\";\r\n SolutionSubType[\"SingleFrame\"] = \"1F\";\r\n SolutionSubType[\"TwoFrame\"] = \"2F\";\r\n SolutionSubType[\"BackhoeManholeBox\"] = \"BH\";\r\n SolutionSubType[\"BackHoeManholeBoxAndTop\"] = \"BH\";\r\n SolutionSubType[\"MultiManholeBox\"] = \"MB\";\r\n SolutionSubType[\"MultiManholeBoxAndTop\"] = \"MB\";\r\n SolutionSubType[\"BackhoeTrenchBox\"] = \"BH\";\r\n SolutionSubType[\"BackhoeTrenchBoxAndTop\"] = \"BH\";\r\n SolutionSubType[\"MiniTrenchBox\"] = \"MI\";\r\n SolutionSubType[\"MiniTrenchBoxAndTop\"] = \"MI\";\r\n SolutionSubType[\"StandardTrenchBox\"] = \"SD\";\r\n SolutionSubType[\"StandardTrenchBoxAndTop\"] = \"SD\";\r\n SolutionSubType[\"PremierTrenchBox\"] = \"PR\";\r\n SolutionSubType[\"RollingStrutTrenchBox\"] = \"PS\";\r\n SolutionSubType[\"MapBox\"] = \"MAP\";\r\n SolutionSubType[\"QuickAccessBox\"] = \"QAB\";\r\n})(SolutionSubType || (SolutionSubType = {}));\r\nexport var SoilType;\r\n(function (SoilType) {\r\n SoilType[\"Cohesive\"] = \"CO\";\r\n SoilType[\"Granular\"] = \"GR\";\r\n})(SoilType || (SoilType = {}));\r\nexport var StepID;\r\n(function (StepID) {\r\n StepID[StepID[\"Landing\"] = 0] = \"Landing\";\r\n StepID[StepID[\"Details\"] = 1] = \"Details\";\r\n StepID[StepID[\"Location\"] = 2] = \"Location\";\r\n StepID[StepID[\"Depth\"] = 3] = \"Depth\";\r\n StepID[StepID[\"Dimensions\"] = 4] = \"Dimensions\";\r\n StepID[StepID[\"Support\"] = 5] = \"Support\";\r\n StepID[StepID[\"Type\"] = 6] = \"Type\";\r\n StepID[StepID[\"Conditions\"] = 7] = \"Conditions\";\r\n StepID[StepID[\"Surcharges\"] = 8] = \"Surcharges\";\r\n StepID[StepID[\"Solutions\"] = 9] = \"Solutions\";\r\n StepID[StepID[\"TermsAndConditions\"] = 10] = \"TermsAndConditions\";\r\n StepID[StepID[\"SoilsGroundConditions\"] = 11] = \"SoilsGroundConditions\";\r\n StepID[StepID[\"SelectedSolution\"] = 12] = \"SelectedSolution\";\r\n})(StepID || (StepID = {}));\r\nexport var SupportStepID;\r\n(function (SupportStepID) {\r\n SupportStepID[SupportStepID[\"System\"] = 0] = \"System\";\r\n SupportStepID[SupportStepID[\"SheetedSolution\"] = 1] = \"SheetedSolution\";\r\n})(SupportStepID || (SupportStepID = {}));\r\nexport var ConditionStepID;\r\n(function (ConditionStepID) {\r\n ConditionStepID[ConditionStepID[\"ProblematicGround\"] = 0] = \"ProblematicGround\";\r\n ConditionStepID[ConditionStepID[\"SoilType\"] = 1] = \"SoilType\";\r\n ConditionStepID[ConditionStepID[\"GroundWater\"] = 2] = \"GroundWater\";\r\n ConditionStepID[ConditionStepID[\"GroundWaterDepth\"] = 3] = \"GroundWaterDepth\";\r\n})(ConditionStepID || (ConditionStepID = {}));\r\nexport var SurchargeStepID;\r\n(function (SurchargeStepID) {\r\n SurchargeStepID[SurchargeStepID[\"LargeSurcharge\"] = 0] = \"LargeSurcharge\";\r\n SurchargeStepID[SurchargeStepID[\"SlopingGround\"] = 1] = \"SlopingGround\";\r\n SurchargeStepID[SurchargeStepID[\"AdjacentWater\"] = 2] = \"AdjacentWater\";\r\n SurchargeStepID[SurchargeStepID[\"ZoneOfInfluence\"] = 3] = \"ZoneOfInfluence\";\r\n})(SurchargeStepID || (SurchargeStepID = {}));\r\nexport var DimensionsStepID;\r\n(function (DimensionsStepID) {\r\n DimensionsStepID[DimensionsStepID[\"Size\"] = 0] = \"Size\";\r\n DimensionsStepID[DimensionsStepID[\"Type\"] = 1] = \"Type\";\r\n DimensionsStepID[DimensionsStepID[\"EndSafePanels\"] = 2] = \"EndSafePanels\";\r\n DimensionsStepID[DimensionsStepID[\"EndSafeSides\"] = 3] = \"EndSafeSides\";\r\n})(DimensionsStepID || (DimensionsStepID = {}));\r\nexport var SoilGroundConditionsStepID;\r\n(function (SoilGroundConditionsStepID) {\r\n SoilGroundConditionsStepID[SoilGroundConditionsStepID[\"SoilProfiles\"] = 0] = \"SoilProfiles\";\r\n SoilGroundConditionsStepID[SoilGroundConditionsStepID[\"SoilInformationSource\"] = 1] = \"SoilInformationSource\";\r\n SoilGroundConditionsStepID[SoilGroundConditionsStepID[\"Groundwater\"] = 2] = \"Groundwater\";\r\n SoilGroundConditionsStepID[SoilGroundConditionsStepID[\"GroundwaterDepth\"] = 3] = \"GroundwaterDepth\";\r\n})(SoilGroundConditionsStepID || (SoilGroundConditionsStepID = {}));\r\nexport var OptionalType;\r\n(function (OptionalType) {\r\n OptionalType[OptionalType[\"Groundwater\"] = 0] = \"Groundwater\";\r\n OptionalType[OptionalType[\"EndSafe\"] = 1] = \"EndSafe\";\r\n OptionalType[OptionalType[\"Surcharges\"] = 2] = \"Surcharges\";\r\n OptionalType[OptionalType[\"SheetedSolution\"] = 3] = \"SheetedSolution\";\r\n})(OptionalType || (OptionalType = {}));\r\nexport const YourSolutionProgression = [\r\n { id: 0, type: 'default', step: StepID.Landing, title: 'Home' },\r\n { id: 1, type: 'default', step: StepID.Details, title: 'Your Details' },\r\n { id: 2, type: 'default', step: StepID.Location, title: 'Location' },\r\n { id: 3, type: 'default', step: StepID.Depth, title: 'Depth' },\r\n { id: 4, type: 'default', step: StepID.Dimensions, title: 'Plan Dimensions' },\r\n { id: 5, type: 'support', step: SupportStepID.System, title: 'Support System' },\r\n {\r\n id: 6,\r\n type: 'support',\r\n step: SupportStepID.SheetedSolution,\r\n optional: OptionalType.SheetedSolution,\r\n },\r\n { id: 7, type: 'default', step: StepID.Type, title: 'Product Type' },\r\n {\r\n id: 8,\r\n type: 'conditions',\r\n step: ConditionStepID.ProblematicGround,\r\n title: 'Soils / Ground Conditions',\r\n },\r\n { id: 9, type: 'conditions', step: ConditionStepID.SoilType },\r\n { id: 10, type: 'conditions', step: ConditionStepID.GroundWater },\r\n {\r\n id: 11,\r\n type: 'conditions',\r\n step: ConditionStepID.GroundWaterDepth,\r\n optional: OptionalType.Groundwater,\r\n },\r\n {\r\n id: 12,\r\n type: 'surcharges',\r\n step: SurchargeStepID.LargeSurcharge,\r\n title: 'Surcharges & Site Risks',\r\n },\r\n { id: 13, type: 'surcharges', step: SurchargeStepID.SlopingGround },\r\n { id: 14, type: 'surcharges', step: SurchargeStepID.AdjacentWater },\r\n { id: 15, type: 'default', step: StepID.Solutions, title: 'Solution Selection Assessment' },\r\n];\r\nexport const YourSolutionPlusProgression = [\r\n { id: 0, type: 'default', step: StepID.Landing, title: 'Home' },\r\n { id: 1, type: 'default', step: StepID.TermsAndConditions, title: 'Terms & Conditions' },\r\n { id: 2, type: 'default', step: StepID.Details, title: 'Your Details' },\r\n { id: 3, type: 'default', step: StepID.Location, title: 'Location' },\r\n { id: 4, type: 'default', step: StepID.Depth, title: 'Depth' },\r\n { id: 5, type: 'dimensions', step: DimensionsStepID.Size, title: 'Plan Dimensions' },\r\n { id: 6, type: 'dimensions', step: DimensionsStepID.Type, title: 'Product Type' },\r\n { id: 7, type: 'dimensions', step: DimensionsStepID.EndSafePanels },\r\n {\r\n id: 8,\r\n type: 'dimensions',\r\n step: DimensionsStepID.EndSafeSides,\r\n optional: OptionalType.EndSafe,\r\n },\r\n {\r\n id: 9,\r\n type: 'soil-ground-conditions',\r\n step: SoilGroundConditionsStepID.SoilProfiles,\r\n title: 'Soils/Ground Conditions',\r\n },\r\n {\r\n id: 10,\r\n type: 'soil-ground-conditions',\r\n step: SoilGroundConditionsStepID.SoilInformationSource,\r\n },\r\n { id: 11, type: 'soil-ground-conditions', step: SoilGroundConditionsStepID.Groundwater },\r\n {\r\n id: 12,\r\n type: 'soil-ground-conditions',\r\n step: SoilGroundConditionsStepID.GroundwaterDepth,\r\n optional: OptionalType.Groundwater,\r\n },\r\n {\r\n id: 13,\r\n type: 'surcharges',\r\n step: SurchargeStepID.LargeSurcharge,\r\n title: 'Surcharges & Site Risks',\r\n },\r\n {\r\n id: 14,\r\n type: 'surcharges',\r\n step: SurchargeStepID.ZoneOfInfluence,\r\n optional: OptionalType.Surcharges,\r\n },\r\n {\r\n id: 15,\r\n type: 'default',\r\n step: StepID.Solutions,\r\n title: 'Solution Selection Assessment',\r\n },\r\n {\r\n id: 16,\r\n type: 'default',\r\n step: StepID.SelectedSolution,\r\n },\r\n];\r\n// DEV PURPOSES ONLY //\r\nexport const YSPQuickProgress = [\r\n { id: 0, type: 'default', step: StepID.Landing, title: 'Home' },\r\n {\r\n id: 1,\r\n type: 'soil-ground-conditions',\r\n step: SoilGroundConditionsStepID.SoilProfiles,\r\n title: 'Soils/Ground Conditions',\r\n },\r\n];\r\nexport var Tab;\r\n(function (Tab) {\r\n Tab[Tab[\"YourSolution\"] = 0] = \"YourSolution\";\r\n Tab[Tab[\"YourSolutionPlus\"] = 1] = \"YourSolutionPlus\";\r\n})(Tab || (Tab = {}));\r\nexport var EndSafeSide;\r\n(function (EndSafeSide) {\r\n EndSafeSide[EndSafeSide[\"None\"] = 0] = \"None\";\r\n EndSafeSide[EndSafeSide[\"One\"] = 1] = \"One\";\r\n EndSafeSide[EndSafeSide[\"Both\"] = 2] = \"Both\";\r\n})(EndSafeSide || (EndSafeSide = {}));\r\nexport var SoilInfoSource;\r\n(function (SoilInfoSource) {\r\n SoilInfoSource[SoilInfoSource[\"Verbal\"] = 0] = \"Verbal\";\r\n SoilInfoSource[SoilInfoSource[\"BoreholeLog\"] = 2] = \"BoreholeLog\";\r\n})(SoilInfoSource || (SoilInfoSource = {}));\r\nexport function getInitialState(props) {\r\n const initialState = {\r\n cultureCode: props.cultureCode,\r\n technicalLibraryUrl: props.technicalLibraryUrl,\r\n yourSolutionUrl: props.yourSolutionUrl,\r\n modal: undefined,\r\n step: StepID.Landing,\r\n steps: YourSolutionProgression,\r\n conditionStep: ConditionStepID.ProblematicGround,\r\n surchargeStep: SurchargeStepID.LargeSurcharge,\r\n supportStep: SupportStepID.System,\r\n dimensionsStep: DimensionsStepID.Size,\r\n soilGroundConditionsStep: SoilGroundConditionsStepID.SoilProfiles,\r\n loading: false,\r\n labels: {},\r\n form: {\r\n depth: 1.5,\r\n width: 3.0,\r\n length: 3.0,\r\n subType: SolutionSubType.None,\r\n groundwaterDepth: 0,\r\n soilDisclaimer: false,\r\n surchargeProfiles: props?.form?.surchargeProfiles ? props?.form?.surchargeProfiles : [],\r\n },\r\n errors: {},\r\n stepFooter: {\r\n nextDisabled: false,\r\n type: 'default',\r\n },\r\n tab: Tab.YourSolution,\r\n globalStep: 0,\r\n progress: 0,\r\n scrollLocked: false,\r\n soilProfiles: [],\r\n surcharges: [],\r\n loadingResults: false,\r\n mobile: false,\r\n formDirtyAfterSolutionsFetch: true,\r\n hasChangedSelectedSolution: true,\r\n zoomModalOpen: false,\r\n soilModalOpen: false,\r\n hasAddedDefaultSurcharge: false,\r\n fetchingNewSolutions: true\r\n };\r\n // Populate the authenicated user\r\n if (props.email) {\r\n initialState.authenticatedUser = {\r\n email: props.email ? props.email : '',\r\n userName: props.userName ? props.userName : '',\r\n telephone: props.telephone ? props.telephone : '',\r\n companyName: props.companyName ? props.companyName : '',\r\n };\r\n // Populate form fields\r\n initialState.form['name'] = props.userName;\r\n initialState.form['email'] = props.email;\r\n initialState.form['telephone'] = props.telephone;\r\n initialState.form['companyName'] = props.companyName;\r\n }\r\n return initialState;\r\n}\r\n","import { ConditionStepID, DimensionsStepID, getInitialState, OptionalType, SoilGroundConditionsStepID, SolutionSubType, StepID, SupportStepID, SupportType, SurchargeStepID, Tab, \r\n// YSPQuickProgress,\r\nYourSolutionPlusProgression, YourSolutionProgression, } from './types';\r\nimport isEqual from 'lodash/isEqual';\r\nconst phoneRegex = new RegExp(/^[0-9 )(+#]{10,}$/);\r\nconst emailRegex = new RegExp(\r\n// eslint-disable-next-line no-useless-escape\r\n/^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/);\r\nconst postcodeRegex = new RegExp(/^([A-PR-Z](([0-9](([0-9]|[A-HJKSTUWX])?)?)|([A-HK-Y][0-9]([0-9]|[ABEHMNPRVWXY])?)) ([0-9][ABD-HJLNP-UW-Z]{2}|[0-9AC-FHKNPRTV-Y]{4}))$/, 'i');\r\nconst determineStep = (state, direction) => {\r\n if (direction === 'next'\r\n ? state.globalStep + 1 <= state.steps.length - 1\r\n : state.globalStep - 1 >= StepID.Landing) {\r\n const currentStep = state.steps[state.globalStep];\r\n const checkStep = state.steps[direction === 'next' ? state.globalStep + 1 : state.globalStep - 1];\r\n if (checkStep.optional !== undefined) {\r\n // There's an optional condition, check it //\r\n switch (checkStep.optional) {\r\n case OptionalType.Groundwater:\r\n if (!state.form.groundwaterPresent) {\r\n // Skip groundwater question //\r\n state.globalStep = direction === 'next' ? state.globalStep + 1 : state.globalStep - 1;\r\n }\r\n break;\r\n case OptionalType.EndSafe:\r\n if (!state.form.endSafePanelsRequired) {\r\n // Skip sides question //\r\n state.globalStep = direction === 'next' ? state.globalStep + 1 : state.globalStep - 1;\r\n }\r\n break;\r\n case OptionalType.Surcharges:\r\n if (!state.form.largeSurcharges) {\r\n if (!state.hasAddedDefaultSurcharge) {\r\n // Skip surcharges question, but preselect any options that come preselected from the CMS //\r\n const preselectedSurcharges = state.surcharges.filter((x) => x.surchargePreselected);\r\n preselectedSurcharges.forEach((surcharge) => {\r\n if (!state.form.surchargeProfiles) {\r\n state.form.surchargeProfiles = [];\r\n }\r\n state.form.surchargeProfiles.push(surcharge);\r\n });\r\n state.hasAddedDefaultSurcharge = true;\r\n }\r\n state.globalStep = direction === 'next' ? state.globalStep + 1 : state.globalStep - 1;\r\n }\r\n break;\r\n case OptionalType.SheetedSolution:\r\n if (state.form.supportType !== SupportType.Frame) {\r\n // Skip sheeted solution question //\r\n state.globalStep = direction === 'next' ? state.globalStep + 1 : state.globalStep - 1;\r\n }\r\n break;\r\n default:\r\n break;\r\n }\r\n }\r\n // Will have been adjusted due to optional conditions, or not //\r\n const newStep = state.steps[direction === 'next' ? state.globalStep + 1 : state.globalStep - 1];\r\n // Progress logic //\r\n // Quite fiddly and probably needs rewriting somepoint, but determines if it should progress the top bar or not //\r\n if (currentStep.type === newStep.type) {\r\n // Titles almost always define a point to progress, so if we're going from a type of question to the same type //\r\n // and both of them have titles, modify progress //\r\n // We also don't want to count the Landing page as a step, so ignore it in the logic //\r\n if ((currentStep.title && newStep.title && currentStep.id !== StepID.Landing) ||\r\n (direction === 'next'\r\n ? currentStep.step === StepID.TermsAndConditions\r\n : newStep.step === StepID.TermsAndConditions) // A bit hacky but also want to apply this logic to the T&C step\r\n ) {\r\n state.progress = direction === 'next' ? state.progress + 1 : state.progress - 1;\r\n }\r\n }\r\n else {\r\n // Going between two different types of question - always modify, luckily factors in optional questions too //\r\n state.progress = direction === 'next' ? state.progress + 1 : state.progress - 1;\r\n }\r\n switch (newStep.type) {\r\n default:\r\n case 'default':\r\n // Normal step //\r\n state.step = newStep.step;\r\n break;\r\n case 'support':\r\n // Support step //\r\n state.step = StepID.Support;\r\n state.supportStep = newStep.step;\r\n break;\r\n case 'conditions':\r\n // Conditions step //\r\n state.step = StepID.Conditions;\r\n state.conditionStep = newStep.step;\r\n break;\r\n case 'surcharges':\r\n // Surcharges step //\r\n state.step = StepID.Surcharges;\r\n state.surchargeStep = newStep.step;\r\n break;\r\n case 'dimensions':\r\n // Dimensions step //\r\n state.step = StepID.Dimensions;\r\n state.dimensionsStep = newStep.step;\r\n break;\r\n case 'soil-ground-conditions':\r\n // Dimensions step //\r\n state.step = StepID.SoilsGroundConditions;\r\n state.soilGroundConditionsStep = newStep.step;\r\n break;\r\n }\r\n state.globalStep = direction === 'next' ? state.globalStep + 1 : state.globalStep - 1;\r\n if (state.progress < 0) {\r\n state.progress = 0;\r\n }\r\n }\r\n};\r\nexport default function reducer(state, action) {\r\n switch (action.type) {\r\n /**\r\n * Initial setup\r\n */\r\n default:\r\n case 'init': {\r\n return state;\r\n }\r\n /**\r\n * Traversing the steps\r\n */\r\n case 'next-step': {\r\n const newState = { ...state };\r\n if (Object.keys(state.errors).length === 0) {\r\n determineStep(newState, 'next');\r\n // Clear any blocking conditions on the footer //\r\n newState.stepFooter.nextDisabled = false;\r\n newState.stepFooter.beforeNext = undefined;\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Reversing through the steps\r\n */\r\n case 'previous-step': {\r\n const newState = { ...state };\r\n // As of right now, the final step is ALWAYS the solutions //\r\n // Meaning if you've come into this reducer, you have to clear the solutions //\r\n newState.results = undefined;\r\n // if a solution has been selected, clear this to prevent invalid solution still being selected after changes to parameters\r\n newState.form.selectedSolutionName = undefined;\r\n newState.form.selectedSolutionIterator = undefined;\r\n determineStep(newState, 'previous');\r\n // Clear any blocking conditions on the footer //\r\n newState.stepFooter.nextDisabled = false;\r\n newState.stepFooter.beforeNext = undefined;\r\n return newState;\r\n }\r\n /**\r\n * Navigates to a specific step\r\n */\r\n case 'go-to-step': {\r\n const newState = { ...state };\r\n const targetStep = newState.steps[action.payload];\r\n const resetStepsIfNeeded = () => {\r\n const copy = [...newState.steps];\r\n const foundSteps = [targetStep.type];\r\n for (let i = state.globalStep; i >= action.payload; i--) {\r\n if (foundSteps.indexOf(copy[i].type) === -1) {\r\n foundSteps.push(copy[i].type);\r\n }\r\n }\r\n foundSteps.forEach((x) => {\r\n switch (x) {\r\n default:\r\n case 'support':\r\n newState.supportStep = SupportStepID.System;\r\n break;\r\n case 'conditions':\r\n newState.conditionStep = ConditionStepID.ProblematicGround;\r\n break;\r\n case 'surcharges':\r\n newState.surchargeStep = SurchargeStepID.LargeSurcharge;\r\n break;\r\n case 'dimensions':\r\n newState.dimensionsStep = DimensionsStepID.Size;\r\n break;\r\n case 'soil-ground-conditions':\r\n newState.soilGroundConditionsStep = SoilGroundConditionsStepID.SoilProfiles;\r\n break;\r\n }\r\n });\r\n };\r\n // e.g. if we're going back past the Support step, reset support to the first step //\r\n resetStepsIfNeeded();\r\n newState.globalStep = action.payload;\r\n newState.stepFooter.nextDisabled = false;\r\n newState.stepFooter.beforeNext = undefined;\r\n // If you're on the final step and go back to change some stuff, we should unselect the solution //\r\n // as you may end up having a (now) failing solution selected when you get back to the solutions list //\r\n newState.selectedSolution = undefined;\r\n newState.selectedSolutionIterator = undefined;\r\n newState.form.selectedSolutionName = undefined;\r\n newState.form.selectedSolutionIterator = undefined;\r\n // Modify the progress too to update the header - find all the steps up until the new point that have titles //\r\n const stepsWithTitles = newState.steps\r\n .slice(0, newState.globalStep)\r\n .filter((x) => x.title && x.title !== 'Home').length;\r\n newState.progress = stepsWithTitles;\r\n switch (targetStep.type) {\r\n default:\r\n case 'default':\r\n // Normal step //\r\n newState.step = targetStep.step;\r\n break;\r\n case 'support':\r\n // Support step //\r\n newState.step = StepID.Support;\r\n newState.supportStep = targetStep.step;\r\n break;\r\n case 'conditions':\r\n // Conditions step //\r\n newState.step = StepID.Conditions;\r\n newState.conditionStep = targetStep.step;\r\n break;\r\n case 'surcharges':\r\n // Surcharges step //\r\n newState.step = StepID.Surcharges;\r\n newState.surchargeStep = targetStep.step;\r\n break;\r\n case 'dimensions':\r\n // Surcharges step //\r\n newState.step = StepID.Dimensions;\r\n newState.dimensionsStep = targetStep.step;\r\n break;\r\n case 'soil-ground-conditions':\r\n // Soils and Ground Conditions steps //\r\n newState.step = StepID.SoilsGroundConditions;\r\n newState.soilGroundConditionsStep = targetStep.step;\r\n break;\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Goes back to the start and clears any data\r\n */\r\n case 'restart': {\r\n const newState = getInitialState({\r\n cultureCode: state.cultureCode,\r\n technicalLibraryUrl: state.technicalLibraryUrl,\r\n yourSolutionUrl: state.yourSolutionUrl,\r\n email: state.authenticatedUser?.email,\r\n userName: state.authenticatedUser?.userName,\r\n telephone: state.authenticatedUser?.telephone,\r\n companyName: state.authenticatedUser?.companyName,\r\n });\r\n return newState;\r\n }\r\n /**\r\n * Submit\r\n */\r\n case 'submit': {\r\n const newState = { ...state };\r\n newState.loadingResults = true;\r\n return newState;\r\n }\r\n /**\r\n * Submit success\r\n */\r\n case 'submit-success': {\r\n const newState = { ...state };\r\n newState.results = action.payload;\r\n newState.loadingResults = false;\r\n return newState;\r\n }\r\n /**\r\n * Initial get step action used for loaders\r\n */\r\n case 'get-step': {\r\n const newState = { ...state };\r\n newState.loading = true;\r\n if (newState.step < StepID.Solutions) {\r\n newState.fetchingNewSolutions = true;\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Get step action used for handling errors\r\n */\r\n case 'get-step-error': {\r\n const newState = { ...state };\r\n return newState;\r\n }\r\n /**\r\n * Get step action used for handling success\r\n */\r\n case 'get-step-success': {\r\n const newState = { ...state };\r\n // YSP responses are wrapped in an additional layer //\r\n // TODO : Make this less hacky //\r\n if (newState.tab === Tab.YourSolutionPlus) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const responseAny = action.payload;\r\n if (responseAny.result) {\r\n newState.labels = responseAny.result.labels;\r\n }\r\n }\r\n else {\r\n newState.labels = action.payload.labels;\r\n }\r\n newState.loading = false;\r\n return newState;\r\n }\r\n /**\r\n * Set a form field to the given value\r\n */\r\n case 'set-form-field': {\r\n const newState = { ...state };\r\n const initialState = getInitialState({\r\n cultureCode: state.cultureCode,\r\n technicalLibraryUrl: state.technicalLibraryUrl,\r\n yourSolutionUrl: state.yourSolutionUrl,\r\n email: state.authenticatedUser?.email,\r\n userName: state.authenticatedUser?.userName,\r\n telephone: state.authenticatedUser?.telephone,\r\n companyName: state.authenticatedUser?.companyName,\r\n });\r\n // Only change if there's an actual change //\r\n if (!isEqual(newState.form[action.payload.field], action.payload.value)) {\r\n newState.form[action.payload.field] = action.payload.value;\r\n if (action.payload.invalidatedFields && action.payload.invalidatedFields.length > 0) {\r\n for (const field of action.payload.invalidatedFields) {\r\n newState.form[field] = initialState.form[field];\r\n }\r\n }\r\n // If we've updated a form field, and we're not on solutions (i.e. a change that will affect the solutions) //\r\n // set the form to dirty so we can trigger a re-fetch when the solutions step is reached again //\r\n if (!newState.formDirtyAfterSolutionsFetch && newState.progress < StepID.Solutions) {\r\n newState.formDirtyAfterSolutionsFetch = true;\r\n }\r\n if (action.payload.field === 'selectedSolutionName' &&\r\n !newState.hasChangedSelectedSolution) {\r\n newState.hasChangedSelectedSolution = true;\r\n }\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates the user details\r\n */\r\n case 'validate-details': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // First Name\r\n if (newState.form.name === undefined || newState.form.name.length === 0) {\r\n newState.errors['name'] = 'custom.ism.details.name.empty';\r\n }\r\n // Email\r\n if (newState.form.email === undefined || newState.form.email.length === 0) {\r\n newState.errors['email'] = 'custom.ism.details.email.empty';\r\n }\r\n else if (newState.form.email.match(emailRegex) === null) {\r\n newState.errors['email'] = 'custom.ism.details.email.invalid';\r\n }\r\n // Confirm Email\r\n if (state.authenticatedUser === undefined &&\r\n (newState.form.confirmEmail?.toLowerCase() !== newState.form.email?.toLowerCase() ||\r\n newState.errors['email'] !== undefined)) {\r\n newState.errors['confirmEmail'] = 'custom.ism.details.email.mismatch';\r\n }\r\n // Scheme Name\r\n if (newState.form.schemeName === undefined || newState.form.schemeName.length === 0) {\r\n newState.errors['schemeName'] = 'custom.ism.details.scheme.empty';\r\n }\r\n // Site Name\r\n if (newState.form.siteName === undefined || newState.form.siteName.length === 0) {\r\n newState.errors['siteName'] = 'custom.ism.details.site.empty';\r\n }\r\n // Company Name\r\n if (newState.form.companyName === undefined || newState.form.companyName.length === 0) {\r\n newState.errors['companyName'] = 'custom.ism.details.company.empty';\r\n }\r\n // Telephone\r\n if (newState.form.telephone === undefined || newState.form.telephone?.length === 0) {\r\n newState.errors['telephone'] = 'custom.ism.details.telephone.empty';\r\n }\r\n else if (newState.form.telephone?.match(phoneRegex) === null) {\r\n newState.errors['telephone'] = 'custom.ism.details.telephone.invalid';\r\n }\r\n // Recaptcha\r\n if (newState.form.recaptchaToken === undefined ||\r\n newState.form.recaptchaToken === null ||\r\n newState.form.recaptchaToken.length === 0) {\r\n newState.errors['recaptchaToken'] = 'custom.ism.details.recaptcha.empty';\r\n }\r\n return newState;\r\n }\r\n case 'validate-depth': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n if (newState.form.depth === undefined || newState.form.depth === 0) {\r\n newState.errors['depth'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n case 'validate-dimensions': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n if (newState.form.width === undefined || newState.form.width === 0) {\r\n newState.errors['width'] = 'invalid';\r\n }\r\n if (newState.form.length === undefined || newState.form.length === 0) {\r\n newState.errors['length'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates the postcode\r\n */\r\n case 'validate-postcode': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.postCode === undefined) {\r\n newState.errors['postCode'] = 'custom.ism.postcode.empty';\r\n }\r\n else if (newState.form.postCode.indexOf(' ') === -1) {\r\n newState.errors['postCode'] = 'custom.ism.postcode.missingspace';\r\n }\r\n else if (newState.form.postCode.match(postcodeRegex) === null) {\r\n newState.errors['postCode'] = 'custom.ism.postcode.invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates the selected type\r\n */\r\n case 'validate-type': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.type === undefined) {\r\n newState.errors['type'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates the selected type\r\n */\r\n case 'validate-sub-type': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.subType === undefined ||\r\n (newState.form.supportType === SupportType.Frame &&\r\n newState.form.subType === SolutionSubType.None)) {\r\n newState.errors['subType'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates groundwater\r\n */\r\n case 'validate-groundwater': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.groundwaterPresent === undefined) {\r\n newState.errors['groundwaterPresent'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates groundwater\r\n */\r\n case 'validate-groundwater-depth': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid Depth\r\n if (newState.form.groundwaterDepth === undefined || newState.form.groundwaterDepth < 0) {\r\n newState.errors['groundwaterDepth'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates soil type\r\n */\r\n case 'validate-soil-type': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.soilType === undefined) {\r\n newState.errors['soilType'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates support\r\n */\r\n case 'validate-support': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.supportType === undefined) {\r\n newState.errors['supportType'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates problematic ground\r\n */\r\n case 'validate-problematic-ground': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.problematicGround === undefined) {\r\n newState.errors['problematicGround'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates problematic ground\r\n */\r\n case 'validate-large-surcharges': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.largeSurcharges === undefined) {\r\n newState.errors['largeSurcharges'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates problematic ground\r\n */\r\n case 'validate-sloping-ground': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.slopingGround === undefined) {\r\n newState.errors['slopingGround'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates problematic ground\r\n */\r\n case 'validate-adjacent-water': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.adjacentWater === undefined) {\r\n newState.errors['adjacentWater'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n /**\r\n * Validates the sheeted solution type\r\n */\r\n case 'validate-sheeted-solution-type': {\r\n const newState = { ...state };\r\n // Reset the errors before recalculating them\r\n newState.errors = {};\r\n // Check for a valid postcode\r\n if (newState.form.sheetedSolutionType === undefined) {\r\n newState.errors['sheetedSolutionType'] = 'invalid';\r\n }\r\n return newState;\r\n }\r\n case 'set-modal': {\r\n const newState = { ...state };\r\n newState.modal = action.payload;\r\n return newState;\r\n }\r\n case 'set-footer': {\r\n const newState = { ...state };\r\n newState.stepFooter = { ...newState.stepFooter, ...action.payload };\r\n if (!action.payload.type) {\r\n newState.stepFooter.type = 'default';\r\n }\r\n return newState;\r\n }\r\n case 'set-tab': {\r\n const newState = { ...state };\r\n newState.tab = action.payload;\r\n if (newState.tab === Tab.YourSolution) {\r\n newState.steps = YourSolutionProgression;\r\n }\r\n else {\r\n newState.steps = YourSolutionPlusProgression;\r\n }\r\n return newState;\r\n }\r\n case 'toggle-locked': {\r\n const newState = { ...state };\r\n newState.scrollLocked = !newState.scrollLocked;\r\n return newState;\r\n }\r\n case 'set-locked': {\r\n const newState = { ...state };\r\n newState.scrollLocked = action.payload;\r\n return newState;\r\n }\r\n case 'set-soil-profiles': {\r\n const newState = { ...state };\r\n newState.soilProfiles = action.payload;\r\n return newState;\r\n }\r\n case 'set-surcharges': {\r\n const newState = { ...state };\r\n newState.surcharges = action.payload;\r\n return newState;\r\n }\r\n /**\r\n * Submit YSP success\r\n */\r\n case 'submit-ysp-success': {\r\n const newState = { ...state };\r\n newState.yspResults = action.payload;\r\n newState.loadingResults = false;\r\n newState.formDirtyAfterSolutionsFetch = false;\r\n return newState;\r\n }\r\n /**\r\n * Submit Solution success\r\n */\r\n case 'submit-solution-success': {\r\n const newState = { ...state };\r\n newState.selectedSolution = action.payload;\r\n newState.loadingResults = false;\r\n newState.hasChangedSelectedSolution = false;\r\n newState.fetchingNewSolutions = false;\r\n return newState;\r\n }\r\n case 'set-mobile': {\r\n const newState = { ...state };\r\n newState.mobile = action.payload;\r\n return newState;\r\n }\r\n case 'set-zoom-modal': {\r\n const newState = { ...state };\r\n newState.zoomModalOpen = action.payload;\r\n return newState;\r\n }\r\n case 'set-soil-modal': {\r\n const newState = { ...state };\r\n newState.soilModalOpen = action.payload;\r\n return newState;\r\n }\r\n case 'swap-to-ys-plus': {\r\n // This will swap the user over from YS to YS+ //\r\n const newState = { ...state };\r\n newState.step = StepID.TermsAndConditions;\r\n newState.tab = Tab.YourSolutionPlus;\r\n newState.steps = YourSolutionPlusProgression;\r\n newState.progress = 0;\r\n newState.globalStep = 0;\r\n return newState;\r\n }\r\n case 'set-has-added-default-surcharge': {\r\n const newState = { ...state };\r\n newState.hasAddedDefaultSurcharge = action.payload;\r\n return newState;\r\n }\r\n }\r\n}\r\n","import React, { createContext, useContext, useReducer } from 'react';\r\nimport reducer from './reducer';\r\nimport { getInitialState } from './types';\r\nconst YSContext = createContext({});\r\nexport const YSContextProvider = (props) => {\r\n const [state, dispatch] = useReducer(reducer, getInitialState(props));\r\n return React.createElement(YSContext.Provider, { value: { state, dispatch } }, props.children);\r\n};\r\nexport const useYSPContext = () => {\r\n const contextValue = useContext(YSContext);\r\n contextValue.setFormField = (field, value, invalidatedFields) => {\r\n contextValue.dispatch({\r\n type: 'set-form-field',\r\n payload: {\r\n field,\r\n value,\r\n invalidatedFields,\r\n },\r\n });\r\n };\r\n return contextValue;\r\n};\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconCross(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 21.735 21.735\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 88\",\n fill: \"none\",\n stroke: \"currentcolor\",\n strokeLinecap: \"round\",\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 14\",\n d: \"M1.414 1.414L20.32 20.32\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 15\",\n d: \"M1.414 20.32L20.32 1.414\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"43cb74bed28e93deaa6712f1d4e50996.svg\";\nexport { SvgIconCross as ReactComponent };","export default __webpack_public_path__ + \"f8761a1b4e54a86d536ffc13b4135b36.png\";","import brand from '@helpers/brand';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { m } from 'framer-motion';\r\nconst Container = styled.div `\r\n position: fixed;\r\n height: var(--ysp-footer-height-mobile);\r\n background-color: ${brand.primary.light};\r\n display: flex;\r\n justify-content: space-between;\r\n pointer-events: none;\r\n\r\n left: 0px;\r\n bottom: 0px;\r\n z-index: 101;\r\n width: 100%;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n transition: opacity 0.25s ease-in-out;\r\n\r\n ${({ isLandingPage }) => isLandingPage &&\r\n css `\r\n justify-content: flex-end;\r\n `};\r\n\r\n ${({ zoomModalOpen }) => zoomModalOpen &&\r\n css `\r\n opacity: 0;\r\n pointer-events: none;\r\n `}\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n background-color: transparent;\r\n width: calc(100% - 120px);\r\n height: var(--ysp-footer-height);\r\n left: 60px;\r\n bottom: 60px;\r\n }\r\n`;\r\nconst ButtonMotionWrapper = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n y: 55,\r\n opacity: 0,\r\n },\r\n visible: {\r\n opacity: 1,\r\n y: 0,\r\n },\r\n },\r\n transition: {\r\n duration: 0.75,\r\n },\r\n})) `\r\n pointer-events: all;\r\n height: 100%;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n display: flex;\r\n width: 100%;\r\n\r\n a {\r\n margin-left: auto;\r\n padding-right: 5px;\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n width: max-content;\r\n }\r\n`;\r\nexport const Button = styled(SharedStyles.Button) `\r\n width: max-content;\r\n\r\n ${({ footerPrevious, footerNext }) => (footerPrevious || footerNext) &&\r\n css `\r\n top: 50%;\r\n transform: translateY(-50%);\r\n `};\r\n\r\n ${({ footerPrevious }) => footerPrevious &&\r\n css `\r\n &:disabled {\r\n background-color: unset;\r\n }\r\n\r\n background-color: unset;\r\n @media ${from(Device.TabletLarge)} {\r\n color: ${brand.primary.alt};\r\n }\r\n left: 20px;\r\n `};\r\n\r\n ${({ footerNext }) => footerNext &&\r\n css `\r\n right: 20px;\r\n `}\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n height: 100%;\r\n left: 0;\r\n right: 0;\r\n width: 100%;\r\n border-radius: 0px;\r\n\r\n ${({ footerNext }) => footerNext &&\r\n css `\r\n padding: 0px 25px 0px 10px;\r\n text-align: right;\r\n justify-content: flex-end;\r\n\r\n svg {\r\n right: 0;\r\n }\r\n `};\r\n\r\n ${({ footerPrevious }) => footerPrevious &&\r\n css `\r\n text-align: left;\r\n padding: 0px 10px 0px 25px;\r\n svg {\r\n left: 0;\r\n }\r\n `};\r\n\r\n svg {\r\n top: calc(50% + 1px); // Idk why but it seems to be about 1px off and it annoys me //\r\n height: 16px;\r\n }\r\n }\r\n\r\n ${({ inverse }) => inverse &&\r\n css `\r\n background-color: ${brand.white} !important;\r\n border-color: ${brand.primary.alt} !important;\r\n color: ${brand.primary.alt} !important;\r\n `};\r\n`;\r\nconst ButtonSmall = styled(Button) `\r\n padding: 4px 15px;\r\n font-size: 20px;\r\n`;\r\nconst MobileButton = styled.div ``;\r\nexport const StepFooterStyles = {\r\n Container,\r\n Button,\r\n ButtonMotionWrapper,\r\n ButtonSmall,\r\n MobileButton,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 5px;\r\n font-size: 17px;\r\n\r\n p {\r\n margin-bottom: 10px;\r\n color: ${brand.black}\r\n }\r\n\r\n label {\r\n ${fonts.DaxPro.Medium};\r\n }\r\n\r\n textarea {\r\n ${fonts.DaxPro.Regular};\r\n font-size: 17px;\r\n }\r\n\r\n small {\r\n font-size: 13px;\r\n }\r\n`;\r\nconst Heading = styled.h3 `\r\n color: ${brand.primary.alt};\r\n font-size: 30px;\r\n font-weight: bold;\r\n`;\r\nconst SuccessText = styled.div `\r\n color: ${brand.black};\r\n`;\r\nexport const EngineerCheckStyles = {\r\n Container,\r\n SuccessText,\r\n Heading,\r\n};\r\n","import ApiService from '@core/api/services/ApiService';\r\nimport React, { useState } from 'react';\r\nimport { useYSPContext } from '../../../Context/YSContext';\r\nimport { Button } from '../../StepFooter/StepFooter.styles';\r\nimport { EngineerCheckStyles as S } from './EngineerCheck.styles';\r\nconst EngineerCheck = (props) => {\r\n const [comment, setComment] = useState();\r\n const [file, setFile] = useState();\r\n const [submitting, setSubmitting] = useState(false);\r\n const [success, setSuccess] = useState();\r\n const { state: { selectedSolution }, } = useYSPContext();\r\n const handleSubmit = async () => {\r\n if (selectedSolution) {\r\n setSubmitting(true);\r\n const response = await ApiService.request({\r\n controller: 'YSP',\r\n slug: 'engineer',\r\n method: 'POST',\r\n isMultipartFormData: true,\r\n files: file ? [file] : null,\r\n params: {\r\n comment,\r\n designRef: selectedSolution.designReference,\r\n },\r\n });\r\n setSuccess(response.result);\r\n setSubmitting(false);\r\n }\r\n };\r\n return (React.createElement(S.Container, null, success === true ? (React.createElement(S.SuccessText, { dangerouslySetInnerHTML: { __html: props.labels['engineer.modal.success'] } })) : (React.createElement(React.Fragment, null,\r\n React.createElement(S.Heading, null, props.labels['engineer.modal.heading']),\r\n React.createElement(\"div\", { dangerouslySetInnerHTML: { __html: props.labels['engineer.modal.content'] } }),\r\n React.createElement(\"label\", { htmlFor: \"engineercheck-comment\" }, \"Comments*:\"),\r\n React.createElement(\"textarea\", { value: comment, onChange: (e) => setComment(e.currentTarget.value), id: \"engineercheck-comment\", rows: 4 }),\r\n React.createElement(\"br\", null),\r\n React.createElement(\"label\", { htmlFor: \"engineercheck-file\" }, \"File:\"),\r\n React.createElement(\"input\", { onChange: (e) => e.currentTarget.files && setFile(e.currentTarget.files[0]), type: \"file\", id: \"engineercheck-file\", accept: \".pdf, .docx\" }),\r\n React.createElement(\"small\", null, \"Please upload a PDF or Word document (.docx).\"),\r\n React.createElement(\"hr\", null),\r\n React.createElement(Button, { disabled: submitting || !comment, onClick: () => handleSubmit() }, \"Submit\")))));\r\n};\r\nexport default EngineerCheck;\r\n","import brand from '@helpers/brand';\r\nimport { Device, from } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { WYSIWYGStyles } from '../Shared.styles';\r\nimport { fonts } from '@helpers/fonts';\r\nconst BoxModal = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n transition: {\r\n delay: 0.15,\r\n },\r\n },\r\n visible: {\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.35,\r\n },\r\n})) `\r\n position: fixed;\r\n background-color: rgba(255, 255, 255, 0.84);\r\n top: 18px;\r\n left: 0;\r\n width: 100%;\r\n height: calc(100% - 50px - 18px);\r\n padding: 16px;\r\n\r\n z-index: 103;\r\n flex-direction: column;\r\n align-items: center;\r\n display: none;\r\n\r\n @media ${from(Device.Tablet)} {\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n overflow-y: unset;\r\n }\r\n\r\n ${({ active }) => active &&\r\n css `\r\n display: flex;\r\n `}\r\n\r\n ${({ small }) => small &&\r\n css `\r\n ${() => BoxModalInner} {\r\n max-width: 460px;\r\n }\r\n `};\r\n`;\r\nconst BoxModalInner = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n y: 100,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n opacity: 1,\r\n transition: {\r\n delay: 0.15,\r\n },\r\n },\r\n },\r\n transition: {\r\n duration: 0.35,\r\n },\r\n})) `\r\n max-width: 760px;\r\n width: 100%;\r\n background-color: ${brand.white};\r\n padding: 20px;\r\n border-bottom: 7px solid ${brand.primary.light};\r\n margin: auto;\r\n display: flex;\r\n box-shadow: 0px 3px 6px 2px rgb(0 0 0 / 25%);\r\n flex-direction: column;\r\n flex-wrap: nowrap;\r\n position: relative;\r\n max-height: 100%;\r\n overflow-y: auto;\r\n\r\n ${({ fullWidth }) => fullWidth &&\r\n css `\r\n flex-direction: column !important;\r\n `}\r\n`;\r\nconst BoxModalClose = styled.div `\r\n position: absolute;\r\n top: 12px;\r\n right: 12px;\r\n cursor: pointer;\r\n\r\n svg {\r\n width: 18px;\r\n height: 18px;\r\n }\r\n`;\r\nconst BoxModalMedia = styled.div `\r\n max-width: 260px;\r\n flex: 0 0 auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin: 0 auto;\r\n }\r\n\r\n ${({ fullWidth }) => fullWidth &&\r\n css `\r\n width: 100%;\r\n max-width: 700px;\r\n `}\r\n`;\r\nconst BoxModalCopy = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 20px;\r\n\r\n ${WYSIWYGStyles}\r\n\r\n padding: 25px 0px;\r\n color: #666666;\r\n line-height: 20px;\r\n`;\r\nconst ResetButton = styled.div ``;\r\nconst ConfirmText = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 20px;\r\n margin: 20px 0px 30px;\r\n text-align: center;\r\n`;\r\nconst Buttons = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n gap: 10px;\r\n\r\n button:last-of-type {\r\n background-color: ${brand.divisionTags.sandhurst};\r\n }\r\n`;\r\nexport const ModalStyles = {\r\n BoxModal,\r\n BoxModalInner,\r\n BoxModalClose,\r\n BoxModalMedia,\r\n BoxModalCopy,\r\n ResetButton,\r\n Buttons,\r\n ConfirmText,\r\n};\r\n","import { ReactComponent as Close } from '@img/ysp/icon-cross.svg';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport React from 'react';\r\nimport EngineerCheck from './EngineerCheck/EngineerCheck';\r\nimport { ModalStyles as S } from './Modal.styles';\r\nconst Modal = ({ modalScrollable, modal }) => {\r\n const { dispatch } = useYSPContext();\r\n return (React.createElement(S.BoxModal, { small: modal.size === 'small', active: true },\r\n React.createElement(S.BoxModalInner, { fullWidth: modal.fullWidth, ref: modalScrollable },\r\n React.createElement(S.BoxModalClose, { onClick: () => dispatch({ type: 'set-modal', payload: undefined }) },\r\n React.createElement(Close, null)),\r\n modal.imageUrl && (React.createElement(S.BoxModalMedia, { fullWidth: modal.fullWidth },\r\n React.createElement(\"img\", { src: modal.imageUrl, alt: modal.title, style: { objectFit: 'cover' } }))),\r\n modal.engineerCheckLabels ? (React.createElement(EngineerCheck, { labels: {\r\n 'engineer.modal.heading': modal.engineerCheckLabels.heading,\r\n 'engineer.modal.content': modal.engineerCheckLabels.content,\r\n 'engineer.modal.success': modal.engineerCheckLabels.success,\r\n } })) : (React.createElement(S.BoxModalCopy, null,\r\n modal.title && modal.title.length && React.createElement(\"h2\", null, modal.title),\r\n modal.description && (React.createElement(\"div\", { style: { display: 'contents' }, dangerouslySetInnerHTML: { __html: modal.description } })))))));\r\n};\r\nexport default Modal;\r\n","import brand from '@helpers/brand';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: row;\r\n flex-wrap: nowrap;\r\n height: var(--ysp-steps-height);\r\n position: relative;\r\n`;\r\nconst Step = styled.div `\r\n flex: 1 1 auto;\r\n background-color: #ccddab;\r\n width: 100%;\r\n height: 100%;\r\n margin-right: 4px;\r\n position: relative;\r\n\r\n &::after {\r\n content: '';\r\n position: absolute;\r\n z-index: 20;\r\n width: 4px;\r\n height: 100%;\r\n top: 0;\r\n left: 100%;\r\n background-color: ${brand.white};\r\n }\r\n\r\n ${({ hideEnd }) => hideEnd &&\r\n css `\r\n margin-right: 0px;\r\n &::after {\r\n display: none;\r\n }\r\n `}\r\n`;\r\nconst StepBackground = styled(m.div).attrs(({ step, steps }) => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n width: 0,\r\n },\r\n visible: {\r\n width: `calc((100dvw / ${steps}) * ${step})`,\r\n },\r\n },\r\n transition: {\r\n type: 'tween',\r\n duration: 1,\r\n ease: 'easeInOut',\r\n },\r\n})) `\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n height: 100%;\r\n overflow: hidden;\r\n background-color: ${brand.primary.dark};\r\n cursor: pointer;\r\n`;\r\nexport const StepHeaderStyles = {\r\n Container,\r\n Step,\r\n StepBackground,\r\n};\r\n","import React, { useMemo } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { StepHeaderStyles as S } from './StepHeader.styles';\r\nimport { AnimatePresence } from 'framer-motion';\r\nconst StepHeader = () => {\r\n const { state } = useYSPContext();\r\n const stepsWithTitle = useMemo(() => {\r\n return state.steps.filter((x) => x.title && x.title !== 'Home');\r\n }, [state.steps]);\r\n return (React.createElement(S.Container, null,\r\n stepsWithTitle.map((x, i) => (React.createElement(S.Step, { key: x.id, hideEnd: i === stepsWithTitle.length - 1 }))),\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(S.StepBackground, { steps: stepsWithTitle.length, step: state.progress + 1 }))));\r\n};\r\nexport default StepHeader;\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n align-self: center;\r\n cursor: pointer;\r\n user-select: none;\r\n position: relative;\r\n z-index: 103;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n justify-content: center;\r\n flex-direction: column;\r\n align-items: center;\r\n width: 100%;\r\n display: flex;\r\n transition: opacity 0.25s ease-in-out;\r\n\r\n ${({ zoomModalOpen }) => zoomModalOpen &&\r\n css `\r\n opacity: 0;\r\n pointer-events: none;\r\n `}\r\n }\r\n\r\n ${({ active }) => active &&\r\n css `\r\n ${() => Items} {\r\n display: block;\r\n }\r\n `}\r\n`;\r\nconst BlurLine = styled.div `\r\n box-shadow: 0px 5px 4px -3px rgba(0, 0, 0, 0.75);\r\n height: 7px;\r\n width: 100%;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst SelectedStep = styled.div `\r\n font-size: 15px;\r\n padding-top: 25px;\r\n ${fonts.DaxPro.Regular};\r\n display: flex;\r\n align-items: center;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n padding-top: 10px;\r\n font-size: 18px;\r\n }\r\n\r\n svg {\r\n width: 22px;\r\n height: 15px;\r\n color: ${brand.primary.light};\r\n margin-left: 8px;\r\n transform: rotate(90deg);\r\n transition: transform 0.15s ease-in-out;\r\n\r\n ${({ isOpen }) => isOpen &&\r\n css `\r\n transform: rotate(-90deg);\r\n `}\r\n }\r\n`;\r\nconst Items = styled(m.div).attrs(({ active }) => ({\r\n initial: 'hidden',\r\n animate: active ? 'visible' : 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n overflow: 'hidden',\r\n },\r\n visible: {\r\n height: 'auto',\r\n },\r\n },\r\n transition: {\r\n type: 'tween',\r\n duration: 0.35,\r\n },\r\n})) `\r\n display: none;\r\n max-width: 415px;\r\n width: calc(100vw - 36px);\r\n max-height: 50vh;\r\n overflow-y: auto;\r\n position: absolute;\r\n top: calc(100% + 15px);\r\n left: 50%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.white};\r\n`;\r\nconst ItemsInner = styled.div `\r\n border: 1px solid #c7c7c7;\r\n`;\r\nconst Step = styled.div `\r\n padding: 12px 10px;\r\n opacity: 0.5;\r\n transition: opacity 0.15s ease-in-out, background-color 0.1s ease-in-out;\r\n background-color: ${brand.grey.grey96};\r\n\r\n ${({ active }) => active &&\r\n css `\r\n opacity: 1;\r\n text-decoration: underline;\r\n `};\r\n\r\n ${({ completed }) => completed &&\r\n css `\r\n opacity: 1;\r\n `};\r\n\r\n &:hover {\r\n opacity: 1;\r\n background-color: ${brand.grey.grey89};\r\n }\r\n`;\r\nexport const StepPickerStyles = {\r\n Container,\r\n SelectedStep,\r\n Items,\r\n Step,\r\n ItemsInner,\r\n BlurLine,\r\n};\r\n","import { isSSR } from '@helpers/ssr';\r\nimport React, { useEffect, useMemo, useState } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { StepPickerStyles as S } from './StepPicker.styles';\r\nimport { ReactComponent as Chevron } from '@img/icons/chevron-right.svg';\r\nimport { StepID } from '@ys/Context/types';\r\nimport { AnimatePresence } from 'framer-motion';\r\nconst StepPicker = () => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const { state, dispatch } = useYSPContext();\r\n const filteredSteps = state.steps.filter((x) => x.title !== undefined);\r\n const currentStep = useMemo(() => {\r\n const currentGlobalStep = state.steps[state.globalStep];\r\n if (currentGlobalStep.title) {\r\n return currentGlobalStep;\r\n }\r\n else {\r\n let step = undefined;\r\n let i = state.globalStep - 1;\r\n do {\r\n const current = state.steps[i];\r\n if (current.title) {\r\n step = current;\r\n }\r\n if (i <= 0 && !step) {\r\n // Should never reach here but just in case //\r\n step = {\r\n id: -1,\r\n step: StepID.Landing,\r\n type: 'default',\r\n title: '???',\r\n };\r\n }\r\n i--;\r\n } while (step === undefined);\r\n return step;\r\n }\r\n }, [state.globalStep]);\r\n const handleWindowClick = () => {\r\n setIsOpen(false);\r\n };\r\n useEffect(() => {\r\n if (!isSSR()) {\r\n window.addEventListener('click', handleWindowClick);\r\n }\r\n return () => window.removeEventListener('click', handleWindowClick);\r\n }, []);\r\n if (currentStep === undefined) {\r\n return null;\r\n }\r\n return (React.createElement(S.Container, { zoomModalOpen: state.zoomModalOpen, active: isOpen, onClick: (e) => {\r\n e.stopPropagation();\r\n e.preventDefault();\r\n setIsOpen(!isOpen);\r\n } },\r\n React.createElement(S.BlurLine, null),\r\n React.createElement(S.SelectedStep, { isOpen: isOpen },\r\n currentStep.title,\r\n React.createElement(Chevron, null)),\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(S.Items, { key: 'StepPicker', active: isOpen },\r\n React.createElement(S.ItemsInner, null, filteredSteps.map((step) => (React.createElement(S.Step, { key: step.id, active: step.id === currentStep.id, completed: step.id < currentStep.id, onClick: (e) => {\r\n e.preventDefault();\r\n if (step.id >= currentStep.id) {\r\n return;\r\n }\r\n dispatch({ type: 'go-to-step', payload: step.id });\r\n } }, step.title))))))));\r\n};\r\nexport default StepPicker;\r\n","var _path, _path2;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconInfo(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 1024 1024\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm0 820c-205.4 0-372-166.6-372-372s166.6-372 372-372 372 166.6 372 372-166.6 372-372 372z\",\n stroke: \"none\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M464 336a48 48 0 1096 0 48 48 0 10-96 0zm72 112h-48c-4.4 0-8 3.6-8 8v272c0 4.4 3.6 8 8 8h48c4.4 0 8-3.6 8-8V456c0-4.4-3.6-8-8-8z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"0c8e59ac31abcea57eab2be80cdfc32e.svg\";\nexport { SvgIconInfo as ReactComponent };","import { fonts } from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\nimport { m } from 'framer-motion';\r\nimport brand from '@helpers/brand';\r\nimport { Device, from } from '@helpers/media';\r\nconst Container = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n y: -25,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 1,\r\n },\r\n})) `\r\n height: 100%;\r\n width: 100%;\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n gap: 15px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n gap: 25px;\r\n }\r\n`;\r\nconst Text = styled(m.div) `\r\n font-size: 50px !important;\r\n line-height: 100% !important;\r\n user-select: none;\r\n ${fonts.DaxPro.Bold}\r\n\r\n @media ${from(Device.Tablet)} {\r\n font-size: 75px !important;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 100px !important;\r\n }\r\n`;\r\nconst FadeTextWrapper = styled.div `\r\n display: flex;\r\n`;\r\nconst TopText = styled(Text) `\r\n font-size: 35px !important;\r\n\r\n @media ${from(Device.Tablet)} {\r\n font-size: 45px !important;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 50px !important;\r\n }\r\n`;\r\nconst Letter = styled(Text).attrs(({ i }) => ({\r\n animate: 'animation',\r\n variants: {\r\n animation: {\r\n opacity: [0, 1, 0],\r\n transition: {\r\n type: 'tween',\r\n opacity: {\r\n delay: i / 15 + 0.6,\r\n duration: 2,\r\n repeat: Infinity,\r\n },\r\n },\r\n },\r\n },\r\n})) `\r\n ${({ colour }) => colour === 'green'\r\n ? css `\r\n color: ${brand.primary.alt};\r\n `\r\n : css `\r\n color: ${brand.grey.grey20};\r\n `}\r\n\r\n ${({ last }) => last &&\r\n css `\r\n color: ${brand.divisionTags.sandhurst};\r\n position: relative;\r\n top: -10px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n top: -15px;\r\n }\r\n `};\r\n`;\r\nexport const LoadingStyles = {\r\n Container,\r\n Text,\r\n Letter,\r\n TopText,\r\n FadeTextWrapper,\r\n};\r\n","import { withMotion } from '@hoc/withMotion';\r\nimport React from 'react';\r\nimport { useYSPContext } from '../../Context/YSContext';\r\nimport { Tab } from '../../Context/types';\r\nimport { LoadingStyles as S } from './Loading.styles';\r\nconst Loading = () => {\r\n const { state } = useYSPContext();\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.TopText, null, \"Loading\"),\r\n React.createElement(S.FadeTextWrapper, null,\r\n 'Your'.split('').map((x, i) => (React.createElement(S.Letter, { colour: \"grey\", key: `Your_${i}`, i: i }, x))),\r\n (state.tab === Tab.YourSolution ? 'Solution' : 'Solution+').split('').map((x, i) => (React.createElement(S.Letter, { last: state.tab === Tab.YourSolutionPlus && x === '+', colour: \"green\", key: `Solution_${i}`, i: i + 4 }, x))))));\r\n};\r\nexport default withMotion(Loading);\r\n","import { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nconst Container = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n scale: 0.75,\r\n },\r\n visible: {\r\n opacity: 1,\r\n scale: 1,\r\n },\r\n },\r\n})) `\r\n width: 100%;\r\n height: 100%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n`;\r\nexport const StepLoadingStyles = {\r\n Container,\r\n};\r\n","import Loader from '@stories/Components/Misc/Loader/Loader';\r\nimport React from 'react';\r\nimport { StepLoadingStyles as S } from './StepLoading.styles';\r\nconst StepLoading = () => {\r\n return (React.createElement(S.Container, null,\r\n React.createElement(Loader, null)));\r\n};\r\nexport default StepLoading;\r\n","import brand from '@helpers/brand';\r\nimport { Device, from } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled(m.div).attrs(() => ({\r\n layout: true,\r\n})) `\r\n width: 100%;\r\n display: flex;\r\n flex-wrap: wrap;\r\n flex-direction: row;\r\n justify-content: center;\r\n`;\r\nconst Item = styled.div `\r\n border: 1px solid #c7c7c7;\r\n padding: 14px;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n cursor: pointer;\r\n user-select: none;\r\n margin-bottom: 18px;\r\n align-self: center;\r\n margin-right: 12px;\r\n position: relative;\r\n\r\n ${({ invalid }) => invalid &&\r\n css `\r\n border: 1px solid ${brand.red.base};\r\n `}\r\n\r\n ${({ active }) => active &&\r\n css `\r\n border: 1px solid ${brand.primary.light};\r\n\r\n ${() => Value}::after {\r\n opacity: 1;\r\n transform: translate(-50%, -50%) scale(1);\r\n }\r\n `};\r\n\r\n &:last-child {\r\n margin-right: 0px;\r\n }\r\n\r\n @media ${from(Device.MobileMedium)} {\r\n align-self: auto;\r\n padding: 20px;\r\n }\r\n`;\r\nconst BottomEffect = styled(m.div) `\r\n top: 100%;\r\n left: -1px;\r\n position: absolute;\r\n width: calc(100% + 2px);\r\n height: 6px;\r\n background-color: ${brand.primary.light};\r\n`;\r\nconst Value = styled.div `\r\n width: 24px;\r\n height: 24px;\r\n border: 1px solid ${brand.grey.grey20};\r\n border-radius: 50%;\r\n margin-right: 7px;\r\n position: relative;\r\n\r\n &::after {\r\n content: '';\r\n position: absolute;\r\n top: 50%;\r\n left: 50%;\r\n width: 15px;\r\n height: 15px;\r\n background-color: ${brand.primary.light};\r\n border-radius: 50%;\r\n transform: translate(-50%, -50%) scale(0.5);\r\n opacity: 0;\r\n transition: opacity 0.15s ease-in-out, transform 0.25s ease-in-out;\r\n }\r\n`;\r\nconst Label = styled.div `\r\n font-size: 14px;\r\n font-weight: normal;\r\n\r\n @media ${from(Device.MobileMedium)} {\r\n font-size: 17px;\r\n }\r\n`;\r\nexport const RadiosStyles = {\r\n Container,\r\n Item,\r\n Value,\r\n Label,\r\n BottomEffect,\r\n};\r\n","import { withMotionMax } from '@hoc/withMotionMax';\r\nimport { AnimateSharedLayout } from 'framer-motion';\r\nimport React from 'react';\r\nimport { RadiosStyles as S } from './Radios.styles';\r\nconst defaultOptions = [\r\n {\r\n label: 'Yes',\r\n value: true,\r\n },\r\n {\r\n label: 'No',\r\n value: false,\r\n },\r\n];\r\nconst Radios = ({ error, value, options = defaultOptions, setValue, }) => {\r\n return (React.createElement(AnimateSharedLayout, null,\r\n React.createElement(S.Container, null, options.map((x) => {\r\n return (React.createElement(S.Item, { key: x.label, active: value !== undefined && x.value === value, invalid: error !== undefined, onClick: () => setValue(x.value) },\r\n React.createElement(S.Value, null),\r\n React.createElement(S.Label, null, x.label),\r\n value !== undefined && x.value === value && (React.createElement(S.BottomEffect, { layoutId: \"BottomEffect\" }))));\r\n }))));\r\n};\r\nexport default withMotionMax(Radios);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nimport { m } from 'framer-motion';\r\nconst Form = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n max-width: 750px;\r\n margin: 0 auto;\r\n width: 100%;\r\n line-height: 20px;\r\n\r\n @media ${from(Device.Tablet)} {\r\n position: relative;\r\n z-index: 1;\r\n }\r\n`;\r\nconst FormRow = styled.div `\r\n width: 100%;\r\n max-width: 304px;\r\n margin: 5px 0px;\r\n\r\n ${({ wide }) => wide &&\r\n css `\r\n max-width: 420px;\r\n `}\r\n\r\n ${({ split }) => split &&\r\n css `\r\n display: flex;\r\n flex-direction: row;\r\n flex-wrap: wrap;\r\n `};\r\n\r\n ${({ xCentered }) => xCentered &&\r\n css `\r\n display: flex;\r\n flex-direction: row;\r\n justify-content: center;\r\n `};\r\n`;\r\nconst FormControl = styled.div `\r\n padding: 5px 0px;\r\n margin: 0 auto;\r\n position: relative;\r\n\r\n ${({ fullWidth }) => fullWidth &&\r\n css `\r\n margin: unset;\r\n `}\r\n\r\n ${({ restrictWidth }) => restrictWidth &&\r\n css `\r\n max-width: 300px;\r\n width: 100%;\r\n `}\r\n\r\n ${({ center }) => center &&\r\n css `\r\n align-items: center;\r\n `}\r\n\r\n label {\r\n display: block;\r\n font-weight: bold;\r\n ${fonts.DaxPro.Bold};\r\n color: ${brand.grey.grey20};\r\n max-width: 100%;\r\n margin-bottom: 5px;\r\n }\r\n\r\n ${() => FormError} {\r\n display: none;\r\n }\r\n\r\n input {\r\n display: inline-block;\r\n width: 100%;\r\n border-radius: 8px;\r\n padding: 10px;\r\n border: 1px solid ${brand.black};\r\n padding-bottom: 10px;\r\n position: relative;\r\n\r\n &[type='number'] {\r\n max-width: 100px;\r\n text-align: center;\r\n }\r\n\r\n &:focus,\r\n &:active {\r\n outline: none;\r\n }\r\n }\r\n\r\n iframe {\r\n border-radius: 4px;\r\n }\r\n\r\n ${({ invalid }) => invalid &&\r\n css `\r\n input {\r\n border: 1px solid ${brand.red.base};\r\n }\r\n\r\n ${() => FormError} {\r\n display: block;\r\n }\r\n `}\r\n`;\r\nconst FormErrorHidden = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'exit',\r\n variants: {\r\n hidden: {\r\n y: 10,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n opacity: 1,\r\n },\r\n },\r\n})) `\r\n position: absolute;\r\n left: 0;\r\n top: 100%;\r\n width: 100%;\r\n\r\n ${() => FormError} {\r\n line-height: 13px;\r\n font-size: 12px;\r\n }\r\n`;\r\nconst FormError = styled.label `\r\n display: block;\r\n font-weight: bold;\r\n ${fonts.DaxPro.Bold};\r\n color: ${brand.red.base} !important;\r\n font-size: 14px;\r\n`;\r\nconst FormSub = styled.span `\r\n display: inline-block;\r\n vertical-align: bottom;\r\n margin-left: 3px;\r\n`;\r\nconst FormSplit = styled(Form) `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 10px;\r\n width: 100%;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n }\r\n\r\n ${() => FormRow} {\r\n max-width: unset;\r\n }\r\n`;\r\nexport const FormStyles = {\r\n Form,\r\n FormRow,\r\n FormControl,\r\n FormError,\r\n FormSub,\r\n FormSplit,\r\n FormErrorHidden,\r\n};\r\n","import React from 'react';\r\nimport { InfoIconStyles as S } from './InfoIcon.styles';\r\nimport { ReactComponent as Info } from '@img/ysp/icon-info.svg';\r\nconst InfoIcon = (props) => {\r\n return (React.createElement(S.Container, { ...props },\r\n React.createElement(S.InfoIcon, null,\r\n React.createElement(Info, null))));\r\n};\r\nexport default InfoIcon;\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgGroundwaterGround(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 398.424,\n height: 133.401\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 305\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 69\",\n d: \"M392.356.815c-3.852-.365-7.394 2.962-11.224 2.413-2.494-.357-4.629-2.327-7.148-2.29-2.48.037-4.616 2.028-7.1 2.053-2.415.025-4.532-1.817-6.946-1.879-2.8-.071-5.251 2.259-8.051 2.149-2.57-.1-4.646-2.219-7.176-2.681-3.973-.726-7.642 2.336-11.238 4.172-3.176-.325-5.62-3.511-8.812-3.405-2.831.094-4.924 2.745-7.68 3.392-4.281 1.005-8.37-3.05-12.745-2.581-2.148.23-4.013 1.524-6.073 2.165a10.31 10.31 0 01-6.722-.233c-2.6-1.011-5.273-3.121-7.851-2.053a19.951 19.951 0 00-2.348 1.507c-2.206 1.3-5.083.892-7.382-.239-1.845-.907-3.839-2.285-5.768-1.568-1.717.639-2.675 2.784-4.5 2.987-2.415.268-3.754-2.985-6.115-3.555-3.065-.74-5.544 3.32-8.686 3.043-1.849-.163-3.236-1.8-5.035-2.246a4.913 4.913 0 00-5.269 2.537l-78.6-.413 79.085.413-78.832-1.448c-3.38.058-3.47-1.893-6.311-2.162-3.852-.365-7.395 2.962-11.225 2.413-2.494-.358-4.628-2.327-7.147-2.29-2.48.037-4.616 2.027-7.1 2.053-2.415.025-4.532-1.818-6.946-1.879-2.8-.072-5.251 2.259-8.051 2.149-2.569-.1-4.646-2.22-7.175-2.681-3.973-.726-7.642 2.336-11.238 4.172-3.176-.325-5.621-3.512-8.812-3.405-2.831.094-4.924 2.745-7.679 3.392-4.281 1.005-8.37-3.05-12.745-2.581-2.147.23-4.013 1.524-6.074 2.164a10.3 10.3 0 01-6.721-.233c-2.6-1.01-5.273-3.121-7.852-2.053a20.235 20.235 0 00-2.347 1.507c-2.206 1.3-5.083.892-7.382-.238-1.845-.907-3.839-2.285-5.768-1.568-1.717.638-2.676 2.784-4.5 2.986-2.415.268-3.753-2.985-6.114-3.555-3.065-.74-5.544 3.321-8.686 3.044-1.849-.164-3.237-1.8-5.035-2.246A4.211 4.211 0 00.451 4.481v128.92h159.447l79.085-.158v.079h159.432V2.955c-3.381.06-3.218-1.872-6.059-2.14z\",\n fill: \"#c9c9c9\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 70\",\n d: \"M7.869 15.188a2.429 2.429 0 01.581-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.115 1.842-8.51 2.86-8.721-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 71\",\n d: \"M29.1 14.685a1.193 1.193 0 01-.042-.351 2.651 2.651 0 01.452-1.268 3.308 3.308 0 01.775-.948 2.392 2.392 0 012.446 0c.84.38-.727 4.429-2.6 3.557a1.7 1.7 0 01-1.031-.99z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 72\",\n d: \"M25.494 44.695a2.4 2.4 0 01.58-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.51 2.859-8.721-1.273a3.385 3.385 0 01.793-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 73\",\n d: \"M52.206 26.389a2.407 2.407 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.51 2.859-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 74\",\n d: \"M71.87 9.889a2.43 2.43 0 01.581-.4 5.3 5.3 0 012.664-.387 6.578 6.578 0 012.4.483c1.648.748 2.179 2.658 2.283 4.325.116 1.842-8.509 2.86-8.72-1.273a3.387 3.387 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 75\",\n d: \"M83.249 31.832a2.424 2.424 0 01.581-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.115 1.842-8.51 2.86-8.721-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 76\",\n d: \"M108.561 10.184a14.057 14.057 0 015.652-.457c2.4.461 2.68 3.745 2.581 5.854-.19 4.088-8.569 2.206-11.1 1.5-1.964-.544-.915-3.745-.146-4.863a5.009 5.009 0 013.013-2.034z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 77\",\n d: \"M126.009 28.616a1.81 1.81 0 01.4-.4 2.687 2.687 0 011.85-.387 3.416 3.416 0 011.666.483c1.144.749 1.513 2.659 1.585 4.326.08 1.842-5.908 2.859-6.055-1.273a4.478 4.478 0 01.554-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 78\",\n d: \"M134.247 9.889a2.432 2.432 0 01.581-.4 5.3 5.3 0 012.664-.387 6.582 6.582 0 012.4.483c1.648.748 2.179 2.658 2.283 4.325.115 1.842-8.51 2.86-8.72-1.273a3.387 3.387 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 79\",\n d: \"M.465 4.481a4.211 4.211 0 014.781-2.437c1.8.45 3.187 2.082 5.035 2.246 3.143.277 5.622-3.784 8.686-3.044 2.36.571 3.7 3.823 6.114 3.555 1.824-.2 2.782-2.348 4.5-2.986 1.929-.717 3.923.661 5.768 1.568 2.3 1.131 5.176 1.537 7.382.238a20.206 20.206 0 012.347-1.507c2.578-1.067 5.25 1.043 7.852 2.053a10.3 10.3 0 006.721.233c2.061-.64 3.926-1.934 6.074-2.164 4.374-.469 8.464 3.586 12.745 2.581 2.755-.647 4.848-3.3 7.679-3.392 3.191-.107 5.636 3.08 8.812 3.405 3.6-1.836 7.265-4.9 11.237-4.172 2.529.461 4.607 2.581 7.176 2.681 2.8.11 5.251-2.221 8.051-2.149 2.414.061 4.531 1.9 6.946 1.879 2.48-.026 4.615-2.016 7.1-2.053 2.519-.038 4.653 1.932 7.147 2.29 3.83.549 7.373-2.778 11.225-2.413 2.841.269 2.931 2.22 6.311 2.162\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 80\",\n d: \"M147.855 94.885a2.428 2.428 0 01.581-.4 5.308 5.308 0 012.664-.387 6.611 6.611 0 012.4.483c1.75.8 3.418 4.3 1.185 5.465-2.12 1.105-7.461.731-7.621-2.412a3.387 3.387 0 01.791-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 81\",\n d: \"M147.855 63.831a2.428 2.428 0 01.581-.4 5.308 5.308 0 012.664-.387 6.611 6.611 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.509 2.859-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 82\",\n d: \"M158.55 118.719a2.426 2.426 0 01.58-.4 5.312 5.312 0 012.665-.387 6.619 6.619 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.841-8.51 2.859-8.72-1.274a3.388 3.388 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 83\",\n d: \"M191.343 98.111a14.054 14.054 0 014.118 3.9c1.265 2.1-.993 4.5-2.628 5.833-3.168 2.591-7.369-4.9-8.54-7.249-.908-1.824 2.174-3.184 3.519-3.36a5.009 5.009 0 013.531.876z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 84\",\n d: \"M221.04 116.829a1.824 1.824 0 01.4-.4 2.679 2.679 0 011.85-.387 3.408 3.408 0 011.667.483c1.144.749 1.512 2.659 1.585 4.326.08 1.842-5.908 2.859-6.055-1.273a4.475 4.475 0 01.553-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 85\",\n d: \"M6.169 102.561a2.417 2.417 0 01.58-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.51 2.859-8.72-1.273a3.388 3.388 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 86\",\n d: \"M30.2 93.279a2.4 2.4 0 01.581-.4 5.3 5.3 0 012.664-.388 6.614 6.614 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.509 2.859-8.72-1.273a3.388 3.388 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 87\",\n d: \"M30.2 117.112a2.4 2.4 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.509 2.859-8.72-1.273a3.39 3.39 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 88\",\n d: \"M62.885 102.02a14.047 14.047 0 012.331 5.168c.376 2.419-2.624 3.784-4.643 4.4-3.914 1.2-4.961-7.327-5.153-9.946-.149-2.033 3.22-2.122 4.531-1.775a5.011 5.011 0 012.934 2.153z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 89\",\n d: \"M84.337 112.008a1.845 1.845 0 01.4-.4 2.685 2.685 0 011.85-.387 3.4 3.4 0 011.666.483c1.144.748 1.513 2.658 1.585 4.326.08 1.842-5.908 2.859-6.055-1.273a4.483 4.483 0 01.554-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 90\",\n d: \"M115.261 112.008a2.426 2.426 0 01.581-.4 5.3 5.3 0 012.665-.387 6.586 6.586 0 012.4.483c1.647.748 2.179 2.658 2.283 4.326.115 1.842-8.51 2.859-8.721-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 91\",\n d: \"M17.257 71.508a2.435 2.435 0 01.252.66 5.3 5.3 0 01-.26 2.68 6.584 6.584 0 01-1.042 2.216c-1.12 1.422-3.1 1.482-4.745 1.186-1.817-.328-.748-8.946 3.315-8.166a3.389 3.389 0 012.48 1.424z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 92\",\n d: \"M48.585 62.824a14.042 14.042 0 015.651-.456c2.405.46 2.68 3.744 2.582 5.854-.19 4.088-8.569 2.206-11.1 1.5-1.964-.544-.915-3.745-.146-4.863a5.01 5.01 0 013.013-2.035z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 93\",\n d: \"M78.386 78.259a1.826 1.826 0 01.4-.4 2.686 2.686 0 011.849-.387 3.417 3.417 0 011.666.484c1.144.749 1.513 2.659 1.585 4.326.08 1.842-5.908 2.859-6.055-1.273a4.479 4.479 0 01.555-2.75z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 94\",\n d: \"M107.443 47.909a2.411 2.411 0 01.58-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.51 2.859-8.72-1.273a3.389 3.389 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 95\",\n d: \"M119.628 70.313a2.426 2.426 0 01.581-.4 5.3 5.3 0 012.664-.387 6.594 6.594 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.116 1.842-8.509 2.86-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 96\",\n d: \"M83.114 61.467a16.758 16.758 0 01-1.106-1.185c-.787-.923-1.953-2.053-2.181-3.284a1.6 1.6 0 01.975-1.861 2.132 2.132 0 011.57.418 11.969 11.969 0 014.924 5.942 1.81 1.81 0 01.157.764c-.082 1.054-1.66 1.209-2.551.639a11.54 11.54 0 01-1.788-1.433z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 97\",\n d: \"M118.992 96.54c-.436.318-.891.612-1.358.887-1.044.617-2.357 1.572-3.609 1.585a1.6 1.6 0 01-1.666-1.28 2.129 2.129 0 01.681-1.475 11.964 11.964 0 016.7-3.832 1.813 1.813 0 01.779-.024c1.025.262.906 1.843.192 2.623a11.5 11.5 0 01-1.719 1.516z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 98\",\n d: \"M233.746 96.646a16.746 16.746 0 01-.431 1.563c-.373 1.153-.725 2.739-1.655 3.578a1.6 1.6 0 01-2.1.143 2.133 2.133 0 01-.467-1.556 11.965 11.965 0 012.484-7.307 1.8 1.8 0 01.568-.535c.941-.482 1.9.781 1.88 1.839a11.533 11.533 0 01-.279 2.275z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 99\",\n d: \"M208.861 67.047a2.431 2.431 0 01.581-.4 5.308 5.308 0 012.664-.387 6.614 6.614 0 012.4.483c1.75.8 3.418 4.3 1.185 5.465-2.12 1.105-7.461.731-7.621-2.412a3.387 3.387 0 01.791-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10,\n strokeWidth: 1.188\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 101\",\n d: \"M246.386 15.11a2.421 2.421 0 01.58-.4 5.313 5.313 0 012.665-.387 6.615 6.615 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.51 2.859-8.72-1.273a3.388 3.388 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 102\",\n d: \"M267.615 14.606a1.21 1.21 0 01-.042-.351 2.66 2.66 0 01.452-1.268 3.317 3.317 0 01.775-.948 2.39 2.39 0 012.446 0c.841.38-.726 4.429-2.6 3.556a1.693 1.693 0 01-1.031-.989z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 103\",\n d: \"M264.012 44.617a2.426 2.426 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.115 1.842-8.509 2.859-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 104\",\n d: \"M290.723 26.309a2.431 2.431 0 01.581-.4 5.3 5.3 0 012.664-.387 6.594 6.594 0 012.4.483c1.648.748 2.179 2.659 2.283 4.325.116 1.842-8.509 2.86-8.72-1.272a3.388 3.388 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 105\",\n d: \"M310.387 9.809a2.429 2.429 0 01.581-.4 5.311 5.311 0 012.665-.387 6.617 6.617 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.115 1.842-8.51 2.859-8.721-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 106\",\n d: \"M321.767 31.753a2.4 2.4 0 01.581-.4 5.3 5.3 0 012.664-.388 6.615 6.615 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.116 1.842-8.509 2.859-8.72-1.273a3.388 3.388 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 107\",\n d: \"M347.079 10.106a14.03 14.03 0 015.651-.457c2.4.461 2.68 3.745 2.582 5.854-.191 4.088-8.569 2.206-11.1 1.505-1.964-.545-.914-3.746-.146-4.864a5.008 5.008 0 013.013-2.038z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 108\",\n d: \"M364.526 28.537a1.805 1.805 0 01.4-.4 2.683 2.683 0 011.85-.387 3.412 3.412 0 011.667.483c1.144.749 1.512 2.659 1.584 4.326.08 1.842-5.908 2.859-6.054-1.273a4.475 4.475 0 01.553-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 109\",\n d: \"M372.764 9.809a2.429 2.429 0 01.581-.4 5.308 5.308 0 012.664-.387 6.613 6.613 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.115 1.842-8.509 2.859-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 110\",\n d: \"M238.983 4.403a4.211 4.211 0 014.781-2.437c1.8.45 3.187 2.083 5.035 2.246 3.143.277 5.622-3.784 8.686-3.043 2.36.57 3.7 3.823 6.115 3.555 1.824-.2 2.782-2.348 4.5-2.987 1.929-.717 3.923.661 5.768 1.568 2.3 1.131 5.176 1.537 7.382.239a19.951 19.951 0 012.348-1.507c2.577-1.068 5.25 1.042 7.851 2.053a10.31 10.31 0 006.722.233c2.06-.641 3.925-1.934 6.073-2.165 4.375-.469 8.464 3.586 12.745 2.581 2.756-.647 4.849-3.3 7.68-3.392 3.192-.106 5.636 3.08 8.812 3.405 3.6-1.836 7.265-4.9 11.238-4.172 2.529.462 4.606 2.581 7.176 2.681 2.8.11 5.25-2.22 8.05-2.149 2.414.062 4.531 1.9 6.946 1.879 2.48-.025 4.615-2.016 7.1-2.053 2.519-.038 4.653 1.933 7.148 2.29 3.83.549 7.372-2.778 11.224-2.413 2.841.269 2.678 2.2 6.059 2.141\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 111\",\n d: \"M386.372 94.806a2.4 2.4 0 01.581-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.75.8 3.418 4.3 1.185 5.466-2.121 1.1-7.461.73-7.622-2.412a3.389 3.389 0 01.791-2.75z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 112\",\n d: \"M386.372 63.752a2.4 2.4 0 01.581-.4 5.3 5.3 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.115 1.842-8.509 2.859-8.721-1.273a3.389 3.389 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 113\",\n d: \"M244.686 102.483a2.425 2.425 0 01.581-.4 5.3 5.3 0 012.664-.387 6.582 6.582 0 012.4.483c1.648.748 2.179 2.658 2.283 4.326.116 1.842-8.509 2.86-8.72-1.272a3.387 3.387 0 01.792-2.75z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 114\",\n d: \"M268.717 93.2a2.425 2.425 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.749 2.18 2.659 2.283 4.326.115 1.842-8.509 2.86-8.72-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 115\",\n d: \"M268.717 117.035a2.427 2.427 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.748 2.18 2.659 2.283 4.325.115 1.842-8.509 2.86-8.72-1.273a3.387 3.387 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 116\",\n d: \"M301.402 101.94a14.04 14.04 0 012.331 5.168c.376 2.419-2.624 3.784-4.643 4.4-3.914 1.2-4.961-7.327-5.152-9.946-.149-2.032 3.219-2.122 4.53-1.774a5 5 0 012.934 2.152z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 117\",\n d: \"M322.856 111.928a1.83 1.83 0 01.4-.4 2.686 2.686 0 011.849-.387 3.415 3.415 0 011.667.483c1.145.748 1.513 2.659 1.585 4.325.08 1.842-5.908 2.86-6.055-1.273a4.478 4.478 0 01.554-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 118\",\n d: \"M353.779 111.928a2.421 2.421 0 01.58-.4 5.312 5.312 0 012.665-.387 6.614 6.614 0 012.4.483c1.648.748 2.179 2.659 2.283 4.325.116 1.842-8.509 2.86-8.72-1.273a3.387 3.387 0 01.792-2.748z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 119\",\n d: \"M255.774 71.429a2.425 2.425 0 01.251.66 5.3 5.3 0 01-.259 2.68 6.621 6.621 0 01-1.042 2.216c-1.121 1.422-3.1 1.482-4.746 1.186-1.817-.327-.748-8.946 3.315-8.165a3.386 3.386 0 012.481 1.423z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 120\",\n d: \"M287.103 62.745a14.034 14.034 0 015.651-.457c2.4.461 2.68 3.745 2.581 5.854-.19 4.088-8.569 2.206-11.1 1.505-1.963-.544-.915-3.746-.146-4.863a5.006 5.006 0 013.014-2.039z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 121\",\n d: \"M316.903 78.18a1.811 1.811 0 01.4-.4 2.682 2.682 0 011.85-.387 3.409 3.409 0 011.667.483c1.144.749 1.512 2.659 1.585 4.326.08 1.842-5.909 2.859-6.055-1.273a4.477 4.477 0 01.553-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 122\",\n d: \"M345.96 47.831a2.428 2.428 0 01.581-.4 5.3 5.3 0 012.664-.387 6.6 6.6 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.116 1.842-8.509 2.86-8.72-1.273a3.388 3.388 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 123\",\n d: \"M358.144 70.233a2.447 2.447 0 01.581-.4 5.311 5.311 0 012.665-.387 6.614 6.614 0 012.4.483c1.648.749 2.179 2.659 2.283 4.326.115 1.842-8.51 2.859-8.721-1.273a3.387 3.387 0 01.792-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 124\",\n d: \"M321.631 61.389a17.456 17.456 0 01-1.106-1.185c-.787-.923-1.953-2.053-2.181-3.284a1.6 1.6 0 01.975-1.861 2.139 2.139 0 011.571.418 11.963 11.963 0 014.924 5.943 1.8 1.8 0 01.158.763c-.082 1.054-1.661 1.209-2.551.639a11.576 11.576 0 01-1.79-1.433z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 125\",\n d: \"M357.509 96.461c-.436.318-.891.611-1.357.886-1.044.617-2.358 1.572-3.61 1.585a1.6 1.6 0 01-1.666-1.28 2.135 2.135 0 01.682-1.475 11.969 11.969 0 016.7-3.832 1.817 1.817 0 01.78-.024c1.024.262.906 1.843.191 2.623a11.55 11.55 0 01-1.72 1.517z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 126\",\n d: \"M172.32 41.4a2.421 2.421 0 01.58-.4 5.312 5.312 0 012.665-.387 6.6 6.6 0 012.4.483c1.648.748 2.179 2.659 2.283 4.326.116 1.842-8.51 2.86-8.721-1.273a3.384 3.384 0 01.793-2.749z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 127\",\n d: \"M230.461 35.921a14.039 14.039 0 014.118 3.9c1.265 2.1-.994 4.5-2.628 5.834-3.168 2.591-7.369-4.9-8.54-7.25-.908-1.824 2.174-3.184 3.519-3.36a5.006 5.006 0 013.531.876z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }))));\n}\n\nexport default __webpack_public_path__ + \"985706f9081b4c9b6cbf5c06fecec013.svg\";\nexport { SvgGroundwaterGround as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n width: min(400px, 90vw);\r\n position: relative;\r\n margin-bottom: 35px;\r\n overflow: hidden;\r\n\r\n svg {\r\n display: block;\r\n width: 100%;\r\n }\r\n`;\r\nconst Ground = styled.div ``;\r\nconst Water = styled(m.div).attrs(({ hasAnimatedIn }) => ({\r\n initial: 'hidden',\r\n animate: hasAnimatedIn ? 'ripple' : 'visible',\r\n variants: {\r\n hidden: {\r\n y: '100%',\r\n },\r\n visible: {\r\n y: ['100%', '75%', '45%', '25%', '15%', '10%', '5%', '0%'],\r\n },\r\n ripple: {\r\n y: ['0%', '5%', '2%', '3%', '4%', '2%', '-1%', '-2%', '1%', '0%'],\r\n transition: {\r\n duration: 10,\r\n repeat: Infinity,\r\n type: 'tween',\r\n },\r\n },\r\n },\r\n transition: {\r\n duration: 4,\r\n type: 'tween',\r\n },\r\n})) `\r\n position: absolute;\r\n left: 0;\r\n\r\n ${({ height }) => height * 20 > 100\r\n ? css `\r\n top: calc(100% - 50px);\r\n `\r\n : css `\r\n top: calc(${height * 20}px - 15px);\r\n `}\r\n\r\n width: 100%;\r\n`;\r\nconst ExcavationOverlay = styled.div `\r\n position: absolute;\r\n top: 0;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n width: 75px;\r\n ${({ height }) => height !== undefined &&\r\n css `\r\n height: min(${height * 20}px, 100px);\r\n `};\r\n background-color: ${brand.white};\r\n border: 2px solid ${brand.black};\r\n border-top: none;\r\n padding: 5px 7px;\r\n z-index: 1;\r\n\r\n display: flex;\r\n align-items: center;\r\n gap: 5px;\r\n\r\n span {\r\n color: ${brand.primary.alt};\r\n ${fonts.DaxPro.Medium};\r\n font-size: 13px;\r\n }\r\n`;\r\nconst Arrow = styled.div `\r\n position: relative;\r\n height: calc(100% - 5px);\r\n width: 1px;\r\n background-color: ${brand.primary.alt};\r\n\r\n &::before {\r\n content: '';\r\n position: absolute;\r\n top: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 0%, 0% 100%, 100% 100%);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n\r\n &::after {\r\n content: '';\r\n position: absolute;\r\n bottom: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 100%, 0 0, 100% 0);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n`;\r\nexport const GroundwaterStyles = {\r\n Container,\r\n Ground,\r\n Water,\r\n ExcavationOverlay,\r\n Arrow,\r\n};\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgGroundwaterWater(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 397.991,\n height: 133.793\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 304\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Union 4\",\n d: \"M244.556 133.793h-94.675v-.162L0 133.793.055 1.006l159.166-.13v.1l79.518-.091V.862l159.252.04v132.891z\",\n fill: \"#72c6df\",\n opacity: 0.549\n }), /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 303\",\n fill: \"none\",\n stroke: \"#137ff6\",\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 39\",\n d: \"M.042 1h238.453\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 41\",\n d: \"M48.086 6.413h63.608\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 50\",\n d: \"M285.602 6.413h63.608\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 42\",\n d: \"M54.853 11.827h50.074\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 49\",\n d: \"M292.368 11.827h50.074\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 43\",\n d: \"M61.62 17.24h36.541\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 48\",\n d: \"M299.135 17.24h36.541\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 44\",\n d: \"M68.387 22.653h23.007\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 47\",\n d: \"M305.902 22.653h23.007\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 45\",\n d: \"M73.8 28.067h12.18\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 46\",\n d: \"M311.315 28.067h12.18\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 40\",\n d: \"M238.234 1h159.697\"\n })))));\n}\n\nexport default __webpack_public_path__ + \"6ab64ef77f5781d0245f7c0fc4c1707e.svg\";\nexport { SvgGroundwaterWater as ReactComponent };","import React, { useEffect, useState } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { Tab } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport { GroundwaterStyles as S } from './Groundwater.styles';\r\nimport { ReactComponent as Ground } from '@img/ysp/groundwater-ground.svg';\r\nimport { ReactComponent as Water } from '@img/ysp/groundwater-water.svg';\r\nimport { withMotion } from '@hoc/withMotion';\r\nconst Groundwater = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const [hasAnimatedIn, setHasAnimatedIn] = useState(false);\r\n useEffect(() => {\r\n setTimeout(() => {\r\n setHasAnimatedIn(true);\r\n }, 5000);\r\n }, []);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'conditions',\r\n beforeNext: () => dispatch({ type: 'validate-groundwater' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n state.tab === Tab.YourSolutionPlus ? (React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) })))) : (React.createElement(\"h2\", null, state.labels['heading_groundWater'])),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.Ground, null,\r\n React.createElement(Ground, null)),\r\n React.createElement(S.Water, { height: state.form.depth || 1.5, hasAnimatedIn: hasAnimatedIn },\r\n React.createElement(Water, null)),\r\n React.createElement(S.ExcavationOverlay, { height: state.form.depth || 1.5 },\r\n React.createElement(S.Arrow, null),\r\n React.createElement(\"span\", null,\r\n state.form.depth,\r\n \"m\"))),\r\n React.createElement(FormStyles.FormRow, { xCentered: true },\r\n React.createElement(Radios, { error: state.errors['groundwaterPresent'], value: state.form.groundwaterPresent, setValue: (value) => setFormField('groundwaterPresent', value) })))));\r\n};\r\nexport default withMotion(Groundwater);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n position: relative;\r\n width: 100%;\r\n max-width: 400px;\r\n margin: 0 auto 45px auto;\r\n overflow: hidden;\r\n\r\n svg {\r\n display: block;\r\n width: 100%;\r\n }\r\n`;\r\nconst Ground = styled.div ``;\r\nconst Water = styled.div `\r\n position: absolute;\r\n left: 0;\r\n transition: top 0.2s ease-in-out;\r\n\r\n ${({ height }) => css `\r\n top: ${height * 20 <= 5 ? 5 : height * 20}px;\r\n `}\r\n\r\n width: 100%;\r\n`;\r\nconst ExcavationOverlay = styled.div `\r\n position: absolute;\r\n top: 0;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n width: 75px;\r\n ${({ height }) => height !== undefined &&\r\n css `\r\n height: min(${height * 20}px, 100px);\r\n `};\r\n background-color: ${brand.white};\r\n border: 2px solid ${brand.black};\r\n border-top: none;\r\n padding: 5px 7px;\r\n z-index: 1;\r\n\r\n display: flex;\r\n align-items: center;\r\n gap: 5px;\r\n\r\n span {\r\n color: ${brand.primary.alt};\r\n ${fonts.DaxPro.Medium};\r\n font-size: 13px;\r\n }\r\n`;\r\nconst Arrow = styled.div `\r\n position: relative;\r\n height: calc(100% - 5px);\r\n width: 1px;\r\n background-color: ${brand.primary.alt};\r\n\r\n &::before {\r\n content: '';\r\n position: absolute;\r\n top: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 0%, 0% 100%, 100% 100%);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n\r\n &::after {\r\n content: '';\r\n position: absolute;\r\n bottom: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 100%, 0 0, 100% 0);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n`;\r\nexport const GroundwaterDepthStyles = {\r\n Container,\r\n Ground,\r\n Water,\r\n ExcavationOverlay,\r\n Arrow,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n border-radius: 5px;\r\n border: 2px solid ${brand.grey.grey35};\r\n display: grid;\r\n grid-template-columns: 1fr 25px;\r\n overflow: hidden;\r\n`;\r\nconst Input = styled.input `\r\n background-color: ${brand.white};\r\n transition: background-color 0.2s ease-in-out;\r\n width: 100%;\r\n && {\r\n border: none;\r\n }\r\n padding: 5px 7px;\r\n text-align: center;\r\n\r\n &:disabled {\r\n background-color: ${brand.grey.grey55};\r\n opacity: 0.7;\r\n cursor: help;\r\n }\r\n`;\r\nconst EndSection = styled.div `\r\n background-color: ${brand.grey.grey89};\r\n height: 100%;\r\n width: 100%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n border-left: 2px solid ${brand.grey.grey55};\r\n font-size: 15px;\r\n ${fonts.DaxPro.Regular};\r\n user-select: none;\r\n`;\r\nexport const InlineNumericalInputStyles = {\r\n Container,\r\n EndSection,\r\n Input,\r\n};\r\n","import Decimal from 'decimal.js-light';\r\nimport React, { useState } from 'react';\r\nimport { InlineNumericalInputStyles as S } from './InlineNumericalInput.styles';\r\nconst InlineNumericalInput = ({ unit, value, onChange, min, max, disabled, lock, absoluteBounds, }) => {\r\n const [hasFocus, setHasFocus] = useState(false);\r\n return (React.createElement(S.Container, { title: disabled\r\n ? `You cannot change the value of the first entry.\\nValues are calculated as 'depth from top' - therefore, the first entry must be 0.`\r\n : undefined },\r\n React.createElement(S.Input, { onFocus: () => {\r\n lock && lock(true);\r\n setHasFocus(true);\r\n }, onBlur: () => {\r\n lock && lock(false);\r\n setHasFocus(false);\r\n if (value && !value.toString().includes('.')) {\r\n onChange(`${value}.0`);\r\n }\r\n else if (value === undefined) {\r\n onChange('0.0');\r\n }\r\n }, min: min !== undefined ? (absoluteBounds ? min : new Decimal(min).add(0.1).toNumber()) : 0.1, max: max !== undefined\r\n ? absoluteBounds\r\n ? max\r\n : new Decimal(max).sub(0.1).toNumber()\r\n : undefined, step: 0.1, type: \"number\", onChange: (e) => {\r\n onChange(e.currentTarget.value);\r\n }, readOnly: disabled, disabled: disabled, value: disabled\r\n ? 0\r\n : !hasFocus\r\n ? value && value.toString().includes('.')\r\n ? value\r\n : `${value}.0`\r\n : undefined }),\r\n React.createElement(S.EndSection, null, unit)));\r\n};\r\nexport default InlineNumericalInput;\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { GroundwaterDepthStyles as S } from './GroundwaterDepth.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport InlineNumericalInput from '../../SoilProfiles/InlineNumericalInput/InlineNumericalInput';\r\nimport { Tab } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { ReactComponent as Ground } from '@img/ysp/groundwater-ground.svg';\r\nimport { ReactComponent as Water } from '@img/ysp/groundwater-water.svg';\r\nimport { withMotion } from '@hoc/withMotion';\r\nconst GroundwaterDepth = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'conditions',\r\n beforeNext: () => dispatch({ type: 'validate-groundwater-depth' }),\r\n },\r\n });\r\n }, []);\r\n const handleDepthChange = (value) => {\r\n let floatValue = parseFloat(value);\r\n if (floatValue > 99999) {\r\n floatValue = 99999;\r\n }\r\n if (value === '' || floatValue < 0) {\r\n setFormField('groundwaterDepth', undefined);\r\n }\r\n else {\r\n setFormField('groundwaterDepth', floatValue);\r\n }\r\n };\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n state.tab === Tab.YourSolutionPlus ? (React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['groundwaterDepth.heading']),\r\n state.labels['groundwaterDepth.tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['groundwaterDepth.tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) })))) : (React.createElement(\"h2\", null, state.labels['heading_groundwaterDepth'])),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.Ground, null,\r\n React.createElement(Ground, null)),\r\n React.createElement(S.Water, { height: Math.min(state.form.groundwaterDepth || 0, 6.7) },\r\n React.createElement(Water, null)),\r\n React.createElement(S.ExcavationOverlay, { height: state.form.depth || 1.5 },\r\n React.createElement(S.Arrow, null),\r\n React.createElement(\"span\", null,\r\n state.form.depth,\r\n \"m\"))),\r\n React.createElement(FormStyles.FormControl, { center: true, invalid: state.errors['groundwaterDepth'] !== undefined },\r\n React.createElement(\"label\", { htmlFor: \"txtDepth\" }, \"Depth\"),\r\n React.createElement(FormStyles.FormError, null, \"Please enter a depth.\"),\r\n React.createElement(InlineNumericalInput, { unit: \"m\", onChange: (v) => handleDepthChange(v.toString()), value: state.form.groundwaterDepth === undefined ? 0 : state.form.groundwaterDepth, min: 0, absoluteBounds: true })))));\r\n};\r\nexport default withMotion(GroundwaterDepth);\r\n","export default __webpack_public_path__ + \"f2c28e70c46c000389e780b11a10dcaa.png\";","export default __webpack_public_path__ + \"bae9d79af8f5afaa09c08d99a15de707.png\";","export default __webpack_public_path__ + \"9f2440b1368818a66612257f3471592c.png\";","export default __webpack_public_path__ + \"ae80959b2fb3b0d88e0a3abc336e26be.png\";","export default __webpack_public_path__ + \"56cf6a53ea00ea83d8932e20f767ae2d.png\";","export default __webpack_public_path__ + \"ac32ac1cb5e2ef1b9003579d5bbedeea.png\";","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport LooseGround from '@img/ysp/materials/loose-ground.png';\r\nimport SoftClay from '@img/ysp/materials/soft-clay.png';\r\nimport LooseSand from '@img/ysp/materials/loose-sand.png';\r\nimport Peat from '@img/ysp/materials/peat.png';\r\nimport Silt from '@img/ysp/materials/silt.png';\r\nimport LooseGravel from '@img/ysp/materials/loose-gravel.png';\r\nconst ProblematicGround = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'conditions',\r\n beforeNext: () => dispatch({ type: 'validate-problematic-ground' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading_problematic']),\r\n React.createElement(FormStyles.FormRow, { xCentered: true },\r\n React.createElement(Radios, { value: state.form.problematicGround, error: state.errors['problematicGround'], setValue: (value) => setFormField('problematicGround', value) })),\r\n React.createElement(SharedStyles.Materials, null,\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${LooseGround}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Very Loose or Loose MADE GROUND\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${SoftClay}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Very Soft or Soft CLAY\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${LooseSand}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Very Loose or Loose SAND\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Peat}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"PEAT\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Silt}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"SILT\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${LooseGravel}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Very Loose GRAVEL\"))))));\r\n};\r\nexport default ProblematicGround;\r\n","export default __webpack_public_path__ + \"f2c28e70c46c000389e780b11a10dcaa.png\";","export default __webpack_public_path__ + \"4585c93819279bdcb0ccf9289b3d07af.png\";","export default __webpack_public_path__ + \"4d657f2ac0e6c9a7ca068cdb2e02fe02.png\";","export default __webpack_public_path__ + \"f0c34a24874b905b5b7e22ad8fb2c92e.png\";","export default __webpack_public_path__ + \"5eec90be09103fd4c5f36e84cd099462.png\";","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SoilType } from '@ys/Context/types';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport Road from '@img/ysp/materials/road.png';\r\nimport DenseSand from '@img/ysp/materials/dense-sand.png';\r\nimport Rock from '@img/ysp/materials/rock.png';\r\nimport LooseGravel from '@img/ysp/materials/loose-gravel.png';\r\nimport CohesiveFill from '@img/ysp/materials/cohesive-fill.png';\r\nimport StiffClay from '@img/ysp/materials/stiff-clay.png';\r\nconst SoilTypes = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'conditions',\r\n beforeNext: () => dispatch({ type: 'validate-soil-type' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading_predominant']),\r\n React.createElement(FormStyles.FormRow, { xCentered: true },\r\n React.createElement(Radios, { value: state.form.soilType, error: state.errors['soilType'], setValue: (value) => setFormField('soilType', value), options: [\r\n {\r\n label: 'Granular',\r\n value: SoilType.Granular,\r\n },\r\n {\r\n label: 'Cohesive',\r\n value: SoilType.Cohesive,\r\n },\r\n ] })),\r\n React.createElement(SharedStyles.Materials, { desktop: true },\r\n React.createElement(SharedStyles.MaterialContainer, null,\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Road}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Well Compacted MADE GROUND/ ROAD CONSTRUCTION\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${DenseSand}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Medium Dense, Dense or Very Dense SAND\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Rock}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"ROCK\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${LooseGravel}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Loose, Medium Dense, Dense and Very Dense GRAVEL\"))),\r\n React.createElement(SharedStyles.MaterialContainer, null,\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${CohesiveFill}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Cohesive Fill\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${StiffClay}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Soft-Firm, Firm, Stiff or Very Stiff CLAY\")))),\r\n React.createElement(SharedStyles.Materials, { mobile: true },\r\n React.createElement(SharedStyles.MaterialContainer, null,\r\n React.createElement(SharedStyles.MaterialTitle, null, \"Granular Soils:\"),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Road}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Well Compacted MADE GROUND/ ROAD CONSTRUCTION\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${DenseSand}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Medium Dense, Dense or Very Dense SAND\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${Rock}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"ROCK\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${LooseGravel}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Loose, Medium Dense, Dense and Very Dense GRAVEL\"))),\r\n React.createElement(SharedStyles.MaterialContainer, null,\r\n React.createElement(SharedStyles.MaterialTitle, null, \"Cohesive Soils:\"),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${CohesiveFill}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Cohesive Fill\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { style: { backgroundImage: `url('${StiffClay}')` } }),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Soft-Firm, Firm, Stiff or Very Stiff CLAY\")))))));\r\n};\r\nexport default SoilTypes;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconPoint(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 7 7\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Polygon 6\",\n d: \"M3.5 7L0 0h7z\",\n fill: \"#6f9d20\"\n })));\n}\n\nexport default __webpack_public_path__ + \"62c84f5566feadc0a39e0d716a7856ac.svg\";\nexport { SvgIconPoint as ReactComponent };","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconCheck(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"none\",\n strokeWidth: 2,\n viewBox: \"0 0 24 24\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M20 6L9 17l-5-5\"\n })));\n}\n\nexport default __webpack_public_path__ + \"0a595e8af8e9ec113af8f5951a69bf2e.svg\";\nexport { SvgIconCheck as ReactComponent };","import brand from '@helpers/brand';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nimport Point from '@img/ysp/icon-point.svg';\r\nconst Container = styled.div `\r\n position: relative;\r\n width: 100%;\r\n max-width: 400px;\r\n margin: 0 auto 45px auto;\r\n`;\r\nconst Label = styled.div `\r\n position: absolute;\r\n top: -3px;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n color: ${brand.primary.light};\r\n font-size: 14px;\r\n font-weight: bold;\r\n display: flex;\r\n flex-direction: row;\r\n align-items: center;\r\n z-index: 2;\r\n padding: 7px 0px;\r\n top: -3px;\r\n user-select: none;\r\n\r\n @media ${from(Device.Tablet)} {\r\n top: 3px;\r\n }\r\n\r\n svg {\r\n display: block;\r\n fill: ${brand.primary.light};\r\n width: 7px;\r\n height: 16px;\r\n margin-right: 4px;\r\n }\r\n`;\r\nconst Indicator = styled.div `\r\n width: 1px;\r\n background-color: ${brand.primary.light};\r\n margin-right: 4px;\r\n position: relative;\r\n height: 100%;\r\n\r\n &:before,\r\n &:after {\r\n content: '';\r\n width: 7px;\r\n height: 7px;\r\n background-image: url(${Point});\r\n position: absolute;\r\n }\r\n\r\n &:before {\r\n content: '';\r\n bottom: 100%;\r\n left: 50%;\r\n transform: translateX(-50%) rotate(180deg);\r\n }\r\n\r\n &:after {\r\n content: '';\r\n top: 100%;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n }\r\n`;\r\nexport const DepthStyles = {\r\n Container,\r\n Label,\r\n Indicator,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n display: flex;\r\n gap: 15px;\r\n align-items: center;\r\n font-size: 14px;\r\n user-select: none;\r\n cursor: pointer;\r\n width: max-content;\r\n max-width: 100%;\r\n transition: opacity 0.3s ease-in-out;\r\n\r\n ${({ disabled }) => disabled &&\r\n css `\r\n opacity: 0.7;\r\n pointer-events: none;\r\n cursor: not-allowed;\r\n `}\r\n`;\r\nconst Box = styled.div `\r\n width: 25px;\r\n height: 25px;\r\n background-color: ${brand.white};\r\n border: 1px solid ${brand.black};\r\n position: relative;\r\n`;\r\nconst Check = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n y: 10,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.35,\r\n },\r\n})) `\r\n width: 100%;\r\n height: 100%;\r\n color: ${brand.primary.alt};\r\n\r\n svg {\r\n width: calc(100% + 10px);\r\n height: calc(100% + 10px);\r\n display: block;\r\n stroke-width: 3px;\r\n top: -7px;\r\n left: 0px;\r\n position: relative;\r\n }\r\n`;\r\nexport const CheckboxStyles = {\r\n Container,\r\n Box,\r\n Check,\r\n};\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgCloseWhite(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 22.628 22.627\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 32606\",\n opacity: 0.5,\n fill: \"none\",\n stroke: \"currentcolor\",\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 3112\",\n d: \"M21.92.707L.707 21.92\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 3113\",\n d: \"M21.92 21.92L.707.707\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"c905c30f36622bc4bedce26c1e2ace87.svg\";\nexport { SvgCloseWhite as ReactComponent };","import React from 'react';\r\nimport { CheckboxStyles as S } from './Checkbox.styles';\r\nimport { ReactComponent as Check } from '@img/ysp/icon-check.svg';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport { withMotion } from '@hoc/withMotion';\r\nconst Checkbox = ({ label, value, onChange, disabled = false, }) => {\r\n return (React.createElement(S.Container, { onClick: () => onChange(), disabled: disabled },\r\n React.createElement(S.Box, null,\r\n React.createElement(AnimatePresence, null, value && (React.createElement(S.Check, null,\r\n React.createElement(Check, null))))),\r\n label));\r\n};\r\nexport default withMotion(Checkbox);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n display: flex;\r\n gap: 25px;\r\n align-items: center;\r\n`;\r\nconst Label = styled.div `\r\n font-size: 18px;\r\n ${fonts.DaxPro.Medium};\r\n`;\r\nconst ToggleWrapper = styled.div `\r\n background-color: ${brand.grey.grey89};\r\n border-radius: 15px;\r\n width: 75px;\r\n height: 31px;\r\n position: relative;\r\n cursor: pointer;\r\n transition: background-color 0.2s ease-in-out;\r\n\r\n ${({ active }) => active &&\r\n css `\r\n background-color: ${brand.divisionTags.sandhurst};\r\n `}\r\n`;\r\nconst ToggleBall = styled.div `\r\n width: 23px;\r\n height: 23px;\r\n border-radius: 50%;\r\n background-color: ${brand.white};\r\n position: absolute;\r\n top: 4px;\r\n transition: left 0.25s ease-in-out, background-color 0.2s ease-in-out;\r\n\r\n ${({ active }) => active\r\n ? css `\r\n left: calc(100% - 28px);\r\n `\r\n : css `\r\n left: 5px;\r\n `}\r\n`;\r\nexport const ToggleStyles = {\r\n Container,\r\n Label,\r\n ToggleWrapper,\r\n ToggleBall,\r\n};\r\n","import React from 'react';\r\nimport { ToggleStyles as S } from './Toggle.styles';\r\nconst Toggle = ({ label, value, onChange }) => {\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.Label, null, label),\r\n React.createElement(S.ToggleWrapper, { active: value, onClick: () => onChange(!value) },\r\n React.createElement(S.ToggleBall, { active: value }))));\r\n};\r\nexport default Toggle;\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { WYSIWYGStyles } from '../../../Shared.styles';\r\nconst Container = styled.div `\r\n display: grid;\r\n grid-template-columns: repeat(9, 1fr); // Description spans 2 so add an extra one //\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n overflow-x: auto;\r\n padding-bottom: 10px;\r\n margin-bottom: 10px;\r\n\r\n &::-webkit-scrollbar {\r\n height: 4px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.grey.grey89};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n }\r\n\r\n ${() => ColumnWrapper} {\r\n min-width: 120px;\r\n }\r\n\r\n ${() => WideColumnWrapper} {\r\n min-width: 200px;\r\n }\r\n }\r\n`;\r\nconst ColumnWrapper = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n height: max-content;\r\n max-height: 100%;\r\n grid-column: span 1;\r\n`;\r\nconst WideColumnWrapper = styled(ColumnWrapper) `\r\n grid-column: span 2;\r\n`;\r\nconst HeaderWrapper = styled.div `\r\n display: grid;\r\n grid-template-rows: 1fr 1fr;\r\n height: 100%;\r\n min-height: 107px;\r\n\r\n ${({ last }) => last &&\r\n css `\r\n max-height: 78px;\r\n `};\r\n`;\r\nconst Header = styled.div `\r\n padding: 5px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n border: 1px solid ${brand.white};\r\n background-color: ${brand.primary.alt};\r\n font-size: 14px;\r\n color: ${brand.white};\r\n text-align: center;\r\n\r\n sub {\r\n font-size: 11px;\r\n position: relative;\r\n bottom: -3px;\r\n }\r\n\r\n ${({ bold }) => bold &&\r\n css `\r\n ${fonts.DaxPro.Medium};\r\n `};\r\n`;\r\nconst HeaderInner = styled.div ``;\r\nconst SmallHeader = styled(Header) `\r\n grid-row: span 1;\r\n`;\r\nconst LargeHeader = styled(Header) `\r\n grid-row: span 2;\r\n`;\r\nconst FieldRow = styled.div `\r\n width: 100%;\r\n border: 1px solid ${brand.white};\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n`;\r\nconst FieldInput = styled.input `\r\n padding: 6px;\r\n border: none;\r\n width: 100%;\r\n position: relative;\r\n transition: outline-color 0.1s ease-in-out;\r\n outline: 2px solid transparent;\r\n\r\n &::-webkit-outer-spin-button,\r\n &::-webkit-inner-spin-button {\r\n margin-left: 5px;\r\n }\r\n\r\n &::selection {\r\n color: ${brand.white};\r\n background-color: ${brand.divisionTags.sandhurst};\r\n }\r\n\r\n &:focus {\r\n outline-color: ${brand.divisionTags.sandhurst};\r\n }\r\n\r\n ${({ align }) => {\r\n switch (align) {\r\n default:\r\n case 'left':\r\n return css `\r\n text-align: start;\r\n `;\r\n case 'center':\r\n return css `\r\n text-align: center;\r\n `;\r\n case 'right':\r\n return css `\r\n text-align: end;\r\n `;\r\n }\r\n}}\r\n\r\n ${({ bg }) => {\r\n switch (bg) {\r\n default:\r\n case 'green':\r\n return css `\r\n background-color: ${brand.ysp.input};\r\n `;\r\n case 'white':\r\n return css `\r\n background-color: ${brand.white};\r\n `;\r\n case 'grey':\r\n return css `\r\n background-color: ${brand.grey.grey89};\r\n `;\r\n }\r\n}}\r\n`;\r\nconst TopSection = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 10px;\r\n margin-bottom: 25px;\r\n margin-top: 35px;\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 23px;\r\n`;\r\nconst Disclaimer = styled.div `\r\n font-size: 20px;\r\n line-height: 22px;\r\n\r\n p:last-child {\r\n margin-bottom: 0;\r\n }\r\n`;\r\nconst Wrapper = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\nconst Modal = styled(m.div).attrs(({ active }) => ({\r\n initial: 'hidden',\r\n animate: active ? 'visible' : 'hidden',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n },\r\n visible: {\r\n opacity: 1,\r\n },\r\n },\r\n})) `\r\n position: fixed;\r\n z-index: 1001;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: rgba(0, 0, 0, 0.2);\r\n opacity: 0;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n ${({ active }) => !active &&\r\n css `\r\n pointer-events: none;\r\n `}\r\n`;\r\nconst ModalInner = styled(m.div).attrs(() => ({\r\n variants: {\r\n hidden: {\r\n y: 50,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n ${WYSIWYGStyles}\r\n position: relative;\r\n margin-top: 20px; // For the close button\r\n background-color: ${brand.white};\r\n border-top: 4px solid ${brand.divisionTags.sandhurst};\r\n padding: 30px 20px;\r\n display: flex;\r\n flex-direction: column;\r\n max-width: 500px;\r\n max-height: 400px;\r\n gap: 15px;\r\n width: 100%;\r\n`;\r\nconst ModalTitle = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 18px;\r\n`;\r\nconst ModalText = styled.div `\r\n ${fonts.DaxPro.Light};\r\n font-size: 16px;\r\n line-height: 20px;\r\n overflow-y: auto;\r\n padding-right: 5px;\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.white};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n`;\r\nconst Close = styled.div `\r\n position: absolute;\r\n right: 0;\r\n top: -24px;\r\n display: flex;\r\n cursor: pointer;\r\n\r\n svg {\r\n color: ${brand.white};\r\n width: 15px;\r\n height: 15px;\r\n\r\n g {\r\n stroke-width: 4px;\r\n opacity: 1;\r\n }\r\n }\r\n`;\r\nconst BlankRows = styled.div `\r\n grid-row: span 2;\r\n border: 1px solid ${brand.white};\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n max-height: 80px;\r\n }\r\n`;\r\nconst Reset = styled.div `\r\n display: flex;\r\n height: 100%;\r\n cursor: pointer;\r\n position: absolute;\r\n top: 0;\r\n left: 100%;\r\n width: 25px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n opacity: 0.5;\r\n transition: opacity 0.25s ease-in-out;\r\n\r\n &:hover {\r\n opacity: 1;\r\n }\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n height: 30px;\r\n width: max-content;\r\n }\r\n\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n`;\r\nconst LastRowWrapper = styled.div `\r\n position: relative;\r\n`;\r\nexport const SoilInfoTableStyles = {\r\n Container,\r\n ColumnWrapper,\r\n HeaderWrapper,\r\n Header,\r\n SmallHeader,\r\n LargeHeader,\r\n WideColumnWrapper,\r\n HeaderInner,\r\n FieldRow,\r\n FieldInput,\r\n TopSection,\r\n Title,\r\n Wrapper,\r\n Disclaimer,\r\n Modal,\r\n ModalInner,\r\n ModalTitle,\r\n ModalText,\r\n Close,\r\n Reset,\r\n BlankRows,\r\n LastRowWrapper,\r\n};\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgResetThick(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 25 20\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12.5 11.25h-5V10a7.5 7.5 0 117.5 7.5h-1.25V20H15A10 10 0 105 10v1.25H0l6.25 6.25z\",\n fill: \"currentcolor\",\n fillRule: \"evenodd\"\n })));\n}\n\nexport default __webpack_public_path__ + \"92c8bfefcf6aa4b3e1b3a536bbe0747c.svg\";\nexport { SvgResetThick as ReactComponent };","var _path, _path2;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgPlusThick(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n \"data-name\": \"Group 238\",\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 15 15\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 53\",\n fill: \"none\",\n stroke: \"currentcolor\",\n strokeWidth: 3,\n d: \"M7.5 0v15\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Line 54\",\n fill: \"none\",\n stroke: \"currentcolor\",\n strokeWidth: 3,\n d: \"M15 7.5H0\"\n })));\n}\n\nexport default __webpack_public_path__ + \"ec8f44fbe85df1f906767b175f594b8b.svg\";\nexport { SvgPlusThick as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { ButtonReset } from '@helpers/global';\r\nimport { from, Device, until } from '@helpers/media';\r\nimport { darken, lighten } from 'polished';\r\nimport styled from 'styled-components';\r\nconst Container = styled.button `\r\n ${ButtonReset}\r\n display: flex;\r\n gap: 15px;\r\n align-items: center;\r\n user-select: none;\r\n\r\n padding: 10px 15px;\r\n &[data-size='wide'] {\r\n padding: 10px 25px;\r\n }\r\n\r\n border-radius: 8px;\r\n width: max-content;\r\n max-width: 100%;\r\n\r\n ${fonts.DaxPro.Medium};\r\n font-size: 20px;\r\n\r\n transition: all 0.1s ease-in-out;\r\n &[data-hide='desktop'] {\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n }\r\n\r\n &[data-hide='mobile'] {\r\n @media ${until(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n }\r\n\r\n &[data-colour='green'] {\r\n --bg: ${brand.primary.light};\r\n --bgHover: ${lighten(0.02, brand.primary.light)};\r\n --bgFocus: ${darken(0.01, brand.primary.light)};\r\n --fg: ${brand.white};\r\n }\r\n\r\n &[data-colour='orange'] {\r\n --bg: ${brand.accent.orange};\r\n --bgHover: ${lighten(0.02, brand.accent.orange)};\r\n --bgFocus: ${darken(0.01, brand.accent.orange)};\r\n --fg: ${brand.white};\r\n }\r\n\r\n &:disabled {\r\n --bg: ${brand.grey.grey40};\r\n --bgHover: ${lighten(0.02, brand.grey.grey40)};\r\n --bgFocus: ${darken(0.01, brand.grey.grey40)};\r\n cursor: not-allowed;\r\n }\r\n\r\n // !important for legacy overrides //\r\n border: 2px solid transparent;\r\n background-color: var(--bg) !important;\r\n color: var(--fg) !important;\r\n\r\n &:hover {\r\n background-color: var(--bgHover) !important;\r\n }\r\n\r\n &:active {\r\n background-color: var(--bgFocus) !important;\r\n }\r\n\r\n &[data-fill='outline'] {\r\n border-color: var(--bg);\r\n background-color: transparent !important;\r\n color: var(--bg) !important;\r\n ${fonts.DaxPro.Bold};\r\n\r\n &:hover {\r\n background-color: transparent !important;\r\n }\r\n\r\n &:focus {\r\n background-color: transparent !important;\r\n }\r\n }\r\n\r\n &[data-center='true'] {\r\n margin: auto;\r\n }\r\n`;\r\nconst Icon = styled.div `\r\n display: flex;\r\n align-items: center;\r\n\r\n [data-icon-position='left'] & {\r\n order: -1;\r\n }\r\n\r\n [data-icon='none'] & {\r\n display: none;\r\n }\r\n\r\n svg {\r\n width: 12px;\r\n color: var(--fg);\r\n [data-fill='outline'] & {\r\n color: var(--bg);\r\n }\r\n\r\n [data-icon='plus'] & {\r\n width: 15px;\r\n }\r\n\r\n [data-icon='check'] & {\r\n width: 19px;\r\n }\r\n\r\n [data-icon='phone'] &,\r\n [data-icon='email'] & {\r\n width: 20px;\r\n }\r\n }\r\n`;\r\nconst LinkWrapper = styled.a `\r\n text-decoration: none !important;\r\n`;\r\nexport const YSButtonStyles = {\r\n Container,\r\n Icon,\r\n LinkWrapper,\r\n};\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconCheckCircleFill(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 16 16\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M16 8A8 8 0 110 8a8 8 0 0116 0zm-3.97-3.03a.75.75 0 00-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 00-1.06 1.06L6.97 11.03a.75.75 0 001.079-.02l3.992-4.99a.75.75 0 00-.01-1.05z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"9b0dc0df312a7e5d3be9b120eefe213e.svg\";\nexport { SvgIconCheckCircleFill as ReactComponent };","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconPhone(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 18.371 18.362\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 1\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 2\",\n d: \"M13.902 18.362a6.132 6.132 0 01-2.147-.448 19.632 19.632 0 01-3.22-1.356 19.187 19.187 0 01-3.907-3.151 21.577 21.577 0 01-2.23-2.644A13.908 13.908 0 01.613 7.047a14.82 14.82 0 01-.541-1.871 4.515 4.515 0 01.475-2.933c.075-.149.165-.29.236-.441A3.231 3.231 0 013.82.002a.622.622 0 01.619.343c.234.408.457.822.694 1.227.428.733.863 1.462 1.295 2.193l.126.216a.706.706 0 01-.088.92c-.3.31-.625.6-.946.886s-.631.546-.938.829a.63.63 0 00-.154.843c.48.807.937 1.632 1.477 2.4a12.25 12.25 0 004.1 3.585c.316.179.635.353.958.52a.577.577 0 00.728-.128c.279-.289.543-.592.812-.891.294-.327.569-.674.885-.977a.753.753 0 011.087-.106l3.286 1.9c.61.353.687.51.552 1.2-.067.341-.153.679-.238 1.016a1.918 1.918 0 01-.592.951 5.681 5.681 0 01-3.581 1.433z\",\n fill: \"currentColor\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"38c345360d88e8b4d2c3cf6334a6233f.svg\";\nexport { SvgIconPhone as ReactComponent };","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconMail(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 19 13.538\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 2\",\n fill: \"currentColor\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 3\",\n d: \"M18.371.207L9.522 8.725.51.325a1.271 1.271 0 01.691-.31 2.477 2.477 0 01.311-.013h16.037a1.376 1.376 0 01.822.205z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 4\",\n d: \"M6.742 7.829l.783.725 1.528 1.422a.625.625 0 00.962-.011q1.1-1.051 2.19-2.1l.125-.114 6.009 5.605a1.273 1.273 0 01-.713.186H1.517c-.192 0-.384-.034-.576-.053l-.009-.055z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 5\",\n d: \"M5.821 6.984L.048 12.538a3.116 3.116 0 01-.046-.361v-10.5c0-.025 0-.049.007-.1z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 6\",\n d: \"M18.997 12.287l-5.789-5.4 5.789-5.574z\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"cf472edd49267d98c469404c181750b2.svg\";\nexport { SvgIconMail as ReactComponent };","import React from 'react';\r\nimport { YSButtonStyles as S } from './YSButton.styles';\r\nimport { ReactComponent as Chevron } from '@img/icons/chevron-right.svg';\r\nimport { ReactComponent as Plus } from '@img/icons/plus-thick.svg';\r\nimport { ReactComponent as CheckCircle } from '@img/ysp/icon-check-circle-fill.svg';\r\nimport { ReactComponent as Phone } from '@img/ysp/icon-phone.svg';\r\nimport { ReactComponent as Email } from '@img/ysp/icon-mail.svg';\r\nconst YSButton = ({ children, icon, hideOnDesktop, hideOnMobile, colour = 'green', iconPosition = 'right', size = 'normal', fill = 'solid', center, ...rest }) => {\r\n const getIcon = () => {\r\n switch (icon) {\r\n case 'arrow':\r\n return React.createElement(Chevron, null);\r\n case 'plus':\r\n return React.createElement(Plus, null);\r\n case 'check':\r\n return React.createElement(CheckCircle, null);\r\n case 'email':\r\n return React.createElement(Email, null);\r\n case 'phone':\r\n return React.createElement(Phone, null);\r\n default:\r\n return React.createElement(React.Fragment, null);\r\n }\r\n };\r\n return (React.createElement(S.Container, { type: \"button\", \"data-colour\": colour, \"data-icon\": icon, \"data-icon-position\": iconPosition, \"data-fill\": fill, \"data-size\": size, \"data-hide\": hideOnDesktop ? 'desktop' : hideOnMobile ? 'mobile' : undefined, \"data-center\": center, ...rest },\r\n children,\r\n \" \",\r\n icon && React.createElement(S.Icon, null, getIcon())));\r\n};\r\nexport default YSButton;\r\nexport const YSLinkButton = ({ href, target, ...rest }) => {\r\n return (React.createElement(S.LinkWrapper, { href: href, target: target },\r\n React.createElement(YSButton, { ...rest })));\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled from 'styled-components';\r\nconst Input = styled.input `\r\n display: inline-block;\r\n width: 100%;\r\n border-radius: 8px;\r\n padding: 10px;\r\n border: 1px solid ${brand.black};\r\n padding-bottom: 10px;\r\n position: relative;\r\n transition: all 0.25s;\r\n\r\n &[type='number'] {\r\n max-width: 100px;\r\n text-align: center;\r\n }\r\n\r\n &[data-layout='soil-table'] {\r\n padding: 6px;\r\n max-width: unset;\r\n border: none;\r\n border-radius: 0;\r\n width: 100%;\r\n position: relative;\r\n transition: outline-color 0.1s ease-in-out;\r\n outline: 2px solid transparent;\r\n\r\n &::-webkit-outer-spin-button,\r\n &::-webkit-inner-spin-button {\r\n margin-left: 5px;\r\n }\r\n\r\n &::selection {\r\n color: ${brand.white};\r\n background-color: ${brand.divisionTags.sandhurst};\r\n }\r\n\r\n &:focus {\r\n outline-color: ${brand.divisionTags.sandhurst};\r\n }\r\n }\r\n\r\n &[data-layout='surcharges-table'] {\r\n padding: 6px 10px;\r\n border: none;\r\n border-radius: 0;\r\n width: 100%;\r\n height: 100%;\r\n position: relative;\r\n transition: outline-color 0.1s ease-in-out;\r\n outline: 2px solid transparent;\r\n ${fonts.DaxPro.Medium};\r\n\r\n &::selection {\r\n color: ${brand.white};\r\n background-color: ${brand.divisionTags.sandhurst};\r\n }\r\n\r\n &:focus {\r\n outline-color: ${brand.divisionTags.sandhurst};\r\n }\r\n }\r\n\r\n &[data-layout='default'] {\r\n &:focus,\r\n &:active {\r\n outline: none;\r\n }\r\n }\r\n\r\n &[data-bg='green'] {\r\n background-color: ${brand.ysp.input};\r\n }\r\n\r\n &[data-bg='white'] {\r\n background-color: ${brand.white};\r\n }\r\n\r\n &[data-bg='grey'] {\r\n background-color: ${brand.grey.grey89};\r\n }\r\n\r\n &[data-alignment='left'] {\r\n text-align: left;\r\n }\r\n\r\n &[data-alignment='center'] {\r\n text-align: center;\r\n }\r\n\r\n &[data-alignment='right'] {\r\n text-align: right;\r\n }\r\n`;\r\nexport const NumberInputStyles = {\r\n Input,\r\n};\r\n","import React from 'react';\r\nimport { NumberInputStyles as S } from './NumberInput.styles';\r\nconst NumberInput = ({ value, defaultValue, onChange, step = 0.1, min = 0, id, layout = 'default', bg = 'default', alignment = 'center', onFocus, onBlur, onClick, }) => {\r\n const [hasFocus, setHasFocus] = React.useState(false);\r\n const padNumber = (n) => n ? (n.toString().includes('.') ? n.toString() : `${n}.0`) : hasFocus ? undefined : '0.0';\r\n const handleKeyPress = (event) => {\r\n if (event.charCode == 13) {\r\n event.preventDefault();\r\n }\r\n };\r\n return (React.createElement(S.Input, { \"data-layout\": layout, \"data-bg\": bg, \"data-alignment\": alignment, type: \"number\", id: id, step: step, min: min, \"data-has-focus\": hasFocus, defaultValue: defaultValue, value: hasFocus ? value : padNumber(value), onChange: (e) => {\r\n onChange(e.currentTarget.value, e);\r\n }, onClick: () => onClick && onClick(), onFocus: () => {\r\n setHasFocus(true);\r\n onFocus && onFocus();\r\n }, onBlur: (e) => {\r\n setHasFocus(false);\r\n if (value && !value.toString().includes('.')) {\r\n onChange(`${value}.0`, e);\r\n }\r\n else if (value === undefined) {\r\n onChange('0.0', e);\r\n }\r\n onBlur && onBlur();\r\n }, onKeyPress: (e) => handleKeyPress(e) }));\r\n};\r\nexport default NumberInput;\r\n","import { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport React, { useEffect, useState } from 'react';\r\nimport Checkbox from '@ys/Components/Steps/Controls/Checkbox/Checkbox';\r\nimport Toggle from '@ys/Components/Steps/Controls/Toggle/Toggle';\r\nimport { SoilInfoTableStyles as S } from './SoilInfoTable.styles';\r\nimport { ReactComponent as Close } from '@img/icons/close-white.svg';\r\nimport { ReactComponent as Reset } from '@img/ysp/reset-thick.svg';\r\nimport YSButton from '../../../Shared/YSButton/YSButton';\r\nimport NumberInput from '../../../Shared/NumberInput/NumberInput';\r\nexport const padNumber = (number) => number ? (number.toString().includes('.') ? number.toString() : `${number}.0`) : '0.0';\r\nconst SoilInfoTable = ({ layers, update, setTargetedLayer, }) => {\r\n const { state: { labels, form }, dispatch, setFormField, } = useYSPContext();\r\n const [editSoilParameters, setEditSoilParameters] = useState(form.acceptedSoilModification ? form.acceptedSoilModification : false);\r\n const [showEditModal, setShowEditModal] = useState(false);\r\n const [hasAccepted, setHasAccepted] = useState(form.acceptedSoilModification ? form.acceptedSoilModification : false);\r\n useEffect(() => {\r\n if (editSoilParameters && !hasAccepted) {\r\n setShowEditModal(true);\r\n }\r\n else if (!editSoilParameters) {\r\n setHasAccepted(false);\r\n }\r\n }, [editSoilParameters]);\r\n useEffect(() => {\r\n setFormField('acceptedSoilModification', editSoilParameters && hasAccepted);\r\n }, [editSoilParameters, hasAccepted]);\r\n useEffect(() => {\r\n // If they've opened the modal box, but not accepted and closed, reset the toggle //\r\n if (!showEditModal && !hasAccepted) {\r\n setEditSoilParameters(false);\r\n }\r\n dispatch({ type: 'set-soil-modal', payload: showEditModal });\r\n }, [showEditModal]);\r\n const determineClick = () => {\r\n if (!hasAccepted) {\r\n setShowEditModal(true);\r\n }\r\n };\r\n const changeHandler = (e, callback) => {\r\n hasAccepted && callback(e);\r\n };\r\n const toggleLocked = (b) => {\r\n dispatch({ type: 'set-locked', payload: b });\r\n };\r\n return (React.createElement(S.Wrapper, null,\r\n React.createElement(S.TopSection, null,\r\n React.createElement(S.Title, { dangerouslySetInnerHTML: { __html: labels['heading_soil'] || 'Soil Parameters' } }),\r\n React.createElement(S.Disclaimer, { dangerouslySetInnerHTML: {\r\n __html: labels['soiltable.heading'] ||\r\n `

If the soil doesn't match what our default parameters state, you can change these to get a more accurate result for which Solution to use. Click on the toggle below to enable Profile editing

\\r\\n`,\r\n } }),\r\n React.createElement(Toggle, { value: hasAccepted && !showEditModal, label: 'Edit Soil Parameters', onChange: (v) => v && setEditSoilParameters(v) }),\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(S.Modal, { active: showEditModal, key: 'SoilProfileModal' },\r\n React.createElement(S.ModalInner, null,\r\n React.createElement(S.Close, { onClick: () => {\r\n setHasAccepted(false);\r\n setShowEditModal(false);\r\n } },\r\n React.createElement(Close, null)),\r\n React.createElement(S.ModalTitle, null, \"Edit Soil Parameters\"),\r\n React.createElement(S.ModalText, { dangerouslySetInnerHTML: {\r\n __html: labels['soilmodal.content'] ||\r\n 'Lorem ipsum, blah blah, words and some more words
'.repeat(50),\r\n } }),\r\n React.createElement(Checkbox, { label: \"I confirm I have read the Terms & Conditions\", value: hasAccepted, onChange: () => setHasAccepted(!hasAccepted) }),\r\n React.createElement(YSButton, { colour: \"orange\", disabled: !hasAccepted, onClick: () => setShowEditModal(false) }, \"Accept\"))))),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, { bold: true },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.layerlabel'] || 'Layer Start Depth',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.layerunits'] || 'mBGL',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: 'green', alignment: \"center\", step: 0.1, min: 0, value: layer.bgl, onChange: (e) => update(i, 'bgl', e), layout: \"soil-table\", onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false) }))))),\r\n React.createElement(S.WideColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.LargeHeader, { bold: true },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.descriptionlabel'] || 'Description',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(S.FieldInput, { bg: 'green', type: \"text\", align: 'left', value: layer.description || '', onChange: (e) => update(i, 'description', e.currentTarget.value) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.soildensitylabel'] || 'Soil Density γ',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.soildensityunits'] || 'kN/m3',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.soilDensity, onChange: (e, event) => changeHandler(event, (e) => update(i, 'soilDensity', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.saturateddensitylabel'] ||\r\n 'Saturated Density, γsat',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.saturateddensityunits'] || 'kN/m3',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.saturatedDensity, onChange: (e, event) => changeHandler(event, (e) => update(i, 'saturatedDensity', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.anglefrictionlabel'] || 'Angle of friction, φ',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.anglefrictionunits'] || '°',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.angleOfFriction, onChange: (e, event) => changeHandler(event, (e) => update(i, 'angleOfFriction', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.wallfrictionlabel'] || 'Wall Friction Factor',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.wallfrictionunits'] || 'tan𝛿 / tanφ',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.wallFrictionFactor, onChange: (e, event) => changeHandler(event, (e) => update(i, 'wallFrictionFactor', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.soilcohesionlabel'] ||\r\n 'Soil cohesion, c or cu',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.soilcohesionunits'] || 'kN/m2',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.FieldRow, { key: `${layer.id}_${i}` },\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.soilCohesion, onChange: (e, event) => changeHandler(event, (e) => update(i, 'soilCohesion', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.walladhesionlabel'] || 'Wall adhesion factor',\r\n } })),\r\n React.createElement(S.SmallHeader, null,\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.soilprofile.table.walladhesionunits'] ||\r\n 'aw/cw',\r\n } }))),\r\n layers.map((layer, i) => (React.createElement(S.LastRowWrapper, { key: `${layer.id}_${i}` },\r\n React.createElement(S.FieldRow, null,\r\n React.createElement(NumberInput, { bg: i % 2 === 0 ? 'white' : 'grey', alignment: \"right\", step: 0.1, min: 0, layout: \"soil-table\", value: layer.wallAdhesion, onChange: (e, event) => changeHandler(event, (e) => update(i, 'wallAdhesion', e.currentTarget.value)), onFocus: () => toggleLocked(true), onBlur: () => toggleLocked(false), onClick: determineClick })),\r\n React.createElement(S.Reset, { key: `Reset_${i}`, title: 'Reset this row to default values?', onClick: () => {\r\n setTargetedLayer(i);\r\n } },\r\n React.createElement(Reset, null)))))))));\r\n};\r\nexport default SoilInfoTable;\r\n","import React, { useEffect, useMemo, useState } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { DepthStyles as S } from './Depth.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport InfoIcon from '../../InfoIcon/InfoIcon';\r\nimport { padNumber } from '../SoilProfiles/SoilInfoTable/SoilInfoTable';\r\nconst Depth = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const [hasFocus, setHasFocus] = useState(false);\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n beforeNext: () => dispatch({ type: 'validate-depth' }),\r\n },\r\n });\r\n }, []);\r\n const svgDepth = useMemo(() => {\r\n let _svgDepth = 17;\r\n if (state.form.depth) {\r\n const factor = state.form.depth > 5 ? 5 : state.form.depth;\r\n _svgDepth = 17 * factor;\r\n if (_svgDepth < 17) {\r\n _svgDepth = 17;\r\n }\r\n }\r\n return _svgDepth;\r\n }, [state.form.depth]);\r\n const handleDepthChange = (value) => {\r\n let floatValue = parseFloat(value);\r\n if (floatValue > 99999) {\r\n floatValue = 99999;\r\n }\r\n if (value === '' || floatValue < 0) {\r\n setFormField('depth', undefined);\r\n }\r\n else {\r\n setFormField('depth', floatValue);\r\n }\r\n };\r\n const handleKeyPress = (event) => {\r\n if (event.charCode == 13) {\r\n event.preventDefault();\r\n }\r\n };\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } }))),\r\n React.createElement(S.Container, null,\r\n state.form.depth !== undefined && (React.createElement(S.Label, { style: { height: `${svgDepth}px` } },\r\n React.createElement(S.Indicator, null),\r\n state.form.depth,\r\n \"m\")),\r\n React.createElement(\"svg\", { id: \"icon\", xmlns: \"http://www.w3.org/2000/svg\", viewBox: \"0 0 294.928 102.119\" },\r\n React.createElement(\"g\", { id: \"Group_44\", \"data-name\": \"Group 44\", transform: \"translate(-102.872 -342.491)\" },\r\n React.createElement(\"path\", { id: \"Path_69\", \"data-name\": \"Path 69\", d: \"M393.309,349.21c-2.85-.27-5.471,2.191-8.305,1.786-1.845-.264-3.425-1.722-5.289-1.694-1.835.027-3.415,1.5-5.25,1.519-1.787.019-3.354-1.345-5.14-1.391-2.072-.052-3.886,1.672-5.957,1.59-1.9-.074-3.438-1.642-5.309-1.984-2.939-.537-5.654,1.729-8.315,3.087-2.35-.241-4.158-2.6-6.52-2.52-2.094.07-3.643,2.031-5.682,2.51-3.167.744-6.193-2.257-9.43-1.909-1.589.17-2.969,1.128-4.493,1.6a7.629,7.629,0,0,1-4.974-.172c-1.924-.748-3.9-2.31-5.809-1.519a14.769,14.769,0,0,0-1.737,1.115,5.885,5.885,0,0,1-5.462-.177c-1.365-.671-2.841-1.691-4.268-1.16-1.27.473-1.979,2.06-3.329,2.21-1.787.2-2.778-2.209-4.524-2.631-2.268-.548-4.1,2.457-6.427,2.252-1.368-.12-2.394-1.328-3.726-1.662a3.635,3.635,0,0,0-3.9,1.877l.023,5.975H221.493v-7.046c-2.5.043-2.568-1.4-4.67-1.6-2.85-.27-5.472,2.191-8.306,1.786-1.845-.265-3.424-1.722-5.289-1.694-1.835.027-3.415,1.5-5.25,1.519-1.787.019-3.354-1.345-5.14-1.391-2.072-.053-3.886,1.672-5.957,1.59-1.9-.074-3.438-1.642-5.309-1.984-2.939-.537-5.654,1.729-8.315,3.087-2.35-.241-4.159-2.6-6.52-2.52-2.095.07-3.644,2.031-5.682,2.51-3.167.744-6.193-2.257-9.43-1.909-1.589.17-2.969,1.128-4.494,1.6a7.619,7.619,0,0,1-4.973-.172c-1.925-.747-3.9-2.309-5.81-1.519a14.964,14.964,0,0,0-1.737,1.115,5.885,5.885,0,0,1-5.462-.176c-1.365-.671-2.841-1.691-4.268-1.16-1.271.472-1.98,2.06-3.329,2.21-1.787.2-2.777-2.208-4.524-2.631-2.268-.547-4.1,2.457-6.427,2.253-1.368-.121-2.4-1.328-3.726-1.662a3.116,3.116,0,0,0-3.537,1.8v95.391H221.307l58.517-.117v.058H397.792V350.794C395.291,350.837,395.411,349.409,393.309,349.21Z\", transform: \"translate(0 -2.705)\", fill: \"#c9c9c9\" }),\r\n React.createElement(\"path\", { id: \"Path_70\", \"data-name\": \"Path 70\", d: \"M112.329,367.252a1.794,1.794,0,0,1,.43-.3,3.924,3.924,0,0,1,1.972-.286,4.884,4.884,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.453-.942A2.506,2.506,0,0,1,112.329,367.252Z\", transform: \"translate(-3.513 -10.111)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_71\", \"data-name\": \"Path 71\", d: \"M139.745,365.494a.882.882,0,0,1-.031-.259,1.961,1.961,0,0,1,.334-.938,2.447,2.447,0,0,1,.573-.7,1.77,1.77,0,0,1,1.81,0c.622.281-.538,3.277-1.926,2.632A1.254,1.254,0,0,1,139.745,365.494Z\", transform: \"translate(-15.219 -8.725)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_72\", \"data-name\": \"Path 72\", d: \"M134.752,404.79a1.776,1.776,0,0,1,.429-.3,3.924,3.924,0,0,1,1.972-.286,4.881,4.881,0,0,1,1.776.357,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.453-.942A2.5,2.5,0,0,1,134.752,404.79Z\", transform: \"translate(-12.895 -25.816)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_73\", \"data-name\": \"Path 73\", d: \"M168.736,381.5a1.78,1.78,0,0,1,.43-.3,3.922,3.922,0,0,1,1.971-.286,4.883,4.883,0,0,1,1.776.357,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.506,2.506,0,0,1,168.736,381.5Z\", transform: \"translate(-27.114 -16.072)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_74\", \"data-name\": \"Path 74\", d: \"M193.753,360.509a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.868,4.868,0,0,1,1.776.358,3.537,3.537,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,193.753,360.509Z\", transform: \"translate(-37.581 -7.289)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_75\", \"data-name\": \"Path 75\", d: \"M208.229,388.426a1.8,1.8,0,0,1,.43-.3,3.924,3.924,0,0,1,1.972-.286,4.883,4.883,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.453-.942A2.506,2.506,0,0,1,208.229,388.426Z\", transform: \"translate(-43.637 -18.97)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_76\", \"data-name\": \"Path 76\", d: \"M238.735,361a10.4,10.4,0,0,1,4.182-.338c1.779.341,1.983,2.771,1.91,4.332-.141,3.025-6.34,1.633-8.213,1.113-1.453-.4-.677-2.771-.108-3.6A3.707,3.707,0,0,1,238.735,361Z\", transform: \"translate(-55.414 -7.562)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_77\", \"data-name\": \"Path 77\", d: \"M262.76,384.335a1.339,1.339,0,0,1,.3-.3,1.987,1.987,0,0,1,1.368-.286,2.528,2.528,0,0,1,1.233.358c.847.554,1.12,1.968,1.173,3.2.059,1.363-4.371,2.115-4.48-.942A3.313,3.313,0,0,1,262.76,384.335Z\", transform: \"translate(-66.529 -17.258)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_78\", \"data-name\": \"Path 78\", d: \"M273.11,360.509a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.871,4.871,0,0,1,1.776.358,3.537,3.537,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,273.11,360.509Z\", transform: \"translate(-70.783 -7.289)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_79\", \"data-name\": \"Path 79\", d: \"M103.338,351.966a3.116,3.116,0,0,1,3.537-1.8c1.331.333,2.358,1.541,3.726,1.662,2.325.2,4.16-2.8,6.427-2.253,1.747.422,2.737,2.829,4.524,2.631,1.349-.149,2.058-1.737,3.329-2.21,1.427-.53,2.9.489,4.268,1.16a5.883,5.883,0,0,0,5.462.176,14.952,14.952,0,0,1,1.737-1.115c1.908-.79,3.885.772,5.81,1.519a7.619,7.619,0,0,0,4.973.172c1.525-.473,2.905-1.431,4.494-1.6,3.237-.347,6.263,2.653,9.43,1.909,2.039-.479,3.587-2.44,5.682-2.51,2.361-.079,4.17,2.279,6.52,2.52,2.661-1.359,5.376-3.625,8.315-3.087,1.872.341,3.409,1.909,5.309,1.984,2.072.081,3.885-1.643,5.957-1.59,1.786.045,3.353,1.409,5.14,1.391,1.835-.019,3.415-1.492,5.25-1.519,1.864-.028,3.443,1.43,5.289,1.694,2.834.406,5.455-2.055,8.306-1.786,2.1.2,2.169,1.642,4.67,1.6\", transform: \"translate(0 -2.747)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_80\", \"data-name\": \"Path 80\", d: \"M290.422,468.643a1.8,1.8,0,0,1,.43-.3,3.928,3.928,0,0,1,1.971-.286,4.893,4.893,0,0,1,1.776.358c1.3.589,2.529,3.183.876,4.044-1.569.818-5.521.541-5.639-1.785A2.506,2.506,0,0,1,290.422,468.643Z\", transform: \"translate(-78.027 -52.532)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_81\", \"data-name\": \"Path 81\", d: \"M290.422,429.136a1.8,1.8,0,0,1,.43-.3,3.928,3.928,0,0,1,1.971-.286,4.892,4.892,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.086,1.363-6.3,2.115-6.452-.942A2.506,2.506,0,0,1,290.422,429.136Z\", transform: \"translate(-78.027 -36.003)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_82\", \"data-name\": \"Path 82\", d: \"M304.029,498.965a1.8,1.8,0,0,1,.429-.3,3.931,3.931,0,0,1,1.972-.286,4.9,4.9,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,304.029,498.965Z\", transform: \"translate(-83.72 -65.219)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_83\", \"data-name\": \"Path 83\", d: \"M342.336,472.686a10.4,10.4,0,0,1,3.047,2.884c.936,1.551-.735,3.327-1.944,4.316-2.344,1.918-5.453-3.624-6.319-5.364-.672-1.35,1.609-2.356,2.6-2.486A3.707,3.707,0,0,1,342.336,472.686Z\", transform: \"translate(-97.762 -54.188)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_84\", \"data-name\": \"Path 84\", d: \"M383.661,496.561a1.349,1.349,0,0,1,.3-.3,1.982,1.982,0,0,1,1.368-.286,2.523,2.523,0,0,1,1.234.357c.847.554,1.119,1.968,1.173,3.2.059,1.363-4.371,2.115-4.48-.942A3.311,3.311,0,0,1,383.661,496.561Z\", transform: \"translate(-117.114 -64.213)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_85\", \"data-name\": \"Path 85\", d: \"M110.167,478.409a1.785,1.785,0,0,1,.429-.3,3.919,3.919,0,0,1,1.972-.286,4.882,4.882,0,0,1,1.776.357,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,110.167,478.409Z\", transform: \"translate(-2.609 -56.619)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_86\", \"data-name\": \"Path 86\", d: \"M140.739,466.6a1.778,1.778,0,0,1,.43-.3,3.922,3.922,0,0,1,1.971-.287,4.895,4.895,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,140.739,466.6Z\", transform: \"translate(-15.4 -51.677)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_87\", \"data-name\": \"Path 87\", d: \"M140.739,496.923a1.777,1.777,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.882,4.882,0,0,1,1.776.357,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.508,2.508,0,0,1,140.739,496.923Z\", transform: \"translate(-15.4 -64.364)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_88\", \"data-name\": \"Path 88\", d: \"M178.773,476.92a10.394,10.394,0,0,1,1.725,3.824c.278,1.79-1.941,2.8-3.436,3.256-2.9.885-3.671-5.421-3.813-7.36-.11-1.5,2.382-1.57,3.352-1.313A3.708,3.708,0,0,1,178.773,476.92Z\", transform: \"translate(-29.249 -55.53)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_89\", \"data-name\": \"Path 89\", d: \"M209.746,490.427a1.363,1.363,0,0,1,.3-.3,1.987,1.987,0,0,1,1.369-.286,2.515,2.515,0,0,1,1.233.358c.847.554,1.12,1.967,1.173,3.2.059,1.363-4.371,2.116-4.48-.942A3.317,3.317,0,0,1,209.746,490.427Z\", transform: \"translate(-44.348 -61.647)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_90\", \"data-name\": \"Path 90\", d: \"M248.956,490.427a1.794,1.794,0,0,1,.43-.3,3.924,3.924,0,0,1,1.972-.286,4.874,4.874,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.453-.942A2.506,2.506,0,0,1,248.956,490.427Z\", transform: \"translate(-60.678 -61.647)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_91\", \"data-name\": \"Path 91\", d: \"M121.16,438.546a1.8,1.8,0,0,1,.186.488,3.923,3.923,0,0,1-.193,1.983,4.872,4.872,0,0,1-.771,1.64,3.539,3.539,0,0,1-3.511.878c-1.344-.243-.554-6.619,2.453-6.042A2.508,2.508,0,0,1,121.16,438.546Z\", transform: \"translate(-5.398 -39.733)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_92\", \"data-name\": \"Path 92\", d: \"M162.432,427.97a10.391,10.391,0,0,1,4.181-.337c1.78.34,1.983,2.77,1.911,4.331-.141,3.025-6.341,1.633-8.213,1.113-1.453-.4-.677-2.771-.108-3.6A3.706,3.706,0,0,1,162.432,427.97Z\", transform: \"translate(-23.489 -35.582)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_93\", \"data-name\": \"Path 93\", d: \"M202.173,447.487a1.353,1.353,0,0,1,.3-.3,1.988,1.988,0,0,1,1.368-.286,2.528,2.528,0,0,1,1.233.358c.847.554,1.12,1.968,1.173,3.2.059,1.363-4.371,2.115-4.48-.942A3.315,3.315,0,0,1,202.173,447.487Z\", transform: \"translate(-41.18 -43.681)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_94\", \"data-name\": \"Path 94\", d: \"M239.009,408.881a1.785,1.785,0,0,1,.429-.3,3.924,3.924,0,0,1,1.972-.286,4.881,4.881,0,0,1,1.776.357,3.539,3.539,0,0,1,1.69,3.2c.086,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,239.009,408.881Z\", transform: \"translate(-56.516 -27.528)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_95\", \"data-name\": \"Path 95\", d: \"M254.511,437.381a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.879,4.879,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,254.511,437.381Z\", transform: \"translate(-63.002 -39.452)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_96\", \"data-name\": \"Path 96\", d: \"M206.72,423.169c-.287-.277-.559-.572-.818-.876a6.115,6.115,0,0,1-1.614-2.43,1.18,1.18,0,0,1,.722-1.377,1.577,1.577,0,0,1,1.162.309,8.857,8.857,0,0,1,3.644,4.4,1.339,1.339,0,0,1,.116.565c-.061.78-1.228.895-1.887.473A8.536,8.536,0,0,1,206.72,423.169Z\", transform: \"translate(-42.228 -31.784)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_97\", \"data-name\": \"Path 97\", d: \"M250.6,468.957c-.323.236-.66.452-1,.656a6.11,6.11,0,0,1-2.671,1.173,1.18,1.18,0,0,1-1.232-.947,1.576,1.576,0,0,1,.5-1.092,8.853,8.853,0,0,1,4.957-2.835,1.341,1.341,0,0,1,.576-.018c.758.194.671,1.364.142,1.941A8.507,8.507,0,0,1,250.6,468.957Z\", transform: \"translate(-59.558 -51.621)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_98\", \"data-name\": \"Path 98\", d: \"M397.648,469.067c-.087.39-.195.776-.319,1.156a6.11,6.11,0,0,1-1.224,2.647,1.18,1.18,0,0,1-1.551.106,1.578,1.578,0,0,1-.345-1.152,8.854,8.854,0,0,1,1.838-5.407,1.33,1.33,0,0,1,.421-.4c.7-.357,1.405.578,1.391,1.36A8.533,8.533,0,0,1,397.648,469.067Z\", transform: \"translate(-121.699 -51.652)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_99\", \"data-name\": \"Path 99\", d: \"M368.035,433.227a1.8,1.8,0,0,1,.43-.3,3.928,3.928,0,0,1,1.971-.286,4.894,4.894,0,0,1,1.776.358c1.3.589,2.529,3.183.876,4.044-1.569.818-5.521.541-5.639-1.785A2.506,2.506,0,0,1,368.035,433.227Z\", transform: \"translate(-110.5 -37.714)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1.188\" }),\r\n React.createElement(\"path\", { id: \"Path_101\", \"data-name\": \"Path 101\", d: \"M415.776,367.151a1.793,1.793,0,0,1,.429-.3,3.931,3.931,0,0,1,1.972-.286,4.9,4.9,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,415.776,367.151Z\", transform: \"translate(-130.474 -10.068)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_102\", \"data-name\": \"Path 102\", d: \"M443.191,365.393a.894.894,0,0,1-.031-.259,1.967,1.967,0,0,1,.334-.938,2.455,2.455,0,0,1,.573-.7,1.769,1.769,0,0,1,1.81,0c.622.281-.537,3.277-1.925,2.631A1.253,1.253,0,0,1,443.191,365.393Z\", transform: \"translate(-142.18 -8.683)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_103\", \"data-name\": \"Path 103\", d: \"M438.2,404.689a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.883,4.883,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,438.2,404.689Z\", transform: \"translate(-139.856 -25.774)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_104\", \"data-name\": \"Path 104\", d: \"M472.182,381.4a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.879,4.879,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,472.182,381.4Z\", transform: \"translate(-154.074 -16.03)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_105\", \"data-name\": \"Path 105\", d: \"M497.2,360.408a1.8,1.8,0,0,1,.43-.3,3.93,3.93,0,0,1,1.972-.286,4.9,4.9,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.453-.942A2.506,2.506,0,0,1,497.2,360.408Z\", transform: \"translate(-164.541 -7.247)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_106\", \"data-name\": \"Path 106\", d: \"M511.676,388.325a1.778,1.778,0,0,1,.43-.3,3.922,3.922,0,0,1,1.971-.287,4.9,4.9,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.086,1.363-6.3,2.115-6.452-.942A2.507,2.507,0,0,1,511.676,388.325Z\", transform: \"translate(-170.598 -18.928)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_107\", \"data-name\": \"Path 107\", d: \"M542.182,360.9a10.382,10.382,0,0,1,4.182-.338c1.779.341,1.983,2.771,1.911,4.331-.141,3.025-6.341,1.633-8.214,1.114-1.453-.4-.676-2.772-.108-3.6A3.7,3.7,0,0,1,542.182,360.9Z\", transform: \"translate(-182.375 -7.52)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_108\", \"data-name\": \"Path 108\", d: \"M566.206,384.235a1.337,1.337,0,0,1,.3-.3,1.985,1.985,0,0,1,1.369-.286,2.524,2.524,0,0,1,1.234.357c.846.554,1.119,1.968,1.172,3.2.059,1.363-4.371,2.115-4.479-.942A3.312,3.312,0,0,1,566.206,384.235Z\", transform: \"translate(-193.49 -17.216)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_109\", \"data-name\": \"Path 109\", d: \"M576.556,360.408a1.8,1.8,0,0,1,.43-.3,3.928,3.928,0,0,1,1.971-.286,4.893,4.893,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.086,1.363-6.3,2.115-6.452-.942A2.506,2.506,0,0,1,576.556,360.408Z\", transform: \"translate(-197.744 -7.247)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_110\", \"data-name\": \"Path 110\", d: \"M406.784,351.865a3.116,3.116,0,0,1,3.537-1.8c1.331.333,2.358,1.541,3.726,1.662,2.325.2,4.16-2.8,6.427-2.252,1.747.422,2.737,2.829,4.524,2.631,1.349-.15,2.058-1.737,3.329-2.21,1.427-.53,2.9.489,4.268,1.16a5.885,5.885,0,0,0,5.462.177,14.769,14.769,0,0,1,1.737-1.115c1.907-.79,3.885.771,5.809,1.519a7.629,7.629,0,0,0,4.974.172c1.524-.474,2.9-1.431,4.493-1.6,3.237-.347,6.263,2.653,9.43,1.909,2.039-.479,3.588-2.44,5.682-2.51,2.362-.079,4.17,2.279,6.52,2.52,2.661-1.359,5.376-3.624,8.315-3.087,1.872.342,3.408,1.909,5.309,1.984,2.071.081,3.885-1.642,5.957-1.59,1.786.046,3.353,1.409,5.14,1.391,1.835-.019,3.415-1.492,5.25-1.519,1.864-.028,3.443,1.43,5.289,1.694,2.834.406,5.455-2.055,8.305-1.786,2.1.2,1.982,1.627,4.483,1.584\", transform: \"translate(-126.961 -2.705)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_111\", \"data-name\": \"Path 111\", d: \"M593.868,468.543a1.777,1.777,0,0,1,.43-.3,3.924,3.924,0,0,1,1.972-.286,4.884,4.884,0,0,1,1.776.357c1.3.589,2.529,3.184.876,4.044-1.569.817-5.521.54-5.64-1.785A2.507,2.507,0,0,1,593.868,468.543Z\", transform: \"translate(-204.987 -52.49)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_112\", \"data-name\": \"Path 112\", d: \"M593.868,429.036a1.777,1.777,0,0,1,.43-.3,3.924,3.924,0,0,1,1.972-.286,4.885,4.885,0,0,1,1.776.357,3.54,3.54,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.453-.942A2.508,2.508,0,0,1,593.868,429.036Z\", transform: \"translate(-204.987 -35.961)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_113\", \"data-name\": \"Path 113\", d: \"M413.613,478.309a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.869,4.869,0,0,1,1.776.358,3.537,3.537,0,0,1,1.69,3.2c.085,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,413.613,478.309Z\", transform: \"translate(-129.569 -56.576)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_114\", \"data-name\": \"Path 114\", d: \"M444.185,466.5a1.794,1.794,0,0,1,.43-.3,3.922,3.922,0,0,1,1.971-.286,4.881,4.881,0,0,1,1.776.357,3.538,3.538,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,444.185,466.5Z\", transform: \"translate(-142.36 -51.636)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_115\", \"data-name\": \"Path 115\", d: \"M444.185,496.822a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.881,4.881,0,0,1,1.776.358,3.537,3.537,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,444.185,496.822Z\", transform: \"translate(-142.36 -64.322)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_116\", \"data-name\": \"Path 116\", d: \"M482.219,476.82a10.389,10.389,0,0,1,1.725,3.824c.278,1.79-1.941,2.8-3.436,3.256-2.9.885-3.671-5.421-3.812-7.36-.11-1.5,2.382-1.57,3.352-1.313A3.7,3.7,0,0,1,482.219,476.82Z\", transform: \"translate(-156.21 -55.488)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_117\", \"data-name\": \"Path 117\", d: \"M513.192,490.326a1.352,1.352,0,0,1,.3-.3,1.987,1.987,0,0,1,1.368-.286,2.527,2.527,0,0,1,1.233.358c.847.554,1.12,1.968,1.173,3.2.059,1.363-4.371,2.116-4.48-.942A3.314,3.314,0,0,1,513.192,490.326Z\", transform: \"translate(-171.309 -61.604)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_118\", \"data-name\": \"Path 118\", d: \"M552.4,490.326a1.792,1.792,0,0,1,.429-.3,3.931,3.931,0,0,1,1.972-.286,4.895,4.895,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,552.4,490.326Z\", transform: \"translate(-187.638 -61.604)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_119\", \"data-name\": \"Path 119\", d: \"M424.606,438.446a1.792,1.792,0,0,1,.186.489,3.923,3.923,0,0,1-.192,1.983,4.9,4.9,0,0,1-.771,1.64,3.539,3.539,0,0,1-3.512.878c-1.344-.242-.553-6.619,2.453-6.042A2.505,2.505,0,0,1,424.606,438.446Z\", transform: \"translate(-132.359 -39.691)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_120\", \"data-name\": \"Path 120\", d: \"M465.878,427.87a10.383,10.383,0,0,1,4.182-.338c1.779.341,1.983,2.771,1.91,4.331-.141,3.025-6.34,1.633-8.213,1.114-1.453-.4-.677-2.772-.108-3.6A3.7,3.7,0,0,1,465.878,427.87Z\", transform: \"translate(-150.45 -35.54)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_121\", \"data-name\": \"Path 121\", d: \"M505.619,447.387a1.339,1.339,0,0,1,.3-.3,1.985,1.985,0,0,1,1.369-.286,2.523,2.523,0,0,1,1.234.357c.847.554,1.119,1.968,1.173,3.2.059,1.363-4.372,2.115-4.48-.942A3.312,3.312,0,0,1,505.619,447.387Z\", transform: \"translate(-168.14 -43.639)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_122\", \"data-name\": \"Path 122\", d: \"M542.455,408.78a1.8,1.8,0,0,1,.43-.3,3.921,3.921,0,0,1,1.971-.286,4.881,4.881,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.452-.942A2.506,2.506,0,0,1,542.455,408.78Z\", transform: \"translate(-183.476 -27.486)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_123\", \"data-name\": \"Path 123\", d: \"M557.957,437.28a1.807,1.807,0,0,1,.43-.3,3.93,3.93,0,0,1,1.972-.286,4.895,4.895,0,0,1,1.776.358,3.539,3.539,0,0,1,1.69,3.2c.085,1.363-6.3,2.115-6.453-.942A2.507,2.507,0,0,1,557.957,437.28Z\", transform: \"translate(-189.962 -39.41)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_124\", \"data-name\": \"Path 124\", d: \"M510.166,423.069c-.287-.278-.559-.573-.818-.877a6.116,6.116,0,0,1-1.614-2.43,1.181,1.181,0,0,1,.722-1.377,1.583,1.583,0,0,1,1.162.309,8.852,8.852,0,0,1,3.644,4.4,1.33,1.33,0,0,1,.117.565c-.06.78-1.229.895-1.888.473A8.566,8.566,0,0,1,510.166,423.069Z\", transform: \"translate(-169.188 -31.742)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_125\", \"data-name\": \"Path 125\", d: \"M554.043,468.856c-.323.235-.66.452-1,.655a6.112,6.112,0,0,1-2.671,1.173,1.18,1.18,0,0,1-1.232-.947,1.579,1.579,0,0,1,.5-1.092,8.856,8.856,0,0,1,4.957-2.835,1.344,1.344,0,0,1,.577-.018c.758.194.67,1.364.141,1.941A8.546,8.546,0,0,1,554.043,468.856Z\", transform: \"translate(-186.519 -51.578)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_126\", \"data-name\": \"Path 126\", d: \"M321.547,400.6a1.792,1.792,0,0,1,.429-.3,3.93,3.93,0,0,1,1.972-.286,4.882,4.882,0,0,1,1.776.358,3.538,3.538,0,0,1,1.69,3.2c.086,1.363-6.3,2.116-6.453-.942A2.5,2.5,0,0,1,321.547,400.6Z\", transform: \"translate(-91.049 -24.063)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_127\", \"data-name\": \"Path 127\", d: \"M392.1,393.566a10.388,10.388,0,0,1,3.047,2.884c.936,1.551-.735,3.327-1.944,4.317-2.344,1.917-5.453-3.624-6.319-5.364-.672-1.35,1.609-2.356,2.6-2.486A3.7,3.7,0,0,1,392.1,393.566Z\", transform: \"translate(-118.585 -21.084)\", fill: \"none\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" }),\r\n React.createElement(\"path\", { id: \"Path_100\", \"data-name\": \"Path 100\", d: `M306.492,342.491v${svgDepth}H364.6V342.491`, transform: \"translate(-84.999)\", fill: \"#fff\", stroke: \"#040405\", strokeMiterlimit: \"10\", strokeWidth: \"1\" })))),\r\n React.createElement(FormStyles.FormControl, { center: true, invalid: state.errors['depth'] !== undefined },\r\n React.createElement(\"label\", { htmlFor: \"txtDepth\" }, \"Depth\"),\r\n React.createElement(FormStyles.FormError, null, \"Please enter a depth.\"),\r\n React.createElement(\"input\", { type: \"number\", id: \"txtDepth\", value: hasFocus ? state.form.depth : padNumber(state.form.depth), onChange: (e) => handleDepthChange(e.currentTarget.value), onKeyPress: (e) => handleKeyPress(e), onFocus: () => setHasFocus(true), onBlur: () => setHasFocus(false), step: \"0.25\", min: 0 }),\r\n React.createElement(FormStyles.FormSub, null, \"m\")))));\r\n};\r\nexport default Depth;\r\n","var _path, _path2;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconAvatar(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n \"data-name\": \"Group 33\",\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 69.235 69.567\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 56\",\n d: \"M.012 69.568c-.344-10.667 6.8-24.837 19.181-30.836 9.523 7.381 21.273 7.419 30.835 0 12.906 6.255 19.549 20.783 19.194 30.836z\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 57\",\n d: \"M34.63 0a20.28 20.28 0 11-20.301 20.208A20.073 20.073 0 0134.63 0z\"\n })));\n}\n\nexport default __webpack_public_path__ + \"3322d59a29c5395f22f56c6e25e420c7.svg\";\nexport { SvgIconAvatar as ReactComponent };","import React from 'react';\r\nimport uniqueId from 'lodash/uniqueId';\r\nimport { FormStyles } from '../../../Shared/Form.styles';\r\nimport { AnimatePresence } from 'framer-motion';\r\nconst Textbox = ({ value, label, onChange, readOnly = false, restrictWidth = false, error, fullWidth, placeholder, }) => {\r\n const id = uniqueId('textbox_');\r\n return (React.createElement(FormStyles.FormControl, { fullWidth: fullWidth, restrictWidth: restrictWidth, invalid: error !== undefined },\r\n React.createElement(\"label\", { htmlFor: id }, label),\r\n React.createElement(\"input\", { placeholder: placeholder, id: id, value: value, onChange: onChange, onKeyPress: (e) => e.key === 'Enter' && e.preventDefault(), readOnly: readOnly }),\r\n React.createElement(AnimatePresence, null, error && (React.createElement(FormStyles.FormErrorHidden, null,\r\n React.createElement(FormStyles.FormError, { htmlFor: id }, error))))));\r\n};\r\nexport default Textbox;\r\n","import brand from '@helpers/brand';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nconst TechnicalLibraryLogin = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n width: 100%;\r\n gap: 15px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n svg {\r\n margin-bottom: 15px;\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n margin-bottom: 15px;\r\n border-bottom: 2px solid ${brand.grey.grey89};\r\n padding-bottom: 15px;\r\n }\r\n`;\r\nconst FullWidth = styled.div `\r\n grid-column: 1 / -1;\r\n`;\r\nconst Disclaimer = styled.div `\r\n p {\r\n margin-bottom: 0px;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n p {\r\n font-size: 13px;\r\n line-height: 16px;\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n p {\r\n line-height: 26px;\r\n }\r\n }\r\n`;\r\nexport const DetailsStyles = {\r\n TechnicalLibraryLogin,\r\n FullWidth,\r\n Disclaimer,\r\n};\r\n","import React, { useEffect, useState } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { ReactComponent as User } from '@img/ysp/icon-avatar.svg';\r\nimport Textbox from '@ys/Components/Steps/Controls/Textbox/Textbox';\r\nimport Recaptcha from '@stories/Components/Forms/Recaptcha/Recaptcha';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport { DetailsStyles as S } from './Details.styles';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport { YSLinkButton } from '../../Shared/YSButton/YSButton';\r\nimport InfoIcon from '../../InfoIcon/InfoIcon';\r\nconst Details = () => {\r\n const { state, dispatch, setFormField: setField } = useYSPContext();\r\n const [nextActive, setNextActive] = useState(true);\r\n const [recaptcha, setRecaptcha] = useState('');\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n beforeNext: handleNext,\r\n },\r\n });\r\n }, []);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: nextActive,\r\n },\r\n });\r\n }, [nextActive]);\r\n const checkContinue = () => {\r\n if (state.authenticatedUser === undefined) {\r\n if (state.form.name != undefined &&\r\n state.form.name.length > 0 &&\r\n state.form.email != undefined &&\r\n state.form.email.length > 0 &&\r\n state.form.confirmEmail != undefined &&\r\n state.form.confirmEmail.length > 0 &&\r\n state.form.telephone != undefined &&\r\n state.form.telephone.length > 0 &&\r\n state.form.companyName != undefined &&\r\n state.form.companyName.length > 0 &&\r\n state.form.schemeName != undefined &&\r\n state.form.schemeName.length > 0 &&\r\n state.form.siteName != undefined &&\r\n state.form.siteName.length > 0 &&\r\n state.form.recaptchaToken != undefined &&\r\n state.form.recaptchaToken.length > 0) {\r\n setNextActive(false);\r\n }\r\n }\r\n else {\r\n if (state.form.name != undefined &&\r\n state.form.name.length > 0 &&\r\n state.form.email != undefined &&\r\n state.form.email.length > 0 &&\r\n state.form.telephone != undefined &&\r\n state.form.telephone.length > 0 &&\r\n state.form.companyName != undefined &&\r\n state.form.companyName.length > 0 &&\r\n state.form.schemeName != undefined &&\r\n state.form.schemeName.length > 0 &&\r\n state.form.siteName != undefined &&\r\n state.form.siteName.length > 0 &&\r\n state.form.recaptchaToken != undefined &&\r\n state.form.recaptchaToken.length > 0) {\r\n setNextActive(false);\r\n }\r\n }\r\n };\r\n const handleRecaptcha = (token) => {\r\n setField('recaptchaToken', token);\r\n if (token) {\r\n setRecaptcha(token);\r\n }\r\n checkContinue();\r\n };\r\n const handleNext = () => {\r\n dispatch({ type: 'validate-details' });\r\n };\r\n return (React.createElement(StepStyles.Grid, null,\r\n React.createElement(Containers.Default, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) }))),\r\n React.createElement(FormStyles.FormSplit, null,\r\n state.authenticatedUser === undefined && (React.createElement(S.FullWidth, null,\r\n React.createElement(S.TechnicalLibraryLogin, null,\r\n React.createElement(SharedStyles.Avatar, null,\r\n React.createElement(User, null)),\r\n React.createElement(YSLinkButton, { href: `${state.technicalLibraryUrl}?ReturnUrl=${encodeURI(state.yourSolutionUrl)}` }, \"Log in to Technical Library\")))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.name, label: \"Name*\", error: state.labels[state.errors['name'] || ''], onChange: (e) => {\r\n setField('name', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.companyName, label: \"Company Name*\", error: state.labels[state.errors['companyName'] || ''], onChange: (e) => {\r\n setField('companyName', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.email, label: \"Email Address*\", error: state.labels[state.errors['email'] || ''], onChange: (e) => {\r\n setField('email', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n state.authenticatedUser === undefined && (React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.confirmEmail, label: \"Confirm Email Address*\", error: state.labels[state.errors['confirmEmail'] || ''], onChange: (e) => {\r\n setField('confirmEmail', e.currentTarget.value);\r\n checkContinue();\r\n } }))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.schemeName, label: \"Scheme Name*\", error: state.labels[state.errors['schemeName'] || ''], onChange: (e) => {\r\n setField('schemeName', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.siteName, label: \"Site Name*\", error: state.labels[state.errors['siteName'] || ''], onChange: (e) => {\r\n setField('siteName', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Textbox, { value: state.form.telephone, label: \"Telephone Number*\", error: state.labels[state.errors['telephone'] || ''], onChange: (e) => {\r\n setField('telephone', e.currentTarget.value);\r\n checkContinue();\r\n } })),\r\n React.createElement(S.FullWidth, null,\r\n React.createElement(FormStyles.FormRow, { style: { marginTop: 15 } },\r\n state.errors['recaptchaToken'] && (React.createElement(FormStyles.FormError, null, state.labels[state.errors['recaptchaToken']])),\r\n React.createElement(\"div\", { className: `${state.errors['recaptchaToken'] ? 'invalid' : ''}` },\r\n React.createElement(Recaptcha, { shouldLoad: true, siteKey: '6Ld_N5wUAAAAANALiCT8yvJYZ8NRnNKut0MEvxdW', value: recaptcha, onChange: handleRecaptcha })))),\r\n React.createElement(S.FullWidth, null, state.labels['disclaimer'] !== undefined && state.labels['disclaimer'].length > 0 && (React.createElement(FormStyles.FormRow, { wide: true },\r\n React.createElement(FormStyles.FormControl, null,\r\n React.createElement(S.Disclaimer, { dangerouslySetInnerHTML: { __html: state.labels['disclaimer'] } })))))))));\r\n};\r\nexport default Details;\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconGrass(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 252 226\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 88\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Rectangle 203\",\n fill: \"#6f9d20\",\n d: \"M0 0h252v226H0z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 334\",\n d: \"M27.003 132.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 335\",\n d: \"M9.003 172.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 336\",\n d: \"M225.003 64.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 337\",\n d: \"M205.003 30.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 338\",\n d: \"M222.003 172.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 339\",\n d: \"M186.003 192.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 340\",\n d: \"M11.003 99.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 341\",\n d: \"M43.003 56.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 342\",\n d: \"M9.003 30.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 343\",\n d: \"M65.003 30.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 344\",\n d: \"M53.003 190.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 345\",\n d: \"M234.003 8.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 346\",\n d: \"M43.003 9.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 347\",\n d: \"M102.003 8.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 348\",\n d: \"M171.003 8.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 349\",\n d: \"M216.003 214.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 350\",\n d: \"M18.003 214.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 352\",\n d: \"M82.003 215.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 353\",\n d: \"M69.003 94.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 138\",\n d: \"M177.003 90.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 354\",\n d: \"M96.003 57.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 355\",\n d: \"M162.003 57.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 356\",\n d: \"M134.003 30.967a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 357\",\n d: \"M144.003 215.467a1.317 1.317 0 01.932-.71 2.645 2.645 0 011.2.059c.694.171 1.347.476 2.033.676a3.289 3.289 0 002.1.03c.983-.385 1.672-1.489 2.728-1.522\",\n fill: \"none\",\n stroke: \"#333\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }))));\n}\n\nexport default __webpack_public_path__ + \"349e12c57fdb55c24885c68014b45e0f.svg\";\nexport { SvgIconGrass as ReactComponent };","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgMap(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 47.656 68.067\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 11\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 21\",\n d: \"M23.797 68.067c-1.44-1.735-2.852-3.386-4.209-5.08A130.02 130.02 0 015.761 42.4 56.176 56.176 0 01.642 29.259 23.845 23.845 0 0119.656.35a23.82 23.82 0 0127.562 18.83 26.379 26.379 0 01-1.171 13.63 77.937 77.937 0 01-9 17.842 152.01 152.01 0 01-12.814 16.95c-.101.119-.214.231-.436.465zm.109-52.736a8.424 8.424 0 00-8.535 8.436 8.43 8.43 0 008.556 8.5 8.429 8.429 0 008.374-8.438 8.42 8.42 0 00-8.395-8.497z\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"6d653077d44aa1f90088cb9110657f8c.svg\";\nexport { SvgMap as ReactComponent };","import styled, { css } from 'styled-components';\r\nimport Grass from '@img/ysp/icon-grass.svg';\r\nimport { Device, from } from '@helpers/media';\r\nimport brand from '@helpers/brand';\r\nconst Container = styled.div `\r\n background-image: url(${Grass});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n width: 300px;\r\n height: 230px;\r\n padding-bottom: 30px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n margin: 0 auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n height: 250px;\r\n padding-bottom: 0px;\r\n }\r\n`;\r\nconst Outer = styled.div `\r\n background-color: #fdc135;\r\n border: 1px solid black;\r\n width: 100%;\r\n height: 100%;\r\n padding: 5px;\r\n position: relative;\r\n margin-right: 20px;\r\n transition: width 300ms ease, height 300ms ease;\r\n`;\r\nconst Inner = styled.div `\r\n background-color: #c7c7c7;\r\n border: 1px solid black;\r\n width: 100%;\r\n height: 100%;\r\n`;\r\nconst Arrow = styled.div `\r\n position: absolute;\r\n background-color: ${brand.grey.grey20};\r\n\r\n span {\r\n position: relative;\r\n color: ${brand.black};\r\n }\r\n\r\n &:before {\r\n content: '';\r\n width: 0;\r\n height: 0;\r\n border-left: 5px solid transparent;\r\n border-right: 5px solid transparent;\r\n border-bottom: 5px solid ${brand.grey.grey20};\r\n position: absolute;\r\n }\r\n\r\n &:after {\r\n content: '';\r\n width: 0;\r\n height: 0;\r\n border-left: 5px solid transparent;\r\n border-right: 5px solid transparent;\r\n border-bottom: 5px solid ${brand.grey.grey20};\r\n position: absolute;\r\n }\r\n\r\n ${({ direction }) => direction === 'width'\r\n ? css `\r\n top: 50%;\r\n right: -15px;\r\n transform: translateY(-50%);\r\n width: 1px;\r\n transition: height 375ms ease;\r\n\r\n &:before {\r\n bottom: 0;\r\n left: 50%;\r\n transform: translateX(-50%) rotate(180deg);\r\n }\r\n\r\n &:after {\r\n top: 0;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n }\r\n\r\n span {\r\n top: 50%;\r\n transform: translateY(-50%);\r\n left: 10px;\r\n }\r\n `\r\n : css `\r\n bottom: -15px;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n height: 1px;\r\n transition: width 375ms ease;\r\n\r\n &:before {\r\n right: -2px;\r\n top: 50%;\r\n transform: translateY(-50%) rotate(90deg);\r\n }\r\n\r\n &:after {\r\n left: -2px;\r\n top: 50%;\r\n transform: translateY(-50%) rotate(-90deg);\r\n }\r\n\r\n span {\r\n left: 50%;\r\n transform: translateX(-50%);\r\n top: 10px;\r\n }\r\n `}\r\n`;\r\nexport const DimensionsStyles = {\r\n Container,\r\n Outer,\r\n Inner,\r\n Arrow,\r\n};\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { DimensionsStyles as S } from './Dimensions.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport NumberInput from '../../Shared/NumberInput/NumberInput';\r\n// Visualizer settings.\r\nexport const MAX_SIZE = 140;\r\nconst Dimensions = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n beforeNext: () => dispatch({ type: 'validate-dimensions' }),\r\n },\r\n });\r\n }, []);\r\n const handleSet = (value, isWidth) => {\r\n if (value === undefined) {\r\n if (isWidth) {\r\n setFormField('width', undefined);\r\n }\r\n else {\r\n setFormField('length', undefined);\r\n }\r\n return;\r\n }\r\n let floatValue = parseFloat(value);\r\n if (floatValue > 99999) {\r\n floatValue = 99999;\r\n }\r\n if (value === '' || floatValue <= 0 || isNaN(floatValue)) {\r\n if (isWidth) {\r\n setFormField('width', undefined);\r\n }\r\n else {\r\n setFormField('length', undefined);\r\n }\r\n return;\r\n }\r\n if (isWidth) {\r\n setFormField('width', floatValue);\r\n }\r\n else {\r\n setFormField('length', floatValue);\r\n }\r\n };\r\n const ratio = (state.form.width || 1) / (state.form.length || 1);\r\n const actualHeight = ratio > 1 ? (1 / ratio) * MAX_SIZE : MAX_SIZE;\r\n const actualWidth = ratio < 1 ? ratio * MAX_SIZE : MAX_SIZE;\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } }))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(S.Container, null,\r\n React.createElement(S.Outer, { style: { width: `${actualHeight}px`, height: `${actualWidth}px` } },\r\n React.createElement(S.Inner, null,\r\n React.createElement(S.Arrow, { direction: \"width\", style: { height: `${actualWidth}px` } }, !isNaN(state.form.width || 0) && (React.createElement(\"span\", null,\r\n (state.form.width || 0).toFixed(2),\r\n \"m\"))),\r\n React.createElement(S.Arrow, { direction: \"length\", style: { width: `${actualHeight}px` } }, !isNaN(state.form.width || 0) && (React.createElement(\"span\", null,\r\n (state.form.length || 0).toFixed(2),\r\n \"m\"))))))),\r\n React.createElement(FormStyles.FormRow, { split: true },\r\n React.createElement(FormStyles.FormControl, { invalid: state.errors['length'] !== undefined },\r\n React.createElement(\"label\", { htmlFor: \"txtLength\" }, \"Length\"),\r\n React.createElement(NumberInput, { id: \"txtLength\", value: state.form.length, onChange: (e) => handleSet(e, false), step: 0.25 }),\r\n React.createElement(FormStyles.FormSub, null, \"m\")),\r\n React.createElement(FormStyles.FormControl, { invalid: state.errors['width'] !== undefined },\r\n React.createElement(\"label\", { htmlFor: \"txtWidth\" }, \"Width\"),\r\n React.createElement(NumberInput, { id: \"txtWidth\", value: state.form.width, onChange: (e) => handleSet(e, true), step: 0.25 }),\r\n React.createElement(FormStyles.FormSub, null, \"m\"))))));\r\n};\r\nexport default Dimensions;\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nimport { FormStyles } from '../../Shared/Form.styles';\r\nconst Intro = styled.div `\r\n text-align: center;\r\n color: ${brand.grey.grey20};\r\n overflow: hidden;\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n\r\n ${FormStyles.Form} {\r\n margin-bottom: 15px;\r\n }\r\n\r\n img {\r\n margin-bottom: 50px;\r\n }\r\n\r\n p {\r\n max-width: 630px;\r\n font-size: 15px;\r\n line-height: 20px;\r\n margin: 0px auto 15px;\r\n\r\n &:last-of-type {\r\n margin-bottom: 5px;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 19px;\r\n line-height: 25px;\r\n margin: 0px auto 20px;\r\n }\r\n }\r\n`;\r\nconst IntroTitleWrapper = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 25px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n margin-bottom: 5px;\r\n gap: 6px;\r\n h1 {\r\n font-size: 25px;\r\n color: rgb(51, 51, 51); \r\n }\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 35px;\r\n margin-bottom: 20px;\r\n gap: 10px;\r\n h1 {\r\n font-size: 35px; \r\n }\r\n }\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n\r\n span {\r\n line-height: 30px;\r\n }\r\n\r\n span:last-child {\r\n color: ${brand.primary.alt};\r\n }\r\n`;\r\nconst TitleAndPlusWrapper = styled.div `\r\n display: flex;\r\n align-items: center;\r\n position: relative;\r\n`;\r\nconst PleaseSelectText = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 20px;\r\n\r\n margin-bottom: 15px;\r\n`;\r\nconst Plus = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n x: 15,\r\n opacity: 0,\r\n },\r\n visible: {\r\n x: 0,\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n font-size: 32px;\r\n color: #ec671a;\r\n ${fonts.DaxPro.Bold};\r\n position: absolute;\r\n left: 100%;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 42px;\r\n }\r\n`;\r\nconst WelcomeText = styled.span `\r\n font-weight: 600;\r\n display: inline; \r\n margin-right: 10px;\r\n`;\r\nconst CenteredDiv = styled.div `\r\n display: flex;\r\n alignItems: center;\r\n @media (max-width: 768px) {\r\n flex-direction: column;\r\n }\r\n`;\r\nexport const LandingStyles = {\r\n Intro,\r\n IntroTitleWrapper,\r\n Title,\r\n PleaseSelectText,\r\n Plus,\r\n TitleAndPlusWrapper,\r\n WelcomeText,\r\n CenteredDiv,\r\n};\r\n","import React from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport { LandingStyles as S } from './Landing.styles';\r\nimport { Tab } from '@ys/Context/types';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport YSButton from '../../Shared/YSButton/YSButton';\r\nconst Landing = () => {\r\n const { state, dispatch } = useYSPContext();\r\n const renderTooltip = () => {\r\n const tooltipText = state.labels['tooltip'];\r\n if (tooltipText === '' || tooltipText === undefined) {\r\n return null;\r\n }\r\n return (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: tooltipText,\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) }));\r\n };\r\n return (React.createElement(StepStyles.Grid, { centered: true },\r\n React.createElement(Containers.FullWidth, null,\r\n React.createElement(S.Intro, null,\r\n React.createElement(S.IntroTitleWrapper, null,\r\n React.createElement(\"h1\", null,\r\n React.createElement(S.CenteredDiv, null,\r\n React.createElement(S.WelcomeText, null, state.labels['title'] || 'Welcome to '),\r\n React.createElement(S.TitleAndPlusWrapper, null,\r\n React.createElement(S.Title, null,\r\n React.createElement(\"span\", null, \" Your\"),\r\n React.createElement(\"span\", null, \"Solution\")),\r\n React.createElement(AnimatePresence, null, state.tab === Tab.YourSolutionPlus && React.createElement(S.Plus, null, \"+\")))))),\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"div\", { dangerouslySetInnerHTML: { __html: state.labels['content'] } }),\r\n renderTooltip()),\r\n React.createElement(YSButton, { onClick: () => dispatch({ type: 'next-step' }), icon: \"arrow\", hideOnMobile: true }, state.labels['next'])))));\r\n};\r\nexport default Landing;\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconWatercourse(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 589.157 503.239\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 87\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Rectangle 28\",\n fill: \"#6f9d20\",\n d: \"M0 0h503.239v503.239H0z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 129\",\n d: \"M104.332 35.186a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 131\",\n d: \"M168.772 121.105a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 132\",\n d: \"M239.348 32.117a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 133\",\n d: \"M392.774 29.049a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 134\",\n d: \"M328.335 124.173a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 135\",\n d: \"M104.332 213.161a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 136\",\n d: \"M257.759 210.092a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 137\",\n d: \"M417.322 213.161a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 138\",\n d: \"M438.802 124.173a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 140\",\n d: \"M168.772 299.079a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 141\",\n d: \"M328.335 302.148a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 142\",\n d: \"M104.332 391.135a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 143\",\n d: \"M257.759 388.067a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 144\",\n d: \"M417.322 391.135a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 145\",\n d: \"M438.802 302.148a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 146\",\n d: \"M61.373 473.985a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 147\",\n d: \"M239.348 480.123a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 148\",\n d: \"M392.774 477.054a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Rectangle 188\",\n fill: \"#85d0e6\",\n d: \"M497.101 0h92.056v503.239h-92.056z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 223\",\n d: \"M527.34 86.616c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 224\",\n d: \"M564.162 151.055c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 225\",\n d: \"M521.202 206.29c-1.031-.952-1.558-2.937-1.585-4.964a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 226\",\n d: \"M564.162 264.591c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 227\",\n d: \"M521.202 335.167c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 228\",\n d: \"M558.025 405.743c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 229\",\n d: \"M521.202 464.045c-1.031-.951-1.558-2.936-1.585-4.963a21.974 21.974 0 01.926-6.042c.948-3.431 2.282-6.608 3.317-9.987a27.153 27.153 0 001.393-10.587c-.566-5.097-3.503-8.98-2.95-14.31\",\n fill: \"none\",\n stroke: \"#06637e\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 230\",\n d: \"M33.756 118.036a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 231\",\n d: \"M33.756 296.011a4.04 4.04 0 012.861-2.18 8.117 8.117 0 013.694.182c2.129.523 4.134 1.46 6.237 2.075a10.094 10.094 0 006.455.093c3.017-1.182 5.13-4.568 8.37-4.671\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Rectangle 205\",\n fill: \"#fdc135\",\n stroke: \"#000\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n stroke: \"none\",\n d: \"M146.52 461.815V32.221h211.728v429.594z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n fill: \"none\",\n d: \"M147.02 461.315V32.721h210.728v428.594z\"\n })), /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Rectangle 233\",\n fill: \"#c7c7c7\",\n stroke: \"#000\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n stroke: \"none\",\n d: \"M167.613 440.721V53.314h169.541v387.407z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n fill: \"none\",\n d: \"M168.113 440.221V53.814h168.541v386.407z\"\n })))));\n}\n\nexport default __webpack_public_path__ + \"0d9b32d307982d5c7462135d4f6358d7.svg\";\nexport { SvgIconWatercourse as ReactComponent };","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { ReactComponent as Map } from '@img/icons/map.svg';\r\nimport Textbox from '@ys/Components/Steps/Controls/Textbox/Textbox';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport InfoIcon from '../../InfoIcon/InfoIcon';\r\nconst Location = () => {\r\n const { state, dispatch, setFormField: setField } = useYSPContext();\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n beforeNext: handleNext,\r\n },\r\n });\r\n }, []);\r\n const handleNext = () => {\r\n dispatch({ type: 'validate-postcode' });\r\n };\r\n const setPostCode = (value) => {\r\n setField('postCode', value);\r\n };\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) }))),\r\n React.createElement(SharedStyles.Avatar, null,\r\n React.createElement(Map, null)),\r\n React.createElement(Textbox, { restrictWidth: true, label: \"Postcode\", value: state.form.postCode, error: state.labels[state.errors['postCode'] || ''], onChange: (e) => setPostCode(e.currentTarget.value) }))));\r\n};\r\nexport default Location;\r\n","import brand from '@helpers/brand';\r\nimport styled from 'styled-components';\r\nconst SwapToYSP = styled.div `\r\n border-top: 1px solid ${brand.primary.light};\r\n position: relative;\r\n max-width: 720px;\r\n margin-top: 25px;\r\n padding: 25px 0px;\r\n display: flex;\r\n flex-direction: column;\r\n align-items: center;\r\n gap: 15px;\r\n`;\r\nconst OrLabel = styled.div `\r\n position: absolute;\r\n top: 0;\r\n left: 50%;\r\n transform: translate(-50%, -50%);\r\n padding: 10px;\r\n background-color: ${brand.white};\r\n`;\r\nconst Buttons = styled.div `\r\n display: flex;\r\n gap: 15px;\r\n margin-top: 20px;\r\n`;\r\nexport const NoSolutionsStyles = {\r\n SwapToYSP,\r\n OrLabel,\r\n Buttons,\r\n};\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport { checkCanTransfer } from '@helpers/ysToYsp';\r\nimport { NoSolutionsStyles as S } from './NoSolutions.styles';\r\nimport YSButton, { YSLinkButton } from '../../Shared/YSButton/YSButton';\r\nconst NoSolutions = () => {\r\n const { state, dispatch } = useYSPContext();\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'default',\r\n },\r\n });\r\n }, []);\r\n if (!state.results) {\r\n return null;\r\n }\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.CenterText, { dangerouslySetInnerHTML: { __html: state.results.responseMessage } }),\r\n React.createElement(S.Buttons, null,\r\n state.results.telNo && (React.createElement(YSLinkButton, { href: `tel:${state.results.telNo}`, fill: \"outline\", colour: \"green\", icon: \"phone\", iconPosition: \"left\" }, \"Call\")),\r\n state.results.emailAddress && (React.createElement(YSLinkButton, { href: `mailto:${state.results.emailAddress}`, fill: \"outline\", colour: \"green\", icon: \"email\", iconPosition: \"left\" }, \"Email\"))),\r\n checkCanTransfer(state.form) && (React.createElement(S.SwapToYSP, null,\r\n React.createElement(S.OrLabel, null, \"or\"),\r\n React.createElement(\"p\", null,\r\n \"The parameters you entered have not yielded any results, however\",\r\n ' ',\r\n React.createElement(\"strong\", null, \"YourSolution+\"),\r\n \" may be able to find some using more in-depth questions.\",\r\n React.createElement(\"br\", null),\r\n \"All applicable answers entered on YourSolution will be carried over.\"),\r\n React.createElement(YSButton, { onClick: () => dispatch({ type: 'swap-to-ys-plus' }) }, \"Swap to YourSolution+\"))))));\r\n};\r\nexport default NoSolutions;\r\n","import { SupportType } from '@stories/Widgets/YourSolution/YS/Context/types';\r\n// Utilities for the transfer logic between the two //\r\nexport const checkCanTransfer = (form) => {\r\n return form.supportType === SupportType.Box;\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n flex-wrap: nowrap;\r\n margin-top: 40px;\r\n max-width: 850px;\r\n width: 100%;\r\n\r\n ${() => FormStyles.FormRow} {\r\n @media ${from(Device.Tablet)} {\r\n position: relative;\r\n z-index: 1;\r\n }\r\n }\r\n\r\n @media ${from(Device.Tablet)} {\r\n position: relative;\r\n z-index: 1;\r\n }\r\n`;\r\nconst Item = styled.div `\r\n display: flex;\r\n flex-direction: column-reverse;\r\n width: 100%;\r\n box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);\r\n margin-bottom: 40px;\r\n\r\n @media ${from(Device.Tablet)} {\r\n flex-direction: row;\r\n flex-wrap: nowrap;\r\n }\r\n\r\n h2 {\r\n font-size: 21px;\r\n text-align: left;\r\n margin-bottom: 18px;\r\n }\r\n\r\n ul {\r\n margin-bottom: 32px;\r\n padding: 0px;\r\n list-style-type: none;\r\n border: 1px solid ${brand.primary.light};\r\n list-style: disc;\r\n\r\n @media ${from(Device.Tablet)} {\r\n list-style-type: disc;\r\n padding-left: 18px;\r\n border: none;\r\n }\r\n\r\n li {\r\n color: ${brand.primary.light};\r\n padding: 5px 10px;\r\n border-bottom: 1px solid ${brand.primary.light};\r\n list-style-type: disc;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 0px;\r\n border-bottom: none;\r\n }\r\n\r\n &:before {\r\n display: none;\r\n }\r\n\r\n &:nth-child(even) {\r\n background-color: #e2f0d9;\r\n\r\n @media ${from(Device.Tablet)} {\r\n background: none;\r\n }\r\n }\r\n\r\n &:last-child {\r\n border-bottom: none;\r\n }\r\n\r\n strong {\r\n margin-right: auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin-right: 0px;\r\n }\r\n\r\n &:after {\r\n @media ${from(Device.Tablet)} {\r\n content: ':';\r\n display: inline-block;\r\n margin-right: 4px;\r\n }\r\n }\r\n }\r\n\r\n span {\r\n color: #333333;\r\n display: flex;\r\n flex-direction: row;\r\n justify-content: space-between;\r\n ${fonts.DaxPro.Bold};\r\n\r\n @media ${from(Device.Tablet)} {\r\n display: inline-block;\r\n }\r\n }\r\n }\r\n }\r\n`;\r\nconst Copy = styled.div `\r\n flex: 0 0 65%;\r\n`;\r\nconst CopyInner = styled.div `\r\n padding: 15px;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 70px;\r\n }\r\n`;\r\nconst Media = styled.div `\r\n flex: 0 0 35%;\r\n background-color: ${brand.white};\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n picture {\r\n height: 100%;\r\n }\r\n\r\n img {\r\n flex: 0 0 auto;\r\n display: block;\r\n margin-left: auto;\r\n height: 100%;\r\n width: 100%;\r\n object-fit: contain;\r\n }\r\n`;\r\nconst MediaInner = styled.div `\r\n width: 100%;\r\n padding: 16px;\r\n flex: 1 0 1px;\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n height: 100%;\r\n display: block;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 0;\r\n }\r\n`;\r\nexport const SolutionsStyles = {\r\n Container,\r\n Item,\r\n Copy,\r\n CopyInner,\r\n Media,\r\n MediaInner,\r\n};\r\n","import React from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { SolutionsStyles as S } from './Solutions.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport { YSLinkButton } from '../../Shared/YSButton/YSButton';\r\nconst Solutions = () => {\r\n const { state } = useYSPContext();\r\n if (state.results === undefined) {\r\n return null;\r\n }\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.CenterText, { dangerouslySetInnerHTML: { __html: state.results.responseMessage } })),\r\n React.createElement(S.Container, null, state.results.solutions.map((x) => (React.createElement(S.Item, { key: x.url },\r\n React.createElement(S.Copy, null,\r\n React.createElement(S.CopyInner, null,\r\n React.createElement(\"h2\", null, x.displayName),\r\n React.createElement(\"ul\", null, Object.keys(x.tableData).map((key) => (React.createElement(\"li\", { key: key },\r\n React.createElement(\"span\", null,\r\n React.createElement(\"strong\", null, key),\r\n x.tableData[key]))))),\r\n React.createElement(YSLinkButton, { fill: \"outline\", target: \"_blank\", href: x.url }, \"Download Solution\"))),\r\n React.createElement(S.Media, null,\r\n React.createElement(S.MediaInner, null,\r\n React.createElement(\"picture\", null,\r\n React.createElement(\"source\", { media: \"(min-width: 996px)\", srcSet: x.desktopImage }),\r\n React.createElement(\"img\", { src: x.desktopImage, srcSet: x.mobileImage })))))))),\r\n state.authenticatedUser === undefined && (React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.CenterText, null,\r\n React.createElement(\"div\", { dangerouslySetInnerHTML: { __html: state.results.technicalMessage } }),\r\n React.createElement(\"br\", null),\r\n React.createElement(YSLinkButton, { center: true, href: state.technicalLibraryUrl }, \"Create an Account\"))))));\r\n};\r\nexport default Solutions;\r\n","import { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n ${({ singleQuestion }) => !singleQuestion &&\r\n css `\r\n display: flex;\r\n flex-direction: column;\r\n max-width: 900px;\r\n width: 100%;\r\n justify-content: center;\r\n\r\n @media ${from(Device.Tablet)} {\r\n flex-direction: row;\r\n flex-wrap: wrap;\r\n width: auto;\r\n }\r\n `};\r\n`;\r\nexport const BoxesStyles = {\r\n Container,\r\n};\r\n","import React from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { BoxesStyles as S } from './Boxes.styles';\r\nconst Boxes = ({ boxes, error, value, setValue }) => {\r\n const { dispatch } = useYSPContext();\r\n const handleSetModalActive = (value) => {\r\n const activeBox = boxes.find((x) => x.id === value);\r\n if (activeBox !== undefined) {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n title: activeBox.title,\r\n description: activeBox.description,\r\n imageUrl: activeBox.imageUrl,\r\n fullWidth: false,\r\n size: 'normal',\r\n },\r\n });\r\n }\r\n };\r\n return (React.createElement(S.Container, null, boxes.map((x) => {\r\n return (React.createElement(SharedStyles.Box, { key: x.id, active: value !== undefined && value === x.id, invalid: error !== undefined },\r\n React.createElement(SharedStyles.BoxInner, { onClick: () => setValue(x.id) },\r\n React.createElement(SharedStyles.BoxMedia, null,\r\n React.createElement(\"img\", { src: x.imageUrl, alt: x.title, style: { objectFit: 'cover' } })),\r\n React.createElement(SharedStyles.BoxLabel, null, x.title),\r\n React.createElement(SharedStyles.BoxState, null)),\r\n x.description && x.description.length > 0 && (React.createElement(SharedStyles.BoxInfo, null,\r\n React.createElement(InfoIcon, { onClick: () => handleSetModalActive(x.id) })))));\r\n })));\r\n};\r\nexport default Boxes;\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SolutionSubType } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport Boxes from '@ys/Components/Steps/Controls/Boxes/Boxes';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '../../../Shared/Form.styles';\r\nconst SheetedSolution = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'support',\r\n beforeNext: () => dispatch({ type: 'validate-sub-type' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading_frameType']),\r\n React.createElement(Boxes, { error: state.errors['subType'], boxes: [\r\n {\r\n id: SolutionSubType.SingleFrame,\r\n title: 'Single frame Propped cantilever',\r\n description: state.labels['tooltip_singleFrame'],\r\n imageUrl: '/sitefiles/images/ism/products/B-1F-1Frame.png',\r\n },\r\n {\r\n id: SolutionSubType.TwoFrame,\r\n title: '2 frame, no toe solution',\r\n description: state.labels['tooltip_twoFrame'],\r\n imageUrl: '/sitefiles/images/ism/products/B-2F-2Frame.png',\r\n },\r\n ], value: state.form.subType, setValue: (value) => setFormField('subType', value) }))));\r\n};\r\nexport default SheetedSolution;\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SupportType } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport Boxes from '@ys/Components/Steps/Controls/Boxes/Boxes';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '../../../Shared/Form.styles';\r\nconst System = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'support',\r\n beforeNext: () => dispatch({ type: 'validate-support' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n React.createElement(Boxes, { error: state.errors['supportType'], boxes: [\r\n {\r\n id: SupportType.Box,\r\n title: 'Boxes',\r\n description: state.labels['tooltip_box'],\r\n imageUrl: '/sitefiles/images/ism/products/MB-BH-1-Backhoe(BaseOnly).png',\r\n },\r\n {\r\n id: SupportType.Frame,\r\n title: 'Sheets & Frames',\r\n description: state.labels['tooltip_frame'],\r\n imageUrl: '/sitefiles/images/ism/products/B-2F-2Frame.png',\r\n },\r\n ], value: state.form.supportType, setValue: (value) => setFormField('supportType', value, ['type', 'subType']) }))));\r\n};\r\nexport default System;\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconSlope(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 201.355 83.276\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 46\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 235\",\n d: \"M200.707 82.63c-4.248-1.669-3.355-4.152-6.761-5.951-4.62-2.44-10.754-.115-15.251-2.773-2.929-1.732-4.576-5.29-7.739-6.541-3.114-1.232-6.8.152-9.912-1.094-3.027-1.214-4.719-4.6-7.7-5.926-3.457-1.532-7.717.112-11.153-1.468-3.154-1.45-4.653-5.164-7.572-7.044-2.473-1.593-5.456-1.732-8.305-1.527-3.57.258-6.818 2.293-9.806-.518-2.5-2.35-3.9-6.055-7.3-7.331-3.581-1.341-7.559.887-11.331.275-5.86-.952-8.873-8.119-14.574-9.789-2.8-.82-5.793-.167-8.695-.43a13.909 13.909 0 01-8.268-3.755c-2.725-2.6-4.972-6.612-8.738-6.608a27.1 27.1 0 00-3.707.671c-3.422.483-6.8-1.507-9.089-4.1-1.834-2.082-3.612-4.83-6.389-4.929-2.472-.088-4.773 2.1-7.154 1.408-3.152-.911-3.145-5.66-5.8-7.588-3.444-2.5-8.63 1.287-12.409-.678-2.222-1.157-3.114-3.908-5.126-5.4a5.685 5.685 0 00-7.222.576v80.52z\",\n fill: \"#c9c9c9\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 236\",\n d: \"M200.707 82.63c-4.248-1.669-3.355-4.152-6.761-5.951-4.62-2.44-10.754-.115-15.251-2.773-2.929-1.732-4.576-5.29-7.739-6.541-3.114-1.232-6.8.152-9.912-1.094-3.027-1.214-4.719-4.6-7.7-5.926-3.457-1.532-7.717.112-11.153-1.468-3.154-1.45-4.653-5.164-7.572-7.044-2.473-1.593-5.456-1.732-8.305-1.527-3.57.258-6.818 2.293-9.806-.518-2.5-2.35-3.9-6.055-7.3-7.331-3.581-1.341-7.559.887-11.331.275-5.86-.952-8.873-8.119-14.574-9.789-2.8-.82-5.793-.167-8.695-.43a13.909 13.909 0 01-8.268-3.755c-2.725-2.6-4.972-6.612-8.738-6.608a27.1 27.1 0 00-3.707.671c-3.422.483-6.8-1.507-9.089-4.1-1.834-2.082-3.612-4.83-6.389-4.929-2.472-.088-4.773 2.1-7.154 1.408-3.152-.911-3.145-5.66-5.8-7.588-3.444-2.5-8.63 1.287-12.409-.678-2.222-1.157-3.114-3.908-5.126-5.4a5.685 5.685 0 00-7.222.576\",\n fill: \"none\",\n stroke: \"#161615\",\n strokeLinecap: \"round\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 237\",\n d: \"M13.036 25.844a3.277 3.277 0 01.784-.542 7.159 7.159 0 013.6-.522 8.907 8.907 0 013.241.652c2.225 1.011 2.942 3.59 3.083 5.841.155 2.486-11.489 3.861-11.774-1.718a4.573 4.573 0 011.066-3.711z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 238\",\n d: \"M47.144 34.647a1.646 1.646 0 01-.056-.473 3.581 3.581 0 01.61-1.712 4.451 4.451 0 011.046-1.28 3.229 3.229 0 013.3 0c1.135.513-.981 5.98-3.513 4.8a2.285 2.285 0 01-1.387-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 239\",\n d: \"M34.857 53.172a3.291 3.291 0 01.783-.542 7.161 7.161 0 013.6-.522 8.886 8.886 0 013.241.653c2.225 1.01 2.942 3.589 3.083 5.84.156 2.488-11.489 3.861-11.773-1.718a4.573 4.573 0 011.066-3.711z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 240\",\n d: \"M72.86 46.116a3.277 3.277 0 01.784-.542 7.16 7.16 0 013.6-.522 8.887 8.887 0 013.241.653c2.225 1.01 2.942 3.59 3.083 5.84.155 2.487-11.489 3.861-11.774-1.718a4.573 4.573 0 011.066-3.711z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 241\",\n d: \"M57.642 75.232a1.646 1.646 0 01-.056-.473 3.581 3.581 0 01.61-1.712 4.451 4.451 0 011.046-1.28 3.229 3.229 0 013.3 0c1.136.513-.981 5.98-3.513 4.8a2.285 2.285 0 01-1.387-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 242\",\n d: \"M103.911 61.173a3.27 3.27 0 01.783-.542 7.159 7.159 0 013.6-.522 8.887 8.887 0 013.241.653c2.225 1.01 2.942 3.589 3.083 5.84.156 2.488-11.489 3.861-11.774-1.718a4.57 4.57 0 011.067-3.711z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 243\",\n d: \"M138.048 72.517a1.682 1.682 0 01-.056-.473 3.572 3.572 0 01.611-1.712 4.434 4.434 0 011.046-1.28 3.227 3.227 0 013.3 0c1.136.513-.981 5.98-3.513 4.8a2.285 2.285 0 01-1.388-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 244\",\n d: \"M8.285 50.577a1.6 1.6 0 01-.056-.473 3.589 3.589 0 01.61-1.712 4.465 4.465 0 011.046-1.28 3.227 3.227 0 013.3 0c1.135.513-.982 5.979-3.514 4.8a2.291 2.291 0 01-1.386-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 245\",\n d: \"M15.267 75.232a1.61 1.61 0 01-.056-.473 3.581 3.581 0 01.61-1.712 4.451 4.451 0 011.046-1.28 3.229 3.229 0 013.3 0c1.136.513-.982 5.98-3.514 4.8a2.286 2.286 0 01-1.386-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 246\",\n d: \"M87.632 71.415a1.684 1.684 0 01-.056-.473 3.571 3.571 0 01.611-1.712 4.433 4.433 0 011.046-1.28 3.227 3.227 0 013.3 0c1.136.513-.981 5.98-3.513 4.8a2.285 2.285 0 01-1.388-1.335z\",\n fill: \"none\",\n stroke: \"#040405\",\n strokeMiterlimit: 10\n }))));\n}\n\nexport default __webpack_public_path__ + \"3235067036ca3bf63b54cf509bf9a25a.svg\";\nexport { SvgIconSlope as ReactComponent };","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { ReactComponent as Watercourse } from '@img/ysp/icon-watercourse.svg';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nconst AdjacentWater = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'surcharges',\r\n beforeNext: () => dispatch({ type: 'validate-adjacent-water' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading_adjacent']),\r\n state.labels['subheading_adjacent'] !== undefined &&\r\n state.labels['subheading_adjacent'].length > 0 && (React.createElement(SharedStyles.CenterText, null, state.labels['subheading_adjacent'])),\r\n React.createElement(SharedStyles.Icon, null,\r\n React.createElement(Watercourse, null)),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Radios, { error: state.errors['adjacentWater'], value: state.form.adjacentWater, setValue: (value) => setFormField('adjacentWater', value) })))));\r\n};\r\nexport default AdjacentWater;\r\n","export default __webpack_public_path__ + \"01f9b79c2f15f33d5089f29474ce3cb2.png\";","export default __webpack_public_path__ + \"270072563d074f6bd7cd0f917e328249.png\";","export default __webpack_public_path__ + \"e258fb1e69d5e7e12dddbed95bcde457.png\";","export default __webpack_public_path__ + \"34baad14557bad6b40020117915dc09a.png\";","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport Embankments from '@img/ysp/surcharges/embankments.png';\r\nimport Building from '@img/ysp/surcharges/building.png';\r\nimport Crane from '@img/ysp/surcharges/crane.png';\r\nimport Railway from '@img/ysp/surcharges/railway.png';\r\nimport { Tab } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nconst LargeSurcharges = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const hasTooltip = state.labels['tooltip_surcharges'] !== undefined &&\r\n state.labels['tooltip_surcharges'].length > 0;\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'surcharges',\r\n beforeNext: () => dispatch({ type: 'validate-large-surcharges' }),\r\n },\r\n });\r\n }, []);\r\n const handleSetModal = () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n fullWidth: true,\r\n title: '',\r\n description: state.labels['tooltip_surcharges'],\r\n imageUrl: '/sitefiles/images/ism/zone-of-influence-new.png',\r\n size: 'normal',\r\n },\r\n });\r\n };\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n state.tab === Tab.YourSolutionPlus ? (React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) })))) : (React.createElement(React.Fragment, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n hasTooltip && React.createElement(InfoIcon, { onClick: () => handleSetModal() }))),\r\n React.createElement(SharedStyles.Materials, null,\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { large: true },\r\n React.createElement(\"img\", { src: Embankments, alt: \"Embankments, spoil heaps, stored material\" })),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Embankments, spoil heaps, stored material\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { large: true },\r\n React.createElement(\"img\", { src: Building, alt: \"Buildings or structures\" })),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Buildings or structures\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { large: true },\r\n React.createElement(\"img\", { src: Crane, alt: \"Plant exceeding 30t (Including cranes)\" })),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Plant exceeding 30t (Including cranes)\")),\r\n React.createElement(SharedStyles.Material, null,\r\n React.createElement(SharedStyles.MaterialMedia, { large: true },\r\n React.createElement(\"img\", { src: Railway, alt: \"Railways, motorways and trunk roads\" })),\r\n React.createElement(SharedStyles.MaterialLabel, null, \"Railways, motorways and trunk roads\"))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Radios, { error: state.errors['largeSurcharges'], value: state.form.largeSurcharges, setValue: (value) => setFormField('largeSurcharges', value) })))));\r\n};\r\nexport default LargeSurcharges;\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { ReactComponent as Slope } from '@img/ysp/icon-slope.svg';\r\nimport Radios from '@ys/Components/Steps/Controls/Radios/Radios';\r\nimport { FormStyles } from '../../../Shared/Form.styles';\r\nconst SlopingGround = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n type: 'surcharges',\r\n beforeNext: () => dispatch({ type: 'validate-sloping-ground' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading_sloping']),\r\n state.labels['subheading_sloping'] !== undefined &&\r\n state.labels['subheading_sloping'].length > 0 && (React.createElement(React.Fragment, null,\r\n React.createElement(SharedStyles.CenterText, null, state.labels['subheading_sloping']),\r\n React.createElement(\"br\", null))),\r\n React.createElement(SharedStyles.Icon, null,\r\n React.createElement(Slope, null)),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(Radios, { error: state.errors['slopingGround'], value: state.form.slopingGround, setValue: (value) => setFormField('slopingGround', value) })))));\r\n};\r\nexport default SlopingGround;\r\n","import React, { useEffect } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SolutionType, SupportType, Tab } from '@ys/Context/types';\r\nimport Boxes from '@ys/Components/Steps/Controls/Boxes/Boxes';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nconst Type = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n //\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n beforeNext: () => dispatch({ type: 'validate-type' }),\r\n },\r\n });\r\n }, []);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n state.form.supportType === SupportType.Box && (React.createElement(React.Fragment, null,\r\n React.createElement(\"h2\", null, state.labels['heading_boxType']),\r\n React.createElement(Boxes, { error: state.errors['type'], boxes: [\r\n {\r\n id: SolutionType.TrenchBox,\r\n title: 'Trench Box',\r\n description: state.labels['tooltip_trench'],\r\n imageUrl: '/sitefiles/images/ism/products/TB-BH-1-Backhoe(BaseOnly).png',\r\n },\r\n {\r\n id: SolutionType.ManholeBox,\r\n title: 'Manhole Box',\r\n description: state.labels['tooltip_manholeBox'],\r\n imageUrl: '/sitefiles/images/ism/products/MB-BH-1-Backhoe(BaseOnly).png',\r\n },\r\n {\r\n id: SolutionType.Lightweight,\r\n title: 'Lightweight box',\r\n description: state.labels['tooltip_lightDuty'],\r\n imageUrl: '/sitefiles/images/ism/products/LW-MAP.png',\r\n },\r\n ], value: state.form.type, setValue: (value) => setFormField('type', value) }))),\r\n state.form.supportType === SupportType.Frame && (React.createElement(React.Fragment, null,\r\n React.createElement(\"h2\", null, state.labels['heading_frameType']),\r\n React.createElement(Boxes, { error: state.errors['type'], boxes: [\r\n {\r\n id: SolutionType.SheetsAndManholeBrace,\r\n title: 'Manhole Brace',\r\n description: state.labels['tooltip_manholeBrace'],\r\n imageUrl: '/sitefiles/images/ism/products/B-1F-1Frame.png',\r\n },\r\n {\r\n id: SolutionType.SheetsAndWalers,\r\n title: 'Walers',\r\n description: state.labels['tooltip_walers'],\r\n imageUrl: '/sitefiles/images/ism/products/W-1F-1Frame.png',\r\n },\r\n ], value: state.form.type, setValue: (value) => setFormField('type', value) }))),\r\n state.tab === Tab.YourSolutionPlus &&\r\n React.createElement(React.Fragment, null,\r\n React.createElement(\"h2\", null, state.labels['heading_frameType']),\r\n state.labels['tooltip_frameType'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip_frameType'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } })),\r\n React.createElement(Boxes, { error: state.errors['type'], boxes: [\r\n {\r\n id: SolutionType.TrenchBox,\r\n title: 'Trench Box',\r\n description: state.labels['tooltip_trench'],\r\n imageUrl: '/sitefiles/images/ism/products/TB-BH-1-Backhoe(BaseOnly).png',\r\n },\r\n {\r\n id: SolutionType.ManholeBox,\r\n title: 'Manhole Box',\r\n description: state.labels['tooltip_manholeBox'],\r\n imageUrl: '/sitefiles/images/ism/products/MB-BH-1-Backhoe(BaseOnly).png',\r\n },\r\n ], value: state.form.type, setValue: (value) => setFormField('type', value) })))));\r\n};\r\nexport default Type;\r\n","export default __webpack_public_path__ + \"af4fdf63c0584fc31888b183213176c7.png\";","import React, { useEffect } from 'react';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport EndSafe from '@img/ysp/endsafe.png';\r\nimport Radios from '../Controls/Radios/Radios';\r\nconst EndSafePanels = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: state.form.endSafePanelsRequired === undefined,\r\n },\r\n });\r\n }, [state.form.endSafePanelsRequired]);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } }))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(\"img\", { src: EndSafe, alt: \"EndSafe Panels\" })),\r\n React.createElement(FormStyles.FormRow, { xCentered: true, style: { marginTop: 25 } },\r\n React.createElement(Radios, { value: state.form.endSafePanelsRequired, error: state.errors['endSafePanelsRequired'], setValue: (value) => setFormField('endSafePanelsRequired', value) })))));\r\n};\r\nexport default EndSafePanels;\r\n","import React, { useEffect } from 'react';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport EndSafe from '@img/ysp/endsafe.png';\r\nimport Radios from '../Controls/Radios/Radios';\r\nimport { EndSafeSide } from '../../../Context/types';\r\nconst EndSafeSides = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: state.form.endSafeSides === undefined,\r\n },\r\n });\r\n }, [state.form.endSafeSides]);\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['sides.heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } }))),\r\n React.createElement(FormStyles.FormRow, null,\r\n React.createElement(\"img\", { src: EndSafe, alt: \"EndSafe Panels\" })),\r\n React.createElement(FormStyles.FormRow, { xCentered: true, style: { marginTop: 25 } },\r\n React.createElement(Radios, { options: [\r\n {\r\n label: 'One',\r\n value: EndSafeSide.One,\r\n },\r\n {\r\n label: 'Both',\r\n value: EndSafeSide.Both,\r\n },\r\n ], value: state.form.endSafeSides, error: state.errors['endSafeSides'], setValue: (value) => {\r\n setFormField('endSafeSides', value);\r\n } })))));\r\n};\r\nexport default EndSafeSides;\r\n","import React from 'react';\r\nimport { ModalStyles as S } from './Modal.styles';\r\nimport { ReactComponent as Close } from '@img/ysp/icon-cross.svg';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport { withMotion } from '@hoc/withMotion';\r\nimport YSButton from '../Shared/YSButton/YSButton';\r\nconst ConfirmModal = ({ text, noText, yesText, onNo, onYes, onClose, visible, }) => {\r\n return (React.createElement(AnimatePresence, null, visible && (React.createElement(S.BoxModal, { key: 'ConfirmModal', small: true, active: true },\r\n React.createElement(S.BoxModalInner, null,\r\n React.createElement(S.BoxModalClose, { onClick: () => onClose() },\r\n React.createElement(Close, null)),\r\n React.createElement(S.ConfirmText, null, text),\r\n React.createElement(S.Buttons, null,\r\n React.createElement(YSButton, { colour: \"green\", onClick: () => onYes() }, yesText),\r\n React.createElement(YSButton, { colour: \"orange\", onClick: () => onNo() }, noText)))))));\r\n};\r\nexport default withMotion(ConfirmModal);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n border-radius: 5px;\r\n border: 2px solid ${brand.grey.grey35};\r\n background-color: ${brand.white};\r\n position: relative;\r\n height: 100%;\r\n transition: background-color 0.2s ease-in-out;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n grid-column: 1 / -1;\r\n }\r\n`;\r\nconst TopSection = styled.div `\r\n ${fonts.DaxPro.Regular};\r\n display: grid;\r\n grid-template-columns: 1fr 25px;\r\n cursor: pointer;\r\n padding: 0px 10px;\r\n height: 100%;\r\n user-select: none;\r\n max-height: 42px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n max-height: 30px;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n min-height: 30px;\r\n }\r\n\r\n span {\r\n margin: auto 0;\r\n }\r\n\r\n svg {\r\n margin: auto;\r\n color: ${brand.primary.alt};\r\n width: 15px;\r\n }\r\n`;\r\nconst DropdownWrapper = styled(m.div).attrs(({ active }) => ({\r\n initial: 'hidden',\r\n animate: active ? 'visible' : 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n opacity: 0,\r\n transition: {\r\n opacity: {\r\n duration: 0.1,\r\n delay: 0.2,\r\n },\r\n },\r\n },\r\n visible: {\r\n height: 'auto',\r\n opacity: 1,\r\n transition: {\r\n opacity: {\r\n duration: 0.1,\r\n },\r\n },\r\n },\r\n },\r\n})) `\r\n position: absolute;\r\n top: calc(100% + 2px);\r\n left: 0;\r\n width: 100%;\r\n z-index: ${({ i }) => 20 - i};\r\n background-color: ${brand.white};\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n z-index: ${({ i }) => 6 - i};\r\n }\r\n`;\r\nconst BorderWrapper = styled.div `\r\n overflow-y: auto;\r\n height: 100%;\r\n border: 2px solid ${brand.grey.grey35};\r\n border-top: none;\r\n max-height: 450px;\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n`;\r\nconst Dropdown = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\nconst DropdownOption = styled.div `\r\n display: grid;\r\n grid-template-columns: 30px 1fr;\r\n gap: 10px;\r\n align-items: center;\r\n padding: 5px;\r\n cursor: pointer;\r\n transition: background-color 0.1s ease-in-out;\r\n user-select: none;\r\n\r\n &:hover {\r\n background-color: ${brand.grey.grey89};\r\n }\r\n`;\r\nconst SoilImage = styled.div `\r\n aspect-ratio: 1 / 1;\r\n border-radius: 3px;\r\n background-image: url('${({ background }) => background}');\r\n`;\r\nconst SelectedOption = styled.div `\r\n display: grid;\r\n grid-template-columns: 24px 1fr;\r\n gap: 5px;\r\n align-items: center;\r\n padding: 3px 0px;\r\n margin-left: -5px;\r\n white-space: nowrap;\r\n\r\n span {\r\n text-overflow: ellipsis;\r\n overflow: hiddne;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n min-height: 30px;\r\n }\r\n\r\n ${() => SoilImage} {\r\n aspect-ratio: unset;\r\n width: 24px;\r\n height: 100%;\r\n background-size: contain;\r\n border: 2px solid ${brand.black};\r\n }\r\n`;\r\nexport const SoilTypeDropdownStyles = {\r\n Container,\r\n TopSection,\r\n DropdownWrapper,\r\n Dropdown,\r\n DropdownOption,\r\n SoilImage,\r\n BorderWrapper,\r\n SelectedOption,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nimport { Containers, StepStyles } from '../../Shared/Step.styles';\r\nimport { YSButtonStyles } from './../../Shared/YSButton/YSButton.styles';\r\nimport { InlineNumericalInputStyles } from './InlineNumericalInput/InlineNumericalInput.styles';\r\nimport { SoilTypeDropdownStyles } from './SoilTypeDropdown/SoilTypeDropdown.styles';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n width: 100%;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-bottom: 25px;\r\n }\r\n`;\r\nconst TopStep = styled.div `\r\n display: grid;\r\n gap: 20px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-template-columns: repeat(12, 1fr);\r\n }\r\n`;\r\nconst LayerOptions = styled.div `\r\n grid-column: 6 / -1;\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\nconst LayerWrapper = styled.div `\r\n display: grid;\r\n grid-template-columns: 55px 110px 1fr 13px;\r\n gap: 15px;\r\n align-items: center;\r\n margin-bottom: 15px;\r\n\r\n &[data-last='true'] {\r\n ${SoilTypeDropdownStyles.Container}, ${InlineNumericalInputStyles.Input}:not(:disabled) {\r\n background-color: ${brand.ysp.input};\r\n }\r\n }\r\n`;\r\nconst LayerName = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 17px;\r\n`;\r\nconst ButtonWrapper = styled.div `\r\n padding-top: 25px;\r\n margin-top: auto;\r\n display: flex;\r\n gap: 16px;\r\n flex-direction: column;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n align-items: center;\r\n flex-direction: row;\r\n }\r\n\r\n ${YSButtonStyles.Container} {\r\n white-space: nowrap;\r\n }\r\n`;\r\nconst DeleteWrapper = styled.div `\r\n cursor: pointer;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n grid-column: 4;\r\n grid-row: 1;\r\n }\r\n`;\r\nconst ResetAllWrapper = styled.div `\r\n display: flex;\r\n gap: 7px;\r\n align-items: center;\r\n cursor: pointer;\r\n user-select: none;\r\n width: max-content;\r\n\r\n span {\r\n font-size: 17px;\r\n ${fonts.DaxPro.Medium};\r\n }\r\n\r\n svg {\r\n width: 20px;\r\n height: 20px;\r\n }\r\n`;\r\nconst GridWrapper = styled(StepStyles.Grid) `\r\n @media ${until(Device.TabletLarge)} {\r\n ${() => Containers.Default} {\r\n grid-column: 1 / -1;\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n ${({ offsetPadding }) => offsetPadding &&\r\n css `\r\n padding-right: 8px;\r\n max-width: calc(75vw + 8px);\r\n `}\r\n }\r\n`;\r\nexport const SoilProfilesStyles = {\r\n Container,\r\n TopStep,\r\n LayerOptions,\r\n LayerWrapper,\r\n LayerName,\r\n ButtonWrapper,\r\n DeleteWrapper,\r\n ResetAllWrapper,\r\n GridWrapper,\r\n};\r\n","import React, { useRef, useState } from 'react';\r\nimport { SoilTypeDropdownStyles as S } from './SoilTypeDropdown.styles';\r\nimport { ReactComponent as Chevron } from '@img/icons/chevron-down.svg';\r\nimport uniqueId from 'lodash/uniqueId';\r\nimport { useClickAway } from 'react-use';\r\nconst SoilTypeDropdown = ({ value, options, onChange, i, }) => {\r\n const [expanded, setExpanded] = useState(false);\r\n const ref = useRef();\r\n useClickAway(ref, () => expanded && setExpanded(false), ['click']);\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.TopSection, { onClick: () => !expanded && setExpanded(true) },\r\n !value ? (React.createElement(\"span\", null, \"Please Select Soil Type\")) : (React.createElement(S.SelectedOption, null,\r\n React.createElement(S.SoilImage, { background: value.icon }),\r\n React.createElement(\"span\", null, value.name))),\r\n React.createElement(Chevron, null)),\r\n React.createElement(S.DropdownWrapper, { i: i, ref: ref, active: expanded },\r\n React.createElement(S.BorderWrapper, null,\r\n React.createElement(S.Dropdown, null, options.map((option, i) => (React.createElement(S.DropdownOption, { key: `SoilTypeDropdown_${i}_${uniqueId()}`, onClick: () => {\r\n onChange(option);\r\n setExpanded(false);\r\n } },\r\n React.createElement(S.SoilImage, { background: option.icon }),\r\n React.createElement(\"span\", null, option.name)))))))));\r\n};\r\nexport default SoilTypeDropdown;\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n grid-column: 1 / 6;\r\n overflow-y: auto;\r\n height: 270px;\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.white};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n`;\r\nconst SoilVisualiser = styled(m.div) `\r\n background-color: powderblue;\r\n display: flex;\r\n flex-direction: column;\r\n position: relative;\r\n height: 100%;\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.white};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n overflow-y: auto;\r\n }\r\n`;\r\nconst ExcavationOverlay = styled.div `\r\n position: absolute;\r\n top: 0;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n width: 75px;\r\n height: ${({ height }) => `${height}%`};\r\n background-color: ${brand.white};\r\n border: 2px solid ${brand.black};\r\n border-top: none;\r\n padding: 5px 7px;\r\n z-index: 1;\r\n\r\n display: flex;\r\n align-items: center;\r\n gap: 5px;\r\n\r\n span {\r\n color: ${brand.primary.alt};\r\n ${fonts.DaxPro.Medium};\r\n font-size: 13px;\r\n }\r\n`;\r\nconst Arrow = styled.div `\r\n position: relative;\r\n height: calc(100% - 5px);\r\n width: 1px;\r\n background-color: ${brand.primary.alt};\r\n\r\n &::before {\r\n content: '';\r\n position: absolute;\r\n top: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 0%, 0% 100%, 100% 100%);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n\r\n &::after {\r\n content: '';\r\n position: absolute;\r\n bottom: -5px;\r\n left: 35%;\r\n transform: translateX(-50%);\r\n background-color: ${brand.primary.alt};\r\n clip-path: polygon(50% 100%, 0 0, 100% 0);\r\n width: 7px;\r\n height: 7px;\r\n }\r\n`;\r\nconst SoilLayer = styled(m.div).attrs(({ height }) => ({\r\n initial: 'hidden',\r\n animate: height === 0 ? 'hidden' : 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n minHeight: 0,\r\n },\r\n visible: {\r\n height: `${height}px`,\r\n minHeight: `${height}px`,\r\n },\r\n },\r\n transition: {\r\n type: 'tween',\r\n ease: 'easeInOut',\r\n duration: 0.35,\r\n },\r\n})) `\r\n position: relative;\r\n width: 100%;\r\n background-image: ${({ background }) => `url('${background}')`};\r\n transform-origin: bottom;\r\n\r\n ${({ isLast, height }) => height === -1 && isLast\r\n ? css `\r\n flex-grow: 1;\r\n `\r\n : null}\r\n\r\n &::after {\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n height: 50%;\r\n width: 100%;\r\n background: rgb(255, 255, 255);\r\n background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);\r\n }\r\n`;\r\nexport const SoilVisualiserStyles = {\r\n Container,\r\n SoilVisualiser,\r\n ExcavationOverlay,\r\n Arrow,\r\n SoilLayer,\r\n};\r\n","import { imageUrl } from '@helpers/cloudinary';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport React, { useMemo, useRef } from 'react';\r\nimport { SoilVisualiserStyles as S } from './SoilVisualiser.styles';\r\nconst SoilVisualiser = () => {\r\n const { state } = useYSPContext();\r\n const containerRef = useRef(null);\r\n const excavationRef = useRef(null);\r\n const soilLayersToDisplay = useMemo(() => {\r\n if (state.form.soilLayers) {\r\n const layers = state.form.soilLayers;\r\n return layers.filter((layer, i) => {\r\n // We always want to show the top layer //\r\n if (i === 0) {\r\n return true;\r\n }\r\n // If a new layer has just been added it will have the same BGL as the previous layer. //\r\n // Ignore this layer if it matches the previous one //\r\n if (i > 0 && layers[i - 1].bgl === layer.bgl) {\r\n return false;\r\n }\r\n return true;\r\n });\r\n }\r\n return [];\r\n }, [state.form.soilLayers]);\r\n const excavationHeight = useMemo(() => {\r\n if (soilLayersToDisplay.length < 1 || !state.form.depth) {\r\n return 90;\r\n }\r\n const lastPopulatedLayer = soilLayersToDisplay[soilLayersToDisplay.length - 1].bgl;\r\n if (lastPopulatedLayer >= state.form.depth) {\r\n const percentage = (state.form.depth / lastPopulatedLayer) * 100;\r\n return percentage - 10;\r\n }\r\n return 90;\r\n }, [soilLayersToDisplay]);\r\n const soilProfileOptions = useMemo(() => state.soilProfiles.reduce((acc, cur) => {\r\n acc.push({\r\n id: cur.id,\r\n icon: imageUrl(cur.image, `c_fill,w_30,h_30`),\r\n name: cur.description,\r\n });\r\n return acc;\r\n }, []), [state.soilProfiles]);\r\n if (state.soilProfiles.length === 0) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n const getHeightForLayer = (l, i) => {\r\n if (containerRef.current && excavationRef.current && state.form.depth) {\r\n if (i < soilLayersToDisplay.length - 1) {\r\n const height = soilLayersToDisplay[i + 1].bgl - l;\r\n // What % of the excavation is this //\r\n const layerPercentage = height / state.form.depth;\r\n const excavationBoundingBox = excavationRef.current.getBoundingClientRect();\r\n const layerHeight = excavationBoundingBox.height * layerPercentage;\r\n return layerHeight;\r\n }\r\n }\r\n return -1;\r\n };\r\n return (React.createElement(S.Container, { ref: containerRef },\r\n React.createElement(S.SoilVisualiser, null,\r\n React.createElement(S.ExcavationOverlay, { ref: excavationRef, height: excavationHeight },\r\n React.createElement(S.Arrow, null),\r\n React.createElement(\"span\", null,\r\n state.form.depth,\r\n \"m\")),\r\n React.createElement(AnimatePresence, null, soilLayersToDisplay\r\n .filter((x) => x.soilTypeId >= 0)\r\n .map((layer, i) => (React.createElement(S.SoilLayer, { isLast: i === soilLayersToDisplay.length - 1, key: `SoilLayer_${layer.id}`, background: soilProfileOptions.find((x) => x.id === layer.soilTypeId)?.icon || '', height: soilLayersToDisplay.length === 1\r\n ? containerRef.current?.clientHeight\r\n : getHeightForLayer(layer.bgl, i) })))))));\r\n};\r\nexport default SoilVisualiser;\r\n","import { imageUrl } from '@helpers/cloudinary';\r\nimport { withMotion } from '@hoc/withMotion';\r\nimport { ReactComponent as Cross } from '@img/ysp/icon-cross.svg';\r\nimport { ReactComponent as Reset } from '@img/ysp/reset-thick.svg';\r\nimport Checkbox from '@stories/Components/Forms/Checkbox/Checkbox';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { Containers } from '@ys/Components/Shared/Step.styles';\r\nimport omit from 'lodash/omit';\r\nimport uniqueId from 'lodash/uniqueId';\r\nimport React, { useEffect, useMemo, useRef, useState } from 'react';\r\nimport ConfirmModal from '../../Modal/ConfirmModal';\r\nimport YSButton from '../../Shared/YSButton/YSButton';\r\nimport InlineNumericalInput from './InlineNumericalInput/InlineNumericalInput';\r\nimport SoilInfoTable from './SoilInfoTable/SoilInfoTable';\r\nimport { SoilProfilesStyles as S } from './SoilProfiles.styles';\r\nimport SoilTypeDropdown from './SoilTypeDropdown/SoilTypeDropdown';\r\nimport SoilVisualiser from './SoilVisualiser/SoilVisualiser';\r\nconst Layer = ({ position, layer, update, soilProfileOptions, previousDepth, nextDepth, lock, setTargetedLayer, ...rest }) => {\r\n return (React.createElement(S.LayerWrapper, { ...rest },\r\n React.createElement(S.LayerName, null,\r\n \"Layer \",\r\n position + 1),\r\n React.createElement(InlineNumericalInput, { lock: lock, unit: \"m\", value: layer.bgl || undefined, disabled: position === 0, onChange: (depth) => {\r\n update(position, 'bgl', depth);\r\n }, min: previousDepth ? (isNaN(previousDepth) ? undefined : previousDepth) : undefined, max: nextDepth ? (isNaN(nextDepth) ? undefined : nextDepth) : undefined }),\r\n React.createElement(SoilTypeDropdown, { i: position, onChange: (value) => {\r\n const updatedValue = update(position, 'soilLayer', value);\r\n update(position, 'soilTypeId', value.id, updatedValue);\r\n }, value: layer.soilLayer, options: soilProfileOptions }),\r\n position > 0 && (React.createElement(S.DeleteWrapper, { onClick: () => setTargetedLayer(position) },\r\n React.createElement(Cross, null)))));\r\n};\r\nconst SoilProfiles = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const contentRef = useRef(null);\r\n const [targetedLayer, setTargetedLayer] = useState(-1);\r\n const [modalMode, setModalMode] = useState();\r\n const [modalOpen, setModalOpen] = useState(false);\r\n const isOverflown = useMemo(() => {\r\n if (contentRef.current) {\r\n return contentRef.current.scrollHeight > contentRef.current.clientHeight;\r\n }\r\n return false;\r\n }, [contentRef.current?.clientHeight, contentRef.current?.scrollHeight]);\r\n const modalLabels = useMemo(() => {\r\n switch (modalMode) {\r\n default:\r\n case 'reset-layer':\r\n return {\r\n text: 'Are you sure you want to reset this layer to its default values?',\r\n yes: 'Yes, reset the layer',\r\n no: 'No, keep my values',\r\n };\r\n case 'delete-layer':\r\n return {\r\n text: 'Are you sure you want to delete this layer? This cannot be undone.',\r\n yes: 'Yes, delete the layer',\r\n no: 'No, keep the layer',\r\n };\r\n case 'reset-all':\r\n return {\r\n text: 'Are you sure you want to reset the soil parameters to the default values?',\r\n yes: 'Yes, reset to default',\r\n no: 'No, keep my parameters',\r\n };\r\n }\r\n }, [modalMode]);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: state.form.soilLayers?.length === 0 || !state.form.soilDisclaimer,\r\n },\r\n });\r\n }, [state.form.soilLayers, state.form.soilDisclaimer]);\r\n const [layers, setLayers] = useState(state.form.soilLayers !== undefined && state.form.soilLayers.length !== 0\r\n ? state.form.soilLayers\r\n : [\r\n {\r\n id: uniqueId(),\r\n bgl: 0,\r\n soilTypeId: -1,\r\n },\r\n ]);\r\n useEffect(() => {\r\n const mergedLayers = layers.reduce((acc, cur) => {\r\n const layer = state.soilProfiles.find((x) => x.id === cur.soilTypeId);\r\n if (layer) {\r\n const merged = {\r\n ...cur,\r\n };\r\n acc.push(merged);\r\n }\r\n return acc;\r\n }, []);\r\n setFormField('soilLayers', mergedLayers);\r\n }, [layers]);\r\n const resetAll = () => {\r\n // Moans about the 'id' not being the right type, but it's being omitted via Lodash //\r\n const clone = [...layers];\r\n clone.map((l, i) => {\r\n const soilInfo = state.soilProfiles.find((x) => x.id === l.soilTypeId);\r\n if (soilInfo) {\r\n clone[i] = { ...l, ...omit(soilInfo, 'id', 'bgl') };\r\n }\r\n });\r\n setLayers(clone);\r\n setFormField('soilDisclaimer', false);\r\n };\r\n const resetLayer = (position) => {\r\n const clone = [...layers];\r\n // Moans about the 'id' not being the right type, but it's being omitted via Lodash //\r\n let layer = clone[position];\r\n const soilInfo = state.soilProfiles.find((x) => x.id === layer.soilTypeId);\r\n if (soilInfo) {\r\n layer = { ...layer, ...omit(soilInfo, 'id', 'bgl') };\r\n clone.splice(position, 1, layer);\r\n }\r\n setLayers(clone);\r\n };\r\n const addLayer = () => {\r\n if (layers.length < 6) {\r\n const clone = [...layers];\r\n clone.push({\r\n id: uniqueId(),\r\n bgl: layers[layers.length - 1].bgl,\r\n soilTypeId: -1,\r\n });\r\n setLayers(clone);\r\n }\r\n };\r\n const modifyLayer = (position, type, value, updatedValue) => {\r\n const layer = updatedValue ? updatedValue : layers[position];\r\n if (layer) {\r\n // Moans about the 'id' not being the right type, but it's being omitted via Lodash //\r\n let clone = { ...layer };\r\n clone[type] = value;\r\n if (type === 'soilTypeId') {\r\n // Also update the table data with the corresponding soil information //\r\n const matchingSoil = state.soilProfiles.find((x) => x.id === value);\r\n if (matchingSoil) {\r\n clone = { ...clone, ...omit(matchingSoil, 'id', 'bgl') };\r\n }\r\n }\r\n const layersClone = [...layers];\r\n layersClone.splice(position, 1, clone);\r\n setLayers(layersClone);\r\n return clone;\r\n }\r\n return layer;\r\n };\r\n const soilProfileOptions = useMemo(() => {\r\n return state.soilProfiles.reduce((acc, cur) => {\r\n acc.push({\r\n id: cur.id,\r\n icon: imageUrl(cur.image, `c_fill,w_30,h_30`),\r\n name: cur.description,\r\n });\r\n return acc;\r\n }, []);\r\n }, [state.soilProfiles]);\r\n return (React.createElement(S.GridWrapper, { ref: contentRef, offsetPadding: state.scrollLocked && isOverflown },\r\n React.createElement(Containers.Default, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) }))),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.TopStep, null,\r\n React.createElement(SoilVisualiser, null),\r\n soilProfileOptions.length > 0 && (React.createElement(S.LayerOptions, null,\r\n layers.map((layer, i) => (React.createElement(Layer, { \"data-last\": i === layers.length - 1, key: `SoilProfile_${i}_${soilProfileOptions.length}`, layer: layer, soilProfileOptions: soilProfileOptions, update: modifyLayer, position: i, previousDepth: i > 0 ? layers[i - 1].bgl : undefined, nextDepth: i < layers.length - 1 ? layers[i + 1].bgl : undefined, lock: (b) => !state.mobile && dispatch({ type: 'set-locked', payload: b }), setTargetedLayer: (pos) => {\r\n if (modalMode !== 'delete-layer') {\r\n setModalMode('delete-layer');\r\n }\r\n setTargetedLayer(pos);\r\n setModalOpen(true);\r\n } }))),\r\n React.createElement(S.ButtonWrapper, null,\r\n React.createElement(YSButton, { icon: \"plus\", disabled: layers.length === 6 || layers.some((x) => x.soilTypeId === -1), onClick: () => addLayer() }, \"Add new layer\"),\r\n React.createElement(Checkbox, { id: \"disclaimer\", name: \"disclaimer\", type: \"checkbox\", value: state.form.soilDisclaimer, onChange: (e) => {\r\n setFormField('soilDisclaimer', e.target.checked);\r\n }, label: state.labels['disclaimer'] ||\r\n 'The above soil profile sufficiently represents the full depth of the excavation' }))))),\r\n React.createElement(SoilInfoTable, { layers: layers.filter((x) => x.soilTypeId > -1), update: modifyLayer, setTargetedLayer: (pos) => {\r\n if (modalMode !== 'reset-layer') {\r\n setModalMode('reset-layer');\r\n }\r\n setTargetedLayer(pos);\r\n setModalOpen(true);\r\n } }),\r\n layers.length > 1 && (React.createElement(S.ResetAllWrapper, { onClick: () => {\r\n setModalMode('reset-all');\r\n setModalOpen(true);\r\n } },\r\n React.createElement(Reset, null),\r\n React.createElement(\"span\", null, \"Reset to default values\"))))),\r\n React.createElement(ConfirmModal, { visible: modalOpen, text: modalLabels.text, yesText: modalLabels.yes, noText: modalLabels.no, onYes: () => {\r\n if (modalMode === 'delete-layer' && targetedLayer > -1) {\r\n const clone = [...layers];\r\n clone.splice(targetedLayer, 1);\r\n setLayers(clone);\r\n }\r\n else if (modalMode === 'reset-layer') {\r\n resetLayer(targetedLayer);\r\n }\r\n else if (modalMode === 'reset-all') {\r\n resetAll();\r\n }\r\n setModalOpen(false);\r\n }, onNo: () => setModalOpen(false), onClose: () => setModalOpen(false) })));\r\n};\r\nexport default withMotion(SoilProfiles);\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgTickUnbound(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 54.182 50\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M19.49 50a3.552 3.552 0 01-2.531-1.024L1.168 32.703a3.709 3.709 0 115.123-5.364l11.571 8.257a1.509 1.509 0 002.23-.241L47.514 1.484a3.7 3.7 0 015.906 4.46l-30.977 42.55a3.693 3.693 0 01-2.652 1.446.544.544 0 01-.3.06z\",\n fill: \"#6f9d20\"\n })));\n}\n\nexport default __webpack_public_path__ + \"c49b89a4ee32c0fda8136c4450c65d4e.svg\";\nexport { SvgTickUnbound as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n border-radius: 5px;\r\n border: 2px solid ${brand.grey.grey35};\r\n background-color: ${brand.white};\r\n position: relative;\r\n height: 100%;\r\n padding: 3px 0px;\r\n transition: background-color 0.2s ease-in-out;\r\n\r\n ${({ short }) => short &&\r\n css `\r\n max-width: 350px;\r\n `}\r\n\r\n ${({ i }) => i !== undefined\r\n ? css `\r\n z-index: ${i};\r\n `\r\n : css `\r\n z-index: 11;\r\n `}\r\n`;\r\nconst TopSection = styled.div `\r\n ${fonts.DaxPro.Regular};\r\n display: grid;\r\n grid-template-columns: 1fr 25px;\r\n cursor: pointer;\r\n padding: 6px 10px;\r\n height: 100%;\r\n user-select: none;\r\n\r\n span {\r\n margin: auto 0;\r\n }\r\n\r\n svg {\r\n margin: auto;\r\n color: ${brand.primary.alt};\r\n width: 15px;\r\n }\r\n`;\r\nconst DropdownWrapper = styled(m.div).attrs(({ active }) => ({\r\n initial: 'hidden',\r\n animate: active ? 'visible' : 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n opacity: 0,\r\n transition: {\r\n opacity: {\r\n duration: 0.1,\r\n delay: 0.2,\r\n },\r\n },\r\n },\r\n visible: {\r\n height: 'auto',\r\n opacity: 1,\r\n transition: {\r\n opacity: {\r\n duration: 0.1,\r\n },\r\n },\r\n },\r\n },\r\n})) `\r\n position: absolute;\r\n top: calc(100% + 2px);\r\n left: 0;\r\n width: 100%;\r\n background-color: ${brand.white};\r\n`;\r\nconst BorderWrapper = styled.div `\r\n overflow-y: auto;\r\n height: 100%;\r\n border: 2px solid ${brand.grey.grey35};\r\n border-top: none;\r\n max-height: 450px;\r\n\r\n margin-left: -2px;\r\n margin-top: -3px;\r\n width: calc(100% + 4px);\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n`;\r\nconst Dropdown = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n padding-top: 6px;\r\n`;\r\nconst DropdownOption = styled.div `\r\n align-items: center;\r\n padding: 8px 10px;\r\n cursor: pointer;\r\n transition: background-color 0.1s ease-in-out;\r\n\r\n span {\r\n svg {\r\n width: 15px;\r\n margin-right: 8px;\r\n }\r\n }\r\n\r\n &:hover {\r\n background-color: ${brand.grey.grey89};\r\n }\r\n`;\r\nconst SelectedOption = styled.div `\r\n align-items: center;\r\n`;\r\nexport const DropdownStyles = {\r\n Container,\r\n TopSection,\r\n DropdownWrapper,\r\n BorderWrapper,\r\n Dropdown,\r\n DropdownOption,\r\n SelectedOption,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nimport { DropdownStyles } from '../../Controls/Dropdown/Dropdown.styles';\r\nimport { SoilVisualiserStyles } from '../SoilVisualiser/SoilVisualiser.styles';\r\nconst Container = styled.div `\r\n display: grid;\r\n grid-template-columns: repeat(12, 1fr);\r\n height: max-content;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-bottom: 25px;\r\n }\r\n\r\n ${() => DropdownStyles.Container} {\r\n background-color: ${brand.ysp.input};\r\n }\r\n\r\n ${SoilVisualiserStyles.Container} {\r\n grid-column: 1 / -1;\r\n @media ${from(Device.TabletLarge)} {\r\n grid-column: 4 / 10;\r\n }\r\n }\r\n`;\r\nconst Centered = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n\r\n > span {\r\n ${fonts.DaxPro.Medium};\r\n margin-bottom: 8px;\r\n }\r\n\r\n grid-column: 1 / -1;\r\n\r\n @media ${from(Device.Tablet)} {\r\n grid-column: 4 / span 6;\r\n }\r\n`;\r\nexport const SoilSourceStyles = {\r\n Container,\r\n Centered,\r\n};\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgWarningUnbound(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 45.93 40.456\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M45.053 31.079L28.282 2.998a6.215 6.215 0 00-10.634 0L.876 31.079a6.218 6.218 0 005.317 9.377h33.544a6.042 6.042 0 005.365-3.142 6.13 6.13 0 00-.048-6.235zm-22.089 2.8a2.61 2.61 0 112.61-2.61 2.6 2.6 0 01-2.609 2.614zm2.8-19.866l-.911 10.785a1.885 1.885 0 01-2.03 1.692 1.859 1.859 0 01-1.692-1.692l-.918-10.779a2.814 2.814 0 015.607-.483 1.641 1.641 0 00-.048.483z\",\n fill: \"#f60\"\n })));\n}\n\nexport default __webpack_public_path__ + \"ab8beafaa5ab70db680886fb310b610e.svg\";\nexport { SvgWarningUnbound as ReactComponent };","import { ReactComponent as Chevron } from '@img/icons/chevron-down.svg';\r\nimport { ReactComponent as Tick } from '@img/ysp/tick-unbound.svg';\r\nimport { ReactComponent as Warning } from '@img/ysp/warning-unbound.svg';\r\nimport uniqueId from 'lodash/uniqueId';\r\nimport React, { useRef, useState } from 'react';\r\nimport { useClickAway } from 'react-use';\r\nimport { DropdownStyles as S } from './Dropdown.styles';\r\nconst Dropdown = ({ value, options, onChange, i, short, placeholder, }) => {\r\n const [expanded, setExpanded] = useState(false);\r\n const ref = useRef(null);\r\n useClickAway(ref, () => expanded && setExpanded(false), ['click']);\r\n return (React.createElement(S.Container, { i: i, short: short },\r\n React.createElement(S.TopSection, { onClick: () => !expanded && setExpanded(true) },\r\n value < 0 || value === undefined ? (React.createElement(\"span\", null, placeholder ? placeholder : 'Please Select....')) : (React.createElement(S.SelectedOption, null,\r\n React.createElement(\"span\", null, options.find((x) => x.id === value)?.text))),\r\n React.createElement(Chevron, null)),\r\n React.createElement(S.DropdownWrapper, { ref: ref, active: expanded },\r\n React.createElement(S.BorderWrapper, null,\r\n React.createElement(S.Dropdown, null, options.map((option, i) => (React.createElement(S.DropdownOption, { key: `Dropdown_${i}_${uniqueId()}`, onClick: () => {\r\n onChange(option.id);\r\n setExpanded(false);\r\n } },\r\n option.selectable !== null && (React.createElement(\"span\", null,\r\n option.selectable && React.createElement(Tick, null),\r\n \" \",\r\n option.selectable === false && React.createElement(Warning, null))),\r\n React.createElement(\"span\", null, option.text)))))))));\r\n};\r\nexport default Dropdown;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgCaret(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 16 16\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M12.14 8.753l-5.482 4.796c-.646.566-1.658.106-1.658-.753V3.204a1 1 0 011.659-.753l5.48 4.796a1 1 0 010 1.506z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"1b58cde4b8d8e84f80b2a07c5b49e399.svg\";\nexport { SvgCaret as ReactComponent };","import { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport React, { useEffect } from 'react';\r\nimport InfoIcon from '@ys/Components/InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport SoilVisualiser from '@ys/Components/Steps/SoilProfiles/SoilVisualiser/SoilVisualiser';\r\nimport { SoilSourceStyles as S } from './SoilSource.styles';\r\nimport Dropdown from '@ys/Components/Steps/Controls/Dropdown/Dropdown';\r\nimport { SoilInfoSource } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport Textbox from '../../Controls/Textbox/Textbox';\r\nconst SoilSource = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: state.form.soilInfoSource === undefined ||\r\n state.form.soilInfoSourceRef === undefined ||\r\n state.form.soilInfoSourceCompany === undefined,\r\n },\r\n });\r\n }, [state.form.soilInfoSource, state.form.soilInfoSourceRef, state.form.soilInfoSourceCompany]);\r\n return (React.createElement(StepStyles.Grid, null,\r\n React.createElement(Containers.Default, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['heading']),\r\n state.labels['tooltip'] && (React.createElement(InfoIcon, { onClick: () => dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n }) }))),\r\n React.createElement(S.Container, null,\r\n React.createElement(SoilVisualiser, null)),\r\n React.createElement(\"br\", null),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.Centered, null,\r\n React.createElement(\"span\", null, state.labels['soilsource.label']),\r\n React.createElement(Dropdown, { onChange: (option) => setFormField('soilInfoSource', option), value: state.form.soilInfoSource !== undefined ? state.form.soilInfoSource : -1, options: [\r\n {\r\n id: SoilInfoSource.Verbal,\r\n text: state.labels['soilsource.verbal'],\r\n },\r\n {\r\n id: SoilInfoSource.BoreholeLog,\r\n text: state.labels['soilsource.boreholelog'],\r\n },\r\n ] }),\r\n state.form.soilInfoSource !== undefined && (React.createElement(React.Fragment, null,\r\n React.createElement(\"br\", null),\r\n React.createElement(Textbox, { fullWidth: true, placeholder: state.labels['typeHere'], label: state.form.soilInfoSource === SoilInfoSource.Verbal\r\n ? state.labels['verbalName'] ?? 'Their name'\r\n : state.labels['boreLogRef'] ?? 'Document reference', value: state.form.soilInfoSourceRef, error: state.labels[state.errors['soilInfoSourceRef'] || ''], onChange: (e) => setFormField('soilInfoSourceRef', e.currentTarget.value) }),\r\n React.createElement(Textbox, { fullWidth: true, placeholder: state.labels['typeHere'], label: state.labels['soilInfoSourceCompany'] ?? 'Company', value: state.form.soilInfoSourceCompany, error: state.labels[state.errors['soilInfoSourceCompany'] || ''], onChange: (e) => setFormField('soilInfoSourceCompany', e.currentTarget.value) }))))))));\r\n};\r\nexport default SoilSource;\r\n","var _path, _path2;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgIconCheckCircle(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 16 16\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M8 15A7 7 0 118 1a7 7 0 010 14zm0 1A8 8 0 108 0a8 8 0 000 16z\",\n stroke: \"none\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M10.97 4.97a.235.235 0 00-.02.022L7.477 9.417 5.384 7.323a.75.75 0 00-1.06 1.06L6.97 11.03a.75.75 0 001.079-.02l3.992-4.99a.75.75 0 00-1.071-1.05z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"cefb9a375c32a1323cb228a212825d43.svg\";\nexport { SvgIconCheckCircle as ReactComponent };","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgRestart(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 24 24\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n fill: \"none\",\n stroke: \"#000\",\n strokeWidth: 2,\n d: \"M20 8c-1.403-2.96-4.463-5-8-5a9 9 0 100 18h0a9 9 0 009-9m0-9v6h-6\"\n })));\n}\n\nexport default __webpack_public_path__ + \"6b0c150b4af3bd8dbe1759b3cb66ea49.svg\";\nexport { SvgRestart as ReactComponent };","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgTick(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 54.182,\n height: 50\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M19.49 50a3.552 3.552 0 01-2.531-1.024L1.168 32.703a3.709 3.709 0 115.123-5.364l11.571 8.257a1.509 1.509 0 002.23-.241L47.514 1.484a3.7 3.7 0 015.906 4.46l-30.977 42.55a3.693 3.693 0 01-2.652 1.446.544.544 0 01-.3.06z\",\n fill: \"#6f9d20\"\n })));\n}\n\nexport default __webpack_public_path__ + \"5995e22123af5881b6655b051af52afc.svg\";\nexport { SvgTick as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n padding: 10px;\r\n background-color: ${brand.white};\r\n overflow: auto;\r\n\r\n @media ${from(Device.ActualDesktop)} {\r\n padding: 25px;\r\n }\r\n`;\r\nconst GraphWrapper = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n\r\n width: max-content;\r\n @media ${from(Device.ActualDesktop)} {\r\n width: 100%;\r\n }\r\n`;\r\nconst GraphContainer = styled.div `\r\n display: grid;\r\n grid-template-columns: 1fr 2fr 1fr;\r\n min-height: 500px;\r\n min-width: 440px;\r\n position: relative;\r\n margin-top: 35px;\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n`;\r\nconst Graph = styled.div `\r\n display: grid;\r\n grid-template-columns: 0.5fr 1fr 0.5fr;\r\n`;\r\nconst Box = styled.div `\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n height: inherit;\r\n border-bottom: 3px solid ${brand.ysp.ground};\r\n align-items: flex-end;\r\n\r\n img {\r\n display: flex;\r\n max-height: 500px;\r\n width: 100%;\r\n height: inherit;\r\n object-fit: contain;\r\n object-position: center right;\r\n\r\n &:first-of-type {\r\n transform: rotateY(180deg);\r\n }\r\n }\r\n`;\r\nconst ProportionalContent = styled.div `\r\n border-top: 3px solid ${brand.ysp.ground}; // Ground level\r\n border-bottom: 3px dashed ${brand.ysp.excavation}; // Dig level\r\n position: relative;\r\n\r\n ${({ offset }) => css `\r\n top: ${offset}%;\r\n height: calc(100% - ${offset}%);\r\n `};\r\n`;\r\nconst LeftContent = styled(ProportionalContent) `\r\n border-right: 3px solid ${brand.ysp.ground};\r\n`;\r\nconst RightContent = styled(ProportionalContent) `\r\n border-left: 3px solid ${brand.ysp.ground};\r\n`;\r\nconst BGLLabel = styled.div `\r\n position: absolute;\r\n\r\n ${({ side }) => side === 'left'\r\n ? css `\r\n left: 0;\r\n `\r\n : css `\r\n right: 0;\r\n `}\r\n bottom: calc(100% + 15px);\r\n width: max-content;\r\n`;\r\nconst Label = styled.div `\r\n padding: 3px;\r\n background-color: ${brand.white};\r\n position: absolute;\r\n z-index: 1;\r\n\r\n ${({ x }) => x === 'left'\r\n ? css `\r\n right: 10px;\r\n `\r\n : css `\r\n right: 0px;\r\n color: ${brand.ysp.ground};\r\n `}\r\n\r\n ${({ y }) => y === 'top'\r\n ? css `\r\n top: 0;\r\n transform: translateY(calc(-50% - 2px)); // Offset the border too //\r\n `\r\n : css `\r\n bottom: 0;\r\n transform: translateY(calc(50% + 2px)); // Offset the border too //\r\n `}\r\n`;\r\nconst SoilContainer = styled.div `\r\n position: relative;\r\n height: 100%;\r\n`;\r\nconst SoilLayer = styled.div `\r\n width: 100%;\r\n position: absolute;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n overflow: hidden;\r\n\r\n background-image: url('${({ image }) => image}');\r\n background-size: 20px;\r\n\r\n ${({ top }) => css `\r\n top: ${top}%;\r\n `};\r\n ${({ height }) => css `\r\n height: ${height}%;\r\n `};\r\n\r\n span {\r\n padding: 5px;\r\n font-size: 13px;\r\n border-radius: 2px;\r\n background-color: ${brand.white};\r\n max-width: 80%;\r\n white-space: nowrap;\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n }\r\n`;\r\nconst GroundwaterLevel = styled.div `\r\n position: absolute;\r\n background-color: #b2e0ed;\r\n border-top: 3px dashed #137ff6;\r\n width: 100%;\r\n\r\n &::before {\r\n content: 'GWL';\r\n position: absolute;\r\n bottom: calc(100% + 13px);\r\n font-size: 14px;\r\n left: 0;\r\n color: #137ff6;\r\n }\r\n\r\n ${({ top }) => css `\r\n top: ${top}%;\r\n height: calc(100% - ${top}%);\r\n `};\r\n`;\r\nexport const GraphStyles = {\r\n Container,\r\n GraphWrapper,\r\n Title,\r\n Graph,\r\n GraphContainer,\r\n Box,\r\n ProportionalContent,\r\n LeftContent,\r\n RightContent,\r\n BGLLabel,\r\n Label,\r\n SoilContainer,\r\n SoilLayer,\r\n GroundwaterLevel,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n background-color: ${brand.white};\r\n padding: 25px;\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n\r\n canvas {\r\n margin: auto;\r\n max-height: 600px;\r\n }\r\n`;\r\nexport const ChartStyles = {\r\n Container,\r\n};\r\n","import { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { Chart as ChartJS, LineElement, LinearScale, PointElement } from 'chart.js';\r\nimport React, { useMemo } from 'react';\r\nimport { Scatter } from 'react-chartjs-2';\r\nimport { GraphStyles } from '../Graph/Graph.styles';\r\nimport { ChartStyles as S } from './Chart.styles';\r\nChartJS.register([LinearScale, PointElement, LineElement]);\r\nconst Chart = ({ chart, title }) => {\r\n const { state } = useYSPContext();\r\n const chartData = useMemo(() => {\r\n return chart.values.map((values) => ({\r\n x: values[1],\r\n y: -values[0],\r\n }));\r\n }, [state.form.depth]);\r\n return (React.createElement(S.Container, null,\r\n React.createElement(GraphStyles.Title, null, title),\r\n React.createElement(Scatter, { height: 600, width: 440, options: {\r\n responsive: true,\r\n animation: false,\r\n layout: {\r\n padding: {\r\n left: 10,\r\n },\r\n },\r\n scales: {\r\n y: {\r\n position: {\r\n x: 0,\r\n },\r\n },\r\n x: {\r\n position: {\r\n y: 0,\r\n },\r\n },\r\n },\r\n }, data: {\r\n datasets: [\r\n {\r\n showLine: true,\r\n pointStyle: false,\r\n borderColor: chart.colorHex,\r\n borderWidth: 2,\r\n data: chartData,\r\n },\r\n ],\r\n } })));\r\n};\r\nexport default Chart;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgZoom(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 1024 1024\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M637 443H519V309c0-4.4-3.6-8-8-8h-60c-4.4 0-8 3.6-8 8v134H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h118v134c0 4.4 3.6 8 8 8h60c4.4 0 8-3.6 8-8V519h118c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"b13587de7dd2ca6f974887fe7f74cfb0.svg\";\nexport { SvgZoom as ReactComponent };","import React, { useMemo } from 'react';\r\nimport { GraphStyles as S } from './Graph.styles';\r\nimport Decimal from 'decimal.js-light';\r\n// import { frozenState } from './Graph.data';\r\nimport { imageUrl } from '@helpers/cloudinary';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nconst Graph = () => {\r\n const { state } = useYSPContext();\r\n if (!state.form.soilLayers || !state.form.depth || !state.selectedSolution) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n const contentOffset = useMemo(() => {\r\n if (state.form.depth && state.selectedSolution) {\r\n return 100 - (state.form.depth / state.selectedSolution.solution.height) * 100;\r\n }\r\n return 0;\r\n }, [state.selectedSolution.solution.height - state.form.depth, state.form.depth]);\r\n // If you're at this point, these values are populated. I don't want to have to do 5 inline checks for undefined stuff just to shut eslint up //\r\n // when it's never going to cause an issue cos it'll never be undefined. Just casting them here to Required and moving on //\r\n const soilLayers = state.form.soilLayers;\r\n const form = state.form;\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.GraphWrapper, null,\r\n React.createElement(S.Title, null, state.selectedSolution.graphs.boxHeading),\r\n React.createElement(S.GraphContainer, null,\r\n React.createElement(S.LeftContent, { offset: contentOffset },\r\n React.createElement(S.BGLLabel, { side: \"left\" }, \"m BGL\"),\r\n React.createElement(S.Label, { x: \"left\", y: \"top\" }, \"0.00\"),\r\n state.form.groundwaterPresent &&\r\n state.form.groundwaterDepth &&\r\n state.form.groundwaterDepth <= state.form.depth && (React.createElement(S.GroundwaterLevel, { top: (state.form.groundwaterDepth / state.form.depth) * 100 })),\r\n React.createElement(S.Label, { x: \"left\", y: \"bottom\" }, new Decimal(state.form.depth || 2).toDecimalPlaces(2).toString())),\r\n React.createElement(S.Box, null,\r\n React.createElement(\"img\", { src: state.selectedSolution.solution.graphic }),\r\n React.createElement(\"img\", { src: state.selectedSolution.solution.graphic })),\r\n React.createElement(S.RightContent, { offset: contentOffset },\r\n React.createElement(S.BGLLabel, { side: \"right\" }, \"m BGL\"),\r\n React.createElement(S.Label, { x: \"right\", y: \"top\" }, \"0.00\"),\r\n state.soilProfiles && soilLayers.length > 0 && (React.createElement(S.SoilContainer, null, soilLayers\r\n .filter((x) => x.bgl <= form.depth)\r\n .map((layer, i) => {\r\n // This is horrible, TODO to fix it //\r\n const height = i < soilLayers.filter((x) => x.bgl <= form.depth).length - 1\r\n ? (soilLayers[i + 1].bgl / form.depth) * 100 -\r\n (layer.bgl / form.depth) * 100\r\n : 100 - (layer.bgl / form.depth) * 100;\r\n return (React.createElement(S.SoilLayer, { title: layer.description, height: height, top: (layer.bgl / form.depth) * 100, key: `SoilLayer_${i}`, image: imageUrl(layer.image, 'c_fill,w_35') },\r\n React.createElement(\"span\", null, layer.description)));\r\n }))),\r\n React.createElement(S.Label, { x: \"right\", y: \"bottom\" }, new Decimal(state.form.depth || 2).toDecimalPlaces(2).toString()))))));\r\n};\r\nexport default Graph;\r\n","import brand from '@helpers/brand';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n display: flex;\r\n position: relative;\r\n width: max-content;\r\n max-width: 100%;\r\n cursor: pointer;\r\n aspect-ratio: 1 / 1;\r\n max-height: 165px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst ZoomIcon = styled.div `\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n padding: 10px;\r\n background-color: ${brand.grey.grey89};\r\n color: ${brand.grey.grey20};\r\n border-radius: 6px;\r\n\r\n svg {\r\n display: flex;\r\n width: 20px;\r\n height: 20px;\r\n }\r\n`;\r\nconst Image = styled.img `\r\n width: 100%;\r\n padding: 7px;\r\n border: 2px solid ${brand.grey.grey89};\r\n border-radius: 5px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n object-fit: contain;\r\n }\r\n`;\r\nconst ModalBackground = styled(m.div).attrs(({ visible }) => ({\r\n initial: 'hidden',\r\n animate: visible ? 'visible' : 'hidden',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n y: 25,\r\n },\r\n visible: {\r\n opacity: 1,\r\n y: 0,\r\n },\r\n },\r\n})) `\r\n position: fixed;\r\n width: 100%;\r\n height: 100%;\r\n top: 0;\r\n left: 0;\r\n z-index: 1000;\r\n background-color: rgba(0, 0, 0, 0.8);\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n ${({ visible }) => !visible &&\r\n css `\r\n pointer-events: none;\r\n `}\r\n`;\r\nconst ModalContent = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 10px;\r\n max-width: 90vw;\r\n max-height: 85dvh;\r\n width: 100%;\r\n height: 100%;\r\n`;\r\nconst Close = styled.div `\r\n margin-left: auto;\r\n width: 25px;\r\n height: 25px;\r\n color: ${brand.white};\r\n cursor: pointer;\r\n`;\r\nconst ZoomedImage = styled.div `\r\n padding: 10px;\r\n background-color: ${brand.white};\r\n flex-grow: 1;\r\n\r\n .react-transform-wrapper {\r\n height: 100%;\r\n width: 100%;\r\n }\r\n`;\r\nconst ControlsBar = styled.div `\r\n display: flex;\r\n gap: 10px;\r\n justify-content: center;\r\n`;\r\nconst Control = styled.div `\r\n width: 35px;\r\n height: 35px;\r\n padding: 5px;\r\n background-color: ${brand.grey.grey89};\r\n color: ${brand.black};\r\n border-radius: 5px;\r\n cursor: pointer;\r\n\r\n svg {\r\n width: 100%;\r\n height: 100%;\r\n }\r\n`;\r\nexport const ZoomImageStyles = {\r\n Container,\r\n Image,\r\n ZoomIcon,\r\n ModalBackground,\r\n ModalContent,\r\n Close,\r\n ZoomedImage,\r\n ControlsBar,\r\n Control,\r\n};\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgZoomOut(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 1024 1024\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M637 443H325c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h312c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm284 424L775 721c122.1-148.9 113.6-369.5-26-509-148-148.1-388.4-148.1-537 0-148.1 148.6-148.1 389 0 537 139.5 139.6 360.1 148.1 509 26l146 146c3.2 2.8 8.3 2.8 11 0l43-43c2.8-2.7 2.8-7.8 0-11zM696 696c-118.8 118.7-311.2 118.7-430 0-118.7-118.8-118.7-311.2 0-430 118.8-118.7 311.2-118.7 430 0 118.7 118.8 118.7 311.2 0 430z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"95a39e54340d709dbfaf2b307ca443e7.svg\";\nexport { SvgZoomOut as ReactComponent };","import React, { useEffect, useRef, useState } from 'react';\r\nimport { ZoomImageStyles as S } from './ZoomImage.styles';\r\nimport { ReactComponent as Zoom } from '@img/ysp/zoom.svg';\r\nimport { ReactComponent as ZoomOut } from '@img/ysp/zoom-out.svg';\r\nimport { ReactComponent as Close } from '@img/ysp/icon-cross.svg';\r\nimport { ReactComponent as Reset } from '@img/ysp/restart.svg';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport { withMotion } from '@hoc/withMotion';\r\nimport { TransformComponent, TransformWrapper } from 'react-zoom-pan-pinch';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nconst ZoomImage = ({ imageUrl }) => {\r\n const { dispatch } = useYSPContext();\r\n const [modalOpen, setModalOpen] = useState(false);\r\n const zoomRef = useRef(null);\r\n useEffect(() => {\r\n dispatch({ type: 'set-zoom-modal', payload: modalOpen });\r\n }, [modalOpen]);\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(S.Container, { onClick: () => setModalOpen(true) },\r\n React.createElement(S.Image, { src: imageUrl }),\r\n React.createElement(S.ZoomIcon, null,\r\n React.createElement(Zoom, null))),\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(S.ModalBackground, { key: `ZoomImageModal`, visible: modalOpen, onClick: () => setModalOpen(false) },\r\n React.createElement(S.ModalContent, { onClick: (e) => e.stopPropagation() },\r\n React.createElement(S.Close, { onClick: () => setModalOpen(false) },\r\n React.createElement(Close, null)),\r\n React.createElement(S.ZoomedImage, null,\r\n React.createElement(TransformWrapper, { ref: zoomRef, centerOnInit: true },\r\n React.createElement(TransformComponent, null,\r\n React.createElement(\"img\", { src: imageUrl })))),\r\n React.createElement(S.ControlsBar, null,\r\n React.createElement(S.Control, { title: \"Zoom In\", onClick: () => zoomRef.current && zoomRef.current.zoomIn() },\r\n React.createElement(Zoom, null)),\r\n React.createElement(S.Control, { title: \"Zoom Out\", onClick: () => zoomRef.current && zoomRef.current.zoomOut() },\r\n React.createElement(ZoomOut, null)),\r\n React.createElement(S.Control, { title: \"Reset Zoom\", onClick: () => zoomRef.current && zoomRef.current.resetTransform() },\r\n React.createElement(Reset, null))))))));\r\n};\r\nexport default withMotion(ZoomImage);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { StepFooterStyles } from '../../../../StepFooter/StepFooter.styles';\r\nconst Container = styled(m.div).attrs(({ visible }) => ({\r\n initial: 'hidden',\r\n animate: visible ? 'visible' : 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n y: 25,\r\n },\r\n visible: {\r\n opacity: 1,\r\n y: 0,\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n box-shadow: 0px 0px 6px 0px ${brand.grey.grey89};\r\n background-color: ${brand.white};\r\n padding: 25px;\r\n display: flex;\r\n flex-direction: column;\r\n gap: 35px;\r\n scroll-margin-top: 25px; // Avoid top being cut off when scrolling to it on the dropdown //\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-top: 60px;\r\n }\r\n\r\n border: 2px solid transparent;\r\n ${({ selected }) => selected &&\r\n css `\r\n border-color: ${brand.primary.alt};\r\n `};\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n grid-template-columns: 1fr 350px;\r\n }\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n gap: 100px;\r\n }\r\n\r\n position: relative;\r\n\r\n max-width: 1300px;\r\n width: 100%;\r\n margin: auto;\r\n`;\r\nconst LeftSection = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n overflow-x: hidden;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n gap: 25px;\r\n }\r\n`;\r\nconst RightSection = styled.div `\r\n padding-top: 70px; // Offset the floating tag //\r\n display: flex;\r\n justify-content: center;\r\n\r\n img {\r\n height: max-content;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 25px;\r\n`;\r\nconst Description = styled.div `\r\n ${fonts.DaxPro.Regular};\r\n font-size: 16px;\r\n line-height: 18px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n font-size: 17px;\r\n line-height: 20px;\r\n }\r\n`;\r\nconst SolutionTag = styled.div `\r\n position: absolute;\r\n right: 20px;\r\n top: 0;\r\n padding: 12px 15px;\r\n user-select: none;\r\n border-radius: 0px 0px 10px 10px;\r\n background-color: ${brand.primary.alt};\r\n color: ${brand.white};\r\n ${fonts.DaxPro.Medium};\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n font-size: 20px;\r\n gap: 10px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n right: 50px;\r\n }\r\n`;\r\nconst LongSmallButton = styled(StepFooterStyles.ButtonSmall) `\r\n background-color: ${brand.primary.alt};\r\n padding: 6px 35px;\r\n font-size: 18px;\r\n ${fonts.DaxPro.Bold};\r\n border: 2px solid transparent;\r\n transition: border-color 0.15s ease-in-out, background-color 0.25s ease-in-out;\r\n display: flex;\r\n gap: 10px;\r\n\r\n ${({ inverse }) => inverse &&\r\n css `\r\n border-color: ${brand.primary.alt};\r\n color: ${brand.primary.alt};\r\n background-color: ${brand.white};\r\n\r\n }\r\n \r\n svg {\r\n color: ${brand.primary.alt};\r\n fill: ${brand.primary.alt};\r\n }\r\n &:hover {\r\n color: ${brand.primary.alt} !important;\r\n }\r\n `};\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n justify-content: center;\r\n padding: 6px 12px;\r\n }\r\n\r\n align-items: center;\r\n\r\n svg {\r\n width: 22px;\r\n }\r\n\r\n ${({ orange }) => orange &&\r\n css `\r\n background-color: ${brand.divisionTags.sandhurst};\r\n\r\n &:hover {\r\n background-color: ${brand.divisionTags.sandhurst} !important;\r\n }\r\n `}\r\n`;\r\nconst Scrollbars = css `\r\n &::-webkit-scrollbar {\r\n width: 4px;\r\n height: 4px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.grey.grey89};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n }\r\n`;\r\nconst TableContainer = styled.div `\r\n display: grid;\r\n grid-template-columns: repeat(5, 150px);\r\n --rows: ${({ rows }) => rows};\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-template-columns: repeat(5, 125px);\r\n }\r\n\r\n overflow-x: auto;\r\n padding-bottom: 15px;\r\n ${Scrollbars}\r\n`;\r\nconst Column = styled.div `\r\n grid-column: span ${({ span }) => span};\r\n\r\n display: grid;\r\n grid-template-rows: repeat(var(--rows), 40px);\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n ${({ isPassFailColumn }) => isPassFailColumn &&\r\n css `\r\n order: -1;\r\n `};\r\n }\r\n`;\r\nconst HeaderSection = styled.div `\r\n // Always spans two //\r\n grid-row: span 2;\r\n\r\n display: grid;\r\n grid-template-rows: 1fr 1fr;\r\n`;\r\nconst Header = styled.div `\r\n grid-row: span ${({ span }) => span};\r\n background-color: ${brand.grey.grey75};\r\n color: ${brand.black};\r\n ${fonts.DaxPro.Medium};\r\n padding: 10px 15px;\r\n display: flex;\r\n align-items: center;\r\n border: 1px solid ${brand.white};\r\n font-size: 15px;\r\n position: relative;\r\n\r\n sub {\r\n font-size: 12px;\r\n position: relative;\r\n top: 2px;\r\n left: 2px;\r\n }\r\n\r\n ${({ center }) => center &&\r\n css `\r\n justify-content: center;\r\n text-align: center;\r\n `}\r\n`;\r\nconst Cell = styled.div `\r\n grid-row: span 1;\r\n justify-content: center;\r\n display: flex;\r\n align-items: center;\r\n background-color: ${brand.grey.grey96};\r\n text-align: center;\r\n color: ${brand.black};\r\n border: 1px solid ${brand.white};\r\n ${fonts.DaxPro.Regular};\r\n font-size: 17px;\r\n`;\r\nconst PassFail = styled(Cell) `\r\n color: ${brand.white};\r\n ${fonts.DaxPro.Bold};\r\n\r\n ${({ pass }) => pass\r\n ? css `\r\n background-color: ${brand.primary.alt};\r\n `\r\n : css `\r\n background-color: ${brand.divisionTags.sandhurst};\r\n `}\r\n`;\r\nconst TableHeader = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 17px;\r\n`;\r\nconst StrutsTableWrapper = styled.div `\r\n display: grid;\r\n grid-template-columns: repeat(10, 50px);\r\n --rows: ${({ rows }) => rows};\r\n\r\n overflow-x: auto;\r\n padding-bottom: 15px;\r\n ${Scrollbars};\r\n`;\r\nconst Blank = styled.div `\r\n grid-row: span 2;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n background-color: ${brand.grey.grey75};\r\n margin: 1px;\r\n }\r\n`;\r\nconst FailText = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n color: ${brand.divisionTags.sandhurst};\r\n`;\r\nconst FailBoxWrapper = styled.div `\r\n padding: 15px;\r\n border: 2px solid ${brand.divisionTags.sandhurst};\r\n border-radius: 5px;\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n`;\r\nconst FailTopRow = styled.div `\r\n display: flex;\r\n gap: 7px;\r\n`;\r\nconst FailNumber = styled.div `\r\n padding: 10px 20px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n text-transform: uppercase;\r\n user-select: none;\r\n color: ${brand.divisionTags.sandhurst};\r\n ${fonts.DaxPro.Bold};\r\n border: 2px solid ${brand.divisionTags.sandhurst};\r\n`;\r\nconst FailDescription = styled.div `\r\n ${fonts.DaxPro.Regular};\r\n`;\r\nconst MobileImage = styled.div `\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst DescriptionAndTable = styled.div `\r\n display: flex;\r\n gap: 10px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n flex-direction: column;\r\n }\r\n`;\r\nexport const SolutionStyles = {\r\n Container,\r\n LeftSection,\r\n Title,\r\n Description,\r\n SolutionTag,\r\n RightSection,\r\n LongSmallButton,\r\n TableContainer,\r\n Column,\r\n HeaderSection,\r\n Header,\r\n Cell,\r\n PassFail,\r\n TableHeader,\r\n StrutsTableWrapper,\r\n Blank,\r\n FailText,\r\n FailBoxWrapper,\r\n FailTopRow,\r\n FailNumber,\r\n FailDescription,\r\n MobileImage,\r\n DescriptionAndTable,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nimport { Containers, StepStyles } from '../../../../Shared/Step.styles';\r\nimport { StepFooterStyles } from '../../../../StepFooter/StepFooter.styles';\r\nimport { SolutionStyles } from '../Solution/Solution.styles';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n\r\n ${SolutionStyles.LongSmallButton} {\r\n font-size: 17px;\r\n padding: 6px 25px;\r\n }\r\n`;\r\nconst TopContent = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n text-align: center;\r\n justify-content: center;\r\n align-items: center;\r\n gap: 25px;\r\n`;\r\nconst BackButton = styled.div `\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n gap: 10px;\r\n color: ${brand.primary.alt};\r\n cursor: pointer;\r\n width: max-content;\r\n ${fonts.DaxPro.Medium};\r\n margin-top: 15px;\r\n\r\n svg {\r\n width: 20px;\r\n transform: rotate(180deg);\r\n }\r\n`;\r\nconst ButtonContainer = styled.div `\r\n display: flex;\r\n gap: 5px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n flex-direction: column;\r\n }\r\n`;\r\nconst RestartButton = styled(StepFooterStyles.ButtonSmall) `\r\n ${fonts.DaxPro.Medium}\r\n background-color: ${brand.white} !important;\r\n border: 2px solid ${brand.primary.alt};\r\n color: ${brand.black};\r\n display: flex;\r\n align-items: center;\r\n font-size: 17px !important;\r\n\r\n &:hover {\r\n color: ${brand.black} !important;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n justify-content: center;\r\n }\r\n\r\n svg {\r\n margin-right: 10px;\r\n }\r\n\r\n span {\r\n color: ${brand.primary.alt};\r\n\r\n &:last-of-type {\r\n position: relative;\r\n bottom: 4px;\r\n font-size: 20px;\r\n }\r\n }\r\n`;\r\nconst Solution = styled.div `\r\n box-shadow: 0px 0px 6px 0px ${brand.grey.grey89};\r\n display: flex;\r\n padding: 25px;\r\n flex-direction: column;\r\n gap: 35px;\r\n max-width: 1300px;\r\n width: 100%;\r\n margin: auto;\r\n margin-top: 45px;\r\n background-color: ${brand.white};\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n position: relative;\r\n padding: 10px;\r\n }\r\n`;\r\nconst TopSection = styled.div `\r\n @media ${until(Device.TabletLarge)} {\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n grid-template-columns: 250px 1fr auto;\r\n position: relative;\r\n }\r\n`;\r\nconst Details = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n padding-top: 10px;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n order: 1;\r\n }\r\n`;\r\nconst Title = styled.div `\r\n font-size: 22px;\r\n ${fonts.DaxPro.Bold};\r\n`;\r\nconst DesignReference = styled.div `\r\n font-size: 17px;\r\n color: ${brand.primary.alt};\r\n ${fonts.DaxPro.Medium};\r\n`;\r\nconst Table = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 10px;\r\n margin-top: 5px;\r\n\r\n &[data-solution-mode='true'] {\r\n min-width: 265px;\r\n margin-top: 0;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n border-top: 1px solid ${brand.grey.grey75};\r\n padding-top: 20px;\r\n }\r\n`;\r\nconst Row = styled.div `\r\n display: flex;\r\n gap: 5px;\r\n\r\n [data-solution-mode='true'] & {\r\n padding-left: 15px;\r\n position: relative;\r\n\r\n &::before {\r\n content: '';\r\n position: absolute;\r\n width: 5px;\r\n height: 5px;\r\n background-color: ${brand.primary.alt};\r\n border-radius: 50%;\r\n left: 0;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n }\r\n }\r\n\r\n strong {\r\n ${fonts.DaxPro.Medium};\r\n }\r\n`;\r\nconst SolutionTag = styled.div `\r\n position: absolute;\r\n top: -25px;\r\n right: 20px;\r\n padding: 12px 15px;\r\n user-select: none;\r\n border-radius: 0px 0px 10px 10px;\r\n background-color: ${brand.primary.alt};\r\n color: ${brand.white};\r\n ${fonts.DaxPro.Medium};\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n font-size: 20px;\r\n gap: 10px;\r\n width: max-content;\r\n max-width: 100%;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst MobileSolutionTag = styled(SolutionTag) `\r\n top: 0;\r\n right: 15px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n`;\r\nconst EndSection = styled.div `\r\n position: relative;\r\n display: flex;\r\n flex-direction: column;\r\n gap: 10px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n padding: 35px 20px 0px;\r\n }\r\n\r\n ${StepFooterStyles.ButtonSmall} {\r\n @media ${from(Device.TabletLarge)} {\r\n margin-top: 45px;\r\n }\r\n font-size: 17px;\r\n border: 1px solid ${brand.primary.alt};\r\n }\r\n`;\r\nconst TableContainers = styled.div `\r\n display: flex;\r\n gap: 10px;\r\n justify-content: space-between;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n flex-direction: column;\r\n }\r\n\r\n ${SolutionStyles.TableHeader} {\r\n margin-bottom: 15px;\r\n }\r\n`;\r\nconst TableWrapper = styled.div `\r\n overflow: hidden;\r\n width: 100%;\r\n\r\n ${SolutionStyles.TableContainer} {\r\n grid-template-columns: repeat(5, 125px);\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-template-columns: repeat(5, auto);\r\n }\r\n\r\n ${SolutionStyles.Header} {\r\n font-size: 14px;\r\n }\r\n\r\n ${SolutionStyles.Cell} {\r\n font-size: 15px;\r\n }\r\n }\r\n\r\n ${SolutionStyles.StrutsTableWrapper} {\r\n grid-template-columns: repeat(10, auto);\r\n }\r\n`;\r\nconst GraphsWrapper = styled.div `\r\n gap: 15px;\r\n padding: 15px;\r\n background-color: ${brand.grey.grey89};\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n display: flex;\r\n flex-direction: column;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n padding: 35px;\r\n gap: 35px;\r\n }\r\n`;\r\nconst GridWrapper = styled(StepStyles.Grid) `\r\n max-width: unset;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n ${() => Containers.Wide} {\r\n grid-column: 1 / -1;\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n max-width: 83vw;\r\n }\r\n`;\r\nconst ImageWrapper = styled.div `\r\n @media ${until(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n\r\n display: flex;\r\n justify-content: flex-start;\r\n align-items: center;\r\n\r\n img {\r\n width: auto;\r\n aspect-ratio: 1 /1;\r\n object-fit: contain;\r\n }\r\n`;\r\nexport const SummaryStyles = {\r\n Container,\r\n TopContent,\r\n BackButton,\r\n ButtonContainer,\r\n RestartButton,\r\n Solution,\r\n TopSection,\r\n Details,\r\n Title,\r\n DesignReference,\r\n Table,\r\n Row,\r\n SolutionTag,\r\n EndSection,\r\n TableContainers,\r\n TableWrapper,\r\n GraphsWrapper,\r\n GridWrapper,\r\n MobileSolutionTag,\r\n ImageWrapper,\r\n};\r\n","import { imageUrl } from '@helpers/cloudinary';\r\nimport { useInView } from '@hooks/useInView';\r\nimport { ReactComponent as Check } from '@img/ysp/icon-check-circle.svg';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport YSButton from '@ys/Components/Shared/YSButton/YSButton';\r\nimport React, { useEffect, useMemo } from 'react';\r\nimport ZoomImage from '../ZoomImage/ZoomImage';\r\nimport { SolutionStyles as S } from './Solution.styles';\r\nimport { SummaryStyles } from '../Summary/Summary.styles';\r\nexport const MomentsTable = ({ solution, labels }) => {\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(S.TableHeader, null, \"Moments\"),\r\n React.createElement(S.TableContainer, { rows: 3 },\r\n React.createElement(S.Column, { span: 2 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { span: 2, dangerouslySetInnerHTML: { __html: labels['ysp.moment.table.corner'] } })),\r\n solution.moments.map((moment, i) => (React.createElement(S.Header, { key: `Solution_${i}_Name`, span: 1 }, moment.name)))),\r\n React.createElement(S.Column, { span: 1 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 2 }, labels['ysp.moment.table.allowable'])),\r\n solution.moments.map((moment, i) => (React.createElement(S.Cell, { key: `Solution_${i}_Allowable` }, moment.allowable)))),\r\n React.createElement(S.Column, { span: 1 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 2 }, labels['ysp.moment.table.actual'])),\r\n solution.moments.map((moment, i) => (React.createElement(S.Cell, { key: `Solution_${i}_Actual` }, moment.actual)))),\r\n React.createElement(S.Column, { isPassFailColumn: true, span: 1 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 2 }, labels['ysp.moment.table.passheading'])),\r\n solution.moments.map((moment, i) => moment.pass === undefined ? (React.createElement(S.Cell, { key: `Solution_${i}_Pass` }, \"N/A\")) : (React.createElement(S.PassFail, { pass: moment.pass, key: `Solution_${i}_Pass` }, moment.pass\r\n ? labels['ysp.momentstruts.table.pass']\r\n : labels['ysp.momentstruts.table.fail'])))))));\r\n};\r\nexport const StrutsTable = ({ solution, labels }) => {\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(S.TableHeader, null, \"Struts\"),\r\n React.createElement(S.StrutsTableWrapper, { rows: 4 },\r\n React.createElement(S.Column, { span: 1 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Blank, null)),\r\n solution.struts.map((strut, i) => (React.createElement(S.Header, { center: true, key: `Solution_Struts_${i}_Name`, span: 1 }, strut.name)))),\r\n React.createElement(S.Column, { span: 2 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 1 }, labels['ysp.struts.table.levellabel']),\r\n React.createElement(S.Header, { center: true, span: 1 }, labels['ysp.struts.table.levelunits'])),\r\n solution.struts.map((strut, i) => (React.createElement(S.Cell, { key: `Solution_Struts_${i}_Level` }, strut.level)))),\r\n React.createElement(S.Column, { span: 2 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 1, dangerouslySetInnerHTML: { __html: labels['ysp.struts.table.loadallowlabel'] } }),\r\n React.createElement(S.Header, { center: true, span: 1, dangerouslySetInnerHTML: { __html: labels['ysp.struts.table.loadunits'] } })),\r\n solution.struts.map((strut, i) => (React.createElement(S.Cell, { key: `Solution_Struts_${i}_LoadAllow` }, strut.loadAllow)))),\r\n React.createElement(S.Column, { span: 2 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 1, dangerouslySetInnerHTML: { __html: labels['ysp.struts.table.loadactuallabel'] } }),\r\n React.createElement(S.Header, { center: true, span: 1, dangerouslySetInnerHTML: { __html: labels['ysp.struts.table.loadunits'] } })),\r\n solution.struts.map((strut, i) => (React.createElement(S.Cell, { key: `Solution_Struts_${i}_LoadActual` }, strut.loadActual)))),\r\n React.createElement(S.Column, { isPassFailColumn: true, span: 3 },\r\n React.createElement(S.HeaderSection, null,\r\n React.createElement(S.Header, { center: true, span: 2 }, labels['ysp.struts.table.passheading'])),\r\n solution.struts.map((strut, i) => strut.pass === undefined ? (React.createElement(S.Cell, { key: `Solution_Strut_${i}_Pass` }, \"N/A\")) : (React.createElement(S.PassFail, { pass: strut.pass, key: `Solution_Strut_${i}_Pass` }, strut.pass ? 'PASS' : 'FAIL')))))));\r\n};\r\nconst Solution = ({ solution, i }) => {\r\n const [ref, inView] = useInView({ threshold: 0.15 });\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const isSelected = useMemo(() => !!state.form.selectedSolutionName && state.form.selectedSolutionName === solution.name, [state.form.selectedSolutionName, solution.name]);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: state.form.selectedSolutionName === undefined,\r\n },\r\n });\r\n }, [state.form.selectedSolutionName]);\r\n const handleSelectSolutionClick = () => {\r\n if (isSelected) {\r\n setFormField('selectedSolutionName', undefined);\r\n setFormField('selectedSolutionIterator', undefined);\r\n }\r\n else {\r\n setFormField('selectedSolutionName', solution.name);\r\n setFormField('selectedSolutionIterator', i);\r\n }\r\n dispatch({ type: 'next-step' });\r\n };\r\n return (React.createElement(S.Container, { selected: isSelected, \"data-solution-id\": solution.name, ref: ref, visible: inView },\r\n React.createElement(S.MobileImage, null,\r\n React.createElement(ZoomImage, { imageUrl: imageUrl(solution.image, `c_fill,w_360`) })),\r\n React.createElement(S.LeftSection, null,\r\n React.createElement(S.Title, null, solution.name),\r\n React.createElement(S.DescriptionAndTable, null,\r\n React.createElement(SummaryStyles.Table, { \"data-solution-mode\": \"true\" }, solution.boxInfo &&\r\n solution.boxInfo.map((info, i) => (React.createElement(SummaryStyles.Row, { key: `Summary_BoxInfo_${i}` },\r\n React.createElement(\"span\", null,\r\n React.createElement(\"strong\", null,\r\n info.item1,\r\n \":\"),\r\n \" \",\r\n info.item2))))),\r\n React.createElement(S.Description, null, solution.description)),\r\n React.createElement(S.SolutionTag, null,\r\n isSelected && React.createElement(Check, null),\r\n \" Solution \",\r\n i + 1),\r\n React.createElement(YSButton, { icon: isSelected ? 'check' : undefined, iconPosition: \"left\", fill: isSelected ? 'outline' : 'solid', disabled: !solution.selectable, onClick: handleSelectSolutionClick }, isSelected ? 'Solution Selected' : 'Select Solution'),\r\n !solution.selectable && (React.createElement(S.FailText, null, \"To be able to select this solution all parameters must pass the tests below.\")),\r\n React.createElement(MomentsTable, { solution: solution, labels: state.labels }),\r\n React.createElement(StrutsTable, { solution: solution, labels: state.labels }),\r\n !solution.selectable && (React.createElement(S.FailBoxWrapper, null,\r\n React.createElement(S.FailDescription, null, \"This solution failed in the above tests. You have the opportunity to change the parameters you have entered in order to make this solution pass and become available to you.\"),\r\n React.createElement(YSButton, { colour: \"orange\", size: \"wide\", onClick: () => {\r\n dispatch({ type: 'go-to-step', payload: 6 }); // ID of the first EndSafe panels question in the YSP steps //\r\n } }, \"Change parameters\")))),\r\n React.createElement(S.RightSection, null,\r\n React.createElement(\"img\", { src: imageUrl(solution.image, `c_fill,w_360`) }))));\r\n};\r\nexport default Solution;\r\n","import { imageUrl } from '@helpers/cloudinary';\r\nimport { ReactComponent as Caret } from '@img/icons/caret.svg';\r\nimport { ReactComponent as Check } from '@img/ysp/icon-check-circle.svg';\r\nimport { ReactComponent as Restart } from '@img/ysp/restart.svg';\r\nimport { ReactComponent as Tick } from '@img/ysp/tick.svg';\r\nimport { WYSIWYGStyles } from '@stories/Components/Content/WYSIWYG/WYSIWYG.styles';\r\nimport { StepID, Tab } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { Containers } from '@ys/Components/Shared/Step.styles';\r\nimport { YSLinkButton } from '@ys/Components/Shared/YSButton/YSButton';\r\nimport React, { useState } from 'react';\r\nimport Chart from '../Chart/Chart';\r\nimport Graph from '../Graph/Graph';\r\nimport { MomentsTable, StrutsTable } from '../Solution/Solution';\r\nimport { SolutionStyles } from '../Solution/Solution.styles';\r\nimport ZoomImage from '../ZoomImage/ZoomImage';\r\nimport { SummaryStyles as S } from './Summary.styles';\r\nconst Summary = () => {\r\n const { state, dispatch } = useYSPContext();\r\n const [loading, setLoading] = useState(false);\r\n if (!state.selectedSolution) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n const sendToEngineer = async () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n size: 'normal',\r\n fullWidth: false,\r\n engineerCheckLabels: {\r\n heading: state.labels['engineer.modal.heading'],\r\n content: state.labels['engineer.modal.content'],\r\n success: state.labels['engineer.modal.success'],\r\n },\r\n },\r\n });\r\n setLoading(false);\r\n };\r\n const data = state.selectedSolution;\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(S.GridWrapper, null,\r\n React.createElement(Containers.Wide, null,\r\n React.createElement(S.Container, null,\r\n React.createElement(S.TopContent, null,\r\n React.createElement(Tick, null),\r\n state.labels['content'] && (React.createElement(WYSIWYGStyles.Wrapper, { dangerouslySetInnerHTML: {\r\n __html: state.labels['content'].replaceAll('{email}', state.form.email ?? ''),\r\n } })),\r\n React.createElement(S.BackButton, { onClick: () => dispatch({ type: 'previous-step' }) },\r\n React.createElement(Caret, null),\r\n \"Return to your solutions\"),\r\n React.createElement(S.ButtonContainer, null,\r\n React.createElement(SolutionStyles.LongSmallButton, { orange: true, disabled: loading, onClick: () => sendToEngineer() }, \"Request a check from Groundforce\"),\r\n React.createElement(S.RestartButton, { onClick: () => {\r\n if (confirm('Are you sure you want to restart? This will erase all your data entered thus far.')) {\r\n dispatch({ type: 'restart' });\r\n dispatch({ type: 'set-tab', payload: Tab.YourSolutionPlus });\r\n dispatch({ type: 'go-to-step', payload: StepID.Landing });\r\n }\r\n } },\r\n React.createElement(Restart, null),\r\n \"Restart Your\",\r\n React.createElement(\"span\", null, \"Solution\"),\r\n React.createElement(\"span\", null, \"+\")))),\r\n React.createElement(S.Solution, null,\r\n React.createElement(S.TopSection, null,\r\n React.createElement(ZoomImage, { imageUrl: imageUrl(data.solution.image, 'c_fill,w_300') }),\r\n React.createElement(S.ImageWrapper, null,\r\n React.createElement(\"img\", { src: imageUrl(data.solution.image, 'c_fill,w_300'), alt: data.solution.name })),\r\n React.createElement(S.Details, null,\r\n React.createElement(S.Title, null, data.solution.name),\r\n React.createElement(S.DesignReference, null,\r\n \"Design reference \",\r\n data.designReference),\r\n React.createElement(S.Table, null, data.boxInfo.map((info, i) => (React.createElement(S.Row, { key: `Summary_BoxInfo_${i}` },\r\n React.createElement(\"span\", null,\r\n info.item1,\r\n \":\"),\r\n \" \",\r\n React.createElement(\"span\", null, info.item2)))))),\r\n React.createElement(S.SolutionTag, null,\r\n React.createElement(Check, null),\r\n \" Solution Generated\"),\r\n React.createElement(S.EndSection, null,\r\n React.createElement(YSLinkButton, { fill: \"outline\", href: data.designDoc, target: \"_blank\" }, \"Download Solution\"))),\r\n React.createElement(S.TableContainers, null,\r\n React.createElement(S.TableWrapper, null,\r\n React.createElement(MomentsTable, { solution: data.solution, labels: state.labels })),\r\n React.createElement(S.TableWrapper, null,\r\n React.createElement(StrutsTable, { solution: data.solution, labels: state.labels }))),\r\n React.createElement(S.GraphsWrapper, null,\r\n React.createElement(Graph, null),\r\n React.createElement(Chart, { chart: data.graphs.horizontalPressure, title: data.graphs.horizontalPressure.heading }),\r\n React.createElement(Chart, { chart: data.graphs.shearForce, title: data.graphs.shearForce.heading }),\r\n React.createElement(Chart, { chart: data.graphs.kickingMoments, title: data.graphs.kickingMoments.heading }))))))));\r\n};\r\nexport default Summary;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgWarning(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 45.93,\n height: 40.456\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M45.053 31.079L28.282 2.998a6.215 6.215 0 00-10.634 0L.876 31.079a6.218 6.218 0 005.317 9.377h33.544a6.042 6.042 0 005.365-3.142 6.13 6.13 0 00-.048-6.235zm-22.089 2.8a2.61 2.61 0 112.61-2.61 2.6 2.6 0 01-2.609 2.614zm2.8-19.866l-.911 10.785a1.885 1.885 0 01-2.03 1.692 1.859 1.859 0 01-1.692-1.692l-.918-10.779a2.814 2.814 0 015.607-.483 1.641 1.641 0 00-.048.483z\",\n fill: \"#f60\"\n })));\n}\n\nexport default __webpack_public_path__ + \"a7fafd51a8415bcac84b8748533cb5d1.svg\";\nexport { SvgWarning as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport styled from 'styled-components';\r\nimport { DropdownStyles } from '../../Controls/Dropdown/Dropdown.styles';\r\nconst Container = styled.div ``;\r\nconst Solutions = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 25px;\r\n`;\r\nconst NoSolutions = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 25px;\r\n padding: 25px 45px;\r\n align-items: center;\r\n justify-content: center;\r\n box-shadow: 0px 0px 17px -6px rgba(0, 0, 0, 0.75);\r\n max-width: 750px;\r\n margin: auto;\r\n text-align: center;\r\n background-color: ${brand.white};\r\n`;\r\nconst NoSolutionsTitle = styled.div `\r\n font-size: 25px;\r\n ${fonts.DaxPro.Bold};\r\n`;\r\nconst NoSolutionsSubtitle = styled.div `\r\n font-size: 20px;\r\n ${fonts.DaxPro.Regular};\r\n\r\n span {\r\n color: ${brand.primary.alt};\r\n }\r\n`;\r\nconst NoSolutionsGetInTouch = styled.div `\r\n font-size: 20px;\r\n ${fonts.DaxPro.Medium};\r\n margin-top: 15px;\r\n`;\r\nconst NoSolutionsDetails = styled.div `\r\n font-size: 20px;\r\n ${fonts.DaxPro.Regular};\r\n display: flex;\r\n flex-direction: column;\r\n gap: 25px;\r\n\r\n a {\r\n color: ${brand.primary.base};\r\n }\r\n`;\r\nconst DropdownWrapper = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n max-width: 1300px;\r\n margin: auto;\r\n margin-bottom: 25px;\r\n\r\n ${DropdownStyles.Container} {\r\n background-color: ${brand.ysp.input};\r\n }\r\n`;\r\nexport const YSPSolutionsStyles = {\r\n Container,\r\n Solutions,\r\n NoSolutions,\r\n NoSolutionsTitle,\r\n NoSolutionsSubtitle,\r\n NoSolutionsGetInTouch,\r\n NoSolutionsDetails,\r\n DropdownWrapper,\r\n};\r\n","import React, { useEffect, useMemo, useState } from 'react';\r\nimport { SharedStyles } from '@ys/Components/Shared.styles';\r\nimport { FormStyles } from '@ys/Components/Shared/Form.styles';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport Solution from './Solution/Solution';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport { StepID } from '@stories/Widgets/YourSolution/YS/Context/types';\r\nimport { YSPSolutionsStyles as S } from './YSPSolutions.styles';\r\nimport { withMotion } from '@hoc/withMotion';\r\nimport { ReactComponent as Warning } from '@img/ysp/warning.svg';\r\nimport { SolutionStyles } from './Solution/Solution.styles';\r\nimport Dropdown from '../../Controls/Dropdown/Dropdown';\r\nimport { isSSR } from '@helpers/ssr';\r\nconst YSPSolutions = () => {\r\n const { state, dispatch } = useYSPContext();\r\n const [selectedSolution, setSelectedSolution] = useState();\r\n useEffect(() => {\r\n if (selectedSolution !== undefined && !isSSR()) {\r\n const matchingSolution = document.querySelector(`div[data-solution-id='${selectedSolution.name}']`);\r\n if (matchingSolution) {\r\n matchingSolution.scrollIntoView({ behavior: 'smooth' });\r\n }\r\n }\r\n }, [selectedSolution]);\r\n const dropdownOptions = useMemo(() => {\r\n if (state.yspResults) {\r\n if (state.yspResults.solutions && state.yspResults.solutions.length > 0) {\r\n return state.yspResults.solutions.map((s, i) => ({\r\n id: i,\r\n text: s.name,\r\n selectable: s.selectable,\r\n }));\r\n }\r\n }\r\n return [];\r\n }, [state.yspResults]);\r\n if (!state.yspResults) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n return (React.createElement(SharedStyles.Question, null,\r\n React.createElement(StepStyles.Grid, null,\r\n React.createElement(Containers.Wide, null,\r\n React.createElement(FormStyles.Form, null,\r\n React.createElement(\"h2\", null, state.labels['heading'] || 'Proposed Solutions for your excavation')),\r\n state.yspResults.solutions && (React.createElement(React.Fragment, null,\r\n React.createElement(S.DropdownWrapper, null,\r\n React.createElement(\"span\", { dangerouslySetInnerHTML: {\r\n __html: state.labels['content'] ||\r\n 'Please select your preferred box type from the dropdown or select from the list below.',\r\n } }),\r\n React.createElement(Dropdown, { short: true, options: dropdownOptions, onChange: (s) => state.yspResults && setSelectedSolution(state.yspResults.solutions[s]), value: selectedSolution ? state.yspResults.solutions.indexOf(selectedSolution) : -1 })),\r\n React.createElement(S.Solutions, null, state.yspResults.solutions.map((solution, i) => (React.createElement(Solution, { solution: solution, key: `Solution_${i}`, i: i })))))),\r\n state.yspResults.territoryManager && (React.createElement(S.NoSolutions, null,\r\n React.createElement(Warning, null),\r\n React.createElement(S.NoSolutionsTitle, { dangerouslySetInnerHTML: { __html: state.yspResults.noSolutionHeading || '' } }),\r\n React.createElement(S.NoSolutionsSubtitle, { dangerouslySetInnerHTML: { __html: state.yspResults.noSolutionText || '' } }),\r\n React.createElement(SolutionStyles.LongSmallButton, { orange: true, onClick: () => dispatch({ type: 'go-to-step', payload: StepID.Dimensions }) }, \"Change parameters\"),\r\n React.createElement(S.NoSolutionsGetInTouch, { dangerouslySetInnerHTML: { __html: state.yspResults.contactText || '' } }),\r\n React.createElement(S.NoSolutionsDetails, null,\r\n React.createElement(\"span\", null, state.yspResults.territoryManager.name),\r\n React.createElement(\"a\", { href: `mailto:${state.yspResults.territoryManager.email}` },\r\n React.createElement(\"span\", null, state.yspResults.territoryManager.email)),\r\n React.createElement(\"a\", { href: `tel:${state.yspResults.territoryManager.telephone}` },\r\n React.createElement(\"span\", null, state.yspResults.territoryManager.telephone)))))))));\r\n};\r\nexport default withMotion(YSPSolutions);\r\n","import { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nimport { DropdownStyles } from '../../Controls/Dropdown/Dropdown.styles';\r\nimport { DimensionsStyles } from '../../Dimensions/Dimensions.styles';\r\nimport { SurchargeIcon } from './SurchargeDetails';\r\nimport brand from '@helpers/brand';\r\nconst Container = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n width: 100%;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n ${() => DropdownStyles.Container} {\r\n grid-column: 1 / -1;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n width: 100%;\r\n }\r\n }\r\n }\r\n`;\r\nconst TopStep = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 20px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n grid-template-columns: repeat(12, 1fr);\r\n }\r\n`;\r\nconst DimensionsWrapper = styled(DimensionsStyles.Container) `\r\n grid-column: 1 / 5;\r\n width: 100%;\r\n`;\r\nconst SurchargesWrapper = styled.div `\r\n grid-column: 5 / -1;\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\nconst IconContainer = styled.div `\r\n overflow: hidden;\r\n position: relative;\r\n width: 100%;\r\n height: 100%;\r\n max-width: 45px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n min-height: 40px;\r\n grid-row: 1;\r\n grid-column: 2;\r\n }\r\n`;\r\nconst IconWrapper = styled.div ``;\r\nconst SurchargeWrapper = styled.div `\r\n @media ${until(Device.TabletLarge)} {\r\n display: flex;\r\n flex-wrap: wrap;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: grid;\r\n }\r\n\r\n gap: 5px 10px;\r\n align-items: center;\r\n margin-bottom: 15px;\r\n\r\n &[data-last='true'] {\r\n ${DropdownStyles.Container} {\r\n background-color: ${brand.ysp.input};\r\n }\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n gap: 15px;\r\n grid-template-columns: 45px 100px 1fr 13px;\r\n }\r\n`;\r\nconst SurchargeName = styled.div `\r\n ${fonts.DaxPro.Medium};\r\n font-size: 17px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n order: -1;\r\n width: 100px;\r\n }\r\n`;\r\nconst getIconAnimation = (i) => {\r\n switch (i) {\r\n default:\r\n case SurchargeIcon.None:\r\n return 'default';\r\n case SurchargeIcon.Building:\r\n return 'building';\r\n case SurchargeIcon.Rail:\r\n return 'rail';\r\n case SurchargeIcon.Slope:\r\n return 'embankments';\r\n case SurchargeIcon.Road:\r\n return 'road';\r\n }\r\n};\r\nconst BaseHidden = {\r\n opacity: 0,\r\n transition: {\r\n opacity: {\r\n delay: 0.5,\r\n },\r\n },\r\n};\r\nconst BaseVisible = {\r\n opacity: 1,\r\n};\r\nconst MotionWrapper = styled(m.div).attrs(({ icon }) => ({\r\n initial: `${getIconAnimation(icon)}-hidden`,\r\n animate: `${getIconAnimation(icon)}-visible`,\r\n exit: `${getIconAnimation(icon)}-exit`,\r\n variants: {\r\n 'default-hidden': {\r\n ...BaseHidden,\r\n x: -50,\r\n },\r\n 'default-visible': {\r\n ...BaseVisible,\r\n x: 0,\r\n },\r\n 'default-exit': {\r\n ...BaseVisible,\r\n x: 50,\r\n },\r\n 'building-hidden': {\r\n ...BaseHidden,\r\n y: 50,\r\n },\r\n 'building-visible': {\r\n ...BaseVisible,\r\n y: 0,\r\n },\r\n 'building-exit': {\r\n ...BaseVisible,\r\n y: 50,\r\n },\r\n 'embankments-hidden': {\r\n ...BaseHidden,\r\n y: -50,\r\n },\r\n 'embankments-visible': {\r\n ...BaseVisible,\r\n y: 0,\r\n },\r\n 'embankments-exit': {\r\n ...BaseVisible,\r\n y: 50,\r\n },\r\n 'rail-hidden': {\r\n ...BaseHidden,\r\n scale: 0,\r\n },\r\n 'rail-visible': {\r\n ...BaseVisible,\r\n scale: 1,\r\n },\r\n 'rail-exit': {\r\n ...BaseVisible,\r\n scale: 0,\r\n },\r\n 'road-hidden': {\r\n ...BaseHidden,\r\n y: -50,\r\n x: -50,\r\n },\r\n 'road-visible': {\r\n ...BaseVisible,\r\n y: 0,\r\n x: 0,\r\n },\r\n 'road-exit': {\r\n ...BaseVisible,\r\n y: 50,\r\n x: 50,\r\n },\r\n },\r\n transition: {\r\n duration: 1,\r\n },\r\n})) `\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n margin: auto;\r\n max-width: 45px;\r\n\r\n img {\r\n width: 100%;\r\n height: 100%;\r\n object-fit: contain;\r\n max-width: 45px;\r\n }\r\n`;\r\nconst ButtonWrapper = styled.div `\r\n @media ${from(Device.TabletLarge)} {\r\n padding-top: 25px;\r\n padding-left: 60px; // To offset the first grid column of the surcharges which houses the icon //\r\n }\r\n`;\r\nconst DeleteWrapper = styled.div `\r\n cursor: pointer;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n grid-row: 1;\r\n grid-column: 4;\r\n }\r\n`;\r\nexport const SurchargeDetailsStyles = {\r\n Container,\r\n TopStep,\r\n DimensionsWrapper,\r\n SurchargesWrapper,\r\n SurchargeWrapper,\r\n SurchargeName,\r\n IconWrapper,\r\n IconContainer,\r\n MotionWrapper,\r\n ButtonWrapper,\r\n DeleteWrapper,\r\n};\r\n","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgEdit(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 32.001 31\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 449\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n d: \"M31.795 5.172L26.829.206a.7.7 0 00-.993 0l-3 3-11.371 11.37a.7.7 0 00-.192.357l-1.258 6.225a.7.7 0 00.689.842.682.682 0 00.139-.014l6.225-1.258a.7.7 0 00.357-.192l14.37-14.37a.7.7 0 000-.993zm-12.88 11.887l-1.49-1.49 8.394-8.394 1.49 1.49zm-2.483-2.483l-1.49-1.49 8.394-8.394 1.49 1.49zm.15 4.817l-4.98 1.007 1.006-4.98 1.341-1.341 3.974 3.974zm11.72-11.721l-3.973-3.973 2-2 3.973 3.973z\",\n fill: \"#f60\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 661\",\n d: \"M27.798 13.202a.789.789 0 00-.789.789v13.673a1.761 1.761 0 01-1.759 1.759H3.337a1.761 1.761 0 01-1.759-1.759V6.77a1.761 1.761 0 011.759-1.759h13.676a.789.789 0 000-1.578H3.337A3.342 3.342 0 000 6.77v20.894a3.341 3.341 0 003.337 3.337H25.25a3.341 3.341 0 003.337-3.337V13.991a.789.789 0 00-.789-.789z\",\n fill: \"#f60\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"c50ec45bb8a94304d94d1084eb0ee732.svg\";\nexport { SvgEdit as ReactComponent };","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, until } from '@helpers/media';\r\nimport { lighten } from 'polished';\r\nimport styled, { css } from 'styled-components';\r\nimport { DropdownStyles } from '../../../Controls/Dropdown/Dropdown.styles';\r\nimport { NumberInputStyles } from '../../../../Shared/NumberInput/NumberInput.styles';\r\nconst Container = styled.div `\r\n margin-top: 25px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-bottom: 25px;\r\n }\r\n`;\r\nconst TopSection = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n margin-bottom: 20px;\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n font-size: 23px;\r\n`;\r\nconst DescriptionWrapper = styled.div `\r\n display: grid;\r\n grid-template-columns: 40px 1fr;\r\n align-items: center;\r\n gap: 10px;\r\n\r\n p {\r\n margin-bottom: 0;\r\n }\r\n\r\n svg {\r\n width: 100%;\r\n }\r\n`;\r\nconst Description = styled.div ``;\r\nconst TableContainer = styled.div `\r\n display: grid;\r\n grid-template-columns: repeat(10, 1fr); // Surcharge spans 3 //\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding-bottom: 25px;\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n overflow: auto;\r\n\r\n &::-webkit-scrollbar {\r\n width: 4px;\r\n height: 4px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.grey.grey89};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n }\r\n }\r\n`;\r\nconst ColumnWrapper = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n height: 100%;\r\n grid-column: span 1;\r\n`;\r\nconst WideColumnWrapper = styled(ColumnWrapper) `\r\n grid-column: span 3;\r\n font-size: 18px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n min-width: 200px;\r\n }\r\n`;\r\nconst HeaderWrapper = styled.div `\r\n display: grid;\r\n grid-template-rows: repeat(4, 1fr);\r\n height: 100%;\r\n min-height: 107px;\r\n`;\r\nconst Header = styled.div `\r\n padding: 5px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n border: 1px solid ${brand.white};\r\n background-color: ${brand.primary.alt};\r\n font-size: 14px;\r\n color: ${brand.white};\r\n text-align: center;\r\n ${fonts.DaxPro.Medium};\r\n\r\n ${({ lightBackground }) => lightBackground &&\r\n css `\r\n background-color: ${brand.ysp.input};\r\n color: ${brand.black};\r\n `};\r\n\r\n sub {\r\n font-size: 11px;\r\n position: relative;\r\n bottom: -3px;\r\n }\r\n`;\r\nconst HeaderInner = styled.div ``;\r\nconst VariableHeader = styled(Header) `\r\n grid-row: span ${({ span }) => span};\r\n`;\r\nconst FieldRow = styled.div `\r\n width: 100%;\r\n border: 1px solid ${brand.white};\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n font-size: 14px;\r\n min-height: 30px;\r\n height: 100%;\r\n\r\n ${({ isNull }) => isNull &&\r\n css `\r\n cursor: not-allowed;\r\n user-select: none;\r\n pointer-events: none;\r\n background-color: ${lighten(0.2, brand.grey.grey55)};\r\n position: relative;\r\n\r\n ${() => NumberInputStyles.Input} {\r\n display: none;\r\n }\r\n\r\n &::after {\r\n content: 'NULL';\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n }\r\n `};\r\n`;\r\nconst FieldBase = css `\r\n padding: 6px 10px;\r\n border: none;\r\n width: 100%;\r\n height: 100%;\r\n position: relative;\r\n transition: outline-color 0.1s ease-in-out;\r\n outline: 2px solid transparent;\r\n ${fonts.DaxPro.Medium};\r\n\r\n &::selection {\r\n color: ${brand.white};\r\n background-color: ${brand.divisionTags.sandhurst};\r\n }\r\n\r\n &:focus {\r\n outline-color: ${brand.divisionTags.sandhurst};\r\n }\r\n`;\r\nconst DropdownWrapper = styled.div `\r\n ${FieldBase}\r\n padding: unset;\r\n height: 100%;\r\n\r\n ${() => DropdownStyles.Container} {\r\n padding: unset;\r\n border: none;\r\n border-radius: none;\r\n background-color: unset;\r\n\r\n ${() => DropdownStyles.TopSection} {\r\n padding: unset;\r\n }\r\n\r\n ${() => DropdownStyles.SelectedOption} {\r\n padding: 0px 6px;\r\n display: flex;\r\n ${fonts.DaxPro.Medium};\r\n }\r\n }\r\n\r\n ${({ bg }) => {\r\n switch (bg) {\r\n default:\r\n case 'green':\r\n return css `\r\n background-color: ${brand.ysp.input};\r\n `;\r\n case 'white':\r\n return css `\r\n background-color: ${brand.white};\r\n `;\r\n case 'grey':\r\n return css `\r\n background-color: ${brand.grey.grey89};\r\n `;\r\n }\r\n}}\r\n`;\r\nconst FieldInput = styled.input `\r\n ${FieldBase}\r\n\r\n ${({ align }) => {\r\n switch (align) {\r\n default:\r\n case 'left':\r\n return css `\r\n text-align: start;\r\n `;\r\n case 'center':\r\n return css `\r\n text-align: center;\r\n `;\r\n case 'right':\r\n return css `\r\n text-align: end;\r\n `;\r\n }\r\n}}\r\n \r\n ${({ bg }) => {\r\n switch (bg) {\r\n default:\r\n case 'green':\r\n return css `\r\n background-color: ${brand.ysp.input};\r\n `;\r\n case 'white':\r\n return css `\r\n background-color: ${brand.white};\r\n `;\r\n case 'grey':\r\n return css `\r\n background-color: ${brand.grey.grey89};\r\n `;\r\n }\r\n}}\r\n`;\r\nexport const SurchargesTableStyles = {\r\n Container,\r\n TopSection,\r\n Title,\r\n DescriptionWrapper,\r\n Description,\r\n TableContainer,\r\n ColumnWrapper,\r\n WideColumnWrapper,\r\n HeaderWrapper,\r\n Header,\r\n HeaderInner,\r\n VariableHeader,\r\n FieldRow,\r\n FieldInput,\r\n DropdownWrapper,\r\n};\r\n","import { ReactComponent as Edit } from '@img/ysp/edit.svg';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport React, { useMemo } from 'react';\r\nimport NumberInput from '../../../../Shared/NumberInput/NumberInput';\r\nimport Dropdown from '../../../Controls/Dropdown/Dropdown';\r\nimport { SurchargeType } from '../SurchargeDetails';\r\nimport { SurchargesTableStyles as S } from './SurchargesTable.styles';\r\nconst SurchargesTable = ({ surcharges, update }) => {\r\n const { state: { labels }, } = useYSPContext();\r\n const typeOptions = useMemo(() => {\r\n return Object.keys(SurchargeType)\r\n .filter((n) => isNaN(Number(n)))\r\n .map((t, i) => ({\r\n id: i,\r\n text: t,\r\n }));\r\n }, []);\r\n const isNull = (k, t) => {\r\n switch (t) {\r\n case SurchargeType.Blanket:\r\n switch (k) {\r\n default:\r\n case 'surchargeMagnitude':\r\n return false;\r\n case 'surchargeDepth':\r\n case 'surchargeOffset':\r\n case 'surchargeWidth':\r\n case 'surchargeLength':\r\n case 'surchargeMagnitudeB':\r\n return true;\r\n }\r\n case SurchargeType.Strip:\r\n switch (k) {\r\n default:\r\n case 'surchargeMagnitude':\r\n case 'surchargeDepth':\r\n case 'surchargeOffset':\r\n case 'surchargeWidth':\r\n return false;\r\n case 'surchargeLength':\r\n case 'surchargeMagnitudeB':\r\n return true;\r\n }\r\n case SurchargeType.Area:\r\n switch (k) {\r\n default:\r\n case 'surchargeMagnitude':\r\n case 'surchargeDepth':\r\n case 'surchargeOffset':\r\n case 'surchargeWidth':\r\n case 'surchargeLength':\r\n return false;\r\n case 'surchargeMagnitudeB':\r\n return true;\r\n }\r\n case SurchargeType.Line:\r\n case SurchargeType.Point:\r\n switch (k) {\r\n default:\r\n case 'surchargeMagnitude':\r\n case 'surchargeDepth':\r\n case 'surchargeOffset':\r\n return false;\r\n case 'surchargeWidth':\r\n case 'surchargeLength':\r\n case 'surchargeMagnitudeB':\r\n return true;\r\n }\r\n case SurchargeType.Trap:\r\n default:\r\n return false;\r\n }\r\n };\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.TopSection, null,\r\n React.createElement(S.Title, { dangerouslySetInnerHTML: { __html: labels['surchargeTable.heading'] || 'Surcharges' } }),\r\n React.createElement(S.DescriptionWrapper, null,\r\n React.createElement(Edit, null),\r\n React.createElement(S.Description, { dangerouslySetInnerHTML: {\r\n __html: labels['surchargeProfile.prompt'] ||\r\n `

Use the below table to fill in the types of Surcharges that are present in the zone of influence, including revelant dimensions and location relative to the dig

\\r\\n`,\r\n } }))),\r\n React.createElement(S.TableContainer, null,\r\n React.createElement(S.WideColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 4 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.surchargelabel'] || 'Surcharge',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(S.FieldInput, { align: 'left', type: \"text\", bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeDescription, onChange: (e) => update(i, 'surchargeDescription', e.currentTarget.value) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 4 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.surchargetypelabel'] || 'Surcharge Type',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(S.DropdownWrapper, { bg: i % 2 === 0 ? 'grey' : 'white' },\r\n React.createElement(Dropdown, { i: 6 - i, options: typeOptions, onChange: (v) => update(i, 'surchargeType', v), value: s.surchargeType ?? SurchargeType.Area })))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitudelabel'] || 'Magnitude',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitudeunits'] || '(kN/m2)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitudecalclabel'] || 'qsur',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeMagnitude ?? 0, onChange: (e) => update(i, 'surchargeMagnitude', e) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.depthlabel'] || 'Surcharge Depth',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.depthunits'] || '(m)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.depthcalclabel'] || 'X',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { isNull: isNull('surchargeDepth', s.surchargeType), key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeDepth ?? 0, onChange: (e) => update(i, 'surchargeDepth', e) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.offsetlabel'] || 'Surcharge Offset',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.offsetunits'] || '(m)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.offsetcalclabel'] || 'A',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { isNull: isNull('surchargeOffset', s.surchargeType), key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeOffset ?? 0, onChange: (e) => update(i, 'surchargeOffset', e) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.widthlabel'] || 'Surcharge Width',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.widthunits'] || '(m)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.widthcalclabel'] || 'B',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { isNull: isNull('surchargeWidth', s.surchargeType), key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeWidth ?? 0, onChange: (e) => update(i, 'surchargeWidth', e) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.lengthlabel'] || 'Surcharge Length',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.lengthunits'] || '(m)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.lengthcalclabel'] || 'Lsur',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { isNull: isNull('surchargeLength', s.surchargeType), key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeLength ?? 0, onChange: (e) => update(i, 'surchargeLength', e) }))))),\r\n React.createElement(S.ColumnWrapper, null,\r\n React.createElement(S.HeaderWrapper, null,\r\n React.createElement(S.VariableHeader, { span: 2 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitude2label'] || 'Surcharge Magnitude 2',\r\n } })),\r\n React.createElement(S.VariableHeader, { span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitude2units'] || '(kN/m2)',\r\n } })),\r\n React.createElement(S.VariableHeader, { lightBackground: true, span: 1 },\r\n React.createElement(S.HeaderInner, { dangerouslySetInnerHTML: {\r\n __html: labels['ysp.surchage.table.magnitude2calclabel'] || 'q2,sur',\r\n } }))),\r\n surcharges.map((s, i) => (React.createElement(S.FieldRow, { isNull: isNull('surchargeMagnitudeB', s.surchargeType), key: `Surcharge_${s.id}_${i}` },\r\n React.createElement(NumberInput, { layout: \"surcharges-table\", alignment: \"center\", min: 0, bg: i % 2 === 0 ? 'grey' : 'white', value: s.surchargeMagnitudeB ?? 0, onChange: (e) => update(i, 'surchargeMagnitudeB', e) }))))))));\r\n};\r\nexport default SurchargesTable;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgRoad(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 77.26 81.32\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M63 10.9c4.01-3.17 8.63-5.31 13.19-7.53.31-.15.61-.3 1.06-.53-3.24-.97-6.29-1.89-9.35-2.8-.17-.05-.38-.04-.56 0-5.65 1.18-11.33 2.24-16.94 3.59-4.94 1.18-9.7 2.97-14.01 5.74-2.69 1.73-5.01 3.82-6.46 6.74-1.79 3.62-1.58 7.32-.2 10.98.83 2.2 1.92 4.3 2.83 6.48 1.08 2.6 1.77 5.3 1.6 8.16-.23 3.87-2.11 6.88-4.94 9.39-2.94 2.6-6.35 4.45-9.88 6.08-5.1 2.35-10.24 4.59-15.36 6.9-1.3.59-2.57 1.26-3.97 1.96.33.11.49.18.67.23 9.2 2.22 18.39 4.44 27.59 6.64.34.08.81-.02 1.13-.2 1.25-.71 2.47-1.48 3.69-2.24 4.02-2.52 8.13-4.93 11.51-8.34.13-.13.39-.23.57-.2 1.48.25 2.96.54 4.57.84-3.56 5.03-8.46 8.39-13.21 12.1.22.08.32.12.42.15 8.75 2.11 17.5 4.23 26.25 6.31.23.06.63-.1.8-.3a73.52 73.52 0 002.69-3.16c4.28-5.43 7.68-11.32 9-18.2 1.34-6.98 0-13.42-4.1-19.26-2.15-3.06-4.93-5.47-7.74-7.88-2.44-2.09-4.8-4.26-6.61-6.94-2.41-3.56-2.33-6.76.53-9.95 1.56-1.74 3.41-3.26 5.25-4.72zm-17.92 2.5c1.14-.75 1.25-.73 2.48.15-3.35 1.81-4.5 4.71-4.13 8.38h-2.18c-.38-3.66.77-6.53 3.83-8.53zm-.05 20.36c-.91-2.46-1.81-4.92-2.74-7.37-.2-.53-.14-.8.47-.89.53-.08 1.05-.25 1.65-.4 1.59 3.37 3.14 6.67 4.74 10.08-1.09.36-2.1.7-3.18 1.06-.33-.86-.65-1.66-.94-2.47zm8.42 18.51c-.07.96-.38 1.9-.65 2.83-.06.2-.48.45-.69.41-1.28-.22-2.54-.51-3.93-.81 1.95-4.79.27-9.3-.8-13.96 1.01-.2 1.97-.41 2.95-.56.14-.02.4.17.46.31 1.52 3.78 2.96 7.59 2.67 11.77zm2.42-43.88c-1.78.92-3.53 1.9-5.35 2.72-.42.19-1.09-.19-1.65-.31v-.4c1.27-.58 2.54-1.18 3.81-1.75.86-.39 1.75-.73 2.62-1.1q.74-.31 1.42.38c-.29.16-.56.32-.84.46zm1.51-2.09c1.7-.68 3.39-1.38 5.11-2.01.25-.09.64.16.96.25 0 .08 0 .17-.01.25-1.71.7-3.41 1.42-5.14 2.06-.23.09-.61-.21-.91-.33V6.3z\",\n fill: \"#333\"\n })));\n}\n\nexport default __webpack_public_path__ + \"cea0b200511f583fad0e9e72ce778b22.svg\";\nexport { SvgRoad as ReactComponent };","var _style, _path, _path2;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgBuilding(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n id: \"building_svg__buildings\",\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 550 550\",\n shapeRendering: \"geometricPrecision\",\n textRendering: \"geometricPrecision\"\n }, props), _style || (_style = /*#__PURE__*/React.createElement(\"style\", null, \"@keyframes buildings-s-path1_to__to{0%{transform:translate(377.629116px,816.849979px);animation-timing-function:cubic-bezier(.42,0,.58,1)}to{transform:translate(377.63px,325.861734px)}}@keyframes buildings-s-path2_to__to{0%{transform:translate(159.87909px,869.350009px)}18.181818%{transform:translate(159.87909px,869.350009px);animation-timing-function:cubic-bezier(.42,0,.58,1)}to{transform:translate(160.199989px,377.061764px)}}\")), /*#__PURE__*/React.createElement(\"g\", {\n transform: \"translate(377.63 816.85)\",\n style: {\n animation: \"buildings-s-path1_to__to 2200ms linear 1 normal forwards\"\n }\n }, _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n id: \"building_svg__buildings-s-path1\",\n d: \"M271.5 194.9v-49.3l69.5-27.4v384.3h210.4V132.8l-204.9-64L233.1 120v61.9M411 334.7l-38.4-9.7v-56.3l38.4 9.7v56.3zm0-72l-38.4-9.7v-56.3l38.4 9.7v56.3zm0-71l-38.4-9.7v-56.3l38.4 9.7v56.3zm57.7 156.2l-34.4-8.9v-56.1l34.4 8.9v56.1zm0-72.8l-34.4-8.9v-51.6l34.4 8.9v51.6zm0-72.8l-34.4-8.9v-51.6l34.4 8.9v51.6zm57.7 159.8l-34.4-8.9v-56.1l34.4 8.9v56.1zm0-72.8l-34.4-8.9v-51.6l34.4 8.9v51.6zm0-72.8l-34.4-8.9V156l34.4 8.9v51.6z\",\n transform: \"translate(-392.25 -285.65)\",\n fill: \"#707070\"\n }))), /*#__PURE__*/React.createElement(\"g\", {\n transform: \"translate(159.88 869.35)\",\n style: {\n animation: \"buildings-s-path2_to__to 2200ms linear 1 normal forwards\"\n }\n }, _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n id: \"building_svg__buildings-s-path2\",\n d: \"M157.6 172.5L71 211.7v102l-36.3 37.7v152.4h28.7V357l37-37.7v-88.1l53.1-21v293.5h160.8V221.4l-156.7-48.9zm49.3 203.2l-29.4-7.4v-43l29.4 7.4v43zm0-55l-29.4-7.4v-43l29.4 7.4v43zm0-54.2l-29.4-7.4v-43l29.4 7.4v43zM251 385.8l-26.3-6.8v-42.8L251 343v42.8zm0-55.6l-26.3-6.8V284l26.3 6.8v39.4zm0-55.7l-26.3-6.8v-39.4l26.3 6.8v39.4zm44 122.1l-26.3-6.8V347l26.3 6.8v42.8zm0-55.6l-26.3-6.8v-39.4l26.3 6.8V341zm0-55.6l-26.3-6.8v-39.4L295 246v39.4z\",\n transform: \"translate(-174.5 -338.15)\",\n fill: \"#690\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"82664cca0270bfeb977d063e46686fb4.svg\";\nexport { SvgBuilding as ReactComponent };","var _style, _g, _g2, _g3;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgCrane(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n id: \"crane_svg__vymnmh\",\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 75.999 65.348\",\n shapeRendering: \"geometricPrecision\",\n textRendering: \"geometricPrecision\"\n }, props), _style || (_style = /*#__PURE__*/React.createElement(\"style\", null, \"@keyframes vymnmh-u-long-bit_tr__tr{0%,to{transform:translate(221.510809px,683.090016px) rotate(0deg)}48.333333%{transform:translate(221.510809px,683.090016px) rotate(-5.959664deg)}}@keyframes vymnmh-u-dangly-bit_to__to{0%{transform:translate(257.868961px,662.938528px)}48.333333%{transform:translate(256.868961px,659.316316px)}to{transform:translate(257.868961px,662.94px)}}@keyframes vymnmh-u-dangly-bit_tr__tr{0%{transform:rotate(-85.023582deg);animation-timing-function:cubic-bezier(.42,0,.58,1)}26.666667%{transform:rotate(-96.341063deg);animation-timing-function:cubic-bezier(.42,0,.58,1)}51.666667%{transform:rotate(-62.115695deg);animation-timing-function:cubic-bezier(.42,0,.58,1)}75%{transform:rotate(-98.321067deg);animation-timing-function:cubic-bezier(.42,0,.58,1)}to{transform:rotate(-85.02deg)}}\")), /*#__PURE__*/React.createElement(\"g\", {\n id: \"crane_svg__vymnmh-u-vymnmh\",\n transform: \"matrix(.92821 0 0 .92822 -177.79 -599.042)\"\n }, _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n id: \"crane_svg__vymnmh-u-base\",\n transform: \"translate(193.868 650.416)\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"crane_svg__vymnmh-u-path-51\",\n d: \"M203.476 689.752h-2.9c-.009-.186-.024-.34-.024-.494v-15.82a1.425 1.425 0 011.578-1.608q6.787-.013 13.575.009a.983.983 0 01.6.3q3.157 3.129 6.286 6.287.292.3 2.737 9.97a.716.716 0 00-.346.716c.02.188 0 .379 0 .625h-2.023v5.028H247.134a10.21 10.21 0 018.985 4.726 10.441 10.441 0 01-6.369 15.961c-.853.193-1.725.29-2.6.287q-21.294.026-42.588.01a10.49 10.49 0 01-2.605-20.7 5.576 5.576 0 011.031-.184c.35-.015.461-.133.461-.484 0-1.386.034-2.772.052-4.158-.001-.123-.013-.266-.025-.471zm6.826 15.506a5.566 5.566 0 10-5.582 5.571 5.534 5.534 0 005.58-5.571zm42.833 0a5.566 5.566 0 10-5.586 5.567 5.534 5.534 0 005.586-5.562zm-28.682 0a5.471 5.471 0 10-5.466 5.567 5.486 5.486 0 005.465-5.563zm3.4-.01a5.471 5.471 0 105.484-5.55 5.487 5.487 0 00-5.484 5.555zm-10.094-20.066c0-1.244.01-2.436-.011-3.628a.809.809 0 00-.255-.475c-1.084-1.1-2.171-2.2-3.279-3.271a1.049 1.049 0 00-.654-.278c-2.165-.021-4.33-.014-6.5-.011-.634 0-.817.19-.818.829v6.4c0 .138.017.277.027.436zM206.3 689.78v4.952h13.8v-4.952z\",\n transform: \"translate(-193.865 -650.405)\",\n fill: \"#595959\"\n }))), /*#__PURE__*/React.createElement(\"g\", {\n transform: \"translate(221.51 683.09)\",\n style: {\n animation: \"vymnmh-u-long-bit_tr__tr 2500ms linear normal forwards\"\n }\n }, _g2 || (_g2 = /*#__PURE__*/React.createElement(\"g\", {\n id: \"crane_svg__vymnmh-u-long-bit\",\n transform: \"translate(-28.883 -31.674)\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"crane_svg__vymnmh-u-path-512\",\n d: \"M222.591 678.426c.292.3.476.326.821.07q10.172-7.54 20.362-15.056l17.369-12.829c.076-.056.156-.108.288-.2l5.414 7.325c-.9.669-1.768 1.312-2.635 1.954-.819.606-1.651 1.2-2.451 1.828-.184.157-2.854 2.088-2.989 2.187q-16.72 12.348-33.442 24.691m29.743-24.272l7.895-5.835-.056-.126-6.871-1.148zm-9.327.764l-.906 6.666.118.044 7.42-5.488-.067-.12zm-13.286 15.232l.889-6.523-.119-.051-7.263 5.367.032.123zm1.99-.9l.1.065 7.09-5.238-.043-.118-6.284-1.053zm8.424-6.954l.888-6.494-7.2 5.319.043.126zm10.313-8l.829-6.073-6.726 4.972.04.117zM225 686.334l6.166-4.558-6.166-1.03zm32.886-31l.044.126 5.425.908.066-.105-2.4-3.249z\",\n transform: \"translate(-193.708 -650.411)\",\n fill: \"#595959\"\n })))), /*#__PURE__*/React.createElement(\"g\", {\n style: {\n animation: \"vymnmh-u-dangly-bit_to__to 2500ms linear normal forwards\"\n }\n }, /*#__PURE__*/React.createElement(\"g\", {\n transform: \"rotate(-85.024 490.52 190.82)\",\n style: {\n animation: \"vymnmh-u-dangly-bit_tr__tr 2500ms linear normal forwards\"\n }\n }, _g3 || (_g3 = /*#__PURE__*/React.createElement(\"g\", {\n id: \"crane_svg__vymnmh-u-dangly-bit\",\n transform: \"translate(-120.47 -33.157)\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"crane_svg__vymnmh-u-path-513\",\n d: \"M261.441 662.14c-.05 5.608-.078 11.215-.116 16.823a.468.468 0 00.372.547 4.159 4.159 0 01-.053 7.928.442.442 0 00-.368.5 21.83 21.83 0 000 2.769 4.572 4.572 0 001.4 3.212 3.087 3.087 0 004.986-1.977c.048-.249.077-.5.119-.783h2.087c-.02.42-.068.839-.14 1.253a5.208 5.208 0 01-10.171.448c-.103-.448-.181-.9-.234-1.357a34.618 34.618 0 01-.166-3.724c-.012-.288-.157-.368-.375-.464a4.024 4.024 0 01-2.49-3.049 4.085 4.085 0 012.45-4.629.648.648 0 00.452-.707c.026-7.551.06-15.343.044-15.544\",\n transform: \"matrix(0 .99648 -.9971 0 780.988 -226.754)\",\n fill: \"#595959\"\n })))))));\n}\n\nexport default __webpack_public_path__ + \"6629751bd52ac32d6ddbb127d4f90d7c.svg\";\nexport { SvgCrane as ReactComponent };","var _style, _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgMaterial(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n id: \"material_svg__material\",\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 600 600\",\n shapeRendering: \"geometricPrecision\",\n textRendering: \"geometricPrecision\"\n }, props), _style || (_style = /*#__PURE__*/React.createElement(\"style\", null, \"@keyframes material-s-g1_to__to{0%{offset-distance:0;animation-timing-function:cubic-bezier(.63,-.045,1,1)}5.555556%{offset-distance:95.398538%}12.962963%,9.259259%,to{offset-distance:100%}}@keyframes material-s-g1_ts__ts{0%,5.555556%{transform:scale(.82748,.82748)}12.962963%,9.259259%{transform:scale(1.056784,.685574)}20.37037%,to{transform:scale(1,1)}}\")), /*#__PURE__*/React.createElement(\"g\", {\n style: {\n offsetPath: \"path('M300.000012,-159.194218C300.000012,36.028089,300,465.88047,300,546.245804C300.000001,533.021342,300.000002,521.688124,300,512.219543Q300.000002,521.688124,300,512.219543')\",\n offsetRotate: \"0deg\",\n animation: \"material-s-g1_to__to 5400ms linear 1 normal forwards\"\n }\n }, /*#__PURE__*/React.createElement(\"g\", {\n transform: \"scale(.82748)\",\n style: {\n animation: \"material-s-g1_ts__ts 5400ms linear 1 normal forwards\"\n }\n }, _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n id: \"material_svg__material-s-g1\",\n transform: \"translate(-299.095 -495.3)\",\n fill: \"#707070\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path1\",\n d: \"M323.2 442c-45.2 0-89.2-2.6-131.2-5.4-56.4-3.8-110.8-9.4-157.5-36.7-10.9-6.3-17.6-15.2-19-25-1.3-8.9 2.1-16.9 5.1-21.9 8.4-14 20.3-26.5 31.8-38.7 3.7-3.9 7.4-7.8 10.9-11.6 15.2-16.8 31-33.5 47-49.4 18.3-18.2 34.7-24.1 48.9-17.4 7 3.3 12 8.5 16.8 13.6 2.8 2.9 5.4 5.7 8.3 7.9 3.1 2.4 3.7 7 1.3 10.1s-7 3.7-10.1 1.3c-3.7-2.9-6.9-6.2-9.9-9.4-4.1-4.3-7.9-8.3-12.5-10.5-10-4.8-23.3 5.3-32.6 14.6-15.8 15.8-31.5 32.2-46.5 48.9-3.5 3.9-7.3 7.9-11.1 11.9-11 11.6-22.3 23.6-29.9 36.2-2.6 4.3-3.7 8.8-3.2 12.5 1.1 7.5 8.8 12.8 12 14.7 44 25.7 96.6 31.1 151.2 34.7 58.3 3.9 120.4 7.4 183.7 4 11.1-.6 22.1-1.3 33.1-2.2 27.2-2.2 56.2-5.2 83.8-12.4 14.6-3.8 27.4-8.2 39.2-13.7l3.3-1.5c9.1-4.1 20.5-9.3 23.2-17 1.4-4 .9-8.2.3-11.1-2-8.4-8.2-16.8-18.9-25.4-31.4-25.5-61.8-52.7-91.2-79.1-9.7-8.7-19.5-17.4-29.3-26.1-14.8-13.1-28.8-27.6-42.3-41.5-19.7-20.3-40-41.3-62.8-58.1-8-5.9-17.6-12.1-27.8-13.2-9.4-1.1-20 2.2-29.9 9.1-10.8 7.5-68.1 69.7-84.3 92.7-2.3 3.3-6.8 4-10 1.7s-4-6.8-1.7-10c16.3-23.1 74.6-87 87.8-96.2 12.8-8.9 26.9-13 39.7-11.6 13.7 1.5 25.3 8.9 34.8 15.9 23.8 17.5 44.5 38.9 64.6 59.6 13.3 13.8 27.1 28 41.5 40.7 9.8 8.7 19.6 17.4 29.3 26.2 29.3 26.2 59.6 53.4 90.7 78.6 13.3 10.8 21 21.7 23.8 33.3 1.6 6.7 1.4 13.4-.7 19.2-4.8 13.5-19.9 20.3-30.9 25.3l-3.2 1.4c-12.6 5.9-26.2 10.6-41.7 14.6-28.7 7.4-58.4 10.5-86.3 12.8-11.2.9-22.3 1.7-33.5 2.3-18.1.9-36.2 1.3-54.1 1.3z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path2\",\n d: \"M344.5 220.7c3.1.4 6.3 1.8 8 4.5 2.2 3.4 1.5 8.1-1 11.3s-6.4 4.9-10.4 5.6c-.8.1-1.5.2-2.3-.1-.6-.2-1.1-.8-1.6-1.2-1.1-1.1-2.2-2.3-3.3-3.4-1.2-1.2-2.4-2.9-1.7-4.4.3-.7 1.1-1.2 1.4-1.8 1.6-3-2.6-6.2.2-9.1 1.9-2.1 8.4-1.7 10.7-1.4z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path3\",\n d: \"M246 356.4c-1.1-2.9-1.3-6.4.3-9.1 2-3.5 6.5-5.1 10.5-4.3 4 .7 7.3 3.4 9.8 6.6.5.6.9 1.3 1 2s-.1 1.4-.4 2l-1.5 4.5c-.5 1.6-1.4 3.5-3.1 3.6-.8 0-1.5-.4-2.3-.4-3.4-.1-4.3 5.2-8.2 4-2.7-.8-5.3-6.8-6.1-8.9z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path4\",\n d: \"M368.1 263c3.4-1.3 7.5-.2 9.9 2.5 1.8 2.1 2.6 5.1 2.1 7.8-.3 1.3-.8 2.5-1.8 3.4-1.1 1-2.5 1.4-4 1.9-2.1.6-4.2 1.3-6.3 1.3-2.2 0-4.4-.6-5.8-2.3-1.2-1.3-1.6-3.1-1.6-4.9.1-2.3.8-4.8 2.3-6.6l5.2-3.1z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path5\",\n d: \"M102.2 340.3c3.4-1.3 7.5-.2 9.9 2.5 1.8 2.1 2.6 5.1 2.1 7.8-.3 1.3-.8 2.5-1.8 3.4-1.1 1-2.5 1.4-4 1.9-2.1.6-4.2 1.3-6.3 1.3s-4.4-.6-5.8-2.3c-1.2-1.3-1.6-3.1-1.6-4.9.1-2.3.8-4.8 2.3-6.6l5.2-3.1z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path6\",\n d: \"M375.9 332.2c3 2.2 4.3 6.1 3.4 9.7-.7 2.7-2.8 5-5.4 6-1.2.5-2.5.7-3.8.4-1.4-.4-2.6-1.3-3.7-2.3-1.7-1.4-3.3-2.8-4.6-4.6-1.2-1.8-1.9-4-1.3-6.1.5-1.7 1.7-3.1 3.2-4 2-1.2 4.5-2 6.8-1.8l5.4 2.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path7\",\n d: \"M135.5 306.2c3 2.2 4.3 6.1 3.4 9.7-.7 2.7-2.8 5-5.4 6-1.2.5-2.5.7-3.8.4-1.4-.4-2.6-1.3-3.7-2.3-1.7-1.4-3.3-2.8-4.6-4.6s-1.9-4-1.3-6.1c.5-1.7 1.7-3.1 3.2-4 2-1.2 4.5-2 6.8-1.8l5.4 2.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path8\",\n d: \"M421.5 368.9c3 2.2 4.3 6.1 3.4 9.7-.7 2.7-2.8 5-5.4 6-1.2.5-2.5.7-3.8.4-1.4-.4-2.6-1.3-3.7-2.3-1.7-1.4-3.3-2.8-4.6-4.6-1.2-1.8-1.9-4-1.3-6.1.5-1.7 1.7-3.1 3.2-4 2-1.2 4.5-2 6.8-1.8l5.4 2.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path9\",\n d: \"M155.5 341.2c-.2 3-2.4 5.7-5.3 6.6-2.2.7-4.7.2-6.6-1.1-.9-.6-1.6-1.5-1.9-2.5-.4-1.2-.2-2.4 0-3.6.2-1.8.5-3.5 1.2-5.2.7-1.6 2-3.1 3.7-3.6 1.4-.4 2.9-.1 4.2.5 1.7.8 3.4 2.2 4.2 4l.5 4.9z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path10\",\n d: \"M350.2 371.6c3.6-.7 7.4 1.1 9.3 4.2 1.5 2.4 1.7 5.5.7 8.1-.5 1.2-1.2 2.3-2.3 3-1.2.8-2.8 1-4.2 1.1-2.1.2-4.3.5-6.4.2s-4.2-1.4-5.4-3.2c-.9-1.5-1.1-3.4-.7-5.1.5-2.3 1.6-4.6 3.4-6.1l5.6-2.2z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path11\",\n d: \"M324.5 461.9c5.1-.4 10.7 1.7 13.7 5 2.3 2.5 2.9 5.7 1.6 8.2-.6 1.2-1.6 2.3-3.1 2.9-1.7.7-3.9.8-6 .8-3 .1-6.1.2-9.2-.3s-6.2-1.7-7.9-3.7c-1.4-1.6-1.8-3.5-1.4-5.2.5-2.3 1.9-4.6 4.4-6l7.9-1.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path12\",\n d: \"M494.8 453.4c5.1-.4 10.7 1.7 13.7 5 2.3 2.5 2.9 5.7 1.6 8.2-.6 1.2-1.6 2.3-3.1 2.9-1.7.7-3.9.8-6 .8-3 .1-6.1.2-9.2-.3s-6.2-1.7-7.9-3.7c-1.4-1.6-1.8-3.5-1.4-5.2.5-2.3 1.9-4.6 4.4-6l7.9-1.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path13\",\n d: \"M538.7 426.4c5.1-.4 10.7 1.7 13.7 5 2.3 2.5 2.9 5.7 1.6 8.2-.6 1.2-1.6 2.3-3.1 2.9-1.7.7-3.9.8-6 .8-3 .1-6.1.2-9.2-.3s-6.2-1.7-7.9-3.7c-1.4-1.6-1.8-3.5-1.4-5.2.5-2.3 1.9-4.6 4.4-6l7.9-1.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path14\",\n d: \"M567 475.1c5.1-.4 10.7 1.7 13.7 5 2.3 2.5 2.9 5.7 1.6 8.2-.6 1.2-1.6 2.3-3.1 2.9-1.7.7-3.9.8-6 .8-3 .1-6.1.2-9.2-.3s-6.2-1.7-7.9-3.7c-1.4-1.6-1.8-3.5-1.4-5.2.5-2.3 1.9-4.6 4.4-6l7.9-1.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path15\",\n d: \"M415.8 292.8c3 2.2 4.3 6.1 3.4 9.7-.7 2.7-2.8 5-5.4 6-1.2.5-2.5.7-3.8.4-1.4-.4-2.6-1.3-3.7-2.3-1.7-1.4-3.3-2.8-4.6-4.6-1.2-1.8-1.9-4-1.3-6.1.5-1.7 1.7-3.1 3.2-4 2-1.2 4.5-2 6.8-1.8l5.4 2.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path16\",\n d: \"M462 329c3 2.2 4.3 6.1 3.4 9.7-.7 2.7-2.8 5-5.4 6-1.2.5-2.5.7-3.8.4-1.4-.4-2.6-1.3-3.7-2.3-1.7-1.4-3.3-2.8-4.6-4.6-1.2-1.8-1.9-4-1.3-6.1.5-1.7 1.7-3.1 3.2-4 2-1.2 4.5-2 6.8-1.8l5.4 2.7z\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n id: \"material_svg__material-s-path17\",\n d: \"M415.5 495.3c-3.1 0-6.3-.3-9.5-1.1-3.1-.8-6.2-2-9.2-3.8-2.2-1.3-5.3-3.3-7.4-6.6-4.6-7.5-1-17 4.8-22 10-8.7 27.4-13.6 39.2-6.5 6.4 3.8 10.7 10.2 11.5 17.1.9 7.6-2.8 15.2-9 18.9-3.6 2.2-7.8 2.9-11.7 3.4-2.6.3-5.6.6-8.7.6zm4.6-36.2c-7.5 0-15.8 3.4-21.2 8.2-3.5 3.1-5.8 8.9-3.4 12.9.9 1.4 2.4 2.7 4.8 4.1 2.5 1.4 5 2.5 7.4 3.1 5.2 1.3 10.8.9 15.5.3 2.9-.4 6.3-.9 8.9-2.4 3.8-2.3 6.1-7.2 5.6-12-.5-4.6-3.6-9.1-8-11.8-2.8-1.7-6.1-2.4-9.6-2.4z\"\n }))))));\n}\n\nexport default __webpack_public_path__ + \"ad0c6e7640223310520080d4ad993892.svg\";\nexport { SvgMaterial as ReactComponent };","import { withMotionMax as withMotion } from '@hoc/withMotionMax';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport YSButton from '@ys/Components/Shared/YSButton/YSButton';\r\nimport Dropdown from '@ys/Components/Steps/Controls/Dropdown/Dropdown';\r\nimport { MAX_SIZE } from '@ys/Components/Steps/Dimensions/Dimensions';\r\nimport { DimensionsStyles } from '@ys/Components/Steps/Dimensions/Dimensions.styles';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport React, { useEffect, useMemo, useState } from 'react';\r\nimport { SurchargeDetailsStyles as S } from './SurchargeDetails.styles';\r\nimport SurchargesTable from './SurchargesTable/SurchargesTable';\r\nimport Building from '@img/ysp/surcharges/building.png';\r\nimport Crane from '@img/ysp/surcharges/crane.png';\r\nimport Embankments from '@img/ysp/surcharges/embankments.png';\r\nimport Railway from '@img/ysp/surcharges/railway.png';\r\nimport Road from '@img/ysp/surcharges/road.svg';\r\nimport { ReactComponent as Cross } from '@img/ysp/icon-cross.svg';\r\nimport { ReactComponent as BuildingAnimated } from '@img/ysp/surcharges/building.svg';\r\nimport { ReactComponent as CraneAnimated } from '@img/ysp/surcharges/crane.svg';\r\nimport { ReactComponent as MaterialAnimated } from '@img/ysp/surcharges/material.svg';\r\nimport InfoIcon from '../../../InfoIcon/InfoIcon';\r\nimport { SharedStyles } from '../../../Shared.styles';\r\nexport var SurchargeIcon;\r\n(function (SurchargeIcon) {\r\n SurchargeIcon[SurchargeIcon[\"None\"] = 0] = \"None\";\r\n SurchargeIcon[SurchargeIcon[\"Building\"] = 1] = \"Building\";\r\n SurchargeIcon[SurchargeIcon[\"Plant\"] = 2] = \"Plant\";\r\n SurchargeIcon[SurchargeIcon[\"Slope\"] = 3] = \"Slope\";\r\n SurchargeIcon[SurchargeIcon[\"Rail\"] = 4] = \"Rail\";\r\n SurchargeIcon[SurchargeIcon[\"Road\"] = 5] = \"Road\";\r\n})(SurchargeIcon || (SurchargeIcon = {}));\r\nexport var SurchargeSource;\r\n(function (SurchargeSource) {\r\n SurchargeSource[SurchargeSource[\"General\"] = 0] = \"General\";\r\n SurchargeSource[SurchargeSource[\"FixedPlant\"] = 1] = \"FixedPlant\";\r\n SurchargeSource[SurchargeSource[\"MovingPlant\"] = 2] = \"MovingPlant\";\r\n SurchargeSource[SurchargeSource[\"Road\"] = 3] = \"Road\";\r\n SurchargeSource[SurchargeSource[\"Rail\"] = 4] = \"Rail\";\r\n SurchargeSource[SurchargeSource[\"SmallBuilding\"] = 5] = \"SmallBuilding\";\r\n SurchargeSource[SurchargeSource[\"LargeBuilding\"] = 6] = \"LargeBuilding\";\r\n SurchargeSource[SurchargeSource[\"Slope\"] = 7] = \"Slope\";\r\n SurchargeSource[SurchargeSource[\"Other\"] = 8] = \"Other\";\r\n})(SurchargeSource || (SurchargeSource = {}));\r\nexport var SurchargeType;\r\n(function (SurchargeType) {\r\n SurchargeType[SurchargeType[\"Blanket\"] = 0] = \"Blanket\";\r\n SurchargeType[SurchargeType[\"Strip\"] = 1] = \"Strip\";\r\n SurchargeType[SurchargeType[\"Area\"] = 2] = \"Area\";\r\n SurchargeType[SurchargeType[\"Trap\"] = 3] = \"Trap\";\r\n SurchargeType[SurchargeType[\"Line\"] = 4] = \"Line\";\r\n SurchargeType[SurchargeType[\"Point\"] = 5] = \"Point\";\r\n})(SurchargeType || (SurchargeType = {}));\r\nconst getIcon = (icon) => {\r\n switch (icon) {\r\n default:\r\n case SurchargeIcon.None:\r\n return '';\r\n case SurchargeIcon.Building:\r\n return Building;\r\n case SurchargeIcon.Plant:\r\n return Crane;\r\n case SurchargeIcon.Rail:\r\n return Railway;\r\n case SurchargeIcon.Slope:\r\n return Embankments;\r\n case SurchargeIcon.Road:\r\n return Road;\r\n }\r\n};\r\nconst Surcharge = ({ i, value, surcharges, onChange, removeSurcharge, dropdownPlaceholder, ...rest }) => {\r\n const iconSrc = useMemo(() => getIcon(value.surchargeIcon), [value.surchargeIcon]);\r\n return (React.createElement(S.SurchargeWrapper, { ...rest },\r\n React.createElement(S.IconContainer, null,\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(S.MotionWrapper, { icon: value.surchargeIcon, key: value.surchargeIcon },\r\n value.surchargeIcon === SurchargeIcon.Plant && React.createElement(CraneAnimated, null),\r\n value.surchargeIcon === SurchargeIcon.Building && React.createElement(BuildingAnimated, null),\r\n value.surchargeIcon === SurchargeIcon.Slope && React.createElement(MaterialAnimated, null),\r\n (value.surchargeIcon === SurchargeIcon.None ||\r\n value.surchargeIcon === SurchargeIcon.Road ||\r\n value.surchargeIcon === SurchargeIcon.Rail) && (React.createElement(React.Fragment, null, iconSrc && React.createElement(\"img\", { src: iconSrc })))))),\r\n React.createElement(S.SurchargeName, null,\r\n \"Surcharge \",\r\n i + 1),\r\n React.createElement(Dropdown, { i: 6 - i + 10, onChange: (id) => onChange(id), value: value.id, options: surcharges, placeholder: dropdownPlaceholder }),\r\n i > 0 && (React.createElement(S.DeleteWrapper, { onClick: () => confirm('Are you sure you want to delete this surcharge?') && removeSurcharge(i) },\r\n React.createElement(Cross, null)))));\r\n};\r\nconst SurchargeDetails = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const determinePreselectedSurcharges = () => {\r\n const preselectedSurcharges = state.surcharges.filter((x) => x.surchargePreselected);\r\n if (preselectedSurcharges.length > 0 && !state.hasAddedDefaultSurcharge) {\r\n // Some are preselected, return those //\r\n dispatch({ type: 'set-has-added-default-surcharge', payload: true });\r\n return preselectedSurcharges;\r\n }\r\n if (state.form.surchargeProfiles) {\r\n return state.form.surchargeProfiles;\r\n }\r\n return [\r\n {\r\n id: -1,\r\n surchargeDescription: 'Please select a surcharge...',\r\n surchargeIcon: SurchargeIcon.None,\r\n },\r\n ];\r\n };\r\n const [surcharges, setSurcharges] = useState(determinePreselectedSurcharges());\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: surcharges.length === 0 ||\r\n surcharges.some((x) => x.id === -1) ||\r\n surcharges.some((x) => !Number(x.surchargeMagnitude)),\r\n },\r\n });\r\n }, [surcharges, surcharges.map((x) => x.surchargeMagnitude).toString()]);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: surcharges.length === 0 ||\r\n surcharges.some((x) => x.id === -1) ||\r\n surcharges.some((x) => !Number(x.surchargeMagnitude)),\r\n },\r\n });\r\n }, [surcharges, surcharges.map((x) => x.surchargeMagnitude).toString()]);\r\n useEffect(() => {\r\n setFormField('surchargeProfiles', surcharges);\r\n }, [surcharges]);\r\n const addSurcharge = () => {\r\n const copy = [...surcharges];\r\n copy.push({\r\n id: -1,\r\n surchargeDescription: 'Please select a surcharge...',\r\n surchargeIcon: SurchargeIcon.None,\r\n });\r\n setSurcharges(copy);\r\n };\r\n const [actualHeight, actualWidth] = useMemo(() => {\r\n const ratio = state.form.width / state.form.length;\r\n const actualHeight = ratio > 1 ? (1 / ratio) * MAX_SIZE : MAX_SIZE;\r\n const actualWidth = ratio < 1 ? ratio * MAX_SIZE : MAX_SIZE;\r\n return [actualHeight, actualWidth];\r\n }, []);\r\n const surchargeOptions = useMemo(() => {\r\n if (state.surcharges.length === 0) {\r\n return [];\r\n }\r\n return state.surcharges.map((s) => ({\r\n id: s.id,\r\n text: s.surchargeDescription,\r\n }));\r\n }, [state.surcharges]);\r\n if (state.surcharges.length === 0) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n const modifyLayer = (position, type, value) => {\r\n const surcharge = surcharges[position];\r\n if (surcharge) {\r\n // Moans about the 'id' not being the right type, but it's being omitted via Lodash //\r\n let clone = { ...surcharge };\r\n clone[type] = value;\r\n if (type === 'surchargeType') {\r\n const retypedClone = clone;\r\n // Depending on the type we need to reset some values back to undefined //\r\n switch (value) {\r\n default:\r\n case SurchargeType.Trap:\r\n break;\r\n case SurchargeType.Blanket:\r\n retypedClone.surchargeDepth = undefined;\r\n retypedClone.surchargeOffset = undefined;\r\n retypedClone.surchargeWidth = undefined;\r\n retypedClone.surchargeLength = undefined;\r\n retypedClone.surchargeMagnitudeB = undefined;\r\n break;\r\n case SurchargeType.Strip:\r\n retypedClone.surchargeLength = undefined;\r\n retypedClone.surchargeMagnitudeB = undefined;\r\n break;\r\n case SurchargeType.Area:\r\n retypedClone.surchargeMagnitudeB = undefined;\r\n break;\r\n case SurchargeType.Line:\r\n case SurchargeType.Point:\r\n retypedClone.surchargeWidth = undefined;\r\n retypedClone.surchargeLength = undefined;\r\n retypedClone.surchargeMagnitudeB = undefined;\r\n break;\r\n }\r\n const matchingSurchargeType = state.surcharges.find((x) => x.surchargeType === value);\r\n if (matchingSurchargeType && matchingSurchargeType?.surchargeMagnitude) {\r\n // If a default magnitude has been set, add it here //\r\n retypedClone.surchargeMagnitude = matchingSurchargeType.surchargeMagnitude;\r\n }\r\n clone = retypedClone;\r\n }\r\n const surchargesClone = [...surcharges];\r\n surchargesClone.splice(position, 1, clone);\r\n setSurcharges(surchargesClone);\r\n }\r\n };\r\n const removeSurcharge = (p) => {\r\n const clone = [...surcharges];\r\n clone.splice(p, 1);\r\n setSurcharges(clone);\r\n };\r\n return (React.createElement(StepStyles.Grid, null,\r\n React.createElement(Containers.Default, null,\r\n React.createElement(SharedStyles.TitleWithInfoIcon, null,\r\n React.createElement(\"h2\", null, state.labels['surchargeProfile.heading']),\r\n state.labels['surchargeProfile.tooltip'] && (React.createElement(InfoIcon, { onClick: () => {\r\n dispatch({\r\n type: 'set-modal',\r\n payload: {\r\n description: state.labels['surchargeProfile.tooltip'],\r\n fullWidth: true,\r\n size: 'normal',\r\n },\r\n });\r\n } }))),\r\n React.createElement(S.Container, null,\r\n React.createElement(S.TopStep, null,\r\n React.createElement(S.DimensionsWrapper, null,\r\n React.createElement(DimensionsStyles.Outer, { style: { width: `${actualHeight}px`, height: `${actualWidth}px` } },\r\n React.createElement(DimensionsStyles.Inner, null,\r\n React.createElement(DimensionsStyles.Arrow, { direction: \"width\", style: { height: `${actualWidth}px` } }, !isNaN(state.form.width) && (React.createElement(\"span\", null,\r\n state.form.width.toFixed(2),\r\n \"m\"))),\r\n React.createElement(DimensionsStyles.Arrow, { direction: \"length\", style: { width: `${actualHeight}px` } }, !isNaN(state.form.length) && (React.createElement(\"span\", null,\r\n state.form.length.toFixed(2),\r\n \"m\")))))),\r\n React.createElement(S.SurchargesWrapper, null,\r\n surcharges.map((s, i) => (React.createElement(Surcharge, { \"data-last\": i === surcharges.length - 1, key: `Surcharges_${i}_${surchargeOptions.length}`, i: i, surcharges: surchargeOptions, onChange: (id) => {\r\n const copy = [...surcharges];\r\n const valIndex = state.surcharges.findIndex((x) => x.id === id);\r\n copy.splice(i, 1, state.surcharges[valIndex]);\r\n setSurcharges(copy);\r\n }, removeSurcharge: removeSurcharge, dropdownPlaceholder: state.labels['ysp.surchage.table.please-select-surcharge'], value: s }))),\r\n React.createElement(S.ButtonWrapper, null,\r\n React.createElement(YSButton, { icon: \"plus\", disabled: surcharges.length === 6, onClick: () => addSurcharge() }, \"Add surcharge\")))),\r\n React.createElement(SurchargesTable, { surcharges: surcharges.filter((x) => x.id !== -1), update: modifyLayer })))));\r\n};\r\nexport default withMotion(SurchargeDetails);\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nimport { WYSIWYGStyles } from '../../Shared.styles';\r\nconst Container = styled.div `\r\n width: 100%;\r\n height: max-content;\r\n max-height: 100%;\r\n\r\n padding: 20px 15px;\r\n background-color: ${brand.grey.grey96};\r\n display: flex;\r\n flex-direction: column;\r\n gap: 20px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n max-height: 55vh;\r\n height: 100%;\r\n padding: 35px 30px;\r\n }\r\n`;\r\nconst Title = styled.div `\r\n ${fonts.DaxPro.Bold};\r\n color: ${brand.primary.alt};\r\n font-size: 22px;\r\n`;\r\nconst TextContainer = styled.div `\r\n ${fonts.DaxPro.Regular};\r\n display: flex;\r\n flex-direction: column;\r\n gap: 20px;\r\n height: 32dvh;\r\n\r\n user-select: none;\r\n\r\n ${WYSIWYGStyles}\r\n font-size: 15px;\r\n line-height: 21px;\r\n white-space: pre-line;\r\n padding-right: 20px;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n max-height: 45dvh;\r\n }\r\n\r\n overflow: auto;\r\n -webkit-overflow-scrolling: touch;\r\n &::-webkit-scrollbar-track {\r\n background-color: ${brand.white};\r\n }\r\n\r\n &::-webkit-scrollbar {\r\n height: 6px;\r\n width: 12px;\r\n }\r\n\r\n &::-webkit-scrollbar-thumb {\r\n background-color: ${brand.grey.grey89};\r\n border-radius: 0;\r\n cursor: pointer;\r\n }\r\n\r\n p {\r\n font-size: 14px;\r\n margin-bottom: 0;\r\n }\r\n\r\n a {\r\n word-break: break-word;\r\n }\r\n\r\n li {\r\n font-size: 14px;\r\n margin-bottom: 5px;\r\n padding-left: 26px;\r\n position: relative;\r\n list-style: none;\r\n\r\n &:before {\r\n content: '';\r\n display: block;\r\n border-radius: 50%;\r\n width: 10px;\r\n height: 10px;\r\n background-color: ${brand.primary.base};\r\n position: absolute;\r\n top: calc(0.5em - 3px);\r\n left: 0px;\r\n }\r\n }\r\n`;\r\nexport const TermsAndConditionsStyles = {\r\n Container,\r\n Title,\r\n TextContainer,\r\n};\r\n","import React, { useEffect, useRef, useState } from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport Checkbox from '@ys/Components/Steps/Controls/Checkbox/Checkbox';\r\nimport { TermsAndConditionsStyles as S } from './TermsAndConditions.styles';\r\nimport debounce from 'lodash/debounce';\r\nimport inRange from 'lodash/inRange';\r\nimport { Containers, StepStyles } from '@ys/Components/Shared/Step.styles';\r\nimport YSButton from '../../Shared/YSButton/YSButton';\r\nconst TermsAndConditions = () => {\r\n const { state, dispatch, setFormField } = useYSPContext();\r\n const textboxRef = useRef(null);\r\n const [attachedListener, setAttachedListener] = useState(false);\r\n const [hasScrolledToBottom, setHasScrolledToBottom] = useState(false);\r\n const trackScroll = (el) => {\r\n setHasScrolledToBottom(inRange(el.scrollTop + el.clientHeight, el.scrollHeight - 50, el.scrollHeight + 50));\r\n };\r\n const debouncedTrackScroll = debounce(trackScroll, 250);\r\n const trackScrollHandler = (ev) => {\r\n ev.target && debouncedTrackScroll(ev.target);\r\n };\r\n useEffect(() => {\r\n if (textboxRef.current && !attachedListener) {\r\n textboxRef.current.addEventListener('scroll', trackScrollHandler);\r\n setAttachedListener(true);\r\n }\r\n }, [textboxRef]);\r\n useEffect(() => {\r\n dispatch({\r\n type: 'set-footer',\r\n payload: {\r\n nextDisabled: !hasScrolledToBottom || !state.form.acceptedTs,\r\n },\r\n });\r\n }, [hasScrolledToBottom, state.form.acceptedTs]);\r\n return (React.createElement(StepStyles.Grid, null,\r\n React.createElement(Containers.Thin, null,\r\n React.createElement(S.Container, null,\r\n React.createElement(S.Title, null, state.labels['terms-and-conditions'] || 'Terms & Conditions'),\r\n React.createElement(S.TextContainer, { ref: textboxRef, dangerouslySetInnerHTML: { __html: state.labels['terms.details'] } }),\r\n React.createElement(Checkbox, { value: state.form.acceptedTs || false, label: state.labels['terms.accept'], onChange: () => setFormField('acceptedTs', !state.form.acceptedTs) }),\r\n React.createElement(YSButton, { icon: \"arrow\", disabled: !hasScrolledToBottom || !state.form.acceptedTs, onClick: () => {\r\n if (hasScrolledToBottom && state.form.acceptedTs) {\r\n dispatch({ type: 'next-step' });\r\n }\r\n } }, state.labels['accept'] || 'Accept')))));\r\n};\r\nexport default TermsAndConditions;\r\n","import { SolutionSubType } from '../../Context/types';\r\nexport const dummyData = {\r\n depth: 2,\r\n width: 3,\r\n length: 3,\r\n subType: SolutionSubType.None,\r\n groundwaterDepth: 1.5,\r\n name: 'jakestringer',\r\n email: 'JakeStringer@netconstruct.co.uk',\r\n telephone: '07111111111',\r\n companyName: 'NetConstruct',\r\n acceptedTs: true,\r\n schemeName: '12',\r\n siteName: '12',\r\n recaptchaToken: '03AFY_a8V5nqCVQ0sT6Rf9SIsbL58nOl8a-_qXRiKFWaT9dGT2Vp4lvs8q4ZkrIZbeAI72eUlN4YjRPfj76Ctk5qCEv5lG9nop4u6aIxbgU-k-wkRsgGEFw_aIO8Nk-HsV9CtKuDOiBJXXg6_DLFUlbJUWkB5px7-0l2tCDRSyTVB0UPzYCCfYNXUba_URwJX3EVzWoaCM_VQkQjhhIX0sxsgURTKPUms0rdkVLbfU7nMRoRZi2nDHJcu8zw43CSEkCGD_aXHxog_Mdeu-yQPip9CMcoVaBKWoNYn5JRDqqMUQ3b7iIOu63oxUddkkNaVbWfhm3NVf1VV7oBfzg1CWMgHdqKD5fNP2CzwTv3o-hzsbQ3YBnwul65du-oC14dDwdt5luZD3LuOVBPBqMCSTeegdBRgE0Q72bl3Bcru53xuSDlW5cBunSgYNdcxjku_TSC3UfaROiT5NmtXhdQVynni9hsUeoX1nacV9FLTF-eUs4_fEC6CHppYhB63f5GKCmUoxKPzrGFQV3ywiwcFTKz_asgM--QfMy_KQuIAthBY1vbJJHtdJMfY',\r\n postCode: 'ls15 7qp',\r\n endSafePanelsRequired: false,\r\n acceptedSoilModification: false,\r\n soilLayers: [\r\n {\r\n id: '3633',\r\n soilTypeId: 4,\r\n bgl: 0,\r\n description: 'Silt (Firm)',\r\n soilDensity: 19,\r\n saturatedDensity: 19,\r\n angleOfFriction: 28,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n {\r\n id: '3889',\r\n soilTypeId: 2,\r\n bgl: 0.25,\r\n description: 'Road Construction',\r\n soilDensity: 21,\r\n saturatedDensity: 21,\r\n angleOfFriction: 40,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n {\r\n id: '3889',\r\n soilTypeId: 2,\r\n bgl: 0.75,\r\n description: 'Peat',\r\n soilDensity: 21,\r\n saturatedDensity: 21,\r\n angleOfFriction: 40,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n {\r\n id: '3835',\r\n soilTypeId: 2,\r\n bgl: 1.25,\r\n description: 'Clay (Soft)',\r\n soilDensity: 21,\r\n saturatedDensity: 21,\r\n angleOfFriction: 40,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n {\r\n id: '3835',\r\n soilTypeId: 2,\r\n bgl: 1.47,\r\n description: 'Clay (Hard)',\r\n soilDensity: 21,\r\n saturatedDensity: 21,\r\n angleOfFriction: 40,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n {\r\n id: '3890',\r\n soilTypeId: 5,\r\n bgl: 3,\r\n description: 'Ash',\r\n soilDensity: 21,\r\n saturatedDensity: 21,\r\n angleOfFriction: 40,\r\n wallFrictionFactor: 0,\r\n soilCohesion: 0,\r\n wallAdhesion: 0,\r\n },\r\n ],\r\n soilDisclaimer: true,\r\n soilInfoSource: 0,\r\n soilInfoSourceRef: '2',\r\n soilInfoSourceCompany: '2',\r\n groundwaterPresent: true,\r\n largeSurcharges: true,\r\n surchargeProfiles: [\r\n {\r\n surchargeDescription: 'Moving Plant up to 45Te',\r\n surchargeIcon: 2,\r\n surchargeSource: 2,\r\n surchargeType: 0,\r\n id: 1,\r\n },\r\n ],\r\n cultureCode: 'en-GB',\r\n};\r\n","import ApiService from '@core/api/services/ApiService';\r\nimport Loading from '@ys/Components/Loading/Loading';\r\nimport StepLoading from '@ys/Components/StepLoading/StepLoading';\r\nimport Groundwater from '@ys/Components/Steps/Conditions/Groundwater/Groundwater';\r\nimport GroundwaterDepth from '@ys/Components/Steps/Conditions/GroundwaterDepth/GroundwaterDepth';\r\nimport ProblematicGround from '@ys/Components/Steps/Conditions/ProblematicGround/ProblematicGround';\r\nimport SoilTypes from '@ys/Components/Steps/Conditions/SoilTypes/SoilTypes';\r\nimport Depth from '@ys/Components/Steps/Depth/Depth';\r\nimport Details from '@ys/Components/Steps/Details/Details';\r\nimport Dimensions from '@ys/Components/Steps/Dimensions/Dimensions';\r\nimport Landing from '@ys/Components/Steps/Landing/Landing';\r\nimport Location from '@ys/Components/Steps/Location/Location';\r\nimport NoSolutions from '@ys/Components/Steps/NoSolutions/NoSolutions';\r\nimport Solutions from '@ys/Components/Steps/Solutions/Solutions';\r\nimport SheetedSolution from '@ys/Components/Steps/Support/SheetedSolution/SheetedSolution';\r\nimport System from '@ys/Components/Steps/Support/System/System';\r\nimport AdjacentWater from '@ys/Components/Steps/Surcharges/AdjacentWater/AdjacentWater';\r\nimport LargeSurcharges from '@ys/Components/Steps/Surcharges/LargeSurcharges/LargeSurcharges';\r\nimport SlopingGround from '@ys/Components/Steps/Surcharges/SlopingGround/SlopingGround';\r\nimport Type from '@ys/Components/Steps/Type/Type';\r\nimport { ConditionStepID, DimensionsStepID, SoilGroundConditionsStepID, StepID, SupportStepID, SurchargeStepID, Tab, } from '@ys/Context/types';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport React, { useEffect, useState } from 'react';\r\nimport EndSafePanels from '../Steps/EndSafePanels/EndSafePanels';\r\nimport EndSafeSides from '../Steps/EndSafeSides/EndSafeSides';\r\nimport SoilProfiles from '../Steps/SoilProfiles/SoilProfiles';\r\nimport SoilSource from '../Steps/SoilProfiles/SoilSource/SoilSource';\r\nimport Summary from '../Steps/Solutions/YSP/Summary/Summary';\r\nimport YSPSolutions from '../Steps/Solutions/YSP/YSPSolutions';\r\nimport SurchargeDetails from '../Steps/Surcharges/SurchargeDetails/SurchargeDetails';\r\nimport TermsAndConditions from '../Steps/TermsAndConditions/TermsAndConditions';\r\nimport { dummyData } from './dummy';\r\nconst getYSPStep = (state) => {\r\n // Because of the different steps on both YS and YS+ using the same enum, there's a difference in the enum values //\r\n // Need to have some kind of middle man function to reconcile this before sending it to the backend //\r\n /*\r\n Landing = 0,\r\n Details = 1,\r\n Location = 2,\r\n Depth = 3,\r\n Dimensions = 4,\r\n EndSafe = 5,\r\n SoilProfiles = 6,\r\n SoilInfo = 7,\r\n Groundwater = 8,\r\n Surcharges = 9,\r\n Solutions = 10,\r\n SelectedSolution = 11,\r\n */\r\n switch (state.step) {\r\n default:\r\n case StepID.Landing:\r\n case StepID.Details:\r\n case StepID.Location:\r\n case StepID.Depth:\r\n // These steps are fine and already match up //\r\n return state.step;\r\n case StepID.TermsAndConditions:\r\n return StepID.Landing; // Landing step returns Terms & Conditions content //\r\n case StepID.Dimensions:\r\n switch (state.dimensionsStep) {\r\n default:\r\n case DimensionsStepID.Size:\r\n return state.step;\r\n case DimensionsStepID.Type:\r\n case DimensionsStepID.EndSafePanels:\r\n case DimensionsStepID.EndSafeSides:\r\n return 5;\r\n }\r\n case StepID.SoilsGroundConditions:\r\n switch (state.soilGroundConditionsStep) {\r\n default:\r\n case SoilGroundConditionsStepID.SoilProfiles:\r\n return 6;\r\n case SoilGroundConditionsStepID.SoilInformationSource:\r\n return 7;\r\n case SoilGroundConditionsStepID.Groundwater:\r\n case SoilGroundConditionsStepID.GroundwaterDepth:\r\n return 8;\r\n }\r\n case StepID.Surcharges:\r\n return 9;\r\n case StepID.Solutions:\r\n return 10;\r\n case StepID.SelectedSolution:\r\n return 11;\r\n }\r\n};\r\nconst StepRouter = (props) => {\r\n const [initialLoad, setInitialLoad] = useState(true);\r\n const { state, dispatch } = props;\r\n useEffect(() => {\r\n setInitialLoad(false);\r\n }, []);\r\n useEffect(() => {\r\n async function fetchStep() {\r\n dispatch({ type: 'get-step' });\r\n const params = {\r\n culture: state.cultureCode,\r\n step: state.tab === Tab.YourSolutionPlus ? getYSPStep(state) : state.step,\r\n };\r\n const response = await ApiService.request({\r\n controller: state.tab === Tab.YourSolution ? 'ISM' : 'YSP',\r\n slug: 'step',\r\n method: 'GET',\r\n params,\r\n });\r\n // Check any additional data that needs to be loaded for this step //\r\n if (state.tab === Tab.YourSolutionPlus) {\r\n if (state.step === StepID.SoilsGroundConditions &&\r\n state.soilGroundConditionsStep === SoilGroundConditionsStepID.SoilProfiles &&\r\n state.soilProfiles.length === 0) {\r\n const soilRequest = await ApiService.request({\r\n controller: 'YSP',\r\n slug: 'soilall',\r\n method: 'GET',\r\n });\r\n if (soilRequest.status.success) {\r\n dispatch({ type: 'set-soil-profiles', payload: soilRequest.result });\r\n }\r\n }\r\n if (state.step === StepID.Surcharges &&\r\n state.surchargeStep === SurchargeStepID.LargeSurcharge &&\r\n state.surcharges.length === 0) {\r\n // Fetch the surcharges //\r\n if (state.surcharges.length === 0) {\r\n const surchargeRequest = await ApiService.request({\r\n controller: 'YSP',\r\n slug: 'surcharges',\r\n method: 'GET',\r\n });\r\n if (surchargeRequest.status.success) {\r\n dispatch({\r\n type: 'set-surcharges',\r\n payload: surchargeRequest.result,\r\n });\r\n }\r\n }\r\n }\r\n }\r\n dispatch({ type: 'get-step-success', payload: response });\r\n }\r\n setTimeout(() => {\r\n // Always re-fetch step data\r\n fetchStep();\r\n }, initialLoad ? 0 : 350);\r\n async function submit() {\r\n if (state.tab === Tab.YourSolution) {\r\n try {\r\n dispatch({ type: 'submit' });\r\n const params = {\r\n ...state.form,\r\n cultureCode: state.cultureCode,\r\n };\r\n const response = await ApiService.request({\r\n controller: 'ISM',\r\n slug: 'submit',\r\n method: 'POST',\r\n params,\r\n });\r\n dispatch({ type: 'submit-success', payload: response });\r\n }\r\n catch (e) {\r\n dispatch({\r\n type: 'submit-success',\r\n payload: {\r\n questionnaireID: -1,\r\n firstReason: e.message,\r\n responseMessage: e.message,\r\n successful: false,\r\n technicalMessage: e.message,\r\n solutions: [],\r\n emailAddress: '',\r\n telNo: '',\r\n },\r\n });\r\n }\r\n }\r\n else {\r\n dispatch({ type: 'submit' });\r\n const params = state.globalStep === 1\r\n ? dummyData\r\n : {\r\n ...state.form,\r\n cultureCode: state.cultureCode,\r\n fetchingNewSolutions: state.fetchingNewSolutions,\r\n returnNoResults: false, // Flip to test the 'none of our boxes' screen on the results page //\r\n };\r\n const response = await ApiService.request({\r\n controller: 'YSP',\r\n slug: 'getsolutions',\r\n method: 'POST',\r\n params,\r\n });\r\n if (response.status.success) {\r\n // Wait a little bit just to show the animation, to not be jarring //\r\n setTimeout(() => {\r\n dispatch({ type: 'submit-ysp-success', payload: response.result });\r\n }, 2500);\r\n }\r\n }\r\n }\r\n async function selectSolution() {\r\n dispatch({ type: 'submit' });\r\n const params = {\r\n ...state.form,\r\n cultureCode: state.cultureCode,\r\n fetchingNewSolutions: false,\r\n };\r\n const response = await ApiService.request({\r\n controller: 'YSP',\r\n slug: 'submit',\r\n method: 'POST',\r\n params,\r\n });\r\n if (response.status.success) {\r\n // Wait a little bit just to show the animation, to not be jarring //\r\n setTimeout(() => {\r\n dispatch({ type: 'submit-solution-success', payload: response.result });\r\n }, 2500);\r\n }\r\n }\r\n // Submit our state data on the final step, this will automatically grab all of the solutions\r\n if (state.step === StepID.Solutions && state.formDirtyAfterSolutionsFetch) {\r\n submit();\r\n }\r\n // Used on YSP to submit the questionnaire with the selected solution to gain graph data etc. //\r\n if (state.step === StepID.SelectedSolution && state.hasChangedSelectedSolution) {\r\n selectSolution();\r\n }\r\n }, [\r\n state.step,\r\n state.tab,\r\n state.dimensionsStep,\r\n state.soilGroundConditionsStep,\r\n state.surchargeStep,\r\n ]);\r\n const getComponent = () => {\r\n // return ;\r\n if (state.loading) {\r\n return React.createElement(StepLoading, null);\r\n }\r\n switch (state.step) {\r\n default:\r\n case StepID.Landing:\r\n return React.createElement(Landing, null);\r\n case StepID.Details:\r\n return React.createElement(Details, null);\r\n case StepID.Location:\r\n return React.createElement(Location, null);\r\n case StepID.Depth:\r\n return React.createElement(Depth, null);\r\n case StepID.Dimensions:\r\n switch (state.dimensionsStep) {\r\n default:\r\n case DimensionsStepID.Size:\r\n return React.createElement(Dimensions, null);\r\n case DimensionsStepID.Type:\r\n return React.createElement(Type, null);\r\n case DimensionsStepID.EndSafePanels:\r\n return React.createElement(EndSafePanels, null);\r\n case DimensionsStepID.EndSafeSides:\r\n return React.createElement(EndSafeSides, null);\r\n }\r\n case StepID.Support:\r\n switch (state.supportStep) {\r\n default:\r\n case SupportStepID.System: {\r\n return React.createElement(System, null);\r\n }\r\n case SupportStepID.SheetedSolution: {\r\n return React.createElement(SheetedSolution, null);\r\n }\r\n }\r\n case StepID.Type:\r\n return React.createElement(Type, null);\r\n case StepID.Conditions:\r\n switch (state.conditionStep) {\r\n default:\r\n case ConditionStepID.ProblematicGround:\r\n return React.createElement(ProblematicGround, null);\r\n case ConditionStepID.SoilType:\r\n return React.createElement(SoilTypes, null);\r\n case ConditionStepID.GroundWater:\r\n return React.createElement(Groundwater, null);\r\n case ConditionStepID.GroundWaterDepth:\r\n return React.createElement(GroundwaterDepth, null);\r\n }\r\n case StepID.Surcharges:\r\n switch (state.surchargeStep) {\r\n default:\r\n case SurchargeStepID.LargeSurcharge:\r\n return React.createElement(LargeSurcharges, null);\r\n case SurchargeStepID.SlopingGround:\r\n return React.createElement(SlopingGround, null);\r\n case SurchargeStepID.AdjacentWater:\r\n return React.createElement(AdjacentWater, null);\r\n case SurchargeStepID.ZoneOfInfluence:\r\n return React.createElement(SurchargeDetails, null);\r\n }\r\n case StepID.Solutions: {\r\n if (state.loadingResults) {\r\n return React.createElement(Loading, null);\r\n }\r\n if (state.tab === Tab.YourSolution) {\r\n if (state.results !== undefined && state.results?.successful === false) {\r\n return React.createElement(NoSolutions, null);\r\n }\r\n return React.createElement(Solutions, null);\r\n }\r\n else {\r\n if (state.yspResults !== undefined && !state.yspResults?.success) {\r\n return React.createElement(\"h1\", null, \"API needs implementing for this\");\r\n }\r\n return React.createElement(YSPSolutions, null);\r\n }\r\n }\r\n case StepID.SelectedSolution: {\r\n if (state.loadingResults || !state.selectedSolution) {\r\n return React.createElement(Loading, null);\r\n }\r\n return React.createElement(Summary, null);\r\n }\r\n // YourSolution+ //\r\n case StepID.TermsAndConditions:\r\n return React.createElement(TermsAndConditions, null);\r\n case StepID.SoilsGroundConditions:\r\n switch (state.soilGroundConditionsStep) {\r\n default:\r\n case SoilGroundConditionsStepID.SoilProfiles:\r\n return React.createElement(SoilProfiles, null);\r\n case SoilGroundConditionsStepID.SoilInformationSource:\r\n return React.createElement(SoilSource, null);\r\n case SoilGroundConditionsStepID.Groundwater:\r\n return React.createElement(Groundwater, null);\r\n case SoilGroundConditionsStepID.GroundwaterDepth:\r\n return React.createElement(GroundwaterDepth, null);\r\n }\r\n }\r\n };\r\n return (React.createElement(AnimatePresence, { exitBeforeEnter: true },\r\n React.createElement(\"div\", { style: { height: '100%' }, \r\n // Need to have a unique key for every step to help Framer track new components - excuse the horrible long key but it's needed! //\r\n key: state.loading\r\n ? 'YourSolution_LoadingSpinner'\r\n : `YourSolution_Step_${state.step}_${state.conditionStep}_${state.supportStep}_${state.surchargeStep}_${state.dimensionsStep}_${state.soilGroundConditionsStep}_${state.loading}_${state.loadingResults}` }, getComponent())));\r\n};\r\nexport default StepRouter;\r\n","var _defs, _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgYspBg(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 1920,\n height: 1080\n }, props), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"clipPath\", {\n id: \"ysp-bg_svg__a\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Rectangle 68\",\n transform: \"translate(-11478 -8295.74)\",\n fill: \"#fff\",\n d: \"M0 0h1920v1080H0z\"\n })))), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Mask Group 9\",\n transform: \"translate(11478 8295.74)\",\n opacity: 0.1,\n clipPath: \"url(#ysp-bg_svg__a)\"\n }, /*#__PURE__*/React.createElement(\"image\", {\n \"data-name\": \"MicrosoftTeams-image (3)\",\n width: 2130,\n height: 1458,\n transform: \"translate(-10831 -8001.74)\",\n xlinkHref: \"\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"139a51757a2782164683c2ddb721a145.svg\";\nexport { SvgYspBg as ReactComponent };","var _g;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgRestart(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 20.14 19.982\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 31\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 55\",\n d: \"M4.198 2.562H1.5a.4.4 0 01-.459-.411.4.4 0 01.458-.412h4.07a.976.976 0 01.014.11v4a.4.4 0 01-.337.426.405.405 0 01-.462-.259.708.708 0 01-.024-.223V3.244l-.056-.037c-.341.333-.7.647-1.018 1a8.471 8.471 0 00-2.2 5.166 8.653 8.653 0 006.085 8.892 8.663 8.663 0 0010.814-5.7 8.65 8.65 0 00-6.444-11.037 16.234 16.234 0 00-1.776-.2c-.3-.028-.47-.168-.462-.433s.179-.394.475-.4a9.493 9.493 0 019.1 7 9.508 9.508 0 01-5.688 11.326 9.458 9.458 0 01-4.013.643 9.5 9.5 0 01-8.494-6.563A9.478 9.478 0 014.012 2.722c.054-.039.101-.084.186-.16z\"\n }))));\n}\n\nexport default __webpack_public_path__ + \"584a50326be0fcfee3fbdc9834b37087.svg\";\nexport { SvgRestart as ReactComponent };","import brand from '@helpers/brand';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport BackgroundImageSVG from '@img/ysp/ysp-bg.svg';\r\nimport { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { StepID } from './Context/types';\r\nconst Container = styled.section `\r\n --ysp-steps-height: 15px;\r\n --ysp-footer-height: 60px;\r\n --ysp-footer-height-mobile: 50px;\r\n\r\n font-size: 16px;\r\n\r\n ${({ step }) => {\r\n switch (step) {\r\n default:\r\n return css `\r\n --ysp-header-height: 170px;\r\n --ysp-header-close: 0px;\r\n `;\r\n case StepID.TermsAndConditions:\r\n return css `\r\n --ysp-header-height: 115px;\r\n --ysp-header-close: 0px;\r\n `;\r\n case StepID.Landing:\r\n return css `\r\n --ysp-header-height: 115px;\r\n --ysp-header-close: 55px;\r\n `;\r\n }\r\n}}\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n --ysp-header-height: 170px;\r\n --ysp-header-close: 0px;\r\n }\r\n\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: ${brand.white};\r\n z-index: 8002;\r\n`;\r\nconst Header = styled.div `\r\n min-height: calc(var(--ysp-header-height) + var(--ysp-header-close));\r\n max-height: calc(var(--ysp-header-height) + var(--ysp-header-close));\r\n`;\r\nconst MainHeaderContentWrapper = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n },\r\n visible: {\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n height: var(--ysp-header-height);\r\n display: flex;\r\n flex-direction: column;\r\n gap: 15px;\r\n\r\n img {\r\n user-select: none;\r\n margin: 0px auto;\r\n max-width: 225px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n max-width: 350px;\r\n }\r\n }\r\n`;\r\nconst ModalInner = styled(m.div) `\r\n height: calc(\r\n 100dvh - var(--ysp-header-height) - var(--ysp-header-close) - var(--ysp-footer-height-mobile)\r\n );\r\n @media ${from(Device.TabletLarge)} {\r\n height: calc(100dvh - var(--ysp-header-height) - var(--ysp-header-close));\r\n }\r\n\r\n padding: 10px;\r\n position: relative;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 20px;\r\n }\r\n`;\r\nconst ModalHeader = styled.div `\r\n position: relative;\r\n padding: 0 30px 0 0;\r\n display: flex;\r\n flex-direction: column;\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 0 30px;\r\n }\r\n\r\n img {\r\n width: 100%;\r\n max-width: 307px;\r\n margin: 0 auto 0 0;\r\n display: block;\r\n flex: 0 0 auto;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin: 0 auto;\r\n }\r\n }\r\n`;\r\nconst Content = styled.div `\r\n height: calc(\r\n 100dvh - var(--ysp-footer-height-mobile) - var(--ysp-header-height) - var(--ysp-header-close)\r\n );\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n height: calc(\r\n 100dvh - var(--ysp-footer-height) - var(--ysp-header-height) - var(--ysp-header-close) - 40px\r\n );\r\n padding: 20px 0px;\r\n }\r\n overflow-y: auto;\r\n z-index: ${({ soilModalOpen }) => (soilModalOpen ? 200 : 101)};\r\n position: relative;\r\n\r\n ${({ locked }) => locked &&\r\n css `\r\n overflow-y: hidden;\r\n `}\r\n\r\n /* width */\r\n &::-webkit-scrollbar {\r\n width: 8px;\r\n }\r\n\r\n /* Track */\r\n &::-webkit-scrollbar-track {\r\n background: ${brand.white};\r\n }\r\n\r\n /* Handle */\r\n &::-webkit-scrollbar-thumb {\r\n background: ${brand.primary.light};\r\n border-radius: 10px;\r\n }\r\n\r\n [data-ys-root='true'] & {\r\n &::after {\r\n content: '';\r\n position: fixed;\r\n bottom: var(--ysp-footer-height);\r\n left: 0;\r\n width: 100%;\r\n height: 25px;\r\n background: rgb(255, 255, 255);\r\n background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);\r\n z-index: 1;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n height: 40px;\r\n bottom: var(--ysp-footer-height-mobile);\r\n }\r\n }\r\n\r\n &::before {\r\n content: '';\r\n position: fixed;\r\n top: calc(var(--ysp-header-height) + var(--ysp-header-close) - 15px);\r\n left: 0;\r\n height: 25px;\r\n width: 100%;\r\n background: rgb(255, 255, 255);\r\n background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);\r\n z-index: 2;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n height: 40px;\r\n }\r\n }\r\n }\r\n`;\r\nconst BackgroundImage = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n y: 50,\r\n x: 50,\r\n opacity: 0,\r\n },\r\n visible: {\r\n y: 0,\r\n x: 0,\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 1,\r\n },\r\n})) `\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-image: url(${BackgroundImageSVG});\r\n background-position: right bottom;\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n z-index: -1;\r\n`;\r\nconst MobileHeader = styled.div `\r\n display: flex;\r\n justify-content: space-between;\r\n max-height: 97px;\r\n position: relative;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n padding: 0px 15px;\r\n }\r\n\r\n svg:first-of-type {\r\n margin: 0;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n justify-content: center;\r\n }\r\n`;\r\nconst Close = styled.div `\r\n width: 20px;\r\n display: flex;\r\n align-items: center;\r\n cursor: pointer;\r\n\r\n svg {\r\n width: 100%;\r\n }\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n position: absolute;\r\n top: 50%;\r\n transform: translateY(-50%);\r\n right: 20px;\r\n }\r\n`;\r\nconst Image = styled.img `\r\n height: 100%;\r\n object-fit: contain;\r\n`;\r\nexport const YourSolutionStyles = {\r\n Container,\r\n ModalInner,\r\n ModalHeader,\r\n Content,\r\n BackgroundImage,\r\n Header,\r\n MainHeaderContentWrapper,\r\n MobileHeader,\r\n Close,\r\n Image,\r\n};\r\n","import brand from '@helpers/brand';\r\nimport { fonts } from '@helpers/fonts';\r\nimport { Device, from } from '@helpers/media';\r\nimport { m } from 'framer-motion';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n position: absolute;\r\n bottom: 30px;\r\n left: 30px;\r\n z-index: 102;\r\n display: none;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: block;\r\n bottom: 50px;\r\n left: 100px;\r\n }\r\n`;\r\nconst Content = styled.div `\r\n display: flex;\r\n flex-direction: column;\r\n`;\r\nconst Return = styled(m.div).attrs(() => ({\r\n whileHover: 'hover',\r\n})) `\r\n display: flex;\r\n align-items: center;\r\n color: ${brand.primary.alt};\r\n gap: 10px;\r\n ${fonts.DaxPro.Bold};\r\n font-size: 18px;\r\n cursor: pointer;\r\n\r\n svg {\r\n width: 10px;\r\n height: 100%;\r\n display: block;\r\n transform: rotate(180deg);\r\n }\r\n`;\r\nconst Arrow = styled(m.div).attrs(() => ({\r\n variants: {\r\n hover: {\r\n x: -10,\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) ``;\r\nexport const BackToMainSiteStyles = {\r\n Container,\r\n Content,\r\n Return,\r\n Arrow,\r\n};\r\n","import React from 'react';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { BackToMainSiteStyles as S } from './BackToMainSite.styles';\r\nimport { ReactComponent as Chevron } from '@img/icons/chevron-right.svg';\r\nimport { isSSR } from '@helpers/ssr';\r\nconst BackToMainSite = ({ closeModal }) => {\r\n const { state } = useYSPContext();\r\n if (!state.labels) {\r\n return React.createElement(React.Fragment, null);\r\n }\r\n return (React.createElement(S.Container, null,\r\n React.createElement(S.Content, null,\r\n React.createElement(S.Return, { onClick: () => (!isSSR() && closeModal ? closeModal() : window.history.back()) },\r\n React.createElement(S.Arrow, null,\r\n React.createElement(Chevron, null)),\r\n state.labels['return-to-main-site'] || 'Return to Main Site'))));\r\n};\r\nexport default BackToMainSite;\r\n","var _path;\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from \"react\";\n\nfunction SvgHome(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n stroke: \"currentColor\",\n fill: \"currentColor\",\n strokeWidth: 0,\n viewBox: \"0 0 1024 1024\",\n height: \"1em\",\n width: \"1em\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M946.5 505L534.6 93.4a31.93 31.93 0 00-45.2 0L77.5 505c-12 12-18.8 28.3-18.8 45.3 0 35.3 28.7 64 64 64h43.4V908c0 17.7 14.3 32 32 32H448V716h112v224h265.9c17.7 0 32-14.3 32-32V614.3h43.4c17 0 33.3-6.7 45.3-18.8 24.9-25 24.9-65.5-.1-90.5z\",\n stroke: \"none\"\n })));\n}\n\nexport default __webpack_public_path__ + \"9f393ad707c50361b72cfe54da59b017.svg\";\nexport { SvgHome as ReactComponent };","import React from 'react';\r\nimport { StepFooterStyles as S } from './StepFooter.styles';\r\nimport { ReactComponent as Chevron } from '@img/icons/chevron-right.svg';\r\nimport { ReactComponent as Restart } from '@img/icons/restart.svg';\r\nimport { ReactComponent as Home } from '@img/ysp/home.svg';\r\nimport { StepID, Tab } from '@ys/Context/types';\r\nimport { AnimatePresence } from 'framer-motion';\r\nconst StepFooter = ({ state, dispatch }) => {\r\n const nextStep = () => {\r\n if (state.stepFooter.beforeNext !== undefined) {\r\n state.stepFooter.beforeNext();\r\n }\r\n dispatch({ type: 'next-step' });\r\n };\r\n const previousStep = () => {\r\n dispatch({ type: 'previous-step' });\r\n };\r\n const restart = () => dispatch({ type: 'restart' });\r\n const isLoadingSolutions = (state.step === StepID.Solutions || state.step === StepID.SelectedSolution) &&\r\n (state.loading || state.loadingResults);\r\n const isNotOnYSSolutions = state.tab === Tab.YourSolution ? state.step !== StepID.Solutions : true;\r\n const hasYSPSolutions = state.tab === Tab.YourSolutionPlus && state.step === StepID.Solutions\r\n ? state.yspResults?.solutions !== undefined\r\n : true;\r\n return (React.createElement(S.Container, { zoomModalOpen: state.zoomModalOpen, isLandingPage: state.step === StepID.Landing },\r\n React.createElement(AnimatePresence, null,\r\n state.labels['back'] && state.step > StepID.Landing && (React.createElement(S.ButtonMotionWrapper, { key: 'BackButton' },\r\n React.createElement(S.Button, { type: \"button\", prev: true, footerPrevious: true, onClick: previousStep, disabled: state.modal !== undefined },\r\n state.labels['back'],\r\n React.createElement(Chevron, null)))),\r\n state.labels['next'] &&\r\n isNotOnYSSolutions &&\r\n state.step !== StepID.TermsAndConditions &&\r\n state.step !== StepID.SelectedSolution &&\r\n !isLoadingSolutions &&\r\n hasYSPSolutions && (React.createElement(S.ButtonMotionWrapper, { key: 'NextButton' },\r\n React.createElement(S.Button, { type: \"button\", disabled: state.stepFooter.nextDisabled || state.modal !== undefined, next: true, footerNext: true, onClick: nextStep },\r\n state.labels['next'],\r\n React.createElement(Chevron, null)))),\r\n state.labels['next'] && state.mobile && state.step === StepID.TermsAndConditions && (React.createElement(S.ButtonMotionWrapper, { key: 'NextButton' },\r\n React.createElement(S.Button, { type: \"button\", disabled: state.stepFooter.nextDisabled, next: true, footerNext: true, onClick: nextStep },\r\n state.labels['accept'] || 'Accept',\r\n React.createElement(Chevron, null)))),\r\n state.tab === Tab.YourSolution && state.step === StepID.Solutions && (React.createElement(S.ButtonMotionWrapper, { key: 'NextButton' },\r\n React.createElement(S.Button, { type: \"button\", footerNext: true, restart: true, onClick: restart, disabled: state.modal !== undefined },\r\n \"Restart\",\r\n React.createElement(Restart, null)))),\r\n !state.loadingResults &&\r\n state.tab === Tab.YourSolutionPlus &&\r\n state.selectedSolution &&\r\n state.step === StepID.SelectedSolution && (React.createElement(S.ButtonMotionWrapper, { key: 'NextButton' },\r\n React.createElement(\"a\", { href: state.technicalLibraryUrl },\r\n React.createElement(S.Button, { type: \"button\", footerNext: true, restart: true },\r\n \"Main Site\",\r\n React.createElement(Home, null))))))));\r\n};\r\nexport default StepFooter;\r\n","export default __webpack_public_path__ + \"aea83c7e45005da5d398d5bd7df79b0a.png\";","export default __webpack_public_path__ + \"8061c02a7291f35015d014eaed8b7e7d.png\";","import brand from '@helpers/brand';\r\nimport styled, { css } from 'styled-components';\r\nimport { Tab as TabEnum } from '@ys/Context/types';\r\nimport { m } from 'framer-motion';\r\nimport { Device, from, until } from '@helpers/media';\r\nconst Container = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n },\r\n visible: {\r\n height: 'var(--ysp-header-height)',\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n width: 100%;\r\n overflow: hidden;\r\n\r\n display: grid;\r\n grid-template-columns: 1fr 1fr;\r\n`;\r\nconst Tab = styled.div `\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n cursor: pointer;\r\n position: relative;\r\n background-color: ${brand.grey.grey89};\r\n\r\n img {\r\n user-select: none;\r\n z-index: 2;\r\n width: 160px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n width: 300px;\r\n }\r\n }\r\n`;\r\nconst BottomLine = styled(m.div) `\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n z-index: 0;\r\n width: 100%;\r\n height: 100%;\r\n\r\n border-bottom: 3px solid ${brand.primary.alt};\r\n`;\r\nconst BackgroundEffect = styled(m.div) `\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n border-top: 3px solid ${brand.primary.alt};\r\n background-color: ${brand.white};\r\n z-index: 1 !important;\r\n\r\n ${({ tab }) => tab === TabEnum.YourSolution\r\n ? css `\r\n border-right: 3px solid ${brand.primary.alt};\r\n `\r\n : css `\r\n border-left: 3px solid ${brand.primary.alt};\r\n `}\r\n`;\r\nconst BackToMainSiteMobile = styled(m.div).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n height: 0,\r\n },\r\n visible: {\r\n height: 'var(--ysp-header-close)',\r\n },\r\n },\r\n transition: {\r\n duration: 0.5,\r\n },\r\n})) `\r\n overflow: hidden;\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n cursor: pointer;\r\n padding: 10px;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n display: none;\r\n }\r\n\r\n svg {\r\n &:first-of-type {\r\n // Logo //\r\n width: 200px;\r\n }\r\n &:last-of-type {\r\n // Close //\r\n width: 20px;\r\n }\r\n }\r\n`;\r\nconst Image = styled.img `\r\n height: 100%;\r\n object-fit: contain;\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n max-width: 75%;\r\n }\r\n`;\r\nexport const TabsStyles = {\r\n Container,\r\n Tab,\r\n BackgroundEffect,\r\n BottomLine,\r\n BackToMainSiteMobile,\r\n Image,\r\n};\r\n","import { ReactComponent as Close } from '@img/ysp/icon-cross.svg';\r\nimport YSLogoNoText from '@img/ysp/ys-no-strapline.png';\r\nimport YSLogo from '@img/ysp/ys-strapline.png';\r\nimport YSPLogo from '@img/ysp/ysp-header-logo-crop.png';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport { Tab } from '@ys/Context/types';\r\nimport { AnimateSharedLayout } from 'framer-motion';\r\nimport React from 'react';\r\nimport { TabsStyles as S } from './Tabs.styles';\r\nconst Tabs = (props) => {\r\n const { state, dispatch } = useYSPContext();\r\n return (React.createElement(React.Fragment, null,\r\n React.createElement(S.BackToMainSiteMobile, null,\r\n state.tab === Tab.YourSolution ? (React.createElement(S.Image, { src: YSLogoNoText })) : (React.createElement(S.Image, { src: YSPLogo })),\r\n React.createElement(Close, { onClick: () => props.closeModal && props.closeModal() })),\r\n React.createElement(S.Container, null,\r\n React.createElement(AnimateSharedLayout, null,\r\n React.createElement(S.Tab, { onClick: () => dispatch({ type: 'set-tab', payload: Tab.YourSolution }) },\r\n state.mobile ? React.createElement(S.Image, { src: YSLogoNoText }) : React.createElement(S.Image, { src: YSLogo }),\r\n state.tab === Tab.YourSolution && (React.createElement(S.BackgroundEffect, { layoutId: \"background-effect\", tab: Tab.YourSolution })),\r\n React.createElement(S.BottomLine, null)),\r\n React.createElement(S.Tab, { onClick: () => dispatch({ type: 'set-tab', payload: Tab.YourSolutionPlus }) },\r\n state.mobile ? React.createElement(S.Image, { src: YSPLogo }) : React.createElement(S.Image, { src: YSPLogo }),\r\n state.tab === Tab.YourSolutionPlus && (React.createElement(S.BackgroundEffect, { layoutId: \"background-effect\", tab: Tab.YourSolutionPlus })),\r\n React.createElement(S.BottomLine, null))))));\r\n};\r\nexport default Tabs;\r\n","import ApiService from '@core/api/services/ApiService';\r\nimport { Device, until } from '@helpers/media';\r\nimport { withMotionMax } from '@hoc/withMotionMax';\r\nimport useMedia from '@hooks/useMedia';\r\nimport { ReactComponent as Close } from '@img/ysp/icon-cross.svg';\r\nimport YSLogo from '@img/ysp/ys-no-strapline.png';\r\nimport YSPLogo from '@img/ysp/ysp-header-logo.png';\r\nimport { useYSPContext } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport Modal from '@ys/Components/Modal/Modal';\r\nimport StepHeader from '@ys/Components/StepHeader/StepHeader';\r\nimport StepPicker from '@ys/Components/StepPicker/StepPicker';\r\nimport StepRouter from '@ys/Components/StepRouter/StepRouter';\r\nimport { YourSolutionStyles as S } from '@ys/YourSolution.styles';\r\nimport { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock';\r\nimport { AnimatePresence } from 'framer-motion';\r\nimport React, { useEffect, useLayoutEffect, useRef } from 'react';\r\nimport BackToMainSite from './Components/BackToMainSite/BackToMainSite';\r\nimport StepFooter from './Components/StepFooter/StepFooter';\r\nimport Tabs from './Components/Tabs/Tabs';\r\nimport { DimensionsStepID, SoilGroundConditionsStepID, StepID, Tab, } from './Context/types';\r\nimport { MediaComponent } from '@helpers/mediaComponent';\r\nconst YourSolution = (props) => {\r\n const { state, ...rest } = useYSPContext();\r\n const stateRef = useRef(state);\r\n const modal = useRef(null);\r\n const scrollableArea = useRef(null);\r\n const modalScrollable = useRef(null);\r\n const modalKey = JSON.stringify(state.modal);\r\n const isMobile = useMedia([until(Device.TabletLarge)], [true], false);\r\n React.useEffect(() => {\r\n const parsed = new URLSearchParams(window.location.search);\r\n if (parsed.get('tab') === 'ysp') {\r\n rest.dispatch({ type: 'set-tab', payload: Tab.YourSolutionPlus });\r\n }\r\n }, []);\r\n useEffect(() => {\r\n // I have no idea what that body-scroll-lock thing does, but it doesn't work on iOS at all. //\r\n // It seems to add 'position: fixed' to the body element which just breaks tons of stuff. //\r\n // Surely just lock the body at 100vh height and disable overflow? //\r\n // The package also seems unmaintained since 2 years ago, so I'm just going to do that, which works. //\r\n const bodyElement = document.querySelector('body');\r\n if (bodyElement) {\r\n let existingStyleAttribute = bodyElement.getAttribute('style') || '';\r\n existingStyleAttribute += ' max-height: 100vh; overflow: hidden';\r\n bodyElement.setAttribute('style', existingStyleAttribute);\r\n }\r\n return function () {\r\n const bodyElement = document.querySelector('body');\r\n if (bodyElement) {\r\n let existingStyleAttribute = bodyElement.getAttribute('style') || '';\r\n existingStyleAttribute = existingStyleAttribute.replace('max-height: 100vh; overflow: hidden', '');\r\n bodyElement.setAttribute('style', existingStyleAttribute);\r\n }\r\n };\r\n }, []);\r\n useEffect(() => {\r\n stateRef.current = state;\r\n }, [state]);\r\n const handleUnload = async () => {\r\n // Ensure user has at least progressed past the location step so we have contact details & postcode //\r\n if (stateRef.current.form.postCode !== undefined &&\r\n stateRef.current.step !== StepID.SelectedSolution) {\r\n const controllerName = stateRef.current.tab === Tab.YourSolution ? 'ISM' : 'YSP';\r\n let stepId = stateRef.current.step;\r\n if (stateRef.current.tab === Tab.YourSolutionPlus) {\r\n switch (stepId) {\r\n case StepID.TermsAndConditions:\r\n stepId = StepID.Landing; // Landing step returns Terms & Conditions content //\r\n break;\r\n case StepID.Dimensions:\r\n switch (stateRef.current.dimensionsStep) {\r\n case DimensionsStepID.EndSafePanels:\r\n case DimensionsStepID.EndSafeSides:\r\n stepId = 5;\r\n break;\r\n default:\r\n case DimensionsStepID.Size:\r\n break;\r\n }\r\n break;\r\n case StepID.SoilsGroundConditions:\r\n switch (state.soilGroundConditionsStep) {\r\n case SoilGroundConditionsStepID.SoilInformationSource:\r\n stepId = 7;\r\n break;\r\n case SoilGroundConditionsStepID.Groundwater:\r\n case SoilGroundConditionsStepID.GroundwaterDepth:\r\n stepId = 8;\r\n break;\r\n default:\r\n case SoilGroundConditionsStepID.SoilProfiles:\r\n stepId = 6;\r\n break;\r\n }\r\n break;\r\n case StepID.Surcharges:\r\n stepId = 9;\r\n break;\r\n case StepID.Solutions:\r\n stepId = 10;\r\n break;\r\n default:\r\n case StepID.Landing:\r\n case StepID.Details:\r\n case StepID.Location:\r\n case StepID.Depth:\r\n break;\r\n }\r\n }\r\n await ApiService.request({\r\n controller: controllerName,\r\n slug: 'partial-submit',\r\n method: 'POST',\r\n params: {\r\n ...stateRef.current.form,\r\n lastStep: stepId,\r\n },\r\n });\r\n }\r\n };\r\n useEffect(() => {\r\n window.addEventListener('beforeunload', handleUnload);\r\n return () => window.removeEventListener('beforeunload', handleUnload);\r\n }, []);\r\n useEffect(() => {\r\n rest.dispatch({ type: 'set-mobile', payload: isMobile });\r\n }, [isMobile]);\r\n useLayoutEffect(() => {\r\n if (!modalScrollable.current) {\r\n return;\r\n }\r\n if (!state.modal) {\r\n enableBodyScroll(modalScrollable.current);\r\n }\r\n else {\r\n disableBodyScroll(modalScrollable.current);\r\n }\r\n // Clear all locks when ISM component is unmounted.\r\n return () => {\r\n if (!modalScrollable.current) {\r\n return;\r\n }\r\n enableBodyScroll(modalScrollable.current);\r\n };\r\n }, [modalKey]);\r\n return (React.createElement(S.Container, { ...props, step: state.step, ref: modal },\r\n React.createElement(S.Header, null,\r\n React.createElement(AnimatePresence, { exitBeforeEnter: true }, state.step === StepID.Landing ? (React.createElement(Tabs, { key: \"tabs\", closeModal: props.closeModal })) : (React.createElement(S.MainHeaderContentWrapper, { key: \"header\" },\r\n React.createElement(StepHeader, null),\r\n React.createElement(S.MobileHeader, null,\r\n state.tab === Tab.YourSolution ? (React.createElement(S.Image, { src: YSLogo })) : (React.createElement(S.Image, { src: YSPLogo })),\r\n React.createElement(S.Close, { onClick: () => props.closeModal && props.closeModal() },\r\n React.createElement(Close, null))),\r\n state.step !== StepID.TermsAndConditions && React.createElement(StepPicker, null))))),\r\n React.createElement(S.ModalInner, null,\r\n React.createElement(S.Content, { isLandingPage: state.step === StepID.Landing, locked: state.scrollLocked, ref: scrollableArea, soilModalOpen: state.soilModalOpen },\r\n React.createElement(StepRouter, { state: state, ...rest })),\r\n React.createElement(AnimatePresence, null, state.tab === Tab.YourSolutionPlus && React.createElement(S.BackgroundImage, null))),\r\n React.createElement(AnimatePresence, null, state.modal !== undefined && (React.createElement(Modal, { key: `YourSolution_Modal`, modal: state.modal, modalScrollable: modalScrollable }))),\r\n React.createElement(AnimatePresence, null,\r\n React.createElement(MediaComponent, { mobile: true },\r\n React.createElement(StepFooter, { key: \"StepFooter\", state: state, ...rest })),\r\n React.createElement(MediaComponent, { desktop: true },\r\n state.step === StepID.Landing && (React.createElement(BackToMainSite, { closeModal: props.closeModal, key: \"BackToMainSite\" })),\r\n state.step > StepID.Landing && React.createElement(StepFooter, { key: \"StepFooter\", state: state, ...rest })))));\r\n};\r\nexport default withMotionMax(YourSolution);\r\n","import { HydrateOption } from '@core/enums';\r\nimport { isSSR } from '@helpers/ssr';\r\nimport withWidget from '@hoc/withWidget';\r\nimport { YSContextProvider } from '@stories/Widgets/YourSolution/YS/Context/YSContext';\r\nimport React from 'react';\r\nimport YourSolution from './YourSolution';\r\nconst YourSolutionRoot = (props) => {\r\n return (React.createElement(YSContextProvider, { ...props },\r\n React.createElement(YourSolution, { closeModal: () => !isSSR() && window.history.back(), ...props })));\r\n};\r\nexport default withWidget(YourSolutionRoot, 'YourSolutionRoot', { hydrate: HydrateOption.Always });\r\n","import React, { useEffect, useState } from 'react';\r\nimport { LoaderStyles } from './Loader.styles';\r\nconst Loader = (props) => {\r\n const [showLoader, setShowLoader] = useState(props.delay === undefined);\r\n useEffect(() => {\r\n if (!props.delay) {\r\n return;\r\n }\r\n const handle = setTimeout(() => setShowLoader(true), props.delay);\r\n return () => window.clearTimeout(handle);\r\n }, []);\r\n if (!showLoader) {\r\n return null;\r\n }\r\n const Loader = (React.createElement(LoaderStyles.Wrapper, null,\r\n React.createElement(LoaderStyles.Loader, null)));\r\n if (props.container === true) {\r\n return (React.createElement(LoaderStyles.Container, null,\r\n React.createElement(LoaderStyles.ContainerInner, null, Loader)));\r\n }\r\n return Loader;\r\n};\r\nexport default Loader;\r\n","import { Cloudinary } from '@cloudinary/base';\r\nimport { format, quality } from '@cloudinary/base/actions/delivery';\r\nimport { fit } from '@cloudinary/base/actions/resize';\r\nimport { audioCodec } from '@cloudinary/base/actions/transcode';\r\nimport { auto as fAuto } from '@cloudinary/base/qualifiers/format';\r\nimport { auto as qAuto } from '@cloudinary/base/qualifiers/quality';\r\nconst cl = new Cloudinary({\r\n cloud: {\r\n cloudName: 'vp-groundforce',\r\n },\r\n url: {\r\n secure: true,\r\n },\r\n});\r\nexport function imageUrl(publicId, rawTransformation) {\r\n if (!publicId) {\r\n return '';\r\n }\r\n const image = cl.image(publicId);\r\n // Apply raw transformation.\r\n if (rawTransformation) {\r\n image.addTransformation(rawTransformation);\r\n }\r\n // Ensure we're specifying a format...\r\n if (containsFormatTransformation(rawTransformation)) {\r\n return image.toURL();\r\n }\r\n // ...otherwise serve with \"f_auto\" for WebP support.\r\n return image.delivery(format(fAuto())).delivery(quality(qAuto())).toURL();\r\n}\r\nexport function videoUrl(publicId, options = {}) {\r\n if (!publicId) {\r\n return '';\r\n }\r\n let video = cl.video(publicId);\r\n // Apply resize.\r\n if (options.aspectRatio || options.width) {\r\n let resize = fit();\r\n if (options.aspectRatio) {\r\n resize = resize.aspectRatio(options.aspectRatio);\r\n }\r\n if (options.width) {\r\n resize = resize.width(options.width);\r\n }\r\n video = video.resize(resize);\r\n }\r\n // Apply transcale (remove audio).\r\n if (options.audioCodec) {\r\n video = video.transcode(audioCodec(options.audioCodec));\r\n }\r\n // Apply format.\r\n if (options.format) {\r\n video = video.delivery(format(options.format));\r\n }\r\n return video.toURL();\r\n}\r\n// eslint-disable-next-line no-useless-escape\r\nconst FormatRegEx = /(\\/|\\,)(f_.*?)(\\/|\\,)/;\r\nfunction containsFormatTransformation(transformation) {\r\n return !!transformation && FormatRegEx.test(transformation);\r\n}\r\n","import { m } from 'framer-motion';\r\nimport styled, { css } from 'styled-components';\r\nimport { WYSIWYGStyles } from '@ys/Components/Shared.styles';\r\nimport { Device, from } from '@helpers/media';\r\nconst MotionBase = styled(m.section).attrs(() => ({\r\n initial: 'hidden',\r\n animate: 'visible',\r\n exit: 'hidden',\r\n variants: {\r\n hidden: {\r\n opacity: 0,\r\n },\r\n visible: {\r\n opacity: 1,\r\n },\r\n },\r\n transition: {\r\n duration: 0.35,\r\n },\r\n})) ``;\r\n// Unified interface to add a grid layout to the steps //\r\nconst Grid = styled(MotionBase) `\r\n width: 100%;\r\n margin: auto;\r\n height: 100%;\r\n\r\n max-width: 92vw;\r\n @media ${from(Device.TabletLarge)} {\r\n max-width: 75vw;\r\n }\r\n\r\n ${({ centered }) => centered &&\r\n css `\r\n place-items: center center;\r\n `}\r\n\r\n display: grid;\r\n grid-template-columns: repeat(12, 1fr);\r\n\r\n ${WYSIWYGStyles};\r\n`;\r\nconst FullWidth = styled.div `\r\n grid-column: 1 / -1;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n padding-bottom: 35px;\r\n }\r\n`;\r\nconst Default = styled.div `\r\n grid-column: 2 / 12;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-column: 3 / 11;\r\n padding-bottom: 35px;\r\n }\r\n`;\r\nconst Thin = styled.div `\r\n grid-column: 1 / -1;\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-column: 4 / 10;\r\n padding-bottom: 35px;\r\n }\r\n`;\r\nconst Wide = styled.div `\r\n grid-column: 2 / 12;\r\n padding-bottom: 35px;\r\n`;\r\nexport const StepStyles = {\r\n Grid,\r\n};\r\nexport const Containers = {\r\n FullWidth,\r\n Default,\r\n Thin,\r\n Wide,\r\n};\r\n","import { css } from 'styled-components';\r\n/**\r\n * Show only for screen readers.\r\n * @description Sourced from https://gist.github.com/ffoodd/000b59f431e3e64e4ce1a24d5bb36034\r\n */\r\nconst srOnly = css `\r\n border: 0 !important;\r\n clip: rect(1px, 1px, 1px, 1px) !important;\r\n -webkit-clip-path: inset(50%) !important;\r\n clip-path: inset(50%) !important;\r\n height: 1px !important;\r\n margin: -1px !important;\r\n overflow: hidden !important;\r\n padding: 0 !important;\r\n position: absolute !important;\r\n width: 1px !important;\r\n white-space: nowrap !important;\r\n`;\r\nexport default srOnly;\r\n"],"sourceRoot":""}