@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.1

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