@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,23 @@
1
+ import { evalFhirPath } from '@medplum/core';
2
+ import React from 'react';
3
+ import { ResourcePropertyDisplay } from './ResourcePropertyDisplay.js';
4
+
5
+ function FhirPathDisplay(props) {
6
+ let value;
7
+ try {
8
+ value = evalFhirPath(props.path, props.resource);
9
+ }
10
+ catch (err) {
11
+ console.warn('FhirPathDisplay:', err);
12
+ return null;
13
+ }
14
+ if (value.length > 1) {
15
+ throw new Error(`Component "path" for "FhirPathDisplay" must resolve to a single element. \
16
+ Received ${value.length} elements \
17
+ [${JSON.stringify(value, null, 2)}]`);
18
+ }
19
+ return React.createElement(ResourcePropertyDisplay, { value: value[0] || '', propertyType: props.propertyType });
20
+ }
21
+
22
+ export { FhirPathDisplay };
23
+ //# sourceMappingURL=FhirPathDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FhirPathDisplay.js","sources":["../../src/FhirPathDisplay.tsx"],"sourcesContent":["import { evalFhirPath, PropertyType } from '@medplum/core';\nimport { Resource } from '@medplum/fhirtypes';\nimport React from 'react';\nimport { ResourcePropertyDisplay } from './ResourcePropertyDisplay';\n\nexport interface FhirPathDisplayProps {\n resource: Resource;\n path: string;\n propertyType: PropertyType;\n}\n\nexport function FhirPathDisplay(props: FhirPathDisplayProps): JSX.Element | null {\n let value;\n\n try {\n value = evalFhirPath(props.path, props.resource);\n } catch (err) {\n console.warn('FhirPathDisplay:', err);\n return null;\n }\n\n if (value.length > 1) {\n throw new Error(\n `Component \"path\" for \"FhirPathDisplay\" must resolve to a single element. \\\n Received ${value.length} elements \\\n [${JSON.stringify(value, null, 2)}]`\n );\n }\n return <ResourcePropertyDisplay value={value[0] || ''} propertyType={props.propertyType} />;\n}\n"],"names":[],"mappings":";;;;AAWM,SAAU,eAAe,CAAC,KAA2B,EAAA;AACzD,IAAA,IAAI,KAAK,CAAC;IAEV,IAAI;QACF,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;AAClD,KAAA;AAAC,IAAA,OAAO,GAAG,EAAE;AACZ,QAAA,OAAO,CAAC,IAAI,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAC;AACtC,QAAA,OAAO,IAAI,CAAC;AACb,KAAA;AAED,IAAA,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;QACpB,MAAM,IAAI,KAAK,CACb,CAAA;AACY,gBAAA,EAAA,KAAK,CAAC,MAAM,CAAA;UACpB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAG,CAAA,CAAA,CACtC,CAAC;AACH,KAAA;AACD,IAAA,OAAO,oBAAC,uBAAuB,EAAA,EAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,YAAY,EAAE,KAAK,CAAC,YAAY,GAAI,CAAC;AAC9F;;;;"}
File without changes
@@ -0,0 +1,117 @@
1
+ import React, { useState, useRef, useEffect } from 'react';
2
+ import { Button } from './Button.js';
3
+ import { FhirPathDisplay } from './FhirPathDisplay.js';
4
+ import { Loading } from './Loading.js';
5
+ import { useMedplum } from './MedplumProvider.js';
6
+ import { SearchClickEvent } from './SearchControl.js';
7
+ import { killEvent, isCheckboxCell } from './utils/dom.js';
8
+
9
+ /**
10
+ * The FhirPathTable component represents the embeddable search table control.
11
+ */
12
+ function FhirPathTable(props) {
13
+ var _a, _b, _c, _d, _e;
14
+ const medplum = useMedplum();
15
+ const [schema, setSchema] = useState();
16
+ const [outcome, setOutcome] = useState();
17
+ const { query, fields } = props;
18
+ const [response, setResponse] = useState();
19
+ const [selected, setSelected] = useState({});
20
+ const responseRef = useRef();
21
+ responseRef.current = response;
22
+ const selectedRef = useRef({});
23
+ selectedRef.current = selected;
24
+ useEffect(() => {
25
+ setOutcome(undefined);
26
+ medplum.graphql(query).then(setResponse).catch(setOutcome);
27
+ }, [medplum, query]);
28
+ function handleSingleCheckboxClick(e, id) {
29
+ e.stopPropagation();
30
+ const el = e.target;
31
+ const checked = el.checked;
32
+ const newSelected = Object.assign({}, selectedRef.current);
33
+ if (checked) {
34
+ newSelected[id] = true;
35
+ }
36
+ else {
37
+ delete newSelected[id];
38
+ }
39
+ setSelected(newSelected);
40
+ }
41
+ function handleAllCheckboxClick(e) {
42
+ var _a, _b;
43
+ e.stopPropagation();
44
+ const el = e.target;
45
+ const checked = el.checked;
46
+ const newSelected = {};
47
+ const resources = (_b = (_a = responseRef.current) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.ResourceList;
48
+ if (checked && resources) {
49
+ resources.forEach((resource) => {
50
+ if (resource === null || resource === void 0 ? void 0 : resource.id) {
51
+ newSelected[resource.id] = true;
52
+ }
53
+ });
54
+ }
55
+ setSelected(newSelected);
56
+ }
57
+ function isAllSelected() {
58
+ var _a, _b;
59
+ const resources = (_b = (_a = responseRef.current) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.ResourceList;
60
+ if (!resources || resources.length === 0) {
61
+ return false;
62
+ }
63
+ for (const resource of resources) {
64
+ if ((resource === null || resource === void 0 ? void 0 : resource.id) && !selectedRef.current[resource.id]) {
65
+ return false;
66
+ }
67
+ }
68
+ return true;
69
+ }
70
+ function handleRowClick(e, resource) {
71
+ if (isCheckboxCell(e.target)) {
72
+ // Ignore clicks on checkboxes
73
+ return;
74
+ }
75
+ killEvent(e);
76
+ if (e.button !== 1 && props.onClick) {
77
+ props.onClick(new SearchClickEvent(resource, e));
78
+ }
79
+ if (e.button === 1 && props.onAuxClick) {
80
+ props.onAuxClick(new SearchClickEvent(resource, e));
81
+ }
82
+ }
83
+ useEffect(() => {
84
+ medplum.requestSchema(props.resourceType).then((newSchema) => {
85
+ // The schema could have the same object identity,
86
+ // so need to use the spread operator to kick React re-render.
87
+ setSchema(Object.assign({}, newSchema));
88
+ });
89
+ }, [medplum, props.resourceType]);
90
+ const typeSchema = (_a = schema === null || schema === void 0 ? void 0 : schema.types) === null || _a === void 0 ? void 0 : _a[props.resourceType];
91
+ if (!typeSchema) {
92
+ return React.createElement(Loading, null);
93
+ }
94
+ const checkboxColumn = props.checkboxesEnabled;
95
+ return (React.createElement("div", { className: "medplum-search-control", onContextMenu: (e) => killEvent(e), "data-testid": "search-control" },
96
+ React.createElement("table", null,
97
+ React.createElement("thead", null,
98
+ React.createElement("tr", null,
99
+ checkboxColumn && (React.createElement("th", { className: "medplum-search-icon-cell" },
100
+ React.createElement("input", { type: "checkbox", value: "checked", "aria-label": "all-checkbox", "data-testid": "all-checkbox", checked: isAllSelected(), onChange: (e) => handleAllCheckboxClick(e) }))),
101
+ fields.map((field) => (React.createElement("th", { key: field.name }, field.name))))),
102
+ React.createElement("tbody", null, (_c = (_b = response === null || response === void 0 ? void 0 : response.data) === null || _b === void 0 ? void 0 : _b.ResourceList) === null || _c === void 0 ? void 0 : _c.map((resource) => resource && (React.createElement("tr", { key: resource.id, "data-testid": "search-control-row", onClick: (e) => handleRowClick(e, resource), onAuxClick: (e) => handleRowClick(e, resource) },
103
+ checkboxColumn && (React.createElement("td", { className: "medplum-search-icon-cell" },
104
+ React.createElement("input", { type: "checkbox", value: "checked", "data-testid": "row-checkbox", "aria-label": `Checkbox for ${resource.id}`, checked: !!selected[resource.id], onChange: (e) => handleSingleCheckboxClick(e, resource.id) }))),
105
+ fields.map((field) => {
106
+ return (React.createElement("td", { key: field.name },
107
+ React.createElement(FhirPathDisplay, { propertyType: field.propertyType, path: field.fhirPath, resource: resource })));
108
+ })))))),
109
+ ((_e = (_d = response === null || response === void 0 ? void 0 : response.data) === null || _d === void 0 ? void 0 : _d.ResourceList) === null || _e === void 0 ? void 0 : _e.length) === 0 && (React.createElement("div", { "data-testid": "empty-search", className: "medplum-empty-search" }, "No results")),
110
+ outcome && (React.createElement("div", { "data-testid": "search-error", className: "medplum-empty-search" },
111
+ React.createElement("pre", { style: { textAlign: 'left' } }, JSON.stringify(outcome, undefined, 2)))),
112
+ props.onBulk && (React.createElement(Button, { size: "small", onClick: () => props.onBulk(Object.keys(selectedRef.current)) }, "Bulk..."))));
113
+ }
114
+ const MemoizedFhirPathTable = React.memo(FhirPathTable);
115
+
116
+ export { FhirPathTable, MemoizedFhirPathTable };
117
+ //# sourceMappingURL=FhirPathTable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FhirPathTable.js","sources":["../../src/FhirPathTable.tsx"],"sourcesContent":["import { IndexedStructureDefinition, PropertyType } from '@medplum/core';\nimport { OperationOutcome, Resource } from '@medplum/fhirtypes';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { Button } from './Button';\nimport { FhirPathDisplay } from './FhirPathDisplay';\nimport { Loading } from './Loading';\nimport { useMedplum } from './MedplumProvider';\nimport { SearchClickEvent } from './SearchControl';\nimport { isCheckboxCell, killEvent } from './utils/dom';\nimport './SearchControl.css';\n\nexport interface SmartSearchField {\n readonly propertyType: PropertyType;\n readonly name: string;\n readonly fhirPath: string;\n}\n\nexport interface FhirPathTableProps {\n resourceType: string;\n query: string;\n fields: SmartSearchField[];\n checkboxesEnabled?: boolean;\n onClick?: (e: SearchClickEvent) => void;\n onAuxClick?: (e: SearchClickEvent) => void;\n onBulk?: (ids: string[]) => void;\n}\n\nexport interface SmartSearchResponse {\n data: {\n ResourceList: Resource[];\n };\n}\n\n/**\n * The FhirPathTable component represents the embeddable search table control.\n */\nexport function FhirPathTable(props: FhirPathTableProps): JSX.Element {\n const medplum = useMedplum();\n const [schema, setSchema] = useState<IndexedStructureDefinition | undefined>();\n const [outcome, setOutcome] = useState<OperationOutcome | undefined>();\n const { query, fields } = props;\n const [response, setResponse] = useState<SmartSearchResponse | undefined>();\n const [selected, setSelected] = useState<{ [id: string]: boolean }>({});\n\n const responseRef = useRef<SmartSearchResponse>();\n responseRef.current = response;\n\n const selectedRef = useRef<{ [id: string]: boolean }>({});\n selectedRef.current = selected;\n\n useEffect(() => {\n setOutcome(undefined);\n medplum.graphql(query).then(setResponse).catch(setOutcome);\n }, [medplum, query]);\n\n function handleSingleCheckboxClick(e: React.ChangeEvent, id: string): void {\n e.stopPropagation();\n\n const el = e.target as HTMLInputElement;\n const checked = el.checked;\n const newSelected = { ...selectedRef.current };\n if (checked) {\n newSelected[id] = true;\n } else {\n delete newSelected[id];\n }\n setSelected(newSelected);\n }\n\n function handleAllCheckboxClick(e: React.ChangeEvent): void {\n e.stopPropagation();\n\n const el = e.target as HTMLInputElement;\n const checked = el.checked;\n const newSelected = {} as { [id: string]: boolean };\n const resources = responseRef.current?.data?.ResourceList;\n if (checked && resources) {\n resources.forEach((resource) => {\n if (resource?.id) {\n newSelected[resource.id] = true;\n }\n });\n }\n setSelected(newSelected);\n }\n\n function isAllSelected(): boolean {\n const resources = responseRef.current?.data?.ResourceList;\n if (!resources || resources.length === 0) {\n return false;\n }\n for (const resource of resources) {\n if (resource?.id && !selectedRef.current[resource.id]) {\n return false;\n }\n }\n return true;\n }\n\n function handleRowClick(e: React.MouseEvent, resource: Resource): void {\n if (isCheckboxCell(e.target as Element)) {\n // Ignore clicks on checkboxes\n return;\n }\n\n killEvent(e);\n\n if (e.button !== 1 && props.onClick) {\n props.onClick(new SearchClickEvent(resource, e));\n }\n\n if (e.button === 1 && props.onAuxClick) {\n props.onAuxClick(new SearchClickEvent(resource, e));\n }\n }\n\n useEffect(() => {\n medplum.requestSchema(props.resourceType).then((newSchema) => {\n // The schema could have the same object identity,\n // so need to use the spread operator to kick React re-render.\n setSchema({ ...newSchema });\n });\n }, [medplum, props.resourceType]);\n\n const typeSchema = schema?.types?.[props.resourceType];\n if (!typeSchema) {\n return <Loading />;\n }\n\n const checkboxColumn = props.checkboxesEnabled;\n\n return (\n <div className=\"medplum-search-control\" onContextMenu={(e) => killEvent(e)} data-testid=\"search-control\">\n <table>\n <thead>\n <tr>\n {checkboxColumn && (\n <th className=\"medplum-search-icon-cell\">\n <input\n type=\"checkbox\"\n value=\"checked\"\n aria-label=\"all-checkbox\"\n data-testid=\"all-checkbox\"\n checked={isAllSelected()}\n onChange={(e) => handleAllCheckboxClick(e)}\n />\n </th>\n )}\n {fields.map((field) => (\n <th key={field.name}>{field.name}</th>\n ))}\n </tr>\n </thead>\n <tbody>\n {response?.data?.ResourceList?.map(\n (resource) =>\n resource && (\n <tr\n key={resource.id}\n data-testid=\"search-control-row\"\n onClick={(e) => handleRowClick(e, resource)}\n onAuxClick={(e) => handleRowClick(e, resource)}\n >\n {checkboxColumn && (\n <td className=\"medplum-search-icon-cell\">\n <input\n type=\"checkbox\"\n value=\"checked\"\n data-testid=\"row-checkbox\"\n aria-label={`Checkbox for ${resource.id}`}\n checked={!!selected[resource.id as string]}\n onChange={(e) => handleSingleCheckboxClick(e, resource.id as string)}\n />\n </td>\n )}\n {fields.map((field) => {\n return (\n <td key={field.name}>\n <FhirPathDisplay propertyType={field.propertyType} path={field.fhirPath} resource={resource} />\n </td>\n );\n })}\n </tr>\n )\n )}\n </tbody>\n </table>\n {response?.data?.ResourceList?.length === 0 && (\n <div data-testid=\"empty-search\" className=\"medplum-empty-search\">\n No results\n </div>\n )}\n {outcome && (\n <div data-testid=\"search-error\" className=\"medplum-empty-search\">\n <pre style={{ textAlign: 'left' }}>{JSON.stringify(outcome, undefined, 2)}</pre>\n </div>\n )}\n {props.onBulk && (\n <Button size=\"small\" onClick={() => (props.onBulk as (ids: string[]) => any)(Object.keys(selectedRef.current))}>\n Bulk...\n </Button>\n )}\n </div>\n );\n}\n\nexport const MemoizedFhirPathTable = React.memo(FhirPathTable);\n"],"names":[],"mappings":"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"}
File without changes
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+
3
+ function FooterLinks(props) {
4
+ return React.createElement("div", { className: "medplum-footer" }, props.children);
5
+ }
6
+
7
+ export { FooterLinks };
8
+ //# sourceMappingURL=FooterLinks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FooterLinks.js","sources":["../../src/FooterLinks.tsx"],"sourcesContent":["import React from 'react';\nimport './FooterLinks.css';\n\nexport interface FooterLinksProps {\n children?: React.ReactNode;\n}\n\nexport function FooterLinks(props: FooterLinksProps): JSX.Element {\n return <div className=\"medplum-footer\">{props.children}</div>;\n}\n"],"names":[],"mappings":";;AAOM,SAAU,WAAW,CAAC,KAAuB,EAAA;IACjD,OAAO,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,gBAAgB,IAAE,KAAK,CAAC,QAAQ,CAAO,CAAC;AAChE;;;;"}
File without changes
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { parseForm } from './FormUtils.js';
3
+
4
+ function Form(props) {
5
+ return (React.createElement("form", { style: props.style, "data-testid": props.testid, onSubmit: (e) => {
6
+ e.preventDefault();
7
+ const formData = parseForm(e.target);
8
+ if (props.onSubmit) {
9
+ props.onSubmit(formData);
10
+ }
11
+ } }, props.children));
12
+ }
13
+
14
+ export { Form };
15
+ //# sourceMappingURL=Form.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Form.js","sources":["../../src/Form.tsx"],"sourcesContent":["import React, { CSSProperties } from 'react';\nimport { parseForm } from './FormUtils';\n\nexport interface FormProps {\n onSubmit?: (formData: Record<string, string>) => void;\n style?: CSSProperties;\n children?: React.ReactNode;\n testid?: string;\n}\n\nexport function Form(props: FormProps): JSX.Element {\n return (\n <form\n style={props.style}\n data-testid={props.testid}\n onSubmit={(e: React.SyntheticEvent) => {\n e.preventDefault();\n const formData = parseForm(e.target as HTMLFormElement);\n if (props.onSubmit) {\n props.onSubmit(formData);\n }\n }}\n >\n {props.children}\n </form>\n );\n}\n"],"names":[],"mappings":";;;AAUM,SAAU,IAAI,CAAC,KAAgB,EAAA;AACnC,IAAA,QACE,KACE,CAAA,aAAA,CAAA,MAAA,EAAA,EAAA,KAAK,EAAE,KAAK,CAAC,KAAK,EAAA,aAAA,EACL,KAAK,CAAC,MAAM,EACzB,QAAQ,EAAE,CAAC,CAAuB,KAAI;YACpC,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,MAAM,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC,MAAyB,CAAC,CAAC;YACxD,IAAI,KAAK,CAAC,QAAQ,EAAE;AAClB,gBAAA,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAC1B,aAAA;AACH,SAAC,IAEA,KAAK,CAAC,QAAQ,CACV,EACP;AACJ;;;;"}
File without changes
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import { getIssuesForExpression } from './utils/outcomes.js';
3
+
4
+ function FormSection(props) {
5
+ const issues = getIssuesForExpression(props.outcome, props.htmlFor);
6
+ const invalid = issues && issues.length > 0;
7
+ return (React.createElement("fieldset", { className: "medplum-form-section" },
8
+ props.title && React.createElement("label", { htmlFor: props.htmlFor }, props.title),
9
+ props.description && React.createElement("p", null, props.description),
10
+ props.children,
11
+ invalid && (React.createElement("div", { id: props.htmlFor + '-errors', className: "medplum-input-error" }, issues === null || issues === void 0 ? void 0 : issues.map((issue) => {
12
+ var _a, _b;
13
+ return (React.createElement("div", { "data-testid": "text-field-error", key: (_a = issue.details) === null || _a === void 0 ? void 0 : _a.text }, (_b = issue.details) === null || _b === void 0 ? void 0 : _b.text));
14
+ })))));
15
+ }
16
+
17
+ export { FormSection };
18
+ //# sourceMappingURL=FormSection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormSection.js","sources":["../../src/FormSection.tsx"],"sourcesContent":["import { OperationOutcome } from '@medplum/fhirtypes';\nimport React from 'react';\nimport { getIssuesForExpression } from './utils/outcomes';\nimport './FormSection.css';\n\nexport interface FormSectionProps {\n title?: string;\n htmlFor?: string;\n description?: string;\n outcome?: OperationOutcome;\n children?: React.ReactNode;\n}\n\nexport function FormSection(props: FormSectionProps): JSX.Element {\n const issues = getIssuesForExpression(props.outcome, props.htmlFor);\n const invalid = issues && issues.length > 0;\n return (\n <fieldset className=\"medplum-form-section\">\n {props.title && <label htmlFor={props.htmlFor}>{props.title}</label>}\n {props.description && <p>{props.description}</p>}\n {props.children}\n {invalid && (\n <div id={props.htmlFor + '-errors'} className=\"medplum-input-error\">\n {issues?.map((issue) => (\n <div data-testid=\"text-field-error\" key={issue.details?.text}>\n {issue.details?.text}\n </div>\n ))}\n </div>\n )}\n </fieldset>\n );\n}\n"],"names":[],"mappings":";;;AAaM,SAAU,WAAW,CAAC,KAAuB,EAAA;AACjD,IAAA,MAAM,MAAM,GAAG,sBAAsB,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;IACpE,MAAM,OAAO,GAAG,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;AAC5C,IAAA,QACE,KAAA,CAAA,aAAA,CAAA,UAAA,EAAA,EAAU,SAAS,EAAC,sBAAsB,EAAA;AACvC,QAAA,KAAK,CAAC,KAAK,IAAI,KAAA,CAAA,aAAA,CAAA,OAAA,EAAA,EAAO,OAAO,EAAE,KAAK,CAAC,OAAO,EAAA,EAAG,KAAK,CAAC,KAAK,CAAS;AACnE,QAAA,KAAK,CAAC,WAAW,IAAI,+BAAI,KAAK,CAAC,WAAW,CAAK;AAC/C,QAAA,KAAK,CAAC,QAAQ;QACd,OAAO,KACN,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,EAAE,EAAE,KAAK,CAAC,OAAO,GAAG,SAAS,EAAE,SAAS,EAAC,qBAAqB,EAChE,EAAA,MAAM,KAAN,IAAA,IAAA,MAAM,KAAN,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,MAAM,CAAE,GAAG,CAAC,CAAC,KAAK,KAAI;;YAAC,QACtB,4CAAiB,kBAAkB,EAAC,GAAG,EAAE,CAAA,EAAA,GAAA,KAAK,CAAC,OAAO,0CAAE,IAAI,EAAA,EACzD,MAAA,KAAK,CAAC,OAAO,MAAE,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAI,CAChB,EACP;AAAA,SAAA,CAAC,CACE,CACP,CACQ,EACX;AACJ;;;;"}
File without changes
@@ -0,0 +1,49 @@
1
+ /**
2
+ * Parses an HTML form and returns the result as a JavaScript object.
3
+ * @param form The HTML form element.
4
+ */
5
+ function parseForm(form) {
6
+ const result = {};
7
+ for (const element of Array.from(form.elements)) {
8
+ if (element instanceof HTMLInputElement) {
9
+ parseInputElement(result, element);
10
+ }
11
+ else if (element instanceof HTMLTextAreaElement) {
12
+ result[element.name] = element.value;
13
+ }
14
+ else if (element instanceof HTMLSelectElement) {
15
+ parseSelectElement(result, element);
16
+ }
17
+ }
18
+ return result;
19
+ }
20
+ /**
21
+ * Parses an HTML input element.
22
+ * Sets the name/value pair in the result,
23
+ * but only if the element is enabled and checked.
24
+ * @param el The input element.
25
+ * @param result The result builder.
26
+ */
27
+ function parseInputElement(result, el) {
28
+ if (el.disabled) {
29
+ // Ignore disabled elements
30
+ return;
31
+ }
32
+ if ((el.type === 'checkbox' || el.type === 'radio') && !el.checked) {
33
+ // Ignore unchecked radio or checkbox elements
34
+ return;
35
+ }
36
+ result[el.name] = el.value;
37
+ }
38
+ /**
39
+ * Parses an HTML select element.
40
+ * Sets the name/value pair if one is selected.
41
+ * @param result The result builder.
42
+ * @param el The select element.
43
+ */
44
+ function parseSelectElement(result, el) {
45
+ result[el.name] = el.value;
46
+ }
47
+
48
+ export { parseForm };
49
+ //# sourceMappingURL=FormUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormUtils.js","sources":["../../src/FormUtils.ts"],"sourcesContent":["/**\n * Parses an HTML form and returns the result as a JavaScript object.\n * @param form The HTML form element.\n */\nexport function parseForm(form: HTMLFormElement): Record<string, string> {\n const result: Record<string, string> = {};\n\n for (const element of Array.from(form.elements)) {\n if (element instanceof HTMLInputElement) {\n parseInputElement(result, element);\n } else if (element instanceof HTMLTextAreaElement) {\n result[element.name] = element.value;\n } else if (element instanceof HTMLSelectElement) {\n parseSelectElement(result, element);\n }\n }\n\n return result;\n}\n\n/**\n * Parses an HTML input element.\n * Sets the name/value pair in the result,\n * but only if the element is enabled and checked.\n * @param el The input element.\n * @param result The result builder.\n */\nfunction parseInputElement(result: Record<string, string>, el: HTMLInputElement): void {\n if (el.disabled) {\n // Ignore disabled elements\n return;\n }\n\n if ((el.type === 'checkbox' || el.type === 'radio') && !el.checked) {\n // Ignore unchecked radio or checkbox elements\n return;\n }\n\n result[el.name] = el.value;\n}\n\n/**\n * Parses an HTML select element.\n * Sets the name/value pair if one is selected.\n * @param result The result builder.\n * @param el The select element.\n */\nfunction parseSelectElement(result: Record<string, string>, el: HTMLSelectElement): void {\n result[el.name] = el.value;\n}\n"],"names":[],"mappings":"AAAA;;;AAGG;AACG,SAAU,SAAS,CAAC,IAAqB,EAAA;IAC7C,MAAM,MAAM,GAA2B,EAAE,CAAC;IAE1C,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;QAC/C,IAAI,OAAO,YAAY,gBAAgB,EAAE;AACvC,YAAA,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACpC,SAAA;aAAM,IAAI,OAAO,YAAY,mBAAmB,EAAE;YACjD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC;AACtC,SAAA;aAAM,IAAI,OAAO,YAAY,iBAAiB,EAAE;AAC/C,YAAA,kBAAkB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AACrC,SAAA;AACF,KAAA;AAED,IAAA,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;;;;AAMG;AACH,SAAS,iBAAiB,CAAC,MAA8B,EAAE,EAAoB,EAAA;IAC7E,IAAI,EAAE,CAAC,QAAQ,EAAE;;QAEf,OAAO;AACR,KAAA;AAED,IAAA,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,UAAU,IAAI,EAAE,CAAC,IAAI,KAAK,OAAO,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE;;QAElE,OAAO;AACR,KAAA;IAED,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;AAC7B,CAAC;AAED;;;;;AAKG;AACH,SAAS,kBAAkB,CAAC,MAA8B,EAAE,EAAqB,EAAA;IAC/E,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;AAC7B;;;;"}
File without changes
@@ -0,0 +1,48 @@
1
+ import React, { useRef, useState, useEffect } from 'react';
2
+ import { useMedplum } from './MedplumProvider.js';
3
+ import { createScriptTag } from './utils.js';
4
+
5
+ function GoogleButton(props) {
6
+ const medplum = useMedplum();
7
+ const { googleClientId, handleGoogleCredential } = props;
8
+ const parentRef = useRef(null);
9
+ const [scriptLoaded, setScriptLoaded] = useState(typeof google !== 'undefined');
10
+ const [initialized, setInitialized] = useState(false);
11
+ const [buttonRendered, setButtonRendered] = useState(false);
12
+ useEffect(() => {
13
+ if (typeof google === 'undefined') {
14
+ createScriptTag('https://accounts.google.com/gsi/client', () => setScriptLoaded(true));
15
+ return;
16
+ }
17
+ if (!initialized) {
18
+ google.accounts.id.initialize({
19
+ client_id: googleClientId,
20
+ callback: handleGoogleCredential,
21
+ });
22
+ setInitialized(true);
23
+ }
24
+ if (parentRef.current && !buttonRendered) {
25
+ google.accounts.id.renderButton(parentRef.current, {});
26
+ setButtonRendered(true);
27
+ }
28
+ }, [medplum, googleClientId, initialized, scriptLoaded, parentRef, buttonRendered, handleGoogleCredential]);
29
+ if (!googleClientId) {
30
+ return null;
31
+ }
32
+ return React.createElement("div", { ref: parentRef });
33
+ }
34
+ function getGoogleClientId(clientId) {
35
+ var _a, _b;
36
+ if (clientId) {
37
+ return clientId;
38
+ }
39
+ const origin = window.location.protocol + '//' + window.location.host;
40
+ const authorizedOrigins = (_b = (_a = "undefined") === null || _a === void 0 ? void 0 : _a.split(',')) !== null && _b !== void 0 ? _b : [];
41
+ if (authorizedOrigins.includes(origin)) {
42
+ return "undefined";
43
+ }
44
+ return undefined;
45
+ }
46
+
47
+ export { GoogleButton, getGoogleClientId };
48
+ //# sourceMappingURL=GoogleButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GoogleButton.js","sources":["../../src/GoogleButton.tsx"],"sourcesContent":["import { GoogleCredentialResponse } from '@medplum/core';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { useMedplum } from './MedplumProvider';\nimport { createScriptTag } from './utils';\n\ninterface GoogleApi {\n accounts: {\n id: {\n initialize: (args: any) => void;\n renderButton: (parent: HTMLElement, args: any) => void;\n };\n };\n}\n\ndeclare const google: GoogleApi;\n\nexport interface GoogleButtonProps {\n readonly googleClientId?: string;\n readonly handleGoogleCredential: (response: GoogleCredentialResponse) => void;\n}\n\nexport function GoogleButton(props: GoogleButtonProps): JSX.Element | null {\n const medplum = useMedplum();\n const { googleClientId, handleGoogleCredential } = props;\n const parentRef = useRef<HTMLDivElement>(null);\n const [scriptLoaded, setScriptLoaded] = useState<boolean>(typeof google !== 'undefined');\n const [initialized, setInitialized] = useState<boolean>(false);\n const [buttonRendered, setButtonRendered] = useState<boolean>(false);\n\n useEffect(() => {\n if (typeof google === 'undefined') {\n createScriptTag('https://accounts.google.com/gsi/client', () => setScriptLoaded(true));\n return;\n }\n\n if (!initialized) {\n google.accounts.id.initialize({\n client_id: googleClientId,\n callback: handleGoogleCredential,\n });\n setInitialized(true);\n }\n\n if (parentRef.current && !buttonRendered) {\n google.accounts.id.renderButton(parentRef.current, {});\n setButtonRendered(true);\n }\n }, [medplum, googleClientId, initialized, scriptLoaded, parentRef, buttonRendered, handleGoogleCredential]);\n\n if (!googleClientId) {\n return null;\n }\n\n return <div ref={parentRef} />;\n}\n\nexport function getGoogleClientId(clientId: string | undefined): string | undefined {\n if (clientId) {\n return clientId;\n }\n\n const origin = window.location.protocol + '//' + window.location.host;\n const authorizedOrigins = process.env.GOOGLE_AUTH_ORIGINS?.split(',') ?? [];\n if (authorizedOrigins.includes(origin)) {\n return process.env.GOOGLE_CLIENT_ID;\n }\n\n return undefined;\n}\n"],"names":[],"mappings":";;;;AAqBM,SAAU,YAAY,CAAC,KAAwB,EAAA;AACnD,IAAA,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;AAC7B,IAAA,MAAM,EAAE,cAAc,EAAE,sBAAsB,EAAE,GAAG,KAAK,CAAC;AACzD,IAAA,MAAM,SAAS,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;AAC/C,IAAA,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAU,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC;IACzF,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAC/D,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAErE,SAAS,CAAC,MAAK;AACb,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;YACjC,eAAe,CAAC,wCAAwC,EAAE,MAAM,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC;YACvF,OAAO;AACR,SAAA;QAED,IAAI,CAAC,WAAW,EAAE;AAChB,YAAA,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,UAAU,CAAC;AAC5B,gBAAA,SAAS,EAAE,cAAc;AACzB,gBAAA,QAAQ,EAAE,sBAAsB;AACjC,aAAA,CAAC,CAAC;YACH,cAAc,CAAC,IAAI,CAAC,CAAC;AACtB,SAAA;AAED,QAAA,IAAI,SAAS,CAAC,OAAO,IAAI,CAAC,cAAc,EAAE;AACxC,YAAA,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACvD,iBAAiB,CAAC,IAAI,CAAC,CAAC;AACzB,SAAA;AACH,KAAC,EAAE,CAAC,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,cAAc,EAAE,sBAAsB,CAAC,CAAC,CAAC;IAE5G,IAAI,CAAC,cAAc,EAAE;AACnB,QAAA,OAAO,IAAI,CAAC;AACb,KAAA;AAED,IAAA,OAAO,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,SAAS,GAAI,CAAC;AACjC,CAAC;AAEK,SAAU,iBAAiB,CAAC,QAA4B,EAAA;;AAC5D,IAAA,IAAI,QAAQ,EAAE;AACZ,QAAA,OAAO,QAAQ,CAAC;AACjB,KAAA;AAED,IAAA,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,GAAG,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AACtE,IAAA,MAAM,iBAAiB,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,WAA+B,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAE,KAAK,CAAC,GAAG,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,EAAE,CAAC;AAC5E,IAAA,IAAI,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;AACtC,QAAA,OAAO,WAA4B,CAAC;AACrC,KAAA;AAED,IAAA,OAAO,SAAS,CAAC;AACnB;;;;"}
File without changes
@@ -0,0 +1,95 @@
1
+ import { getReferenceString } from '@medplum/core';
2
+ import React, { useState } from 'react';
3
+ import { useNavigate, useLocation } from 'react-router-dom';
4
+ import { Avatar } from './Avatar.js';
5
+ import { Button } from './Button.js';
6
+ import { HeaderSearchInput } from './HeaderSearchInput.js';
7
+ import { HumanNameDisplay } from './HumanNameDisplay.js';
8
+ import { MedplumLink } from './MedplumLink.js';
9
+ import { useMedplumContext } from './MedplumProvider.js';
10
+ import { Popup } from './Popup.js';
11
+
12
+ function Header(props) {
13
+ var _a, _b, _c, _d, _e, _f;
14
+ const navigate = useNavigate();
15
+ const location = useLocation();
16
+ const context = useMedplumContext();
17
+ const medplum = context.medplum;
18
+ const logins = medplum.getLogins();
19
+ const [userMenuVisible, setUserMenuVisible] = useState(false);
20
+ const [sidebarVisible, setSidebarVisible] = useState(false);
21
+ return (React.createElement(React.Fragment, null,
22
+ React.createElement("header", { role: "banner", "data-testid": "header", style: { background: props.bgColor } },
23
+ React.createElement("div", null,
24
+ React.createElement(MedplumLink, { label: "Toggle sidebar", testid: "header-menu-button", onClick: () => setSidebarVisible(!sidebarVisible) },
25
+ React.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", style: { width: 20, height: 20, verticalAlign: 'text-top' }, viewBox: "0 0 20 20", fill: "currentColor" },
26
+ React.createElement("path", { fillRule: "evenodd", d: "M3 5a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 10a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 15a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1z", clipRule: "evenodd" }))),
27
+ React.createElement(MedplumLink, { id: "medplum-header-logo", testid: "header-logo", onClick: props.onLogo }, props.title || 'Medplum'),
28
+ context.profile && (React.createElement(HeaderSearchInput, { key: `header-input-${location.pathname}`, name: "search", className: "medplum-nav-search-container", placeholder: "Search", onChange: (resource) => navigate(`/${resource.resourceType}/${resource.id}`) }))),
29
+ context.profile && (React.createElement("div", { className: "medplum-nav-menu-container" },
30
+ React.createElement(MedplumLink, { testid: "header-profile-menu-button", onClick: () => setUserMenuVisible(true) },
31
+ React.createElement(Avatar, { size: "small", color: "#f68d42", value: context.profile })),
32
+ React.createElement(Popup, { visible: userMenuVisible, autoClose: true, activeClassName: "medplum-nav-menu-popover", onClose: () => setUserMenuVisible(false) },
33
+ React.createElement("div", { className: "medplum-nav-menu" },
34
+ React.createElement("div", { style: { margin: 'auto', padding: '8px' } },
35
+ React.createElement(Avatar, { size: "large", value: context.profile })),
36
+ React.createElement("div", { style: { margin: 'auto', padding: '8px' } },
37
+ React.createElement("div", { style: { margin: '4px auto 4px auto', fontWeight: 'bold' } },
38
+ React.createElement(HumanNameDisplay, { value: (_b = (_a = context.profile) === null || _a === void 0 ? void 0 : _a.name) === null || _b === void 0 ? void 0 : _b[0] })),
39
+ React.createElement("div", { style: { margin: '4px auto 4px auto' } }, (_d = (_c = medplum.getActiveLogin()) === null || _c === void 0 ? void 0 : _c.project) === null || _d === void 0 ? void 0 : _d.display),
40
+ React.createElement(Button, { testid: "header-profile-link", onClick: () => {
41
+ setUserMenuVisible(false);
42
+ if (props.onProfile) {
43
+ props.onProfile();
44
+ }
45
+ } }, "Manage your account")),
46
+ logins.length > 1 && (React.createElement("div", null,
47
+ React.createElement("hr", null),
48
+ logins.map((login) => {
49
+ var _a, _b, _c, _d;
50
+ return ((_a = login.profile) === null || _a === void 0 ? void 0 : _a.reference) !== getReferenceString(context.profile) && (React.createElement("div", { className: "medplum-nav-menu-profile", key: (_b = login.profile) === null || _b === void 0 ? void 0 : _b.reference, onClick: () => {
51
+ medplum.setActiveLogin(login);
52
+ setUserMenuVisible(false);
53
+ window.location.reload();
54
+ } },
55
+ React.createElement("div", { className: "medplum-nav-menu-profile-icon" },
56
+ React.createElement(Avatar, null)),
57
+ React.createElement("div", { className: "medplum-nav-menu-profile-label" }, (_c = login.profile) === null || _c === void 0 ? void 0 :
58
+ _c.display,
59
+ React.createElement("div", { className: "medplum-nav-menu-profile-help-text" }, (_d = login.project) === null || _d === void 0 ? void 0 : _d.display))));
60
+ }))),
61
+ React.createElement("hr", null),
62
+ React.createElement("div", { style: { margin: 'auto', padding: '8px' } },
63
+ React.createElement(Button, { testid: "header-add-account-button", onClick: () => {
64
+ navigate('/signin');
65
+ } }, "Add another account")),
66
+ React.createElement("hr", null),
67
+ React.createElement("div", { style: { margin: 'auto', padding: '8px' } },
68
+ React.createElement(Button, { testid: "header-signout-button", onClick: () => {
69
+ setUserMenuVisible(false);
70
+ if (props.onSignOut) {
71
+ props.onSignOut();
72
+ }
73
+ } }, "Sign out of all accounts")),
74
+ React.createElement("hr", null),
75
+ React.createElement("div", { style: { margin: 'auto', padding: '8px', fontSize: '12px' } },
76
+ React.createElement("a", { href: "https://www.medplum.com/terms" }, "Terms"),
77
+ React.createElement("a", { href: "https://www.medplum.com/privacy" }, "Privacy"))))))),
78
+ React.createElement(Popup, { modal: true, autoClose: true, visible: sidebarVisible, activeClassName: "medplum-sidebar active", inactiveClassName: "medplum-sidebar", onClose: () => setSidebarVisible(false) }, (_f = (_e = props.config) === null || _e === void 0 ? void 0 : _e.menu) === null || _f === void 0 ? void 0 :
79
+ _f.map((menu, index) => {
80
+ var _a, _b, _c;
81
+ return (React.createElement(React.Fragment, { key: `menu-${index}-${(_b = (_a = props.config) === null || _a === void 0 ? void 0 : _a.menu) === null || _b === void 0 ? void 0 : _b.length}` },
82
+ React.createElement("h5", null, menu.title),
83
+ React.createElement("ul", null, (_c = menu.link) === null || _c === void 0 ? void 0 : _c.map((link) => (React.createElement("li", { key: link.target },
84
+ React.createElement(MedplumLink, { to: link.target }, link.name)))))));
85
+ }),
86
+ React.createElement("h5", null, "Settings"),
87
+ React.createElement("ul", null,
88
+ React.createElement("li", null,
89
+ React.createElement(MedplumLink, { to: context.profile }, "Profile")),
90
+ React.createElement("li", null,
91
+ React.createElement(MedplumLink, { to: "/changepassword" }, "Change password"))))));
92
+ }
93
+
94
+ export { Header };
95
+ //# sourceMappingURL=Header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.js","sources":["../../src/Header.tsx"],"sourcesContent":["import { getReferenceString, ProfileResource } from '@medplum/core';\nimport { HumanName, UserConfiguration } from '@medplum/fhirtypes';\nimport React, { useState } from 'react';\nimport { useLocation, useNavigate } from 'react-router-dom';\nimport { Avatar } from './Avatar';\nimport { Button } from './Button';\nimport { HeaderSearchInput, HeaderSearchTypes } from './HeaderSearchInput';\nimport { HumanNameDisplay } from './HumanNameDisplay';\nimport { MedplumLink } from './MedplumLink';\nimport { useMedplumContext } from './MedplumProvider';\nimport { Popup } from './Popup';\nimport './Header.css';\n\nexport interface HeaderProps {\n readonly title?: string;\n readonly bgColor?: string;\n readonly onLogo?: () => void;\n readonly onProfile?: () => void;\n readonly onSignOut?: () => void;\n readonly config?: UserConfiguration;\n}\n\nexport function Header(props: HeaderProps): JSX.Element {\n const navigate = useNavigate();\n const location = useLocation();\n const context = useMedplumContext();\n const medplum = context.medplum;\n const logins = medplum.getLogins();\n const [userMenuVisible, setUserMenuVisible] = useState(false);\n const [sidebarVisible, setSidebarVisible] = useState(false);\n\n return (\n <>\n <header role=\"banner\" data-testid=\"header\" style={{ background: props.bgColor }}>\n <div>\n <MedplumLink\n label=\"Toggle sidebar\"\n testid=\"header-menu-button\"\n onClick={() => setSidebarVisible(!sidebarVisible)}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{ width: 20, height: 20, verticalAlign: 'text-top' }}\n viewBox=\"0 0 20 20\"\n fill=\"currentColor\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M3 5a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 10a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 15a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1z\"\n clipRule=\"evenodd\"\n />\n </svg>\n </MedplumLink>\n <MedplumLink id=\"medplum-header-logo\" testid=\"header-logo\" onClick={props.onLogo}>\n {props.title || 'Medplum'}\n </MedplumLink>\n {context.profile && (\n <HeaderSearchInput\n key={`header-input-${location.pathname}`}\n name=\"search\"\n className=\"medplum-nav-search-container\"\n placeholder=\"Search\"\n onChange={(resource: HeaderSearchTypes) => navigate(`/${resource.resourceType}/${resource.id}`)}\n />\n )}\n </div>\n {context.profile && (\n <div className=\"medplum-nav-menu-container\">\n <MedplumLink testid=\"header-profile-menu-button\" onClick={() => setUserMenuVisible(true)}>\n <Avatar size=\"small\" color=\"#f68d42\" value={context.profile} />\n </MedplumLink>\n <Popup\n visible={userMenuVisible}\n autoClose={true}\n activeClassName=\"medplum-nav-menu-popover\"\n onClose={() => setUserMenuVisible(false)}\n >\n <div className=\"medplum-nav-menu\">\n <div style={{ margin: 'auto', padding: '8px' }}>\n <Avatar size=\"large\" value={context.profile} />\n </div>\n <div style={{ margin: 'auto', padding: '8px' }}>\n <div style={{ margin: '4px auto 4px auto', fontWeight: 'bold' }}>\n <HumanNameDisplay value={context.profile?.name?.[0] as HumanName} />\n </div>\n <div style={{ margin: '4px auto 4px auto' }}>{medplum.getActiveLogin()?.project?.display}</div>\n <Button\n testid=\"header-profile-link\"\n onClick={() => {\n setUserMenuVisible(false);\n if (props.onProfile) {\n props.onProfile();\n }\n }}\n >\n Manage your account\n </Button>\n </div>\n {logins.length > 1 && (\n <div>\n <hr />\n {logins.map(\n (login) =>\n login.profile?.reference !== getReferenceString(context.profile as ProfileResource) && (\n <div\n className=\"medplum-nav-menu-profile\"\n key={login.profile?.reference}\n onClick={() => {\n medplum.setActiveLogin(login);\n setUserMenuVisible(false);\n window.location.reload();\n }}\n >\n <div className=\"medplum-nav-menu-profile-icon\">\n <Avatar />\n </div>\n <div className=\"medplum-nav-menu-profile-label\">\n {login.profile?.display}\n <div className=\"medplum-nav-menu-profile-help-text\">{login.project?.display}</div>\n </div>\n </div>\n )\n )}\n </div>\n )}\n <hr />\n <div style={{ margin: 'auto', padding: '8px' }}>\n <Button\n testid=\"header-add-account-button\"\n onClick={() => {\n navigate('/signin');\n }}\n >\n Add another account\n </Button>\n </div>\n <hr />\n <div style={{ margin: 'auto', padding: '8px' }}>\n <Button\n testid=\"header-signout-button\"\n onClick={() => {\n setUserMenuVisible(false);\n if (props.onSignOut) {\n props.onSignOut();\n }\n }}\n >\n Sign out of all accounts\n </Button>\n </div>\n <hr />\n <div style={{ margin: 'auto', padding: '8px', fontSize: '12px' }}>\n <a href=\"https://www.medplum.com/terms\">Terms</a>\n <a href=\"https://www.medplum.com/privacy\">Privacy</a>\n </div>\n </div>\n </Popup>\n </div>\n )}\n </header>\n <Popup\n modal={true}\n autoClose={true}\n visible={sidebarVisible}\n activeClassName=\"medplum-sidebar active\"\n inactiveClassName=\"medplum-sidebar\"\n onClose={() => setSidebarVisible(false)}\n >\n {props.config?.menu?.map((menu, index) => (\n <React.Fragment key={`menu-${index}-${props.config?.menu?.length}`}>\n <h5>{menu.title}</h5>\n <ul>\n {menu.link?.map((link) => (\n <li key={link.target}>\n <MedplumLink to={link.target}>{link.name}</MedplumLink>\n </li>\n ))}\n </ul>\n </React.Fragment>\n ))}\n <h5>Settings</h5>\n <ul>\n <li>\n <MedplumLink to={context.profile}>Profile</MedplumLink>\n </li>\n <li>\n <MedplumLink to=\"/changepassword\">Change password</MedplumLink>\n </li>\n </ul>\n </Popup>\n </>\n );\n}\n"],"names":[],"mappings":"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"}
File without changes