@aehrc/smart-forms-renderer 0.3.0 → 0.5.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/.storybook/main.ts +28 -0
- package/.storybook/preview.ts +34 -0
- package/__mocks__/zustand.ts +60 -0
- package/jest.config.ts +16 -0
- package/lib/api/populate.js +63 -0
- package/lib/api/populate.js.map +1 -0
- package/{dist → lib}/components/Alert.styles.d.ts +5 -5
- package/lib/components/Alert.styles.js +40 -0
- package/lib/components/Alert.styles.js.map +1 -0
- package/lib/components/BackToTopButton/BackToTopButton.js +32 -0
- package/lib/components/BackToTopButton/BackToTopButton.js.map +1 -0
- package/{dist → lib}/components/Box.styles.d.ts +15 -15
- package/lib/components/Box.styles.js +30 -0
- package/lib/components/Box.styles.js.map +1 -0
- package/lib/components/FormComponents/BooleanItem/BooleanField.js +24 -0
- package/lib/components/FormComponents/BooleanItem/BooleanField.js.map +1 -0
- package/lib/components/FormComponents/BooleanItem/BooleanItem.js +49 -0
- package/lib/components/FormComponents/BooleanItem/BooleanItem.js.map +1 -0
- package/lib/components/FormComponents/DateItem/DateField.js +31 -0
- package/lib/components/FormComponents/DateItem/DateField.js.map +1 -0
- package/lib/components/FormComponents/DateItem/DateItem.js +52 -0
- package/lib/components/FormComponents/DateItem/DateItem.js.map +1 -0
- package/lib/components/FormComponents/DateTimeItem/DateTimeField.js +33 -0
- package/lib/components/FormComponents/DateTimeItem/DateTimeField.js.map +1 -0
- package/lib/components/FormComponents/DateTimeItem/DateTimeItem.js +52 -0
- package/lib/components/FormComponents/DateTimeItem/DateTimeItem.js.map +1 -0
- package/lib/components/FormComponents/DecimalItem/DecimalField.js +30 -0
- package/lib/components/FormComponents/DecimalItem/DecimalField.js.map +1 -0
- package/lib/components/FormComponents/DecimalItem/DecimalItem.js +80 -0
- package/lib/components/FormComponents/DecimalItem/DecimalItem.js.map +1 -0
- package/lib/components/FormComponents/DisplayItem/DisplayInstructions.js +26 -0
- package/lib/components/FormComponents/DisplayItem/DisplayInstructions.js.map +1 -0
- package/{dist → lib}/components/FormComponents/DisplayItem/DisplayInstructions.styles.d.ts +5 -5
- package/lib/components/FormComponents/DisplayItem/DisplayInstructions.styles.js +23 -0
- package/lib/components/FormComponents/DisplayItem/DisplayInstructions.styles.js.map +1 -0
- package/lib/components/FormComponents/DisplayItem/DisplayItem.js +31 -0
- package/lib/components/FormComponents/DisplayItem/DisplayItem.js.map +1 -0
- package/{dist → lib}/components/FormComponents/GridGroup/GridGroup.d.ts +1 -1
- package/lib/components/FormComponents/GridGroup/GridGroup.js +58 -0
- package/lib/components/FormComponents/GridGroup/GridGroup.js.map +1 -0
- package/{dist → lib}/components/FormComponents/GridGroup/GridRow.d.ts +1 -1
- package/lib/components/FormComponents/GridGroup/GridRow.js +55 -0
- package/lib/components/FormComponents/GridGroup/GridRow.js.map +1 -0
- package/lib/components/FormComponents/GridGroup/GridTable.js +42 -0
- package/lib/components/FormComponents/GridGroup/GridTable.js.map +1 -0
- package/lib/components/FormComponents/GroupItem/GroupHeading.js +39 -0
- package/lib/components/FormComponents/GroupItem/GroupHeading.js.map +1 -0
- package/{dist → lib}/components/FormComponents/GroupItem/GroupItem.d.ts +1 -1
- package/lib/components/FormComponents/GroupItem/GroupItem.js +62 -0
- package/lib/components/FormComponents/GroupItem/GroupItem.js.map +1 -0
- package/{dist → lib}/components/FormComponents/GroupItem/GroupItem.styles.d.ts +5 -5
- package/lib/components/FormComponents/GroupItem/GroupItem.styles.js +27 -0
- package/lib/components/FormComponents/GroupItem/GroupItem.styles.js.map +1 -0
- package/{dist → lib}/components/FormComponents/GroupItem/GroupItemSwitcher.d.ts +1 -1
- package/lib/components/FormComponents/GroupItem/GroupItemSwitcher.js +73 -0
- package/lib/components/FormComponents/GroupItem/GroupItemSwitcher.js.map +1 -0
- package/lib/components/FormComponents/GroupItem/NextTabButton.js +25 -0
- package/lib/components/FormComponents/GroupItem/NextTabButton.js.map +1 -0
- package/lib/components/FormComponents/GroupItem/NextTabButtonWrapper.js +55 -0
- package/lib/components/FormComponents/GroupItem/NextTabButtonWrapper.js.map +1 -0
- package/lib/components/FormComponents/IntegerItem/IntegerField.js +30 -0
- package/lib/components/FormComponents/IntegerItem/IntegerField.js.map +1 -0
- package/lib/components/FormComponents/IntegerItem/IntegerItem.js +73 -0
- package/lib/components/FormComponents/IntegerItem/IntegerItem.js.map +1 -0
- package/lib/components/FormComponents/Item.styles.d.ts +6 -0
- package/lib/components/FormComponents/Item.styles.js +27 -0
- package/lib/components/FormComponents/Item.styles.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/ContextDisplayItem.js +29 -0
- package/lib/components/FormComponents/ItemParts/ContextDisplayItem.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/FadingCheckIcon.js +26 -0
- package/lib/components/FormComponents/ItemParts/FadingCheckIcon.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/ItemFieldGrid.js +31 -0
- package/lib/components/FormComponents/ItemParts/ItemFieldGrid.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/ItemLabelText.js +45 -0
- package/lib/components/FormComponents/ItemParts/ItemLabelText.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/ItemLabelWrapper.js +32 -0
- package/lib/components/FormComponents/ItemParts/ItemLabelWrapper.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/QItemCheckboxSingle.js +24 -0
- package/lib/components/FormComponents/ItemParts/QItemCheckboxSingle.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/QItemCheckboxSingleWithOpenLabel.js +33 -0
- package/lib/components/FormComponents/ItemParts/QItemCheckboxSingleWithOpenLabel.js.map +1 -0
- package/lib/components/FormComponents/ItemParts/QItemRadioButtonWithOpenLabel.js +31 -0
- package/lib/components/FormComponents/ItemParts/QItemRadioButtonWithOpenLabel.js.map +1 -0
- package/{dist → lib}/components/FormComponents/Lists.styles.d.ts +5 -5
- package/lib/components/FormComponents/Lists.styles.js +38 -0
- package/lib/components/FormComponents/Lists.styles.js.map +1 -0
- package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoice.d.ts +1 -1
- package/lib/components/FormComponents/QItemChoice/QItemChoice.js +61 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoice.js.map +1 -0
- package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceAutocomplete.d.ts +1 -1
- package/lib/components/FormComponents/QItemChoice/QItemChoiceAutocomplete.js +85 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceAutocomplete.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerOption.js +70 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerValueSet.js +66 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerValueSet.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerOption.js +70 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerValueSet.js +70 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerValueSet.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioSingle.js +24 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceRadioSingle.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerOption.js +70 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerValueSet.js +80 -0
- package/lib/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerValueSet.js.map +1 -0
- package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoice.d.ts +1 -1
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoice.js +49 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoice.js.map +1 -0
- package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoiceAutocomplete.d.ts +1 -1
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceAutocomplete.js +104 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceAutocomplete.js.map +1 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceCheckboxAnswerOption.js +105 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceCheckboxAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceRadioAnswerOption.js +116 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceRadioAnswerOption.js.map +1 -0
- package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerOption.d.ts +1 -1
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerOption.js +74 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerOption.js.map +1 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerValueSet.js +66 -0
- package/lib/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerValueSet.js.map +1 -0
- package/lib/components/FormComponents/RepeatGroup/AddItemButton.js +27 -0
- package/lib/components/FormComponents/RepeatGroup/AddItemButton.js.map +1 -0
- package/lib/components/FormComponents/RepeatGroup/DeleteItemButton.js +30 -0
- package/lib/components/FormComponents/RepeatGroup/DeleteItemButton.js.map +1 -0
- package/lib/components/FormComponents/RepeatGroup/RepeatGroup.js +81 -0
- package/lib/components/FormComponents/RepeatGroup/RepeatGroup.js.map +1 -0
- package/lib/components/FormComponents/RepeatGroup/RepeatGroupItem.js +30 -0
- package/lib/components/FormComponents/RepeatGroup/RepeatGroupItem.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/AddItemButton.js +27 -0
- package/lib/components/FormComponents/RepeatItem/AddItemButton.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/DeleteItemButton.js +30 -0
- package/lib/components/FormComponents/RepeatItem/DeleteItemButton.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/RepeatField.js +31 -0
- package/lib/components/FormComponents/RepeatItem/RepeatField.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.js +69 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.js.map +1 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.styles.d.ts +22 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.styles.js +29 -0
- package/lib/components/FormComponents/RepeatItem/RepeatItem.styles.js.map +1 -0
- package/lib/components/FormComponents/SingleItem/SingleItem.js +32 -0
- package/lib/components/FormComponents/SingleItem/SingleItem.js.map +1 -0
- package/lib/components/FormComponents/SingleItem/SingleItemSwitcher.js +63 -0
- package/lib/components/FormComponents/SingleItem/SingleItemSwitcher.js.map +1 -0
- package/lib/components/FormComponents/StringItem/StringField.js +30 -0
- package/lib/components/FormComponents/StringItem/StringField.js.map +1 -0
- package/lib/components/FormComponents/StringItem/StringItem.js +71 -0
- package/lib/components/FormComponents/StringItem/StringItem.js.map +1 -0
- package/lib/components/FormComponents/Tables/DeleteRowButton.js +31 -0
- package/lib/components/FormComponents/Tables/DeleteRowButton.js.map +1 -0
- package/{dist → lib}/components/FormComponents/Tables/QItemGroupTable.d.ts +1 -1
- package/lib/components/FormComponents/Tables/QItemGroupTable.js +99 -0
- package/lib/components/FormComponents/Tables/QItemGroupTable.js.map +1 -0
- package/{dist → lib}/components/FormComponents/Tables/QItemGroupTableRow.d.ts +1 -1
- package/lib/components/FormComponents/Tables/QItemGroupTableRow.js +46 -0
- package/lib/components/FormComponents/Tables/QItemGroupTableRow.js.map +1 -0
- package/lib/components/FormComponents/Tables/Table.styles.js +46 -0
- package/lib/components/FormComponents/Tables/Table.styles.js.map +1 -0
- package/lib/components/FormComponents/TextItem/TextField.js +29 -0
- package/lib/components/FormComponents/TextItem/TextField.js.map +1 -0
- package/lib/components/FormComponents/TextItem/TextItem.js +71 -0
- package/lib/components/FormComponents/TextItem/TextItem.js.map +1 -0
- package/{dist → lib}/components/FormComponents/Textfield.styles.d.ts +1 -1
- package/lib/components/FormComponents/Textfield.styles.js +27 -0
- package/lib/components/FormComponents/Textfield.styles.js.map +1 -0
- package/lib/components/FormComponents/TimeItem/TimeField.js +30 -0
- package/lib/components/FormComponents/TimeItem/TimeField.js.map +1 -0
- package/lib/components/FormComponents/TimeItem/TimeItem.js +52 -0
- package/lib/components/FormComponents/TimeItem/TimeItem.js.map +1 -0
- package/lib/components/FormComponents/Typography.styles.d.ts +6 -0
- package/lib/components/FormComponents/Typography.styles.js +23 -0
- package/lib/components/FormComponents/Typography.styles.js.map +1 -0
- package/lib/components/FormComponents/UrlItem/UrlField.js +25 -0
- package/lib/components/FormComponents/UrlItem/UrlField.js.map +1 -0
- package/lib/components/FormComponents/UrlItem/UrlItem.js +61 -0
- package/lib/components/FormComponents/UrlItem/UrlItem.js.map +1 -0
- package/lib/components/FormRenderer/BaseRenderer.js +54 -0
- package/lib/components/FormRenderer/BaseRenderer.js.map +1 -0
- package/lib/components/FormRenderer/FormBodyCollapsible.js +57 -0
- package/lib/components/FormRenderer/FormBodyCollapsible.js.map +1 -0
- package/lib/components/FormRenderer/FormBodySingleCollapsible.js +39 -0
- package/lib/components/FormRenderer/FormBodySingleCollapsible.js.map +1 -0
- package/{dist → lib}/components/FormRenderer/FormBodySingleCollapsibleWrapper.d.ts +1 -1
- package/lib/components/FormRenderer/FormBodySingleCollapsibleWrapper.js +31 -0
- package/lib/components/FormRenderer/FormBodySingleCollapsibleWrapper.js.map +1 -0
- package/lib/components/FormRenderer/FormBodyTabbed.js +60 -0
- package/lib/components/FormRenderer/FormBodyTabbed.js.map +1 -0
- package/lib/components/FormRenderer/FormRenderer.js +54 -0
- package/lib/components/FormRenderer/FormRenderer.js.map +1 -0
- package/lib/components/FormRenderer/FormTitle.js +30 -0
- package/lib/components/FormRenderer/FormTitle.js.map +1 -0
- package/lib/components/FormRenderer/FormTopLevelItem.js +45 -0
- package/lib/components/FormRenderer/FormTopLevelItem.js.map +1 -0
- package/lib/components/FormRenderer/SmartFormsRenderer.js +39 -0
- package/lib/components/FormRenderer/SmartFormsRenderer.js.map +1 -0
- package/lib/components/FormRenderer/index.js +19 -0
- package/lib/components/FormRenderer/index.js.map +1 -0
- package/lib/components/Iconify/Iconify.js +26 -0
- package/lib/components/Iconify/Iconify.js.map +1 -0
- package/{dist → lib}/components/Lists.styles.d.ts +6 -6
- package/lib/components/Lists.styles.js +38 -0
- package/lib/components/Lists.styles.js.map +1 -0
- package/lib/components/Tabs/CompleteTabButton.js +29 -0
- package/lib/components/Tabs/CompleteTabButton.js.map +1 -0
- package/lib/components/Tabs/FormBodySingleTab.js +39 -0
- package/lib/components/Tabs/FormBodySingleTab.js.map +1 -0
- package/lib/components/Tabs/FormBodyTabList.js +52 -0
- package/lib/components/Tabs/FormBodyTabList.js.map +1 -0
- package/lib/components/index.js +18 -0
- package/lib/components/index.js.map +1 -0
- package/lib/hooks/index.js +2 -0
- package/lib/hooks/index.js.map +1 -0
- package/lib/hooks/useBackToTop.js +26 -0
- package/lib/hooks/useBackToTop.js.map +1 -0
- package/lib/hooks/useDebounce.js +38 -0
- package/lib/hooks/useDebounce.js.map +1 -0
- package/lib/hooks/useDecimalCalculatedExpression.js +50 -0
- package/lib/hooks/useDecimalCalculatedExpression.js.map +1 -0
- package/lib/hooks/useHidden.js +35 -0
- package/lib/hooks/useHidden.js.map +1 -0
- package/lib/hooks/useInitialiseGroupTable.js +36 -0
- package/lib/hooks/useInitialiseGroupTable.js.map +1 -0
- package/lib/hooks/useInitialiseRenderer.js +49 -0
- package/lib/hooks/useInitialiseRenderer.js.map +1 -0
- package/lib/hooks/useInitialiseRepeatAnswers.js +36 -0
- package/lib/hooks/useInitialiseRepeatAnswers.js.map +1 -0
- package/lib/hooks/useInitialiseRepeatGroups.js +36 -0
- package/lib/hooks/useInitialiseRepeatGroups.js.map +1 -0
- package/lib/hooks/useIntegerCalculatedExpression.js +44 -0
- package/lib/hooks/useIntegerCalculatedExpression.js.map +1 -0
- package/lib/hooks/useQueryClient.js +29 -0
- package/lib/hooks/useQueryClient.js.map +1 -0
- package/lib/hooks/useRenderingExtensions.js +30 -0
- package/lib/hooks/useRenderingExtensions.js.map +1 -0
- package/lib/hooks/useResponsive.js +37 -0
- package/lib/hooks/useResponsive.js.map +1 -0
- package/lib/hooks/useStringCalculatedExpression.js +44 -0
- package/lib/hooks/useStringCalculatedExpression.js.map +1 -0
- package/lib/hooks/useTerminologyServerQuery.js +73 -0
- package/lib/hooks/useTerminologyServerQuery.js.map +1 -0
- package/lib/hooks/useValidationError.js +38 -0
- package/lib/hooks/useValidationError.js.map +1 -0
- package/{dist → lib}/hooks/useValueSetCodings.d.ts +1 -1
- package/lib/hooks/useValueSetCodings.js +125 -0
- package/lib/hooks/useValueSetCodings.js.map +1 -0
- package/lib/index.d.ts +89 -0
- package/lib/index.js +153 -0
- package/lib/index.js.map +1 -0
- package/lib/interfaces/answerExpression.interface.js +18 -0
- package/lib/interfaces/answerExpression.interface.js.map +1 -0
- package/lib/interfaces/calculatedExpression.interface.js +2 -0
- package/lib/interfaces/calculatedExpression.interface.js.map +1 -0
- package/lib/interfaces/choice.enum.js +41 -0
- package/lib/interfaces/choice.enum.js.map +1 -0
- package/lib/interfaces/enableWhen.interface.js +18 -0
- package/lib/interfaces/enableWhen.interface.js.map +1 -0
- package/lib/interfaces/groupTable.interface.js +18 -0
- package/lib/interfaces/groupTable.interface.js.map +1 -0
- package/lib/interfaces/populate.interface.js +18 -0
- package/lib/interfaces/populate.interface.js.map +1 -0
- package/lib/interfaces/questionnaireStore.interface.js +18 -0
- package/lib/interfaces/questionnaireStore.interface.js.map +1 -0
- package/lib/interfaces/regex.interface.js +18 -0
- package/lib/interfaces/regex.interface.js.map +1 -0
- package/{dist → lib}/interfaces/renderProps.interface.d.ts +1 -1
- package/lib/interfaces/renderProps.interface.js +18 -0
- package/lib/interfaces/renderProps.interface.js.map +1 -0
- package/lib/interfaces/repeatGroup.interface.js +18 -0
- package/lib/interfaces/repeatGroup.interface.js.map +1 -0
- package/lib/interfaces/repeatItem.interface.js +2 -0
- package/lib/interfaces/repeatItem.interface.js.map +1 -0
- package/lib/interfaces/tab.interface.js +2 -0
- package/lib/interfaces/tab.interface.js.map +1 -0
- package/lib/interfaces/valueSet.interface.js +18 -0
- package/lib/interfaces/valueSet.interface.js.map +1 -0
- package/lib/interfaces/variables.interface.js +18 -0
- package/lib/interfaces/variables.interface.js.map +1 -0
- package/lib/stores/useConfigStore.js +17 -0
- package/lib/stores/useConfigStore.js.map +1 -0
- package/lib/stores/useQuestionnaireResponseStore.js +39 -0
- package/lib/stores/useQuestionnaireResponseStore.js.map +1 -0
- package/lib/stores/useQuestionnaireStore.js +151 -0
- package/lib/stores/useQuestionnaireStore.js.map +1 -0
- package/lib/theme/Theme.d.ts +38 -0
- package/lib/theme/Theme.js +39 -0
- package/lib/theme/Theme.js.map +1 -0
- package/lib/theme/globalStyles.d.ts +2 -0
- package/lib/theme/globalStyles.js +64 -0
- package/lib/theme/globalStyles.js.map +1 -0
- package/lib/theme/overrides/Accordion.d.ts +14 -0
- package/lib/theme/overrides/Accordion.js +32 -0
- package/lib/theme/overrides/Accordion.js.map +1 -0
- package/lib/theme/overrides/Autocomplete.d.ts +10 -0
- package/lib/theme/overrides/Autocomplete.js +28 -0
- package/lib/theme/overrides/Autocomplete.js.map +1 -0
- package/lib/theme/overrides/Backdrop.d.ts +13 -0
- package/lib/theme/overrides/Backdrop.js +32 -0
- package/lib/theme/overrides/Backdrop.js.map +1 -0
- package/lib/theme/overrides/Button.d.ts +33 -0
- package/lib/theme/overrides/Button.js +52 -0
- package/lib/theme/overrides/Button.js.map +1 -0
- package/lib/theme/overrides/Card.d.ts +35 -0
- package/lib/theme/overrides/Card.js +49 -0
- package/lib/theme/overrides/Card.js.map +1 -0
- package/lib/theme/overrides/Input.d.ts +64 -0
- package/lib/theme/overrides/Input.js +81 -0
- package/lib/theme/overrides/Input.js.map +1 -0
- package/lib/theme/overrides/Overrides.d.ts +3 -0
- package/lib/theme/overrides/Overrides.js +31 -0
- package/lib/theme/overrides/Overrides.js.map +1 -0
- package/lib/theme/overrides/Paper.d.ts +12 -0
- package/lib/theme/overrides/Paper.js +31 -0
- package/lib/theme/overrides/Paper.js.map +1 -0
- package/lib/theme/overrides/SpeedDial.d.ts +16 -0
- package/lib/theme/overrides/SpeedDial.js +34 -0
- package/lib/theme/overrides/SpeedDial.js.map +1 -0
- package/lib/theme/overrides/Table.d.ts +11 -0
- package/lib/theme/overrides/Table.js +29 -0
- package/lib/theme/overrides/Table.js.map +1 -0
- package/lib/theme/overrides/Typography.d.ts +13 -0
- package/lib/theme/overrides/Typography.js +31 -0
- package/lib/theme/overrides/Typography.js.map +1 -0
- package/lib/theme/palette.d.ts +28 -0
- package/lib/theme/palette.js +67 -0
- package/lib/theme/palette.js.map +1 -0
- package/lib/theme/shadows.d.ts +2 -0
- package/lib/theme/shadows.js +52 -0
- package/lib/theme/shadows.js.map +1 -0
- package/lib/theme/typography.d.ts +139 -0
- package/lib/theme/typography.js +80 -0
- package/lib/theme/typography.js.map +1 -0
- package/lib/utils/calculatedExpression.js +180 -0
- package/lib/utils/calculatedExpression.js.map +1 -0
- package/lib/utils/choice.js +160 -0
- package/lib/utils/choice.js.map +1 -0
- package/lib/utils/debounce.js +19 -0
- package/lib/utils/debounce.js.map +1 -0
- package/lib/utils/emptyResource.js +25 -0
- package/lib/utils/emptyResource.js.map +1 -0
- package/lib/utils/enableWhen.js +228 -0
- package/lib/utils/enableWhen.js.map +1 -0
- package/lib/utils/enableWhenExpression.js +76 -0
- package/lib/utils/enableWhenExpression.js.map +1 -0
- package/lib/utils/fhirpath.js +98 -0
- package/lib/utils/fhirpath.js.map +1 -0
- package/lib/utils/initialiseForm.js +45 -0
- package/lib/utils/initialiseForm.js.map +1 -0
- package/lib/utils/itemControl.js +299 -0
- package/lib/utils/itemControl.js.map +1 -0
- package/lib/utils/mapItem.js +80 -0
- package/lib/utils/mapItem.js.map +1 -0
- package/lib/utils/openChoice.js +150 -0
- package/lib/utils/openChoice.js.map +1 -0
- package/lib/utils/parseInputs.js +49 -0
- package/lib/utils/parseInputs.js.map +1 -0
- package/lib/utils/populate.js +78 -0
- package/lib/utils/populate.js.map +1 -0
- package/lib/utils/populateCallback.js +40 -0
- package/lib/utils/populateCallback.js.map +1 -0
- package/lib/utils/populateContexts.js +76 -0
- package/lib/utils/populateContexts.js.map +1 -0
- package/lib/utils/populateInputParams.js +193 -0
- package/lib/utils/populateInputParams.js.map +1 -0
- package/lib/utils/qItem.js +73 -0
- package/lib/utils/qItem.js.map +1 -0
- package/lib/utils/qrItem.js +221 -0
- package/lib/utils/qrItem.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/addAdditionalVariables.js +43 -0
- package/lib/utils/questionnaireStoreUtils/addAdditionalVariables.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/createQuestionaireModel.js +79 -0
- package/lib/utils/questionnaireStoreUtils/createQuestionaireModel.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/extractContainedValueSets.js +59 -0
- package/lib/utils/questionnaireStoreUtils/extractContainedValueSets.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/extractLaunchContext.js +18 -0
- package/lib/utils/questionnaireStoreUtils/extractLaunchContext.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/extractOtherExtensions.js +174 -0
- package/lib/utils/questionnaireStoreUtils/extractOtherExtensions.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/extractTabs.js +31 -0
- package/lib/utils/questionnaireStoreUtils/extractTabs.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/extractVariables.js +63 -0
- package/lib/utils/questionnaireStoreUtils/extractVariables.js.map +1 -0
- package/lib/utils/questionnaireStoreUtils/resolveValueSets.js +58 -0
- package/lib/utils/questionnaireStoreUtils/resolveValueSets.js.map +1 -0
- package/lib/utils/removeHidden.js +104 -0
- package/lib/utils/removeHidden.js.map +1 -0
- package/lib/utils/tabs.js +190 -0
- package/lib/utils/tabs.js.map +1 -0
- package/lib/utils/valueSet.js +126 -0
- package/lib/utils/valueSet.js.map +1 -0
- package/package.json +19 -27
- package/src/api/populate.ts +70 -0
- package/src/components/Alert.styles.ts +45 -0
- package/src/components/BackToTopButton/BackToTopButton.tsx +47 -0
- package/src/components/Box.styles.ts +33 -0
- package/src/components/FormComponents/BooleanItem/BooleanField.tsx +44 -0
- package/src/components/FormComponents/BooleanItem/BooleanItem.tsx +82 -0
- package/src/components/FormComponents/DateItem/DateField.tsx +56 -0
- package/src/components/FormComponents/DateItem/DateItem.tsx +95 -0
- package/src/components/FormComponents/DateTimeItem/DateTimeField.tsx +58 -0
- package/src/components/FormComponents/DateTimeItem/DateTimeItem.tsx +94 -0
- package/src/components/FormComponents/DecimalItem/DecimalField.tsx +76 -0
- package/src/components/FormComponents/DecimalItem/DecimalItem.tsx +152 -0
- package/src/components/FormComponents/DisplayItem/DisplayInstructions.styles.ts +24 -0
- package/src/components/FormComponents/DisplayItem/DisplayInstructions.tsx +38 -0
- package/src/components/FormComponents/DisplayItem/DisplayItem.tsx +43 -0
- package/src/components/FormComponents/GridGroup/GridGroup.tsx +92 -0
- package/src/components/FormComponents/GridGroup/GridRow.tsx +88 -0
- package/src/components/FormComponents/GridGroup/GridTable.tsx +77 -0
- package/src/components/FormComponents/GroupItem/GroupHeading.tsx +59 -0
- package/src/components/FormComponents/GroupItem/GroupItem.styles.ts +28 -0
- package/src/components/FormComponents/GroupItem/GroupItem.tsx +124 -0
- package/src/components/FormComponents/GroupItem/GroupItemSwitcher.tsx +150 -0
- package/src/components/FormComponents/GroupItem/NextTabButton.tsx +43 -0
- package/src/components/FormComponents/GroupItem/NextTabButtonWrapper.tsx +76 -0
- package/src/components/FormComponents/IntegerItem/IntegerField.tsx +76 -0
- package/src/components/FormComponents/IntegerItem/IntegerItem.tsx +140 -0
- package/src/components/FormComponents/Item.styles.ts +30 -0
- package/src/components/FormComponents/ItemParts/ContextDisplayItem.tsx +38 -0
- package/src/components/FormComponents/ItemParts/FadingCheckIcon.tsx +36 -0
- package/src/components/FormComponents/ItemParts/ItemFieldGrid.tsx +47 -0
- package/src/components/FormComponents/ItemParts/ItemLabelText.tsx +58 -0
- package/src/components/FormComponents/ItemParts/ItemLabelWrapper.tsx +47 -0
- package/src/components/FormComponents/ItemParts/QItemCheckboxSingle.tsx +44 -0
- package/src/components/FormComponents/ItemParts/QItemCheckboxSingleWithOpenLabel.tsx +62 -0
- package/src/components/FormComponents/ItemParts/QItemRadioButtonWithOpenLabel.tsx +54 -0
- package/src/components/FormComponents/Lists.styles.ts +39 -0
- package/src/components/FormComponents/QItemChoice/QItemChoice.tsx +130 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceAutocomplete.tsx +178 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerOption.tsx +131 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerValueSet.tsx +126 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerOption.tsx +125 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerValueSet.tsx +129 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceRadioSingle.tsx +41 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerOption.tsx +130 -0
- package/src/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerValueSet.tsx +162 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoice.tsx +104 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoiceAutocomplete.tsx +207 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoiceCheckboxAnswerOption.tsx +194 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoiceRadioAnswerOption.tsx +190 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerOption.tsx +149 -0
- package/src/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerValueSet.tsx +138 -0
- package/src/components/FormComponents/RepeatGroup/AddItemButton.tsx +47 -0
- package/src/components/FormComponents/RepeatGroup/DeleteItemButton.tsx +46 -0
- package/src/components/FormComponents/RepeatGroup/RepeatGroup.tsx +125 -0
- package/src/components/FormComponents/RepeatGroup/RepeatGroupItem.tsx +66 -0
- package/src/components/FormComponents/RepeatItem/AddItemButton.tsx +47 -0
- package/src/components/FormComponents/RepeatItem/DeleteItemButton.tsx +46 -0
- package/src/components/FormComponents/RepeatItem/RepeatField.tsx +61 -0
- package/src/components/FormComponents/RepeatItem/RepeatItem.styles.tsx +32 -0
- package/src/components/FormComponents/RepeatItem/RepeatItem.tsx +116 -0
- package/src/components/FormComponents/SingleItem/SingleItem.tsx +62 -0
- package/src/components/FormComponents/SingleItem/SingleItemSwitcher.tsx +171 -0
- package/src/components/FormComponents/StringItem/StringField.tsx +76 -0
- package/src/components/FormComponents/StringItem/StringItem.tsx +131 -0
- package/src/components/FormComponents/Tables/DeleteRowButton.tsx +47 -0
- package/src/components/FormComponents/Tables/QItemGroupTable.tsx +171 -0
- package/src/components/FormComponents/Tables/QItemGroupTableRow.tsx +77 -0
- package/src/components/FormComponents/Tables/Table.styles.tsx +51 -0
- package/src/components/FormComponents/TextItem/TextField.tsx +74 -0
- package/src/components/FormComponents/TextItem/TextItem.tsx +128 -0
- package/src/components/FormComponents/Textfield.styles.ts +28 -0
- package/src/components/FormComponents/TimeItem/TimeField.tsx +54 -0
- package/src/components/FormComponents/TimeItem/TimeItem.tsx +94 -0
- package/src/components/FormComponents/Typography.styles.ts +24 -0
- package/src/components/FormComponents/UrlItem/UrlField.tsx +66 -0
- package/src/components/FormComponents/UrlItem/UrlItem.tsx +118 -0
- package/src/components/FormRenderer/BaseRenderer.tsx +82 -0
- package/src/components/FormRenderer/FormBodyCollapsible.tsx +96 -0
- package/src/components/FormRenderer/FormBodySingleCollapsible.tsx +76 -0
- package/src/components/FormRenderer/FormBodySingleCollapsibleWrapper.tsx +60 -0
- package/src/components/FormRenderer/FormBodyTabbed.tsx +106 -0
- package/src/components/FormRenderer/FormTitle.tsx +44 -0
- package/src/components/FormRenderer/FormTopLevelItem.tsx +93 -0
- package/src/components/FormRenderer/SmartFormsRenderer.tsx +62 -0
- package/src/components/FormRenderer/index.ts +19 -0
- package/src/components/Iconify/Iconify.tsx +38 -0
- package/src/components/Lists.styles.ts +39 -0
- package/src/components/Tabs/CompleteTabButton.tsx +42 -0
- package/src/components/Tabs/FormBodySingleTab.tsx +67 -0
- package/src/components/Tabs/FormBodyTabList.tsx +83 -0
- package/src/components/index.ts +18 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useBackToTop.ts +29 -0
- package/src/hooks/useDebounce.ts +45 -0
- package/src/hooks/useDecimalCalculatedExpression.ts +80 -0
- package/src/hooks/useHidden.ts +40 -0
- package/src/hooks/useInitialiseGroupTable.ts +42 -0
- package/src/hooks/useInitialiseRenderer.ts +62 -0
- package/src/hooks/useInitialiseRepeatAnswers.ts +42 -0
- package/src/hooks/useInitialiseRepeatGroups.ts +42 -0
- package/src/hooks/useIntegerCalculatedExpression.ts +72 -0
- package/src/hooks/useQueryClient.ts +31 -0
- package/src/hooks/useRenderingExtensions.ts +52 -0
- package/src/hooks/useResponsive.ts +51 -0
- package/src/hooks/useStringCalculatedExpression.ts +71 -0
- package/src/hooks/useTerminologyServerQuery.ts +98 -0
- package/src/hooks/useValidationError.ts +48 -0
- package/src/hooks/useValueSetCodings.ts +150 -0
- package/src/index.ts +163 -0
- package/src/interfaces/answerExpression.interface.ts +23 -0
- package/src/interfaces/calculatedExpression.interface.ts +4 -0
- package/src/interfaces/choice.enum.ts +40 -0
- package/src/interfaces/enableWhen.interface.ts +40 -0
- package/src/interfaces/groupTable.interface.ts +23 -0
- package/src/interfaces/populate.interface.ts +218 -0
- package/src/interfaces/questionnaireStore.interface.ts +36 -0
- package/src/interfaces/regex.interface.ts +21 -0
- package/src/interfaces/renderProps.interface.ts +34 -0
- package/src/interfaces/repeatGroup.interface.ts +28 -0
- package/src/interfaces/repeatItem.interface.ts +6 -0
- package/src/interfaces/tab.interface.ts +18 -0
- package/src/interfaces/valueSet.interface.ts +23 -0
- package/src/interfaces/variables.interface.ts +28 -0
- package/src/stores/useConfigStore.ts +36 -0
- package/src/stores/useQuestionnaireResponseStore.ts +58 -0
- package/src/stores/useQuestionnaireStore.ts +232 -0
- package/src/stories/SmartFormsRenderer.stories.ts +104 -0
- package/src/stories/assets/Q715.json +15086 -0
- package/src/stories/assets/QTestGrid.json +166 -0
- package/src/stories/assets/R715.json +311 -0
- package/src/stories/assets/RTestGrid.json +34 -0
- package/src/theme/Theme.tsx +107 -0
- package/src/theme/globalStyles.tsx +68 -0
- package/src/theme/overrides/Accordion.ts +34 -0
- package/src/theme/overrides/Autocomplete.ts +30 -0
- package/src/theme/overrides/Backdrop.ts +34 -0
- package/src/theme/overrides/Button.ts +54 -0
- package/src/theme/overrides/Card.ts +51 -0
- package/src/theme/overrides/Input.ts +83 -0
- package/src/theme/overrides/Overrides.ts +45 -0
- package/src/theme/overrides/Paper.ts +31 -0
- package/src/theme/overrides/SpeedDial.ts +36 -0
- package/src/theme/overrides/Table.ts +31 -0
- package/src/theme/overrides/Typography.ts +33 -0
- package/src/theme/palette.ts +100 -0
- package/src/theme/shadows.ts +54 -0
- package/src/theme/typography.ts +114 -0
- package/src/utils/calculatedExpression.ts +299 -0
- package/src/utils/choice.ts +194 -0
- package/src/utils/debounce.ts +20 -0
- package/src/utils/emptyResource.ts +28 -0
- package/src/utils/enableWhen.ts +303 -0
- package/src/utils/enableWhenExpression.ts +123 -0
- package/src/utils/fhirpath.ts +164 -0
- package/src/utils/initialiseForm.ts +81 -0
- package/src/utils/itemControl.ts +367 -0
- package/src/utils/mapItem.ts +97 -0
- package/src/utils/openChoice.ts +179 -0
- package/src/utils/parseInputs.ts +58 -0
- package/src/utils/populate.ts +117 -0
- package/src/utils/populateCallback.ts +53 -0
- package/src/utils/populateContexts.ts +112 -0
- package/src/utils/populateInputParams.ts +242 -0
- package/src/utils/qItem.ts +103 -0
- package/src/utils/qrItem.ts +250 -0
- package/src/utils/questionnaireStoreUtils/addAdditionalVariables.ts +52 -0
- package/src/utils/questionnaireStoreUtils/createQuestionaireModel.ts +96 -0
- package/src/utils/questionnaireStoreUtils/extractContainedValueSets.ts +74 -0
- package/src/utils/questionnaireStoreUtils/extractLaunchContext.ts +21 -0
- package/src/utils/questionnaireStoreUtils/extractOtherExtensions.ts +239 -0
- package/src/utils/questionnaireStoreUtils/extractTabs.ts +37 -0
- package/src/utils/questionnaireStoreUtils/extractVariables.ts +77 -0
- package/src/utils/questionnaireStoreUtils/resolveValueSets.ts +68 -0
- package/src/utils/removeHidden.ts +162 -0
- package/src/utils/tabs.ts +255 -0
- package/src/utils/valueSet.ts +159 -0
- package/tsconfig.json +21 -0
- package/dist/components/FormComponents/Item.styles.d.ts +0 -6
- package/dist/components/FormComponents/RepeatItem/RepeatItem.styles.d.ts +0 -22
- package/dist/components/FormComponents/Typography.styles.d.ts +0 -6
- package/dist/components/FormRenderer/BaseFormRenderer.d.ts +0 -3
- package/dist/components/FormRenderer/Form.d.ts +0 -3
- package/dist/index.d.ts +0 -16
- package/dist/index.esm.js +0 -10650
- package/dist/index.esm.js.map +0 -1
- package/dist/index.js +0 -10710
- package/dist/index.js.map +0 -1
- package/dist/stories/SmartFormsRenderer.stories.d.ts +0 -14
- /package/{dist → lib}/api/populate.d.ts +0 -0
- /package/{dist → lib}/components/BackToTopButton/BackToTopButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/BooleanItem/BooleanField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/BooleanItem/BooleanItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DateItem/DateField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DateItem/DateItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DateTimeItem/DateTimeField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DateTimeItem/DateTimeItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DecimalItem/DecimalField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DecimalItem/DecimalItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DisplayItem/DisplayInstructions.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/DisplayItem/DisplayItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/GridGroup/GridTable.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/GroupItem/GroupHeading.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/GroupItem/NextTabButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/GroupItem/NextTabButtonWrapper.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/IntegerItem/IntegerField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/IntegerItem/IntegerItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/ContextDisplayItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/FadingCheckIcon.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/ItemFieldGrid.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/ItemLabelText.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/ItemLabelWrapper.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/QItemCheckboxSingle.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/QItemCheckboxSingleWithOpenLabel.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/ItemParts/QItemRadioButtonWithOpenLabel.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerOption.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceCheckboxAnswerValueSet.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerOption.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceRadioAnswerValueSet.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceRadioSingle.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerOption.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemChoice/QItemChoiceSelectAnswerValueSet.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoiceCheckboxAnswerOption.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoiceRadioAnswerOption.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/QItemOpenChoice/QItemOpenChoiceSelectAnswerValueSet.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatGroup/AddItemButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatGroup/DeleteItemButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatGroup/RepeatGroup.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatGroup/RepeatGroupItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatItem/AddItemButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatItem/DeleteItemButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatItem/RepeatField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/RepeatItem/RepeatItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/SingleItem/SingleItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/SingleItem/SingleItemSwitcher.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/StringItem/StringField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/StringItem/StringItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/Tables/DeleteRowButton.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/Tables/Table.styles.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/TextItem/TextField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/TextItem/TextItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/TimeItem/TimeField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/TimeItem/TimeItem.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/UrlItem/UrlField.d.ts +0 -0
- /package/{dist → lib}/components/FormComponents/UrlItem/UrlItem.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/BaseRenderer.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormBodyCollapsible.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormBodySingleCollapsible.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormBodyTabbed.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormRenderer.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormTitle.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/FormTopLevelItem.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/SmartFormsRenderer.d.ts +0 -0
- /package/{dist → lib}/components/FormRenderer/index.d.ts +0 -0
- /package/{dist → lib}/components/Iconify/Iconify.d.ts +0 -0
- /package/{dist → lib}/components/Tabs/CompleteTabButton.d.ts +0 -0
- /package/{dist → lib}/components/Tabs/FormBodySingleTab.d.ts +0 -0
- /package/{dist → lib}/components/Tabs/FormBodyTabList.d.ts +0 -0
- /package/{dist → lib}/components/index.d.ts +0 -0
- /package/{dist → lib}/hooks/index.d.ts +0 -0
- /package/{dist → lib}/hooks/useBackToTop.d.ts +0 -0
- /package/{dist → lib}/hooks/useDebounce.d.ts +0 -0
- /package/{dist → lib}/hooks/useDecimalCalculatedExpression.d.ts +0 -0
- /package/{dist → lib}/hooks/useHidden.d.ts +0 -0
- /package/{dist → lib}/hooks/useInitialiseGroupTable.d.ts +0 -0
- /package/{dist → lib}/hooks/useInitialiseRenderer.d.ts +0 -0
- /package/{dist → lib}/hooks/useInitialiseRepeatAnswers.d.ts +0 -0
- /package/{dist → lib}/hooks/useInitialiseRepeatGroups.d.ts +0 -0
- /package/{dist → lib}/hooks/useIntegerCalculatedExpression.d.ts +0 -0
- /package/{dist → lib}/hooks/useQueryClient.d.ts +0 -0
- /package/{dist → lib}/hooks/useRenderingExtensions.d.ts +0 -0
- /package/{dist → lib}/hooks/useResponsive.d.ts +0 -0
- /package/{dist → lib}/hooks/useStringCalculatedExpression.d.ts +0 -0
- /package/{dist → lib}/hooks/useTerminologyServerQuery.d.ts +0 -0
- /package/{dist → lib}/hooks/useValidationError.d.ts +0 -0
- /package/{dist → lib}/interfaces/answerExpression.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/calculatedExpression.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/choice.enum.d.ts +0 -0
- /package/{dist → lib}/interfaces/enableWhen.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/groupTable.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/populate.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/questionnaireStore.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/regex.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/repeatGroup.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/repeatItem.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/tab.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/valueSet.interface.d.ts +0 -0
- /package/{dist → lib}/interfaces/variables.interface.d.ts +0 -0
- /package/{dist → lib}/stores/useConfigStore.d.ts +0 -0
- /package/{dist → lib}/stores/useQuestionnaireResponseStore.d.ts +0 -0
- /package/{dist → lib}/stores/useQuestionnaireStore.d.ts +0 -0
- /package/{dist → lib}/utils/calculatedExpression.d.ts +0 -0
- /package/{dist → lib}/utils/choice.d.ts +0 -0
- /package/{dist → lib}/utils/debounce.d.ts +0 -0
- /package/{dist → lib}/utils/emptyResource.d.ts +0 -0
- /package/{dist → lib}/utils/enableWhen.d.ts +0 -0
- /package/{dist → lib}/utils/enableWhenExpression.d.ts +0 -0
- /package/{dist → lib}/utils/fhirpath.d.ts +0 -0
- /package/{dist → lib}/utils/initialiseForm.d.ts +0 -0
- /package/{dist → lib}/utils/itemControl.d.ts +0 -0
- /package/{dist → lib}/utils/mapItem.d.ts +0 -0
- /package/{dist → lib}/utils/openChoice.d.ts +0 -0
- /package/{dist → lib}/utils/parseInputs.d.ts +0 -0
- /package/{dist → lib}/utils/populate.d.ts +0 -0
- /package/{dist → lib}/utils/populateCallback.d.ts +0 -0
- /package/{dist → lib}/utils/populateContexts.d.ts +0 -0
- /package/{dist → lib}/utils/populateInputParams.d.ts +0 -0
- /package/{dist → lib}/utils/qItem.d.ts +0 -0
- /package/{dist → lib}/utils/qrItem.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/addAdditionalVariables.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/createQuestionaireModel.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/extractContainedValueSets.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/extractLaunchContext.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/extractOtherExtensions.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/extractTabs.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/extractVariables.d.ts +0 -0
- /package/{dist → lib}/utils/questionnaireStoreUtils/resolveValueSets.d.ts +0 -0
- /package/{dist → lib}/utils/removeHidden.d.ts +0 -0
- /package/{dist → lib}/utils/tabs.d.ts +0 -0
- /package/{dist → lib}/utils/valueSet.d.ts +0 -0
- /package/{dist/setup-jest.d.ts → src/setup-jest.ts} +0 -0
|
@@ -0,0 +1,178 @@
|
|
|
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 { ChangeEvent, SyntheticEvent } from 'react';
|
|
19
|
+
import React, { useState } from 'react';
|
|
20
|
+
import { Autocomplete, CircularProgress, Fade, Grid, Tooltip } from '@mui/material';
|
|
21
|
+
import type { Coding, QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
22
|
+
|
|
23
|
+
import { createEmptyQrItem } from '../../../utils/qrItem';
|
|
24
|
+
import { StandardTextField } from '../Textfield.styles';
|
|
25
|
+
import { FullWidthFormComponentBox } from '../../Box.styles';
|
|
26
|
+
import SearchIcon from '@mui/icons-material/Search';
|
|
27
|
+
import useDebounce from '../../../hooks/useDebounce';
|
|
28
|
+
import useTerminologyServerQuery from '../../../hooks/useTerminologyServerQuery';
|
|
29
|
+
import InfoIcon from '@mui/icons-material/Info';
|
|
30
|
+
import WarningAmberIcon from '@mui/icons-material/WarningAmber';
|
|
31
|
+
import DoneIcon from '@mui/icons-material/Done';
|
|
32
|
+
import ErrorIcon from '@mui/icons-material/Error';
|
|
33
|
+
import useRenderingExtensions from '../../../hooks/useRenderingExtensions';
|
|
34
|
+
import { getTerminologyServerUrl } from '../../../utils/valueSet';
|
|
35
|
+
import type {
|
|
36
|
+
PropsWithIsRepeatedAttribute,
|
|
37
|
+
PropsWithIsTabledAttribute,
|
|
38
|
+
PropsWithQrItemChangeHandler
|
|
39
|
+
} from '../../../interfaces/renderProps.interface';
|
|
40
|
+
import { AUTOCOMPLETE_DEBOUNCE_DURATION } from '../../../utils/debounce';
|
|
41
|
+
import DisplayInstructions from '../DisplayItem/DisplayInstructions';
|
|
42
|
+
import LabelWrapper from '../ItemParts/ItemLabelWrapper';
|
|
43
|
+
|
|
44
|
+
interface QItemChoiceAutocompleteProps
|
|
45
|
+
extends PropsWithQrItemChangeHandler<QuestionnaireResponseItem>,
|
|
46
|
+
PropsWithIsRepeatedAttribute,
|
|
47
|
+
PropsWithIsTabledAttribute {
|
|
48
|
+
qItem: QuestionnaireItem;
|
|
49
|
+
qrItem: QuestionnaireResponseItem;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function QItemChoiceAutocomplete(props: QItemChoiceAutocompleteProps) {
|
|
53
|
+
const { qItem, qrItem, isRepeated, isTabled, onQrItemChange } = props;
|
|
54
|
+
const qrChoice = qrItem ?? createEmptyQrItem(qItem);
|
|
55
|
+
|
|
56
|
+
// Init input value
|
|
57
|
+
let valueCoding: Coding | undefined;
|
|
58
|
+
if (qrChoice.answer) {
|
|
59
|
+
valueCoding = qrChoice.answer[0].valueCoding;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Get additional rendering extensions
|
|
63
|
+
const { displayUnit, displayPrompt, displayInstructions, readOnly, entryFormat } =
|
|
64
|
+
useRenderingExtensions(qItem);
|
|
65
|
+
|
|
66
|
+
// Query ontoserver for options
|
|
67
|
+
const maxList = 10;
|
|
68
|
+
|
|
69
|
+
const [input, setInput] = useState('');
|
|
70
|
+
const debouncedInput = useDebounce(input, AUTOCOMPLETE_DEBOUNCE_DURATION);
|
|
71
|
+
|
|
72
|
+
const answerValueSetUrl = qItem.answerValueSet;
|
|
73
|
+
const terminologyServerUrl = getTerminologyServerUrl(qItem);
|
|
74
|
+
const { options, loading, feedback } = useTerminologyServerQuery(
|
|
75
|
+
answerValueSetUrl,
|
|
76
|
+
maxList,
|
|
77
|
+
input,
|
|
78
|
+
debouncedInput,
|
|
79
|
+
terminologyServerUrl
|
|
80
|
+
);
|
|
81
|
+
|
|
82
|
+
if (!answerValueSetUrl) return null;
|
|
83
|
+
|
|
84
|
+
// Event handlers
|
|
85
|
+
function handleValueChange(_: SyntheticEvent<Element, Event>, newValue: Coding | null) {
|
|
86
|
+
if (newValue === null) {
|
|
87
|
+
setInput('');
|
|
88
|
+
onQrItemChange(createEmptyQrItem(qItem));
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
onQrItemChange({
|
|
93
|
+
...createEmptyQrItem(qItem),
|
|
94
|
+
answer: [{ valueCoding: newValue }]
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const choiceAutocomplete = (
|
|
99
|
+
<>
|
|
100
|
+
<Autocomplete
|
|
101
|
+
id={qItem.id}
|
|
102
|
+
value={valueCoding ?? null}
|
|
103
|
+
placeholder={entryFormat}
|
|
104
|
+
options={options}
|
|
105
|
+
getOptionLabel={(option) => `${option.display}`}
|
|
106
|
+
isOptionEqualToValue={(option, value) => option.id === value.id}
|
|
107
|
+
loading={loading}
|
|
108
|
+
loadingText={'Fetching results...'}
|
|
109
|
+
clearOnEscape
|
|
110
|
+
autoHighlight
|
|
111
|
+
onChange={handleValueChange}
|
|
112
|
+
sx={{ maxWidth: !isTabled ? 280 : 3000, minWidth: 160, flexGrow: 1 }}
|
|
113
|
+
filterOptions={(x) => x}
|
|
114
|
+
renderInput={(params) => (
|
|
115
|
+
<StandardTextField
|
|
116
|
+
{...params}
|
|
117
|
+
onChange={(e: ChangeEvent<HTMLInputElement>) => setInput(e.target.value)}
|
|
118
|
+
isTabled={isTabled}
|
|
119
|
+
disabled={readOnly}
|
|
120
|
+
label={displayPrompt}
|
|
121
|
+
size="small"
|
|
122
|
+
InputProps={{
|
|
123
|
+
...params.InputProps,
|
|
124
|
+
|
|
125
|
+
startAdornment: (
|
|
126
|
+
<>
|
|
127
|
+
{!valueCoding ? <SearchIcon fontSize="small" sx={{ ml: 0.5 }} /> : null}
|
|
128
|
+
{params.InputProps.startAdornment}
|
|
129
|
+
</>
|
|
130
|
+
),
|
|
131
|
+
endAdornment: (
|
|
132
|
+
<>
|
|
133
|
+
{loading ? (
|
|
134
|
+
<CircularProgress color="inherit" size={16} />
|
|
135
|
+
) : feedback ? (
|
|
136
|
+
<Fade in={!!feedback} timeout={300}>
|
|
137
|
+
<Tooltip title={feedback.message} arrow sx={{ ml: 1 }}>
|
|
138
|
+
{
|
|
139
|
+
{
|
|
140
|
+
info: <InfoIcon fontSize="small" color="info" />,
|
|
141
|
+
warning: <WarningAmberIcon fontSize="small" color="warning" />,
|
|
142
|
+
success: <DoneIcon fontSize="small" color="success" />,
|
|
143
|
+
error: <ErrorIcon fontSize="small" color="error" />
|
|
144
|
+
}[feedback.color]
|
|
145
|
+
}
|
|
146
|
+
</Tooltip>
|
|
147
|
+
</Fade>
|
|
148
|
+
) : null}
|
|
149
|
+
{params.InputProps.endAdornment}
|
|
150
|
+
{displayUnit}
|
|
151
|
+
</>
|
|
152
|
+
)
|
|
153
|
+
}}
|
|
154
|
+
/>
|
|
155
|
+
)}
|
|
156
|
+
/>
|
|
157
|
+
</>
|
|
158
|
+
);
|
|
159
|
+
|
|
160
|
+
const renderQItemChoiceAutocomplete = isRepeated ? (
|
|
161
|
+
<>{choiceAutocomplete}</>
|
|
162
|
+
) : (
|
|
163
|
+
<FullWidthFormComponentBox>
|
|
164
|
+
<Grid container columnSpacing={6}>
|
|
165
|
+
<Grid item xs={5}>
|
|
166
|
+
<LabelWrapper qItem={qItem} />
|
|
167
|
+
</Grid>
|
|
168
|
+
<Grid item xs={7}>
|
|
169
|
+
{choiceAutocomplete}
|
|
170
|
+
<DisplayInstructions displayInstructions={displayInstructions} />
|
|
171
|
+
</Grid>
|
|
172
|
+
</Grid>
|
|
173
|
+
</FullWidthFormComponentBox>
|
|
174
|
+
);
|
|
175
|
+
return <>{renderQItemChoiceAutocomplete}</>;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
export default QItemChoiceAutocomplete;
|
|
@@ -0,0 +1,131 @@
|
|
|
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 React from 'react';
|
|
19
|
+
import { Grid } from '@mui/material';
|
|
20
|
+
import { QItemChoiceOrientation } from '../../../interfaces/choice.enum';
|
|
21
|
+
import type { QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
22
|
+
import QItemChoiceCheckboxSingle from '../ItemParts/QItemCheckboxSingle';
|
|
23
|
+
import { createEmptyQrItem } from '../../../utils/qrItem';
|
|
24
|
+
import { QFormGroup } from '../Item.styles';
|
|
25
|
+
import { updateQrCheckboxAnswers } from '../../../utils/choice';
|
|
26
|
+
import { FullWidthFormComponentBox } from '../../Box.styles';
|
|
27
|
+
import useRenderingExtensions from '../../../hooks/useRenderingExtensions';
|
|
28
|
+
import type {
|
|
29
|
+
PropsWithIsRepeatedAttribute,
|
|
30
|
+
PropsWithQrItemChangeHandler
|
|
31
|
+
} from '../../../interfaces/renderProps.interface';
|
|
32
|
+
import DisplayInstructions from '../DisplayItem/DisplayInstructions';
|
|
33
|
+
import LabelWrapper from '../ItemParts/ItemLabelWrapper';
|
|
34
|
+
|
|
35
|
+
interface QItemChoiceCheckboxProps
|
|
36
|
+
extends PropsWithQrItemChangeHandler<QuestionnaireResponseItem>,
|
|
37
|
+
PropsWithIsRepeatedAttribute {
|
|
38
|
+
qItem: QuestionnaireItem;
|
|
39
|
+
qrItem: QuestionnaireResponseItem;
|
|
40
|
+
orientation: QItemChoiceOrientation;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
function QItemChoiceCheckboxAnswerOption(props: QItemChoiceCheckboxProps) {
|
|
44
|
+
const { qItem, qrItem, isRepeated, onQrItemChange, orientation } = props;
|
|
45
|
+
|
|
46
|
+
// Init input value
|
|
47
|
+
const qrChoiceCheckbox = qrItem ?? createEmptyQrItem(qItem);
|
|
48
|
+
const answers = qrChoiceCheckbox.answer ? qrChoiceCheckbox.answer : [];
|
|
49
|
+
|
|
50
|
+
// Get additional rendering extensions
|
|
51
|
+
const { displayInstructions, readOnly } = useRenderingExtensions(qItem);
|
|
52
|
+
|
|
53
|
+
// Event handlers
|
|
54
|
+
function handleCheckedChange(changedValue: string) {
|
|
55
|
+
const answerOptions = qItem.answerOption;
|
|
56
|
+
if (!answerOptions) return null;
|
|
57
|
+
|
|
58
|
+
const updatedQrChoiceCheckbox = updateQrCheckboxAnswers(
|
|
59
|
+
changedValue,
|
|
60
|
+
answers,
|
|
61
|
+
answerOptions,
|
|
62
|
+
qrChoiceCheckbox,
|
|
63
|
+
isRepeated
|
|
64
|
+
);
|
|
65
|
+
|
|
66
|
+
if (updatedQrChoiceCheckbox) {
|
|
67
|
+
onQrItemChange(updatedQrChoiceCheckbox);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const choiceCheckbox = (
|
|
72
|
+
<QFormGroup row={orientation === QItemChoiceOrientation.Horizontal}>
|
|
73
|
+
{qItem.answerOption?.map((option) => {
|
|
74
|
+
if (option['valueCoding']) {
|
|
75
|
+
return (
|
|
76
|
+
<QItemChoiceCheckboxSingle
|
|
77
|
+
key={option.valueCoding.code ?? ''}
|
|
78
|
+
value={option.valueCoding.code ?? ''}
|
|
79
|
+
label={option.valueCoding.display ?? `${option.valueCoding.code}`}
|
|
80
|
+
readOnly={readOnly}
|
|
81
|
+
isChecked={answers.some(
|
|
82
|
+
(answer) => JSON.stringify(answer) === JSON.stringify(option)
|
|
83
|
+
)}
|
|
84
|
+
onCheckedChange={handleCheckedChange}
|
|
85
|
+
/>
|
|
86
|
+
);
|
|
87
|
+
} else if (option['valueString']) {
|
|
88
|
+
return (
|
|
89
|
+
<QItemChoiceCheckboxSingle
|
|
90
|
+
key={option.valueString}
|
|
91
|
+
value={option.valueString}
|
|
92
|
+
label={option.valueString}
|
|
93
|
+
readOnly={readOnly}
|
|
94
|
+
isChecked={answers.some((answer) => answer.valueString === option.valueString)}
|
|
95
|
+
onCheckedChange={handleCheckedChange}
|
|
96
|
+
/>
|
|
97
|
+
);
|
|
98
|
+
} else if (option['valueInteger']) {
|
|
99
|
+
return (
|
|
100
|
+
<QItemChoiceCheckboxSingle
|
|
101
|
+
key={option.valueInteger}
|
|
102
|
+
value={option.valueInteger.toString()}
|
|
103
|
+
label={option.valueInteger.toString()}
|
|
104
|
+
readOnly={readOnly}
|
|
105
|
+
isChecked={answers.some((answer) => answer.valueInteger === option.valueInteger)}
|
|
106
|
+
onCheckedChange={handleCheckedChange}
|
|
107
|
+
/>
|
|
108
|
+
);
|
|
109
|
+
} else {
|
|
110
|
+
return null;
|
|
111
|
+
}
|
|
112
|
+
})}
|
|
113
|
+
</QFormGroup>
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
return (
|
|
117
|
+
<FullWidthFormComponentBox data-test="q-item-choice-checkbox-answer-option-box">
|
|
118
|
+
<Grid container columnSpacing={6}>
|
|
119
|
+
<Grid item xs={5}>
|
|
120
|
+
<LabelWrapper qItem={qItem} />
|
|
121
|
+
</Grid>
|
|
122
|
+
<Grid item xs={7}>
|
|
123
|
+
{choiceCheckbox}
|
|
124
|
+
<DisplayInstructions displayInstructions={displayInstructions} />
|
|
125
|
+
</Grid>
|
|
126
|
+
</Grid>
|
|
127
|
+
</FullWidthFormComponentBox>
|
|
128
|
+
);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
export default QItemChoiceCheckboxAnswerOption;
|
|
@@ -0,0 +1,126 @@
|
|
|
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 React from 'react';
|
|
19
|
+
import { Grid, Typography } from '@mui/material';
|
|
20
|
+
|
|
21
|
+
import type { QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
22
|
+
import { createEmptyQrItem } from '../../../utils/qrItem';
|
|
23
|
+
import useValueSetCodings from '../../../hooks/useValueSetCodings';
|
|
24
|
+
import { QItemChoiceOrientation } from '../../../interfaces/choice.enum';
|
|
25
|
+
import { mapCodingsToOptions, updateQrCheckboxAnswers } from '../../../utils/choice';
|
|
26
|
+
import QItemCheckboxSingle from '../ItemParts/QItemCheckboxSingle';
|
|
27
|
+
import { QFormGroup } from '../Item.styles';
|
|
28
|
+
import { FullWidthFormComponentBox } from '../../Box.styles';
|
|
29
|
+
import useRenderingExtensions from '../../../hooks/useRenderingExtensions';
|
|
30
|
+
import ErrorOutlineIcon from '@mui/icons-material/ErrorOutline';
|
|
31
|
+
import type {
|
|
32
|
+
PropsWithIsRepeatedAttribute,
|
|
33
|
+
PropsWithQrItemChangeHandler
|
|
34
|
+
} from '../../../interfaces/renderProps.interface';
|
|
35
|
+
import { StyledAlert } from '../../Alert.styles';
|
|
36
|
+
import DisplayInstructions from '../DisplayItem/DisplayInstructions';
|
|
37
|
+
import LabelWrapper from '../ItemParts/ItemLabelWrapper';
|
|
38
|
+
|
|
39
|
+
interface Props
|
|
40
|
+
extends PropsWithQrItemChangeHandler<QuestionnaireResponseItem>,
|
|
41
|
+
PropsWithIsRepeatedAttribute {
|
|
42
|
+
qItem: QuestionnaireItem;
|
|
43
|
+
qrItem: QuestionnaireResponseItem;
|
|
44
|
+
orientation: QItemChoiceOrientation;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function QItemChoiceCheckboxAnswerValueSet(props: Props) {
|
|
48
|
+
const { qItem, qrItem, isRepeated, onQrItemChange, orientation } = props;
|
|
49
|
+
|
|
50
|
+
// Init input value
|
|
51
|
+
const qrChoiceCheckbox = qrItem ?? createEmptyQrItem(qItem);
|
|
52
|
+
const answers = qrChoiceCheckbox.answer ? qrChoiceCheckbox.answer : [];
|
|
53
|
+
|
|
54
|
+
// Get additional rendering extensions
|
|
55
|
+
const { displayInstructions, readOnly } = useRenderingExtensions(qItem);
|
|
56
|
+
|
|
57
|
+
// Get codings/options from valueSet
|
|
58
|
+
const { codings, serverError } = useValueSetCodings(qItem);
|
|
59
|
+
|
|
60
|
+
// Event handlers
|
|
61
|
+
function handleCheckedChange(changedValue: string) {
|
|
62
|
+
if (codings.length < 1) return null;
|
|
63
|
+
|
|
64
|
+
const updatedQrChoiceCheckbox = updateQrCheckboxAnswers(
|
|
65
|
+
changedValue,
|
|
66
|
+
answers,
|
|
67
|
+
mapCodingsToOptions(codings),
|
|
68
|
+
qrChoiceCheckbox,
|
|
69
|
+
isRepeated
|
|
70
|
+
);
|
|
71
|
+
|
|
72
|
+
if (updatedQrChoiceCheckbox) {
|
|
73
|
+
onQrItemChange(updatedQrChoiceCheckbox);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const choiceCheckbox =
|
|
78
|
+
codings.length > 0 ? (
|
|
79
|
+
<QFormGroup row={orientation === QItemChoiceOrientation.Horizontal}>
|
|
80
|
+
{codings.map((coding) => {
|
|
81
|
+
return (
|
|
82
|
+
<QItemCheckboxSingle
|
|
83
|
+
key={coding.code ?? ''}
|
|
84
|
+
value={coding.code ?? ''}
|
|
85
|
+
label={coding.display ?? `${coding.code}`}
|
|
86
|
+
readOnly={readOnly}
|
|
87
|
+
isChecked={answers.some(
|
|
88
|
+
(answer) => JSON.stringify(answer.valueCoding) === JSON.stringify(coding)
|
|
89
|
+
)}
|
|
90
|
+
onCheckedChange={handleCheckedChange}
|
|
91
|
+
/>
|
|
92
|
+
);
|
|
93
|
+
})}
|
|
94
|
+
</QFormGroup>
|
|
95
|
+
) : serverError ? (
|
|
96
|
+
<StyledAlert color="error">
|
|
97
|
+
<ErrorOutlineIcon color="error" sx={{ pr: 0.75 }} />
|
|
98
|
+
<Typography variant="subtitle2">
|
|
99
|
+
There was an error fetching options from the terminology server
|
|
100
|
+
</Typography>
|
|
101
|
+
</StyledAlert>
|
|
102
|
+
) : (
|
|
103
|
+
<StyledAlert color="error">
|
|
104
|
+
<ErrorOutlineIcon color="error" sx={{ pr: 0.75 }} />
|
|
105
|
+
<Typography variant="subtitle2">
|
|
106
|
+
Unable to fetch options from the questionnaire or launch context
|
|
107
|
+
</Typography>
|
|
108
|
+
</StyledAlert>
|
|
109
|
+
);
|
|
110
|
+
|
|
111
|
+
return (
|
|
112
|
+
<FullWidthFormComponentBox data-test="q-item-choice-checkbox-answer-value-set-box">
|
|
113
|
+
<Grid container columnSpacing={6}>
|
|
114
|
+
<Grid item xs={5}>
|
|
115
|
+
<LabelWrapper qItem={qItem} />
|
|
116
|
+
</Grid>
|
|
117
|
+
<Grid item xs={7}>
|
|
118
|
+
{choiceCheckbox}
|
|
119
|
+
<DisplayInstructions displayInstructions={displayInstructions} />
|
|
120
|
+
</Grid>
|
|
121
|
+
</Grid>
|
|
122
|
+
</FullWidthFormComponentBox>
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
export default QItemChoiceCheckboxAnswerValueSet;
|
|
@@ -0,0 +1,125 @@
|
|
|
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 { ChangeEvent } from 'react';
|
|
19
|
+
import React from 'react';
|
|
20
|
+
import { Grid } from '@mui/material';
|
|
21
|
+
import { QItemChoiceOrientation } from '../../../interfaces/choice.enum';
|
|
22
|
+
import type { QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
23
|
+
import { findInAnswerOptions, getQrChoiceValue } from '../../../utils/choice';
|
|
24
|
+
import QItemChoiceRadioSingle from './QItemChoiceRadioSingle';
|
|
25
|
+
import { createEmptyQrItem } from '../../../utils/qrItem';
|
|
26
|
+
import { QRadioGroup } from '../Item.styles';
|
|
27
|
+
import { FullWidthFormComponentBox } from '../../Box.styles';
|
|
28
|
+
import useRenderingExtensions from '../../../hooks/useRenderingExtensions';
|
|
29
|
+
import type {
|
|
30
|
+
PropsWithIsRepeatedAttribute,
|
|
31
|
+
PropsWithQrItemChangeHandler
|
|
32
|
+
} from '../../../interfaces/renderProps.interface';
|
|
33
|
+
import DisplayInstructions from '../DisplayItem/DisplayInstructions';
|
|
34
|
+
import LabelWrapper from '../ItemParts/ItemLabelWrapper';
|
|
35
|
+
|
|
36
|
+
interface Props
|
|
37
|
+
extends PropsWithQrItemChangeHandler<QuestionnaireResponseItem>,
|
|
38
|
+
PropsWithIsRepeatedAttribute {
|
|
39
|
+
qItem: QuestionnaireItem;
|
|
40
|
+
qrItem: QuestionnaireResponseItem;
|
|
41
|
+
orientation: QItemChoiceOrientation;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function QItemChoiceRadioAnswerOption(props: Props) {
|
|
45
|
+
const { qItem, qrItem, isRepeated, onQrItemChange, orientation } = props;
|
|
46
|
+
|
|
47
|
+
// Init input value
|
|
48
|
+
const qrChoiceRadio = qrItem ?? createEmptyQrItem(qItem);
|
|
49
|
+
const valueRadio = getQrChoiceValue(qrChoiceRadio);
|
|
50
|
+
|
|
51
|
+
// Get additional rendering extensions
|
|
52
|
+
const { displayInstructions, readOnly } = useRenderingExtensions(qItem);
|
|
53
|
+
|
|
54
|
+
// Event handlers
|
|
55
|
+
function handleChange(e: ChangeEvent<HTMLInputElement>) {
|
|
56
|
+
if (qItem.answerOption) {
|
|
57
|
+
const qrAnswer = findInAnswerOptions(qItem.answerOption, e.target.value);
|
|
58
|
+
if (qrAnswer) {
|
|
59
|
+
onQrItemChange({ ...createEmptyQrItem(qItem), answer: [qrAnswer] });
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const choiceRadio = (
|
|
65
|
+
<QRadioGroup
|
|
66
|
+
row={orientation === QItemChoiceOrientation.Horizontal}
|
|
67
|
+
name={qItem.text}
|
|
68
|
+
id={qItem.id}
|
|
69
|
+
onChange={handleChange}
|
|
70
|
+
value={valueRadio}
|
|
71
|
+
data-test="q-item-radio-group">
|
|
72
|
+
{qItem.answerOption?.map((option) => {
|
|
73
|
+
if (option['valueCoding']) {
|
|
74
|
+
return (
|
|
75
|
+
<QItemChoiceRadioSingle
|
|
76
|
+
key={option.valueCoding.code ?? ''}
|
|
77
|
+
value={option.valueCoding.code ?? ''}
|
|
78
|
+
label={option.valueCoding.display ?? `${option.valueCoding.code}`}
|
|
79
|
+
readOnly={readOnly}
|
|
80
|
+
/>
|
|
81
|
+
);
|
|
82
|
+
} else if (option['valueString']) {
|
|
83
|
+
return (
|
|
84
|
+
<QItemChoiceRadioSingle
|
|
85
|
+
key={option.valueString}
|
|
86
|
+
value={option.valueString}
|
|
87
|
+
label={option.valueString}
|
|
88
|
+
readOnly={readOnly}
|
|
89
|
+
/>
|
|
90
|
+
);
|
|
91
|
+
} else if (option['valueInteger']) {
|
|
92
|
+
return (
|
|
93
|
+
<QItemChoiceRadioSingle
|
|
94
|
+
key={option.valueInteger}
|
|
95
|
+
value={option.valueInteger.toString()}
|
|
96
|
+
label={option.valueInteger.toString()}
|
|
97
|
+
readOnly={readOnly}
|
|
98
|
+
/>
|
|
99
|
+
);
|
|
100
|
+
} else {
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
})}
|
|
104
|
+
</QRadioGroup>
|
|
105
|
+
);
|
|
106
|
+
|
|
107
|
+
const renderQItemChoiceRadio = isRepeated ? (
|
|
108
|
+
<>{choiceRadio}</>
|
|
109
|
+
) : (
|
|
110
|
+
<FullWidthFormComponentBox data-test="q-item-choice-radio-answer-option-box">
|
|
111
|
+
<Grid container columnSpacing={6}>
|
|
112
|
+
<Grid item xs={5}>
|
|
113
|
+
<LabelWrapper qItem={qItem} />
|
|
114
|
+
</Grid>
|
|
115
|
+
<Grid item xs={7}>
|
|
116
|
+
{choiceRadio}
|
|
117
|
+
<DisplayInstructions displayInstructions={displayInstructions} />
|
|
118
|
+
</Grid>
|
|
119
|
+
</Grid>
|
|
120
|
+
</FullWidthFormComponentBox>
|
|
121
|
+
);
|
|
122
|
+
return <>{renderQItemChoiceRadio}</>;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
export default QItemChoiceRadioAnswerOption;
|
|
@@ -0,0 +1,129 @@
|
|
|
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 { ChangeEvent } from 'react';
|
|
19
|
+
import React from 'react';
|
|
20
|
+
import { Grid, Typography } from '@mui/material';
|
|
21
|
+
import { QItemChoiceOrientation } from '../../../interfaces/choice.enum';
|
|
22
|
+
import type { Coding, QuestionnaireItem, QuestionnaireResponseItem } from 'fhir/r4';
|
|
23
|
+
import { findInAnswerValueSetCodings } from '../../../utils/choice';
|
|
24
|
+
import QItemChoiceRadioSingle from './QItemChoiceRadioSingle';
|
|
25
|
+
import { createEmptyQrItem } from '../../../utils/qrItem';
|
|
26
|
+
import { QRadioGroup } from '../Item.styles';
|
|
27
|
+
import { FullWidthFormComponentBox } from '../../Box.styles';
|
|
28
|
+
import useValueSetCodings from '../../../hooks/useValueSetCodings';
|
|
29
|
+
import useRenderingExtensions from '../../../hooks/useRenderingExtensions';
|
|
30
|
+
import ErrorOutlineIcon from '@mui/icons-material/ErrorOutline';
|
|
31
|
+
import type {
|
|
32
|
+
PropsWithIsRepeatedAttribute,
|
|
33
|
+
PropsWithQrItemChangeHandler
|
|
34
|
+
} from '../../../interfaces/renderProps.interface';
|
|
35
|
+
import { StyledAlert } from '../../Alert.styles';
|
|
36
|
+
import DisplayInstructions from '../DisplayItem/DisplayInstructions';
|
|
37
|
+
import LabelWrapper from '../ItemParts/ItemLabelWrapper';
|
|
38
|
+
|
|
39
|
+
interface Props
|
|
40
|
+
extends PropsWithQrItemChangeHandler<QuestionnaireResponseItem>,
|
|
41
|
+
PropsWithIsRepeatedAttribute {
|
|
42
|
+
qItem: QuestionnaireItem;
|
|
43
|
+
qrItem: QuestionnaireResponseItem;
|
|
44
|
+
orientation: QItemChoiceOrientation;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function QItemChoiceRadioAnswerValueSet(props: Props) {
|
|
48
|
+
const { qItem, qrItem, isRepeated, onQrItemChange, orientation } = props;
|
|
49
|
+
|
|
50
|
+
// Init input value
|
|
51
|
+
const qrChoiceRadio = qrItem ?? createEmptyQrItem(qItem);
|
|
52
|
+
|
|
53
|
+
let valueRadio: string | undefined;
|
|
54
|
+
if (qrChoiceRadio.answer) {
|
|
55
|
+
valueRadio = qrChoiceRadio.answer[0].valueCoding?.code;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// Get additional rendering extensions
|
|
59
|
+
const { displayInstructions, readOnly } = useRenderingExtensions(qItem);
|
|
60
|
+
|
|
61
|
+
// Get codings/options from valueSet
|
|
62
|
+
const { codings, serverError } = useValueSetCodings(qItem);
|
|
63
|
+
|
|
64
|
+
function handleChange(event: ChangeEvent<HTMLInputElement>) {
|
|
65
|
+
if (codings.length > 0) {
|
|
66
|
+
const qrAnswer = findInAnswerValueSetCodings(codings, event.target.value);
|
|
67
|
+
if (qrAnswer) {
|
|
68
|
+
onQrItemChange({
|
|
69
|
+
...createEmptyQrItem(qItem),
|
|
70
|
+
answer: [{ valueCoding: qrAnswer }]
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const choiceRadio =
|
|
77
|
+
codings.length > 0 ? (
|
|
78
|
+
<QRadioGroup
|
|
79
|
+
row={orientation === QItemChoiceOrientation.Horizontal}
|
|
80
|
+
name={qItem.text}
|
|
81
|
+
id={qItem.id}
|
|
82
|
+
onChange={handleChange}
|
|
83
|
+
value={valueRadio ?? null}>
|
|
84
|
+
{codings.map((coding: Coding) => {
|
|
85
|
+
return (
|
|
86
|
+
<QItemChoiceRadioSingle
|
|
87
|
+
key={coding.code ?? ''}
|
|
88
|
+
value={coding.code ?? ''}
|
|
89
|
+
label={coding.display ?? `${coding.code}`}
|
|
90
|
+
readOnly={readOnly}
|
|
91
|
+
/>
|
|
92
|
+
);
|
|
93
|
+
})}
|
|
94
|
+
</QRadioGroup>
|
|
95
|
+
) : serverError ? (
|
|
96
|
+
<StyledAlert color="error">
|
|
97
|
+
<ErrorOutlineIcon color="error" sx={{ pr: 0.75 }} />
|
|
98
|
+
<Typography variant="subtitle2">
|
|
99
|
+
There was an error fetching options from the terminology server
|
|
100
|
+
</Typography>
|
|
101
|
+
</StyledAlert>
|
|
102
|
+
) : (
|
|
103
|
+
<StyledAlert color="error">
|
|
104
|
+
<ErrorOutlineIcon color="error" sx={{ pr: 0.75 }} />
|
|
105
|
+
<Typography variant="subtitle2">
|
|
106
|
+
Unable to fetch options from the questionnaire or launch context
|
|
107
|
+
</Typography>
|
|
108
|
+
</StyledAlert>
|
|
109
|
+
);
|
|
110
|
+
|
|
111
|
+
const renderQItemChoiceRadio = isRepeated ? (
|
|
112
|
+
<>{choiceRadio}</>
|
|
113
|
+
) : (
|
|
114
|
+
<FullWidthFormComponentBox data-test="q-item-choice-radio-answer-value-set-box">
|
|
115
|
+
<Grid container columnSpacing={6}>
|
|
116
|
+
<Grid item xs={5}>
|
|
117
|
+
<LabelWrapper qItem={qItem} />
|
|
118
|
+
</Grid>
|
|
119
|
+
<Grid item xs={7}>
|
|
120
|
+
{choiceRadio}
|
|
121
|
+
<DisplayInstructions displayInstructions={displayInstructions} />
|
|
122
|
+
</Grid>
|
|
123
|
+
</Grid>
|
|
124
|
+
</FullWidthFormComponentBox>
|
|
125
|
+
);
|
|
126
|
+
return <>{renderQItemChoiceRadio}</>;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export default QItemChoiceRadioAnswerValueSet;
|