@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 +254 -215
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/insurances/car/pages/quote/sections/VehicleOfferCoverage.d.ts +3 -0
- package/dist/cjs/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverage.d.ts +9 -0
- package/dist/cjs/shared/headers/HeaderDesktop/BeginInsurance.d.ts +3 -0
- package/dist/cjs/shared/headers/HeaderDesktop/index.d.ts +1 -0
- package/dist/cjs/shared/headers/HeaderMobile/BeginInsurance.d.ts +3 -0
- package/dist/cjs/shared/headers/HeaderMobile/index.d.ts +1 -0
- package/dist/esm/index.js +254 -217
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/insurances/car/pages/quote/sections/VehicleOfferCoverage.d.ts +3 -0
- package/dist/esm/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverage.d.ts +9 -0
- package/dist/esm/shared/headers/HeaderDesktop/BeginInsurance.d.ts +3 -0
- package/dist/esm/shared/headers/HeaderDesktop/index.d.ts +1 -0
- package/dist/esm/shared/headers/HeaderMobile/BeginInsurance.d.ts +3 -0
- package/dist/esm/shared/headers/HeaderMobile/index.d.ts +1 -0
- package/dist/index.d.ts +5 -1
- package/package.json +4 -4
package/dist/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
|
|
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 =
|
|
29
|
-
return (jsxRuntime.jsxs("div", { className: `label-container ${className}`, children: [jsxRuntime.jsx(mychoiceSdkComponents.TitleForm, { className: isThebig ? 'thebig-medium' : '', title: title, subTitle: subTitle, isActive: isActive }),
|
|
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
|
|
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 =
|
|
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
|
-
|
|
238
|
-
|
|
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 =
|
|
392
|
-
const mychoiceCls =
|
|
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
|
|
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 (
|
|
457
|
+
if (!mychoiceSdkComponents.isMyChoiceLike(appType))
|
|
443
458
|
return null;
|
|
444
|
-
|
|
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: `/${
|
|
451
|
-
[`${mychoiceSdkComponents.InsuranceTypes.Home}`]: [{ name: 'Home', link: `/${
|
|
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
|
-
|
|
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
|
-
|
|
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 ||
|
|
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
|
|
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
|
|
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
|
-
|
|
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') ||
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
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 =
|
|
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 =
|
|
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
|
|
950
|
-
const mychoiceCls =
|
|
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 =
|
|
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
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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
|
|
1150
|
-
|
|
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
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
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
|
|
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 =
|
|
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 =
|
|
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
|
|
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 ?
|
|
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 =
|
|
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, {}),
|
|
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 =
|
|
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
|
|
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 =
|
|
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 =
|
|
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 =
|
|
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
|
|
2322
|
-
const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
|
|
2323
|
-
const mychoiceCls =
|
|
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 =
|
|
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 =
|
|
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
|
|
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 =
|
|
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
|
|
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
|
-
|
|
2848
|
-
|
|
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 =
|
|
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
|
|
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:
|
|
2924
|
-
? errorMessage
|
|
2925
|
-
|
|
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 =
|
|
2956
|
-
const { item: { postalCode, provinceCode, city, streetAddress
|
|
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: [
|
|
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 =
|
|
3036
|
+
const mychoiceCls = mychoiceSdkComponents.isMyChoiceLike(appType) ? 'mychoice' : '';
|
|
3013
3037
|
const { dwellingState, dispatchDwellingState } = mychoiceSdkStore.useStoreFormHomeDwelling();
|
|
3014
|
-
const { deductible, liability, waterCoverage, pp
|
|
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 =
|
|
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:
|
|
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
|
|
3419
|
-
const { status, getPostal, errorMessage: reqErrorMessage
|
|
3420
|
-
const { postalState: { item, inValidation }, dispatchPostalState } = mychoiceSdkStore.useStoreFormHomePostal();
|
|
3421
|
-
const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
|
|
3422
|
-
const { postalCode, city, provinceCode, streetAddress, unitNumber
|
|
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)
|
|
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({
|
|
3466
|
+
dispatchPostalState({
|
|
3467
|
+
type: mychoiceSdkStore.StoreFormHomePostalActionTypes.FormHomePostalValidate,
|
|
3468
|
+
payload: { inValidation: true },
|
|
3469
|
+
});
|
|
3444
3470
|
}
|
|
3445
3471
|
else {
|
|
3446
|
-
getPostal(mychoiceSdkComponents.postalCodeFormat(localPostalCode))
|
|
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
|
-
})
|
|
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 ${
|
|
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
|
|
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}`) {
|
|
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,
|
|
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[
|
|
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:
|
|
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:
|
|
3617
|
+
default:
|
|
3618
|
+
cls = 'todo';
|
|
3584
3619
|
}
|
|
3585
3620
|
// const homeNavigationCls = propertyIsCompleted ? 'mychoice-car-navigation-step-container' : 'mychoice-home-navigation-step-container';
|
|
3586
|
-
if (
|
|
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:
|
|
3590
|
-
|
|
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 ${
|
|
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
|
|
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
|
|
3985
|
+
return jsxRuntime.jsx(ModalMessage, {});
|
|
3954
3986
|
case mychoiceSdkComponents.ModalTypes.ConfirmModal:
|
|
3955
|
-
return
|
|
3987
|
+
return jsxRuntime.jsx(ModalConfirm, {});
|
|
3956
3988
|
case mychoiceSdkComponents.ModalTypes.PostalModal:
|
|
3957
|
-
return
|
|
3989
|
+
return jsxRuntime.jsx(ModalPostal, {});
|
|
3958
3990
|
case mychoiceSdkComponents.ModalTypes.AddressModal:
|
|
3959
|
-
return
|
|
3991
|
+
return jsxRuntime.jsx(ModalAddress, {});
|
|
3960
3992
|
case mychoiceSdkComponents.ModalTypes.FinaleModal:
|
|
3961
|
-
return
|
|
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 ${
|
|
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
|
-
|
|
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 =
|
|
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 &&
|
|
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 ||
|
|
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;
|