@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.0
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 +251 -213
- 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 +251 -215
- 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: '',
|
|
@@ -492,20 +502,42 @@ HeaderTheBig.defaultProps = {
|
|
|
492
502
|
className: '',
|
|
493
503
|
};
|
|
494
504
|
|
|
495
|
-
const
|
|
496
|
-
const { appConfigState: { insuranceType } } = useStoreAppConfig();
|
|
505
|
+
const HeaderBeginInsurance = ({ className }) => {
|
|
506
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
507
|
+
const insuranceTypeCls = insuranceType !== InsuranceTypes.Car && insuranceType !== InsuranceTypes.Life ? InsuranceTypes.Home : insuranceType;
|
|
508
|
+
const { externalPathGroup } = usePathGroups(insuranceTypeCls);
|
|
509
|
+
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" })] }) }));
|
|
510
|
+
};
|
|
511
|
+
HeaderBeginInsurance.defaultProps = {
|
|
512
|
+
className: '',
|
|
513
|
+
};
|
|
514
|
+
|
|
515
|
+
const HeaderMyChoiceMobile = ({ className }) => {
|
|
516
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
497
517
|
const { externalPathGroup } = usePathGroups(insuranceType);
|
|
498
518
|
const [isMenuOpen, setIsMenuOpen] = useState(false);
|
|
499
519
|
const handleMenuClick = () => {
|
|
500
520
|
setIsMenuOpen(!isMenuOpen);
|
|
501
521
|
};
|
|
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 }) }) }))] }));
|
|
522
|
+
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
523
|
};
|
|
505
524
|
HeaderMyChoiceMobile.defaultProps = {
|
|
506
525
|
className: '',
|
|
507
526
|
};
|
|
508
527
|
|
|
528
|
+
const HeaderBeginInsuranceMobile = ({ className }) => {
|
|
529
|
+
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|
|
530
|
+
const { externalPathGroup } = usePathGroups(insuranceType);
|
|
531
|
+
const [isMenuOpen, setIsMenuOpen] = useState(false);
|
|
532
|
+
const handleMenuClick = () => {
|
|
533
|
+
setIsMenuOpen(!isMenuOpen);
|
|
534
|
+
};
|
|
535
|
+
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 }) }) }))] }));
|
|
536
|
+
};
|
|
537
|
+
HeaderBeginInsuranceMobile.defaultProps = {
|
|
538
|
+
className: '',
|
|
539
|
+
};
|
|
540
|
+
|
|
509
541
|
const LoaderVid = () => {
|
|
510
542
|
const { appDeviceType } = useStoreDeviceType();
|
|
511
543
|
const isMobile = appDeviceType === DeviceTypes.Mobile;
|
|
@@ -516,11 +548,11 @@ const LoaderPrimary = () => {
|
|
|
516
548
|
const { appLoaderState } = useStoreAppLoader();
|
|
517
549
|
const { appConfigState } = useStoreAppConfig();
|
|
518
550
|
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
|
-
|
|
551
|
+
const isHome = window.location.pathname.includes('home') ||
|
|
552
|
+
window.location.pathname.includes('condo') ||
|
|
553
|
+
window.location.pathname.includes('tenant');
|
|
554
|
+
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 &&
|
|
555
|
+
isHome && jsx("h4", { children: "Hang tight, while we collect and process information about your property." }))] }));
|
|
524
556
|
};
|
|
525
557
|
|
|
526
558
|
const ModalConfirm = () => {
|
|
@@ -770,16 +802,16 @@ const BlockCarConditionInfo = () => {
|
|
|
770
802
|
};
|
|
771
803
|
|
|
772
804
|
const VehicleSectionMain = () => {
|
|
773
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
774
|
-
const mychoiceCls = appType
|
|
805
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
806
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
775
807
|
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
808
|
};
|
|
777
809
|
|
|
778
810
|
const VehicleSectionCoverage = () => {
|
|
779
811
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
780
812
|
const { collision, comprehensive } = vehicleState.items[vehicleState.activeIndex];
|
|
781
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
782
|
-
const mychoiceCls = appType
|
|
813
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
814
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
783
815
|
const handleComprehensiveChange = ({ value }) => {
|
|
784
816
|
dispatchVehicleState({
|
|
785
817
|
type: StoreFormCarVehicleActionTypes.FormCarComprehensiveCoverageSelect,
|
|
@@ -933,11 +965,11 @@ const TabDriver = ({ createItem, readOnly }) => {
|
|
|
933
965
|
|
|
934
966
|
const SectionDriverInfo = () => {
|
|
935
967
|
const { configState } = useStoreFormCarConfig();
|
|
936
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
968
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
937
969
|
const { driverState, dispatchDriverInfoState } = useStoreFormCarDriverInfo();
|
|
938
970
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
939
|
-
const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship
|
|
940
|
-
const mychoiceCls = appType
|
|
971
|
+
const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship } = driverState.items[driverState.activeIndex];
|
|
972
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
941
973
|
const defaultDateOfBirth = {
|
|
942
974
|
day: birthDay,
|
|
943
975
|
month: birthMonth,
|
|
@@ -1001,17 +1033,16 @@ const SectionDriverInfo = () => {
|
|
|
1001
1033
|
payload: { applicantRelationship: value },
|
|
1002
1034
|
});
|
|
1003
1035
|
};
|
|
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) }))] }));
|
|
1036
|
+
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
1037
|
};
|
|
1007
1038
|
|
|
1008
1039
|
const SectionDriverLicence = () => {
|
|
1009
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1040
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1010
1041
|
const [driverEducation, setDriverEducation] = useState(false);
|
|
1011
1042
|
const { configState } = useStoreFormCarConfig();
|
|
1012
1043
|
const { driverState, dispatchDriverLicenceState } = useStoreFormCarDriverLicence();
|
|
1013
1044
|
const { isAlbertaProvince } = useProvince();
|
|
1014
|
-
const mychoiceCls = appType
|
|
1045
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1015
1046
|
const { firstName, birthDay, birthMonth, birthYear, licenceInfo: { firstLicenceAge, licenceType, g1LicenceYear, g1LicenceMonth, gLicenceYear, gLicenceMonth, g2LicenceYear, g2LicenceMonth, passedDriverTraining, previousLicence, }, minMaxDates, } = driverState.items[driverState.activeIndex];
|
|
1016
1047
|
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
1048
|
const maxLicenceAge = licenceAgeMax;
|
|
@@ -1020,7 +1051,7 @@ const SectionDriverLicence = () => {
|
|
|
1020
1051
|
const defaultMinDate = birthDate && firstLicenceAge ? addYearsToDate(birthDate, +firstLicenceAge) : '';
|
|
1021
1052
|
const isOnlyG = checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
|
|
1022
1053
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1023
|
-
const { g, g1, g2, minLicenceAge
|
|
1054
|
+
const { g, g1, g2, minLicenceAge } = configState.licenceConfig;
|
|
1024
1055
|
const licenceTypeOptions = [
|
|
1025
1056
|
{ value: g.name, name: g.title },
|
|
1026
1057
|
{ value: g1.name, name: g1.title },
|
|
@@ -1050,7 +1081,8 @@ const SectionDriverLicence = () => {
|
|
|
1050
1081
|
return gOneMin;
|
|
1051
1082
|
case DriverLicenceTypes.G2:
|
|
1052
1083
|
return gTwoMin;
|
|
1053
|
-
default:
|
|
1084
|
+
default:
|
|
1085
|
+
return '';
|
|
1054
1086
|
}
|
|
1055
1087
|
};
|
|
1056
1088
|
const getMaxDate = (type) => {
|
|
@@ -1061,7 +1093,8 @@ const SectionDriverLicence = () => {
|
|
|
1061
1093
|
return gOneMax;
|
|
1062
1094
|
case DriverLicenceTypes.G2:
|
|
1063
1095
|
return gTwoMax;
|
|
1064
|
-
default:
|
|
1096
|
+
default:
|
|
1097
|
+
return '';
|
|
1065
1098
|
}
|
|
1066
1099
|
};
|
|
1067
1100
|
const getLicenceYear = (type) => {
|
|
@@ -1072,7 +1105,8 @@ const SectionDriverLicence = () => {
|
|
|
1072
1105
|
return g1LicenceYear;
|
|
1073
1106
|
case DriverLicenceTypes.G2:
|
|
1074
1107
|
return g2LicenceYear;
|
|
1075
|
-
default:
|
|
1108
|
+
default:
|
|
1109
|
+
return '';
|
|
1076
1110
|
}
|
|
1077
1111
|
};
|
|
1078
1112
|
const getLicenceMonth = (type) => {
|
|
@@ -1083,7 +1117,8 @@ const SectionDriverLicence = () => {
|
|
|
1083
1117
|
return g1LicenceMonth;
|
|
1084
1118
|
case DriverLicenceTypes.G2:
|
|
1085
1119
|
return g2LicenceMonth;
|
|
1086
|
-
default:
|
|
1120
|
+
default:
|
|
1121
|
+
return '';
|
|
1087
1122
|
}
|
|
1088
1123
|
};
|
|
1089
1124
|
const getDefaultLicenceDate = (type) => ({
|
|
@@ -1136,8 +1171,10 @@ const SectionDriverLicence = () => {
|
|
|
1136
1171
|
const formattedMinDate = `${getFormattedDate(licenceMinDate, 'MMMM yyyy')}`;
|
|
1137
1172
|
const defaultHintMessage = `${formattedMinDate} would be your earliest ${licenceTypeTitle}
|
|
1138
1173
|
licence date based on your first licenced age and date of birth`;
|
|
1139
|
-
return currentType === DriverLicenceTypes.G2
|
|
1140
|
-
|
|
1174
|
+
return currentType === DriverLicenceTypes.G2
|
|
1175
|
+
? `${defaultHintMessage}
|
|
1176
|
+
if you completed a driver education course`
|
|
1177
|
+
: defaultHintMessage;
|
|
1141
1178
|
};
|
|
1142
1179
|
const getLicenceAgeTitle = () => {
|
|
1143
1180
|
if (isAlbertaProvince && isTheBig) {
|
|
@@ -1145,10 +1182,10 @@ const SectionDriverLicence = () => {
|
|
|
1145
1182
|
}
|
|
1146
1183
|
return `What age was ${firstName || driverNameDefault} when first licenced?`;
|
|
1147
1184
|
};
|
|
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
|
-
|
|
1185
|
+
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
|
|
1186
|
+
? `${firstName || driverNameDefault} was licenced in
|
|
1187
|
+
${Number(birthYear) + Number(firstLicenceAge)} - ${Number(birthYear) + Number(firstLicenceAge) + 1}`
|
|
1188
|
+
: '', 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
1189
|
};
|
|
1153
1190
|
|
|
1154
1191
|
const SectionDriverInsurancePolicy = () => {
|
|
@@ -1157,18 +1194,14 @@ const SectionDriverInsurancePolicy = () => {
|
|
|
1157
1194
|
const { driverState, dispatchDriverInsuranceState } = useStoreFormCarDriverInsurance();
|
|
1158
1195
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
1159
1196
|
const { quoteState: { isRequested }, } = useStoreFormCarQuote();
|
|
1160
|
-
const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth
|
|
1197
|
+
const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth }, } = driverState.items[driverState.activeIndex];
|
|
1161
1198
|
const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
|
|
1162
1199
|
const driverNameDefault = `Driver ${driverState.activeIndex + 1}`;
|
|
1163
|
-
const birthDate = birthYear && birthMonth && birthDay
|
|
1164
|
-
? `${birthYear}-${birthMonth}-${birthDay}`
|
|
1165
|
-
: '';
|
|
1200
|
+
const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
|
|
1166
1201
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1167
|
-
const mychoiceCls = appType
|
|
1202
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1168
1203
|
const getPeriodOptions = (year, month) => {
|
|
1169
|
-
const options = [
|
|
1170
|
-
{ value: '', name: 'Date Period', disabled: true },
|
|
1171
|
-
];
|
|
1204
|
+
const options = [{ value: '', name: 'Date Period', disabled: true }];
|
|
1172
1205
|
if (year && month) {
|
|
1173
1206
|
const todayDate = new Date();
|
|
1174
1207
|
const month = String(todayDate.getMonth() + 1).padStart(2, '0');
|
|
@@ -1224,9 +1257,7 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1224
1257
|
}
|
|
1225
1258
|
};
|
|
1226
1259
|
if (birthDate) {
|
|
1227
|
-
const defaultMinDate = birthDate && firstLicenceAge
|
|
1228
|
-
? addYearsToDate(birthDate, +firstLicenceAge)
|
|
1229
|
-
: '';
|
|
1260
|
+
const defaultMinDate = birthDate && firstLicenceAge ? addYearsToDate(birthDate, +firstLicenceAge) : '';
|
|
1230
1261
|
const isOnlyG = checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
|
|
1231
1262
|
if (isOnlyG) {
|
|
1232
1263
|
setMessage(gLicenceYear, gLicenceMonth);
|
|
@@ -1245,16 +1276,7 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1245
1276
|
else {
|
|
1246
1277
|
setHintMessage('');
|
|
1247
1278
|
}
|
|
1248
|
-
}, [
|
|
1249
|
-
listedYear,
|
|
1250
|
-
listedMonth,
|
|
1251
|
-
g1LicenceYear,
|
|
1252
|
-
g1LicenceMonth,
|
|
1253
|
-
firstLicenceAge,
|
|
1254
|
-
birthDate,
|
|
1255
|
-
gLicenceYear,
|
|
1256
|
-
gLicenceMonth,
|
|
1257
|
-
]);
|
|
1279
|
+
}, [listedYear, listedMonth, g1LicenceYear, g1LicenceMonth, firstLicenceAge, birthDate, gLicenceYear, gLicenceMonth]);
|
|
1258
1280
|
const handleInsuredChange = ({ value }) => {
|
|
1259
1281
|
dispatchDriverInsuranceState({
|
|
1260
1282
|
type: StoreFormCarDriverInsuranceActionTypes.FormCarDriverInsuredSelect,
|
|
@@ -1309,18 +1331,16 @@ you had insurance. If this is correct, please continue with the form.`);
|
|
|
1309
1331
|
};
|
|
1310
1332
|
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
1333
|
? 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 })] }));
|
|
1334
|
+
: '', 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
1335
|
};
|
|
1316
1336
|
|
|
1317
1337
|
const SectionDriverCancellation = () => {
|
|
1318
1338
|
const { driverState, dispatchDriverCancellationState } = useStoreFormCarDriverCancellation();
|
|
1319
1339
|
const { dispatchDriverBaseState } = useStoreFormCarDriverBase();
|
|
1320
1340
|
const { insuranceCancellation, insuranceCancellationList = [] } = driverState.items[driverState.activeIndex];
|
|
1321
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1341
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1322
1342
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1323
|
-
const mychoiceCls = appType
|
|
1343
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1324
1344
|
const { firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge }, } = driverState.items[driverState.activeIndex];
|
|
1325
1345
|
const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
|
|
1326
1346
|
const handleIconClick = (index) => () => {
|
|
@@ -1396,7 +1416,7 @@ const SectionDriverCancellation = () => {
|
|
|
1396
1416
|
}
|
|
1397
1417
|
};
|
|
1398
1418
|
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
|
|
1419
|
+
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
1420
|
const defaultStartDate = {
|
|
1401
1421
|
year: startYear,
|
|
1402
1422
|
month: startMonth,
|
|
@@ -1406,12 +1426,11 @@ const SectionDriverCancellation = () => {
|
|
|
1406
1426
|
month: endMonth,
|
|
1407
1427
|
};
|
|
1408
1428
|
const now = getFormattedDate('', 'yyyy-MM-dd');
|
|
1409
|
-
const days = birthDay ?
|
|
1429
|
+
const days = birthDay ? +birthDay + 1 : 1;
|
|
1410
1430
|
const endDate = endYear && endMonth ? addDayToDate(`${endYear}-${endMonth}`, days) : now;
|
|
1411
1431
|
const currentMinDate = getMinDateByYears(getMinDate(birthDate, firstLicenceAge), 3);
|
|
1412
1432
|
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}`));
|
|
1433
|
+
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
1434
|
}), insuranceCancellationList?.length < 3 && (jsx(ButtonBase, { category: CategoryTypes.Filled, onClick: handleAddButtonClick, size: SizeTypes.Medium, color: ColorTypes.Primary, label: "Add another" }))] }))] }));
|
|
1416
1435
|
};
|
|
1417
1436
|
|
|
@@ -1667,8 +1686,8 @@ const BlockDriverTicket = () => {
|
|
|
1667
1686
|
};
|
|
1668
1687
|
|
|
1669
1688
|
const SectionDriverHistory = () => {
|
|
1670
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1671
|
-
const mychoiceCls = appType
|
|
1689
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1690
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1672
1691
|
return (jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsx(BlockDriverSuspension, {}), jsx(BlockDriverAccident, {}), jsx(BlockDriverTicket, {})] }));
|
|
1673
1692
|
};
|
|
1674
1693
|
|
|
@@ -1707,7 +1726,7 @@ const PageDriver = () => {
|
|
|
1707
1726
|
useEffect(() => {
|
|
1708
1727
|
setIsRender(true);
|
|
1709
1728
|
}, [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
|
|
1729
|
+
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
1730
|
};
|
|
1712
1731
|
|
|
1713
1732
|
const getDynamicLicenceBoxProps = ({ isAlbertaProvince, isOntarioProvince, isNewfoundlandProvince, isNovaScotiaProvince, isNewBrunswickProvince, }) => {
|
|
@@ -1757,11 +1776,11 @@ const SectionDiscountInfo$1 = () => {
|
|
|
1757
1776
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1758
1777
|
const allProvinces = useProvince();
|
|
1759
1778
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1760
|
-
const mychoiceCls = appType
|
|
1779
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1761
1780
|
const { discountState, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
1762
1781
|
const { validateEmail, errorMessage } = useHandlerCarQuoterEmail();
|
|
1763
1782
|
const { multiplePoliciesDiscount, appInstallDiscount, caaMemberDiscount, quoterInfo, emailTo: { email, emailStatus }, } = discountState;
|
|
1764
|
-
const { firstName, lastName, phone, driverLicense = '', caslConsent
|
|
1783
|
+
const { firstName, lastName, phone, driverLicense = '', caslConsent } = quoterInfo;
|
|
1765
1784
|
const handleMultiplePolicyChange = ({ value }) => {
|
|
1766
1785
|
dispatchDiscountState({
|
|
1767
1786
|
type: StoreFormCarDiscountActionTypes.FormCarDiscountMultiplePoliciesSelect,
|
|
@@ -1815,8 +1834,7 @@ const SectionDiscountInfo$1 = () => {
|
|
|
1815
1834
|
};
|
|
1816
1835
|
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
1836
|
? 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, {})] }));
|
|
1837
|
+
: 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
1838
|
};
|
|
1821
1839
|
|
|
1822
1840
|
const PageCarDiscount = () => {
|
|
@@ -1841,10 +1859,10 @@ const SectionQuoteEdit$2 = () => {
|
|
|
1841
1859
|
const { appConfigState } = useStoreAppConfig();
|
|
1842
1860
|
const { driverState, dispatchDriverBaseState } = useStoreFormCarDriverBase();
|
|
1843
1861
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
1844
|
-
const { discountState: { appInstallDiscount, multiplePoliciesDiscount } } = useStoreFormCarDiscount();
|
|
1845
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1862
|
+
const { discountState: { appInstallDiscount, multiplePoliciesDiscount }, } = useStoreFormCarDiscount();
|
|
1863
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1846
1864
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1847
|
-
const mychoiceCls = appType
|
|
1865
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1848
1866
|
const navigate = useNavigate();
|
|
1849
1867
|
const vehicles = vehicleState.items.map(({ year, make, model }) => [`${year} ${make} ${model}`]);
|
|
1850
1868
|
const drivers = driverState.items.map(({ firstName }) => [`${firstName}`]);
|
|
@@ -1909,7 +1927,7 @@ const BlockMCEndorsements = () => {
|
|
|
1909
1927
|
const SectionQuoteRecalc$1 = () => {
|
|
1910
1928
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
1911
1929
|
const isTheBig = appType === AppTypes.TheBig;
|
|
1912
|
-
const mychoiceCls = appType
|
|
1930
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
1913
1931
|
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
1914
1932
|
const { comprehensive, collision, liability } = vehicleState.items[vehicleState.activeIndex];
|
|
1915
1933
|
const handleComprehensiveChange = ({ value }) => {
|
|
@@ -2070,7 +2088,7 @@ const SectionAddress = () => {
|
|
|
2070
2088
|
const { streetAddress = '', postalCode = '', addressObject, errorMessage } = item;
|
|
2071
2089
|
const navigate = useNavigate();
|
|
2072
2090
|
const asyncSelectRef = useRef(null);
|
|
2073
|
-
const isMychoice = appType
|
|
2091
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
2074
2092
|
const mychoiceCls = isMychoice ? 'mychoice' : '';
|
|
2075
2093
|
const handleAddressChange = (address) => {
|
|
2076
2094
|
dispatchPostalState({
|
|
@@ -2308,9 +2326,9 @@ const SectionApplicantInfo = () => {
|
|
|
2308
2326
|
const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
|
|
2309
2327
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2310
2328
|
const { dwellingState, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
2311
|
-
const { firstName, insured: { birthDay, birthMonth, birthYear
|
|
2312
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2313
|
-
const mychoiceCls = appType
|
|
2329
|
+
const { firstName, insured: { birthDay, birthMonth, birthYear }, } = applicantState;
|
|
2330
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2331
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2314
2332
|
const { familiesCount, occupiedYear } = dwellingState;
|
|
2315
2333
|
// VARIABLES =========
|
|
2316
2334
|
const birthDate = birthYear ? `${birthYear}-${birthMonth || '01'}-${birthDay || '01'}` : '';
|
|
@@ -2391,9 +2409,9 @@ const SectionApplicantInsurancePolicy = () => {
|
|
|
2391
2409
|
const { applicantState, dispatchApplicantInsuranceState } = useStoreFormHomeApplicantInsurance();
|
|
2392
2410
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2393
2411
|
const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
|
|
2394
|
-
const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince } } = applicantState;
|
|
2395
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
2396
|
-
const mychoiceCls = appType
|
|
2412
|
+
const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince }, } = applicantState;
|
|
2413
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
2414
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2397
2415
|
const defaultPolicyStartDate = {
|
|
2398
2416
|
year: policyStartYear,
|
|
2399
2417
|
month: policyStartMonth,
|
|
@@ -2443,19 +2461,17 @@ const SectionApplicantInsurancePolicy = () => {
|
|
|
2443
2461
|
payload: { dateInsuredCurrent: value },
|
|
2444
2462
|
});
|
|
2445
2463
|
};
|
|
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) }))] }));
|
|
2464
|
+
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
2465
|
};
|
|
2450
2466
|
|
|
2451
2467
|
const SectionApplicantCancellation = () => {
|
|
2452
2468
|
const { applicantState, dispatchApplicantCancellationState } = useStoreFormHomeApplicantCancellation();
|
|
2453
2469
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
2454
2470
|
const { insuranceCancellation, insuranceCancellationList } = applicantState;
|
|
2455
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2471
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2456
2472
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2457
|
-
const mychoiceCls = appType
|
|
2458
|
-
const { insured: { birthYear, birthMonth, birthDay } } = applicantState;
|
|
2473
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2474
|
+
const { insured: { birthYear, birthMonth, birthDay }, } = applicantState;
|
|
2459
2475
|
const handleIconClick = (index) => () => {
|
|
2460
2476
|
dispatchApplicantCancellationState({
|
|
2461
2477
|
type: StoreFormHomeApplicantCancellationActionTypes.FormHomeApplicantCancellationDelete,
|
|
@@ -2499,24 +2515,23 @@ const SectionApplicantCancellation = () => {
|
|
|
2499
2515
|
});
|
|
2500
2516
|
}
|
|
2501
2517
|
};
|
|
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
|
|
2518
|
+
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
2519
|
const defaultCancellationDate = {
|
|
2504
2520
|
year: cancellationYear,
|
|
2505
2521
|
month: cancellationMonth,
|
|
2506
2522
|
day: '01',
|
|
2507
2523
|
};
|
|
2508
2524
|
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." }))] }))] }));
|
|
2525
|
+
}), 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
2526
|
};
|
|
2512
2527
|
|
|
2513
2528
|
const SectionApplicantClaim = () => {
|
|
2514
2529
|
const { applicantState, dispatchApplicantClaimState } = useStoreFormHomeApplicantClaim();
|
|
2515
2530
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
2516
2531
|
const { insuranceClaim, insuranceClaimList } = applicantState;
|
|
2517
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2532
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2518
2533
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2519
|
-
const mychoiceCls = appType
|
|
2534
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2520
2535
|
const handleIconClick = (index) => () => {
|
|
2521
2536
|
dispatchApplicantClaimState({
|
|
2522
2537
|
type: StoreFormHomeApplicantClaimActionTypes.FormHomeApplicantClaimDelete,
|
|
@@ -2569,15 +2584,14 @@ const SectionApplicantClaim = () => {
|
|
|
2569
2584
|
});
|
|
2570
2585
|
}
|
|
2571
2586
|
};
|
|
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
|
|
2587
|
+
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
2588
|
const defaultClaimDate = {
|
|
2574
2589
|
year: claimYear,
|
|
2575
2590
|
month: claimMonth,
|
|
2576
2591
|
day: '01',
|
|
2577
2592
|
};
|
|
2578
2593
|
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." }))] }))] }));
|
|
2594
|
+
}), 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
2595
|
};
|
|
2582
2596
|
|
|
2583
2597
|
const PageApplicant = () => {
|
|
@@ -2833,9 +2847,14 @@ const BlockDwellingInfo = () => {
|
|
|
2833
2847
|
};
|
|
2834
2848
|
|
|
2835
2849
|
const BlockNextPageInfo$1 = () => {
|
|
2836
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2837
|
-
|
|
2838
|
-
|
|
2850
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2851
|
+
if (appType === AppTypes.TheBig) {
|
|
2852
|
+
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."] }) }));
|
|
2853
|
+
}
|
|
2854
|
+
if (appType === AppTypes.MyChoice) {
|
|
2855
|
+
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" }), "."] }) })] });
|
|
2856
|
+
}
|
|
2857
|
+
return null;
|
|
2839
2858
|
};
|
|
2840
2859
|
|
|
2841
2860
|
const BlockSubmit$1 = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
@@ -2865,14 +2884,14 @@ BlockSubmit$1.defaultProps = {
|
|
|
2865
2884
|
};
|
|
2866
2885
|
|
|
2867
2886
|
const SectionDiscountInfo = () => {
|
|
2868
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
2887
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
2869
2888
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2870
|
-
const mychoiceCls = appType
|
|
2889
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2871
2890
|
const { discountState, dispatchDiscountState } = useStoreFormHomeDiscount();
|
|
2872
2891
|
// const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
|
|
2873
2892
|
const { validateEmail, errorMessage } = useHandlerHomeQuoterEmail();
|
|
2874
2893
|
const { multiplePoliciesDiscount, emailTo: { email, emailStatus }, quoterInfo = {}, } = discountState;
|
|
2875
|
-
const { firstName = '', lastName = '', phone = '', caslConsent
|
|
2894
|
+
const { firstName = '', lastName = '', phone = '', caslConsent } = quoterInfo;
|
|
2876
2895
|
const handleMultiplePolicyChange = ({ value }) => {
|
|
2877
2896
|
dispatchDiscountState({
|
|
2878
2897
|
type: StoreFormHomeDiscountActionTypes.FormHomeDiscountMultiplePoliciesSelect,
|
|
@@ -2906,13 +2925,11 @@ const SectionDiscountInfo = () => {
|
|
|
2906
2925
|
payload: { caslConsent: value },
|
|
2907
2926
|
});
|
|
2908
2927
|
};
|
|
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,
|
|
2928
|
+
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
2929
|
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
|
-
|
|
2930
|
+
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
|
|
2931
|
+
? errorMessage
|
|
2932
|
+
: 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
2933
|
};
|
|
2917
2934
|
|
|
2918
2935
|
const PageHomeDiscount = () => {
|
|
@@ -2935,18 +2952,18 @@ const PageHomeDiscount = () => {
|
|
|
2935
2952
|
};
|
|
2936
2953
|
|
|
2937
2954
|
const SectionQuoteEdit$1 = () => {
|
|
2938
|
-
const { appConfigState: { localIndex, insuranceType } } = useStoreAppConfig();
|
|
2955
|
+
const { appConfigState: { localIndex, insuranceType }, } = useStoreAppConfig();
|
|
2939
2956
|
const { applicantState } = useStoreFormHomeApplicantBase();
|
|
2940
2957
|
const { dwellingState } = useStoreFormHomeDwelling();
|
|
2941
2958
|
const { postalState } = useStoreFormHomePostal();
|
|
2942
|
-
const { discountState: { multiplePoliciesDiscount, quoterInfo } } = useStoreFormHomeDiscount();
|
|
2943
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
2959
|
+
const { discountState: { multiplePoliciesDiscount, quoterInfo }, } = useStoreFormHomeDiscount();
|
|
2960
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
2944
2961
|
const isTheBig = appType === AppTypes.TheBig;
|
|
2945
|
-
const mychoiceCls = appType
|
|
2946
|
-
const { item: { postalCode, provinceCode, city, streetAddress
|
|
2962
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
2963
|
+
const { item: { postalCode, provinceCode, city, streetAddress }, } = postalState;
|
|
2947
2964
|
const { deadbolt, sprinkler, burglarAlarm, fireAlarm, fireExtinguishersCount, // mortgagesCount,
|
|
2948
2965
|
} = dwellingState;
|
|
2949
|
-
const { insured: { nonsmoker } } = applicantState;
|
|
2966
|
+
const { insured: { nonsmoker }, } = applicantState;
|
|
2950
2967
|
const discounts = [];
|
|
2951
2968
|
const isHome = insuranceType === InsuranceTypes.Home;
|
|
2952
2969
|
if (multiplePoliciesDiscount) {
|
|
@@ -2991,17 +3008,23 @@ const SectionQuoteEdit$1 = () => {
|
|
|
2991
3008
|
const discountEdit = () => () => {
|
|
2992
3009
|
navigate(`/${localIndex || defaultLocalIndex}/${insuranceType}/discount`);
|
|
2993
3010
|
};
|
|
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: [
|
|
3011
|
+
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
|
+
[
|
|
3013
|
+
`Name: ${quoterInfo?.firstName}`,
|
|
3014
|
+
`Occupied by: ${occupiedMembers}`,
|
|
3015
|
+
`Year Occupied: ${dwellingState.occupiedYear}`,
|
|
3016
|
+
],
|
|
3017
|
+
] }), jsx(QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: discountEdit, title: "Discount Information", items: [discounts] })] })] }));
|
|
2995
3018
|
};
|
|
2996
3019
|
|
|
2997
3020
|
// import { BlockEndorsements } from './blocks/BlockEndorsements';
|
|
2998
3021
|
const SectionQuoteRecalc = () => {
|
|
2999
3022
|
const [ppLocalOptions, setPpLocalOptions] = useState(ppOptions);
|
|
3000
|
-
const { appConfigState: { appType, insuranceType } } = useStoreAppConfig();
|
|
3023
|
+
const { appConfigState: { appType, insuranceType }, } = useStoreAppConfig();
|
|
3001
3024
|
const isTheBig = appType === AppTypes.TheBig;
|
|
3002
|
-
const mychoiceCls = appType
|
|
3025
|
+
const mychoiceCls = isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
3003
3026
|
const { dwellingState, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
3004
|
-
const { deductible, liability, waterCoverage, pp
|
|
3027
|
+
const { deductible, liability, waterCoverage, pp } = dwellingState;
|
|
3005
3028
|
useEffect(() => {
|
|
3006
3029
|
if (insuranceType === InsuranceTypes.Condo) {
|
|
3007
3030
|
setPpLocalOptions(ppOptions.slice(1));
|
|
@@ -3034,9 +3057,7 @@ const SectionQuoteRecalc = () => {
|
|
|
3034
3057
|
payload: { waterCoverage: value },
|
|
3035
3058
|
});
|
|
3036
3059
|
};
|
|
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 })] }) })] }) }));
|
|
3060
|
+
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
3061
|
};
|
|
3041
3062
|
|
|
3042
3063
|
const SplashScreen$1 = () => {
|
|
@@ -3106,7 +3127,7 @@ const Description = () => (jsxs("div", { children: [jsx("span", { children: jsx(
|
|
|
3106
3127
|
const SectionCoverage = () => {
|
|
3107
3128
|
const { coverageState: { type, coverage, province, inValidation }, dispatchCoverageState, } = useStoreFormLifeCoverage();
|
|
3108
3129
|
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3109
|
-
const isMychoice = appType
|
|
3130
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
3110
3131
|
// const handleProvinceChange = ({ value }: OnChangeEventInterface) => {
|
|
3111
3132
|
// dispatchCoverageState({
|
|
3112
3133
|
// type: StoreFormLifeCoverageActionTypes.FormLifeProvinceSelect,
|
|
@@ -3289,10 +3310,9 @@ const SectionApplicant = () => {
|
|
|
3289
3310
|
textAlign: 'center',
|
|
3290
3311
|
fontSize: '1.15rem',
|
|
3291
3312
|
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:
|
|
3313
|
+
}, 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
3314
|
? errorMessage
|
|
3294
|
-
: getErrorMessage(email, inValidation), error: emailStatus === ValidationStatusTypes.Declined ||
|
|
3295
|
-
(!email && inValidation) }), jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsx(BlockNextPageInfo, {})] }));
|
|
3315
|
+
: getErrorMessage(email, inValidation), error: emailStatus === ValidationStatusTypes.Declined || (!email && inValidation) }), jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsx(BlockNextPageInfo, {})] }));
|
|
3296
3316
|
};
|
|
3297
3317
|
|
|
3298
3318
|
const PageLifeApplicant = () => {
|
|
@@ -3405,16 +3425,18 @@ const getFormattedAddress = (unitNumber, streetAddress, city, provinceCode, post
|
|
|
3405
3425
|
return '';
|
|
3406
3426
|
};
|
|
3407
3427
|
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
|
|
3428
|
+
const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack }, dispatchAppModalState, } = useStoreAppModal();
|
|
3429
|
+
const { status, getPostal, errorMessage: reqErrorMessage } = useHandlerPostal(InsuranceTypes.Home);
|
|
3430
|
+
const { postalState: { item, inValidation }, dispatchPostalState, } = useStoreFormHomePostal();
|
|
3431
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3432
|
+
const { postalCode, city, provinceCode, streetAddress, unitNumber } = item;
|
|
3413
3433
|
const [localPostalCode, setLocalPostalCode] = useState(postalCode);
|
|
3414
3434
|
const [localUnitNumber, setLocalUnitNumber] = useState(unitNumber);
|
|
3415
3435
|
const [localStreetAddress, setLocalStreetAddress] = useState(streetAddress);
|
|
3416
3436
|
const loading = status === RequestStatusTypes.Loading;
|
|
3417
|
-
const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
|
|
3437
|
+
const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
|
|
3438
|
+
? 'The street address should be in the format "123 Streetname Rd."'
|
|
3439
|
+
: '';
|
|
3418
3440
|
const postalCodeErrMessage = localPostalCode.length < 4 ? 'Postal code should have at least 4 characters' : '';
|
|
3419
3441
|
const handleClick = (callBack) => () => {
|
|
3420
3442
|
if (callBack) {
|
|
@@ -3430,10 +3452,14 @@ const ModalAddress = () => {
|
|
|
3430
3452
|
submitCallBack();
|
|
3431
3453
|
}
|
|
3432
3454
|
else if (!localPostalCode || !localStreetAddress || streetAddressErrMessage || postalCodeErrMessage) {
|
|
3433
|
-
dispatchPostalState({
|
|
3455
|
+
dispatchPostalState({
|
|
3456
|
+
type: StoreFormHomePostalActionTypes.FormHomePostalValidate,
|
|
3457
|
+
payload: { inValidation: true },
|
|
3458
|
+
});
|
|
3434
3459
|
}
|
|
3435
3460
|
else {
|
|
3436
|
-
getPostal(postalCodeFormat(localPostalCode))
|
|
3461
|
+
getPostal(postalCodeFormat(localPostalCode))
|
|
3462
|
+
.then((result) => {
|
|
3437
3463
|
const formattedAddress = getFormattedAddress(localUnitNumber, localStreetAddress, result?.data?.city || '', result?.data?.provinceCode || '', localPostalCode, 'Canada');
|
|
3438
3464
|
dispatchPostalState({
|
|
3439
3465
|
type: StoreFormHomePostalActionTypes.FormHomePostalSet,
|
|
@@ -3446,7 +3472,8 @@ const ModalAddress = () => {
|
|
|
3446
3472
|
},
|
|
3447
3473
|
});
|
|
3448
3474
|
dispatchAppModalState({ type: StoreConfigAppModalActionTypes.AppModalClose });
|
|
3449
|
-
})
|
|
3475
|
+
})
|
|
3476
|
+
.catch();
|
|
3450
3477
|
}
|
|
3451
3478
|
}
|
|
3452
3479
|
};
|
|
@@ -3463,7 +3490,7 @@ const ModalAddress = () => {
|
|
|
3463
3490
|
break;
|
|
3464
3491
|
}
|
|
3465
3492
|
};
|
|
3466
|
-
return (jsxs("div", { className: `modal-container edit-address ${appType
|
|
3493
|
+
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
3494
|
};
|
|
3468
3495
|
|
|
3469
3496
|
const ModalFinale = () => {
|
|
@@ -3490,8 +3517,8 @@ PostalCodeDataBox.defaultProps = {
|
|
|
3490
3517
|
postalCode: '',
|
|
3491
3518
|
};
|
|
3492
3519
|
|
|
3493
|
-
const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted
|
|
3494
|
-
const { appConfigState: { insuranceType, appType, localIndex } } = useStoreAppConfig();
|
|
3520
|
+
const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted }) => {
|
|
3521
|
+
const { appConfigState: { insuranceType, appType, localIndex }, } = useStoreAppConfig();
|
|
3495
3522
|
const { appDeviceType } = useStoreDeviceType();
|
|
3496
3523
|
const isMobile = appDeviceType === DeviceTypes.Mobile;
|
|
3497
3524
|
const navigate = useNavigate();
|
|
@@ -3503,7 +3530,9 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3503
3530
|
const activeStep = formSteps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1));
|
|
3504
3531
|
let activeIndex = formSteps.indexOf(activeStep);
|
|
3505
3532
|
activeIndex = activeIndex === -1 ? 0 : activeIndex;
|
|
3506
|
-
let navigationCls = propertyIsCompleted
|
|
3533
|
+
let navigationCls = propertyIsCompleted
|
|
3534
|
+
? 'mychoice-car-navigation-step-container'
|
|
3535
|
+
: 'mychoice-home-navigation-step-container';
|
|
3507
3536
|
if (insuranceType === InsuranceTypes.Life) {
|
|
3508
3537
|
navigationCls = 'mychoice-life-navigation-step-container';
|
|
3509
3538
|
}
|
|
@@ -3517,7 +3546,8 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3517
3546
|
// }
|
|
3518
3547
|
// }, [propertyIsCompleted]);
|
|
3519
3548
|
const handleStepClick = (item, itemIndex) => () => {
|
|
3520
|
-
if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
|
|
3549
|
+
if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
|
|
3550
|
+
// ignore double click
|
|
3521
3551
|
if (activeIndex > (itemIndex || 0)) {
|
|
3522
3552
|
navigate(`/${localIndex}/${insuranceType}${item?.path}`);
|
|
3523
3553
|
}
|
|
@@ -3533,13 +3563,16 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3533
3563
|
validateOptions.forEach((option, index) => {
|
|
3534
3564
|
const isValid = !option.isValid ? option.validate(false) : option.isValid;
|
|
3535
3565
|
formValidations.push({
|
|
3536
|
-
isValid,
|
|
3566
|
+
isValid,
|
|
3567
|
+
validate: option.validate,
|
|
3568
|
+
requestFn: option?.requestFn || undefined,
|
|
3569
|
+
index,
|
|
3537
3570
|
});
|
|
3538
3571
|
});
|
|
3539
3572
|
}
|
|
3540
3573
|
const formValidated = formValidations.find((option) => !option.isValid);
|
|
3541
3574
|
if (formValidated && !formValidated.isValid) {
|
|
3542
|
-
navigate(`/${localIndex}/${insuranceType}${formSteps[
|
|
3575
|
+
navigate(`/${localIndex}/${insuranceType}${formSteps[formValidated.index || 0]?.path}`);
|
|
3543
3576
|
//
|
|
3544
3577
|
// dispatchAppModalState({
|
|
3545
3578
|
// type: StoreConfigAppModalActionTypes.AppModalMessageModal,
|
|
@@ -3561,7 +3594,7 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3561
3594
|
}
|
|
3562
3595
|
}
|
|
3563
3596
|
};
|
|
3564
|
-
return (jsxs("ol", { className: appType
|
|
3597
|
+
return (jsxs("ol", { className: isMyChoiceLike(appType) ? 'mychoice-navigation-steps-container' : 'navigation-steps-container', children: [!isMobile ? (jsx(Fragment, { children: formSteps?.map((item, index) => {
|
|
3565
3598
|
let cls;
|
|
3566
3599
|
switch (true) {
|
|
3567
3600
|
case activeIndex > index:
|
|
@@ -3570,16 +3603,15 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
|
|
|
3570
3603
|
case activeIndex === index:
|
|
3571
3604
|
cls = 'in-progress';
|
|
3572
3605
|
break;
|
|
3573
|
-
default:
|
|
3606
|
+
default:
|
|
3607
|
+
cls = 'todo';
|
|
3574
3608
|
}
|
|
3575
3609
|
// const homeNavigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
|
|
3576
|
-
if (appType
|
|
3610
|
+
if (isMyChoiceLike(appType) && index === formSteps.length - 1) {
|
|
3577
3611
|
return jsx(Fragment, {});
|
|
3578
3612
|
}
|
|
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"] })] })] }))] }));
|
|
3613
|
+
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}`));
|
|
3614
|
+
}) })) : (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
3615
|
};
|
|
3584
3616
|
StepsBox.defaultProps = {
|
|
3585
3617
|
partnerId: '',
|
|
@@ -3666,7 +3698,7 @@ ButtonsBox.defaultProps = {
|
|
|
3666
3698
|
|
|
3667
3699
|
const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearForm, propertyIsCompleted, }) => {
|
|
3668
3700
|
const { pathname } = useLocation();
|
|
3669
|
-
const { appConfigState: { appType, localIndex } } = useStoreAppConfig();
|
|
3701
|
+
const { appConfigState: { appType, localIndex }, } = useStoreAppConfig();
|
|
3670
3702
|
const isTheBig = appType === AppTypes.TheBig;
|
|
3671
3703
|
const { appDeviceType } = useStoreDeviceType();
|
|
3672
3704
|
const isDesktop = appDeviceType === DeviceTypes.Desktop;
|
|
@@ -3692,8 +3724,7 @@ const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearFor
|
|
|
3692
3724
|
return `rgba(${r}, ${g}, ${b}, ${alpha})`;
|
|
3693
3725
|
}
|
|
3694
3726
|
}
|
|
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 })] }) }));
|
|
3727
|
+
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
3728
|
};
|
|
3698
3729
|
NavigationTop.defaultProps = {
|
|
3699
3730
|
isMobile: false,
|
|
@@ -3704,9 +3735,9 @@ const NavigationBottom = ({ createItem, validateForm, formSteps, className, item
|
|
|
3704
3735
|
const { pathname } = useLocation();
|
|
3705
3736
|
const navigate = useNavigate();
|
|
3706
3737
|
const { appConfigState } = useStoreAppConfig();
|
|
3707
|
-
const isMychoice = appConfigState.appType
|
|
3738
|
+
const isMychoice = isMyChoiceLike(appConfigState.appType);
|
|
3708
3739
|
const { insuranceType } = appConfigState;
|
|
3709
|
-
const { dwellingState: { isCompleted } } = useStoreFormHomeDwelling();
|
|
3740
|
+
const { dwellingState: { isCompleted }, } = useStoreFormHomeDwelling();
|
|
3710
3741
|
const [steps, setSteps] = useState(formSteps);
|
|
3711
3742
|
const currentPath = pathname.split('/');
|
|
3712
3743
|
const activeIndex = steps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1))?.key || 0;
|
|
@@ -3940,39 +3971,35 @@ const AppModalWrapper = () => {
|
|
|
3940
3971
|
const { appModalState } = useStoreAppModal();
|
|
3941
3972
|
switch (appModalState.modalType) {
|
|
3942
3973
|
case ModalTypes.MessageModal:
|
|
3943
|
-
return
|
|
3974
|
+
return jsx(ModalMessage, {});
|
|
3944
3975
|
case ModalTypes.ConfirmModal:
|
|
3945
|
-
return
|
|
3976
|
+
return jsx(ModalConfirm, {});
|
|
3946
3977
|
case ModalTypes.PostalModal:
|
|
3947
|
-
return
|
|
3978
|
+
return jsx(ModalPostal, {});
|
|
3948
3979
|
case ModalTypes.AddressModal:
|
|
3949
|
-
return
|
|
3980
|
+
return jsx(ModalAddress, {});
|
|
3950
3981
|
case ModalTypes.FinaleModal:
|
|
3951
|
-
return
|
|
3982
|
+
return jsx(ModalFinale, {});
|
|
3952
3983
|
default:
|
|
3953
3984
|
return null;
|
|
3954
3985
|
}
|
|
3955
3986
|
};
|
|
3956
3987
|
const AppModal = () => {
|
|
3957
3988
|
const { appModalState } = useStoreAppModal();
|
|
3958
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
3989
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
3959
3990
|
const insuranceType = getInsuranceType();
|
|
3960
3991
|
if (appModalState.isOpen && document.location.pathname.indexOf(insuranceType) !== -1) {
|
|
3961
|
-
return (jsx("div", { className: `app-modal ${appType
|
|
3992
|
+
return (jsx("div", { className: `app-modal ${isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: jsx(AppModalWrapper, {}) }));
|
|
3962
3993
|
}
|
|
3963
3994
|
return null;
|
|
3964
3995
|
};
|
|
3965
3996
|
|
|
3966
3997
|
const AppHeader = () => {
|
|
3967
|
-
const { appConfigState: { appType, localIndex } } = useStoreAppConfig();
|
|
3998
|
+
const { appConfigState: { appType, localIndex }, } = useStoreAppConfig();
|
|
3968
3999
|
const { appDeviceType } = useStoreDeviceType();
|
|
3969
4000
|
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, {}) })))] }));
|
|
4001
|
+
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 &&
|
|
4002
|
+
(localIndex !== defaultLocalIndex ? (jsx(HeaderPartner, {})) : (jsx(Fragment, { children: appDeviceType === DeviceTypes.Desktop ? jsx(HeaderMyChoice, {}) : jsx(HeaderMyChoiceMobile, {}) })))] }));
|
|
3976
4003
|
}
|
|
3977
4004
|
return null;
|
|
3978
4005
|
};
|
|
@@ -4072,7 +4099,7 @@ const AppRouteWrapper = (props) => {
|
|
|
4072
4099
|
let postalCode = carPostal;
|
|
4073
4100
|
const { clearFormData, checkIsExpired, checkIsExpiredWithModal } = ClearFormDataHandler();
|
|
4074
4101
|
const { appLoaderState } = useStoreAppLoader();
|
|
4075
|
-
const isMychoice = appType
|
|
4102
|
+
const isMychoice = isMyChoiceLike(appType);
|
|
4076
4103
|
switch (insuranceType) {
|
|
4077
4104
|
case InsuranceTypes.Car:
|
|
4078
4105
|
postalCode = carPostal;
|
|
@@ -4337,7 +4364,7 @@ const AppRouteWrapper = (props) => {
|
|
|
4337
4364
|
}
|
|
4338
4365
|
}
|
|
4339
4366
|
}, [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
|
|
4367
|
+
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
4368
|
};
|
|
4342
4369
|
const NestedRoutes = () => {
|
|
4343
4370
|
const insuranceType = getInsuranceType();
|
|
@@ -4479,7 +4506,7 @@ const AppConfig = (props) => {
|
|
|
4479
4506
|
// home insurance steps states
|
|
4480
4507
|
const { dispatchPostalState: dispatchHomePostalState } = useStoreFormHomePostal();
|
|
4481
4508
|
const { dispatchApplicantBaseState } = useStoreFormHomeApplicantBase();
|
|
4482
|
-
const { dwellingState: { isCompleted }, dispatchDwellingState } = useStoreFormHomeDwelling();
|
|
4509
|
+
const { dwellingState: { isCompleted }, dispatchDwellingState, } = useStoreFormHomeDwelling();
|
|
4483
4510
|
const { dispatchDiscountState: dispatchHomeDiscountState } = useStoreFormHomeDiscount();
|
|
4484
4511
|
const { dispatchQuoteState: dispatchHomeQuoteState } = useStoreFormHomeQuote();
|
|
4485
4512
|
// life insurance
|
|
@@ -4538,8 +4565,7 @@ const AppConfig = (props) => {
|
|
|
4538
4565
|
if (authHandler.status === RequestStatusTypes.Waiting) {
|
|
4539
4566
|
authHandler.checkUser();
|
|
4540
4567
|
}
|
|
4541
|
-
if (authHandler.status !== RequestStatusTypes.Waiting
|
|
4542
|
-
&& authHandler.status !== RequestStatusTypes.Loading) {
|
|
4568
|
+
if (authHandler.status !== RequestStatusTypes.Waiting && authHandler.status !== RequestStatusTypes.Loading) {
|
|
4543
4569
|
if (insuranceType === InsuranceTypes.Car) {
|
|
4544
4570
|
dispatchCarPostalState({
|
|
4545
4571
|
type: StoreFormCarPostalActionTypes.FormCarPostalGetLocal,
|
|
@@ -4569,7 +4595,9 @@ const AppConfig = (props) => {
|
|
|
4569
4595
|
type: StoreFormCarQuoteActionTypes.FormCarQuoteGetLocal,
|
|
4570
4596
|
});
|
|
4571
4597
|
}
|
|
4572
|
-
if (insuranceType === InsuranceTypes.Home ||
|
|
4598
|
+
if (insuranceType === InsuranceTypes.Home ||
|
|
4599
|
+
insuranceType === InsuranceTypes.Condo ||
|
|
4600
|
+
insuranceType === InsuranceTypes.Tenant) {
|
|
4573
4601
|
dispatchHomePostalState({
|
|
4574
4602
|
type: StoreFormHomePostalActionTypes.FormHomePostalGetLocal,
|
|
4575
4603
|
});
|
|
@@ -4620,6 +4648,14 @@ const AppConfig = (props) => {
|
|
|
4620
4648
|
payload: true,
|
|
4621
4649
|
});
|
|
4622
4650
|
}
|
|
4651
|
+
if (appType === AppTypes.BeginInsurance) {
|
|
4652
|
+
// Begin Insurance brand colors: Navy Blue primary, Green accent
|
|
4653
|
+
setExternalColors('#0F2043', '#50C878');
|
|
4654
|
+
dispatchAppConfigState({
|
|
4655
|
+
type: StoreConfigAppConfigActionTypes.AppConfigSetPreloaded,
|
|
4656
|
+
payload: true,
|
|
4657
|
+
});
|
|
4658
|
+
}
|
|
4623
4659
|
}, [appType]);
|
|
4624
4660
|
useEffect(() => {
|
|
4625
4661
|
if (insuranceType === InsuranceTypes.Home && isCompleted) {
|
|
@@ -4674,5 +4710,5 @@ AppWrapper.defaultProps = {
|
|
|
4674
4710
|
insuranceType: InsuranceTypes.Car,
|
|
4675
4711
|
};
|
|
4676
4712
|
|
|
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 };
|
|
4713
|
+
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
4714
|
//# sourceMappingURL=index.js.map
|