Skip to content

Commit

Permalink
Add first cut of pre-population docs
Browse files Browse the repository at this point in the history
  • Loading branch information
fongsean committed May 19, 2024
1 parent 2a89448 commit 6eb151c
Show file tree
Hide file tree
Showing 4 changed files with 132 additions and 24 deletions.
2 changes: 0 additions & 2 deletions documentation/docs/sdc/advanced/fundamental.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -129,8 +129,6 @@ Allows one or more values to be pre-filled in the answer when initially renderin

Questions using answerOption can use `answerOption.initialSelected` as an alternative.

[//]: # 'FIXME add support for initialSelected'

:::note

Multiple initial values can be used in repeating items. There can only be one initial value for non-repeating items.
Expand Down
8 changes: 8 additions & 0 deletions documentation/docs/sdc/calculations.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,14 @@ The only way to use calculations is via **calculatedExpressions** currently.

:::

### Variable

Used to define a variable that is available for use in [expressions](http://hl7.org/fhir/uv/sdc/expressions.html) within the same item and any descendant items. This allows it to be consumed by calculatedExpressions when the renderer executes a calculation.

For more information, refer to http://hl7.org/fhir/uv/sdc/expressions.html#variable.

For usages, refer to the [CalculatedExpression](#calculatedexpression) section on this page.

### CalculatedExpression

The basis of calculations in SDC. Allows an item value to update continuously as the answers to dependent questions change.
Expand Down
130 changes: 124 additions & 6 deletions documentation/docs/sdc/population.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,133 @@
sidebar_position: 2
---

import IframeContainer from '../../src/react/IframeContainer';

# Pre-population

Pre-population Placeholder
Pre-population is a mechanism to pre-fill form questions with information already present in the clinical system. It is a way to reduce the burden on the user to fill in information that is already known.

For a detailed explanation, see the [Form Population](https://hl7.org/fhir/uv/sdc/populate.html) section in the SDC spec.

The elements/extensions that fall under this category are:

#### Extensions containing pre-population queries:

- [initial](http://hl7.org/fhir/uv/sdc/behavior.html#initial)
- [variable](http://hl7.org/fhir/uv/sdc/expressions.html#variable)
- [initialExpression](http://hl7.org/fhir/uv/sdc/expressions.html#initialExpression)
- [calculatedExpression](http://hl7.org/fhir/uv/sdc/expressions.html#calculatedExpression)
- [itemPopulationContext](http://hl7.org/fhir/uv/sdc/expressions.html#itemPopulationContext)
- [launchContext](http://hl7.org/fhir/uv/sdc/expressions.html#launchContext)
- [variable](http://hl7.org/fhir/uv/sdc/expressions.html#variable)
- [x-fhir-query](http://hl7.org/fhir/uv/sdc/expressions.html#x-fhir-query-enhancements)
- [sourceQueries](https://build.fhir.org/ig/HL7/sdc/populate.html#structuremap-based-population)
- [itemPopulationContext](http://hl7.org/fhir/uv/sdc/expressions.html#itemPopulationContext)

#### Elements/expressions defined at the question to be pre-populated:

- [initial](http://hl7.org/fhir/uv/sdc/behavior.html#initial)
- [initialExpression](http://hl7.org/fhir/uv/sdc/expressions.html#initialExpression)
- [calculatedExpression](http://hl7.org/fhir/uv/sdc/expressions.html#calculatedExpression)

### LaunchContext

Allows information to be passed into the execution environment based on the context in which the Questionnaire is being pre-populated i.e patient, user, encounter, etc.

The passed information is known as "in context" within the launching system, and is subsequently applied in pre-population queries.

#### Example

Below is an example of how a launchContext extension is defined in the questionnaire.
It specifies that the patient in context is to be used to pre-populate the form.

```json
{
"url": "http://hl7.org/fhir/uv/sdc/StructureDefinition/sdc-questionnaire-launchContext",
"extension": [
{
"url": "name",
"valueCoding": {
"system": "http://hl7.org/fhir/uv/sdc/CodeSystem/launchContext",
"code": "patient"
}
},
{
"url": "type",
"valueCode": "Patient"
},
{
"url": "description",
"valueString": "The patient that is to be used to pre-populate the form"
}
]
}
```

In the below x-fhir-query variable, `{{%patient.id}}` is a reference to the launchContext extension defined above. During pre-population, the value of `{{%patient.id}}` will be replaced with the actual patient id before the query is executed.

```json
{
"url": "http://hl7.org/fhir/StructureDefinition/variable",
"valueExpression": {
"name": "Condition",
"language": "application/x-fhir-query",
"expression": "Condition?patient={{%patient.id}}"
}
}
```

For usages, refer to initial, initialExpression, and calculatedExpression sections on this page.

### X-FHIR-Query Variable

The variable extension is used to define a variable that is available for use in expressions within the same item and any descendant items.

When the variable is defined using the `application/x-fhir-query` language, it can be used to contain a query that is executed against the FHIR server during pre-population to retrieve the value to be used in the expression.

For more information, refer to http://hl7.org/fhir/uv/sdc/expressions.html#x-fhir-query-enhancements.

#### Example

Below is an example of how a variable extension using the `application/x-fhir-query` language is defined in the questionnaire.

It specifies a variable called "Condition" and it's value is to be retrieved by executing the query `Condition?patient={{%patient.id}}` on the launching system.
`{{%patient.id}}` is a reference to a defined launchContext, which will be replaced with the actual patient ID before the query is executed.

After the query is executed, the expression can be consumed by pre-population expressions during the pre-population process.

```json
{
"url": "http://hl7.org/fhir/StructureDefinition/variable",
"valueExpression": {
"name": "Condition",
"language": "application/x-fhir-query",
"expression": "Condition?patient={{%patient.id}}"
}
}
```

For usages, refer to initial, initialExpression, and calculatedExpression sections on this page.

### SourceQueries

[//]: # 'TODO'

### Initial

Allows one or more values to be pre-filled in the answer when initially rendering the questionnaire for user input. Initial values can't be specified for groups or display items.

This uses answers defined in the questionnaire itself, instead of relying on a FHIR server to provide the initial values.

Questions using answerOption can use `answerOption.initialSelected` as an alternative.

:::note

Multiple initial values can be used in repeating items. There can only be one initial value for non-repeating items.

:::

#### Basic Usage

<IframeContainer storyUrl="https://smartforms.csiro.au/storybook/index.html?path=/story/component-sdc-8-1-4-advanced-other--read-only">
<iframe
src="https://smartforms.csiro.au/storybook/iframe.html?args=&id=component-sdc-8-1-4-advanced-other--read-only"
width="100%"
height="100"
/>
</IframeContainer>
Original file line number Diff line number Diff line change
Expand Up @@ -1218,22 +1218,6 @@ export const qSourceQueriesBMICalculator: Questionnaire = {
}
],
extension: [
{
url: 'http://hl7.org/fhir/StructureDefinition/variable',
valueExpression: {
name: 'ObsBodyHeight',
language: 'application/x-fhir-query',
expression: 'Observation?code=8302-2&_count=1&_sort=-date&patient={{%patient.id}}'
}
},
// {
// url: 'http://hl7.org/fhir/StructureDefinition/variable',
// valueExpression: {
// name: 'ObsBodyWeight',
// language: 'application/x-fhir-query',
// expression: 'Observation?code=29463-7&_count=1&_sort=-date&patient={{%patient.id}}'
// }
// },
{
url: 'http://hl7.org/fhir/uv/sdc/StructureDefinition/sdc-questionnaire-launchContext',
extension: [
Expand Down

0 comments on commit 6eb151c

Please sign in to comment.