@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.js +254 -215
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/insurances/car/pages/quote/sections/VehicleOfferCoverage.d.ts +3 -0
- package/dist/cjs/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverage.d.ts +9 -0
- package/dist/cjs/shared/headers/HeaderDesktop/BeginInsurance.d.ts +3 -0
- package/dist/cjs/shared/headers/HeaderDesktop/index.d.ts +1 -0
- package/dist/cjs/shared/headers/HeaderMobile/BeginInsurance.d.ts +3 -0
- package/dist/cjs/shared/headers/HeaderMobile/index.d.ts +1 -0
- package/dist/esm/index.js +254 -217
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/insurances/car/pages/quote/sections/VehicleOfferCoverage.d.ts +3 -0
- package/dist/esm/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverage.d.ts +9 -0
- package/dist/esm/shared/headers/HeaderDesktop/BeginInsurance.d.ts +3 -0
- package/dist/esm/shared/headers/HeaderDesktop/index.d.ts +1 -0
- package/dist/esm/shared/headers/HeaderMobile/BeginInsurance.d.ts +3 -0
- package/dist/esm/shared/headers/HeaderMobile/index.d.ts +1 -0
- package/dist/index.d.ts +5 -1
- package/package.json +4 -4
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
2
|
import { ErrorBoundary } from 'react-error-boundary';
|
|
3
|
-
import { AppTypes, TitleForm, TooltipForm, IconDelete, ColorVariablesTypes, InputTypes, InputForm, InputFormPhone, InputFormEmail, InputFormLicence, SelectForm, getFormattedDate, DateTypes, getDateOptions, ButtonForm, defaultBrokerPhone, DriverPriorityTypes, SizeTypes, ButtonBase, CategoryTypes, ColorTypes, defaultLocalIndex, liabilityOptions, coverageOptions, lossOfUseOptions, liabilityForDamageOptions, limitedWaiverOfDepreciationOptions, OfferDetail, CompanyRoleTypes, OperationHoursInfo, OfferHeader, OfferPrice, ButtonTypes, ButtonVariantTypes, IconDropdownArrow, InsuranceTypes, HeaderNavGroup, ButtonMenu, DeviceTypes, IconLoaderPrimary, getInsuranceType, RequestStatusTypes, formatPostalCode, IconLoaderSecondary, postalCodeFormat, useEffectOnce, carCondition, carStatus, carWinterTiresCheck, carKeepPlace, carUsagePurpose, firstDriveDistanceList, dailyDriveBusinessDistanceList, yearlyDriveDistanceList, numberWithCommas, VehiclePrimaryUseTypes, comprehensiveCoverage, collisionCoverage, maritalStatusOptions, subYearsFromDate, occupationOptions, genderOptions, applicantRelationshipOptions, addYearsToDate, checkDateIsSpecial, DriverLicenceTypes, getDifferenceInYears, getLicenceTypeOptions, getDisabledLicenceTypes, yesNoOptions, addDaysToDate, getMinDate, CheckboxForm, getMinDateByYears, compareDates, insuranceCancellationReasonOptions, DriverListTypes, licenceSuspensionsReasonOptions, trafficTicketsGroupOptions, ValidationStatusTypes, QuoteEdit, homeOwnerTypeOptions, tenantBuildingStructureOptions, condoBuildingStructureOptions, homeBuildingStructureOptions, residentsOptions, insuredYearsOptions, getInsuranceYearsOptions, ApplicantListTypes, claimTypeOptions, exteriorFinishOptions, constructionTypeOptions, garageTypeOptions, getNumericOptions, fireHallDistanceOptions, fireHydrantDistanceOptions, primaryHeatingTypeOptions, auxHeatingTypeOptions, InfoMessage, ppOptions, homeCoverageOptions, homeLiabilityOptions, lifeInsuranceTypeOptions, lifeInsuranceOntarioTypeOptions, lifeCoverageOptions, smokerOptions, MychoiceStep, Step, IconClock, ButtonArrow, DirectionTypes, ButtonTabArrow, ButtonTab, ButtonTabMobile, NavigationCar, NavigationPerson, NavigationDiscount, NavigationQuotes, NavigationAddress, NavigationProperty, ModalTypes } from '@mychoice/mychoice-sdk-components';
|
|
3
|
+
import { AppTypes, isMyChoiceLike, TitleForm, TooltipForm, IconDelete, ColorVariablesTypes, InputTypes, InputForm, InputFormPhone, InputFormEmail, InputFormLicence, SelectForm, getFormattedDate, DateTypes, getDateOptions, ButtonForm, defaultBrokerPhone, DriverPriorityTypes, SizeTypes, ButtonBase, CategoryTypes, ColorTypes, defaultLocalIndex, liabilityOptions, coverageOptions, lossOfUseOptions, liabilityForDamageOptions, limitedWaiverOfDepreciationOptions, OfferDetail, CompanyRoleTypes, OperationHoursInfo, OfferHeader, OfferPrice, ButtonTypes, ButtonVariantTypes, IconDropdownArrow, InsuranceTypes, HeaderNavGroup, ButtonMenu, DeviceTypes, IconLoaderPrimary, getInsuranceType, RequestStatusTypes, formatPostalCode, IconLoaderSecondary, postalCodeFormat, useEffectOnce, carCondition, carStatus, carWinterTiresCheck, carKeepPlace, carUsagePurpose, firstDriveDistanceList, dailyDriveBusinessDistanceList, yearlyDriveDistanceList, numberWithCommas, VehiclePrimaryUseTypes, comprehensiveCoverage, collisionCoverage, maritalStatusOptions, subYearsFromDate, occupationOptions, genderOptions, applicantRelationshipOptions, addYearsToDate, checkDateIsSpecial, DriverLicenceTypes, getDifferenceInYears, getLicenceTypeOptions, getDisabledLicenceTypes, yesNoOptions, addDaysToDate, getMinDate, CheckboxForm, getMinDateByYears, compareDates, insuranceCancellationReasonOptions, DriverListTypes, licenceSuspensionsReasonOptions, trafficTicketsGroupOptions, ValidationStatusTypes, getPlaceholderEmail, QuoteEdit, homeOwnerTypeOptions, tenantBuildingStructureOptions, condoBuildingStructureOptions, homeBuildingStructureOptions, residentsOptions, insuredYearsOptions, getInsuranceYearsOptions, ApplicantListTypes, claimTypeOptions, exteriorFinishOptions, constructionTypeOptions, garageTypeOptions, getNumericOptions, fireHallDistanceOptions, fireHydrantDistanceOptions, primaryHeatingTypeOptions, auxHeatingTypeOptions, InfoMessage, ppOptions, homeCoverageOptions, homeLiabilityOptions, lifeInsuranceTypeOptions, lifeInsuranceOntarioTypeOptions, lifeCoverageOptions, smokerOptions, MychoiceStep, Step, IconClock, ButtonArrow, DirectionTypes, ButtonTabArrow, ButtonTab, ButtonTabMobile, NavigationCar, NavigationPerson, NavigationDiscount, NavigationQuotes, NavigationAddress, NavigationProperty, ModalTypes } from '@mychoice/mychoice-sdk-components';
|
|
4
4
|
import { useStoreAppConfig, useStoreFormCarVehicle, useStoreFormCarDriverBase, useStoreFormCarDiscount, StoreFormCarDiscountActionTypes, useStoreFormCarQuote, CarQuoteDataHandler, useValidationCarDiscount, StoreFormCarVehicleActionTypes, useStorePartner, useStoreDeviceType, useStoreAppLoader, useStoreAppModal, StoreConfigAppModalActionTypes, useHandlerPostal, useHandlerCarMake, useHandlerCarModel, useProvince, useValidationVehicle, StoreFormCarDriverBaseActionTypes, useStoreFormCarConfig, useStoreFormCarDriverInfo, StoreFormCarDriverInfoActionTypes, useStoreFormCarDriverLicence, addDayToDate, StoreFormCarDriverLicenceActionTypes, useStoreFormCarDriverInsurance, StoreFormCarDriverInsuranceActionTypes, useStoreFormCarDriverCancellation, StoreFormCarDriverCancellationActionTypes, useStoreFormCarDriverSuspension, StoreFormCarDriverSuspensionActionTypes, useStoreFormCarDriverAccident, StoreFormCarDriverAccidentActionTypes, useStoreFormCarDriverTicket, StoreFormCarDriverTicketActionTypes, useValidationDriver, useHandlerCarQuoterEmail, useStoreFormHomeDwelling, useStoreFormHomePostal, useStoreFormHomeApplicantBase, StoreFormHomePostalActionTypes, StoreFormHomeDwellingActionTypes, StoreConfigAppConfigActionTypes, StoreFormHomeApplicantBaseActionTypes, useValidationAddress, useStoreFormHomeApplicantInfo, useStoreFormHomeDiscount, StoreFormHomeDiscountActionTypes, StoreFormHomeApplicantInfoActionTypes, useStoreFormHomeApplicantInsurance, StoreFormHomeApplicantInsuranceActionTypes, useStoreFormHomeApplicantCancellation, StoreFormHomeApplicantCancellationActionTypes, useStoreFormHomeApplicantClaim, StoreFormHomeApplicantClaimActionTypes, useValidationApplicant, useValidationDwelling, useStoreFormHomeQuote, HomeQuoteDataHandler, useValidationHomeDiscount, useHandlerHomeQuoterEmail, useStoreFormLifeCoverage, StoreFormLifeCoverageActionTypes, useValidationCoverage, useStoreFormLifeQuote, useStoreFormLifeApplicant, LifeQuoteDataHandler, useValidationLifeApplicant, useHandlerLifeQuoterEmail, StoreFormLifeApplicantActionTypes, useStoreFormCarPostal, useStoreFormLifePostal, ClearFormDataHandler, useStoreAppDevice, useStoreClient, useHandlerAuth, useHandlerPartner, StoreConfigAppLoaderActionTypes, StoreFormCarConfigActionTypes, StoreFormCarPostalActionTypes, StoreFormCarQuoteActionTypes, StoreFormHomeQuoteActionTypes, StoreFormLifePostalActionTypes, StoreFormLifeQuoteActionTypes, StoreClientActionTypes, StoreConfigAppDeviceActionTypes, StoreProvider, initHttpResponse } from '@mychoice/mychoice-sdk-store';
|
|
5
5
|
import { useNavigate, useLocation, BrowserRouter, Routes, Route, Navigate } from 'react-router-dom';
|
|
6
6
|
import React, { useState, useCallback, useEffect, useRef, useMemo } from 'react';
|
|
@@ -12,13 +12,11 @@ import TagManager from 'react-gtm-module';
|
|
|
12
12
|
import 'react-phone-input-2/lib/style.css';
|
|
13
13
|
|
|
14
14
|
const LabelFormBox = (props) => {
|
|
15
|
-
const { name, className, title, subTitle, description, isRemovable, onIconClick, isActive
|
|
16
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
15
|
+
const { name, className, title, subTitle, description, isRemovable, onIconClick, isActive } = props;
|
|
16
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
17
17
|
const isThebig = appType === AppTypes.TheBig;
|
|
18
|
-
const isMychoice = appType
|
|
19
|
-
return (jsxs("div", { className: `label-container ${className}`, children: [jsx(TitleForm, { className: isThebig ? 'thebig-medium' : '', title: title, subTitle: subTitle, isActive: isActive }),
|
|
20
|
-
&& jsx(TooltipForm, { id: `${name.toLowerCase()}-tooltip`, description: description, color: isMychoice ? '#F7C2D9' : '' }), isRemovable
|
|
21
|
-
&& (jsx(IconDelete, { className: "icon-label-delete", onClick: onIconClick, color: ColorVariablesTypes.Primary, height: "1.125rem", width: "1.125rem" }))] }));
|
|
18
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
19
|
+
return (jsxs("div", { className: `label-container ${className}`, children: [jsx(TitleForm, { className: isThebig ? 'thebig-medium' : '', title: title, subTitle: subTitle, isActive: isActive }), name && description && (jsx(TooltipForm, { id: `${name.toLowerCase()}-tooltip`, description: description, color: isMychoice ? '#F7C2D9' : '' })), isRemovable && (jsx(IconDelete, { className: "icon-label-delete", onClick: onIconClick, color: ColorVariablesTypes.Primary, height: "1.125rem", width: "1.125rem" }))] }));
|
|
22
20
|
};
|
|
23
21
|
LabelFormBox.defaultProps = {
|
|
24
22
|
className: '',
|
|
@@ -109,11 +107,11 @@ DateSelectFormBox.defaultProps = {
|
|
|
109
107
|
};
|
|
110
108
|
|
|
111
109
|
const SwitchButtonBox = (props) => {
|
|
112
|
-
const { name, title, description, hintMessage, isRemovable, errorMessage, className, defaultValue, items, onChange
|
|
110
|
+
const { name, title, description, hintMessage, isRemovable, errorMessage, className, defaultValue, items, onChange } = props;
|
|
113
111
|
const [activeId, setActiveId] = useState(defaultValue);
|
|
114
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
112
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
115
113
|
const isTheBig = appType === AppTypes.TheBig;
|
|
116
|
-
const isMychoice = appType
|
|
114
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
117
115
|
const setClassNames = (isActive) => {
|
|
118
116
|
if (isTheBig) {
|
|
119
117
|
return isActive ? 'thebig-bold' : 'thebig-regular';
|
|
@@ -223,9 +221,14 @@ const BlockVehLinks = () => {
|
|
|
223
221
|
};
|
|
224
222
|
|
|
225
223
|
const BlockNextPageInfo$2 = () => {
|
|
226
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
227
|
-
|
|
228
|
-
|
|
224
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
225
|
+
if (appType === AppTypes.TheBig) {
|
|
226
|
+
return (jsx("div", { className: "privacy-policy", children: jsxs("p", { children: [jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) }));
|
|
227
|
+
}
|
|
228
|
+
if (appType === AppTypes.MyChoice) {
|
|
229
|
+
return (jsxs(Fragment, { children: [jsx("h5", { children: "On the next page, you will also be able to:" }), jsxs("div", { className: "next-page-points", children: [jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsx("div", { className: "privacy-policy", children: jsxs("p", { children: ["Once you submit this form, you are agreeing to have your insurance quote sent to you via email and My Choice will provide your contact information to one of our trusted broker partners, who will contact you after your quote is complete to further assist you in securing your best rate. For more details, see our", jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] }));
|
|
230
|
+
}
|
|
231
|
+
return null;
|
|
229
232
|
};
|
|
230
233
|
|
|
231
234
|
const BlockSubmit$2 = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
@@ -378,8 +381,8 @@ const OfferSection = ({ offerCompany, brokerCompany, offerPrice, phoneNumber, is
|
|
|
378
381
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
379
382
|
const { postRequestQuoteOnliaUrl } = CarQuoteDataHandler();
|
|
380
383
|
const isTheBig = appType === AppTypes.TheBig;
|
|
381
|
-
const isMyChoice = appType
|
|
382
|
-
const mychoiceCls = appType
|
|
384
|
+
const isMyChoice = isMyChoiceLike(appType);
|
|
385
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
383
386
|
const { weekdayHours, saturdayHours, sundayHours } = operationHours;
|
|
384
387
|
const [detailsIsOpen, setDetailsIsOpenIsOpen] = useState(isBestOffer ?? false);
|
|
385
388
|
const handleDropdownClick = () => {
|
|
@@ -415,66 +418,73 @@ OfferSection.defaultProps = {
|
|
|
415
418
|
isBestOffer: false,
|
|
416
419
|
};
|
|
417
420
|
|
|
418
|
-
var logo = "";
|
|
421
|
+
var logo$1 = "";
|
|
419
422
|
|
|
420
|
-
const TITLE = {
|
|
423
|
+
var logo = "";
|
|
424
|
+
|
|
425
|
+
const TITLE_MYCHOICE = {
|
|
421
426
|
car: 'Hello Canadian Drivers, Welcome to MyChoice!',
|
|
422
427
|
home: 'Hello Canadian Residents, Welcome to MyChoice!',
|
|
423
428
|
life: 'Hello Canadian Residents, Welcome to MyChoice!',
|
|
424
429
|
};
|
|
425
|
-
const
|
|
430
|
+
const TITLE_BEGIN = {
|
|
431
|
+
car: 'Hello Canadian Drivers, Welcome to Begin Insurance!',
|
|
432
|
+
home: 'Hello Canadian Residents, Welcome to Begin Insurance!',
|
|
433
|
+
life: 'Hello Canadian Residents, Welcome to Begin Insurance!',
|
|
434
|
+
};
|
|
435
|
+
const TEXT_MYCHOICE = {
|
|
426
436
|
car: 'Our apologies but unfortunately, we are unable to provide you with an auto insurance rate in your home province at this current time however we are actively working on adding partners to our platform who will be able to provide you with a rate in the near future! Please check back with us at a later date, in the meantime, drive safely!',
|
|
427
437
|
home: 'Our apologies but unfortunately, we are unable to provide you with an property insurance rate in your home province at this current time however we are actively working on adding partners to our platform who will be able to provide you with a rate in the near future! Please check back with us at a later date, in the meantime, stay safe!',
|
|
428
438
|
life: 'Our apologies, but at this time, none of our insurance partners offer any life insurance products that match the combination of your age, product type, and desired coverage amount you selected. As you shop around, it’s important to note that once you reach a certain age, life insurance options become more limited, as many providers have stricter eligibility criteria for older applicants. We encourage you to consider selecting a different product or coverage amount and try again.',
|
|
429
439
|
};
|
|
440
|
+
const TEXT_BEGIN = {
|
|
441
|
+
car: 'Our apologies but unfortunately, we are unable to provide you with an auto insurance rate in your home province at this current time however we are actively working on adding partners to our platform who will be able to provide you with a rate in the near future! Please check back with us at a later date, in the meantime, drive safely!',
|
|
442
|
+
home: 'Our apologies but unfortunately, we are unable to provide you with an property insurance rate in your home province at this current time however we are actively working on adding partners to our platform who will be able to provide you with a rate in the near future! Please check back with us at a later date, in the meantime, stay safe!',
|
|
443
|
+
life: 'Our apologies, but at this time, none of our insurance partners offer any life insurance products that match the combination of your age, product type, and desired coverage amount you selected. As you shop around, it is important to note that once you reach a certain age, life insurance options become more limited, as many providers have stricter eligibility criteria for older applicants. We encourage you to consider selecting a different product or coverage amount and try again.',
|
|
444
|
+
};
|
|
430
445
|
const NoQuotesMessage = ({ type }) => {
|
|
431
446
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
432
|
-
if (appType
|
|
447
|
+
if (!isMyChoiceLike(appType))
|
|
433
448
|
return null;
|
|
434
|
-
|
|
449
|
+
const isBegin = appType === AppTypes.BeginInsurance;
|
|
450
|
+
const logo$2 = isBegin ? logo : logo$1;
|
|
451
|
+
const title = isBegin ? TITLE_BEGIN[type] : TITLE_MYCHOICE[type];
|
|
452
|
+
const text = isBegin ? TEXT_BEGIN[type] : TEXT_MYCHOICE[type];
|
|
453
|
+
const altText = isBegin ? 'Begin Insurance' : 'My Choice';
|
|
454
|
+
return (jsxs("div", { className: "offer-section mychoice", children: [jsx("div", { style: { width: '100%' }, children: jsx("img", { src: logo$2, alt: altText, style: { width: '120px' } }) }), jsx("p", { children: jsx("h3", { style: { whiteSpace: 'normal' }, children: title }) }), jsx("p", { style: { lineHeight: '1.25rem' }, children: text })] }));
|
|
435
455
|
};
|
|
436
456
|
|
|
437
457
|
const usePathGroups = (insuranceType) => {
|
|
438
458
|
const { appConfigState } = useStoreAppConfig();
|
|
459
|
+
const { localIndex, appType } = appConfigState;
|
|
439
460
|
const insurancePathGroup = {
|
|
440
|
-
[`${InsuranceTypes.Car}`]: [{ name: 'Car', link: `/${
|
|
441
|
-
[`${InsuranceTypes.Home}`]: [{ name: 'Home', link: `/${
|
|
442
|
-
// @todo: will be used in future
|
|
443
|
-
// [`${InsuranceTypes.Life}`]: [{ name: 'Life', link: `/${appConfigState.localIndex}/life` }],
|
|
461
|
+
[`${InsuranceTypes.Car}`]: [{ name: 'Car', link: `/${localIndex}/car` }],
|
|
462
|
+
[`${InsuranceTypes.Home}`]: [{ name: 'Home', link: `/${localIndex}/home` }],
|
|
444
463
|
};
|
|
445
|
-
|
|
464
|
+
// Begin Insurance only shows Auto and Home
|
|
465
|
+
const beginInsurancePathGroup = [
|
|
466
|
+
{ name: 'Auto', link: '/insurance/car' },
|
|
467
|
+
{ name: 'Home', link: '/insurance/home' },
|
|
468
|
+
];
|
|
469
|
+
// MyChoice shows all options including Life and Learn
|
|
470
|
+
const myChoicePathGroup = [
|
|
446
471
|
{ name: 'Car', link: '/insurance/car' },
|
|
447
472
|
{ name: 'Home', link: '/insurance/home' },
|
|
448
473
|
{ name: 'Life', link: '/insurance/life' },
|
|
449
474
|
{ name: 'Learn', link: 'https://www.mychoice.ca/blog/' },
|
|
450
475
|
];
|
|
451
|
-
|
|
452
|
-
// const loggedOutPathGroup = [
|
|
453
|
-
// { name: 'Login', link: '/accounts/signin' },
|
|
454
|
-
// { name: 'Signup', link: '/accounts/signup' },
|
|
455
|
-
// ];
|
|
456
|
-
//
|
|
457
|
-
// const loggedInPathGroup = [
|
|
458
|
-
// { name: 'My Profile', link: '/accounts/myProfile' },
|
|
459
|
-
// { name: 'Quotes History', link: '/accounts/quotes/history' },
|
|
460
|
-
// { name: 'Logout', link: '/accounts/logout' },
|
|
461
|
-
// ];
|
|
476
|
+
const externalPathGroup = appType === AppTypes.BeginInsurance ? beginInsurancePathGroup : myChoicePathGroup;
|
|
462
477
|
return {
|
|
463
478
|
insurancePathGroup: insurancePathGroup[insuranceType],
|
|
464
479
|
externalPathGroup,
|
|
465
|
-
// loggedOutPathGroup,
|
|
466
|
-
// loggedInPathGroup,
|
|
467
480
|
};
|
|
468
481
|
};
|
|
469
482
|
|
|
470
|
-
const HeaderMyChoice = ({ className
|
|
483
|
+
const HeaderMyChoice = ({ className }) => {
|
|
471
484
|
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
472
|
-
const insuranceTypeCls = insuranceType !== InsuranceTypes.Car &&
|
|
473
|
-
insuranceType !== InsuranceTypes.Life
|
|
474
|
-
? InsuranceTypes.Home
|
|
475
|
-
: insuranceType;
|
|
485
|
+
const insuranceTypeCls = insuranceType !== InsuranceTypes.Car && insuranceType !== InsuranceTypes.Life ? InsuranceTypes.Home : insuranceType;
|
|
476
486
|
const { externalPathGroup } = usePathGroups(insuranceTypeCls);
|
|
477
|
-
return (jsx("div", { className: `${className} primary-header`, children: jsxs("div", { className: "content", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.mychoice.ca/", rel: "noreferrer", children: jsx("img", { src: logo, alt: "logotype" }) }) }), jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsx("div", { className: "empty-box" })] }) }));
|
|
487
|
+
return (jsx("div", { className: `${className} primary-header`, children: jsxs("div", { className: "content", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.mychoice.ca/", rel: "noreferrer", children: jsx("img", { src: logo$1, alt: "logotype" }) }) }), jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsx("div", { className: "empty-box" })] }) }));
|
|
478
488
|
};
|
|
479
489
|
HeaderMyChoice.defaultProps = {
|
|
480
490
|
className: '',
|
|
@@ -482,30 +492,53 @@ HeaderMyChoice.defaultProps = {
|
|
|
482
492
|
|
|
483
493
|
const HeaderPartner = ({ className }) => {
|
|
484
494
|
const { partnerState } = useStorePartner();
|
|
485
|
-
return (jsx("div", { className: `${className} primary-header-partner`, children: jsxs("div", { className: "content", children: [jsx("a", { href: partnerState.redirectUrl || 'https://www.mychoice.ca/', target: "_blank", rel: "noreferrer", children: jsx("img", { src: partnerState.logo ||
|
|
495
|
+
return (jsx("div", { className: `${className} primary-header-partner`, children: jsxs("div", { className: "content", children: [jsx("a", { href: partnerState.redirectUrl || 'https://www.mychoice.ca/', target: "_blank", rel: "noreferrer", children: jsx("img", { src: partnerState.logo ||
|
|
496
|
+
'https://s3.amazonaws.com/mychoice-logos-dev/partners/newpartner/AE1C9160-F0AD-4969-BEBB-86EBFA7CF2E7.png', alt: "new-partner-logotype" }) }), jsx("div", {})] }) }));
|
|
486
497
|
};
|
|
487
498
|
|
|
488
499
|
var theBigLogotype = "";
|
|
489
500
|
|
|
490
|
-
const HeaderTheBig = ({ textBack, className
|
|
501
|
+
const HeaderTheBig = ({ textBack, className }) => (jsx("div", { className: `${className} primary-header-thebig`, children: jsxs("div", { className: "content", children: [jsx("div", { className: "logo", children: jsx("img", { src: theBigLogotype, alt: "thebig-logotype" }) }), jsx("a", { href: "https://www.thebig.ca/", target: "_blank", rel: "noreferrer", children: jsxs("div", { className: "back-button", children: [jsx("div", { className: "back-icon" }), jsx("h2", { children: textBack })] }) })] }) }));
|
|
491
502
|
HeaderTheBig.defaultProps = {
|
|
492
503
|
className: '',
|
|
493
504
|
};
|
|
494
505
|
|
|
495
|
-
const
|
|
496
|
-
const { appConfigState: { insuranceType } } = useStoreAppConfig();
|
|
506
|
+
const HeaderBeginInsurance = ({ className }) => {
|
|
507
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
508
|
+
const insuranceTypeCls = insuranceType !== InsuranceTypes.Car && insuranceType !== InsuranceTypes.Life ? InsuranceTypes.Home : insuranceType;
|
|
509
|
+
const { externalPathGroup } = usePathGroups(insuranceTypeCls);
|
|
510
|
+
return (jsx("div", { className: `${className} primary-header`, children: jsxs("div", { className: "content", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.begininsurance.com/", rel: "noreferrer", children: jsx("img", { src: logo, alt: "Begin Insurance" }) }) }), jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsx("div", { className: "empty-box" })] }) }));
|
|
511
|
+
};
|
|
512
|
+
HeaderBeginInsurance.defaultProps = {
|
|
513
|
+
className: '',
|
|
514
|
+
};
|
|
515
|
+
|
|
516
|
+
const HeaderMyChoiceMobile = ({ className }) => {
|
|
517
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
497
518
|
const { externalPathGroup } = usePathGroups(insuranceType);
|
|
498
519
|
const [isMenuOpen, setIsMenuOpen] = useState(false);
|
|
499
520
|
const handleMenuClick = () => {
|
|
500
521
|
setIsMenuOpen(!isMenuOpen);
|
|
501
522
|
};
|
|
502
|
-
|
|
503
|
-
return (jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxs("div", { className: "content-mobile", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.mychoice.ca/", target: "_blank", rel: "noreferrer", children: jsx("img", { src: logo, alt: "logotype" }) }) }), jsx(ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsx("div", { className: "menu-items", children: jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
|
|
523
|
+
return (jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxs("div", { className: "content-mobile", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.mychoice.ca/", target: "_blank", rel: "noreferrer", children: jsx("img", { src: logo$1, alt: "logotype" }) }) }), jsx(ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsx("div", { className: "menu-items", children: jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
|
|
504
524
|
};
|
|
505
525
|
HeaderMyChoiceMobile.defaultProps = {
|
|
506
526
|
className: '',
|
|
507
527
|
};
|
|
508
528
|
|
|
529
|
+
const HeaderBeginInsuranceMobile = ({ className }) => {
|
|
530
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
531
|
+
const { externalPathGroup } = usePathGroups(insuranceType);
|
|
532
|
+
const [isMenuOpen, setIsMenuOpen] = useState(false);
|
|
533
|
+
const handleMenuClick = () => {
|
|
534
|
+
setIsMenuOpen(!isMenuOpen);
|
|
535
|
+
};
|
|
536
|
+
return (jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxs("div", { className: "content-mobile", children: [jsx("div", { className: "logo", children: jsx("a", { href: "https://www.begininsurance.com/", target: "_blank", rel: "noreferrer", children: jsx("img", { src: logo, alt: "Begin Insurance" }) }) }), jsx(ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsx("div", { className: "menu-items", children: jsx("div", { className: "nav-links", children: jsx(HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
|
|
537
|
+
};
|
|
538
|
+
HeaderBeginInsuranceMobile.defaultProps = {
|
|
539
|
+
className: '',
|
|
540
|
+
};
|
|
541
|
+
|
|
509
542
|
const LoaderVid = () => {
|
|
510
543
|
const { appDeviceType } = useStoreDeviceType();
|
|
511
544
|
const isMobile = appDeviceType === DeviceTypes.Mobile;
|
|
@@ -516,11 +549,11 @@ const LoaderPrimary = () => {
|
|
|
516
549
|
const { appLoaderState } = useStoreAppLoader();
|
|
517
550
|
const { appConfigState } = useStoreAppConfig();
|
|
518
551
|
const isLastPage = window.location.pathname.includes('discount') || window.location.pathname.includes('/life/applicant');
|
|
519
|
-
const isHome = window.location.pathname.includes('home') ||
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
552
|
+
const isHome = window.location.pathname.includes('home') ||
|
|
553
|
+
window.location.pathname.includes('condo') ||
|
|
554
|
+
window.location.pathname.includes('tenant');
|
|
555
|
+
return (jsxs("div", { className: "loader-wrapper", children: [appConfigState.appType === AppTypes.MyChoice && !isLastPage ? jsx(LoaderVid, {}) : jsx(IconLoaderPrimary, {}), appLoaderState.description ? (jsx("h4", { children: appLoaderState.description.split('\n').map((line, index) => (jsxs("div", { children: [line, jsx("br", {})] }, index))) })) : (!appLoaderState.description &&
|
|
556
|
+
isHome && jsx("h4", { children: "Hang tight, while we collect and process information about your property." }))] }));
|
|
524
557
|
};
|
|
525
558
|
|
|
526
559
|
const ModalConfirm = () => {
|
|
@@ -770,16 +803,16 @@ const BlockCarConditionInfo = () => {
|
|
|
770
803
|
};
|
|
771
804
|
|
|
772
805
|
const VehicleSectionMain = () => {
|
|
773
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
774
|
-
const mychoiceCls = appType
|
|
806
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
807
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
775
808
|
return (jsxs("div", { className: `form-section top-section ${mychoiceCls}`, children: [mychoiceCls && jsx("h2", { className: "section-title", children: "Give us the scoop on your four-wheeled friend." }), jsx(BlockCarInfo, {}), jsx(BlockCarConditionInfo, {})] }));
|
|
776
809
|
};
|
|
777
810
|
|
|
778
811
|
const VehicleSectionCoverage = () => {
|
|
779
812
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
780
813
|
const { collision, comprehensive } = vehicleState.items[vehicleState.activeIndex];
|
|
781
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
782
|
-
const mychoiceCls = appType
|
|
814
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
815
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
783
816
|
const handleComprehensiveChange = ({ value }) => {
|
|
784
817
|
dispatchVehicleState({
|
|
785
818
|
type: StoreFormCarVehicleActionTypes.FormCarComprehensiveCoverageSelect,
|
|
@@ -933,11 +966,11 @@ const TabDriver = ({ createItem, readOnly }) => {
|
|
|
933
966
|
|
|
934
967
|
const SectionDriverInfo = () => {
|
|
935
968
|
const { configState } = useStoreFormCarConfig();
|
|
936
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
969
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
937
970
|
const { driverState, dispatchDriverInfoState } = useStoreFormCarDriverInfo();
|
|
938
971
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
939
|
-
const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship
|
|
940
|
-
const mychoiceCls = appType
|
|
972
|
+
const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship } = driverState.items[driverState.activeIndex];
|
|
973
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
941
974
|
const defaultDateOfBirth = {
|
|
942
975
|
day: birthDay,
|
|
943
976
|
month: birthMonth,
|
|
@@ -1001,17 +1034,16 @@ const SectionDriverInfo = () => {
|
|
|
1001
1034
|
payload: { applicantRelationship: value },
|
|
1002
1035
|
});
|
|
1003
1036
|
};
|
|
1004
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [mychoiceCls && jsx("h2", { className: "section-title", children: "Time for a micro autobiography \u2013 tell us about you." }), jsx(InputFormBox, { name: "firstName", title: "What is your legal first name?", onChange: handleFirstNameChange, defaultValue: firstName, description: "The name on a policy should match the one on your official driver\u2019s licence.", placeholder: "Driver First Name", error: !firstName && driverState.inValidation, errorMessage: getErrorMessage(firstName, driverState.inValidation) }), jsx(SelectFormBox, { options: maritalStatusOptions, name: "maritalStatus", onChange: handleMaritalStatusChange, defaultValue: getSelectedOption(maritalStatusOptions, maritalStatus), title: "What is your marital status?", placeholder: "Select from the list", description: "If you are married, it may have a positive effect on your car insurance premiums and coverage. In some provinces, the law now considers same-sex partners to have a common-law marriage, so you will need to check your local regulations. If you are divorced or widowed, select single.", autoSelectIfValueIsOutOfOptions: false, error: !maritalStatus && driverState.inValidation, errorMessage: getErrorMessage(maritalStatus, driverState.inValidation) }), jsx(DateSelectFormBox, { name: "dateOfBirth", dateNames: ['birthYear', 'birthMonth', 'birthDay'], onDateChange: handleDateOfBirthChange, defaultValue: defaultDateOfBirth, title: "When were you born?", description: "Insurers generally consider your age and driving experience when calculating a vehicle insurance quote. The safest drivers are often those who are over thirty, but each insurer will have their own parameters. The youngest and oldest drivers have the greatest liability reflected in their premiums due to inexperience or health complications, respectively.", errorMessage: getDateErrorMessage([birthDay || '', birthMonth || '', birthYear || ''], driverState.inValidation), error: driverState.inValidation, maxDate: subYearsFromDate('', configState.licenceConfig.minLicenceAge || 16), isDay: true }), jsx(SwitchButtonBox, { name: "occupation", items: occupationOptions, onChange: handleOccupationChange, defaultValue: getSelectedOption(occupationOptions, occupation), title: "Are you currently employed or unemployed?", description: "Your employment status reflects your driving frequency, and insurers consider this in your policy." }), jsx(SwitchButtonBox, { items: genderOptions, onChange: handleGenderChange, name: "gender", defaultValue: getSelectedOption(genderOptions, gender), title: "What is your gender?", description: "The gender on the policy should match your official driver\u2019s licence. Some insurers analyze a driver's sex when creating a policy. Men are typically considered higher risk than female drivers, but the statistics supporting this idea vary from province to province. On average, men and women pay roughly the same for insurance, though." }), driverState.activeIndex > 0
|
|
1005
|
-
&& (jsx(SelectFormBox, { options: applicantRelationshipOptions, name: "applicantRelationship", onChange: handleApplicantRelationshipChange, defaultValue: getSelectedOption(applicantRelationshipOptions, applicantRelationship), title: "Relationship to applicant", placeholder: "Select...", autoSelectIfValueIsOutOfOptions: false, error: !applicantRelationship && driverState.inValidation, errorMessage: getErrorMessage(applicantRelationship, driverState.inValidation) }))] }));
|
|
1037
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [mychoiceCls && jsx("h2", { className: "section-title", children: "Time for a micro autobiography \u2013 tell us about you." }), jsx(InputFormBox, { name: "firstName", title: "What is your legal first name?", onChange: handleFirstNameChange, defaultValue: firstName, description: "The name on a policy should match the one on your official driver\u2019s licence.", placeholder: "Driver First Name", error: !firstName && driverState.inValidation, errorMessage: getErrorMessage(firstName, driverState.inValidation) }), jsx(SelectFormBox, { options: maritalStatusOptions, name: "maritalStatus", onChange: handleMaritalStatusChange, defaultValue: getSelectedOption(maritalStatusOptions, maritalStatus), title: "What is your marital status?", placeholder: "Select from the list", description: "If you are married, it may have a positive effect on your car insurance premiums and coverage. In some provinces, the law now considers same-sex partners to have a common-law marriage, so you will need to check your local regulations. If you are divorced or widowed, select single.", autoSelectIfValueIsOutOfOptions: false, error: !maritalStatus && driverState.inValidation, errorMessage: getErrorMessage(maritalStatus, driverState.inValidation) }), jsx(DateSelectFormBox, { name: "dateOfBirth", dateNames: ['birthYear', 'birthMonth', 'birthDay'], onDateChange: handleDateOfBirthChange, defaultValue: defaultDateOfBirth, title: "When were you born?", description: "Insurers generally consider your age and driving experience when calculating a vehicle insurance quote. The safest drivers are often those who are over thirty, but each insurer will have their own parameters. The youngest and oldest drivers have the greatest liability reflected in their premiums due to inexperience or health complications, respectively.", errorMessage: getDateErrorMessage([birthDay || '', birthMonth || '', birthYear || ''], driverState.inValidation), error: driverState.inValidation, maxDate: subYearsFromDate('', configState.licenceConfig.minLicenceAge || 16), isDay: true }), jsx(SwitchButtonBox, { name: "occupation", items: occupationOptions, onChange: handleOccupationChange, defaultValue: getSelectedOption(occupationOptions, occupation), title: "Are you currently employed or unemployed?", description: "Your employment status reflects your driving frequency, and insurers consider this in your policy." }), jsx(SwitchButtonBox, { items: genderOptions, onChange: handleGenderChange, name: "gender", defaultValue: getSelectedOption(genderOptions, gender), title: "What is your gender?", description: "The gender on the policy should match your official driver\u2019s licence. Some insurers analyze a driver's sex when creating a policy. Men are typically considered higher risk than female drivers, but the statistics supporting this idea vary from province to province. On average, men and women pay roughly the same for insurance, though." }), driverState.activeIndex > 0 && (jsx(SelectFormBox, { options: applicantRelationshipOptions, name: "applicantRelationship", onChange: handleApplicantRelationshipChange, defaultValue: getSelectedOption(applicantRelationshipOptions, applicantRelationship), title: "Relationship to applicant", placeholder: "Select...", autoSelectIfValueIsOutOfOptions: false, error: !applicantRelationship && driverState.inValidation, errorMessage: getErrorMessage(applicantRelationship, driverState.inValidation) }))] }));
|
|
1006
1038
|
};
|
|
1007
1039
|
|
|
1008
1040
|
const SectionDriverLicence = () => {
|
|
1009
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1041
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1010
1042
|
const [driverEducation, setDriverEducation] = useState(false);
|
|
1011
1043
|
const { configState } = useStoreFormCarConfig();
|
|
1012
1044
|
const { driverState, dispatchDriverLicenceState } = useStoreFormCarDriverLicence();
|
|
1013
1045
|
const { isAlbertaProvince } = useProvince();
|
|
1014
|
-
const mychoiceCls = appType
|
|
1046
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1015
1047
|
const { firstName, birthDay, birthMonth, birthYear, licenceInfo: { firstLicenceAge, licenceType, g1LicenceYear, g1LicenceMonth, gLicenceYear, gLicenceMonth, g2LicenceYear, g2LicenceMonth, passedDriverTraining, previousLicence, }, minMaxDates, } = driverState.items[driverState.activeIndex];
|
|
1016
1048
|
const { gMax = getFormattedDate('', 'yyyy-MM-dd'), gMin = '1922-01-01', gOneMax = getFormattedDate('', 'yyyy-MM-dd'), gOneMin = '1922-01-01', gTwoMax = getFormattedDate('', 'yyyy-MM-dd'), gTwoMin = '1922-01-01', gBlock = false, gTwoBlock = false, gOneBlock = false, licenceAgeMax = 16, } = minMaxDates ?? {};
|
|
1017
1049
|
const maxLicenceAge = licenceAgeMax;
|
|
@@ -1020,7 +1052,7 @@ const SectionDriverLicence = () => {
|
|
|
1020
1052
|
const defaultMinDate = birthDate && firstLicenceAge ? addYearsToDate(birthDate, +firstLicenceAge) : '';
|
|
1021
1053
|
const isOnlyG = checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
|
|
1022
1054
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1023
|
-
const { g, g1, g2, minLicenceAge
|
|
1055
|
+
const { g, g1, g2, minLicenceAge } = configState.licenceConfig;
|
|
1024
1056
|
const licenceTypeOptions = [
|
|
1025
1057
|
{ value: g.name, name: g.title },
|
|
1026
1058
|
{ value: g1.name, name: g1.title },
|
|
@@ -1050,7 +1082,8 @@ const SectionDriverLicence = () => {
|
|
|
1050
1082
|
return gOneMin;
|
|
1051
1083
|
case DriverLicenceTypes.G2:
|
|
1052
1084
|
return gTwoMin;
|
|
1053
|
-
default:
|
|
1085
|
+
default:
|
|
1086
|
+
return '';
|
|
1054
1087
|
}
|
|
1055
1088
|
};
|
|
1056
1089
|
const getMaxDate = (type) => {
|
|
@@ -1061,7 +1094,8 @@ const SectionDriverLicence = () => {
|
|
|
1061
1094
|
return gOneMax;
|
|
1062
1095
|
case DriverLicenceTypes.G2:
|
|
1063
1096
|
return gTwoMax;
|
|
1064
|
-
default:
|
|
1097
|
+
default:
|
|
1098
|
+
return '';
|
|
1065
1099
|
}
|
|
1066
1100
|
};
|
|
1067
1101
|
const getLicenceYear = (type) => {
|
|
@@ -1072,7 +1106,8 @@ const SectionDriverLicence = () => {
|
|
|
1072
1106
|
return g1LicenceYear;
|
|
1073
1107
|
case DriverLicenceTypes.G2:
|
|
1074
1108
|
return g2LicenceYear;
|
|
1075
|
-
default:
|
|
1109
|
+
default:
|
|
1110
|
+
return '';
|
|
1076
1111
|
}
|
|
1077
1112
|
};
|
|
1078
1113
|
const getLicenceMonth = (type) => {
|
|
@@ -1083,7 +1118,8 @@ const SectionDriverLicence = () => {
|
|
|
1083
1118
|
return g1LicenceMonth;
|
|
1084
1119
|
case DriverLicenceTypes.G2:
|
|
1085
1120
|
return g2LicenceMonth;
|
|
1086
|
-
default:
|
|
1121
|
+
default:
|
|
1122
|
+
return '';
|
|
1087
1123
|
}
|
|
1088
1124
|
};
|
|
1089
1125
|
const getDefaultLicenceDate = (type) => ({
|
|
@@ -1136,8 +1172,10 @@ const SectionDriverLicence = () => {
|
|
|
1136
1172
|
const formattedMinDate = `${getFormattedDate(licenceMinDate, 'MMMM yyyy')}`;
|
|
1137
1173
|
const defaultHintMessage = `${formattedMinDate} would be your earliest ${licenceTypeTitle}
|
|
1138
1174
|
licence date based on your first licenced age and date of birth`;
|
|
1139
|
-
return currentType === DriverLicenceTypes.G2
|
|
1140
|
-
|
|
1175
|
+
return currentType === DriverLicenceTypes.G2
|
|
1176
|
+
? `${defaultHintMessage}
|
|
1177
|
+
if you completed a driver education course`
|
|
1178
|
+
: defaultHintMessage;
|
|
1141
1179
|
};
|
|
1142
1180
|
const getLicenceAgeTitle = () => {
|
|
1143
1181
|
if (isAlbertaProvince && isTheBig) {
|
|
@@ -1145,10 +1183,10 @@ const SectionDriverLicence = () => {
|
|
|
1145
1183
|
}
|
|
1146
1184
|
return `What age was ${firstName || driverNameDefault} when first licenced?`;
|
|
1147
1185
|
};
|
|
1148
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(InputFormBox, { name: "firstLicenceAge", title: getLicenceAgeTitle(), onChange: handleLicenceAgeChange, type: InputTypes.Number, defaultValue: firstLicenceAge, description: configState.toolTip.licenceAge, hintMessage: birthDate
|
|
1149
|
-
|
|
1150
|
-
|
|
1151
|
-
|
|
1186
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(InputFormBox, { name: "firstLicenceAge", title: getLicenceAgeTitle(), onChange: handleLicenceAgeChange, type: InputTypes.Number, defaultValue: firstLicenceAge, description: configState.toolTip.licenceAge, hintMessage: birthDate
|
|
1187
|
+
? `${firstName || driverNameDefault} was licenced in
|
|
1188
|
+
${Number(birthYear) + Number(firstLicenceAge)} - ${Number(birthYear) + Number(firstLicenceAge) + 1}`
|
|
1189
|
+
: '', placeholder: "Select Licence Age", disabled: !birthDate, error: !firstLicenceAge && driverState.inValidation, errorMessage: getErrorMessage(firstLicenceAge, driverState.inValidation), minValue: minLicenceAge || 16, maxValue: maxLicenceAge }), jsx(SelectFormBox, { options: getLicenceTypeOptions(licenceTypeOptions, getDisabledLicenceTypes(gBlock, gTwoBlock, gOneBlock), true), name: "licenceType", onChange: handleLicenceTypeChange, defaultValue: getSelectedOption(licenceTypeOptions, licenceType), title: `Please choose the type of licence that ${firstName || driverNameDefault} currently holds`, placeholder: "Select from the list", disabled: !birthDate, description: configState.toolTip.licenceType, autoSelectIfValueIsOutOfOptions: false }), licenceType === DriverLicenceTypes.G && !isOnlyG && (jsx(DateSelectFormBox, { name: "g2LicenceDate", dateNames: ['g2LicenceYear', 'g2LicenceMonth'], onDateChange: handleLicenceDateChange(DriverLicenceTypes.G2), defaultValue: getDefaultLicenceDate(DriverLicenceTypes.G2), title: `${configState.licenceConfig.g2.title} licence date`, errorMessage: getDateErrorMessage(['01', g2LicenceMonth, g2LicenceYear], driverState.inValidation), hintMessage: getHintMessage(DriverLicenceTypes.G2), error: driverState.inValidation, minDate: getMinDate(DriverLicenceTypes.G2), maxDate: getMaxDate(DriverLicenceTypes.G2) })), licenceType && (jsx(DateSelectFormBox, { name: `${licenceType}LicenceDate`, dateNames: [`${licenceType}LicenceYear`, `${licenceType}LicenceMonth`], onDateChange: handleLicenceDateChange(), defaultValue: getDefaultLicenceDate(licenceType), title: `${configState.licenceConfig[licenceType].title} licence date`, errorMessage: getDateErrorMessage(['01', getLicenceMonth(licenceType), getLicenceYear(licenceType)], driverState.inValidation), hintMessage: getHintMessage(), error: driverState.inValidation, maxDate: getMaxDate(licenceType), minDate: getMinDate(licenceType) })), driverEducation && (jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleTrainingChange, name: "passedDriverTraining", defaultValue: getSelectedOption(yesNoOptions, passedDriverTraining), title: `Has ${firstName || driverNameDefault} completed a driver education course within the last 3 years?` })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handlePreviousLicenceChange, name: "previousLicence", defaultValue: getSelectedOption(yesNoOptions, previousLicence), title: `Has ${firstName || driverNameDefault} ever had a full license anywhere else in Canada or USA?`, description: "If you have driving experience outside Canada or the United States, it may lower your premium. Your insurer may require proof of insurance in these other locations or some proof of driving experience from the country you indicate (like a copy of a previous driver\u2019s licence)." })] }));
|
|
1152
1190
|
};
|
|
1153
1191
|
|
|
1154
1192
|
const SectionDriverInsurancePolicy = () => {
|
|
@@ -1157,18 +1195,14 @@ const SectionDriverInsurancePolicy = () => {
|
|
|
1157
1195
|
const { driverState, dispatchDriverInsuranceState } = useStoreFormCarDriverInsurance();
|
|
1158
1196
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
1159
1197
|
const { quoteState: { isRequested }, } = useStoreFormCarQuote();
|
|
1160
|
-
const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth
|
|
1198
|
+
const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth }, } = driverState.items[driverState.activeIndex];
|
|
1161
1199
|
const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
|
|
1162
1200
|
const driverNameDefault = `Driver ${driverState.activeIndex + 1}`;
|
|
1163
|
-
const birthDate = birthYear && birthMonth && birthDay
|
|
1164
|
-
? `${birthYear}-${birthMonth}-${birthDay}`
|
|
1165
|
-
: '';
|
|
1201
|
+
const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
|
|
1166
1202
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1167
|
-
const mychoiceCls = appType
|
|
1203
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1168
1204
|
const getPeriodOptions = (year, month) => {
|
|
1169
|
-
const options = [
|
|
1170
|
-
{ value: '', name: 'Date Period', disabled: true },
|
|
1171
|
-
];
|
|
1205
|
+
const options = [{ value: '', name: 'Date Period', disabled: true }];
|
|
1172
1206
|
if (year && month) {
|
|
1173
1207
|
const todayDate = new Date();
|
|
1174
1208
|
const month = String(todayDate.getMonth() + 1).padStart(2, '0');
|
|
@@ -1224,9 +1258,7 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1224
1258
|
}
|
|
1225
1259
|
};
|
|
1226
1260
|
if (birthDate) {
|
|
1227
|
-
const defaultMinDate = birthDate && firstLicenceAge
|
|
1228
|
-
? addYearsToDate(birthDate, +firstLicenceAge)
|
|
1229
|
-
: '';
|
|
1261
|
+
const defaultMinDate = birthDate && firstLicenceAge ? addYearsToDate(birthDate, +firstLicenceAge) : '';
|
|
1230
1262
|
const isOnlyG = checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
|
|
1231
1263
|
if (isOnlyG) {
|
|
1232
1264
|
setMessage(gLicenceYear, gLicenceMonth);
|
|
@@ -1245,16 +1277,7 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1245
1277
|
else {
|
|
1246
1278
|
setHintMessage('');
|
|
1247
1279
|
}
|
|
1248
|
-
}, [
|
|
1249
|
-
listedYear,
|
|
1250
|
-
listedMonth,
|
|
1251
|
-
g1LicenceYear,
|
|
1252
|
-
g1LicenceMonth,
|
|
1253
|
-
firstLicenceAge,
|
|
1254
|
-
birthDate,
|
|
1255
|
-
gLicenceYear,
|
|
1256
|
-
gLicenceMonth,
|
|
1257
|
-
]);
|
|
1280
|
+
}, [listedYear, listedMonth, g1LicenceYear, g1LicenceMonth, firstLicenceAge, birthDate, gLicenceYear, gLicenceMonth]);
|
|
1258
1281
|
const handleInsuredChange = ({ value }) => {
|
|
1259
1282
|
dispatchDriverInsuranceState({
|
|
1260
1283
|
type: StoreFormCarDriverInsuranceActionTypes.FormCarDriverInsuredSelect,
|
|
@@ -1309,18 +1332,16 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1309
1332
|
};
|
|
1310
1333
|
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxs("div", { className: "box-container", children: [jsx(DateSelectFormBox, { name: "listedYear", dateNames: ['listedYear', 'listedMonth'], onDateChange: handleListedDateChange, defaultValue: defaultListedDate, disabled: !listed, title: `When was ${firstName || driverNameDefault} first listed as a driver on a Canadian or US insurance policy?`, description: "The selection indicates what year the main driver was first listed on a Canadian or US insurance policy. If you do not remember your age, it is acceptable to provide a best estimate for the purposes of the policy or quote.", errorMessage: listed
|
|
1311
1334
|
? getDateErrorMessage(['01', listedMonth, listedYear], driverState.inValidation)
|
|
1312
|
-
: '', error: driverState.inValidation, hintMessage: hintMessage, minDate: getMinDate(birthDate, firstLicenceAge) }), jsx(CheckboxForm, { name: "listed", label: "Never listed on an insurance policy", onChange: handleListedChange, defaultValue: !listed })] }), listed && (jsxs("div", { className: "box-container", children: [jsx(SelectFormBox, { name: "insuredDate", onChange: handleInsuredPeriodChange, options: getPeriodOptions(listedYear, listedMonth), defaultValue: insuredDate, disabled: !insured, title: `How long has ${firstName || driverNameDefault} been with their current insurance provider?`, description: "It is common for insurers to provide loyalty rewards or discounts for valued customers. Loyalty is a positive trait in the industry, and most insurance companies will want to provide some incentive for continued customer relationships through tangible policy rewards.", errorMessage: insured
|
|
1313
|
-
? getErrorMessage(insuredDate, driverState.inValidation)
|
|
1314
|
-
: '', error: !insuredDate && driverState.inValidation }), jsx(CheckboxForm, { name: "insured", label: "Not currently insured", onChange: handleInsuredChange, defaultValue: !insured })] })), jsx(DateSelectFormBox, { name: "policyStart", dateNames: ['policyStartYear', 'policyStartMonth', 'policyStartDay'], onDateChange: handlePolicyStartDateChange, defaultValue: defaultPolicyStartDate, title: "What is the ideal start date for your new insurance policy?", description: "Select your preferred date for the beginning of your new insurance policy.For instance, you may set the start date for the day that your current insurance expires to ensure that you\u2019re continuously covered. Alternatively, select today's date for a quote or new policy.", errorMessage: getDateErrorMessage([policyStartDay || '', policyStartMonth || '', policyStartYear || ''], driverState.inValidation), error: driverState.inValidation, minDate: addDaysToDate('', 1), maxDate: addDaysToDate('', 60), isDay: true })] }));
|
|
1335
|
+
: '', error: driverState.inValidation, hintMessage: hintMessage, minDate: getMinDate(birthDate, firstLicenceAge) }), jsx(CheckboxForm, { name: "listed", label: "Never listed on an insurance policy", onChange: handleListedChange, defaultValue: !listed })] }), listed && (jsxs("div", { className: "box-container", children: [jsx(SelectFormBox, { name: "insuredDate", onChange: handleInsuredPeriodChange, options: getPeriodOptions(listedYear, listedMonth), defaultValue: insuredDate, disabled: !insured, title: `How long has ${firstName || driverNameDefault} been with their current insurance provider?`, description: "It is common for insurers to provide loyalty rewards or discounts for valued customers. Loyalty is a positive trait in the industry, and most insurance companies will want to provide some incentive for continued customer relationships through tangible policy rewards.", errorMessage: insured ? getErrorMessage(insuredDate, driverState.inValidation) : '', error: !insuredDate && driverState.inValidation }), jsx(CheckboxForm, { name: "insured", label: "Not currently insured", onChange: handleInsuredChange, defaultValue: !insured })] })), jsx(DateSelectFormBox, { name: "policyStart", dateNames: ['policyStartYear', 'policyStartMonth', 'policyStartDay'], onDateChange: handlePolicyStartDateChange, defaultValue: defaultPolicyStartDate, title: "What is the ideal start date for your new insurance policy?", description: "Select your preferred date for the beginning of your new insurance policy.For instance, you may set the start date for the day that your current insurance expires to ensure that you\u2019re continuously covered. Alternatively, select today's date for a quote or new policy.", errorMessage: getDateErrorMessage([policyStartDay || '', policyStartMonth || '', policyStartYear || ''], driverState.inValidation), error: driverState.inValidation, minDate: addDaysToDate('', 1), maxDate: addDaysToDate('', 60), isDay: true })] }));
|
|
1315
1336
|
};
|
|
1316
1337
|
|
|
1317
1338
|
const SectionDriverCancellation = () => {
|
|
1318
1339
|
const { driverState, dispatchDriverCancellationState } = useStoreFormCarDriverCancellation();
|
|
1319
1340
|
const { dispatchDriverBaseState } = useStoreFormCarDriverBase();
|
|
1320
1341
|
const { insuranceCancellation, insuranceCancellationList = [] } = driverState.items[driverState.activeIndex];
|
|
1321
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1342
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1322
1343
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1323
|
-
const mychoiceCls = appType
|
|
1344
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1324
1345
|
const { firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge }, } = driverState.items[driverState.activeIndex];
|
|
1325
1346
|
const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
|
|
1326
1347
|
const handleIconClick = (index) => () => {
|
|
@@ -1396,7 +1417,7 @@ const SectionDriverCancellation = () => {
|
|
|
1396
1417
|
}
|
|
1397
1418
|
};
|
|
1398
1419
|
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Insurance Cancellation" }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(yesNoOptions, insuranceCancellation), title: `Has ${firstName} had an insurance company cancellation or
|
|
1399
|
-
a time without insurance coverage, within the past 3 years?`, description: "If an insurance company cancels your policy, it will increase your future insurance premiums. The most common reasons for cancellations include missed payments, excessive claims, false declarations, or criminal actions, for example. If you cancel the insurance policy, it is not relevant." }), insuranceCancellation && (jsxs(Fragment, { children: [insuranceCancellationList?.map(({ cancellationReason, startYear, startMonth, endYear, endMonth
|
|
1420
|
+
a time without insurance coverage, within the past 3 years?`, description: "If an insurance company cancels your policy, it will increase your future insurance premiums. The most common reasons for cancellations include missed payments, excessive claims, false declarations, or criminal actions, for example. If you cancel the insurance policy, it is not relevant." }), insuranceCancellation && (jsxs(Fragment, { children: [insuranceCancellationList?.map(({ cancellationReason, startYear, startMonth, endYear, endMonth }, index) => {
|
|
1400
1421
|
const defaultStartDate = {
|
|
1401
1422
|
year: startYear,
|
|
1402
1423
|
month: startMonth,
|
|
@@ -1406,12 +1427,11 @@ const SectionDriverCancellation = () => {
|
|
|
1406
1427
|
month: endMonth,
|
|
1407
1428
|
};
|
|
1408
1429
|
const now = getFormattedDate('', 'yyyy-MM-dd');
|
|
1409
|
-
const days = birthDay ?
|
|
1430
|
+
const days = birthDay ? +birthDay + 1 : 1;
|
|
1410
1431
|
const endDate = endYear && endMonth ? addDayToDate(`${endYear}-${endMonth}`, days) : now;
|
|
1411
1432
|
const currentMinDate = getMinDateByYears(getMinDate(birthDate, firstLicenceAge), 3);
|
|
1412
1433
|
const currentEndDate = compareDates(endDate, currentMinDate) < 0 ? currentMinDate : endDate;
|
|
1413
|
-
return (jsxs("div", { className: "list-block", children: [jsx("hr", {}), jsxs("div", { className: "list-item", children: [jsx(SelectFormBox, { options: insuranceCancellationReasonOptions, name: `cancellationReason-${index}`, onChange: handleReasonChange(index), defaultValue: cancellationReason, title: "Reason", placeholder: "Select from the list", isRemovable: insuranceCancellationList.length > 1, onIconClick: handleIconClick(index), autoSelectIfValueIsOutOfOptions: false, error: !cancellationReason && driverState.inValidation, errorMessage: getErrorMessage(cancellationReason, driverState.inValidation) }), jsx(DateSelectFormBox, { name: `startDate-${index}`, dateNames: [`startYear-${index}`, `startMonth-${index}`], onDateChange: handleStartDateChange(index), defaultValue: defaultStartDate, title: "Start date", errorMessage: getDateErrorMessage(['01', startMonth, startYear], driverState.inValidation), error: driverState.inValidation, minDate: currentMinDate, maxDate: currentEndDate }), jsx(DateSelectFormBox, { name: `endDate-${index}`, dateNames: [`endYear-${index}`, `endMonth-${index}`], onDateChange: handleEndDateChange(index), defaultValue: defaultEndDate, title: "End Date", errorMessage: getDateErrorMessage(['01', endMonth, endYear], driverState.inValidation), error: driverState.inValidation, minDate: startMonth && startYear
|
|
1414
|
-
? addDayToDate(`${startYear}-${startMonth}`, days) : currentMinDate })] })] }, `insurance-cancellation-${index}`));
|
|
1434
|
+
return (jsxs("div", { className: "list-block", children: [jsx("hr", {}), jsxs("div", { className: "list-item", children: [jsx(SelectFormBox, { options: insuranceCancellationReasonOptions, name: `cancellationReason-${index}`, onChange: handleReasonChange(index), defaultValue: cancellationReason, title: "Reason", placeholder: "Select from the list", isRemovable: insuranceCancellationList.length > 1, onIconClick: handleIconClick(index), autoSelectIfValueIsOutOfOptions: false, error: !cancellationReason && driverState.inValidation, errorMessage: getErrorMessage(cancellationReason, driverState.inValidation) }), jsx(DateSelectFormBox, { name: `startDate-${index}`, dateNames: [`startYear-${index}`, `startMonth-${index}`], onDateChange: handleStartDateChange(index), defaultValue: defaultStartDate, title: "Start date", errorMessage: getDateErrorMessage(['01', startMonth, startYear], driverState.inValidation), error: driverState.inValidation, minDate: currentMinDate, maxDate: currentEndDate }), jsx(DateSelectFormBox, { name: `endDate-${index}`, dateNames: [`endYear-${index}`, `endMonth-${index}`], onDateChange: handleEndDateChange(index), defaultValue: defaultEndDate, title: "End Date", errorMessage: getDateErrorMessage(['01', endMonth, endYear], driverState.inValidation), error: driverState.inValidation, minDate: startMonth && startYear ? addDayToDate(`${startYear}-${startMonth}`, days) : currentMinDate })] })] }, `insurance-cancellation-${index}`));
|
|
1415
1435
|
}), insuranceCancellationList?.length < 3 && (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" }))] }))] }));
|
|
1416
1436
|
};
|
|
1417
1437
|
|
|
@@ -1667,8 +1687,8 @@ const BlockDriverTicket = () => {
|
|
|
1667
1687
|
};
|
|
1668
1688
|
|
|
1669
1689
|
const SectionDriverHistory = () => {
|
|
1670
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1671
|
-
const mychoiceCls = appType
|
|
1690
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1691
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1672
1692
|
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(BlockDriverSuspension, {}), jsx(BlockDriverAccident, {}), jsx(BlockDriverTicket, {})] }));
|
|
1673
1693
|
};
|
|
1674
1694
|
|
|
@@ -1707,7 +1727,7 @@ const PageDriver = () => {
|
|
|
1707
1727
|
useEffect(() => {
|
|
1708
1728
|
setIsRender(true);
|
|
1709
1729
|
}, [isRender]);
|
|
1710
|
-
return (jsxs("div", { className: "form-container", children: [jsx(TabDriver, { createItem: createDriver }), jsxs("div", { className: "form-section-container", children: [isRender && (jsxs(Fragment, { children: [jsx(SectionDriverInfo, {}), jsx(SectionDriverLicence, {}), jsx(SectionDriverInsurancePolicy, {}), jsx(SectionDriverCancellation, {}), jsx(SectionDriverHistory, {}), appType
|
|
1730
|
+
return (jsxs("div", { className: "form-container", children: [jsx(TabDriver, { createItem: createDriver }), jsxs("div", { className: "form-section-container", children: [isRender && (jsxs(Fragment, { children: [jsx(SectionDriverInfo, {}), jsx(SectionDriverLicence, {}), jsx(SectionDriverInsurancePolicy, {}), jsx(SectionDriverCancellation, {}), jsx(SectionDriverHistory, {}), isMyChoiceLike(appType) && jsx(HonestyMessage, {})] })), appType === AppTypes.TheBig ? (jsx(NavigationBottomTheBig, { createItem: createDriver, formSteps: formSteps[InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid })) : (jsx(NavigationBottom, { className: "mychoice", createItem: createDriver, formSteps: formSteps[InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid }))] }), localIndex !== defaultLocalIndex && (jsx("img", { className: "logo-for-partner", src: myChoicePartnerLogo, alt: "partner logo" }))] }));
|
|
1711
1731
|
};
|
|
1712
1732
|
|
|
1713
1733
|
const getDynamicLicenceBoxProps = ({ isAlbertaProvince, isOntarioProvince, isNewfoundlandProvince, isNovaScotiaProvince, isNewBrunswickProvince, }) => {
|
|
@@ -1757,11 +1777,11 @@ const SectionDiscountInfo$1 = () => {
|
|
|
1757
1777
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1758
1778
|
const allProvinces = useProvince();
|
|
1759
1779
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1760
|
-
const mychoiceCls = appType
|
|
1780
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1761
1781
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
1762
1782
|
const { validateEmail, errorMessage } = useHandlerCarQuoterEmail();
|
|
1763
1783
|
const { multiplePoliciesDiscount, appInstallDiscount, caaMemberDiscount, quoterInfo, emailTo: { email, emailStatus }, } = discountState;
|
|
1764
|
-
const { firstName, lastName, phone, driverLicense = '', caslConsent
|
|
1784
|
+
const { firstName, lastName, phone, driverLicense = '', caslConsent } = quoterInfo;
|
|
1765
1785
|
const handleMultiplePolicyChange = ({ value }) => {
|
|
1766
1786
|
dispatchDiscountState({
|
|
1767
1787
|
type: StoreFormCarDiscountActionTypes.FormCarDiscountMultiplePoliciesSelect,
|
|
@@ -1815,8 +1835,7 @@ const SectionDiscountInfo$1 = () => {
|
|
|
1815
1835
|
};
|
|
1816
1836
|
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [isTheBig ? (jsx(LabelFormBox, { title: "You are seconds away from receiving your car insurance quotes,\n please provide your email after completing the discount section so we\n can send you your personalized free car insurance quotes!" })) : (jsxs(Fragment, { children: [jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), jsx("span", { className: "info-title-message", children: "You are seconds away from receiving your car insurance quotes, please provide your email after completing the discount section so we can send you your personalized free car insurance quotes!" })] })), jsx(BlockVehLinks, {}), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(yesNoOptions, multiplePoliciesDiscount), title: "You could receive a 10-15% discount for bundling insurance with multiple policies with the same insurance company. Does that interest you?", description: "Bundling your home and auto insurance can save you significantly on insurance premiums as a whole package. Do you want to learn more about the benefits of multiple policies for home, tenant, condo, or car insurance? All you have to do is select yes.." }), !isTheBig && (jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleCaaMemberChange, name: "caaMemberDiscount", defaultValue: getSelectedOption(yesNoOptions, caaMemberDiscount), title: "Please indicate if you are a member of CAA, you could save up to an additional 20%." })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleAppInstallChange, name: "appInstallDiscount", defaultValue: getSelectedOption(yesNoOptions, appInstallDiscount), title: "You could receive up to a 30% discount by using an app to track driving habits. Does that interest you?", description: "Get rewarded for safe driving with the click of a button. If you install the app, you may be eligible for a 30% discount on your insurance premiums. Typically, you receive 10% of the discount upfront and the balance after six months of good driving." }), isTheBig ? (jsxs("div", { className: "input-form-box-container", children: [jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxs("ol", { className: "ordered-block", children: [jsx("li", { children: "See what rates insurance carriers are offering" }), jsx("li", { children: "Get in touch with us and secure your rate" }), jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })) : (jsx("h2", { children: "Complete the form below to see which companies are offering your quotes." })), jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsx(InputFormBox, { name: "lastname", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && discountState.inValidation, errorMessage: getErrorMessage(lastName, discountState.inValidation) }), isTheBig && (jsx(InputFormLicenceBox, { ...getDynamicLicenceBoxProps({ ...allProvinces }), name: "driverLicense", title: "Driver Licence Number (Optional)", onChange: handleDriverLicenseChange, defaultValue: driverLicense, description: "Enter your drivers licence number in to receive a more accurate, prequalified quote from our broker partners. This will enable you to provide less details over the phone if you choose to have a broker contact you. This is an optional input." })), jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsx(InputFormEmailBox, { validationStatus: emailStatus, errorMessage: emailStatus === ValidationStatusTypes.Declined
|
|
1817
1837
|
? errorMessage
|
|
1818
|
-
: getErrorMessage(email, discountState.inValidation), error: emailStatus === ValidationStatusTypes.Declined ||
|
|
1819
|
-
(!email && discountState.inValidation), name: "email", title: "Please share your email address with us, we'll use it to send you a copy of your quotes.", description: "We will provide you with your insurance quotes immediately after this form completion. If you are not ready to apply today, don\u2019t worry as we will be emailing your quotes to you if you\u2019d like to complete at a later date with the help of one of our trusted broker partners.", onChange: handleEmailChange, defaultValue: email, placeholder: isTheBig ? 'johnsmith@thebig.ca' : 'johnsmith@mychoice.ca' }), isTheBig && (jsx(CheckboxForm, { className: "casl-consent", name: "caslConsent", label: "Yes, I consent to receiving emails from the Billyard Insurance Group.\n I understand that I can unsubscribe at any time", onChange: handleCaslConsentChange, defaultValue: caslConsent })), jsx(BlockSubmit$2, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsx(BlockNextPageInfo$2, {})] }));
|
|
1838
|
+
: getErrorMessage(email, discountState.inValidation), error: emailStatus === ValidationStatusTypes.Declined || (!email && discountState.inValidation), name: "email", title: "Please share your email address with us, we'll use it to send you a copy of your quotes.", description: "We will provide you with your insurance quotes immediately after this form completion. If you are not ready to apply today, don\u2019t worry as we will be emailing your quotes to you if you\u2019d like to complete at a later date with the help of one of our trusted broker partners.", onChange: handleEmailChange, defaultValue: email, placeholder: getPlaceholderEmail(appType) }), isTheBig && (jsx(CheckboxForm, { className: "casl-consent", name: "caslConsent", label: "Yes, I consent to receiving emails from the Billyard Insurance Group.\n I understand that I can unsubscribe at any time", onChange: handleCaslConsentChange, defaultValue: caslConsent })), jsx(BlockSubmit$2, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsx(BlockNextPageInfo$2, {})] }));
|
|
1820
1839
|
};
|
|
1821
1840
|
|
|
1822
1841
|
const PageCarDiscount = () => {
|
|
@@ -1841,10 +1860,10 @@ const SectionQuoteEdit$2 = () => {
|
|
|
1841
1860
|
const { appConfigState } = useStoreAppConfig();
|
|
1842
1861
|
const { driverState, dispatchDriverBaseState } = useStoreFormCarDriverBase();
|
|
1843
1862
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
1844
|
-
const { discountState: { appInstallDiscount, multiplePoliciesDiscount } } = useStoreFormCarDiscount();
|
|
1845
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1863
|
+
const { discountState: { appInstallDiscount, multiplePoliciesDiscount }, } = useStoreFormCarDiscount();
|
|
1864
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1846
1865
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1847
|
-
const mychoiceCls = appType
|
|
1866
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1848
1867
|
const navigate = useNavigate();
|
|
1849
1868
|
const vehicles = vehicleState.items.map(({ year, make, model }) => [`${year} ${make} ${model}`]);
|
|
1850
1869
|
const drivers = driverState.items.map(({ firstName }) => [`${firstName}`]);
|
|
@@ -1909,7 +1928,7 @@ const BlockMCEndorsements = () => {
|
|
|
1909
1928
|
const SectionQuoteRecalc$1 = () => {
|
|
1910
1929
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1911
1930
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1912
|
-
const mychoiceCls = appType
|
|
1931
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1913
1932
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
1914
1933
|
const { comprehensive, collision, liability } = vehicleState.items[vehicleState.activeIndex];
|
|
1915
1934
|
const handleComprehensiveChange = ({ value }) => {
|
|
@@ -2070,7 +2089,7 @@ const SectionAddress = () => {
|
|
|
2070
2089
|
const { streetAddress = '', postalCode = '', addressObject, errorMessage } = item;
|
|
2071
2090
|
const navigate = useNavigate();
|
|
2072
2091
|
const asyncSelectRef = useRef(null);
|
|
2073
|
-
const isMychoice = appType
|
|
2092
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
2074
2093
|
const mychoiceCls = isMychoice ? 'mychoice' : '';
|
|
2075
2094
|
const handleAddressChange = (address) => {
|
|
2076
2095
|
dispatchPostalState({
|
|
@@ -2308,9 +2327,9 @@ const SectionApplicantInfo = () => {
|
|
|
2308
2327
|
const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
|
|
2309
2328
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2310
2329
|
const { dwellingState, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
2311
|
-
const { firstName, insured: { birthDay, birthMonth, birthYear
|
|
2312
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2313
|
-
const mychoiceCls = appType
|
|
2330
|
+
const { firstName, insured: { birthDay, birthMonth, birthYear }, } = applicantState;
|
|
2331
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2332
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2314
2333
|
const { familiesCount, occupiedYear } = dwellingState;
|
|
2315
2334
|
// VARIABLES =========
|
|
2316
2335
|
const birthDate = birthYear ? `${birthYear}-${birthMonth || '01'}-${birthDay || '01'}` : '';
|
|
@@ -2391,9 +2410,9 @@ const SectionApplicantInsurancePolicy = () => {
|
|
|
2391
2410
|
const { applicantState, dispatchApplicantInsuranceState } = useStoreFormHomeApplicantInsurance();
|
|
2392
2411
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2393
2412
|
const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
|
|
2394
|
-
const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince } } = applicantState;
|
|
2395
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
2396
|
-
const mychoiceCls = appType
|
|
2413
|
+
const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince }, } = applicantState;
|
|
2414
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
2415
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2397
2416
|
const defaultPolicyStartDate = {
|
|
2398
2417
|
year: policyStartYear,
|
|
2399
2418
|
month: policyStartMonth,
|
|
@@ -2443,19 +2462,17 @@ const SectionApplicantInsurancePolicy = () => {
|
|
|
2443
2462
|
payload: { dateInsuredCurrent: value },
|
|
2444
2463
|
});
|
|
2445
2464
|
};
|
|
2446
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(DateSelectFormBox, { name: "policyStart", dateNames: ['policyStartYear', 'policyStartMonth', 'policyStartDay'], onDateChange: handlePolicyStartChange, defaultValue: defaultPolicyStartDate, title: "What date do you want to start this policy?", errorMessage: getDateErrorMessage([policyStartDay || '', policyStartMonth || '', policyStartYear || ''], applicantState.inValidation), error: applicantState.inValidation, minDate: addDaysToDate('', 1), maxDate: addDaysToDate('', 60), isDay: true }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleInsuredCurrentChange, name: "insuredCurrent", defaultValue: getSelectedOption(yesNoOptions, insuredCurrent), title: "Is your existing policy currently active?", description: "Insurers offer better rates to customers who have a long history of coverage without any gaps.", errorMessage: getErrorMessage(insuredCurrent, applicantState.inValidation) }), insuredCurrent
|
|
2447
|
-
&& (jsxs(Fragment, { children: [jsx(SelectFormBox, { options: insuredYearsOptions, name: "dateInsuredSince", onChange: handleInsuredSinceDateChange, defaultValue: getSelectedOption(insuredYearsOptions, dateInsuredSince), title: "For how long have you maintained uninterrupted insurance coverage?", description: `Let us know how long you’ve had ${insuranceType} insurance without letting the policy expire. It’s fine if you’ve changed providers in the past: what matters is that you switched before your coverage expired.`, placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !dateInsuredSince && applicantState.inValidation, errorMessage: getErrorMessage(dateInsuredSince, applicantState.inValidation) }), jsx(SelectFormBox, { options: getInsuranceYearsOptions(dateInsuredSince || insuredYearsOptions.length.toString()), name: "dateInsuredCurrent", onChange: handleInsuredCurrentDateChange, defaultValue: getSelectedOption(getInsuranceYearsOptions(dateInsuredSince || insuredYearsOptions.length.toString()), dateInsuredCurrent), title: "What is the duration of your insurance coverage with your existing provider?", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !dateInsuredCurrent && applicantState.inValidation, errorMessage: getErrorMessage(dateInsuredCurrent, applicantState.inValidation) })] })), (!insuredCurrent && insuredCurrent !== undefined)
|
|
2448
|
-
&& (jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleInsuredBeforeChange, name: "insuredBefore", defaultValue: getSelectedOption(yesNoOptions, insuredBefore), title: `Have you had a ${insuranceType} insurance policy in the past?`, description: "The gender on the policy should match your official applicant\u2019s licence. Some insurers analyze a applicant's sex when creating a policy. Men are typically considered higher risk than female applicants, but the statistics supporting this idea vary from province to province. On average, men and women pay roughly the same for insurance, though.", errorMessage: getErrorMessage(insuredBefore, applicantState.inValidation) }))] }));
|
|
2465
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(DateSelectFormBox, { name: "policyStart", dateNames: ['policyStartYear', 'policyStartMonth', 'policyStartDay'], onDateChange: handlePolicyStartChange, defaultValue: defaultPolicyStartDate, title: "What date do you want to start this policy?", errorMessage: getDateErrorMessage([policyStartDay || '', policyStartMonth || '', policyStartYear || ''], applicantState.inValidation), error: applicantState.inValidation, minDate: addDaysToDate('', 1), maxDate: addDaysToDate('', 60), isDay: true }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleInsuredCurrentChange, name: "insuredCurrent", defaultValue: getSelectedOption(yesNoOptions, insuredCurrent), title: "Is your existing policy currently active?", description: "Insurers offer better rates to customers who have a long history of coverage without any gaps.", errorMessage: getErrorMessage(insuredCurrent, applicantState.inValidation) }), insuredCurrent && (jsxs(Fragment, { children: [jsx(SelectFormBox, { options: insuredYearsOptions, name: "dateInsuredSince", onChange: handleInsuredSinceDateChange, defaultValue: getSelectedOption(insuredYearsOptions, dateInsuredSince), title: "For how long have you maintained uninterrupted insurance coverage?", description: `Let us know how long you’ve had ${insuranceType} insurance without letting the policy expire. It’s fine if you’ve changed providers in the past: what matters is that you switched before your coverage expired.`, placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !dateInsuredSince && applicantState.inValidation, errorMessage: getErrorMessage(dateInsuredSince, applicantState.inValidation) }), jsx(SelectFormBox, { options: getInsuranceYearsOptions(dateInsuredSince || insuredYearsOptions.length.toString()), name: "dateInsuredCurrent", onChange: handleInsuredCurrentDateChange, defaultValue: getSelectedOption(getInsuranceYearsOptions(dateInsuredSince || insuredYearsOptions.length.toString()), dateInsuredCurrent), title: "What is the duration of your insurance coverage with your existing provider?", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !dateInsuredCurrent && applicantState.inValidation, errorMessage: getErrorMessage(dateInsuredCurrent, applicantState.inValidation) })] })), !insuredCurrent && insuredCurrent !== undefined && (jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleInsuredBeforeChange, name: "insuredBefore", defaultValue: getSelectedOption(yesNoOptions, insuredBefore), title: `Have you had a ${insuranceType} insurance policy in the past?`, description: "The gender on the policy should match your official applicant\u2019s licence. Some insurers analyze a applicant's sex when creating a policy. Men are typically considered higher risk than female applicants, but the statistics supporting this idea vary from province to province. On average, men and women pay roughly the same for insurance, though.", errorMessage: getErrorMessage(insuredBefore, applicantState.inValidation) }))] }));
|
|
2449
2466
|
};
|
|
2450
2467
|
|
|
2451
2468
|
const SectionApplicantCancellation = () => {
|
|
2452
2469
|
const { applicantState, dispatchApplicantCancellationState } = useStoreFormHomeApplicantCancellation();
|
|
2453
2470
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
2454
2471
|
const { insuranceCancellation, insuranceCancellationList } = applicantState;
|
|
2455
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2472
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2456
2473
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2457
|
-
const mychoiceCls = appType
|
|
2458
|
-
const { insured: { birthYear, birthMonth, birthDay } } = applicantState;
|
|
2474
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2475
|
+
const { insured: { birthYear, birthMonth, birthDay }, } = applicantState;
|
|
2459
2476
|
const handleIconClick = (index) => () => {
|
|
2460
2477
|
dispatchApplicantCancellationState({
|
|
2461
2478
|
type: StoreFormHomeApplicantCancellationActionTypes.FormHomeApplicantCancellationDelete,
|
|
@@ -2499,24 +2516,23 @@ const SectionApplicantCancellation = () => {
|
|
|
2499
2516
|
});
|
|
2500
2517
|
}
|
|
2501
2518
|
};
|
|
2502
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Cancellations" }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(yesNoOptions, insuranceCancellation), title: "Have you ever had a cancelation due to non payment?" }), insuranceCancellation && (jsxs(Fragment, { children: [insuranceCancellationList?.map(({ cancellationYear, cancellationMonth
|
|
2519
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Cancellations" }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(yesNoOptions, insuranceCancellation), title: "Have you ever had a cancelation due to non payment?" }), insuranceCancellation && (jsxs(Fragment, { children: [insuranceCancellationList?.map(({ cancellationYear, cancellationMonth }, index) => {
|
|
2503
2520
|
const defaultCancellationDate = {
|
|
2504
2521
|
year: cancellationYear,
|
|
2505
2522
|
month: cancellationMonth,
|
|
2506
2523
|
day: '01',
|
|
2507
2524
|
};
|
|
2508
2525
|
return (jsxs("div", { className: "list-block", children: [jsx("hr", {}), jsx("div", { className: "list-item", children: jsx(DateSelectFormBox, { name: `cancellationDate-${index}`, dateNames: [`cancellationYear-${index}`, `cancellationMonth-${index}`], onDateChange: handleCancellationDateChange(index), defaultValue: defaultCancellationDate, title: "What was the date of the cancellation?", isRemovable: insuranceCancellationList.length > 1, onIconClick: handleIconClick(index), errorMessage: getDateErrorMessage(['01', cancellationMonth, cancellationYear], applicantState.inValidation), error: applicantState.inValidation, minDate: birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '' }) })] }, `insurance-cancellation-${index}`));
|
|
2509
|
-
}), insuranceCancellationList && insuranceCancellationList.length < 3
|
|
2510
|
-
? (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" })) : (jsx("p", { className: "warning-message", children: "We\u2019re sorry. We cannot currently provide quotes online for 3+ insurance cancelations. Please call one of our broker partners at 1.855.843.1570 to ensure you get an accurate quote over the phone." }))] }))] }));
|
|
2526
|
+
}), insuranceCancellationList && insuranceCancellationList.length < 3 ? (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" })) : (jsx("p", { className: "warning-message", children: "We\u2019re sorry. We cannot currently provide quotes online for 3+ insurance cancelations. Please call one of our broker partners at 1.855.843.1570 to ensure you get an accurate quote over the phone." }))] }))] }));
|
|
2511
2527
|
};
|
|
2512
2528
|
|
|
2513
2529
|
const SectionApplicantClaim = () => {
|
|
2514
2530
|
const { applicantState, dispatchApplicantClaimState } = useStoreFormHomeApplicantClaim();
|
|
2515
2531
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
2516
2532
|
const { insuranceClaim, insuranceClaimList } = applicantState;
|
|
2517
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2533
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2518
2534
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2519
|
-
const mychoiceCls = appType
|
|
2535
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2520
2536
|
const handleIconClick = (index) => () => {
|
|
2521
2537
|
dispatchApplicantClaimState({
|
|
2522
2538
|
type: StoreFormHomeApplicantClaimActionTypes.FormHomeApplicantClaimDelete,
|
|
@@ -2569,15 +2585,14 @@ const SectionApplicantClaim = () => {
|
|
|
2569
2585
|
});
|
|
2570
2586
|
}
|
|
2571
2587
|
};
|
|
2572
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Claims" }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleClaimChange, name: "insuranceClaim", defaultValue: getSelectedOption(yesNoOptions, insuranceClaim), title: "Any claims within the last 5 years?", description: "Your quotes will be more accurate if you let us know your claims history." }), insuranceClaim && (jsxs(Fragment, { children: [insuranceClaimList?.map(({ claimYear, claimMonth, claimType
|
|
2588
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Claims" }), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleClaimChange, name: "insuranceClaim", defaultValue: getSelectedOption(yesNoOptions, insuranceClaim), title: "Any claims within the last 5 years?", description: "Your quotes will be more accurate if you let us know your claims history." }), insuranceClaim && (jsxs(Fragment, { children: [insuranceClaimList?.map(({ claimYear, claimMonth, claimType }, index) => {
|
|
2573
2589
|
const defaultClaimDate = {
|
|
2574
2590
|
year: claimYear,
|
|
2575
2591
|
month: claimMonth,
|
|
2576
2592
|
day: '01',
|
|
2577
2593
|
};
|
|
2578
2594
|
return (jsxs("div", { className: "list-block", children: [jsx("hr", {}), jsxs("div", { className: "list-item", children: [jsx(DateSelectFormBox, { name: `claimDate-${index}`, dateNames: [`claimYear-${index}`, `claimMonth-${index}`], onDateChange: handleClaimDateChange(index), defaultValue: defaultClaimDate, title: "Claim Date", isRemovable: insuranceClaimList.length > 1, onIconClick: handleIconClick(index), errorMessage: getDateErrorMessage(['01', claimMonth, claimYear], applicantState.inValidation), error: applicantState.inValidation, minDate: subYearsFromDate('', 5) }), jsx(SelectFormBox, { options: claimTypeOptions, name: `claim-type-${index}`, onChange: handleClaimTypeChange(index), defaultValue: claimType, title: "Claim Type", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !claimType && applicantState.inValidation, errorMessage: getErrorMessage(claimType, applicantState.inValidation) })] })] }, `driver-claim-${index}`));
|
|
2579
|
-
}), insuranceClaimList && insuranceClaimList.length < 3
|
|
2580
|
-
? (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" })) : (jsx("p", { className: "warning-message", children: "We\u2019re sorry. We cannot currently provide quotes online for 3+ insurance claims. Please call one of our broker partners at 1.855.843.1570 to ensure you get an accurate quote over the phone." }))] }))] }));
|
|
2595
|
+
}), insuranceClaimList && insuranceClaimList.length < 3 ? (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" })) : (jsx("p", { className: "warning-message", children: "We\u2019re sorry. We cannot currently provide quotes online for 3+ insurance claims. Please call one of our broker partners at 1.855.843.1570 to ensure you get an accurate quote over the phone." }))] }))] }));
|
|
2581
2596
|
};
|
|
2582
2597
|
|
|
2583
2598
|
const PageApplicant = () => {
|
|
@@ -2833,9 +2848,14 @@ const BlockDwellingInfo = () => {
|
|
|
2833
2848
|
};
|
|
2834
2849
|
|
|
2835
2850
|
const BlockNextPageInfo$1 = () => {
|
|
2836
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2837
|
-
|
|
2838
|
-
|
|
2851
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2852
|
+
if (appType === AppTypes.TheBig) {
|
|
2853
|
+
return (jsx("div", { className: "privacy-policy", children: jsxs("p", { children: [jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) }));
|
|
2854
|
+
}
|
|
2855
|
+
if (appType === AppTypes.MyChoice) {
|
|
2856
|
+
jsxs(Fragment, { children: [jsx("h5", { children: "On the next page, you will also be able to:" }), jsxs("div", { className: "next-page-points", children: [jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsx("div", { className: "privacy-policy", children: jsxs("p", { children: ["Once you submit this form, you are agreeing to have your insurance quote sent to you via email and My Choice will provide your contact information to one of our trusted broker partners, who will contact you after your quote is complete to further assist you in securing your best rate. For more details, see our", jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] });
|
|
2857
|
+
}
|
|
2858
|
+
return null;
|
|
2839
2859
|
};
|
|
2840
2860
|
|
|
2841
2861
|
const BlockSubmit$1 = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
@@ -2865,14 +2885,14 @@ BlockSubmit$1.defaultProps = {
|
|
|
2865
2885
|
};
|
|
2866
2886
|
|
|
2867
2887
|
const SectionDiscountInfo = () => {
|
|
2868
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
2888
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
2869
2889
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2870
|
-
const mychoiceCls = appType
|
|
2890
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2871
2891
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2872
2892
|
// const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
|
|
2873
2893
|
const { validateEmail, errorMessage } = useHandlerHomeQuoterEmail();
|
|
2874
2894
|
const { multiplePoliciesDiscount, emailTo: { email, emailStatus }, quoterInfo = {}, } = discountState;
|
|
2875
|
-
const { firstName = '', lastName = '', phone = '', caslConsent
|
|
2895
|
+
const { firstName = '', lastName = '', phone = '', caslConsent } = quoterInfo;
|
|
2876
2896
|
const handleMultiplePolicyChange = ({ value }) => {
|
|
2877
2897
|
dispatchDiscountState({
|
|
2878
2898
|
type: StoreFormHomeDiscountActionTypes.FormHomeDiscountMultiplePoliciesSelect,
|
|
@@ -2906,13 +2926,11 @@ const SectionDiscountInfo = () => {
|
|
|
2906
2926
|
payload: { caslConsent: value },
|
|
2907
2927
|
});
|
|
2908
2928
|
};
|
|
2909
|
-
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), isTheBig
|
|
2910
|
-
? (jsx(LabelFormBox, { title: `You are seconds away from receiving your ${insuranceType} insurance quotes, please provide your email after completing the discount section so we can send you your personalized free ${insuranceType} insurance quotes!` }))
|
|
2911
|
-
: (jsx("span", { className: "info-title-message", children: `You are seconds away from receiving your ${insuranceType} insurance quotes,
|
|
2929
|
+
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), isTheBig ? (jsx(LabelFormBox, { title: `You are seconds away from receiving your ${insuranceType} insurance quotes, please provide your email after completing the discount section so we can send you your personalized free ${insuranceType} insurance quotes!` })) : (jsx("span", { className: "info-title-message", children: `You are seconds away from receiving your ${insuranceType} insurance quotes,
|
|
2912
2930
|
please provide your email after completing the discount section so we
|
|
2913
|
-
can send you your personalized free ${insuranceType} insurance quotes!` })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(yesNoOptions, multiplePoliciesDiscount), title: "You could potentially save up to 18% more. Would you consider consolidating multiple policies (like auto insurance) with the same provider?", description: "Most insurers offer discounts to consumers who purchase multiple policies. Select \u2018yes\u2019 if you\u2019d like to bundle your home and auto insurance policies." }), jsx(BlockDwellingInfo, {}), jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsx(InputFormBox, { name: "lastName", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && discountState.inValidation, errorMessage: getErrorMessage(lastName, discountState.inValidation) }), jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsx(InputFormEmailBox, { validationStatus: emailStatus, name: "email", title: "Please share your email address with us, we'll use it to send you a copy of your quotes.", description: "We will provide you with your insurance quotes immediately after this form completion. If you are not ready to apply today, don\u2019t worry as we will be emailing your quotes to you if you\u2019d like to complete at a later date with the help of one of our trusted broker partners.", onChange: handleEmailChange, defaultValue: email, placeholder:
|
|
2914
|
-
? errorMessage
|
|
2915
|
-
|
|
2931
|
+
can send you your personalized free ${insuranceType} insurance quotes!` })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(yesNoOptions, multiplePoliciesDiscount), title: "You could potentially save up to 18% more. Would you consider consolidating multiple policies (like auto insurance) with the same provider?", description: "Most insurers offer discounts to consumers who purchase multiple policies. Select \u2018yes\u2019 if you\u2019d like to bundle your home and auto insurance policies." }), jsx(BlockDwellingInfo, {}), jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsx(InputFormBox, { name: "lastName", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && discountState.inValidation, errorMessage: getErrorMessage(lastName, discountState.inValidation) }), jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsx(InputFormEmailBox, { validationStatus: emailStatus, name: "email", title: "Please share your email address with us, we'll use it to send you a copy of your quotes.", description: "We will provide you with your insurance quotes immediately after this form completion. If you are not ready to apply today, don\u2019t worry as we will be emailing your quotes to you if you\u2019d like to complete at a later date with the help of one of our trusted broker partners.", onChange: handleEmailChange, defaultValue: email, placeholder: getPlaceholderEmail(appType), errorMessage: emailStatus === ValidationStatusTypes.Declined
|
|
2932
|
+
? errorMessage
|
|
2933
|
+
: getErrorMessage(email, discountState.inValidation), error: emailStatus === ValidationStatusTypes.Declined || (!email && discountState.inValidation) }), isTheBig && (jsx(CheckboxForm, { className: "casl-consent", name: "caslConsent", label: "Yes, I consent to receiving emails from the Billyard Insurance Group.\n I understand that I can unsubscribe at any time", onChange: handleCaslConsentChange, defaultValue: caslConsent })), jsx(BlockSubmit$1, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsx(BlockNextPageInfo$1, {})] }));
|
|
2916
2934
|
};
|
|
2917
2935
|
|
|
2918
2936
|
const PageHomeDiscount = () => {
|
|
@@ -2935,18 +2953,18 @@ const PageHomeDiscount = () => {
|
|
|
2935
2953
|
};
|
|
2936
2954
|
|
|
2937
2955
|
const SectionQuoteEdit$1 = () => {
|
|
2938
|
-
const { appConfigState: { localIndex, insuranceType } } = useStoreAppConfig();
|
|
2956
|
+
const { appConfigState: { localIndex, insuranceType }, } = useStoreAppConfig();
|
|
2939
2957
|
const { applicantState } = useStoreFormHomeApplicantBase();
|
|
2940
2958
|
const { dwellingState } = useStoreFormHomeDwelling();
|
|
2941
2959
|
const { postalState } = useStoreFormHomePostal();
|
|
2942
|
-
const { discountState: { multiplePoliciesDiscount, quoterInfo } } = useStoreFormHomeDiscount();
|
|
2943
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2960
|
+
const { discountState: { multiplePoliciesDiscount, quoterInfo }, } = useStoreFormHomeDiscount();
|
|
2961
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2944
2962
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2945
|
-
const mychoiceCls = appType
|
|
2946
|
-
const { item: { postalCode, provinceCode, city, streetAddress
|
|
2963
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2964
|
+
const { item: { postalCode, provinceCode, city, streetAddress }, } = postalState;
|
|
2947
2965
|
const { deadbolt, sprinkler, burglarAlarm, fireAlarm, fireExtinguishersCount, // mortgagesCount,
|
|
2948
2966
|
} = dwellingState;
|
|
2949
|
-
const { insured: { nonsmoker } } = applicantState;
|
|
2967
|
+
const { insured: { nonsmoker }, } = applicantState;
|
|
2950
2968
|
const discounts = [];
|
|
2951
2969
|
const isHome = insuranceType === InsuranceTypes.Home;
|
|
2952
2970
|
if (multiplePoliciesDiscount) {
|
|
@@ -2991,17 +3009,23 @@ const SectionQuoteEdit$1 = () => {
|
|
|
2991
3009
|
const discountEdit = () => () => {
|
|
2992
3010
|
navigate(`/${localIndex || defaultLocalIndex}/${insuranceType}/discount`);
|
|
2993
3011
|
};
|
|
2994
|
-
return (jsxs("div", { className: `edit-quote-section ${mychoiceCls}`, children: [jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Edit Quote" }), jsxs("div", { className: "edit-section-content", children: [jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: addressEdit, title: "Address", items: [[address]] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: dwellingEdit, title: "Property Information", items: [[`Year Built: ${dwellingState.builtYear}`]] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: applicantEdit, title: "Applicant Information", items: [
|
|
3012
|
+
return (jsxs("div", { className: `edit-quote-section ${mychoiceCls}`, children: [jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Edit Quote" }), jsxs("div", { className: "edit-section-content", children: [jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: addressEdit, title: "Address", items: [[address]] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: dwellingEdit, title: "Property Information", items: [[`Year Built: ${dwellingState.builtYear}`]] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: applicantEdit, title: "Applicant Information", items: [
|
|
3013
|
+
[
|
|
3014
|
+
`Name: ${quoterInfo?.firstName}`,
|
|
3015
|
+
`Occupied by: ${occupiedMembers}`,
|
|
3016
|
+
`Year Occupied: ${dwellingState.occupiedYear}`,
|
|
3017
|
+
],
|
|
3018
|
+
] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: discountEdit, title: "Discount Information", items: [discounts] })] })] }));
|
|
2995
3019
|
};
|
|
2996
3020
|
|
|
2997
3021
|
// import { BlockEndorsements } from './blocks/BlockEndorsements';
|
|
2998
3022
|
const SectionQuoteRecalc = () => {
|
|
2999
3023
|
const [ppLocalOptions, setPpLocalOptions] = useState(ppOptions);
|
|
3000
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
3024
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
3001
3025
|
const isTheBig = appType === AppTypes.TheBig;
|
|
3002
|
-
const mychoiceCls = appType
|
|
3026
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
3003
3027
|
const { dwellingState, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
3004
|
-
const { deductible, liability, waterCoverage, pp
|
|
3028
|
+
const { deductible, liability, waterCoverage, pp } = dwellingState;
|
|
3005
3029
|
useEffect(() => {
|
|
3006
3030
|
if (insuranceType === InsuranceTypes.Condo) {
|
|
3007
3031
|
setPpLocalOptions(ppOptions.slice(1));
|
|
@@ -3034,9 +3058,7 @@ const SectionQuoteRecalc = () => {
|
|
|
3034
3058
|
payload: { waterCoverage: value },
|
|
3035
3059
|
});
|
|
3036
3060
|
};
|
|
3037
|
-
return (jsx("div", { className: "form-container", children: jsxs("div", { className: `form-section edit-recalc-container ${mychoiceCls}`, children: [jsx(SelectFormBox, { options: homeCoverageOptions, name: "deductible", onChange: handleDeductibleChange, defaultValue: getSelectedOption(homeCoverageOptions, deductible), title: "Deductible", description: "The deductible is the sum you commit to paying out-of-pocket when making an insurance claim. This amount is subtracted from the total payout you receive from your insurance provider. As an illustration, if your agreed-upon deductible is $500 and the overall damage cost is $5,000, you would cover the first $500, while the insurance company would handle the remaining $4,500. By choosing to increase your deductible, you can reduce the price of your premium.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), jsx(SelectFormBox, { options: homeLiabilityOptions, name: "liability", onChange: handleLiabilityChange, defaultValue: getSelectedOption(homeLiabilityOptions, liability), title: "Liability", description: "Liability insurance safeguards you in case someone gets hurt on your premises, regardless of whether the injury was accidental. For instance, if an individual falls over and injures themselves within your property and opts to take legal action, liability insurance will shoulder a portion of the related expenses. Additionally, it provides protection in the event that you cause damage to another person's property. However, it's important to note that elevating your liability limit can lead to a higher premium cost.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), !(insuranceType === InsuranceTypes.Home) && (jsx(SelectFormBox, { options: ppLocalOptions, name: "pp", onChange: handlePpChange, defaultValue: getSelectedOption(ppLocalOptions, pp), title: "Personal Property Limit", description: "Personal property refers to the items that you own and typically store within your home, including things like furniture, appliances, clothing, and so on.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleWaterCoverageChange, name: "waterCoverage", defaultValue: getSelectedOption(yesNoOptions, waterCoverage), title: "Water Damage", description: "Water damage insurance includes the following three types of coverage:\n\n1. Sewer Backup Coverage: This protection safeguards you against floods resulting from an overflow of the sewage system due to heavy rainfall or snowmelt.\n\n2. Overland Water Coverage: This coverage defends you against damages from water entering your home at or above ground level, which may be due to an overflowing lake or river, heavy rain, or melted snow.\n\n3. Ground Water Coverage: This coverage provides protection from damage caused by groundwater entering your home through the foundation, floors, or basement walls following sudden water accumulation after substantial rain or snowmelt.\n\nPlease be aware that each insurance provider may have unique policies regarding water damage coverage. Some providers may only offer all three types of coverage together, while others might offer just one. To determine the coverage that is most appropriate for your needs, please consult with our broker partner." }), jsx(BlockSubmit$1, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} recalculate`, label: "Recalculate Quote", buttonSize: SizeTypes.Medium, isRecalc: true }), jsx("div", { className: "endorsements-container", children: jsxs("div", { className: "labels-block", children: [!(insuranceType === InsuranceTypes.Home)
|
|
3038
|
-
? (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "additionalLivingExpenses", title: "Additional Living Expenses", description: "This coverage allows you to cover the medical expenses of someone who sustains an injury on your property, irrespective of your legal liability for the damages. To clarify the extent of this coverage, please engage in a conversation with the broker.", isActive: true }), insuranceType === InsuranceTypes.Condo
|
|
3039
|
-
&& (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "contingentLiability", title: "Contingent Liability", description: "Contingent liability provides protection for your condominium unit if the condominium management's insurance policy proves to be inadequate or has lapsed. For information on the coverage limit, please speak with the broker.", isActive: true }), jsx(LabelFormBox, { name: "lossAssessmentProperty", title: "Loss Assessment - Property", description: "This type of coverage safeguards the communal property that you utilize along with other condominium residents, in the event that the policy held by the condominium management falls short or has ended. For specifics regarding the coverage limit, please engage with the broker.", isActive: true }), jsx(LabelFormBox, { name: "lossAssessmentLiability", title: "Loss Assessment - Liability", description: "This coverage shields the collective liability that you and other condo residents bear for the shared property, should the condo management's insurance policy be inadequate or have expired. To understand the limit of this coverage, it's advisable to consult with the broker.", isActive: true }), jsx(LabelFormBox, { name: "bettermentsImprovements", title: "Betterments and Improvements", description: "This coverage applies to any enhancements you've made to the built-in attributes and amenities of your condominium. To determine the extent of this coverage, please speak with the broker.", isActive: true })] }))] })) : (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "outbuildings", title: "Outbuildings", isActive: true }), jsx(LabelFormBox, { name: "contents", title: "Contents", isActive: true })] })), jsx(LabelFormBox, { name: "voluntaryMedical", title: "Voluntary Medical", description: "This coverage allows you to cover the medical expenses of someone who sustains an injury on your property, irrespective of your legal liability for the damages. To clarify the extent of this coverage, please engage in a conversation with the broker.", isActive: true }), jsx(LabelFormBox, { name: "voluntaryProperty", title: "Voluntary Property", description: "This coverage provides protection if you inadvertently cause damage to another individual's property, irrespective of your legal obligation to compensate for the damages. For information regarding the coverage limit, please consult with the broker.", isActive: true })] }) })] }) }));
|
|
3061
|
+
return (jsx("div", { className: "form-container", children: jsxs("div", { className: `form-section edit-recalc-container ${mychoiceCls}`, children: [jsx(SelectFormBox, { options: homeCoverageOptions, name: "deductible", onChange: handleDeductibleChange, defaultValue: getSelectedOption(homeCoverageOptions, deductible), title: "Deductible", description: "The deductible is the sum you commit to paying out-of-pocket when making an insurance claim. This amount is subtracted from the total payout you receive from your insurance provider. As an illustration, if your agreed-upon deductible is $500 and the overall damage cost is $5,000, you would cover the first $500, while the insurance company would handle the remaining $4,500. By choosing to increase your deductible, you can reduce the price of your premium.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), jsx(SelectFormBox, { options: homeLiabilityOptions, name: "liability", onChange: handleLiabilityChange, defaultValue: getSelectedOption(homeLiabilityOptions, liability), title: "Liability", description: "Liability insurance safeguards you in case someone gets hurt on your premises, regardless of whether the injury was accidental. For instance, if an individual falls over and injures themselves within your property and opts to take legal action, liability insurance will shoulder a portion of the related expenses. Additionally, it provides protection in the event that you cause damage to another person's property. However, it's important to note that elevating your liability limit can lead to a higher premium cost.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), !(insuranceType === InsuranceTypes.Home) && (jsx(SelectFormBox, { options: ppLocalOptions, name: "pp", onChange: handlePpChange, defaultValue: getSelectedOption(ppLocalOptions, pp), title: "Personal Property Limit", description: "Personal property refers to the items that you own and typically store within your home, including things like furniture, appliances, clothing, and so on.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false })), jsx(SwitchButtonBox, { items: yesNoOptions, onChange: handleWaterCoverageChange, name: "waterCoverage", defaultValue: getSelectedOption(yesNoOptions, waterCoverage), title: "Water Damage", description: "Water damage insurance includes the following three types of coverage:\n\n1. Sewer Backup Coverage: This protection safeguards you against floods resulting from an overflow of the sewage system due to heavy rainfall or snowmelt.\n\n2. Overland Water Coverage: This coverage defends you against damages from water entering your home at or above ground level, which may be due to an overflowing lake or river, heavy rain, or melted snow.\n\n3. Ground Water Coverage: This coverage provides protection from damage caused by groundwater entering your home through the foundation, floors, or basement walls following sudden water accumulation after substantial rain or snowmelt.\n\nPlease be aware that each insurance provider may have unique policies regarding water damage coverage. Some providers may only offer all three types of coverage together, while others might offer just one. To determine the coverage that is most appropriate for your needs, please consult with our broker partner." }), jsx(BlockSubmit$1, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} recalculate`, label: "Recalculate Quote", buttonSize: SizeTypes.Medium, isRecalc: true }), jsx("div", { className: "endorsements-container", children: jsxs("div", { className: "labels-block", children: [!(insuranceType === InsuranceTypes.Home) ? (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "additionalLivingExpenses", title: "Additional Living Expenses", description: "This coverage allows you to cover the medical expenses of someone who sustains an injury on your property, irrespective of your legal liability for the damages. To clarify the extent of this coverage, please engage in a conversation with the broker.", isActive: true }), insuranceType === InsuranceTypes.Condo && (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "contingentLiability", title: "Contingent Liability", description: "Contingent liability provides protection for your condominium unit if the condominium management's insurance policy proves to be inadequate or has lapsed. For information on the coverage limit, please speak with the broker.", isActive: true }), jsx(LabelFormBox, { name: "lossAssessmentProperty", title: "Loss Assessment - Property", description: "This type of coverage safeguards the communal property that you utilize along with other condominium residents, in the event that the policy held by the condominium management falls short or has ended. For specifics regarding the coverage limit, please engage with the broker.", isActive: true }), jsx(LabelFormBox, { name: "lossAssessmentLiability", title: "Loss Assessment - Liability", description: "This coverage shields the collective liability that you and other condo residents bear for the shared property, should the condo management's insurance policy be inadequate or have expired. To understand the limit of this coverage, it's advisable to consult with the broker.", isActive: true }), jsx(LabelFormBox, { name: "bettermentsImprovements", title: "Betterments and Improvements", description: "This coverage applies to any enhancements you've made to the built-in attributes and amenities of your condominium. To determine the extent of this coverage, please speak with the broker.", isActive: true })] }))] })) : (jsxs(Fragment, { children: [jsx(LabelFormBox, { name: "outbuildings", title: "Outbuildings", isActive: true }), jsx(LabelFormBox, { name: "contents", title: "Contents", isActive: true })] })), jsx(LabelFormBox, { name: "voluntaryMedical", title: "Voluntary Medical", description: "This coverage allows you to cover the medical expenses of someone who sustains an injury on your property, irrespective of your legal liability for the damages. To clarify the extent of this coverage, please engage in a conversation with the broker.", isActive: true }), jsx(LabelFormBox, { name: "voluntaryProperty", title: "Voluntary Property", description: "This coverage provides protection if you inadvertently cause damage to another individual's property, irrespective of your legal obligation to compensate for the damages. For information regarding the coverage limit, please consult with the broker.", isActive: true })] }) })] }) }));
|
|
3040
3062
|
};
|
|
3041
3063
|
|
|
3042
3064
|
const SplashScreen$1 = () => {
|
|
@@ -3106,7 +3128,7 @@ const Description = () => (jsxs("div", { children: [jsx("span", { children: jsx(
|
|
|
3106
3128
|
const SectionCoverage = () => {
|
|
3107
3129
|
const { coverageState: { type, coverage, province, inValidation }, dispatchCoverageState, } = useStoreFormLifeCoverage();
|
|
3108
3130
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3109
|
-
const isMychoice = appType
|
|
3131
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
3110
3132
|
// const handleProvinceChange = ({ value }: OnChangeEventInterface) => {
|
|
3111
3133
|
// dispatchCoverageState({
|
|
3112
3134
|
// type: StoreFormLifeCoverageActionTypes.FormLifeProvinceSelect,
|
|
@@ -3289,10 +3311,9 @@ const SectionApplicant = () => {
|
|
|
3289
3311
|
textAlign: 'center',
|
|
3290
3312
|
fontSize: '1.15rem',
|
|
3291
3313
|
marginTop: '10px',
|
|
3292
|
-
}, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsx("h2", { className: "section-title", style: { textAlign: 'center' }, children: `${lockEmoji} Complete the form below to see which companies are offering your quotes.` }), jsx("span", { className: "info-title-message", children: "You are seconds away from receiving your life insurance quotes, please provide your email after completing the final steps so we can send you your personalized free life insurance quotes!" }), jsx(DateSelectFormBox, { name: "dateOfBirth", dateNames: ['birthYear', 'birthMonth', 'birthDay'], onDateChange: handleDateOfBirthChange, defaultValue: defaultDateOfBirth, title: "Date of birth", error: inValidation, errorMessage: getDateErrorMessage([birthDay || '', birthMonth || '', birthYear || ''], inValidation), maxDate: subYearsFromDate('', 14), isDay: true }), jsx(SelectFormBox, { options: genderOptions, name: "gender", onChange: handleGenderChange, defaultValue: getSelectedOption(genderOptions, gender), title: "Gender", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !gender && inValidation, errorMessage: getErrorMessage(`${gender}`.toString(), inValidation) }), jsx(SwitchButtonBox, { items: smokerOptions, onChange: handleSmokerChange, name: "smoker", defaultValue: getSelectedOption(smokerOptions, smoker), title: "Smoker" }), isTheBig && (jsxs("div", { className: "input-form-box-container", children: [jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxs("ol", { className: "ordered-block", children: [jsx("li", { children: "See what rates insurance carriers are offering" }), jsx("li", { children: "Get in touch with us and secure your rate" }), jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })), jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && inValidation, errorMessage: getErrorMessage(firstName, inValidation) }), jsx(InputFormBox, { name: "lastname", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && inValidation, errorMessage: getErrorMessage(lastName, inValidation) }), jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && inValidation, errorMessage: getErrorMessage(phone, inValidation) }), jsx(InputFormEmailBox, { validationStatus: emailStatus, name: "email", title: "Please provide your email address so we can send you a copy of your quotes", onChange: handleEmailChange, defaultValue: email, placeholder:
|
|
3314
|
+
}, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsx("h2", { className: "section-title", style: { textAlign: 'center' }, children: `${lockEmoji} Complete the form below to see which companies are offering your quotes.` }), jsx("span", { className: "info-title-message", children: "You are seconds away from receiving your life insurance quotes, please provide your email after completing the final steps so we can send you your personalized free life insurance quotes!" }), jsx(DateSelectFormBox, { name: "dateOfBirth", dateNames: ['birthYear', 'birthMonth', 'birthDay'], onDateChange: handleDateOfBirthChange, defaultValue: defaultDateOfBirth, title: "Date of birth", error: inValidation, errorMessage: getDateErrorMessage([birthDay || '', birthMonth || '', birthYear || ''], inValidation), maxDate: subYearsFromDate('', 14), isDay: true }), jsx(SelectFormBox, { options: genderOptions, name: "gender", onChange: handleGenderChange, defaultValue: getSelectedOption(genderOptions, gender), title: "Gender", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !gender && inValidation, errorMessage: getErrorMessage(`${gender}`.toString(), inValidation) }), jsx(SwitchButtonBox, { items: smokerOptions, onChange: handleSmokerChange, name: "smoker", defaultValue: getSelectedOption(smokerOptions, smoker), title: "Smoker" }), isTheBig && (jsxs("div", { className: "input-form-box-container", children: [jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxs("ol", { className: "ordered-block", children: [jsx("li", { children: "See what rates insurance carriers are offering" }), jsx("li", { children: "Get in touch with us and secure your rate" }), jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })), jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && inValidation, errorMessage: getErrorMessage(firstName, inValidation) }), jsx(InputFormBox, { name: "lastname", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && inValidation, errorMessage: getErrorMessage(lastName, inValidation) }), jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && inValidation, errorMessage: getErrorMessage(phone, inValidation) }), jsx(InputFormEmailBox, { validationStatus: emailStatus, name: "email", title: "Please provide your email address so we can send you a copy of your quotes", onChange: handleEmailChange, defaultValue: email, placeholder: getPlaceholderEmail(appType), errorMessage: emailStatus === ValidationStatusTypes.Declined
|
|
3293
3315
|
? errorMessage
|
|
3294
|
-
: getErrorMessage(email, inValidation), error: emailStatus === ValidationStatusTypes.Declined ||
|
|
3295
|
-
(!email && inValidation) }), jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsx(BlockNextPageInfo, {})] }));
|
|
3316
|
+
: getErrorMessage(email, inValidation), error: emailStatus === ValidationStatusTypes.Declined || (!email && inValidation) }), jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsx(BlockNextPageInfo, {})] }));
|
|
3296
3317
|
};
|
|
3297
3318
|
|
|
3298
3319
|
const PageLifeApplicant = () => {
|
|
@@ -3405,16 +3426,18 @@ const getFormattedAddress = (unitNumber, streetAddress, city, provinceCode, post
|
|
|
3405
3426
|
return '';
|
|
3406
3427
|
};
|
|
3407
3428
|
const ModalAddress = () => {
|
|
3408
|
-
const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack
|
|
3409
|
-
const { status, getPostal, errorMessage: reqErrorMessage
|
|
3410
|
-
const { postalState: { item, inValidation }, dispatchPostalState } = useStoreFormHomePostal();
|
|
3411
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
3412
|
-
const { postalCode, city, provinceCode, streetAddress, unitNumber
|
|
3429
|
+
const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack }, dispatchAppModalState, } = useStoreAppModal();
|
|
3430
|
+
const { status, getPostal, errorMessage: reqErrorMessage } = useHandlerPostal(InsuranceTypes.Home);
|
|
3431
|
+
const { postalState: { item, inValidation }, dispatchPostalState, } = useStoreFormHomePostal();
|
|
3432
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3433
|
+
const { postalCode, city, provinceCode, streetAddress, unitNumber } = item;
|
|
3413
3434
|
const [localPostalCode, setLocalPostalCode] = useState(postalCode);
|
|
3414
3435
|
const [localUnitNumber, setLocalUnitNumber] = useState(unitNumber);
|
|
3415
3436
|
const [localStreetAddress, setLocalStreetAddress] = useState(streetAddress);
|
|
3416
3437
|
const loading = status === RequestStatusTypes.Loading;
|
|
3417
|
-
const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
|
|
3438
|
+
const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
|
|
3439
|
+
? 'The street address should be in the format "123 Streetname Rd."'
|
|
3440
|
+
: '';
|
|
3418
3441
|
const postalCodeErrMessage = localPostalCode.length < 4 ? 'Postal code should have at least 4 characters' : '';
|
|
3419
3442
|
const handleClick = (callBack) => () => {
|
|
3420
3443
|
if (callBack) {
|
|
@@ -3430,10 +3453,14 @@ const ModalAddress = () => {
|
|
|
3430
3453
|
submitCallBack();
|
|
3431
3454
|
}
|
|
3432
3455
|
else if (!localPostalCode || !localStreetAddress || streetAddressErrMessage || postalCodeErrMessage) {
|
|
3433
|
-
dispatchPostalState({
|
|
3456
|
+
dispatchPostalState({
|
|
3457
|
+
type: StoreFormHomePostalActionTypes.FormHomePostalValidate,
|
|
3458
|
+
payload: { inValidation: true },
|
|
3459
|
+
});
|
|
3434
3460
|
}
|
|
3435
3461
|
else {
|
|
3436
|
-
getPostal(postalCodeFormat(localPostalCode))
|
|
3462
|
+
getPostal(postalCodeFormat(localPostalCode))
|
|
3463
|
+
.then((result) => {
|
|
3437
3464
|
const formattedAddress = getFormattedAddress(localUnitNumber, localStreetAddress, result?.data?.city || '', result?.data?.provinceCode || '', localPostalCode, 'Canada');
|
|
3438
3465
|
dispatchPostalState({
|
|
3439
3466
|
type: StoreFormHomePostalActionTypes.FormHomePostalSet,
|
|
@@ -3446,7 +3473,8 @@ const ModalAddress = () => {
|
|
|
3446
3473
|
},
|
|
3447
3474
|
});
|
|
3448
3475
|
dispatchAppModalState({ type: StoreConfigAppModalActionTypes.AppModalClose });
|
|
3449
|
-
})
|
|
3476
|
+
})
|
|
3477
|
+
.catch();
|
|
3450
3478
|
}
|
|
3451
3479
|
}
|
|
3452
3480
|
};
|
|
@@ -3463,7 +3491,7 @@ const ModalAddress = () => {
|
|
|
3463
3491
|
break;
|
|
3464
3492
|
}
|
|
3465
3493
|
};
|
|
3466
|
-
return (jsxs("div", { className: `modal-container edit-address ${appType
|
|
3494
|
+
return (jsxs("div", { className: `modal-container edit-address ${isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: [title && jsx("h3", { children: title }), description && jsx("p", { children: description }), jsx(InputFormBox, { name: "streetAddress", title: "Street Address", onChange: handleChange('streetAddress'), defaultValue: localStreetAddress, placeholder: "Street Name and Number", error: (!localStreetAddress || !/\b\s+\b/.test(localStreetAddress)) && inValidation, errorMessage: getErrorMessage(localStreetAddress, inValidation, streetAddressErrMessage) }), jsx(InputFormBox, { name: "unitApartmentNumber", title: "Unit/Apartment number", onChange: handleChange('unitNumber'), defaultValue: localUnitNumber, placeholder: "Unit, Suite or Apartment Number" }), jsx(InputFormBox, { name: "city", title: "City", defaultValue: city, placeholder: "City", error: !city && inValidation, errorMessage: getErrorMessage(city, inValidation), disabled: true }), jsx(InputFormBox, { name: "postalCode", title: "Postal Code", onChange: handleChange('postalCode'), defaultValue: localPostalCode, placeholder: "", maxLength: 7, error: ((!localPostalCode || localPostalCode.length < 4) && inValidation) || !!reqErrorMessage, errorMessage: getErrorMessage(localPostalCode, inValidation, postalCodeErrMessage) || reqErrorMessage }), jsx(InputFormBox, { name: "province", title: "Province Code", defaultValue: provinceCode, placeholder: "", error: !provinceCode && inValidation, errorMessage: getErrorMessage(provinceCode, inValidation), disabled: true }), jsxs("div", { className: "modal-buttons", children: [cancelButtonText && (jsx(ButtonBase, { type: ButtonTypes.Button, label: cancelButtonText, category: CategoryTypes.Outlined, color: ColorTypes.Default, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Large, onClick: handleClick(cancelCallBack) })), jsx(ButtonBase, { className: `${loading ? 'disabled' : ''}`, type: ButtonTypes.Button, label: !loading ? submitButtonText || 'OK' : '', category: CategoryTypes.Filled, color: ColorTypes.Primary, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Large, onClick: onSubmit, children: loading ? jsx(IconLoaderSecondary, {}) : undefined })] })] }));
|
|
3467
3495
|
};
|
|
3468
3496
|
|
|
3469
3497
|
const ModalFinale = () => {
|
|
@@ -3490,8 +3518,8 @@ PostalCodeDataBox.defaultProps = {
|
|
|
3490
3518
|
postalCode: '',
|
|
3491
3519
|
};
|
|
3492
3520
|
|
|
3493
|
-
const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted
|
|
3494
|
-
const { appConfigState: { insuranceType, appType, localIndex } } = useStoreAppConfig();
|
|
3521
|
+
const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted }) => {
|
|
3522
|
+
const { appConfigState: { insuranceType, appType, localIndex }, } = useStoreAppConfig();
|
|
3495
3523
|
const { appDeviceType } = useStoreDeviceType();
|
|
3496
3524
|
const isMobile = appDeviceType === DeviceTypes.Mobile;
|
|
3497
3525
|
const navigate = useNavigate();
|
|
@@ -3503,7 +3531,9 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3503
3531
|
const activeStep = formSteps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1));
|
|
3504
3532
|
let activeIndex = formSteps.indexOf(activeStep);
|
|
3505
3533
|
activeIndex = activeIndex === -1 ? 0 : activeIndex;
|
|
3506
|
-
let navigationCls = propertyIsCompleted
|
|
3534
|
+
let navigationCls = propertyIsCompleted
|
|
3535
|
+
? 'mychoice-car-navigation-step-container'
|
|
3536
|
+
: 'mychoice-home-navigation-step-container';
|
|
3507
3537
|
if (insuranceType === InsuranceTypes.Life) {
|
|
3508
3538
|
navigationCls = 'mychoice-life-navigation-step-container';
|
|
3509
3539
|
}
|
|
@@ -3517,7 +3547,8 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3517
3547
|
// }
|
|
3518
3548
|
// }, [propertyIsCompleted]);
|
|
3519
3549
|
const handleStepClick = (item, itemIndex) => () => {
|
|
3520
|
-
if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
|
|
3550
|
+
if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
|
|
3551
|
+
// ignore double click
|
|
3521
3552
|
if (activeIndex > (itemIndex || 0)) {
|
|
3522
3553
|
navigate(`/${localIndex}/${insuranceType}${item?.path}`);
|
|
3523
3554
|
}
|
|
@@ -3533,13 +3564,16 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3533
3564
|
validateOptions.forEach((option, index) => {
|
|
3534
3565
|
const isValid = !option.isValid ? option.validate(false) : option.isValid;
|
|
3535
3566
|
formValidations.push({
|
|
3536
|
-
isValid,
|
|
3567
|
+
isValid,
|
|
3568
|
+
validate: option.validate,
|
|
3569
|
+
requestFn: option?.requestFn || undefined,
|
|
3570
|
+
index,
|
|
3537
3571
|
});
|
|
3538
3572
|
});
|
|
3539
3573
|
}
|
|
3540
3574
|
const formValidated = formValidations.find((option) => !option.isValid);
|
|
3541
3575
|
if (formValidated && !formValidated.isValid) {
|
|
3542
|
-
navigate(`/${localIndex}/${insuranceType}${formSteps[
|
|
3576
|
+
navigate(`/${localIndex}/${insuranceType}${formSteps[formValidated.index || 0]?.path}`);
|
|
3543
3577
|
//
|
|
3544
3578
|
// dispatchAppModalState({
|
|
3545
3579
|
// type: StoreConfigAppModalActionTypes.AppModalMessageModal,
|
|
@@ -3561,7 +3595,7 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3561
3595
|
}
|
|
3562
3596
|
}
|
|
3563
3597
|
};
|
|
3564
|
-
return (jsxs("ol", { className: appType
|
|
3598
|
+
return (jsxs("ol", { className: isMyChoiceLike(appType) ? 'mychoice-navigation-steps-container' : 'navigation-steps-container', children: [!isMobile ? (jsx(Fragment, { children: formSteps?.map((item, index) => {
|
|
3565
3599
|
let cls;
|
|
3566
3600
|
switch (true) {
|
|
3567
3601
|
case activeIndex > index:
|
|
@@ -3570,16 +3604,15 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3570
3604
|
case activeIndex === index:
|
|
3571
3605
|
cls = 'in-progress';
|
|
3572
3606
|
break;
|
|
3573
|
-
default:
|
|
3607
|
+
default:
|
|
3608
|
+
cls = 'todo';
|
|
3574
3609
|
}
|
|
3575
3610
|
// const homeNavigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
|
|
3576
|
-
if (appType
|
|
3611
|
+
if (isMyChoiceLike(appType) && index === formSteps.length - 1) {
|
|
3577
3612
|
return jsx(Fragment, {});
|
|
3578
3613
|
}
|
|
3579
|
-
return (jsx("div", { role: "presentation", className: appType
|
|
3580
|
-
|
|
3581
|
-
: jsx(Step, { className: cls, item: item, index: index }, `${index}-${item?.title}`) }, `${index}-${item?.title}`));
|
|
3582
|
-
}) })) : jsx(Step, { item: formSteps[activeIndex], index: activeIndex, itemsCount: formSteps.length, isMobile: true }), appType === AppTypes.MyChoice && (jsxs(Fragment, { children: [jsx("hr", {}), jsxs("div", { className: "estimated-minutes", children: [jsx(IconClock, {}), jsxs("div", { children: ["Estimated", ' ', jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] })] })] }))] }));
|
|
3614
|
+
return (jsx("div", { role: "presentation", className: isMyChoiceLike(appType) ? navigationCls : 'navigation-step-container', onKeyDown: handleStepClick(item, index), onClick: handleStepClick(item, index), children: isMyChoiceLike(appType) ? (jsx(MychoiceStep, { className: cls, item: item, index: index }, `${index}-${item?.title}`)) : (jsx(Step, { className: cls, item: item, index: index }, `${index}-${item?.title}`)) }, `${index}-${item?.title}`));
|
|
3615
|
+
}) })) : (jsx(Step, { item: formSteps[activeIndex], index: activeIndex, itemsCount: formSteps.length, isMobile: true })), isMyChoiceLike(appType) && (jsxs(Fragment, { children: [jsx("hr", {}), jsxs("div", { className: "estimated-minutes", children: [jsx(IconClock, {}), jsxs("div", { children: ["Estimated", ' ', jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, " ", formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] })] })] }))] }));
|
|
3583
3616
|
};
|
|
3584
3617
|
StepsBox.defaultProps = {
|
|
3585
3618
|
partnerId: '',
|
|
@@ -3666,7 +3699,7 @@ ButtonsBox.defaultProps = {
|
|
|
3666
3699
|
|
|
3667
3700
|
const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearForm, propertyIsCompleted, }) => {
|
|
3668
3701
|
const { pathname } = useLocation();
|
|
3669
|
-
const { appConfigState: { appType, localIndex } } = useStoreAppConfig();
|
|
3702
|
+
const { appConfigState: { appType, localIndex }, } = useStoreAppConfig();
|
|
3670
3703
|
const isTheBig = appType === AppTypes.TheBig;
|
|
3671
3704
|
const { appDeviceType } = useStoreDeviceType();
|
|
3672
3705
|
const isDesktop = appDeviceType === DeviceTypes.Desktop;
|
|
@@ -3692,8 +3725,7 @@ const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearFor
|
|
|
3692
3725
|
return `rgba(${r}, ${g}, ${b}, ${alpha})`;
|
|
3693
3726
|
}
|
|
3694
3727
|
}
|
|
3695
|
-
return (jsx("div", { className: localIndex !== defaultLocalIndex ? 'navigation-container-partner' : 'navigation-container', children: jsxs("div", { className: `content ${appType
|
|
3696
|
-
? (jsx(Fragment, { children: !isDesktop && (formSteps.length - activeIndex - 1) ? (jsxs("div", { className: "estimated-minutes", children: [jsx(IconClock, {}), jsxs("div", { children: [isMobile ? (jsx("div", { children: jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }) })) : (jsx(Fragment, { children: jsxs("div", { children: ["Estimated", ' ', jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] }) })), jsx("span", { children: `Step ${activeIndex + 1}/${formSteps.length - 1}` })] })] })) : jsx("span", {}) })) : (jsx(StepsBox, { formSteps: formSteps, validationHooks: validationHooks, propertyIsCompleted: propertyIsCompleted })), jsx(ButtonsBox, { formSteps: formSteps, validationHooks: validationHooks, clearForm: clearForm, propertyIsCompleted: propertyIsCompleted })] }) }));
|
|
3728
|
+
return (jsx("div", { className: localIndex !== defaultLocalIndex ? 'navigation-container-partner' : 'navigation-container', children: jsxs("div", { className: `content ${isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: [jsx(PostalCodeDataBox, { className: isTheBig ? 'thebig' : '', title: title, postalCode: postalCode }), isMyChoiceLike(appType) ? (jsx(Fragment, { children: !isDesktop && formSteps.length - activeIndex - 1 ? (jsxs("div", { className: "estimated-minutes", children: [jsx(IconClock, {}), jsxs("div", { children: [isMobile ? (jsx("div", { children: jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }) })) : (jsx(Fragment, { children: jsxs("div", { children: ["Estimated", ' ', jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] }) })), jsx("span", { children: `Step ${activeIndex + 1}/${formSteps.length - 1}` })] })] })) : (jsx("span", {})) })) : (jsx(StepsBox, { formSteps: formSteps, validationHooks: validationHooks, propertyIsCompleted: propertyIsCompleted })), jsx(ButtonsBox, { formSteps: formSteps, validationHooks: validationHooks, clearForm: clearForm, propertyIsCompleted: propertyIsCompleted })] }) }));
|
|
3697
3729
|
};
|
|
3698
3730
|
NavigationTop.defaultProps = {
|
|
3699
3731
|
isMobile: false,
|
|
@@ -3704,9 +3736,9 @@ const NavigationBottom = ({ createItem, validateForm, formSteps, className, item
|
|
|
3704
3736
|
const { pathname } = useLocation();
|
|
3705
3737
|
const navigate = useNavigate();
|
|
3706
3738
|
const { appConfigState } = useStoreAppConfig();
|
|
3707
|
-
const isMychoice = appConfigState.appType
|
|
3739
|
+
const isMychoice = isMyChoiceLike(appConfigState.appType);
|
|
3708
3740
|
const { insuranceType } = appConfigState;
|
|
3709
|
-
const { dwellingState: { isCompleted } } = useStoreFormHomeDwelling();
|
|
3741
|
+
const { dwellingState: { isCompleted }, } = useStoreFormHomeDwelling();
|
|
3710
3742
|
const [steps, setSteps] = useState(formSteps);
|
|
3711
3743
|
const currentPath = pathname.split('/');
|
|
3712
3744
|
const activeIndex = steps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1))?.key || 0;
|
|
@@ -3940,39 +3972,35 @@ const AppModalWrapper = () => {
|
|
|
3940
3972
|
const { appModalState } = useStoreAppModal();
|
|
3941
3973
|
switch (appModalState.modalType) {
|
|
3942
3974
|
case ModalTypes.MessageModal:
|
|
3943
|
-
return
|
|
3975
|
+
return jsx(ModalMessage, {});
|
|
3944
3976
|
case ModalTypes.ConfirmModal:
|
|
3945
|
-
return
|
|
3977
|
+
return jsx(ModalConfirm, {});
|
|
3946
3978
|
case ModalTypes.PostalModal:
|
|
3947
|
-
return
|
|
3979
|
+
return jsx(ModalPostal, {});
|
|
3948
3980
|
case ModalTypes.AddressModal:
|
|
3949
|
-
return
|
|
3981
|
+
return jsx(ModalAddress, {});
|
|
3950
3982
|
case ModalTypes.FinaleModal:
|
|
3951
|
-
return
|
|
3983
|
+
return jsx(ModalFinale, {});
|
|
3952
3984
|
default:
|
|
3953
3985
|
return null;
|
|
3954
3986
|
}
|
|
3955
3987
|
};
|
|
3956
3988
|
const AppModal = () => {
|
|
3957
3989
|
const { appModalState } = useStoreAppModal();
|
|
3958
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
3990
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3959
3991
|
const insuranceType = getInsuranceType();
|
|
3960
3992
|
if (appModalState.isOpen && document.location.pathname.indexOf(insuranceType) !== -1) {
|
|
3961
|
-
return (jsx("div", { className: `app-modal ${appType
|
|
3993
|
+
return (jsx("div", { className: `app-modal ${isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: jsx(AppModalWrapper, {}) }));
|
|
3962
3994
|
}
|
|
3963
3995
|
return null;
|
|
3964
3996
|
};
|
|
3965
3997
|
|
|
3966
3998
|
const AppHeader = () => {
|
|
3967
|
-
const { appConfigState: { appType, localIndex } } = useStoreAppConfig();
|
|
3999
|
+
const { appConfigState: { appType, localIndex }, } = useStoreAppConfig();
|
|
3968
4000
|
const { appDeviceType } = useStoreDeviceType();
|
|
3969
4001
|
if (appType) {
|
|
3970
|
-
return (jsxs("div", { className: "app-header", children: [appType === AppTypes.TheBig && jsx(HeaderTheBig, { textBack: "home" }), appType === AppTypes.MyChoice
|
|
3971
|
-
|
|
3972
|
-
? jsx(HeaderPartner, {})
|
|
3973
|
-
: (jsx(Fragment, { children: appDeviceType === DeviceTypes.Desktop
|
|
3974
|
-
? jsx(HeaderMyChoice, {})
|
|
3975
|
-
: jsx(HeaderMyChoiceMobile, {}) })))] }));
|
|
4002
|
+
return (jsxs("div", { className: "app-header", children: [appType === AppTypes.TheBig && jsx(HeaderTheBig, { textBack: "home" }), appType === AppTypes.BeginInsurance && (jsx(Fragment, { children: appDeviceType === DeviceTypes.Desktop ? jsx(HeaderBeginInsurance, {}) : jsx(HeaderBeginInsuranceMobile, {}) })), appType === AppTypes.MyChoice &&
|
|
4003
|
+
(localIndex !== defaultLocalIndex ? (jsx(HeaderPartner, {})) : (jsx(Fragment, { children: appDeviceType === DeviceTypes.Desktop ? jsx(HeaderMyChoice, {}) : jsx(HeaderMyChoiceMobile, {}) })))] }));
|
|
3976
4004
|
}
|
|
3977
4005
|
return null;
|
|
3978
4006
|
};
|
|
@@ -4072,7 +4100,7 @@ const AppRouteWrapper = (props) => {
|
|
|
4072
4100
|
let postalCode = carPostal;
|
|
4073
4101
|
const { clearFormData, checkIsExpired, checkIsExpiredWithModal } = ClearFormDataHandler();
|
|
4074
4102
|
const { appLoaderState } = useStoreAppLoader();
|
|
4075
|
-
const isMychoice = appType
|
|
4103
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
4076
4104
|
switch (insuranceType) {
|
|
4077
4105
|
case InsuranceTypes.Car:
|
|
4078
4106
|
postalCode = carPostal;
|
|
@@ -4337,7 +4365,7 @@ const AppRouteWrapper = (props) => {
|
|
|
4337
4365
|
}
|
|
4338
4366
|
}
|
|
4339
4367
|
}, [carPostal, homePostal, lifePostal, isReady]);
|
|
4340
|
-
return (jsx(Fragment, { children: isReady && (jsxs(Fragment, { children: [jsx(AppHeader, {}), jsx(AppModal, {}), insuranceType && (jsx(NavigationTop, { title: `${insuranceType.replace(/^./, insuranceType[0].toUpperCase())} Insurance Quote`, postalCode: postalCode, formSteps: steps, validationHooks: validationHooks, clearForm: clearFormData, propertyIsCompleted: isCompleted })), insuranceType && appType
|
|
4368
|
+
return (jsx(Fragment, { children: isReady && (jsxs(Fragment, { children: [jsx(AppHeader, {}), jsx(AppModal, {}), insuranceType && (jsx(NavigationTop, { title: `${insuranceType.replace(/^./, insuranceType[0].toUpperCase())} Insurance Quote`, postalCode: postalCode, formSteps: steps, validationHooks: validationHooks, clearForm: clearFormData, propertyIsCompleted: isCompleted })), insuranceType && isMyChoiceLike(appType) && (jsx("div", { className: localIndex !== defaultLocalIndex ? 'step-progress-bar-partner' : 'step-progress-bar', children: jsx("span", { style: { width: progressLength } }) })), jsx("div", { className: `${insuranceType ? 'form-page-content' : ''} ${insuranceType && isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: insuranceType && isMyChoiceLike(appType) && isDesktop && progressLength ? (jsx(Fragment, { children: jsxs("div", { className: "mychoice-content", children: [jsx(StepsBox, { className: "step-box", formSteps: steps, validationHooks: validationHooks, propertyIsCompleted: isCompleted }), children, jsx("div", { className: "empty-steps-container" })] }) })) : (children) }), isMychoice && !appLoaderState.isOpen && jsx(ProviderImageFooter, {})] })) }));
|
|
4341
4369
|
};
|
|
4342
4370
|
const NestedRoutes = () => {
|
|
4343
4371
|
const insuranceType = getInsuranceType();
|
|
@@ -4479,7 +4507,7 @@ const AppConfig = (props) => {
|
|
|
4479
4507
|
// home insurance steps states
|
|
4480
4508
|
const { dispatchPostalState: dispatchHomePostalState } = useStoreFormHomePostal();
|
|
4481
4509
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
4482
|
-
const { dwellingState: { isCompleted }, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
4510
|
+
const { dwellingState: { isCompleted }, dispatchDwellingState, } = useStoreFormHomeDwelling();
|
|
4483
4511
|
const { dispatchDiscountState: dispatchHomeDiscountState } = useStoreFormHomeDiscount();
|
|
4484
4512
|
const { dispatchQuoteState: dispatchHomeQuoteState } = useStoreFormHomeQuote();
|
|
4485
4513
|
// life insurance
|
|
@@ -4538,8 +4566,7 @@ const AppConfig = (props) => {
|
|
|
4538
4566
|
if (authHandler.status === RequestStatusTypes.Waiting) {
|
|
4539
4567
|
authHandler.checkUser();
|
|
4540
4568
|
}
|
|
4541
|
-
if (authHandler.status !== RequestStatusTypes.Waiting
|
|
4542
|
-
&& authHandler.status !== RequestStatusTypes.Loading) {
|
|
4569
|
+
if (authHandler.status !== RequestStatusTypes.Waiting && authHandler.status !== RequestStatusTypes.Loading) {
|
|
4543
4570
|
if (insuranceType === InsuranceTypes.Car) {
|
|
4544
4571
|
dispatchCarPostalState({
|
|
4545
4572
|
type: StoreFormCarPostalActionTypes.FormCarPostalGetLocal,
|
|
@@ -4569,7 +4596,9 @@ const AppConfig = (props) => {
|
|
|
4569
4596
|
type: StoreFormCarQuoteActionTypes.FormCarQuoteGetLocal,
|
|
4570
4597
|
});
|
|
4571
4598
|
}
|
|
4572
|
-
if (insuranceType === InsuranceTypes.Home ||
|
|
4599
|
+
if (insuranceType === InsuranceTypes.Home ||
|
|
4600
|
+
insuranceType === InsuranceTypes.Condo ||
|
|
4601
|
+
insuranceType === InsuranceTypes.Tenant) {
|
|
4573
4602
|
dispatchHomePostalState({
|
|
4574
4603
|
type: StoreFormHomePostalActionTypes.FormHomePostalGetLocal,
|
|
4575
4604
|
});
|
|
@@ -4620,6 +4649,14 @@ const AppConfig = (props) => {
|
|
|
4620
4649
|
payload: true,
|
|
4621
4650
|
});
|
|
4622
4651
|
}
|
|
4652
|
+
if (appType === AppTypes.BeginInsurance) {
|
|
4653
|
+
// Begin Insurance brand colors: Navy Blue primary, Green accent
|
|
4654
|
+
setExternalColors('#0F2043', '#50C878');
|
|
4655
|
+
dispatchAppConfigState({
|
|
4656
|
+
type: StoreConfigAppConfigActionTypes.AppConfigSetPreloaded,
|
|
4657
|
+
payload: true,
|
|
4658
|
+
});
|
|
4659
|
+
}
|
|
4623
4660
|
}, [appType]);
|
|
4624
4661
|
useEffect(() => {
|
|
4625
4662
|
if (insuranceType === InsuranceTypes.Home && isCompleted) {
|
|
@@ -4674,5 +4711,5 @@ AppWrapper.defaultProps = {
|
|
|
4674
4711
|
insuranceType: InsuranceTypes.Car,
|
|
4675
4712
|
};
|
|
4676
4713
|
|
|
4677
|
-
export { AppWrapper, DateSelectFormBox, HeaderMyChoice, HeaderMyChoiceMobile, HeaderPartner, HeaderTheBig, InputFormBox, InputFormEmailBox, InputFormLicenceBox, InputFormPhoneBox, LabelFormBox, LoaderPrimary, LoaderVid, ModalAddress, ModalConfirm, ModalFinale, ModalMessage, ModalPostal, ModalQuoteRequest, NavigationBottom, NavigationBottomTheBig, NavigationTab, NavigationTabMobile, NavigationTop, NoQuotesMessage, OfferSection, PageAddress, PageApplicant, PageCarDiscount, PageCarQuote, PageCoverage, PageDriver, PageHomeDiscount, PageHomeQuote, PageLifeApplicant, PageLifeQuote, PageProperty, PageVehicle, ProviderImageFooter, SelectFormBox, SwitchButtonBox, capitalize, formSteps, formatPhoneObject, formatTitleToCapital, getDateErrorMessage, getErrorMessage, getSelectedOption, usePathGroups };
|
|
4714
|
+
export { AppWrapper, DateSelectFormBox, HeaderBeginInsurance, HeaderBeginInsuranceMobile, HeaderMyChoice, HeaderMyChoiceMobile, HeaderPartner, HeaderTheBig, InputFormBox, InputFormEmailBox, InputFormLicenceBox, InputFormPhoneBox, LabelFormBox, LoaderPrimary, LoaderVid, ModalAddress, ModalConfirm, ModalFinale, ModalMessage, ModalPostal, ModalQuoteRequest, NavigationBottom, NavigationBottomTheBig, NavigationTab, NavigationTabMobile, NavigationTop, NoQuotesMessage, OfferSection, PageAddress, PageApplicant, PageCarDiscount, PageCarQuote, PageCoverage, PageDriver, PageHomeDiscount, PageHomeQuote, PageLifeApplicant, PageLifeQuote, PageProperty, PageVehicle, ProviderImageFooter, SelectFormBox, SwitchButtonBox, capitalize, formSteps, formatPhoneObject, formatTitleToCapital, getDateErrorMessage, getErrorMessage, getSelectedOption, usePathGroups };
|
|
4678
4715
|
//# sourceMappingURL=index.js.map
|