@tetrascience-npm/tetrascience-react-ui 0.5.0-beta.20.1 → 0.5.0-beta.22.1

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 (472) hide show
  1. package/dist/components/charts/AreaGraph/AreaGraph.cjs +2 -0
  2. package/dist/components/charts/AreaGraph/AreaGraph.cjs.map +1 -0
  3. package/dist/components/charts/AreaGraph/AreaGraph.js +209 -0
  4. package/dist/components/charts/AreaGraph/AreaGraph.js.map +1 -0
  5. package/dist/components/charts/BarGraph/BarGraph.cjs +2 -0
  6. package/dist/components/charts/BarGraph/BarGraph.cjs.map +1 -0
  7. package/dist/components/charts/BarGraph/BarGraph.js +175 -0
  8. package/dist/components/charts/BarGraph/BarGraph.js.map +1 -0
  9. package/dist/components/charts/Boxplot/Boxplot.cjs +2 -0
  10. package/dist/components/charts/Boxplot/Boxplot.cjs.map +1 -0
  11. package/dist/components/charts/Boxplot/Boxplot.js +171 -0
  12. package/dist/components/charts/Boxplot/Boxplot.js.map +1 -0
  13. package/dist/components/charts/Chromatogram/Chromatogram.cjs +2 -0
  14. package/dist/components/charts/Chromatogram/Chromatogram.cjs.map +1 -0
  15. package/dist/components/charts/Chromatogram/Chromatogram.js +164 -0
  16. package/dist/components/charts/Chromatogram/Chromatogram.js.map +1 -0
  17. package/dist/components/charts/ChromatogramChart/ChromatogramChart.cjs +2 -0
  18. package/dist/components/charts/ChromatogramChart/ChromatogramChart.cjs.map +1 -0
  19. package/dist/components/charts/ChromatogramChart/ChromatogramChart.js +219 -0
  20. package/dist/components/charts/ChromatogramChart/ChromatogramChart.js.map +1 -0
  21. package/dist/components/charts/ChromatogramChart/annotations.cjs +2 -0
  22. package/dist/components/charts/ChromatogramChart/annotations.cjs.map +1 -0
  23. package/dist/components/charts/ChromatogramChart/annotations.js +73 -0
  24. package/dist/components/charts/ChromatogramChart/annotations.js.map +1 -0
  25. package/dist/components/charts/ChromatogramChart/boundaryMarkers.cjs +2 -0
  26. package/dist/components/charts/ChromatogramChart/boundaryMarkers.cjs.map +1 -0
  27. package/dist/components/charts/ChromatogramChart/boundaryMarkers.js +34 -0
  28. package/dist/components/charts/ChromatogramChart/boundaryMarkers.js.map +1 -0
  29. package/dist/components/charts/ChromatogramChart/constants.cjs +2 -0
  30. package/dist/components/charts/ChromatogramChart/constants.cjs.map +1 -0
  31. package/dist/components/charts/ChromatogramChart/constants.js +24 -0
  32. package/dist/components/charts/ChromatogramChart/constants.js.map +1 -0
  33. package/dist/components/charts/ChromatogramChart/dataProcessing.cjs +2 -0
  34. package/dist/components/charts/ChromatogramChart/dataProcessing.cjs.map +1 -0
  35. package/dist/components/charts/ChromatogramChart/dataProcessing.js +90 -0
  36. package/dist/components/charts/ChromatogramChart/dataProcessing.js.map +1 -0
  37. package/dist/components/charts/ChromatogramChart/peakDetection.cjs +2 -0
  38. package/dist/components/charts/ChromatogramChart/peakDetection.cjs.map +1 -0
  39. package/dist/components/charts/ChromatogramChart/peakDetection.js +89 -0
  40. package/dist/components/charts/ChromatogramChart/peakDetection.js.map +1 -0
  41. package/dist/components/charts/DotPlot/DotPlot.cjs +2 -0
  42. package/dist/components/charts/DotPlot/DotPlot.cjs.map +1 -0
  43. package/dist/components/charts/DotPlot/DotPlot.js +184 -0
  44. package/dist/components/charts/DotPlot/DotPlot.js.map +1 -0
  45. package/dist/components/charts/Heatmap/Heatmap.cjs +2 -0
  46. package/dist/components/charts/Heatmap/Heatmap.cjs.map +1 -0
  47. package/dist/components/charts/Heatmap/Heatmap.js +67 -0
  48. package/dist/components/charts/Heatmap/Heatmap.js.map +1 -0
  49. package/dist/components/charts/Histogram/Histogram.cjs +2 -0
  50. package/dist/components/charts/Histogram/Histogram.cjs.map +1 -0
  51. package/dist/components/charts/Histogram/Histogram.js +209 -0
  52. package/dist/components/charts/Histogram/Histogram.js.map +1 -0
  53. package/dist/components/charts/LineGraph/LineGraph.cjs +2 -0
  54. package/dist/components/charts/LineGraph/LineGraph.cjs.map +1 -0
  55. package/dist/components/charts/LineGraph/LineGraph.js +185 -0
  56. package/dist/components/charts/LineGraph/LineGraph.js.map +1 -0
  57. package/dist/components/charts/PieChart/PieChart.cjs +2 -0
  58. package/dist/components/charts/PieChart/PieChart.cjs.map +1 -0
  59. package/dist/components/charts/PieChart/PieChart.js +106 -0
  60. package/dist/components/charts/PieChart/PieChart.js.map +1 -0
  61. package/dist/components/charts/PlateMap/PlateMap.cjs +2 -0
  62. package/dist/components/charts/PlateMap/PlateMap.cjs.map +1 -0
  63. package/dist/components/charts/PlateMap/PlateMap.js +450 -0
  64. package/dist/components/charts/PlateMap/PlateMap.js.map +1 -0
  65. package/dist/components/charts/PlateMap/constants.cjs +2 -0
  66. package/dist/components/charts/PlateMap/constants.cjs.map +1 -0
  67. package/dist/components/charts/PlateMap/constants.js +137 -0
  68. package/dist/components/charts/PlateMap/constants.js.map +1 -0
  69. package/dist/components/charts/PlateMap/types.cjs +2 -0
  70. package/dist/components/charts/PlateMap/types.cjs.map +1 -0
  71. package/dist/components/charts/PlateMap/types.js +8 -0
  72. package/dist/components/charts/PlateMap/types.js.map +1 -0
  73. package/dist/components/charts/PlateMap/utils.cjs +2 -0
  74. package/dist/components/charts/PlateMap/utils.cjs.map +1 -0
  75. package/dist/components/charts/PlateMap/utils.js +235 -0
  76. package/dist/components/charts/PlateMap/utils.js.map +1 -0
  77. package/dist/components/charts/ScatterGraph/ScatterGraph.cjs +2 -0
  78. package/dist/components/charts/ScatterGraph/ScatterGraph.cjs.map +1 -0
  79. package/dist/components/charts/ScatterGraph/ScatterGraph.js +186 -0
  80. package/dist/components/charts/ScatterGraph/ScatterGraph.js.map +1 -0
  81. package/dist/components/composed/AppHeader/AppHeader.cjs +2 -0
  82. package/dist/components/composed/AppHeader/AppHeader.cjs.map +1 -0
  83. package/dist/components/composed/AppHeader/AppHeader.js +35 -0
  84. package/dist/components/composed/AppHeader/AppHeader.js.map +1 -0
  85. package/dist/components/composed/AppLayout/AppLayout.cjs +2 -0
  86. package/dist/components/composed/AppLayout/AppLayout.cjs.map +1 -0
  87. package/dist/components/composed/AppLayout/AppLayout.js +65 -0
  88. package/dist/components/composed/AppLayout/AppLayout.js.map +1 -0
  89. package/dist/components/composed/AssistantModal/AssistantModal.cjs +2 -0
  90. package/dist/components/composed/AssistantModal/AssistantModal.cjs.map +1 -0
  91. package/dist/components/composed/AssistantModal/AssistantModal.js +75 -0
  92. package/dist/components/composed/AssistantModal/AssistantModal.js.map +1 -0
  93. package/dist/components/composed/CodeScriptEditorButton/CodeScriptEditorButton.cjs +3 -0
  94. package/dist/components/composed/CodeScriptEditorButton/CodeScriptEditorButton.cjs.map +1 -0
  95. package/dist/components/composed/CodeScriptEditorButton/CodeScriptEditorButton.js +74 -0
  96. package/dist/components/composed/CodeScriptEditorButton/CodeScriptEditorButton.js.map +1 -0
  97. package/dist/components/composed/LaunchContent/LaunchContent.cjs +6 -0
  98. package/dist/components/composed/LaunchContent/LaunchContent.cjs.map +1 -0
  99. package/dist/components/composed/LaunchContent/LaunchContent.js +66 -0
  100. package/dist/components/composed/LaunchContent/LaunchContent.js.map +1 -0
  101. package/dist/components/composed/Main/LaunchContentPanel.cjs +6 -0
  102. package/dist/components/composed/Main/LaunchContentPanel.cjs.map +1 -0
  103. package/dist/components/composed/Main/LaunchContentPanel.js +63 -0
  104. package/dist/components/composed/Main/LaunchContentPanel.js.map +1 -0
  105. package/dist/components/composed/Main/Main.cjs +2 -0
  106. package/dist/components/composed/Main/Main.cjs.map +1 -0
  107. package/dist/components/composed/Main/Main.js +276 -0
  108. package/dist/components/composed/Main/Main.js.map +1 -0
  109. package/dist/components/composed/Main/MainHeader.cjs +2 -0
  110. package/dist/components/composed/Main/MainHeader.cjs.map +1 -0
  111. package/dist/components/composed/Main/MainHeader.js +36 -0
  112. package/dist/components/composed/Main/MainHeader.js.map +1 -0
  113. package/dist/components/composed/Main/MainNavbar.cjs +2 -0
  114. package/dist/components/composed/Main/MainNavbar.cjs.map +1 -0
  115. package/dist/components/composed/Main/MainNavbar.js +25 -0
  116. package/dist/components/composed/Main/MainNavbar.js.map +1 -0
  117. package/dist/components/composed/Main/MainSidebar.cjs +2 -0
  118. package/dist/components/composed/Main/MainSidebar.cjs.map +1 -0
  119. package/dist/components/composed/Main/MainSidebar.js +12 -0
  120. package/dist/components/composed/Main/MainSidebar.js.map +1 -0
  121. package/dist/components/composed/Main/MainTabBar.cjs +2 -0
  122. package/dist/components/composed/Main/MainTabBar.cjs.map +1 -0
  123. package/dist/components/composed/Main/MainTabBar.js +7 -0
  124. package/dist/components/composed/Main/MainTabBar.js.map +1 -0
  125. package/dist/components/composed/Main/ProtocolConfigurationPanel.cjs +2 -0
  126. package/dist/components/composed/Main/ProtocolConfigurationPanel.cjs.map +1 -0
  127. package/dist/components/composed/Main/ProtocolConfigurationPanel.js +30 -0
  128. package/dist/components/composed/Main/ProtocolConfigurationPanel.js.map +1 -0
  129. package/dist/components/composed/Main/TemplateSidebarCard.cjs +2 -0
  130. package/dist/components/composed/Main/TemplateSidebarCard.cjs.map +1 -0
  131. package/dist/components/composed/Main/TemplateSidebarCard.js +71 -0
  132. package/dist/components/composed/Main/TemplateSidebarCard.js.map +1 -0
  133. package/dist/components/composed/Navbar/Navbar.cjs +2 -0
  134. package/dist/components/composed/Navbar/Navbar.cjs.map +1 -0
  135. package/dist/components/composed/Navbar/Navbar.js +25 -0
  136. package/dist/components/composed/Navbar/Navbar.js.map +1 -0
  137. package/dist/components/composed/ProtocolConfiguration/ProtocolConfiguration.cjs +2 -0
  138. package/dist/components/composed/ProtocolConfiguration/ProtocolConfiguration.cjs.map +1 -0
  139. package/dist/components/composed/ProtocolConfiguration/ProtocolConfiguration.js +44 -0
  140. package/dist/components/composed/ProtocolConfiguration/ProtocolConfiguration.js.map +1 -0
  141. package/dist/components/composed/ProtocolYamlCard/ProtocolYamlCard.cjs +2 -0
  142. package/dist/components/composed/ProtocolYamlCard/ProtocolYamlCard.cjs.map +1 -0
  143. package/dist/components/composed/ProtocolYamlCard/ProtocolYamlCard.js +53 -0
  144. package/dist/components/composed/ProtocolYamlCard/ProtocolYamlCard.js.map +1 -0
  145. package/dist/components/composed/PythonEditorModal/PythonEditorModal.cjs +2 -0
  146. package/dist/components/composed/PythonEditorModal/PythonEditorModal.cjs.map +1 -0
  147. package/dist/components/composed/PythonEditorModal/PythonEditorModal.js +51 -0
  148. package/dist/components/composed/PythonEditorModal/PythonEditorModal.js.map +1 -0
  149. package/dist/components/composed/Sidebar/Sidebar.cjs +2 -0
  150. package/dist/components/composed/Sidebar/Sidebar.cjs.map +1 -0
  151. package/dist/components/composed/Sidebar/Sidebar.js +46 -0
  152. package/dist/components/composed/Sidebar/Sidebar.js.map +1 -0
  153. package/dist/components/composed/TdpSearch/TdpSearch.cjs +2 -0
  154. package/dist/components/composed/TdpSearch/TdpSearch.cjs.map +1 -0
  155. package/dist/components/composed/TdpSearch/TdpSearch.js +97 -0
  156. package/dist/components/composed/TdpSearch/TdpSearch.js.map +1 -0
  157. package/dist/components/composed/TdpSearch/components/DefaultFilters.cjs +2 -0
  158. package/dist/components/composed/TdpSearch/components/DefaultFilters.cjs.map +1 -0
  159. package/dist/components/composed/TdpSearch/components/DefaultFilters.js +31 -0
  160. package/dist/components/composed/TdpSearch/components/DefaultFilters.js.map +1 -0
  161. package/dist/components/composed/TdpSearch/components/DefaultResults.cjs +2 -0
  162. package/dist/components/composed/TdpSearch/components/DefaultResults.cjs.map +1 -0
  163. package/dist/components/composed/TdpSearch/components/DefaultResults.js +107 -0
  164. package/dist/components/composed/TdpSearch/components/DefaultResults.js.map +1 -0
  165. package/dist/components/composed/TdpSearch/components/DefaultSearchBar.cjs +2 -0
  166. package/dist/components/composed/TdpSearch/components/DefaultSearchBar.cjs.map +1 -0
  167. package/dist/components/composed/TdpSearch/components/DefaultSearchBar.js +32 -0
  168. package/dist/components/composed/TdpSearch/components/DefaultSearchBar.js.map +1 -0
  169. package/dist/components/composed/TdpSearch/constants.cjs +2 -0
  170. package/dist/components/composed/TdpSearch/constants.cjs.map +1 -0
  171. package/dist/components/composed/TdpSearch/constants.js +7 -0
  172. package/dist/components/composed/TdpSearch/constants.js.map +1 -0
  173. package/dist/components/composed/TdpSearch/hooks/useSearch.cjs +2 -0
  174. package/dist/components/composed/TdpSearch/hooks/useSearch.cjs.map +1 -0
  175. package/dist/components/composed/TdpSearch/hooks/useSearch.js +52 -0
  176. package/dist/components/composed/TdpSearch/hooks/useSearch.js.map +1 -0
  177. package/dist/components/composed/TdpSearch/hooks/useTdpCredentials.cjs +2 -0
  178. package/dist/components/composed/TdpSearch/hooks/useTdpCredentials.cjs.map +1 -0
  179. package/dist/components/composed/TdpSearch/hooks/useTdpCredentials.js +29 -0
  180. package/dist/components/composed/TdpSearch/hooks/useTdpCredentials.js.map +1 -0
  181. package/dist/components/composed/TdpSearch/utils.cjs +2 -0
  182. package/dist/components/composed/TdpSearch/utils.cjs.map +1 -0
  183. package/dist/components/composed/TdpSearch/utils.js +15 -0
  184. package/dist/components/composed/TdpSearch/utils.js.map +1 -0
  185. package/dist/components/composed/tdp-link.cjs +2 -0
  186. package/dist/components/composed/tdp-link.cjs.map +1 -0
  187. package/dist/components/composed/tdp-link.js +84 -0
  188. package/dist/components/composed/tdp-link.js.map +1 -0
  189. package/dist/components/composed/tdp-url.cjs +2 -0
  190. package/dist/components/composed/tdp-url.cjs.map +1 -0
  191. package/dist/components/composed/tdp-url.js +76 -0
  192. package/dist/components/composed/tdp-url.js.map +1 -0
  193. package/dist/components/ui/accordion.cjs +2 -0
  194. package/dist/components/ui/accordion.cjs.map +1 -0
  195. package/dist/components/ui/accordion.js +83 -0
  196. package/dist/components/ui/accordion.js.map +1 -0
  197. package/dist/components/ui/alert-dialog.cjs +2 -0
  198. package/dist/components/ui/alert-dialog.cjs.map +1 -0
  199. package/dist/components/ui/alert-dialog.js +181 -0
  200. package/dist/components/ui/alert-dialog.js.map +1 -0
  201. package/dist/components/ui/alert.cjs +2 -0
  202. package/dist/components/ui/alert.cjs.map +1 -0
  203. package/dist/components/ui/alert.js +78 -0
  204. package/dist/components/ui/alert.js.map +1 -0
  205. package/dist/components/ui/aspect-ratio.cjs +2 -0
  206. package/dist/components/ui/aspect-ratio.cjs.map +1 -0
  207. package/dist/components/ui/aspect-ratio.js +11 -0
  208. package/dist/components/ui/aspect-ratio.js.map +1 -0
  209. package/dist/components/ui/avatar.cjs +2 -0
  210. package/dist/components/ui/avatar.cjs.map +1 -0
  211. package/dist/components/ui/avatar.js +107 -0
  212. package/dist/components/ui/avatar.js.map +1 -0
  213. package/dist/components/ui/badge.cjs +2 -0
  214. package/dist/components/ui/badge.cjs.map +1 -0
  215. package/dist/components/ui/badge.js +44 -0
  216. package/dist/components/ui/badge.js.map +1 -0
  217. package/dist/components/ui/breadcrumb.cjs +2 -0
  218. package/dist/components/ui/breadcrumb.cjs.map +1 -0
  219. package/dist/components/ui/breadcrumb.js +118 -0
  220. package/dist/components/ui/breadcrumb.js.map +1 -0
  221. package/dist/components/ui/button-group.cjs +2 -0
  222. package/dist/components/ui/button-group.cjs.map +1 -0
  223. package/dist/components/ui/button-group.js +77 -0
  224. package/dist/components/ui/button-group.js.map +1 -0
  225. package/dist/components/ui/button.cjs +2 -0
  226. package/dist/components/ui/button.cjs.map +1 -0
  227. package/dist/components/ui/button.js +57 -0
  228. package/dist/components/ui/button.js.map +1 -0
  229. package/dist/components/ui/calendar.cjs +2 -0
  230. package/dist/components/ui/calendar.cjs.map +1 -0
  231. package/dist/components/ui/calendar.js +174 -0
  232. package/dist/components/ui/calendar.js.map +1 -0
  233. package/dist/components/ui/card.cjs +2 -0
  234. package/dist/components/ui/card.cjs.map +1 -0
  235. package/dist/components/ui/card.js +102 -0
  236. package/dist/components/ui/card.js.map +1 -0
  237. package/dist/components/ui/carousel.cjs +2 -0
  238. package/dist/components/ui/carousel.cjs.map +1 -0
  239. package/dist/components/ui/carousel.js +179 -0
  240. package/dist/components/ui/carousel.js.map +1 -0
  241. package/dist/components/ui/checkbox.cjs +2 -0
  242. package/dist/components/ui/checkbox.cjs.map +1 -0
  243. package/dist/components/ui/checkbox.js +35 -0
  244. package/dist/components/ui/checkbox.js.map +1 -0
  245. package/dist/components/ui/code-editor.cjs +2 -0
  246. package/dist/components/ui/code-editor.cjs.map +1 -0
  247. package/dist/components/ui/code-editor.js +103 -0
  248. package/dist/components/ui/code-editor.js.map +1 -0
  249. package/dist/components/ui/collapsible.cjs +2 -0
  250. package/dist/components/ui/collapsible.cjs.map +1 -0
  251. package/dist/components/ui/collapsible.js +35 -0
  252. package/dist/components/ui/collapsible.js.map +1 -0
  253. package/dist/components/ui/combobox.cjs +2 -0
  254. package/dist/components/ui/combobox.cjs.map +1 -0
  255. package/dist/components/ui/combobox.js +278 -0
  256. package/dist/components/ui/combobox.js.map +1 -0
  257. package/dist/components/ui/command.cjs +2 -0
  258. package/dist/components/ui/command.cjs.map +1 -0
  259. package/dist/components/ui/command.js +174 -0
  260. package/dist/components/ui/command.js.map +1 -0
  261. package/dist/components/ui/context-menu.cjs +2 -0
  262. package/dist/components/ui/context-menu.cjs.map +1 -0
  263. package/dist/components/ui/context-menu.js +236 -0
  264. package/dist/components/ui/context-menu.js.map +1 -0
  265. package/dist/components/ui/dialog.cjs +2 -0
  266. package/dist/components/ui/dialog.cjs.map +1 -0
  267. package/dist/components/ui/dialog.js +154 -0
  268. package/dist/components/ui/dialog.js.map +1 -0
  269. package/dist/components/ui/drawer.cjs +2 -0
  270. package/dist/components/ui/drawer.cjs.map +1 -0
  271. package/dist/components/ui/drawer.js +125 -0
  272. package/dist/components/ui/drawer.js.map +1 -0
  273. package/dist/components/ui/dropdown-menu.cjs +2 -0
  274. package/dist/components/ui/dropdown-menu.cjs.map +1 -0
  275. package/dist/components/ui/dropdown-menu.js +252 -0
  276. package/dist/components/ui/dropdown-menu.js.map +1 -0
  277. package/dist/components/ui/field.cjs +2 -0
  278. package/dist/components/ui/field.cjs.map +1 -0
  279. package/dist/components/ui/field.js +210 -0
  280. package/dist/components/ui/field.js.map +1 -0
  281. package/dist/components/ui/hover-card.cjs +2 -0
  282. package/dist/components/ui/hover-card.cjs.map +1 -0
  283. package/dist/components/ui/hover-card.js +39 -0
  284. package/dist/components/ui/hover-card.js.map +1 -0
  285. package/dist/components/ui/input-group.cjs +2 -0
  286. package/dist/components/ui/input-group.cjs.map +1 -0
  287. package/dist/components/ui/input-group.js +145 -0
  288. package/dist/components/ui/input-group.js.map +1 -0
  289. package/dist/components/ui/input-otp.cjs +2 -0
  290. package/dist/components/ui/input-otp.cjs.map +1 -0
  291. package/dist/components/ui/input-otp.js +82 -0
  292. package/dist/components/ui/input-otp.js.map +1 -0
  293. package/dist/components/ui/input.cjs +2 -0
  294. package/dist/components/ui/input.cjs.map +1 -0
  295. package/dist/components/ui/input.js +20 -0
  296. package/dist/components/ui/input.js.map +1 -0
  297. package/dist/components/ui/item.cjs +2 -0
  298. package/dist/components/ui/item.cjs.map +1 -0
  299. package/dist/components/ui/item.js +191 -0
  300. package/dist/components/ui/item.js.map +1 -0
  301. package/dist/components/ui/kbd.cjs +2 -0
  302. package/dist/components/ui/kbd.cjs.map +1 -0
  303. package/dist/components/ui/kbd.js +30 -0
  304. package/dist/components/ui/kbd.js.map +1 -0
  305. package/dist/components/ui/label.cjs +2 -0
  306. package/dist/components/ui/label.cjs.map +1 -0
  307. package/dist/components/ui/label.js +23 -0
  308. package/dist/components/ui/label.js.map +1 -0
  309. package/dist/components/ui/menubar.cjs +2 -0
  310. package/dist/components/ui/menubar.cjs.map +1 -0
  311. package/dist/components/ui/menubar.js +256 -0
  312. package/dist/components/ui/menubar.js.map +1 -0
  313. package/dist/components/ui/navigation-menu.cjs +2 -0
  314. package/dist/components/ui/navigation-menu.cjs.map +1 -0
  315. package/dist/components/ui/navigation-menu.js +164 -0
  316. package/dist/components/ui/navigation-menu.js.map +1 -0
  317. package/dist/components/ui/radio-group.cjs +2 -0
  318. package/dist/components/ui/radio-group.cjs.map +1 -0
  319. package/dist/components/ui/radio-group.js +45 -0
  320. package/dist/components/ui/radio-group.js.map +1 -0
  321. package/dist/components/ui/resizable.cjs +2 -0
  322. package/dist/components/ui/resizable.cjs.map +1 -0
  323. package/dist/components/ui/resizable.js +46 -0
  324. package/dist/components/ui/resizable.js.map +1 -0
  325. package/dist/components/ui/scroll-area.cjs +2 -0
  326. package/dist/components/ui/scroll-area.cjs.map +1 -0
  327. package/dist/components/ui/scroll-area.js +60 -0
  328. package/dist/components/ui/scroll-area.js.map +1 -0
  329. package/dist/components/ui/select.cjs +2 -0
  330. package/dist/components/ui/select.cjs.map +1 -0
  331. package/dist/components/ui/select.js +184 -0
  332. package/dist/components/ui/select.js.map +1 -0
  333. package/dist/components/ui/separator.cjs +2 -0
  334. package/dist/components/ui/separator.cjs.map +1 -0
  335. package/dist/components/ui/separator.js +27 -0
  336. package/dist/components/ui/separator.js.map +1 -0
  337. package/dist/components/ui/sheet.cjs +2 -0
  338. package/dist/components/ui/sheet.cjs.map +1 -0
  339. package/dist/components/ui/sheet.js +137 -0
  340. package/dist/components/ui/sheet.js.map +1 -0
  341. package/dist/components/ui/sidebar.cjs +2 -0
  342. package/dist/components/ui/sidebar.cjs.map +1 -0
  343. package/dist/components/ui/sidebar.js +579 -0
  344. package/dist/components/ui/sidebar.js.map +1 -0
  345. package/dist/components/ui/skeleton.cjs +2 -0
  346. package/dist/components/ui/skeleton.cjs.map +1 -0
  347. package/dist/components/ui/skeleton.js +16 -0
  348. package/dist/components/ui/skeleton.js.map +1 -0
  349. package/dist/components/ui/slider.cjs +2 -0
  350. package/dist/components/ui/slider.cjs.map +1 -0
  351. package/dist/components/ui/slider.js +60 -0
  352. package/dist/components/ui/slider.js.map +1 -0
  353. package/dist/components/ui/sonner.cjs +2 -0
  354. package/dist/components/ui/sonner.cjs.map +1 -0
  355. package/dist/components/ui/sonner.js +37 -0
  356. package/dist/components/ui/sonner.js.map +1 -0
  357. package/dist/components/ui/spinner.cjs +2 -0
  358. package/dist/components/ui/spinner.cjs.map +1 -0
  359. package/dist/components/ui/spinner.js +10 -0
  360. package/dist/components/ui/spinner.js.map +1 -0
  361. package/dist/components/ui/switch.cjs +2 -0
  362. package/dist/components/ui/switch.cjs.map +1 -0
  363. package/dist/components/ui/switch.js +32 -0
  364. package/dist/components/ui/switch.js.map +1 -0
  365. package/dist/components/ui/table.cjs +2 -0
  366. package/dist/components/ui/table.cjs.map +1 -0
  367. package/dist/components/ui/table.js +115 -0
  368. package/dist/components/ui/table.js.map +1 -0
  369. package/dist/components/ui/tabs.cjs +2 -0
  370. package/dist/components/ui/tabs.cjs.map +1 -0
  371. package/dist/components/ui/tabs.js +91 -0
  372. package/dist/components/ui/tabs.js.map +1 -0
  373. package/dist/components/ui/tetrascience-icon.cjs +2 -0
  374. package/dist/components/ui/tetrascience-icon.cjs.map +1 -0
  375. package/dist/components/ui/tetrascience-icon.js +46 -0
  376. package/dist/components/ui/tetrascience-icon.js.map +1 -0
  377. package/dist/components/ui/textarea.cjs +2 -0
  378. package/dist/components/ui/textarea.cjs.map +1 -0
  379. package/dist/components/ui/textarea.js +19 -0
  380. package/dist/components/ui/textarea.js.map +1 -0
  381. package/dist/components/ui/toggle-group.cjs +2 -0
  382. package/dist/components/ui/toggle-group.cjs.map +1 -0
  383. package/dist/components/ui/toggle-group.js +77 -0
  384. package/dist/components/ui/toggle-group.js.map +1 -0
  385. package/dist/components/ui/toggle.cjs +2 -0
  386. package/dist/components/ui/toggle.cjs.map +1 -0
  387. package/dist/components/ui/toggle.js +44 -0
  388. package/dist/components/ui/toggle.js.map +1 -0
  389. package/dist/components/ui/tooltip.cjs +2 -0
  390. package/dist/components/ui/tooltip.cjs.map +1 -0
  391. package/dist/components/ui/tooltip.js +56 -0
  392. package/dist/components/ui/tooltip.js.map +1 -0
  393. package/dist/hooks/use-code-editor-theme.cjs +2 -0
  394. package/dist/hooks/use-code-editor-theme.cjs.map +1 -0
  395. package/dist/hooks/use-code-editor-theme.js +31 -0
  396. package/dist/hooks/use-code-editor-theme.js.map +1 -0
  397. package/dist/hooks/use-is-dark.cjs +2 -0
  398. package/dist/hooks/use-is-dark.cjs.map +1 -0
  399. package/dist/hooks/use-is-dark.js +18 -0
  400. package/dist/hooks/use-is-dark.js.map +1 -0
  401. package/dist/hooks/use-mobile.cjs +2 -0
  402. package/dist/hooks/use-mobile.cjs.map +1 -0
  403. package/dist/hooks/use-mobile.js +15 -0
  404. package/dist/hooks/use-mobile.js.map +1 -0
  405. package/dist/hooks/use-plotly-theme.cjs +2 -0
  406. package/dist/hooks/use-plotly-theme.cjs.map +1 -0
  407. package/dist/hooks/use-plotly-theme.js +33 -0
  408. package/dist/hooks/use-plotly-theme.js.map +1 -0
  409. package/dist/index.cjs +1 -10
  410. package/dist/index.cjs.map +1 -1
  411. package/dist/index.js +389 -9435
  412. package/dist/index.js.map +1 -1
  413. package/dist/lib/utils.cjs +2 -0
  414. package/dist/lib/utils.cjs.map +1 -0
  415. package/dist/lib/utils.js +9 -0
  416. package/dist/lib/utils.js.map +1 -0
  417. package/dist/providers/athena.cjs +1 -1
  418. package/dist/providers/athena.cjs.map +1 -1
  419. package/dist/providers/athena.js +9 -157
  420. package/dist/providers/athena.js.map +1 -1
  421. package/dist/providers/databricks.cjs +1 -1
  422. package/dist/providers/databricks.cjs.map +1 -1
  423. package/dist/providers/databricks.js +9 -82
  424. package/dist/providers/databricks.js.map +1 -1
  425. package/dist/providers/snowflake.cjs +1 -1
  426. package/dist/providers/snowflake.cjs.map +1 -1
  427. package/dist/providers/snowflake.js +8 -118
  428. package/dist/providers/snowflake.js.map +1 -1
  429. package/dist/server/auth/JwtTokenManager.cjs +2 -0
  430. package/dist/server/auth/JwtTokenManager.cjs.map +1 -0
  431. package/dist/server/auth/JwtTokenManager.js +134 -0
  432. package/dist/server/auth/JwtTokenManager.js.map +1 -0
  433. package/dist/server/providers/AthenaProvider.cjs +2 -0
  434. package/dist/server/providers/AthenaProvider.cjs.map +1 -0
  435. package/dist/server/providers/AthenaProvider.js +154 -0
  436. package/dist/server/providers/AthenaProvider.js.map +1 -0
  437. package/dist/server/providers/DatabricksProvider.cjs +2 -0
  438. package/dist/server/providers/DatabricksProvider.cjs.map +1 -0
  439. package/dist/server/providers/DatabricksProvider.js +79 -0
  440. package/dist/server/providers/DatabricksProvider.js.map +1 -0
  441. package/dist/server/providers/SnowflakeProvider.cjs +2 -0
  442. package/dist/server/providers/SnowflakeProvider.cjs.map +1 -0
  443. package/dist/server/providers/SnowflakeProvider.js +116 -0
  444. package/dist/server/providers/SnowflakeProvider.js.map +1 -0
  445. package/dist/server/providers/buildProvider.cjs +2 -0
  446. package/dist/server/providers/buildProvider.cjs.map +1 -0
  447. package/dist/server/providers/buildProvider.js +22 -0
  448. package/dist/server/providers/buildProvider.js.map +1 -0
  449. package/dist/server/providers/exceptions.cjs +2 -0
  450. package/dist/server/providers/exceptions.cjs.map +1 -0
  451. package/dist/{exceptions-jCQ6h5C8.js → server/providers/exceptions.js} +11 -11
  452. package/dist/server/providers/exceptions.js.map +1 -0
  453. package/dist/server/providers/getProviderConfigurations.cjs +2 -0
  454. package/dist/server/providers/getProviderConfigurations.cjs.map +1 -0
  455. package/dist/server/providers/getProviderConfigurations.js +78 -0
  456. package/dist/server/providers/getProviderConfigurations.js.map +1 -0
  457. package/dist/server/providers/providerDiscovery.cjs +2 -0
  458. package/dist/server/providers/providerDiscovery.cjs.map +1 -0
  459. package/dist/server/providers/providerDiscovery.js +28 -0
  460. package/dist/server/providers/providerDiscovery.js.map +1 -0
  461. package/dist/server.cjs +1 -1
  462. package/dist/server.cjs.map +1 -1
  463. package/dist/server.js +27 -262
  464. package/dist/server.js.map +1 -1
  465. package/dist/utils/colors.cjs +2 -0
  466. package/dist/utils/colors.cjs.map +1 -0
  467. package/dist/utils/colors.js +98 -0
  468. package/dist/utils/colors.js.map +1 -0
  469. package/package.json +4 -1
  470. package/dist/exceptions-DN25pCDi.cjs +0 -2
  471. package/dist/exceptions-DN25pCDi.cjs.map +0 -1
  472. package/dist/exceptions-jCQ6h5C8.js.map +0 -1
@@ -0,0 +1,171 @@
1
+ import { jsx as b } from "react/jsx-runtime";
2
+ import C from "plotly.js-dist";
3
+ import { useRef as E, useMemo as s, useEffect as z } from "react";
4
+ import { usePlotlyTheme as N } from "../../../hooks/use-plotly-theme.js";
5
+ const _ = -1.8, A = ({
6
+ dataSeries: a,
7
+ width: h = 1e3,
8
+ height: u = 600,
9
+ xRange: p,
10
+ yRange: c,
11
+ xTitle: d = "Columns",
12
+ yTitle: g = "Rows",
13
+ title: x = "Boxplot",
14
+ showPoints: y = !1
15
+ }) => {
16
+ const f = E(null), t = N(), { yMin: M, yMax: w } = s(() => {
17
+ let r = Number.MAX_VALUE, o = Number.MIN_VALUE;
18
+ a.forEach((n) => {
19
+ n.y.forEach((e) => {
20
+ r = Math.min(r, e), o = Math.max(o, e);
21
+ });
22
+ });
23
+ const l = (o - r) * 0.1;
24
+ return {
25
+ yMin: r - l,
26
+ yMax: o + l
27
+ };
28
+ }, [a]), i = s(
29
+ () => c || [M, w],
30
+ [c, M, w]
31
+ ), k = s(() => {
32
+ const r = i[1] - i[0];
33
+ let o = Math.pow(10, Math.floor(Math.log10(r)));
34
+ r / o > 10 && (o = o * 2), r / o < 4 && (o = o / 2);
35
+ const l = [];
36
+ let n = Math.ceil(i[0] / o) * o;
37
+ for (; n <= i[1]; )
38
+ l.push(n), n += o;
39
+ return l;
40
+ }, [i]), m = s(
41
+ () => ({
42
+ tickcolor: t.tickColor,
43
+ ticklen: 12,
44
+ tickwidth: 1,
45
+ ticks: "outside",
46
+ tickfont: {
47
+ size: 16,
48
+ color: t.textColor,
49
+ family: "Inter, sans-serif",
50
+ weight: 400
51
+ },
52
+ linecolor: t.lineColor,
53
+ linewidth: 1,
54
+ position: 0,
55
+ zeroline: !1
56
+ }),
57
+ [t]
58
+ ), I = s(
59
+ () => ({
60
+ text: x,
61
+ x: 0.5,
62
+ y: 0.95,
63
+ xanchor: "center",
64
+ yanchor: "top",
65
+ font: {
66
+ size: 32,
67
+ weight: 600,
68
+ family: "Inter, sans-serif",
69
+ color: t.textColor,
70
+ lineheight: 1.2,
71
+ standoff: 30
72
+ }
73
+ }),
74
+ [x, t]
75
+ );
76
+ return z(() => {
77
+ if (!f.current) return;
78
+ const r = a.map((e) => ({
79
+ y: e.y,
80
+ x: e.x,
81
+ type: "box",
82
+ name: e.name,
83
+ marker: {
84
+ color: e.color
85
+ },
86
+ line: {
87
+ color: e.color
88
+ },
89
+ fillcolor: e.color + "40",
90
+ // Add transparency
91
+ boxpoints: y ? e.boxpoints || "outliers" : !1,
92
+ jitter: e.jitter || 0.3,
93
+ pointpos: e.pointpos || _
94
+ })), o = {
95
+ width: h,
96
+ height: u,
97
+ title: I,
98
+ margin: { l: 80, r: 40, b: 80, t: 80, pad: 0 },
99
+ paper_bgcolor: t.paperBg,
100
+ plot_bgcolor: t.plotBg,
101
+ font: {
102
+ family: "Inter, sans-serif"
103
+ },
104
+ dragmode: !1,
105
+ xaxis: {
106
+ title: {
107
+ text: d,
108
+ font: {
109
+ size: 16,
110
+ color: t.textSecondary,
111
+ family: "Inter, sans-serif",
112
+ weight: 400
113
+ },
114
+ standoff: 15
115
+ },
116
+ gridcolor: t.gridColor,
117
+ range: p,
118
+ autorange: !p,
119
+ showgrid: !0,
120
+ ...m
121
+ },
122
+ yaxis: {
123
+ title: {
124
+ text: g,
125
+ font: {
126
+ size: 16,
127
+ color: t.textSecondary,
128
+ family: "Inter, sans-serif",
129
+ weight: 400
130
+ },
131
+ standoff: 15
132
+ },
133
+ gridcolor: t.gridColor,
134
+ range: c,
135
+ autorange: !c,
136
+ tickmode: "array",
137
+ tickvals: k,
138
+ showgrid: !0,
139
+ ...m
140
+ },
141
+ legend: {
142
+ x: 0.5,
143
+ y: -0.2,
144
+ xanchor: "center",
145
+ yanchor: "top",
146
+ orientation: "h",
147
+ font: {
148
+ size: 13,
149
+ color: t.legendColor,
150
+ family: "Inter, sans-serif",
151
+ weight: 500,
152
+ lineheight: 18
153
+ }
154
+ },
155
+ showlegend: !0
156
+ }, l = {
157
+ responsive: !0,
158
+ displayModeBar: !1,
159
+ displaylogo: !1
160
+ };
161
+ C.newPlot(f.current, r, o, l);
162
+ const n = f.current;
163
+ return () => {
164
+ n && C.purge(n);
165
+ };
166
+ }, [a, h, u, p, c, i, d, g, y, I, m, k, t]), /* @__PURE__ */ b("div", { className: "boxplot-container", children: /* @__PURE__ */ b("div", { ref: f, style: { width: "100%", height: "100%" } }) });
167
+ };
168
+ export {
169
+ A as Boxplot
170
+ };
171
+ //# sourceMappingURL=Boxplot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Boxplot.js","sources":["../../../../src/components/charts/Boxplot/Boxplot.tsx"],"sourcesContent":["import Plotly from \"plotly.js-dist\";\nimport React, { useEffect, useRef, useMemo } from \"react\";\n\nimport { usePlotlyTheme } from \"@/hooks/use-plotly-theme\";\n\n/** Default point position offset from the box edge */\nconst DEFAULT_POINT_POSITION = -1.8;\n\ninterface BoxDataSeries {\n y: number[];\n name: string;\n color: string;\n x?: string[] | number[];\n boxpoints?: \"all\" | \"outliers\" | \"suspectedoutliers\" | false;\n jitter?: number;\n pointpos?: number;\n}\n\ninterface BoxplotProps {\n dataSeries: BoxDataSeries[];\n width?: number;\n height?: number;\n xRange?: [number, number];\n yRange?: [number, number];\n xTitle?: string;\n yTitle?: string;\n title?: string;\n showPoints?: boolean;\n}\n\nconst Boxplot: React.FC<BoxplotProps> = ({\n dataSeries,\n width = 1000,\n height = 600,\n xRange,\n yRange,\n xTitle = \"Columns\",\n yTitle = \"Rows\",\n title = \"Boxplot\",\n showPoints = false,\n}) => {\n const plotRef = useRef<HTMLDivElement>(null);\n const theme = usePlotlyTheme();\n\n const { yMin, yMax } = useMemo(() => {\n let minY = Number.MAX_VALUE;\n let maxY = Number.MIN_VALUE;\n\n dataSeries.forEach((series) => {\n series.y.forEach((y) => {\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n });\n });\n\n const yPadding = (maxY - minY) * 0.1;\n\n return {\n yMin: minY - yPadding,\n yMax: maxY + yPadding,\n };\n }, [dataSeries]);\n\n const effectiveYRange = useMemo(\n () => yRange || [yMin, yMax],\n [yRange, yMin, yMax],\n );\n\n const yTicks = useMemo(() => {\n const range = effectiveYRange[1] - effectiveYRange[0];\n let step = Math.pow(10, Math.floor(Math.log10(range)));\n\n if (range / step > 10) step = step * 2;\n if (range / step < 4) step = step / 2;\n\n const ticks = [];\n let current = Math.ceil(effectiveYRange[0] / step) * step;\n while (current <= effectiveYRange[1]) {\n ticks.push(current);\n current += step;\n }\n return ticks;\n }, [effectiveYRange]);\n\n const tickOptions = useMemo(\n () => ({\n tickcolor: theme.tickColor,\n ticklen: 12,\n tickwidth: 1,\n ticks: \"outside\" as const,\n tickfont: {\n size: 16,\n color: theme.textColor,\n family: \"Inter, sans-serif\",\n weight: 400,\n },\n linecolor: theme.lineColor,\n linewidth: 1,\n position: 0,\n zeroline: false,\n }),\n [theme],\n );\n\n const titleOptions = useMemo(\n () => ({\n text: title,\n x: 0.5,\n y: 0.95,\n xanchor: \"center\" as const,\n yanchor: \"top\" as const,\n font: {\n size: 32,\n weight: 600,\n family: \"Inter, sans-serif\",\n color: theme.textColor,\n lineheight: 1.2,\n standoff: 30,\n },\n }),\n [title, theme],\n );\n\n useEffect(() => {\n if (!plotRef.current) return;\n\n const data = dataSeries.map((series) => ({\n y: series.y,\n x: series.x,\n type: \"box\" as const,\n name: series.name,\n marker: {\n color: series.color,\n },\n line: {\n color: series.color,\n },\n fillcolor: series.color + \"40\", // Add transparency\n boxpoints: showPoints ? series.boxpoints || \"outliers\" : (false as const),\n jitter: series.jitter || 0.3,\n pointpos: series.pointpos || DEFAULT_POINT_POSITION,\n }));\n\n const layout = {\n width,\n height: height,\n title: titleOptions,\n margin: { l: 80, r: 40, b: 80, t: 80, pad: 0 },\n paper_bgcolor: theme.paperBg,\n plot_bgcolor: theme.plotBg,\n font: {\n family: \"Inter, sans-serif\",\n },\n dragmode: false as const,\n xaxis: {\n title: {\n text: xTitle,\n font: {\n size: 16,\n color: theme.textSecondary,\n family: \"Inter, sans-serif\",\n weight: 400,\n },\n standoff: 15,\n },\n gridcolor: theme.gridColor,\n range: xRange,\n autorange: !xRange,\n showgrid: true,\n ...tickOptions,\n },\n yaxis: {\n title: {\n text: yTitle,\n font: {\n size: 16,\n color: theme.textSecondary,\n family: \"Inter, sans-serif\",\n weight: 400,\n },\n standoff: 15,\n },\n gridcolor: theme.gridColor,\n range: yRange,\n autorange: !yRange,\n tickmode: \"array\" as const,\n tickvals: yTicks,\n showgrid: true,\n ...tickOptions,\n },\n legend: {\n x: 0.5,\n y: -0.2,\n xanchor: \"center\" as const,\n yanchor: \"top\" as const,\n orientation: \"h\" as const,\n font: {\n size: 13,\n color: theme.legendColor,\n family: \"Inter, sans-serif\",\n weight: 500,\n lineheight: 18,\n },\n },\n showlegend: true,\n };\n\n const config = {\n responsive: true,\n displayModeBar: false,\n displaylogo: false,\n };\n\n Plotly.newPlot(plotRef.current, data, layout, config);\n\n // Capture ref value for cleanup\n const plotElement = plotRef.current;\n\n // Cleanup function\n return () => {\n if (plotElement) {\n Plotly.purge(plotElement);\n }\n };\n }, [dataSeries, width, height, xRange, yRange, effectiveYRange, xTitle, yTitle, showPoints, titleOptions, tickOptions, yTicks, theme]);\n\n return (\n <div className=\"boxplot-container\">\n <div ref={plotRef} style={{ width: \"100%\", height: \"100%\" }} />\n </div>\n );\n};\n\nexport { Boxplot };\nexport type { BoxDataSeries, BoxplotProps };\n"],"names":["DEFAULT_POINT_POSITION","Boxplot","dataSeries","width","height","xRange","yRange","xTitle","yTitle","title","showPoints","plotRef","useRef","theme","usePlotlyTheme","yMin","yMax","useMemo","minY","maxY","series","y","yPadding","effectiveYRange","yTicks","range","step","ticks","current","tickOptions","titleOptions","useEffect","data","layout","config","Plotly","plotElement","jsx"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),F=require("plotly.js-dist"),n=require("react"),G=require("../../../hooks/use-plotly-theme.cjs");;/* empty css */const O=75,D=1.05,R=e=>{const a={A:e.peakA,T:e.peakT,G:e.peakG,C:e.peakC},p=Object.values(a);if(p.every(c=>c===p[0]))return"";let u="",h=0;return Object.entries(a).forEach(([c,f])=>{f>h&&(u=c,h=f)}),u},$=({data:e=[],width:a=900,height:p=600,positionInterval:x=10,colorA:u="#2D9CDB",colorT:h="#A1C63C",colorG:c="#FF5C64",colorC:f="#FFA62E"})=>{const d=n.useRef(null),y=G.usePlotlyTheme(),s=n.useMemo(()=>e.map(t=>t.position),[e]),S=n.useMemo(()=>e.map(t=>R(t)),[e]),M=n.useMemo(()=>e.map(t=>t.peakA),[e]),P=n.useMemo(()=>e.map(t=>t.peakT),[e]),k=n.useMemo(()=>e.map(t=>t.peakG),[e]),T=n.useMemo(()=>e.map(t=>t.peakC),[e]),C=n.useMemo(()=>({x:s,y:M,type:"scatter",mode:"lines",name:"A",line:{color:u,width:2,shape:"spline"}}),[s,M,u]),b=n.useMemo(()=>({x:s,y:P,type:"scatter",mode:"lines",name:"T",line:{color:h,width:2,shape:"spline"}}),[s,P,h]),N=n.useMemo(()=>({x:s,y:k,type:"scatter",mode:"lines",name:"G",line:{color:c,width:2,shape:"spline"}}),[s,k,c]),v=n.useMemo(()=>({x:s,y:T,type:"scatter",mode:"lines",name:"C",line:{color:f,width:2,shape:"spline"}}),[s,T,f]),w=n.useMemo(()=>Math.max(...M,...P,...k,...T),[M,P,k,T]);if(n.useEffect(()=>{if(!d.current||e.length===0)return;const t=[C,b,N,v],j={width:a,height:p-O,margin:{l:0,r:0,b:20,t:10,pad:0},paper_bgcolor:y.paperBg,plot_bgcolor:y.plotBg,font:{family:"Inter, sans-serif"},showlegend:!1,xaxis:{showgrid:!1,zeroline:!1,showticklabels:!1,showline:!1,range:[Math.min(...s),Math.max(...s)],fixedrange:!0},yaxis:{showgrid:!1,zeroline:!1,showticklabels:!1,showline:!1,range:[0,w*D],fixedrange:!0}},i={responsive:!0,displayModeBar:!1,displaylogo:!1,fillFrame:!0};F.newPlot(d.current,t,j,i);const l=d.current;return()=>{l&&F.purge(l)}},[e,a,p,C,b,N,v,w,s,y]),e.length===0)return r.jsx("div",{className:"chart-container",children:"No data available"});const _=()=>{const t=()=>{const i=Math.min(...s),l=Math.max(...s),q=a;return r.jsx("div",{className:"sequence-letters-container",children:S.map((m,g)=>{const o=s[g],A=m==="A"?u:m==="T"?h:m==="G"?c:m==="C"?f:y.textColor,B=(o-i)/(l-i)*q;return r.jsx("span",{className:"sequence-letter",style:{left:`${B}px`,color:A},children:m},`base-${g}`)})})},j=()=>{const i=Math.min(...s),l=Math.max(...s),q=a,m=Math.ceil(i/x)*x,g=[];for(let o=m;o<=l;o+=x)g.push({position:o,label:o.toString()});return r.jsx("div",{className:"position-numbers-container",children:g.map(o=>{const E=(o.position-i)/(l-i)*q;return r.jsx("span",{className:"position-number",style:{left:`${E}px`},children:o.label},`pos-${o.position}`)})})};return r.jsxs("div",{className:"sequence-header",children:[t(),j()]})};return r.jsxs("div",{className:"chromatogram-container",style:{width:a,height:p},children:[_(),r.jsx("div",{className:"chromatogram-chart",children:r.jsx("div",{ref:d,style:{width:"100%",height:"100%"}})})]})};exports.Chromatogram=$;
2
+ //# sourceMappingURL=Chromatogram.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Chromatogram.cjs","sources":["../../../../src/components/charts/Chromatogram/Chromatogram.tsx"],"sourcesContent":["import Plotly from \"plotly.js-dist\";\nimport React, { useEffect, useRef, useMemo } from \"react\";\n\nimport { usePlotlyTheme } from \"@/hooks/use-plotly-theme\";\nimport \"./Chromatogram.scss\";\n\n/** Height offset for the plot area in pixels */\nconst PLOT_HEIGHT_OFFSET = 75;\n/** Scale factor for y-axis range to add padding above max value */\nconst Y_AXIS_PADDING_FACTOR = 1.05;\n\ninterface PeakData {\n position: number;\n base?: string;\n peakA: number;\n peakT: number;\n peakG: number;\n peakC: number;\n}\n\ninterface ChromatogramProps {\n data?: PeakData[];\n width?: number;\n height?: number;\n positionInterval?: number;\n colorA?: string;\n colorT?: string;\n colorG?: string;\n colorC?: string;\n}\n\nconst determineBase = (item: PeakData): string => {\n const peakValues = {\n A: item.peakA,\n T: item.peakT,\n G: item.peakG,\n C: item.peakC,\n };\n\n const values = Object.values(peakValues);\n const allEqual = values.every((val) => val === values[0]);\n\n if (allEqual) {\n return \"\";\n }\n\n let highestBase = \"\";\n let highestValue = 0;\n\n Object.entries(peakValues).forEach(([base, value]) => {\n if (value > highestValue) {\n highestBase = base;\n highestValue = value;\n }\n });\n\n return highestBase;\n};\n\nconst Chromatogram: React.FC<ChromatogramProps> = ({\n data = [],\n width = 900,\n height = 600,\n positionInterval = 10,\n colorA = \"#2D9CDB\",\n colorT = \"#A1C63C\",\n colorG = \"#FF5C64\",\n colorC = \"#FFA62E\",\n}) => {\n const plotRef = useRef<HTMLDivElement>(null);\n const theme = usePlotlyTheme();\n\n const positions = useMemo(() => data.map((item) => item.position), [data]);\n const sequence = useMemo(() => data.map((item) => determineBase(item)), [data]);\n const peakA = useMemo(() => data.map((item) => item.peakA), [data]);\n const peakT = useMemo(() => data.map((item) => item.peakT), [data]);\n const peakG = useMemo(() => data.map((item) => item.peakG), [data]);\n const peakC = useMemo(() => data.map((item) => item.peakC), [data]);\n\n const aTrace = useMemo(\n () => ({\n x: positions,\n y: peakA,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"A\",\n line: { color: colorA, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakA, colorA],\n );\n\n const tTrace = useMemo(\n () => ({\n x: positions,\n y: peakT,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"T\",\n line: { color: colorT, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakT, colorT],\n );\n\n const gTrace = useMemo(\n () => ({\n x: positions,\n y: peakG,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"G\",\n line: { color: colorG, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakG, colorG],\n );\n\n const cTrace = useMemo(\n () => ({\n x: positions,\n y: peakC,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"C\",\n line: { color: colorC, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakC, colorC],\n );\n\n const maxValue = useMemo(\n () => Math.max(...peakA, ...peakT, ...peakG, ...peakC),\n [peakA, peakT, peakG, peakC],\n );\n\n useEffect(() => {\n if (!plotRef.current || data.length === 0) return;\n\n const plotData = [aTrace, tTrace, gTrace, cTrace];\n\n const layout: Partial<Plotly.Layout> = {\n width: width,\n height: height - PLOT_HEIGHT_OFFSET,\n margin: { l: 0, r: 0, b: 20, t: 10, pad: 0 },\n paper_bgcolor: theme.paperBg,\n plot_bgcolor: theme.plotBg,\n font: {\n family: \"Inter, sans-serif\",\n },\n showlegend: false,\n xaxis: {\n showgrid: false,\n zeroline: false,\n showticklabels: false,\n showline: false,\n range: [Math.min(...positions), Math.max(...positions)],\n fixedrange: true,\n },\n yaxis: {\n showgrid: false,\n zeroline: false,\n showticklabels: false,\n showline: false,\n range: [0, maxValue * Y_AXIS_PADDING_FACTOR],\n fixedrange: true,\n },\n };\n\n const config = {\n responsive: true,\n displayModeBar: false,\n displaylogo: false,\n fillFrame: true,\n };\n\n Plotly.newPlot(plotRef.current, plotData, layout, config);\n\n // Capture ref value for cleanup\n const plotElement = plotRef.current;\n\n return () => {\n if (plotElement) {\n Plotly.purge(plotElement);\n }\n };\n }, [data, width, height, aTrace, tTrace, gTrace, cTrace, maxValue, positions, theme]);\n\n if (data.length === 0) {\n return <div className=\"chart-container\">No data available</div>;\n }\n\n const renderSequence = () => {\n const renderSequenceLetters = () => {\n const minPosition = Math.min(...positions);\n const maxPosition = Math.max(...positions);\n const chartWidth = width;\n\n return (\n <div className=\"sequence-letters-container\">\n {sequence.map((base, index) => {\n const position = positions[index];\n const color =\n base === \"A\"\n ? colorA\n : base === \"T\"\n ? colorT\n : base === \"G\"\n ? colorG\n : base === \"C\"\n ? colorC\n : theme.textColor;\n\n const percentage =\n (position - minPosition) / (maxPosition - minPosition);\n const leftPosition = percentage * chartWidth;\n\n return (\n <span\n key={`base-${index}`}\n className=\"sequence-letter\"\n style={{\n left: `${leftPosition}px`,\n color,\n }}\n >\n {base}\n </span>\n );\n })}\n </div>\n );\n };\n\n const renderPositionNumbers = () => {\n const minPosition = Math.min(...positions);\n const maxPosition = Math.max(...positions);\n const chartWidth = width;\n\n const startPos =\n Math.ceil(minPosition / positionInterval) * positionInterval;\n\n const regularPositionLabels: Array<{ position: number; label: string }> =\n [];\n\n for (let pos = startPos; pos <= maxPosition; pos += positionInterval) {\n regularPositionLabels.push({\n position: pos,\n label: pos.toString(),\n });\n }\n\n return (\n <div className=\"position-numbers-container\">\n {regularPositionLabels.map((label) => {\n const percentage =\n (label.position - minPosition) / (maxPosition - minPosition);\n const leftPosition = percentage * chartWidth;\n\n return (\n <span\n key={`pos-${label.position}`}\n className=\"position-number\"\n style={{\n left: `${leftPosition}px`,\n }}\n >\n {label.label}\n </span>\n );\n })}\n </div>\n );\n };\n\n return (\n <div className=\"sequence-header\">\n {renderSequenceLetters()}\n {renderPositionNumbers()}\n </div>\n );\n };\n\n return (\n <div className=\"chromatogram-container\" style={{ width, height }}>\n {renderSequence()}\n <div className=\"chromatogram-chart\">\n <div ref={plotRef} style={{ width: \"100%\", height: \"100%\" }} />\n </div>\n </div>\n );\n};\n\nexport { Chromatogram };\nexport type { PeakData, ChromatogramProps };\n"],"names":["PLOT_HEIGHT_OFFSET","Y_AXIS_PADDING_FACTOR","determineBase","item","peakValues","values","val","highestBase","highestValue","base","value","Chromatogram","data","width","height","positionInterval","colorA","colorT","colorG","colorC","plotRef","useRef","theme","usePlotlyTheme","positions","useMemo","sequence","peakA","peakT","peakG","peakC","aTrace","tTrace","gTrace","cTrace","maxValue","useEffect","plotData","layout","config","Plotly","plotElement","jsx","renderSequence","renderSequenceLetters","minPosition","maxPosition","chartWidth","index","position","color","leftPosition","renderPositionNumbers","startPos","regularPositionLabels","pos","label","jsxs"],"mappings":"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"}
@@ -0,0 +1,164 @@
1
+ import { jsx as p, jsxs as _ } from "react/jsx-runtime";
2
+ import B from "plotly.js-dist";
3
+ import { useRef as D, useMemo as n, useEffect as O } from "react";
4
+ import { usePlotlyTheme as j } from "../../../hooks/use-plotly-theme.js";
5
+ /* empty css */
6
+ const $ = 75, L = 1.05, R = (e) => {
7
+ const r = {
8
+ A: e.peakA,
9
+ T: e.peakT,
10
+ G: e.peakG,
11
+ C: e.peakC
12
+ }, m = Object.values(r);
13
+ if (m.every((i) => i === m[0]))
14
+ return "";
15
+ let h = "", u = 0;
16
+ return Object.entries(r).forEach(([i, f]) => {
17
+ f > u && (h = i, u = f);
18
+ }), h;
19
+ }, Y = ({
20
+ data: e = [],
21
+ width: r = 900,
22
+ height: m = 600,
23
+ positionInterval: d = 10,
24
+ colorA: h = "#2D9CDB",
25
+ colorT: u = "#A1C63C",
26
+ colorG: i = "#FF5C64",
27
+ colorC: f = "#FFA62E"
28
+ }) => {
29
+ const x = D(null), y = j(), s = n(() => e.map((t) => t.position), [e]), G = n(() => e.map((t) => R(t)), [e]), k = n(() => e.map((t) => t.peakA), [e]), P = n(() => e.map((t) => t.peakT), [e]), T = n(() => e.map((t) => t.peakG), [e]), C = n(() => e.map((t) => t.peakC), [e]), b = n(
30
+ () => ({
31
+ x: s,
32
+ y: k,
33
+ type: "scatter",
34
+ mode: "lines",
35
+ name: "A",
36
+ line: { color: h, width: 2, shape: "spline" }
37
+ }),
38
+ [s, k, h]
39
+ ), q = n(
40
+ () => ({
41
+ x: s,
42
+ y: P,
43
+ type: "scatter",
44
+ mode: "lines",
45
+ name: "T",
46
+ line: { color: u, width: 2, shape: "spline" }
47
+ }),
48
+ [s, P, u]
49
+ ), v = n(
50
+ () => ({
51
+ x: s,
52
+ y: T,
53
+ type: "scatter",
54
+ mode: "lines",
55
+ name: "G",
56
+ line: { color: i, width: 2, shape: "spline" }
57
+ }),
58
+ [s, T, i]
59
+ ), w = n(
60
+ () => ({
61
+ x: s,
62
+ y: C,
63
+ type: "scatter",
64
+ mode: "lines",
65
+ name: "C",
66
+ line: { color: f, width: 2, shape: "spline" }
67
+ }),
68
+ [s, C, f]
69
+ ), A = n(
70
+ () => Math.max(...k, ...P, ...T, ...C),
71
+ [k, P, T, C]
72
+ );
73
+ return O(() => {
74
+ if (!x.current || e.length === 0) return;
75
+ const t = [b, q, v, w], N = {
76
+ width: r,
77
+ height: m - $,
78
+ margin: { l: 0, r: 0, b: 20, t: 10, pad: 0 },
79
+ paper_bgcolor: y.paperBg,
80
+ plot_bgcolor: y.plotBg,
81
+ font: {
82
+ family: "Inter, sans-serif"
83
+ },
84
+ showlegend: !1,
85
+ xaxis: {
86
+ showgrid: !1,
87
+ zeroline: !1,
88
+ showticklabels: !1,
89
+ showline: !1,
90
+ range: [Math.min(...s), Math.max(...s)],
91
+ fixedrange: !0
92
+ },
93
+ yaxis: {
94
+ showgrid: !1,
95
+ zeroline: !1,
96
+ showticklabels: !1,
97
+ showline: !1,
98
+ range: [0, A * L],
99
+ fixedrange: !0
100
+ }
101
+ }, a = {
102
+ responsive: !0,
103
+ displayModeBar: !1,
104
+ displaylogo: !1,
105
+ fillFrame: !0
106
+ };
107
+ B.newPlot(x.current, t, N, a);
108
+ const c = x.current;
109
+ return () => {
110
+ c && B.purge(c);
111
+ };
112
+ }, [e, r, m, b, q, v, w, A, s, y]), e.length === 0 ? /* @__PURE__ */ p("div", { className: "chart-container", children: "No data available" }) : /* @__PURE__ */ _("div", { className: "chromatogram-container", style: { width: r, height: m }, children: [
113
+ (() => {
114
+ const t = () => {
115
+ const a = Math.min(...s), c = Math.max(...s), M = r;
116
+ return /* @__PURE__ */ p("div", { className: "sequence-letters-container", children: G.map((l, g) => {
117
+ const o = s[g], E = l === "A" ? h : l === "T" ? u : l === "G" ? i : l === "C" ? f : y.textColor, S = (o - a) / (c - a) * M;
118
+ return /* @__PURE__ */ p(
119
+ "span",
120
+ {
121
+ className: "sequence-letter",
122
+ style: {
123
+ left: `${S}px`,
124
+ color: E
125
+ },
126
+ children: l
127
+ },
128
+ `base-${g}`
129
+ );
130
+ }) });
131
+ }, N = () => {
132
+ const a = Math.min(...s), c = Math.max(...s), M = r, l = Math.ceil(a / d) * d, g = [];
133
+ for (let o = l; o <= c; o += d)
134
+ g.push({
135
+ position: o,
136
+ label: o.toString()
137
+ });
138
+ return /* @__PURE__ */ p("div", { className: "position-numbers-container", children: g.map((o) => {
139
+ const F = (o.position - a) / (c - a) * M;
140
+ return /* @__PURE__ */ p(
141
+ "span",
142
+ {
143
+ className: "position-number",
144
+ style: {
145
+ left: `${F}px`
146
+ },
147
+ children: o.label
148
+ },
149
+ `pos-${o.position}`
150
+ );
151
+ }) });
152
+ };
153
+ return /* @__PURE__ */ _("div", { className: "sequence-header", children: [
154
+ t(),
155
+ N()
156
+ ] });
157
+ })(),
158
+ /* @__PURE__ */ p("div", { className: "chromatogram-chart", children: /* @__PURE__ */ p("div", { ref: x, style: { width: "100%", height: "100%" } }) })
159
+ ] });
160
+ };
161
+ export {
162
+ Y as Chromatogram
163
+ };
164
+ //# sourceMappingURL=Chromatogram.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Chromatogram.js","sources":["../../../../src/components/charts/Chromatogram/Chromatogram.tsx"],"sourcesContent":["import Plotly from \"plotly.js-dist\";\nimport React, { useEffect, useRef, useMemo } from \"react\";\n\nimport { usePlotlyTheme } from \"@/hooks/use-plotly-theme\";\nimport \"./Chromatogram.scss\";\n\n/** Height offset for the plot area in pixels */\nconst PLOT_HEIGHT_OFFSET = 75;\n/** Scale factor for y-axis range to add padding above max value */\nconst Y_AXIS_PADDING_FACTOR = 1.05;\n\ninterface PeakData {\n position: number;\n base?: string;\n peakA: number;\n peakT: number;\n peakG: number;\n peakC: number;\n}\n\ninterface ChromatogramProps {\n data?: PeakData[];\n width?: number;\n height?: number;\n positionInterval?: number;\n colorA?: string;\n colorT?: string;\n colorG?: string;\n colorC?: string;\n}\n\nconst determineBase = (item: PeakData): string => {\n const peakValues = {\n A: item.peakA,\n T: item.peakT,\n G: item.peakG,\n C: item.peakC,\n };\n\n const values = Object.values(peakValues);\n const allEqual = values.every((val) => val === values[0]);\n\n if (allEqual) {\n return \"\";\n }\n\n let highestBase = \"\";\n let highestValue = 0;\n\n Object.entries(peakValues).forEach(([base, value]) => {\n if (value > highestValue) {\n highestBase = base;\n highestValue = value;\n }\n });\n\n return highestBase;\n};\n\nconst Chromatogram: React.FC<ChromatogramProps> = ({\n data = [],\n width = 900,\n height = 600,\n positionInterval = 10,\n colorA = \"#2D9CDB\",\n colorT = \"#A1C63C\",\n colorG = \"#FF5C64\",\n colorC = \"#FFA62E\",\n}) => {\n const plotRef = useRef<HTMLDivElement>(null);\n const theme = usePlotlyTheme();\n\n const positions = useMemo(() => data.map((item) => item.position), [data]);\n const sequence = useMemo(() => data.map((item) => determineBase(item)), [data]);\n const peakA = useMemo(() => data.map((item) => item.peakA), [data]);\n const peakT = useMemo(() => data.map((item) => item.peakT), [data]);\n const peakG = useMemo(() => data.map((item) => item.peakG), [data]);\n const peakC = useMemo(() => data.map((item) => item.peakC), [data]);\n\n const aTrace = useMemo(\n () => ({\n x: positions,\n y: peakA,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"A\",\n line: { color: colorA, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakA, colorA],\n );\n\n const tTrace = useMemo(\n () => ({\n x: positions,\n y: peakT,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"T\",\n line: { color: colorT, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakT, colorT],\n );\n\n const gTrace = useMemo(\n () => ({\n x: positions,\n y: peakG,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"G\",\n line: { color: colorG, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakG, colorG],\n );\n\n const cTrace = useMemo(\n () => ({\n x: positions,\n y: peakC,\n type: \"scatter\" as const,\n mode: \"lines\" as const,\n name: \"C\",\n line: { color: colorC, width: 2, shape: \"spline\" as const },\n }),\n [positions, peakC, colorC],\n );\n\n const maxValue = useMemo(\n () => Math.max(...peakA, ...peakT, ...peakG, ...peakC),\n [peakA, peakT, peakG, peakC],\n );\n\n useEffect(() => {\n if (!plotRef.current || data.length === 0) return;\n\n const plotData = [aTrace, tTrace, gTrace, cTrace];\n\n const layout: Partial<Plotly.Layout> = {\n width: width,\n height: height - PLOT_HEIGHT_OFFSET,\n margin: { l: 0, r: 0, b: 20, t: 10, pad: 0 },\n paper_bgcolor: theme.paperBg,\n plot_bgcolor: theme.plotBg,\n font: {\n family: \"Inter, sans-serif\",\n },\n showlegend: false,\n xaxis: {\n showgrid: false,\n zeroline: false,\n showticklabels: false,\n showline: false,\n range: [Math.min(...positions), Math.max(...positions)],\n fixedrange: true,\n },\n yaxis: {\n showgrid: false,\n zeroline: false,\n showticklabels: false,\n showline: false,\n range: [0, maxValue * Y_AXIS_PADDING_FACTOR],\n fixedrange: true,\n },\n };\n\n const config = {\n responsive: true,\n displayModeBar: false,\n displaylogo: false,\n fillFrame: true,\n };\n\n Plotly.newPlot(plotRef.current, plotData, layout, config);\n\n // Capture ref value for cleanup\n const plotElement = plotRef.current;\n\n return () => {\n if (plotElement) {\n Plotly.purge(plotElement);\n }\n };\n }, [data, width, height, aTrace, tTrace, gTrace, cTrace, maxValue, positions, theme]);\n\n if (data.length === 0) {\n return <div className=\"chart-container\">No data available</div>;\n }\n\n const renderSequence = () => {\n const renderSequenceLetters = () => {\n const minPosition = Math.min(...positions);\n const maxPosition = Math.max(...positions);\n const chartWidth = width;\n\n return (\n <div className=\"sequence-letters-container\">\n {sequence.map((base, index) => {\n const position = positions[index];\n const color =\n base === \"A\"\n ? colorA\n : base === \"T\"\n ? colorT\n : base === \"G\"\n ? colorG\n : base === \"C\"\n ? colorC\n : theme.textColor;\n\n const percentage =\n (position - minPosition) / (maxPosition - minPosition);\n const leftPosition = percentage * chartWidth;\n\n return (\n <span\n key={`base-${index}`}\n className=\"sequence-letter\"\n style={{\n left: `${leftPosition}px`,\n color,\n }}\n >\n {base}\n </span>\n );\n })}\n </div>\n );\n };\n\n const renderPositionNumbers = () => {\n const minPosition = Math.min(...positions);\n const maxPosition = Math.max(...positions);\n const chartWidth = width;\n\n const startPos =\n Math.ceil(minPosition / positionInterval) * positionInterval;\n\n const regularPositionLabels: Array<{ position: number; label: string }> =\n [];\n\n for (let pos = startPos; pos <= maxPosition; pos += positionInterval) {\n regularPositionLabels.push({\n position: pos,\n label: pos.toString(),\n });\n }\n\n return (\n <div className=\"position-numbers-container\">\n {regularPositionLabels.map((label) => {\n const percentage =\n (label.position - minPosition) / (maxPosition - minPosition);\n const leftPosition = percentage * chartWidth;\n\n return (\n <span\n key={`pos-${label.position}`}\n className=\"position-number\"\n style={{\n left: `${leftPosition}px`,\n }}\n >\n {label.label}\n </span>\n );\n })}\n </div>\n );\n };\n\n return (\n <div className=\"sequence-header\">\n {renderSequenceLetters()}\n {renderPositionNumbers()}\n </div>\n );\n };\n\n return (\n <div className=\"chromatogram-container\" style={{ width, height }}>\n {renderSequence()}\n <div className=\"chromatogram-chart\">\n <div ref={plotRef} style={{ width: \"100%\", height: \"100%\" }} />\n </div>\n </div>\n );\n};\n\nexport { Chromatogram };\nexport type { PeakData, ChromatogramProps };\n"],"names":["PLOT_HEIGHT_OFFSET","Y_AXIS_PADDING_FACTOR","determineBase","item","peakValues","values","val","highestBase","highestValue","base","value","Chromatogram","data","width","height","positionInterval","colorA","colorT","colorG","colorC","plotRef","useRef","theme","usePlotlyTheme","positions","useMemo","sequence","peakA","peakT","peakG","peakC","aTrace","tTrace","gTrace","cTrace","maxValue","useEffect","plotData","layout","config","Plotly","plotElement","jsx","jsxs","renderSequenceLetters","minPosition","maxPosition","chartWidth","index","position","color","leftPosition","renderPositionNumbers","startPos","regularPositionLabels","pos","label"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("react/jsx-runtime"),Y=require("plotly.js-dist"),u=require("react"),j=require("../../../utils/colors.cjs"),D=require("./annotations.cjs"),K=require("./boundaryMarkers.cjs"),s=require("./constants.cjs"),f=require("./dataProcessing.cjs"),Q=require("./peakDetection.cjs"),V=require("../../../hooks/use-plotly-theme.cjs"),Z=({series:a,width:A=900,height:T=500,title:d,xAxisTitle:R="Retention Time (min)",yAxisTitle:k="Signal (mAU)",annotations:m=[],xRange:M,yRange:O,showLegend:P=!0,showGridX:v=!0,showGridY:G=!0,showMarkers:C=!1,markerSize:H=4,showCrosshairs:p=!1,baselineCorrection:q="none",baselineWindowSize:L=50,peakDetectionOptions:l,showPeakAreas:b=!1,boundaryMarkers:z="none",annotationOverlapThreshold:B=.4,showExportButton:x=!0})=>{const g=l!==void 0,N=u.useRef(null),e=V.usePlotlyTheme(),n=u.useMemo(()=>a.map(t=>{const r=f.validateSeriesData(t.x,t.y);return{...t,x:r.x,y:f.applyBaselineCorrection(r.y,q,L)}}),[a,q,L]),I=u.useMemo(()=>{if(m.length===0||n.length===0)return m;const{x:t,y:r}=n[0];return f.processUserAnnotations(m,t,r)},[m,n]),_=u.useMemo(()=>{const t=[];return g&&l&&n.forEach((r,c)=>{const y=Q.detectPeaks(r.x,r.y,l);y.length>0&&t.push({peaks:y,seriesIndex:c})}),t},[n,g,l]);return u.useEffect(()=>{const t=N.current;if(!t||a.length===0)return;const r=n.map((o,i)=>{const h=o.color||j.CHART_COLORS[i%j.CHART_COLORS.length],J=f.buildHoverExtraContent(o.name,o.metadata),E={x:o.x,y:o.y,type:"scatter",mode:C?"lines+markers":"lines",name:o.name,line:{color:h,width:1.5},hovertemplate:`%{x:.2f} ${R}<br>%{y:.2f} ${k}<extra>${J}</extra>`};return C&&(E.marker={size:H,color:h}),E});if(z!=="none"){const o=f.collectPeaksWithBoundaryData(_,I,n);if(o.length>0){const i=K.createBoundaryMarkerTraces(o);r.push(...i)}}const c=[];I.forEach(o=>{c.push({peak:o,seriesIndex:-1})}),b&&g&&_.forEach(({peaks:o,seriesIndex:i})=>{o.forEach(h=>{c.push({peak:h,seriesIndex:i})})});const y=D.groupOverlappingPeaks(c,B),U=[];for(const o of y)U.push(...D.createGroupAnnotations(o));const W={title:d?{text:d,font:{size:20,family:"Inter, sans-serif",color:e.textColor}}:void 0,width:A,height:T,margin:{l:s.CHROMATOGRAM_LAYOUT.MARGIN_LEFT,r:s.CHROMATOGRAM_LAYOUT.MARGIN_RIGHT,b:s.CHROMATOGRAM_LAYOUT.MARGIN_BOTTOM,t:d?s.CHROMATOGRAM_LAYOUT.MARGIN_TOP_WITH_TITLE:s.CHROMATOGRAM_LAYOUT.MARGIN_TOP_NO_TITLE,pad:s.CHROMATOGRAM_LAYOUT.MARGIN_PAD},paper_bgcolor:e.paperBg,plot_bgcolor:e.plotBg,font:{family:"Inter, sans-serif"},hovermode:p?"x":"x unified",dragmode:"zoom",xaxis:{title:{text:R,font:{size:14,color:e.textSecondary,family:"Inter, sans-serif"},standoff:15},showgrid:v,gridcolor:e.gridColor,linecolor:e.lineColor,linewidth:1,range:M,autorange:!M,zeroline:!1,tickfont:{size:12,color:e.textColor,family:"Inter, sans-serif"},showspikes:p,spikemode:"across",spikesnap:"cursor",spikecolor:e.spikeColor,spikethickness:1,spikedash:"dot"},yaxis:{title:{text:k,font:{size:14,color:e.textSecondary,family:"Inter, sans-serif"},standoff:10},showgrid:G,gridcolor:e.gridColor,linecolor:e.lineColor,linewidth:1,range:O,autorange:!O,zeroline:!1,tickfont:{size:12,color:e.textColor,family:"Inter, sans-serif"},showspikes:p,spikemode:"across",spikesnap:"cursor",spikecolor:e.spikeColor,spikethickness:1,spikedash:"dot"},legend:{x:.5,y:-.15,xanchor:"center",yanchor:"top",orientation:"h",font:{size:12,color:e.textColor,family:"Inter, sans-serif"}},showlegend:P&&a.length>1,annotations:U},F={responsive:!0,displayModeBar:!0,displaylogo:!1,modeBarButtonsToRemove:["lasso2d","select2d",...x?[]:["toImage"]],...x&&{toImageButtonOptions:{format:"png",filename:"chromatogram",width:A,height:T}}};return Y.newPlot(t,r,W,F),()=>{t&&Y.purge(t)}},[n,_,a.length,A,T,d,R,k,I,M,O,P,v,G,C,H,p,g,l,b,z,B,x,e]),S.jsx("div",{className:"chromatogram-chart-container",children:S.jsx("div",{ref:N,style:{width:"100%",height:"100%"}})})};exports.ChromatogramChart=Z;
2
+ //# sourceMappingURL=ChromatogramChart.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChromatogramChart.cjs","sources":["../../../../src/components/charts/ChromatogramChart/ChromatogramChart.tsx"],"sourcesContent":["import Plotly from \"plotly.js-dist\";\nimport React, { useEffect, useMemo, useRef } from \"react\";\n\nimport { CHART_COLORS } from \"../../../utils/colors\";\n\n\nimport {\n groupOverlappingPeaks,\n createGroupAnnotations,\n} from \"./annotations\";\nimport { createBoundaryMarkerTraces } from \"./boundaryMarkers\";\nimport { CHROMATOGRAM_LAYOUT } from \"./constants\";\nimport {\n validateSeriesData,\n applyBaselineCorrection,\n buildHoverExtraContent,\n collectPeaksWithBoundaryData,\n processUserAnnotations,\n} from \"./dataProcessing\";\nimport { detectPeaks } from \"./peakDetection\";\n\nimport type {\n ChromatogramSeries,\n PeakAnnotation,\n BaselineCorrectionMethod,\n BoundaryMarkerStyle,\n BoundaryMarkerType,\n PeakDetectionOptions,\n ChromatogramChartProps,\n PeakWithMeta,\n} from \"./types\";\n\nimport { usePlotlyTheme } from \"@/hooks/use-plotly-theme\";\n\n// Re-export types for external use\nexport type {\n ChromatogramSeries,\n PeakAnnotation,\n BaselineCorrectionMethod,\n BoundaryMarkerStyle,\n BoundaryMarkerType,\n PeakDetectionOptions,\n ChromatogramChartProps,\n};\n\n\nconst ChromatogramChart: React.FC<ChromatogramChartProps> = ({\n series,\n width = 900,\n height = 500,\n title,\n xAxisTitle = \"Retention Time (min)\",\n yAxisTitle = \"Signal (mAU)\",\n annotations = [],\n xRange,\n yRange,\n showLegend = true,\n showGridX = true,\n showGridY = true,\n showMarkers = false,\n markerSize = 4,\n showCrosshairs = false,\n baselineCorrection = \"none\",\n baselineWindowSize = 50,\n peakDetectionOptions,\n showPeakAreas = false,\n boundaryMarkers = \"none\",\n annotationOverlapThreshold = 0.4,\n showExportButton = true,\n}) => {\n // Derive peak detection state from options\n const enablePeakDetection = peakDetectionOptions !== undefined;\n const plotRef = useRef<HTMLDivElement>(null);\n const theme = usePlotlyTheme();\n\n // Memoize processed series with baseline correction\n const processedSeries = useMemo(() => {\n return series.map((s) => {\n const validated = validateSeriesData(s.x, s.y);\n return {\n ...s,\n x: validated.x,\n y: applyBaselineCorrection(validated.y, baselineCorrection, baselineWindowSize),\n };\n });\n }, [series, baselineCorrection, baselineWindowSize]);\n\n // Process user annotations to convert startX/endX to indices and compute areas\n const processedAnnotations = useMemo(() => {\n if (annotations.length === 0 || processedSeries.length === 0) {\n return annotations;\n }\n // Use first series data for index lookup (user annotations apply to first series)\n const { x, y } = processedSeries[0];\n return processUserAnnotations(annotations, x, y);\n }, [annotations, processedSeries]);\n\n // Memoize peak detection results\n const allDetectedPeaks = useMemo(() => {\n const peaks: { peaks: PeakAnnotation[]; seriesIndex: number }[] = [];\n if (enablePeakDetection && peakDetectionOptions) {\n processedSeries.forEach((s, index) => {\n const detected = detectPeaks(s.x, s.y, peakDetectionOptions);\n if (detected.length > 0) {\n peaks.push({ peaks: detected, seriesIndex: index });\n }\n });\n }\n return peaks;\n }, [processedSeries, enablePeakDetection, peakDetectionOptions]);\n\n useEffect(() => {\n const currentRef = plotRef.current;\n if (!currentRef || series.length === 0) return;\n\n // Build trace data with auto-assigned colors\n const plotData: Plotly.Data[] = processedSeries.map((s, index) => {\n const traceColor = s.color || CHART_COLORS[index % CHART_COLORS.length];\n const extraContent = buildHoverExtraContent(s.name, s.metadata);\n\n const trace: Plotly.Data = {\n x: s.x,\n y: s.y,\n type: \"scatter\" as const,\n mode: showMarkers ? \"lines+markers\" as const : \"lines\" as const,\n name: s.name,\n line: {\n color: traceColor,\n width: 1.5,\n },\n hovertemplate: `%{x:.2f} ${xAxisTitle}<br>%{y:.2f} ${yAxisTitle}<extra>${extraContent}</extra>`,\n };\n if (showMarkers) {\n trace.marker = {\n size: markerSize,\n color: traceColor,\n };\n }\n return trace;\n });\n\n // Add peak boundary markers if enabled\n if (boundaryMarkers !== \"none\") {\n const peaksWithData = collectPeaksWithBoundaryData(allDetectedPeaks, processedAnnotations, processedSeries);\n if (peaksWithData.length > 0) {\n const boundaryTraces = createBoundaryMarkerTraces(peaksWithData);\n plotData.push(...boundaryTraces);\n }\n }\n\n // Collect all peaks for unified staggering logic\n const allPeaksWithMeta: PeakWithMeta[] = [];\n\n // Add user-defined annotations (seriesIndex -1 indicates user-defined)\n processedAnnotations.forEach((ann) => {\n allPeaksWithMeta.push({ peak: ann, seriesIndex: -1 });\n });\n\n // Add auto-detected peaks if enabled\n if (showPeakAreas && enablePeakDetection) {\n allDetectedPeaks.forEach(({ peaks, seriesIndex }) => {\n peaks.forEach((peak) => {\n allPeaksWithMeta.push({ peak, seriesIndex });\n });\n });\n }\n\n // Group all overlapping peaks and create annotations with staggering\n const groups = groupOverlappingPeaks(allPeaksWithMeta, annotationOverlapThreshold);\n const plotlyAnnotations: Partial<Plotly.Annotations>[] = [];\n\n for (const group of groups) {\n plotlyAnnotations.push(...createGroupAnnotations(group));\n }\n\n const layout: Partial<Plotly.Layout> = {\n title: title\n ? {\n text: title,\n font: {\n size: 20,\n family: \"Inter, sans-serif\",\n color: theme.textColor,\n },\n }\n : undefined,\n width,\n height,\n margin: {\n l: CHROMATOGRAM_LAYOUT.MARGIN_LEFT,\n r: CHROMATOGRAM_LAYOUT.MARGIN_RIGHT,\n b: CHROMATOGRAM_LAYOUT.MARGIN_BOTTOM,\n t: title ? CHROMATOGRAM_LAYOUT.MARGIN_TOP_WITH_TITLE : CHROMATOGRAM_LAYOUT.MARGIN_TOP_NO_TITLE,\n pad: CHROMATOGRAM_LAYOUT.MARGIN_PAD,\n },\n paper_bgcolor: theme.paperBg,\n plot_bgcolor: theme.plotBg,\n font: { family: \"Inter, sans-serif\" },\n hovermode: showCrosshairs ? \"x\" as const : \"x unified\" as const,\n dragmode: \"zoom\" as const,\n xaxis: {\n title: {\n text: xAxisTitle,\n font: { size: 14, color: theme.textSecondary, family: \"Inter, sans-serif\" },\n standoff: 15,\n },\n showgrid: showGridX,\n gridcolor: theme.gridColor,\n linecolor: theme.lineColor,\n linewidth: 1,\n range: xRange,\n autorange: !xRange,\n zeroline: false,\n tickfont: { size: 12, color: theme.textColor, family: \"Inter, sans-serif\" },\n showspikes: showCrosshairs,\n spikemode: \"across\" as const,\n spikesnap: \"cursor\" as const,\n spikecolor: theme.spikeColor,\n spikethickness: 1,\n spikedash: \"dot\" as const,\n },\n yaxis: {\n title: {\n text: yAxisTitle,\n font: { size: 14, color: theme.textSecondary, family: \"Inter, sans-serif\" },\n standoff: 10,\n },\n showgrid: showGridY,\n gridcolor: theme.gridColor,\n linecolor: theme.lineColor,\n linewidth: 1,\n range: yRange,\n autorange: !yRange,\n zeroline: false,\n tickfont: { size: 12, color: theme.textColor, family: \"Inter, sans-serif\" },\n showspikes: showCrosshairs,\n spikemode: \"across\" as const,\n spikesnap: \"cursor\" as const,\n spikecolor: theme.spikeColor,\n spikethickness: 1,\n spikedash: \"dot\" as const,\n },\n legend: {\n x: 0.5,\n y: -0.15,\n xanchor: \"center\" as const,\n yanchor: \"top\" as const,\n orientation: \"h\" as const,\n font: { size: 12, color: theme.textColor, family: \"Inter, sans-serif\" },\n },\n showlegend: showLegend && series.length > 1,\n annotations: plotlyAnnotations,\n };\n\n const config: Partial<Plotly.Config> = {\n responsive: true,\n displayModeBar: true,\n displaylogo: false,\n modeBarButtonsToRemove: [\n \"lasso2d\",\n \"select2d\",\n ...(showExportButton ? [] : [\"toImage\"] as Plotly.ModeBarDefaultButtons[]),\n ] as Plotly.ModeBarDefaultButtons[],\n ...(showExportButton && {\n toImageButtonOptions: {\n format: \"png\",\n filename: \"chromatogram\",\n width: width,\n height: height,\n },\n }),\n };\n\n Plotly.newPlot(currentRef, plotData, layout, config);\n\n return () => {\n if (currentRef) {\n Plotly.purge(currentRef);\n }\n };\n }, [\n processedSeries, allDetectedPeaks, series.length, width, height, title, xAxisTitle, yAxisTitle,\n processedAnnotations, xRange, yRange, showLegend, showGridX, showGridY, showMarkers, markerSize,\n showCrosshairs, enablePeakDetection, peakDetectionOptions, showPeakAreas, boundaryMarkers,\n annotationOverlapThreshold, showExportButton, theme,\n ]);\n\n return (\n <div className=\"chromatogram-chart-container\">\n <div ref={plotRef} style={{ width: \"100%\", height: \"100%\" }} />\n </div>\n );\n};\n\nexport { ChromatogramChart };\n\n"],"names":["ChromatogramChart","series","width","height","title","xAxisTitle","yAxisTitle","annotations","xRange","yRange","showLegend","showGridX","showGridY","showMarkers","markerSize","showCrosshairs","baselineCorrection","baselineWindowSize","peakDetectionOptions","showPeakAreas","boundaryMarkers","annotationOverlapThreshold","showExportButton","enablePeakDetection","plotRef","useRef","theme","usePlotlyTheme","processedSeries","useMemo","s","validated","validateSeriesData","applyBaselineCorrection","processedAnnotations","x","y","processUserAnnotations","allDetectedPeaks","peaks","index","detected","detectPeaks","useEffect","currentRef","plotData","traceColor","CHART_COLORS","extraContent","buildHoverExtraContent","trace","peaksWithData","collectPeaksWithBoundaryData","boundaryTraces","createBoundaryMarkerTraces","allPeaksWithMeta","ann","seriesIndex","peak","groups","groupOverlappingPeaks","plotlyAnnotations","group","createGroupAnnotations","layout","CHROMATOGRAM_LAYOUT","config","Plotly","jsx"],"mappings":"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"}