src/applications/user-testing/new-conditions/pages/conditionByConditionPages/utils.js
import { getArrayUrlSearchParams } from 'platform/forms-system/src/js/patterns/array-builder/helpers';
import { conditionObjects } from '../../content/conditionOptions';
export const createDefaultAndEditTitles = (defaultTitle, editTitle) => {
const search = getArrayUrlSearchParams();
const isEdit = search.get('edit');
if (isEdit) {
return editTitle;
}
return defaultTitle;
};
const createCauseDescriptions = item => {
return {
NEW: 'Caused by an injury or exposure during my service.',
SECONDARY: `Caused by ${item?.causedByCondition}.`,
WORSENED:
'Existed before I served in the military, but got worse because of my military service.',
VA:
'Caused by an injury or event that happened when I was receiving VA care.',
};
};
const causeFollowUpChecks = {
NEW: item => !item?.primaryDescription,
SECONDARY: item =>
!item?.causedByCondition || !item?.causedByConditionDescription,
WORSENED: item => !item?.worsenedDescription || !item?.worsenedEffects,
VA: item => !item?.vaMistreatmentDescription || !item?.vaMistreatmentLocation,
};
// Different than lodash _capitalize because does not make rest of string lowercase which would break acronyms
const capitalizeFirstLetter = string => {
return string?.charAt(0).toUpperCase() + string?.slice(1);
};
export const createItemName = (item, capFirstLetter = false) => {
const condition = capFirstLetter
? capitalizeFirstLetter(item?.condition)
: item?.condition || 'condition';
if (item?.sideOfBody) {
return `${condition}, ${item?.sideOfBody.toLowerCase()}`;
}
return condition;
};
/** @type {ArrayBuilderOptions} */
export const arrayBuilderOptions = {
arrayPath: 'conditionByCondition',
nounSingular: 'condition',
nounPlural: 'conditions',
required: true,
isItemIncomplete: item =>
!item?.condition ||
!item?.date ||
!item?.cause ||
causeFollowUpChecks[item.cause](item),
maxItems: 100,
text: {
getItemName: item => createItemName(item, true),
cardDescription: item => createCauseDescriptions(item)[(item?.cause)],
},
};
// TODO: Fix formData so that shape is consistent
// formData changes shape between add and edit which results in the need for the conditional below
export const hasSideOfBody = (formData, index) => {
const condition = formData?.[arrayBuilderOptions.arrayPath]
? formData?.[arrayBuilderOptions.arrayPath][index]?.condition
: formData.condition;
const conditionObject = conditionObjects.find(
conditionObj => conditionObj.option === condition,
);
return conditionObject ? conditionObject.sideOfBody : false;
};