@mychoice/mychoice-sdk-modules 2.1.38 → 2.1.40
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 +70 -13
- package/dist/cjs/index.js.map +1 -1
- package/dist/esm/index.js +71 -14
- package/dist/esm/index.js.map +1 -1
- package/package.json +4 -4
package/dist/cjs/index.js
CHANGED
|
@@ -1787,7 +1787,7 @@ const SectionQuoteRecalc$1 = () => {
|
|
|
1787
1787
|
return (jsxRuntime.jsxs("div", { className: "form-container", children: [jsxRuntime.jsx(TabVehicle, { readOnly: true }), jsxRuntime.jsxs("div", { className: `form-section edit-recalc-container ${mychoiceCls}`, children: [jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.coverageOptions, name: "comprehensive-coverage", onChange: handleComprehensiveChange, defaultValue: getSelectedOption(mychoiceSdkComponents.coverageOptions, comprehensive.coverage ? comprehensive.deductible : 0), title: "Comprehensive coverage", description: "This deductible is the amount of money that you will pay out of your own pocket if your vehicle is damaged in events not covered by collision coverage. This includes events such as falling or flying objects, vandalism, and theft. Your insurance company covers the cost of repair minus the deductible chosen.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.coverageOptions, name: "collision-coverage", onChange: handleCollisionChange, defaultValue: getSelectedOption(mychoiceSdkComponents.coverageOptions, collision.coverage ? collision.deductible : 0), title: "Collision coverage", description: "This deductible is the specific dollar amount you will pay out of your own pocket if your vehicle is damaged in an accident. Your insurance company covers the remaining amount.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.liabilityOptions, name: "liability-limit", onChange: handleLiabilityChange, defaultValue: getSelectedOption(mychoiceSdkComponents.liabilityOptions, liability.coverage ? liability.limit : 1000000), title: "Third Party Liability", description: "This protects you from lawsuits resulting from accidents causing bodily injury or death to others or property damage.", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false }), jsxRuntime.jsx(BlockSubmit$2, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} recalculate`, label: "Recalculate Quote", buttonSize: mychoiceSdkComponents.SizeTypes.Medium, isRecalc: true }), isTheBig && jsxRuntime.jsx(BlockEndorsements, {})] })] }));
|
|
1788
1788
|
};
|
|
1789
1789
|
|
|
1790
|
-
const lockEmoji = '\u{1F512}';
|
|
1790
|
+
const lockEmoji$1 = '\u{1F512}';
|
|
1791
1791
|
const savedPercentage = lodash.random(25, 30);
|
|
1792
1792
|
const SectionConfirm = () => {
|
|
1793
1793
|
const { discountState, dispatchDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
|
|
@@ -1840,7 +1840,7 @@ const SectionConfirm = () => {
|
|
|
1840
1840
|
};
|
|
1841
1841
|
if (!bestQuote)
|
|
1842
1842
|
return null;
|
|
1843
|
-
return (jsxRuntime.jsxs("div", { style: { zIndex: '1' }, children: [jsxRuntime.jsxs("div", { className: "shadow-box", children: [jsxRuntime.jsx("div", { className: "highlighted-heading", children: "Best Offer" }), jsxRuntime.jsx("h1", { children: `$${bestQuote.priceMonthly} / month` }), jsxRuntime.jsx("div", { className: "highlighted-heading", children: jsxRuntime.jsx("span", { children: `$${bestQuote.priceYearly} / year` }) })] }), jsxRuntime.jsxs("div", { className: "statistics-wrapper", children: [jsxRuntime.jsx("div", { className: "counter", id: "output", children: comparedCountMin.toLocaleString('en-US') }), jsxRuntime.jsx("div", { className: "divider" }), jsxRuntime.jsx("div", { style: { textAlign: 'center', fontSize: '1.15rem', marginTop: '10px' }, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsxRuntime.jsx("div", { style: { marginBottom: '2rem' }, children: jsxRuntime.jsx("div", { className: "all-quotes-form", children: jsxRuntime.jsx("h2", { style: { whiteSpace: 'normal', marginTop: '20px', textAlign: 'center' }, children: `${lockEmoji} Complete the form below to see which companies are offering your quotes.` }) }) }), jsxRuntime.jsx("div", { style: { marginBottom: '1rem' }, children: 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("div", { style: { marginBottom: '1rem' }, children: 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("div", { style: { marginBottom: '1rem' }, children: jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(111) 111-1111", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }) }), jsxRuntime.jsx("div", { className: "submit-wrapper", children: jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { className: "mychoice", size: mychoiceSdkComponents.SizeTypes.Large, category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleSubmit, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Get Your Quote" }) }), jsxRuntime.jsxs("div", { className: "extra-info", children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsx("div", { className: "next-page-points", children: jsxRuntime.jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "1" }), jsxRuntime.jsx("div", { children: "See what rates insurance carriers are offering" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "2" }), jsxRuntime.jsx("div", { children: "Get in touch with a broker and secure your rate" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "3" }), jsxRuntime.jsx("div", { children: "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" }), "."] }) })] })] }));
|
|
1843
|
+
return (jsxRuntime.jsxs("div", { style: { zIndex: '1' }, children: [jsxRuntime.jsxs("div", { className: "shadow-box", children: [jsxRuntime.jsx("div", { className: "highlighted-heading", children: "Best Offer" }), jsxRuntime.jsx("h1", { children: `$${bestQuote.priceMonthly} / month` }), jsxRuntime.jsx("div", { className: "highlighted-heading", children: jsxRuntime.jsx("span", { children: `$${bestQuote.priceYearly} / year` }) })] }), jsxRuntime.jsxs("div", { className: "statistics-wrapper", children: [jsxRuntime.jsx("div", { className: "counter", id: "output", children: comparedCountMin.toLocaleString('en-US') }), jsxRuntime.jsx("div", { className: "divider" }), jsxRuntime.jsx("div", { style: { textAlign: 'center', fontSize: '1.15rem', marginTop: '10px' }, children: `Canadians have compared rates in the last 24 hours and saved ${savedPercentage}% on average` })] }), jsxRuntime.jsx("div", { style: { marginBottom: '2rem' }, children: jsxRuntime.jsx("div", { className: "all-quotes-form", children: jsxRuntime.jsx("h2", { style: { whiteSpace: 'normal', marginTop: '20px', textAlign: 'center' }, children: `${lockEmoji$1} Complete the form below to see which companies are offering your quotes.` }) }) }), jsxRuntime.jsx("div", { style: { marginBottom: '1rem' }, children: 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("div", { style: { marginBottom: '1rem' }, children: 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("div", { style: { marginBottom: '1rem' }, children: jsxRuntime.jsx(InputFormPhoneBox, { name: "phone", onChange: handlePhoneNumberChange, defaultValue: phone, title: "Phone Number", placeholder: "(111) 111-1111", error: !phone && discountState.inValidation, errorMessage: getErrorMessage(phone, discountState.inValidation) }) }), jsxRuntime.jsx("div", { className: "submit-wrapper", children: jsxRuntime.jsx(mychoiceSdkComponents.ButtonBase, { className: "mychoice", size: mychoiceSdkComponents.SizeTypes.Large, category: mychoiceSdkComponents.CategoryTypes.Filled, onClick: handleSubmit, color: mychoiceSdkComponents.ColorTypes.Primary, label: "Get Your Quote" }) }), jsxRuntime.jsxs("div", { className: "extra-info", children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsx("div", { className: "next-page-points", children: jsxRuntime.jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "1" }), jsxRuntime.jsx("div", { children: "See what rates insurance carriers are offering" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "2" }), jsxRuntime.jsx("div", { children: "Get in touch with a broker and secure your rate" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "3" }), jsxRuntime.jsx("div", { children: "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" }), "."] }) })] })] }));
|
|
1844
1844
|
};
|
|
1845
1845
|
|
|
1846
1846
|
const SplashScreen$2 = () => {
|
|
@@ -2942,6 +2942,7 @@ const PageHomeQuote = () => {
|
|
|
2942
2942
|
const Description = () => (jsxRuntime.jsxs("div", { children: [jsxRuntime.jsx("span", { children: jsxRuntime.jsx("p", { children: "There are two primary categories of life insurance policies: term life insurance and permanent life insurance." }) }), jsxRuntime.jsx("h4", { children: "Term Life Insurance Options" }), jsxRuntime.jsx("h5", { children: "Options include 10, 15, 20, 30-year plans" }), jsxRuntime.jsx("p", { children: "These policies provide coverage for a specific term of either 10, 15, 20, or 30 years. The premiums are consistent throughout the term. At the end of the term, policyholders have the choice to renew or convert their policy." }), jsxRuntime.jsx("h5", { children: "Coverage Until Ages 65, 70, 75" }), jsxRuntime.jsx("p", { children: "These are term life policies that extend coverage until the policyholder reaches the age of 65, 70, or 75. Premiums are consistent for the entirety of the policy's duration. However, renewal options are not available after reaching the specified age." }), jsxRuntime.jsx("h5", { children: "Coverage Until Age 100" }), jsxRuntime.jsx("p", { children: "Although it's sometimes categorized as a permanent life insurance plan, the Term to 100 plan is, in fact, a term life policy. This plan offers coverage until the policyholder reaches the age of 100 and cannot be renewed." }), jsxRuntime.jsx("h4", { children: "Permanent Life Insurance Options" }), jsxRuntime.jsx("h5", { children: "Universal Life Insurance" }), jsxRuntime.jsx("p", { children: "This policy is valid for the entirety of the policyholder's life and includes a cash value component. The premium can be modified by reducing the death benefit or utilizing the cash value within the plan. The premiums for this type of plan are typically higher than those for term life insurance." }), jsxRuntime.jsx("h5", { children: "Whole Life Insurance" }), jsxRuntime.jsx("p", { children: "This is a lifetime policy where the premiums are fixed and never increase (without exception). The policy also has a cash value feature, which the policyholder can borrow against in a tax-free manner. Similar to universal life insurance, the premiums for whole life insurance are generally higher than those for term life insurance." })] }));
|
|
2943
2943
|
const SectionCoverage = () => {
|
|
2944
2944
|
const { coverageState: { type, coverage, province, inValidation }, dispatchCoverageState, } = mychoiceSdkStore.useStoreFormLifeCoverage();
|
|
2945
|
+
const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
|
|
2945
2946
|
const handleProvinceChange = ({ value }) => {
|
|
2946
2947
|
dispatchCoverageState({
|
|
2947
2948
|
type: mychoiceSdkStore.StoreFormLifeCoverageActionTypes.FormLifeProvinceSelect,
|
|
@@ -2961,7 +2962,8 @@ const SectionCoverage = () => {
|
|
|
2961
2962
|
});
|
|
2962
2963
|
};
|
|
2963
2964
|
const newLifeOptions = mychoiceSdkComponents.lifeInsuranceTypeOptions.filter((option) => option.name.includes('Year Level'));
|
|
2964
|
-
|
|
2965
|
+
const isMychoice = appType === mychoiceSdkComponents.AppTypes.MyChoice;
|
|
2966
|
+
return (jsxRuntime.jsxs("div", { className: "form-section", children: [jsxRuntime.jsx("h2", { className: "section-title", style: { textAlign: 'center' }, children: "Get the coverage you need" }), jsxRuntime.jsx(SelectFormBox, { options: isMychoice ? mychoiceSdkComponents.lifeProvinceOptionsMC : mychoiceSdkComponents.lifeProvinceOptions, name: "province", onChange: handleProvinceChange, defaultValue: province, title: "Province", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !province && inValidation, errorMessage: getErrorMessage(type, inValidation) }), jsxRuntime.jsx(SelectFormBox, { options: newLifeOptions, name: "type", onChange: handleLifeInsuranceTypeChange, defaultValue: type, title: "Type of Insurance", description: jsxRuntime.jsx(Description, {}), placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !type && inValidation, errorMessage: getErrorMessage(type, inValidation) }), jsxRuntime.jsx(SelectFormBox, { options: mychoiceSdkComponents.lifeCoverageOptions, name: "coverage", onChange: handleCoverageChange, defaultValue: coverage, title: "Required coverage", description: "The extent of coverage you need is determined by several factors,\n including your expenditure patterns, anticipated future expenses, yearly earnings,\n and so forth. Generally, individuals opt for a coverage amount that equals five\n times their current annual income before taxes. On an average,\n it is observed that Canadians choose a coverage amount of around $500,000.", placeholder: "Select", autoSelectIfValueIsOutOfOptions: false, error: !coverage && inValidation, errorMessage: getErrorMessage(coverage, inValidation) })] }));
|
|
2965
2967
|
};
|
|
2966
2968
|
|
|
2967
2969
|
const PageCoverage = () => {
|
|
@@ -2974,9 +2976,9 @@ const PageCoverage = () => {
|
|
|
2974
2976
|
};
|
|
2975
2977
|
|
|
2976
2978
|
const BlockNextPageInfo = () => {
|
|
2977
|
-
const { appConfigState: { appType } } = mychoiceSdkStore.useStoreAppConfig();
|
|
2979
|
+
const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
|
|
2978
2980
|
const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
|
|
2979
|
-
return (jsxRuntime.jsx("div", { className: "next-page-info", children: isTheBig ? (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.
|
|
2981
|
+
return (jsxRuntime.jsx("div", { className: "next-page-info", children: isTheBig ? (jsxRuntime.jsx("div", { className: "privacy-policy", children: jsxRuntime.jsxs("p", { children: [jsxRuntime.jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) })) : (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs("div", { className: "extra-info", children: [jsxRuntime.jsx("h5", { children: "On the next page, you will also be able to:" }), jsxRuntime.jsx("div", { className: "next-page-points", children: jsxRuntime.jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "1" }), jsxRuntime.jsx("div", { children: "See what rates insurance carriers are offering" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "2" }), jsxRuntime.jsx("div", { children: "Get in touch with a broker and secure your rate" })] }), jsxRuntime.jsxs("div", { className: "bullet-container", children: [jsxRuntime.jsx("div", { className: "bullet-point", children: "3" }), jsxRuntime.jsx("div", { children: "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.jsxs("a", { href: "https://www.mychoice.ca/privacy-policy/", children: [' ', "Privacy Policy"] }), "."] }) })] })) }));
|
|
2980
2982
|
};
|
|
2981
2983
|
|
|
2982
2984
|
const BlockSubmit = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
@@ -3005,13 +3007,38 @@ BlockSubmit.defaultProps = {
|
|
|
3005
3007
|
className: '',
|
|
3006
3008
|
};
|
|
3007
3009
|
|
|
3010
|
+
const lockEmoji = '\u{1F512}';
|
|
3011
|
+
const getSavedPercentage = () => {
|
|
3012
|
+
const currentDay = new Date().getDate();
|
|
3013
|
+
const options = [25, 26, 27, 28, 29, 30];
|
|
3014
|
+
for (let i = 0; i < options.length; i++) {
|
|
3015
|
+
if (currentDay % options.length === i) {
|
|
3016
|
+
return options[i];
|
|
3017
|
+
}
|
|
3018
|
+
}
|
|
3019
|
+
return 30;
|
|
3020
|
+
};
|
|
3021
|
+
const getInitComparedCount = () => {
|
|
3022
|
+
const currentDay = new Date().getDate();
|
|
3023
|
+
const options = [1003, 1102, 1343, 1412, 1502];
|
|
3024
|
+
for (let i = 0; i < options.length; i++) {
|
|
3025
|
+
if (currentDay % options.length === i) {
|
|
3026
|
+
return options[i];
|
|
3027
|
+
}
|
|
3028
|
+
}
|
|
3029
|
+
return 1102;
|
|
3030
|
+
};
|
|
3008
3031
|
const SectionApplicant = () => {
|
|
3009
|
-
const
|
|
3032
|
+
const initComparedCount = getInitComparedCount();
|
|
3033
|
+
const savedPercentage = getSavedPercentage();
|
|
3034
|
+
const [comparedCountMin, setComparedCountMin] = React.useState(1000);
|
|
3035
|
+
const [comparedCountMax] = React.useState(initComparedCount);
|
|
3036
|
+
const { appConfigState: { appType }, } = mychoiceSdkStore.useStoreAppConfig();
|
|
3010
3037
|
const isTheBig = appType === mychoiceSdkComponents.AppTypes.TheBig;
|
|
3011
3038
|
const { applicantState, dispatchApplicantState } = mychoiceSdkStore.useStoreFormLifeApplicant();
|
|
3012
3039
|
const { validateEmail, errorMessage } = mychoiceSdkStore.useHandlerLifeQuoterEmail();
|
|
3013
3040
|
const { birthYear, birthMonth, birthDay, gender, smoker, quoterInfo, emailTo: { email, emailStatus }, inValidation, } = applicantState;
|
|
3014
|
-
const { firstName, lastName, phone
|
|
3041
|
+
const { firstName, lastName, phone } = quoterInfo || {};
|
|
3015
3042
|
const defaultDateOfBirth = {
|
|
3016
3043
|
day: birthDay,
|
|
3017
3044
|
month: birthMonth,
|
|
@@ -3070,10 +3097,25 @@ const SectionApplicant = () => {
|
|
|
3070
3097
|
const handleEmailChange = ({ value }) => {
|
|
3071
3098
|
validateEmail(value);
|
|
3072
3099
|
};
|
|
3073
|
-
|
|
3074
|
-
|
|
3075
|
-
|
|
3076
|
-
|
|
3100
|
+
React.useEffect(() => {
|
|
3101
|
+
if (comparedCountMin < comparedCountMax) {
|
|
3102
|
+
const intervalId = setInterval(() => {
|
|
3103
|
+
setComparedCountMin((prev) => prev + 1);
|
|
3104
|
+
}, 2.5);
|
|
3105
|
+
return () => {
|
|
3106
|
+
clearInterval(intervalId);
|
|
3107
|
+
};
|
|
3108
|
+
}
|
|
3109
|
+
return () => { };
|
|
3110
|
+
}, [comparedCountMax, comparedCountMin]);
|
|
3111
|
+
return (jsxRuntime.jsxs("div", { className: "form-section", children: [jsxRuntime.jsxs("div", { className: "statistics-wrapper live", children: [jsxRuntime.jsx("div", { className: "counter", id: "output", children: comparedCountMin.toLocaleString('en-US') }), jsxRuntime.jsx("div", { className: "divider" }), jsxRuntime.jsx("div", { style: {
|
|
3112
|
+
textAlign: 'center',
|
|
3113
|
+
fontSize: '1.15rem',
|
|
3114
|
+
marginTop: '10px',
|
|
3115
|
+
}, 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: "johnsmith@mychoice.ca", errorMessage: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined
|
|
3116
|
+
? errorMessage
|
|
3117
|
+
: getErrorMessage(email, inValidation), error: emailStatus === mychoiceSdkComponents.ValidationStatusTypes.Declined ||
|
|
3118
|
+
(!email && inValidation) }), jsxRuntime.jsx(BlockSubmit, { className: isTheBig ? 'thebig-bold' : '' }), jsxRuntime.jsx(BlockNextPageInfo, {})] }));
|
|
3077
3119
|
};
|
|
3078
3120
|
|
|
3079
3121
|
const PageLifeApplicant = () => {
|
|
@@ -3686,7 +3728,23 @@ var Caa = "
|
|
|
3686
3728
|
|
|
3687
3729
|
var Coachman = "";
|
|
3688
3730
|
|
|
3689
|
-
const ProviderImageFooter = () => (jsxRuntime.jsxs("div", { className: "footer-image-section", children: [jsxRuntime.jsx("div", { className: "providers-title", children: "We compare rates from Canada's top providers, including:" }), jsxRuntime.jsxs("div", { className: "providers-carousel", children: [jsxRuntime.jsx("img", { height: "70", src: SGICanada, alt: "S.G.I. Canada" }), jsxRuntime.jsx("img", { height: "70", src: Onlia, alt: "Onlia Insurance" }), jsxRuntime.jsx("img", { height: "70", src: Economical, alt: "Economical insurance" }), jsxRuntime.jsx("img", { height: "70", src: Caa, alt: "CAA" }), jsxRuntime.jsx("img", { height: "70", src: Coachman, alt: "Coachman" })] })] }));
|
|
3731
|
+
var SunLife = "";
|
|
3732
|
+
|
|
3733
|
+
var Manulife = "";
|
|
3734
|
+
|
|
3735
|
+
var IAFinancialGroup = "";
|
|
3736
|
+
|
|
3737
|
+
var Desjardins = "";
|
|
3738
|
+
|
|
3739
|
+
var CanadaLife = "";
|
|
3740
|
+
|
|
3741
|
+
const ProviderImageFooter = () => {
|
|
3742
|
+
const { appConfigState: { insuranceType }, } = mychoiceSdkStore.useStoreAppConfig();
|
|
3743
|
+
if (insuranceType === mychoiceSdkComponents.InsuranceTypes.Life) {
|
|
3744
|
+
return (jsxRuntime.jsxs("div", { className: "footer-image-section", children: [jsxRuntime.jsx("div", { className: "providers-title", children: "We compare rates from Canada's top providers, including:" }), jsxRuntime.jsxs("div", { className: "providers-carousel life", children: [jsxRuntime.jsx("img", { height: "60", src: SunLife, alt: "Sun Life" }), jsxRuntime.jsx("img", { height: "60", src: Manulife, alt: "Manulife" }), jsxRuntime.jsx("img", { height: "60", src: IAFinancialGroup, alt: "iA Financial Group" }), jsxRuntime.jsx("img", { height: "60", src: Desjardins, alt: "Desjardins" }), jsxRuntime.jsx("img", { height: "60", src: CanadaLife, alt: "Canada Life" })] })] }));
|
|
3745
|
+
}
|
|
3746
|
+
return (jsxRuntime.jsxs("div", { className: "footer-image-section", children: [jsxRuntime.jsx("div", { className: "providers-title", children: "We compare rates from Canada's top providers, including:" }), jsxRuntime.jsxs("div", { className: "providers-carousel", children: [jsxRuntime.jsx("img", { height: "70", src: SGICanada, alt: "S.G.I. Canada" }), jsxRuntime.jsx("img", { height: "70", src: Onlia, alt: "Onlia Insurance" }), jsxRuntime.jsx("img", { height: "70", src: Economical, alt: "Economical insurance" }), jsxRuntime.jsx("img", { height: "70", src: Caa, alt: "CAA" }), jsxRuntime.jsx("img", { height: "70", src: Coachman, alt: "Coachman" })] })] }));
|
|
3747
|
+
};
|
|
3690
3748
|
|
|
3691
3749
|
const AppModalWrapper = () => {
|
|
3692
3750
|
const { appModalState } = mychoiceSdkStore.useStoreAppModal();
|
|
@@ -4110,7 +4168,6 @@ const NestedRoutes = () => {
|
|
|
4110
4168
|
};
|
|
4111
4169
|
const RedirectWithSearchParams = ({ to, path, }) => {
|
|
4112
4170
|
const insuranceType = mychoiceSdkComponents.getInsuranceType();
|
|
4113
|
-
mychoiceSdkStore.useStoreAppConfig();
|
|
4114
4171
|
const [isRender, setIsRender] = React.useState(false);
|
|
4115
4172
|
const { getPostal } = mychoiceSdkStore.useHandlerPostal(insuranceType);
|
|
4116
4173
|
const { dispatchDiscountState: dispatchCarDiscountState } = mychoiceSdkStore.useStoreFormCarDiscount();
|