@medplum/react 0.9.27 → 0.9.30
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/dist/cjs/AddressDisplay.d.ts +6 -0
- package/dist/cjs/AddressInput.d.ts +8 -0
- package/dist/cjs/AnnotationInput.d.ts +8 -0
- package/dist/cjs/AttachmentArrayDisplay.d.ts +7 -0
- package/dist/cjs/AttachmentArrayInput.d.ts +9 -0
- package/dist/cjs/AttachmentDisplay.d.ts +7 -0
- package/dist/cjs/AttachmentInput.d.ts +9 -0
- package/dist/cjs/Autocomplete.d.ts +20 -0
- package/dist/cjs/Avatar.d.ts +12 -0
- package/dist/cjs/BackboneElementDisplay.d.ts +9 -0
- package/dist/cjs/BackboneElementInput.d.ts +9 -0
- package/dist/cjs/Button.d.ts +15 -0
- package/dist/cjs/CalendarInput.d.ts +16 -0
- package/dist/cjs/Checkbox.d.ts +12 -0
- package/dist/cjs/CheckboxFormSection.d.ts +9 -0
- package/dist/cjs/CodeInput.d.ts +9 -0
- package/dist/cjs/CodeableConceptDisplay.d.ts +6 -0
- package/dist/cjs/CodeableConceptInput.d.ts +9 -0
- package/dist/cjs/CodingDisplay.d.ts +6 -0
- package/dist/cjs/CodingInput.d.ts +9 -0
- package/dist/cjs/ContactDetailDisplay.d.ts +6 -0
- package/dist/cjs/ContactDetailInput.d.ts +8 -0
- package/dist/cjs/ContactPointDisplay.d.ts +6 -0
- package/dist/cjs/ContactPointInput.d.ts +8 -0
- package/dist/cjs/DateTimeInput.d.ts +23 -0
- package/dist/cjs/DefaultResourceTimeline.d.ts +6 -0
- package/dist/cjs/DescriptionList.d.ts +12 -0
- package/dist/cjs/DiagnosticReportDisplay.d.ts +12 -0
- package/dist/cjs/Dialog.d.ts +10 -0
- package/dist/cjs/Document.d.ts +7 -0
- package/dist/cjs/EncounterTimeline.d.ts +6 -0
- package/dist/cjs/ErrorBoundary.d.ts +18 -0
- package/dist/cjs/ExtensionInput.d.ts +8 -0
- package/dist/cjs/FhirPathDisplay.d.ts +9 -0
- package/dist/cjs/FhirPathTable.d.ts +29 -0
- package/dist/cjs/FooterLinks.d.ts +6 -0
- package/dist/cjs/Form.d.ts +8 -0
- package/dist/cjs/FormSection.d.ts +11 -0
- package/dist/cjs/FormUtils.d.ts +5 -0
- package/dist/cjs/GoogleButton.d.ts +8 -0
- package/dist/cjs/Header.d.ts +12 -0
- package/dist/cjs/HeaderSearchInput.d.ts +10 -0
- package/dist/cjs/HumanNameDisplay.d.ts +8 -0
- package/dist/cjs/HumanNameInput.d.ts +8 -0
- package/dist/cjs/IdentifierDisplay.d.ts +6 -0
- package/dist/cjs/IdentifierInput.d.ts +8 -0
- package/dist/cjs/Input.d.ts +22 -0
- package/dist/cjs/InputRow.d.ts +7 -0
- package/dist/cjs/Loading.d.ts +3 -0
- package/dist/cjs/Logo.d.ts +6 -0
- package/dist/cjs/MedplumLink.d.ts +13 -0
- package/dist/cjs/MedplumProvider.d.ts +34 -0
- package/dist/cjs/MenuItem.d.ts +9 -0
- package/dist/cjs/MenuSeparator.d.ts +3 -0
- package/dist/cjs/PatientTimeline.d.ts +6 -0
- package/dist/cjs/PeriodInput.d.ts +8 -0
- package/dist/cjs/PlanDefinitionBuilder.d.ts +7 -0
- package/dist/cjs/Popup.d.ts +14 -0
- package/dist/cjs/QuantityDisplay.d.ts +7 -0
- package/dist/cjs/QuantityInput.d.ts +8 -0
- package/dist/cjs/QuestionnaireBuilder.d.ts +8 -0
- package/dist/cjs/QuestionnaireForm.d.ts +14 -0
- package/dist/cjs/QuestionnaireUtils.d.ts +30 -0
- package/dist/cjs/RangeDisplay.d.ts +7 -0
- package/dist/cjs/RangeInput.d.ts +14 -0
- package/dist/cjs/RatioDisplay.d.ts +6 -0
- package/dist/cjs/RatioInput.d.ts +14 -0
- package/dist/cjs/ReferenceDisplay.d.ts +7 -0
- package/dist/cjs/ReferenceInput.d.ts +9 -0
- package/dist/cjs/RegisterForm.d.ts +18 -0
- package/dist/cjs/RequestGroupDisplay.d.ts +9 -0
- package/dist/cjs/ResourceArrayDisplay.d.ts +11 -0
- package/dist/cjs/ResourceArrayInput.d.ts +11 -0
- package/dist/cjs/ResourceBadge.d.ts +9 -0
- package/dist/cjs/ResourceBlame.d.ts +10 -0
- package/dist/cjs/ResourceDiff.d.ts +9 -0
- package/dist/cjs/ResourceDiffTable.d.ts +9 -0
- package/dist/cjs/ResourceForm.d.ts +10 -0
- package/dist/cjs/ResourceHistoryTable.d.ts +9 -0
- package/dist/cjs/ResourceInput.d.ts +12 -0
- package/dist/cjs/ResourceName.d.ts +7 -0
- package/dist/cjs/ResourcePropertyDisplay.d.ts +24 -0
- package/dist/cjs/ResourcePropertyInput.d.ts +21 -0
- package/dist/cjs/ResourceTable.d.ts +7 -0
- package/dist/cjs/ResourceTimeline.d.ts +11 -0
- package/dist/cjs/Scheduler.d.ts +7 -0
- package/dist/cjs/Scrollable.d.ts +9 -0
- package/dist/cjs/SearchControl.d.ts +40 -0
- package/dist/cjs/SearchControlField.d.ts +41 -0
- package/dist/cjs/SearchFieldEditor.d.ts +11 -0
- package/dist/cjs/SearchFilterEditor.d.ts +11 -0
- package/dist/cjs/SearchFilterValueDialog.d.ts +15 -0
- package/dist/cjs/SearchFilterValueDisplay.d.ts +7 -0
- package/dist/cjs/SearchFilterValueInput.d.ts +12 -0
- package/dist/cjs/SearchPopupMenu.d.ts +15 -0
- package/dist/cjs/SearchUtils.d.ts +174 -0
- package/dist/cjs/Select.d.ts +16 -0
- package/dist/cjs/ServiceRequestTimeline.d.ts +6 -0
- package/dist/cjs/SignInForm.d.ts +17 -0
- package/dist/cjs/StatusBadge.d.ts +6 -0
- package/dist/cjs/SubMenu.d.ts +7 -0
- package/dist/cjs/Tab.d.ts +12 -0
- package/dist/cjs/TabList.d.ts +10 -0
- package/dist/cjs/TabPanel.d.ts +6 -0
- package/dist/cjs/TabSwitch.d.ts +6 -0
- package/dist/cjs/TextArea.d.ts +18 -0
- package/dist/cjs/Timeline.d.ts +17 -0
- package/dist/cjs/TimingInput.d.ts +8 -0
- package/dist/cjs/TitleBar.d.ts +6 -0
- package/dist/cjs/UploadButton.d.ts +7 -0
- package/dist/cjs/constants.d.ts +1 -0
- package/dist/cjs/index.d.ts +87 -0
- package/dist/cjs/index.js +387 -196
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/index.min.js +1 -1
- package/dist/cjs/index.min.js.map +1 -1
- package/dist/cjs/stories/AddressInput.stories.d.ts +6 -0
- package/dist/cjs/stories/AttachmentArrayInput.stories.d.ts +6 -0
- package/dist/cjs/stories/AttachmentInput.stories.d.ts +6 -0
- package/dist/cjs/stories/Autocomplete.stories.d.ts +9 -0
- package/dist/cjs/stories/Avatar.stories.d.ts +10 -0
- package/dist/cjs/stories/Button.stories.d.ts +9 -0
- package/dist/cjs/stories/CodeableConceptDisplay.stories.d.ts +8 -0
- package/dist/cjs/stories/DiagnosticReportDisplay.stories.d.ts +5 -0
- package/dist/cjs/stories/Dialog.stories.d.ts +5 -0
- package/dist/cjs/stories/EncounterTimeline.stories.d.ts +5 -0
- package/dist/cjs/stories/FhirPathDisplay.stories.d.ts +7 -0
- package/dist/cjs/stories/FormSection.stories.d.ts +6 -0
- package/dist/cjs/stories/Header.stories.d.ts +8 -0
- package/dist/cjs/stories/Input.stories.d.ts +6 -0
- package/dist/cjs/stories/Loading.stories.d.ts +5 -0
- package/dist/cjs/stories/Logo.stories.d.ts +5 -0
- package/dist/cjs/stories/PatientTimeline.stories.d.ts +5 -0
- package/dist/cjs/stories/PlanDefinitionBuilder.stories.d.ts +5 -0
- package/dist/cjs/stories/QuestionnaireBuilder.stories.d.ts +7 -0
- package/dist/cjs/stories/QuestionnaireForm.stories.d.ts +11 -0
- package/dist/cjs/stories/ReferenceInput.stories.d.ts +6 -0
- package/dist/cjs/stories/RegisterForm.stories.d.ts +7 -0
- package/dist/cjs/stories/RequestGroupDisplay.stories.d.ts +5 -0
- package/dist/cjs/stories/ResourceBlame.stories.d.ts +5 -0
- package/dist/cjs/stories/ResourceForm.stories.d.ts +12 -0
- package/dist/cjs/stories/ResourceHistoryTable.stories.d.ts +5 -0
- package/dist/cjs/stories/ResourceTable.stories.d.ts +7 -0
- package/dist/cjs/stories/Scheduler.stories.d.ts +5 -0
- package/dist/cjs/stories/SearchControl.stories.d.ts +13 -0
- package/dist/cjs/stories/Select.stories.d.ts +6 -0
- package/dist/cjs/stories/SignInForm.stories.d.ts +8 -0
- package/dist/cjs/stories/StatusBadge.stories.d.ts +5 -0
- package/dist/cjs/stories/Tabs.stories.d.ts +6 -0
- package/dist/cjs/stories/Timeline.stories.d.ts +5 -0
- package/dist/cjs/stories/TimingInput.stories.d.ts +6 -0
- package/dist/cjs/stories/UploadButton.stories.d.ts +6 -0
- package/dist/cjs/styles.css +135 -130
- package/dist/cjs/test.setup.d.ts +1 -0
- package/dist/cjs/useResource.d.ts +8 -0
- package/dist/cjs/utils/blame.d.ts +8 -0
- package/dist/cjs/utils/date.d.ts +6 -0
- package/dist/cjs/utils/diff.d.ts +16 -0
- package/dist/cjs/utils/dom.d.ts +15 -0
- package/dist/cjs/utils/outcomes.d.ts +2 -0
- package/dist/cjs/utils/recaptcha.d.ts +12 -0
- package/dist/cjs/utils.d.ts +5 -0
- package/dist/esm/Autocomplete.d.ts +1 -0
- package/dist/esm/Autocomplete.js +5 -8
- package/dist/esm/Autocomplete.js.map +1 -1
- package/dist/esm/CalendarInput.d.ts +1 -0
- package/dist/esm/CalendarInput.js +6 -5
- package/dist/esm/CalendarInput.js.map +1 -1
- package/dist/esm/CodeInput.js +1 -1
- package/dist/esm/CodeInput.js.map +1 -1
- package/dist/esm/CodeableConceptDisplay.js +4 -2
- package/dist/esm/CodeableConceptDisplay.js.map +1 -1
- package/dist/esm/CodeableConceptInput.js +1 -1
- package/dist/esm/CodeableConceptInput.js.map +1 -1
- package/dist/esm/CodingInput.js +1 -1
- package/dist/esm/CodingInput.js.map +1 -1
- package/dist/esm/DateTimeInput.js +1 -3
- package/dist/esm/DateTimeInput.js.map +1 -1
- package/dist/esm/DiagnosticReportDisplay.js +2 -4
- package/dist/esm/DiagnosticReportDisplay.js.map +1 -1
- package/dist/esm/FhirPathTable.js +5 -2
- package/dist/esm/FhirPathTable.js.map +1 -1
- package/dist/esm/GoogleButton.js +2 -2
- package/dist/esm/GoogleButton.js.map +1 -1
- package/dist/esm/Header.js +7 -3
- package/dist/esm/Header.js.map +1 -1
- package/dist/esm/PlanDefinitionBuilder.js +108 -39
- package/dist/esm/PlanDefinitionBuilder.js.map +1 -1
- package/dist/esm/QuestionnaireBuilder.js +1 -1
- package/dist/esm/QuestionnaireBuilder.js.map +1 -1
- package/dist/esm/QuestionnaireForm.js +5 -1
- package/dist/esm/QuestionnaireForm.js.map +1 -1
- package/dist/esm/RegisterForm.js +2 -2
- package/dist/esm/RegisterForm.js.map +1 -1
- package/dist/esm/RequestGroupDisplay.js +3 -4
- package/dist/esm/RequestGroupDisplay.js.map +1 -1
- package/dist/esm/ResourceArrayInput.js +1 -2
- package/dist/esm/ResourceArrayInput.js.map +1 -1
- package/dist/esm/ResourceBlame.js +1 -1
- package/dist/esm/ResourceBlame.js.map +1 -1
- package/dist/esm/ResourceDiffTable.js +1 -1
- package/dist/esm/ResourceDiffTable.js.map +1 -1
- package/dist/esm/ResourceForm.js +1 -1
- package/dist/esm/ResourceForm.js.map +1 -1
- package/dist/esm/ResourceHistoryTable.js +6 -4
- package/dist/esm/ResourceHistoryTable.js.map +1 -1
- package/dist/esm/ResourceInput.d.ts +1 -0
- package/dist/esm/ResourceInput.js +4 -3
- package/dist/esm/ResourceInput.js.map +1 -1
- package/dist/esm/ResourcePropertyDisplay.js +5 -5
- package/dist/esm/ResourcePropertyDisplay.js.map +1 -1
- package/dist/esm/ResourcePropertyInput.js +3 -0
- package/dist/esm/ResourcePropertyInput.js.map +1 -1
- package/dist/esm/ResourceTable.js +1 -1
- package/dist/esm/ResourceTable.js.map +1 -1
- package/dist/esm/ResourceTimeline.js +13 -7
- package/dist/esm/ResourceTimeline.js.map +1 -1
- package/dist/esm/Scheduler.js +13 -6
- package/dist/esm/Scheduler.js.map +1 -1
- package/dist/esm/SearchControl.js +5 -2
- package/dist/esm/SearchControl.js.map +1 -1
- package/dist/esm/SearchFilterValueDisplay.js +2 -2
- package/dist/esm/SearchFilterValueDisplay.js.map +1 -1
- package/dist/esm/SearchUtils.js +2 -3
- package/dist/esm/SearchUtils.js.map +1 -1
- package/dist/esm/SignInForm.js +39 -2
- package/dist/esm/SignInForm.js.map +1 -1
- package/dist/esm/Timeline.js +2 -4
- package/dist/esm/Timeline.js.map +1 -1
- package/dist/esm/TimingInput.d.ts +8 -0
- package/dist/esm/TimingInput.js +90 -0
- package/dist/esm/TimingInput.js.map +1 -0
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.min.js +1 -1
- package/dist/esm/index.min.js.map +1 -1
- package/dist/esm/stories/Autocomplete.stories.d.ts +1 -0
- package/dist/esm/stories/CodeableConceptDisplay.stories.d.ts +8 -0
- package/dist/esm/stories/TimingInput.stories.d.ts +6 -0
- package/dist/esm/styles.css +135 -130
- package/dist/esm/utils/recaptcha.js +10 -4
- package/dist/esm/utils/recaptcha.js.map +1 -1
- package/package.json +6 -6
- package/stats.html +4034 -0
- package/dist/esm/DateTimeDisplay.d.ts +0 -5
- package/dist/esm/DateTimeDisplay.js +0 -11
- package/dist/esm/DateTimeDisplay.js.map +0 -1
- package/dist/esm/PeriodDisplay.d.ts +0 -6
- package/dist/esm/PeriodDisplay.js +0 -16
- package/dist/esm/PeriodDisplay.js.map +0 -1
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Period } from '@medplum/fhirtypes';
|
|
3
|
+
export interface PeriodInputProps {
|
|
4
|
+
name: string;
|
|
5
|
+
defaultValue?: Period;
|
|
6
|
+
onChange?: (value: Period) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare function PeriodInput(props: PeriodInputProps): JSX.Element;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { PlanDefinition, Reference } from '@medplum/fhirtypes';
|
|
3
|
+
export interface PlanDefinitionBuilderProps {
|
|
4
|
+
value: PlanDefinition | Reference<PlanDefinition>;
|
|
5
|
+
onSubmit: (result: PlanDefinition) => void;
|
|
6
|
+
}
|
|
7
|
+
export declare function PlanDefinitionBuilder(props: PlanDefinitionBuilderProps): JSX.Element | null;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './Popup.css';
|
|
3
|
+
interface PopupProps {
|
|
4
|
+
visible: boolean;
|
|
5
|
+
anchor?: DOMRectReadOnly;
|
|
6
|
+
modal?: boolean;
|
|
7
|
+
autoClose?: boolean;
|
|
8
|
+
onClose: () => void;
|
|
9
|
+
activeClassName?: string;
|
|
10
|
+
inactiveClassName?: string;
|
|
11
|
+
children?: React.ReactNode;
|
|
12
|
+
}
|
|
13
|
+
export declare function Popup(props: PopupProps): JSX.Element;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Quantity } from '@medplum/fhirtypes';
|
|
3
|
+
export interface QuantityDisplayProps {
|
|
4
|
+
value?: Quantity;
|
|
5
|
+
}
|
|
6
|
+
export declare function QuantityDisplay(props: QuantityDisplayProps): JSX.Element | null;
|
|
7
|
+
export declare function formatQuantityString(quantity: Quantity | undefined): string;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Quantity } from '@medplum/fhirtypes';
|
|
3
|
+
export interface QuantityInputProps {
|
|
4
|
+
name: string;
|
|
5
|
+
defaultValue?: Quantity;
|
|
6
|
+
onChange?: (value: Quantity) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare function QuantityInput(props: QuantityInputProps): JSX.Element;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Questionnaire, Reference } from '@medplum/fhirtypes';
|
|
3
|
+
import './QuestionnaireBuilder.css';
|
|
4
|
+
export interface QuestionnaireBuilderProps {
|
|
5
|
+
questionnaire: Questionnaire | Reference<Questionnaire>;
|
|
6
|
+
onSubmit: (result: Questionnaire) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare function QuestionnaireBuilder(props: QuestionnaireBuilderProps): JSX.Element | null;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Questionnaire, QuestionnaireItem, QuestionnaireResponse, QuestionnaireResponseItem, Reference } from '@medplum/fhirtypes';
|
|
3
|
+
import './QuestionnaireForm.css';
|
|
4
|
+
export interface QuestionnaireFormProps {
|
|
5
|
+
questionnaire: Questionnaire | Reference<Questionnaire>;
|
|
6
|
+
subject?: Reference;
|
|
7
|
+
onSubmit: (response: QuestionnaireResponse) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function QuestionnaireForm(props: QuestionnaireFormProps): JSX.Element | null;
|
|
10
|
+
export interface QuestionnaireFormItemProps {
|
|
11
|
+
item: QuestionnaireItem;
|
|
12
|
+
onChange: (newResponseItem: QuestionnaireResponseItem) => void;
|
|
13
|
+
}
|
|
14
|
+
export declare function QuestionnaireFormItem(props: QuestionnaireFormItemProps): JSX.Element | null;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Questionnaire, QuestionnaireItem } from '@medplum/fhirtypes';
|
|
2
|
+
export declare enum QuestionnaireItemType {
|
|
3
|
+
group = "group",
|
|
4
|
+
display = "display",
|
|
5
|
+
question = "question",
|
|
6
|
+
boolean = "boolean",
|
|
7
|
+
decimal = "decimal",
|
|
8
|
+
integer = "integer",
|
|
9
|
+
date = "date",
|
|
10
|
+
dateTime = "dateTime",
|
|
11
|
+
time = "time",
|
|
12
|
+
string = "string",
|
|
13
|
+
text = "text",
|
|
14
|
+
url = "url",
|
|
15
|
+
choice = "choice",
|
|
16
|
+
openChoice = "open-choice",
|
|
17
|
+
attachment = "attachment",
|
|
18
|
+
reference = "reference",
|
|
19
|
+
quantity = "quantity"
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Adds initial values to a questionnaire resource from key value pairs.
|
|
23
|
+
* The values map uses "linkId" as key.
|
|
24
|
+
* The value depends on the questionnaire item type.
|
|
25
|
+
* @param questionnaire The original questionnaire.
|
|
26
|
+
* @param values Key value pairs for initial values.
|
|
27
|
+
* @returns Rewritten questionnaire with initial values.
|
|
28
|
+
*/
|
|
29
|
+
export declare function addQuestionnaireInitialValues(questionnaire: Questionnaire, values: Record<string, string>): Questionnaire;
|
|
30
|
+
export declare function isChoiceQuestion(item: QuestionnaireItem): boolean;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Range } from '@medplum/fhirtypes';
|
|
3
|
+
export interface RangeDisplayProps {
|
|
4
|
+
value?: Range;
|
|
5
|
+
}
|
|
6
|
+
export declare function RangeDisplay(props: RangeDisplayProps): JSX.Element | null;
|
|
7
|
+
export declare function formatRangeString(range: Range | undefined): string;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Range } from '@medplum/fhirtypes';
|
|
3
|
+
export interface RangeInputProps {
|
|
4
|
+
name: string;
|
|
5
|
+
defaultValue?: Range;
|
|
6
|
+
onChange?: (value: Range) => void;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Renders a Range input.
|
|
10
|
+
* See: https://www.hl7.org/fhir/datatypes.html#Range
|
|
11
|
+
* @param props Range input properties.
|
|
12
|
+
* @returns Range input element.
|
|
13
|
+
*/
|
|
14
|
+
export declare function RangeInput(props: RangeInputProps): JSX.Element;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Ratio } from '@medplum/fhirtypes';
|
|
3
|
+
export interface RatioInputProps {
|
|
4
|
+
name: string;
|
|
5
|
+
defaultValue?: Ratio;
|
|
6
|
+
onChange?: (value: Ratio) => void;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Renders a Ratio input.
|
|
10
|
+
* See: https://www.hl7.org/fhir/datatypes.html#Ratio
|
|
11
|
+
* @param props Ratio input properties.
|
|
12
|
+
* @returns Ratio input element.
|
|
13
|
+
*/
|
|
14
|
+
export declare function RatioInput(props: RatioInputProps): JSX.Element;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference } from '@medplum/fhirtypes';
|
|
3
|
+
export interface ReferenceInputProps {
|
|
4
|
+
name: string;
|
|
5
|
+
defaultValue?: Reference;
|
|
6
|
+
targetTypes?: string[];
|
|
7
|
+
onChange?: (value: Reference | undefined) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function ReferenceInput(props: ReferenceInputProps): JSX.Element;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './SignInForm.css';
|
|
3
|
+
import './util.css';
|
|
4
|
+
export interface BaseRegisterFormProps {
|
|
5
|
+
readonly googleClientId?: string;
|
|
6
|
+
readonly recaptchaSiteKey: string;
|
|
7
|
+
readonly children?: React.ReactNode;
|
|
8
|
+
readonly onSuccess: () => void;
|
|
9
|
+
}
|
|
10
|
+
export interface PatientRegisterFormProps extends BaseRegisterFormProps {
|
|
11
|
+
readonly type: 'patient';
|
|
12
|
+
readonly projectId: string;
|
|
13
|
+
}
|
|
14
|
+
export interface ProjectRegisterFormProps extends BaseRegisterFormProps {
|
|
15
|
+
readonly type: 'project';
|
|
16
|
+
}
|
|
17
|
+
export declare type RegisterFormProps = PatientRegisterFormProps | ProjectRegisterFormProps;
|
|
18
|
+
export declare function RegisterForm(props: RegisterFormProps): JSX.Element;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, RequestGroup, Task } from '@medplum/fhirtypes';
|
|
3
|
+
import './RequestGroupDisplay.css';
|
|
4
|
+
export interface RequestGroupDisplayProps {
|
|
5
|
+
value?: RequestGroup | Reference<RequestGroup>;
|
|
6
|
+
onStart: (task: Task, input: Reference) => void;
|
|
7
|
+
onEdit: (task: Task, input: Reference, output: Reference) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function RequestGroupDisplay(props: RequestGroupDisplayProps): JSX.Element | null;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ElementDefinition } from '@medplum/fhirtypes';
|
|
3
|
+
interface ResourceArrayDisplayProps {
|
|
4
|
+
property: ElementDefinition;
|
|
5
|
+
values: any[];
|
|
6
|
+
arrayElement?: boolean;
|
|
7
|
+
ignoreMissingValues?: boolean;
|
|
8
|
+
link?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare function ResourceArrayDisplay(props: ResourceArrayDisplayProps): JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ElementDefinition } from '@medplum/fhirtypes';
|
|
3
|
+
interface ResourceArrayInputProps {
|
|
4
|
+
property: ElementDefinition;
|
|
5
|
+
name: string;
|
|
6
|
+
defaultValue?: any[];
|
|
7
|
+
arrayElement?: boolean;
|
|
8
|
+
onChange?: (value: any[]) => void;
|
|
9
|
+
}
|
|
10
|
+
export declare function ResourceArrayInput(props: ResourceArrayInputProps): JSX.Element;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, Resource } from '@medplum/fhirtypes';
|
|
3
|
+
import './ResourceBadge.css';
|
|
4
|
+
export interface ResourceBadgeProps {
|
|
5
|
+
value?: Reference | Resource;
|
|
6
|
+
size?: 'xsmall' | 'small' | 'medium' | 'large';
|
|
7
|
+
link?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceBadge(props: ResourceBadgeProps): JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Bundle, ResourceType } from '@medplum/fhirtypes';
|
|
3
|
+
import './ResourceBlame.css';
|
|
4
|
+
export interface ResourceBlameProps {
|
|
5
|
+
history?: Bundle;
|
|
6
|
+
resourceType?: ResourceType;
|
|
7
|
+
id?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceBlame(props: ResourceBlameProps): JSX.Element;
|
|
10
|
+
export declare function getTimeString(lastUpdated: string): string;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Resource } from '@medplum/fhirtypes';
|
|
3
|
+
import './ResourceDiff.css';
|
|
4
|
+
export interface ResourceDiffProps {
|
|
5
|
+
original: Resource;
|
|
6
|
+
revised: Resource;
|
|
7
|
+
ignoreMeta?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceDiff(props: ResourceDiffProps): JSX.Element;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Resource } from '@medplum/fhirtypes';
|
|
3
|
+
import './ResourceDiff.css';
|
|
4
|
+
import './ResourceDiffTable.css';
|
|
5
|
+
export interface ResourceDiffTableProps {
|
|
6
|
+
original: Resource;
|
|
7
|
+
revised: Resource;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceDiffTable(props: ResourceDiffTableProps): JSX.Element | null;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ElementDefinition, OperationOutcome, Reference, Resource } from '@medplum/fhirtypes';
|
|
3
|
+
export interface ResourceFormProps {
|
|
4
|
+
defaultValue: Resource | Reference;
|
|
5
|
+
outcome?: OperationOutcome;
|
|
6
|
+
onSubmit: (resource: Resource) => void;
|
|
7
|
+
onDelete?: (resource: Resource) => void;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceForm(props: ResourceFormProps): JSX.Element;
|
|
10
|
+
export declare function setPropertyValue(obj: any, key: string, propName: string, elementDefinition: ElementDefinition, value: any): any;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Bundle } from '@medplum/fhirtypes';
|
|
3
|
+
import './Table.css';
|
|
4
|
+
export interface ResourceHistoryTableProps {
|
|
5
|
+
history?: Bundle;
|
|
6
|
+
resourceType?: string;
|
|
7
|
+
id?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function ResourceHistoryTable(props: ResourceHistoryTableProps): JSX.Element;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, Resource } from '@medplum/fhirtypes';
|
|
3
|
+
export interface ResourceInputProps<T extends Resource = Resource> {
|
|
4
|
+
readonly resourceType: string;
|
|
5
|
+
readonly name: string;
|
|
6
|
+
readonly defaultValue?: T | Reference<T>;
|
|
7
|
+
readonly className?: string;
|
|
8
|
+
readonly placeholder?: string;
|
|
9
|
+
readonly loadOnFocus?: boolean;
|
|
10
|
+
readonly onChange?: (value: T | undefined) => void;
|
|
11
|
+
}
|
|
12
|
+
export declare function ResourceInput<T extends Resource = Resource>(props: ResourceInputProps<T>): JSX.Element;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, Resource } from '@medplum/fhirtypes';
|
|
3
|
+
export interface ResourceNameProps {
|
|
4
|
+
value?: Reference | Resource;
|
|
5
|
+
link?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function ResourceName(props: ResourceNameProps): JSX.Element | null;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { PropertyType, TypedValue } from '@medplum/core';
|
|
3
|
+
import { ElementDefinition } from '@medplum/fhirtypes';
|
|
4
|
+
export interface ResourcePropertyDisplayProps {
|
|
5
|
+
property?: ElementDefinition;
|
|
6
|
+
propertyType: PropertyType;
|
|
7
|
+
value: any;
|
|
8
|
+
arrayElement?: boolean;
|
|
9
|
+
maxWidth?: number;
|
|
10
|
+
ignoreMissingValues?: boolean;
|
|
11
|
+
link?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare function ResourcePropertyDisplay(props: ResourcePropertyDisplayProps): JSX.Element;
|
|
14
|
+
/**
|
|
15
|
+
* Returns the value of the property and the property type.
|
|
16
|
+
* Some property definitions support multiple types.
|
|
17
|
+
* For example, "Observation.value[x]" can be "valueString", "valueInteger", "valueQuantity", etc.
|
|
18
|
+
* According to the spec, there can only be one property for a given element definition.
|
|
19
|
+
* This function returns the value and the type.
|
|
20
|
+
* @param context The base context (usually a FHIR resource).
|
|
21
|
+
* @param property The property definition.
|
|
22
|
+
* @returns The value of the property and the property type.
|
|
23
|
+
*/
|
|
24
|
+
export declare function getValueAndType(context: TypedValue, path: string): [any, PropertyType];
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { PropertyType } from '@medplum/core';
|
|
3
|
+
import { ElementDefinition, ElementDefinitionType, OperationOutcome } from '@medplum/fhirtypes';
|
|
4
|
+
export interface ResourcePropertyInputProps {
|
|
5
|
+
property: ElementDefinition;
|
|
6
|
+
name: string;
|
|
7
|
+
defaultPropertyType?: PropertyType;
|
|
8
|
+
defaultValue?: any;
|
|
9
|
+
arrayElement?: boolean;
|
|
10
|
+
onChange?: (value: any, propName?: string) => void;
|
|
11
|
+
outcome?: OperationOutcome;
|
|
12
|
+
}
|
|
13
|
+
export declare function ResourcePropertyInput(props: ResourcePropertyInputProps): JSX.Element;
|
|
14
|
+
export interface ElementDefinitionSelectorProps extends ResourcePropertyInputProps {
|
|
15
|
+
elementDefinitionTypes: ElementDefinitionType[];
|
|
16
|
+
}
|
|
17
|
+
export declare function ElementDefinitionInputSelector(props: ElementDefinitionSelectorProps): JSX.Element;
|
|
18
|
+
export interface ElementDefinitionTypeInputProps extends ResourcePropertyInputProps {
|
|
19
|
+
elementDefinitionType: ElementDefinitionType;
|
|
20
|
+
}
|
|
21
|
+
export declare function ElementDefinitionTypeInput(props: ElementDefinitionTypeInputProps): JSX.Element;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, Resource } from '@medplum/fhirtypes';
|
|
3
|
+
export interface ResourceTableProps {
|
|
4
|
+
value: Resource | Reference;
|
|
5
|
+
ignoreMissingValues?: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function ResourceTable(props: ResourceTableProps): JSX.Element | null;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ProfileResource } from '@medplum/core';
|
|
3
|
+
import { Attachment, Bundle, Communication, Media, Reference, Resource } from '@medplum/fhirtypes';
|
|
4
|
+
import './ResourceTimeline.css';
|
|
5
|
+
export interface ResourceTimelineProps<T extends Resource> {
|
|
6
|
+
value: T | Reference<T>;
|
|
7
|
+
buildSearchRequests: (resource: T) => Bundle;
|
|
8
|
+
createCommunication?: (resource: T, sender: ProfileResource, text: string) => Communication;
|
|
9
|
+
createMedia?: (resource: T, operator: ProfileResource, attachment: Attachment) => Media;
|
|
10
|
+
}
|
|
11
|
+
export declare function ResourceTimeline<T extends Resource>(props: ResourceTimelineProps<T>): JSX.Element;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Reference, Schedule } from '@medplum/fhirtypes';
|
|
3
|
+
import './Scheduler.css';
|
|
4
|
+
export interface SchedulerProps {
|
|
5
|
+
schedule: Schedule | Reference<Schedule>;
|
|
6
|
+
}
|
|
7
|
+
export declare function Scheduler(props: SchedulerProps): JSX.Element | null;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './Scrollable.css';
|
|
3
|
+
export interface ScrollableProps {
|
|
4
|
+
readonly role?: string;
|
|
5
|
+
readonly className?: string;
|
|
6
|
+
readonly height?: number;
|
|
7
|
+
readonly children: React.ReactNode;
|
|
8
|
+
}
|
|
9
|
+
export declare function Scrollable(props: ScrollableProps): JSX.Element;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { SearchRequest } from '@medplum/core';
|
|
2
|
+
import { Bundle, Resource, UserConfiguration } from '@medplum/fhirtypes';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import './SearchControl.css';
|
|
5
|
+
export declare class SearchChangeEvent extends Event {
|
|
6
|
+
readonly definition: SearchRequest;
|
|
7
|
+
constructor(definition: SearchRequest);
|
|
8
|
+
}
|
|
9
|
+
export declare class SearchLoadEvent extends Event {
|
|
10
|
+
readonly response: Bundle;
|
|
11
|
+
constructor(response: Bundle);
|
|
12
|
+
}
|
|
13
|
+
export declare class SearchClickEvent extends Event {
|
|
14
|
+
readonly resource: Resource;
|
|
15
|
+
readonly browserEvent: React.MouseEvent;
|
|
16
|
+
constructor(resource: Resource, browserEvent: React.MouseEvent);
|
|
17
|
+
}
|
|
18
|
+
export interface SearchControlProps {
|
|
19
|
+
search: SearchRequest;
|
|
20
|
+
userConfig?: UserConfiguration;
|
|
21
|
+
checkboxesEnabled?: boolean;
|
|
22
|
+
hideToolbar?: boolean;
|
|
23
|
+
hideFilters?: boolean;
|
|
24
|
+
onLoad?: (e: SearchLoadEvent) => void;
|
|
25
|
+
onChange?: (e: SearchChangeEvent) => void;
|
|
26
|
+
onClick?: (e: SearchClickEvent) => void;
|
|
27
|
+
onAuxClick?: (e: SearchClickEvent) => void;
|
|
28
|
+
onNew?: () => void;
|
|
29
|
+
onExport?: () => void;
|
|
30
|
+
onDelete?: (ids: string[]) => void;
|
|
31
|
+
onPatch?: (ids: string[]) => void;
|
|
32
|
+
onBulk?: (ids: string[]) => void;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* The SearchControl component represents the embeddable search table control.
|
|
36
|
+
* It includes the table, rows, headers, sorting, etc.
|
|
37
|
+
* It does not include the field editor, filter editor, pagination buttons.
|
|
38
|
+
*/
|
|
39
|
+
export declare function SearchControl(props: SearchControlProps): JSX.Element;
|
|
40
|
+
export declare const MemoizedSearchControl: React.MemoExoticComponent<typeof SearchControl>;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { IndexedStructureDefinition, SearchRequest } from '@medplum/core';
|
|
2
|
+
import { ElementDefinition, SearchParameter } from '@medplum/fhirtypes';
|
|
3
|
+
/**
|
|
4
|
+
* The SearchControlField type describes a field in the search control.
|
|
5
|
+
*
|
|
6
|
+
* In a SearchRequest, a field is a simple string. Strings can be one of the following:
|
|
7
|
+
* 1) Simple property names, which refer to ElementDefinition objects
|
|
8
|
+
* 2) Search parameter names, which refer to SearchParameter resources
|
|
9
|
+
*
|
|
10
|
+
* Consider a few examples of how this becomes complicated.
|
|
11
|
+
*
|
|
12
|
+
* "name" (easy)
|
|
13
|
+
* - element definition path="Patient.name"
|
|
14
|
+
* - search parameter code="name"
|
|
15
|
+
*
|
|
16
|
+
* "birthDate" (medium)
|
|
17
|
+
* - refers to the element definition path="Patient.birthDate"
|
|
18
|
+
* - refers to the search parameter code="birthdate" (note the capitalization)
|
|
19
|
+
*
|
|
20
|
+
* "email" (hard)
|
|
21
|
+
* - refers to the search parameter code="email"
|
|
22
|
+
* - refers to the element definition path="Patient.telecom"
|
|
23
|
+
*
|
|
24
|
+
* In the last case, we start with the search parameter, and walk backwards to the
|
|
25
|
+
* element definition in order to get type details for rendering.
|
|
26
|
+
*
|
|
27
|
+
* Overall, we want columns, fields, properties, and search parameters to feel seamless,
|
|
28
|
+
* so we try our darndest to make this work.
|
|
29
|
+
*/
|
|
30
|
+
export interface SearchControlField {
|
|
31
|
+
readonly name: string;
|
|
32
|
+
readonly elementDefinition?: ElementDefinition;
|
|
33
|
+
readonly searchParams?: SearchParameter[];
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Returns the collection of field definitions for the search request.
|
|
37
|
+
* @param typeSchema The schema for the resource type
|
|
38
|
+
* @param search The search request definition.
|
|
39
|
+
* @returns An array of field definitions.
|
|
40
|
+
*/
|
|
41
|
+
export declare function getFieldDefinitions(schema: IndexedStructureDefinition, search: SearchRequest): SearchControlField[];
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { IndexedStructureDefinition, SearchRequest } from '@medplum/core';
|
|
3
|
+
interface SearchFieldEditorProps {
|
|
4
|
+
schema: IndexedStructureDefinition;
|
|
5
|
+
visible: boolean;
|
|
6
|
+
search: SearchRequest;
|
|
7
|
+
onOk: (search: SearchRequest) => void;
|
|
8
|
+
onCancel: () => void;
|
|
9
|
+
}
|
|
10
|
+
export declare function SearchFieldEditor(props: SearchFieldEditorProps): JSX.Element | null;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { IndexedStructureDefinition, SearchRequest } from '@medplum/core';
|
|
3
|
+
import './SearchFilterEditor.css';
|
|
4
|
+
export interface SearchFilterEditorProps {
|
|
5
|
+
schema: IndexedStructureDefinition;
|
|
6
|
+
visible: boolean;
|
|
7
|
+
search: SearchRequest;
|
|
8
|
+
onOk: (search: SearchRequest) => void;
|
|
9
|
+
onCancel: () => void;
|
|
10
|
+
}
|
|
11
|
+
export declare function SearchFilterEditor(props: SearchFilterEditorProps): JSX.Element | null;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Filter, IndexedStructureDefinition } from '@medplum/core';
|
|
3
|
+
import { SearchParameter } from '@medplum/fhirtypes';
|
|
4
|
+
export interface SearchFilterValueDialogProps {
|
|
5
|
+
title: string;
|
|
6
|
+
visible: boolean;
|
|
7
|
+
schema: IndexedStructureDefinition;
|
|
8
|
+
resourceType: string;
|
|
9
|
+
searchParam?: SearchParameter;
|
|
10
|
+
filter?: Filter;
|
|
11
|
+
defaultValue?: string;
|
|
12
|
+
onOk: (filter: Filter) => void;
|
|
13
|
+
onCancel: () => void;
|
|
14
|
+
}
|
|
15
|
+
export declare function SearchFilterValueDialog(props: SearchFilterValueDialogProps): JSX.Element | null;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Filter } from '@medplum/core';
|
|
3
|
+
export interface SearchFilterValueDisplayProps {
|
|
4
|
+
readonly resourceType: string;
|
|
5
|
+
readonly filter: Filter;
|
|
6
|
+
}
|
|
7
|
+
export declare function SearchFilterValueDisplay(props: SearchFilterValueDisplayProps): JSX.Element | null;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { IndexedStructureDefinition } from '@medplum/core';
|
|
3
|
+
import { SearchParameter } from '@medplum/fhirtypes';
|
|
4
|
+
export interface SearchFilterValueInputProps {
|
|
5
|
+
schema: IndexedStructureDefinition;
|
|
6
|
+
resourceType: string;
|
|
7
|
+
searchParam: SearchParameter;
|
|
8
|
+
defaultValue?: string;
|
|
9
|
+
autoFocus?: boolean;
|
|
10
|
+
onChange: (value: string) => void;
|
|
11
|
+
}
|
|
12
|
+
export declare function SearchFilterValueInput(props: SearchFilterValueInputProps): JSX.Element | null;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { Filter, IndexedStructureDefinition, SearchRequest } from '@medplum/core';
|
|
3
|
+
import { SearchParameter } from '@medplum/fhirtypes';
|
|
4
|
+
export interface SearchPopupMenuProps {
|
|
5
|
+
schema: IndexedStructureDefinition;
|
|
6
|
+
search: SearchRequest;
|
|
7
|
+
visible: boolean;
|
|
8
|
+
x: number;
|
|
9
|
+
y: number;
|
|
10
|
+
searchParams?: SearchParameter[];
|
|
11
|
+
onPrompt: (searchParam: SearchParameter, filter: Filter) => void;
|
|
12
|
+
onChange: (definition: SearchRequest) => void;
|
|
13
|
+
onClose: () => void;
|
|
14
|
+
}
|
|
15
|
+
export declare function SearchPopupMenu(props: SearchPopupMenuProps): JSX.Element | null;
|