@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.0

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