@medplum/react 0.9.24 → 0.9.27

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.
Files changed (408) hide show
  1. package/dist/cjs/index.js +24 -9
  2. package/dist/cjs/index.js.map +1 -1
  3. package/dist/cjs/index.min.js +1 -1
  4. package/dist/cjs/index.min.js.map +1 -1
  5. package/dist/{types → esm}/AddressDisplay.d.ts +0 -0
  6. package/dist/esm/AddressDisplay.js +13 -0
  7. package/dist/esm/AddressDisplay.js.map +1 -0
  8. package/dist/{types → esm}/AddressInput.d.ts +0 -0
  9. package/dist/esm/AddressInput.js +69 -0
  10. package/dist/esm/AddressInput.js.map +1 -0
  11. package/dist/{types → esm}/AnnotationInput.d.ts +0 -0
  12. package/dist/esm/AnnotationInput.js +28 -0
  13. package/dist/esm/AnnotationInput.js.map +1 -0
  14. package/dist/{types → esm}/AttachmentArrayDisplay.d.ts +0 -0
  15. package/dist/esm/AttachmentArrayDisplay.js +11 -0
  16. package/dist/esm/AttachmentArrayDisplay.js.map +1 -0
  17. package/dist/{types → esm}/AttachmentArrayInput.d.ts +0 -0
  18. package/dist/esm/AttachmentArrayInput.js +42 -0
  19. package/dist/esm/AttachmentArrayInput.js.map +1 -0
  20. package/dist/{types → esm}/AttachmentDisplay.d.ts +0 -0
  21. package/dist/esm/AttachmentDisplay.js +20 -0
  22. package/dist/esm/AttachmentDisplay.js.map +1 -0
  23. package/dist/{types → esm}/AttachmentInput.d.ts +0 -0
  24. package/dist/esm/AttachmentInput.js +27 -0
  25. package/dist/esm/AttachmentInput.js.map +1 -0
  26. package/dist/{types → esm}/Autocomplete.d.ts +0 -0
  27. package/dist/esm/Autocomplete.js +284 -0
  28. package/dist/esm/Autocomplete.js.map +1 -0
  29. package/dist/{types → esm}/Avatar.d.ts +0 -0
  30. package/dist/esm/Avatar.js +24 -0
  31. package/dist/esm/Avatar.js.map +1 -0
  32. package/dist/{types → esm}/BackboneElementDisplay.d.ts +0 -0
  33. package/dist/esm/BackboneElementDisplay.js +43 -0
  34. package/dist/esm/BackboneElementDisplay.js.map +1 -0
  35. package/dist/{types → esm}/BackboneElementInput.d.ts +0 -0
  36. package/dist/esm/BackboneElementInput.js +51 -0
  37. package/dist/esm/BackboneElementInput.js.map +1 -0
  38. package/dist/{types → esm}/Button.d.ts +0 -0
  39. package/dist/esm/Button.js +13 -0
  40. package/dist/esm/Button.js.map +1 -0
  41. package/dist/{types → esm}/CalendarInput.d.ts +0 -0
  42. package/dist/esm/CalendarInput.js +96 -0
  43. package/dist/esm/CalendarInput.js.map +1 -0
  44. package/dist/{types → esm}/Checkbox.d.ts +0 -0
  45. package/dist/esm/Checkbox.js +13 -0
  46. package/dist/esm/Checkbox.js.map +1 -0
  47. package/dist/{types → esm}/CheckboxFormSection.d.ts +0 -0
  48. package/dist/esm/CheckboxFormSection.js +12 -0
  49. package/dist/esm/CheckboxFormSection.js.map +1 -0
  50. package/dist/{types → esm}/CodeInput.d.ts +0 -0
  51. package/dist/esm/CodeInput.js +28 -0
  52. package/dist/esm/CodeInput.js.map +1 -0
  53. package/dist/{types → esm}/CodeableConceptDisplay.d.ts +0 -0
  54. package/dist/esm/CodeableConceptDisplay.js +19 -0
  55. package/dist/esm/CodeableConceptDisplay.js.map +1 -0
  56. package/dist/{types → esm}/CodeableConceptInput.d.ts +0 -0
  57. package/dist/esm/CodeableConceptInput.js +52 -0
  58. package/dist/esm/CodeableConceptInput.js.map +1 -0
  59. package/dist/{types → esm}/CodingDisplay.d.ts +0 -0
  60. package/dist/esm/CodingDisplay.js +9 -0
  61. package/dist/esm/CodingDisplay.js.map +1 -0
  62. package/dist/{types → esm}/CodingInput.d.ts +0 -0
  63. package/dist/esm/CodingInput.js +30 -0
  64. package/dist/esm/CodingInput.js.map +1 -0
  65. package/dist/{types → esm}/ContactDetailDisplay.d.ts +0 -0
  66. package/dist/esm/ContactDetailDisplay.js +17 -0
  67. package/dist/esm/ContactDetailDisplay.js.map +1 -0
  68. package/dist/{types → esm}/ContactDetailInput.d.ts +0 -0
  69. package/dist/esm/ContactDetailInput.js +37 -0
  70. package/dist/esm/ContactDetailInput.js.map +1 -0
  71. package/dist/{types → esm}/ContactPointDisplay.d.ts +0 -0
  72. package/dist/esm/ContactPointDisplay.js +29 -0
  73. package/dist/esm/ContactPointDisplay.js.map +1 -0
  74. package/dist/{types → esm}/ContactPointInput.d.ts +0 -0
  75. package/dist/esm/ContactPointInput.js +60 -0
  76. package/dist/esm/ContactPointInput.js.map +1 -0
  77. package/dist/{types → esm}/DateTimeDisplay.d.ts +0 -0
  78. package/dist/esm/DateTimeDisplay.js +11 -0
  79. package/dist/esm/DateTimeDisplay.js.map +1 -0
  80. package/dist/{types → esm}/DateTimeInput.d.ts +0 -0
  81. package/dist/esm/DateTimeInput.js +62 -0
  82. package/dist/esm/DateTimeInput.js.map +1 -0
  83. package/dist/{types → esm}/DefaultResourceTimeline.d.ts +0 -0
  84. package/dist/esm/DefaultResourceTimeline.js +27 -0
  85. package/dist/esm/DefaultResourceTimeline.js.map +1 -0
  86. package/dist/{types → esm}/DescriptionList.d.ts +0 -0
  87. package/dist/esm/DescriptionList.js +13 -0
  88. package/dist/esm/DescriptionList.js.map +1 -0
  89. package/dist/{types → esm}/DiagnosticReportDisplay.d.ts +0 -0
  90. package/dist/esm/DiagnosticReportDisplay.js +103 -0
  91. package/dist/esm/DiagnosticReportDisplay.js.map +1 -0
  92. package/dist/{types → esm}/Dialog.d.ts +0 -0
  93. package/dist/esm/Dialog.js +43 -0
  94. package/dist/esm/Dialog.js.map +1 -0
  95. package/dist/{types → esm}/Document.d.ts +0 -0
  96. package/dist/esm/Document.js +9 -0
  97. package/dist/esm/Document.js.map +1 -0
  98. package/dist/{types → esm}/EncounterTimeline.d.ts +0 -0
  99. package/dist/esm/EncounterTimeline.js +47 -0
  100. package/dist/esm/EncounterTimeline.js.map +1 -0
  101. package/dist/{types → esm}/ErrorBoundary.d.ts +0 -0
  102. package/dist/esm/ErrorBoundary.js +27 -0
  103. package/dist/esm/ErrorBoundary.js.map +1 -0
  104. package/dist/{types → esm}/ExtensionInput.d.ts +0 -0
  105. package/dist/esm/ExtensionInput.js +14 -0
  106. package/dist/esm/ExtensionInput.js.map +1 -0
  107. package/dist/{types → esm}/FhirPathDisplay.d.ts +0 -0
  108. package/dist/esm/FhirPathDisplay.js +23 -0
  109. package/dist/esm/FhirPathDisplay.js.map +1 -0
  110. package/dist/{types → esm}/FhirPathTable.d.ts +0 -0
  111. package/dist/esm/FhirPathTable.js +117 -0
  112. package/dist/esm/FhirPathTable.js.map +1 -0
  113. package/dist/{types → esm}/FooterLinks.d.ts +0 -0
  114. package/dist/esm/FooterLinks.js +8 -0
  115. package/dist/esm/FooterLinks.js.map +1 -0
  116. package/dist/{types → esm}/Form.d.ts +0 -0
  117. package/dist/esm/Form.js +15 -0
  118. package/dist/esm/Form.js.map +1 -0
  119. package/dist/{types → esm}/FormSection.d.ts +0 -0
  120. package/dist/esm/FormSection.js +18 -0
  121. package/dist/esm/FormSection.js.map +1 -0
  122. package/dist/{types → esm}/FormUtils.d.ts +0 -0
  123. package/dist/esm/FormUtils.js +49 -0
  124. package/dist/esm/FormUtils.js.map +1 -0
  125. package/dist/{types → esm}/GoogleButton.d.ts +0 -0
  126. package/dist/esm/GoogleButton.js +48 -0
  127. package/dist/esm/GoogleButton.js.map +1 -0
  128. package/dist/{types → esm}/Header.d.ts +0 -0
  129. package/dist/esm/Header.js +95 -0
  130. package/dist/esm/Header.js.map +1 -0
  131. package/dist/{types → esm}/HeaderSearchInput.d.ts +0 -0
  132. package/dist/esm/HeaderSearchInput.js +181 -0
  133. package/dist/esm/HeaderSearchInput.js.map +1 -0
  134. package/dist/{types → esm}/HumanNameDisplay.d.ts +0 -0
  135. package/dist/esm/HumanNameDisplay.js +13 -0
  136. package/dist/esm/HumanNameDisplay.js.map +1 -0
  137. package/dist/{types → esm}/HumanNameInput.d.ts +0 -0
  138. package/dist/esm/HumanNameInput.js +49 -0
  139. package/dist/esm/HumanNameInput.js.map +1 -0
  140. package/dist/{types → esm}/IdentifierDisplay.d.ts +0 -0
  141. package/dist/esm/IdentifierDisplay.js +12 -0
  142. package/dist/esm/IdentifierDisplay.js.map +1 -0
  143. package/dist/{types → esm}/IdentifierInput.d.ts +0 -0
  144. package/dist/esm/IdentifierInput.js +19 -0
  145. package/dist/esm/IdentifierInput.js.map +1 -0
  146. package/dist/{types → esm}/Input.d.ts +0 -0
  147. package/dist/esm/Input.js +26 -0
  148. package/dist/esm/Input.js.map +1 -0
  149. package/dist/{types → esm}/InputRow.d.ts +0 -0
  150. package/dist/esm/InputRow.js +8 -0
  151. package/dist/esm/InputRow.js.map +1 -0
  152. package/dist/{types → esm}/Loading.d.ts +0 -0
  153. package/dist/esm/Loading.js +11 -0
  154. package/dist/esm/Loading.js.map +1 -0
  155. package/dist/{types → esm}/Logo.d.ts +0 -0
  156. package/dist/esm/Logo.js +14 -0
  157. package/dist/esm/Logo.js.map +1 -0
  158. package/dist/{types → esm}/MedplumLink.d.ts +0 -0
  159. package/dist/esm/MedplumLink.js +34 -0
  160. package/dist/esm/MedplumLink.js.map +1 -0
  161. package/dist/{types → esm}/MedplumProvider.d.ts +0 -0
  162. package/dist/esm/MedplumProvider.js +50 -0
  163. package/dist/esm/MedplumProvider.js.map +1 -0
  164. package/dist/{types → esm}/MenuItem.d.ts +0 -0
  165. package/dist/esm/MenuItem.js +8 -0
  166. package/dist/esm/MenuItem.js.map +1 -0
  167. package/dist/{types → esm}/MenuSeparator.d.ts +0 -0
  168. package/dist/esm/MenuSeparator.js +8 -0
  169. package/dist/esm/MenuSeparator.js.map +1 -0
  170. package/dist/{types → esm}/PatientTimeline.d.ts +0 -0
  171. package/dist/esm/PatientTimeline.js +40 -0
  172. package/dist/esm/PatientTimeline.js.map +1 -0
  173. package/dist/{types → esm}/PeriodDisplay.d.ts +0 -0
  174. package/dist/esm/PeriodDisplay.js +16 -0
  175. package/dist/esm/PeriodDisplay.js.map +1 -0
  176. package/dist/{types → esm}/PeriodInput.d.ts +0 -0
  177. package/dist/esm/PeriodInput.js +19 -0
  178. package/dist/esm/PeriodInput.js.map +1 -0
  179. package/dist/{types → esm}/PlanDefinitionBuilder.d.ts +0 -0
  180. package/dist/esm/PlanDefinitionBuilder.js +155 -0
  181. package/dist/esm/PlanDefinitionBuilder.js.map +1 -0
  182. package/dist/{types → esm}/Popup.d.ts +0 -0
  183. package/dist/esm/Popup.js +64 -0
  184. package/dist/esm/Popup.js.map +1 -0
  185. package/dist/{types → esm}/QuantityDisplay.d.ts +0 -0
  186. package/dist/esm/QuantityDisplay.js +28 -0
  187. package/dist/esm/QuantityDisplay.js.map +1 -0
  188. package/dist/{types → esm}/QuantityInput.d.ts +0 -0
  189. package/dist/esm/QuantityInput.js +33 -0
  190. package/dist/esm/QuantityInput.js.map +1 -0
  191. package/dist/{types → esm}/QuestionnaireBuilder.d.ts +0 -0
  192. package/dist/esm/QuestionnaireBuilder.js +217 -0
  193. package/dist/esm/QuestionnaireBuilder.js.map +1 -0
  194. package/dist/{types → esm}/QuestionnaireForm.d.ts +0 -0
  195. package/dist/esm/QuestionnaireForm.js +215 -0
  196. package/dist/esm/QuestionnaireForm.js.map +1 -0
  197. package/dist/{types → esm}/QuestionnaireUtils.d.ts +0 -0
  198. package/dist/esm/QuestionnaireUtils.js +103 -0
  199. package/dist/esm/QuestionnaireUtils.js.map +1 -0
  200. package/dist/{types → esm}/RangeDisplay.d.ts +0 -0
  201. package/dist/esm/RangeDisplay.js +21 -0
  202. package/dist/esm/RangeDisplay.js.map +1 -0
  203. package/dist/{types → esm}/RangeInput.d.ts +0 -0
  204. package/dist/esm/RangeInput.js +25 -0
  205. package/dist/esm/RangeInput.js.map +1 -0
  206. package/dist/{types → esm}/RatioDisplay.d.ts +0 -0
  207. package/dist/esm/RatioDisplay.js +16 -0
  208. package/dist/esm/RatioDisplay.js.map +1 -0
  209. package/dist/{types → esm}/RatioInput.d.ts +0 -0
  210. package/dist/esm/RatioInput.js +25 -0
  211. package/dist/esm/RatioInput.js.map +1 -0
  212. package/dist/{types → esm}/ReferenceDisplay.d.ts +0 -0
  213. package/dist/esm/ReferenceDisplay.js +21 -0
  214. package/dist/esm/ReferenceDisplay.js.map +1 -0
  215. package/dist/{types → esm}/ReferenceInput.d.ts +0 -0
  216. package/dist/esm/ReferenceInput.js +42 -0
  217. package/dist/esm/ReferenceInput.js.map +1 -0
  218. package/dist/{types → esm}/RegisterForm.d.ts +1 -0
  219. package/dist/esm/RegisterForm.js +121 -0
  220. package/dist/esm/RegisterForm.js.map +1 -0
  221. package/dist/{types → esm}/RequestGroupDisplay.d.ts +0 -0
  222. package/dist/esm/RequestGroupDisplay.js +73 -0
  223. package/dist/esm/RequestGroupDisplay.js.map +1 -0
  224. package/dist/{types → esm}/ResourceArrayDisplay.d.ts +0 -0
  225. package/dist/esm/ResourceArrayDisplay.js +14 -0
  226. package/dist/esm/ResourceArrayDisplay.js.map +1 -0
  227. package/dist/{types → esm}/ResourceArrayInput.d.ts +0 -0
  228. package/dist/esm/ResourceArrayInput.js +48 -0
  229. package/dist/esm/ResourceArrayInput.js.map +1 -0
  230. package/dist/{types → esm}/ResourceBadge.d.ts +0 -0
  231. package/dist/esm/ResourceBadge.js +13 -0
  232. package/dist/esm/ResourceBadge.js.map +1 -0
  233. package/dist/{types → esm}/ResourceBlame.d.ts +0 -0
  234. package/dist/esm/ResourceBlame.js +65 -0
  235. package/dist/esm/ResourceBlame.js.map +1 -0
  236. package/dist/{types → esm}/ResourceDiff.d.ts +0 -0
  237. package/dist/esm/ResourceDiff.js +28 -0
  238. package/dist/esm/ResourceDiff.js.map +1 -0
  239. package/dist/{types → esm}/ResourceDiffTable.d.ts +0 -0
  240. package/dist/esm/ResourceDiffTable.js +58 -0
  241. package/dist/esm/ResourceDiffTable.js.map +1 -0
  242. package/dist/{types → esm}/ResourceForm.d.ts +0 -0
  243. package/dist/esm/ResourceForm.js +55 -0
  244. package/dist/esm/ResourceForm.js.map +1 -0
  245. package/dist/{types → esm}/ResourceHistoryTable.d.ts +0 -0
  246. package/dist/esm/ResourceHistoryTable.js +46 -0
  247. package/dist/esm/ResourceHistoryTable.js.map +1 -0
  248. package/dist/{types → esm}/ResourceInput.d.ts +0 -0
  249. package/dist/esm/ResourceInput.js +40 -0
  250. package/dist/esm/ResourceInput.js.map +1 -0
  251. package/dist/{types → esm}/ResourceName.d.ts +0 -0
  252. package/dist/esm/ResourceName.js +16 -0
  253. package/dist/esm/ResourceName.js.map +1 -0
  254. package/dist/{types → esm}/ResourcePropertyDisplay.d.ts +0 -0
  255. package/dist/esm/ResourcePropertyDisplay.js +107 -0
  256. package/dist/esm/ResourcePropertyDisplay.js.map +1 -0
  257. package/dist/{types → esm}/ResourcePropertyInput.d.ts +0 -0
  258. package/dist/esm/ResourcePropertyInput.js +151 -0
  259. package/dist/esm/ResourcePropertyInput.js.map +1 -0
  260. package/dist/{types → esm}/ResourceTable.d.ts +0 -0
  261. package/dist/esm/ResourceTable.js +22 -0
  262. package/dist/esm/ResourceTable.js.map +1 -0
  263. package/dist/{types → esm}/ResourceTimeline.d.ts +0 -0
  264. package/dist/esm/ResourceTimeline.js +221 -0
  265. package/dist/esm/ResourceTimeline.js.map +1 -0
  266. package/dist/{types → esm}/Scheduler.d.ts +0 -0
  267. package/dist/esm/Scheduler.js +82 -0
  268. package/dist/esm/Scheduler.js.map +1 -0
  269. package/dist/{types → esm}/Scrollable.d.ts +0 -0
  270. package/dist/esm/Scrollable.js +12 -0
  271. package/dist/esm/Scrollable.js.map +1 -0
  272. package/dist/{types → esm}/SearchControl.d.ts +0 -0
  273. package/dist/esm/SearchControl.js +268 -0
  274. package/dist/esm/SearchControl.js.map +1 -0
  275. package/dist/{types → esm}/SearchControlField.d.ts +0 -0
  276. package/dist/esm/SearchControlField.js +98 -0
  277. package/dist/esm/SearchControlField.js.map +1 -0
  278. package/dist/{types → esm}/SearchFieldEditor.d.ts +0 -0
  279. package/dist/esm/SearchFieldEditor.js +192 -0
  280. package/dist/esm/SearchFieldEditor.js.map +1 -0
  281. package/dist/{types → esm}/SearchFilterEditor.d.ts +0 -0
  282. package/dist/esm/SearchFilterEditor.js +103 -0
  283. package/dist/esm/SearchFilterEditor.js.map +1 -0
  284. package/dist/{types → esm}/SearchFilterValueDialog.d.ts +0 -0
  285. package/dist/esm/SearchFilterValueDialog.js +22 -0
  286. package/dist/esm/SearchFilterValueDialog.js.map +1 -0
  287. package/dist/{types → esm}/SearchFilterValueDisplay.d.ts +0 -0
  288. package/dist/esm/SearchFilterValueDisplay.js +22 -0
  289. package/dist/esm/SearchFilterValueDisplay.js.map +1 -0
  290. package/dist/{types → esm}/SearchFilterValueInput.d.ts +0 -0
  291. package/dist/esm/SearchFilterValueInput.js +59 -0
  292. package/dist/esm/SearchFilterValueInput.js.map +1 -0
  293. package/dist/{types → esm}/SearchPopupMenu.d.ts +0 -0
  294. package/dist/esm/SearchPopupMenu.js +135 -0
  295. package/dist/esm/SearchPopupMenu.js.map +1 -0
  296. package/dist/{types → esm}/SearchUtils.d.ts +0 -0
  297. package/dist/esm/SearchUtils.js +488 -0
  298. package/dist/esm/SearchUtils.js.map +1 -0
  299. package/dist/{types → esm}/Select.d.ts +0 -0
  300. package/dist/esm/Select.js +16 -0
  301. package/dist/esm/Select.js.map +1 -0
  302. package/dist/{types → esm}/ServiceRequestTimeline.d.ts +0 -0
  303. package/dist/esm/ServiceRequestTimeline.js +53 -0
  304. package/dist/esm/ServiceRequestTimeline.js.map +1 -0
  305. package/dist/{types → esm}/SignInForm.d.ts +0 -0
  306. package/dist/esm/SignInForm.js +130 -0
  307. package/dist/esm/SignInForm.js.map +1 -0
  308. package/dist/{types → esm}/StatusBadge.d.ts +0 -0
  309. package/dist/esm/StatusBadge.js +8 -0
  310. package/dist/esm/StatusBadge.js.map +1 -0
  311. package/dist/{types → esm}/SubMenu.d.ts +0 -0
  312. package/dist/esm/SubMenu.js +38 -0
  313. package/dist/esm/SubMenu.js.map +1 -0
  314. package/dist/{types → esm}/Tab.d.ts +0 -0
  315. package/dist/esm/Tab.js +19 -0
  316. package/dist/esm/Tab.js.map +1 -0
  317. package/dist/{types → esm}/TabList.d.ts +0 -0
  318. package/dist/esm/TabList.js +23 -0
  319. package/dist/esm/TabList.js.map +1 -0
  320. package/dist/{types → esm}/TabPanel.d.ts +0 -0
  321. package/dist/esm/TabPanel.js +8 -0
  322. package/dist/esm/TabPanel.js.map +1 -0
  323. package/dist/{types → esm}/TabSwitch.d.ts +0 -0
  324. package/dist/esm/TabSwitch.js +16 -0
  325. package/dist/esm/TabSwitch.js.map +1 -0
  326. package/dist/{types → esm}/TextArea.d.ts +0 -0
  327. package/dist/esm/TextArea.js +16 -0
  328. package/dist/esm/TextArea.js.map +1 -0
  329. package/dist/{types → esm}/Timeline.d.ts +0 -0
  330. package/dist/esm/Timeline.js +50 -0
  331. package/dist/esm/Timeline.js.map +1 -0
  332. package/dist/{types → esm}/TitleBar.d.ts +0 -0
  333. package/dist/esm/TitleBar.js +8 -0
  334. package/dist/esm/TitleBar.js.map +1 -0
  335. package/dist/{types → esm}/UploadButton.d.ts +0 -0
  336. package/dist/esm/UploadButton.js +55 -0
  337. package/dist/esm/UploadButton.js.map +1 -0
  338. package/dist/{types → esm}/constants.d.ts +0 -0
  339. package/dist/esm/constants.js +12 -0
  340. package/dist/esm/constants.js.map +1 -0
  341. package/dist/{types → esm}/index.d.ts +1 -0
  342. package/dist/esm/index.js +87 -5811
  343. package/dist/esm/index.js.map +1 -1
  344. package/dist/esm/index.min.js +1 -1
  345. package/dist/esm/index.min.js.map +1 -1
  346. package/dist/esm/node_modules/tslib/tslib.es6.js +27 -0
  347. package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -0
  348. package/dist/{types → esm}/stories/AddressInput.stories.d.ts +0 -0
  349. package/dist/{types → esm}/stories/AttachmentArrayInput.stories.d.ts +0 -0
  350. package/dist/{types → esm}/stories/AttachmentInput.stories.d.ts +0 -0
  351. package/dist/{types → esm}/stories/Autocomplete.stories.d.ts +0 -0
  352. package/dist/{types → esm}/stories/Avatar.stories.d.ts +0 -0
  353. package/dist/{types → esm}/stories/Button.stories.d.ts +0 -0
  354. package/dist/{types → esm}/stories/DiagnosticReportDisplay.stories.d.ts +0 -0
  355. package/dist/{types → esm}/stories/Dialog.stories.d.ts +0 -0
  356. package/dist/{types → esm}/stories/EncounterTimeline.stories.d.ts +0 -0
  357. package/dist/{types → esm}/stories/FhirPathDisplay.stories.d.ts +0 -0
  358. package/dist/{types → esm}/stories/FormSection.stories.d.ts +0 -0
  359. package/dist/{types → esm}/stories/Header.stories.d.ts +0 -0
  360. package/dist/{types → esm}/stories/Input.stories.d.ts +0 -0
  361. package/dist/{types → esm}/stories/Loading.stories.d.ts +0 -0
  362. package/dist/{types → esm}/stories/Logo.stories.d.ts +0 -0
  363. package/dist/{types → esm}/stories/PatientTimeline.stories.d.ts +0 -0
  364. package/dist/{types → esm}/stories/PlanDefinitionBuilder.stories.d.ts +0 -0
  365. package/dist/{types → esm}/stories/QuestionnaireBuilder.stories.d.ts +0 -0
  366. package/dist/{types → esm}/stories/QuestionnaireForm.stories.d.ts +0 -0
  367. package/dist/{types → esm}/stories/ReferenceInput.stories.d.ts +0 -0
  368. package/dist/{types → esm}/stories/RegisterForm.stories.d.ts +0 -0
  369. package/dist/{types → esm}/stories/RequestGroupDisplay.stories.d.ts +0 -0
  370. package/dist/{types → esm}/stories/ResourceBlame.stories.d.ts +0 -0
  371. package/dist/{types → esm}/stories/ResourceForm.stories.d.ts +0 -0
  372. package/dist/{types → esm}/stories/ResourceHistoryTable.stories.d.ts +0 -0
  373. package/dist/{types → esm}/stories/ResourceTable.stories.d.ts +0 -0
  374. package/dist/{types → esm}/stories/Scheduler.stories.d.ts +0 -0
  375. package/dist/{types → esm}/stories/SearchControl.stories.d.ts +0 -0
  376. package/dist/{types → esm}/stories/Select.stories.d.ts +0 -0
  377. package/dist/{types → esm}/stories/SignInForm.stories.d.ts +0 -0
  378. package/dist/{types → esm}/stories/StatusBadge.stories.d.ts +0 -0
  379. package/dist/{types → esm}/stories/Tabs.stories.d.ts +0 -0
  380. package/dist/{types → esm}/stories/Timeline.stories.d.ts +0 -0
  381. package/dist/{types → esm}/stories/UploadButton.stories.d.ts +0 -0
  382. package/dist/{types → esm}/test.setup.d.ts +0 -0
  383. package/dist/{types → esm}/useResource.d.ts +0 -0
  384. package/dist/esm/useResource.js +65 -0
  385. package/dist/esm/useResource.js.map +1 -0
  386. package/dist/{types → esm}/utils/blame.d.ts +0 -0
  387. package/dist/esm/utils/blame.js +74 -0
  388. package/dist/esm/utils/blame.js.map +1 -0
  389. package/dist/{types → esm}/utils/date.d.ts +0 -0
  390. package/dist/esm/utils/date.js +48 -0
  391. package/dist/esm/utils/date.js.map +1 -0
  392. package/dist/{types → esm}/utils/diff.d.ts +0 -0
  393. package/dist/esm/utils/diff.js +118 -0
  394. package/dist/esm/utils/diff.js.map +1 -0
  395. package/dist/{types → esm}/utils/dom.d.ts +0 -0
  396. package/dist/esm/utils/dom.js +34 -0
  397. package/dist/esm/utils/dom.js.map +1 -0
  398. package/dist/{types → esm}/utils/outcomes.d.ts +0 -0
  399. package/dist/esm/utils/outcomes.js +7 -0
  400. package/dist/esm/utils/outcomes.js.map +1 -0
  401. package/dist/esm/utils/recaptcha.d.ts +12 -0
  402. package/dist/esm/utils/recaptcha.js +27 -0
  403. package/dist/esm/utils/recaptcha.js.map +1 -0
  404. package/dist/{types → esm}/utils.d.ts +0 -0
  405. package/dist/esm/utils.js +15 -0
  406. package/dist/esm/utils.js.map +1 -0
  407. package/package.json +11 -11
  408. package/dist/types/utils/recaptcha.d.ts +0 -10
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PatientTimeline.js","sources":["../../src/PatientTimeline.tsx"],"sourcesContent":["import { createReference, getReferenceString, ProfileResource } from '@medplum/core';\nimport { Attachment, Patient, Reference, Resource } from '@medplum/fhirtypes';\nimport React from 'react';\nimport { ResourceTimeline } from './ResourceTimeline';\n\nexport interface PatientTimelineProps {\n patient: Patient | Reference<Patient>;\n}\n\nconst searches = [\n '$/_history',\n 'Communication?subject=$',\n 'Device?patient=$',\n 'DeviceRequest?patient=$',\n 'DiagnosticReport?subject=$',\n 'Media?subject=$',\n 'ServiceRequest?subject=$',\n];\n\nexport function PatientTimeline(props: PatientTimelineProps): JSX.Element {\n return (\n <ResourceTimeline\n value={props.patient}\n buildSearchRequests={(resource: Resource) => ({\n resourceType: 'Bundle',\n type: 'batch',\n entry: searches.map((search) => ({\n request: {\n method: 'GET',\n url: search.replaceAll('$', getReferenceString(resource)),\n },\n })),\n })}\n createCommunication={(resource: Patient, sender: ProfileResource, text: string) => ({\n resourceType: 'Communication',\n subject: createReference(resource),\n sender: createReference(sender),\n sent: new Date().toISOString(),\n payload: [{ contentString: text }],\n })}\n createMedia={(resource: Patient, operator: ProfileResource, content: Attachment) => ({\n resourceType: 'Media',\n subject: createReference(resource),\n operator: createReference(operator),\n issued: new Date().toISOString(),\n content,\n })}\n />\n );\n}\n"],"names":[],"mappings":";;;;AASA,MAAM,QAAQ,GAAG;IACf,YAAY;IACZ,yBAAyB;IACzB,kBAAkB;IAClB,yBAAyB;IACzB,4BAA4B;IAC5B,iBAAiB;IACjB,0BAA0B;CAC3B,CAAC;AAEI,SAAU,eAAe,CAAC,KAA2B,EAAA;AACzD,IAAA,QACE,KAAC,CAAA,aAAA,CAAA,gBAAgB,EACf,EAAA,KAAK,EAAE,KAAK,CAAC,OAAO,EACpB,mBAAmB,EAAE,CAAC,QAAkB,MAAM;AAC5C,YAAA,YAAY,EAAE,QAAQ;AACtB,YAAA,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,MAAM,MAAM;AAC/B,gBAAA,OAAO,EAAE;AACP,oBAAA,MAAM,EAAE,KAAK;oBACb,GAAG,EAAE,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC,QAAQ,CAAC,CAAC;AAC1D,iBAAA;AACF,aAAA,CAAC,CAAC;AACJ,SAAA,CAAC,EACF,mBAAmB,EAAE,CAAC,QAAiB,EAAE,MAAuB,EAAE,IAAY,MAAM;AAClF,YAAA,YAAY,EAAE,eAAe;AAC7B,YAAA,OAAO,EAAE,eAAe,CAAC,QAAQ,CAAC;AAClC,YAAA,MAAM,EAAE,eAAe,CAAC,MAAM,CAAC;AAC/B,YAAA,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;AAC9B,YAAA,OAAO,EAAE,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;AACnC,SAAA,CAAC,EACF,WAAW,EAAE,CAAC,QAAiB,EAAE,QAAyB,EAAE,OAAmB,MAAM;AACnF,YAAA,YAAY,EAAE,OAAO;AACrB,YAAA,OAAO,EAAE,eAAe,CAAC,QAAQ,CAAC;AAClC,YAAA,QAAQ,EAAE,eAAe,CAAC,QAAQ,CAAC;AACnC,YAAA,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YAChC,OAAO;SACR,CAAC,EAAA,CACF,EACF;AACJ;;;;"}
File without changes
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { DateTimeDisplay } from './DateTimeDisplay.js';
3
+
4
+ function PeriodDisplay(props) {
5
+ const value = props.value;
6
+ if (!value || (!value.start && !value.end)) {
7
+ return null;
8
+ }
9
+ return (React.createElement("span", null,
10
+ React.createElement(DateTimeDisplay, { value: value.start }),
11
+ "-",
12
+ React.createElement(DateTimeDisplay, { value: value.end })));
13
+ }
14
+
15
+ export { PeriodDisplay };
16
+ //# sourceMappingURL=PeriodDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeriodDisplay.js","sources":["../../src/PeriodDisplay.tsx"],"sourcesContent":["import { Period } from '@medplum/fhirtypes';\nimport React from 'react';\nimport { DateTimeDisplay } from './DateTimeDisplay';\n\nexport interface PeriodDisplayProps {\n value?: Period;\n}\n\nexport function PeriodDisplay(props: PeriodDisplayProps): JSX.Element | null {\n const value = props.value;\n if (!value || (!value.start && !value.end)) {\n return null;\n }\n\n return (\n <span>\n <DateTimeDisplay value={value.start} />\n -\n <DateTimeDisplay value={value.end} />\n </span>\n );\n}\n"],"names":[],"mappings":";;;AAQM,SAAU,aAAa,CAAC,KAAyB,EAAA;AACrD,IAAA,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;AAC1B,IAAA,IAAI,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;AAC1C,QAAA,OAAO,IAAI,CAAC;AACb,KAAA;AAED,IAAA,QACE,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,IAAA;AACE,QAAA,KAAA,CAAA,aAAA,CAAC,eAAe,EAAC,EAAA,KAAK,EAAE,KAAK,CAAC,KAAK,EAAI,CAAA;;QAEvC,KAAC,CAAA,aAAA,CAAA,eAAe,EAAC,EAAA,KAAK,EAAE,KAAK,CAAC,GAAG,EAAA,CAAI,CAChC,EACP;AACJ;;;;"}
File without changes
@@ -0,0 +1,19 @@
1
+ import React, { useState } from 'react';
2
+ import { Input } from './Input.js';
3
+ import { InputRow } from './InputRow.js';
4
+
5
+ function PeriodInput(props) {
6
+ const [value, setValue] = useState(props.defaultValue);
7
+ function setValueWrapper(newValue) {
8
+ setValue(newValue);
9
+ if (props.onChange) {
10
+ props.onChange(newValue);
11
+ }
12
+ }
13
+ return (React.createElement(InputRow, null,
14
+ React.createElement(Input, { type: "datetime-local", placeholder: "Start", defaultValue: value === null || value === void 0 ? void 0 : value.start, onChange: (newValue) => setValueWrapper(Object.assign(Object.assign({}, value), { start: newValue })) }),
15
+ React.createElement(Input, { type: "datetime-local", placeholder: "End", defaultValue: value === null || value === void 0 ? void 0 : value.end, onChange: (newValue) => setValueWrapper(Object.assign(Object.assign({}, value), { end: newValue })) })));
16
+ }
17
+
18
+ export { PeriodInput };
19
+ //# sourceMappingURL=PeriodInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PeriodInput.js","sources":["../../src/PeriodInput.tsx"],"sourcesContent":["import { Period } from '@medplum/fhirtypes';\nimport React, { useState } from 'react';\nimport { Input } from './Input';\nimport { InputRow } from './InputRow';\n\nexport interface PeriodInputProps {\n name: string;\n defaultValue?: Period;\n onChange?: (value: Period) => void;\n}\n\nexport function PeriodInput(props: PeriodInputProps): JSX.Element {\n const [value, setValue] = useState(props.defaultValue);\n\n function setValueWrapper(newValue: Period): void {\n setValue(newValue);\n if (props.onChange) {\n props.onChange(newValue);\n }\n }\n\n return (\n <InputRow>\n <Input\n type=\"datetime-local\"\n placeholder=\"Start\"\n defaultValue={value?.start}\n onChange={(newValue) => setValueWrapper({ ...value, start: newValue })}\n />\n <Input\n type=\"datetime-local\"\n placeholder=\"End\"\n defaultValue={value?.end}\n onChange={(newValue) => setValueWrapper({ ...value, end: newValue })}\n />\n </InputRow>\n );\n}\n"],"names":[],"mappings":";;;;AAWM,SAAU,WAAW,CAAC,KAAuB,EAAA;AACjD,IAAA,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAEvD,SAAS,eAAe,CAAC,QAAgB,EAAA;QACvC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACnB,IAAI,KAAK,CAAC,QAAQ,EAAE;AAClB,YAAA,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAC1B,SAAA;KACF;IAED,QACE,oBAAC,QAAQ,EAAA,IAAA;AACP,QAAA,KAAA,CAAA,aAAA,CAAC,KAAK,EAAA,EACJ,IAAI,EAAC,gBAAgB,EACrB,WAAW,EAAC,OAAO,EACnB,YAAY,EAAE,KAAK,KAAA,IAAA,IAAL,KAAK,KAAL,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,KAAK,CAAE,KAAK,EAC1B,QAAQ,EAAE,CAAC,QAAQ,KAAK,eAAe,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAM,KAAK,CAAE,EAAA,EAAA,KAAK,EAAE,QAAQ,IAAG,EACtE,CAAA;AACF,QAAA,KAAA,CAAA,aAAA,CAAC,KAAK,EACJ,EAAA,IAAI,EAAC,gBAAgB,EACrB,WAAW,EAAC,KAAK,EACjB,YAAY,EAAE,KAAK,aAAL,KAAK,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAL,KAAK,CAAE,GAAG,EACxB,QAAQ,EAAE,CAAC,QAAQ,KAAK,eAAe,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAM,KAAK,CAAA,EAAA,EAAE,GAAG,EAAE,QAAQ,IAAG,EACpE,CAAA,CACO,EACX;AACJ;;;;"}
File without changes
@@ -0,0 +1,155 @@
1
+ import { getReferenceString } from '@medplum/core';
2
+ import React, { useState, useRef, useEffect } from 'react';
3
+ import { Button } from './Button.js';
4
+ import { Form } from './Form.js';
5
+ import { FormSection } from './FormSection.js';
6
+ import { Input } from './Input.js';
7
+ import { ResourceInput } from './ResourceInput.js';
8
+ import { Select } from './Select.js';
9
+ import { useResource } from './useResource.js';
10
+
11
+ function PlanDefinitionBuilder(props) {
12
+ const defaultValue = useResource(props.value);
13
+ const [value, setValue] = useState();
14
+ const valueRef = useRef();
15
+ valueRef.current = value;
16
+ useEffect(() => {
17
+ setValue(ensurePlanDefinitionKeys(defaultValue !== null && defaultValue !== void 0 ? defaultValue : { resourceType: 'PlanDefinition' }));
18
+ }, [defaultValue]);
19
+ if (!value) {
20
+ return null;
21
+ }
22
+ function changeProperty(property, newValue) {
23
+ setValue(Object.assign(Object.assign({}, valueRef.current), { [property]: newValue }));
24
+ }
25
+ return (React.createElement("div", { className: "medplum-questionnaire-builder" },
26
+ React.createElement(Form, { testid: "questionnaire-form", onSubmit: () => props.onSubmit(value) },
27
+ React.createElement(FormSection, { title: "Plan Title", description: "The display name of the 'Plan', something that can be ordered.", htmlFor: "title" },
28
+ React.createElement(Input, { defaultValue: value.title, onChange: (newValue) => changeProperty('title', newValue) })),
29
+ React.createElement(ActionArrayBuilder, { actions: value.action || [], onChange: (x) => changeProperty('action', x) }),
30
+ React.createElement(Button, { type: "submit", size: "large" }, "Save"))));
31
+ }
32
+ function ActionArrayBuilder(props) {
33
+ const actionsRef = useRef();
34
+ actionsRef.current = props.actions;
35
+ function changeAction(changedAction) {
36
+ props.onChange(actionsRef.current.map((i) => (i.id === changedAction.id ? changedAction : i)));
37
+ }
38
+ function addAction(addedAction) {
39
+ props.onChange([...actionsRef.current, addedAction]);
40
+ }
41
+ function removeAction(removedAction) {
42
+ props.onChange(actionsRef.current.filter((i) => i !== removedAction));
43
+ }
44
+ return (React.createElement("div", { className: "section" },
45
+ props.actions.map((i) => (React.createElement("div", { key: i.id },
46
+ React.createElement(ActionBuilder, { action: i, onChange: changeAction, onRemove: () => removeAction(i) })))),
47
+ React.createElement("div", { className: "bottom-actions" },
48
+ React.createElement("a", { href: "#", onClick: (e) => {
49
+ e.preventDefault();
50
+ addAction({ id: generateId() });
51
+ } }, "Add action"))));
52
+ }
53
+ function ActionBuilder(props) {
54
+ const { action } = props;
55
+ const [actionType, setActionType] = useState(getInitialActionType(action));
56
+ const actionRef = useRef();
57
+ actionRef.current = props.action;
58
+ function changeProperty(property, value) {
59
+ props.onChange(Object.assign(Object.assign({}, actionRef.current), { [property]: value }));
60
+ }
61
+ return (React.createElement("div", { className: "section" },
62
+ React.createElement(FormSection, { title: "Action Title", description: "The name of the action, an operational task to be completed.", htmlFor: `actionTitle-${action.id}` },
63
+ React.createElement(Input, { name: `actionTitle-${action.id}`, defaultValue: action.title, onChange: (newValue) => changeProperty('title', newValue) })),
64
+ React.createElement(FormSection, { title: "Action Type", description: "The type of the action to be performed.", htmlFor: `actionType-${action.id}` },
65
+ React.createElement(Select, { name: `actionType-${action.id}`, defaultValue: actionType, onChange: setActionType },
66
+ React.createElement("option", null),
67
+ React.createElement("option", { value: "appointment" }, "Appointment"),
68
+ React.createElement("option", { value: "documentation" }, "Documentation"),
69
+ React.createElement("option", { value: "lab" }, "Lab"),
70
+ React.createElement("option", { value: "questionnaire" }, "Questionnaire"),
71
+ React.createElement("option", { value: "shipping" }, "Shipping"),
72
+ React.createElement("option", { value: "task" }, "Task"))),
73
+ action.action && action.action.length > 0 && (React.createElement(ActionArrayBuilder, { actions: action.action, onChange: (x) => changeProperty('action', x) })),
74
+ (() => {
75
+ switch (actionType) {
76
+ case 'appointment':
77
+ return React.createElement("div", null, "Appointment details");
78
+ case 'documentation':
79
+ return React.createElement("div", null, "Documentation details");
80
+ case 'lab':
81
+ return React.createElement(LabActionBuilder, { action: action, onChange: props.onChange });
82
+ case 'questionnaire':
83
+ return React.createElement(QuestionnaireActionBuilder, { action: action, onChange: props.onChange });
84
+ case 'shipping':
85
+ return React.createElement("div", null, "Shipping details");
86
+ case 'task':
87
+ return React.createElement("div", null, "Task details");
88
+ default:
89
+ return null;
90
+ }
91
+ })(),
92
+ React.createElement("div", { className: "bottom-actions" },
93
+ React.createElement("a", { href: "#", onClick: (e) => {
94
+ e.preventDefault();
95
+ props.onRemove();
96
+ } }, "Remove"))));
97
+ }
98
+ function LabActionBuilder(props) {
99
+ return (React.createElement(FormSection, { title: "Lab Details", description: "Choose observations definitions", htmlFor: props.action.id },
100
+ React.createElement("a", { href: "#", onClick: () => props.onChange(props.action) }, "Add")));
101
+ }
102
+ function QuestionnaireActionBuilder(props) {
103
+ const { id, definitionCanonical } = props.action;
104
+ const questionnaireRef = (definitionCanonical === null || definitionCanonical === void 0 ? void 0 : definitionCanonical.startsWith('Questionnaire/'))
105
+ ? { reference: definitionCanonical }
106
+ : undefined;
107
+ return (React.createElement(FormSection, { title: "Questionnaire", description: "Choose questionnaire", htmlFor: id },
108
+ React.createElement(ResourceInput, { name: id, resourceType: "Questionnaire", defaultValue: questionnaireRef, onChange: (newValue) => {
109
+ if (newValue) {
110
+ props.onChange(Object.assign(Object.assign({}, props.action), { definitionCanonical: getReferenceString(newValue) }));
111
+ }
112
+ else {
113
+ props.onChange(Object.assign(Object.assign({}, props.action), { definitionCanonical: undefined }));
114
+ }
115
+ } })));
116
+ }
117
+ function getInitialActionType(action) {
118
+ var _a;
119
+ if ((_a = action.definitionCanonical) === null || _a === void 0 ? void 0 : _a.startsWith('Questionnaire/')) {
120
+ return 'questionnaire';
121
+ }
122
+ return undefined;
123
+ }
124
+ let nextId = 1;
125
+ /**
126
+ * Generates a unique ID.
127
+ * React needs unique IDs for components for rendering performance.
128
+ * All of the important components in the questionnaire builder have id properties for this:
129
+ * Questionnaire, QuestionnaireItem, and QuestionnaireItemAnswerOption.
130
+ * @return A unique key.
131
+ */
132
+ function generateId(existing) {
133
+ if (existing) {
134
+ if (existing.startsWith('id-')) {
135
+ const existingNum = parseInt(existing.substring(3));
136
+ if (!isNaN(existingNum)) {
137
+ nextId = Math.max(nextId, existingNum + 1);
138
+ }
139
+ }
140
+ return existing;
141
+ }
142
+ return 'id-' + nextId++;
143
+ }
144
+ function ensurePlanDefinitionKeys(planDefinition) {
145
+ return Object.assign(Object.assign({}, planDefinition), { action: ensurePlanDefinitionActionKeys(planDefinition.action) });
146
+ }
147
+ function ensurePlanDefinitionActionKeys(actions) {
148
+ if (!actions) {
149
+ return undefined;
150
+ }
151
+ return actions.map((action) => (Object.assign(Object.assign({}, action), { id: generateId(action.id), action: ensurePlanDefinitionActionKeys(action.action) })));
152
+ }
153
+
154
+ export { PlanDefinitionBuilder };
155
+ //# sourceMappingURL=PlanDefinitionBuilder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlanDefinitionBuilder.js","sources":["../../src/PlanDefinitionBuilder.tsx"],"sourcesContent":["import { getReferenceString } from '@medplum/core';\nimport { PlanDefinition, PlanDefinitionAction, Reference } from '@medplum/fhirtypes';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { Button } from './Button';\nimport { Form } from './Form';\nimport { FormSection } from './FormSection';\nimport { Input } from './Input';\nimport { ResourceInput } from './ResourceInput';\nimport { Select } from './Select';\nimport { useResource } from './useResource';\n\nexport interface PlanDefinitionBuilderProps {\n value: PlanDefinition | Reference<PlanDefinition>;\n onSubmit: (result: PlanDefinition) => void;\n}\n\nexport function PlanDefinitionBuilder(props: PlanDefinitionBuilderProps): JSX.Element | null {\n const defaultValue = useResource(props.value);\n const [value, setValue] = useState<PlanDefinition>();\n const valueRef = useRef<PlanDefinition>();\n valueRef.current = value;\n\n useEffect(() => {\n setValue(ensurePlanDefinitionKeys(defaultValue ?? { resourceType: 'PlanDefinition' }));\n }, [defaultValue]);\n\n if (!value) {\n return null;\n }\n\n function changeProperty(property: string, newValue: any): void {\n setValue({\n ...valueRef.current,\n [property]: newValue,\n } as PlanDefinition);\n }\n\n return (\n <div className=\"medplum-questionnaire-builder\">\n <Form testid=\"questionnaire-form\" onSubmit={() => props.onSubmit(value)}>\n <FormSection\n title=\"Plan Title\"\n description=\"The display name of the 'Plan', something that can be ordered.\"\n htmlFor=\"title\"\n >\n <Input defaultValue={value.title} onChange={(newValue) => changeProperty('title', newValue)} />\n </FormSection>\n <ActionArrayBuilder actions={value.action || []} onChange={(x) => changeProperty('action', x)} />\n <Button type=\"submit\" size=\"large\">\n Save\n </Button>\n </Form>\n </div>\n );\n}\n\ninterface ActionArrayBuilderProps {\n actions: PlanDefinitionAction[];\n onChange: (actions: PlanDefinitionAction[]) => void;\n}\n\nfunction ActionArrayBuilder(props: ActionArrayBuilderProps): JSX.Element {\n const actionsRef = useRef<PlanDefinitionAction[]>();\n actionsRef.current = props.actions;\n\n function changeAction(changedAction: PlanDefinitionAction): void {\n props.onChange(\n (actionsRef.current as PlanDefinition[]).map((i) => (i.id === changedAction.id ? changedAction : i))\n );\n }\n\n function addAction(addedAction: PlanDefinitionAction): void {\n props.onChange([...(actionsRef.current as PlanDefinition[]), addedAction]);\n }\n\n function removeAction(removedAction: PlanDefinitionAction): void {\n props.onChange((actionsRef.current as PlanDefinition[]).filter((i) => i !== removedAction));\n }\n\n return (\n <div className=\"section\">\n {props.actions.map((i) => (\n <div key={i.id}>\n <ActionBuilder action={i} onChange={changeAction} onRemove={() => removeAction(i)} />\n </div>\n ))}\n <div className=\"bottom-actions\">\n <a\n href=\"#\"\n onClick={(e) => {\n e.preventDefault();\n addAction({ id: generateId() });\n }}\n >\n Add action\n </a>\n </div>\n </div>\n );\n}\n\ninterface ActionBuilderProps {\n action: PlanDefinitionAction;\n onChange: (action: PlanDefinitionAction) => void;\n onRemove: () => void;\n}\n\nfunction ActionBuilder(props: ActionBuilderProps): JSX.Element {\n const { action } = props;\n const [actionType, setActionType] = useState<string | undefined>(getInitialActionType(action));\n\n const actionRef = useRef<PlanDefinitionAction>();\n actionRef.current = props.action;\n\n function changeProperty(property: string, value: any): void {\n props.onChange({\n ...actionRef.current,\n [property]: value,\n } as PlanDefinitionAction);\n }\n\n return (\n <div className=\"section\">\n <FormSection\n title=\"Action Title\"\n description=\"The name of the action, an operational task to be completed.\"\n htmlFor={`actionTitle-${action.id}`}\n >\n <Input\n name={`actionTitle-${action.id}`}\n defaultValue={action.title}\n onChange={(newValue) => changeProperty('title', newValue)}\n />\n </FormSection>\n <FormSection\n title=\"Action Type\"\n description=\"The type of the action to be performed.\"\n htmlFor={`actionType-${action.id}`}\n >\n <Select name={`actionType-${action.id}`} defaultValue={actionType} onChange={setActionType}>\n <option></option>\n <option value=\"appointment\">Appointment</option>\n <option value=\"documentation\">Documentation</option>\n <option value=\"lab\">Lab</option>\n <option value=\"questionnaire\">Questionnaire</option>\n <option value=\"shipping\">Shipping</option>\n <option value=\"task\">Task</option>\n </Select>\n </FormSection>\n {action.action && action.action.length > 0 && (\n <ActionArrayBuilder actions={action.action} onChange={(x) => changeProperty('action', x)} />\n )}\n {(() => {\n switch (actionType) {\n case 'appointment':\n return <div>Appointment details</div>;\n case 'documentation':\n return <div>Documentation details</div>;\n case 'lab':\n return <LabActionBuilder action={action} onChange={props.onChange} />;\n case 'questionnaire':\n return <QuestionnaireActionBuilder action={action} onChange={props.onChange} />;\n case 'shipping':\n return <div>Shipping details</div>;\n case 'task':\n return <div>Task details</div>;\n default:\n return null;\n }\n })()}\n <div className=\"bottom-actions\">\n <a\n href=\"#\"\n onClick={(e) => {\n e.preventDefault();\n props.onRemove();\n }}\n >\n Remove\n </a>\n </div>\n </div>\n );\n}\n\ninterface LabActionBuilderProps {\n action: PlanDefinitionAction;\n onChange: (action: PlanDefinitionAction) => void;\n}\n\nfunction LabActionBuilder(props: LabActionBuilderProps): JSX.Element {\n return (\n <FormSection title=\"Lab Details\" description=\"Choose observations definitions\" htmlFor={props.action.id}>\n <a href=\"#\" onClick={() => props.onChange(props.action)}>\n Add\n </a>\n </FormSection>\n );\n}\n\ninterface QuestionnaireActionBuilderProps {\n action: PlanDefinitionAction;\n onChange: (action: PlanDefinitionAction) => void;\n}\n\nfunction QuestionnaireActionBuilder(props: QuestionnaireActionBuilderProps): JSX.Element {\n const { id, definitionCanonical } = props.action;\n const questionnaireRef = definitionCanonical?.startsWith('Questionnaire/')\n ? { reference: definitionCanonical }\n : undefined;\n return (\n <FormSection title=\"Questionnaire\" description=\"Choose questionnaire\" htmlFor={id}>\n <ResourceInput\n name={id as string}\n resourceType=\"Questionnaire\"\n defaultValue={questionnaireRef}\n onChange={(newValue) => {\n if (newValue) {\n props.onChange({ ...props.action, definitionCanonical: getReferenceString(newValue) });\n } else {\n props.onChange({ ...props.action, definitionCanonical: undefined });\n }\n }}\n />\n </FormSection>\n );\n}\n\nfunction getInitialActionType(action: PlanDefinitionAction): string | undefined {\n if (action.definitionCanonical?.startsWith('Questionnaire/')) {\n return 'questionnaire';\n }\n\n return undefined;\n}\n\nlet nextId = 1;\n\n/**\n * Generates a unique ID.\n * React needs unique IDs for components for rendering performance.\n * All of the important components in the questionnaire builder have id properties for this:\n * Questionnaire, QuestionnaireItem, and QuestionnaireItemAnswerOption.\n * @return A unique key.\n */\nfunction generateId(existing?: string): string {\n if (existing) {\n if (existing.startsWith('id-')) {\n const existingNum = parseInt(existing.substring(3));\n if (!isNaN(existingNum)) {\n nextId = Math.max(nextId, existingNum + 1);\n }\n }\n return existing;\n }\n return 'id-' + nextId++;\n}\n\nfunction ensurePlanDefinitionKeys(planDefinition: PlanDefinition): PlanDefinition {\n return {\n ...planDefinition,\n action: ensurePlanDefinitionActionKeys(planDefinition.action),\n } as PlanDefinition;\n}\n\nfunction ensurePlanDefinitionActionKeys(\n actions: PlanDefinitionAction[] | undefined\n): PlanDefinitionAction[] | undefined {\n if (!actions) {\n return undefined;\n }\n return actions.map((action) => ({\n ...action,\n id: generateId(action.id),\n action: ensurePlanDefinitionActionKeys(action.action),\n }));\n}\n"],"names":[],"mappings":";;;;;;;;;;AAgBM,SAAU,qBAAqB,CAAC,KAAiC,EAAA;IACrE,MAAM,YAAY,GAAG,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC9C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,EAAkB,CAAC;AACrD,IAAA,MAAM,QAAQ,GAAG,MAAM,EAAkB,CAAC;AAC1C,IAAA,QAAQ,CAAC,OAAO,GAAG,KAAK,CAAC;IAEzB,SAAS,CAAC,MAAK;AACb,QAAA,QAAQ,CAAC,wBAAwB,CAAC,YAAY,KAAA,IAAA,IAAZ,YAAY,KAAZ,KAAA,CAAA,GAAA,YAAY,GAAI,EAAE,YAAY,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;AACzF,KAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnB,IAAI,CAAC,KAAK,EAAE;AACV,QAAA,OAAO,IAAI,CAAC;AACb,KAAA;AAED,IAAA,SAAS,cAAc,CAAC,QAAgB,EAAE,QAAa,EAAA;AACrD,QAAA,QAAQ,CAAC,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACJ,QAAQ,CAAC,OAAO,CAAA,EAAA,EACnB,CAAC,QAAQ,GAAG,QAAQ,EAAA,CACH,CAAC,CAAC;KACtB;AAED,IAAA,QACE,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,+BAA+B,EAAA;AAC5C,QAAA,KAAA,CAAA,aAAA,CAAC,IAAI,EAAC,EAAA,MAAM,EAAC,oBAAoB,EAAC,QAAQ,EAAE,MAAM,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAA;AACrE,YAAA,KAAA,CAAA,aAAA,CAAC,WAAW,EAAA,EACV,KAAK,EAAC,YAAY,EAClB,WAAW,EAAC,gEAAgE,EAC5E,OAAO,EAAC,OAAO,EAAA;gBAEf,KAAC,CAAA,aAAA,CAAA,KAAK,IAAC,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,QAAQ,KAAK,cAAc,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAA,CAAI,CACnF;YACd,KAAC,CAAA,aAAA,CAAA,kBAAkB,IAAC,OAAO,EAAE,KAAK,CAAC,MAAM,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,KAAK,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAI,CAAA;AACjG,YAAA,KAAA,CAAA,aAAA,CAAC,MAAM,EAAA,EAAC,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAC,OAAO,EAAA,EAAA,MAAA,CAEzB,CACJ,CACH,EACN;AACJ,CAAC;AAOD,SAAS,kBAAkB,CAAC,KAA8B,EAAA;AACxD,IAAA,MAAM,UAAU,GAAG,MAAM,EAA0B,CAAC;AACpD,IAAA,UAAU,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAEnC,SAAS,YAAY,CAAC,aAAmC,EAAA;AACvD,QAAA,KAAK,CAAC,QAAQ,CACX,UAAU,CAAC,OAA4B,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,aAAa,CAAC,EAAE,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC,CACrG,CAAC;KACH;IAED,SAAS,SAAS,CAAC,WAAiC,EAAA;AAClD,QAAA,KAAK,CAAC,QAAQ,CAAC,CAAC,GAAI,UAAU,CAAC,OAA4B,EAAE,WAAW,CAAC,CAAC,CAAC;KAC5E;IAED,SAAS,YAAY,CAAC,aAAmC,EAAA;AACvD,QAAA,KAAK,CAAC,QAAQ,CAAE,UAAU,CAAC,OAA4B,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,aAAa,CAAC,CAAC,CAAC;KAC7F;AAED,IAAA,QACE,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,SAAS,EAAA;AACrB,QAAA,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,MACnB,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,CAAC,CAAC,EAAE,EAAA;YACZ,KAAC,CAAA,aAAA,CAAA,aAAa,IAAC,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC,CAAC,CAAC,EAAA,CAAI,CACjF,CACP,CAAC;QACF,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,gBAAgB,EAAA;YAC7B,KACE,CAAA,aAAA,CAAA,GAAA,EAAA,EAAA,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,CAAC,CAAC,KAAI;oBACb,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,SAAS,CAAC,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;AAClC,iBAAC,EAGC,EAAA,YAAA,CAAA,CACA,CACF,EACN;AACJ,CAAC;AAQD,SAAS,aAAa,CAAC,KAAyB,EAAA;AAC9C,IAAA,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;AACzB,IAAA,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAqB,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC;AAE/F,IAAA,MAAM,SAAS,GAAG,MAAM,EAAwB,CAAC;AACjD,IAAA,SAAS,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;AAEjC,IAAA,SAAS,cAAc,CAAC,QAAgB,EAAE,KAAU,EAAA;AAClD,QAAA,KAAK,CAAC,QAAQ,CAAC,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACV,SAAS,CAAC,OAAO,CACpB,EAAA,EAAA,CAAC,QAAQ,GAAG,KAAK,EAAA,CACM,CAAC,CAAC;KAC5B;AAED,IAAA,QACE,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,SAAS,EAAA;AACtB,QAAA,KAAA,CAAA,aAAA,CAAC,WAAW,EACV,EAAA,KAAK,EAAC,cAAc,EACpB,WAAW,EAAC,8DAA8D,EAC1E,OAAO,EAAE,CAAA,YAAA,EAAe,MAAM,CAAC,EAAE,CAAE,CAAA,EAAA;AAEnC,YAAA,KAAA,CAAA,aAAA,CAAC,KAAK,EAAA,EACJ,IAAI,EAAE,CAAe,YAAA,EAAA,MAAM,CAAC,EAAE,CAAE,CAAA,EAChC,YAAY,EAAE,MAAM,CAAC,KAAK,EAC1B,QAAQ,EAAE,CAAC,QAAQ,KAAK,cAAc,CAAC,OAAO,EAAE,QAAQ,CAAC,GACzD,CACU;AACd,QAAA,KAAA,CAAA,aAAA,CAAC,WAAW,EACV,EAAA,KAAK,EAAC,aAAa,EACnB,WAAW,EAAC,yCAAyC,EACrD,OAAO,EAAE,CAAA,WAAA,EAAc,MAAM,CAAC,EAAE,CAAE,CAAA,EAAA;AAElC,YAAA,KAAA,CAAA,aAAA,CAAC,MAAM,EAAC,EAAA,IAAI,EAAE,CAAA,WAAA,EAAc,MAAM,CAAC,EAAE,CAAE,CAAA,EAAE,YAAY,EAAE,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAA;gBACxF,KAAiB,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,CAAA;gBACjB,KAAQ,CAAA,aAAA,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,aAAa,EAAqB,EAAA,aAAA,CAAA;gBAChD,KAAQ,CAAA,aAAA,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,eAAe,EAAuB,EAAA,eAAA,CAAA;gBACpD,KAAQ,CAAA,aAAA,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,KAAK,EAAa,EAAA,KAAA,CAAA;gBAChC,KAAQ,CAAA,aAAA,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,eAAe,EAAuB,EAAA,eAAA,CAAA;gBACpD,KAAQ,CAAA,aAAA,CAAA,QAAA,EAAA,EAAA,KAAK,EAAC,UAAU,EAAkB,EAAA,UAAA,CAAA;AAC1C,gBAAA,KAAA,CAAA,aAAA,CAAA,QAAA,EAAA,EAAQ,KAAK,EAAC,MAAM,EAAA,EAAA,MAAA,CAAc,CAC3B,CACG;AACb,QAAA,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,KACxC,KAAC,CAAA,aAAA,CAAA,kBAAkB,IAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC,KAAK,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAI,CAC7F;AACA,QAAA,CAAC,MAAK;AACL,YAAA,QAAQ,UAAU;AAChB,gBAAA,KAAK,aAAa;AAChB,oBAAA,OAAO,uDAA8B,CAAC;AACxC,gBAAA,KAAK,eAAe;AAClB,oBAAA,OAAO,yDAAgC,CAAC;AAC1C,gBAAA,KAAK,KAAK;AACR,oBAAA,OAAO,KAAC,CAAA,aAAA,CAAA,gBAAgB,EAAC,EAAA,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,GAAI,CAAC;AACxE,gBAAA,KAAK,eAAe;AAClB,oBAAA,OAAO,KAAC,CAAA,aAAA,CAAA,0BAA0B,EAAC,EAAA,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,GAAI,CAAC;AAClF,gBAAA,KAAK,UAAU;AACb,oBAAA,OAAO,oDAA2B,CAAC;AACrC,gBAAA,KAAK,MAAM;AACT,oBAAA,OAAO,gDAAuB,CAAC;AACjC,gBAAA;AACE,oBAAA,OAAO,IAAI,CAAC;AACf,aAAA;AACH,SAAC,GAAG;QACJ,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,gBAAgB,EAAA;YAC7B,KACE,CAAA,aAAA,CAAA,GAAA,EAAA,EAAA,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,CAAC,CAAC,KAAI;oBACb,CAAC,CAAC,cAAc,EAAE,CAAC;oBACnB,KAAK,CAAC,QAAQ,EAAE,CAAC;AACnB,iBAAC,EAGC,EAAA,QAAA,CAAA,CACA,CACF,EACN;AACJ,CAAC;AAOD,SAAS,gBAAgB,CAAC,KAA4B,EAAA;AACpD,IAAA,QACE,KAAC,CAAA,aAAA,CAAA,WAAW,IAAC,KAAK,EAAC,aAAa,EAAC,WAAW,EAAC,iCAAiC,EAAC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE,EAAA;QACrG,KAAG,CAAA,aAAA,CAAA,GAAA,EAAA,EAAA,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,MAAM,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAEnD,EAAA,KAAA,CAAA,CACQ,EACd;AACJ,CAAC;AAOD,SAAS,0BAA0B,CAAC,KAAsC,EAAA;IACxE,MAAM,EAAE,EAAE,EAAE,mBAAmB,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;AACjD,IAAA,MAAM,gBAAgB,GAAG,CAAA,mBAAmB,KAAnB,IAAA,IAAA,mBAAmB,KAAnB,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,mBAAmB,CAAE,UAAU,CAAC,gBAAgB,CAAC;AACxE,UAAE,EAAE,SAAS,EAAE,mBAAmB,EAAE;UAClC,SAAS,CAAC;AACd,IAAA,QACE,KAAA,CAAA,aAAA,CAAC,WAAW,EAAA,EAAC,KAAK,EAAC,eAAe,EAAC,WAAW,EAAC,sBAAsB,EAAC,OAAO,EAAE,EAAE,EAAA;AAC/E,QAAA,KAAA,CAAA,aAAA,CAAC,aAAa,EACZ,EAAA,IAAI,EAAE,EAAY,EAClB,YAAY,EAAC,eAAe,EAC5B,YAAY,EAAE,gBAAgB,EAC9B,QAAQ,EAAE,CAAC,QAAQ,KAAI;AACrB,gBAAA,IAAI,QAAQ,EAAE;AACZ,oBAAA,KAAK,CAAC,QAAQ,CAAM,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,KAAK,CAAC,MAAM,CAAA,EAAA,EAAE,mBAAmB,EAAE,kBAAkB,CAAC,QAAQ,CAAC,IAAG,CAAC;AACxF,iBAAA;AAAM,qBAAA;oBACL,KAAK,CAAC,QAAQ,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAM,KAAK,CAAC,MAAM,CAAA,EAAA,EAAE,mBAAmB,EAAE,SAAS,EAAA,CAAA,CAAG,CAAC;AACrE,iBAAA;aACF,EAAA,CACD,CACU,EACd;AACJ,CAAC;AAED,SAAS,oBAAoB,CAAC,MAA4B,EAAA;;IACxD,IAAI,CAAA,EAAA,GAAA,MAAM,CAAC,mBAAmB,0CAAE,UAAU,CAAC,gBAAgB,CAAC,EAAE;AAC5D,QAAA,OAAO,eAAe,CAAC;AACxB,KAAA;AAED,IAAA,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,IAAI,MAAM,GAAG,CAAC,CAAC;AAEf;;;;;;AAMG;AACH,SAAS,UAAU,CAAC,QAAiB,EAAA;AACnC,IAAA,IAAI,QAAQ,EAAE;AACZ,QAAA,IAAI,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;YAC9B,MAAM,WAAW,GAAG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;AACpD,YAAA,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE;gBACvB,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,WAAW,GAAG,CAAC,CAAC,CAAC;AAC5C,aAAA;AACF,SAAA;AACD,QAAA,OAAO,QAAQ,CAAC;AACjB,KAAA;AACD,IAAA,OAAO,KAAK,GAAG,MAAM,EAAE,CAAC;AAC1B,CAAC;AAED,SAAS,wBAAwB,CAAC,cAA8B,EAAA;AAC9D,IAAA,OAAO,MACF,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,cAAc,CACjB,EAAA,EAAA,MAAM,EAAE,8BAA8B,CAAC,cAAc,CAAC,MAAM,CAAC,EAAA,CAC5C,CAAC;AACtB,CAAC;AAED,SAAS,8BAA8B,CACrC,OAA2C,EAAA;IAE3C,IAAI,CAAC,OAAO,EAAE;AACZ,QAAA,OAAO,SAAS,CAAC;AAClB,KAAA;AACD,IAAA,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,MAAK,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAC1B,MAAM,CAAA,EAAA,EACT,EAAE,EAAE,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,EACzB,MAAM,EAAE,8BAA8B,CAAC,MAAM,CAAC,MAAM,CAAC,EAAA,CAAA,CACrD,CAAC,CAAC;AACN;;;;"}
File without changes
@@ -0,0 +1,64 @@
1
+ import React, { useRef, useEffect } from 'react';
2
+ import { useLocation } from 'react-router-dom';
3
+
4
+ function Popup(props) {
5
+ const ref = useRef(null);
6
+ // Track browser URL location, and the location when the popup becomes visible
7
+ const location = useLocation();
8
+ const locationRef = useRef();
9
+ if (props.visible) {
10
+ if (locationRef.current === undefined) {
11
+ locationRef.current = location;
12
+ }
13
+ }
14
+ else {
15
+ locationRef.current = undefined;
16
+ }
17
+ const propsRef = useRef();
18
+ propsRef.current = props;
19
+ // Listen for clicks outside of the popup
20
+ // If the user clicks outside of the popup, close it
21
+ useEffect(() => {
22
+ function handleClick(e) {
23
+ var _a, _b;
24
+ if (((_a = propsRef.current) === null || _a === void 0 ? void 0 : _a.visible) &&
25
+ ((_b = propsRef.current) === null || _b === void 0 ? void 0 : _b.autoClose) &&
26
+ (ref === null || ref === void 0 ? void 0 : ref.current) &&
27
+ !ref.current.contains(e.target)) {
28
+ props.onClose();
29
+ }
30
+ }
31
+ document.addEventListener('click', handleClick, true);
32
+ return () => document.removeEventListener('click', handleClick, true);
33
+ }, [props]);
34
+ // Listen for changes in the location
35
+ // If the browser navigates to a new page, close the popup
36
+ useEffect(() => {
37
+ if (props.visible && location !== locationRef.current) {
38
+ props.onClose();
39
+ }
40
+ }, [location, props]);
41
+ const style = {
42
+ display: props.visible ? 'block' : 'none',
43
+ };
44
+ if (props.anchor) {
45
+ if (props.anchor.right + 250 < document.body.clientWidth) {
46
+ style.left = props.anchor.right + 'px';
47
+ }
48
+ else {
49
+ style.right = document.body.clientWidth - props.anchor.left + 'px';
50
+ }
51
+ if (props.anchor.top + 300 < document.body.clientHeight) {
52
+ style.top = props.anchor.top + 'px';
53
+ }
54
+ else {
55
+ style.bottom = document.body.clientHeight - props.anchor.top + 'px';
56
+ }
57
+ }
58
+ return (React.createElement(React.Fragment, null,
59
+ props.modal && (React.createElement("div", { className: props.visible ? 'medplum-backdrop active' : 'medplum-backdrop', onClick: props.onClose })),
60
+ React.createElement("div", { ref: ref, className: 'medplum-popup ' + (props.visible ? props.activeClassName : props.inactiveClassName), style: style, "data-testid": "popup" }, props.children)));
61
+ }
62
+
63
+ export { Popup };
64
+ //# sourceMappingURL=Popup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Popup.js","sources":["../../src/Popup.tsx"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport { Location, useLocation } from 'react-router-dom';\nimport './Popup.css';\n\ninterface PopupProps {\n visible: boolean;\n anchor?: DOMRectReadOnly;\n modal?: boolean;\n autoClose?: boolean;\n onClose: () => void;\n activeClassName?: string;\n inactiveClassName?: string;\n children?: React.ReactNode;\n}\n\nexport function Popup(props: PopupProps): JSX.Element {\n const ref = useRef<HTMLDivElement>(null);\n\n // Track browser URL location, and the location when the popup becomes visible\n const location = useLocation();\n const locationRef = useRef<Location>();\n if (props.visible) {\n if (locationRef.current === undefined) {\n locationRef.current = location;\n }\n } else {\n locationRef.current = undefined;\n }\n\n const propsRef = useRef<PopupProps>();\n propsRef.current = props;\n\n // Listen for clicks outside of the popup\n // If the user clicks outside of the popup, close it\n useEffect(() => {\n function handleClick(e: Event): void {\n if (\n propsRef.current?.visible &&\n propsRef.current?.autoClose &&\n ref?.current &&\n !ref.current.contains(e.target as Node)\n ) {\n props.onClose();\n }\n }\n\n document.addEventListener('click', handleClick, true);\n return () => document.removeEventListener('click', handleClick, true);\n }, [props]);\n\n // Listen for changes in the location\n // If the browser navigates to a new page, close the popup\n useEffect(() => {\n if (props.visible && location !== locationRef.current) {\n props.onClose();\n }\n }, [location, props]);\n\n const style: React.CSSProperties = {\n display: props.visible ? 'block' : 'none',\n };\n\n if (props.anchor) {\n if (props.anchor.right + 250 < document.body.clientWidth) {\n style.left = props.anchor.right + 'px';\n } else {\n style.right = document.body.clientWidth - props.anchor.left + 'px';\n }\n\n if (props.anchor.top + 300 < document.body.clientHeight) {\n style.top = props.anchor.top + 'px';\n } else {\n style.bottom = document.body.clientHeight - props.anchor.top + 'px';\n }\n }\n\n return (\n <>\n {props.modal && (\n <div className={props.visible ? 'medplum-backdrop active' : 'medplum-backdrop'} onClick={props.onClose} />\n )}\n <div\n ref={ref}\n className={'medplum-popup ' + (props.visible ? props.activeClassName : props.inactiveClassName)}\n style={style}\n data-testid=\"popup\"\n >\n {props.children}\n </div>\n </>\n );\n}\n"],"names":[],"mappings":"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"}
File without changes
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+
3
+ function QuantityDisplay(props) {
4
+ return React.createElement(React.Fragment, null, formatQuantityString(props.value));
5
+ }
6
+ function formatQuantityString(quantity) {
7
+ if (!quantity) {
8
+ return '';
9
+ }
10
+ const result = [];
11
+ if (quantity.comparator) {
12
+ result.push(quantity.comparator);
13
+ result.push(' ');
14
+ }
15
+ if (quantity.value !== undefined) {
16
+ result.push(quantity.value);
17
+ }
18
+ if (quantity.unit) {
19
+ if (quantity.unit !== '%') {
20
+ result.push(' ');
21
+ }
22
+ result.push(quantity.unit);
23
+ }
24
+ return result.join('');
25
+ }
26
+
27
+ export { QuantityDisplay, formatQuantityString };
28
+ //# sourceMappingURL=QuantityDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuantityDisplay.js","sources":["../../src/QuantityDisplay.tsx"],"sourcesContent":["import { Quantity } from '@medplum/fhirtypes';\nimport React from 'react';\n\nexport interface QuantityDisplayProps {\n value?: Quantity;\n}\n\nexport function QuantityDisplay(props: QuantityDisplayProps): JSX.Element | null {\n return <>{formatQuantityString(props.value)}</>;\n}\n\nexport function formatQuantityString(quantity: Quantity | undefined): string {\n if (!quantity) {\n return '';\n }\n\n const result = [];\n\n if (quantity.comparator) {\n result.push(quantity.comparator);\n result.push(' ');\n }\n\n if (quantity.value !== undefined) {\n result.push(quantity.value);\n }\n\n if (quantity.unit) {\n if (quantity.unit !== '%') {\n result.push(' ');\n }\n result.push(quantity.unit);\n }\n\n return result.join('');\n}\n"],"names":[],"mappings":";;AAOM,SAAU,eAAe,CAAC,KAA2B,EAAA;IACzD,OAAO,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,EAAG,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAI,CAAC;AAClD,CAAC;AAEK,SAAU,oBAAoB,CAAC,QAA8B,EAAA;IACjE,IAAI,CAAC,QAAQ,EAAE;AACb,QAAA,OAAO,EAAE,CAAC;AACX,KAAA;IAED,MAAM,MAAM,GAAG,EAAE,CAAC;IAElB,IAAI,QAAQ,CAAC,UAAU,EAAE;AACvB,QAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;AACjC,QAAA,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAClB,KAAA;AAED,IAAA,IAAI,QAAQ,CAAC,KAAK,KAAK,SAAS,EAAE;AAChC,QAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAC7B,KAAA;IAED,IAAI,QAAQ,CAAC,IAAI,EAAE;AACjB,QAAA,IAAI,QAAQ,CAAC,IAAI,KAAK,GAAG,EAAE;AACzB,YAAA,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAClB,SAAA;AACD,QAAA,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC5B,KAAA;AAED,IAAA,OAAO,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzB;;;;"}
File without changes
@@ -0,0 +1,33 @@
1
+ import React, { useState } from 'react';
2
+ import { Input } from './Input.js';
3
+ import { InputRow } from './InputRow.js';
4
+ import { Select } from './Select.js';
5
+
6
+ function QuantityInput(props) {
7
+ var _a;
8
+ const [value, setValue] = useState(props.defaultValue);
9
+ function setValueWrapper(newValue) {
10
+ setValue(newValue);
11
+ if (props.onChange) {
12
+ props.onChange(newValue);
13
+ }
14
+ }
15
+ return (React.createElement(InputRow, null,
16
+ React.createElement(Select, { style: { width: 80 }, testid: props.name + '-comparator', defaultValue: value === null || value === void 0 ? void 0 : value.comparator, onChange: (newValue) => setValueWrapper(Object.assign(Object.assign({}, value), { comparator: newValue })) },
17
+ React.createElement("option", null),
18
+ React.createElement("option", null, "<"),
19
+ React.createElement("option", null, "<="),
20
+ React.createElement("option", null, ">="),
21
+ React.createElement("option", null, ">")),
22
+ React.createElement(Input, { name: props.name, type: "number", step: "any", placeholder: "Value", defaultValue: (_a = value === null || value === void 0 ? void 0 : value.value) === null || _a === void 0 ? void 0 : _a.toString(), onChange: (newValue) => setValueWrapper(Object.assign(Object.assign({}, value), { value: tryParseNumber(newValue) })) }),
23
+ React.createElement(Input, { placeholder: "Unit", defaultValue: value === null || value === void 0 ? void 0 : value.unit, onChange: (newValue) => setValueWrapper(Object.assign(Object.assign({}, value), { unit: newValue })) })));
24
+ }
25
+ function tryParseNumber(str) {
26
+ if (!str) {
27
+ return undefined;
28
+ }
29
+ return parseFloat(str);
30
+ }
31
+
32
+ export { QuantityInput };
33
+ //# sourceMappingURL=QuantityInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuantityInput.js","sources":["../../src/QuantityInput.tsx"],"sourcesContent":["import { Quantity } from '@medplum/fhirtypes';\nimport React, { useState } from 'react';\nimport { Input } from './Input';\nimport { InputRow } from './InputRow';\nimport { Select } from './Select';\n\nexport interface QuantityInputProps {\n name: string;\n defaultValue?: Quantity;\n onChange?: (value: Quantity) => void;\n}\n\nexport function QuantityInput(props: QuantityInputProps): JSX.Element {\n const [value, setValue] = useState(props.defaultValue);\n\n function setValueWrapper(newValue: Quantity): void {\n setValue(newValue);\n if (props.onChange) {\n props.onChange(newValue);\n }\n }\n\n return (\n <InputRow>\n <Select\n style={{ width: 80 }}\n testid={props.name + '-comparator'}\n defaultValue={value?.comparator}\n onChange={(newValue) =>\n setValueWrapper({\n ...value,\n comparator: newValue,\n })\n }\n >\n <option></option>\n <option>&lt;</option>\n <option>&lt;=</option>\n <option>&gt;=</option>\n <option>&gt;</option>\n </Select>\n <Input\n name={props.name}\n type=\"number\"\n step=\"any\"\n placeholder=\"Value\"\n defaultValue={value?.value?.toString()}\n onChange={(newValue) =>\n setValueWrapper({\n ...value,\n value: tryParseNumber(newValue),\n })\n }\n />\n <Input\n placeholder=\"Unit\"\n defaultValue={value?.unit}\n onChange={(newValue) =>\n setValueWrapper({\n ...value,\n unit: newValue,\n })\n }\n />\n </InputRow>\n );\n}\n\nfunction tryParseNumber(str: string): number | undefined {\n if (!str) {\n return undefined;\n }\n return parseFloat(str);\n}\n"],"names":[],"mappings":";;;;;AAYM,SAAU,aAAa,CAAC,KAAyB,EAAA;;AACrD,IAAA,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAEvD,SAAS,eAAe,CAAC,QAAkB,EAAA;QACzC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACnB,IAAI,KAAK,CAAC,QAAQ,EAAE;AAClB,YAAA,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAC1B,SAAA;KACF;IAED,QACE,oBAAC,QAAQ,EAAA,IAAA;AACP,QAAA,KAAA,CAAA,aAAA,CAAC,MAAM,EACL,EAAA,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EACpB,MAAM,EAAE,KAAK,CAAC,IAAI,GAAG,aAAa,EAClC,YAAY,EAAE,KAAK,KAAL,IAAA,IAAA,KAAK,uBAAL,KAAK,CAAE,UAAU,EAC/B,QAAQ,EAAE,CAAC,QAAQ,KACjB,eAAe,CACV,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,KAAK,KACR,UAAU,EAAE,QAAQ,EACpB,CAAA,CAAA,EAAA;YAGJ,KAAiB,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,CAAA;YACjB,KAAqB,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,EAAA,GAAA,CAAA;YACrB,KAAsB,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,EAAA,IAAA,CAAA;YACtB,KAAsB,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,EAAA,IAAA,CAAA;AACtB,YAAA,KAAA,CAAA,aAAA,CAAA,QAAA,EAAA,IAAA,EAAA,GAAA,CAAqB,CACd;QACT,KAAC,CAAA,aAAA,CAAA,KAAK,EACJ,EAAA,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,KAAK,EACV,WAAW,EAAC,OAAO,EACnB,YAAY,EAAE,CAAA,EAAA,GAAA,KAAK,KAAL,IAAA,IAAA,KAAK,uBAAL,KAAK,CAAE,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAE,QAAQ,EAAE,EACtC,QAAQ,EAAE,CAAC,QAAQ,KACjB,eAAe,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EACV,KAAK,CAAA,EAAA,EACR,KAAK,EAAE,cAAc,CAAC,QAAQ,CAAC,EAAA,CAAA,CAC/B,EAEJ,CAAA;AACF,QAAA,KAAA,CAAA,aAAA,CAAC,KAAK,EAAA,EACJ,WAAW,EAAC,MAAM,EAClB,YAAY,EAAE,KAAK,aAAL,KAAK,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAL,KAAK,CAAE,IAAI,EACzB,QAAQ,EAAE,CAAC,QAAQ,KACjB,eAAe,CACV,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,KAAK,CACR,EAAA,EAAA,IAAI,EAAE,QAAQ,EAAA,CAAA,CACd,EAEJ,CAAA,CACO,EACX;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,GAAW,EAAA;IACjC,IAAI,CAAC,GAAG,EAAE;AACR,QAAA,OAAO,SAAS,CAAC;AAClB,KAAA;AACD,IAAA,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;AACzB;;;;"}
File without changes