101 lines
2.8 KiB
JavaScript
101 lines
2.8 KiB
JavaScript
|
import i18n from 'widget/i18n/index';
|
||
|
const defaultTranslations = Object.fromEntries(
|
||
|
Object.entries(i18n).filter(([key]) => key.includes('en'))
|
||
|
).en;
|
||
|
|
||
|
export const standardFieldKeys = {
|
||
|
emailAddress: {
|
||
|
key: 'EMAIL_ADDRESS',
|
||
|
label: 'Email Id',
|
||
|
placeholder: 'Please enter your email address',
|
||
|
},
|
||
|
fullName: {
|
||
|
key: 'FULL_NAME',
|
||
|
label: 'Full Name',
|
||
|
placeholder: 'Please enter your full name',
|
||
|
},
|
||
|
phoneNumber: {
|
||
|
key: 'PHONE_NUMBER',
|
||
|
label: 'Phone Number',
|
||
|
placeholder: 'Please enter your phone number',
|
||
|
},
|
||
|
};
|
||
|
|
||
|
export const getLabel = ({ key, label }) => {
|
||
|
return defaultTranslations.PRE_CHAT_FORM.FIELDS[key]
|
||
|
? defaultTranslations.PRE_CHAT_FORM.FIELDS[key].LABEL
|
||
|
: label;
|
||
|
};
|
||
|
export const getPlaceHolder = ({ key, placeholder }) => {
|
||
|
return defaultTranslations.PRE_CHAT_FORM.FIELDS[key]
|
||
|
? defaultTranslations.PRE_CHAT_FORM.FIELDS[key].PLACEHOLDER
|
||
|
: placeholder;
|
||
|
};
|
||
|
|
||
|
export const getCustomFields = ({ standardFields, customAttributes }) => {
|
||
|
let customFields = [];
|
||
|
const { pre_chat_fields: preChatFields } = standardFields;
|
||
|
customAttributes.forEach(attribute => {
|
||
|
const itemExist = preChatFields.find(
|
||
|
item => item.name === attribute.attribute_key
|
||
|
);
|
||
|
if (!itemExist) {
|
||
|
customFields.push({
|
||
|
label: attribute.attribute_display_name,
|
||
|
placeholder: attribute.attribute_display_name,
|
||
|
name: attribute.attribute_key,
|
||
|
type: attribute.attribute_display_type,
|
||
|
values: attribute.attribute_values,
|
||
|
field_type: attribute.attribute_model,
|
||
|
required: false,
|
||
|
enabled: false,
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
return customFields;
|
||
|
};
|
||
|
|
||
|
export const getFormattedPreChatFields = ({ preChatFields }) => {
|
||
|
return preChatFields.map(item => {
|
||
|
return {
|
||
|
...item,
|
||
|
label: getLabel({
|
||
|
key: standardFieldKeys[item.name]
|
||
|
? standardFieldKeys[item.name].key
|
||
|
: item.name,
|
||
|
label: item.label ? item.label : item.name,
|
||
|
}),
|
||
|
placeholder: getPlaceHolder({
|
||
|
key: standardFieldKeys[item.name]
|
||
|
? standardFieldKeys[item.name].key
|
||
|
: item.name,
|
||
|
placeholder: item.placeholder ? item.placeholder : item.name,
|
||
|
}),
|
||
|
};
|
||
|
});
|
||
|
};
|
||
|
|
||
|
export const getPreChatFields = ({
|
||
|
preChatFormOptions = {},
|
||
|
customAttributes = [],
|
||
|
}) => {
|
||
|
const { pre_chat_message, pre_chat_fields } = preChatFormOptions;
|
||
|
let customFields = {};
|
||
|
let preChatFields = {};
|
||
|
|
||
|
const formattedPreChatFields = getFormattedPreChatFields({
|
||
|
preChatFields: pre_chat_fields,
|
||
|
});
|
||
|
|
||
|
customFields = getCustomFields({
|
||
|
standardFields: { pre_chat_fields: formattedPreChatFields },
|
||
|
customAttributes,
|
||
|
});
|
||
|
preChatFields = [...formattedPreChatFields, ...customFields];
|
||
|
|
||
|
return {
|
||
|
pre_chat_message,
|
||
|
pre_chat_fields: preChatFields,
|
||
|
};
|
||
|
};
|