@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cjs/index.js CHANGED
@@ -22,13 +22,11 @@ var GooglePlacesAutocomplete__default = /*#__PURE__*/_interopDefaultLegacy(Googl
22
22
  var TagManager__default = /*#__PURE__*/_interopDefaultLegacy(TagManager);
23
23
 
24
24
  const LabelFormBox = (props) => {
25
- const { name, className, title, subTitle, description, isRemovable, onIconClick, isActive, } = props;
26
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
25
+ const { name, className, title, subTitle, description, isRemovable, onIconClick, isActive } = props;
26
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
27
27
  const isThebig = appType === mychoiceSdkComponents.AppTypes.TheBig;
28
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
29
- return (jsxRuntime.jsxs("div", { className: `label-container ${className}`, children: [jsxRuntime.jsx(mychoiceSdkComponents.TitleForm, { className: isThebig ? 'thebig-medium' : '', title: title, subTitle: subTitle, isActive: isActive }), (name && description)
30
- && jsxRuntime.jsx(mychoiceSdkComponents.TooltipForm, { id: `${name.toLowerCase()}-tooltip`, description: description, color: isMychoice ? '#F7C2D9' : '' }), isRemovable
31
- && (jsxRuntime.jsx(mychoiceSdkComponents.IconDelete, { className: "icon-label-delete", onClick: onIconClick, color: mychoiceSdkComponents.ColorVariablesTypes.Primary, height: "1.125rem", width: "1.125rem" }))] }));
28
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
29
+ return (jsxRuntime.jsxs("div", { className: `label-container ${className}`, children: [jsxRuntime.jsx(mychoiceSdkComponents.TitleForm, { className: isThebig ? 'thebig-medium' : '', title: title, subTitle: subTitle, isActive: isActive }), name && description && (jsxRuntime.jsx(mychoiceSdkComponents.TooltipForm, { id: `${name.toLowerCase()}-tooltip`, description: description, color: isMychoice ? '#F7C2D9' : '' })), isRemovable && (jsxRuntime.jsx(mychoiceSdkComponents.IconDelete, { className: "icon-label-delete", onClick: onIconClick, color: mychoiceSdkComponents.ColorVariablesTypes.Primary, height: "1.125rem", width: "1.125rem" }))] }));
32
30
  };
33
31
  LabelFormBox.defaultProps = {
34
32
  className: '',
@@ -119,11 +117,11 @@ DateSelectFormBox.defaultProps = {
119
117
  };
120
118
 
121
119
  const SwitchButtonBox = (props) => {
122
- const { name, title, description, hintMessage, isRemovable, errorMessage, className, defaultValue, items, onChange, } = props;
120
+ const { name, title, description, hintMessage, isRemovable, errorMessage, className, defaultValue, items, onChange } = props;
123
121
  const [activeId, setActiveId] = React.useState(defaultValue);
124
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
122
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
125
123
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
126
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
124
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
127
125
  const setClassNames = (isActive) => {
128
126
  if (isTheBig) {
129
127
  return isActive ? 'thebig-bold' : 'thebig-regular';
@@ -233,9 +231,14 @@ const BlockVehLinks = () => {
233
231
  };
234
232
 
235
233
  const BlockNextPageInfo$2 = () => {
236
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
237
- const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
238
- return (jsxRuntime.jsx("div", { className: "next-page-info", children: isTheBig ? (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.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."] }) })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsxs("div", { className: "next-page-points", children: [jsxRuntime.jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsxRuntime.jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsxRuntime.jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.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", jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] })) }));
234
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
235
+ if (appType === mychoiceSdkComponents.AppTypes.TheBig) {
236
+ return (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.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."] }) }));
237
+ }
238
+ if (appType === mychoiceSdkComponents.AppTypes.MyChoice) {
239
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsxs("div", { className: "next-page-points", children: [jsxRuntime.jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsxRuntime.jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsxRuntime.jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.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", jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] }));
240
+ }
241
+ return null;
239
242
  };
240
243
 
241
244
  const BlockSubmit$2 = ({ className, label, buttonSize, isRecalc = false, }) => {
@@ -388,8 +391,8 @@ const OfferSection = ({ offerCompany, brokerCompany, offerPrice, phoneNumber, is
388
391
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
389
392
  const { postRequestQuoteOnliaUrl } = mychoiceSdkStore.CarQuoteDataHandler();
390
393
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
391
- const isMyChoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
392
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
394
+ const isMyChoice = mychoiceSdkComponents.isMyChoiceLike(appType);
395
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
393
396
  const { weekdayHours, saturdayHours, sundayHours } = operationHours;
394
397
  const [detailsIsOpen, setDetailsIsOpenIsOpen] = React.useState(isBestOffer ?? false);
395
398
  const handleDropdownClick = () => {
@@ -425,66 +428,73 @@ OfferSection.defaultProps = {
425
428
  isBestOffer: false,
426
429
  };
427
430
 
428
- var logo = "";
431
+ var logo$1 = "";
429
432
 
430
- const TITLE = {
433
+ var logo = "";
434
+
435
+ const TITLE_MYCHOICE = {
431
436
  car: 'Hello Canadian Drivers, Welcome to MyChoice!',
432
437
  home: 'Hello Canadian Residents, Welcome to MyChoice!',
433
438
  life: 'Hello Canadian Residents, Welcome to MyChoice!',
434
439
  };
435
- const TEXT = {
440
+ const TITLE_BEGIN = {
441
+ car: 'Hello Canadian Drivers, Welcome to Begin Insurance!',
442
+ home: 'Hello Canadian Residents, Welcome to Begin Insurance!',
443
+ life: 'Hello Canadian Residents, Welcome to Begin Insurance!',
444
+ };
445
+ const TEXT_MYCHOICE = {
436
446
  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!',
437
447
  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!',
438
448
  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.',
439
449
  };
450
+ const TEXT_BEGIN = {
451
+ 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!',
452
+ 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!',
453
+ 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.',
454
+ };
440
455
  const NoQuotesMessage = ({ type }) => {
441
456
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
442
- if (appType === mychoiceSdkComponents.AppTypes.TheBig)
457
+ if (!mychoiceSdkComponents.isMyChoiceLike(appType))
443
458
  return null;
444
- return (jsxRuntime.jsxs("div", { className: "offer-section mychoice", children: [jsxRuntime.jsx("div", { style: { width: '100%' }, children: jsxRuntime.jsx("img", { src: logo, alt: "My Choice", style: { width: '120px' } }) }), jsxRuntime.jsx("p", { children: jsxRuntime.jsx("h3", { style: { whiteSpace: 'normal' }, children: TITLE[type] }) }), jsxRuntime.jsx("p", { style: { lineHeight: '1.25rem' }, children: TEXT[type] })] }));
459
+ const isBegin = appType === mychoiceSdkComponents.AppTypes.BeginInsurance;
460
+ const logo$2 = isBegin ? logo : logo$1;
461
+ const title = isBegin ? TITLE_BEGIN[type] : TITLE_MYCHOICE[type];
462
+ const text = isBegin ? TEXT_BEGIN[type] : TEXT_MYCHOICE[type];
463
+ const altText = isBegin ? 'Begin Insurance' : 'My Choice';
464
+ return (jsxRuntime.jsxs("div", { className: "offer-section mychoice", children: [jsxRuntime.jsx("div", { style: { width: '100%' }, children: jsxRuntime.jsx("img", { src: logo$2, alt: altText, style: { width: '120px' } }) }), jsxRuntime.jsx("p", { children: jsxRuntime.jsx("h3", { style: { whiteSpace: 'normal' }, children: title }) }), jsxRuntime.jsx("p", { style: { lineHeight: '1.25rem' }, children: text })] }));
445
465
  };
446
466
 
447
467
  const usePathGroups = (insuranceType) => {
448
468
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
469
+ const { localIndex, appType } = appConfigState;
449
470
  const insurancePathGroup = {
450
- [`${mychoiceSdkComponents.InsuranceTypes.Car}`]: [{ name: 'Car', link: `/${appConfigState.localIndex}/car` }],
451
- [`${mychoiceSdkComponents.InsuranceTypes.Home}`]: [{ name: 'Home', link: `/${appConfigState.localIndex}/home` }],
452
- // @todo: will be used in future
453
- // [`${InsuranceTypes.Life}`]: [{ name: 'Life', link: `/${appConfigState.localIndex}/life` }],
471
+ [`${mychoiceSdkComponents.InsuranceTypes.Car}`]: [{ name: 'Car', link: `/${localIndex}/car` }],
472
+ [`${mychoiceSdkComponents.InsuranceTypes.Home}`]: [{ name: 'Home', link: `/${localIndex}/home` }],
454
473
  };
455
- const externalPathGroup = [
474
+ // Begin Insurance only shows Auto and Home
475
+ const beginInsurancePathGroup = [
476
+ { name: 'Auto', link: '/insurance/car' },
477
+ { name: 'Home', link: '/insurance/home' },
478
+ ];
479
+ // MyChoice shows all options including Life and Learn
480
+ const myChoicePathGroup = [
456
481
  { name: 'Car', link: '/insurance/car' },
457
482
  { name: 'Home', link: '/insurance/home' },
458
483
  { name: 'Life', link: '/insurance/life' },
459
484
  { name: 'Learn', link: 'https://www.mychoice.ca/blog/' },
460
485
  ];
461
- // @todo: use in future.
462
- // const loggedOutPathGroup = [
463
- // { name: 'Login', link: '/accounts/signin' },
464
- // { name: 'Signup', link: '/accounts/signup' },
465
- // ];
466
- //
467
- // const loggedInPathGroup = [
468
- // { name: 'My Profile', link: '/accounts/myProfile' },
469
- // { name: 'Quotes History', link: '/accounts/quotes/history' },
470
- // { name: 'Logout', link: '/accounts/logout' },
471
- // ];
486
+ const externalPathGroup = appType === mychoiceSdkComponents.AppTypes.BeginInsurance ? beginInsurancePathGroup : myChoicePathGroup;
472
487
  return {
473
488
  insurancePathGroup: insurancePathGroup[insuranceType],
474
489
  externalPathGroup,
475
- // loggedOutPathGroup,
476
- // loggedInPathGroup,
477
490
  };
478
491
  };
479
492
 
480
- const HeaderMyChoice = ({ className, }) => {
493
+ const HeaderMyChoice = ({ className }) => {
481
494
  const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
482
- const insuranceTypeCls = insuranceType !== mychoiceSdkComponents.InsuranceTypes.Car &&
483
- insuranceType !== mychoiceSdkComponents.InsuranceTypes.Life
484
- ? mychoiceSdkComponents.InsuranceTypes.Home
485
- : insuranceType;
495
+ const insuranceTypeCls = insuranceType !== mychoiceSdkComponents.InsuranceTypes.Car && insuranceType !== mychoiceSdkComponents.InsuranceTypes.Life ? mychoiceSdkComponents.InsuranceTypes.Home : insuranceType;
486
496
  const { externalPathGroup } = usePathGroups(insuranceTypeCls);
487
- return (jsxRuntime.jsx("div", { className: `${className} primary-header`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo, alt: "logotype" }) }) }), jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsxRuntime.jsx("div", { className: "empty-box" })] }) }));
497
+ return (jsxRuntime.jsx("div", { className: `${className} primary-header`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo$1, alt: "logotype" }) }) }), jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsxRuntime.jsx("div", { className: "empty-box" })] }) }));
488
498
  };
489
499
  HeaderMyChoice.defaultProps = {
490
500
  className: '',
@@ -502,20 +512,42 @@ HeaderTheBig.defaultProps = {
502
512
  className: '',
503
513
  };
504
514
 
505
- const HeaderMyChoiceMobile = ({ className, }) => {
506
- const { appConfigState: { insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
515
+ const HeaderBeginInsurance = ({ className }) => {
516
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
517
+ const insuranceTypeCls = insuranceType !== mychoiceSdkComponents.InsuranceTypes.Car && insuranceType !== mychoiceSdkComponents.InsuranceTypes.Life ? mychoiceSdkComponents.InsuranceTypes.Home : insuranceType;
518
+ const { externalPathGroup } = usePathGroups(insuranceTypeCls);
519
+ return (jsxRuntime.jsx("div", { className: `${className} primary-header`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.begininsurance.com/", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo, alt: "Begin Insurance" }) }) }), jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceTypeCls, navItems: externalPathGroup, isExternal: true }) }), jsxRuntime.jsx("div", { className: "empty-box" })] }) }));
520
+ };
521
+ HeaderBeginInsurance.defaultProps = {
522
+ className: '',
523
+ };
524
+
525
+ const HeaderMyChoiceMobile = ({ className }) => {
526
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
507
527
  const { externalPathGroup } = usePathGroups(insuranceType);
508
528
  const [isMenuOpen, setIsMenuOpen] = React.useState(false);
509
529
  const handleMenuClick = () => {
510
530
  setIsMenuOpen(!isMenuOpen);
511
531
  };
512
- // const isLoggedIn = true;
513
- return (jsxRuntime.jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxRuntime.jsxs("div", { className: "content-mobile", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/", target: "_blank", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo, alt: "logotype" }) }) }), jsxRuntime.jsx(mychoiceSdkComponents.ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsxRuntime.jsx("div", { className: "menu-items", children: jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
532
+ return (jsxRuntime.jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxRuntime.jsxs("div", { className: "content-mobile", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/", target: "_blank", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo$1, alt: "logotype" }) }) }), jsxRuntime.jsx(mychoiceSdkComponents.ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsxRuntime.jsx("div", { className: "menu-items", children: jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
514
533
  };
515
534
  HeaderMyChoiceMobile.defaultProps = {
516
535
  className: '',
517
536
  };
518
537
 
538
+ const HeaderBeginInsuranceMobile = ({ className }) => {
539
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
540
+ const { externalPathGroup } = usePathGroups(insuranceType);
541
+ const [isMenuOpen, setIsMenuOpen] = React.useState(false);
542
+ const handleMenuClick = () => {
543
+ setIsMenuOpen(!isMenuOpen);
544
+ };
545
+ return (jsxRuntime.jsxs("div", { className: `${className} ${isMenuOpen ? 'open' : ''} primary-header-mobile`, children: [jsxRuntime.jsxs("div", { className: "content-mobile", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("a", { href: "https://www.begininsurance.com/", target: "_blank", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: logo, alt: "Begin Insurance" }) }) }), jsxRuntime.jsx(mychoiceSdkComponents.ButtonMenu, { className: `${className} ${isMenuOpen ? 'is-active' : ''}`, onClick: handleMenuClick })] }), isMenuOpen && (jsxRuntime.jsx("div", { className: "menu-items", children: jsxRuntime.jsx("div", { className: "nav-links", children: jsxRuntime.jsx(mychoiceSdkComponents.HeaderNavGroup, { className: insuranceType, navItems: externalPathGroup, isExternal: true }) }) }))] }));
546
+ };
547
+ HeaderBeginInsuranceMobile.defaultProps = {
548
+ className: '',
549
+ };
550
+
519
551
  const LoaderVid = () => {
520
552
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
521
553
  const isMobile = appDeviceType === mychoiceSdkComponents.DeviceTypes.Mobile;
@@ -526,11 +558,11 @@ const LoaderPrimary = () => {
526
558
  const { appLoaderState } = mychoiceSdkStore.useStoreAppLoader();
527
559
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
528
560
  const isLastPage = window.location.pathname.includes('discount') || window.location.pathname.includes('/life/applicant');
529
- const isHome = window.location.pathname.includes('home') || window.location.pathname.includes('condo') || window.location.pathname.includes('tenant');
530
- return (jsxRuntime.jsxs("div", { className: "loader-wrapper", children: [appConfigState.appType === mychoiceSdkComponents.AppTypes.TheBig || !isLastPage ? jsxRuntime.jsx(mychoiceSdkComponents.IconLoaderPrimary, {}) : jsxRuntime.jsx(LoaderVid, {}), appLoaderState.description
531
- ? (jsxRuntime.jsx("h4", { children: appLoaderState.description.split('\n').map((line, index) => (jsxRuntime.jsxs("div", { children: [line, jsxRuntime.jsx("br", {})] }, index))) }))
532
- // eslint-disable-next-line react/no-unescaped-entities
533
- : !appLoaderState.description && isHome && jsxRuntime.jsx("h4", { children: "Hang tight, while we collect and process information about your property." })] }));
561
+ const isHome = window.location.pathname.includes('home') ||
562
+ window.location.pathname.includes('condo') ||
563
+ window.location.pathname.includes('tenant');
564
+ return (jsxRuntime.jsxs("div", { className: "loader-wrapper", children: [appConfigState.appType === mychoiceSdkComponents.AppTypes.MyChoice && !isLastPage ? jsxRuntime.jsx(LoaderVid, {}) : jsxRuntime.jsx(mychoiceSdkComponents.IconLoaderPrimary, {}), appLoaderState.description ? (jsxRuntime.jsx("h4", { children: appLoaderState.description.split('\n').map((line, index) => (jsxRuntime.jsxs("div", { children: [line, jsxRuntime.jsx("br", {})] }, index))) })) : (!appLoaderState.description &&
565
+ isHome && jsxRuntime.jsx("h4", { children: "Hang tight, while we collect and process information about your property." }))] }));
534
566
  };
535
567
 
536
568
  const ModalConfirm = () => {
@@ -780,16 +812,16 @@ const BlockCarConditionInfo = () => {
780
812
  };
781
813
 
782
814
  const VehicleSectionMain = () => {
783
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
784
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
815
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
816
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
785
817
  return (jsxRuntime.jsxs("div", { className: `form-section top-section ${mychoiceCls}`, children: [mychoiceCls && jsxRuntime.jsx("h2", { className: "section-title", children: "Give us the scoop on your four-wheeled friend." }), jsxRuntime.jsx(BlockCarInfo, {}), jsxRuntime.jsx(BlockCarConditionInfo, {})] }));
786
818
  };
787
819
 
788
820
  const VehicleSectionCoverage = () => {
789
821
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
790
822
  const { collision, comprehensive } = vehicleState.items[vehicleState.activeIndex];
791
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
792
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
823
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
824
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
793
825
  const handleComprehensiveChange = ({ value }) => {
794
826
  dispatchVehicleState({
795
827
  type: mychoiceSdkStore.StoreFormCarVehicleActionTypes.FormCarComprehensiveCoverageSelect,
@@ -943,11 +975,11 @@ const TabDriver = ({ createItem, readOnly }) => {
943
975
 
944
976
  const SectionDriverInfo = () => {
945
977
  const { configState } = mychoiceSdkStore.useStoreFormCarConfig();
946
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
978
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
947
979
  const { driverState, dispatchDriverInfoState } = mychoiceSdkStore.useStoreFormCarDriverInfo();
948
980
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
949
- const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship, } = driverState.items[driverState.activeIndex];
950
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
981
+ const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship } = driverState.items[driverState.activeIndex];
982
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
951
983
  const defaultDateOfBirth = {
952
984
  day: birthDay,
953
985
  month: birthMonth,
@@ -1011,17 +1043,16 @@ const SectionDriverInfo = () => {
1011
1043
  payload: { applicantRelationship: value },
1012
1044
  });
1013
1045
  };
1014
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [mychoiceCls && jsxRuntime.jsx("h2", { className: "section-title", children: "Time for a micro autobiography \u2013 tell us about you." }), jsxRuntime.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) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.maritalStatusOptions, name: "maritalStatus", onChange: handleMaritalStatusChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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) }), jsxRuntime.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: mychoiceSdkComponents.subYearsFromDate('', configState.licenceConfig.minLicenceAge || 16), isDay: true }), jsxRuntime.jsx(SwitchButtonBox, { name: "occupation", items: mychoiceSdkComponents.occupationOptions, onChange: handleOccupationChange, defaultValue: getSelectedOption(mychoiceSdkComponents.occupationOptions, occupation), title: "Are you currently employed or unemployed?", description: "Your employment status reflects your driving frequency, and insurers consider this in your policy." }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.genderOptions, onChange: handleGenderChange, name: "gender", defaultValue: getSelectedOption(mychoiceSdkComponents.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
1015
- && (jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.applicantRelationshipOptions, name: "applicantRelationship", onChange: handleApplicantRelationshipChange, defaultValue: getSelectedOption(mychoiceSdkComponents.applicantRelationshipOptions, applicantRelationship), title: "Relationship to applicant", placeholder: "Select...", autoSelectIfValueIsOutOfOptions: false, error: !applicantRelationship && driverState.inValidation, errorMessage: getErrorMessage(applicantRelationship, driverState.inValidation) }))] }));
1046
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [mychoiceCls && jsxRuntime.jsx("h2", { className: "section-title", children: "Time for a micro autobiography \u2013 tell us about you." }), jsxRuntime.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) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.maritalStatusOptions, name: "maritalStatus", onChange: handleMaritalStatusChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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) }), jsxRuntime.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: mychoiceSdkComponents.subYearsFromDate('', configState.licenceConfig.minLicenceAge || 16), isDay: true }), jsxRuntime.jsx(SwitchButtonBox, { name: "occupation", items: mychoiceSdkComponents.occupationOptions, onChange: handleOccupationChange, defaultValue: getSelectedOption(mychoiceSdkComponents.occupationOptions, occupation), title: "Are you currently employed or unemployed?", description: "Your employment status reflects your driving frequency, and insurers consider this in your policy." }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.genderOptions, onChange: handleGenderChange, name: "gender", defaultValue: getSelectedOption(mychoiceSdkComponents.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 && (jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.applicantRelationshipOptions, name: "applicantRelationship", onChange: handleApplicantRelationshipChange, defaultValue: getSelectedOption(mychoiceSdkComponents.applicantRelationshipOptions, applicantRelationship), title: "Relationship to applicant", placeholder: "Select...", autoSelectIfValueIsOutOfOptions: false, error: !applicantRelationship && driverState.inValidation, errorMessage: getErrorMessage(applicantRelationship, driverState.inValidation) }))] }));
1016
1047
  };
1017
1048
 
1018
1049
  const SectionDriverLicence = () => {
1019
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1050
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1020
1051
  const [driverEducation, setDriverEducation] = React.useState(false);
1021
1052
  const { configState } = mychoiceSdkStore.useStoreFormCarConfig();
1022
1053
  const { driverState, dispatchDriverLicenceState } = mychoiceSdkStore.useStoreFormCarDriverLicence();
1023
1054
  const { isAlbertaProvince } = mychoiceSdkStore.useProvince();
1024
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1055
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1025
1056
  const { firstName, birthDay, birthMonth, birthYear, licenceInfo: { firstLicenceAge, licenceType, g1LicenceYear, g1LicenceMonth, gLicenceYear, gLicenceMonth, g2LicenceYear, g2LicenceMonth, passedDriverTraining, previousLicence, }, minMaxDates, } = driverState.items[driverState.activeIndex];
1026
1057
  const { gMax = mychoiceSdkComponents.getFormattedDate('', 'yyyy-MM-dd'), gMin = '1922-01-01', gOneMax = mychoiceSdkComponents.getFormattedDate('', 'yyyy-MM-dd'), gOneMin = '1922-01-01', gTwoMax = mychoiceSdkComponents.getFormattedDate('', 'yyyy-MM-dd'), gTwoMin = '1922-01-01', gBlock = false, gTwoBlock = false, gOneBlock = false, licenceAgeMax = 16, } = minMaxDates ?? {};
1027
1058
  const maxLicenceAge = licenceAgeMax;
@@ -1030,7 +1061,7 @@ const SectionDriverLicence = () => {
1030
1061
  const defaultMinDate = birthDate && firstLicenceAge ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge) : '';
1031
1062
  const isOnlyG = mychoiceSdkComponents.checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
1032
1063
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1033
- const { g, g1, g2, minLicenceAge, } = configState.licenceConfig;
1064
+ const { g, g1, g2, minLicenceAge } = configState.licenceConfig;
1034
1065
  const licenceTypeOptions = [
1035
1066
  { value: g.name, name: g.title },
1036
1067
  { value: g1.name, name: g1.title },
@@ -1060,7 +1091,8 @@ const SectionDriverLicence = () => {
1060
1091
  return gOneMin;
1061
1092
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1062
1093
  return gTwoMin;
1063
- default: return '';
1094
+ default:
1095
+ return '';
1064
1096
  }
1065
1097
  };
1066
1098
  const getMaxDate = (type) => {
@@ -1071,7 +1103,8 @@ const SectionDriverLicence = () => {
1071
1103
  return gOneMax;
1072
1104
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1073
1105
  return gTwoMax;
1074
- default: return '';
1106
+ default:
1107
+ return '';
1075
1108
  }
1076
1109
  };
1077
1110
  const getLicenceYear = (type) => {
@@ -1082,7 +1115,8 @@ const SectionDriverLicence = () => {
1082
1115
  return g1LicenceYear;
1083
1116
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1084
1117
  return g2LicenceYear;
1085
- default: return '';
1118
+ default:
1119
+ return '';
1086
1120
  }
1087
1121
  };
1088
1122
  const getLicenceMonth = (type) => {
@@ -1093,7 +1127,8 @@ const SectionDriverLicence = () => {
1093
1127
  return g1LicenceMonth;
1094
1128
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1095
1129
  return g2LicenceMonth;
1096
- default: return '';
1130
+ default:
1131
+ return '';
1097
1132
  }
1098
1133
  };
1099
1134
  const getDefaultLicenceDate = (type) => ({
@@ -1146,8 +1181,10 @@ const SectionDriverLicence = () => {
1146
1181
  const formattedMinDate = `${mychoiceSdkComponents.getFormattedDate(licenceMinDate, 'MMMM yyyy')}`;
1147
1182
  const defaultHintMessage = `${formattedMinDate} would be your earliest ${licenceTypeTitle}
1148
1183
  licence date based on your first licenced age and date of birth`;
1149
- return currentType === mychoiceSdkComponents.DriverLicenceTypes.G2 ? `${defaultHintMessage}
1150
- if you completed a driver education course` : defaultHintMessage;
1184
+ return currentType === mychoiceSdkComponents.DriverLicenceTypes.G2
1185
+ ? `${defaultHintMessage}
1186
+ if you completed a driver education course`
1187
+ : defaultHintMessage;
1151
1188
  };
1152
1189
  const getLicenceAgeTitle = () => {
1153
1190
  if (isAlbertaProvince && isTheBig) {
@@ -1155,10 +1192,10 @@ const SectionDriverLicence = () => {
1155
1192
  }
1156
1193
  return `What age was ${firstName || driverNameDefault} when first licenced?`;
1157
1194
  };
1158
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx(InputFormBox, { name: "firstLicenceAge", title: getLicenceAgeTitle(), onChange: handleLicenceAgeChange, type: mychoiceSdkComponents.InputTypes.Number, defaultValue: firstLicenceAge, description: configState.toolTip.licenceAge, hintMessage: birthDate ? `${firstName || driverNameDefault} was licenced in
1159
- ${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 }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.getLicenceTypeOptions(licenceTypeOptions, mychoiceSdkComponents.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 === mychoiceSdkComponents.DriverLicenceTypes.G && !isOnlyG
1160
- && (jsxRuntime.jsx(DateSelectFormBox, { name: "g2LicenceDate", dateNames: ['g2LicenceYear', 'g2LicenceMonth'], onDateChange: handleLicenceDateChange(mychoiceSdkComponents.DriverLicenceTypes.G2), defaultValue: getDefaultLicenceDate(mychoiceSdkComponents.DriverLicenceTypes.G2), title: `${configState.licenceConfig.g2.title} licence date`, errorMessage: getDateErrorMessage(['01', g2LicenceMonth, g2LicenceYear], driverState.inValidation), hintMessage: getHintMessage(mychoiceSdkComponents.DriverLicenceTypes.G2), error: driverState.inValidation, minDate: getMinDate(mychoiceSdkComponents.DriverLicenceTypes.G2), maxDate: getMaxDate(mychoiceSdkComponents.DriverLicenceTypes.G2) })), licenceType && (jsxRuntime.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
1161
- && (jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleTrainingChange, name: "passedDriverTraining", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, passedDriverTraining), title: `Has ${firstName || driverNameDefault} completed a driver education course within the last 3 years?` })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handlePreviousLicenceChange, name: "previousLicence", defaultValue: getSelectedOption(mychoiceSdkComponents.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)." })] }));
1195
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx(InputFormBox, { name: "firstLicenceAge", title: getLicenceAgeTitle(), onChange: handleLicenceAgeChange, type: mychoiceSdkComponents.InputTypes.Number, defaultValue: firstLicenceAge, description: configState.toolTip.licenceAge, hintMessage: birthDate
1196
+ ? `${firstName || driverNameDefault} was licenced in
1197
+ ${Number(birthYear) + Number(firstLicenceAge)} - ${Number(birthYear) + Number(firstLicenceAge) + 1}`
1198
+ : '', placeholder: "Select Licence Age", disabled: !birthDate, error: !firstLicenceAge && driverState.inValidation, errorMessage: getErrorMessage(firstLicenceAge, driverState.inValidation), minValue: minLicenceAge || 16, maxValue: maxLicenceAge }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.getLicenceTypeOptions(licenceTypeOptions, mychoiceSdkComponents.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 === mychoiceSdkComponents.DriverLicenceTypes.G && !isOnlyG && (jsxRuntime.jsx(DateSelectFormBox, { name: "g2LicenceDate", dateNames: ['g2LicenceYear', 'g2LicenceMonth'], onDateChange: handleLicenceDateChange(mychoiceSdkComponents.DriverLicenceTypes.G2), defaultValue: getDefaultLicenceDate(mychoiceSdkComponents.DriverLicenceTypes.G2), title: `${configState.licenceConfig.g2.title} licence date`, errorMessage: getDateErrorMessage(['01', g2LicenceMonth, g2LicenceYear], driverState.inValidation), hintMessage: getHintMessage(mychoiceSdkComponents.DriverLicenceTypes.G2), error: driverState.inValidation, minDate: getMinDate(mychoiceSdkComponents.DriverLicenceTypes.G2), maxDate: getMaxDate(mychoiceSdkComponents.DriverLicenceTypes.G2) })), licenceType && (jsxRuntime.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 && (jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleTrainingChange, name: "passedDriverTraining", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, passedDriverTraining), title: `Has ${firstName || driverNameDefault} completed a driver education course within the last 3 years?` })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handlePreviousLicenceChange, name: "previousLicence", defaultValue: getSelectedOption(mychoiceSdkComponents.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)." })] }));
1162
1199
  };
1163
1200
 
1164
1201
  const SectionDriverInsurancePolicy = () => {
@@ -1167,18 +1204,14 @@ const SectionDriverInsurancePolicy = () => {
1167
1204
  const { driverState, dispatchDriverInsuranceState } = mychoiceSdkStore.useStoreFormCarDriverInsurance();
1168
1205
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
1169
1206
  const { quoteState: { isRequested }, } = mychoiceSdkStore.useStoreFormCarQuote();
1170
- const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth, }, } = driverState.items[driverState.activeIndex];
1207
+ const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth }, } = driverState.items[driverState.activeIndex];
1171
1208
  const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
1172
1209
  const driverNameDefault = `Driver ${driverState.activeIndex + 1}`;
1173
- const birthDate = birthYear && birthMonth && birthDay
1174
- ? `${birthYear}-${birthMonth}-${birthDay}`
1175
- : '';
1210
+ const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
1176
1211
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1177
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1212
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1178
1213
  const getPeriodOptions = (year, month) => {
1179
- const options = [
1180
- { value: '', name: 'Date Period', disabled: true },
1181
- ];
1214
+ const options = [{ value: '', name: 'Date Period', disabled: true }];
1182
1215
  if (year && month) {
1183
1216
  const todayDate = new Date();
1184
1217
  const month = String(todayDate.getMonth() + 1).padStart(2, '0');
@@ -1234,9 +1267,7 @@ you had insurance. If this is correct, please continue with the form.`);
1234
1267
  }
1235
1268
  };
1236
1269
  if (birthDate) {
1237
- const defaultMinDate = birthDate && firstLicenceAge
1238
- ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge)
1239
- : '';
1270
+ const defaultMinDate = birthDate && firstLicenceAge ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge) : '';
1240
1271
  const isOnlyG = mychoiceSdkComponents.checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
1241
1272
  if (isOnlyG) {
1242
1273
  setMessage(gLicenceYear, gLicenceMonth);
@@ -1255,16 +1286,7 @@ you had insurance. If this is correct, please continue with the form.`);
1255
1286
  else {
1256
1287
  setHintMessage('');
1257
1288
  }
1258
- }, [
1259
- listedYear,
1260
- listedMonth,
1261
- g1LicenceYear,
1262
- g1LicenceMonth,
1263
- firstLicenceAge,
1264
- birthDate,
1265
- gLicenceYear,
1266
- gLicenceMonth,
1267
- ]);
1289
+ }, [listedYear, listedMonth, g1LicenceYear, g1LicenceMonth, firstLicenceAge, birthDate, gLicenceYear, gLicenceMonth]);
1268
1290
  const handleInsuredChange = ({ value }) => {
1269
1291
  dispatchDriverInsuranceState({
1270
1292
  type: mychoiceSdkStore.StoreFormCarDriverInsuranceActionTypes.FormCarDriverInsuredSelect,
@@ -1319,18 +1341,16 @@ you had insurance. If this is correct, please continue with the form.`);
1319
1341
  };
1320
1342
  return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsxs("div", { className: "box-container", children: [jsxRuntime.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
1321
1343
  ? getDateErrorMessage(['01', listedMonth, listedYear], driverState.inValidation)
1322
- : '', error: driverState.inValidation, hintMessage: hintMessage, minDate: mychoiceSdkComponents.getMinDate(birthDate, firstLicenceAge) }), jsxRuntime.jsx(mychoiceSdkComponents.CheckboxForm, { name: "listed", label: "Never listed on an insurance policy", onChange: handleListedChange, defaultValue: !listed })] }), listed && (jsxRuntime.jsxs("div", { className: "box-container", children: [jsxRuntime.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
1323
- ? getErrorMessage(insuredDate, driverState.inValidation)
1324
- : '', error: !insuredDate && driverState.inValidation }), jsxRuntime.jsx(mychoiceSdkComponents.CheckboxForm, { name: "insured", label: "Not currently insured", onChange: handleInsuredChange, defaultValue: !insured })] })), jsxRuntime.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: mychoiceSdkComponents.addDaysToDate('', 1), maxDate: mychoiceSdkComponents.addDaysToDate('', 60), isDay: true })] }));
1344
+ : '', error: driverState.inValidation, hintMessage: hintMessage, minDate: mychoiceSdkComponents.getMinDate(birthDate, firstLicenceAge) }), jsxRuntime.jsx(mychoiceSdkComponents.CheckboxForm, { name: "listed", label: "Never listed on an insurance policy", onChange: handleListedChange, defaultValue: !listed })] }), listed && (jsxRuntime.jsxs("div", { className: "box-container", children: [jsxRuntime.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 }), jsxRuntime.jsx(mychoiceSdkComponents.CheckboxForm, { name: "insured", label: "Not currently insured", onChange: handleInsuredChange, defaultValue: !insured })] })), jsxRuntime.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: mychoiceSdkComponents.addDaysToDate('', 1), maxDate: mychoiceSdkComponents.addDaysToDate('', 60), isDay: true })] }));
1325
1345
  };
1326
1346
 
1327
1347
  const SectionDriverCancellation = () => {
1328
1348
  const { driverState, dispatchDriverCancellationState } = mychoiceSdkStore.useStoreFormCarDriverCancellation();
1329
1349
  const { dispatchDriverBaseState } = mychoiceSdkStore.useStoreFormCarDriverBase();
1330
1350
  const { insuranceCancellation, insuranceCancellationList = [] } = driverState.items[driverState.activeIndex];
1331
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1351
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1332
1352
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1333
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1353
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1334
1354
  const { firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge }, } = driverState.items[driverState.activeIndex];
1335
1355
  const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
1336
1356
  const handleIconClick = (index) => () => {
@@ -1406,7 +1426,7 @@ const SectionDriverCancellation = () => {
1406
1426
  }
1407
1427
  };
1408
1428
  return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Insurance Cancellation" }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, insuranceCancellation), title: `Has ${firstName} had an insurance company cancellation or
1409
- 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 && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceCancellationList?.map(({ cancellationReason, startYear, startMonth, endYear, endMonth, }, index) => {
1429
+ 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 && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceCancellationList?.map(({ cancellationReason, startYear, startMonth, endYear, endMonth }, index) => {
1410
1430
  const defaultStartDate = {
1411
1431
  year: startYear,
1412
1432
  month: startMonth,
@@ -1416,12 +1436,11 @@ const SectionDriverCancellation = () => {
1416
1436
  month: endMonth,
1417
1437
  };
1418
1438
  const now = mychoiceSdkComponents.getFormattedDate('', 'yyyy-MM-dd');
1419
- const days = birthDay ? (+birthDay + 1) : 1;
1439
+ const days = birthDay ? +birthDay + 1 : 1;
1420
1440
  const endDate = endYear && endMonth ? mychoiceSdkStore.addDayToDate(`${endYear}-${endMonth}`, days) : now;
1421
1441
  const currentMinDate = mychoiceSdkComponents.getMinDateByYears(mychoiceSdkComponents.getMinDate(birthDate, firstLicenceAge), 3);
1422
1442
  const currentEndDate = mychoiceSdkComponents.compareDates(endDate, currentMinDate) < 0 ? currentMinDate : endDate;
1423
- return (jsxRuntime.jsxs("div", { className: "list-block", children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsxs("div", { className: "list-item", children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.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) }), jsxRuntime.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 }), jsxRuntime.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
1424
- ? mychoiceSdkStore.addDayToDate(`${startYear}-${startMonth}`, days) : currentMinDate })] })] }, `insurance-cancellation-${index}`));
1443
+ return (jsxRuntime.jsxs("div", { className: "list-block", children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsxs("div", { className: "list-item", children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.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) }), jsxRuntime.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 }), jsxRuntime.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 ? mychoiceSdkStore.addDayToDate(`${startYear}-${startMonth}`, days) : currentMinDate })] })] }, `insurance-cancellation-${index}`));
1425
1444
  }), insuranceCancellationList?.length < 3 && (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleAddButtonClick, size: mychoiceSdkComponents.SizeTypes.Medium, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Add another" }))] }))] }));
1426
1445
  };
1427
1446
 
@@ -1677,8 +1696,8 @@ const BlockDriverTicket = () => {
1677
1696
  };
1678
1697
 
1679
1698
  const SectionDriverHistory = () => {
1680
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1681
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1699
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1700
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1682
1701
  return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx(BlockDriverSuspension, {}), jsxRuntime.jsx(BlockDriverAccident, {}), jsxRuntime.jsx(BlockDriverTicket, {})] }));
1683
1702
  };
1684
1703
 
@@ -1717,7 +1736,7 @@ const PageDriver = () => {
1717
1736
  React.useEffect(() => {
1718
1737
  setIsRender(true);
1719
1738
  }, [isRender]);
1720
- return (jsxRuntime.jsxs("div", { className: "form-container", children: [jsxRuntime.jsx(TabDriver, { createItem: createDriver }), jsxRuntime.jsxs("div", { className: "form-section-container", children: [isRender && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(SectionDriverInfo, {}), jsxRuntime.jsx(SectionDriverLicence, {}), jsxRuntime.jsx(SectionDriverInsurancePolicy, {}), jsxRuntime.jsx(SectionDriverCancellation, {}), jsxRuntime.jsx(SectionDriverHistory, {}), appType === mychoiceSdkComponents.AppTypes.MyChoice && jsxRuntime.jsx(HonestyMessage, {})] })), appType === mychoiceSdkComponents.AppTypes.TheBig ? (jsxRuntime.jsx(NavigationBottomTheBig, { createItem: createDriver, formSteps: formSteps[mychoiceSdkComponents.InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid })) : (jsxRuntime.jsx(NavigationBottom, { className: "mychoice", createItem: createDriver, formSteps: formSteps[mychoiceSdkComponents.InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid }))] }), localIndex !== mychoiceSdkComponents.defaultLocalIndex && (jsxRuntime.jsx("img", { className: "logo-for-partner", src: myChoicePartnerLogo, alt: "partner logo" }))] }));
1739
+ return (jsxRuntime.jsxs("div", { className: "form-container", children: [jsxRuntime.jsx(TabDriver, { createItem: createDriver }), jsxRuntime.jsxs("div", { className: "form-section-container", children: [isRender && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(SectionDriverInfo, {}), jsxRuntime.jsx(SectionDriverLicence, {}), jsxRuntime.jsx(SectionDriverInsurancePolicy, {}), jsxRuntime.jsx(SectionDriverCancellation, {}), jsxRuntime.jsx(SectionDriverHistory, {}), mychoiceSdkComponents.isMyChoiceLike(appType) && jsxRuntime.jsx(HonestyMessage, {})] })), appType === mychoiceSdkComponents.AppTypes.TheBig ? (jsxRuntime.jsx(NavigationBottomTheBig, { createItem: createDriver, formSteps: formSteps[mychoiceSdkComponents.InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid })) : (jsxRuntime.jsx(NavigationBottom, { className: "mychoice", createItem: createDriver, formSteps: formSteps[mychoiceSdkComponents.InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid }))] }), localIndex !== mychoiceSdkComponents.defaultLocalIndex && (jsxRuntime.jsx("img", { className: "logo-for-partner", src: myChoicePartnerLogo, alt: "partner logo" }))] }));
1721
1740
  };
1722
1741
 
1723
1742
  const getDynamicLicenceBoxProps = ({ isAlbertaProvince, isOntarioProvince, isNewfoundlandProvince, isNovaScotiaProvince, isNewBrunswickProvince, }) => {
@@ -1767,11 +1786,11 @@ const SectionDiscountInfo$1 = () => {
1767
1786
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1768
1787
  const allProvinces = mychoiceSdkStore.useProvince();
1769
1788
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1770
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1789
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1771
1790
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
1772
1791
  const { validateEmail, errorMessage } = mychoiceSdkStore.useHandlerCarQuoterEmail();
1773
1792
  const { multiplePoliciesDiscount, appInstallDiscount, caaMemberDiscount, quoterInfo, emailTo: { email, emailStatus }, } = discountState;
1774
- const { firstName, lastName, phone, driverLicense = '', caslConsent, } = quoterInfo;
1793
+ const { firstName, lastName, phone, driverLicense = '', caslConsent } = quoterInfo;
1775
1794
  const handleMultiplePolicyChange = ({ value }) => {
1776
1795
  dispatchDiscountState({
1777
1796
  type: mychoiceSdkStore.StoreFormCarDiscountActionTypes.FormCarDiscountMultiplePoliciesSelect,
@@ -1825,8 +1844,7 @@ const SectionDiscountInfo$1 = () => {
1825
1844
  };
1826
1845
  return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [isTheBig ? (jsxRuntime.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!" })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), jsxRuntime.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!" })] })), jsxRuntime.jsx(BlockVehLinks, {}), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(mychoiceSdkComponents.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 && (jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleCaaMemberChange, name: "caaMemberDiscount", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, caaMemberDiscount), title: "Please indicate if you are a member of CAA, you could save up to an additional 20%." })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleAppInstallChange, name: "appInstallDiscount", defaultValue: getSelectedOption(mychoiceSdkComponents.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 ? (jsxRuntime.jsxs("div", { className: "input-form-box-container", children: [jsxRuntime.jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxRuntime.jsxs("ol", { className: "ordered-block", children: [jsxRuntime.jsx("li", { children: "See what rates insurance carriers are offering" }), jsxRuntime.jsx("li", { children: "Get in touch with us and secure your rate" }), jsxRuntime.jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })) : (jsxRuntime.jsx("h2", { children: "Complete the form below to see which companies are offering your quotes." })), jsxRuntime.jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsxRuntime.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 && (jsxRuntime.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." })), jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsxRuntime.jsx(InputFormEmailBox, { validationStatus: emailStatus, errorMessage: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined
1827
1846
  ? errorMessage
1828
- : getErrorMessage(email, discountState.inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined ||
1829
- (!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 && (jsxRuntime.jsx(mychoiceSdkComponents.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 })), jsxRuntime.jsx(BlockSubmit$2, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsxRuntime.jsx(BlockNextPageInfo$2, {})] }));
1847
+ : getErrorMessage(email, discountState.inValidation), error: emailStatus === mychoiceSdkComponents.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: mychoiceSdkComponents.getPlaceholderEmail(appType) }), isTheBig && (jsxRuntime.jsx(mychoiceSdkComponents.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 })), jsxRuntime.jsx(BlockSubmit$2, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsxRuntime.jsx(BlockNextPageInfo$2, {})] }));
1830
1848
  };
1831
1849
 
1832
1850
  const PageCarDiscount = () => {
@@ -1851,10 +1869,10 @@ const SectionQuoteEdit$2 = () => {
1851
1869
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
1852
1870
  const { driverState, dispatchDriverBaseState } = mychoiceSdkStore.useStoreFormCarDriverBase();
1853
1871
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
1854
- const { discountState: { appInstallDiscount, multiplePoliciesDiscount } } = mychoiceSdkStore.useStoreFormCarDiscount();
1855
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1872
+ const { discountState: { appInstallDiscount, multiplePoliciesDiscount }, } = mychoiceSdkStore.useStoreFormCarDiscount();
1873
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1856
1874
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1857
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1875
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1858
1876
  const navigate = reactRouterDom.useNavigate();
1859
1877
  const vehicles = vehicleState.items.map(({ year, make, model }) => [`${year} ${make} ${model}`]);
1860
1878
  const drivers = driverState.items.map(({ firstName }) => [`${firstName}`]);
@@ -1919,7 +1937,7 @@ const BlockMCEndorsements = () => {
1919
1937
  const SectionQuoteRecalc$1 = () => {
1920
1938
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1921
1939
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1922
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1940
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1923
1941
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
1924
1942
  const { comprehensive, collision, liability } = vehicleState.items[vehicleState.activeIndex];
1925
1943
  const handleComprehensiveChange = ({ value }) => {
@@ -2080,7 +2098,7 @@ const SectionAddress = () => {
2080
2098
  const { streetAddress = '', postalCode = '', addressObject, errorMessage } = item;
2081
2099
  const navigate = reactRouterDom.useNavigate();
2082
2100
  const asyncSelectRef = React.useRef(null);
2083
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
2101
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
2084
2102
  const mychoiceCls = isMychoice ? 'mychoice' : '';
2085
2103
  const handleAddressChange = (address) => {
2086
2104
  dispatchPostalState({
@@ -2318,9 +2336,9 @@ const SectionApplicantInfo = () => {
2318
2336
  const { applicantState, dispatchApplicantInfoState } = mychoiceSdkStore.useStoreFormHomeApplicantInfo();
2319
2337
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2320
2338
  const { dwellingState, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
2321
- const { firstName, insured: { birthDay, birthMonth, birthYear, }, } = applicantState;
2322
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2323
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2339
+ const { firstName, insured: { birthDay, birthMonth, birthYear }, } = applicantState;
2340
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2341
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2324
2342
  const { familiesCount, occupiedYear } = dwellingState;
2325
2343
  // VARIABLES =========
2326
2344
  const birthDate = birthYear ? `${birthYear}-${birthMonth || '01'}-${birthDay || '01'}` : '';
@@ -2401,9 +2419,9 @@ const SectionApplicantInsurancePolicy = () => {
2401
2419
  const { applicantState, dispatchApplicantInsuranceState } = mychoiceSdkStore.useStoreFormHomeApplicantInsurance();
2402
2420
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2403
2421
  const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
2404
- const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince } } = applicantState;
2405
- const { appConfigState: { appType, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
2406
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2422
+ const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince }, } = applicantState;
2423
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2424
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2407
2425
  const defaultPolicyStartDate = {
2408
2426
  year: policyStartYear,
2409
2427
  month: policyStartMonth,
@@ -2453,19 +2471,17 @@ const SectionApplicantInsurancePolicy = () => {
2453
2471
  payload: { dateInsuredCurrent: value },
2454
2472
  });
2455
2473
  };
2456
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.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: mychoiceSdkComponents.addDaysToDate('', 1), maxDate: mychoiceSdkComponents.addDaysToDate('', 60), isDay: true }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleInsuredCurrentChange, name: "insuredCurrent", defaultValue: getSelectedOption(mychoiceSdkComponents.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
2457
- && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.insuredYearsOptions, name: "dateInsuredSince", onChange: handleInsuredSinceDateChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.getInsuranceYearsOptions(dateInsuredSince || mychoiceSdkComponents.insuredYearsOptions.length.toString()), name: "dateInsuredCurrent", onChange: handleInsuredCurrentDateChange, defaultValue: getSelectedOption(mychoiceSdkComponents.getInsuranceYearsOptions(dateInsuredSince || mychoiceSdkComponents.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)
2458
- && (jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleInsuredBeforeChange, name: "insuredBefore", defaultValue: getSelectedOption(mychoiceSdkComponents.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) }))] }));
2474
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.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: mychoiceSdkComponents.addDaysToDate('', 1), maxDate: mychoiceSdkComponents.addDaysToDate('', 60), isDay: true }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleInsuredCurrentChange, name: "insuredCurrent", defaultValue: getSelectedOption(mychoiceSdkComponents.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 && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.insuredYearsOptions, name: "dateInsuredSince", onChange: handleInsuredSinceDateChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.getInsuranceYearsOptions(dateInsuredSince || mychoiceSdkComponents.insuredYearsOptions.length.toString()), name: "dateInsuredCurrent", onChange: handleInsuredCurrentDateChange, defaultValue: getSelectedOption(mychoiceSdkComponents.getInsuranceYearsOptions(dateInsuredSince || mychoiceSdkComponents.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 && (jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleInsuredBeforeChange, name: "insuredBefore", defaultValue: getSelectedOption(mychoiceSdkComponents.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) }))] }));
2459
2475
  };
2460
2476
 
2461
2477
  const SectionApplicantCancellation = () => {
2462
2478
  const { applicantState, dispatchApplicantCancellationState } = mychoiceSdkStore.useStoreFormHomeApplicantCancellation();
2463
2479
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2464
2480
  const { insuranceCancellation, insuranceCancellationList } = applicantState;
2465
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2481
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2466
2482
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2467
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2468
- const { insured: { birthYear, birthMonth, birthDay } } = applicantState;
2483
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2484
+ const { insured: { birthYear, birthMonth, birthDay }, } = applicantState;
2469
2485
  const handleIconClick = (index) => () => {
2470
2486
  dispatchApplicantCancellationState({
2471
2487
  type: mychoiceSdkStore.StoreFormHomeApplicantCancellationActionTypes.FormHomeApplicantCancellationDelete,
@@ -2509,24 +2525,23 @@ const SectionApplicantCancellation = () => {
2509
2525
  });
2510
2526
  }
2511
2527
  };
2512
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Cancellations" }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, insuranceCancellation), title: "Have you ever had a cancelation due to non payment?" }), insuranceCancellation && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceCancellationList?.map(({ cancellationYear, cancellationMonth, }, index) => {
2528
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Cancellations" }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleCancellationChange, name: "insuranceCancellation", defaultValue: getSelectedOption(mychoiceSdkComponents.yesNoOptions, insuranceCancellation), title: "Have you ever had a cancelation due to non payment?" }), insuranceCancellation && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceCancellationList?.map(({ cancellationYear, cancellationMonth }, index) => {
2513
2529
  const defaultCancellationDate = {
2514
2530
  year: cancellationYear,
2515
2531
  month: cancellationMonth,
2516
2532
  day: '01',
2517
2533
  };
2518
2534
  return (jsxRuntime.jsxs("div", { className: "list-block", children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsx("div", { className: "list-item", children: jsxRuntime.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}`));
2519
- }), insuranceCancellationList && insuranceCancellationList.length < 3
2520
- ? (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleAddButtonClick, size: mychoiceSdkComponents.SizeTypes.Medium, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Add another" })) : (jsxRuntime.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." }))] }))] }));
2535
+ }), insuranceCancellationList && insuranceCancellationList.length < 3 ? (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleAddButtonClick, size: mychoiceSdkComponents.SizeTypes.Medium, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Add another" })) : (jsxRuntime.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." }))] }))] }));
2521
2536
  };
2522
2537
 
2523
2538
  const SectionApplicantClaim = () => {
2524
2539
  const { applicantState, dispatchApplicantClaimState } = mychoiceSdkStore.useStoreFormHomeApplicantClaim();
2525
2540
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2526
2541
  const { insuranceClaim, insuranceClaimList } = applicantState;
2527
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2542
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2528
2543
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2529
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2544
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2530
2545
  const handleIconClick = (index) => () => {
2531
2546
  dispatchApplicantClaimState({
2532
2547
  type: mychoiceSdkStore.StoreFormHomeApplicantClaimActionTypes.FormHomeApplicantClaimDelete,
@@ -2579,15 +2594,14 @@ const SectionApplicantClaim = () => {
2579
2594
  });
2580
2595
  }
2581
2596
  };
2582
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Claims" }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleClaimChange, name: "insuranceClaim", defaultValue: getSelectedOption(mychoiceSdkComponents.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 && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceClaimList?.map(({ claimYear, claimMonth, claimType, }, index) => {
2597
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: isTheBig ? 'thebig-bold' : '', children: "Claims" }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleClaimChange, name: "insuranceClaim", defaultValue: getSelectedOption(mychoiceSdkComponents.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 && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [insuranceClaimList?.map(({ claimYear, claimMonth, claimType }, index) => {
2583
2598
  const defaultClaimDate = {
2584
2599
  year: claimYear,
2585
2600
  month: claimMonth,
2586
2601
  day: '01',
2587
2602
  };
2588
2603
  return (jsxRuntime.jsxs("div", { className: "list-block", children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsxs("div", { className: "list-item", children: [jsxRuntime.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: mychoiceSdkComponents.subYearsFromDate('', 5) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.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}`));
2589
- }), insuranceClaimList && insuranceClaimList.length < 3
2590
- ? (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleAddButtonClick, size: mychoiceSdkComponents.SizeTypes.Medium, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Add another" })) : (jsxRuntime.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." }))] }))] }));
2604
+ }), insuranceClaimList && insuranceClaimList.length < 3 ? (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleAddButtonClick, size: mychoiceSdkComponents.SizeTypes.Medium, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Add another" })) : (jsxRuntime.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." }))] }))] }));
2591
2605
  };
2592
2606
 
2593
2607
  const PageApplicant = () => {
@@ -2843,9 +2857,14 @@ const BlockDwellingInfo = () => {
2843
2857
  };
2844
2858
 
2845
2859
  const BlockNextPageInfo$1 = () => {
2846
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2847
- const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2848
- return (jsxRuntime.jsx("div", { className: "next-page-info", children: isTheBig ? (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.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."] }) })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsxs("div", { className: "next-page-points", children: [jsxRuntime.jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsxRuntime.jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsxRuntime.jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.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", jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] })) }));
2860
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2861
+ if (appType === mychoiceSdkComponents.AppTypes.TheBig) {
2862
+ return (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.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."] }) }));
2863
+ }
2864
+ if (appType === mychoiceSdkComponents.AppTypes.MyChoice) {
2865
+ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsxs("div", { className: "next-page-points", children: [jsxRuntime.jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsxRuntime.jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsxRuntime.jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.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", jsxRuntime.jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] });
2866
+ }
2867
+ return null;
2849
2868
  };
2850
2869
 
2851
2870
  const BlockSubmit$1 = ({ className, label, buttonSize, isRecalc = false, }) => {
@@ -2875,14 +2894,14 @@ BlockSubmit$1.defaultProps = {
2875
2894
  };
2876
2895
 
2877
2896
  const SectionDiscountInfo = () => {
2878
- const { appConfigState: { appType, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
2897
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2879
2898
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2880
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2899
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2881
2900
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2882
2901
  // const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
2883
2902
  const { validateEmail, errorMessage } = mychoiceSdkStore.useHandlerHomeQuoterEmail();
2884
2903
  const { multiplePoliciesDiscount, emailTo: { email, emailStatus }, quoterInfo = {}, } = discountState;
2885
- const { firstName = '', lastName = '', phone = '', caslConsent, } = quoterInfo;
2904
+ const { firstName = '', lastName = '', phone = '', caslConsent } = quoterInfo;
2886
2905
  const handleMultiplePolicyChange = ({ value }) => {
2887
2906
  dispatchDiscountState({
2888
2907
  type: mychoiceSdkStore.StoreFormHomeDiscountActionTypes.FormHomeDiscountMultiplePoliciesSelect,
@@ -2916,13 +2935,11 @@ const SectionDiscountInfo = () => {
2916
2935
  payload: { caslConsent: value },
2917
2936
  });
2918
2937
  };
2919
- return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), isTheBig
2920
- ? (jsxRuntime.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!` }))
2921
- : (jsxRuntime.jsx("span", { className: "info-title-message", children: `You are seconds away from receiving your ${insuranceType} insurance quotes,
2938
+ return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h2", { className: "section-title", children: "A little extra info for discounts and connecting you with our partners." }), isTheBig ? (jsxRuntime.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!` })) : (jsxRuntime.jsx("span", { className: "info-title-message", children: `You are seconds away from receiving your ${insuranceType} insurance quotes,
2922
2939
  please provide your email after completing the discount section so we
2923
- can send you your personalized free ${insuranceType} insurance quotes!` })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(mychoiceSdkComponents.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." }), jsxRuntime.jsx(BlockDwellingInfo, {}), jsxRuntime.jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsxRuntime.jsx(InputFormBox, { name: "lastName", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && discountState.inValidation, errorMessage: getErrorMessage(lastName, discountState.inValidation) }), jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsxRuntime.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 === mychoiceSdkComponents.ValidationStatusTypes.Declined
2924
- ? errorMessage : getErrorMessage(email, discountState.inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined || (!email && discountState.inValidation) }), isTheBig
2925
- && (jsxRuntime.jsx(mychoiceSdkComponents.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 })), jsxRuntime.jsx(BlockSubmit$1, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsxRuntime.jsx(BlockNextPageInfo$1, {})] }));
2940
+ can send you your personalized free ${insuranceType} insurance quotes!` })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleMultiplePolicyChange, name: "multiplePoliciesDiscount", defaultValue: getSelectedOption(mychoiceSdkComponents.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." }), jsxRuntime.jsx(BlockDwellingInfo, {}), jsxRuntime.jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && discountState.inValidation, errorMessage: getErrorMessage(firstName, discountState.inValidation) }), jsxRuntime.jsx(InputFormBox, { name: "lastName", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && discountState.inValidation, errorMessage: getErrorMessage(lastName, discountState.inValidation) }), jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }), jsxRuntime.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: mychoiceSdkComponents.getPlaceholderEmail(appType), errorMessage: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined
2941
+ ? errorMessage
2942
+ : getErrorMessage(email, discountState.inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined || (!email && discountState.inValidation) }), isTheBig && (jsxRuntime.jsx(mychoiceSdkComponents.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 })), jsxRuntime.jsx(BlockSubmit$1, { className: isTheBig ? 'thebig-bold' : 'mychoice' }), jsxRuntime.jsx(BlockNextPageInfo$1, {})] }));
2926
2943
  };
2927
2944
 
2928
2945
  const PageHomeDiscount = () => {
@@ -2945,18 +2962,18 @@ const PageHomeDiscount = () => {
2945
2962
  };
2946
2963
 
2947
2964
  const SectionQuoteEdit$1 = () => {
2948
- const { appConfigState: { localIndex, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
2965
+ const { appConfigState: { localIndex, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2949
2966
  const { applicantState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2950
2967
  const { dwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
2951
2968
  const { postalState } = mychoiceSdkStore.useStoreFormHomePostal();
2952
- const { discountState: { multiplePoliciesDiscount, quoterInfo } } = mychoiceSdkStore.useStoreFormHomeDiscount();
2953
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2969
+ const { discountState: { multiplePoliciesDiscount, quoterInfo }, } = mychoiceSdkStore.useStoreFormHomeDiscount();
2970
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2954
2971
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2955
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2956
- const { item: { postalCode, provinceCode, city, streetAddress, }, } = postalState;
2972
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2973
+ const { item: { postalCode, provinceCode, city, streetAddress }, } = postalState;
2957
2974
  const { deadbolt, sprinkler, burglarAlarm, fireAlarm, fireExtinguishersCount, // mortgagesCount,
2958
2975
  } = dwellingState;
2959
- const { insured: { nonsmoker } } = applicantState;
2976
+ const { insured: { nonsmoker }, } = applicantState;
2960
2977
  const discounts = [];
2961
2978
  const isHome = insuranceType === mychoiceSdkComponents.InsuranceTypes.Home;
2962
2979
  if (multiplePoliciesDiscount) {
@@ -3001,17 +3018,23 @@ const SectionQuoteEdit$1 = () => {
3001
3018
  const discountEdit = () => () => {
3002
3019
  navigate(`/${localIndex || mychoiceSdkComponents.defaultLocalIndex}/${insuranceType}/discount`);
3003
3020
  };
3004
- return (jsxRuntime.jsxs("div", { className: `edit-quote-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Edit Quote" }), jsxRuntime.jsxs("div", { className: "edit-section-content", children: [jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: addressEdit, title: "Address", items: [[address]] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: dwellingEdit, title: "Property Information", items: [[`Year Built: ${dwellingState.builtYear}`]] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: applicantEdit, title: "Applicant Information", items: [[`Name: ${quoterInfo?.firstName}`, `Occupied by: ${occupiedMembers}`, `Year Occupied: ${dwellingState.occupiedYear}`]] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: discountEdit, title: "Discount Information", items: [discounts] })] })] }));
3021
+ return (jsxRuntime.jsxs("div", { className: `edit-quote-section ${mychoiceCls}`, children: [jsxRuntime.jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Edit Quote" }), jsxRuntime.jsxs("div", { className: "edit-section-content", children: [jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: addressEdit, title: "Address", items: [[address]] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: dwellingEdit, title: "Property Information", items: [[`Year Built: ${dwellingState.builtYear}`]] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: applicantEdit, title: "Applicant Information", items: [
3022
+ [
3023
+ `Name: ${quoterInfo?.firstName}`,
3024
+ `Occupied by: ${occupiedMembers}`,
3025
+ `Year Occupied: ${dwellingState.occupiedYear}`,
3026
+ ],
3027
+ ] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: discountEdit, title: "Discount Information", items: [discounts] })] })] }));
3005
3028
  };
3006
3029
 
3007
3030
  // import { BlockEndorsements } from './blocks/BlockEndorsements';
3008
3031
  const SectionQuoteRecalc = () => {
3009
3032
  const [ppLocalOptions, setPpLocalOptions] = React.useState(mychoiceSdkComponents.ppOptions);
3010
- const { appConfigState: { appType, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
3033
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
3011
3034
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
3012
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
3035
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
3013
3036
  const { dwellingState, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
3014
- const { deductible, liability, waterCoverage, pp, } = dwellingState;
3037
+ const { deductible, liability, waterCoverage, pp } = dwellingState;
3015
3038
  React.useEffect(() => {
3016
3039
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo) {
3017
3040
  setPpLocalOptions(mychoiceSdkComponents.ppOptions.slice(1));
@@ -3044,9 +3067,7 @@ const SectionQuoteRecalc = () => {
3044
3067
  payload: { waterCoverage: value },
3045
3068
  });
3046
3069
  };
3047
- return (jsxRuntime.jsx("div", { className: "form-container", children: jsxRuntime.jsxs("div", { className: `form-section edit-recalc-container ${mychoiceCls}`, children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.homeCoverageOptions, name: "deductible", onChange: handleDeductibleChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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 }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.homeLiabilityOptions, name: "liability", onChange: handleLiabilityChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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 === mychoiceSdkComponents.InsuranceTypes.Home) && (jsxRuntime.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 })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleWaterCoverageChange, name: "waterCoverage", defaultValue: getSelectedOption(mychoiceSdkComponents.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." }), jsxRuntime.jsx(BlockSubmit$1, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} recalculate`, label: "Recalculate Quote", buttonSize: mychoiceSdkComponents.SizeTypes.Medium, isRecalc: true }), jsxRuntime.jsx("div", { className: "endorsements-container", children: jsxRuntime.jsxs("div", { className: "labels-block", children: [!(insuranceType === mychoiceSdkComponents.InsuranceTypes.Home)
3048
- ? (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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 === mychoiceSdkComponents.InsuranceTypes.Condo
3049
- && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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 }), jsxRuntime.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 }), jsxRuntime.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 }), jsxRuntime.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 })] }))] })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(LabelFormBox, { name: "outbuildings", title: "Outbuildings", isActive: true }), jsxRuntime.jsx(LabelFormBox, { name: "contents", title: "Contents", isActive: true })] })), jsxRuntime.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 }), jsxRuntime.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 })] }) })] }) }));
3070
+ return (jsxRuntime.jsx("div", { className: "form-container", children: jsxRuntime.jsxs("div", { className: `form-section edit-recalc-container ${mychoiceCls}`, children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.homeCoverageOptions, name: "deductible", onChange: handleDeductibleChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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 }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.homeLiabilityOptions, name: "liability", onChange: handleLiabilityChange, defaultValue: getSelectedOption(mychoiceSdkComponents.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 === mychoiceSdkComponents.InsuranceTypes.Home) && (jsxRuntime.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 })), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.yesNoOptions, onChange: handleWaterCoverageChange, name: "waterCoverage", defaultValue: getSelectedOption(mychoiceSdkComponents.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." }), jsxRuntime.jsx(BlockSubmit$1, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} recalculate`, label: "Recalculate Quote", buttonSize: mychoiceSdkComponents.SizeTypes.Medium, isRecalc: true }), jsxRuntime.jsx("div", { className: "endorsements-container", children: jsxRuntime.jsxs("div", { className: "labels-block", children: [!(insuranceType === mychoiceSdkComponents.InsuranceTypes.Home) ? (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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 === mychoiceSdkComponents.InsuranceTypes.Condo && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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 }), jsxRuntime.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 }), jsxRuntime.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 }), jsxRuntime.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 })] }))] })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(LabelFormBox, { name: "outbuildings", title: "Outbuildings", isActive: true }), jsxRuntime.jsx(LabelFormBox, { name: "contents", title: "Contents", isActive: true })] })), jsxRuntime.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 }), jsxRuntime.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 })] }) })] }) }));
3050
3071
  };
3051
3072
 
3052
3073
  const SplashScreen$1 = () => {
@@ -3116,7 +3137,7 @@ const Description = () => (jsxRuntime.jsxs("div", { children: [jsxRuntime.jsx("s
3116
3137
  const SectionCoverage = () => {
3117
3138
  const { coverageState: { type, coverage, province, inValidation }, dispatchCoverageState, } = mychoiceSdkStore.useStoreFormLifeCoverage();
3118
3139
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3119
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
3140
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
3120
3141
  // const handleProvinceChange = ({ value }: OnChangeEventInterface) => {
3121
3142
  // dispatchCoverageState({
3122
3143
  // type: StoreFormLifeCoverageActionTypes.FormLifeProvinceSelect,
@@ -3299,10 +3320,9 @@ const SectionApplicant = () => {
3299
3320
  textAlign: 'center',
3300
3321
  fontSize: '1.15rem',
3301
3322
  marginTop: '10px',
3302
- }, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsxRuntime.jsx("h2", { className: "section-title", style: { textAlign: 'center' }, children: `${lockEmoji} Complete the form below to see which companies are offering your quotes.` }), jsxRuntime.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!" }), jsxRuntime.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: mychoiceSdkComponents.subYearsFromDate('', 14), isDay: true }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.genderOptions, name: "gender", onChange: handleGenderChange, defaultValue: getSelectedOption(mychoiceSdkComponents.genderOptions, gender), title: "Gender", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !gender && inValidation, errorMessage: getErrorMessage(`${gender}`.toString(), inValidation) }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.smokerOptions, onChange: handleSmokerChange, name: "smoker", defaultValue: getSelectedOption(mychoiceSdkComponents.smokerOptions, smoker), title: "Smoker" }), isTheBig && (jsxRuntime.jsxs("div", { className: "input-form-box-container", children: [jsxRuntime.jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxRuntime.jsxs("ol", { className: "ordered-block", children: [jsxRuntime.jsx("li", { children: "See what rates insurance carriers are offering" }), jsxRuntime.jsx("li", { children: "Get in touch with us and secure your rate" }), jsxRuntime.jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })), jsxRuntime.jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && inValidation, errorMessage: getErrorMessage(firstName, inValidation) }), jsxRuntime.jsx(InputFormBox, { name: "lastname", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && inValidation, errorMessage: getErrorMessage(lastName, inValidation) }), jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && inValidation, errorMessage: getErrorMessage(phone, inValidation) }), jsxRuntime.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 === mychoiceSdkComponents.ValidationStatusTypes.Declined
3323
+ }, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsxRuntime.jsx("h2", { className: "section-title", style: { textAlign: 'center' }, children: `${lockEmoji} Complete the form below to see which companies are offering your quotes.` }), jsxRuntime.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!" }), jsxRuntime.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: mychoiceSdkComponents.subYearsFromDate('', 14), isDay: true }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.genderOptions, name: "gender", onChange: handleGenderChange, defaultValue: getSelectedOption(mychoiceSdkComponents.genderOptions, gender), title: "Gender", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !gender && inValidation, errorMessage: getErrorMessage(`${gender}`.toString(), inValidation) }), jsxRuntime.jsx(SwitchButtonBox, { items: mychoiceSdkComponents.smokerOptions, onChange: handleSmokerChange, name: "smoker", defaultValue: getSelectedOption(mychoiceSdkComponents.smokerOptions, smoker), title: "Smoker" }), isTheBig && (jsxRuntime.jsxs("div", { className: "input-form-box-container", children: [jsxRuntime.jsx(LabelFormBox, { title: "Complete this form to see all your personalized\n quotes on the next page, you will also be able to:" }), jsxRuntime.jsxs("ol", { className: "ordered-block", children: [jsxRuntime.jsx("li", { children: "See what rates insurance carriers are offering" }), jsxRuntime.jsx("li", { children: "Get in touch with us and secure your rate" }), jsxRuntime.jsx("li", { children: "Potentially save more by speaking with a broker" })] })] })), jsxRuntime.jsx(InputFormBox, { name: "firstName", title: "First Name", onChange: handleFirstNameChange, defaultValue: firstName, placeholder: "Your First Name", error: !firstName && inValidation, errorMessage: getErrorMessage(firstName, inValidation) }), jsxRuntime.jsx(InputFormBox, { name: "lastname", title: "Last Name", onChange: handleLastNameChange, defaultValue: lastName, placeholder: "Your Last Name", error: !lastName && inValidation, errorMessage: getErrorMessage(lastName, inValidation) }), jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(855) 325-8444", error: !phone && inValidation, errorMessage: getErrorMessage(phone, inValidation) }), jsxRuntime.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: mychoiceSdkComponents.getPlaceholderEmail(appType), errorMessage: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined
3303
3324
  ? errorMessage
3304
- : getErrorMessage(email, inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined ||
3305
- (!email && inValidation) }), jsxRuntime.jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsxRuntime.jsx(BlockNextPageInfo, {})] }));
3325
+ : getErrorMessage(email, inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined || (!email && inValidation) }), jsxRuntime.jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsxRuntime.jsx(BlockNextPageInfo, {})] }));
3306
3326
  };
3307
3327
 
3308
3328
  const PageLifeApplicant = () => {
@@ -3415,16 +3435,18 @@ const getFormattedAddress = (unitNumber, streetAddress, city, provinceCode, post
3415
3435
  return '';
3416
3436
  };
3417
3437
  const ModalAddress = () => {
3418
- const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack, }, dispatchAppModalState, } = mychoiceSdkStore.useStoreAppModal();
3419
- const { status, getPostal, errorMessage: reqErrorMessage, } = mychoiceSdkStore.useHandlerPostal(mychoiceSdkComponents.InsuranceTypes.Home);
3420
- const { postalState: { item, inValidation }, dispatchPostalState } = mychoiceSdkStore.useStoreFormHomePostal();
3421
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
3422
- const { postalCode, city, provinceCode, streetAddress, unitNumber, } = item;
3438
+ const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack }, dispatchAppModalState, } = mychoiceSdkStore.useStoreAppModal();
3439
+ const { status, getPostal, errorMessage: reqErrorMessage } = mychoiceSdkStore.useHandlerPostal(mychoiceSdkComponents.InsuranceTypes.Home);
3440
+ const { postalState: { item, inValidation }, dispatchPostalState, } = mychoiceSdkStore.useStoreFormHomePostal();
3441
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3442
+ const { postalCode, city, provinceCode, streetAddress, unitNumber } = item;
3423
3443
  const [localPostalCode, setLocalPostalCode] = React.useState(postalCode);
3424
3444
  const [localUnitNumber, setLocalUnitNumber] = React.useState(unitNumber);
3425
3445
  const [localStreetAddress, setLocalStreetAddress] = React.useState(streetAddress);
3426
3446
  const loading = status === mychoiceSdkComponents.RequestStatusTypes.Loading;
3427
- const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress) ? 'The street address should be in the format "123 Streetname Rd."' : '';
3447
+ const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
3448
+ ? 'The street address should be in the format "123 Streetname Rd."'
3449
+ : '';
3428
3450
  const postalCodeErrMessage = localPostalCode.length < 4 ? 'Postal code should have at least 4 characters' : '';
3429
3451
  const handleClick = (callBack) => () => {
3430
3452
  if (callBack) {
@@ -3440,10 +3462,14 @@ const ModalAddress = () => {
3440
3462
  submitCallBack();
3441
3463
  }
3442
3464
  else if (!localPostalCode || !localStreetAddress || streetAddressErrMessage || postalCodeErrMessage) {
3443
- dispatchPostalState({ type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalValidate, payload: { inValidation: true } });
3465
+ dispatchPostalState({
3466
+ type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalValidate,
3467
+ payload: { inValidation: true },
3468
+ });
3444
3469
  }
3445
3470
  else {
3446
- getPostal(mychoiceSdkComponents.postalCodeFormat(localPostalCode)).then((result) => {
3471
+ getPostal(mychoiceSdkComponents.postalCodeFormat(localPostalCode))
3472
+ .then((result) => {
3447
3473
  const formattedAddress = getFormattedAddress(localUnitNumber, localStreetAddress, result?.data?.city || '', result?.data?.provinceCode || '', localPostalCode, 'Canada');
3448
3474
  dispatchPostalState({
3449
3475
  type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalSet,
@@ -3456,7 +3482,8 @@ const ModalAddress = () => {
3456
3482
  },
3457
3483
  });
3458
3484
  dispatchAppModalState({ type: mychoiceSdkStore.StoreConfigAppModalActionTypes.AppModalClose });
3459
- }).catch();
3485
+ })
3486
+ .catch();
3460
3487
  }
3461
3488
  }
3462
3489
  };
@@ -3473,7 +3500,7 @@ const ModalAddress = () => {
3473
3500
  break;
3474
3501
  }
3475
3502
  };
3476
- return (jsxRuntime.jsxs("div", { className: `modal-container edit-address ${appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : ''}`, children: [title && jsxRuntime.jsx("h3", { children: title }), description && jsxRuntime.jsx("p", { children: description }), jsxRuntime.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) }), jsxRuntime.jsx(InputFormBox, { name: "unitApartmentNumber", title: "Unit/Apartment number", onChange: handleChange('unitNumber'), defaultValue: localUnitNumber, placeholder: "Unit, Suite or Apartment Number" }), jsxRuntime.jsx(InputFormBox, { name: "city", title: "City", defaultValue: city, placeholder: "City", error: !city && inValidation, errorMessage: getErrorMessage(city, inValidation), disabled: true }), jsxRuntime.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 }), jsxRuntime.jsx(InputFormBox, { name: "province", title: "Province Code", defaultValue: provinceCode, placeholder: "", error: !provinceCode && inValidation, errorMessage: getErrorMessage(provinceCode, inValidation), disabled: true }), jsxRuntime.jsxs("div", { className: "modal-buttons", children: [cancelButtonText && (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { type: mychoiceSdkComponents.ButtonTypes.Button, label: cancelButtonText, category: mychoiceSdkComponents.CategoryTypes.Outlined, color: mychoiceSdkComponents.ColorTypes.Default, variant: mychoiceSdkComponents.ButtonVariantTypes.Rectangle, size: mychoiceSdkComponents.SizeTypes.Large, onClick: handleClick(cancelCallBack) })), jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { className: `${loading ? 'disabled' : ''}`, type: mychoiceSdkComponents.ButtonTypes.Button, label: !loading ? submitButtonText || 'OK' : '', category: mychoiceSdkComponents.CategoryTypes.Filled, color: mychoiceSdkComponents.ColorTypes.Primary, variant: mychoiceSdkComponents.ButtonVariantTypes.Rectangle, size: mychoiceSdkComponents.SizeTypes.Large, onClick: onSubmit, children: loading ? jsxRuntime.jsx(mychoiceSdkComponents.IconLoaderSecondary, {}) : undefined })] })] }));
3503
+ return (jsxRuntime.jsxs("div", { className: `modal-container edit-address ${mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: [title && jsxRuntime.jsx("h3", { children: title }), description && jsxRuntime.jsx("p", { children: description }), jsxRuntime.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) }), jsxRuntime.jsx(InputFormBox, { name: "unitApartmentNumber", title: "Unit/Apartment number", onChange: handleChange('unitNumber'), defaultValue: localUnitNumber, placeholder: "Unit, Suite or Apartment Number" }), jsxRuntime.jsx(InputFormBox, { name: "city", title: "City", defaultValue: city, placeholder: "City", error: !city && inValidation, errorMessage: getErrorMessage(city, inValidation), disabled: true }), jsxRuntime.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 }), jsxRuntime.jsx(InputFormBox, { name: "province", title: "Province Code", defaultValue: provinceCode, placeholder: "", error: !provinceCode && inValidation, errorMessage: getErrorMessage(provinceCode, inValidation), disabled: true }), jsxRuntime.jsxs("div", { className: "modal-buttons", children: [cancelButtonText && (jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { type: mychoiceSdkComponents.ButtonTypes.Button, label: cancelButtonText, category: mychoiceSdkComponents.CategoryTypes.Outlined, color: mychoiceSdkComponents.ColorTypes.Default, variant: mychoiceSdkComponents.ButtonVariantTypes.Rectangle, size: mychoiceSdkComponents.SizeTypes.Large, onClick: handleClick(cancelCallBack) })), jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { className: `${loading ? 'disabled' : ''}`, type: mychoiceSdkComponents.ButtonTypes.Button, label: !loading ? submitButtonText || 'OK' : '', category: mychoiceSdkComponents.CategoryTypes.Filled, color: mychoiceSdkComponents.ColorTypes.Primary, variant: mychoiceSdkComponents.ButtonVariantTypes.Rectangle, size: mychoiceSdkComponents.SizeTypes.Large, onClick: onSubmit, children: loading ? jsxRuntime.jsx(mychoiceSdkComponents.IconLoaderSecondary, {}) : undefined })] })] }));
3477
3504
  };
3478
3505
 
3479
3506
  const ModalFinale = () => {
@@ -3500,8 +3527,8 @@ PostalCodeDataBox.defaultProps = {
3500
3527
  postalCode: '',
3501
3528
  };
3502
3529
 
3503
- const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3504
- const { appConfigState: { insuranceType, appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
3530
+ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted }) => {
3531
+ const { appConfigState: { insuranceType, appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3505
3532
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3506
3533
  const isMobile = appDeviceType === mychoiceSdkComponents.DeviceTypes.Mobile;
3507
3534
  const navigate = reactRouterDom.useNavigate();
@@ -3513,7 +3540,9 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3513
3540
  const activeStep = formSteps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1));
3514
3541
  let activeIndex = formSteps.indexOf(activeStep);
3515
3542
  activeIndex = activeIndex === -1 ? 0 : activeIndex;
3516
- let navigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
3543
+ let navigationCls = propertyIsCompleted
3544
+ ? 'mychoice-car-navigation-step-container'
3545
+ : 'mychoice-home-navigation-step-container';
3517
3546
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Life) {
3518
3547
  navigationCls = 'mychoice-life-navigation-step-container';
3519
3548
  }
@@ -3527,7 +3556,8 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3527
3556
  // }
3528
3557
  // }, [propertyIsCompleted]);
3529
3558
  const handleStepClick = (item, itemIndex) => () => {
3530
- if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) { // ignore double click
3559
+ if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
3560
+ // ignore double click
3531
3561
  if (activeIndex > (itemIndex || 0)) {
3532
3562
  navigate(`/${localIndex}/${insuranceType}${item?.path}`);
3533
3563
  }
@@ -3543,13 +3573,16 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3543
3573
  validateOptions.forEach((option, index) => {
3544
3574
  const isValid = !option.isValid ? option.validate(false) : option.isValid;
3545
3575
  formValidations.push({
3546
- isValid, validate: option.validate, requestFn: option?.requestFn || undefined, index,
3576
+ isValid,
3577
+ validate: option.validate,
3578
+ requestFn: option?.requestFn || undefined,
3579
+ index,
3547
3580
  });
3548
3581
  });
3549
3582
  }
3550
3583
  const formValidated = formValidations.find((option) => !option.isValid);
3551
3584
  if (formValidated && !formValidated.isValid) {
3552
- navigate(`/${localIndex}/${insuranceType}${formSteps[(formValidated.index || 0)]?.path}`);
3585
+ navigate(`/${localIndex}/${insuranceType}${formSteps[formValidated.index || 0]?.path}`);
3553
3586
  //
3554
3587
  // dispatchAppModalState({
3555
3588
  // type: StoreConfigAppModalActionTypes.AppModalMessageModal,
@@ -3571,7 +3604,7 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3571
3604
  }
3572
3605
  }
3573
3606
  };
3574
- return (jsxRuntime.jsxs("ol", { className: appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice-navigation-steps-container' : 'navigation-steps-container', children: [!isMobile ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: formSteps?.map((item, index) => {
3607
+ return (jsxRuntime.jsxs("ol", { className: mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice-navigation-steps-container' : 'navigation-steps-container', children: [!isMobile ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: formSteps?.map((item, index) => {
3575
3608
  let cls;
3576
3609
  switch (true) {
3577
3610
  case activeIndex > index:
@@ -3580,16 +3613,15 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3580
3613
  case activeIndex === index:
3581
3614
  cls = 'in-progress';
3582
3615
  break;
3583
- default: cls = 'todo';
3616
+ default:
3617
+ cls = 'todo';
3584
3618
  }
3585
3619
  // const homeNavigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
3586
- if (appType === mychoiceSdkComponents.AppTypes.MyChoice && (index === formSteps.length - 1)) {
3620
+ if (mychoiceSdkComponents.isMyChoiceLike(appType) && index === formSteps.length - 1) {
3587
3621
  return jsxRuntime.jsx(jsxRuntime.Fragment, {});
3588
3622
  }
3589
- return (jsxRuntime.jsx("div", { role: "presentation", className: appType === mychoiceSdkComponents.AppTypes.MyChoice ? navigationCls : 'navigation-step-container', onKeyDown: handleStepClick(item, index), onClick: handleStepClick(item, index), children: appType === mychoiceSdkComponents.AppTypes.MyChoice
3590
- ? jsxRuntime.jsx(mychoiceSdkComponents.MychoiceStep, { className: cls, item: item, index: index }, `${index}-${item?.title}`)
3591
- : jsxRuntime.jsx(mychoiceSdkComponents.Step, { className: cls, item: item, index: index }, `${index}-${item?.title}`) }, `${index}-${item?.title}`));
3592
- }) })) : jsxRuntime.jsx(mychoiceSdkComponents.Step, { item: formSteps[activeIndex], index: activeIndex, itemsCount: formSteps.length, isMobile: true }), appType === mychoiceSdkComponents.AppTypes.MyChoice && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsxs("div", { className: "estimated-minutes", children: [jsxRuntime.jsx(mychoiceSdkComponents.IconClock, {}), jsxRuntime.jsxs("div", { children: ["Estimated", ' ', jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] })] })] }))] }));
3623
+ return (jsxRuntime.jsx("div", { role: "presentation", className: mychoiceSdkComponents.isMyChoiceLike(appType) ? navigationCls : 'navigation-step-container', onKeyDown: handleStepClick(item, index), onClick: handleStepClick(item, index), children: mychoiceSdkComponents.isMyChoiceLike(appType) ? (jsxRuntime.jsx(mychoiceSdkComponents.MychoiceStep, { className: cls, item: item, index: index }, `${index}-${item?.title}`)) : (jsxRuntime.jsx(mychoiceSdkComponents.Step, { className: cls, item: item, index: index }, `${index}-${item?.title}`)) }, `${index}-${item?.title}`));
3624
+ }) })) : (jsxRuntime.jsx(mychoiceSdkComponents.Step, { item: formSteps[activeIndex], index: activeIndex, itemsCount: formSteps.length, isMobile: true })), mychoiceSdkComponents.isMyChoiceLike(appType) && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("hr", {}), jsxRuntime.jsxs("div", { className: "estimated-minutes", children: [jsxRuntime.jsx(mychoiceSdkComponents.IconClock, {}), jsxRuntime.jsxs("div", { children: ["Estimated", ' ', jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, " ", formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] })] })] }))] }));
3593
3625
  };
3594
3626
  StepsBox.defaultProps = {
3595
3627
  partnerId: '',
@@ -3676,7 +3708,7 @@ ButtonsBox.defaultProps = {
3676
3708
 
3677
3709
  const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearForm, propertyIsCompleted, }) => {
3678
3710
  const { pathname } = reactRouterDom.useLocation();
3679
- const { appConfigState: { appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
3711
+ const { appConfigState: { appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3680
3712
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
3681
3713
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3682
3714
  const isDesktop = appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop;
@@ -3702,8 +3734,7 @@ const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearFor
3702
3734
  return `rgba(${r}, ${g}, ${b}, ${alpha})`;
3703
3735
  }
3704
3736
  }
3705
- return (jsxRuntime.jsx("div", { className: localIndex !== mychoiceSdkComponents.defaultLocalIndex ? 'navigation-container-partner' : 'navigation-container', children: jsxRuntime.jsxs("div", { className: `content ${appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : ''}`, children: [jsxRuntime.jsx(PostalCodeDataBox, { className: isTheBig ? 'thebig' : '', title: title, postalCode: postalCode }), appType === mychoiceSdkComponents.AppTypes.MyChoice
3706
- ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: !isDesktop && (formSteps.length - activeIndex - 1) ? (jsxRuntime.jsxs("div", { className: "estimated-minutes", children: [jsxRuntime.jsx(mychoiceSdkComponents.IconClock, {}), jsxRuntime.jsxs("div", { children: [isMobile ? (jsxRuntime.jsx("div", { children: jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }) })) : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { children: ["Estimated", ' ', jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] }) })), jsxRuntime.jsx("span", { children: `Step ${activeIndex + 1}/${formSteps.length - 1}` })] })] })) : jsxRuntime.jsx("span", {}) })) : (jsxRuntime.jsx(StepsBox, { formSteps: formSteps, validationHooks: validationHooks, propertyIsCompleted: propertyIsCompleted })), jsxRuntime.jsx(ButtonsBox, { formSteps: formSteps, validationHooks: validationHooks, clearForm: clearForm, propertyIsCompleted: propertyIsCompleted })] }) }));
3737
+ return (jsxRuntime.jsx("div", { className: localIndex !== mychoiceSdkComponents.defaultLocalIndex ? 'navigation-container-partner' : 'navigation-container', children: jsxRuntime.jsxs("div", { className: `content ${mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: [jsxRuntime.jsx(PostalCodeDataBox, { className: isTheBig ? 'thebig' : '', title: title, postalCode: postalCode }), mychoiceSdkComponents.isMyChoiceLike(appType) ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: !isDesktop && formSteps.length - activeIndex - 1 ? (jsxRuntime.jsxs("div", { className: "estimated-minutes", children: [jsxRuntime.jsx(mychoiceSdkComponents.IconClock, {}), jsxRuntime.jsxs("div", { children: [isMobile ? (jsxRuntime.jsx("div", { children: jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }) })) : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { children: ["Estimated", ' ', jsxRuntime.jsxs("span", { className: "time", children: [formSteps.length - activeIndex - 1, ' ', formSteps.length - activeIndex - 1 > 1 ? 'minutes' : 'minute'] }), ' ', "to complete"] }) })), jsxRuntime.jsx("span", { children: `Step ${activeIndex + 1}/${formSteps.length - 1}` })] })] })) : (jsxRuntime.jsx("span", {})) })) : (jsxRuntime.jsx(StepsBox, { formSteps: formSteps, validationHooks: validationHooks, propertyIsCompleted: propertyIsCompleted })), jsxRuntime.jsx(ButtonsBox, { formSteps: formSteps, validationHooks: validationHooks, clearForm: clearForm, propertyIsCompleted: propertyIsCompleted })] }) }));
3707
3738
  };
3708
3739
  NavigationTop.defaultProps = {
3709
3740
  isMobile: false,
@@ -3714,9 +3745,9 @@ const NavigationBottom = ({ createItem, validateForm, formSteps, className, item
3714
3745
  const { pathname } = reactRouterDom.useLocation();
3715
3746
  const navigate = reactRouterDom.useNavigate();
3716
3747
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
3717
- const isMychoice = appConfigState.appType === mychoiceSdkComponents.AppTypes.MyChoice;
3748
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appConfigState.appType);
3718
3749
  const { insuranceType } = appConfigState;
3719
- const { dwellingState: { isCompleted } } = mychoiceSdkStore.useStoreFormHomeDwelling();
3750
+ const { dwellingState: { isCompleted }, } = mychoiceSdkStore.useStoreFormHomeDwelling();
3720
3751
  const [steps, setSteps] = React.useState(formSteps);
3721
3752
  const currentPath = pathname.split('/');
3722
3753
  const activeIndex = steps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1))?.key || 0;
@@ -3950,39 +3981,35 @@ const AppModalWrapper = () => {
3950
3981
  const { appModalState } = mychoiceSdkStore.useStoreAppModal();
3951
3982
  switch (appModalState.modalType) {
3952
3983
  case mychoiceSdkComponents.ModalTypes.MessageModal:
3953
- return (jsxRuntime.jsx(ModalMessage, {}));
3984
+ return jsxRuntime.jsx(ModalMessage, {});
3954
3985
  case mychoiceSdkComponents.ModalTypes.ConfirmModal:
3955
- return (jsxRuntime.jsx(ModalConfirm, {}));
3986
+ return jsxRuntime.jsx(ModalConfirm, {});
3956
3987
  case mychoiceSdkComponents.ModalTypes.PostalModal:
3957
- return (jsxRuntime.jsx(ModalPostal, {}));
3988
+ return jsxRuntime.jsx(ModalPostal, {});
3958
3989
  case mychoiceSdkComponents.ModalTypes.AddressModal:
3959
- return (jsxRuntime.jsx(ModalAddress, {}));
3990
+ return jsxRuntime.jsx(ModalAddress, {});
3960
3991
  case mychoiceSdkComponents.ModalTypes.FinaleModal:
3961
- return (jsxRuntime.jsx(ModalFinale, {}));
3992
+ return jsxRuntime.jsx(ModalFinale, {});
3962
3993
  default:
3963
3994
  return null;
3964
3995
  }
3965
3996
  };
3966
3997
  const AppModal = () => {
3967
3998
  const { appModalState } = mychoiceSdkStore.useStoreAppModal();
3968
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
3999
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3969
4000
  const insuranceType = mychoiceSdkComponents.getInsuranceType();
3970
4001
  if (appModalState.isOpen && document.location.pathname.indexOf(insuranceType) !== -1) {
3971
- return (jsxRuntime.jsx("div", { className: `app-modal ${appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : ''}`, children: jsxRuntime.jsx(AppModalWrapper, {}) }));
4002
+ return (jsxRuntime.jsx("div", { className: `app-modal ${mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: jsxRuntime.jsx(AppModalWrapper, {}) }));
3972
4003
  }
3973
4004
  return null;
3974
4005
  };
3975
4006
 
3976
4007
  const AppHeader = () => {
3977
- const { appConfigState: { appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
4008
+ const { appConfigState: { appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3978
4009
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3979
4010
  if (appType) {
3980
- return (jsxRuntime.jsxs("div", { className: "app-header", children: [appType === mychoiceSdkComponents.AppTypes.TheBig && jsxRuntime.jsx(HeaderTheBig, { textBack: "home" }), appType === mychoiceSdkComponents.AppTypes.MyChoice
3981
- && (localIndex !== mychoiceSdkComponents.defaultLocalIndex
3982
- ? jsxRuntime.jsx(HeaderPartner, {})
3983
- : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop
3984
- ? jsxRuntime.jsx(HeaderMyChoice, {})
3985
- : jsxRuntime.jsx(HeaderMyChoiceMobile, {}) })))] }));
4011
+ return (jsxRuntime.jsxs("div", { className: "app-header", children: [appType === mychoiceSdkComponents.AppTypes.TheBig && jsxRuntime.jsx(HeaderTheBig, { textBack: "home" }), appType === mychoiceSdkComponents.AppTypes.BeginInsurance && (jsxRuntime.jsx(jsxRuntime.Fragment, { children: appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop ? jsxRuntime.jsx(HeaderBeginInsurance, {}) : jsxRuntime.jsx(HeaderBeginInsuranceMobile, {}) })), appType === mychoiceSdkComponents.AppTypes.MyChoice &&
4012
+ (localIndex !== mychoiceSdkComponents.defaultLocalIndex ? (jsxRuntime.jsx(HeaderPartner, {})) : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop ? jsxRuntime.jsx(HeaderMyChoice, {}) : jsxRuntime.jsx(HeaderMyChoiceMobile, {}) })))] }));
3986
4013
  }
3987
4014
  return null;
3988
4015
  };
@@ -4082,7 +4109,7 @@ const AppRouteWrapper = (props) => {
4082
4109
  let postalCode = carPostal;
4083
4110
  const { clearFormData, checkIsExpired, checkIsExpiredWithModal } = mychoiceSdkStore.ClearFormDataHandler();
4084
4111
  const { appLoaderState } = mychoiceSdkStore.useStoreAppLoader();
4085
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
4112
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
4086
4113
  switch (insuranceType) {
4087
4114
  case mychoiceSdkComponents.InsuranceTypes.Car:
4088
4115
  postalCode = carPostal;
@@ -4347,7 +4374,7 @@ const AppRouteWrapper = (props) => {
4347
4374
  }
4348
4375
  }
4349
4376
  }, [carPostal, homePostal, lifePostal, isReady]);
4350
- return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: isReady && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(AppHeader, {}), jsxRuntime.jsx(AppModal, {}), insuranceType && (jsxRuntime.jsx(NavigationTop, { title: `${insuranceType.replace(/^./, insuranceType[0].toUpperCase())} Insurance Quote`, postalCode: postalCode, formSteps: steps, validationHooks: validationHooks, clearForm: clearFormData, propertyIsCompleted: isCompleted })), insuranceType && appType === mychoiceSdkComponents.AppTypes.MyChoice && (jsxRuntime.jsx("div", { className: localIndex !== mychoiceSdkComponents.defaultLocalIndex ? 'step-progress-bar-partner' : 'step-progress-bar', children: jsxRuntime.jsx("span", { style: { width: progressLength } }) })), jsxRuntime.jsx("div", { className: `${insuranceType ? 'form-page-content' : ''} ${insuranceType && appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : ''}`, children: insuranceType && appType === mychoiceSdkComponents.AppTypes.MyChoice && isDesktop && progressLength ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { className: "mychoice-content", children: [jsxRuntime.jsx(StepsBox, { className: "step-box", formSteps: steps, validationHooks: validationHooks, propertyIsCompleted: isCompleted }), children, jsxRuntime.jsx("div", { className: "empty-steps-container" })] }) })) : (children) }), isMychoice && !appLoaderState.isOpen && jsxRuntime.jsx(ProviderImageFooter, {})] })) }));
4377
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: isReady && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(AppHeader, {}), jsxRuntime.jsx(AppModal, {}), insuranceType && (jsxRuntime.jsx(NavigationTop, { title: `${insuranceType.replace(/^./, insuranceType[0].toUpperCase())} Insurance Quote`, postalCode: postalCode, formSteps: steps, validationHooks: validationHooks, clearForm: clearFormData, propertyIsCompleted: isCompleted })), insuranceType && mychoiceSdkComponents.isMyChoiceLike(appType) && (jsxRuntime.jsx("div", { className: localIndex !== mychoiceSdkComponents.defaultLocalIndex ? 'step-progress-bar-partner' : 'step-progress-bar', children: jsxRuntime.jsx("span", { style: { width: progressLength } }) })), jsxRuntime.jsx("div", { className: `${insuranceType ? 'form-page-content' : ''} ${insuranceType && mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: insuranceType && mychoiceSdkComponents.isMyChoiceLike(appType) && isDesktop && progressLength ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsxs("div", { className: "mychoice-content", children: [jsxRuntime.jsx(StepsBox, { className: "step-box", formSteps: steps, validationHooks: validationHooks, propertyIsCompleted: isCompleted }), children, jsxRuntime.jsx("div", { className: "empty-steps-container" })] }) })) : (children) }), isMychoice && !appLoaderState.isOpen && jsxRuntime.jsx(ProviderImageFooter, {})] })) }));
4351
4378
  };
4352
4379
  const NestedRoutes = () => {
4353
4380
  const insuranceType = mychoiceSdkComponents.getInsuranceType();
@@ -4489,7 +4516,7 @@ const AppConfig = (props) => {
4489
4516
  // home insurance steps states
4490
4517
  const { dispatchPostalState: dispatchHomePostalState } = mychoiceSdkStore.useStoreFormHomePostal();
4491
4518
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
4492
- const { dwellingState: { isCompleted }, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
4519
+ const { dwellingState: { isCompleted }, dispatchDwellingState, } = mychoiceSdkStore.useStoreFormHomeDwelling();
4493
4520
  const { dispatchDiscountState: dispatchHomeDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
4494
4521
  const { dispatchQuoteState: dispatchHomeQuoteState } = mychoiceSdkStore.useStoreFormHomeQuote();
4495
4522
  // life insurance
@@ -4548,8 +4575,7 @@ const AppConfig = (props) => {
4548
4575
  if (authHandler.status === mychoiceSdkComponents.RequestStatusTypes.Waiting) {
4549
4576
  authHandler.checkUser();
4550
4577
  }
4551
- if (authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Waiting
4552
- && authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Loading) {
4578
+ if (authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Waiting && authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Loading) {
4553
4579
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Car) {
4554
4580
  dispatchCarPostalState({
4555
4581
  type: mychoiceSdkStore.StoreFormCarPostalActionTypes.FormCarPostalGetLocal,
@@ -4579,7 +4605,9 @@ const AppConfig = (props) => {
4579
4605
  type: mychoiceSdkStore.StoreFormCarQuoteActionTypes.FormCarQuoteGetLocal,
4580
4606
  });
4581
4607
  }
4582
- if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home || insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo || insuranceType === mychoiceSdkComponents.InsuranceTypes.Tenant) {
4608
+ if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home ||
4609
+ insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo ||
4610
+ insuranceType === mychoiceSdkComponents.InsuranceTypes.Tenant) {
4583
4611
  dispatchHomePostalState({
4584
4612
  type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalGetLocal,
4585
4613
  });
@@ -4630,6 +4658,14 @@ const AppConfig = (props) => {
4630
4658
  payload: true,
4631
4659
  });
4632
4660
  }
4661
+ if (appType === mychoiceSdkComponents.AppTypes.BeginInsurance) {
4662
+ // Begin Insurance brand colors: Navy Blue primary, Green accent
4663
+ setExternalColors('#0F2043', '#50C878');
4664
+ dispatchAppConfigState({
4665
+ type: mychoiceSdkStore.StoreConfigAppConfigActionTypes.AppConfigSetPreloaded,
4666
+ payload: true,
4667
+ });
4668
+ }
4633
4669
  }, [appType]);
4634
4670
  React.useEffect(() => {
4635
4671
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home && isCompleted) {
@@ -4686,6 +4722,8 @@ AppWrapper.defaultProps = {
4686
4722
 
4687
4723
  exports.AppWrapper = AppWrapper;
4688
4724
  exports.DateSelectFormBox = DateSelectFormBox;
4725
+ exports.HeaderBeginInsurance = HeaderBeginInsurance;
4726
+ exports.HeaderBeginInsuranceMobile = HeaderBeginInsuranceMobile;
4689
4727
  exports.HeaderMyChoice = HeaderMyChoice;
4690
4728
  exports.HeaderMyChoiceMobile = HeaderMyChoiceMobile;
4691
4729
  exports.HeaderPartner = HeaderPartner;