{"version":3,"sources":["assets/images/dealer-mini-site-bg-2x.png","assets/images/Mobile_dealer-mini-site-bg.png","assets/images/cash-offer.jpg","assets/images/financing.jpg","assets/images/listing.jpg","assets/images/ATV_type.png","assets/images/Side X Side.png","assets/images/boat.png","assets/images/car.png","assets/images/motorcycle.png","assets/images/personalwatercraft.png","assets/images/rv.png","assets/images/snowmobile.png","assets/images/trailer-icon.png","assets/images/CareersImgs/Cafe.png","assets/images/CareersImgs/CompanyCulture.png","assets/images/CareersImgs/CoreValues.png","assets/images/CareersImgs/Development.png","assets/images/CareersImgs/ExpressAllBlack.png","assets/images/CareersImgs/Health.png","assets/images/CareersImgs/PTO.png","assets/images/CareersImgs/Pet.png","assets/images/CareersImgs/Refer.png","assets/images/CareersImgs/RideNowAllBlack.png","assets/images/CareersImgs/RumbleOnAllBlack.png","assets/images/CareersImgs/SliderImage1.png","assets/images/CareersImgs/SliderImage2.png","assets/images/CareersImgs/SliderImage3.png","assets/images/CareersImgs/SliderImage4.png","assets/images/CareersImgs/locations.png","assets/images/RN_Insurance_Progressive_HERO_v3.jpg","assets/images/TradeIn.svg","assets/images/liveAuctionBg2x.jpg","assets/images/mapicon.png","assets/images/next-white.png","assets/images/rumbleon_finance.png","assets/images/web_hero-section-bg.jpg","assets/images/NADA_JDPower_Logo1.png","assets/images/how-to-step-1-photo.jpg","assets/images/boat-marines.png","assets/images/how-to-step-3-photo.jpg","assets/images/how-to-step-2-photo.jpg","assets/images sync /^/.*$","assets/images/JDPowerLogo.png","assets/images/Minutes.svg","assets/images/NADA-Logo.png","assets/images/Rates.svg","assets/images/RumbleOn_Finance.svg","assets/images/View Payment _ TXU Energy Aug_2020.pdf","assets/images/atv.png","assets/images/call-24px.svg","assets/images/chevron_right-24px.svg","assets/images/hero-image-cash-offer.jpg","assets/images/large-Web_LiveAuction.png","assets/images/large-trailer-icon.png","assets/images/live auctions.png","assets/images/liveAuctionBg.jpg","assets/images/location_on-24px.svg","assets/images/mileage.svg","assets/images/mobile_hero-section-bg.jpg","assets/images/mobile_hero-section-bg@2x.jpg","assets/images/mobile_live-auction-bg.jpg","assets/images/mobile_live-auction-bg@2x.jpg","assets/images/mobile_live-auction-bg@3x.jpg","assets/images/mobile_live-auction-bg@4x.jpg","assets/images/mobile_vin-entry-purple-bg.png","assets/images/open_in_new-24px.svg","assets/images/palette-24px.svg","assets/images/share-24px.svg","assets/images/star-24px.svg","assets/images/star_outline-24px.svg","assets/images/textsms-24px.svg","assets/images/trailer-icon-resized.png","assets/images/truck.png","assets/images/visibility-24px.svg","assets/images/web-cash-offer-bg-asset-v2.png","assets/images/web_atv-vin-location-1.jpg","assets/images/web_atv-vin-location-2.jpg","assets/images/web_car-vin-location-1.jpg","assets/images/web_car-vin-location-2.jpg","assets/images/web_hero-section-bg@2x.jpg","assets/images/web_motorcycle-vin-location-1.jpg","assets/images/web_motorcycle-vin-location-2.jpg","assets/images/whatshot-24px.svg","components/how-to/components/Header.tsx","Modals/CashOfferVideoModal.tsx","components/how-to/components/HowItWorks.tsx","components/how-to/components/Testimonies.tsx","components/how-to/components/Ratings.tsx","components/how-to/components/VinDecoder.tsx","components/how-to/components/StepOneBlock.tsx","components/how-to/components/StepThreeBlock.tsx","components/how-to/components/StepTwoBlock.tsx","components/how-to/components/VinDecoderBlocks.tsx","components/how-to/components/VinDecoderMobile.tsx","Modals/components/FIndYourVinCategory.tsx","Modals/components/VinInfoOptions.tsx","Modals/FindYourVINModal.tsx","components/how-to/how-to.tsx","components/how-to/index.tsx","components/UI/CustomButton.tsx","components/UI/CustomInput.tsx","components/UI/CustomDropDown.tsx","assets/images/cash-offer-bg.jpg","assets/images/web_vin-entry-purple-bg.png","assets/images/how-to-step-1-photo-sm.jpg","assets/images/how-to-step-2-photo-sm.jpg","assets/images/how-to-step-3-photo-sm.jpg","assets/images/track-offer-automotive.jpg","assets/images/track-offer-powersports.jpg","assets/images/web-hero-image-cash-offer.jpg","assets/images/mobile-hero-cash-offer.jpg","components/CashOfferPage/components/VinDecoderComponent.tsx"],"names":["module","exports","map","webpackContext","req","id","webpackContextResolve","__webpack_require__","o","e","Error","code","keys","Object","resolve","vehicleTypeText","truck","motorcycle","car","atv","generic","jd","buttonCss","Header","dispatch","useModalFlowDispatch","useState","timer","setTimer","setloading","type","setType","history","useHistory","url","window","location","pathname","state","dealerBrand","queryString","parseUrl","search","query","utm_source","useEffect","refresh","replace","reload","typeFromParam","split","includes","toLowerCase","interval","setInterval","length","clearInterval","css","src","JDPower","HeroBgList","jdpower","path","HeroBg","renderDealerBrandedHeroBg","gutter","minMedia","xs","md","href","colors","darkBlack","maxMedia","VinDecoderComponent","extraTextCss","lightGreen","onClick","args","showFindYourVINModal","theme","style","width","height","objectFit","textAlign","CashOfferVideoModal","useModalFlowState","React","playing","setPlaying","showCashOfferVideoModal","visible","closable","footer","onCancel","destroyOnClose","autoPlay","controls","HowItWorks","breakpoints","mid","justify","align","span","size","icon","Testimonies","disabled","defaultValue","target","rel","Ratings","allowHalf","color","dots","slidesToShow","arrows","background","create","form","vin","setVin","onSubmit","preventDefault","push","currentVin","Item","getFieldDecorator","initialValue","normalize","v","toUpperCase","rules","len","max","maxLength","placeholder","onChange","value","block","htmlType","StepOneBlock","console","log","text","lg","StepOneMarineBg","StepOneBg","join","scroll","StepThreeBlock","StepThreeBg","StepTwoBlock","StepTwoBg","VinDecoderBlocks","extra","FIndYourVinCategory","data","label","require","rightText","leftText","VinInfoOptions","FindYourVINModal","title","className","sm","dotsClass","Categories","category","i","key","SellInfo","property","content","header","CustomButton","filled","children","props","bgColor","darkCharcoal","textColor","BlueLinkButton","blue","FloatingLabelInput","forwardRef","_ref","isPassword","autoFocus","extraCss","focus","setFocus","ref","useRef","current","input","superLightGray","lightCharcoal","onBlur","onFocus","Password","FloatingLabelTextArea","textAreaRef","TextArea","CustomDropDown","placeHolder","active","setActive","selected","setDropDownSelected","handleClickOutside","contains","document","addEventListener","removeEventListener","textGrey","lightGrey","cloneElement","CustomDropDownRender","memo","hover","render","CustomSelect","suffixIcon","fontSize","paddingRight","rcSelect","VALIDATION_RULES","required","message","pattern","ErrorMessage","error","failedCount","description","showIcon","banner","ERROR_MESSAGE","beingAppraised","backgroundColor","padding","marginBottom","textDecoration","inputTipCss","SubmitVinBanner","useCashOfferContext","handleSubmit","validateFields","RESET_STATE","DecoderBanner","offset","xl","Search","getFieldValue","setFieldsValue","onSearch","_value","_","enterButton","purple","name","listingId","useDetailsFlowState","authState","useAuthPopupState","setFailCount","finished","setFinished","loading","decodeRequest","createRequest","trade","parse","parseBooleans","Year","setYear","Make","setMake","fetching","setFetching","undefined","useApolloClient","model","make","fetchOffers","fetchOffers1","fetchOffers2","yearList","setyearList","MakeList","setMakeList","ModelList","setModelList","a","environmentVariableList","VINLESS_ES_URL","REACT_MARINEVINLESS_ES_LINK","REACT_MARINEVINLESS_ES_APP","fetch","method","headers","Authorization","REACT_ES_BASIC_AUTH","body","JSON","stringify","aggs","terms","field","response","json","result","aggregations","buckets","match","sort","bool","must","term","ModelName","payload","fetchOffers3","ModelId","ModelType","ItemTypeId","Bike","VIN","Model","Id","SourceTypeId","AppraisalStatusId","GoogleCLID","CurrentStepNo","TradeForItemId","Decoder","ItemYear","CategoryName","MarketingCategory","COEntryTypeId","REACT_APP_CW_CASH_OFFER","Headers","Accept","ModelTrimId","trimResponse","trimResult","Marine","Series","ModelTrimID","dealerBrandType","BeamInches","HullMaterial","Brakes","Marines_Brakes","LengthInches","HorsePower","HP","NumEngines","Weight","Weights","SET_DEALER_BRAND","decodeVin","SET_DECODE_REQUEST","ok","statusText","fetchFailed","responseText","SET_COENTRY","SET_DECODE_DATA","SET_CURRENT_STEP","errorMessage","default","requestFailed","limitExceeded","SET_ERROR","count","handleScroll","scrollTo","decodeData","nextStep","historyState","renewOffer","renewData","params","exclude","isLoggedIn","RESET_ERROR","SET_CREATE_REQUEST","Message","appraisalRefNo","AppraisalRefNo","Category","SellItemMarine","LicensePlate","Models","SellItemBike","SET_APPRAISAL_REF","hideRequiredMark","colon","getFieldError","validateTrigger","b","Option","startCase","toUpper"],"mappings":"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","file":"static/js/16.9620e06b.chunk.js","sourcesContent":["module.exports = __webpack_public_path__ + \"static/media/dealer-mini-site-bg-2x.364ae142.png\";","module.exports = __webpack_public_path__ + \"static/media/Mobile_dealer-mini-site-bg.25ea745e.png\";","module.exports = __webpack_public_path__ + \"static/media/cash-offer.d01b4c43.jpg\";","module.exports = __webpack_public_path__ + \"static/media/financing.4a9ad8ca.jpg\";","module.exports = __webpack_public_path__ + \"static/media/listing.5e6408d0.jpg\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/CompanyCulture.1df81887.png\";","module.exports = __webpack_public_path__ + \"static/media/CoreValues.b0212900.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/ExpressAllBlack.3fdc3b7a.png\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/RideNowAllBlack.f577261f.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/SliderImage1.f184bc41.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImage2.0ea858e6.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImage3.771efcdf.png\";","module.exports = __webpack_public_path__ + \"static/media/SliderImage4.fcd08283.png\";","module.exports = __webpack_public_path__ + \"static/media/locations.da742a35.png\";","module.exports = __webpack_public_path__ + \"static/media/RN_Insurance_Progressive_HERO_v3.5494441e.jpg\";","module.exports = __webpack_public_path__ + \"static/media/TradeIn.129a1241.svg\";","module.exports = __webpack_public_path__ + \"static/media/liveAuctionBg2x.b108b0c4.jpg\";","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/rumbleon_finance.03220eae.png\";","module.exports = __webpack_public_path__ + \"static/media/web_hero-section-bg.e88bc2a6.jpg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/how-to-step-1-photo.78c187b3.jpg\";","module.exports = __webpack_public_path__ + \"static/media/boat-marines.96713155.png\";","module.exports = __webpack_public_path__ + \"static/media/how-to-step-3-photo.f6460fed.jpg\";","module.exports = __webpack_public_path__ + \"static/media/how-to-step-2-photo.0ee82944.jpg\";","var map = {\n\t\"./ATV_type.png\": 1089,\n\t\"./CareersImgs/Cafe.png\": 1100,\n\t\"./CareersImgs/CompanyCulture.png\": 1101,\n\t\"./CareersImgs/CoreValues.png\": 1102,\n\t\"./CareersImgs/Development.png\": 1103,\n\t\"./CareersImgs/ExpressAllBlack.png\": 1104,\n\t\"./CareersImgs/Health.png\": 1105,\n\t\"./CareersImgs/PTO.png\": 1106,\n\t\"./CareersImgs/Pet.png\": 1107,\n\t\"./CareersImgs/Refer.png\": 1108,\n\t\"./CareersImgs/RideNowAllBlack.png\": 1109,\n\t\"./CareersImgs/RumbleOnAllBlack.png\": 1110,\n\t\"./CareersImgs/SliderImage1.png\": 1111,\n\t\"./CareersImgs/SliderImage2.png\": 1112,\n\t\"./CareersImgs/SliderImage3.png\": 1113,\n\t\"./CareersImgs/SliderImage4.png\": 1114,\n\t\"./CareersImgs/locations.png\": 1115,\n\t\"./JDPowerLogo.png\": 1345,\n\t\"./Minutes.svg\": 1346,\n\t\"./Mobile_dealer-mini-site-bg.png\": 1011,\n\t\"./NADA-Logo.png\": 1347,\n\t\"./NADA_JDPower_Logo1.png\": 1174,\n\t\"./RN_Insurance_Progressive_HERO_v3.jpg\": 1116,\n\t\"./Rates.svg\": 1348,\n\t\"./RumbleOn_Finance.svg\": 1349,\n\t\"./Side X Side.png\": 1090,\n\t\"./TradeIn.svg\": 1117,\n\t\"./View Payment _ TXU Energy Aug_2020.pdf\": 1350,\n\t\"./atv.png\": 1351,\n\t\"./boat-marines.png\": 1176,\n\t\"./boat.png\": 1091,\n\t\"./call-24px.svg\": 1352,\n\t\"./car.png\": 1092,\n\t\"./cash-offer-bg.jpg\": 875,\n\t\"./cash-offer.jpg\": 1015,\n\t\"./chevron_right-24px.svg\": 1353,\n\t\"./dealer-mini-site-bg-2x.png\": 1010,\n\t\"./financing.jpg\": 1016,\n\t\"./hero-image-cash-offer.jpg\": 1354,\n\t\"./how-to-step-1-photo-sm.jpg\": 913,\n\t\"./how-to-step-1-photo.jpg\": 1175,\n\t\"./how-to-step-2-photo-sm.jpg\": 914,\n\t\"./how-to-step-2-photo.jpg\": 1178,\n\t\"./how-to-step-3-photo-sm.jpg\": 915,\n\t\"./how-to-step-3-photo.jpg\": 1177,\n\t\"./large-Web_LiveAuction.png\": 1355,\n\t\"./large-trailer-icon.png\": 1356,\n\t\"./listing.jpg\": 1017,\n\t\"./live auctions.png\": 1357,\n\t\"./liveAuctionBg.jpg\": 1358,\n\t\"./liveAuctionBg2x.jpg\": 1118,\n\t\"./location_on-24px.svg\": 1359,\n\t\"./maintenance_page_2x.png\": 385,\n\t\"./maintenance_page_mobile.png\": 386,\n\t\"./mapicon.png\": 1119,\n\t\"./mileage.svg\": 1360,\n\t\"./mobile-hero-cash-offer.jpg\": 919,\n\t\"./mobile_hero-section-bg.jpg\": 1361,\n\t\"./mobile_hero-section-bg@2x.jpg\": 1362,\n\t\"./mobile_live-auction-bg.jpg\": 1363,\n\t\"./mobile_live-auction-bg@2x.jpg\": 1364,\n\t\"./mobile_live-auction-bg@3x.jpg\": 1365,\n\t\"./mobile_live-auction-bg@4x.jpg\": 1366,\n\t\"./mobile_vin-entry-purple-bg.png\": 1367,\n\t\"./motorcycle.png\": 1093,\n\t\"./next-white.png\": 1120,\n\t\"./open_in_new-24px.svg\": 1368,\n\t\"./palette-24px.svg\": 1369,\n\t\"./personalwatercraft.png\": 1094,\n\t\"./rumbleon_finance.png\": 1121,\n\t\"./rv.png\": 1095,\n\t\"./share-24px.svg\": 1370,\n\t\"./snowmobile.png\": 1096,\n\t\"./star-24px.svg\": 1371,\n\t\"./star_outline-24px.svg\": 1372,\n\t\"./textsms-24px.svg\": 1373,\n\t\"./track-offer-automotive.jpg\": 916,\n\t\"./track-offer-powersports.jpg\": 917,\n\t\"./trailer-icon-resized.png\": 1374,\n\t\"./trailer-icon.png\": 1097,\n\t\"./truck.png\": 1375,\n\t\"./visibility-24px.svg\": 1376,\n\t\"./web-cash-offer-bg-asset-v2.png\": 1377,\n\t\"./web-hero-image-cash-offer.jpg\": 918,\n\t\"./web_atv-vin-location-1.jpg\": 1378,\n\t\"./web_atv-vin-location-2.jpg\": 1379,\n\t\"./web_car-vin-location-1.jpg\": 1380,\n\t\"./web_car-vin-location-2.jpg\": 1381,\n\t\"./web_hero-section-bg.jpg\": 1173,\n\t\"./web_hero-section-bg@2x.jpg\": 1382,\n\t\"./web_motorcycle-vin-location-1.jpg\": 1383,\n\t\"./web_motorcycle-vin-location-2.jpg\": 1384,\n\t\"./web_vin-entry-purple-bg.png\": 902,\n\t\"./whatshot-24px.svg\": 1385\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 1179;","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/Minutes.31f4769d.svg\";","module.exports = __webpack_public_path__ + \"static/media/NADA-Logo.c92606de.png\";","module.exports = __webpack_public_path__ + \"static/media/Rates.bdc3b4df.svg\";","module.exports = __webpack_public_path__ + \"static/media/RumbleOn_Finance.5de3147d.svg\";","module.exports = __webpack_public_path__ + \"static/media/View Payment _ TXU Energy Aug_2020.c450b996.pdf\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/call-24px.c4c5213c.svg\";","module.exports = __webpack_public_path__ + \"static/media/chevron_right-24px.bf24bd79.svg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/large-Web_LiveAuction.641b2f08.png\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/live auctions.641b2f08.png\";","module.exports = __webpack_public_path__ + \"static/media/liveAuctionBg.6051c0f5.jpg\";","module.exports = __webpack_public_path__ + \"static/media/location_on-24px.b741fbf9.svg\";","module.exports = __webpack_public_path__ + \"static/media/mileage.562b0978.svg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/mobile_hero-section-bg@2x.70ffffc0.jpg\";","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/mobile_live-auction-bg@2x.e6cca8c0.jpg\";","module.exports = __webpack_public_path__ + \"static/media/mobile_live-auction-bg@3x.db712300.jpg\";","module.exports = __webpack_public_path__ + \"static/media/mobile_live-auction-bg@4x.49a93482.jpg\";","module.exports = __webpack_public_path__ + \"static/media/mobile_vin-entry-purple-bg.dadddc9e.png\";","module.exports = __webpack_public_path__ + \"static/media/open_in_new-24px.3cdee7ab.svg\";","module.exports = __webpack_public_path__ + \"static/media/palette-24px.460fea0a.svg\";","module.exports = __webpack_public_path__ + \"static/media/share-24px.73c2a70b.svg\";","module.exports = __webpack_public_path__ + \"static/media/star-24px.17d52911.svg\";","module.exports = __webpack_public_path__ + \"static/media/star_outline-24px.1352fd55.svg\";","module.exports = __webpack_public_path__ + \"static/media/textsms-24px.1479796b.svg\";","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/visibility-24px.641061ff.svg\";","module.exports = __webpack_public_path__ + \"static/media/web-cash-offer-bg-asset-v2.78d6a6a0.png\";","module.exports = __webpack_public_path__ + \"static/media/web_atv-vin-location-1.28fa7405.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_atv-vin-location-2.9d282db3.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_car-vin-location-1.37842f6c.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_car-vin-location-2.cf693af4.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_hero-section-bg@2x.46a53957.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_motorcycle-vin-location-1.8fd1642f.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_motorcycle-vin-location-2.4ac8e151.jpg\";","module.exports = __webpack_public_path__ + \"static/media/whatshot-24px.def9ce8d.svg\";","import { Col, Divider, Icon, Row } from \"antd\";\r\nimport React, { useEffect, useState } from \"react\";\r\nimport { colors, maxMedia, minMedia } from \"../../../constants/styles\";\r\nimport { useParams, useHistory } from 'react-router-dom';\r\nimport HeroBg from \"../../../assets/images/web_hero-section-bg.jpg\";\r\nimport HeroBgList from \"../../../utils/heroBgList.json\";\r\nimport JDPower from \"../../../assets/images/NADA_JDPower_Logo1.png\";\r\nimport JDPowerLogo from \"../../../assets/images/JDPowerLogo.png\";\r\nimport NADALogo from \"../../../assets/images/NADA-Logo.png\";\r\nimport VinDecoderComponent from \"../../CashOfferPage/components/VinDecoderComponent\";\r\nimport { css } from \"@emotion/core\";\r\nimport queryString from \"query-string\";\r\nimport { useModalFlowDispatch } from \"../../../context/ModalContext\";\r\n\r\nexport const vehicleTypeText: any = {\r\n truck: [\"Chevy\", \"Dodge\", \"Jeep\", \"Ford\"],\r\n motorcycle: [\"Harley Davidson\", \"Yamaha\", \"Honda\", \"Indian\", \"Kawasaki\"],\r\n car: [\"Exotics\", \"Classics\", \"Collectors\"],\r\n atv: [\"Polaris\", \"Can-Am\", \"Kawasaki\", \"Honda\"],\r\n generic: [\r\n \"motorcycle\",\r\n \"ATV\",\r\n \"side-by-side\",\r\n \"SUV\",\r\n \"Truck\",\r\n \"RV\",\r\n \"trailer\",\r\n ],\r\n jd: [\"motorcycle\", \"ATV\", \"side-by-side\", \"RV\", \"trailer\"],\r\n};\r\n\r\nconst Header = () => {\r\n const dispatch = useModalFlowDispatch();\r\n const [timer, setTimer] = useState(0);\r\n const [loading, setloading] = useState(false);\r\n const [type, setType] = useState(\"generic\");\r\n const history = useHistory();\r\n const url = window.location.pathname;\r\n const { state } = history.location;\r\n\r\n const dealerBrand = queryString.parseUrl(window.location.search).query\r\n ?.utm_source;\r\n useEffect(() => {\r\n // console.log(\"refresh::::\", state?.refresh)\r\n if (state?.refresh === true) {\r\n // Ã¥console.log(\"history.location::::\", history.location)\r\n delete state.refresh;\r\n history.replace({ ...history.location, state: { refresh: false } });\r\n window.location.reload();\r\n setloading(true)\r\n }\r\n else {\r\n setloading(false)\r\n }\r\n }, []);\r\n useEffect(() => {\r\n const typeFromParam =\r\n dealerBrand === \"jdpower\" ? \"jd\" : url?.split(\"/\")[2].split(\"-\")[2] || \"\";\r\n Object.keys(vehicleTypeText).includes(typeFromParam.toLowerCase()) &&\r\n setType(typeFromParam);\r\n\r\n const interval = setInterval(() => {\r\n setTimer((timer) => {\r\n return timer === vehicleTypeText[type].length - 1 ? 0 : timer + 1;\r\n });\r\n }, 2000);\r\n return () => clearInterval(interval);\r\n }, [type]);\r\n\r\n const renderDealerBrandedHeroBg = () => {\r\n switch (dealerBrand) {\r\n case \"jdpower\":\r\n return HeroBgList.jdpower.path;\r\n\r\n default:\r\n return HeroBg;\r\n }\r\n };\r\n\r\n const renderVehicleTypes = () => {\r\n if (type === \"car\") {\r\n vehicleTypeText[type] = [\"Car\", \"Exotics\", \"Classics\", \"Collectors\"];\r\n }\r\n if (window.location.href.includes(\"boat\")) {\r\n vehicleTypeText[type] = [\"MotorBoat\", \"Watercraft\", \"Speedboat\"];\r\n }\r\n\r\n return (\r\n <h3\r\n css={css`\r\n background: #85ce06;\r\n color: ${colors.darkBlack} !important;\r\n text-transform: uppercase;\r\n width: fit-content;\r\n padding: 0 0.5rem;\r\n ${maxMedia[1]} {\r\n margin: auto !important;\r\n }\r\n `}\r\n >\r\n {vehicleTypeText[type][timer]}\r\n </h3>\r\n );\r\n };\r\n\r\n const handleShowFindYourVINModal = () => {\r\n dispatch({\r\n type: \"SHOW_FIND_YOUR_VIN_MODAL\",\r\n args: {\r\n showFindYourVINModal: true,\r\n },\r\n });\r\n };\r\n\r\n return (\r\n <>\r\n {dealerBrand === \"jdpower\" && (\r\n <Row\r\n css={css`\r\n display: flex;\r\n align-items: center;\r\n height: 65px;\r\n padding: 1%;\r\n background: #ffffff;\r\n display: none;\r\n @media (max-width: 786px) {\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n }\r\n `}\r\n >\r\n <img\r\n src={JDPower}\r\n css={css`\r\n width: max-content;\r\n height: 3rem;\r\n `}\r\n />\r\n </Row>\r\n )}\r\n\r\n <div\r\n css={css`\r\n background-image: url(${renderDealerBrandedHeroBg()});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: left;\r\n min-height: 484px;\r\n\r\n ::before {\r\n content: \"\";\r\n position: absolute;\r\n /* top: 0; */\r\n /* left: 0; */\r\n width: 100%;\r\n max-width: 1800px !important;\r\n height: ${dealerBrand === \"jdpower\" ? \"100%\" : \"486px\"};\r\n background-image: linear-gradient(0deg, #ffffff, gray);\r\n opacity: ${dealerBrand === \"jdpower\" ? 0.8 : 0};\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n }\r\n\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n min-height: 350px !important;\r\n\r\n ::before {\r\n /* height: 350px; */\r\n opacity: ${dealerBrand === \"jdpower\" ? 0.6 : 0};\r\n }\r\n }\r\n `}\r\n >\r\n <Row\r\n gutter={32}\r\n css={css`\r\n display: flex;\r\n flex-direction: column;\r\n min-height: 484px;\r\n ${minMedia[1]} {\r\n flex-direction: row;\r\n padding: 2% 10%;\r\n /* padding: ${dealerBrand === \"jdpower\"\r\n } ? 2% : 2% 10% !important; */\r\n }\r\n\r\n @media (min-width: 1300px) {\r\n padding: ${dealerBrand === \"jdpower\"} ? 2% 10% : 20%;\r\n /* padding-right: ${dealerBrand === \"jdpower\"\r\n } ? 0% : 20% !important; */\r\n /* padding-bottom: 0; */\r\n /* padding-right: 2%; */\r\n }\r\n @media (max-width: 990px) {\r\n height: 100%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n align-self: center;\r\n }\r\n `}\r\n >\r\n {/* {dealerBrand && (\r\n <Col\r\n xs={24}\r\n md={8}\r\n css={css`\r\n display: none !important;\r\n @media (max-width: 786px) {\r\n display: flex !important;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n }\r\n `}\r\n >\r\n <img\r\n src={NADALogo}\r\n style={{\r\n width: \"60%\",\r\n height: \"60%\",\r\n objectFit: \"contain\",\r\n textAlign: \"center\",\r\n }}\r\n />\r\n </Col>\r\n )} */}\r\n\r\n <Col\r\n xs={24}\r\n md={dealerBrand === \"jdpower\" ? 8 : 12}\r\n css={css`\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n font-size: 16px;\r\n font-weight: bold !important;\r\n font-family: interstate;\r\n height: 100%;\r\n /* padding: 2%; */\r\n h3 {\r\n font-weight: bold !important;\r\n margin-bottom: 0;\r\n color: white;\r\n font-size: 35px;\r\n }\r\n h1 {\r\n font-weight: bold !important;\r\n margin-bottom: 0;\r\n color: white;\r\n font-size: 35px;\r\n }\r\n\r\n ${minMedia[2]} {\r\n align-self: center;\r\n align-items: flex-start;\r\n text-align: left;\r\n justify-content: center !important;\r\n height: 100%;\r\n }\r\n `}\r\n >\r\n <h3>SELL YOUR</h3>\r\n {renderVehicleTypes()}\r\n <h3>FOR CASH</h3>\r\n <Divider />\r\n <span\r\n css={css`\r\n h3 {\r\n font-size: 2rem;\r\n font-weight: bold !important;\r\n font-family: interstate;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n h3 {\r\n font-size: 22px !important;\r\n // color: black;\r\n }\r\n }\r\n `}\r\n >\r\n <h3>YOU TAKE THE CASH,</h3>\r\n <h3>WE'LL HANDLE THE</h3>\r\n <h3>VEHICLE.</h3>\r\n </span>\r\n </Col>\r\n\r\n <Col xs={24} md={dealerBrand === \"jdpower\" ? 10 : 12}>\r\n <Row\r\n css={css`\r\n background: white;\r\n ${minMedia[1]} {\r\n background: black;\r\n border-radius: 4px;\r\n padding: 2rem 1rem 0;\r\n height: 100%;\r\n width: 100% h3 {\r\n font-size: 20px;\r\n padding-bottom: 1rem;\r\n font-family: interstate;\r\n font-weight: bold;\r\n }\r\n }\r\n `}\r\n >\r\n <Row\r\n css={css`\r\n padding: 1rem 2% 2%;\r\n h3 {\r\n color: black;\r\n font-size: 20px;\r\n font-weight: bold;\r\n padding-bottom: 1rem;\r\n }\r\n ${minMedia[1]} {\r\n h3 {\r\n color: white;\r\n }\r\n }\r\n `}\r\n >\r\n {window.location.href.includes(\"vehicle\") && (\r\n <Row>\r\n <h3>ENTER YOUR VIN TO GET YOUR OFFER</h3>\r\n </Row>\r\n )}\r\n <VinDecoderComponent\r\n extraTextCss={css`\r\n ${minMedia[1]} {\r\n color: white;\r\n }\r\n `}\r\n />\r\n {window.location.href.includes(\"vehicle\") && (\r\n <Row>\r\n <button\r\n css={css`\r\n font-size: 14px;\r\n font-weight: normal;\r\n color: ${colors.lightGreen};\r\n margin-top: 0.5rem;\r\n ${buttonCss}\r\n `}\r\n onClick={handleShowFindYourVINModal}\r\n >\r\n <Icon type=\"question-circle\" theme=\"outlined\" /> Where is\r\n my VIN?\r\n </button>\r\n </Row>\r\n )}\r\n </Row>\r\n </Row>\r\n </Col>\r\n\r\n {dealerBrand === \"jdpower\" && (\r\n <Col\r\n xs={24}\r\n md={8}\r\n css={css`\r\n display: flex !important;\r\n justify-content: center;\r\n align-items: center;\r\n text-align: center;\r\n @media (max-width: 786px) {\r\n display: none !important;\r\n }\r\n `}\r\n >\r\n <img\r\n src={JDPower}\r\n style={{\r\n width: \"100%\",\r\n height: \"100%\",\r\n objectFit: \"contain\",\r\n textAlign: \"center\",\r\n }}\r\n />\r\n </Col>\r\n )}\r\n </Row>\r\n </div>\r\n </>\r\n );\r\n};\r\n\r\nconst buttonCss = css`\r\n border: 0;\r\n background: transparent;\r\n padding: 0;\r\n cursor: pointer;\r\n`;\r\n\r\nexport default Header;","import {\r\n useModalFlowDispatch,\r\n useModalFlowState,\r\n} from \"../context/ModalContext\";\r\n\r\nimport { Modal } from \"antd\";\r\nimport React from \"react\";\r\nimport ReactPlayer from \"react-player\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst CashOfferVideoModal: React.FC = () => {\r\n const dispatch = useModalFlowDispatch();\r\n const state = useModalFlowState();\r\n\r\n const [playing, setPlaying] = React.useState(true);\r\n const { showCashOfferVideoModal } = state;\r\n return (\r\n <div>\r\n <Modal\r\n visible={showCashOfferVideoModal}\r\n closable\r\n footer={null}\r\n css={css`\r\n .ant-modal-close-x {\r\n width: 34px;\r\n height: 34px;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n }\r\n .ant-modal-body {\r\n padding: 1.75rem;\r\n }\r\n `}\r\n onCancel={() => {\r\n setPlaying(false);\r\n // console.log(playing);\r\n dispatch({\r\n type: \"HIDE_ACCEPT_OFFER_SUCCESS_MODAL\",\r\n args: {\r\n showCashOfferVideoModal: false,\r\n },\r\n });\r\n }}\r\n destroyOnClose\r\n >\r\n <ReactPlayer\r\n // src={\"\"}\r\n url={\"https://www.youtube.com/watch?v=_ueYIYCwhr4&feature=emb_title\"}\r\n autoPlay={false}\r\n playing={playing}\r\n controls={true}\r\n width={\"100%\"}\r\n height={\"300px\"}\r\n >\r\n {/* <source\r\n src={\r\n \"https://www.youtube.com/watch?v=_ueYIYCwhr4&feature=emb_title\"\r\n }\r\n /> */}\r\n </ReactPlayer>\r\n </Modal>\r\n </div>\r\n );\r\n};\r\n\r\nexport default CashOfferVideoModal;\r\n","import { Button, Col, Icon, Row } from \"antd\";\r\nimport { Ratings, VinDecoderBlocks } from \".\";\r\n\r\nimport CashOfferVideoModal from \"../../../Modals/CashOfferVideoModal\";\r\nimport React from \"react\";\r\nimport VinDecoderMobile from \"./VinDecoderMobile\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport { useModalFlowDispatch } from \"../../../context/ModalContext\";\r\n\r\nconst HowItWorks: React.FC = () => {\r\n const dispatch = useModalFlowDispatch();\r\n\r\n const handleShowCashOfferVideo = () => {\r\n dispatch({\r\n type: \"SHOW_CASH_OFFER_VIDEO_MODAL\",\r\n args: {\r\n showCashOfferVideoModal: true,\r\n },\r\n });\r\n };\r\n\r\n return (\r\n <div\r\n css={css`\r\n padding: 2% 10%;\r\n background: white;\r\n // h3 {\r\n // font-weight: bold !important;\r\n // margin-bottom: 0;\r\n // color: white;\r\n // }\r\n @media (max-width: ${breakpoints.mid}) {\r\n padding: 2% 10%;\r\n }\r\n @media (min-width: 1300px) {\r\n padding: 2% 20%;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n padding: 0;\r\n }\r\n `}\r\n >\r\n <Row\r\n type=\"flex\"\r\n justify=\"center\"\r\n align=\"middle\"\r\n css={css`\r\n text-align: center;\r\n h3 {\r\n font-family: interstate;\r\n font-weight: bold;\r\n font-size: 35px !important;\r\n }\r\n button {\r\n width: auto;\r\n min-width: 30%;\r\n border: 1px solid gray;\r\n font-size: 14px;\r\n &:hover {\r\n border: 1px solid gray;\r\n }\r\n }\r\n @media (max-width: ${breakpoints.md}) {\r\n padding: 2%;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n h3 {\r\n font-size: 20px !important;\r\n }\r\n }\r\n `}\r\n >\r\n <Col span={24}>\r\n <h3>HOW IT WORKS</h3>\r\n </Col>\r\n\r\n {!window.location.href.includes(\"/how-to/sell-your-boat\") && (\r\n <Col span={24}>\r\n <Button\r\n type=\"ghost\"\r\n size=\"large\"\r\n icon=\"\"\r\n onClick={handleShowCashOfferVideo}\r\n >\r\n <Icon type=\"play-circle\" theme=\"filled\" />\r\n Watch how it works\r\n </Button>\r\n </Col>\r\n )}\r\n\r\n <Col span={24}>\r\n <VinDecoderBlocks />\r\n </Col>\r\n\r\n {/* <Col span={24}>\r\n <Ratings />\r\n </Col> */}\r\n </Row>\r\n <CashOfferVideoModal />\r\n </div>\r\n );\r\n};\r\n\r\nexport default HowItWorks;\r\n","import { Col, Rate, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst Testimonies: React.FC = () => {\r\n return (\r\n // <div style={{ height: \"160px\", display: \"flex\", flexDirection: \"column\" }}>\r\n <Row>\r\n <Col\r\n span={8}\r\n css={css`\r\n text-align: justify;\r\n padding: 0 11%;\r\n padding-right: 0;\r\n height: 150px;\r\n // border-right: 1px solid gray;\r\n h3 {\r\n font-family: aktiv-grotesk;\r\n font-size: 16px;\r\n\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n }\r\n h4 {\r\n font-family: aktiv-grotesk;\r\n font-size: 14px;\r\n font-weight: normal;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n }\r\n p {\r\n font-family: aktiv-grotesk;\r\n font-weight: normal;\r\n color: #1b51cf;\r\n cursor: pointer;\r\n position: absolute;\r\n bottom: 0;\r\n }\r\n @media (max-width: 990px) {\r\n font-size: 14px !important;\r\n padding-left: 2%;\r\n padding-right: 2%;\r\n h3 {\r\n font-family: aktiv-grotesk;\r\n font-size: 14px !important;\r\n\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n }\r\n h4 {\r\n font-family: aktiv-grotesk;\r\n font-size: 14px;\r\n font-weight: normal;\r\n margin-bottom: 0;\r\n }\r\n }\r\n // @media (max-width: 786px) {\r\n // font-size: 14px;\r\n // padding-left: 2%;\r\n // padding-right: 2%;\r\n // }\r\n `}\r\n >\r\n <Rate\r\n css={css`\r\n font-size: 18px !important;\r\n color: #13388f;\r\n margin-bottom: 4%;\r\n svg {\r\n fill: #db7011;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 12px !important;\r\n }\r\n `}\r\n disabled\r\n defaultValue={5}\r\n />\r\n <h3>Tanner Maginnis</h3>\r\n <h4>6 months ago</h4>\r\n\r\n <a\r\n href=\"https://www.google.com/search?q=rumbleon+reviews#lrd=0x864c292bcc36ba7f:0x5fbf63d534a1cf53,1,,,\"\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n >\r\n <p>Read full review</p>\r\n </a>\r\n </Col>\r\n <Col\r\n span={16}\r\n css={css`\r\n p {\r\n font-family: aktiv-grotesk;\r\n font-size: 28px;\r\n text-align: justify;\r\n padding-left: 4%;\r\n font-weight: normal;\r\n margin-bottom: 4%;\r\n color: black;\r\n }\r\n border-left: 1px solid gray;\r\n @media (max-width: 990px) {\r\n font-size: 14px;\r\n padding-right: 4%;\r\n p {\r\n font-size: 16px;\r\n }\r\n }\r\n `}\r\n >\r\n <p>\r\n “Sold the bike to them on day one, paperwork on day two, payment in my\r\n account on day four, bike pick up on day four. Woah! …â€\r\n </p>\r\n </Col>\r\n </Row>\r\n // </div>\r\n );\r\n};\r\n\r\nexport default Testimonies;\r\n","import { Button, Carousel, Col, Divider, Pagination, Rate, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport Testimonies from \"./Testimonies\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst Ratings: React.FC = () => {\r\n return (\r\n <div\r\n css={css`\r\n text-align: center;\r\n background: #fafafa;\r\n padding: 0 20%;\r\n margin-bottom: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n padding: 0;\r\n }\r\n `}\r\n >\r\n <Row type=\"flex\" justify=\"center\" align=\"middle\">\r\n <Col span={24}>\r\n <h3\r\n css={css`\r\n font-family: interstate;\r\n font-size: 40px;\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 20px;\r\n }\r\n `}\r\n >\r\n WHAT OUR CUSTOMERS ARE SAYING\r\n </h3>\r\n </Col>\r\n\r\n <Col span={24}>\r\n <h3\r\n css={css`\r\n font-family: aktiv-grotesk;\r\n font-size: 100px;\r\n font-weight: medium;\r\n color: #13388f;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 50px;\r\n }\r\n `}\r\n >\r\n 4.8\r\n </h3>\r\n\r\n <Rate\r\n defaultValue={5}\r\n disabled\r\n allowHalf\r\n css={css`\r\n font-size: 30px !important;\r\n color: #13388f;\r\n margin-bottom: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n `}\r\n style={{\r\n color: \"#db7011\",\r\n }}\r\n />\r\n </Col>\r\n\r\n <Col>\r\n <h3\r\n css={css`\r\n font-family: aktiv-grotesk;\r\n font-size: 18px;\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n margin: 4% 0;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n `}\r\n >\r\n 500+ Customer Reviews on Google\r\n </h3>\r\n\r\n <a\r\n href=\"https://www.google.com/search?q=rumbleon+reviews#lrd=0x864c292bcc36ba7f:0x5fbf63d534a1cf53,1,,,\"\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n >\r\n <p\r\n css={css`\r\n font-family: aktiv-grotesk;\r\n font-weight: normal;\r\n color: #1b51cf;\r\n `}\r\n >\r\n See all reviews\r\n </p>\r\n </a>\r\n\r\n <Divider\r\n css={css`\r\n width: 20%;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n `}\r\n />\r\n </Col>\r\n\r\n <Col span={24}>\r\n <div>\r\n {/* <Row>\r\n <Col\r\n span={8}\r\n css={css`\r\n text-align: justify;\r\n padding: 0 11%;\r\n padding-right: 0;\r\n // border-right: 1px solid gray;\r\n h3 {\r\n font-family: aktiv-grotesk;\r\n font-size: 18px;\r\n\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n }\r\n h4 {\r\n font-family: aktiv-grotesk;\r\n font-size: 18px;\r\n font-weight: normal;\r\n margin-bottom: 0;\r\n @media (max-width: 786px) {\r\n font-size: 14px;\r\n }\r\n }\r\n @media (max-width: 990px) {\r\n font-size: 14px !important;\r\n padding-left: 2%;\r\n padding-right: 2%;\r\n h3 {\r\n font-family: aktiv-grotesk;\r\n font-size: 14px !important;\r\n\r\n font-weight: bold;\r\n margin-bottom: 0;\r\n }\r\n h4 {\r\n font-family: aktiv-grotesk;\r\n font-size: 14px;\r\n font-weight: normal;\r\n margin-bottom: 0;\r\n }\r\n }\r\n // @media (max-width: 786px) {\r\n // font-size: 14px;\r\n // padding-left: 2%;\r\n // padding-right: 2%;\r\n // }\r\n `}\r\n >\r\n <Rate\r\n css={css`\r\n font-size: 18px !important;\r\n color: #13388f;\r\n margin-bottom: 4%;\r\n svg {\r\n fill: #db7011;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 12px !important;\r\n }\r\n `}\r\n defaultValue={5}\r\n />\r\n <h3>Tanner Maginnis</h3>\r\n <h4>6 months ago</h4>\r\n </Col>\r\n <Col\r\n span={16}\r\n css={css`\r\n p {\r\n font-family: aktiv-grotesk;\r\n font-size: 28px;\r\n text-align: justify;\r\n padding-left: 4%;\r\n font-weight: normal;\r\n margin-bottom: 4%;\r\n color: black;\r\n }\r\n border-left: 1px solid gray;\r\n @media (max-width: 990px) {\r\n font-size: 14px;\r\n padding-right: 4%;\r\n p {\r\n font-size: 16px;\r\n }\r\n }\r\n `}\r\n >\r\n <p>\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day four.\r\n Woah! …â€\r\n </p>\r\n </Col>\r\n </Row> */}\r\n\r\n <Row>\r\n {/* <Col span={4}>\r\n <Button icon=\"carat\" />\r\n </Col>\r\n\r\n <Col span={4}>\r\n <div></div>\r\n </Col>\r\n\r\n <Col span={4}>\r\n <Button icon=\"carat\" />\r\n </Col> */}\r\n\r\n <Col>\r\n <Carousel\r\n dots={true}\r\n slidesToShow={1}\r\n arrows={true}\r\n css={css`\r\n // .slick-next {\r\n // right: 35% !important;\r\n // top: 85% !important;\r\n // border: 2px solid #1b51cf !important;\r\n // background: #1b51cf !important;\r\n // border-radius: 50% !important;\r\n // width: 40px !important;\r\n // height: 40px !important;\r\n // z-index: 1 !important;\r\n // text-align: center;\r\n // :hover {\r\n // background: #1b51cf !important;\r\n // }\r\n // }\r\n\r\n // .slick-prev {\r\n // left: 35% !important;\r\n // top: 85% !important;\r\n // border: 2px solid #1b51cf !important;\r\n // background: #1b51cf !important;\r\n // border-radius: 50% !important;\r\n // width: 40px !important;\r\n // height: 40px !important;\r\n // z-index: 1 !important;\r\n // text-align: center !important;\r\n // :hover {\r\n // background: #1b51cf !important;\r\n // }\r\n // }\r\n @media (max-width: 786px) {\r\n font-size: 20px;\r\n }\r\n `}\r\n style={{\r\n // height: \"160px\",\r\n color: \"#fff\",\r\n // lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"transparent\",\r\n }}\r\n >\r\n {/* <div> */}\r\n {/* <p\r\n style={{\r\n height: \"160px\",\r\n color: \"#fff\",\r\n lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"#364d79\",\r\n }}\r\n >\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day\r\n four. Woah! …â€\r\n </p> */}\r\n {/* <Testimonies /> */}\r\n {/* </div> */}\r\n\r\n {/* <div> */}\r\n {/* <p\r\n style={{\r\n // height: \"160px\",\r\n color: \"#fff\",\r\n lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"#364d79\",\r\n }}\r\n >\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day\r\n four. Woah! …â€\r\n </p> */}\r\n\r\n <Testimonies />\r\n <Testimonies />\r\n {/* </div> */}\r\n\r\n {/* <div>\r\n <p\r\n style={{\r\n height: \"160px\",\r\n color: \"#fff\",\r\n lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"#364d79\",\r\n }}\r\n >\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day\r\n four. Woah! …â€\r\n </p>\r\n </div>\r\n\r\n <div>\r\n <p\r\n style={{\r\n height: \"160px\",\r\n color: \"#fff\",\r\n lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"#364d79\",\r\n }}\r\n >\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day\r\n four. Woah! …â€\r\n </p>\r\n </div>\r\n\r\n <div>\r\n <p\r\n style={{\r\n height: \"160px\",\r\n color: \"#fff\",\r\n lineHeight: \"160px\",\r\n textAlign: \"center\",\r\n background: \"#364d79\",\r\n }}\r\n >\r\n “Sold the bike to them on day one, paperwork on day two,\r\n payment in my account on day four, bike pick up on day\r\n four. Woah! …â€\r\n </p>\r\n </div> */}\r\n </Carousel>\r\n </Col>\r\n </Row>\r\n </div>\r\n </Col>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default Ratings;\r\n","import { Button, Form, Icon, Input, Row } from \"antd\";\r\n\r\nimport { FormComponentProps } from \"antd/lib/form\";\r\nimport React from \"react\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport { useModalFlowDispatch } from \"../../../context/ModalContext\";\r\n\r\ninterface Props extends FormComponentProps {}\r\n\r\nconst VinDecoder: React.FC<Props> = ({ form }) => {\r\n const history = useHistory();\r\n const dispatch = useModalFlowDispatch();\r\n const [vin, setVin] = React.useState();\r\n\r\n const handleShowFindYourVINModal = (e: React.FormEvent) => {\r\n e.preventDefault();\r\n dispatch({\r\n type: \"SHOW_FIND_YOUR_VIN_MODAL\",\r\n args: {\r\n showFindYourVINModal: true,\r\n },\r\n });\r\n };\r\n\r\n const handleOnChange = (e: any) => {\r\n setVin(e.target.value);\r\n };\r\n\r\n const handleVinDecodeSubmit = (e: React.FormEvent) => {\r\n e.preventDefault();\r\n history.push(\"/sell\", {\r\n currentVin: vin,\r\n });\r\n };\r\n return (\r\n <div\r\n css={css`\r\n display: flex !important;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n height: 400px;\r\n @media (max-width: ${breakpoints.md}) {\r\n display: none !important;\r\n }\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <div\r\n css={css`\r\n padding: 4%;\r\n width: 100%;\r\n background: #000000;\r\n height: 100% !important;\r\n border-radius: 4px;\r\n h3 {\r\n color: white;\r\n padding: 4%;\r\n padding-left: 0;\r\n }\r\n h4 {\r\n font-size: 12px;\r\n color: white;\r\n padding: 2% 4%;\r\n }\r\n p {\r\n color: #85ce06;\r\n cursor: pointer;\r\n font-size: 14px;\r\n font-family: aktiv-grotesk;\r\n font-weight: normal;\r\n }\r\n .ant-row {\r\n margin: 2% 0;\r\n }\r\n i {\r\n margin-right: 1%;\r\n }\r\n input {\r\n height: 52px !important;\r\n }\r\n button {\r\n height: 48px;\r\n background: #9e9e9e;\r\n }\r\n font-size: 16px;\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <h3>ENTER YOUR VIN TO GET YOUR OFFER</h3>\r\n\r\n <Form onSubmit={handleVinDecodeSubmit}>\r\n <Form.Item>\r\n {form.getFieldDecorator(\"VIN\", {\r\n initialValue: vin,\r\n normalize: (v: string) =>\r\n v ? v.replace(/[iIoOqQ|\\W|\\_]/g, \"\").toUpperCase() : \"\",\r\n rules: [\r\n {\r\n len: 17,\r\n max: 17,\r\n },\r\n ],\r\n })(\r\n <Input\r\n size=\"large\"\r\n maxLength={17}\r\n placeholder=\"Your VIN\"\r\n onChange={handleOnChange}\r\n />\r\n )}\r\n </Form.Item>\r\n <h4>THE LETTER I, O AND Q ARE NOT ACCEPTED.</h4>\r\n\r\n <Button\r\n block\r\n htmlType=\"submit\"\r\n size=\"large\"\r\n type=\"primary\"\r\n // onClick={handleVinDecodeSubmit}\r\n >\r\n Get your offer\r\n </Button>\r\n </Form>\r\n\r\n <Row>\r\n <p onClick={handleShowFindYourVINModal}>\r\n <Icon type=\"question-circle\" theme=\"outlined\" /> Where is my VIN?\r\n </p>\r\n </Row>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nexport default Form.create()(VinDecoder);\r\n","import { Button, Col, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport StepOneBg from \"../../../assets/images/how-to-step-1-photo.jpg\";\r\nimport StepOneMarineBg from \"../../../assets/images/boat-marines.png\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport queryString from \"query-string\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport { vehicleTypeText } from \"./Header\";\r\n\r\nconst dealerBrand = queryString.parseUrl(window.location.search).query\r\n ?.utm_source;\r\n\r\nconst StepOneBlock: React.FC = () => {\r\n const history = useHistory();\r\n console.log(\"windowhistory\", window.location);\r\n const goToSell = () => {\r\n if (\r\n window.location.href.includes(\"jdpower\") ||\r\n window.location.href.includes(\"lawtiger\") ||\r\n window.location.href.includes(\"cycletrader\")\r\n ) {\r\n window.scroll(0, 0);\r\n } else {\r\n history.push(\"/sell\");\r\n }\r\n };\r\n\r\n const url = window.location.pathname;\r\n const typeFromParam = url?.split(\"/\")[2].split(\"-\")[2] || \"\";\r\n const text =\r\n vehicleTypeText[typeFromParam.toLowerCase()] || vehicleTypeText[\"generic\"];\r\n return (\r\n <div\r\n css={css`\r\n width: 100%;\r\n .ant-col {\r\n height: 400px !important;\r\n }\r\n // @media (max-width: ${breakpoints.md}) {\r\n // padding: 4% 16%;\r\n // }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n }\r\n `}\r\n >\r\n <Row>\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background-image: url(${window.location.href.includes(\"boat\")\r\n ? StepOneMarineBg\r\n : StepOneBg});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: center;\r\n `}\r\n ></Col>\r\n\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background: #13388f;\r\n text-align: left;\r\n padding: 4% 2%;\r\n h3 {\r\n font-family: interstate;\r\n font-weight: bold;\r\n font-size: 20px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 48px !important;\r\n }\r\n }\r\n h4 {\r\n font-family: interstate;\r\n font-weight: normal;\r\n font-size: 16px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 20px !important;\r\n }\r\n }\r\n button {\r\n border: 1px solid white;\r\n margin-top: 10%;\r\n color: white;\r\n height: 48px;\r\n &:hover {\r\n border: 1px solid white;\r\n color: white;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n }\r\n }\r\n `}\r\n >\r\n <h3>1.</h3>\r\n <h4>ENTER VEHICLE INFO</h4>\r\n <h4>\r\n You’ll answer a few questions about the condition of your{\" \"}\r\n {typeFromParam}. Sell your{\" \"}\r\n {!window.location.href.includes(\"boat\")\r\n ? typeFromParam === \"vehicle\"\r\n ? \" motorcycle, car, truck, ATV, and more.\"\r\n : text.join(\", \") + \" and more.\"\r\n : typeFromParam === \"vehicle\"\r\n ? \" Motorboat, Watercraft, Speedboat, and more.\"\r\n : text.join(\", \") + \" and more.\"}\r\n </h4>\r\n {!window.location.href.includes(\"boat\") && (\r\n <Button size=\"large\" type=\"ghost\" color=\"white\" onClick={goToSell}>\r\n Enter your VIN to begin\r\n </Button>\r\n )}\r\n </Col>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default StepOneBlock;\r\n","import { Button, Col, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport StepThreeBg from \"../../../assets/images/how-to-step-3-photo.jpg\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst StepThreeBlock: React.FC = () => {\r\n const history = useHistory();\r\n\r\n const goToSell = () => {\r\n if (\r\n window.location.href.includes(\"jdpower\") ||\r\n window.location.href.includes(\"lawtiger\") ||\r\n window.location.href.includes(\"cycletrader\")\r\n ) {\r\n window.scroll(0, 0);\r\n } else {\r\n history.push(\"/sell\");\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n css={css`\r\n width: 100%;\r\n .ant-col {\r\n height: 400px !important;\r\n }\r\n // @media (max-width: ${breakpoints.md}) {\r\n // padding: 4% 16%;\r\n // }\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <Row>\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background-image: url(${StepThreeBg});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: center;\r\n `}\r\n ></Col>\r\n\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background: #5c903f;\r\n text-align: left;\r\n padding: 4% 2%;\r\n h3 {\r\n font-family: interstate;\r\n font-weight: bold;\r\n font-size: 20px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 48px !important;\r\n }\r\n }\r\n h4 {\r\n font-family: interstate;\r\n font-weight: normal;\r\n font-size: 16px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 20px !important;\r\n }\r\n }\r\n button {\r\n border: 1px solid white;\r\n margin-top: 10%;\r\n color: white;\r\n height: 48px;\r\n &:hover {\r\n border: 1px solid white;\r\n color: white;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n }\r\n }\r\n `}\r\n >\r\n <h3>3.</h3>\r\n <h4>GET PAID</h4>\r\n <h4>\r\n You get paid in full once we receive your title. Until then, your\r\n vehicle stays in your garage and we even arrange shipping at no cost\r\n to you.\r\n </h4>\r\n <Button size=\"large\" type=\"ghost\" color=\"white\" onClick={goToSell}>\r\n Sell your vehicle for cash\r\n </Button>\r\n </Col>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default StepThreeBlock;\r\n","import { Button, Col, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport StepTwoBg from \"../../../assets/images/how-to-step-2-photo.jpg\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst StepTwoBlock: React.FC = () => {\r\n const history = useHistory();\r\n\r\n const goToSell = () => {\r\n if (\r\n window.location.href.includes(\"jdpower\") ||\r\n window.location.href.includes(\"lawtiger\") ||\r\n window.location.href.includes(\"cycletrader\")\r\n ) {\r\n window.scroll(0, 0);\r\n } else {\r\n history.push(\"/sell\");\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n css={css`\r\n width: 100%;\r\n .ant-col {\r\n height: 400px !important;\r\n }\r\n // @media (max-width: ${breakpoints.md}) {\r\n // padding: 4% 16%;\r\n // }\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <Row\r\n css={css`\r\n display: flex;\r\n flex-direction: row;\r\n // @media (max-width: ${breakpoints.md}) {\r\n // padding: 4% 16%;\r\n // }\r\n @media (max-width: 990px) {\r\n flex-direction: column-reverse;\r\n }\r\n `}\r\n >\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background: #2b2b2b;\r\n text-align: left;\r\n padding: 4% 2%;\r\n h3 {\r\n font-family: interstate;\r\n font-weight: bold;\r\n font-size: 20px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 48px !important;\r\n }\r\n }\r\n h4 {\r\n font-family: interstate;\r\n font-weight: normal;\r\n font-size: 16px;\r\n color: white;\r\n bottom-margin: 4%;\r\n @media (max-width: 786px) {\r\n font-size: 20px !important;\r\n }\r\n }\r\n button {\r\n border: 1px solid white;\r\n margin-top: 10%;\r\n color: white;\r\n height: 48px;\r\n &:hover {\r\n border: 1px solid white;\r\n color: white;\r\n }\r\n @media (max-width: 786px) {\r\n font-size: 16px;\r\n }\r\n }\r\n `}\r\n >\r\n <h3>2.</h3>\r\n <h4>ACCEPT YOUR CASH OFFER</h4>\r\n <h4>\r\n After receiving your vehicle information, you’ll have a cash offer\r\n in your inbox in minutes, waiting for you to accept it.\r\n </h4>\r\n <Button size=\"large\" type=\"ghost\" color=\"white\" onClick={goToSell}>\r\n Get your offer now\r\n </Button>\r\n </Col>\r\n <Col\r\n xs={24}\r\n lg={12}\r\n css={css`\r\n background-image: url(${StepTwoBg});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: center;\r\n `}\r\n ></Col>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default StepTwoBlock;\r\n","import { Col, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport StepOneBlock from \"./StepOneBlock\";\r\nimport StepThreeBlock from \"./StepThreeBlock\";\r\nimport StepTwoBlock from \"./StepTwoBlock\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst VinDecoderBlocks: React.FC = () => {\r\n return (\r\n <div\r\n css={css`\r\n margin-top: 2%;\r\n width: 100%;\r\n .ant-col {\r\n height: 400px !important;\r\n }\r\n // @media (max-width: ${breakpoints.md}) {\r\n // padding: 4% 16%;\r\n // }\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <Row>\r\n <StepOneBlock />\r\n\r\n <StepTwoBlock />\r\n\r\n <StepThreeBlock />\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default VinDecoderBlocks;\r\n","import { Button, Form, Icon, Input, Row } from \"antd\";\r\n\r\nimport { FormComponentProps } from \"antd/lib/form\";\r\nimport React from \"react\";\r\nimport { breakpoints } from \"../../../constants\";\r\nimport { css } from \"@emotion/core\";\r\nimport { useHistory } from \"react-router-dom\";\r\nimport { useModalFlowDispatch } from \"../../../context/ModalContext\";\r\n\r\ninterface Props extends FormComponentProps {}\r\n\r\nconst VinDecoderMobile: React.FC<Props> = ({ form }) => {\r\n const history = useHistory();\r\n const dispatch = useModalFlowDispatch();\r\n const [vin, setVin] = React.useState();\r\n\r\n const handleOnChange = (e: any) => {\r\n setVin(e.target.value);\r\n };\r\n\r\n const handleShowFindYourVINModal = (e: React.FormEvent) => {\r\n e.preventDefault();\r\n dispatch({\r\n type: \"SHOW_FIND_YOUR_VIN_MODAL\",\r\n args: {\r\n showFindYourVINModal: true,\r\n },\r\n });\r\n };\r\n\r\n const handleVinDecodeSubmit = (e: React.FormEvent) => {\r\n e.preventDefault();\r\n history.push(\"/sell\", {\r\n currentVin: vin,\r\n });\r\n };\r\n return (\r\n <div\r\n css={css`\r\n display: flex !important;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n height: fit-content;\r\n width: 100%;\r\n i {\r\n margin-right: 1%;\r\n }\r\n .ant-row {\r\n width: 100%;\r\n }\r\n @media (min-width: ${breakpoints.md}) {\r\n display: none !important;\r\n }\r\n `}\r\n >\r\n <div\r\n css={css`\r\n padding: 4%;\r\n width: 100%;\r\n background: transparent;\r\n height: 100% !important;\r\n border-radius: 4px;\r\n h3 {\r\n color: #2b2b2b;\r\n padding: 2%;\r\n padding-left: 0;\r\n }\r\n .ant-form-extra {\r\n font-size: 12px;\r\n color: #2b2b2b;\r\n padding: 2% 4%;\r\n }\r\n input {\r\n height: 52px !important;\r\n outline: none;\r\n &:selected {\r\n outline: none;\r\n }\r\n @media (max-width: ${breakpoints.md}) {\r\n background: #eeeeee;\r\n width: 100% !important;\r\n border-bottom: 1px solid gray;\r\n border-bottom-left-radius: 0;\r\n border-bottom-right-radius: 0;\r\n }\r\n }\r\n\r\n button {\r\n height: 48px;\r\n background: #9e9e9e;\r\n @media (max-width: 768px) {\r\n width: 100% !important;\r\n }\r\n }\r\n font-size: 16px;\r\n // @media (max-width: 786px) {\r\n // font-size: 16px;\r\n // }\r\n `}\r\n >\r\n <h3>ENTER YOUR VIN TO GET YOUR OFFER</h3>\r\n\r\n <Form onSubmit={handleVinDecodeSubmit}>\r\n <Form.Item extra={\"THE LETTER I, O AND Q ARE NOT ACCEPTED.\"}>\r\n {form.getFieldDecorator(\"VIN\", {\r\n initialValue: vin,\r\n normalize: (v: string) =>\r\n v ? v.replace(/[ioq]/g, \"\").toUpperCase() : \"\",\r\n rules: [\r\n {\r\n len: 17,\r\n max: 17,\r\n },\r\n ],\r\n })(\r\n <Input\r\n size=\"large\"\r\n maxLength={17}\r\n placeholder=\"Your VIN\"\r\n onChange={handleOnChange}\r\n />\r\n )}\r\n </Form.Item>\r\n {/* <h4>THE LETTER I, O AND Q ARE NOT ACCEPTED.</h4> */}\r\n\r\n <Button\r\n block\r\n htmlType=\"submit\"\r\n size=\"large\"\r\n type=\"primary\"\r\n // onClick={handleVinDecodeSubmit}\r\n >\r\n Get your offer\r\n </Button>\r\n </Form>\r\n </div>\r\n\r\n <Row>\r\n <p onClick={handleShowFindYourVINModal}>\r\n <Icon type=\"question-circle\" theme=\"outlined\" />\r\n Where is my VIN?\r\n </p>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default Form.create()(VinDecoderMobile);\r\n","import { Col, Divider, Row } from \"antd\";\r\n\r\nimport React from \"react\";\r\nimport { css } from \"@emotion/core\";\r\n\r\ninterface Props {\r\n data: any;\r\n}\r\nconst FIndYourVinCategory: React.FC<Props> = ({ data }) => {\r\n return (\r\n <div\r\n css={css`\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n margin: 4% 14%;\r\n h3 {\r\n font-family: interstate;\r\n font-size: 16px;\r\n font-weight: bold;\r\n text-transform: uppercase;\r\n }\r\n @media (max-width: 990px) {\r\n }\r\n .ant-row {\r\n display: flex;\r\n\r\n flex: 1;\r\n height: 150px;\r\n }\r\n\r\n .ant-col {\r\n background: transparent;\r\n height: 100%;\r\n padding: 4%;\r\n\r\n img {\r\n border-radius: 4px;\r\n }\r\n }\r\n @media (max-width: 768px) {\r\n margin: 4% 0%;\r\n .ant-row {\r\n flex-direction: column;\r\n height: max-content;\r\n }\r\n .ant-col {\r\n height: 250px;\r\n p {\r\n position: absolute;\r\n top: 8%;\r\n left: 8%;\r\n color: white;\r\n }\r\n }\r\n\r\n img {\r\n height: 100%;\r\n }\r\n }\r\n `}\r\n >\r\n <div>\r\n <h3>{data.label + \"S\"}</h3>\r\n </div>\r\n\r\n <Row>\r\n <Col xs={24} lg={12}>\r\n <img\r\n src={require(`../../assets/images/${\r\n \"web_\" +\r\n data.label?.toLowerCase() +\r\n \"-vin-location-\" +\r\n \"1\" +\r\n \".jpg\"\r\n }`)}\r\n css={css`\r\n width: 100%;\r\n height: 90%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n // padding: 4%;\r\n `}\r\n />\r\n <p>{data.rightText}</p>\r\n </Col>\r\n\r\n <Col xs={24} lg={12}>\r\n <img\r\n src={require(`../../assets/images/${\r\n \"web_\" +\r\n data.label?.toLowerCase() +\r\n \"-vin-location-\" +\r\n \"2\" +\r\n \".jpg\"\r\n }`)}\r\n css={css`\r\n width: 100%;\r\n height: 90%;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n // padding: 4%;\r\n `}\r\n ></img>\r\n\r\n <p>{data.leftText}</p>\r\n </Col>\r\n </Row>\r\n </div>\r\n );\r\n};\r\n\r\nexport default FIndYourVinCategory;\r\n","import React from \"react\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst VinInfoOptions: React.FC = () => {\r\n return (\r\n <div\r\n css={css`\r\n padding-left: 4%;\r\n h1 {\r\n font-family: interstate;\r\n font-size: 18px;\r\n }\r\n\r\n li {\r\n font-family: interstate;\r\n font-size: 16px;\r\n }\r\n\r\n @media (max-width: 990px) {\r\n height: max-content;\r\n }\r\n `}\r\n >\r\n <div>\r\n <h1>Other Options</h1>\r\n </div>\r\n <ul>\r\n <li>Insurance card or policy</li>\r\n <li>Vehicle title and registration</li>\r\n </ul>\r\n </div>\r\n );\r\n};\r\n\r\nexport default VinInfoOptions;\r\n","import { Carousel, Col, Divider, Modal, Row } from \"antd\";\r\nimport {\r\n useModalFlowDispatch,\r\n useModalFlowState,\r\n} from \"../context/ModalContext\";\r\n\r\nimport Categories from \"./components/Category.json\";\r\nimport FIndYourVinCategory from \"./components/FIndYourVinCategory\";\r\nimport React from \"react\";\r\nimport VinInfoOptions from \"./components/VinInfoOptions\";\r\nimport { breakpoints } from \"../constants\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nconst FindYourVINModal: React.FC = () => {\r\n const dispatch = useModalFlowDispatch();\r\n const state = useModalFlowState();\r\n\r\n const { showFindYourVINModal } = state;\r\n\r\n return (\r\n <div>\r\n <Modal\r\n visible={showFindYourVINModal}\r\n footer={null}\r\n closable={true}\r\n destroyOnClose={true}\r\n title={\r\n <div className=\"header-container\">\r\n <h3 className=\"header_title\">Where to Find your vin</h3>\r\n </div>\r\n }\r\n css={css`\r\n width: 500px;\r\n .ant-modal-content {\r\n width: 500px;\r\n }\r\n\r\n .header-container {\r\n padding-top: 4%;\r\n }\r\n\r\n .ant-modal {\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n top: 20% !important;\r\n }\r\n .ant-carousel .slick-dots {\r\n top: 270px;\r\n }\r\n .ant-modal-close-x {\r\n position: absolute;\r\n top: 22px;\r\n right: 15px;\r\n display: block;\r\n font-size: 20px;\r\n font-style: normal;\r\n line-height: 30px;\r\n text-align: center;\r\n text-transform: none;\r\n border-radius: 15px;\r\n text-rendering: auto;\r\n color: #212121;\r\n }\r\n\r\n .ant-modal-header {\r\n margin-right: 1%;\r\n margin-bottom: 0;\r\n }\r\n\r\n .ant-modal-body {\r\n padding: 0;\r\n }\r\n\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n\r\n .header_title {\r\n font-family: interstate !important;\r\n font-size: 22px !important;\r\n font-weight: bold !important;\r\n text-transform: uppercase !important;\r\n }\r\n\r\n @media (min-width: ${breakpoints.sm}) {\r\n .ant-modal-content {\r\n // width: 340px;\r\n height: 100% !important;\r\n border-radius: 0 !important;\r\n z-index: 99999;\r\n }\r\n }\r\n .ant-modal-header {\r\n border: none;\r\n border-bottom: 1px solid #e0e0e0;\r\n }\r\n\r\n @media (max-width: ${breakpoints.sm}) {\r\n margin: 0 !important;\r\n max-width: 100% !important;\r\n top: 0 !important;\r\n font-family: aktiv-grotesk, arial, Helvetica, sans-serif !important;\r\n font-weight: bold;\r\n height: 100%;\r\n width: 100% !important;\r\n .ant-modal-content {\r\n width: 100%;\r\n height: 1000px;\r\n position: absolute;\r\n top: 0;\r\n z-index: 99999;\r\n }\r\n\r\n .ant-modal-body {\r\n padding-left: 2%;\r\n padding-right: 2%;\r\n }\r\n\r\n .ant-modal-header {\r\n margin-right: 0;\r\n border-bottom: 1px solid #e0e0e0;\r\n }\r\n .ant-modal-close-x {\r\n position: absolute;\r\n top: 22px;\r\n right: 15px;\r\n display: block;\r\n font-size: 20px;\r\n font-style: normal;\r\n line-height: 30px;\r\n text-align: center;\r\n text-transform: none;\r\n border-radius: 15px;\r\n text-rendering: auto;\r\n color: #212121;\r\n }\r\n\r\n .header_title {\r\n font-size: 16px !important;\r\n // padding-left: 4%;\r\n // display: none;\r\n }\r\n }\r\n `}\r\n onCancel={() =>\r\n dispatch({\r\n type: \"SHOW_FIND_YOUR_VIN_MODAL\",\r\n args: {\r\n showFindYourVINModal: false,\r\n },\r\n })\r\n }\r\n >\r\n {/* <div>\r\n <h3 className=\"header_title\">Where to Find your vin</h3>\r\n </div> */}\r\n <Row\r\n css={css`\r\n padding-top: 0;\r\n height: 400px;\r\n overflow: auto;\r\n background: transparent;\r\n // border-top: 0.2px solid lightgray;\r\n @media (max-width: 990px) {\r\n height: max-content;\r\n }\r\n `}\r\n >\r\n <Col>\r\n <div>\r\n <Carousel\r\n slidesToShow={1}\r\n dots\r\n dotsClass=\"dots-style\"\r\n arrows={true}\r\n css={css`\r\n height: 250px;\r\n .slick-next {\r\n right: 2% !important;\r\n // top: 85% !important;\r\n border: 2px solid #1b51cf !important;\r\n background: #1b51cf !important;\r\n border-radius: 50% !important;\r\n width: 40px !important;\r\n height: 40px !important;\r\n z-index: 1 !important;\r\n text-align: center;\r\n :hover {\r\n background: #1b51cf !important;\r\n }\r\n }\r\n\r\n .slick-next::before {\r\n content: \"›\" !important;\r\n color: white;\r\n font-size: 20px !important;\r\n }\r\n\r\n .slick-prev {\r\n left: 2% !important;\r\n // top: 85% !important;\r\n border: 2px solid #1b51cf !important;\r\n background: #1b51cf !important;\r\n border-radius: 50% !important;\r\n width: 40px !important;\r\n height: 40px !important;\r\n z-index: 1 !important;\r\n text-align: center !important;\r\n :hover {\r\n background: #1b51cf !important;\r\n }\r\n }\r\n\r\n .slick-prev::before {\r\n content: \"‹\" !important;\r\n color: white;\r\n font-size: 20px !important;\r\n }\r\n\r\n .slick-dots li button {\r\n margin-left: 10px;\r\n opacity: 1 !important;\r\n border: 2px solid #4c4c4c !important;\r\n background: white !important;\r\n color: #4c4c4c !important;\r\n height: 8px !important;\r\n width: 8px !important;\r\n border-radius: 4px !important;\r\n }\r\n\r\n .slick-dots li.slick-active button {\r\n width: 8px !important;\r\n background: #4c4c4c !important;\r\n }\r\n\r\n .ant-carousel .slick-dots li.slick-active button {\r\n // height: 20px !important;\r\n // width: 20px !important;\r\n // border-radius: 50% !important;\r\n }\r\n @media (max-width: 768px) {\r\n height: max-content;\r\n .slick-next,\r\n .slick-prev {\r\n display: none !important;\r\n }\r\n\r\n .slick-dots li.slick-active button {\r\n width: 14px !important;\r\n height: 14px !important;\r\n background: #4c4c4c !important;\r\n }\r\n\r\n .slick-dots li button {\r\n margin-left: 10px;\r\n opacity: 1 !important;\r\n border: 2px solid #4c4c4c !important;\r\n background: white !important;\r\n color: #4c4c4c !important;\r\n height: 14px !important;\r\n width: 14px !important;\r\n border-radius: 7px !important;\r\n }\r\n }\r\n `}\r\n >\r\n {Categories.map((category, i) => {\r\n return (\r\n <div key={i}>\r\n <FIndYourVinCategory data={category} />\r\n </div>\r\n );\r\n })}\r\n </Carousel>\r\n </div>\r\n </Col>\r\n\r\n <Divider\r\n css={css`\r\n margin-top: 40px !important;\r\n `}\r\n />\r\n <Col>\r\n <VinInfoOptions />\r\n </Col>\r\n </Row>\r\n </Modal>\r\n </div>\r\n );\r\n};\r\n\r\nexport default FindYourVINModal;\r\n","import { Header, HowItWorks, Ratings } from \"./components\";\r\n\r\nimport FindYourVINModal from \"../../Modals/FindYourVINModal\";\r\nimport Helmet from \"react-helmet\";\r\nimport React from \"react\";\r\nimport { SubmitVinBanner } from \"../CashOfferPage/components/VinDecoderComponent\";\r\n\r\nconst SellInfo = () => {\r\n return (\r\n <div style={{ width: \"100%\" }}>\r\n <Helmet>\r\n <title>\r\n Sell Your Motorcycle or Powersports Vehicle Online | RumbleOn\r\n </title>\r\n <meta\r\n property=\"description\"\r\n content={`Looking to sell your motorcycle, car, or ATV quickly? Get a fair cash offer from RumbleOn with no hassle. Learn how to sell your vehicle safely and efficiently.`}\r\n />\r\n <meta\r\n property=\"og:title\"\r\n content=\"Sell Your Motorcycle or Powersports Vehicle Online | RumbleOn\"\r\n />\r\n <meta\r\n property=\"og:description\"\r\n content={\"Get a Fast Online Cash Offer for Your Vehicle Today.\"}\r\n />\r\n {/* <meta\r\n property=\"og:image\"\r\n content=\"https://go.rumbleon.com/hubfs/_classifieds/img/og-hp.jpg\"\r\n />\r\n <meta property=\"og:image:width\" content=\"800\" />\r\n <meta property=\"og:image:height\" content=\"400\" />\r\n <meta\r\n property=\"og:image\"\r\n content=\"https://go.rumbleon.com/hubfs/_classifieds/img/og-hp-th.jpg\"\r\n /> */}\r\n <meta property=\"og:image:width\" content=\"200\" />\r\n <meta property=\"og:image:height\" content=\"200\" />\r\n <meta property=\"og:image:alt\" content=\"RumbleOn\" />\r\n <meta property=\"og:type\" content=\"website\" />\r\n <meta property=\"og:url\" content=\"https://www.rumbleon.com/\" />\r\n {/* {renderCanonical()} */}\r\n </Helmet>\r\n <Header />\r\n <HowItWorks />\r\n <Ratings />\r\n <SubmitVinBanner header=\"ENTER YOUR VIN TO GET YOUR OFFER\" />\r\n <FindYourVINModal />\r\n </div>\r\n );\r\n};\r\n\r\nexport default SellInfo;\r\n","import SellInfo from \"./how-to\";\r\n\r\nexport default SellInfo;\r\n","import React, { FC, MouseEvent, ReactNode } from \"react\";\r\n\r\nimport { Button } from \"antd\";\r\nimport { colors } from \"../../constants/styles\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nexport const CustomButton: FC<{\r\n filled?: boolean;\r\n [key: string]: any;\r\n}> = ({ filled = false, children, ...props }) => {\r\n const bgColor = filled ? colors.darkCharcoal : \"white\",\r\n textColor = !filled ? colors.darkCharcoal : \"white\";\r\n\r\n return (\r\n <Button\r\n {...props}\r\n css={css`\r\n background: ${bgColor};\r\n color: ${textColor};\r\n border: 1px solid ${colors.darkCharcoal};\r\n cursor: pointer;\r\n &:hover,\r\n &:focus {\r\n background: ${bgColor};\r\n color: ${textColor};\r\n border: 1px solid ${colors.darkCharcoal};\r\n }\r\n &:disabled {\r\n opacity: 0.4;\r\n cursor: pointer;\r\n }\r\n `}\r\n >\r\n {children}\r\n </Button>\r\n );\r\n};\r\n\r\nexport const BlueLinkButton = ({\r\n children,\r\n disabled,\r\n onClick,\r\n ...props\r\n}: {\r\n children: ReactNode;\r\n disabled?: boolean;\r\n onClick: (e: MouseEvent) => void;\r\n}) => (\r\n <button\r\n {...props}\r\n disabled={disabled}\r\n onClick={onClick}\r\n css={css`\r\n background: none;\r\n border: none;\r\n padding: 0;\r\n color: ${colors.blue};\r\n cursor: pointer;\r\n text-decoration: underline;\r\n font-weight: bold;\r\n `}\r\n >\r\n {children}\r\n </button>\r\n);\r\n","import React, { FC, forwardRef, useEffect, useRef, useState } from \"react\";\r\n\r\nimport { Input } from \"antd\";\r\nimport Password from \"antd/lib/input/Password\";\r\nimport TextArea from \"antd/lib/input/TextArea\";\r\nimport { colors } from \"../../constants/styles\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nexport const FloatingLabelInput: FC<{\r\n label?: string;\r\n isPassword?: boolean;\r\n extraCss?: string;\r\n autoFocus?: boolean;\r\n [key: string]: any;\r\n}> = forwardRef(\r\n ({ label, isPassword, autoFocus, extraCss, ...props }, _ref) => {\r\n const [focus, setFocus] = useState(false);\r\n const ref = useRef<Input & Password>(null);\r\n\r\n useEffect(() => {\r\n if (autoFocus) {\r\n setFocus(true);\r\n }\r\n }, [autoFocus]);\r\n useEffect(() => {\r\n if (ref.current && ref.current?.input.value) {\r\n setFocus(true);\r\n }\r\n }, [ref.current && ref.current?.input.value]);\r\n\r\n return (\r\n <div\r\n css={css`\r\n position: relative !important;\r\n input,\r\n label {\r\n font-family: aktiv-grotesk !important;\r\n }\r\n label {\r\n position: absolute !important;\r\n left: 17px;\r\n top: ${focus\r\n ? \"0.25rem\"\r\n : ref.current && ref.current?.input.value\r\n ? \"0.25rem\"\r\n : \"1.5rem\"};\r\n transition: 0.1s ease;\r\n pointer-events: none;\r\n line-height: 40px;\r\n @media (max-width: 300px) {\r\n font-size: 11px;\r\n }\r\n }\r\n input {\r\n border-radius: 4px 4px 0 0 !important;\r\n background: ${colors.superLightGray}!important;\r\n border: 1px solid ${colors.superLightGray} !important;\r\n border-bottom-color: ${colors.lightCharcoal}!important;\r\n padding: 2rem 1rem 0.5rem 1rem !important;\r\n height: 64px !important;\r\n \r\n &:focus {\r\n border-bottom-color: ${colors.blue} !important;\r\n }\r\n &:disabled {\r\n opacity: 0.4 !important;\r\n & + label {\r\n top: ${focus\r\n ? \"0.25rem\"\r\n : ref.current && ref.current?.input.value\r\n ? \"0.25rem\"\r\n : \"1.5rem\"};\r\n opacity: 0.4 !important;\r\n }\r\n }\r\n \r\n ${extraCss}\r\n }\r\n `}\r\n onBlur={() => setFocus(false)}\r\n onFocus={() => setFocus(true)}\r\n >\r\n {isPassword ? (\r\n <Input.Password ref={ref} {...props} />\r\n ) : (\r\n <Input ref={ref} {...props} />\r\n )}\r\n <label>{label}</label>\r\n </div>\r\n );\r\n }\r\n);\r\n\r\nexport const FloatingLabelTextArea: FC<{\r\n label?: string;\r\n [key: string]: any;\r\n autoFocus?: boolean;\r\n}> = forwardRef(({ label, autoFocus, ...props }, _ref) => {\r\n const [focus, setFocus] = useState(false);\r\n const ref = useRef<TextArea>(null);\r\n //@ts-ignore\r\n const value = ref.current && ref.current?.textAreaRef.value;\r\n\r\n useEffect(() => {\r\n if (autoFocus) {\r\n setFocus(true);\r\n }\r\n }, [autoFocus]);\r\n\r\n return (\r\n <div\r\n css={css`\r\n position: relative !important;\r\n padding-top: 2rem;\r\n border-radius: 4px 4px 0 0 !important;\r\n background: ${colors.superLightGray}!important;\r\n border: 1px solid ${colors.superLightGray} !important;\r\n border-width: 1px 1px 0px 1px;\r\n opacity: ${ref.current && ref.current?.props.disabled ? \"0.4\" : \"1\"};\r\n box-shadow: ${focus ? \"0 0 0 2px rgba(43, 43, 43, 0.2)\" : \"\"};\r\n transition: all 0.3s;\r\n label {\r\n position: absolute !important;\r\n left: 17px;\r\n top: ${value ? \"0.25rem\" : \"1.5rem\"};\r\n transition: 0.1s ease;\r\n pointer-events: none;\r\n line-height: 40px;\r\n }\r\n textarea {\r\n background: transparent !important;\r\n box-shadow: none !important;\r\n border-color: transparent !important;\r\n margin-bottom: -1px !important;\r\n border-width: 0 0 1px 0 !important;\r\n border-radius: 0;\r\n padding: 0 1rem !important;\r\n border-bottom-color: ${colors.lightCharcoal}!important;\r\n &:focus {\r\n border-bottom-color: ${colors.blue} !important;\r\n & + label {\r\n top: 0.25rem;\r\n }\r\n }\r\n &:disabled {\r\n & + label {\r\n top: 0.25rem;\r\n }\r\n }\r\n &:hover {\r\n border-right-width: 0 !important;\r\n }\r\n }\r\n .ant-input[disabled]:hover {\r\n border-right-width: 0 !important;\r\n }\r\n `}\r\n onBlur={() => setFocus(false)}\r\n onFocus={() => setFocus(true)}\r\n >\r\n <Input.TextArea ref={ref} {...props} />\r\n <label>{label}</label>\r\n </div>\r\n );\r\n});\r\n","import { Icon, Select } from \"antd\";\r\nimport React, {\r\n Dispatch,\r\n FC,\r\n SetStateAction,\r\n forwardRef,\r\n memo,\r\n useEffect,\r\n useRef,\r\n useState,\r\n} from \"react\";\r\n\r\nimport { colors } from \"../../constants/styles\";\r\nimport { css } from \"@emotion/core\";\r\n\r\nexport const CustomDropDown: FC<{\r\n placeHolder: string;\r\n extraCss?: string;\r\n}> = ({ placeHolder, extraCss, children }) => {\r\n const [active, setActive] = useState(false);\r\n const [selected, setDropDownSelected] = useState(placeHolder);\r\n const ref = useRef<any>();\r\n\r\n const handleClickOutside = (e: MouseEvent) => {\r\n const clickInside = ref && ref.current.contains(e.target);\r\n if (clickInside) {\r\n return;\r\n } else {\r\n setActive(false);\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (active) {\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n } else {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n };\r\n }, [active]);\r\n\r\n return (\r\n <div\r\n ref={ref}\r\n css={css`\r\n position: relative;\r\n z-index: 1;\r\n width: 100%;\r\n border-radius: 5px;\r\n box-shadow: ${active ? \"0 0 0 2px rgba(27, 81, 207, 0.2)\" : \"none\"};\r\n transition: 0.1s ease;\r\n cursor: pointer;\r\n &:before {\r\n content: '${selected !== placeHolder ? placeHolder : \"\"}';\r\n position: absolute;\r\n font-size: 13px;\r\n top: 0.25rem;\r\n left: 1rem;\r\n color: ${colors.textGrey};\r\n }\r\n ${extraCss}\r\n `}\r\n >\r\n <button\r\n onClick={() => setActive(!active)}\r\n css={css`\r\n height: 64px !important;\r\n display: flex;\r\n justify-content: space-between;\r\n align-items: center;\r\n padding: 0 1rem;\r\n width: 100%;\r\n background: ${colors.superLightGray};\r\n border: 1px solid ${colors.superLightGray};\r\n border-radius: 5px 5px 0 0;\r\n border-bottom-color: ${active\r\n ? colors.lightGrey\r\n : colors.darkCharcoal};\r\n height: 48px;\r\n z-index: 100;\r\n position: relative;\r\n cursor: pointer;\r\n &:focus {\r\n outline: none;\r\n }\r\n `}\r\n >\r\n {selected}\r\n <Icon type={active ? \"caret-up\" : \"caret-down\"} />\r\n </button>\r\n <div\r\n css={css`\r\n ${active ? \"\" : \"display: none;\"}\r\n border: 1px solid ${colors.lightCharcoal};\r\n min-width: 100%;\r\n background: white;\r\n top: 64px;\r\n border-top: none;\r\n border-radius: 0 0 4px 4px; max-width: 100%;\r\n `}\r\n >\r\n {React.cloneElement(children as React.ReactElement<any>, {\r\n placeHolder,\r\n setDropDownSelected,\r\n setActive,\r\n })}\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\ntype RenderProps = {\r\n setDropDownSelected: Dispatch<SetStateAction<string>>;\r\n setActive: Dispatch<SetStateAction<boolean>>;\r\n};\r\n\r\nexport const CustomDropDownRender: FC<{\r\n label: string;\r\n render: (args: RenderProps) => React.ReactElement<any>;\r\n extraCss?: string;\r\n hover?: boolean;\r\n initialValue?: string;\r\n [key: string]: any;\r\n}> = memo(({ label, initialValue, extraCss, hover, render, ...props }) => {\r\n const [active, setActive] = useState(false);\r\n const [selected, setDropDownSelected] = useState(initialValue || \"\");\r\n const [focus, setFocus] = useState(false);\r\n const ref = useRef<any>();\r\n\r\n const handleClickOutside = (e: MouseEvent) => {\r\n const clickInside = ref && ref.current.contains(e.target);\r\n if (clickInside) {\r\n return;\r\n } else {\r\n setActive(false);\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (active) {\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n } else {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n }\r\n\r\n return () => {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n };\r\n }, [active]);\r\n\r\n return (\r\n <div\r\n onBlur={() => setFocus(false)}\r\n onFocus={() => setFocus(true)}\r\n ref={ref}\r\n css={css`\r\n position: relative !important;\r\n z-index: 1;\r\n width: 100%;\r\n border-radius: 5px;\r\n box-shadow: ${active ? \"0 0 0 2px rgba(43, 43, 43, 0.2)\" : \"\"};\r\n cursor: pointer;\r\n label {\r\n position: absolute !important;\r\n line-height: 40px;\r\n top: ${selected ? \"0.25rem\" : \"1.5rem\"};\r\n left: 1rem;\r\n transition: 0.1s ease;\r\n pointer-events: none;\r\n }\r\n i {\r\n position: absolute;\r\n right: 1rem;\r\n top: 25px;\r\n }\r\n ${extraCss}\r\n `}\r\n >\r\n <button\r\n onClick={() => setActive(!active)}\r\n css={css`\r\n height: 64px !important;\r\n padding: 2rem 2rem 0.5rem 1rem;\r\n width: 100%;\r\n background: ${colors.superLightGray};\r\n border: 1px solid ${colors.superLightGray};\r\n border-radius: 5px 5px 0 0;\r\n border-bottom-color: ${active\r\n ? colors.lightGrey\r\n : colors.darkCharcoal};\r\n height: 48px;\r\n z-index: 100;\r\n cursor: pointer;\r\n text-align: left;\r\n &:focus {\r\n outline: none;\r\n }\r\n `}\r\n >\r\n {selected}\r\n <Icon type={active ? \"caret-up\" : \"caret-down\"} />\r\n </button>\r\n <label>{label}</label>\r\n <div\r\n css={css`\r\n ${active ? \"\" : \"display: none;\"}\r\n border: 1px solid ${colors.lightCharcoal};\r\n min-width: 100%;\r\n background: white;\r\n top: 64px;\r\n border-top: none;\r\n border-radius: 0 0 4px 4px; max-width: 100%;\r\n ${hover && \"position: absolute;\"}\r\n `}\r\n >\r\n {render({\r\n setDropDownSelected,\r\n setActive,\r\n ...props,\r\n })}\r\n </div>\r\n </div>\r\n );\r\n});\r\n\r\nexport const CustomSelect: FC<{\r\n id?: string;\r\n label?: string;\r\n disabled?: boolean;\r\n}> = forwardRef(({ id, label, disabled, children, ...props }, _ref) => {\r\n const [focus, setFocus] = useState(false);\r\n const ref = useRef<any>(null);\r\n\r\n return (\r\n <div\r\n css={css`\r\n position: relative !important;\r\n `}\r\n onBlur={() => setFocus(false)}\r\n onFocus={() => setFocus(true)}\r\n >\r\n <Select\r\n css={css`\r\n .ant-select-selection {\r\n border-radius: 3px 3px 0 0;\r\n height: 64px;\r\n display: flex;\r\n justify-content: flex-start;\r\n align-items: center;\r\n padding: 2rem 2rem 0.5rem 1rem !important;\r\n background: ${colors.superLightGray};\r\n border: 1px solid ${colors.superLightGray} !important;\r\n border-bottom-color: ${colors.darkCharcoal} !important;\r\n &:hover {\r\n border-color: ${colors.lightGrey} !important;\r\n }\r\n &:focus {\r\n border-bottom-color: ${colors.blue} !important;\r\n }\r\n .ant-select-selection__rendered {\r\n margin: 0 !important;\r\n }\r\n }\r\n `}\r\n ref={ref}\r\n disabled={disabled}\r\n suffixIcon={\r\n <Icon\r\n type={\"caret-down\"}\r\n style={{\r\n fontSize: \"0.85rem\",\r\n color: colors.darkCharcoal,\r\n paddingRight: \"4px\",\r\n }}\r\n />\r\n }\r\n {...props}\r\n >\r\n {children}\r\n </Select>\r\n <label\r\n css={css`\r\n position: absolute !important;\r\n pointer-events: none;\r\n top: ${ref.current && ref.current.rcSelect.state.value.length\r\n ? \"0.25rem\"\r\n : focus\r\n ? \"0.25rem\"\r\n : \"1.5rem\"};\r\n left: 1rem;\r\n line-height: 40px;\r\n transition: 0.1s ease;\r\n `}\r\n >\r\n {label}\r\n </label>\r\n </div>\r\n );\r\n});\r\n","module.exports = __webpack_public_path__ + \"static/media/cash-offer-bg.b71d9c79.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web_vin-entry-purple-bg.866627dd.png\";","module.exports = \"\"","module.exports = \"\"","module.exports = \"\"","module.exports = __webpack_public_path__ + \"static/media/track-offer-automotive.2885cd83.jpg\";","module.exports = __webpack_public_path__ + \"static/media/track-offer-powersports.d8bc47f2.jpg\";","module.exports = __webpack_public_path__ + \"static/media/web-hero-image-cash-offer.b6bbe1d4.jpg\";","module.exports = \"\"","import { Alert, Col, Form, Input, Row, Select, Spin, notification } from \"antd\";\r\nimport {\r\n RESET_ERROR,\r\n RESET_STATE,\r\n SET_APPRAISAL_REF,\r\n SET_COENTRY,\r\n SET_CREATE_REQUEST,\r\n SET_CURRENT_STEP,\r\n SET_DEALER_BRAND,\r\n SET_DECODE_DATA,\r\n SET_DECODE_REQUEST,\r\n SET_ERROR,\r\n SET_SELECTED_TRIM_OR_MODEL_LIST,\r\n useCashOfferContext,\r\n} from \"../../../context/CashOfferContext\";\r\nimport React, { FC, FormEvent, useEffect, useState } from \"react\";\r\nimport { SerializedStyles, css } from \"@emotion/core\";\r\nimport { colors, minMedia } from \"../../../constants/styles\";\r\n\r\nimport { CustomButton } from \"../../UI/CustomButton\";\r\nimport { CustomSelect } from \"../../UI/CustomDropDown\";\r\nimport DecoderBanner from \"../../../assets/images/web_vin-entry-purple-bg.png\";\r\nimport { ERROR_MESSAGE } from \"../../../constants\";\r\nimport { FloatingLabelInput } from \"../../UI/CustomInput\";\r\nimport { FormComponentProps } from \"antd/lib/form\";\r\nimport _ from \"lodash\";\r\nimport { async } from \"q\";\r\nimport { environmentVariableList } from \"../../../config/env\";\r\nimport { loader } from \"graphql.macro\";\r\nimport queryString from \"query-string\";\r\nimport { useApolloClient } from \"@apollo/react-hooks\";\r\nimport { useAuthPopupState } from \"../../../context/AuthPopupContext\";\r\nimport { useDetailsFlowState } from \"../../../context/DetailsFlowContext\";\r\nimport { useHistory } from \"react-router-dom\";\r\n\r\nconst GET_LOCATION_BY_CLIENT_IP_QUERY = loader(\r\n \"./getLocationByClientIp.graphql\"\r\n);\r\nconst Item = Form.Item;\r\n\r\ninterface Props extends FormComponentProps {\r\n extraTextCss?: SerializedStyles;\r\n buttonCss?: SerializedStyles;\r\n}\r\nconst dealerBrand = queryString.parseUrl(window.location.search).query\r\n ?.utm_source;\r\nconst VALIDATION_RULES = [\r\n {\r\n required: dealerBrand === \"jdpower\" || \"marines\" ? false : true,\r\n message: \"Please enter your VIN.\",\r\n },\r\n\r\n {\r\n len: 17,\r\n message: \"VINs must contain a combination of 17 characters and numbers.\",\r\n },\r\n {\r\n pattern: /^[^iIoOqQ]*$/g,\r\n message: \"The letters I, O, and Q are not accepted.\",\r\n },\r\n];\r\n\r\nconst NEXT_STEP = \"/sell\";\r\n\r\nconst VinDecoderComponent: FC<Props> = ({ form, ...props }) => {\r\n const history = useHistory();\r\n const { state, dispatch } = useCashOfferContext();\r\n const { listingId } = useDetailsFlowState();\r\n const authState = useAuthPopupState();\r\n const [vin, setVin] = useState<string>(\"\");\r\n const [failedCount, setFailCount] = useState(0);\r\n const [finished, setFinished] = useState(false);\r\n const loading =\r\n state.decodeRequest === \"pending\" || state.createRequest === \"pending\";\r\n const trade = queryString.parse(window.location.search, {\r\n parseBooleans: true,\r\n })[\"trade\"];\r\n const [Year, setYear] = useState<string>(\"\");\r\n const [Make, setMake] = useState<string>(\"\");\r\n const [ModelId, setModelId] = useState<string>(\"\");\r\n const [ModelType, setModelType] = useState<string>(\"\");\r\n const [fetching, setFetching] = useState(false);\r\n const [trimDetails, setTrimDetails] = useState({});\r\n {\r\n /* Uncomment it back if we get the geoLocation back */\r\n }\r\n // const [isTexas, setIsTexas] = useState<boolean>(false)\r\n const [location, setLocation] = useState<any>(undefined);\r\n const [locloading, setLocloading] = useState<boolean>(false);\r\n const client = useApolloClient();\r\n let locstatus: any = undefined;\r\n // useEffect(() => {\r\n // const checkInitial = async () => {\r\n // // await getLocationFromThirdPartyService()\r\n // await checkifTexas()\r\n // }\r\n // checkInitial()\r\n // }, [locstatus === \"declined\"])\r\n // useEffect(() => {\r\n // const checkInitial = async () => {\r\n // const { state }: any = await navigator.permissions.query({\r\n // name: \"geolocation\",\r\n // });\r\n // locstatus = state !== \"prompt\" || state !== \"declined\" ? \"declined\" : \"given\"\r\n // }\r\n // checkInitial()\r\n // }, [])\r\n\r\n const getLocationFromThirdPartyService = async () => {\r\n try {\r\n const { data } = await client.query({\r\n query: GET_LOCATION_BY_CLIENT_IP_QUERY,\r\n });\r\n const { latitude, longitude } = data.getLocationByClientIp;\r\n setLocation({ lat: latitude, lng: longitude });\r\n return {\r\n latitude,\r\n longitude,\r\n };\r\n } catch (e) {\r\n console.error(e);\r\n }\r\n };\r\n const getLocationFromBrowserApi = async (): Promise<{\r\n latitude: number;\r\n longitude: number;\r\n } | null> => {\r\n //check browser support\r\n\r\n if (navigator.geolocation) {\r\n try {\r\n const { state }: any = await navigator.permissions.query({\r\n name: \"geolocation\",\r\n });\r\n console.log(\"state\", state);\r\n if (state === \"prompt\" || state === \"granted\") {\r\n return new Promise((resolve, reject) => {\r\n navigator.geolocation.getCurrentPosition(\r\n ({ coords: { latitude, longitude } }) => {\r\n resolve({ latitude, longitude });\r\n },\r\n (error) => {\r\n if (error.message !== \"User denied Geolocation\") {\r\n console.error(error);\r\n }\r\n resolve(null);\r\n },\r\n { enableHighAccuracy: false, maximumAge: 0 } //prevent caching as user can move around\r\n );\r\n });\r\n } else {\r\n return null;\r\n }\r\n } catch (e) {\r\n console.error(e);\r\n console.log(e);\r\n return null;\r\n }\r\n }\r\n return null;\r\n };\r\n const getLocation = async () => {\r\n const locationFromBrowserAPI = await getLocationFromBrowserApi();\r\n console.log(\"distance:\", locationFromBrowserAPI);\r\n if (locationFromBrowserAPI) {\r\n setLocation({\r\n lat: locationFromBrowserAPI.latitude,\r\n lng: locationFromBrowserAPI.longitude,\r\n });\r\n return {\r\n lat: locationFromBrowserAPI.latitude,\r\n lng: locationFromBrowserAPI.longitude,\r\n };\r\n }\r\n const locationFromThirdPartyService = await getLocationFromThirdPartyService();\r\n console.log(\"distance2:\", locationFromThirdPartyService);\r\n if (locationFromThirdPartyService) {\r\n setLocation({\r\n lat: locationFromThirdPartyService!.latitude,\r\n lng: locationFromThirdPartyService!.longitude,\r\n });\r\n return {\r\n lat: locationFromThirdPartyService!.latitude,\r\n lng: locationFromThirdPartyService!.longitude,\r\n };\r\n }\r\n return null;\r\n };\r\n\r\n const checkifTexas = async () => {\r\n setLocloading(true);\r\n const loc = await getLocation();\r\n console.log(\"Loaction :::\", loc);\r\n if (loc !== null && loc !== undefined) {\r\n try {\r\n const url = `${\r\n environmentVariableList.REACT_APP_DEALER_DETAIL\r\n }/api/States/CheckUserState?lat=${\r\n location !== undefined ? Number(location.lat) : Number(loc.lat)\r\n }&lng=${\r\n location !== undefined ? Number(location.lng) : Number(loc.lng)\r\n }`;\r\n const response = await fetch(url, {\r\n method: \"GET\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n },\r\n });\r\n\r\n if (!response.ok) {\r\n if (!response.text) {\r\n const error = response.statusText || ERROR_MESSAGE.fetchFailed;\r\n {\r\n /* Uncomment it back if we get the geoLocation back */\r\n }\r\n // setIsTexas(false)\r\n throw Error(error);\r\n } else {\r\n //todo: api error response is weird here.\r\n }\r\n }\r\n\r\n const data = await response.json();\r\n console.log(\"update:\", data);\r\n if (data.Message === \"Success\" && data.IsValidState === true) {\r\n {\r\n /* Uncomment it back if we get the geoLocation back */\r\n }\r\n // setIsTexas(true)\r\n }\r\n } catch (error) {\r\n {\r\n /* Uncomment it back if we get the geoLocation back */\r\n }\r\n // setIsTexas(false)\r\n console.error(error);\r\n } finally {\r\n setLocloading(false);\r\n }\r\n } else {\r\n {\r\n /* Uncomment it back if we get the geoLocation back */\r\n }\r\n // setIsTexas(false)\r\n setLocloading(false);\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n setYear(form.getFieldValue(\"year\"));\r\n // console.log(\"Year:\", Year, form.getFieldValue(\"year\"))\r\n if (form.getFieldValue(\"make\") !== undefined) {\r\n setMake(form.getFieldValue(\"make\"));\r\n }\r\n if (\r\n Make !== \"\" &&\r\n Make !== undefined &&\r\n Make !== form.getFieldValue(\"make\") &&\r\n form.getFieldValue(\"make\") !== undefined\r\n ) {\r\n form.setFieldsValue({\r\n model: \"\",\r\n });\r\n }\r\n if (\r\n Year !== \"\" &&\r\n Year !== undefined &&\r\n Year !== form.getFieldValue(\"year\") &&\r\n form.getFieldValue(\"year\") !== undefined\r\n ) {\r\n form.setFieldsValue({\r\n make: \"\",\r\n });\r\n form.setFieldsValue({\r\n model: \"\",\r\n });\r\n }\r\n if (form.getFieldValue(\"year\") === undefined) {\r\n fetchOffers();\r\n }\r\n if (\r\n form.getFieldValue(\"year\") !== undefined &&\r\n Year !== form.getFieldValue(\"year\")\r\n ) {\r\n // console.log(\"entered here\")\r\n fetchOffers1();\r\n }\r\n if (\r\n form.getFieldValue(\"year\") !== undefined &&\r\n form.getFieldValue(\"make\") !== undefined\r\n ) {\r\n fetchOffers2();\r\n }\r\n }, [form.getFieldValue(\"year\"), form.getFieldValue(\"make\")]);\r\n\r\n const [yearList, setyearList] = useState<any>([]);\r\n const [MakeList, setMakeList] = useState<any>([]);\r\n const [ModelList, setModelList] = useState<any>([]);\r\n\r\n async function fetchOffers() {\r\n const url = window.location.href.includes(\"vehicle\")\r\n ? `${environmentVariableList.VINLESS_ES_URL}/devnadaymmbike/_search?`\r\n : `${environmentVariableList.REACT_MARINEVINLESS_ES_LINK}/${environmentVariableList.REACT_MARINEVINLESS_ES_APP}/_search?`;\r\n try {\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n Authorization: environmentVariableList.REACT_ES_BASIC_AUTH,\r\n },\r\n body: JSON.stringify({\r\n size: 5,\r\n aggs: {\r\n Year: {\r\n terms: {\r\n field: \"Year.keyword\",\r\n size: 1000,\r\n },\r\n },\r\n },\r\n }),\r\n });\r\n\r\n const result = await response.json();\r\n if (result) {\r\n // console.log(\"Results:\", result.aggregations.Year.buckets);\r\n setyearList(result.aggregations.Year.buckets);\r\n }\r\n } catch (error) {\r\n console.log(error.message);\r\n }\r\n }\r\n async function fetchOffers1() {\r\n const url = window.location.href.includes(\"vehicle\")\r\n ? `${environmentVariableList.VINLESS_ES_URL}/devnadaymmbike/_search?`\r\n : `${environmentVariableList.REACT_MARINEVINLESS_ES_LINK}/${environmentVariableList.REACT_MARINEVINLESS_ES_APP}/_search?`;\r\n try {\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n Authorization: environmentVariableList.REACT_ES_BASIC_AUTH,\r\n },\r\n body: JSON.stringify({\r\n size: 0,\r\n query: {\r\n match: {\r\n \"Year.keyword\": form.getFieldValue(\"year\"),\r\n },\r\n },\r\n aggs: {\r\n Make: {\r\n terms: {\r\n field: \"Make.keyword\",\r\n size: 1000,\r\n },\r\n },\r\n },\r\n sort: {\r\n \"Make.keyword\": \"asc\",\r\n },\r\n }),\r\n });\r\n\r\n const result = await response.json();\r\n if (result) {\r\n // console.log(\"Results1:\", result.aggregations.Make.buckets);\r\n setMakeList(result.aggregations.Make.buckets);\r\n }\r\n } catch (error) {\r\n console.log(error.message);\r\n }\r\n }\r\n async function fetchOffers2() {\r\n const url = window.location.href.includes(\"vehicle\")\r\n ? `${environmentVariableList.VINLESS_ES_URL}/devnadaymmbike/_search?`\r\n : `${environmentVariableList.REACT_MARINEVINLESS_ES_LINK}/${environmentVariableList.REACT_MARINEVINLESS_ES_APP}/_search?`;\r\n try {\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n Authorization: environmentVariableList.REACT_ES_BASIC_AUTH,\r\n },\r\n body: JSON.stringify({\r\n size: 0,\r\n // match_all: {},\r\n query: {\r\n bool: {\r\n must: [\r\n {\r\n term: {\r\n \"Year.keyword\": form.getFieldValue(\"year\"),\r\n },\r\n },\r\n {\r\n term: { \"Make.keyword\": form.getFieldValue(\"make\") },\r\n },\r\n ],\r\n },\r\n },\r\n aggs: {\r\n ModelName: {\r\n terms: {\r\n field: window.location.href.includes(\"boat\")\r\n ? \"TrimName.keyword\"\r\n : \"ModelName.keyword\",\r\n size: 1000,\r\n },\r\n },\r\n },\r\n sort: window.location.href.includes(\"boat\")\r\n ? {\r\n \"TrimName.keyword\": \"asc\",\r\n }\r\n : {\r\n \"ModelName.keyword\": \"asc\",\r\n },\r\n }),\r\n });\r\n const result = await response.json();\r\n if (result) {\r\n // console.log(\"Results1:\", result.aggregations.Model.buckets);\r\n setModelList(result.aggregations.ModelName.buckets);\r\n }\r\n } catch (error) {\r\n console.log(error.message);\r\n }\r\n }\r\n let payload: any = null;\r\n async function fetchOffers3() {\r\n const url = window.location.href.includes(\"vehicle\")\r\n ? `${environmentVariableList.VINLESS_ES_URL}/devnadaymmbike/_search?`\r\n : `${environmentVariableList.REACT_MARINEVINLESS_ES_LINK}/${environmentVariableList.REACT_MARINEVINLESS_ES_APP}/_search?`;\r\n try {\r\n const response = await fetch(url, {\r\n method: \"POST\",\r\n headers: {\r\n \"Content-Type\": \"application/json\",\r\n Authorization: environmentVariableList.REACT_ES_BASIC_AUTH,\r\n },\r\n body: JSON.stringify({\r\n size: 0,\r\n // match_all: {},\r\n query: {\r\n bool: {\r\n must: [\r\n {\r\n term: {\r\n \"Year.keyword\": form.getFieldValue(\"year\"),\r\n },\r\n },\r\n {\r\n term: { \"Make.keyword\": form.getFieldValue(\"make\") },\r\n },\r\n {\r\n term: window.location.href.includes(\"boat\")\r\n ? { \"TrimName.keyword\": form.getFieldValue(\"model\") }\r\n : { \"ModelName.keyword\": form.getFieldValue(\"model\") },\r\n },\r\n ],\r\n },\r\n },\r\n aggs: {\r\n ModelId: {\r\n terms: {\r\n field: window.location.href.includes(\"/how-to/sell-your-boat\")\r\n ? \"TrimId.keyword\"\r\n : \"ModelId.keyword\",\r\n size: 1000,\r\n },\r\n aggs: {\r\n ModelType: {\r\n terms: {\r\n field: \"ModelType.keyword\",\r\n size: 1000,\r\n },\r\n },\r\n },\r\n },\r\n },\r\n }),\r\n });\r\n let result = await response.json();\r\n\r\n if (result && window.location.href.includes(\"vehicle\")) {\r\n payload = {\r\n ItemTypeId: 1,\r\n Bike: {\r\n VIN: \"\",\r\n Make: form.getFieldValue(\"make\"),\r\n Model: form.getFieldValue(\"model\"),\r\n Id: result.aggregations.ModelId.buckets[0]\r\n ? result.aggregations.ModelId.buckets[0].key\r\n : null,\r\n SourceTypeId:\r\n dealerBrand === \"jdpower\"\r\n ? 11\r\n : window.location.pathname === \"/how-to/sell-your-vehicle-1\"\r\n ? 15\r\n : 1,\r\n AppraisalStatusId: 1,\r\n GoogleCLID: \"\",\r\n CurrentStepNo: 1,\r\n TradeForItemId: null,\r\n Decoder: \"NADA\",\r\n ItemYear: form.getFieldValue(\"year\"),\r\n CategoryName: result.aggregations.ModelId.buckets[0].ModelType\r\n .buckets[0]\r\n ? result.aggregations.ModelId.buckets[0].ModelType.buckets[0].key\r\n : null,\r\n MarketingCategory: \"motorcycle\",\r\n COEntryTypeId: 1,\r\n },\r\n };\r\n // console.log(\"ModelIdbuckets:\", result.aggregations.ModelId.buckets[0].ModelType.buckets[0].key);\r\n // console.log(\"ModelId:\", result.aggregations.ModelId.buckets[0].key);\r\n }\r\n if (result && window.location.href.includes(\"boat\")) {\r\n const trimResponse = await fetch(\r\n `${environmentVariableList.REACT_APP_CW_CASH_OFFER}/Services/Sell/Item/GetModelTrimDetails/`,\r\n {\r\n method: \"POST\",\r\n headers: new Headers({\r\n Accept: \"application/json\",\r\n \"Content-Type\": \"application/json\",\r\n }),\r\n body: JSON.stringify({\r\n ModelTrimId: result.aggregations.ModelId.buckets[0]\r\n ? result.aggregations.ModelId.buckets[0].key\r\n : null,\r\n }),\r\n }\r\n );\r\n let trimResult = await trimResponse.json();\r\n payload = {\r\n ItemTypeId: 3,\r\n Marine: {\r\n VIN: \"\",\r\n Make: form.getFieldValue(\"make\"),\r\n Model: form.getFieldValue(\"model\"),\r\n Series: form.getFieldValue(\"model\"),\r\n // Id: result.aggregations.ModelId.buckets[0]\r\n // ? result.aggregations.ModelId.buckets[0].key\r\n // : null,\r\n ModelTrimID: trimResult.ModelTrimID,\r\n SourceTypeId:\r\n window.location.pathname === \"/how-to/sell-your-boat-1\" ||\r\n state.dealerBrandType === \"campaign\"\r\n ? 15\r\n : 11,\r\n AppraisalStatusId: 1,\r\n GoogleCLID: \"\",\r\n CurrentStepNo: 1,\r\n TradeForItemId: null,\r\n Decoder: \"NADA\",\r\n ItemYear: form.getFieldValue(\"year\"),\r\n CategoryName: result.aggregations.ModelId.buckets[0].ModelType\r\n .buckets[0]\r\n ? result.aggregations.ModelId.buckets[0].ModelType.buckets[0].key\r\n : null,\r\n MarketingCategory: \"Boats/Personal Watercraft\",\r\n COEntryTypeId: 1,\r\n BeamInches: trimResult.BeamInches,\r\n HullMaterial: trimResult.HullMaterial,\r\n Brakes: trimResult.Marines_Brakes,\r\n LengthInches: trimResult.LengthInches,\r\n HorsePower: trimResult.HP,\r\n NumEngines: trimResult.NumEngines,\r\n Weight: trimResult.Weights,\r\n },\r\n };\r\n // console.log(\"ModelIdbuckets:\", result.aggregations.ModelId.buckets[0].ModelType.buckets[0].key);\r\n // console.log(\"ModelId:\", result.aggregations.ModelId.buckets[0].key);\r\n }\r\n if (\r\n window.location.pathname === \"/how-to/sell-your-vehicle-1\" ||\r\n window.location.pathname === \"/how-to/sell-your-boat-1\"\r\n ) {\r\n dispatch({\r\n type: SET_DEALER_BRAND,\r\n payload: \"campaign\",\r\n });\r\n } else {\r\n dispatch({\r\n type: SET_DEALER_BRAND,\r\n payload: queryString.parseUrl(window.location.search).query\r\n ?.utm_source,\r\n });\r\n }\r\n } catch (error) {\r\n console.log(error.message);\r\n }\r\n }\r\n\r\n const decodeVin = async (vin: string) => {\r\n try {\r\n dispatch({ type: RESET_STATE });\r\n dispatch({ type: SET_DECODE_REQUEST, payload: \"pending\" });\r\n\r\n const response = await fetch(\r\n `${environmentVariableList.REACT_APP_CW_CASH_OFFER}/api/${vin}/decode`\r\n );\r\n\r\n if (!response.ok) {\r\n if (!response.text) {\r\n const error = response.statusText || ERROR_MESSAGE.fetchFailed;\r\n console.log(\"Error:\", response.statusText, ERROR_MESSAGE.fetchFailed);\r\n throw Error(error);\r\n } else {\r\n //todo: api error response is weird here.\r\n const responseText = await response.text();\r\n const error = responseText.includes(\r\n \"already in our appraisal process\"\r\n )\r\n ? ERROR_MESSAGE.beingAppraised\r\n : dealerBrand === \"jdpower\" &&\r\n responseText.includes(\"Could not find vehicle with VIN\")\r\n ? `${responseText}. Please re-enter VIN or remove to select Year, Make, and Model`\r\n : responseText;\r\n\r\n console.log(\"Error:\", error);\r\n throw Error(error);\r\n }\r\n }\r\n\r\n const data = await response.json();\r\n if (\r\n form.getFieldValue(\"year\") !== null &&\r\n form.getFieldValue(\"year\") !== undefined &&\r\n form.getFieldValue(\"year\") !== \"\"\r\n ) {\r\n dispatch({ type: SET_COENTRY, payload: { COEntryTypeId: 3 } });\r\n } else {\r\n dispatch({ type: SET_COENTRY, payload: { COEntryTypeId: 2 } });\r\n }\r\n if (window.location.pathname === \"/how-to/sell-your-vehicle-1\") {\r\n dispatch({\r\n type: SET_DEALER_BRAND,\r\n payload: \"campaign\",\r\n });\r\n } else {\r\n dispatch({\r\n type: SET_DEALER_BRAND,\r\n payload: queryString.parseUrl(window.location.search).query\r\n ?.utm_source,\r\n });\r\n }\r\n dispatch({ type: SET_DECODE_REQUEST, payload: \"success\" });\r\n dispatch({ type: SET_DECODE_DATA, payload: data });\r\n dispatch({ type: SET_CURRENT_STEP, payload: 1 });\r\n } catch (error) {\r\n let errorMessage = error.message || ERROR_MESSAGE.default;\r\n if (error.message === ERROR_MESSAGE.fetchFailed) {\r\n errorMessage = ERROR_MESSAGE.requestFailed;\r\n } else if (error.message.includes(\"API calls quota exceeded\")) {\r\n errorMessage = ERROR_MESSAGE.limitExceeded;\r\n }\r\n\r\n dispatch({ type: SET_DECODE_REQUEST, payload: \"failure\" });\r\n dispatch({ type: SET_ERROR, payload: errorMessage });\r\n setFailCount((count) => count + 1);\r\n setFinished(false);\r\n console.error(error);\r\n }\r\n };\r\n\r\n const handleSubmit = (e: FormEvent<HTMLFormElement>): void => {\r\n // console.log(\"Vin\", form.getFieldValue(\"vin\"))\r\n e.preventDefault();\r\n form.validateFields(async (error: any, value: any) => {\r\n if (!error) {\r\n //forces useeffect to run when VIN is valid, but is stopped b/c decode limit is exceeded\r\n setFetching(true);\r\n if (\r\n window.location.href.includes(\"boat\") ||\r\n (form.getFieldValue(\"vin\") === \"\" &&\r\n form.getFieldValue(\"year\") !== undefined) ||\r\n ((dealerBrand === \"jdpower\" ||\r\n window.location.pathname === \"/how-to/sell-your-vehicle-1\") &&\r\n (form.getFieldValue(\"vin\") === \"\" ||\r\n form.getFieldValue(\"vin\") === undefined ||\r\n form.getFieldValue(\"vin\") === null) &&\r\n form.getFieldValue(\"year\") !== undefined)\r\n ) {\r\n await fetchOffers3();\r\n\r\n try {\r\n dispatch({ type: RESET_ERROR });\r\n dispatch({ type: SET_CREATE_REQUEST, payload: \"pending\" });\r\n\r\n const ItemTypeId: any = window.location.href.includes(\"boat\")\r\n ? 3\r\n : 1;\r\n ///Services/Sell/Item/Update\r\n const response = await fetch(\r\n `${environmentVariableList.REACT_APP_CW_CASH_OFFER}/Services/Sell/Item/Create`,\r\n {\r\n method: \"POST\",\r\n headers: new Headers({\r\n Accept: \"application/json\",\r\n \"Content-Type\": \"application/json\",\r\n }),\r\n body: JSON.stringify(payload),\r\n }\r\n );\r\n\r\n if (!response.ok) {\r\n if (!response.json) {\r\n throw Error(response.statusText || ERROR_MESSAGE.fetchFailed);\r\n }\r\n const error = await response.json();\r\n throw Error(error?.Error?.Message || ERROR_MESSAGE.default);\r\n }\r\n\r\n const data = await response.json();\r\n\r\n const appraisalRefNo =\r\n data[\r\n ItemTypeId === 1\r\n ? \"SellItemBike\"\r\n : ItemTypeId === 3\r\n ? \"SellItemMarine\"\r\n : \"SellItemCar\"\r\n ].AppraisalRefNo;\r\n dispatch({ type: SET_DECODE_REQUEST, payload: \"success\" });\r\n dispatch({ type: SET_CREATE_REQUEST, payload: \"success\" });\r\n window.location.href.includes(\"boat\")\r\n ? dispatch({\r\n type: SET_DECODE_DATA,\r\n payload: {\r\n Category: data.SellItemMarine.CategoryName,\r\n Decoder: \"NADA\",\r\n ItemTypeId: 3,\r\n LicensePlate: \"\",\r\n Make: data.SellItemMarine.Make,\r\n MarketingCategory: data.SellItemMarine.MarketingCategory,\r\n Model: data.SellItemMarine.Model,\r\n Models: [data.SellItemMarine.Model],\r\n VIN: \"\",\r\n Year: data.SellItemMarine.ItemYear,\r\n ModelTrimId: data.SellItemMarine.ModelTrimId,\r\n Weight: data.SellItemMarine.Weight,\r\n BeamInches: data.SellItemMarine.BeamInches,\r\n HorsePower: data.SellItemMarine.HorsePower,\r\n LengthInches: data.SellItemMarine.LengthInches,\r\n NumEngines: data.SellItemMarine.NumEngines,\r\n Brakes: data.SellItemMarine.Brakes,\r\n HullMaterial: data.SellItemMarine.HullMaterial,\r\n },\r\n })\r\n : dispatch({\r\n type: SET_DECODE_DATA,\r\n payload: {\r\n Category: data.SellItemBike.CategoryName,\r\n Decoder: \"NADA\",\r\n ItemTypeId: 1,\r\n LicensePlate: \"\",\r\n Make: data.SellItemBike.Make,\r\n MarketingCategory: data.SellItemBike.MarketingCategory,\r\n Models: [data.SellItemBike.Model],\r\n VIN: \"\",\r\n Year: data.SellItemBike.ItemYear,\r\n },\r\n });\r\n dispatch({ type: SET_APPRAISAL_REF, payload: appraisalRefNo });\r\n dispatch({ type: SET_CURRENT_STEP, payload: 2 });\r\n } catch (error) {\r\n dispatch({ type: SET_CREATE_REQUEST, payload: \"failure\" });\r\n dispatch({ type: SET_ERROR, payload: error.message });\r\n console.error(error);\r\n } finally {\r\n setFetching(false);\r\n }\r\n } else {\r\n setFetching(false);\r\n setFinished(true);\r\n setVin(value.vin);\r\n console.log(\"not working!!!!\");\r\n }\r\n }\r\n });\r\n };\r\n // console.log(\"create request:::\", state.decodeRequest)\r\n // console.log(\"state.bothInfoinvin decode:::\", state.bothInfo)\r\n const handleScroll = () => {\r\n window.scrollTo(0, 0);\r\n };\r\n\r\n useEffect(() => {\r\n handleScroll();\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (state.decodeRequest === \"pending\") {\r\n handleScroll();\r\n }\r\n }, [state.decodeRequest]);\r\n\r\n useEffect(() => {\r\n if (vin && finished) {\r\n decodeVin(vin);\r\n }\r\n }, [finished, vin]);\r\n\r\n useEffect(() => {\r\n if (history?.location?.state?.currentVin) {\r\n setVin(history?.location?.state?.currentVin);\r\n setFinished(true);\r\n }\r\n }, [history?.location?.state?.currentVin]);\r\n\r\n useEffect(() => {\r\n if (\r\n state.decodeRequest === \"success\" &&\r\n state.decodeData &&\r\n window.location.pathname !== \"/list-your-vehicle-for-a-dealer\"\r\n ) {\r\n dispatch({ type: SET_DECODE_REQUEST, payload: \"idle\" });\r\n let nextStep = `${NEXT_STEP}/${state.decodeData.MarketingCategory}`;\r\n let historyState = {};\r\n let search = \"\";\r\n\r\n if (history.location?.state) {\r\n const { renewOffer, renewData } = history?.location?.state;\r\n const isRenewCashOfferFlow = renewOffer && renewData;\r\n const isTradeInFlow = trade && listingId;\r\n\r\n if (isRenewCashOfferFlow) {\r\n historyState = {\r\n renewData,\r\n renewOffer: true,\r\n };\r\n } else if (isTradeInFlow) {\r\n historyState = {\r\n ...history?.location?.state,\r\n };\r\n search = \"?trade=true\";\r\n }\r\n }\r\n\r\n history.push({\r\n pathname: nextStep,\r\n search: window.location.search,\r\n state: { ...historyState },\r\n });\r\n }\r\n }, [state.decodeData, state.decodeRequest, history?.location?.state]);\r\n\r\n //remove trade in query param\r\n useEffect(() => {\r\n if (trade && !listingId) {\r\n const params = queryString.exclude(history.location.search, [\"trade\"], {\r\n sort: false,\r\n });\r\n history.replace(history.location.pathname + params);\r\n }\r\n }, [trade, authState.isLoggedIn]);\r\n\r\n return (\r\n <Row>\r\n <Col>\r\n <Form\r\n onSubmit={handleSubmit}\r\n hideRequiredMark={true}\r\n colon={false}\r\n css={css`\r\n display: flex;\r\n justify-content: center;\r\n flex-direction: column;\r\n align-items: center;\r\n > div {\r\n width: 100%;\r\n }\r\n .ant-form-item {\r\n margin-bottom: 14px !important;\r\n @media (max-width: 990px) {\r\n margin-bottom: 4px !important;\r\n }\r\n }\r\n `}\r\n >\r\n {window.location.href.includes(\"vehicle\") && (\r\n <Item\r\n extra={\r\n !form.getFieldError(\"vin\")?.length && (\r\n <span\r\n css={css`\r\n text-align: left;\r\n padding-left: 1rem;\r\n font: 12px interstate;\r\n letter-spacing: 0px;\r\n color: #2b2b2b;\r\n text-transform: uppercase;\r\n opacity: 1;\r\n color: ${colors.darkCharcoal};\r\n ${props.extraTextCss}\r\n `}\r\n >\r\n The letters I, O, and Q are not accepted.\r\n </span>\r\n )\r\n }\r\n >\r\n {form.getFieldDecorator(\"vin\", {\r\n initialValue: vin,\r\n normalize: (v: string) =>\r\n v ? v.replace(/\\W|\\_/g, \"\").toUpperCase() : \"\",\r\n rules: VALIDATION_RULES,\r\n validateTrigger: \"onSubmit\",\r\n })(\r\n <FloatingLabelInput\r\n label=\"VEHICLE IDENTIFICATION NUMBER\"\r\n maxLength={17}\r\n disabled={loading}\r\n extraCss={`\r\n letter-spacing: 0.5px;\r\n font-size: 16px;\r\n `}\r\n />\r\n )}\r\n </Item>\r\n )}\r\n {state.decodeRequest === \"failure\" && (\r\n <ErrorMessage error={state.error} failedCount={failedCount} />\r\n )}\r\n {/* Add it back if we get the geoLocation back-> isTexas && */}\r\n {(window.location.href.includes(\"/how-to/sell-your-vehicle\") &&\r\n dealerBrand === \"jdpower\") ||\r\n window.location.pathname === \"/how-to/sell-your-vehicle-1\" ||\r\n (window.location.pathname === \"/list-your-vehicle-for-a-dealer\" && (\r\n <Row\r\n css={css`\r\n display: flex;\r\n flex-direction: column;\r\n width: 100%;\r\n `}\r\n >\r\n {\" \"}\r\n <Row\r\n css={css`\r\n text-align: center;\r\n `}\r\n >\r\n <h3>OR</h3>\r\n </Row>\r\n <Row>\r\n <h3>ENTER YOUR YEAR, MAKE AND MODEL TO GET YOUR OFFER</h3>\r\n </Row>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"year\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect\r\n label=\"YEAR\"\r\n disabled={\r\n form.getFieldValue(\"vin\") === \"\" ? false : true\r\n }\r\n >\r\n {yearList.length > 0 &&\r\n yearList\r\n .sort((a: any, b: any) => (a.key > b.key ? -1 : 1))\r\n .map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.startCase(_.toUpper(i.key))}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING YEAR</span>\r\n </Col>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"make\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect\r\n label=\"MAKE\"\r\n disabled={\r\n form.getFieldValue(\"year\") === undefined ||\r\n form.getFieldValue(\"vin\") !== \"\"\r\n ? true\r\n : false\r\n }\r\n >\r\n {MakeList.length > 0 &&\r\n MakeList.sort((a: any, b: any) =>\r\n a.key < b.key ? -1 : 1\r\n ).map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.startCase(_.toUpper(i.key))}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING MAKE</span>\r\n </Col>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"model\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect\r\n label=\"MODEL\"\r\n disabled={\r\n form.getFieldValue(\"make\") === undefined ||\r\n form.getFieldValue(\"year\") === undefined ||\r\n form.getFieldValue(\"vin\") !== \"\"\r\n ? true\r\n : false\r\n }\r\n >\r\n {ModelList.length > 0 &&\r\n ModelList.sort((a: any, b: any) =>\r\n a.key < b.key ? -1 : 1\r\n ).map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.toUpper(i.key)}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING MODEL</span>\r\n </Col>\r\n </Row>\r\n ))}\r\n\r\n {window.location.href.includes(\"/how-to/sell-your-boat\") && (\r\n <Row\r\n css={css`\r\n display: flex;\r\n flex-direction: column;\r\n width: 100%;\r\n `}\r\n >\r\n {\" \"}\r\n <Row\r\n css={css`\r\n text-align: center;\r\n `}\r\n ></Row>\r\n <Row>\r\n <h3>ENTER YOUR YEAR, MAKE AND MODEL TO GET YOUR OFFER</h3>\r\n </Row>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"year\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect label=\"YEAR\">\r\n {yearList.length > 0 &&\r\n yearList\r\n .sort((a: any, b: any) => (a.key > b.key ? -1 : 1))\r\n .map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.startCase(_.toUpper(i.key))}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING YEAR</span>\r\n </Col>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"make\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect\r\n label=\"MAKE\"\r\n disabled={form.getFieldValue(\"year\") === undefined}\r\n >\r\n {MakeList.length > 0 &&\r\n MakeList.sort((a: any, b: any) =>\r\n a.key < b.key ? -1 : 1\r\n ).map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.startCase(_.toUpper(i.key))}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING MAKE</span>\r\n </Col>\r\n <Col span={24}>\r\n <Item>\r\n {form.getFieldDecorator(\"model\", {\r\n rules: [\r\n {\r\n required:\r\n form.getFieldValue(\"vin\") === \"\" ? true : false,\r\n message: \"Please select one\",\r\n },\r\n ],\r\n })(\r\n <CustomSelect\r\n label=\"MODEL\"\r\n disabled={\r\n form.getFieldValue(\"make\") === undefined ||\r\n form.getFieldValue(\"year\") === undefined\r\n }\r\n >\r\n {ModelList.length > 0 &&\r\n ModelList.sort((a: any, b: any) =>\r\n a.key < b.key ? -1 : 1\r\n ).map((i: any) => (\r\n <Select.Option value={i.key} key={i.key}>\r\n {_.toUpper(i.key)}\r\n </Select.Option>\r\n ))}\r\n </CustomSelect>\r\n )}\r\n </Item>\r\n <span css={inputTipCss}>SELECT THE BEST MATCHING MODEL</span>\r\n </Col>\r\n </Row>\r\n )}\r\n {/* {dealerBrand === \"jdpower\" && ( */}\r\n <CustomButton\r\n htmlType=\"submit\"\r\n // disabled={\r\n // form.getFieldValue(\"vin\") !== undefined\r\n // ? form.getFieldValue(\"vin\") === undefined\r\n // : form.getFieldValue(\"make\") === undefined ||\r\n // form.getFieldValue(\"year\") === undefined ||\r\n // form.getFieldValue(\"model\") === undefined\r\n // }\r\n css={css`\r\n width: 100%;\r\n height: 48px;\r\n ${props.buttonCss}\r\n `}\r\n filled\r\n loading={loading || fetching}\r\n >\r\n Get your offer\r\n </CustomButton>\r\n {/* )}\r\n {dealerBrand !== \"jdpower\" && (\r\n <CustomButton\r\n htmlType=\"submit\"\r\n disabled={form.getFieldValue(\"vin\") === undefined}\r\n css={css`\r\n width: 100%;\r\n height: 48px;\r\n ${props.buttonCss}\r\n `}\r\n filled\r\n loading={loading || fetching}\r\n >\r\n Get your offer\r\n </CustomButton>\r\n )} */}\r\n </Form>\r\n </Col>\r\n </Row>\r\n );\r\n};\r\n\r\nconst ErrorMessage: FC<{ error: string; failedCount: number }> = ({\r\n error,\r\n failedCount,\r\n}) => {\r\n return failedCount >= 3 && error && error.includes(\"Could not find\") ? (\r\n <Alert\r\n message=\"Sorry, we couldn't decode this VIN\"\r\n description={\r\n <ul>\r\n <li>Make sure you choose the right vehicle type.</li>\r\n <li>\r\n Make sure the VIN you entered doesn't contain the letters I, O, or Q\r\n since these letters are never used in VINs.\r\n </li>\r\n <li>\r\n If you are certain you have entered your 17-character VIN without\r\n any mistaken digits and still receive an error, we may not have\r\n enough market data to pull your vehicle's information properly. If\r\n this is the case, unfortunately, we are unable to make an offer on\r\n the vehicle at this time.\r\n </li>\r\n </ul>\r\n }\r\n type=\"error\"\r\n showIcon\r\n banner\r\n css={css`\r\n ul {\r\n padding: 0px;\r\n }\r\n margin-bottom: 1.5rem !important;\r\n `}\r\n />\r\n ) : error === ERROR_MESSAGE.beingAppraised ? (\r\n <div\r\n style={{\r\n backgroundColor: \"lightpink\",\r\n padding: \"2%\",\r\n marginBottom: \"2%\",\r\n }}\r\n >\r\n {error}{\" \"}\r\n <span>\r\n Feel free to reach us at{\" \"}\r\n <a\r\n style={{ color: \"blue\", textDecoration: \"underline\" }}\r\n href={`tel:${5732984851}`}\r\n >\r\n {\"(573) 298-4851\"}\r\n </a>{\" \"}\r\n for any questions.\r\n </span>\r\n </div>\r\n ) : (\r\n <Alert\r\n message={error}\r\n type=\"error\"\r\n showIcon\r\n banner\r\n css={css`\r\n margin-bottom: 1.5rem !important;\r\n `}\r\n />\r\n );\r\n};\r\n\r\ninterface SubmitVinBanner extends FormComponentProps {\r\n header: string;\r\n}\r\nconst SubmitVinBannerComponent: FC<SubmitVinBanner> = ({ form, header }) => {\r\n const history = useHistory();\r\n\r\n const { dispatch } = useCashOfferContext();\r\n\r\n const handleSubmit = (e?: FormEvent) => {\r\n e && e.preventDefault();\r\n form.validateFields((error: any, value: { vin: string }) => {\r\n if (!error) {\r\n if (\r\n window.location.href.includes(\"jdpower\") ||\r\n window.location.href.includes(\"lawtiger\") ||\r\n window.location.href.includes(\"cycletrader\")\r\n ) {\r\n dispatch({ type: RESET_STATE });\r\n history.push(window.location.search, {\r\n currentVin: value.vin,\r\n });\r\n } else {\r\n dispatch({ type: RESET_STATE });\r\n if (window.location.pathname === \"/how-to/sell-your-vehicle-1\") {\r\n history.push(\"/how-to/sell-your-vehicle-1\", {\r\n currentVin: value.vin,\r\n });\r\n } else if (window.location.pathname === \"/how-to/sell-your-boat-1\") {\r\n history.push(\"/how-to/sell-your-boat-1\", {\r\n currentVin: value.vin,\r\n });\r\n } else if (window.location.pathname === \"/how-to/sell-your-vehicle\") {\r\n history.push(\"/how-to/sell-your-vehicle\", {\r\n currentVin: value.vin,\r\n });\r\n } else if (\r\n window.location.pathname === \"/list-your-vehicle-for-a-dealer\"\r\n ) {\r\n history.push(\"/list-your-vehicle-for-a-dealer\", {\r\n currentVin: value.vin,\r\n });\r\n }\r\n }\r\n }\r\n });\r\n };\r\n\r\n return (\r\n <Form onSubmit={handleSubmit}>\r\n <Row\r\n css={css`\r\n background-image: url(${DecoderBanner});\r\n background-repeat: no-repeat;\r\n background-size: cover;\r\n background-position: center;\r\n height: 154px;\r\n padding: 1.5rem 0.75rem 0;\r\n h4 {\r\n font-family: interstate;\r\n text-transform: uppercase;\r\n color: white;\r\n text-align: center;\r\n font-size: 16px;\r\n ${minMedia[1]} {\r\n font-size: 20px;\r\n }\r\n }\r\n ${minMedia[0]} {\r\n height: 172px;\r\n padding-top: 1rem;\r\n }\r\n ${minMedia[3]} {\r\n padding-top: 2rem;\r\n }\r\n `}\r\n >\r\n <Col\r\n xs={{ span: 24 }}\r\n md={{ span: 16, offset: 4 }}\r\n xl={{ span: 10, offset: 7 }}\r\n >\r\n <Row>\r\n <h4>{window.location.href.includes(\"vehicle\") && header}</h4>\r\n </Row>\r\n <Row>\r\n {!window.location.href.includes(\"boat\") && (\r\n <Col xs={{ span: 24 }} sm={{ span: 0 }}>\r\n <Form.Item>\r\n {form.getFieldDecorator(\"vin\", {\r\n normalize: (v: string) =>\r\n v ? v.replace(/\\W|\\_/g, \"\").toUpperCase() : \"\",\r\n rules: VALIDATION_RULES,\r\n })(\r\n <>\r\n <Input.Search\r\n size=\"large\"\r\n maxLength={17}\r\n placeholder=\"Your VIN\"\r\n value={form.getFieldValue(\"vin\")}\r\n onChange={(e) => {\r\n form.setFieldsValue({\r\n vin: e.target.value,\r\n });\r\n form.validateFields();\r\n }}\r\n onSearch={(_value, _) => handleSubmit()}\r\n enterButton={\"Get offer\"}\r\n css={css`\r\n input {\r\n border-color: #d9d9d9 !important;\r\n box-shadow: none !important;\r\n &:hover,\r\n &:focus {\r\n box-shadow: none;\r\n border-color: #d9d9d9;\r\n }\r\n }\r\n\r\n button {\r\n background: white;\r\n border-color: #d9d9d9;\r\n border-left: 0;\r\n color: ${colors.purple};\r\n &:hover,\r\n &:focus {\r\n color: ${colors.purple};\r\n box-shadow: none;\r\n background: white;\r\n border-color: #d9d9d9;\r\n }\r\n }\r\n `}\r\n />\r\n </>\r\n )}\r\n </Form.Item>\r\n </Col>\r\n )}\r\n <Col xs={{ span: 0 }} sm={{ span: 24 }}>\r\n <Row gutter={16}>\r\n <Col\r\n span={12}\r\n css={css`\r\n button,\r\n input {\r\n height: 56px;\r\n }\r\n `}\r\n >\r\n {window.location.href.includes(\"vehicle\") && (\r\n <Form.Item>\r\n {form.getFieldDecorator(\"vin\", {\r\n normalize: (v: string) =>\r\n v ? v.replace(/\\W|\\_/g, \"\").toUpperCase() : \"\",\r\n rules: VALIDATION_RULES,\r\n })(\r\n <Input\r\n size=\"large\"\r\n maxLength={17}\r\n placeholder=\"Your VIN\"\r\n />\r\n )}\r\n </Form.Item>\r\n )}\r\n </Col>\r\n <Col span={12}>\r\n {window.location.href.includes(\"vehicle\") && (\r\n <CustomButton\r\n htmlType=\"submit\"\r\n css={css`\r\n width: 100%;\r\n height: 56px;\r\n font-size: 16px;\r\n `}\r\n >\r\n Get your offer\r\n </CustomButton>\r\n )}\r\n </Col>\r\n </Row>\r\n </Col>\r\n </Row>\r\n </Col>\r\n </Row>\r\n </Form>\r\n );\r\n};\r\nconst inputTipCss = css`\r\n display: flex;\r\n font-size: 12px;\r\n padding-left: 1rem;\r\n color: white;\r\n margin-bottom: 14px !important;\r\n @media (max-width: 990px) {\r\n color: black;\r\n }\r\n`;\r\n\r\nexport const SubmitVinBanner = Form.create<SubmitVinBanner>()(\r\n SubmitVinBannerComponent\r\n);\r\n\r\nexport default Form.create<Props>({ name: \"vin-decoder-form\" })(\r\n VinDecoderComponent\r\n);\r\n"],"sourceRoot":""}