@mychoice/mychoice-sdk-modules 2.1.88 → 2.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cjs/index.js 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: '',
@@ -492,30 +502,53 @@ HeaderMyChoice.defaultProps = {
492
502
 
493
503
  const HeaderPartner = ({ className }) => {
494
504
  const { partnerState } = mychoiceSdkStore.useStorePartner();
495
- return (jsxRuntime.jsx("div", { className: `${className} primary-header-partner`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("a", { href: partnerState.redirectUrl || 'https://www.mychoice.ca/', target: "_blank", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: partnerState.logo || 'https://s3.amazonaws.com/mychoice-logos-dev/partners/newpartner/AE1C9160-F0AD-4969-BEBB-86EBFA7CF2E7.png', alt: "new-partner-logotype" }) }), jsxRuntime.jsx("div", {})] }) }));
505
+ return (jsxRuntime.jsx("div", { className: `${className} primary-header-partner`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("a", { href: partnerState.redirectUrl || 'https://www.mychoice.ca/', target: "_blank", rel: "noreferrer", children: jsxRuntime.jsx("img", { src: partnerState.logo ||
506
+ 'https://s3.amazonaws.com/mychoice-logos-dev/partners/newpartner/AE1C9160-F0AD-4969-BEBB-86EBFA7CF2E7.png', alt: "new-partner-logotype" }) }), jsxRuntime.jsx("div", {})] }) }));
496
507
  };
497
508
 
498
509
  var theBigLogotype = "";
499
510
 
500
- const HeaderTheBig = ({ textBack, className, }) => (jsxRuntime.jsx("div", { className: `${className} primary-header-thebig`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("img", { src: theBigLogotype, alt: "thebig-logotype" }) }), jsxRuntime.jsx("a", { href: "https://www.thebig.ca/", target: "_blank", rel: "noreferrer", children: jsxRuntime.jsxs("div", { className: "back-button", children: [jsxRuntime.jsx("div", { className: "back-icon" }), jsxRuntime.jsx("h2", { children: textBack })] }) })] }) }));
511
+ const HeaderTheBig = ({ textBack, className }) => (jsxRuntime.jsx("div", { className: `${className} primary-header-thebig`, children: jsxRuntime.jsxs("div", { className: "content", children: [jsxRuntime.jsx("div", { className: "logo", children: jsxRuntime.jsx("img", { src: theBigLogotype, alt: "thebig-logotype" }) }), jsxRuntime.jsx("a", { href: "https://www.thebig.ca/", target: "_blank", rel: "noreferrer", children: jsxRuntime.jsxs("div", { className: "back-button", children: [jsxRuntime.jsx("div", { className: "back-icon" }), jsxRuntime.jsx("h2", { children: textBack })] }) })] }) }));
501
512
  HeaderTheBig.defaultProps = {
502
513
  className: '',
503
514
  };
504
515
 
505
- const HeaderMyChoiceMobile = ({ className, }) => {
506
- const { appConfigState: { insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
516
+ const HeaderBeginInsurance = ({ className }) => {
517
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
518
+ const insuranceTypeCls = insuranceType !== mychoiceSdkComponents.InsuranceTypes.Car && insuranceType !== mychoiceSdkComponents.InsuranceTypes.Life ? mychoiceSdkComponents.InsuranceTypes.Home : insuranceType;
519
+ const { externalPathGroup } = usePathGroups(insuranceTypeCls);
520
+ 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" })] }) }));
521
+ };
522
+ HeaderBeginInsurance.defaultProps = {
523
+ className: '',
524
+ };
525
+
526
+ const HeaderMyChoiceMobile = ({ className }) => {
527
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
507
528
  const { externalPathGroup } = usePathGroups(insuranceType);
508
529
  const [isMenuOpen, setIsMenuOpen] = React.useState(false);
509
530
  const handleMenuClick = () => {
510
531
  setIsMenuOpen(!isMenuOpen);
511
532
  };
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 }) }) }))] }));
533
+ 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
534
  };
515
535
  HeaderMyChoiceMobile.defaultProps = {
516
536
  className: '',
517
537
  };
518
538
 
539
+ const HeaderBeginInsuranceMobile = ({ className }) => {
540
+ const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
541
+ const { externalPathGroup } = usePathGroups(insuranceType);
542
+ const [isMenuOpen, setIsMenuOpen] = React.useState(false);
543
+ const handleMenuClick = () => {
544
+ setIsMenuOpen(!isMenuOpen);
545
+ };
546
+ 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 }) }) }))] }));
547
+ };
548
+ HeaderBeginInsuranceMobile.defaultProps = {
549
+ className: '',
550
+ };
551
+
519
552
  const LoaderVid = () => {
520
553
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
521
554
  const isMobile = appDeviceType === mychoiceSdkComponents.DeviceTypes.Mobile;
@@ -526,11 +559,11 @@ const LoaderPrimary = () => {
526
559
  const { appLoaderState } = mychoiceSdkStore.useStoreAppLoader();
527
560
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
528
561
  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." })] }));
562
+ const isHome = window.location.pathname.includes('home') ||
563
+ window.location.pathname.includes('condo') ||
564
+ window.location.pathname.includes('tenant');
565
+ 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 &&
566
+ isHome && jsxRuntime.jsx("h4", { children: "Hang tight, while we collect and process information about your property." }))] }));
534
567
  };
535
568
 
536
569
  const ModalConfirm = () => {
@@ -780,16 +813,16 @@ const BlockCarConditionInfo = () => {
780
813
  };
781
814
 
782
815
  const VehicleSectionMain = () => {
783
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
784
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
816
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
817
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
785
818
  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
819
  };
787
820
 
788
821
  const VehicleSectionCoverage = () => {
789
822
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
790
823
  const { collision, comprehensive } = vehicleState.items[vehicleState.activeIndex];
791
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
792
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
824
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
825
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
793
826
  const handleComprehensiveChange = ({ value }) => {
794
827
  dispatchVehicleState({
795
828
  type: mychoiceSdkStore.StoreFormCarVehicleActionTypes.FormCarComprehensiveCoverageSelect,
@@ -943,11 +976,11 @@ const TabDriver = ({ createItem, readOnly }) => {
943
976
 
944
977
  const SectionDriverInfo = () => {
945
978
  const { configState } = mychoiceSdkStore.useStoreFormCarConfig();
946
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
979
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
947
980
  const { driverState, dispatchDriverInfoState } = mychoiceSdkStore.useStoreFormCarDriverInfo();
948
981
  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' : '';
982
+ const { firstName, maritalStatus, birthDay, birthMonth, birthYear, occupation, gender, applicantRelationship } = driverState.items[driverState.activeIndex];
983
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
951
984
  const defaultDateOfBirth = {
952
985
  day: birthDay,
953
986
  month: birthMonth,
@@ -1011,17 +1044,16 @@ const SectionDriverInfo = () => {
1011
1044
  payload: { applicantRelationship: value },
1012
1045
  });
1013
1046
  };
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) }))] }));
1047
+ 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
1048
  };
1017
1049
 
1018
1050
  const SectionDriverLicence = () => {
1019
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1051
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1020
1052
  const [driverEducation, setDriverEducation] = React.useState(false);
1021
1053
  const { configState } = mychoiceSdkStore.useStoreFormCarConfig();
1022
1054
  const { driverState, dispatchDriverLicenceState } = mychoiceSdkStore.useStoreFormCarDriverLicence();
1023
1055
  const { isAlbertaProvince } = mychoiceSdkStore.useProvince();
1024
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1056
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1025
1057
  const { firstName, birthDay, birthMonth, birthYear, licenceInfo: { firstLicenceAge, licenceType, g1LicenceYear, g1LicenceMonth, gLicenceYear, gLicenceMonth, g2LicenceYear, g2LicenceMonth, passedDriverTraining, previousLicence, }, minMaxDates, } = driverState.items[driverState.activeIndex];
1026
1058
  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
1059
  const maxLicenceAge = licenceAgeMax;
@@ -1030,7 +1062,7 @@ const SectionDriverLicence = () => {
1030
1062
  const defaultMinDate = birthDate && firstLicenceAge ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge) : '';
1031
1063
  const isOnlyG = mychoiceSdkComponents.checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
1032
1064
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1033
- const { g, g1, g2, minLicenceAge, } = configState.licenceConfig;
1065
+ const { g, g1, g2, minLicenceAge } = configState.licenceConfig;
1034
1066
  const licenceTypeOptions = [
1035
1067
  { value: g.name, name: g.title },
1036
1068
  { value: g1.name, name: g1.title },
@@ -1060,7 +1092,8 @@ const SectionDriverLicence = () => {
1060
1092
  return gOneMin;
1061
1093
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1062
1094
  return gTwoMin;
1063
- default: return '';
1095
+ default:
1096
+ return '';
1064
1097
  }
1065
1098
  };
1066
1099
  const getMaxDate = (type) => {
@@ -1071,7 +1104,8 @@ const SectionDriverLicence = () => {
1071
1104
  return gOneMax;
1072
1105
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1073
1106
  return gTwoMax;
1074
- default: return '';
1107
+ default:
1108
+ return '';
1075
1109
  }
1076
1110
  };
1077
1111
  const getLicenceYear = (type) => {
@@ -1082,7 +1116,8 @@ const SectionDriverLicence = () => {
1082
1116
  return g1LicenceYear;
1083
1117
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1084
1118
  return g2LicenceYear;
1085
- default: return '';
1119
+ default:
1120
+ return '';
1086
1121
  }
1087
1122
  };
1088
1123
  const getLicenceMonth = (type) => {
@@ -1093,7 +1128,8 @@ const SectionDriverLicence = () => {
1093
1128
  return g1LicenceMonth;
1094
1129
  case mychoiceSdkComponents.DriverLicenceTypes.G2:
1095
1130
  return g2LicenceMonth;
1096
- default: return '';
1131
+ default:
1132
+ return '';
1097
1133
  }
1098
1134
  };
1099
1135
  const getDefaultLicenceDate = (type) => ({
@@ -1146,8 +1182,10 @@ const SectionDriverLicence = () => {
1146
1182
  const formattedMinDate = `${mychoiceSdkComponents.getFormattedDate(licenceMinDate, 'MMMM yyyy')}`;
1147
1183
  const defaultHintMessage = `${formattedMinDate} would be your earliest ${licenceTypeTitle}
1148
1184
  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;
1185
+ return currentType === mychoiceSdkComponents.DriverLicenceTypes.G2
1186
+ ? `${defaultHintMessage}
1187
+ if you completed a driver education course`
1188
+ : defaultHintMessage;
1151
1189
  };
1152
1190
  const getLicenceAgeTitle = () => {
1153
1191
  if (isAlbertaProvince && isTheBig) {
@@ -1155,10 +1193,10 @@ const SectionDriverLicence = () => {
1155
1193
  }
1156
1194
  return `What age was ${firstName || driverNameDefault} when first licenced?`;
1157
1195
  };
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)." })] }));
1196
+ 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
1197
+ ? `${firstName || driverNameDefault} was licenced in
1198
+ ${Number(birthYear) + Number(firstLicenceAge)} - ${Number(birthYear) + Number(firstLicenceAge) + 1}`
1199
+ : '', 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
1200
  };
1163
1201
 
1164
1202
  const SectionDriverInsurancePolicy = () => {
@@ -1167,18 +1205,14 @@ const SectionDriverInsurancePolicy = () => {
1167
1205
  const { driverState, dispatchDriverInsuranceState } = mychoiceSdkStore.useStoreFormCarDriverInsurance();
1168
1206
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
1169
1207
  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];
1208
+ const { listed, listedMonth = '', listedYear = '', insured, insuredDate = '', firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge, licenceType, gLicenceYear, gLicenceMonth, g1LicenceYear, g1LicenceMonth }, } = driverState.items[driverState.activeIndex];
1171
1209
  const { policyStartYear, policyStartMonth, policyStartDay } = discountState;
1172
1210
  const driverNameDefault = `Driver ${driverState.activeIndex + 1}`;
1173
- const birthDate = birthYear && birthMonth && birthDay
1174
- ? `${birthYear}-${birthMonth}-${birthDay}`
1175
- : '';
1211
+ const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
1176
1212
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1177
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1213
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1178
1214
  const getPeriodOptions = (year, month) => {
1179
- const options = [
1180
- { value: '', name: 'Date Period', disabled: true },
1181
- ];
1215
+ const options = [{ value: '', name: 'Date Period', disabled: true }];
1182
1216
  if (year && month) {
1183
1217
  const todayDate = new Date();
1184
1218
  const month = String(todayDate.getMonth() + 1).padStart(2, '0');
@@ -1234,9 +1268,7 @@ you had insurance. If this is correct, please continue with the form.`);
1234
1268
  }
1235
1269
  };
1236
1270
  if (birthDate) {
1237
- const defaultMinDate = birthDate && firstLicenceAge
1238
- ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge)
1239
- : '';
1271
+ const defaultMinDate = birthDate && firstLicenceAge ? mychoiceSdkComponents.addYearsToDate(birthDate, +firstLicenceAge) : '';
1240
1272
  const isOnlyG = mychoiceSdkComponents.checkDateIsSpecial(defaultMinDate, configState.minDates.g.specialDate);
1241
1273
  if (isOnlyG) {
1242
1274
  setMessage(gLicenceYear, gLicenceMonth);
@@ -1255,16 +1287,7 @@ you had insurance. If this is correct, please continue with the form.`);
1255
1287
  else {
1256
1288
  setHintMessage('');
1257
1289
  }
1258
- }, [
1259
- listedYear,
1260
- listedMonth,
1261
- g1LicenceYear,
1262
- g1LicenceMonth,
1263
- firstLicenceAge,
1264
- birthDate,
1265
- gLicenceYear,
1266
- gLicenceMonth,
1267
- ]);
1290
+ }, [listedYear, listedMonth, g1LicenceYear, g1LicenceMonth, firstLicenceAge, birthDate, gLicenceYear, gLicenceMonth]);
1268
1291
  const handleInsuredChange = ({ value }) => {
1269
1292
  dispatchDriverInsuranceState({
1270
1293
  type: mychoiceSdkStore.StoreFormCarDriverInsuranceActionTypes.FormCarDriverInsuredSelect,
@@ -1319,18 +1342,16 @@ you had insurance. If this is correct, please continue with the form.`);
1319
1342
  };
1320
1343
  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
1344
  ? 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 })] }));
1345
+ : '', 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
1346
  };
1326
1347
 
1327
1348
  const SectionDriverCancellation = () => {
1328
1349
  const { driverState, dispatchDriverCancellationState } = mychoiceSdkStore.useStoreFormCarDriverCancellation();
1329
1350
  const { dispatchDriverBaseState } = mychoiceSdkStore.useStoreFormCarDriverBase();
1330
1351
  const { insuranceCancellation, insuranceCancellationList = [] } = driverState.items[driverState.activeIndex];
1331
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1352
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1332
1353
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1333
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1354
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1334
1355
  const { firstName, birthYear, birthMonth, birthDay, licenceInfo: { firstLicenceAge }, } = driverState.items[driverState.activeIndex];
1335
1356
  const birthDate = birthYear && birthMonth && birthDay ? `${birthYear}-${birthMonth}-${birthDay}` : '';
1336
1357
  const handleIconClick = (index) => () => {
@@ -1406,7 +1427,7 @@ const SectionDriverCancellation = () => {
1406
1427
  }
1407
1428
  };
1408
1429
  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) => {
1430
+ 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
1431
  const defaultStartDate = {
1411
1432
  year: startYear,
1412
1433
  month: startMonth,
@@ -1416,12 +1437,11 @@ const SectionDriverCancellation = () => {
1416
1437
  month: endMonth,
1417
1438
  };
1418
1439
  const now = mychoiceSdkComponents.getFormattedDate('', 'yyyy-MM-dd');
1419
- const days = birthDay ? (+birthDay + 1) : 1;
1440
+ const days = birthDay ? +birthDay + 1 : 1;
1420
1441
  const endDate = endYear && endMonth ? mychoiceSdkStore.addDayToDate(`${endYear}-${endMonth}`, days) : now;
1421
1442
  const currentMinDate = mychoiceSdkComponents.getMinDateByYears(mychoiceSdkComponents.getMinDate(birthDate, firstLicenceAge), 3);
1422
1443
  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}`));
1444
+ 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
1445
  }), 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
1446
  };
1427
1447
 
@@ -1677,8 +1697,8 @@ const BlockDriverTicket = () => {
1677
1697
  };
1678
1698
 
1679
1699
  const SectionDriverHistory = () => {
1680
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1681
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1700
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1701
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1682
1702
  return (jsxRuntime.jsxs("div", { className: `form-section ${mychoiceCls}`, children: [jsxRuntime.jsx(BlockDriverSuspension, {}), jsxRuntime.jsx(BlockDriverAccident, {}), jsxRuntime.jsx(BlockDriverTicket, {})] }));
1683
1703
  };
1684
1704
 
@@ -1717,7 +1737,7 @@ const PageDriver = () => {
1717
1737
  React.useEffect(() => {
1718
1738
  setIsRender(true);
1719
1739
  }, [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" }))] }));
1740
+ 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
1741
  };
1722
1742
 
1723
1743
  const getDynamicLicenceBoxProps = ({ isAlbertaProvince, isOntarioProvince, isNewfoundlandProvince, isNovaScotiaProvince, isNewBrunswickProvince, }) => {
@@ -1767,11 +1787,11 @@ const SectionDiscountInfo$1 = () => {
1767
1787
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1768
1788
  const allProvinces = mychoiceSdkStore.useProvince();
1769
1789
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1770
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1790
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1771
1791
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
1772
1792
  const { validateEmail, errorMessage } = mychoiceSdkStore.useHandlerCarQuoterEmail();
1773
1793
  const { multiplePoliciesDiscount, appInstallDiscount, caaMemberDiscount, quoterInfo, emailTo: { email, emailStatus }, } = discountState;
1774
- const { firstName, lastName, phone, driverLicense = '', caslConsent, } = quoterInfo;
1794
+ const { firstName, lastName, phone, driverLicense = '', caslConsent } = quoterInfo;
1775
1795
  const handleMultiplePolicyChange = ({ value }) => {
1776
1796
  dispatchDiscountState({
1777
1797
  type: mychoiceSdkStore.StoreFormCarDiscountActionTypes.FormCarDiscountMultiplePoliciesSelect,
@@ -1825,8 +1845,7 @@ const SectionDiscountInfo$1 = () => {
1825
1845
  };
1826
1846
  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
1847
  ? 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, {})] }));
1848
+ : 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
1849
  };
1831
1850
 
1832
1851
  const PageCarDiscount = () => {
@@ -1851,10 +1870,10 @@ const SectionQuoteEdit$2 = () => {
1851
1870
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
1852
1871
  const { driverState, dispatchDriverBaseState } = mychoiceSdkStore.useStoreFormCarDriverBase();
1853
1872
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
1854
- const { discountState: { appInstallDiscount, multiplePoliciesDiscount } } = mychoiceSdkStore.useStoreFormCarDiscount();
1855
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
1873
+ const { discountState: { appInstallDiscount, multiplePoliciesDiscount }, } = mychoiceSdkStore.useStoreFormCarDiscount();
1874
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1856
1875
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1857
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1876
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1858
1877
  const navigate = reactRouterDom.useNavigate();
1859
1878
  const vehicles = vehicleState.items.map(({ year, make, model }) => [`${year} ${make} ${model}`]);
1860
1879
  const drivers = driverState.items.map(({ firstName }) => [`${firstName}`]);
@@ -1919,7 +1938,7 @@ const BlockMCEndorsements = () => {
1919
1938
  const SectionQuoteRecalc$1 = () => {
1920
1939
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
1921
1940
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
1922
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
1941
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
1923
1942
  const { vehicleState, dispatchVehicleState } = mychoiceSdkStore.useStoreFormCarVehicle();
1924
1943
  const { comprehensive, collision, liability } = vehicleState.items[vehicleState.activeIndex];
1925
1944
  const handleComprehensiveChange = ({ value }) => {
@@ -2080,7 +2099,7 @@ const SectionAddress = () => {
2080
2099
  const { streetAddress = '', postalCode = '', addressObject, errorMessage } = item;
2081
2100
  const navigate = reactRouterDom.useNavigate();
2082
2101
  const asyncSelectRef = React.useRef(null);
2083
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
2102
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
2084
2103
  const mychoiceCls = isMychoice ? 'mychoice' : '';
2085
2104
  const handleAddressChange = (address) => {
2086
2105
  dispatchPostalState({
@@ -2318,9 +2337,9 @@ const SectionApplicantInfo = () => {
2318
2337
  const { applicantState, dispatchApplicantInfoState } = mychoiceSdkStore.useStoreFormHomeApplicantInfo();
2319
2338
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2320
2339
  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' : '';
2340
+ const { firstName, insured: { birthDay, birthMonth, birthYear }, } = applicantState;
2341
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2342
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2324
2343
  const { familiesCount, occupiedYear } = dwellingState;
2325
2344
  // VARIABLES =========
2326
2345
  const birthDate = birthYear ? `${birthYear}-${birthMonth || '01'}-${birthDay || '01'}` : '';
@@ -2401,9 +2420,9 @@ const SectionApplicantInsurancePolicy = () => {
2401
2420
  const { applicantState, dispatchApplicantInsuranceState } = mychoiceSdkStore.useStoreFormHomeApplicantInsurance();
2402
2421
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2403
2422
  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' : '';
2423
+ const { insuredCurrent, insuredBefore, insured: { dateInsuredCurrent, dateInsuredSince }, } = applicantState;
2424
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2425
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2407
2426
  const defaultPolicyStartDate = {
2408
2427
  year: policyStartYear,
2409
2428
  month: policyStartMonth,
@@ -2453,19 +2472,17 @@ const SectionApplicantInsurancePolicy = () => {
2453
2472
  payload: { dateInsuredCurrent: value },
2454
2473
  });
2455
2474
  };
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) }))] }));
2475
+ 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
2476
  };
2460
2477
 
2461
2478
  const SectionApplicantCancellation = () => {
2462
2479
  const { applicantState, dispatchApplicantCancellationState } = mychoiceSdkStore.useStoreFormHomeApplicantCancellation();
2463
2480
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2464
2481
  const { insuranceCancellation, insuranceCancellationList } = applicantState;
2465
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2482
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2466
2483
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2467
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2468
- const { insured: { birthYear, birthMonth, birthDay } } = applicantState;
2484
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2485
+ const { insured: { birthYear, birthMonth, birthDay }, } = applicantState;
2469
2486
  const handleIconClick = (index) => () => {
2470
2487
  dispatchApplicantCancellationState({
2471
2488
  type: mychoiceSdkStore.StoreFormHomeApplicantCancellationActionTypes.FormHomeApplicantCancellationDelete,
@@ -2509,24 +2526,23 @@ const SectionApplicantCancellation = () => {
2509
2526
  });
2510
2527
  }
2511
2528
  };
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) => {
2529
+ 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
2530
  const defaultCancellationDate = {
2514
2531
  year: cancellationYear,
2515
2532
  month: cancellationMonth,
2516
2533
  day: '01',
2517
2534
  };
2518
2535
  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." }))] }))] }));
2536
+ }), 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
2537
  };
2522
2538
 
2523
2539
  const SectionApplicantClaim = () => {
2524
2540
  const { applicantState, dispatchApplicantClaimState } = mychoiceSdkStore.useStoreFormHomeApplicantClaim();
2525
2541
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2526
2542
  const { insuranceClaim, insuranceClaimList } = applicantState;
2527
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2543
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2528
2544
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2529
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2545
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2530
2546
  const handleIconClick = (index) => () => {
2531
2547
  dispatchApplicantClaimState({
2532
2548
  type: mychoiceSdkStore.StoreFormHomeApplicantClaimActionTypes.FormHomeApplicantClaimDelete,
@@ -2579,15 +2595,14 @@ const SectionApplicantClaim = () => {
2579
2595
  });
2580
2596
  }
2581
2597
  };
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) => {
2598
+ 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
2599
  const defaultClaimDate = {
2584
2600
  year: claimYear,
2585
2601
  month: claimMonth,
2586
2602
  day: '01',
2587
2603
  };
2588
2604
  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." }))] }))] }));
2605
+ }), 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
2606
  };
2592
2607
 
2593
2608
  const PageApplicant = () => {
@@ -2843,9 +2858,14 @@ const BlockDwellingInfo = () => {
2843
2858
  };
2844
2859
 
2845
2860
  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" }), "."] }) })] })) }));
2861
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2862
+ if (appType === mychoiceSdkComponents.AppTypes.TheBig) {
2863
+ 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."] }) }));
2864
+ }
2865
+ if (appType === mychoiceSdkComponents.AppTypes.MyChoice) {
2866
+ 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" }), "."] }) })] });
2867
+ }
2868
+ return null;
2849
2869
  };
2850
2870
 
2851
2871
  const BlockSubmit$1 = ({ className, label, buttonSize, isRecalc = false, }) => {
@@ -2875,14 +2895,14 @@ BlockSubmit$1.defaultProps = {
2875
2895
  };
2876
2896
 
2877
2897
  const SectionDiscountInfo = () => {
2878
- const { appConfigState: { appType, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
2898
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2879
2899
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2880
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2900
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2881
2901
  const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
2882
2902
  // const { applicantState, dispatchApplicantInfoState } = useStoreFormHomeApplicantInfo();
2883
2903
  const { validateEmail, errorMessage } = mychoiceSdkStore.useHandlerHomeQuoterEmail();
2884
2904
  const { multiplePoliciesDiscount, emailTo: { email, emailStatus }, quoterInfo = {}, } = discountState;
2885
- const { firstName = '', lastName = '', phone = '', caslConsent, } = quoterInfo;
2905
+ const { firstName = '', lastName = '', phone = '', caslConsent } = quoterInfo;
2886
2906
  const handleMultiplePolicyChange = ({ value }) => {
2887
2907
  dispatchDiscountState({
2888
2908
  type: mychoiceSdkStore.StoreFormHomeDiscountActionTypes.FormHomeDiscountMultiplePoliciesSelect,
@@ -2916,13 +2936,11 @@ const SectionDiscountInfo = () => {
2916
2936
  payload: { caslConsent: value },
2917
2937
  });
2918
2938
  };
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,
2939
+ 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
2940
  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, {})] }));
2941
+ 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
2942
+ ? errorMessage
2943
+ : 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
2944
  };
2927
2945
 
2928
2946
  const PageHomeDiscount = () => {
@@ -2945,18 +2963,18 @@ const PageHomeDiscount = () => {
2945
2963
  };
2946
2964
 
2947
2965
  const SectionQuoteEdit$1 = () => {
2948
- const { appConfigState: { localIndex, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
2966
+ const { appConfigState: { localIndex, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
2949
2967
  const { applicantState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
2950
2968
  const { dwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
2951
2969
  const { postalState } = mychoiceSdkStore.useStoreFormHomePostal();
2952
- const { discountState: { multiplePoliciesDiscount, quoterInfo } } = mychoiceSdkStore.useStoreFormHomeDiscount();
2953
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
2970
+ const { discountState: { multiplePoliciesDiscount, quoterInfo }, } = mychoiceSdkStore.useStoreFormHomeDiscount();
2971
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
2954
2972
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
2955
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
2956
- const { item: { postalCode, provinceCode, city, streetAddress, }, } = postalState;
2973
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
2974
+ const { item: { postalCode, provinceCode, city, streetAddress }, } = postalState;
2957
2975
  const { deadbolt, sprinkler, burglarAlarm, fireAlarm, fireExtinguishersCount, // mortgagesCount,
2958
2976
  } = dwellingState;
2959
- const { insured: { nonsmoker } } = applicantState;
2977
+ const { insured: { nonsmoker }, } = applicantState;
2960
2978
  const discounts = [];
2961
2979
  const isHome = insuranceType === mychoiceSdkComponents.InsuranceTypes.Home;
2962
2980
  if (multiplePoliciesDiscount) {
@@ -3001,17 +3019,23 @@ const SectionQuoteEdit$1 = () => {
3001
3019
  const discountEdit = () => () => {
3002
3020
  navigate(`/${localIndex || mychoiceSdkComponents.defaultLocalIndex}/${insuranceType}/discount`);
3003
3021
  };
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] })] })] }));
3022
+ 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: [
3023
+ [
3024
+ `Name: ${quoterInfo?.firstName}`,
3025
+ `Occupied by: ${occupiedMembers}`,
3026
+ `Year Occupied: ${dwellingState.occupiedYear}`,
3027
+ ],
3028
+ ] }), jsxRuntime.jsx(mychoiceSdkComponents.QuoteEdit, { className: isTheBig ? 'thebig-medium' : '', editClick: discountEdit, title: "Discount Information", items: [discounts] })] })] }));
3005
3029
  };
3006
3030
 
3007
3031
  // import { BlockEndorsements } from './blocks/BlockEndorsements';
3008
3032
  const SectionQuoteRecalc = () => {
3009
3033
  const [ppLocalOptions, setPpLocalOptions] = React.useState(mychoiceSdkComponents.ppOptions);
3010
- const { appConfigState: { appType, insuranceType } } = mychoiceSdkStore.useStoreAppConfig();
3034
+ const { appConfigState: { appType, insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
3011
3035
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
3012
- const mychoiceCls = appType === mychoiceSdkComponents.AppTypes.MyChoice ? 'mychoice' : '';
3036
+ const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
3013
3037
  const { dwellingState, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
3014
- const { deductible, liability, waterCoverage, pp, } = dwellingState;
3038
+ const { deductible, liability, waterCoverage, pp } = dwellingState;
3015
3039
  React.useEffect(() => {
3016
3040
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo) {
3017
3041
  setPpLocalOptions(mychoiceSdkComponents.ppOptions.slice(1));
@@ -3044,9 +3068,7 @@ const SectionQuoteRecalc = () => {
3044
3068
  payload: { waterCoverage: value },
3045
3069
  });
3046
3070
  };
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 })] }) })] }) }));
3071
+ 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
3072
  };
3051
3073
 
3052
3074
  const SplashScreen$1 = () => {
@@ -3116,7 +3138,7 @@ const Description = () => (jsxRuntime.jsxs("div", { children: [jsxRuntime.jsx("s
3116
3138
  const SectionCoverage = () => {
3117
3139
  const { coverageState: { type, coverage, province, inValidation }, dispatchCoverageState, } = mychoiceSdkStore.useStoreFormLifeCoverage();
3118
3140
  const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3119
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
3141
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
3120
3142
  // const handleProvinceChange = ({ value }: OnChangeEventInterface) => {
3121
3143
  // dispatchCoverageState({
3122
3144
  // type: StoreFormLifeCoverageActionTypes.FormLifeProvinceSelect,
@@ -3299,10 +3321,9 @@ const SectionApplicant = () => {
3299
3321
  textAlign: 'center',
3300
3322
  fontSize: '1.15rem',
3301
3323
  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
3324
+ }, 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
3325
  ? errorMessage
3304
- : getErrorMessage(email, inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined ||
3305
- (!email && inValidation) }), jsxRuntime.jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsxRuntime.jsx(BlockNextPageInfo, {})] }));
3326
+ : getErrorMessage(email, inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined || (!email && inValidation) }), jsxRuntime.jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsxRuntime.jsx(BlockNextPageInfo, {})] }));
3306
3327
  };
3307
3328
 
3308
3329
  const PageLifeApplicant = () => {
@@ -3415,16 +3436,18 @@ const getFormattedAddress = (unitNumber, streetAddress, city, provinceCode, post
3415
3436
  return '';
3416
3437
  };
3417
3438
  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;
3439
+ const { appModalState: { title, description, submitButtonText, cancelButtonText, submitCallBack, cancelCallBack }, dispatchAppModalState, } = mychoiceSdkStore.useStoreAppModal();
3440
+ const { status, getPostal, errorMessage: reqErrorMessage } = mychoiceSdkStore.useHandlerPostal(mychoiceSdkComponents.InsuranceTypes.Home);
3441
+ const { postalState: { item, inValidation }, dispatchPostalState, } = mychoiceSdkStore.useStoreFormHomePostal();
3442
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3443
+ const { postalCode, city, provinceCode, streetAddress, unitNumber } = item;
3423
3444
  const [localPostalCode, setLocalPostalCode] = React.useState(postalCode);
3424
3445
  const [localUnitNumber, setLocalUnitNumber] = React.useState(unitNumber);
3425
3446
  const [localStreetAddress, setLocalStreetAddress] = React.useState(streetAddress);
3426
3447
  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."' : '';
3448
+ const streetAddressErrMessage = !/\b\s+\b/.test(localStreetAddress)
3449
+ ? 'The street address should be in the format "123 Streetname Rd."'
3450
+ : '';
3428
3451
  const postalCodeErrMessage = localPostalCode.length < 4 ? 'Postal code should have at least 4 characters' : '';
3429
3452
  const handleClick = (callBack) => () => {
3430
3453
  if (callBack) {
@@ -3440,10 +3463,14 @@ const ModalAddress = () => {
3440
3463
  submitCallBack();
3441
3464
  }
3442
3465
  else if (!localPostalCode || !localStreetAddress || streetAddressErrMessage || postalCodeErrMessage) {
3443
- dispatchPostalState({ type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalValidate, payload: { inValidation: true } });
3466
+ dispatchPostalState({
3467
+ type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalValidate,
3468
+ payload: { inValidation: true },
3469
+ });
3444
3470
  }
3445
3471
  else {
3446
- getPostal(mychoiceSdkComponents.postalCodeFormat(localPostalCode)).then((result) => {
3472
+ getPostal(mychoiceSdkComponents.postalCodeFormat(localPostalCode))
3473
+ .then((result) => {
3447
3474
  const formattedAddress = getFormattedAddress(localUnitNumber, localStreetAddress, result?.data?.city || '', result?.data?.provinceCode || '', localPostalCode, 'Canada');
3448
3475
  dispatchPostalState({
3449
3476
  type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalSet,
@@ -3456,7 +3483,8 @@ const ModalAddress = () => {
3456
3483
  },
3457
3484
  });
3458
3485
  dispatchAppModalState({ type: mychoiceSdkStore.StoreConfigAppModalActionTypes.AppModalClose });
3459
- }).catch();
3486
+ })
3487
+ .catch();
3460
3488
  }
3461
3489
  }
3462
3490
  };
@@ -3473,7 +3501,7 @@ const ModalAddress = () => {
3473
3501
  break;
3474
3502
  }
3475
3503
  };
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 })] })] }));
3504
+ 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
3505
  };
3478
3506
 
3479
3507
  const ModalFinale = () => {
@@ -3500,8 +3528,8 @@ PostalCodeDataBox.defaultProps = {
3500
3528
  postalCode: '',
3501
3529
  };
3502
3530
 
3503
- const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3504
- const { appConfigState: { insuranceType, appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
3531
+ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted }) => {
3532
+ const { appConfigState: { insuranceType, appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3505
3533
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3506
3534
  const isMobile = appDeviceType === mychoiceSdkComponents.DeviceTypes.Mobile;
3507
3535
  const navigate = reactRouterDom.useNavigate();
@@ -3513,7 +3541,9 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3513
3541
  const activeStep = formSteps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1));
3514
3542
  let activeIndex = formSteps.indexOf(activeStep);
3515
3543
  activeIndex = activeIndex === -1 ? 0 : activeIndex;
3516
- let navigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
3544
+ let navigationCls = propertyIsCompleted
3545
+ ? 'mychoice-car-navigation-step-container'
3546
+ : 'mychoice-home-navigation-step-container';
3517
3547
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Life) {
3518
3548
  navigationCls = 'mychoice-life-navigation-step-container';
3519
3549
  }
@@ -3527,7 +3557,8 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3527
3557
  // }
3528
3558
  // }, [propertyIsCompleted]);
3529
3559
  const handleStepClick = (item, itemIndex) => () => {
3530
- if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) { // ignore double click
3560
+ if (window.location.pathname !== `/${localIndex}/${insuranceType}${item.path}`) {
3561
+ // ignore double click
3531
3562
  if (activeIndex > (itemIndex || 0)) {
3532
3563
  navigate(`/${localIndex}/${insuranceType}${item?.path}`);
3533
3564
  }
@@ -3543,13 +3574,16 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3543
3574
  validateOptions.forEach((option, index) => {
3544
3575
  const isValid = !option.isValid ? option.validate(false) : option.isValid;
3545
3576
  formValidations.push({
3546
- isValid, validate: option.validate, requestFn: option?.requestFn || undefined, index,
3577
+ isValid,
3578
+ validate: option.validate,
3579
+ requestFn: option?.requestFn || undefined,
3580
+ index,
3547
3581
  });
3548
3582
  });
3549
3583
  }
3550
3584
  const formValidated = formValidations.find((option) => !option.isValid);
3551
3585
  if (formValidated && !formValidated.isValid) {
3552
- navigate(`/${localIndex}/${insuranceType}${formSteps[(formValidated.index || 0)]?.path}`);
3586
+ navigate(`/${localIndex}/${insuranceType}${formSteps[formValidated.index || 0]?.path}`);
3553
3587
  //
3554
3588
  // dispatchAppModalState({
3555
3589
  // type: StoreConfigAppModalActionTypes.AppModalMessageModal,
@@ -3571,7 +3605,7 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3571
3605
  }
3572
3606
  }
3573
3607
  };
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) => {
3608
+ 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
3609
  let cls;
3576
3610
  switch (true) {
3577
3611
  case activeIndex > index:
@@ -3580,16 +3614,15 @@ const StepsBox = ({ formSteps, validationHooks, propertyIsCompleted, }) => {
3580
3614
  case activeIndex === index:
3581
3615
  cls = 'in-progress';
3582
3616
  break;
3583
- default: cls = 'todo';
3617
+ default:
3618
+ cls = 'todo';
3584
3619
  }
3585
3620
  // const homeNavigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
3586
- if (appType === mychoiceSdkComponents.AppTypes.MyChoice && (index === formSteps.length - 1)) {
3621
+ if (mychoiceSdkComponents.isMyChoiceLike(appType) && index === formSteps.length - 1) {
3587
3622
  return jsxRuntime.jsx(jsxRuntime.Fragment, {});
3588
3623
  }
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"] })] })] }))] }));
3624
+ 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}`));
3625
+ }) })) : (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
3626
  };
3594
3627
  StepsBox.defaultProps = {
3595
3628
  partnerId: '',
@@ -3676,7 +3709,7 @@ ButtonsBox.defaultProps = {
3676
3709
 
3677
3710
  const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearForm, propertyIsCompleted, }) => {
3678
3711
  const { pathname } = reactRouterDom.useLocation();
3679
- const { appConfigState: { appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
3712
+ const { appConfigState: { appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3680
3713
  const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
3681
3714
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3682
3715
  const isDesktop = appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop;
@@ -3702,8 +3735,7 @@ const NavigationTop = ({ title, postalCode, validationHooks, formSteps, clearFor
3702
3735
  return `rgba(${r}, ${g}, ${b}, ${alpha})`;
3703
3736
  }
3704
3737
  }
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 })] }) }));
3738
+ 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
3739
  };
3708
3740
  NavigationTop.defaultProps = {
3709
3741
  isMobile: false,
@@ -3714,9 +3746,9 @@ const NavigationBottom = ({ createItem, validateForm, formSteps, className, item
3714
3746
  const { pathname } = reactRouterDom.useLocation();
3715
3747
  const navigate = reactRouterDom.useNavigate();
3716
3748
  const { appConfigState } = mychoiceSdkStore.useStoreAppConfig();
3717
- const isMychoice = appConfigState.appType === mychoiceSdkComponents.AppTypes.MyChoice;
3749
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appConfigState.appType);
3718
3750
  const { insuranceType } = appConfigState;
3719
- const { dwellingState: { isCompleted } } = mychoiceSdkStore.useStoreFormHomeDwelling();
3751
+ const { dwellingState: { isCompleted }, } = mychoiceSdkStore.useStoreFormHomeDwelling();
3720
3752
  const [steps, setSteps] = React.useState(formSteps);
3721
3753
  const currentPath = pathname.split('/');
3722
3754
  const activeIndex = steps.find((step) => currentPath[currentPath.length - 1] === step.path?.substring(1))?.key || 0;
@@ -3950,39 +3982,35 @@ const AppModalWrapper = () => {
3950
3982
  const { appModalState } = mychoiceSdkStore.useStoreAppModal();
3951
3983
  switch (appModalState.modalType) {
3952
3984
  case mychoiceSdkComponents.ModalTypes.MessageModal:
3953
- return (jsxRuntime.jsx(ModalMessage, {}));
3985
+ return jsxRuntime.jsx(ModalMessage, {});
3954
3986
  case mychoiceSdkComponents.ModalTypes.ConfirmModal:
3955
- return (jsxRuntime.jsx(ModalConfirm, {}));
3987
+ return jsxRuntime.jsx(ModalConfirm, {});
3956
3988
  case mychoiceSdkComponents.ModalTypes.PostalModal:
3957
- return (jsxRuntime.jsx(ModalPostal, {}));
3989
+ return jsxRuntime.jsx(ModalPostal, {});
3958
3990
  case mychoiceSdkComponents.ModalTypes.AddressModal:
3959
- return (jsxRuntime.jsx(ModalAddress, {}));
3991
+ return jsxRuntime.jsx(ModalAddress, {});
3960
3992
  case mychoiceSdkComponents.ModalTypes.FinaleModal:
3961
- return (jsxRuntime.jsx(ModalFinale, {}));
3993
+ return jsxRuntime.jsx(ModalFinale, {});
3962
3994
  default:
3963
3995
  return null;
3964
3996
  }
3965
3997
  };
3966
3998
  const AppModal = () => {
3967
3999
  const { appModalState } = mychoiceSdkStore.useStoreAppModal();
3968
- const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
4000
+ const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
3969
4001
  const insuranceType = mychoiceSdkComponents.getInsuranceType();
3970
4002
  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, {}) }));
4003
+ return (jsxRuntime.jsx("div", { className: `app-modal ${mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : ''}`, children: jsxRuntime.jsx(AppModalWrapper, {}) }));
3972
4004
  }
3973
4005
  return null;
3974
4006
  };
3975
4007
 
3976
4008
  const AppHeader = () => {
3977
- const { appConfigState: { appType, localIndex } } = mychoiceSdkStore.useStoreAppConfig();
4009
+ const { appConfigState: { appType, localIndex }, } = mychoiceSdkStore.useStoreAppConfig();
3978
4010
  const { appDeviceType } = mychoiceSdkStore.useStoreDeviceType();
3979
4011
  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, {}) })))] }));
4012
+ 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 &&
4013
+ (localIndex !== mychoiceSdkComponents.defaultLocalIndex ? (jsxRuntime.jsx(HeaderPartner, {})) : (jsxRuntime.jsx(jsxRuntime.Fragment, { children: appDeviceType === mychoiceSdkComponents.DeviceTypes.Desktop ? jsxRuntime.jsx(HeaderMyChoice, {}) : jsxRuntime.jsx(HeaderMyChoiceMobile, {}) })))] }));
3986
4014
  }
3987
4015
  return null;
3988
4016
  };
@@ -4082,7 +4110,7 @@ const AppRouteWrapper = (props) => {
4082
4110
  let postalCode = carPostal;
4083
4111
  const { clearFormData, checkIsExpired, checkIsExpiredWithModal } = mychoiceSdkStore.ClearFormDataHandler();
4084
4112
  const { appLoaderState } = mychoiceSdkStore.useStoreAppLoader();
4085
- const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
4113
+ const isMychoice = mychoiceSdkComponents.isMyChoiceLike(appType);
4086
4114
  switch (insuranceType) {
4087
4115
  case mychoiceSdkComponents.InsuranceTypes.Car:
4088
4116
  postalCode = carPostal;
@@ -4347,7 +4375,7 @@ const AppRouteWrapper = (props) => {
4347
4375
  }
4348
4376
  }
4349
4377
  }, [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, {})] })) }));
4378
+ 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
4379
  };
4352
4380
  const NestedRoutes = () => {
4353
4381
  const insuranceType = mychoiceSdkComponents.getInsuranceType();
@@ -4489,7 +4517,7 @@ const AppConfig = (props) => {
4489
4517
  // home insurance steps states
4490
4518
  const { dispatchPostalState: dispatchHomePostalState } = mychoiceSdkStore.useStoreFormHomePostal();
4491
4519
  const { dispatchApplicantBaseState } = mychoiceSdkStore.useStoreFormHomeApplicantBase();
4492
- const { dwellingState: { isCompleted }, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
4520
+ const { dwellingState: { isCompleted }, dispatchDwellingState, } = mychoiceSdkStore.useStoreFormHomeDwelling();
4493
4521
  const { dispatchDiscountState: dispatchHomeDiscountState } = mychoiceSdkStore.useStoreFormHomeDiscount();
4494
4522
  const { dispatchQuoteState: dispatchHomeQuoteState } = mychoiceSdkStore.useStoreFormHomeQuote();
4495
4523
  // life insurance
@@ -4548,8 +4576,7 @@ const AppConfig = (props) => {
4548
4576
  if (authHandler.status === mychoiceSdkComponents.RequestStatusTypes.Waiting) {
4549
4577
  authHandler.checkUser();
4550
4578
  }
4551
- if (authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Waiting
4552
- && authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Loading) {
4579
+ if (authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Waiting && authHandler.status !== mychoiceSdkComponents.RequestStatusTypes.Loading) {
4553
4580
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Car) {
4554
4581
  dispatchCarPostalState({
4555
4582
  type: mychoiceSdkStore.StoreFormCarPostalActionTypes.FormCarPostalGetLocal,
@@ -4579,7 +4606,9 @@ const AppConfig = (props) => {
4579
4606
  type: mychoiceSdkStore.StoreFormCarQuoteActionTypes.FormCarQuoteGetLocal,
4580
4607
  });
4581
4608
  }
4582
- if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home || insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo || insuranceType === mychoiceSdkComponents.InsuranceTypes.Tenant) {
4609
+ if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home ||
4610
+ insuranceType === mychoiceSdkComponents.InsuranceTypes.Condo ||
4611
+ insuranceType === mychoiceSdkComponents.InsuranceTypes.Tenant) {
4583
4612
  dispatchHomePostalState({
4584
4613
  type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalGetLocal,
4585
4614
  });
@@ -4630,6 +4659,14 @@ const AppConfig = (props) => {
4630
4659
  payload: true,
4631
4660
  });
4632
4661
  }
4662
+ if (appType === mychoiceSdkComponents.AppTypes.BeginInsurance) {
4663
+ // Begin Insurance brand colors: Navy Blue primary, Green accent
4664
+ setExternalColors('#0F2043', '#50C878');
4665
+ dispatchAppConfigState({
4666
+ type: mychoiceSdkStore.StoreConfigAppConfigActionTypes.AppConfigSetPreloaded,
4667
+ payload: true,
4668
+ });
4669
+ }
4633
4670
  }, [appType]);
4634
4671
  React.useEffect(() => {
4635
4672
  if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Home && isCompleted) {
@@ -4686,6 +4723,8 @@ AppWrapper.defaultProps = {
4686
4723
 
4687
4724
  exports.AppWrapper = AppWrapper;
4688
4725
  exports.DateSelectFormBox = DateSelectFormBox;
4726
+ exports.HeaderBeginInsurance = HeaderBeginInsurance;
4727
+ exports.HeaderBeginInsuranceMobile = HeaderBeginInsuranceMobile;
4689
4728
  exports.HeaderMyChoice = HeaderMyChoice;
4690
4729
  exports.HeaderMyChoiceMobile = HeaderMyChoiceMobile;
4691
4730
  exports.HeaderPartner = HeaderPartner;