@mychoice/mychoice-sdk-modules 2.1.67 → 2.1.69
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 +243 -124
- 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/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverages.d.ts +7 -0
- package/dist/cjs/shared/boxes/SelectFormBox/interface.d.ts +2 -1
- package/dist/cjs/shared/sections/quotes/interfaces.d.ts +3 -0
- package/dist/esm/index.js +245 -126
- 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/insurances/car/pages/quote/sections/blocks/VehicleOfferCoverages.d.ts +7 -0
- package/dist/esm/shared/boxes/SelectFormBox/interface.d.ts +2 -1
- package/dist/esm/shared/sections/quotes/interfaces.d.ts +3 -0
- package/dist/index.d.ts +5 -1
- package/package.json +4 -4
package/dist/esm/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
2
2
|
import { ErrorBoundary } from 'react-error-boundary';
|
|
3
|
-
import { AppTypes, TitleForm, TooltipForm, IconDelete, ColorVariablesTypes, InputTypes, InputForm, InputFormPhone, InputFormEmail, InputFormLicence, SelectForm, getFormattedDate, DateTypes, getDateOptions, ButtonForm,
|
|
4
|
-
import { useStoreAppConfig, CarQuoteDataHandler, useStorePartner, useStoreDeviceType, useStoreAppLoader, useStoreAppModal, StoreConfigAppModalActionTypes, useHandlerPostal, useHandlerCarMake, useHandlerCarModel,
|
|
3
|
+
import { AppTypes, TitleForm, TooltipForm, IconDelete, ColorVariablesTypes, InputTypes, InputForm, InputFormPhone, InputFormEmail, InputFormLicence, SelectForm, getFormattedDate, DateTypes, getDateOptions, ButtonForm, defaultBrokerPhone, DriverPriorityTypes, SizeTypes, ButtonBase, CategoryTypes, ColorTypes, defaultLocalIndex, liabilityOptions, coverageOptions, lossOfUseOptions, liabilityForDamageOptions, limitedWaiverOfDepreciationOptions, OfferHeader, OfferPrice, ButtonTypes, ButtonVariantTypes, IconDropdownArrow, OfferDetail, CompanyRoleTypes, OperationHoursInfo, InsuranceTypes, HeaderNavGroup, ButtonMenu, DeviceTypes, IconLoaderPrimary, getInsuranceType, RequestStatusTypes, formatPostalCode, IconLoaderSecondary, postalCodeFormat, useEffectOnce, carCondition, carStatus, carWinterTiresCheck, carKeepPlace, carUsagePurpose, firstDriveDistanceList, dailyDriveBusinessDistanceList, yearlyDriveDistanceList, numberWithCommas, VehiclePrimaryUseTypes, comprehensiveCoverage, collisionCoverage, maritalStatusOptions, subYearsFromDate, occupationOptions, genderOptions, applicantRelationshipOptions, addYearsToDate, checkDateIsSpecial, DriverLicenceTypes, getDifferenceInYears, getLicenceTypeOptions, getDisabledLicenceTypes, yesNoOptions, addDaysToDate, getMinDate, CheckboxForm, getMinDateByYears, compareDates, insuranceCancellationReasonOptions, DriverListTypes, licenceSuspensionsReasonOptions, trafficTicketsGroupOptions, ValidationStatusTypes, QuoteEdit, homeOwnerTypeOptions, tenantBuildingStructureOptions, condoBuildingStructureOptions, homeBuildingStructureOptions, residentsOptions, insuredYearsOptions, getInsuranceYearsOptions, ApplicantListTypes, claimTypeOptions, exteriorFinishOptions, constructionTypeOptions, garageTypeOptions, getNumericOptions, fireHallDistanceOptions, fireHydrantDistanceOptions, primaryHeatingTypeOptions, auxHeatingTypeOptions, InfoMessage, ppOptions, homeCoverageOptions, homeLiabilityOptions, lifeInsuranceTypeOptions, lifeInsuranceOntarioTypeOptions, lifeCoverageOptions, smokerOptions, MychoiceStep, Step, IconClock, ButtonArrow, DirectionTypes, ButtonTabArrow, ButtonTab, ButtonTabMobile, NavigationCar, NavigationPerson, NavigationDiscount, NavigationQuotes, NavigationAddress, NavigationProperty, ModalTypes } from '@mychoice/mychoice-sdk-components';
|
|
4
|
+
import { useStoreAppConfig, useStoreFormCarVehicle, useStoreFormCarDriverBase, useStoreFormCarDiscount, StoreFormCarDiscountActionTypes, useStoreFormCarQuote, CarQuoteDataHandler, useValidationCarDiscount, StoreFormCarVehicleActionTypes, useStorePartner, useStoreDeviceType, useStoreAppLoader, useStoreAppModal, StoreConfigAppModalActionTypes, useHandlerPostal, useHandlerCarMake, useHandlerCarModel, useProvince, useValidationVehicle, StoreFormCarDriverBaseActionTypes, useStoreFormCarConfig, useStoreFormCarDriverInfo, StoreFormCarDriverInfoActionTypes, useStoreFormCarDriverLicence, addDayToDate, StoreFormCarDriverLicenceActionTypes, useStoreFormCarDriverInsurance, StoreFormCarDriverInsuranceActionTypes, useStoreFormCarDriverCancellation, StoreFormCarDriverCancellationActionTypes, useStoreFormCarDriverSuspension, StoreFormCarDriverSuspensionActionTypes, useStoreFormCarDriverAccident, StoreFormCarDriverAccidentActionTypes, useStoreFormCarDriverTicket, StoreFormCarDriverTicketActionTypes, useValidationDriver, useHandlerCarQuoterEmail, useStoreFormHomeDwelling, useStoreFormHomePostal, useStoreFormHomeApplicantBase, StoreFormHomePostalActionTypes, StoreFormHomeDwellingActionTypes, StoreConfigAppConfigActionTypes, StoreFormHomeApplicantBaseActionTypes, useValidationAddress, useStoreFormHomeApplicantInfo, useStoreFormHomeDiscount, StoreFormHomeDiscountActionTypes, StoreFormHomeApplicantInfoActionTypes, useStoreFormHomeApplicantInsurance, StoreFormHomeApplicantInsuranceActionTypes, useStoreFormHomeApplicantCancellation, StoreFormHomeApplicantCancellationActionTypes, useStoreFormHomeApplicantClaim, StoreFormHomeApplicantClaimActionTypes, useValidationApplicant, useValidationDwelling, useStoreFormHomeQuote, HomeQuoteDataHandler, useValidationHomeDiscount, useHandlerHomeQuoterEmail, useStoreFormLifeCoverage, StoreFormLifeCoverageActionTypes, useValidationCoverage, useStoreFormLifeQuote, useStoreFormLifeApplicant, LifeQuoteDataHandler, useValidationLifeApplicant, useHandlerLifeQuoterEmail, StoreFormLifeApplicantActionTypes, useStoreFormCarPostal, useStoreFormLifePostal, ClearFormDataHandler, useStoreAppDevice, useStoreClient, useHandlerAuth, useHandlerPartner, StoreConfigAppLoaderActionTypes, StoreFormCarConfigActionTypes, StoreFormCarPostalActionTypes, StoreFormCarQuoteActionTypes, StoreFormHomeQuoteActionTypes, StoreFormLifePostalActionTypes, StoreFormLifeQuoteActionTypes, StoreClientActionTypes, StoreConfigAppDeviceActionTypes, StoreProvider, initHttpResponse } from '@mychoice/mychoice-sdk-store';
|
|
5
5
|
import { useNavigate, useLocation, BrowserRouter, Routes, Route, Navigate } from 'react-router-dom';
|
|
6
6
|
import React, { useState, useCallback, useEffect, useRef, useMemo } from 'react';
|
|
7
7
|
import { random } from 'lodash';
|
|
@@ -77,8 +77,8 @@ InputFormLicenceBox.defaultProps = {
|
|
|
77
77
|
};
|
|
78
78
|
|
|
79
79
|
const SelectFormBox = (props) => {
|
|
80
|
-
const { className, defaultValue, disabled, error, name, title, description, onChange, errorMessage, hintMessage, isRemovable, onIconClick, options, groupOptions, placeholder, autoSelectIfValueIsOutOfOptions, } = props;
|
|
81
|
-
return (jsx(Container, { name: name, className: ` ${className} ${error ? 'error' : ''}`, title: title, description: description, errorMessage: errorMessage, hintMessage: hintMessage, isRemovable: isRemovable, onIconClick: onIconClick, children: jsx(SelectForm, { className: "input-form", name: name, defaultValue: defaultValue, onChange: onChange, options: options || [], groupOptions: groupOptions || [], placeholder: placeholder, disabled: disabled, autoSelectIfValueIsOutOfOptions: autoSelectIfValueIsOutOfOptions, error: error }) }));
|
|
80
|
+
const { className, defaultValue, disabled, error, name, title, description, onChange, errorMessage, hintMessage, isRemovable, onIconClick, options, groupOptions, placeholder, autoSelectIfValueIsOutOfOptions, size, } = props;
|
|
81
|
+
return (jsx(Container, { name: name, className: ` ${className} ${error ? 'error' : ''}`, title: title, description: description, errorMessage: errorMessage, hintMessage: hintMessage, isRemovable: isRemovable, onIconClick: onIconClick, children: jsx(SelectForm, { className: "input-form", name: name, defaultValue: defaultValue, onChange: onChange, options: options || [], groupOptions: groupOptions || [], placeholder: placeholder, disabled: disabled, autoSelectIfValueIsOutOfOptions: autoSelectIfValueIsOutOfOptions, error: error, size: size }) }));
|
|
82
82
|
};
|
|
83
83
|
SelectFormBox.defaultProps = {
|
|
84
84
|
className: '',
|
|
@@ -139,10 +139,246 @@ SwitchButtonBox.defaultProps = {
|
|
|
139
139
|
items: [],
|
|
140
140
|
};
|
|
141
141
|
|
|
142
|
-
const
|
|
142
|
+
const getSelectedOption = (options, val) => {
|
|
143
|
+
if (typeof val === 'boolean') {
|
|
144
|
+
return options.find(({ value }) => val === value)?.value || false;
|
|
145
|
+
}
|
|
146
|
+
if (typeof val === 'number') {
|
|
147
|
+
return options.find((option) => option.value?.toString() === val.toString())?.value;
|
|
148
|
+
}
|
|
149
|
+
return options.find((option) => option.value === val)?.value;
|
|
150
|
+
};
|
|
151
|
+
const getErrorMessage = (value, inValidation = false, message = '') => {
|
|
152
|
+
if (inValidation) {
|
|
153
|
+
if (value === null) {
|
|
154
|
+
return 'This field is required.';
|
|
155
|
+
}
|
|
156
|
+
if (typeof value === 'boolean') {
|
|
157
|
+
return '';
|
|
158
|
+
}
|
|
159
|
+
return !value ? 'This field is required.' : message;
|
|
160
|
+
}
|
|
161
|
+
return '';
|
|
162
|
+
};
|
|
163
|
+
const getDateErrorMessage = (values, inValidation = false) => {
|
|
164
|
+
const emptyValues = values.filter((value) => !value);
|
|
165
|
+
if (inValidation) {
|
|
166
|
+
if (emptyValues.length > 1) {
|
|
167
|
+
return 'These fields are required.';
|
|
168
|
+
}
|
|
169
|
+
if (emptyValues.length === 1) {
|
|
170
|
+
return 'This field is required.';
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
return '';
|
|
174
|
+
};
|
|
175
|
+
const formatPhoneObject = (phone) => {
|
|
176
|
+
const phoneToArray = (phone || defaultBrokerPhone).split(',');
|
|
177
|
+
const onlyNumbers = phoneToArray[0].replace(/\D/g, '');
|
|
178
|
+
let phoneNumber;
|
|
179
|
+
if (onlyNumbers.length < 11) {
|
|
180
|
+
phoneNumber = `1${onlyNumbers}`;
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
phoneNumber = onlyNumbers;
|
|
184
|
+
}
|
|
185
|
+
const phoneToNumbers = Number(phoneNumber).toString();
|
|
186
|
+
const phoneWithoutSpecialKey = phoneToNumbers.length > 10
|
|
187
|
+
? phoneToNumbers.replace(/(\d{1})(\d{3})(\d{3})(\d{4})/, '$1-$2-$3-$4')
|
|
188
|
+
: phoneToNumbers.replace(/(\d{1})(\d{3})(\d{3})(\d{3})/, '$1-$2-$3-$4');
|
|
189
|
+
const title = phoneToArray.length < 2 ? phoneWithoutSpecialKey : `${phoneWithoutSpecialKey} x${phoneToArray[1]}`;
|
|
190
|
+
const specialKeys = phoneToArray[1] ? `,${phoneToArray[1]}` : '';
|
|
191
|
+
return {
|
|
192
|
+
number: phoneWithoutSpecialKey,
|
|
193
|
+
title,
|
|
194
|
+
specialKeys,
|
|
195
|
+
};
|
|
196
|
+
};
|
|
197
|
+
const formatTitleToCapital = (name) => name.replace(/-/g, ' ')
|
|
198
|
+
.replace(/\+/g, ' ').replace(/(\b[a-z](?!\s))/g, (letter) => letter.toUpperCase());
|
|
199
|
+
const capitalize = (text) => text.charAt(0).toUpperCase() + text.slice(1);
|
|
200
|
+
|
|
201
|
+
const BlockVehLinks = () => {
|
|
202
|
+
const { vehicleState: { items: vehicles } } = useStoreFormCarVehicle();
|
|
203
|
+
const { driverState: { items: drivers } } = useStoreFormCarDriverBase();
|
|
204
|
+
const { discountState: { vehlinks }, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
205
|
+
const driverOptions = drivers.map((driver, index) => ({ name: driver.firstName, value: index }));
|
|
206
|
+
const handleDriverChange = (vehicleIndex) => ({ value }) => {
|
|
207
|
+
dispatchDiscountState({
|
|
208
|
+
type: StoreFormCarDiscountActionTypes.FormCarDiscountVehlinkSelect,
|
|
209
|
+
payload: {
|
|
210
|
+
driverIndex: value,
|
|
211
|
+
vehicleIndex,
|
|
212
|
+
},
|
|
213
|
+
});
|
|
214
|
+
};
|
|
215
|
+
if (drivers.length > 1) {
|
|
216
|
+
return (jsxs(Fragment, { children: [jsx(LabelFormBox, { title: "Since there are multiple drivers in this quote,\n please tell us who drives which vehicle the most.\n Please provide an answer that best suits your situation." }), vehicles.map((vehicle, index) => {
|
|
217
|
+
const { year, make, model } = vehicle;
|
|
218
|
+
const selectedDriver = vehlinks.find((vehlink) => (vehlink.vehicleIndex === index && vehlink.priority === DriverPriorityTypes.Prn));
|
|
219
|
+
return (jsx(SelectFormBox, { title: `Who is the principal driver of the ${year} ${make} ${model} ?`, onChange: handleDriverChange(index), options: driverOptions, defaultValue: selectedDriver?.driverIndex || 0, name: `vehlink-${index}` }, `vehlink-${index}`));
|
|
220
|
+
})] }));
|
|
221
|
+
}
|
|
222
|
+
return null;
|
|
223
|
+
};
|
|
224
|
+
|
|
225
|
+
const BlockNextPageInfo$2 = () => {
|
|
143
226
|
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
227
|
+
const isTheBig = appType === AppTypes.TheBig;
|
|
228
|
+
return (jsx("div", { className: "next-page-info", children: isTheBig ? (jsx("div", { className: "privacy-policy", children: jsxs("p", { children: [jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) })) : (jsxs(Fragment, { children: [jsx("h5", { children: "On the next page, you will also be able to:" }), jsxs("div", { className: "next-page-points", children: [jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsx("div", { className: "privacy-policy", children: jsxs("p", { children: ["Once you submit this form, you are agreeing to have your insurance quote sent to you via email and My Choice will provide your contact information to one of our trusted broker partners, who will contact you after your quote is complete to further assist you in securing your best rate. For more details, see our", jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] })) }));
|
|
229
|
+
};
|
|
230
|
+
|
|
231
|
+
const BlockSubmit$2 = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
232
|
+
const { quoteState: { isRequested, quoteConfirm } } = useStoreFormCarQuote();
|
|
233
|
+
const { discountState: { isValid } } = useStoreFormCarDiscount();
|
|
234
|
+
const { appConfigState: { localIndex, insuranceType } } = useStoreAppConfig();
|
|
235
|
+
const navigate = useNavigate();
|
|
236
|
+
const { postRequestQuote } = CarQuoteDataHandler();
|
|
237
|
+
const { carDiscountFormValidate } = useValidationCarDiscount();
|
|
238
|
+
const handleGetQuotesClick = () => {
|
|
239
|
+
if (!isValid) {
|
|
240
|
+
carDiscountFormValidate(false, () => postRequestQuote(isRecalc, quoteConfirm));
|
|
241
|
+
}
|
|
242
|
+
else if (!isRequested) {
|
|
243
|
+
postRequestQuote(isRecalc, quoteConfirm);
|
|
244
|
+
}
|
|
245
|
+
else if (!isRecalc) {
|
|
246
|
+
navigate(`/${localIndex || defaultLocalIndex}/${insuranceType}/quotes`);
|
|
247
|
+
}
|
|
248
|
+
};
|
|
249
|
+
return (jsx(ButtonBase, { className: className, size: buttonSize, category: CategoryTypes.Filled, onClick: handleGetQuotesClick, color: ColorTypes.Primary, label: label }));
|
|
250
|
+
};
|
|
251
|
+
BlockSubmit$2.defaultProps = {
|
|
252
|
+
buttonSize: SizeTypes.Large,
|
|
253
|
+
label: 'Get Your Quotes',
|
|
254
|
+
className: '',
|
|
255
|
+
};
|
|
256
|
+
|
|
257
|
+
const VehicleOfferCoverages = ({ coverages, nonStandardCoverages, }) => {
|
|
258
|
+
const { vehicleState, dispatchVehicleState } = useStoreFormCarVehicle();
|
|
259
|
+
const { comprehensive, collision, liability, lossofuse, liabilityfordamage, limitedwaiverofdepreciation } = vehicleState.items[vehicleState.activeIndex];
|
|
260
|
+
const vehicle_names = vehicleState.items.map(({ year, make, model }) => [`${year} ${make} ${model}`]);
|
|
261
|
+
const isLeased = vehicleState.items.some((item) => item.leased);
|
|
262
|
+
const handleComprehensiveChange = ({ value }) => {
|
|
263
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
264
|
+
dispatchVehicleState({
|
|
265
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
266
|
+
payload: {
|
|
267
|
+
vehicleIndex: i,
|
|
268
|
+
},
|
|
269
|
+
});
|
|
270
|
+
dispatchVehicleState({
|
|
271
|
+
type: StoreFormCarVehicleActionTypes.FormCarComprehensiveCoverageSelect,
|
|
272
|
+
payload: { coverage: !!Number(value), deductible: value },
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
};
|
|
276
|
+
const handleLiabilityChange = ({ value }) => {
|
|
277
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
278
|
+
dispatchVehicleState({
|
|
279
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
280
|
+
payload: {
|
|
281
|
+
vehicleIndex: i,
|
|
282
|
+
},
|
|
283
|
+
});
|
|
284
|
+
dispatchVehicleState({
|
|
285
|
+
type: StoreFormCarVehicleActionTypes.FormCarLiabilityCoverageSelect,
|
|
286
|
+
payload: { coverage: true, limit: value },
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
};
|
|
290
|
+
const handleCollisionChange = ({ value }) => {
|
|
291
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
292
|
+
dispatchVehicleState({
|
|
293
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
294
|
+
payload: {
|
|
295
|
+
vehicleIndex: i,
|
|
296
|
+
},
|
|
297
|
+
});
|
|
298
|
+
dispatchVehicleState({
|
|
299
|
+
type: StoreFormCarVehicleActionTypes.FormCarCollisionCoverageSelect,
|
|
300
|
+
payload: { coverage: !!Number(value), deductible: value },
|
|
301
|
+
});
|
|
302
|
+
}
|
|
303
|
+
};
|
|
304
|
+
const handleLossOfUseChange = ({ value }) => {
|
|
305
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
306
|
+
dispatchVehicleState({
|
|
307
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
308
|
+
payload: {
|
|
309
|
+
vehicleIndex: i,
|
|
310
|
+
},
|
|
311
|
+
});
|
|
312
|
+
dispatchVehicleState({
|
|
313
|
+
type: StoreFormCarVehicleActionTypes.FormCarLossOfUseCoverageSelect,
|
|
314
|
+
payload: { coverage: !!Number(value), limit: value },
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
};
|
|
318
|
+
const handleLiaiblityForDamageChange = ({ value }) => {
|
|
319
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
320
|
+
dispatchVehicleState({
|
|
321
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
322
|
+
payload: {
|
|
323
|
+
vehicleIndex: i,
|
|
324
|
+
},
|
|
325
|
+
});
|
|
326
|
+
dispatchVehicleState({
|
|
327
|
+
type: StoreFormCarVehicleActionTypes.FormCarLiabilityForDamageCoverageSelect,
|
|
328
|
+
payload: { coverage: !!Number(value), limit: value },
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
};
|
|
332
|
+
const handleLimitedWaiverOfDepreciationChange = ({ value }) => {
|
|
333
|
+
for (let i = 0; i < vehicleState.items.length; i += 1) {
|
|
334
|
+
dispatchVehicleState({
|
|
335
|
+
type: StoreFormCarVehicleActionTypes.FormCarVehicleSelect,
|
|
336
|
+
payload: {
|
|
337
|
+
vehicleIndex: i,
|
|
338
|
+
},
|
|
339
|
+
});
|
|
340
|
+
dispatchVehicleState({
|
|
341
|
+
type: StoreFormCarVehicleActionTypes.FormCarLimitedWaiverOfDepreciationCoverageSelect,
|
|
342
|
+
payload: { coverage: !!Number(value), limit: value },
|
|
343
|
+
});
|
|
344
|
+
}
|
|
345
|
+
};
|
|
346
|
+
const getCoveragePremium = (code) => {
|
|
347
|
+
const coverage = coverages.find((coverage) => coverage.code === code);
|
|
348
|
+
return coverage ? `$${coverage.annualPremium.toFixed(2)}` : '-';
|
|
349
|
+
};
|
|
350
|
+
const doesCoverageExist = (code) => {
|
|
351
|
+
return coverages.some((coverage) => coverage.code === code);
|
|
352
|
+
};
|
|
353
|
+
const isNonStandardCoverageActive = (name) => {
|
|
354
|
+
if (!nonStandardCoverages)
|
|
355
|
+
return false;
|
|
356
|
+
return nonStandardCoverages[name] === true;
|
|
357
|
+
};
|
|
358
|
+
const getTPBIandTPPD = () => {
|
|
359
|
+
const tpbi = coverages.find((coverage) => coverage.code === 'TPBI');
|
|
360
|
+
const tppd = coverages.find((coverage) => coverage.code === 'TPPD');
|
|
361
|
+
if (!tpbi || !tppd) {
|
|
362
|
+
return '-';
|
|
363
|
+
}
|
|
364
|
+
const total = tpbi.annualPremium + tppd.annualPremium;
|
|
365
|
+
return `$${total.toFixed(2)}`;
|
|
366
|
+
};
|
|
367
|
+
const getSumOfPremiums = () => {
|
|
368
|
+
const premiums = coverages.map((coverage) => coverage.annualPremium);
|
|
369
|
+
const total = premiums.reduce((acc, premium) => {
|
|
370
|
+
return acc + Number(premium);
|
|
371
|
+
}, 0);
|
|
372
|
+
return `$${total.toFixed(2)}`;
|
|
373
|
+
};
|
|
374
|
+
return (jsxs(Fragment, { children: [jsx("div", { className: "offer-coverages-container", children: jsxs("table", { className: "offer-coverages-table", children: [jsxs("tr", { className: "table-header", children: [jsx("td", { children: vehicle_names.join(', ') }), jsx("td", { children: "Selection" }), jsx("td", { children: "Premium" })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Third Party Liability Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: "Third-party liability coverage is mandatory in Ontario and protects you if you're found at fault for injuring or killing someone or damaging their property while driving. This includes people in other vehicles, pedestrians, cyclists, and even passengers in your own car, as well as property like fences, buildings, street signs, and light poles. If you’re sued, this coverage helps pay for legal defence, settlements, and any court-ordered payments. The minimum required coverage is $200,000, but that amount often isn’t enough—most drivers choose at least $2 million to avoid having to pay out-of-pocket if costs exceed the limit. This is a mandatory coverage in Ontario. Talk to your broker to ensure you have the right amount of protection." }) })] }), jsx("td", { children: jsx(SelectFormBox, { options: liabilityOptions, name: "liability-limit", onChange: handleLiabilityChange, defaultValue: getSelectedOption(liabilityOptions, liability.coverage ? liability.limit : 1000000), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), jsx("td", { children: getTPBIandTPPD() })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Direct Compensation - Property Damange Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: "Third - Party Liability Direct Compensation responds when you are determined to be not at-fault in an accident with another vehicle, and covers the cost of damage to your vehicle (or actual cash value payout), it's equipment, contents, loss of use, and other associated incidentals such as towing fees and lot fees. This is considered an optional coverage, and it is highly recommended that you do not remove it. If your vehicle is financed or leased, the lienholder/lessor must agree to allow you to remove it. Should you remove it, you must also remove collision or all perils coverage. You will be entirely out-of-pocket in a not-at-fault accident and are legally restricted from claiming reimbursement (suing) the other vehicle owner or their insurer. Chat to your broker for more details about this coverage." }) })] }), jsx("td", { children: "$0 Deductible" }), jsx("td", { children: getCoveragePremium('TPDC') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Accident Benefits Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'Accident Benefits is a mandatory coverage that responds when there is injury or death in an accident, regardless of fault, and for all affected individuals. It provides a core series of benefits with the capacity to increase coverage values, along with a menu of optional additional benefits that can be added on. The core and optional coverages must be thoroughly reviewed and evaluated, and decisions made based on your own personal circumstances and needs. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: "Included" }), jsx("td", { children: getCoveragePremium('AB') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Uninsured Automobile Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'Uninsured Motorist Coverage is a mandatory coverage which responds when you are not at-fault in an accident with an uninsured or unidentified (hit-and-run) vehicle, and have incurred bodily injuries, death, or damage to your property, and the offending vehicle owner cannot be found, of if identified, cannot adequately compensate you. Coverage is capped to match the province minimum liability limit of $200,000. Due to the low coverage value, it is highly recommended to ensure inclusion of the OPCF44 Family Protection Coverage endorsement for additional protection. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: "Included" }), jsx("td", { children: getCoveragePremium('UA') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Comprehensive Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'Comprehensive coverage responds to types of damages ( repair or actual cash value payout) incurred by your vehicle when it is not actively being driven. Examples would be fire, theft, vandalism, glass breakage, and weather-related losses. While considered an optional coverage, it is highly recommended. Should your vehicle be financed or leased, the lienholder/lessor will not allow you to leave this coverage out and will impose a satisfactory deductible to meet their requirements.' }) })] }), jsx("td", { children: jsx(SelectFormBox, { options: coverageOptions, name: "comprehensive-coverage", onChange: handleComprehensiveChange, defaultValue: getSelectedOption(coverageOptions, comprehensive.coverage ? comprehensive.deductible : 0), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), jsx("td", { children: getCoveragePremium('CMP') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { children: [jsxs("td", { children: ["Collision Coverage", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'Collision coverage responds to your vehicle damages (repair or actual cash value payout) in the event you collide with another vehicle or object in the course of its use or operation, and is determined to be at-fault. While considered an optional coverage, it is highly recommended. Should your vehicle be financed or leased, the lienholder/lessor will not allow you to leave this coverage out and will impose a satisfactory deductible to meet their requirements. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: jsx(SelectFormBox, { options: coverageOptions, name: "collision-coverage", onChange: handleCollisionChange, defaultValue: getSelectedOption(coverageOptions, collision.coverage ? collision.deductible : 0), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), jsx("td", { children: getCoveragePremium('COL') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), doesCoverageExist('5') && (jsxs(Fragment, { children: [jsxs("tr", { children: [jsx("td", { children: "Permission to Rent or Lease (OPCF 5)" }), jsx("td", { children: "Included" }), jsx("td", { children: getCoveragePremium('5') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) })] })), isNonStandardCoverageActive(20) && (jsx(Fragment, { children: jsxs("tr", { children: [jsxs("td", { children: ["Loss of Use (OPCF 20)", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'The OPCF20 Loss of Use / Transportation Replacement endorsement responds when you are determined to be at-fault for an accident, or have a comprehensive claim, and need replacement transportation while your vehicle is out-of-service being repaired, or until it is deemed to be a total loss and a settlement offer is made by your insurer. Most often used to pay for a temporary replacement vehicle rental, it can also be used to compensate for other acceptable forms of travel. Depending on the insurer, the coverage limits available may be a dollar amount or a time amount, and you must have collision and comprehensive, or all perils coverage to include this endorsement. While it is optional, it is highly recommended, and careful consideration must be given to the coverage amounts chosen, as repair delays can quickly exhaust your policy limits, leaving you out-of-pocket for transportation expenses. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { style: { paddingBottom: '7px' }, children: jsx(SelectFormBox, { options: lossOfUseOptions, name: "loss-of-use", onChange: handleLossOfUseChange, defaultValue: getSelectedOption(lossOfUseOptions, lossofuse.coverage ? lossofuse.limit : 0), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), jsx("td", { rowSpan: doesCoverageExist('PAK6') ? 2 : 1, children: doesCoverageExist('PAK6') ? getCoveragePremium('PAK6') : getCoveragePremium('20') })] }) })), isNonStandardCoverageActive(27) && (jsxs(Fragment, { children: [jsxs("tr", { children: [jsxs("td", { children: ["Liability for Damage for Non-Owned Cars (OPCF 27)", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'The OPCF27 Liability for Damage to Non-Owned Automobile(s) endorsement responds when you rent or borrow a vehicle, and want to extend your coverages to that vehicle. Often used for special occasion rentals or vacation vehicle rentals. Full liability and physical damage coverages must be on your insured vehicle for this endorsement to apply, and a deductible is applicable. Careful consideration must be given in choosing a coverage amount that adequately covers the value of the vehicle you are expecting to rent or borrow. While considered optional, it is highly recommended, and often "packaged" with the OPCF20 Loss of Use / Transportation Replacement coverage by many insurers. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: jsx(SelectFormBox, { options: liabilityForDamageOptions, name: "liaiblity-for-damage", onChange: handleLiaiblityForDamageChange, defaultValue: getSelectedOption(liabilityForDamageOptions, liabilityfordamage.coverage ? liabilityfordamage.limit : 0), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), !doesCoverageExist('PAK6') && jsx("td", { children: getCoveragePremium('27') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) })] })), isNonStandardCoverageActive('ACCW') && (jsxs(Fragment, { children: [jsxs("tr", { children: [jsxs("td", { children: ["Accident Waiver or Forgiveness (OPCF 39)", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: "The OPCF39 Accident Waiver/Forgiveness endorsement responds by protecting your existing driving record from being negatively impacted by a single, partial at-fault or fully at-fault accident, and must be on the policy before the accident. The benefit of the coverage continues as long as you stay with the same insurer, as it's not transferable should you move to another insurance company. Subsequent at-fault or partial at-fault accidents will not have the protection and will be adversely rated accordingly. Eligibility, terms, conditions, and formulations used can vary significantly between insurers, so careful review and consideration are essential. While purchasing this endorsement is optional, it is highly recommended as the alternative of being accident-rated for several years will be significantly higher in premiums than the cost of the endorsement. Chat to your broker for more details about this coverage." }) })] }), jsx("td", { children: "Included" }), jsx("td", { children: getCoveragePremium('ACCW') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) })] })), isNonStandardCoverageActive(43) && (jsxs(Fragment, { children: [jsxs("tr", { children: [jsxs("td", { children: ["Limited waiver of depreciation (OPCF ", isLeased ? '43A' : '43', ")", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'The OPCF43/43A Removing Depreciation Deduction / Limited Waiver of Depreciation endorsement responds by protecting your original purchase/lease price of a "new" vehicle (as evidenced by a bill of sale or lease agreement) from depreciation should the vehicle be a total loss from an insured peril. Only new vehicles, and in some cases "demo\'s" with limited mileage are eligible, and the endorsement must be added immediately upon the vehicle delivery. Coverage durations available vary between insurers, generally ranging from 24 months to 60 months from the possession date of the vehicle. While an optional coverage, it is highly recommended as, without it, a total loss settlement based on actual cash value could leave you contractually owing money to a lienholder or lessor. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: jsx(SelectFormBox, { options: limitedWaiverOfDepreciationOptions, name: "liaiblity-for-damage", onChange: handleLimitedWaiverOfDepreciationChange, defaultValue: getSelectedOption(limitedWaiverOfDepreciationOptions, limitedwaiverofdepreciation.coverage ? limitedwaiverofdepreciation.limit : 0), title: "", description: "", placeholder: "Select from the list", autoSelectIfValueIsOutOfOptions: false, size: SizeTypes.Small, className: "coverages-select-input" }) }), jsx("td", { children: getCoveragePremium('43') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) })] })), jsxs("tr", { children: [jsxs("td", { children: ["Family Protection (OPCF 44)", jsx("div", { style: { display: 'inline-block', marginLeft: '5px' }, children: jsx(TooltipForm, { id: "my-tooltip", description: 'The OPCF44 Family Protection Endorsement responds when you are determined to be not at-fault in a vehicle accident, and your claim / civil suit against the offending vehicle owner is not adequately satisfied as they are unidentified, uninsured, or underinsured. This endorsement bridges their coverages (if any) up to the full limits of the OPCF44 coverage on your policy. While considered an optional coverage, it is highly recommended as a form of self protection, and is extremely low in cost. Chat to your broker for more details about this coverage.' }) })] }), jsx("td", { children: "Included" }), jsx("td", { children: getCoveragePremium('44') })] }), jsx("tr", { children: jsx("td", { colSpan: 3, children: jsx("div", { className: "divider" }) }) }), jsxs("tr", { className: "premium-total", children: [jsx("td", { children: "Annual Premium" }), jsx("td", {}), jsx("td", { children: getSumOfPremiums() })] })] }) }), jsx("div", { style: { display: 'flex', flexDirection: 'column' }, children: jsx(BlockSubmit$2, { className: "mychoice recalculate", label: "Recalculate Quote", buttonSize: SizeTypes.Medium, isRecalc: true }) })] }));
|
|
375
|
+
};
|
|
376
|
+
|
|
377
|
+
const OfferSection = ({ offerCompany, brokerCompany, offerPrice, phoneNumber, isBestOffer, operationHours = {}, redirectUrl, fulfillmentUrl, coverages, nonStandardCoverages, }) => {
|
|
378
|
+
const { appConfigState: { appType }, } = useStoreAppConfig();
|
|
144
379
|
const { postRequestQuoteOnliaUrl } = CarQuoteDataHandler();
|
|
145
380
|
const isTheBig = appType === AppTypes.TheBig;
|
|
381
|
+
const isMyChoice = appType === AppTypes.MyChoice;
|
|
146
382
|
const mychoiceCls = appType === AppTypes.MyChoice ? 'mychoice' : '';
|
|
147
383
|
const { weekdayHours, saturdayHours, sundayHours } = operationHours;
|
|
148
384
|
const [detailsIsOpen, setDetailsIsOpenIsOpen] = useState(isBestOffer ?? false);
|
|
@@ -157,9 +393,7 @@ const OfferSection = ({ offerCompany, brokerCompany, offerPrice, phoneNumber, is
|
|
|
157
393
|
}
|
|
158
394
|
postRequestQuoteOnliaUrl(true, redirectUrl);
|
|
159
395
|
};
|
|
160
|
-
return (jsxs("div", { className: `offer-section ${mychoiceCls}`, children: [jsx(OfferHeader, { className: isTheBig ? 'thebig-bold' : '', companyName: offerCompany?.name, isBestOffer: isBestOffer }), jsx(OfferPrice, { className: isTheBig ? 'thebig' : '', companyLogo: offerCompany?.logo, price: offerPrice }), !isTheBig && offsiteUrl
|
|
161
|
-
? (jsxs("div", { className: "offer-phone", children: [jsx("h3", { children: "Click below to get this rate" }), jsx(ButtonBase, { className: `offer-phone-number ${mychoiceCls}`, label: "Buy Online", type: ButtonTypes.Button, category: CategoryTypes.Filled, color: ColorTypes.Primary, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Medium, onClick: handleCTAClick })] })) : (jsxs("div", { className: "offer-phone", children: [jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Call now to get this rate" }), jsx("a", { target: "_blank", rel: "noreferrer noopener", href: `tel:${phoneNumber?.number}`, children: jsx(ButtonBase, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} offer-phone-number`, label: phoneNumber?.title, type: ButtonTypes.Button, category: CategoryTypes.Filled, color: ColorTypes.Primary, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Medium }) })] })), jsxs("button", { className: "dropdown", onClick: handleDropdownClick, children: [jsx("span", { children: detailsIsOpen ? 'Less Info' : 'More Info' }), jsx(IconDropdownArrow, { color: "grey", className: detailsIsOpen ? 'rotated' : '' })] }), detailsIsOpen && (jsxs("div", { className: "offer-details", children: [jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', name: offerCompany?.name, companyType: CompanyRoleTypes.Offering, description: offerCompany?.description }), jsx("hr", {}), (isTheBig || !offsiteUrl)
|
|
162
|
-
&& (jsxs(Fragment, { children: [jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', logo: brokerCompany?.logo, name: brokerCompany?.title, companyType: CompanyRoleTypes.Broker, description: brokerCompany?.description }), jsx("hr", {})] })), jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', name: "Hours of Operation", children: jsx(OperationHoursInfo, { weekdayHours: weekdayHours, saturdayHours: saturdayHours, sundayHours: sundayHours }) })] }))] }));
|
|
396
|
+
return (jsxs("div", { className: `offer-section ${mychoiceCls}`, children: [jsx(OfferHeader, { className: isTheBig ? 'thebig-bold' : '', companyName: offerCompany?.name, isBestOffer: isBestOffer }), jsx(OfferPrice, { className: isTheBig ? 'thebig' : '', companyLogo: offerCompany?.logo, price: offerPrice }), !isTheBig && offsiteUrl ? (jsxs("div", { className: "offer-phone", children: [jsx("h3", { children: "Click below to get this rate" }), jsx(ButtonBase, { className: `offer-phone-number ${mychoiceCls}`, label: "Buy Online", type: ButtonTypes.Button, category: CategoryTypes.Filled, color: ColorTypes.Primary, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Medium, onClick: handleCTAClick })] })) : (jsxs("div", { className: "offer-phone", children: [jsx("h3", { className: isTheBig ? 'thebig-bold' : '', children: "Call now to get this rate" }), jsx("a", { target: "_blank", rel: "noreferrer noopener", href: `tel:${phoneNumber?.number}`, children: jsx(ButtonBase, { className: `${isTheBig ? 'thebig-bold' : 'mychoice'} offer-phone-number`, label: phoneNumber?.title, type: ButtonTypes.Button, category: CategoryTypes.Filled, color: ColorTypes.Primary, variant: ButtonVariantTypes.Rectangle, size: SizeTypes.Medium }) })] })), jsxs("button", { className: "dropdown", onClick: handleDropdownClick, children: [jsx("span", { children: detailsIsOpen ? 'Less Info' : 'More Info' }), jsx(IconDropdownArrow, { color: "grey", className: detailsIsOpen ? 'rotated' : '' })] }), detailsIsOpen && (jsxs("div", { className: "offer-details", children: [jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', name: offerCompany?.name, companyType: CompanyRoleTypes.Offering, description: offerCompany?.description }), jsx("hr", {}), (isTheBig || !offsiteUrl) && (jsxs(Fragment, { children: [jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', logo: brokerCompany?.logo, name: brokerCompany?.title, companyType: CompanyRoleTypes.Broker, description: brokerCompany?.description }), jsx("hr", {})] })), jsx(OfferDetail, { className: isTheBig ? 'thebig-bold' : '', name: "Hours of Operation", children: jsx(OperationHoursInfo, { weekdayHours: weekdayHours, saturdayHours: saturdayHours, sundayHours: sundayHours }) }), isMyChoice && coverages && (jsxs(Fragment, { children: [jsx("hr", {}), jsx(VehicleOfferCoverages, { coverages: coverages, nonStandardCoverages: nonStandardCoverages })] }))] }))] }));
|
|
163
397
|
};
|
|
164
398
|
OfferSection.defaultProps = {
|
|
165
399
|
offerPrice: { monthly: 0, yearly: 0 },
|
|
@@ -373,65 +607,6 @@ const getRecommendedRange = (distanceDaily, distanceBusiness) => {
|
|
|
373
607
|
}
|
|
374
608
|
};
|
|
375
609
|
|
|
376
|
-
const getSelectedOption = (options, val) => {
|
|
377
|
-
if (typeof val === 'boolean') {
|
|
378
|
-
return options.find(({ value }) => val === value)?.value || false;
|
|
379
|
-
}
|
|
380
|
-
if (typeof val === 'number') {
|
|
381
|
-
return options.find((option) => option.value?.toString() === val.toString())?.value;
|
|
382
|
-
}
|
|
383
|
-
return options.find((option) => option.value === val)?.value;
|
|
384
|
-
};
|
|
385
|
-
const getErrorMessage = (value, inValidation = false, message = '') => {
|
|
386
|
-
if (inValidation) {
|
|
387
|
-
if (value === null) {
|
|
388
|
-
return 'This field is required.';
|
|
389
|
-
}
|
|
390
|
-
if (typeof value === 'boolean') {
|
|
391
|
-
return '';
|
|
392
|
-
}
|
|
393
|
-
return !value ? 'This field is required.' : message;
|
|
394
|
-
}
|
|
395
|
-
return '';
|
|
396
|
-
};
|
|
397
|
-
const getDateErrorMessage = (values, inValidation = false) => {
|
|
398
|
-
const emptyValues = values.filter((value) => !value);
|
|
399
|
-
if (inValidation) {
|
|
400
|
-
if (emptyValues.length > 1) {
|
|
401
|
-
return 'These fields are required.';
|
|
402
|
-
}
|
|
403
|
-
if (emptyValues.length === 1) {
|
|
404
|
-
return 'This field is required.';
|
|
405
|
-
}
|
|
406
|
-
}
|
|
407
|
-
return '';
|
|
408
|
-
};
|
|
409
|
-
const formatPhoneObject = (phone) => {
|
|
410
|
-
const phoneToArray = (phone || defaultBrokerPhone).split(',');
|
|
411
|
-
const onlyNumbers = phoneToArray[0].replace(/\D/g, '');
|
|
412
|
-
let phoneNumber;
|
|
413
|
-
if (onlyNumbers.length < 11) {
|
|
414
|
-
phoneNumber = `1${onlyNumbers}`;
|
|
415
|
-
}
|
|
416
|
-
else {
|
|
417
|
-
phoneNumber = onlyNumbers;
|
|
418
|
-
}
|
|
419
|
-
const phoneToNumbers = Number(phoneNumber).toString();
|
|
420
|
-
const phoneWithoutSpecialKey = phoneToNumbers.length > 10
|
|
421
|
-
? phoneToNumbers.replace(/(\d{1})(\d{3})(\d{3})(\d{4})/, '$1-$2-$3-$4')
|
|
422
|
-
: phoneToNumbers.replace(/(\d{1})(\d{3})(\d{3})(\d{3})/, '$1-$2-$3-$4');
|
|
423
|
-
const title = phoneToArray.length < 2 ? phoneWithoutSpecialKey : `${phoneWithoutSpecialKey} x${phoneToArray[1]}`;
|
|
424
|
-
const specialKeys = phoneToArray[1] ? `,${phoneToArray[1]}` : '';
|
|
425
|
-
return {
|
|
426
|
-
number: phoneWithoutSpecialKey,
|
|
427
|
-
title,
|
|
428
|
-
specialKeys,
|
|
429
|
-
};
|
|
430
|
-
};
|
|
431
|
-
const formatTitleToCapital = (name) => name.replace(/-/g, ' ')
|
|
432
|
-
.replace(/\+/g, ' ').replace(/(\b[a-z](?!\s))/g, (letter) => letter.toUpperCase());
|
|
433
|
-
const capitalize = (text) => text.charAt(0).toUpperCase() + text.slice(1);
|
|
434
|
-
|
|
435
610
|
const BlockCarInfo = () => {
|
|
436
611
|
const { status: statusMake, getVehicleMake, vehicleMakeList = [] } = useHandlerCarMake();
|
|
437
612
|
const { status: statusModel, getVehicleModel, vehicleModelList = [] } = useHandlerCarModel();
|
|
@@ -1521,62 +1696,6 @@ const PageDriver = () => {
|
|
|
1521
1696
|
return (jsxs("div", { className: "form-container", children: [jsx(TabDriver, { createItem: createDriver }), jsxs("div", { className: "form-section-container", children: [isRender && (jsxs(Fragment, { children: [jsx(SectionDriverInfo, {}), jsx(SectionDriverLicence, {}), jsx(SectionDriverInsurancePolicy, {}), jsx(SectionDriverCancellation, {}), jsx(SectionDriverHistory, {}), appType === AppTypes.MyChoice && jsx(HonestyMessage, {})] })), appType === AppTypes.TheBig ? (jsx(NavigationBottomTheBig, { createItem: createDriver, formSteps: formSteps[InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid })) : (jsx(NavigationBottom, { className: "mychoice", createItem: createDriver, formSteps: formSteps[InsuranceTypes.Car], itemCount: items.length, validateForm: validateForm, formIsValid: driverFormIsValid }))] }), localIndex !== defaultLocalIndex && (jsx("img", { className: "logo-for-partner", src: myChoicePartnerLogo, alt: "partner logo" }))] }));
|
|
1522
1697
|
};
|
|
1523
1698
|
|
|
1524
|
-
const BlockVehLinks = () => {
|
|
1525
|
-
const { vehicleState: { items: vehicles } } = useStoreFormCarVehicle();
|
|
1526
|
-
const { driverState: { items: drivers } } = useStoreFormCarDriverBase();
|
|
1527
|
-
const { discountState: { vehlinks }, dispatchDiscountState } = useStoreFormCarDiscount();
|
|
1528
|
-
const driverOptions = drivers.map((driver, index) => ({ name: driver.firstName, value: index }));
|
|
1529
|
-
const handleDriverChange = (vehicleIndex) => ({ value }) => {
|
|
1530
|
-
dispatchDiscountState({
|
|
1531
|
-
type: StoreFormCarDiscountActionTypes.FormCarDiscountVehlinkSelect,
|
|
1532
|
-
payload: {
|
|
1533
|
-
driverIndex: value,
|
|
1534
|
-
vehicleIndex,
|
|
1535
|
-
},
|
|
1536
|
-
});
|
|
1537
|
-
};
|
|
1538
|
-
if (drivers.length > 1) {
|
|
1539
|
-
return (jsxs(Fragment, { children: [jsx(LabelFormBox, { title: "Since there are multiple drivers in this quote,\n please tell us who drives which vehicle the most.\n Please provide an answer that best suits your situation." }), vehicles.map((vehicle, index) => {
|
|
1540
|
-
const { year, make, model } = vehicle;
|
|
1541
|
-
const selectedDriver = vehlinks.find((vehlink) => (vehlink.vehicleIndex === index && vehlink.priority === DriverPriorityTypes.Prn));
|
|
1542
|
-
return (jsx(SelectFormBox, { title: `Who is the principal driver of the ${year} ${make} ${model} ?`, onChange: handleDriverChange(index), options: driverOptions, defaultValue: selectedDriver?.driverIndex || 0, name: `vehlink-${index}` }, `vehlink-${index}`));
|
|
1543
|
-
})] }));
|
|
1544
|
-
}
|
|
1545
|
-
return null;
|
|
1546
|
-
};
|
|
1547
|
-
|
|
1548
|
-
const BlockNextPageInfo$2 = () => {
|
|
1549
|
-
const { appConfigState: { appType } } = useStoreAppConfig();
|
|
1550
|
-
const isTheBig = appType === AppTypes.TheBig;
|
|
1551
|
-
return (jsx("div", { className: "next-page-info", children: isTheBig ? (jsx("div", { className: "privacy-policy", children: jsxs("p", { children: [jsx("span", { children: "DISCLAIMER: " }), "As insurance premiums are based on the information you provide it is important that it be 100% accurate and up to date. If you are not sure it is best to check before completing your quote."] }) })) : (jsxs(Fragment, { children: [jsx("h5", { children: "On the next page, you will also be able to:" }), jsxs("div", { className: "next-page-points", children: [jsx("p", { children: "1. See what rates insurance carriers are offering" }), jsx("p", { children: "2. Get in touch with a broker and secure your rate" }), jsx("p", { children: "3. Potentially save more by speaking with a broker" })] }), jsx("div", { className: "privacy-policy", children: jsxs("p", { children: ["Once you submit this form, you are agreeing to have your insurance quote sent to you via email and My Choice will provide your contact information to one of our trusted broker partners, who will contact you after your quote is complete to further assist you in securing your best rate. For more details, see our", jsx("a", { href: "https://www.mychoice.ca/privacy-policy/", children: " Privacy Policy" }), "."] }) })] })) }));
|
|
1552
|
-
};
|
|
1553
|
-
|
|
1554
|
-
const BlockSubmit$2 = ({ className, label, buttonSize, isRecalc = false, }) => {
|
|
1555
|
-
const { quoteState: { isRequested, quoteConfirm } } = useStoreFormCarQuote();
|
|
1556
|
-
const { discountState: { isValid } } = useStoreFormCarDiscount();
|
|
1557
|
-
const { appConfigState: { localIndex, insuranceType } } = useStoreAppConfig();
|
|
1558
|
-
const navigate = useNavigate();
|
|
1559
|
-
const { postRequestQuote } = CarQuoteDataHandler();
|
|
1560
|
-
const { carDiscountFormValidate } = useValidationCarDiscount();
|
|
1561
|
-
const handleGetQuotesClick = () => {
|
|
1562
|
-
if (!isValid) {
|
|
1563
|
-
carDiscountFormValidate(false, () => postRequestQuote(isRecalc, quoteConfirm));
|
|
1564
|
-
}
|
|
1565
|
-
else if (!isRequested) {
|
|
1566
|
-
postRequestQuote(isRecalc, quoteConfirm);
|
|
1567
|
-
}
|
|
1568
|
-
else if (!isRecalc) {
|
|
1569
|
-
navigate(`/${localIndex || defaultLocalIndex}/${insuranceType}/quotes`);
|
|
1570
|
-
}
|
|
1571
|
-
};
|
|
1572
|
-
return (jsx(ButtonBase, { className: className, size: buttonSize, category: CategoryTypes.Filled, onClick: handleGetQuotesClick, color: ColorTypes.Primary, label: label }));
|
|
1573
|
-
};
|
|
1574
|
-
BlockSubmit$2.defaultProps = {
|
|
1575
|
-
buttonSize: SizeTypes.Large,
|
|
1576
|
-
label: 'Get Your Quotes',
|
|
1577
|
-
className: '',
|
|
1578
|
-
};
|
|
1579
|
-
|
|
1580
1699
|
const getDynamicLicenceBoxProps = ({ isAlbertaProvince, isOntarioProvince, isNewfoundlandProvince, isNovaScotiaProvince, isNewBrunswickProvince, }) => {
|
|
1581
1700
|
if (isAlbertaProvince) {
|
|
1582
1701
|
return {
|
|
@@ -1910,7 +2029,7 @@ const PageCarQuote = () => {
|
|
|
1910
2029
|
saturdayHours: items[0]?.brokerProfile.hoursSaturday,
|
|
1911
2030
|
sundayHours: items[0]?.brokerProfile.hoursSunday,
|
|
1912
2031
|
weekdayHours: items[0]?.brokerProfile.hoursWorkdays,
|
|
1913
|
-
}, phoneNumber: formatPhoneObject(items[0]?.brokerProfile.phone), redirectUrl: items[0]?.brokerProfile.redirectUrl || '' }) })) : (jsx(SplashScreen$2, {})) })) : (jsx(NoQuotesMessage, { type: "car" })) })), (!hasConfirmStep || appDeviceType !== DeviceTypes.Mobile) && (jsxs(Fragment, { children: [jsx(SectionQuoteEdit$2, {}), jsx(SectionQuoteRecalc$1, {})] }))] }), appDeviceType !== DeviceTypes.Mobile && quoteState.showCallMessage && jsx(SplashScreen$2, {}), !quoteState.showCallMessage && (jsx(Fragment, { children: jsxs("div", { style: { position: 'relative', width: '100%' }, children: [hasConfirmStep && (jsxs(Fragment, { children: [jsx("div", { className: "offer-container", children: jsx(SectionConfirm, {}) }), appDeviceType === DeviceTypes.Mobile && (jsxs(Fragment, { children: [jsx(SectionQuoteEdit$2, {}), jsx(SectionQuoteRecalc$1, {})] }))] })), jsx("div", { className: `offer-container ${hasConfirmStep ? 'blur' : ''}`, children: !!items?.length ? (quoteItems.map(({ company, brokerProfile, priceMonthly, priceYearly }, index) => (jsx("div", { children: (appDeviceType !== DeviceTypes.Mobile ||
|
|
2032
|
+
}, phoneNumber: formatPhoneObject(items[0]?.brokerProfile.phone), redirectUrl: items[0]?.brokerProfile.redirectUrl || '', coverages: items[0]?.coverages, nonStandardCoverages: items[0]?.nonStandardCoverages }) })) : (jsx(SplashScreen$2, {})) })) : (jsx(NoQuotesMessage, { type: "car" })) })), (!hasConfirmStep || appDeviceType !== DeviceTypes.Mobile) && (jsxs(Fragment, { children: [jsx(SectionQuoteEdit$2, {}), (isTheBig || !items[0]?.coverages) && jsx(SectionQuoteRecalc$1, {})] }))] }), appDeviceType !== DeviceTypes.Mobile && quoteState.showCallMessage && jsx(SplashScreen$2, {}), !quoteState.showCallMessage && (jsx(Fragment, { children: jsxs("div", { style: { position: 'relative', width: '100%' }, children: [hasConfirmStep && (jsxs(Fragment, { children: [jsx("div", { className: "offer-container", children: jsx(SectionConfirm, {}) }), appDeviceType === DeviceTypes.Mobile && (jsxs(Fragment, { children: [jsx(SectionQuoteEdit$2, {}), (isTheBig || !items[0]?.coverages) && jsx(SectionQuoteRecalc$1, {})] }))] })), jsx("div", { className: `offer-container ${hasConfirmStep ? 'blur' : ''}`, children: !!items?.length ? (quoteItems.map(({ company, brokerProfile, priceMonthly, priceYearly, coverages, nonStandardCoverages, }, index) => (jsx("div", { children: (appDeviceType !== DeviceTypes.Mobile ||
|
|
1914
2033
|
(appDeviceType === DeviceTypes.Mobile && index !== 0)) && (jsx(OfferSection, { isBestOffer: index === 0, offerCompany: company, brokerCompany: brokerProfile, offerPrice: {
|
|
1915
2034
|
monthly: priceMonthly,
|
|
1916
2035
|
yearly: priceYearly,
|
|
@@ -1918,7 +2037,7 @@ const PageCarQuote = () => {
|
|
|
1918
2037
|
saturdayHours: brokerProfile.hoursSaturday,
|
|
1919
2038
|
sundayHours: brokerProfile.hoursSunday,
|
|
1920
2039
|
weekdayHours: brokerProfile.hoursWorkdays,
|
|
1921
|
-
}, phoneNumber: formatPhoneObject(brokerProfile.phone), redirectUrl: brokerProfile.redirectUrl || '' })) }, index)))) : (jsx(NoQuotesMessage, { type: "car" })) })] }) }))] })) }));
|
|
2040
|
+
}, phoneNumber: formatPhoneObject(brokerProfile.phone), redirectUrl: brokerProfile.redirectUrl || '', coverages: coverages, nonStandardCoverages: nonStandardCoverages })) }, index)))) : (jsx(NoQuotesMessage, { type: "car" })) })] }) }))] })) }));
|
|
1922
2041
|
};
|
|
1923
2042
|
|
|
1924
2043
|
const IndicatorsContainer = () => jsx(Fragment, {});
|
|
@@ -3777,7 +3896,7 @@ var Desjardins = "
|
|
|
3777
3896
|
|
|
3778
3897
|
var CanadaLife = "";
|
|
3779
3898
|
|
|
3780
|
-
var SquareOne = "data:image/png;base64,
|
|
3899
|
+
var SquareOne = "";
|
|
3781
3900
|
|
|
3782
3901
|
const ProviderImageFooter = () => {
|
|
3783
3902
|
const { appConfigState: { insuranceType }, } = useStoreAppConfig();
|