@morscherlab/mint-sdk 1.0.0-beta.2 → 1.0.0-beta.4

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 (427) hide show
  1. package/README.md +225 -6
  2. package/dist/__tests__/components/ActionItem.test.d.ts +1 -0
  3. package/dist/__tests__/components/AppAvatarMenu.test.d.ts +1 -0
  4. package/dist/__tests__/components/AppPageSelector.test.d.ts +1 -0
  5. package/dist/__tests__/components/AppPillNav.test.d.ts +1 -0
  6. package/dist/__tests__/components/AppPluginSwitcher.test.d.ts +1 -0
  7. package/dist/__tests__/components/AppToastContainer.test.d.ts +1 -0
  8. package/dist/__tests__/components/BaseRadioGroup.test.d.ts +1 -0
  9. package/dist/__tests__/components/BaseSelect.test.d.ts +1 -0
  10. package/dist/__tests__/components/BaseTabs.test.d.ts +1 -0
  11. package/dist/__tests__/components/BatchProgressList.test.d.ts +1 -0
  12. package/dist/__tests__/components/BioTemplateExperimentWorkspaceView.test.d.ts +1 -0
  13. package/dist/__tests__/components/BioTemplatePackWorkspaceView.test.d.ts +1 -0
  14. package/dist/__tests__/components/BioTemplatePresetWorkspaceView.test.d.ts +1 -0
  15. package/dist/__tests__/components/BioTemplateRenderer.test.d.ts +1 -0
  16. package/dist/__tests__/components/Breadcrumb.test.d.ts +1 -0
  17. package/dist/__tests__/components/CalendarGridPanel.test.d.ts +1 -0
  18. package/dist/__tests__/components/ComponentBindingRenderer.test.d.ts +1 -0
  19. package/dist/__tests__/components/ConcentrationInput.test.d.ts +1 -0
  20. package/dist/__tests__/components/ControlWorkspaceView.test.d.ts +1 -0
  21. package/dist/__tests__/components/DatePicker.test.d.ts +1 -0
  22. package/dist/__tests__/components/DateTimePicker.test.d.ts +1 -0
  23. package/dist/__tests__/components/DoseDesignWorkspaceView.test.d.ts +1 -0
  24. package/dist/__tests__/components/EmptyState.test.d.ts +1 -0
  25. package/dist/__tests__/components/ExperimentPopover.test.d.ts +1 -0
  26. package/dist/__tests__/components/FormBuilder.test.d.ts +1 -0
  27. package/dist/__tests__/components/GroupAssigner.test.d.ts +1 -0
  28. package/dist/__tests__/components/MultiSelect.test.d.ts +1 -0
  29. package/dist/__tests__/components/PluginWorkspaceView.test.d.ts +1 -0
  30. package/dist/__tests__/components/ProtocolStepEditor.test.d.ts +1 -0
  31. package/dist/__tests__/components/ReagentList.test.d.ts +1 -0
  32. package/dist/__tests__/components/SampleHierarchyTree.test.d.ts +1 -0
  33. package/dist/__tests__/components/SampleSelector.test.d.ts +1 -0
  34. package/dist/__tests__/components/SegmentedControl.test.d.ts +1 -0
  35. package/dist/__tests__/components/SettingsModal.test.d.ts +1 -0
  36. package/dist/__tests__/components/TagsInput.test.d.ts +1 -0
  37. package/dist/__tests__/components/ThemeToggle.test.d.ts +1 -0
  38. package/dist/__tests__/components/TimePicker.test.d.ts +1 -0
  39. package/dist/__tests__/composables/experiment-utils.test.d.ts +1 -0
  40. package/dist/__tests__/composables/useApi.test.d.ts +1 -0
  41. package/dist/__tests__/composables/useBioTemplatePackWorkspace.test.d.ts +1 -0
  42. package/dist/__tests__/composables/useBioTemplatePresetWorkspace.test.d.ts +1 -0
  43. package/dist/__tests__/composables/useBioTemplateWorkspace.test.d.ts +1 -0
  44. package/dist/__tests__/composables/useCalendarGrid.test.d.ts +1 -0
  45. package/dist/__tests__/composables/useControlSchema.test.d.ts +1 -0
  46. package/dist/__tests__/composables/useDebouncedWatch.test.d.ts +1 -0
  47. package/dist/__tests__/composables/useDropdownState.test.d.ts +1 -0
  48. package/dist/__tests__/composables/useEventListener.test.d.ts +1 -0
  49. package/dist/__tests__/composables/useExpansionSet.test.d.ts +1 -0
  50. package/dist/__tests__/composables/useExperimentData.test.d.ts +1 -0
  51. package/dist/__tests__/composables/useExperimentSelector.test.d.ts +1 -0
  52. package/dist/__tests__/composables/useGroupAssignment.test.d.ts +1 -0
  53. package/dist/__tests__/composables/useListSelection.test.d.ts +1 -0
  54. package/dist/__tests__/composables/usePluginClient.test.d.ts +1 -0
  55. package/dist/__tests__/composables/usePluginConfig.test.d.ts +1 -0
  56. package/dist/__tests__/composables/useRequestSyncState.test.d.ts +1 -0
  57. package/dist/__tests__/composables/useSampleGroups.test.d.ts +1 -0
  58. package/dist/__tests__/composables/useSelectionLimit.test.d.ts +1 -0
  59. package/dist/__tests__/composables/useSortedItems.test.d.ts +1 -0
  60. package/dist/__tests__/composables/useTemplateCollection.test.d.ts +1 -0
  61. package/dist/__tests__/composables/useTextSearch.test.d.ts +1 -0
  62. package/dist/__tests__/composables/useTheme.test.d.ts +1 -0
  63. package/dist/__tests__/composables/useTimeUtils.test.d.ts +1 -0
  64. package/dist/__tests__/docs/frontendDocsCatalog.test.d.ts +1 -0
  65. package/dist/__tests__/templates/templates.test.d.ts +1 -0
  66. package/dist/{auth-DsI0rQ7_.js → auth-QQj2kkze.js} +12 -5
  67. package/dist/auth-QQj2kkze.js.map +1 -0
  68. package/dist/components/AppAvatarMenu.vue.d.ts +2 -7
  69. package/dist/components/AppContainer.vue.d.ts +1 -1
  70. package/dist/components/AppLayout.vue.d.ts +20 -1
  71. package/dist/components/AppSidebar.vue.d.ts +111 -6
  72. package/dist/components/AppTopBar.vue.d.ts +35 -22
  73. package/dist/components/BaseButton.vue.d.ts +1 -1
  74. package/dist/components/BaseCheckbox.vue.d.ts +1 -1
  75. package/dist/components/BaseInput.vue.d.ts +2 -2
  76. package/dist/components/BasePill.vue.d.ts +2 -2
  77. package/dist/components/BaseRadioGroup.vue.d.ts +3 -3
  78. package/dist/components/BaseSelect.vue.d.ts +3 -3
  79. package/dist/components/BaseTabs.vue.d.ts +2 -2
  80. package/dist/components/BaseTextarea.vue.d.ts +1 -1
  81. package/dist/components/BaseToggle.vue.d.ts +1 -1
  82. package/dist/components/BioTemplateExperimentWorkspaceView.vue.d.ts +119 -0
  83. package/dist/components/BioTemplatePackWorkspaceView.vue.d.ts +93 -0
  84. package/dist/components/BioTemplatePresetWorkspaceView.vue.d.ts +87 -0
  85. package/dist/components/BioTemplateRenderer.vue.d.ts +29 -0
  86. package/dist/components/Breadcrumb.vue.d.ts +2 -2
  87. package/dist/components/Calendar.vue.d.ts +1 -1
  88. package/dist/components/CollapsibleCard.vue.d.ts +1 -1
  89. package/dist/components/ComponentBindingRenderer.vue.d.ts +44 -0
  90. package/dist/components/ConcentrationInput.vue.d.ts +2 -2
  91. package/dist/components/ConfirmDialog.vue.d.ts +2 -2
  92. package/dist/components/ControlWorkspaceView.vue.d.ts +147 -0
  93. package/dist/components/DatePicker.vue.d.ts +1 -1
  94. package/dist/components/DateTimePicker.vue.d.ts +3 -3
  95. package/dist/components/Divider.vue.d.ts +1 -1
  96. package/dist/components/DoseDesignWorkspaceView.vue.d.ts +149 -0
  97. package/dist/components/DropdownButton.vue.d.ts +3 -3
  98. package/dist/components/EmptyState.vue.d.ts +1 -2
  99. package/dist/components/ExperimentDataViewer.vue.d.ts +1 -1
  100. package/dist/components/ExperimentTimeline.vue.d.ts +2 -2
  101. package/dist/components/FileUploader.vue.d.ts +1 -1
  102. package/dist/components/FitPanel.vue.d.ts +1 -1
  103. package/dist/components/FormActions.vue.d.ts +4 -4
  104. package/dist/components/FormBuilder.vue.d.ts +31 -17
  105. package/dist/components/FormulaInput.vue.d.ts +2 -2
  106. package/dist/components/MoleculeInput.vue.d.ts +2 -2
  107. package/dist/components/MultiSelect.vue.d.ts +3 -3
  108. package/dist/components/NumberInput.vue.d.ts +1 -1
  109. package/dist/components/PlateMapEditor.vue.d.ts +1 -1
  110. package/dist/components/PluginWorkspaceView.vue.d.ts +310 -0
  111. package/dist/components/ProgressBar.vue.d.ts +1 -1
  112. package/dist/components/ProtocolStepEditor.vue.d.ts +3 -1
  113. package/dist/components/RackEditor.vue.d.ts +2 -2
  114. package/dist/components/SampleLegend.vue.d.ts +2 -2
  115. package/dist/components/ScheduleCalendar.vue.d.ts +2 -2
  116. package/dist/components/SegmentedControl.vue.d.ts +2 -2
  117. package/dist/components/SequenceInput.vue.d.ts +3 -3
  118. package/dist/components/SettingsModal.vue.d.ts +14 -6
  119. package/dist/components/StatusIndicator.vue.d.ts +1 -1
  120. package/dist/components/TagsInput.vue.d.ts +3 -2
  121. package/dist/components/TimePicker.vue.d.ts +3 -3
  122. package/dist/components/TimeRangeInput.vue.d.ts +1 -1
  123. package/dist/components/UnitInput.vue.d.ts +2 -2
  124. package/dist/components/WellPlate.vue.d.ts +6 -6
  125. package/dist/components/index.d.ts +9 -8
  126. package/dist/components/index.js +3 -3
  127. package/dist/components/{SettingsButton.vue.d.ts → internal/ActionItemInternal.vue.d.ts} +11 -9
  128. package/dist/components/{AppPageSelector.vue.d.ts → internal/AppPageSelectorInternal.vue.d.ts} +3 -6
  129. package/dist/components/{AppPillNav.vue.d.ts → internal/AppPillNavInternal.vue.d.ts} +4 -2
  130. package/dist/components/internal/CalendarGridPanelInternal.vue.d.ts +25 -0
  131. package/dist/components/{FormFieldRenderer.vue.d.ts → internal/FormFieldRendererInternal.vue.d.ts} +2 -2
  132. package/dist/components/{FormSection.vue.d.ts → internal/FormSectionRenderer.vue.d.ts} +7 -7
  133. package/dist/components/{WellEditPopup.vue.d.ts → internal/WellEditPopupInternal.vue.d.ts} +1 -1
  134. package/dist/{components-_XqPEhP9.js → components-BkGF4B4y.js} +9760 -8471
  135. package/dist/components-BkGF4B4y.js.map +1 -0
  136. package/dist/composables/experiment-utils.d.ts +8 -0
  137. package/dist/composables/index.d.ts +22 -5
  138. package/dist/composables/index.js +4 -3
  139. package/dist/composables/platformContextHelpers.d.ts +14 -0
  140. package/dist/composables/useAppExperiment.d.ts +31 -2
  141. package/dist/composables/useBioTemplateComponents.d.ts +22 -0
  142. package/dist/composables/useBioTemplateControls.d.ts +6 -0
  143. package/dist/composables/useBioTemplatePackWorkspace.d.ts +46 -0
  144. package/dist/composables/useBioTemplatePresetWorkspace.d.ts +75 -0
  145. package/dist/composables/useBioTemplateWorkspace.d.ts +51 -0
  146. package/dist/composables/useCalendarGrid.d.ts +26 -0
  147. package/dist/composables/useControlSchema.d.ts +343 -0
  148. package/dist/composables/useDebouncedWatch.d.ts +20 -0
  149. package/dist/composables/useDropdownState.d.ts +19 -0
  150. package/dist/composables/useEventListener.d.ts +13 -0
  151. package/dist/composables/useExpansionSet.d.ts +21 -0
  152. package/dist/composables/useExperimentData.d.ts +10 -0
  153. package/dist/composables/useExperimentSave.d.ts +31 -2
  154. package/dist/composables/useExperimentSelector.d.ts +20 -0
  155. package/dist/composables/useForm.d.ts +2 -0
  156. package/dist/composables/useGroupAssignment.d.ts +31 -0
  157. package/dist/composables/useListSelection.d.ts +35 -0
  158. package/dist/composables/usePlatformContext.d.ts +21 -3
  159. package/dist/composables/usePluginClient.d.ts +112 -0
  160. package/dist/composables/usePluginConfig.d.ts +12 -0
  161. package/dist/composables/useRequestSyncState.d.ts +34 -0
  162. package/dist/composables/useSampleGroups.d.ts +32 -0
  163. package/dist/composables/useSelectionLimit.d.ts +17 -0
  164. package/dist/composables/useSortedItems.d.ts +32 -0
  165. package/dist/composables/useTemplateCollection.d.ts +58 -0
  166. package/dist/composables/useTextSearch.d.ts +18 -0
  167. package/dist/composables/useTimeUtils.d.ts +8 -0
  168. package/dist/{composables-tiZqLu1M.js → composables-CHsME9H1.js} +240 -146
  169. package/dist/composables-CHsME9H1.js.map +1 -0
  170. package/dist/index.d.ts +6 -4
  171. package/dist/index.js +6 -5
  172. package/dist/install.d.ts +7 -2
  173. package/dist/install.js +2 -2
  174. package/dist/install.js.map +1 -1
  175. package/dist/stores/index.js +1 -1
  176. package/dist/stores/settings.d.ts +4 -1
  177. package/dist/styles.css +4746 -5514
  178. package/dist/templates/adapters.d.ts +43 -0
  179. package/dist/templates/builders.d.ts +63 -0
  180. package/dist/templates/catalog.d.ts +188 -0
  181. package/dist/templates/componentBindings.d.ts +71 -0
  182. package/dist/templates/controlSchemas.d.ts +25 -0
  183. package/dist/templates/index.d.ts +15 -0
  184. package/dist/templates/index.js +2 -0
  185. package/dist/templates/lookup.d.ts +4 -0
  186. package/dist/templates/packs.d.ts +18 -0
  187. package/dist/templates/presets.d.ts +90 -0
  188. package/dist/templates/types.d.ts +531 -0
  189. package/dist/templates-B5jmTWuk.js +9388 -0
  190. package/dist/templates-B5jmTWuk.js.map +1 -0
  191. package/dist/types/components.d.ts +26 -23
  192. package/dist/types/form-builder.d.ts +6 -8
  193. package/dist/types/index.d.ts +2 -2
  194. package/dist/types/platform.d.ts +7 -1
  195. package/dist/useScheduleDrag-BgzpQT53.js +4414 -0
  196. package/dist/useScheduleDrag-BgzpQT53.js.map +1 -0
  197. package/dist/utils/formModelSync.d.ts +5 -0
  198. package/dist/utils/items.d.ts +8 -0
  199. package/dist/utils/options.d.ts +6 -0
  200. package/dist/utils/pluginIcon.d.ts +9 -0
  201. package/package.json +7 -2
  202. package/src/__tests__/components/ActionItem.test.ts +99 -0
  203. package/src/__tests__/components/AppAvatarMenu.test.ts +27 -0
  204. package/src/__tests__/components/AppLayout.test.ts +44 -0
  205. package/src/__tests__/components/AppPageSelector.test.ts +134 -0
  206. package/src/__tests__/components/AppPillNav.test.ts +125 -0
  207. package/src/__tests__/components/AppPluginSwitcher.test.ts +44 -0
  208. package/src/__tests__/components/AppSidebar.test.ts +496 -0
  209. package/src/__tests__/components/AppToastContainer.test.ts +37 -0
  210. package/src/__tests__/components/AppTopBar.test.ts +455 -9
  211. package/src/__tests__/components/BaseRadioGroup.test.ts +25 -0
  212. package/src/__tests__/components/BaseSelect.test.ts +21 -0
  213. package/src/__tests__/components/BaseTabs.test.ts +25 -0
  214. package/src/__tests__/components/BatchProgressList.test.ts +52 -0
  215. package/src/__tests__/components/BioTemplateExperimentWorkspaceView.test.ts +159 -0
  216. package/src/__tests__/components/BioTemplatePackWorkspaceView.test.ts +175 -0
  217. package/src/__tests__/components/BioTemplatePresetWorkspaceView.test.ts +306 -0
  218. package/src/__tests__/components/BioTemplateRenderer.test.ts +71 -0
  219. package/src/__tests__/components/Breadcrumb.test.ts +23 -0
  220. package/src/__tests__/components/CalendarGridPanel.test.ts +36 -0
  221. package/src/__tests__/components/ComponentBindingRenderer.test.ts +161 -0
  222. package/src/__tests__/components/ConcentrationInput.test.ts +45 -0
  223. package/src/__tests__/components/ControlWorkspaceView.test.ts +1102 -0
  224. package/src/__tests__/components/DataFrame.test.ts +11 -0
  225. package/src/__tests__/components/DatePicker.test.ts +45 -0
  226. package/src/__tests__/components/DateTimePicker.test.ts +48 -0
  227. package/src/__tests__/components/DoseDesignWorkspaceView.test.ts +185 -0
  228. package/src/__tests__/components/DropdownButton.test.ts +23 -0
  229. package/src/__tests__/components/EmptyState.test.ts +23 -0
  230. package/src/__tests__/components/ExperimentPopover.test.ts +56 -0
  231. package/src/__tests__/components/FormBuilder.test.ts +296 -0
  232. package/src/__tests__/components/GroupAssigner.test.ts +30 -0
  233. package/src/__tests__/components/MultiSelect.test.ts +48 -0
  234. package/src/__tests__/components/PluginWorkspaceView.test.ts +548 -0
  235. package/src/__tests__/components/ProtocolStepEditor.test.ts +33 -0
  236. package/src/__tests__/components/ReagentList.test.ts +82 -0
  237. package/src/__tests__/components/SampleHierarchyTree.test.ts +53 -0
  238. package/src/__tests__/components/SampleSelector.test.ts +60 -0
  239. package/src/__tests__/components/SegmentedControl.test.ts +24 -0
  240. package/src/__tests__/components/SettingsModal.test.ts +296 -0
  241. package/src/__tests__/components/TagsInput.test.ts +75 -0
  242. package/src/__tests__/components/ThemeToggle.test.ts +47 -0
  243. package/src/__tests__/components/TimePicker.test.ts +38 -0
  244. package/src/__tests__/composables/experiment-utils.test.ts +30 -0
  245. package/src/__tests__/composables/useApi.test.ts +30 -0
  246. package/src/__tests__/composables/useAppExperiment.test.ts +100 -1
  247. package/src/__tests__/composables/useBioTemplatePackWorkspace.test.ts +125 -0
  248. package/src/__tests__/composables/useBioTemplatePresetWorkspace.test.ts +199 -0
  249. package/src/__tests__/composables/useBioTemplateWorkspace.test.ts +104 -0
  250. package/src/__tests__/composables/useCalendarGrid.test.ts +38 -0
  251. package/src/__tests__/composables/useControlSchema.test.ts +1033 -0
  252. package/src/__tests__/composables/useDebouncedWatch.test.ts +93 -0
  253. package/src/__tests__/composables/useDropdownState.test.ts +95 -0
  254. package/src/__tests__/composables/useEventListener.test.ts +116 -0
  255. package/src/__tests__/composables/useExpansionSet.test.ts +62 -0
  256. package/src/__tests__/composables/useExperimentData.test.ts +4 -0
  257. package/src/__tests__/composables/useExperimentSave.test.ts +203 -8
  258. package/src/__tests__/composables/useExperimentSelector.test.ts +164 -0
  259. package/src/__tests__/composables/useForm.test.ts +58 -0
  260. package/src/__tests__/composables/useFormBuilder.test.ts +77 -0
  261. package/src/__tests__/composables/useGroupAssignment.test.ts +73 -0
  262. package/src/__tests__/composables/useListSelection.test.ts +66 -0
  263. package/src/__tests__/composables/usePluginClient.test.ts +541 -0
  264. package/src/__tests__/composables/usePluginConfig.test.ts +5 -0
  265. package/src/__tests__/composables/useRequestSyncState.test.ts +92 -0
  266. package/src/__tests__/composables/useSampleGroups.test.ts +66 -0
  267. package/src/__tests__/composables/useSelectionLimit.test.ts +41 -0
  268. package/src/__tests__/composables/useSortedItems.test.ts +87 -0
  269. package/src/__tests__/composables/useTemplateCollection.test.ts +147 -0
  270. package/src/__tests__/composables/useTextSearch.test.ts +55 -0
  271. package/src/__tests__/composables/useTheme.test.ts +91 -0
  272. package/src/__tests__/composables/useTimeUtils.test.ts +35 -0
  273. package/src/__tests__/docs/frontendDocsCatalog.test.ts +324 -0
  274. package/src/__tests__/fixtures/templates/dose-response.json +81 -0
  275. package/src/__tests__/fixtures/templates/plate-map.json +54 -0
  276. package/src/__tests__/fixtures/templates/qpcr-plate.json +96 -0
  277. package/src/__tests__/fixtures/templates/sample-sheet.json +71 -0
  278. package/src/__tests__/templates/templates.test.ts +1055 -0
  279. package/src/components/AppAvatarMenu.vue +15 -69
  280. package/src/components/AppLayout.story.vue +64 -25
  281. package/src/components/AppLayout.vue +83 -2
  282. package/src/components/AppPluginSwitcher.vue +41 -145
  283. package/src/components/AppSidebar.story.vue +203 -1
  284. package/src/components/AppSidebar.vue +320 -25
  285. package/src/components/{ToastNotification.story.vue → AppToastContainer.story.vue} +6 -6
  286. package/src/components/{ToastNotification.vue → AppToastContainer.vue} +1 -1
  287. package/src/components/AppTopBar.story.vue +7 -33
  288. package/src/components/AppTopBar.vue +104 -300
  289. package/src/components/BaseModal.vue +3 -5
  290. package/src/components/BaseRadioGroup.vue +7 -3
  291. package/src/components/BaseSelect.vue +11 -7
  292. package/src/components/BaseTabs.vue +6 -4
  293. package/src/components/BatchProgressList.vue +5 -8
  294. package/src/components/BioTemplateExperimentWorkspaceView.story.vue +123 -0
  295. package/src/components/BioTemplateExperimentWorkspaceView.vue +343 -0
  296. package/src/components/BioTemplatePackWorkspaceView.story.vue +107 -0
  297. package/src/components/BioTemplatePackWorkspaceView.vue +177 -0
  298. package/src/components/BioTemplatePresetWorkspaceView.story.vue +163 -0
  299. package/src/components/BioTemplatePresetWorkspaceView.vue +401 -0
  300. package/src/components/BioTemplateRenderer.story.vue +57 -0
  301. package/src/components/BioTemplateRenderer.vue +57 -0
  302. package/src/components/Breadcrumb.vue +14 -8
  303. package/src/components/ComponentBindingRenderer.story.vue +57 -0
  304. package/src/components/ComponentBindingRenderer.vue +308 -0
  305. package/src/components/ConcentrationInput.vue +27 -64
  306. package/src/components/ControlWorkspaceView.story.vue +347 -0
  307. package/src/components/ControlWorkspaceView.vue +378 -0
  308. package/src/components/DataFrame.vue +34 -50
  309. package/src/components/DatePicker.vue +59 -192
  310. package/src/components/DateTimePicker.vue +50 -171
  311. package/src/components/DoseDesignWorkspaceView.story.vue +77 -0
  312. package/src/components/DoseDesignWorkspaceView.vue +255 -0
  313. package/src/components/DropdownButton.vue +14 -32
  314. package/src/components/EmptyState.vue +4 -2
  315. package/src/components/ExperimentPopover.vue +7 -28
  316. package/src/components/ExperimentSelectorModal.vue +6 -5
  317. package/src/components/FormBuilder.story.vue +190 -0
  318. package/src/components/FormBuilder.vue +124 -27
  319. package/src/components/GroupAssigner.vue +24 -56
  320. package/src/components/MultiSelect.vue +17 -12
  321. package/src/components/PlateMapEditor.vue +3 -8
  322. package/src/components/PluginIcon.vue +2 -22
  323. package/src/components/PluginWorkspaceView.story.vue +334 -0
  324. package/src/components/PluginWorkspaceView.vue +708 -0
  325. package/src/components/ProtocolStepEditor.vue +13 -22
  326. package/src/components/ReagentList.vue +25 -33
  327. package/src/components/SampleHierarchyTree.vue +12 -23
  328. package/src/components/SampleSelector.vue +42 -122
  329. package/src/components/SegmentedControl.vue +7 -3
  330. package/src/components/SettingsModal.story.vue +88 -1
  331. package/src/components/SettingsModal.vue +120 -29
  332. package/src/components/TagsInput.vue +29 -14
  333. package/src/components/ThemeToggle.vue +9 -7
  334. package/src/components/TimePicker.vue +19 -41
  335. package/src/components/Tooltip.vue +7 -12
  336. package/src/components/WellPlate.vue +6 -12
  337. package/src/components/index.ts +9 -8
  338. package/src/components/internal/ActionItemInternal.vue +82 -0
  339. package/src/components/internal/AppPageSelectorInternal.vue +128 -0
  340. package/src/components/internal/AppPillNavInternal.vue +194 -0
  341. package/src/components/internal/CalendarGridPanelInternal.vue +120 -0
  342. package/src/components/{FormFieldRenderer.vue → internal/FormFieldRendererInternal.vue} +4 -12
  343. package/src/components/{FormSection.vue → internal/FormSectionRenderer.vue} +6 -18
  344. package/src/components/{WellEditPopup.vue → internal/WellEditPopupInternal.vue} +5 -10
  345. package/src/composables/experiment-utils.ts +26 -0
  346. package/src/composables/index.ts +229 -3
  347. package/src/composables/platformContextHelpers.ts +74 -0
  348. package/src/composables/useApi.ts +9 -2
  349. package/src/composables/useAppExperiment.ts +85 -13
  350. package/src/composables/useBioTemplateComponents.ts +105 -0
  351. package/src/composables/useBioTemplateControls.ts +41 -0
  352. package/src/composables/useBioTemplatePackWorkspace.ts +185 -0
  353. package/src/composables/useBioTemplatePresetWorkspace.ts +326 -0
  354. package/src/composables/useBioTemplateWorkspace.ts +141 -0
  355. package/src/composables/useCalendarGrid.ts +140 -0
  356. package/src/composables/useControlSchema.ts +1362 -0
  357. package/src/composables/useDebouncedWatch.ts +119 -0
  358. package/src/composables/useDropdownState.ts +83 -0
  359. package/src/composables/useEventListener.ts +111 -0
  360. package/src/composables/useExpansionSet.ts +117 -0
  361. package/src/composables/useExperimentData.ts +20 -11
  362. package/src/composables/useExperimentSave.ts +202 -50
  363. package/src/composables/useExperimentSelector.ts +86 -72
  364. package/src/composables/useForm.ts +49 -4
  365. package/src/composables/useFormBuilder.ts +93 -42
  366. package/src/composables/useGroupAssignment.ts +148 -0
  367. package/src/composables/useListSelection.ts +158 -0
  368. package/src/composables/usePluginClient.ts +466 -0
  369. package/src/composables/usePluginConfig.ts +34 -13
  370. package/src/composables/useRequestSyncState.ts +126 -0
  371. package/src/composables/useSampleGroups.ts +126 -0
  372. package/src/composables/useSelectionLimit.ts +57 -0
  373. package/src/composables/useSortedItems.ts +118 -0
  374. package/src/composables/useTemplateCollection.ts +229 -0
  375. package/src/composables/useTextSearch.ts +60 -0
  376. package/src/composables/useTheme.ts +2 -28
  377. package/src/composables/useTimeUtils.ts +26 -2
  378. package/src/composables/useWellPlateEditor.ts +13 -9
  379. package/src/index.ts +11 -348
  380. package/src/install.ts +11 -4
  381. package/src/stores/settings.ts +13 -9
  382. package/src/styles/components/app-layout.css +82 -0
  383. package/src/styles/components/app-page-selector.css +23 -0
  384. package/src/styles/components/app-pill-nav.css +77 -0
  385. package/src/styles/components/app-sidebar.css +119 -0
  386. package/src/styles/components/app-top-bar.css +0 -201
  387. package/src/styles/components/concentration-input.css +3 -142
  388. package/src/styles/components/empty-state.css +0 -16
  389. package/src/styles/components/theme-toggle.css +3 -66
  390. package/src/styles/index.css +0 -2
  391. package/src/templates/adapters.ts +785 -0
  392. package/src/templates/builders.ts +2149 -0
  393. package/src/templates/catalog.ts +245 -0
  394. package/src/templates/componentBindings.ts +653 -0
  395. package/src/templates/controlSchemas.ts +718 -0
  396. package/src/templates/index.ts +318 -0
  397. package/src/templates/lookup.ts +18 -0
  398. package/src/templates/packs.ts +156 -0
  399. package/src/templates/presets.ts +146 -0
  400. package/src/templates/types.ts +668 -0
  401. package/src/types/components.ts +39 -27
  402. package/src/types/form-builder.ts +7 -2
  403. package/src/types/index.ts +13 -3
  404. package/src/types/platform.ts +7 -1
  405. package/src/utils/formModelSync.ts +52 -0
  406. package/src/utils/items.ts +28 -0
  407. package/src/utils/options.ts +23 -0
  408. package/src/utils/pluginIcon.ts +30 -0
  409. package/dist/__tests__/composables/usePluginApi.test.d.ts +0 -13
  410. package/dist/auth-DsI0rQ7_.js.map +0 -1
  411. package/dist/components/GroupingModal.vue.d.ts +0 -12
  412. package/dist/components-_XqPEhP9.js.map +0 -1
  413. package/dist/composables/usePluginApi.d.ts +0 -29
  414. package/dist/composables-tiZqLu1M.js.map +0 -1
  415. package/dist/useScheduleDrag-CA9sGNJG.js +0 -7181
  416. package/dist/useScheduleDrag-CA9sGNJG.js.map +0 -1
  417. package/src/__tests__/composables/usePluginApi.test.ts +0 -81
  418. package/src/components/AppPageSelector.vue +0 -159
  419. package/src/components/AppPillNav.vue +0 -66
  420. package/src/components/GroupingModal.story.vue +0 -52
  421. package/src/components/GroupingModal.vue +0 -422
  422. package/src/components/SettingsButton.story.vue +0 -58
  423. package/src/components/SettingsButton.vue +0 -76
  424. package/src/composables/usePluginApi.ts +0 -39
  425. package/src/styles/components/grouping-modal.css +0 -323
  426. package/src/styles/components/settings-button.css +0 -94
  427. /package/dist/components/{ToastNotification.vue.d.ts → AppToastContainer.vue.d.ts} +0 -0
@@ -0,0 +1,308 @@
1
+ <script setup lang="ts">
2
+ /** Render generated SDK component bindings such as WellPlate, DoseCalculator, DataFrame, and PlateMapEditor. */
3
+ import { computed, type Component } from 'vue'
4
+ import DataFrame from './DataFrame.vue'
5
+ import DoseCalculator from './DoseCalculator.vue'
6
+ import ExperimentTimeline from './ExperimentTimeline.vue'
7
+ import PlateMapEditor from './PlateMapEditor.vue'
8
+ import ReagentList from './ReagentList.vue'
9
+ import SampleSelector from './SampleSelector.vue'
10
+ import WellPlate from './WellPlate.vue'
11
+
12
+ export interface ComponentBindingRendererBinding {
13
+ id?: string
14
+ component: string
15
+ props?: Record<string, unknown> | readonly string[]
16
+ propsObject?: Record<string, unknown>
17
+ description?: string
18
+ template_id?: string
19
+ }
20
+
21
+ type ComponentBindingRendererLayout = 'grid' | 'stack'
22
+
23
+ interface Props {
24
+ /** Single generated SDK component binding to render. */
25
+ binding?: ComponentBindingRendererBinding
26
+ /** Generated SDK component bindings to render. */
27
+ bindings?: ComponentBindingRendererBinding[]
28
+ /** Optional allow-list of component names, for example ['WellPlate', 'DataFrame']. */
29
+ include?: string[]
30
+ /** Optional deny-list of component names. */
31
+ exclude?: string[]
32
+ /** Compact child component sizing. */
33
+ dense?: boolean
34
+ /** Prefer preview-safe props for editable components. */
35
+ readonly?: boolean
36
+ /** Show component/template labels above each rendered component. */
37
+ showHeaders?: boolean
38
+ /** Show binding descriptions in each header. */
39
+ showDescriptions?: boolean
40
+ /** Grid or vertical stack layout. */
41
+ layout?: ComponentBindingRendererLayout
42
+ /** Message shown when no binding can be rendered. */
43
+ emptyText?: string
44
+ }
45
+
46
+ type RenderableBinding = ComponentBindingRendererBinding & {
47
+ id: string
48
+ componentImpl: Component
49
+ normalizedProps: Record<string, unknown>
50
+ }
51
+
52
+ const props = withDefaults(defineProps<Props>(), {
53
+ binding: undefined,
54
+ bindings: () => [],
55
+ include: () => [],
56
+ exclude: () => [],
57
+ dense: false,
58
+ readonly: true,
59
+ showHeaders: true,
60
+ showDescriptions: true,
61
+ layout: 'grid',
62
+ emptyText: 'No renderable SDK component bindings.',
63
+ })
64
+
65
+ const componentRegistry: Record<string, Component> = {
66
+ DataFrame,
67
+ DoseCalculator,
68
+ ExperimentTimeline,
69
+ PlateMapEditor,
70
+ ReagentList,
71
+ SampleSelector,
72
+ WellPlate,
73
+ }
74
+
75
+ const inputBindings = computed<ComponentBindingRendererBinding[]>(() => [
76
+ ...(props.binding ? [props.binding] : []),
77
+ ...props.bindings,
78
+ ])
79
+
80
+ const renderableBindings = computed<RenderableBinding[]>(() =>
81
+ inputBindings.value
82
+ .filter(binding => isIncluded(binding.component))
83
+ .map((binding, index) => {
84
+ const componentImpl = componentRegistry[binding.component]
85
+ if (!componentImpl) return null
86
+ return {
87
+ ...binding,
88
+ id: binding.id ?? `${binding.component}-${index + 1}`,
89
+ componentImpl,
90
+ normalizedProps: normalizeProps(binding),
91
+ }
92
+ })
93
+ .filter((binding): binding is RenderableBinding => binding !== null)
94
+ )
95
+
96
+ const rendererClasses = computed(() => [
97
+ 'mint-component-binding-renderer',
98
+ `mint-component-binding-renderer--${props.layout}`,
99
+ props.dense ? 'mint-component-binding-renderer--dense' : '',
100
+ ])
101
+
102
+ function isIncluded(componentName: string): boolean {
103
+ if (props.include.length > 0 && !props.include.includes(componentName)) return false
104
+ return !props.exclude.includes(componentName)
105
+ }
106
+
107
+ function baseProps(binding: ComponentBindingRendererBinding): Record<string, unknown> {
108
+ if (binding.propsObject) return { ...binding.propsObject }
109
+ if (isRecord(binding.props)) return { ...binding.props }
110
+ return {}
111
+ }
112
+
113
+ function normalizeProps(binding: ComponentBindingRendererBinding): Record<string, unknown> {
114
+ const base = baseProps(binding)
115
+
116
+ switch (binding.component) {
117
+ case 'WellPlate':
118
+ return {
119
+ ...base,
120
+ readonly: props.readonly || Boolean(base.readonly),
121
+ size: props.dense ? 'md' : (base.size ?? 'fill'),
122
+ }
123
+ case 'PlateMapEditor':
124
+ return {
125
+ ...base,
126
+ size: props.dense ? 'md' : (base.size ?? 'fill'),
127
+ showToolbar: props.readonly ? false : (base.showToolbar ?? true),
128
+ showSidebar: props.readonly ? false : (base.showSidebar ?? true),
129
+ allowAddPlates: props.readonly ? false : (base.allowAddPlates ?? true),
130
+ allowAddSamples: props.readonly ? false : (base.allowAddSamples ?? true),
131
+ }
132
+ case 'DataFrame':
133
+ return {
134
+ ...base,
135
+ size: props.dense ? 'sm' : (base.size ?? 'md'),
136
+ maxHeight: base.maxHeight ?? (props.dense ? '280px' : undefined),
137
+ }
138
+ case 'ExperimentTimeline':
139
+ return {
140
+ ...base,
141
+ editable: props.readonly ? false : base.editable,
142
+ size: props.dense ? 'sm' : (base.size ?? 'md'),
143
+ }
144
+ case 'ReagentList':
145
+ return {
146
+ ...base,
147
+ readonly: props.readonly || Boolean(base.readonly),
148
+ }
149
+ case 'SampleSelector':
150
+ return {
151
+ ...base,
152
+ enableGrouping: props.readonly ? false : (base.enableGrouping ?? true),
153
+ enableSmartGroup: props.readonly ? false : (base.enableSmartGroup ?? true),
154
+ }
155
+ default:
156
+ return base
157
+ }
158
+ }
159
+
160
+ function isRecord(value: unknown): value is Record<string, unknown> {
161
+ return typeof value === 'object' && value !== null && !Array.isArray(value)
162
+ }
163
+ </script>
164
+
165
+ <template>
166
+ <div :class="rendererClasses">
167
+ <section
168
+ v-for="renderableBinding in renderableBindings"
169
+ :key="renderableBinding.id"
170
+ class="mint-component-binding-renderer__item"
171
+ :data-component-binding-id="renderableBinding.id"
172
+ :data-template-id="renderableBinding.template_id"
173
+ :data-template-component="renderableBinding.component"
174
+ >
175
+ <header
176
+ v-if="showHeaders"
177
+ class="mint-component-binding-renderer__header"
178
+ >
179
+ <div class="mint-component-binding-renderer__title-group">
180
+ <p class="mint-component-binding-renderer__component">
181
+ {{ renderableBinding.component }}
182
+ </p>
183
+ <p
184
+ v-if="renderableBinding.template_id || renderableBinding.id"
185
+ class="mint-component-binding-renderer__source"
186
+ >
187
+ {{ renderableBinding.template_id ?? renderableBinding.id }}
188
+ </p>
189
+ </div>
190
+ <p
191
+ v-if="showDescriptions && renderableBinding.description"
192
+ class="mint-component-binding-renderer__description"
193
+ >
194
+ {{ renderableBinding.description }}
195
+ </p>
196
+ </header>
197
+
198
+ <div class="mint-component-binding-renderer__body">
199
+ <component
200
+ :is="renderableBinding.componentImpl"
201
+ v-bind="renderableBinding.normalizedProps"
202
+ />
203
+ </div>
204
+ </section>
205
+
206
+ <p
207
+ v-if="renderableBindings.length === 0"
208
+ class="mint-component-binding-renderer__empty"
209
+ >
210
+ {{ emptyText }}
211
+ </p>
212
+ </div>
213
+ </template>
214
+
215
+ <style scoped>
216
+ .mint-component-binding-renderer {
217
+ display: grid;
218
+ gap: 1rem;
219
+ min-width: 0;
220
+ }
221
+
222
+ .mint-component-binding-renderer--grid {
223
+ grid-template-columns: repeat(auto-fit, minmax(min(100%, 28rem), 1fr));
224
+ }
225
+
226
+ .mint-component-binding-renderer--stack {
227
+ grid-template-columns: minmax(0, 1fr);
228
+ }
229
+
230
+ .mint-component-binding-renderer--dense {
231
+ gap: 0.75rem;
232
+ }
233
+
234
+ .mint-component-binding-renderer__item {
235
+ min-width: 0;
236
+ overflow: hidden;
237
+ border: 1px solid var(--border-color, #e5e7eb);
238
+ border-radius: 0.5rem;
239
+ background: var(--bg-card, #ffffff);
240
+ box-shadow: var(--shadow-sm, 0 1px 2px rgb(15 23 42 / 0.06));
241
+ }
242
+
243
+ .mint-component-binding-renderer__header {
244
+ display: flex;
245
+ align-items: flex-start;
246
+ justify-content: space-between;
247
+ gap: 1rem;
248
+ padding: 0.75rem 1rem;
249
+ border-bottom: 1px solid var(--border-color, #e5e7eb);
250
+ background: var(--bg-secondary, #f8fafc);
251
+ }
252
+
253
+ .mint-component-binding-renderer__title-group {
254
+ min-width: 0;
255
+ }
256
+
257
+ .mint-component-binding-renderer__component {
258
+ margin: 0;
259
+ color: var(--text-primary, #0f172a);
260
+ font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace);
261
+ font-size: 0.8125rem;
262
+ font-weight: 600;
263
+ }
264
+
265
+ .mint-component-binding-renderer__source,
266
+ .mint-component-binding-renderer__description,
267
+ .mint-component-binding-renderer__empty {
268
+ margin: 0;
269
+ color: var(--text-secondary, #475569);
270
+ font-size: 0.75rem;
271
+ line-height: 1.4;
272
+ }
273
+
274
+ .mint-component-binding-renderer__description {
275
+ max-width: 24rem;
276
+ text-align: right;
277
+ }
278
+
279
+ .mint-component-binding-renderer__body {
280
+ min-width: 0;
281
+ padding: 1rem;
282
+ }
283
+
284
+ .mint-component-binding-renderer--dense .mint-component-binding-renderer__header,
285
+ .mint-component-binding-renderer--dense .mint-component-binding-renderer__body {
286
+ padding: 0.75rem;
287
+ }
288
+
289
+ .mint-component-binding-renderer__empty {
290
+ padding: 1rem;
291
+ border: 1px dashed var(--border-color, #e5e7eb);
292
+ border-radius: 0.5rem;
293
+ background: var(--bg-secondary, #f8fafc);
294
+ text-align: center;
295
+ }
296
+
297
+ @media (max-width: 720px) {
298
+ .mint-component-binding-renderer__header {
299
+ display: block;
300
+ }
301
+
302
+ .mint-component-binding-renderer__description {
303
+ max-width: none;
304
+ margin-top: 0.25rem;
305
+ text-align: left;
306
+ }
307
+ }
308
+ </style>
@@ -6,6 +6,7 @@ import {
6
6
  type ConcentrationValue,
7
7
  type ConcentrationUnit,
8
8
  } from '../composables/useConcentrationUnits'
9
+ import UnitInput from './UnitInput.vue'
9
10
 
10
11
  interface Props {
11
12
  modelValue?: ConcentrationValue
@@ -52,6 +53,16 @@ const availableUnits = computed(() => {
52
53
  return filteredCategories.value.flatMap(cat => cat.units)
53
54
  })
54
55
 
56
+ const unitOptions = computed(() =>
57
+ filteredCategories.value.flatMap(category =>
58
+ category.units.map(unit => ({
59
+ value: unit,
60
+ label: unit,
61
+ group: filteredCategories.value.length > 1 ? category.label : undefined,
62
+ }))
63
+ )
64
+ )
65
+
55
66
  // Current value and unit
56
67
  const currentValue = computed(() => props.modelValue?.value)
57
68
  const currentUnit = computed(() => props.modelValue?.unit || availableUnits.value[0] || 'µM')
@@ -62,10 +73,7 @@ const conversionHint = computed(() => {
62
73
  return getConversionHint(props.modelValue)
63
74
  })
64
75
 
65
- function handleValueInput(event: Event) {
66
- const target = event.target as HTMLInputElement
67
- const value = target.value === '' ? undefined : Number(target.value)
68
-
76
+ function handleValueUpdate(value: number | undefined) {
69
77
  if (value === undefined || isNaN(value)) {
70
78
  emit('update:modelValue', undefined)
71
79
  return
@@ -86,13 +94,10 @@ function handleValueInput(event: Event) {
86
94
  })
87
95
  }
88
96
 
89
- function handleUnitChange(event: Event) {
90
- const target = event.target as HTMLSelectElement
91
- const unit = target.value as ConcentrationUnit
92
-
97
+ function handleUnitUpdate(unit: string) {
93
98
  emit('update:modelValue', {
94
99
  value: currentValue.value ?? 0,
95
- unit,
100
+ unit: unit as ConcentrationUnit,
96
101
  })
97
102
  }
98
103
 
@@ -115,61 +120,19 @@ watch(availableUnits, (units) => {
115
120
  disabled ? 'mint-concentration-input--disabled' : '',
116
121
  ]"
117
122
  >
118
- <div :class="['mint-concentration-input__controls', `mint-concentration-input__controls--${size}`]">
119
- <input
120
- type="number"
121
- :value="currentValue"
122
- :min="min"
123
- :max="max"
124
- :disabled="disabled"
125
- :placeholder="placeholder"
126
- :class="[
127
- 'mint-concentration-input__value',
128
- `mint-concentration-input__value--${size}`,
129
- disabled ? 'mint-concentration-input__value--disabled' : '',
130
- ]"
131
- aria-label="Concentration value"
132
- @input="handleValueInput"
133
- />
134
-
135
- <div class="mint-concentration-input__unit">
136
- <select
137
- :value="currentUnit"
138
- :disabled="disabled"
139
- :class="[
140
- 'mint-concentration-input__unit-select',
141
- `mint-concentration-input__unit-select--${size}`,
142
- ]"
143
- aria-label="Concentration unit"
144
- @change="handleUnitChange"
145
- >
146
- <template v-for="category in filteredCategories" :key="category.label">
147
- <optgroup
148
- v-if="filteredCategories.length > 1"
149
- :label="category.label"
150
- class="mint-concentration-input__unit-group"
151
- >
152
- <option
153
- v-for="unit in category.units"
154
- :key="unit"
155
- :value="unit"
156
- >
157
- {{ unit }}
158
- </option>
159
- </optgroup>
160
- <template v-else>
161
- <option
162
- v-for="unit in category.units"
163
- :key="unit"
164
- :value="unit"
165
- >
166
- {{ unit }}
167
- </option>
168
- </template>
169
- </template>
170
- </select>
171
- </div>
172
- </div>
123
+ <UnitInput
124
+ :model-value="currentValue"
125
+ :unit="currentUnit"
126
+ :units="unitOptions"
127
+ :min="min"
128
+ :max="max"
129
+ :disabled="disabled"
130
+ :error="error"
131
+ :size="size"
132
+ :placeholder="placeholder"
133
+ @update:model-value="handleValueUpdate"
134
+ @update:unit="handleUnitUpdate"
135
+ />
173
136
 
174
137
  <div
175
138
  v-if="showConversion && conversionHint"