@health-samurai/react-components 0.0.0-alpha.2 → 0.0.0-alpha.21

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 (571) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +102 -1
  3. package/dist/bundle.css +2349 -754
  4. package/dist/src/components/button-dropdown.d.ts +10 -0
  5. package/dist/src/components/button-dropdown.d.ts.map +1 -0
  6. package/dist/src/components/button-dropdown.js +70 -0
  7. package/dist/src/components/button-dropdown.js.map +1 -0
  8. package/dist/src/components/button-dropdown.stories.js +48 -0
  9. package/dist/src/components/button-dropdown.stories.js.map +1 -0
  10. package/dist/src/components/code-editor/fhir-autocomplete.d.ts +70 -0
  11. package/dist/src/components/code-editor/fhir-autocomplete.d.ts.map +1 -0
  12. package/dist/src/components/code-editor/fhir-autocomplete.js +1850 -0
  13. package/dist/src/components/code-editor/fhir-autocomplete.js.map +1 -0
  14. package/dist/src/components/code-editor/fhir-autocomplete.test.js +1099 -0
  15. package/dist/src/components/code-editor/fhir-autocomplete.test.js.map +1 -0
  16. package/dist/src/components/code-editor/http/grammar/http.d.ts +3 -0
  17. package/dist/src/components/code-editor/http/grammar/http.d.ts.map +1 -0
  18. package/dist/src/components/code-editor/http/grammar/http.grammar +74 -0
  19. package/dist/src/components/code-editor/http/grammar/http.js +38 -0
  20. package/dist/src/components/code-editor/http/grammar/http.js.map +1 -0
  21. package/dist/src/components/code-editor/http/grammar/http.terms.d.ts +2 -0
  22. package/dist/src/components/code-editor/http/grammar/http.terms.d.ts.map +1 -0
  23. package/dist/src/components/code-editor/http/grammar/http.terms.js +4 -0
  24. package/dist/src/components/code-editor/http/grammar/http.terms.js.map +1 -0
  25. package/dist/src/components/code-editor/http/grammar/http.test.js +80 -0
  26. package/dist/src/components/code-editor/http/grammar/http.test.js.map +1 -0
  27. package/dist/src/components/code-editor/http/index.d.ts +12 -0
  28. package/dist/src/components/code-editor/http/index.d.ts.map +1 -0
  29. package/dist/src/components/code-editor/http/index.js +486 -0
  30. package/dist/src/components/code-editor/http/index.js.map +1 -0
  31. package/dist/src/components/code-editor/index.d.ts +39 -1
  32. package/dist/src/components/code-editor/index.d.ts.map +1 -1
  33. package/dist/src/components/code-editor/index.js +1792 -45
  34. package/dist/src/components/code-editor/index.js.map +1 -1
  35. package/dist/src/components/code-editor/json-ast.d.ts +46 -0
  36. package/dist/src/components/code-editor/json-ast.d.ts.map +1 -0
  37. package/dist/src/components/code-editor/json-ast.js +465 -0
  38. package/dist/src/components/code-editor/json-ast.js.map +1 -0
  39. package/dist/src/components/code-editor/json-ast.test.js +206 -0
  40. package/dist/src/components/code-editor/json-ast.test.js.map +1 -0
  41. package/dist/src/components/code-editor/sql-completion.d.ts +22 -0
  42. package/dist/src/components/code-editor/sql-completion.d.ts.map +1 -0
  43. package/dist/src/components/code-editor/sql-completion.js +897 -0
  44. package/dist/src/components/code-editor/sql-completion.js.map +1 -0
  45. package/dist/src/components/code-editor.stories.js +280 -3
  46. package/dist/src/components/code-editor.stories.js.map +1 -1
  47. package/dist/src/components/copy-icon.d.ts +5 -1
  48. package/dist/src/components/copy-icon.d.ts.map +1 -1
  49. package/dist/src/components/copy-icon.js +41 -3
  50. package/dist/src/components/copy-icon.js.map +1 -1
  51. package/dist/src/components/data-table.d.ts +9 -0
  52. package/dist/src/components/data-table.d.ts.map +1 -0
  53. package/dist/src/components/data-table.js +66 -0
  54. package/dist/src/components/data-table.js.map +1 -0
  55. package/dist/src/components/data-table.stories.js +240 -0
  56. package/dist/src/components/data-table.stories.js.map +1 -0
  57. package/dist/src/components/date-picker-input.d.ts +10 -0
  58. package/dist/src/components/date-picker-input.d.ts.map +1 -0
  59. package/dist/src/components/date-picker-input.js +90 -0
  60. package/dist/src/components/date-picker-input.js.map +1 -0
  61. package/dist/src/components/date-picker-input.stories.js +76 -0
  62. package/dist/src/components/date-picker-input.stories.js.map +1 -0
  63. package/dist/src/components/fhir-structure-view.d.ts +34 -0
  64. package/dist/src/components/fhir-structure-view.d.ts.map +1 -0
  65. package/dist/src/components/fhir-structure-view.js +230 -0
  66. package/dist/src/components/fhir-structure-view.js.map +1 -0
  67. package/dist/src/components/fhir-structure-view.stories.js +447 -0
  68. package/dist/src/components/fhir-structure-view.stories.js.map +1 -0
  69. package/dist/src/components/icon-button.d.ts +12 -0
  70. package/dist/src/components/icon-button.d.ts.map +1 -0
  71. package/dist/src/components/icon-button.js +41 -0
  72. package/dist/src/components/icon-button.js.map +1 -0
  73. package/dist/src/components/icon-button.stories.js +157 -0
  74. package/dist/src/components/icon-button.stories.js.map +1 -0
  75. package/dist/src/components/operation-outcome-view.d.ts +27 -0
  76. package/dist/src/components/operation-outcome-view.d.ts.map +1 -0
  77. package/dist/src/components/operation-outcome-view.js +198 -0
  78. package/dist/src/components/operation-outcome-view.js.map +1 -0
  79. package/dist/src/components/operation-outcome-view.stories.js +207 -0
  80. package/dist/src/components/operation-outcome-view.stories.js.map +1 -0
  81. package/dist/src/components/request-line-editor.d.ts +13 -35
  82. package/dist/src/components/request-line-editor.d.ts.map +1 -1
  83. package/dist/src/components/request-line-editor.js +73 -49
  84. package/dist/src/components/request-line-editor.js.map +1 -1
  85. package/dist/src/components/request-line-editor.stories.js +17 -53
  86. package/dist/src/components/request-line-editor.stories.js.map +1 -1
  87. package/dist/src/components/sandbox.d.ts +13 -0
  88. package/dist/src/components/sandbox.d.ts.map +1 -0
  89. package/dist/src/components/sandbox.js +107 -0
  90. package/dist/src/components/sandbox.js.map +1 -0
  91. package/dist/src/components/sandbox.stories.js +126 -0
  92. package/dist/src/components/sandbox.stories.js.map +1 -0
  93. package/dist/src/components/segment-control.d.ts +13 -0
  94. package/dist/src/components/segment-control.d.ts.map +1 -0
  95. package/dist/src/components/segment-control.js +33 -0
  96. package/dist/src/components/segment-control.js.map +1 -0
  97. package/dist/src/components/segment-control.stories.js +68 -0
  98. package/dist/src/components/segment-control.stories.js.map +1 -0
  99. package/dist/src/components/split-button.d.ts +12 -0
  100. package/dist/src/components/split-button.d.ts.map +1 -0
  101. package/dist/src/components/split-button.js +33 -0
  102. package/dist/src/components/split-button.js.map +1 -0
  103. package/dist/src/components/split-button.stories.js +84 -0
  104. package/dist/src/components/split-button.stories.js.map +1 -0
  105. package/dist/src/components/tag.d.ts +16 -0
  106. package/dist/src/components/tag.d.ts.map +1 -0
  107. package/dist/src/components/tag.js +198 -0
  108. package/dist/src/components/tag.js.map +1 -0
  109. package/dist/src/components/tag.stories.js +459 -0
  110. package/dist/src/components/tag.stories.js.map +1 -0
  111. package/dist/src/components/tile.d.ts +15 -0
  112. package/dist/src/components/tile.d.ts.map +1 -0
  113. package/dist/src/components/tile.js +76 -0
  114. package/dist/src/components/tile.js.map +1 -0
  115. package/dist/src/components/tile.stories.js +167 -0
  116. package/dist/src/components/tile.stories.js.map +1 -0
  117. package/dist/src/components/toolbar.d.ts +18 -0
  118. package/dist/src/components/toolbar.d.ts.map +1 -0
  119. package/dist/src/components/toolbar.js +61 -0
  120. package/dist/src/components/toolbar.js.map +1 -0
  121. package/dist/src/components/toolbar.stories.js +69 -0
  122. package/dist/src/components/toolbar.stories.js.map +1 -0
  123. package/dist/src/components/tree-view.d.ts +47 -0
  124. package/dist/src/components/tree-view.d.ts.map +1 -0
  125. package/dist/src/components/tree-view.js +122 -0
  126. package/dist/src/components/tree-view.js.map +1 -0
  127. package/dist/src/components/tree-view.stories.js +283 -0
  128. package/dist/src/components/tree-view.stories.js.map +1 -0
  129. package/dist/src/icons.d.ts +11 -0
  130. package/dist/src/icons.d.ts.map +1 -0
  131. package/dist/src/icons.js +328 -0
  132. package/dist/src/icons.js.map +1 -0
  133. package/dist/src/index.css +358 -74
  134. package/dist/src/index.d.ts +17 -1
  135. package/dist/src/index.d.ts.map +1 -1
  136. package/dist/src/index.js +17 -1
  137. package/dist/src/index.js.map +1 -1
  138. package/dist/src/shadcn/components/ui/accordion.d.ts +2 -2
  139. package/dist/src/shadcn/components/ui/accordion.d.ts.map +1 -1
  140. package/dist/src/shadcn/components/ui/accordion.js +35 -9
  141. package/dist/src/shadcn/components/ui/accordion.js.map +1 -1
  142. package/dist/src/shadcn/components/ui/alert-dialog.d.ts +12 -4
  143. package/dist/src/shadcn/components/ui/alert-dialog.d.ts.map +1 -1
  144. package/dist/src/shadcn/components/ui/alert-dialog.js +128 -18
  145. package/dist/src/shadcn/components/ui/alert-dialog.js.map +1 -1
  146. package/dist/src/shadcn/components/ui/alert-dialog.stories.js +269 -19
  147. package/dist/src/shadcn/components/ui/alert-dialog.stories.js.map +1 -1
  148. package/dist/src/shadcn/components/ui/alert.d.ts +29 -6
  149. package/dist/src/shadcn/components/ui/alert.d.ts.map +1 -1
  150. package/dist/src/shadcn/components/ui/alert.js +50 -19
  151. package/dist/src/shadcn/components/ui/alert.js.map +1 -1
  152. package/dist/src/shadcn/components/ui/alert.stories.js +140 -36
  153. package/dist/src/shadcn/components/ui/alert.stories.js.map +1 -1
  154. package/dist/src/shadcn/components/ui/aspect-ratio.d.ts.map +1 -1
  155. package/dist/src/shadcn/components/ui/aspect-ratio.js +1 -0
  156. package/dist/src/shadcn/components/ui/aspect-ratio.js.map +1 -1
  157. package/dist/src/shadcn/components/ui/avatar.d.ts.map +1 -1
  158. package/dist/src/shadcn/components/ui/avatar.js +4 -3
  159. package/dist/src/shadcn/components/ui/avatar.js.map +1 -1
  160. package/dist/src/shadcn/components/ui/avatar.stories.js +68 -2
  161. package/dist/src/shadcn/components/ui/avatar.stories.js.map +1 -1
  162. package/dist/src/shadcn/components/ui/badge.d.ts +1 -1
  163. package/dist/src/shadcn/components/ui/badge.d.ts.map +1 -1
  164. package/dist/src/shadcn/components/ui/badge.js +16 -5
  165. package/dist/src/shadcn/components/ui/badge.js.map +1 -1
  166. package/dist/src/shadcn/components/ui/breadcrumb.d.ts +5 -2
  167. package/dist/src/shadcn/components/ui/breadcrumb.d.ts.map +1 -1
  168. package/dist/src/shadcn/components/ui/breadcrumb.js +98 -13
  169. package/dist/src/shadcn/components/ui/breadcrumb.js.map +1 -1
  170. package/dist/src/shadcn/components/ui/breadcrumb.stories.js +205 -45
  171. package/dist/src/shadcn/components/ui/breadcrumb.stories.js.map +1 -1
  172. package/dist/src/shadcn/components/ui/button.d.ts.map +1 -1
  173. package/dist/src/shadcn/components/ui/button.js +65 -11
  174. package/dist/src/shadcn/components/ui/button.js.map +1 -1
  175. package/dist/src/shadcn/components/ui/button.stories.js +99 -17
  176. package/dist/src/shadcn/components/ui/button.stories.js.map +1 -1
  177. package/dist/src/shadcn/components/ui/calendar.d.ts +1 -1
  178. package/dist/src/shadcn/components/ui/calendar.d.ts.map +1 -1
  179. package/dist/src/shadcn/components/ui/calendar.js +1 -0
  180. package/dist/src/shadcn/components/ui/calendar.js.map +1 -1
  181. package/dist/src/shadcn/components/ui/card.d.ts +5 -1
  182. package/dist/src/shadcn/components/ui/card.d.ts.map +1 -1
  183. package/dist/src/shadcn/components/ui/card.js +28 -7
  184. package/dist/src/shadcn/components/ui/card.js.map +1 -1
  185. package/dist/src/shadcn/components/ui/card.stories.js +23 -2
  186. package/dist/src/shadcn/components/ui/card.stories.js.map +1 -1
  187. package/dist/src/shadcn/components/ui/carousel.d.ts +1 -1
  188. package/dist/src/shadcn/components/ui/carousel.d.ts.map +1 -1
  189. package/dist/src/shadcn/components/ui/carousel.js +1 -0
  190. package/dist/src/shadcn/components/ui/carousel.js.map +1 -1
  191. package/dist/src/shadcn/components/ui/chart.d.ts +5 -5
  192. package/dist/src/shadcn/components/ui/chart.d.ts.map +1 -1
  193. package/dist/src/shadcn/components/ui/chart.js +4 -3
  194. package/dist/src/shadcn/components/ui/chart.js.map +1 -1
  195. package/dist/src/shadcn/components/ui/checkbox.d.ts +5 -1
  196. package/dist/src/shadcn/components/ui/checkbox.d.ts.map +1 -1
  197. package/dist/src/shadcn/components/ui/checkbox.js +46 -6
  198. package/dist/src/shadcn/components/ui/checkbox.js.map +1 -1
  199. package/dist/src/shadcn/components/ui/checkbox.stories.js +156 -46
  200. package/dist/src/shadcn/components/ui/checkbox.stories.js.map +1 -1
  201. package/dist/src/shadcn/components/ui/combobox.d.ts +29 -0
  202. package/dist/src/shadcn/components/ui/combobox.d.ts.map +1 -0
  203. package/dist/src/shadcn/components/ui/combobox.js +226 -0
  204. package/dist/src/shadcn/components/ui/combobox.js.map +1 -0
  205. package/dist/src/shadcn/components/ui/combobox.stories.js +167 -0
  206. package/dist/src/shadcn/components/ui/combobox.stories.js.map +1 -0
  207. package/dist/src/shadcn/components/ui/command.d.ts +4 -2
  208. package/dist/src/shadcn/components/ui/command.d.ts.map +1 -1
  209. package/dist/src/shadcn/components/ui/command.js +75 -13
  210. package/dist/src/shadcn/components/ui/command.js.map +1 -1
  211. package/dist/src/shadcn/components/ui/command.stories.js +277 -57
  212. package/dist/src/shadcn/components/ui/command.stories.js.map +1 -1
  213. package/dist/src/shadcn/components/ui/context-menu.d.ts +7 -3
  214. package/dist/src/shadcn/components/ui/context-menu.d.ts.map +1 -1
  215. package/dist/src/shadcn/components/ui/context-menu.js +120 -13
  216. package/dist/src/shadcn/components/ui/context-menu.js.map +1 -1
  217. package/dist/src/shadcn/components/ui/dialog.d.ts.map +1 -1
  218. package/dist/src/shadcn/components/ui/dialog.js +35 -7
  219. package/dist/src/shadcn/components/ui/dialog.js.map +1 -1
  220. package/dist/src/shadcn/components/ui/drawer.d.ts.map +1 -1
  221. package/dist/src/shadcn/components/ui/drawer.js +27 -5
  222. package/dist/src/shadcn/components/ui/drawer.js.map +1 -1
  223. package/dist/src/shadcn/components/ui/dropdown-menu.d.ts +7 -3
  224. package/dist/src/shadcn/components/ui/dropdown-menu.d.ts.map +1 -1
  225. package/dist/src/shadcn/components/ui/dropdown-menu.js +122 -14
  226. package/dist/src/shadcn/components/ui/dropdown-menu.js.map +1 -1
  227. package/dist/src/shadcn/components/ui/dropdown-menu.stories.js +22 -5
  228. package/dist/src/shadcn/components/ui/dropdown-menu.stories.js.map +1 -1
  229. package/dist/src/shadcn/components/ui/form.d.ts +2 -2
  230. package/dist/src/shadcn/components/ui/form.d.ts.map +1 -1
  231. package/dist/src/shadcn/components/ui/form.js +17 -8
  232. package/dist/src/shadcn/components/ui/form.js.map +1 -1
  233. package/dist/src/shadcn/components/ui/hover-card.d.ts.map +1 -1
  234. package/dist/src/shadcn/components/ui/hover-card.js +2 -1
  235. package/dist/src/shadcn/components/ui/hover-card.js.map +1 -1
  236. package/dist/src/shadcn/components/ui/input-otp.d.ts.map +1 -1
  237. package/dist/src/shadcn/components/ui/input-otp.js +1 -0
  238. package/dist/src/shadcn/components/ui/input-otp.js.map +1 -1
  239. package/dist/src/shadcn/components/ui/input.d.ts +3 -1
  240. package/dist/src/shadcn/components/ui/input.d.ts.map +1 -1
  241. package/dist/src/shadcn/components/ui/input.js +126 -17
  242. package/dist/src/shadcn/components/ui/input.js.map +1 -1
  243. package/dist/src/shadcn/components/ui/input.stories.js +218 -29
  244. package/dist/src/shadcn/components/ui/input.stories.js.map +1 -1
  245. package/dist/src/shadcn/components/ui/label.d.ts.map +1 -1
  246. package/dist/src/shadcn/components/ui/label.js +9 -1
  247. package/dist/src/shadcn/components/ui/label.js.map +1 -1
  248. package/dist/src/shadcn/components/ui/menubar.d.ts.map +1 -1
  249. package/dist/src/shadcn/components/ui/menubar.js +35 -13
  250. package/dist/src/shadcn/components/ui/menubar.js.map +1 -1
  251. package/dist/src/shadcn/components/ui/pagination.d.ts +9 -2
  252. package/dist/src/shadcn/components/ui/pagination.d.ts.map +1 -1
  253. package/dist/src/shadcn/components/ui/pagination.js +41 -24
  254. package/dist/src/shadcn/components/ui/pagination.js.map +1 -1
  255. package/dist/src/shadcn/components/ui/pagination.stories.js +44 -37
  256. package/dist/src/shadcn/components/ui/pagination.stories.js.map +1 -1
  257. package/dist/src/shadcn/components/ui/popover.d.ts.map +1 -1
  258. package/dist/src/shadcn/components/ui/popover.js +13 -1
  259. package/dist/src/shadcn/components/ui/popover.js.map +1 -1
  260. package/dist/src/shadcn/components/ui/progress.d.ts.map +1 -1
  261. package/dist/src/shadcn/components/ui/progress.js +6 -2
  262. package/dist/src/shadcn/components/ui/progress.js.map +1 -1
  263. package/dist/src/shadcn/components/ui/radio-button-group.d.ts +21 -0
  264. package/dist/src/shadcn/components/ui/radio-button-group.d.ts.map +1 -0
  265. package/dist/src/shadcn/components/ui/radio-button-group.js +148 -0
  266. package/dist/src/shadcn/components/ui/radio-button-group.js.map +1 -0
  267. package/dist/src/shadcn/components/ui/radio-button-group.stories.js +283 -0
  268. package/dist/src/shadcn/components/ui/radio-button-group.stories.js.map +1 -0
  269. package/dist/src/shadcn/components/ui/radio-group.d.ts +5 -1
  270. package/dist/src/shadcn/components/ui/radio-group.d.ts.map +1 -1
  271. package/dist/src/shadcn/components/ui/radio-group.js +40 -7
  272. package/dist/src/shadcn/components/ui/radio-group.js.map +1 -1
  273. package/dist/src/shadcn/components/ui/radio-group.stories.js +107 -32
  274. package/dist/src/shadcn/components/ui/radio-group.stories.js.map +1 -1
  275. package/dist/src/shadcn/components/ui/resizable.d.ts.map +1 -1
  276. package/dist/src/shadcn/components/ui/resizable.js +2 -1
  277. package/dist/src/shadcn/components/ui/resizable.js.map +1 -1
  278. package/dist/src/shadcn/components/ui/resizable.stories.js +2 -2
  279. package/dist/src/shadcn/components/ui/resizable.stories.js.map +1 -1
  280. package/dist/src/shadcn/components/ui/scroll-area.d.ts.map +1 -1
  281. package/dist/src/shadcn/components/ui/scroll-area.js +10 -3
  282. package/dist/src/shadcn/components/ui/scroll-area.js.map +1 -1
  283. package/dist/src/shadcn/components/ui/select.d.ts +1 -2
  284. package/dist/src/shadcn/components/ui/select.d.ts.map +1 -1
  285. package/dist/src/shadcn/components/ui/select.js +49 -19
  286. package/dist/src/shadcn/components/ui/select.js.map +1 -1
  287. package/dist/src/shadcn/components/ui/select.stories.js +193 -70
  288. package/dist/src/shadcn/components/ui/select.stories.js.map +1 -1
  289. package/dist/src/shadcn/components/ui/separator.d.ts.map +1 -1
  290. package/dist/src/shadcn/components/ui/separator.js +8 -1
  291. package/dist/src/shadcn/components/ui/separator.js.map +1 -1
  292. package/dist/src/shadcn/components/ui/sheet.js +1 -1
  293. package/dist/src/shadcn/components/ui/sheet.js.map +1 -1
  294. package/dist/src/shadcn/components/ui/sidebar.d.ts +4 -4
  295. package/dist/src/shadcn/components/ui/sidebar.d.ts.map +1 -1
  296. package/dist/src/shadcn/components/ui/sidebar.js +21 -6
  297. package/dist/src/shadcn/components/ui/sidebar.js.map +1 -1
  298. package/dist/src/shadcn/components/ui/skeleton.d.ts.map +1 -1
  299. package/dist/src/shadcn/components/ui/skeleton.js +3 -1
  300. package/dist/src/shadcn/components/ui/skeleton.js.map +1 -1
  301. package/dist/src/shadcn/components/ui/slider.d.ts.map +1 -1
  302. package/dist/src/shadcn/components/ui/slider.js +35 -4
  303. package/dist/src/shadcn/components/ui/slider.js.map +1 -1
  304. package/dist/src/shadcn/components/ui/sonner.d.ts +24 -2
  305. package/dist/src/shadcn/components/ui/sonner.d.ts.map +1 -1
  306. package/dist/src/shadcn/components/ui/sonner.js +127 -9
  307. package/dist/src/shadcn/components/ui/sonner.js.map +1 -1
  308. package/dist/src/shadcn/components/ui/sonner.stories.js +251 -12
  309. package/dist/src/shadcn/components/ui/sonner.stories.js.map +1 -1
  310. package/dist/src/shadcn/components/ui/switch.d.ts +7 -1
  311. package/dist/src/shadcn/components/ui/switch.d.ts.map +1 -1
  312. package/dist/src/shadcn/components/ui/switch.js +55 -3
  313. package/dist/src/shadcn/components/ui/switch.js.map +1 -1
  314. package/dist/src/shadcn/components/ui/switch.stories.js +84 -9
  315. package/dist/src/shadcn/components/ui/switch.stories.js.map +1 -1
  316. package/dist/src/shadcn/components/ui/table.d.ts +23 -6
  317. package/dist/src/shadcn/components/ui/table.d.ts.map +1 -1
  318. package/dist/src/shadcn/components/ui/table.js +65 -20
  319. package/dist/src/shadcn/components/ui/table.js.map +1 -1
  320. package/dist/src/shadcn/components/ui/table.stories.js +217 -97
  321. package/dist/src/shadcn/components/ui/table.stories.js.map +1 -1
  322. package/dist/src/shadcn/components/ui/tabs.d.ts +30 -5
  323. package/dist/src/shadcn/components/ui/tabs.d.ts.map +1 -1
  324. package/dist/src/shadcn/components/ui/tabs.js +470 -23
  325. package/dist/src/shadcn/components/ui/tabs.js.map +1 -1
  326. package/dist/src/shadcn/components/ui/tabs.stories.js +405 -181
  327. package/dist/src/shadcn/components/ui/tabs.stories.js.map +1 -1
  328. package/dist/src/shadcn/components/ui/textarea.d.ts +8 -1
  329. package/dist/src/shadcn/components/ui/textarea.d.ts.map +1 -1
  330. package/dist/src/shadcn/components/ui/textarea.js +30 -2
  331. package/dist/src/shadcn/components/ui/textarea.js.map +1 -1
  332. package/dist/src/shadcn/components/ui/textarea.stories.js +85 -4
  333. package/dist/src/shadcn/components/ui/textarea.stories.js.map +1 -1
  334. package/dist/src/shadcn/components/ui/toggle-group.d.ts +3 -3
  335. package/dist/src/shadcn/components/ui/toggle-group.d.ts.map +1 -1
  336. package/dist/src/shadcn/components/ui/toggle-group.js +14 -12
  337. package/dist/src/shadcn/components/ui/toggle-group.js.map +1 -1
  338. package/dist/src/shadcn/components/ui/toggle.d.ts +3 -4
  339. package/dist/src/shadcn/components/ui/toggle.d.ts.map +1 -1
  340. package/dist/src/shadcn/components/ui/toggle.js +44 -16
  341. package/dist/src/shadcn/components/ui/toggle.js.map +1 -1
  342. package/dist/src/shadcn/components/ui/toggle.stories.js +130 -7
  343. package/dist/src/shadcn/components/ui/toggle.stories.js.map +1 -1
  344. package/dist/src/shadcn/components/ui/tooltip.d.ts.map +1 -1
  345. package/dist/src/shadcn/components/ui/tooltip.js +12 -1
  346. package/dist/src/shadcn/components/ui/tooltip.js.map +1 -1
  347. package/dist/src/shadcn/components/ui/tree.d.ts +29 -0
  348. package/dist/src/shadcn/components/ui/tree.d.ts.map +1 -0
  349. package/dist/src/shadcn/components/ui/tree.js +135 -0
  350. package/dist/src/shadcn/components/ui/tree.js.map +1 -0
  351. package/dist/src/shadcn/shadcn.css +4 -4
  352. package/dist/src/tokens.css +50 -20
  353. package/dist/src/typography.css +78 -15
  354. package/package.json +84 -64
  355. package/src/components/button-dropdown.stories.tsx +41 -0
  356. package/src/components/button-dropdown.tsx +97 -0
  357. package/src/components/code-editor/fhir-autocomplete.test.ts +993 -0
  358. package/src/components/code-editor/fhir-autocomplete.ts +2322 -0
  359. package/src/components/code-editor/http/grammar/http.grammar +74 -0
  360. package/src/components/code-editor/http/grammar/http.terms.ts +9 -0
  361. package/src/components/code-editor/http/grammar/http.test.ts +110 -0
  362. package/src/components/code-editor/http/grammar/http.ts +21 -0
  363. package/src/components/code-editor/http/index.ts +424 -0
  364. package/src/components/code-editor/index.tsx +1944 -42
  365. package/src/components/code-editor/json-ast.test.ts +230 -0
  366. package/src/components/code-editor/json-ast.ts +590 -0
  367. package/src/components/code-editor/sql-completion.ts +1112 -0
  368. package/src/components/code-editor.stories.tsx +325 -2
  369. package/src/components/copy-icon.tsx +57 -3
  370. package/src/components/data-table.stories.tsx +91 -0
  371. package/src/components/data-table.tsx +126 -0
  372. package/src/components/date-picker-input.stories.tsx +79 -0
  373. package/src/components/date-picker-input.tsx +104 -0
  374. package/src/components/fhir-structure-view.stories.tsx +439 -0
  375. package/src/components/fhir-structure-view.tsx +233 -0
  376. package/src/components/icon-button.stories.tsx +86 -0
  377. package/src/components/icon-button.tsx +57 -0
  378. package/src/components/operation-outcome-view.stories.tsx +163 -0
  379. package/src/components/operation-outcome-view.tsx +254 -0
  380. package/src/components/request-line-editor.stories.tsx +17 -27
  381. package/src/components/request-line-editor.tsx +103 -61
  382. package/src/components/sandbox.stories.tsx +131 -0
  383. package/src/components/sandbox.tsx +191 -0
  384. package/src/components/segment-control.stories.tsx +61 -0
  385. package/src/components/segment-control.tsx +83 -0
  386. package/src/components/split-button.stories.tsx +68 -0
  387. package/src/components/split-button.tsx +74 -0
  388. package/src/components/tag.stories.tsx +371 -0
  389. package/src/components/tag.tsx +236 -0
  390. package/src/components/tile.stories.tsx +149 -0
  391. package/src/components/tile.tsx +105 -0
  392. package/src/components/toolbar.stories.tsx +64 -0
  393. package/src/components/toolbar.tsx +98 -0
  394. package/src/components/tree-view.stories.tsx +265 -0
  395. package/src/components/tree-view.tsx +246 -0
  396. package/src/icons.tsx +331 -0
  397. package/src/index.css +358 -74
  398. package/src/index.tsx +17 -3
  399. package/src/shadcn/components/ui/accordion.tsx +91 -10
  400. package/src/shadcn/components/ui/alert-dialog.stories.tsx +209 -15
  401. package/src/shadcn/components/ui/alert-dialog.tsx +236 -26
  402. package/src/shadcn/components/ui/alert.stories.tsx +120 -21
  403. package/src/shadcn/components/ui/alert.tsx +125 -28
  404. package/src/shadcn/components/ui/aspect-ratio.tsx +1 -0
  405. package/src/shadcn/components/ui/avatar.stories.tsx +74 -1
  406. package/src/shadcn/components/ui/avatar.tsx +22 -6
  407. package/src/shadcn/components/ui/badge.tsx +67 -18
  408. package/src/shadcn/components/ui/breadcrumb.stories.tsx +161 -41
  409. package/src/shadcn/components/ui/breadcrumb.tsx +172 -23
  410. package/src/shadcn/components/ui/button.stories.tsx +106 -18
  411. package/src/shadcn/components/ui/button.tsx +151 -55
  412. package/src/shadcn/components/ui/calendar.tsx +1 -0
  413. package/src/shadcn/components/ui/card.stories.tsx +17 -3
  414. package/src/shadcn/components/ui/card.tsx +89 -14
  415. package/src/shadcn/components/ui/carousel.tsx +1 -0
  416. package/src/shadcn/components/ui/chart.tsx +9 -5
  417. package/src/shadcn/components/ui/checkbox.stories.tsx +78 -30
  418. package/src/shadcn/components/ui/checkbox.tsx +91 -8
  419. package/src/shadcn/components/ui/combobox.stories.tsx +148 -0
  420. package/src/shadcn/components/ui/combobox.tsx +324 -0
  421. package/src/shadcn/components/ui/command.stories.tsx +184 -39
  422. package/src/shadcn/components/ui/command.tsx +218 -37
  423. package/src/shadcn/components/ui/context-menu.tsx +333 -40
  424. package/src/shadcn/components/ui/dialog.tsx +101 -13
  425. package/src/shadcn/components/ui/drawer.tsx +94 -18
  426. package/src/shadcn/components/ui/dropdown-menu.stories.tsx +18 -2
  427. package/src/shadcn/components/ui/dropdown-menu.tsx +334 -68
  428. package/src/shadcn/components/ui/form.tsx +22 -11
  429. package/src/shadcn/components/ui/hover-card.tsx +2 -1
  430. package/src/shadcn/components/ui/input-otp.tsx +1 -0
  431. package/src/shadcn/components/ui/input.stories.tsx +235 -27
  432. package/src/shadcn/components/ui/input.tsx +400 -29
  433. package/src/shadcn/components/ui/label.tsx +22 -4
  434. package/src/shadcn/components/ui/menubar.tsx +188 -43
  435. package/src/shadcn/components/ui/pagination.stories.tsx +8 -2
  436. package/src/shadcn/components/ui/pagination.tsx +65 -8
  437. package/src/shadcn/components/ui/popover.tsx +36 -4
  438. package/src/shadcn/components/ui/progress.tsx +21 -5
  439. package/src/shadcn/components/ui/radio-button-group.stories.tsx +247 -0
  440. package/src/shadcn/components/ui/radio-button-group.tsx +188 -0
  441. package/src/shadcn/components/ui/radio-group.stories.tsx +70 -14
  442. package/src/shadcn/components/ui/radio-group.tsx +85 -9
  443. package/src/shadcn/components/ui/resizable.stories.tsx +2 -2
  444. package/src/shadcn/components/ui/resizable.tsx +2 -1
  445. package/src/shadcn/components/ui/scroll-area.tsx +34 -5
  446. package/src/shadcn/components/ui/select.stories.tsx +108 -32
  447. package/src/shadcn/components/ui/select.tsx +182 -36
  448. package/src/shadcn/components/ui/separator.tsx +16 -5
  449. package/src/shadcn/components/ui/sheet.tsx +1 -1
  450. package/src/shadcn/components/ui/sidebar.tsx +69 -26
  451. package/src/shadcn/components/ui/skeleton.tsx +4 -1
  452. package/src/shadcn/components/ui/slider.tsx +83 -11
  453. package/src/shadcn/components/ui/sonner.stories.tsx +238 -17
  454. package/src/shadcn/components/ui/sonner.tsx +254 -11
  455. package/src/shadcn/components/ui/switch.stories.tsx +52 -5
  456. package/src/shadcn/components/ui/switch.tsx +92 -7
  457. package/src/shadcn/components/ui/table.stories.tsx +252 -72
  458. package/src/shadcn/components/ui/table.tsx +204 -26
  459. package/src/shadcn/components/ui/tabs.stories.tsx +235 -123
  460. package/src/shadcn/components/ui/tabs.tsx +694 -36
  461. package/src/shadcn/components/ui/textarea.stories.tsx +94 -2
  462. package/src/shadcn/components/ui/textarea.tsx +70 -5
  463. package/src/shadcn/components/ui/toggle-group.tsx +35 -13
  464. package/src/shadcn/components/ui/toggle.stories.tsx +92 -5
  465. package/src/shadcn/components/ui/toggle.tsx +96 -23
  466. package/src/shadcn/components/ui/tooltip.tsx +34 -8
  467. package/src/shadcn/components/ui/tree.tsx +257 -0
  468. package/src/shadcn/shadcn.css +4 -4
  469. package/src/tokens.css +50 -20
  470. package/src/typography.css +78 -15
  471. package/dist/src/components/code-editor.stories.d.ts +0 -7
  472. package/dist/src/components/code-editor.stories.d.ts.map +0 -1
  473. package/dist/src/components/request-line-editor.stories.d.ts +0 -11
  474. package/dist/src/components/request-line-editor.stories.d.ts.map +0 -1
  475. package/dist/src/index.stories.d.ts +0 -14
  476. package/dist/src/index.stories.d.ts.map +0 -1
  477. package/dist/src/index.stories.js +0 -19
  478. package/dist/src/index.stories.js.map +0 -1
  479. package/dist/src/shadcn/components/ui/accordion.stories.d.ts +0 -8
  480. package/dist/src/shadcn/components/ui/accordion.stories.d.ts.map +0 -1
  481. package/dist/src/shadcn/components/ui/alert-dialog.stories.d.ts +0 -8
  482. package/dist/src/shadcn/components/ui/alert-dialog.stories.d.ts.map +0 -1
  483. package/dist/src/shadcn/components/ui/alert.stories.d.ts +0 -8
  484. package/dist/src/shadcn/components/ui/alert.stories.d.ts.map +0 -1
  485. package/dist/src/shadcn/components/ui/aspect-ratio.stories.d.ts +0 -8
  486. package/dist/src/shadcn/components/ui/aspect-ratio.stories.d.ts.map +0 -1
  487. package/dist/src/shadcn/components/ui/avatar.stories.d.ts +0 -8
  488. package/dist/src/shadcn/components/ui/avatar.stories.d.ts.map +0 -1
  489. package/dist/src/shadcn/components/ui/badge.stories.d.ts +0 -8
  490. package/dist/src/shadcn/components/ui/badge.stories.d.ts.map +0 -1
  491. package/dist/src/shadcn/components/ui/breadcrumb.stories.d.ts +0 -8
  492. package/dist/src/shadcn/components/ui/breadcrumb.stories.d.ts.map +0 -1
  493. package/dist/src/shadcn/components/ui/button.stories.d.ts +0 -23
  494. package/dist/src/shadcn/components/ui/button.stories.d.ts.map +0 -1
  495. package/dist/src/shadcn/components/ui/calendar.stories.d.ts +0 -8
  496. package/dist/src/shadcn/components/ui/calendar.stories.d.ts.map +0 -1
  497. package/dist/src/shadcn/components/ui/card.stories.d.ts +0 -8
  498. package/dist/src/shadcn/components/ui/card.stories.d.ts.map +0 -1
  499. package/dist/src/shadcn/components/ui/carousel.stories.d.ts +0 -8
  500. package/dist/src/shadcn/components/ui/carousel.stories.d.ts.map +0 -1
  501. package/dist/src/shadcn/components/ui/chart.stories.d.ts +0 -8
  502. package/dist/src/shadcn/components/ui/chart.stories.d.ts.map +0 -1
  503. package/dist/src/shadcn/components/ui/checkbox.stories.d.ts +0 -8
  504. package/dist/src/shadcn/components/ui/checkbox.stories.d.ts.map +0 -1
  505. package/dist/src/shadcn/components/ui/collapsible.stories.d.ts +0 -8
  506. package/dist/src/shadcn/components/ui/collapsible.stories.d.ts.map +0 -1
  507. package/dist/src/shadcn/components/ui/command.stories.d.ts +0 -8
  508. package/dist/src/shadcn/components/ui/command.stories.d.ts.map +0 -1
  509. package/dist/src/shadcn/components/ui/context-menu.stories.d.ts +0 -8
  510. package/dist/src/shadcn/components/ui/context-menu.stories.d.ts.map +0 -1
  511. package/dist/src/shadcn/components/ui/dialog.stories.d.ts +0 -8
  512. package/dist/src/shadcn/components/ui/dialog.stories.d.ts.map +0 -1
  513. package/dist/src/shadcn/components/ui/drawer.stories.d.ts +0 -8
  514. package/dist/src/shadcn/components/ui/drawer.stories.d.ts.map +0 -1
  515. package/dist/src/shadcn/components/ui/dropdown-menu.stories.d.ts +0 -8
  516. package/dist/src/shadcn/components/ui/dropdown-menu.stories.d.ts.map +0 -1
  517. package/dist/src/shadcn/components/ui/form.stories.d.ts +0 -8
  518. package/dist/src/shadcn/components/ui/form.stories.d.ts.map +0 -1
  519. package/dist/src/shadcn/components/ui/hover-card.stories.d.ts +0 -8
  520. package/dist/src/shadcn/components/ui/hover-card.stories.d.ts.map +0 -1
  521. package/dist/src/shadcn/components/ui/input-otp.stories.d.ts +0 -8
  522. package/dist/src/shadcn/components/ui/input-otp.stories.d.ts.map +0 -1
  523. package/dist/src/shadcn/components/ui/input.stories.d.ts +0 -18
  524. package/dist/src/shadcn/components/ui/input.stories.d.ts.map +0 -1
  525. package/dist/src/shadcn/components/ui/label.stories.d.ts +0 -8
  526. package/dist/src/shadcn/components/ui/label.stories.d.ts.map +0 -1
  527. package/dist/src/shadcn/components/ui/menubar.stories.d.ts +0 -8
  528. package/dist/src/shadcn/components/ui/menubar.stories.d.ts.map +0 -1
  529. package/dist/src/shadcn/components/ui/navigation-menu.stories.d.ts +0 -8
  530. package/dist/src/shadcn/components/ui/navigation-menu.stories.d.ts.map +0 -1
  531. package/dist/src/shadcn/components/ui/pagination.stories.d.ts +0 -8
  532. package/dist/src/shadcn/components/ui/pagination.stories.d.ts.map +0 -1
  533. package/dist/src/shadcn/components/ui/popover.stories.d.ts +0 -8
  534. package/dist/src/shadcn/components/ui/popover.stories.d.ts.map +0 -1
  535. package/dist/src/shadcn/components/ui/progress.stories.d.ts +0 -8
  536. package/dist/src/shadcn/components/ui/progress.stories.d.ts.map +0 -1
  537. package/dist/src/shadcn/components/ui/radio-group.stories.d.ts +0 -8
  538. package/dist/src/shadcn/components/ui/radio-group.stories.d.ts.map +0 -1
  539. package/dist/src/shadcn/components/ui/resizable.stories.d.ts +0 -8
  540. package/dist/src/shadcn/components/ui/resizable.stories.d.ts.map +0 -1
  541. package/dist/src/shadcn/components/ui/scroll-area.stories.d.ts +0 -8
  542. package/dist/src/shadcn/components/ui/scroll-area.stories.d.ts.map +0 -1
  543. package/dist/src/shadcn/components/ui/select.stories.d.ts +0 -11
  544. package/dist/src/shadcn/components/ui/select.stories.d.ts.map +0 -1
  545. package/dist/src/shadcn/components/ui/separator.stories.d.ts +0 -8
  546. package/dist/src/shadcn/components/ui/separator.stories.d.ts.map +0 -1
  547. package/dist/src/shadcn/components/ui/sheet.stories.d.ts +0 -8
  548. package/dist/src/shadcn/components/ui/sheet.stories.d.ts.map +0 -1
  549. package/dist/src/shadcn/components/ui/sidebar.stories.d.ts +0 -11
  550. package/dist/src/shadcn/components/ui/sidebar.stories.d.ts.map +0 -1
  551. package/dist/src/shadcn/components/ui/skeleton.stories.d.ts +0 -8
  552. package/dist/src/shadcn/components/ui/skeleton.stories.d.ts.map +0 -1
  553. package/dist/src/shadcn/components/ui/slider.stories.d.ts +0 -8
  554. package/dist/src/shadcn/components/ui/slider.stories.d.ts.map +0 -1
  555. package/dist/src/shadcn/components/ui/sonner.stories.d.ts +0 -8
  556. package/dist/src/shadcn/components/ui/sonner.stories.d.ts.map +0 -1
  557. package/dist/src/shadcn/components/ui/switch.stories.d.ts +0 -8
  558. package/dist/src/shadcn/components/ui/switch.stories.d.ts.map +0 -1
  559. package/dist/src/shadcn/components/ui/table.stories.d.ts +0 -8
  560. package/dist/src/shadcn/components/ui/table.stories.d.ts.map +0 -1
  561. package/dist/src/shadcn/components/ui/tabs.stories.d.ts +0 -32
  562. package/dist/src/shadcn/components/ui/tabs.stories.d.ts.map +0 -1
  563. package/dist/src/shadcn/components/ui/textarea.stories.d.ts +0 -8
  564. package/dist/src/shadcn/components/ui/textarea.stories.d.ts.map +0 -1
  565. package/dist/src/shadcn/components/ui/toggle-group.stories.d.ts +0 -8
  566. package/dist/src/shadcn/components/ui/toggle-group.stories.d.ts.map +0 -1
  567. package/dist/src/shadcn/components/ui/toggle.stories.d.ts +0 -8
  568. package/dist/src/shadcn/components/ui/toggle.stories.d.ts.map +0 -1
  569. package/dist/src/shadcn/components/ui/tooltip.stories.d.ts +0 -8
  570. package/dist/src/shadcn/components/ui/tooltip.stories.d.ts.map +0 -1
  571. package/src/index.stories.tsx +0 -21
@@ -1,5 +1,13 @@
1
+ import type { EditorView } from "@codemirror/view";
2
+ import {
3
+ AidboxClient,
4
+ BrowserAuthProvider,
5
+ } from "@health-samurai/aidbox-client";
6
+ import { createCodeMirrorLsp } from "@health-samurai/aidbox-fhirpath-lsp";
1
7
  import type { Meta, StoryObj } from "@storybook/react-vite";
2
- import { CodeEditor } from "./code-editor";
8
+ import React from "react";
9
+ import { Input } from "#shadcn/components/ui/input.js";
10
+ import { CodeEditor, EditorInput } from "./code-editor";
3
11
 
4
12
  const meta: Meta<typeof CodeEditor> = {
5
13
  title: "Component/Editor",
@@ -28,7 +36,322 @@ export const Default: Story = {
28
36
  },
29
37
  render: () => (
30
38
  <div className="h-[500px] w-[500px]">
31
- <CodeEditor />
39
+ <CodeEditor mode="http" />
32
40
  </div>
33
41
  ),
34
42
  };
43
+
44
+ type ParsedHeader = {
45
+ name: string;
46
+ nameTrivia: string;
47
+ value: string;
48
+ valueTrivia: string;
49
+ };
50
+
51
+ type Parsed = {
52
+ method: string;
53
+ methodTrivia: string;
54
+ path: string;
55
+ pathTrivia: string;
56
+ headers: ParsedHeader[];
57
+ headersTrivia: string;
58
+ };
59
+
60
+ function parse(query: string): Parsed {
61
+ let hi = 0;
62
+ let lo = 0;
63
+ const res: Parsed = {
64
+ method: "",
65
+ methodTrivia: "",
66
+ path: "",
67
+ pathTrivia: "",
68
+ headers: [],
69
+ headersTrivia: "",
70
+ };
71
+
72
+ // Note that we iterate by code units, but it doesn't change correctness.
73
+ // method
74
+ for (hi = 0; hi < query.length; ++hi) {
75
+ const c = query[hi];
76
+ if (c === " " || c === "\t" || c === "\n") {
77
+ break;
78
+ }
79
+ }
80
+ res.method = query.substring(lo, hi);
81
+ lo = hi;
82
+ if (lo >= query.length) {
83
+ return res;
84
+ }
85
+
86
+ // method trivia
87
+ for (hi = lo; hi < query.length; ++hi) {
88
+ const c = query[hi];
89
+ if (!(c === " " || c === "\t")) {
90
+ break;
91
+ }
92
+ }
93
+ res.methodTrivia = query.substring(lo, hi);
94
+ lo = hi;
95
+ if (lo >= query.length) {
96
+ return res;
97
+ }
98
+
99
+ // path
100
+ for (hi = lo; hi < query.length; ++hi) {
101
+ const c = query[hi];
102
+ if (c === "\n") {
103
+ break;
104
+ }
105
+ }
106
+ res.path = query.substring(lo, hi);
107
+ lo = hi;
108
+ if (lo >= query.length) {
109
+ return res;
110
+ }
111
+
112
+ // path trivia
113
+ if (query[hi] === "\n") {
114
+ hi += 1;
115
+ res.pathTrivia = query.substring(lo, hi);
116
+ }
117
+ lo = hi;
118
+ if (lo >= query.length) {
119
+ return res;
120
+ }
121
+
122
+ // headers
123
+ let header: ParsedHeader = {
124
+ name: "",
125
+ nameTrivia: "",
126
+ value: "",
127
+ valueTrivia: "",
128
+ };
129
+ let headerReady = false;
130
+ // SAFETY: don't decrease hi inside this loop.
131
+ for (hi = lo; hi < query.length; ++hi) {
132
+ if (headerReady) {
133
+ res.headers.push(header);
134
+ }
135
+ header = { name: "", nameTrivia: "", value: "", valueTrivia: "" };
136
+ headerReady = false;
137
+
138
+ if (query[hi] === "\n") {
139
+ // end of headers
140
+ break;
141
+ }
142
+
143
+ // header name
144
+ for (lo = hi; hi < query.length; ++hi) {
145
+ const c = query[hi];
146
+ if (c === " " || c === "\t" || c === "\n" || c === ":") {
147
+ break;
148
+ }
149
+ }
150
+ headerReady = true;
151
+ header.name = query.substring(lo, hi);
152
+ lo = hi;
153
+ if (lo >= query.length) {
154
+ break;
155
+ }
156
+
157
+ // header name trivia
158
+ let colonFound = false;
159
+ for (lo = hi; hi < query.length; ++hi) {
160
+ const c = query[hi];
161
+ if (c === ":" && !colonFound) {
162
+ colonFound = true;
163
+ } else if (!(c === " " || c === "\t")) {
164
+ break;
165
+ }
166
+ }
167
+ header.nameTrivia = query.substring(lo, hi);
168
+ lo = hi;
169
+ if (lo >= query.length) {
170
+ break;
171
+ }
172
+
173
+ // header value
174
+ for (hi = lo; hi < query.length; ++hi) {
175
+ const c = query[hi];
176
+ if (c === "\n") {
177
+ break;
178
+ }
179
+ }
180
+ header.value = query.substring(lo, hi);
181
+ lo = hi;
182
+ if (lo >= query.length) {
183
+ break;
184
+ }
185
+
186
+ // header value trivia
187
+ if (query[hi] === "\n") {
188
+ header.valueTrivia = query.substring(lo, hi + 1);
189
+ }
190
+ lo = hi + 1;
191
+ if (lo >= query.length) {
192
+ break;
193
+ }
194
+ }
195
+ if (headerReady) {
196
+ res.headers.push(header);
197
+ }
198
+
199
+ if (query[hi] === "\n") {
200
+ res.headersTrivia = query.substring(lo, hi + 1);
201
+ }
202
+
203
+ return res;
204
+ }
205
+
206
+ const MethodInput = React.memo(function MethodInput({
207
+ method,
208
+ onMethodChange,
209
+ }: {
210
+ method: string;
211
+ onMethodChange: (ev: React.ChangeEvent<HTMLInputElement>) => void;
212
+ }) {
213
+ return (
214
+ <div className="flex justify-center items-baseline">
215
+ Method:
216
+ <Input
217
+ type="text"
218
+ className="inline"
219
+ value={method}
220
+ onChange={onMethodChange}
221
+ />
222
+ </div>
223
+ );
224
+ });
225
+
226
+ const PathInput = React.memo(function PathInput({
227
+ path,
228
+ onPathChange,
229
+ }: {
230
+ path: string;
231
+ onPathChange: (ev: React.ChangeEvent<HTMLInputElement>) => void;
232
+ }) {
233
+ return (
234
+ <div className="flex justify-center items-baseline">
235
+ {"Path: "}
236
+ <Input
237
+ type="text"
238
+ className="inline"
239
+ value={path}
240
+ onChange={onPathChange}
241
+ />
242
+ </div>
243
+ );
244
+ });
245
+
246
+ function ComplexComp() {
247
+ const [rawQuery, setRawQuery] = React.useState("");
248
+ const parsed = React.useMemo(() => parse(rawQuery), [rawQuery]);
249
+ const parsedRef = React.useRef(parsed);
250
+ React.useEffect(() => {
251
+ parsedRef.current = parsed;
252
+ }, [parsed]);
253
+ const method = React.useMemo(() => parsed.method, [parsed.method]);
254
+ const path = React.useMemo(() => parsed.path, [parsed.path]);
255
+
256
+ const viewRef = React.useRef<EditorView | null>(null);
257
+
258
+ const onMethodChange = React.useCallback(
259
+ (ev: React.ChangeEvent<HTMLInputElement>) => {
260
+ let newVal = ev.target.value;
261
+
262
+ if (newVal.indexOf(" ") !== -1) {
263
+ newVal = newVal.replaceAll(" ", "").replaceAll("\t", "");
264
+ }
265
+
266
+ const view = viewRef.current;
267
+ if (view === null) {
268
+ return null;
269
+ }
270
+
271
+ const from = 0;
272
+ const to = parsedRef.current.method.length;
273
+
274
+ view.dispatch({
275
+ changes: {
276
+ from: from,
277
+ to: to,
278
+ insert: newVal,
279
+ },
280
+ });
281
+ },
282
+ [],
283
+ );
284
+
285
+ const onPathChange = React.useCallback(
286
+ (ev: React.ChangeEvent<HTMLInputElement>) => {
287
+ const newVal = ev.target.value;
288
+
289
+ const view = viewRef.current;
290
+ if (view === null) {
291
+ return null;
292
+ }
293
+
294
+ const from =
295
+ parsedRef.current.method.length + parsedRef.current.methodTrivia.length;
296
+ const to = from + parsedRef.current.path.length;
297
+
298
+ view.dispatch({
299
+ changes: {
300
+ from: from,
301
+ to: to,
302
+ insert: newVal,
303
+ },
304
+ });
305
+ },
306
+ [],
307
+ );
308
+
309
+ return (
310
+ <>
311
+ <MethodInput method={method} onMethodChange={onMethodChange} />
312
+ <PathInput path={path} onPathChange={onPathChange} />
313
+ <div className="h-[500px] w-[500px] border-black border-2">
314
+ <CodeEditor
315
+ mode="http"
316
+ onUpdate={(update) => {
317
+ if (update.docChanged) {
318
+ setRawQuery(update.state.doc.toString());
319
+ }
320
+ }}
321
+ viewCallback={(view) => {
322
+ viewRef.current = view;
323
+ }}
324
+ />
325
+ </div>
326
+ </>
327
+ );
328
+ }
329
+
330
+ export const Complex: Story = {
331
+ render: () => ComplexComp(),
332
+ };
333
+
334
+ function FhirpathComp() {
335
+ const { extension, worker } = React.useMemo(() => {
336
+ const client = new AidboxClient(
337
+ "http://localhost:8765",
338
+ new BrowserAuthProvider("http://localhost:8765"),
339
+ );
340
+ return createCodeMirrorLsp(client, { debug: true });
341
+ }, []);
342
+
343
+ React.useEffect(() => () => worker.terminate(), [worker]);
344
+
345
+ return (
346
+ <div className="h-[500px] w-[500px]">
347
+ <EditorInput
348
+ id="fhirpath-editor-input"
349
+ additionalExtensions={[extension]}
350
+ />
351
+ </div>
352
+ );
353
+ }
354
+
355
+ export const FhirpathExtension: Story = {
356
+ render: () => <FhirpathComp />,
357
+ };
@@ -1,17 +1,53 @@
1
1
  import { Check, Copy } from "lucide-react";
2
2
  import * as React from "react";
3
+ import { toast } from "sonner";
4
+ import {
5
+ Tooltip,
6
+ TooltipContent,
7
+ TooltipTrigger,
8
+ } from "#shadcn/components/ui/tooltip";
3
9
 
4
10
  interface CopyIconProps {
5
11
  text: string;
12
+ showTooltip?: boolean;
13
+ tooltipText?: string;
14
+ showToast?: boolean;
15
+ onCopy?: (text: string) => void;
6
16
  }
7
17
 
8
- function CopyIcon({ text }: CopyIconProps) {
18
+ function CopyIcon({
19
+ text,
20
+ showTooltip = true,
21
+ tooltipText = "Copy",
22
+ showToast = true,
23
+ onCopy,
24
+ ...props
25
+ }: CopyIconProps) {
9
26
  const [isActive, setIsActive] = React.useState(false);
10
27
 
11
28
  async function handleClick() {
12
29
  try {
13
30
  await navigator.clipboard.writeText(text);
14
31
  setIsActive(true);
32
+
33
+ if (showToast) {
34
+ const truncatedText =
35
+ text.length > 30 ? `${text.slice(0, 30)}...` : text;
36
+ toast(
37
+ <div className="flex flex-col gap-1">
38
+ <span className="typo-body">Successfully copied</span>
39
+ <span className="typo-code text-text-secondary">
40
+ {truncatedText}
41
+ </span>
42
+ </div>,
43
+ {
44
+ duration: 2000,
45
+ },
46
+ );
47
+ }
48
+
49
+ onCopy?.(text);
50
+
15
51
  setTimeout(() => {
16
52
  setIsActive(false);
17
53
  }, 1000);
@@ -20,11 +56,29 @@ function CopyIcon({ text }: CopyIconProps) {
20
56
  }
21
57
  }
22
58
 
23
- return (
24
- <button type="button" onClick={handleClick} style={{ cursor: "pointer" }}>
59
+ const button = (
60
+ <button
61
+ {...props}
62
+ type="button"
63
+ onClick={handleClick}
64
+ style={{ cursor: "pointer" }}
65
+ >
25
66
  {isActive ? <Check /> : <Copy />}
26
67
  </button>
27
68
  );
69
+
70
+ if (!showTooltip) {
71
+ return button;
72
+ }
73
+
74
+ return (
75
+ <Tooltip>
76
+ <TooltipTrigger asChild>{button}</TooltipTrigger>
77
+ <TooltipContent>
78
+ <p>{tooltipText}</p>
79
+ </TooltipContent>
80
+ </Tooltip>
81
+ );
28
82
  }
29
83
 
30
84
  export { CopyIcon };
@@ -0,0 +1,91 @@
1
+ import type { Meta, StoryObj } from "@storybook/react-vite";
2
+ import { DataTable, type DataTableProps } from "./data-table";
3
+
4
+ type Data = {
5
+ name: string;
6
+ age: number;
7
+ };
8
+
9
+ const meta: Meta<typeof DataTable<Data>> = {
10
+ title: "Component/Data table",
11
+ component: DataTable<Data>,
12
+ tags: ["autodocs"],
13
+ };
14
+
15
+ export default meta;
16
+ type Story = StoryObj<typeof meta>;
17
+
18
+ function DataTableWrapper({ columns, data }: DataTableProps<Data>) {
19
+ return <DataTable columns={columns} data={data} />;
20
+ }
21
+
22
+ export const Default: Story = {
23
+ args: {
24
+ columns: [
25
+ {
26
+ header: "Name",
27
+ accessorKey: "name",
28
+ },
29
+ {
30
+ header: "Age",
31
+ accessorKey: "age",
32
+ },
33
+ ],
34
+ data: [
35
+ { name: "John Doe", age: 30 },
36
+ { name: "Jane Smith", age: 25 },
37
+ { name: "Bob Johnson", age: 42 },
38
+ { name: "Alice Williams", age: 35 },
39
+ { name: "Charlie Brown", age: 28 },
40
+ { name: "Diana Prince", age: 31 },
41
+ { name: "Edward Norton", age: 45 },
42
+ { name: "Fiona Green", age: 27 },
43
+ { name: "George Miller", age: 38 },
44
+ { name: "Hannah Davis", age: 33 },
45
+ { name: "Ian Moore", age: 29 },
46
+ { name: "Julia Taylor", age: 41 },
47
+ { name: "Kevin Anderson", age: 36 },
48
+ { name: "Laura Thomas", age: 32 },
49
+ { name: "Michael Jackson", age: 44 },
50
+ { name: "Nancy Wilson", age: 26 },
51
+ { name: "Oscar Martinez", age: 39 },
52
+ { name: "Patricia Lee", age: 34 },
53
+ { name: "Quinn Harris", age: 37 },
54
+ { name: "Rachel Clark", age: 40 },
55
+ { name: "Samuel Wright", age: 43 },
56
+ { name: "Tina Turner", age: 48 },
57
+ { name: "Ulysses Grant", age: 52 },
58
+ { name: "Victoria Baker", age: 29 },
59
+ { name: "William Scott", age: 35 },
60
+ { name: "Xavier Adams", age: 31 },
61
+ { name: "Yolanda King", age: 38 },
62
+ { name: "Zachary Nelson", age: 27 },
63
+ { name: "Amy Carter", age: 33 },
64
+ { name: "Benjamin Hall", age: 46 },
65
+ { name: "Catherine Allen", age: 24 },
66
+ { name: "David Young", age: 41 },
67
+ { name: "Emily Walker", age: 36 },
68
+ { name: "Frank Robinson", age: 39 },
69
+ { name: "Grace White", age: 28 },
70
+ { name: "Henry Lewis", age: 47 },
71
+ { name: "Isabella Hill", age: 32 },
72
+ { name: "Jack Martin", age: 34 },
73
+ { name: "Katherine Garcia", age: 30 },
74
+ { name: "Louis Rodriguez", age: 45 },
75
+ { name: "Margaret Martinez", age: 37 },
76
+ { name: "Nathan Hernandez", age: 26 },
77
+ { name: "Olivia Lopez", age: 29 },
78
+ { name: "Peter Gonzalez", age: 43 },
79
+ { name: "Quincy Wilson", age: 38 },
80
+ { name: "Rebecca Anderson", age: 31 },
81
+ { name: "Steven Thomas", age: 44 },
82
+ { name: "Teresa Taylor", age: 35 },
83
+ { name: "Ursula Moore", age: 40 },
84
+ { name: "Victor Jackson", age: 42 },
85
+ ],
86
+ },
87
+ parameters: {
88
+ layout: "fullscreen",
89
+ },
90
+ render: (args) => <DataTableWrapper {...args} />,
91
+ };
@@ -0,0 +1,126 @@
1
+ "use client";
2
+
3
+ import {
4
+ type AccessorKeyColumnDef,
5
+ type ColumnDef,
6
+ flexRender,
7
+ getCoreRowModel,
8
+ useReactTable,
9
+ } from "@tanstack/react-table";
10
+
11
+ import {
12
+ Table,
13
+ TableBody,
14
+ TableCell,
15
+ TableHead,
16
+ TableHeader,
17
+ TableRow,
18
+ } from "../shadcn/components/ui/table";
19
+
20
+ export interface DataTableProps<TData> {
21
+ // It is not possible to allow arbitrary and nested data structures
22
+ // and have more type safety. Note that the useReactTable type definition
23
+ // is exactly the same.
24
+ // There is an open issue: https://github.com/TanStack/table/issues/4382
25
+ // biome-ignore lint/suspicious/noExplicitAny: cannot be stricter while being a useful library
26
+ columns: ColumnDef<TData, any>[];
27
+ data: TData[];
28
+ stickyHeader?: boolean;
29
+ }
30
+
31
+ export function DataTable<TData>({
32
+ columns,
33
+ data,
34
+ stickyHeader = false,
35
+ }: DataTableProps<TData>) {
36
+ "use no memo";
37
+ const table = useReactTable({
38
+ data,
39
+ columns,
40
+ getCoreRowModel: getCoreRowModel(),
41
+ columnResizeMode: "onChange",
42
+ enableColumnResizing: true,
43
+ });
44
+
45
+ return (
46
+ <div className="overflow-hidden w-full h-full">
47
+ <Table className="relative border-spacing-0 border-separate w-full">
48
+ <TableHeader>
49
+ {table.getHeaderGroups().map((headerGroup) => (
50
+ <TableRow key={headerGroup.id}>
51
+ {headerGroup.headers.map((header) => {
52
+ return (
53
+ <TableHead
54
+ key={header.id}
55
+ className={`relative group border ${stickyHeader ? "sticky top-0 z-10 bg-bg-secondary text-elements-assistive" : ""}`}
56
+ style={{
57
+ width:
58
+ header.column.getIndex() ===
59
+ headerGroup.headers.length - 1
60
+ ? "100%"
61
+ : header.getSize(),
62
+ }}
63
+ >
64
+ {header.isPlaceholder
65
+ ? null
66
+ : flexRender(
67
+ header.column.columnDef.header,
68
+ header.getContext(),
69
+ )}
70
+ {header.column.getCanResize() && (
71
+ <div
72
+ {...{
73
+ onMouseDown: header.getResizeHandler(),
74
+ onTouchStart: header.getResizeHandler(),
75
+ className: `hidden group-hover:block absolute top-0 right-0 h-full w-1 bg-border-secondary cursor-col-resize hover:bg-border-secondary`,
76
+ style: {
77
+ userSelect: "none",
78
+ touchAction: "none",
79
+ },
80
+ }}
81
+ />
82
+ )}
83
+ </TableHead>
84
+ );
85
+ })}
86
+ </TableRow>
87
+ ))}
88
+ </TableHeader>
89
+ <TableBody>
90
+ {table.getRowModel().rows?.length ? (
91
+ table.getRowModel().rows.map((row) => (
92
+ <TableRow
93
+ key={row.id}
94
+ data-state={row.getIsSelected() && "selected"}
95
+ >
96
+ {row.getVisibleCells().map((cell) => (
97
+ <TableCell
98
+ className="border"
99
+ key={cell.id}
100
+ style={{
101
+ width:
102
+ cell.column.getIndex() ===
103
+ row.getVisibleCells().length - 1
104
+ ? "100%"
105
+ : cell.column.getSize(),
106
+ }}
107
+ >
108
+ {flexRender(cell.column.columnDef.cell, cell.getContext())}
109
+ </TableCell>
110
+ ))}
111
+ </TableRow>
112
+ ))
113
+ ) : (
114
+ <TableRow>
115
+ <TableCell colSpan={columns.length} className="h-24 text-center">
116
+ No results.
117
+ </TableCell>
118
+ </TableRow>
119
+ )}
120
+ </TableBody>
121
+ </Table>
122
+ </div>
123
+ );
124
+ }
125
+
126
+ export type { ColumnDef, AccessorKeyColumnDef };
@@ -0,0 +1,79 @@
1
+ import type { Meta, StoryObj } from "@storybook/react-vite";
2
+ import { useState } from "react";
3
+ import { DatePickerInput } from "./date-picker-input";
4
+
5
+ function DatePickerInputWrapper(props: {
6
+ placeholder?: string;
7
+ disabled?: boolean;
8
+ }) {
9
+ const [value, setValue] = useState("");
10
+ return (
11
+ <div className="w-48">
12
+ <DatePickerInput value={value} onChange={setValue} {...props} />
13
+ </div>
14
+ );
15
+ }
16
+
17
+ function DatePickerInputPrefilledWrapper() {
18
+ const [value, setValue] = useState("15.06.2025");
19
+ return (
20
+ <div className="w-48">
21
+ <DatePickerInput value={value} onChange={setValue} />
22
+ </div>
23
+ );
24
+ }
25
+
26
+ function DatePickerRangeWrapper() {
27
+ const [from, setFrom] = useState("");
28
+ const [to, setTo] = useState("");
29
+ return (
30
+ <div className="flex items-center gap-2">
31
+ <DatePickerInput
32
+ value={from}
33
+ onChange={setFrom}
34
+ className="w-40"
35
+ placeholder="From"
36
+ />
37
+ <span className="text-text-secondary">—</span>
38
+ <DatePickerInput
39
+ value={to}
40
+ onChange={setTo}
41
+ className="w-40"
42
+ placeholder="To"
43
+ />
44
+ </div>
45
+ );
46
+ }
47
+
48
+ const meta = {
49
+ title: "Component/DatePickerInput",
50
+ component: DatePickerInputWrapper,
51
+ parameters: {
52
+ layout: "centered",
53
+ },
54
+ } satisfies Meta<typeof DatePickerInputWrapper>;
55
+
56
+ export default meta;
57
+ type Story = StoryObj<typeof meta>;
58
+
59
+ export const Default: Story = {};
60
+
61
+ export const WithPlaceholder: Story = {
62
+ args: {
63
+ placeholder: "Select a date...",
64
+ },
65
+ };
66
+
67
+ export const Disabled: Story = {
68
+ args: {
69
+ disabled: true,
70
+ },
71
+ };
72
+
73
+ export const Prefilled: StoryObj = {
74
+ render: () => <DatePickerInputPrefilledWrapper />,
75
+ };
76
+
77
+ export const DateRange: StoryObj = {
78
+ render: () => <DatePickerRangeWrapper />,
79
+ };