From c8dc2d5479e1a24c529449cf41831001ac1c4796 Mon Sep 17 00:00:00 2001 From: John Dunning Date: Wed, 31 Aug 2022 12:41:40 -0700 Subject: [PATCH] Move Urgency field up into Incident info section Refactor and simplify creation of validationData in Ringdown.js. Update section labels in ringdown form. Fix Form.children prop type. --- src/Components/Form.js | 2 +- src/EMS/PatientFields.js | 28 +++++++++---------- src/Models/Ringdown.js | 60 +++++++++++++++++++--------------------- src/metadata/patient.js | 12 ++++---- 4 files changed, 50 insertions(+), 52 deletions(-) diff --git a/src/Components/Form.js b/src/Components/Form.js index a177929f..9d5e4e27 100644 --- a/src/Components/Form.js +++ b/src/Components/Form.js @@ -26,7 +26,7 @@ Form.propTypes = { // eslint-disable-next-line react/forbid-prop-types data: PropTypes.object.isRequired, onChange: PropTypes.func, - children: Promise.node, + children: PropTypes.node, }; Form.defaultProps = { diff --git a/src/EMS/PatientFields.js b/src/EMS/PatientFields.js index 4caa50f8..b7b114f5 100644 --- a/src/EMS/PatientFields.js +++ b/src/EMS/PatientFields.js @@ -47,7 +47,7 @@ function PatientFields({ ringdown, onChange }) { return (
- +
+ + + +
- +
@@ -89,17 +100,6 @@ function PatientFields({ ringdown, onChange }) { - - - -
@@ -167,7 +167,7 @@ function PatientFields({ ringdown, onChange }) {
- +
diff --git a/src/Models/Ringdown.js b/src/Models/Ringdown.js index a4951f42..91ede059 100644 --- a/src/Models/Ringdown.js +++ b/src/Models/Ringdown.js @@ -37,6 +37,19 @@ function overrideSetter(target, key, setter) { }); } +// specify the fields that must all have valid input to make the ringdown valid. the second array item is an optional function to determine +// whether the field's current value is valid as input. the array order should be the same as the field order in PatientFields. +const validatedFields = [ + ['ambulanceIdentifier'], + ['dispatchCallNumber'], + ['emergencyServiceResponseType'], + ['age'], + ['sex'], + ['chiefComplaintDescription'], + ['stableIndicator', (value) => typeof value === 'boolean'], + ['all', () => ValidationState.NO_INPUT], +]; + class Ringdown { static get Status() { return DeliveryStatus; @@ -48,7 +61,8 @@ class Ringdown { this.payload.emsCall = this.payload.emsCall || {}; this.payload.hospital = this.payload.hospital || {}; // default the urgency to Code 2 for a new ringdown - this.payload.patient = this.payload.patient || { emergencyServiceResponseType: 'CODE 2' }; + this.payload.patient = + this.payload.patient || (window.env.REACT_APP_DISABLE_CODE_3 && { emergencyServiceResponseType: 'CODE 2' }) || {}; this.payload.patientDelivery = this.payload.patientDelivery || {}; // add getters/setters for patient fields @@ -66,36 +80,7 @@ class Ringdown { this.restraintIndicator = newValue && this.restraintIndicator; }); - this.validationData = validationData || { - ambulanceIdentifier: new PatientFieldData( - 'ambulanceIdentifier', - 0, - this.ambulanceIdentifier ? ValidationState.INPUT : ValidationState.NO_INPUT - ), - dispatchCallNumber: new PatientFieldData( - 'dispatchCallNumber', - 1, - this.dispatchCallNumber ? ValidationState.INPUT : ValidationState.NO_INPUT - ), - age: new PatientFieldData('age', 2, this.age ? ValidationState.INPUT : ValidationState.NO_INPUT), - sex: new PatientFieldData('sex', 3, this.sex ? ValidationState.INPUT : ValidationState.NO_INPUT), - emergencyServiceResponseType: new PatientFieldData( - 'emergencyServiceResponseType', - 4, - this.emergencyServiceResponseType ? ValidationState.INPUT : ValidationState.NO_INPUT - ), - chiefComplaintDescription: new PatientFieldData( - 'chiefComplaintDescription', - 5, - this.chiefComplaintDescription ? ValidationState.INPUT : ValidationState.NO_INPUT - ), - stableIndicator: new PatientFieldData( - 'stableIndicator', - 6, - typeof this.stableIndicator === 'boolean' ? ValidationState.INPUT : ValidationState.NO_INPUT - ), - all: new PatientFieldData('all', 7, ValidationState.NO_INPUT), - }; + this.validationData = validationData || this.createValidationData(validatedFields); } clone() { @@ -253,6 +238,19 @@ class Ringdown { return 1; } + createValidationData(fields) { + return fields.reduce((result, field, i) => { + const [name, validator] = field; + const fieldValue = this[name]; + const value = typeof validator === 'function' ? validator(fieldValue) : fieldValue; + const state = value ? ValidationState.INPUT : ValidationState.NO_INPUT; + + result[name] = new PatientFieldData(name, i, state); + + return result; + }, {}); + } + validatePatientFields(updatedField, inputValue) { const updatedFieldHasValidations = updatedField in this.validationData; diff --git a/src/metadata/patient.js b/src/metadata/patient.js index 80c2f703..bbbd7e50 100644 --- a/src/metadata/patient.js +++ b/src/metadata/patient.js @@ -15,6 +15,12 @@ const fields = [ allowNull: false, unique: true, }, + { + name: 'emergencyServiceResponseType', + type: 'enum', + enumValues: ['CODE 2', 'CODE 3'], + required: true, + }, { name: 'age', type: 'integer', @@ -29,12 +35,6 @@ const fields = [ enumValues: ['MALE', 'FEMALE', 'NON-BINARY'], required: true, }, - { - name: 'emergencyServiceResponseType', - type: 'enum', - enumValues: ['CODE 2', 'CODE 3'], - required: true, - }, { name: 'chiefComplaintDescription', type: 'text',