@aehrc/smart-forms-renderer 0.7.1 → 0.8.0
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/README.md +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceAutocompleteItem.js +1 -2
- package/lib/components/FormComponents/ChoiceItems/ChoiceAutocompleteItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionFields.d.ts +12 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionFields.js +39 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionItem.d.ts +3 -3
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionItem.js +14 -27
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetFields.d.ts +13 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetFields.js +42 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetItem.d.ts +4 -3
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetItem.js +14 -22
- package/lib/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceItemSwitcher.d.ts +2 -2
- package/lib/components/FormComponents/ChoiceItems/ChoiceItemSwitcher.js +3 -3
- package/lib/components/FormComponents/ChoiceItems/ChoiceItemSwitcher.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionFields.d.ts +12 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionFields.js +27 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionItem.d.ts +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionItem.js +9 -24
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetFields.d.ts +14 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetFields.js +42 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetItem.d.ts +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetItem.js +8 -21
- package/lib/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionFields.d.ts +10 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionFields.js +41 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionItem.js +7 -23
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetFields.d.ts +12 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetFields.js +42 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetFields.js.map +1 -0
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetItem.js +8 -18
- package/lib/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetItem.js.map +1 -1
- package/lib/components/FormComponents/DecimalItem/DecimalItem.js +3 -2
- package/lib/components/FormComponents/DecimalItem/DecimalItem.js.map +1 -1
- package/lib/components/FormComponents/GridGroup/GridGroup.js +2 -2
- package/lib/components/FormComponents/GridGroup/GridGroup.js.map +1 -1
- package/lib/components/FormComponents/GridGroup/GridRow.js +2 -2
- package/lib/components/FormComponents/GridGroup/GridRow.js.map +1 -1
- package/lib/components/FormComponents/GroupItem/GroupChildItemSwitcher.d.ts +10 -0
- package/lib/components/FormComponents/GroupItem/GroupChildItemSwitcher.js +73 -0
- package/lib/components/FormComponents/GroupItem/GroupChildItemSwitcher.js.map +1 -0
- package/lib/components/FormComponents/GroupItem/GroupItem.js +3 -3
- package/lib/components/FormComponents/GroupItem/GroupItem.js.map +1 -1
- package/lib/components/FormComponents/GroupItem/GroupItemSwitcher.js +4 -4
- package/lib/components/FormComponents/GroupItem/GroupItemSwitcher.js.map +1 -1
- package/lib/components/FormComponents/GroupItem/ItemSwitcher.d.ts +10 -0
- package/lib/components/FormComponents/GroupItem/ItemSwitcher.js +81 -0
- package/lib/components/FormComponents/GroupItem/ItemSwitcher.js.map +1 -0
- package/lib/components/FormComponents/GroupItem/TopLevelGroupItemSwitcher.d.ts +10 -0
- package/lib/components/FormComponents/GroupItem/TopLevelGroupItemSwitcher.js +45 -0
- package/lib/components/FormComponents/GroupItem/TopLevelGroupItemSwitcher.js.map +1 -0
- package/lib/components/FormComponents/IntegerItem/IntegerItem.js +3 -2
- package/lib/components/FormComponents/IntegerItem/IntegerItem.js.map +1 -1
- package/lib/components/FormComponents/Item.styles.d.ts +2 -2
- package/lib/components/FormComponents/Item.styles.js +2 -2
- package/lib/components/FormComponents/Item.styles.js.map +1 -1
- package/lib/components/FormComponents/ItemParts/RadioAnswerOptionButtons.d.ts +8 -0
- package/lib/components/FormComponents/ItemParts/RadioAnswerOptionButtons.js +37 -0
- package/lib/components/FormComponents/ItemParts/RadioAnswerOptionButtons.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/RadioButtons.d.ts +8 -0
- package/lib/components/FormComponents/ItemParts/RadioButtons.js +37 -0
- package/lib/components/FormComponents/ItemParts/RadioButtons.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/RadioButtonsAnswerOption.d.ts +8 -0
- package/lib/components/FormComponents/ItemParts/RadioButtonsAnswerOption.js +37 -0
- package/lib/components/FormComponents/ItemParts/RadioButtonsAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteField.d.ts +20 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteField.js +49 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteField.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteFieldEndAdornment.d.ts +0 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteFieldEndAdornment.js +2 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteFieldEndAdornment.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteItem.js +11 -35
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteItem.js.map +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionFields.d.ts +17 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionFields.js +42 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionItem.d.ts +3 -3
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionItem.js +23 -36
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceItemSwitcher.d.ts +2 -2
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceItemSwitcher.js +3 -3
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceItemSwitcher.js.map +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionFields.d.ts +15 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionFields.js +29 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionItem.d.ts +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionItem.js +3 -23
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionField.d.ts +11 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionField.js +14 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionField.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionFields.d.ts +0 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionFields.js +2 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionFields.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionItem.js +18 -23
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionItem.js.map +1 -1
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetField.d.ts +12 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetField.js +16 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetField.js.map +1 -0
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetItem.js +8 -14
- package/lib/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetItem.js.map +1 -1
- package/lib/components/FormComponents/RepeatGroup/RepeatGroup.js +4 -3
- package/lib/components/FormComponents/RepeatGroup/RepeatGroup.js.map +1 -1
- package/lib/components/FormComponents/RepeatGroup/index.d.ts +1 -0
- package/lib/components/FormComponents/RepeatGroup/index.js +18 -0
- package/lib/components/FormComponents/RepeatGroup/index.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.js +1 -1
- package/lib/components/FormComponents/RepeatItem/RepeatItem.js.map +1 -1
- package/lib/components/FormComponents/SingleItem/SingleItem.d.ts +2 -2
- package/lib/components/FormComponents/SingleItem/SingleItem.js +2 -2
- package/lib/components/FormComponents/SingleItem/SingleItem.js.map +1 -1
- package/lib/components/FormComponents/SingleItem/SingleItemSwitcher.d.ts +2 -2
- package/lib/components/FormComponents/SingleItem/SingleItemSwitcher.js +3 -3
- package/lib/components/FormComponents/SingleItem/SingleItemSwitcher.js.map +1 -1
- package/lib/components/FormComponents/SingleItem/index.d.ts +1 -0
- package/lib/components/FormComponents/SingleItem/index.js +18 -0
- package/lib/components/FormComponents/SingleItem/index.js.map +1 -0
- package/lib/components/FormComponents/StringItem/StringItem.js +3 -2
- package/lib/components/FormComponents/StringItem/StringItem.js.map +1 -1
- package/lib/components/FormComponents/Tables/AddItemButton.d.ts +8 -0
- package/lib/components/FormComponents/Tables/AddItemButton.js +28 -0
- package/lib/components/FormComponents/Tables/AddItemButton.js.map +1 -0
- package/lib/components/FormComponents/Tables/AddRowButton.d.ts +8 -0
- package/lib/components/FormComponents/Tables/AddRowButton.js +28 -0
- package/lib/components/FormComponents/Tables/AddRowButton.js.map +1 -0
- package/lib/components/FormComponents/Tables/GroupTable.d.ts +10 -0
- package/lib/components/FormComponents/Tables/GroupTable.js +108 -0
- package/lib/components/FormComponents/Tables/GroupTable.js.map +1 -0
- package/lib/components/FormComponents/Tables/GroupTableRow.d.ts +10 -0
- package/lib/components/FormComponents/Tables/GroupTableRow.js +46 -0
- package/lib/components/FormComponents/Tables/GroupTableRow.js.map +1 -0
- package/lib/components/FormComponents/Tables/QItemGroupTable.js +7 -5
- package/lib/components/FormComponents/Tables/QItemGroupTable.js.map +1 -1
- package/lib/components/FormComponents/Tables/QItemGroupTableRow.js +2 -2
- package/lib/components/FormComponents/Tables/QItemGroupTableRow.js.map +1 -1
- package/lib/components/FormComponents/Tables/index.d.ts +1 -0
- package/lib/components/FormComponents/Tables/index.js +18 -0
- package/lib/components/FormComponents/Tables/index.js.map +1 -0
- package/lib/components/FormComponents/TextItem/TextItem.js +3 -2
- package/lib/components/FormComponents/TextItem/TextItem.js.map +1 -1
- package/lib/components/FormComponents/index.d.ts +3 -0
- package/lib/components/FormComponents/index.js +20 -0
- package/lib/components/FormComponents/index.js.map +1 -0
- package/lib/components/Renderer/BaseRenderer.js +26 -14
- package/lib/components/Renderer/BaseRenderer.js.map +1 -1
- package/lib/components/Renderer/FormBodyCollapsible.js +2 -2
- package/lib/components/Renderer/FormBodyCollapsible.js.map +1 -1
- package/lib/components/Renderer/FormBodyTabbed.js +3 -3
- package/lib/components/Renderer/FormBodyTabbed.js.map +1 -1
- package/lib/components/Renderer/FormTopLevelItem.d.ts +4 -4
- package/lib/components/Renderer/FormTopLevelItem.js +14 -1
- package/lib/components/Renderer/FormTopLevelItem.js.map +1 -1
- package/lib/components/Tabs/FormBodySingleTab.js +1 -1
- package/lib/components/Tabs/FormBodySingleTab.js.map +1 -1
- package/lib/components/Tabs/FormBodyTabList.d.ts +1 -0
- package/lib/components/Tabs/FormBodyTabList.js +3 -4
- package/lib/components/Tabs/FormBodyTabList.js.map +1 -1
- package/lib/components/Tabs/FormBodyTabListWrapper.d.ts +1 -1
- package/lib/components/Tabs/FormBodyTabListWrapper.js +6 -13
- package/lib/components/Tabs/FormBodyTabListWrapper.js.map +1 -1
- package/lib/components/Tabs/ShowCompletedTabsSection.d.ts +7 -0
- package/lib/components/Tabs/ShowCompletedTabsSection.js +34 -0
- package/lib/components/Tabs/ShowCompletedTabsSection.js.map +1 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +1 -0
- package/lib/components/index.js.map +1 -1
- package/lib/hooks/index.d.ts +1 -0
- package/lib/hooks/index.js +2 -0
- package/lib/hooks/index.js.map +1 -0
- package/lib/hooks/useContextDisplayItems.d.ts +6 -0
- package/lib/hooks/useContextDisplayItems.js +30 -0
- package/lib/hooks/useContextDisplayItems.js.map +1 -0
- package/lib/hooks/useDecimalUpdateFromProp.d.ts +2 -0
- package/lib/hooks/useDecimalUpdateFromProp.js +29 -0
- package/lib/hooks/useDecimalUpdateFromProp.js.map +1 -0
- package/lib/hooks/useInitialiseRenderer.js +2 -2
- package/lib/hooks/useInitialiseRenderer.js.map +1 -1
- package/lib/hooks/useInitialiseRepeatAnswers.d.ts +2 -2
- package/lib/hooks/useInitialiseRepeatAnswers.js +21 -15
- package/lib/hooks/useInitialiseRepeatAnswers.js.map +1 -1
- package/lib/hooks/useInitialiseRepeatGroups.d.ts +2 -1
- package/lib/hooks/useInitialiseRepeatGroups.js +21 -15
- package/lib/hooks/useInitialiseRepeatGroups.js.map +1 -1
- package/lib/hooks/useIntegerUpdateFromProp.d.ts +2 -0
- package/lib/hooks/useIntegerUpdateFromProp.js +29 -0
- package/lib/hooks/useIntegerUpdateFromProp.js.map +1 -0
- package/lib/hooks/useNumberInput.d.ts +3 -0
- package/lib/hooks/useNumberInput.js +31 -0
- package/lib/hooks/useNumberInput.js.map +1 -0
- package/lib/hooks/useNumberUpdateFromProp.d.ts +2 -0
- package/lib/hooks/useNumberUpdateFromProp.js +29 -0
- package/lib/hooks/useNumberUpdateFromProp.js.map +1 -0
- package/lib/hooks/useRepeatItemState.d.ts +5 -0
- package/lib/hooks/useRepeatItemState.js +35 -0
- package/lib/hooks/useRepeatItemState.js.map +1 -0
- package/lib/hooks/useRepeatItemUpdateFromProp.d.ts +2 -0
- package/lib/hooks/useRepeatItemUpdateFromProp.js +29 -0
- package/lib/hooks/useRepeatItemUpdateFromProp.js.map +1 -0
- package/lib/hooks/useStringField.d.ts +2 -0
- package/lib/hooks/useStringField.js +29 -0
- package/lib/hooks/useStringField.js.map +1 -0
- package/lib/hooks/useStringInput.d.ts +3 -0
- package/lib/hooks/useStringInput.js +31 -0
- package/lib/hooks/useStringInput.js.map +1 -0
- package/lib/hooks/useStringUpdateFromProp.d.ts +2 -0
- package/lib/hooks/useStringUpdateFromProp.js +29 -0
- package/lib/hooks/useStringUpdateFromProp.js.map +1 -0
- package/lib/hooks/useTerminologyServerQuery.js +3 -6
- package/lib/hooks/useTerminologyServerQuery.js.map +1 -1
- package/lib/index.d.ts +16 -0
- package/lib/index.js +29 -2
- package/lib/index.js.map +1 -1
- package/lib/interfaces/questionnaireStore.interface.d.ts +1 -0
- package/lib/interfaces/renderProps.interface.d.ts +3 -0
- package/lib/stores/useQuestionnaireResponseStore.d.ts +2 -1
- package/lib/stores/useQuestionnaireResponseStore.js +17 -10
- package/lib/stores/useQuestionnaireResponseStore.js.map +1 -1
- package/lib/stores/useQuestionnaireStore.d.ts +2 -1
- package/lib/stores/useQuestionnaireStore.js +5 -2
- package/lib/stores/useQuestionnaireStore.js.map +1 -1
- package/lib/theme/overrides/Overrides.js +1 -2
- package/lib/theme/overrides/Overrides.js.map +1 -1
- package/lib/utils/calculatedExpression.js +2 -2
- package/lib/utils/calculatedExpression.js.map +1 -1
- package/lib/utils/formChanges.d.ts +18 -0
- package/lib/utils/formChanges.js +91 -0
- package/lib/utils/formChanges.js.map +1 -0
- package/lib/utils/formChangesOld.d.ts +18 -0
- package/lib/utils/formChangesOld.js +91 -0
- package/lib/utils/formChangesOld.js.map +1 -0
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/index.js +18 -0
- package/lib/utils/index.js.map +1 -0
- package/lib/utils/mapItem.d.ts +2 -2
- package/lib/utils/mapItem.js +3 -3
- package/lib/utils/mapItem.js.map +1 -1
- package/lib/utils/qItem.d.ts +2 -0
- package/lib/utils/qItem.js +22 -0
- package/lib/utils/qItem.js.map +1 -1
- package/lib/utils/qrItem.d.ts +3 -4
- package/lib/utils/qrItem.js +94 -96
- package/lib/utils/qrItem.js.map +1 -1
- package/lib/utils/questionnaireStoreUtils/createQuestionaireModel.js +4 -0
- package/lib/utils/questionnaireStoreUtils/createQuestionaireModel.js.map +1 -1
- package/lib/utils/repopulate.d.ts +9 -0
- package/lib/utils/repopulate.js +133 -0
- package/lib/utils/repopulate.js.map +1 -0
- package/lib/utils/repopulateGenerateItems.d.ts +9 -0
- package/lib/utils/repopulateGenerateItems.js +133 -0
- package/lib/utils/repopulateGenerateItems.js.map +1 -0
- package/lib/utils/repopulateIntoResponse.d.ts +3 -0
- package/lib/utils/repopulateIntoResponse.js +92 -0
- package/lib/utils/repopulateIntoResponse.js.map +1 -0
- package/lib/utils/repopulateItems.d.ts +9 -0
- package/lib/utils/repopulateItems.js +130 -0
- package/lib/utils/repopulateItems.js.map +1 -0
- package/lib/utils/repopulateRepeatGroup.d.ts +4 -0
- package/lib/utils/repopulateRepeatGroup.js +54 -0
- package/lib/utils/repopulateRepeatGroup.js.map +1 -0
- package/package.json +7 -5
- package/src/components/FormComponents/ChoiceItems/ChoiceAutocompleteItem.tsx +1 -2
- package/src/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionFields.tsx +85 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerOptionItem.tsx +35 -58
- package/src/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetFields.tsx +79 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceCheckboxAnswerValueSetItem.tsx +37 -50
- package/src/components/FormComponents/ChoiceItems/ChoiceItemSwitcher.tsx +10 -5
- package/src/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionFields.tsx +48 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceRadioAnswerOptionItem.tsx +25 -53
- package/src/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetFields.tsx +83 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceRadioAnswerValueSetItem.tsx +27 -49
- package/src/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionFields.tsx +81 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceSelectAnswerOptionItem.tsx +19 -54
- package/src/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetFields.tsx +97 -0
- package/src/components/FormComponents/ChoiceItems/ChoiceSelectAnswerValueSetItem.tsx +22 -60
- package/src/components/FormComponents/DecimalItem/DecimalItem.tsx +3 -2
- package/src/components/FormComponents/GridGroup/GridGroup.tsx +2 -2
- package/src/components/FormComponents/GridGroup/GridRow.tsx +2 -2
- package/src/components/FormComponents/GroupItem/GroupItem.tsx +3 -3
- package/src/components/FormComponents/GroupItem/GroupItemSwitcher.tsx +4 -4
- package/src/components/FormComponents/IntegerItem/IntegerItem.tsx +3 -2
- package/src/components/FormComponents/Item.styles.ts +2 -2
- package/src/components/FormComponents/ItemParts/RadioAnswerOptionButtons.tsx +72 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteField.tsx +131 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceAutocompleteItem.tsx +38 -93
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionFields.tsx +112 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceCheckboxAnswerOptionItem.tsx +57 -76
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceItemSwitcher.tsx +8 -5
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionFields.tsx +72 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceRadioAnswerOptionItem.tsx +12 -59
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionField.tsx +54 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerOptionItem.tsx +40 -64
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetField.tsx +63 -0
- package/src/components/FormComponents/OpenChoiceItems/OpenChoiceSelectAnswerValueSetItem.tsx +22 -50
- package/src/components/FormComponents/RepeatGroup/RepeatGroup.tsx +4 -3
- package/src/{theme/overrides/Backdrop.ts → components/FormComponents/RepeatGroup/index.ts} +1 -17
- package/src/components/FormComponents/RepeatItem/RepeatItem.tsx +1 -1
- package/src/components/FormComponents/SingleItem/SingleItem.tsx +6 -3
- package/src/components/FormComponents/SingleItem/SingleItemSwitcher.tsx +7 -3
- package/src/components/FormComponents/SingleItem/index.ts +18 -0
- package/src/components/FormComponents/StringItem/StringItem.tsx +3 -2
- package/src/components/FormComponents/Tables/AddRowButton.tsx +49 -0
- package/src/components/FormComponents/Tables/{QItemGroupTable.tsx → GroupTable.tsx} +21 -23
- package/src/components/FormComponents/Tables/{QItemGroupTableRow.tsx → GroupTableRow.tsx} +4 -4
- package/src/components/FormComponents/Tables/index.ts +18 -0
- package/src/components/FormComponents/TextItem/TextItem.tsx +3 -2
- package/src/components/FormComponents/index.ts +20 -0
- package/src/components/Renderer/BaseRenderer.tsx +39 -18
- package/src/components/Renderer/FormBodyCollapsible.tsx +2 -2
- package/src/components/Renderer/FormBodyTabbed.tsx +3 -3
- package/src/components/Renderer/FormTopLevelItem.tsx +33 -4
- package/src/components/Tabs/FormBodySingleTab.tsx +1 -1
- package/src/components/Tabs/FormBodyTabList.tsx +5 -8
- package/src/components/Tabs/FormBodyTabListWrapper.tsx +15 -26
- package/src/components/Tabs/ShowCompletedTabsSection.tsx +52 -0
- package/src/components/index.ts +1 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useContextDisplayItems.ts +40 -0
- package/src/hooks/useInitialiseRenderer.ts +2 -2
- package/src/hooks/useInitialiseRepeatAnswers.ts +28 -17
- package/src/hooks/useInitialiseRepeatGroups.ts +28 -17
- package/src/hooks/useNumberInput.ts +38 -0
- package/src/hooks/useStringInput.ts +38 -0
- package/src/hooks/useTerminologyServerQuery.ts +3 -6
- package/src/index.ts +45 -2
- package/src/interfaces/questionnaireStore.interface.ts +1 -0
- package/src/interfaces/renderProps.interface.ts +4 -0
- package/src/stores/useQuestionnaireResponseStore.ts +15 -10
- package/src/stores/useQuestionnaireStore.ts +10 -3
- package/src/theme/overrides/Overrides.ts +0 -2
- package/src/utils/calculatedExpression.ts +2 -2
- package/src/utils/formChanges.ts +141 -0
- package/src/utils/index.ts +18 -0
- package/src/utils/mapItem.ts +6 -4
- package/src/utils/qItem.ts +29 -0
- package/src/utils/qrItem.ts +108 -97
- package/src/utils/questionnaireStoreUtils/createQuestionaireModel.ts +4 -0
- package/src/utils/repopulateIntoResponse.ts +153 -0
- package/src/utils/repopulateItems.ts +206 -0
- package/src/utils/repopulateRepeatGroup.ts +68 -0
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2023 Commonwealth Scientific and Industrial Research
|
|
3
|
+
* Organisation (CSIRO) ABN 41 687 119 230.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
import type { QuestionnaireResponseItemAnswer } from 'fhir/r4';
|
|
19
|
+
|
|
20
|
+
type JsonDiffOperator = '+' | '-' | '~' | ' ';
|
|
21
|
+
|
|
22
|
+
type QuestionnaireResponseItemDiffArray = [JsonDiffOperator, QuestionnaireResponseDiffItem];
|
|
23
|
+
type QuestionnaireResponseItemAnswerDiffArray = [JsonDiffOperator, QuestionnaireResponseItemAnswer];
|
|
24
|
+
|
|
25
|
+
interface QuestionnaireResponseDiffItem {
|
|
26
|
+
linkId: string;
|
|
27
|
+
item: QuestionnaireResponseItemDiffArray[] | undefined;
|
|
28
|
+
answer:
|
|
29
|
+
| QuestionnaireResponseItemAnswer[]
|
|
30
|
+
| QuestionnaireResponseItemAnswerDiffArray[]
|
|
31
|
+
| undefined;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
interface ItemChange {
|
|
35
|
+
linkId: string;
|
|
36
|
+
itemType: string;
|
|
37
|
+
operation: 'add' | 'remove' | 'update';
|
|
38
|
+
value: QuestionnaireResponseItemAnswer;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function readFormChanges(formChanges: object, itemTypes: Record<string, string>) {
|
|
42
|
+
if (!('item' in formChanges)) {
|
|
43
|
+
return {};
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
const changedItems: Record<string, ItemChange | null> = {};
|
|
47
|
+
const diffArrays = formChanges.item as QuestionnaireResponseItemDiffArray[];
|
|
48
|
+
for (const diffArray of diffArrays) {
|
|
49
|
+
readItemChangesRecursive(diffArray, itemTypes, changedItems);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return changedItems;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export function readItemChangesRecursive(
|
|
56
|
+
diffArray: QuestionnaireResponseItemDiffArray,
|
|
57
|
+
itemTypes: Record<string, string>,
|
|
58
|
+
changedItems: Record<string, ItemChange | null>
|
|
59
|
+
) {
|
|
60
|
+
const operator = diffArray[0];
|
|
61
|
+
const diffItem = diffArray[1];
|
|
62
|
+
|
|
63
|
+
if (!operator || !diffItem) {
|
|
64
|
+
return changedItems;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
changedItems[diffItem.linkId] = null;
|
|
68
|
+
|
|
69
|
+
const childDiffArrays = diffItem.item;
|
|
70
|
+
if (childDiffArrays && childDiffArrays.length > 0) {
|
|
71
|
+
for (const childDiffArray of childDiffArrays) {
|
|
72
|
+
readItemChangesRecursive(childDiffArray, itemTypes, changedItems);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// if (operator !== ' ') {
|
|
77
|
+
// console.log(operator, diffItem);
|
|
78
|
+
// }
|
|
79
|
+
|
|
80
|
+
// explore answer diff arrays
|
|
81
|
+
// exmaple: [["+", {"valueString": "test"}], ["-", {"valueString": "test"}]]
|
|
82
|
+
// or it could be a regular answer array
|
|
83
|
+
// exmaple: [{"valueString": "test"}, {"valueString": "test"}]
|
|
84
|
+
|
|
85
|
+
const answerDiffArrays = diffItem.answer;
|
|
86
|
+
if (answerDiffArrays && isAnswerDiffArray(answerDiffArrays)) {
|
|
87
|
+
for (const answerDiffArray of answerDiffArrays) {
|
|
88
|
+
getItemChange(diffItem, answerDiffArray, itemTypes, changedItems);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
return changedItems;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
function getItemChange(
|
|
96
|
+
diffItem: QuestionnaireResponseDiffItem,
|
|
97
|
+
answerDiffArray: QuestionnaireResponseItemAnswerDiffArray,
|
|
98
|
+
itemTypes: Record<string, string>,
|
|
99
|
+
changedItems: Record<string, ItemChange | null>
|
|
100
|
+
) {
|
|
101
|
+
const operator = answerDiffArray[0];
|
|
102
|
+
const answer = answerDiffArray[1];
|
|
103
|
+
|
|
104
|
+
if (operator === ' ') {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const itemType = itemTypes[diffItem.linkId];
|
|
109
|
+
const operation = answerDiffOperationSwitcher(operator);
|
|
110
|
+
if (operation) {
|
|
111
|
+
changedItems[diffItem.linkId] = {
|
|
112
|
+
linkId: diffItem.linkId,
|
|
113
|
+
itemType: itemType,
|
|
114
|
+
operation: operation,
|
|
115
|
+
value: answer
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
function answerDiffOperationSwitcher(operator: JsonDiffOperator): ItemChange['operation'] | null {
|
|
121
|
+
switch (operator) {
|
|
122
|
+
case '+':
|
|
123
|
+
return 'add';
|
|
124
|
+
case '-':
|
|
125
|
+
return 'remove';
|
|
126
|
+
case '~':
|
|
127
|
+
return 'update';
|
|
128
|
+
default:
|
|
129
|
+
return null;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// type predicates
|
|
134
|
+
function isAnswerDiffArray(answer: any[]): answer is QuestionnaireResponseItemAnswerDiffArray[] {
|
|
135
|
+
return answer.every(
|
|
136
|
+
(answerItem) =>
|
|
137
|
+
Array.isArray(answerItem) &&
|
|
138
|
+
typeof answerItem[0] === 'string' &&
|
|
139
|
+
typeof answerItem[1] === 'object'
|
|
140
|
+
);
|
|
141
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2023 Commonwealth Scientific and Industrial Research
|
|
3
|
+
* Organisation (CSIRO) ABN 41 687 119 230.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
export { isSpecificItemControl } from './itemControl';
|
package/src/utils/mapItem.ts
CHANGED
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
* limitations under the License.
|
|
16
16
|
*/
|
|
17
17
|
|
|
18
|
-
import type { QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
18
|
+
import type { Questionnaire, QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
19
19
|
import { isRepeatItemAndNotCheckbox } from './qItem';
|
|
20
20
|
|
|
21
21
|
/**
|
|
@@ -84,13 +84,15 @@ export function getQrItemsIndex(
|
|
|
84
84
|
*
|
|
85
85
|
* @author Sean Fong
|
|
86
86
|
*/
|
|
87
|
-
export function mapQItemsIndex(
|
|
88
|
-
|
|
87
|
+
export function mapQItemsIndex(
|
|
88
|
+
questionnaireOrQItem: QuestionnaireItem | Questionnaire
|
|
89
|
+
): Record<string, number> {
|
|
90
|
+
if (!questionnaireOrQItem.item) {
|
|
89
91
|
return {};
|
|
90
92
|
}
|
|
91
93
|
|
|
92
94
|
// generate a <linkId, QItemIndex> dictionary
|
|
93
|
-
return
|
|
95
|
+
return questionnaireOrQItem.item.reduce((mapping: Record<string, number>, item, i) => {
|
|
94
96
|
mapping[item.linkId] = i;
|
|
95
97
|
return mapping;
|
|
96
98
|
}, {});
|
package/src/utils/qItem.ts
CHANGED
|
@@ -101,3 +101,32 @@ export function getXHtmlStringFromQuestionnaire(questionnaire: Questionnaire): s
|
|
|
101
101
|
}
|
|
102
102
|
return null;
|
|
103
103
|
}
|
|
104
|
+
|
|
105
|
+
export function getLinkIdTypeTuples(questionnaire: Questionnaire): [string, string][] {
|
|
106
|
+
if (!questionnaire.item || questionnaire.item.length === 0) {
|
|
107
|
+
return [];
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
const linkIds: [string, string][] = [];
|
|
111
|
+
for (const topLevelItem of questionnaire.item) {
|
|
112
|
+
linkIds.push(...getLinkIdTypeTuplesFromItemRecursive(topLevelItem));
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return linkIds;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export function getLinkIdTypeTuplesFromItemRecursive(qItem: QuestionnaireItem): [string, string][] {
|
|
119
|
+
const linkIds: [string, string][] = [];
|
|
120
|
+
|
|
121
|
+
if (qItem.linkId) {
|
|
122
|
+
linkIds.push([qItem.linkId, qItem.type]);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
if (qItem.item) {
|
|
126
|
+
for (const childItem of qItem.item) {
|
|
127
|
+
linkIds.push(...getLinkIdTypeTuplesFromItemRecursive(childItem));
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return linkIds;
|
|
132
|
+
}
|
package/src/utils/qrItem.ts
CHANGED
|
@@ -25,12 +25,13 @@ import type {
|
|
|
25
25
|
import type { QrRepeatGroup } from '../interfaces/repeatGroup.interface';
|
|
26
26
|
|
|
27
27
|
/**
|
|
28
|
-
* Create
|
|
29
|
-
* A questionnaire form item is the first item of a questionnaire
|
|
28
|
+
* Create an empty questionnaireResponse from a given questionnaire
|
|
30
29
|
*
|
|
31
30
|
* @author Sean Fong
|
|
32
31
|
*/
|
|
33
|
-
export function
|
|
32
|
+
export function createEmptyQuestionnaireResponse(
|
|
33
|
+
questionnaire: Questionnaire
|
|
34
|
+
): QuestionnaireResponse {
|
|
34
35
|
const questionnaireResponse: QuestionnaireResponse = {
|
|
35
36
|
resourceType: 'QuestionnaireResponse',
|
|
36
37
|
status: 'in-progress'
|
|
@@ -134,116 +135,126 @@ export function createEmptyQrItemWithUnit(
|
|
|
134
135
|
*
|
|
135
136
|
* @author Sean Fong
|
|
136
137
|
*/
|
|
137
|
-
export function
|
|
138
|
+
export function updateQrItemsInGroup(
|
|
138
139
|
newQrItem: QuestionnaireResponseItem | null,
|
|
139
140
|
newQrRepeatGroup: QrRepeatGroup | null,
|
|
140
|
-
|
|
141
|
+
questionnaireResponseOrQrItem: QuestionnaireResponseItem | QuestionnaireResponse,
|
|
141
142
|
qItemsIndexMap: Record<string, number>
|
|
142
143
|
): void {
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
if (newQrItem && newQrItem.linkId in qItemsIndexMap) {
|
|
149
|
-
if (qrGroup.item.length === 0) {
|
|
150
|
-
qrGroup.item.push(newQrItem);
|
|
151
|
-
} else {
|
|
152
|
-
// Get actual sequence index of qrItem within qrGroup
|
|
153
|
-
const newQrItemIndex = qItemsIndexMap[newQrItem.linkId];
|
|
154
|
-
|
|
155
|
-
for (let i = 0; i < qrItemsRealIndexArr.length; i++) {
|
|
156
|
-
// Add qrItem at the end of qrGroup if it is larger than the other indexes
|
|
157
|
-
if (newQrItemIndex > qrItemsRealIndexArr[i]) {
|
|
158
|
-
if (i === qrItemsRealIndexArr.length - 1) {
|
|
159
|
-
qrGroup.item.push(newQrItem);
|
|
160
|
-
}
|
|
161
|
-
continue;
|
|
162
|
-
}
|
|
144
|
+
const qrItems = questionnaireResponseOrQrItem.item;
|
|
145
|
+
if (!qrItems) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
163
148
|
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
// newQrItem has answer value
|
|
168
|
-
qrGroup.item[i] = newQrItem;
|
|
169
|
-
} else {
|
|
170
|
-
// newQrItem has no answer value
|
|
171
|
-
qrGroup.item.splice(i, 1);
|
|
172
|
-
}
|
|
173
|
-
break;
|
|
174
|
-
}
|
|
149
|
+
// Get actual sequence indexes of qrItems present within a qrGroup
|
|
150
|
+
// e.g. qrGroup has 4 fields but only the 2nd and 3rd field have values - resulting array is [1, 2]
|
|
151
|
+
const qrItemsRealIndexArr = qrItems.map((qrItem) => qItemsIndexMap[qrItem.linkId]);
|
|
175
152
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
153
|
+
if (newQrItem && newQrItem.linkId in qItemsIndexMap) {
|
|
154
|
+
if (qrItems.length === 0) {
|
|
155
|
+
qrItems.push(newQrItem);
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// Get actual sequence index of qrItem within qrGroup
|
|
160
|
+
const newQrItemIndex = qItemsIndexMap[newQrItem.linkId];
|
|
161
|
+
for (let i = 0; i < qrItemsRealIndexArr.length; i++) {
|
|
162
|
+
// Add qrItem at the end of qrGroup if it is larger than the other indexes
|
|
163
|
+
if (newQrItemIndex > qrItemsRealIndexArr[i]) {
|
|
164
|
+
if (i === qrItemsRealIndexArr.length - 1) {
|
|
165
|
+
qrItems.push(newQrItem);
|
|
181
166
|
}
|
|
167
|
+
continue;
|
|
182
168
|
}
|
|
183
|
-
} else if (newQrRepeatGroup && newQrRepeatGroup.linkId in qItemsIndexMap) {
|
|
184
|
-
const newQrItems = newQrRepeatGroup.qrItems;
|
|
185
|
-
if (qrGroup.item.length === 0) {
|
|
186
|
-
qrGroup.item.push(...newQrItems);
|
|
187
|
-
} else {
|
|
188
|
-
// Get actual sequence index of qrItems within qrGroup
|
|
189
|
-
const newQrItemIndex = qItemsIndexMap[newQrRepeatGroup.linkId];
|
|
190
|
-
|
|
191
|
-
for (let i = 0; i < qrItemsRealIndexArr.length; i++) {
|
|
192
|
-
// Add qrItem at the end of qrGroup if it is larger than the other indexes
|
|
193
|
-
if (newQrItemIndex > qrItemsRealIndexArr[i]) {
|
|
194
|
-
if (i === qrItemsRealIndexArr.length - 1) {
|
|
195
|
-
qrGroup.item.push(...newQrItems);
|
|
196
|
-
}
|
|
197
|
-
continue;
|
|
198
|
-
}
|
|
199
169
|
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
170
|
+
// Replace or delete qrItem at its supposed position if its index is already present within qrGroup
|
|
171
|
+
if (newQrItemIndex === qrItemsRealIndexArr[i]) {
|
|
172
|
+
// newQrItem has answer value
|
|
173
|
+
if (newQrItem.item?.length || newQrItem.answer?.length) {
|
|
174
|
+
qrItems[i] = newQrItem;
|
|
175
|
+
break;
|
|
176
|
+
}
|
|
207
177
|
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
178
|
+
// newQrItem has no answer value
|
|
179
|
+
qrItems.splice(i, 1);
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
// Add qrItem at its supposed position if its index is not present within qrGroup
|
|
184
|
+
if (newQrItemIndex < qrItemsRealIndexArr[i]) {
|
|
185
|
+
qrItems.splice(i, 0, newQrItem);
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
if (newQrRepeatGroup && newQrRepeatGroup.linkId in qItemsIndexMap) {
|
|
192
|
+
const newQrItems = newQrRepeatGroup.qrItems;
|
|
193
|
+
if (qrItems.length === 0) {
|
|
194
|
+
qrItems.push(...newQrItems);
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
// Get actual sequence index of qrItems within qrGroup
|
|
199
|
+
const newQrItemIndex = qItemsIndexMap[newQrRepeatGroup.linkId];
|
|
200
|
+
for (let i = 0; i < qrItemsRealIndexArr.length; i++) {
|
|
201
|
+
// Add qrItem at the end of qrGroup if it is larger than the other indexes
|
|
202
|
+
if (newQrItemIndex > qrItemsRealIndexArr[i]) {
|
|
203
|
+
if (i === qrItemsRealIndexArr.length - 1) {
|
|
204
|
+
qrItems.push(...newQrItems);
|
|
205
|
+
}
|
|
206
|
+
continue;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
// Replace or delete qrItem at its supposed position if its index is already present within qrGroup
|
|
210
|
+
if (newQrItemIndex === qrItemsRealIndexArr[i]) {
|
|
211
|
+
// Get number of repeatGroupItems that has the same linkId present in qrGroup
|
|
212
|
+
let repeatGroupItemCount = 0;
|
|
213
|
+
while (newQrItemIndex === qrItemsRealIndexArr[i + repeatGroupItemCount]) {
|
|
214
|
+
repeatGroupItemCount++;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
// Replace each repeat group qrItem with their new counterparts
|
|
218
|
+
if (newQrItems.length === repeatGroupItemCount) {
|
|
219
|
+
for (let j = 0; j < newQrItems.length; j++) {
|
|
220
|
+
qrItems[i + j] = newQrItems[j];
|
|
221
|
+
}
|
|
222
|
+
break;
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
if (newQrItems.length > repeatGroupItemCount) {
|
|
226
|
+
// Replace each repeat group qrItem with their new counterparts,
|
|
227
|
+
// followed by adding an extra newQrItem behind the newly replaced qrItems
|
|
228
|
+
for (let j = 0, k = repeatGroupItemCount; j < newQrItems.length; j++, k--) {
|
|
229
|
+
if (k > 0) {
|
|
230
|
+
qrItems[i + j] = newQrItems[j];
|
|
231
|
+
} else {
|
|
232
|
+
qrItems.splice(i + j, 0, newQrItems[j]);
|
|
236
233
|
}
|
|
237
234
|
}
|
|
235
|
+
break;
|
|
236
|
+
}
|
|
238
237
|
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
238
|
+
if (newQrItems.length < repeatGroupItemCount) {
|
|
239
|
+
// Replace each repeat group qrItem with their new counterparts (except the last one),
|
|
240
|
+
// followed by deleting the last newQrItem which wasn't replaced
|
|
241
|
+
for (let j = 0; j < repeatGroupItemCount; j++) {
|
|
242
|
+
if (j <= newQrItems.length - 1) {
|
|
243
|
+
qrItems[i + j] = newQrItems[j];
|
|
244
|
+
} else {
|
|
245
|
+
qrItems.splice(i + j, 1);
|
|
243
246
|
}
|
|
244
|
-
break;
|
|
245
247
|
}
|
|
248
|
+
break;
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
// Add qrItem at its supposed position if its index is not present within qrGroup
|
|
253
|
+
if (newQrItemIndex < qrItemsRealIndexArr[i]) {
|
|
254
|
+
for (let j = 0; j < newQrItems.length; j++) {
|
|
255
|
+
qrItems.splice(i + j, 0, newQrItems[j]);
|
|
246
256
|
}
|
|
257
|
+
break;
|
|
247
258
|
}
|
|
248
259
|
}
|
|
249
260
|
}
|
|
@@ -27,6 +27,7 @@ import { extractOtherExtensions } from './extractOtherExtensions';
|
|
|
27
27
|
import type { Variables } from '../../interfaces/variables.interface';
|
|
28
28
|
import { resolveValueSets } from './resolveValueSets';
|
|
29
29
|
import { addAdditionalVariables } from './addAdditionalVariables';
|
|
30
|
+
import { getLinkIdTypeTuples } from '../qItem';
|
|
30
31
|
|
|
31
32
|
export async function createQuestionnaireModel(
|
|
32
33
|
questionnaire: Questionnaire,
|
|
@@ -37,6 +38,7 @@ export async function createQuestionnaireModel(
|
|
|
37
38
|
return createEmptyModel();
|
|
38
39
|
}
|
|
39
40
|
|
|
41
|
+
const itemTypes: Record<string, string> = Object.fromEntries(getLinkIdTypeTuples(questionnaire));
|
|
40
42
|
const tabs: Tabs = extractTabs(questionnaire);
|
|
41
43
|
|
|
42
44
|
const launchContexts: Record<string, LaunchContext> = extractLaunchContexts(questionnaire);
|
|
@@ -75,6 +77,7 @@ export async function createQuestionnaireModel(
|
|
|
75
77
|
processedValueSetCodings = resolveValueSetsResult.processedValueSetCodings;
|
|
76
78
|
|
|
77
79
|
return {
|
|
80
|
+
itemTypes,
|
|
78
81
|
tabs,
|
|
79
82
|
variables,
|
|
80
83
|
launchContexts,
|
|
@@ -89,6 +92,7 @@ export async function createQuestionnaireModel(
|
|
|
89
92
|
|
|
90
93
|
function createEmptyModel(): QuestionnaireModel {
|
|
91
94
|
return {
|
|
95
|
+
itemTypes: {},
|
|
92
96
|
tabs: {},
|
|
93
97
|
variables: { fhirPathVariables: {}, xFhirQueryVariables: {} },
|
|
94
98
|
launchContexts: {},
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
Questionnaire,
|
|
3
|
+
QuestionnaireItem,
|
|
4
|
+
QuestionnaireResponse,
|
|
5
|
+
QuestionnaireResponseItem
|
|
6
|
+
} from 'fhir/r4';
|
|
7
|
+
import type { ItemToRepopulate } from './repopulateItems';
|
|
8
|
+
import { getQrItemsIndex, mapQItemsIndex } from './mapItem';
|
|
9
|
+
import { updateQrItemsInGroup } from './qrItem';
|
|
10
|
+
|
|
11
|
+
export function repopulateItemsIntoResponse(
|
|
12
|
+
questionnaire: Questionnaire,
|
|
13
|
+
updatableResponse: QuestionnaireResponse,
|
|
14
|
+
checkedItemsToRepopulate: Record<string, ItemToRepopulate>
|
|
15
|
+
): QuestionnaireResponse {
|
|
16
|
+
if (
|
|
17
|
+
!questionnaire.item ||
|
|
18
|
+
questionnaire.item.length === 0 ||
|
|
19
|
+
!updatableResponse.item ||
|
|
20
|
+
updatableResponse.item.length === 0
|
|
21
|
+
) {
|
|
22
|
+
return updatableResponse;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const topLevelQrItems: QuestionnaireResponseItem[] = [];
|
|
26
|
+
for (const [index, topLevelQItem] of questionnaire.item.entries()) {
|
|
27
|
+
const repopulatedTopLevelQrItem = updatableResponse.item[index] ?? {
|
|
28
|
+
linkId: topLevelQItem.linkId,
|
|
29
|
+
text: topLevelQItem.text,
|
|
30
|
+
item: []
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const updatedTopLevelQRItem = repopulateItemRecursive(
|
|
34
|
+
topLevelQItem,
|
|
35
|
+
repopulatedTopLevelQrItem,
|
|
36
|
+
checkedItemsToRepopulate
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
if (Array.isArray(updatedTopLevelQRItem)) {
|
|
40
|
+
if (updatedTopLevelQRItem.length > 0) {
|
|
41
|
+
topLevelQrItems.push(...updatedTopLevelQRItem);
|
|
42
|
+
}
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
if (updatedTopLevelQRItem) {
|
|
47
|
+
topLevelQrItems.push(updatedTopLevelQRItem);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
return { ...updatableResponse, item: topLevelQrItems };
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function repopulateItemRecursive(
|
|
55
|
+
qItem: QuestionnaireItem,
|
|
56
|
+
qrItem: QuestionnaireResponseItem | undefined,
|
|
57
|
+
checkedItemsToRepopulate: Record<string, ItemToRepopulate>
|
|
58
|
+
): QuestionnaireResponseItem[] | QuestionnaireResponseItem | null {
|
|
59
|
+
const childQItems = qItem.item;
|
|
60
|
+
if (childQItems && childQItems.length > 0) {
|
|
61
|
+
// iterate through items of item recursively
|
|
62
|
+
const childQrItems = qrItem?.item ?? [];
|
|
63
|
+
// const updatedChildQrItems: QuestionnaireResponseItem[] = [];
|
|
64
|
+
|
|
65
|
+
// FIXME Not implemented for repeat groups
|
|
66
|
+
if (qItem.type === 'group' && qItem.repeats) {
|
|
67
|
+
return qrItem ?? null;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const indexMap = mapQItemsIndex(qItem);
|
|
71
|
+
const qrItemsByIndex = getQrItemsIndex(childQItems, childQrItems, indexMap);
|
|
72
|
+
|
|
73
|
+
// Otherwise loop through qItem as usual
|
|
74
|
+
for (const [index, childQItem] of childQItems.entries()) {
|
|
75
|
+
const childQrItem = qrItemsByIndex[index];
|
|
76
|
+
|
|
77
|
+
// FIXME Not implemented for repeat groups
|
|
78
|
+
if (Array.isArray(childQrItem)) {
|
|
79
|
+
continue;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const newQrItem = repopulateItemRecursive(childQItem, childQrItem, checkedItemsToRepopulate);
|
|
83
|
+
|
|
84
|
+
// FIXME Not implemented for repeat groups
|
|
85
|
+
if (Array.isArray(newQrItem)) {
|
|
86
|
+
continue;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
if (newQrItem) {
|
|
90
|
+
updateQrItemsInGroup(
|
|
91
|
+
newQrItem,
|
|
92
|
+
null,
|
|
93
|
+
qrItem ?? { linkId: qItem.linkId, text: qItem.text, item: [] },
|
|
94
|
+
indexMap
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return constructGroupItem(qItem, qrItem, checkedItemsToRepopulate);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return constructSingleItem(qItem, qrItem, checkedItemsToRepopulate);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function constructGroupItem(
|
|
106
|
+
qItem: QuestionnaireItem,
|
|
107
|
+
qrItem: QuestionnaireResponseItem | undefined,
|
|
108
|
+
checkedItemsToRepopulate: Record<string, ItemToRepopulate>
|
|
109
|
+
): QuestionnaireResponseItem | null {
|
|
110
|
+
const itemToRepopulate = checkedItemsToRepopulate[qItem.linkId];
|
|
111
|
+
|
|
112
|
+
if (!itemToRepopulate) {
|
|
113
|
+
return qrItem ?? null;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
if (qrItem) {
|
|
117
|
+
return {
|
|
118
|
+
...qrItem,
|
|
119
|
+
answer: itemToRepopulate.newQRItem.answer
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return {
|
|
124
|
+
linkId: qItem.linkId,
|
|
125
|
+
text: qItem.text,
|
|
126
|
+
answer: itemToRepopulate.newQRItem.answer
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
function constructSingleItem(
|
|
131
|
+
qItem: QuestionnaireItem,
|
|
132
|
+
qrItem: QuestionnaireResponseItem | undefined,
|
|
133
|
+
checkedItemsToRepopulate: Record<string, ItemToRepopulate>
|
|
134
|
+
): QuestionnaireResponseItem | null {
|
|
135
|
+
const itemToRepopulate = checkedItemsToRepopulate[qItem.linkId];
|
|
136
|
+
|
|
137
|
+
if (!itemToRepopulate) {
|
|
138
|
+
return qrItem ?? null;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
if (qrItem) {
|
|
142
|
+
return {
|
|
143
|
+
...qrItem,
|
|
144
|
+
answer: itemToRepopulate.newQRItem.answer
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
return {
|
|
149
|
+
linkId: qItem.linkId,
|
|
150
|
+
text: qItem.text,
|
|
151
|
+
answer: itemToRepopulate.newQRItem.answer
|
|
152
|
+
};
|
|
153
|
+
}
|