@morscherlab/mld-sdk 0.6.0
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.
- package/README.md +326 -0
- package/dist/__tests__/components/AppLayout.test.d.ts +1 -0
- package/dist/__tests__/components/AppSidebar.test.d.ts +1 -0
- package/dist/__tests__/components/AppTopBar.test.d.ts +1 -0
- package/dist/__tests__/components/BaseInput.test.d.ts +1 -0
- package/dist/__tests__/components/BasePill.test.d.ts +1 -0
- package/dist/__tests__/components/Calendar.test.d.ts +1 -0
- package/dist/__tests__/components/CollapsibleCard.test.d.ts +1 -0
- package/dist/__tests__/components/DataFrame.test.d.ts +1 -0
- package/dist/__tests__/components/DropdownButton.test.d.ts +1 -0
- package/dist/__tests__/composables/useAuth.test.d.ts +1 -0
- package/dist/__tests__/composables/useForm.test.d.ts +1 -0
- package/dist/components/AlertBox.vue.d.ts +30 -0
- package/dist/components/AlertBox.vue.js +125 -0
- package/dist/components/AlertBox.vue.js.map +1 -0
- package/dist/components/AlertBox.vue3.js +6 -0
- package/dist/components/AlertBox.vue3.js.map +1 -0
- package/dist/components/AppContainer.vue.d.ts +28 -0
- package/dist/components/AppContainer.vue.js +28 -0
- package/dist/components/AppContainer.vue.js.map +1 -0
- package/dist/components/AppContainer.vue2.js +5 -0
- package/dist/components/AppContainer.vue2.js.map +1 -0
- package/dist/components/AppLayout.vue.d.ts +31 -0
- package/dist/components/AppLayout.vue.js +51 -0
- package/dist/components/AppLayout.vue.js.map +1 -0
- package/dist/components/AppLayout.vue3.js +6 -0
- package/dist/components/AppLayout.vue3.js.map +1 -0
- package/dist/components/AppSidebar.vue.d.ts +44 -0
- package/dist/components/AppSidebar.vue.js +79 -0
- package/dist/components/AppSidebar.vue.js.map +1 -0
- package/dist/components/AppSidebar.vue3.js +6 -0
- package/dist/components/AppSidebar.vue3.js.map +1 -0
- package/dist/components/AppTopBar.vue.d.ts +77 -0
- package/dist/components/AppTopBar.vue.js +564 -0
- package/dist/components/AppTopBar.vue.js.map +1 -0
- package/dist/components/AppTopBar.vue3.js +6 -0
- package/dist/components/AppTopBar.vue3.js.map +1 -0
- package/dist/components/AuditTrail.vue.d.ts +47 -0
- package/dist/components/AuditTrail.vue.js +189 -0
- package/dist/components/AuditTrail.vue.js.map +1 -0
- package/dist/components/AuditTrail.vue3.js +6 -0
- package/dist/components/AuditTrail.vue3.js.map +1 -0
- package/dist/components/Avatar.vue.d.ts +13 -0
- package/dist/components/Avatar.vue.js +64 -0
- package/dist/components/Avatar.vue.js.map +1 -0
- package/dist/components/Avatar.vue3.js +6 -0
- package/dist/components/Avatar.vue3.js.map +1 -0
- package/dist/components/BaseButton.vue.d.ts +37 -0
- package/dist/components/BaseButton.vue.js +64 -0
- package/dist/components/BaseButton.vue.js.map +1 -0
- package/dist/components/BaseButton.vue3.js +6 -0
- package/dist/components/BaseButton.vue3.js.map +1 -0
- package/dist/components/BaseCheckbox.vue.d.ts +16 -0
- package/dist/components/BaseCheckbox.vue.js +71 -0
- package/dist/components/BaseCheckbox.vue.js.map +1 -0
- package/dist/components/BaseCheckbox.vue3.js +6 -0
- package/dist/components/BaseCheckbox.vue3.js.map +1 -0
- package/dist/components/BaseInput.vue.d.ts +33 -0
- package/dist/components/BaseInput.vue.js +57 -0
- package/dist/components/BaseInput.vue.js.map +1 -0
- package/dist/components/BaseInput.vue3.js +6 -0
- package/dist/components/BaseInput.vue3.js.map +1 -0
- package/dist/components/BaseModal.vue.d.ts +38 -0
- package/dist/components/BaseModal.vue.js +118 -0
- package/dist/components/BaseModal.vue.js.map +1 -0
- package/dist/components/BaseModal.vue3.js +6 -0
- package/dist/components/BaseModal.vue3.js.map +1 -0
- package/dist/components/BasePill.vue.d.ts +54 -0
- package/dist/components/BasePill.vue.js +68 -0
- package/dist/components/BasePill.vue.js.map +1 -0
- package/dist/components/BasePill.vue3.js +6 -0
- package/dist/components/BasePill.vue3.js.map +1 -0
- package/dist/components/BaseRadioGroup.vue.d.ts +19 -0
- package/dist/components/BaseRadioGroup.vue.js +80 -0
- package/dist/components/BaseRadioGroup.vue.js.map +1 -0
- package/dist/components/BaseRadioGroup.vue3.js +6 -0
- package/dist/components/BaseRadioGroup.vue3.js.map +1 -0
- package/dist/components/BaseSelect.vue.d.ts +19 -0
- package/dist/components/BaseSelect.vue.js +70 -0
- package/dist/components/BaseSelect.vue.js.map +1 -0
- package/dist/components/BaseSelect.vue3.js +6 -0
- package/dist/components/BaseSelect.vue3.js.map +1 -0
- package/dist/components/BaseSlider.vue.d.ts +22 -0
- package/dist/components/BaseSlider.vue.js +97 -0
- package/dist/components/BaseSlider.vue.js.map +1 -0
- package/dist/components/BaseSlider.vue3.js +6 -0
- package/dist/components/BaseSlider.vue3.js.map +1 -0
- package/dist/components/BaseTabs.vue.d.ts +14 -0
- package/dist/components/BaseTabs.vue.js +63 -0
- package/dist/components/BaseTabs.vue.js.map +1 -0
- package/dist/components/BaseTabs.vue3.js +6 -0
- package/dist/components/BaseTabs.vue3.js.map +1 -0
- package/dist/components/BaseTextarea.vue.d.ts +28 -0
- package/dist/components/BaseTextarea.vue.js +49 -0
- package/dist/components/BaseTextarea.vue.js.map +1 -0
- package/dist/components/BaseTextarea.vue3.js +6 -0
- package/dist/components/BaseTextarea.vue3.js.map +1 -0
- package/dist/components/BaseToggle.vue.d.ts +16 -0
- package/dist/components/BaseToggle.vue.js +65 -0
- package/dist/components/BaseToggle.vue.js.map +1 -0
- package/dist/components/BaseToggle.vue3.js +6 -0
- package/dist/components/BaseToggle.vue3.js.map +1 -0
- package/dist/components/BatchProgressList.vue.d.ts +59 -0
- package/dist/components/BatchProgressList.vue.js +250 -0
- package/dist/components/BatchProgressList.vue.js.map +1 -0
- package/dist/components/BatchProgressList.vue3.js +6 -0
- package/dist/components/BatchProgressList.vue3.js.map +1 -0
- package/dist/components/Breadcrumb.vue.d.ts +37 -0
- package/dist/components/Breadcrumb.vue.js +71 -0
- package/dist/components/Breadcrumb.vue.js.map +1 -0
- package/dist/components/Breadcrumb.vue3.js +6 -0
- package/dist/components/Breadcrumb.vue3.js.map +1 -0
- package/dist/components/Calendar.vue.d.ts +107 -0
- package/dist/components/Calendar.vue.js +328 -0
- package/dist/components/Calendar.vue.js.map +1 -0
- package/dist/components/Calendar.vue3.js +6 -0
- package/dist/components/Calendar.vue3.js.map +1 -0
- package/dist/components/ChartContainer.vue.d.ts +31 -0
- package/dist/components/ChartContainer.vue.js +78 -0
- package/dist/components/ChartContainer.vue.js.map +1 -0
- package/dist/components/ChartContainer.vue3.js +6 -0
- package/dist/components/ChartContainer.vue3.js.map +1 -0
- package/dist/components/ChemicalFormula.vue.d.ts +8 -0
- package/dist/components/ChemicalFormula.vue.js +57 -0
- package/dist/components/ChemicalFormula.vue.js.map +1 -0
- package/dist/components/ChemicalFormula.vue3.js +6 -0
- package/dist/components/ChemicalFormula.vue3.js.map +1 -0
- package/dist/components/CollapsibleCard.vue.d.ts +39 -0
- package/dist/components/CollapsibleCard.vue.js +175 -0
- package/dist/components/CollapsibleCard.vue.js.map +1 -0
- package/dist/components/CollapsibleCard.vue3.js +6 -0
- package/dist/components/CollapsibleCard.vue3.js.map +1 -0
- package/dist/components/ColorSlider.vue.d.ts +34 -0
- package/dist/components/ColorSlider.vue.js +131 -0
- package/dist/components/ColorSlider.vue.js.map +1 -0
- package/dist/components/ColorSlider.vue3.js +6 -0
- package/dist/components/ColorSlider.vue3.js.map +1 -0
- package/dist/components/ConcentrationInput.vue.d.ts +25 -0
- package/dist/components/ConcentrationInput.vue.js +161 -0
- package/dist/components/ConcentrationInput.vue.js.map +1 -0
- package/dist/components/ConcentrationInput.vue3.js +6 -0
- package/dist/components/ConcentrationInput.vue3.js.map +1 -0
- package/dist/components/ConfirmDialog.vue.d.ts +41 -0
- package/dist/components/ConfirmDialog.vue.js +140 -0
- package/dist/components/ConfirmDialog.vue.js.map +1 -0
- package/dist/components/ConfirmDialog.vue3.js +6 -0
- package/dist/components/ConfirmDialog.vue3.js.map +1 -0
- package/dist/components/DataFrame.vue.d.ts +107 -0
- package/dist/components/DataFrame.vue.js +430 -0
- package/dist/components/DataFrame.vue.js.map +1 -0
- package/dist/components/DataFrame.vue3.js +6 -0
- package/dist/components/DataFrame.vue3.js.map +1 -0
- package/dist/components/DatePicker.vue.d.ts +23 -0
- package/dist/components/DatePicker.vue.js +278 -0
- package/dist/components/DatePicker.vue.js.map +1 -0
- package/dist/components/DatePicker.vue3.js +6 -0
- package/dist/components/DatePicker.vue3.js.map +1 -0
- package/dist/components/DateTimePicker.vue.d.ts +30 -0
- package/dist/components/DateTimePicker.vue.js +413 -0
- package/dist/components/DateTimePicker.vue.js.map +1 -0
- package/dist/components/DateTimePicker.vue3.js +6 -0
- package/dist/components/DateTimePicker.vue3.js.map +1 -0
- package/dist/components/Divider.vue.d.ts +11 -0
- package/dist/components/Divider.vue.js +42 -0
- package/dist/components/Divider.vue.js.map +1 -0
- package/dist/components/Divider.vue3.js +6 -0
- package/dist/components/Divider.vue3.js.map +1 -0
- package/dist/components/DoseCalculator.vue.d.ts +19 -0
- package/dist/components/DoseCalculator.vue.js +470 -0
- package/dist/components/DoseCalculator.vue.js.map +1 -0
- package/dist/components/DoseCalculator.vue3.js +6 -0
- package/dist/components/DoseCalculator.vue3.js.map +1 -0
- package/dist/components/DropdownButton.vue.d.ts +47 -0
- package/dist/components/DropdownButton.vue.js +171 -0
- package/dist/components/DropdownButton.vue.js.map +1 -0
- package/dist/components/DropdownButton.vue3.js +6 -0
- package/dist/components/DropdownButton.vue3.js.map +1 -0
- package/dist/components/EmptyState.vue.d.ts +33 -0
- package/dist/components/EmptyState.vue.js +80 -0
- package/dist/components/EmptyState.vue.js.map +1 -0
- package/dist/components/EmptyState.vue3.js +6 -0
- package/dist/components/EmptyState.vue3.js.map +1 -0
- package/dist/components/ExperimentTimeline.vue.d.ts +44 -0
- package/dist/components/ExperimentTimeline.vue.js +395 -0
- package/dist/components/ExperimentTimeline.vue.js.map +1 -0
- package/dist/components/ExperimentTimeline.vue3.js +6 -0
- package/dist/components/ExperimentTimeline.vue3.js.map +1 -0
- package/dist/components/FileUploader.vue.d.ts +23 -0
- package/dist/components/FileUploader.vue.js +416 -0
- package/dist/components/FileUploader.vue.js.map +1 -0
- package/dist/components/FileUploader.vue3.js +6 -0
- package/dist/components/FileUploader.vue3.js.map +1 -0
- package/dist/components/FormField.vue.d.ts +24 -0
- package/dist/components/FormField.vue.js +45 -0
- package/dist/components/FormField.vue.js.map +1 -0
- package/dist/components/FormField.vue3.js +6 -0
- package/dist/components/FormField.vue3.js.map +1 -0
- package/dist/components/FormulaInput.vue.d.ts +25 -0
- package/dist/components/FormulaInput.vue.js +121 -0
- package/dist/components/FormulaInput.vue.js.map +1 -0
- package/dist/components/FormulaInput.vue3.js +6 -0
- package/dist/components/FormulaInput.vue3.js.map +1 -0
- package/dist/components/GroupAssigner.vue.d.ts +25 -0
- package/dist/components/GroupAssigner.vue.js +311 -0
- package/dist/components/GroupAssigner.vue.js.map +1 -0
- package/dist/components/GroupAssigner.vue3.js +6 -0
- package/dist/components/GroupAssigner.vue3.js.map +1 -0
- package/dist/components/GroupingModal.vue.d.ts +12 -0
- package/dist/components/GroupingModal.vue.js +446 -0
- package/dist/components/GroupingModal.vue.js.map +1 -0
- package/dist/components/GroupingModal.vue3.js +6 -0
- package/dist/components/GroupingModal.vue3.js.map +1 -0
- package/dist/components/IconButton.vue.d.ts +34 -0
- package/dist/components/IconButton.vue.js +67 -0
- package/dist/components/IconButton.vue.js.map +1 -0
- package/dist/components/IconButton.vue3.js +6 -0
- package/dist/components/IconButton.vue3.js.map +1 -0
- package/dist/components/LoadingSpinner.vue.d.ts +11 -0
- package/dist/components/LoadingSpinner.vue.js +47 -0
- package/dist/components/LoadingSpinner.vue.js.map +1 -0
- package/dist/components/LoadingSpinner.vue3.js +6 -0
- package/dist/components/LoadingSpinner.vue3.js.map +1 -0
- package/dist/components/MoleculeInput.vue.d.ts +30 -0
- package/dist/components/MoleculeInput.vue.js +327 -0
- package/dist/components/MoleculeInput.vue.js.map +1 -0
- package/dist/components/MoleculeInput.vue3.js +6 -0
- package/dist/components/MoleculeInput.vue3.js.map +1 -0
- package/dist/components/MultiSelect.vue.d.ts +19 -0
- package/dist/components/MultiSelect.vue.js +109 -0
- package/dist/components/MultiSelect.vue.js.map +1 -0
- package/dist/components/MultiSelect.vue3.js +6 -0
- package/dist/components/MultiSelect.vue3.js.map +1 -0
- package/dist/components/NumberInput.vue.d.ts +21 -0
- package/dist/components/NumberInput.vue.js +133 -0
- package/dist/components/NumberInput.vue.js.map +1 -0
- package/dist/components/NumberInput.vue3.js +6 -0
- package/dist/components/NumberInput.vue3.js.map +1 -0
- package/dist/components/PlateMapEditor.vue.d.ts +50 -0
- package/dist/components/PlateMapEditor.vue.js +480 -0
- package/dist/components/PlateMapEditor.vue.js.map +1 -0
- package/dist/components/PlateMapEditor.vue3.js +6 -0
- package/dist/components/PlateMapEditor.vue3.js.map +1 -0
- package/dist/components/ProgressBar.vue.d.ts +17 -0
- package/dist/components/ProgressBar.vue.js +65 -0
- package/dist/components/ProgressBar.vue.js.map +1 -0
- package/dist/components/ProgressBar.vue3.js +6 -0
- package/dist/components/ProgressBar.vue3.js.map +1 -0
- package/dist/components/ProtocolStepEditor.vue.d.ts +24 -0
- package/dist/components/ProtocolStepEditor.vue.js +491 -0
- package/dist/components/ProtocolStepEditor.vue.js.map +1 -0
- package/dist/components/ProtocolStepEditor.vue3.js +6 -0
- package/dist/components/ProtocolStepEditor.vue3.js.map +1 -0
- package/dist/components/RackEditor.vue.d.ts +40 -0
- package/dist/components/RackEditor.vue.js +325 -0
- package/dist/components/RackEditor.vue.js.map +1 -0
- package/dist/components/RackEditor.vue3.js +6 -0
- package/dist/components/RackEditor.vue3.js.map +1 -0
- package/dist/components/ReagentList.vue.d.ts +46 -0
- package/dist/components/ReagentList.vue.js +526 -0
- package/dist/components/ReagentList.vue.js.map +1 -0
- package/dist/components/ReagentList.vue3.js +6 -0
- package/dist/components/ReagentList.vue3.js.map +1 -0
- package/dist/components/ResourceCard.vue.d.ts +50 -0
- package/dist/components/ResourceCard.vue.js +212 -0
- package/dist/components/ResourceCard.vue.js.map +1 -0
- package/dist/components/ResourceCard.vue3.js +6 -0
- package/dist/components/ResourceCard.vue3.js.map +1 -0
- package/dist/components/SampleHierarchyTree.vue.d.ts +37 -0
- package/dist/components/SampleHierarchyTree.vue.js +217 -0
- package/dist/components/SampleHierarchyTree.vue.js.map +1 -0
- package/dist/components/SampleHierarchyTree.vue3.js +6 -0
- package/dist/components/SampleHierarchyTree.vue3.js.map +1 -0
- package/dist/components/SampleLegend.vue.d.ts +32 -0
- package/dist/components/SampleLegend.vue.js +129 -0
- package/dist/components/SampleLegend.vue.js.map +1 -0
- package/dist/components/SampleLegend.vue3.js +6 -0
- package/dist/components/SampleLegend.vue3.js.map +1 -0
- package/dist/components/SampleSelector.vue.d.ts +29 -0
- package/dist/components/SampleSelector.vue.js +1076 -0
- package/dist/components/SampleSelector.vue.js.map +1 -0
- package/dist/components/SampleSelector.vue3.js +6 -0
- package/dist/components/SampleSelector.vue3.js.map +1 -0
- package/dist/components/ScheduleCalendar.vue.d.ts +110 -0
- package/dist/components/ScheduleCalendar.vue.js +535 -0
- package/dist/components/ScheduleCalendar.vue.js.map +1 -0
- package/dist/components/ScheduleCalendar.vue3.js +6 -0
- package/dist/components/ScheduleCalendar.vue3.js.map +1 -0
- package/dist/components/ScientificNumber.vue.d.ts +14 -0
- package/dist/components/ScientificNumber.vue.js +190 -0
- package/dist/components/ScientificNumber.vue.js.map +1 -0
- package/dist/components/ScientificNumber.vue3.js +6 -0
- package/dist/components/ScientificNumber.vue3.js.map +1 -0
- package/dist/components/SegmentedControl.vue.d.ts +20 -0
- package/dist/components/SegmentedControl.vue.js +71 -0
- package/dist/components/SegmentedControl.vue.js.map +1 -0
- package/dist/components/SegmentedControl.vue3.js +6 -0
- package/dist/components/SegmentedControl.vue3.js.map +1 -0
- package/dist/components/SequenceInput.vue.d.ts +54 -0
- package/dist/components/SequenceInput.vue.js +204 -0
- package/dist/components/SequenceInput.vue.js.map +1 -0
- package/dist/components/SequenceInput.vue3.js +6 -0
- package/dist/components/SequenceInput.vue3.js.map +1 -0
- package/dist/components/SettingsButton.vue.d.ts +30 -0
- package/dist/components/SettingsButton.vue.js +72 -0
- package/dist/components/SettingsButton.vue.js.map +1 -0
- package/dist/components/SettingsButton.vue3.js +6 -0
- package/dist/components/SettingsButton.vue3.js.map +1 -0
- package/dist/components/SettingsModal.vue.d.ts +40 -0
- package/dist/components/SettingsModal.vue.js +141 -0
- package/dist/components/SettingsModal.vue.js.map +1 -0
- package/dist/components/SettingsModal.vue3.js +6 -0
- package/dist/components/SettingsModal.vue3.js.map +1 -0
- package/dist/components/Skeleton.vue.d.ts +11 -0
- package/dist/components/Skeleton.vue.js +65 -0
- package/dist/components/Skeleton.vue.js.map +1 -0
- package/dist/components/Skeleton.vue3.js +6 -0
- package/dist/components/Skeleton.vue3.js.map +1 -0
- package/dist/components/StatusIndicator.vue.d.ts +13 -0
- package/dist/components/StatusIndicator.vue.js +38 -0
- package/dist/components/StatusIndicator.vue.js.map +1 -0
- package/dist/components/StatusIndicator.vue3.js +6 -0
- package/dist/components/StatusIndicator.vue3.js.map +1 -0
- package/dist/components/StepWizard.vue.d.ts +72 -0
- package/dist/components/StepWizard.vue.js +213 -0
- package/dist/components/StepWizard.vue.js.map +1 -0
- package/dist/components/StepWizard.vue3.js +6 -0
- package/dist/components/StepWizard.vue3.js.map +1 -0
- package/dist/components/TagsInput.vue.d.ts +23 -0
- package/dist/components/TagsInput.vue.js +124 -0
- package/dist/components/TagsInput.vue.js.map +1 -0
- package/dist/components/TagsInput.vue3.js +6 -0
- package/dist/components/TagsInput.vue3.js.map +1 -0
- package/dist/components/ThemeToggle.vue.d.ts +7 -0
- package/dist/components/ThemeToggle.vue.js +49 -0
- package/dist/components/ThemeToggle.vue.js.map +1 -0
- package/dist/components/ThemeToggle.vue3.js +6 -0
- package/dist/components/ThemeToggle.vue3.js.map +1 -0
- package/dist/components/TimePicker.vue.d.ts +29 -0
- package/dist/components/TimePicker.vue.js +275 -0
- package/dist/components/TimePicker.vue.js.map +1 -0
- package/dist/components/TimePicker.vue3.js +6 -0
- package/dist/components/TimePicker.vue3.js.map +1 -0
- package/dist/components/TimeRangeInput.vue.d.ts +27 -0
- package/dist/components/TimeRangeInput.vue.js +115 -0
- package/dist/components/TimeRangeInput.vue.js.map +1 -0
- package/dist/components/TimeRangeInput.vue3.js +6 -0
- package/dist/components/TimeRangeInput.vue3.js.map +1 -0
- package/dist/components/ToastNotification.vue.d.ts +2 -0
- package/dist/components/ToastNotification.vue.js +113 -0
- package/dist/components/ToastNotification.vue.js.map +1 -0
- package/dist/components/ToastNotification.vue3.js +6 -0
- package/dist/components/ToastNotification.vue3.js.map +1 -0
- package/dist/components/Tooltip.vue.d.ts +25 -0
- package/dist/components/Tooltip.vue.js +52 -0
- package/dist/components/Tooltip.vue.js.map +1 -0
- package/dist/components/Tooltip.vue3.js +6 -0
- package/dist/components/Tooltip.vue3.js.map +1 -0
- package/dist/components/UnitInput.vue.d.ts +44 -0
- package/dist/components/UnitInput.vue.js +178 -0
- package/dist/components/UnitInput.vue.js.map +1 -0
- package/dist/components/UnitInput.vue3.js +6 -0
- package/dist/components/UnitInput.vue3.js.map +1 -0
- package/dist/components/WellEditPopup.vue.d.ts +25 -0
- package/dist/components/WellEditPopup.vue.js +250 -0
- package/dist/components/WellEditPopup.vue.js.map +1 -0
- package/dist/components/WellEditPopup.vue3.js +6 -0
- package/dist/components/WellEditPopup.vue3.js.map +1 -0
- package/dist/components/WellPlate.vue.d.ts +69 -0
- package/dist/components/WellPlate.vue.js +531 -0
- package/dist/components/WellPlate.vue.js.map +1 -0
- package/dist/components/WellPlate.vue3.js +6 -0
- package/dist/components/WellPlate.vue3.js.map +1 -0
- package/dist/components/index.d.ts +71 -0
- package/dist/components/index.js +215 -0
- package/dist/components/index.js.map +1 -0
- package/dist/composables/index.d.ts +17 -0
- package/dist/composables/index.js +49 -0
- package/dist/composables/index.js.map +1 -0
- package/dist/composables/useApi.d.ts +19 -0
- package/dist/composables/useApi.js +101 -0
- package/dist/composables/useApi.js.map +1 -0
- package/dist/composables/useAsync.d.ts +127 -0
- package/dist/composables/useAsync.js +141 -0
- package/dist/composables/useAsync.js.map +1 -0
- package/dist/composables/useAuth.d.ts +44 -0
- package/dist/composables/useAuth.js +286 -0
- package/dist/composables/useAuth.js.map +1 -0
- package/dist/composables/useChemicalFormula.d.ts +20 -0
- package/dist/composables/useChemicalFormula.js +228 -0
- package/dist/composables/useChemicalFormula.js.map +1 -0
- package/dist/composables/useConcentrationUnits.d.ts +28 -0
- package/dist/composables/useConcentrationUnits.js +154 -0
- package/dist/composables/useConcentrationUnits.js.map +1 -0
- package/dist/composables/useDoseCalculator.d.ts +57 -0
- package/dist/composables/useDoseCalculator.js +228 -0
- package/dist/composables/useDoseCalculator.js.map +1 -0
- package/dist/composables/useForm.d.ts +91 -0
- package/dist/composables/useForm.js +253 -0
- package/dist/composables/useForm.js.map +1 -0
- package/dist/composables/usePasskey.d.ts +9 -0
- package/dist/composables/usePasskey.js +171 -0
- package/dist/composables/usePasskey.js.map +1 -0
- package/dist/composables/usePlatformContext.d.ts +125 -0
- package/dist/composables/usePlatformContext.js +149 -0
- package/dist/composables/usePlatformContext.js.map +1 -0
- package/dist/composables/useProtocolTemplates.d.ts +43 -0
- package/dist/composables/useProtocolTemplates.js +437 -0
- package/dist/composables/useProtocolTemplates.js.map +1 -0
- package/dist/composables/useRackEditor.d.ts +30 -0
- package/dist/composables/useRackEditor.js +168 -0
- package/dist/composables/useRackEditor.js.map +1 -0
- package/dist/composables/useScheduleDrag.d.ts +77 -0
- package/dist/composables/useScheduleDrag.js +183 -0
- package/dist/composables/useScheduleDrag.js.map +1 -0
- package/dist/composables/useSequenceUtils.d.ts +13 -0
- package/dist/composables/useSequenceUtils.js +93 -0
- package/dist/composables/useSequenceUtils.js.map +1 -0
- package/dist/composables/useTheme.d.ts +7 -0
- package/dist/composables/useTheme.js +40 -0
- package/dist/composables/useTheme.js.map +1 -0
- package/dist/composables/useTimeUtils.d.ts +15 -0
- package/dist/composables/useTimeUtils.js +105 -0
- package/dist/composables/useTimeUtils.js.map +1 -0
- package/dist/composables/useToast.d.ts +19 -0
- package/dist/composables/useToast.js +33 -0
- package/dist/composables/useToast.js.map +1 -0
- package/dist/composables/useWellPlateEditor.d.ts +31 -0
- package/dist/composables/useWellPlateEditor.js +315 -0
- package/dist/composables/useWellPlateEditor.js.map +1 -0
- package/dist/histoire.setup.d.ts +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +265 -0
- package/dist/index.js.map +1 -0
- package/dist/install.d.ts +16 -0
- package/dist/install.js +15 -0
- package/dist/install.js.map +1 -0
- package/dist/stores/auth.d.ts +146 -0
- package/dist/stores/auth.js +122 -0
- package/dist/stores/auth.js.map +1 -0
- package/dist/stores/index.d.ts +2 -0
- package/dist/stores/index.js +8 -0
- package/dist/stores/index.js.map +1 -0
- package/dist/stores/settings.d.ts +75 -0
- package/dist/stores/settings.js +180 -0
- package/dist/stores/settings.js.map +1 -0
- package/dist/styles.css +23264 -0
- package/dist/tailwind.preset.d.ts +56 -0
- package/dist/tailwind.preset.js +59 -0
- package/dist/tailwind.preset.js.map +1 -0
- package/dist/types/auth.d.ts +42 -0
- package/dist/types/components.d.ts +405 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/platform.d.ts +66 -0
- package/package.json +111 -0
- package/src/__tests__/components/AppLayout.test.ts +163 -0
- package/src/__tests__/components/AppSidebar.test.ts +292 -0
- package/src/__tests__/components/AppTopBar.test.ts +590 -0
- package/src/__tests__/components/BaseInput.test.ts +99 -0
- package/src/__tests__/components/BasePill.test.ts +291 -0
- package/src/__tests__/components/Calendar.test.ts +566 -0
- package/src/__tests__/components/CollapsibleCard.test.ts +524 -0
- package/src/__tests__/components/DataFrame.test.ts +767 -0
- package/src/__tests__/components/DropdownButton.test.ts +471 -0
- package/src/__tests__/composables/useAuth.test.ts +141 -0
- package/src/__tests__/composables/useForm.test.ts +205 -0
- package/src/components/AlertBox.story.vue +100 -0
- package/src/components/AlertBox.vue +68 -0
- package/src/components/AppContainer.story.vue +104 -0
- package/src/components/AppContainer.vue +33 -0
- package/src/components/AppLayout.story.vue +218 -0
- package/src/components/AppLayout.vue +75 -0
- package/src/components/AppSidebar.story.vue +300 -0
- package/src/components/AppSidebar.vue +114 -0
- package/src/components/AppTopBar.story.vue +112 -0
- package/src/components/AppTopBar.vue +471 -0
- package/src/components/AuditTrail.story.vue +163 -0
- package/src/components/AuditTrail.vue +161 -0
- package/src/components/Avatar.story.vue +92 -0
- package/src/components/Avatar.vue +65 -0
- package/src/components/BaseButton.story.vue +96 -0
- package/src/components/BaseButton.vue +72 -0
- package/src/components/BaseCheckbox.story.vue +73 -0
- package/src/components/BaseCheckbox.vue +68 -0
- package/src/components/BaseInput.story.vue +98 -0
- package/src/components/BaseInput.vue +70 -0
- package/src/components/BaseModal.story.vue +126 -0
- package/src/components/BaseModal.vue +118 -0
- package/src/components/BasePill.story.vue +131 -0
- package/src/components/BasePill.vue +84 -0
- package/src/components/BaseRadioGroup.story.vue +116 -0
- package/src/components/BaseRadioGroup.vue +83 -0
- package/src/components/BaseSelect.story.vue +110 -0
- package/src/components/BaseSelect.vue +67 -0
- package/src/components/BaseSlider.story.vue +82 -0
- package/src/components/BaseSlider.vue +112 -0
- package/src/components/BaseTabs.story.vue +106 -0
- package/src/components/BaseTabs.vue +58 -0
- package/src/components/BaseTextarea.story.vue +91 -0
- package/src/components/BaseTextarea.vue +58 -0
- package/src/components/BaseToggle.story.vue +81 -0
- package/src/components/BaseToggle.vue +72 -0
- package/src/components/BatchProgressList.story.vue +92 -0
- package/src/components/BatchProgressList.vue +202 -0
- package/src/components/Breadcrumb.story.vue +93 -0
- package/src/components/Breadcrumb.vue +73 -0
- package/src/components/Calendar.story.vue +106 -0
- package/src/components/Calendar.vue +362 -0
- package/src/components/ChartContainer.story.vue +113 -0
- package/src/components/ChartContainer.vue +63 -0
- package/src/components/ChemicalFormula.story.vue +102 -0
- package/src/components/ChemicalFormula.vue +38 -0
- package/src/components/CollapsibleCard.story.vue +124 -0
- package/src/components/CollapsibleCard.vue +164 -0
- package/src/components/ColorSlider.story.vue +120 -0
- package/src/components/ColorSlider.vue +163 -0
- package/src/components/ConcentrationInput.story.vue +77 -0
- package/src/components/ConcentrationInput.vue +184 -0
- package/src/components/ConfirmDialog.story.vue +145 -0
- package/src/components/ConfirmDialog.vue +96 -0
- package/src/components/DataFrame.story.vue +148 -0
- package/src/components/DataFrame.vue +418 -0
- package/src/components/DatePicker.story.vue +104 -0
- package/src/components/DatePicker.vue +298 -0
- package/src/components/DateTimePicker.story.vue +112 -0
- package/src/components/DateTimePicker.vue +391 -0
- package/src/components/Divider.story.vue +72 -0
- package/src/components/Divider.vue +45 -0
- package/src/components/DoseCalculator.story.vue +68 -0
- package/src/components/DoseCalculator.vue +475 -0
- package/src/components/DropdownButton.story.vue +102 -0
- package/src/components/DropdownButton.vue +180 -0
- package/src/components/EmptyState.story.vue +124 -0
- package/src/components/EmptyState.vue +64 -0
- package/src/components/ExperimentTimeline.story.vue +161 -0
- package/src/components/ExperimentTimeline.vue +381 -0
- package/src/components/FileUploader.story.vue +106 -0
- package/src/components/FileUploader.vue +397 -0
- package/src/components/FormField.story.vue +119 -0
- package/src/components/FormField.vue +37 -0
- package/src/components/FormulaInput.story.vue +96 -0
- package/src/components/FormulaInput.vue +123 -0
- package/src/components/GroupAssigner.story.vue +83 -0
- package/src/components/GroupAssigner.vue +283 -0
- package/src/components/GroupingModal.story.vue +52 -0
- package/src/components/GroupingModal.vue +420 -0
- package/src/components/IconButton.story.vue +135 -0
- package/src/components/IconButton.vue +72 -0
- package/src/components/LoadingSpinner.story.vue +70 -0
- package/src/components/LoadingSpinner.vue +49 -0
- package/src/components/MoleculeInput.story.vue +66 -0
- package/src/components/MoleculeInput.vue +414 -0
- package/src/components/MultiSelect.story.vue +121 -0
- package/src/components/MultiSelect.vue +117 -0
- package/src/components/NumberInput.story.vue +90 -0
- package/src/components/NumberInput.vue +128 -0
- package/src/components/PlateMapEditor.story.vue +92 -0
- package/src/components/PlateMapEditor.vue +512 -0
- package/src/components/ProgressBar.story.vue +117 -0
- package/src/components/ProgressBar.vue +63 -0
- package/src/components/ProtocolStepEditor.story.vue +69 -0
- package/src/components/ProtocolStepEditor.vue +521 -0
- package/src/components/RackEditor.story.vue +100 -0
- package/src/components/RackEditor.vue +370 -0
- package/src/components/ReagentList.story.vue +137 -0
- package/src/components/ReagentList.vue +487 -0
- package/src/components/ResourceCard.story.vue +150 -0
- package/src/components/ResourceCard.vue +160 -0
- package/src/components/SampleHierarchyTree.story.vue +161 -0
- package/src/components/SampleHierarchyTree.vue +279 -0
- package/src/components/SampleLegend.story.vue +91 -0
- package/src/components/SampleLegend.vue +118 -0
- package/src/components/SampleSelector.story.vue +100 -0
- package/src/components/SampleSelector.vue +955 -0
- package/src/components/ScheduleCalendar.story.vue +195 -0
- package/src/components/ScheduleCalendar.vue +568 -0
- package/src/components/ScientificNumber.story.vue +128 -0
- package/src/components/ScientificNumber.vue +197 -0
- package/src/components/SegmentedControl.story.vue +112 -0
- package/src/components/SegmentedControl.vue +78 -0
- package/src/components/SequenceInput.story.vue +119 -0
- package/src/components/SequenceInput.vue +208 -0
- package/src/components/SettingsButton.story.vue +58 -0
- package/src/components/SettingsButton.vue +75 -0
- package/src/components/SettingsModal.story.vue +145 -0
- package/src/components/SettingsModal.vue +151 -0
- package/src/components/Skeleton.story.vue +120 -0
- package/src/components/Skeleton.vue +73 -0
- package/src/components/StatusIndicator.story.vue +99 -0
- package/src/components/StatusIndicator.vue +39 -0
- package/src/components/StepWizard.story.vue +155 -0
- package/src/components/StepWizard.vue +231 -0
- package/src/components/TagsInput.story.vue +104 -0
- package/src/components/TagsInput.vue +127 -0
- package/src/components/ThemeToggle.story.vue +36 -0
- package/src/components/ThemeToggle.vue +53 -0
- package/src/components/TimePicker.story.vue +96 -0
- package/src/components/TimePicker.vue +272 -0
- package/src/components/TimeRangeInput.story.vue +104 -0
- package/src/components/TimeRangeInput.vue +121 -0
- package/src/components/ToastNotification.story.vue +130 -0
- package/src/components/ToastNotification.vue +54 -0
- package/src/components/Tooltip.story.vue +102 -0
- package/src/components/Tooltip.vue +61 -0
- package/src/components/UnitInput.story.vue +170 -0
- package/src/components/UnitInput.vue +218 -0
- package/src/components/WellEditPopup.vue +234 -0
- package/src/components/WellPlate.story.vue +198 -0
- package/src/components/WellPlate.vue +637 -0
- package/src/components/index.ts +96 -0
- package/src/composables/index.ts +87 -0
- package/src/composables/useApi.ts +145 -0
- package/src/composables/useAsync.ts +322 -0
- package/src/composables/useAuth.ts +427 -0
- package/src/composables/useChemicalFormula.ts +274 -0
- package/src/composables/useConcentrationUnits.ts +245 -0
- package/src/composables/useDoseCalculator.ts +369 -0
- package/src/composables/useForm.ts +415 -0
- package/src/composables/usePasskey.ts +209 -0
- package/src/composables/usePlatformContext.ts +232 -0
- package/src/composables/useProtocolTemplates.ts +517 -0
- package/src/composables/useRackEditor.ts +221 -0
- package/src/composables/useScheduleDrag.ts +244 -0
- package/src/composables/useSequenceUtils.ts +104 -0
- package/src/composables/useTheme.ts +49 -0
- package/src/composables/useTimeUtils.ts +114 -0
- package/src/composables/useToast.ts +39 -0
- package/src/composables/useWellPlateEditor.ts +408 -0
- package/src/histoire.setup.ts +17 -0
- package/src/index.ts +283 -0
- package/src/install.ts +32 -0
- package/src/stores/auth.ts +144 -0
- package/src/stores/index.ts +2 -0
- package/src/stores/settings.ts +229 -0
- package/src/styles/components/alert-box.css +94 -0
- package/src/styles/components/app-container.css +32 -0
- package/src/styles/components/app-layout.css +99 -0
- package/src/styles/components/app-sidebar.css +133 -0
- package/src/styles/components/app-top-bar.css +396 -0
- package/src/styles/components/audit-trail.css +143 -0
- package/src/styles/components/avatar.css +64 -0
- package/src/styles/components/batch-progress-list.css +196 -0
- package/src/styles/components/breadcrumb.css +45 -0
- package/src/styles/components/button.css +119 -0
- package/src/styles/components/calendar.css +192 -0
- package/src/styles/components/chart-container.css +69 -0
- package/src/styles/components/checkbox.css +112 -0
- package/src/styles/components/chemical-formula.css +46 -0
- package/src/styles/components/collapsible-card.css +184 -0
- package/src/styles/components/color-slider.css +110 -0
- package/src/styles/components/concentration-input.css +142 -0
- package/src/styles/components/confirm-dialog.css +137 -0
- package/src/styles/components/dataframe.css +382 -0
- package/src/styles/components/date-picker.css +239 -0
- package/src/styles/components/datetime-picker.css +225 -0
- package/src/styles/components/divider.css +62 -0
- package/src/styles/components/dose-calculator.css +301 -0
- package/src/styles/components/dropdown-button.css +236 -0
- package/src/styles/components/empty-state.css +148 -0
- package/src/styles/components/experiment-timeline.css +529 -0
- package/src/styles/components/file-uploader.css +517 -0
- package/src/styles/components/form-field.css +35 -0
- package/src/styles/components/formula-input.css +96 -0
- package/src/styles/components/group-assigner.css +200 -0
- package/src/styles/components/grouping-modal.css +323 -0
- package/src/styles/components/icon-button.css +128 -0
- package/src/styles/components/input.css +53 -0
- package/src/styles/components/loading-spinner.css +67 -0
- package/src/styles/components/modal.css +122 -0
- package/src/styles/components/molecule-input.css +186 -0
- package/src/styles/components/multi-select.css +131 -0
- package/src/styles/components/number-input.css +110 -0
- package/src/styles/components/pill.css +172 -0
- package/src/styles/components/plate-map-editor.css +464 -0
- package/src/styles/components/progress-bar.css +88 -0
- package/src/styles/components/protocol-step-editor.css +449 -0
- package/src/styles/components/rack-editor.css +259 -0
- package/src/styles/components/radio-group.css +158 -0
- package/src/styles/components/reagent-list.css +407 -0
- package/src/styles/components/resource-card.css +360 -0
- package/src/styles/components/sample-hierarchy-tree.css +314 -0
- package/src/styles/components/sample-legend.css +201 -0
- package/src/styles/components/sample-selector.css +701 -0
- package/src/styles/components/schedule-calendar.css +478 -0
- package/src/styles/components/scientific-number.css +63 -0
- package/src/styles/components/segmented-control.css +190 -0
- package/src/styles/components/select.css +72 -0
- package/src/styles/components/sequence-input.css +184 -0
- package/src/styles/components/settings-button.css +75 -0
- package/src/styles/components/settings-modal.css +95 -0
- package/src/styles/components/skeleton.css +36 -0
- package/src/styles/components/slider.css +78 -0
- package/src/styles/components/status-indicator.css +59 -0
- package/src/styles/components/step-wizard.css +187 -0
- package/src/styles/components/tabs.css +108 -0
- package/src/styles/components/tags-input.css +118 -0
- package/src/styles/components/textarea.css +65 -0
- package/src/styles/components/theme-toggle.css +50 -0
- package/src/styles/components/time-picker.css +171 -0
- package/src/styles/components/time-range-input.css +42 -0
- package/src/styles/components/toast.css +72 -0
- package/src/styles/components/toggle.css +115 -0
- package/src/styles/components/tooltip.css +98 -0
- package/src/styles/components/unit-input.css +138 -0
- package/src/styles/components/well-edit-popup.css +252 -0
- package/src/styles/components/well-plate.css +310 -0
- package/src/styles/index.css +80 -0
- package/src/styles/variables.css +1078 -0
- package/src/tailwind.preset.ts +59 -0
- package/src/types/auth.ts +55 -0
- package/src/types/components.ts +560 -0
- package/src/types/index.ts +146 -0
- package/src/types/platform.ts +101 -0
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { defineComponent, ref, computed, openBlock, createElementBlock, toDisplayString, Fragment, createElementVNode, createCommentVNode, withModifiers, normalizeClass } from "vue";
|
|
2
|
+
const _hoisted_1 = { class: "mld-sci-number" };
|
|
3
|
+
const _hoisted_2 = {
|
|
4
|
+
key: 0,
|
|
5
|
+
class: "mld-sci-number__plain"
|
|
6
|
+
};
|
|
7
|
+
const _hoisted_3 = { class: "mld-sci-number__mantissa" };
|
|
8
|
+
const _hoisted_4 = { class: "mld-sci-number__exponent" };
|
|
9
|
+
const _hoisted_5 = { class: "mld-sci-number__plain" };
|
|
10
|
+
const _hoisted_6 = {
|
|
11
|
+
key: 0,
|
|
12
|
+
class: "mld-sci-number__suffix"
|
|
13
|
+
};
|
|
14
|
+
const _hoisted_7 = {
|
|
15
|
+
key: 3,
|
|
16
|
+
class: "mld-sci-number__plain"
|
|
17
|
+
};
|
|
18
|
+
const _hoisted_8 = {
|
|
19
|
+
key: 4,
|
|
20
|
+
class: "mld-sci-number__unit"
|
|
21
|
+
};
|
|
22
|
+
const _hoisted_9 = ["title"];
|
|
23
|
+
const _hoisted_10 = {
|
|
24
|
+
key: 0,
|
|
25
|
+
width: "14",
|
|
26
|
+
height: "14",
|
|
27
|
+
viewBox: "0 0 24 24",
|
|
28
|
+
fill: "none",
|
|
29
|
+
stroke: "currentColor",
|
|
30
|
+
"stroke-width": "2",
|
|
31
|
+
"stroke-linecap": "round",
|
|
32
|
+
"stroke-linejoin": "round"
|
|
33
|
+
};
|
|
34
|
+
const _hoisted_11 = {
|
|
35
|
+
key: 1,
|
|
36
|
+
width: "14",
|
|
37
|
+
height: "14",
|
|
38
|
+
viewBox: "0 0 24 24",
|
|
39
|
+
fill: "none",
|
|
40
|
+
stroke: "currentColor",
|
|
41
|
+
"stroke-width": "2",
|
|
42
|
+
"stroke-linecap": "round",
|
|
43
|
+
"stroke-linejoin": "round"
|
|
44
|
+
};
|
|
45
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
46
|
+
__name: "ScientificNumber",
|
|
47
|
+
props: {
|
|
48
|
+
value: {},
|
|
49
|
+
precision: { default: 3 },
|
|
50
|
+
notation: { default: "auto" },
|
|
51
|
+
unit: {},
|
|
52
|
+
copyable: { type: Boolean, default: false }
|
|
53
|
+
},
|
|
54
|
+
setup(__props) {
|
|
55
|
+
const props = __props;
|
|
56
|
+
const copied = ref(false);
|
|
57
|
+
const SUPERSCRIPT_DIGITS = {
|
|
58
|
+
"0": "⁰",
|
|
59
|
+
"1": "¹",
|
|
60
|
+
"2": "²",
|
|
61
|
+
"3": "³",
|
|
62
|
+
"4": "⁴",
|
|
63
|
+
"5": "⁵",
|
|
64
|
+
"6": "⁶",
|
|
65
|
+
"7": "⁷",
|
|
66
|
+
"8": "⁸",
|
|
67
|
+
"9": "⁹",
|
|
68
|
+
"-": "⁻"
|
|
69
|
+
};
|
|
70
|
+
const SI_SUFFIXES = [
|
|
71
|
+
[1e12, "T"],
|
|
72
|
+
[1e9, "G"],
|
|
73
|
+
[1e6, "M"],
|
|
74
|
+
[1e3, "k"],
|
|
75
|
+
[1e-3, "m"],
|
|
76
|
+
[1e-6, "µ"],
|
|
77
|
+
[1e-9, "n"],
|
|
78
|
+
[1e-12, "p"]
|
|
79
|
+
];
|
|
80
|
+
function toSuperscript(exp) {
|
|
81
|
+
return String(exp).split("").map((ch) => SUPERSCRIPT_DIGITS[ch] ?? ch).join("");
|
|
82
|
+
}
|
|
83
|
+
function roundToPrecision(n, digits) {
|
|
84
|
+
return n.toFixed(digits).replace(/\.?0+$/, "") || "0";
|
|
85
|
+
}
|
|
86
|
+
const formatted = computed(() => {
|
|
87
|
+
const v = props.value;
|
|
88
|
+
if (!Number.isFinite(v)) return { type: "plain", plain: "" };
|
|
89
|
+
if (v === 0) return { type: "plain", plain: "0" };
|
|
90
|
+
const absV = Math.abs(v);
|
|
91
|
+
if (props.notation === "compact") {
|
|
92
|
+
for (const [threshold, suffix] of SI_SUFFIXES) {
|
|
93
|
+
if (absV >= threshold * 0.999) {
|
|
94
|
+
return {
|
|
95
|
+
type: "compact",
|
|
96
|
+
plain: roundToPrecision(v / threshold, props.precision),
|
|
97
|
+
suffix
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return { type: "plain", plain: roundToPrecision(v, props.precision) };
|
|
102
|
+
}
|
|
103
|
+
const useScientific = props.notation === "scientific" || props.notation === "engineering" || props.notation === "auto" && (absV < 0.01 || absV >= 1e4);
|
|
104
|
+
if (!useScientific) {
|
|
105
|
+
return { type: "plain", plain: roundToPrecision(v, props.precision) };
|
|
106
|
+
}
|
|
107
|
+
let exp = Math.floor(Math.log10(absV));
|
|
108
|
+
if (props.notation === "engineering") {
|
|
109
|
+
exp = Math.floor(exp / 3) * 3;
|
|
110
|
+
}
|
|
111
|
+
const mantissa = v / Math.pow(10, exp);
|
|
112
|
+
const mantissaStr = roundToPrecision(mantissa, props.precision);
|
|
113
|
+
return {
|
|
114
|
+
type: "scientific",
|
|
115
|
+
mantissa: mantissaStr,
|
|
116
|
+
exponent: exp,
|
|
117
|
+
exponentStr: toSuperscript(exp)
|
|
118
|
+
};
|
|
119
|
+
});
|
|
120
|
+
const specialDisplay = computed(() => {
|
|
121
|
+
if (Number.isNaN(props.value)) return "NaN";
|
|
122
|
+
if (props.value === Infinity) return "∞";
|
|
123
|
+
if (props.value === -Infinity) return "-∞";
|
|
124
|
+
return null;
|
|
125
|
+
});
|
|
126
|
+
const plainTextValue = computed(() => {
|
|
127
|
+
if (specialDisplay.value) return specialDisplay.value;
|
|
128
|
+
const f = formatted.value;
|
|
129
|
+
let text;
|
|
130
|
+
if (f.type === "scientific") {
|
|
131
|
+
text = `${f.mantissa}e${f.exponent}`;
|
|
132
|
+
} else if (f.type === "compact") {
|
|
133
|
+
text = `${f.plain}${f.suffix ?? ""}`;
|
|
134
|
+
} else {
|
|
135
|
+
text = f.plain ?? "0";
|
|
136
|
+
}
|
|
137
|
+
if (props.unit) text += ` ${props.unit}`;
|
|
138
|
+
return text;
|
|
139
|
+
});
|
|
140
|
+
async function copyToClipboard() {
|
|
141
|
+
try {
|
|
142
|
+
await navigator.clipboard.writeText(plainTextValue.value);
|
|
143
|
+
copied.value = true;
|
|
144
|
+
setTimeout(() => {
|
|
145
|
+
copied.value = false;
|
|
146
|
+
}, 1500);
|
|
147
|
+
} catch {
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return (_ctx, _cache) => {
|
|
151
|
+
return openBlock(), createElementBlock("span", _hoisted_1, [
|
|
152
|
+
specialDisplay.value ? (openBlock(), createElementBlock("span", _hoisted_2, toDisplayString(specialDisplay.value), 1)) : formatted.value.type === "scientific" ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
|
|
153
|
+
createElementVNode("span", _hoisted_3, toDisplayString(formatted.value.mantissa), 1),
|
|
154
|
+
_cache[0] || (_cache[0] = createElementVNode("span", { class: "mld-sci-number__times" }, "×", -1)),
|
|
155
|
+
_cache[1] || (_cache[1] = createElementVNode("span", { class: "mld-sci-number__base" }, "10", -1)),
|
|
156
|
+
createElementVNode("span", _hoisted_4, toDisplayString(formatted.value.exponentStr), 1)
|
|
157
|
+
], 64)) : formatted.value.type === "compact" ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
|
|
158
|
+
createElementVNode("span", _hoisted_5, toDisplayString(formatted.value.plain), 1),
|
|
159
|
+
formatted.value.suffix ? (openBlock(), createElementBlock("span", _hoisted_6, toDisplayString(formatted.value.suffix), 1)) : createCommentVNode("", true)
|
|
160
|
+
], 64)) : (openBlock(), createElementBlock("span", _hoisted_7, toDisplayString(formatted.value.plain), 1)),
|
|
161
|
+
__props.unit ? (openBlock(), createElementBlock("span", _hoisted_8, toDisplayString(__props.unit), 1)) : createCommentVNode("", true),
|
|
162
|
+
__props.copyable ? (openBlock(), createElementBlock("button", {
|
|
163
|
+
key: 5,
|
|
164
|
+
class: normalizeClass(["mld-sci-number__copy-btn", { "mld-sci-number__copy-btn--copied": copied.value }]),
|
|
165
|
+
type: "button",
|
|
166
|
+
title: copied.value ? "Copied!" : "Copy value",
|
|
167
|
+
onClick: withModifiers(copyToClipboard, ["stop"])
|
|
168
|
+
}, [
|
|
169
|
+
!copied.value ? (openBlock(), createElementBlock("svg", _hoisted_10, [..._cache[2] || (_cache[2] = [
|
|
170
|
+
createElementVNode("rect", {
|
|
171
|
+
x: "9",
|
|
172
|
+
y: "9",
|
|
173
|
+
width: "13",
|
|
174
|
+
height: "13",
|
|
175
|
+
rx: "2",
|
|
176
|
+
ry: "2"
|
|
177
|
+
}, null, -1),
|
|
178
|
+
createElementVNode("path", { d: "M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1" }, null, -1)
|
|
179
|
+
])])) : (openBlock(), createElementBlock("svg", _hoisted_11, [..._cache[3] || (_cache[3] = [
|
|
180
|
+
createElementVNode("polyline", { points: "20 6 9 17 4 12" }, null, -1)
|
|
181
|
+
])]))
|
|
182
|
+
], 10, _hoisted_9)) : createCommentVNode("", true)
|
|
183
|
+
]);
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
export {
|
|
188
|
+
_sfc_main as default
|
|
189
|
+
};
|
|
190
|
+
//# sourceMappingURL=ScientificNumber.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScientificNumber.vue.js","sources":["../../src/components/ScientificNumber.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, ref } from 'vue'\n\ntype NumberNotation = 'auto' | 'scientific' | 'engineering' | 'compact'\n\ninterface Props {\n value: number\n precision?: number\n notation?: NumberNotation\n unit?: string\n copyable?: boolean\n}\n\nconst props = withDefaults(defineProps<Props>(), {\n precision: 3,\n notation: 'auto',\n copyable: false,\n})\n\nconst copied = ref(false)\n\nconst SUPERSCRIPT_DIGITS: Record<string, string> = {\n '0': '\\u2070',\n '1': '\\u00B9',\n '2': '\\u00B2',\n '3': '\\u00B3',\n '4': '\\u2074',\n '5': '\\u2075',\n '6': '\\u2076',\n '7': '\\u2077',\n '8': '\\u2078',\n '9': '\\u2079',\n '-': '\\u207B',\n}\n\nconst SI_SUFFIXES: [number, string][] = [\n [1e12, 'T'],\n [1e9, 'G'],\n [1e6, 'M'],\n [1e3, 'k'],\n [1e-3, 'm'],\n [1e-6, '\\u00B5'],\n [1e-9, 'n'],\n [1e-12, 'p'],\n]\n\nfunction toSuperscript(exp: number): string {\n return String(exp)\n .split('')\n .map(ch => SUPERSCRIPT_DIGITS[ch] ?? ch)\n .join('')\n}\n\nfunction roundToPrecision(n: number, digits: number): string {\n return n.toFixed(digits).replace(/\\.?0+$/, '') || '0'\n}\n\ninterface FormattedNumber {\n type: 'plain' | 'scientific' | 'compact'\n mantissa?: string\n exponent?: number\n exponentStr?: string\n plain?: string\n suffix?: string\n}\n\nconst formatted = computed<FormattedNumber>(() => {\n const v = props.value\n\n if (!Number.isFinite(v)) return { type: 'plain', plain: '' }\n if (v === 0) return { type: 'plain', plain: '0' }\n\n const absV = Math.abs(v)\n\n if (props.notation === 'compact') {\n for (const [threshold, suffix] of SI_SUFFIXES) {\n if (absV >= threshold * 0.999) {\n return {\n type: 'compact',\n plain: roundToPrecision(v / threshold, props.precision),\n suffix,\n }\n }\n }\n return { type: 'plain', plain: roundToPrecision(v, props.precision) }\n }\n\n const useScientific =\n props.notation === 'scientific' ||\n props.notation === 'engineering' ||\n (props.notation === 'auto' && (absV < 0.01 || absV >= 10000))\n\n if (!useScientific) {\n return { type: 'plain', plain: roundToPrecision(v, props.precision) }\n }\n\n let exp = Math.floor(Math.log10(absV))\n\n if (props.notation === 'engineering') {\n exp = Math.floor(exp / 3) * 3\n }\n\n const mantissa = v / Math.pow(10, exp)\n const mantissaStr = roundToPrecision(mantissa, props.precision)\n\n return {\n type: 'scientific',\n mantissa: mantissaStr,\n exponent: exp,\n exponentStr: toSuperscript(exp),\n }\n})\n\nconst specialDisplay = computed(() => {\n if (Number.isNaN(props.value)) return 'NaN'\n if (props.value === Infinity) return '\\u221E'\n if (props.value === -Infinity) return '-\\u221E'\n return null\n})\n\nconst plainTextValue = computed(() => {\n if (specialDisplay.value) return specialDisplay.value\n const f = formatted.value\n let text: string\n if (f.type === 'scientific') {\n text = `${f.mantissa}e${f.exponent}`\n } else if (f.type === 'compact') {\n text = `${f.plain}${f.suffix ?? ''}`\n } else {\n text = f.plain ?? '0'\n }\n if (props.unit) text += ` ${props.unit}`\n return text\n})\n\nasync function copyToClipboard() {\n try {\n await navigator.clipboard.writeText(plainTextValue.value)\n copied.value = true\n setTimeout(() => { copied.value = false }, 1500)\n } catch {\n // clipboard not available\n }\n}\n</script>\n\n<template>\n <span class=\"mld-sci-number\">\n <!-- Special values: NaN, Infinity -->\n <template v-if=\"specialDisplay\">\n <span class=\"mld-sci-number__plain\">{{ specialDisplay }}</span>\n </template>\n\n <!-- Scientific / Engineering notation -->\n <template v-else-if=\"formatted.type === 'scientific'\">\n <span class=\"mld-sci-number__mantissa\">{{ formatted.mantissa }}</span>\n <span class=\"mld-sci-number__times\">×</span>\n <span class=\"mld-sci-number__base\">10</span>\n <span class=\"mld-sci-number__exponent\">{{ formatted.exponentStr }}</span>\n </template>\n\n <!-- Compact notation with SI suffix -->\n <template v-else-if=\"formatted.type === 'compact'\">\n <span class=\"mld-sci-number__plain\">{{ formatted.plain }}</span>\n <span v-if=\"formatted.suffix\" class=\"mld-sci-number__suffix\">{{ formatted.suffix }}</span>\n </template>\n\n <!-- Plain number -->\n <template v-else>\n <span class=\"mld-sci-number__plain\">{{ formatted.plain }}</span>\n </template>\n\n <!-- Unit -->\n <span v-if=\"unit\" class=\"mld-sci-number__unit\">{{ unit }}</span>\n\n <!-- Copy button -->\n <button\n v-if=\"copyable\"\n :class=\"['mld-sci-number__copy-btn', { 'mld-sci-number__copy-btn--copied': copied }]\"\n type=\"button\"\n :title=\"copied ? 'Copied!' : 'Copy value'\"\n @click.stop=\"copyToClipboard\"\n >\n <svg v-if=\"!copied\" width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <rect x=\"9\" y=\"9\" width=\"13\" height=\"13\" rx=\"2\" ry=\"2\" />\n <path d=\"M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1\" />\n </svg>\n <svg v-else width=\"14\" height=\"14\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <polyline points=\"20 6 9 17 4 12\" />\n </svg>\n </button>\n </span>\n</template>\n\n<style>\n@import '../styles/components/scientific-number.css';\n</style>\n"],"names":["_openBlock","_createElementBlock","_toDisplayString","_Fragment","_createElementVNode"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ScientificNumber.vue3.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { SegmentedOption, SegmentedControlVariant, SegmentedControlSize } from '../types';
|
|
2
|
+
interface Props {
|
|
3
|
+
modelValue: string | number;
|
|
4
|
+
options: SegmentedOption[];
|
|
5
|
+
variant?: SegmentedControlVariant;
|
|
6
|
+
size?: SegmentedControlSize;
|
|
7
|
+
fullWidth?: boolean;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
}
|
|
10
|
+
declare const _default: import('vue').DefineComponent<Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
11
|
+
"update:modelValue": (value: string | number) => any;
|
|
12
|
+
}, string, import('vue').PublicProps, Readonly<Props> & Readonly<{
|
|
13
|
+
"onUpdate:modelValue"?: ((value: string | number) => any) | undefined;
|
|
14
|
+
}>, {
|
|
15
|
+
disabled: boolean;
|
|
16
|
+
variant: SegmentedControlVariant;
|
|
17
|
+
size: SegmentedControlSize;
|
|
18
|
+
fullWidth: boolean;
|
|
19
|
+
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
|
|
20
|
+
export default _default;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { defineComponent, openBlock, createElementBlock, normalizeClass, Fragment, renderList, createElementVNode, toDisplayString, createCommentVNode } from "vue";
|
|
2
|
+
const _hoisted_1 = ["aria-checked", "disabled", "onClick", "onKeydown"];
|
|
3
|
+
const _hoisted_2 = { class: "mld-segmented-control__label" };
|
|
4
|
+
const _hoisted_3 = {
|
|
5
|
+
key: 0,
|
|
6
|
+
class: "mld-segmented-control__description"
|
|
7
|
+
};
|
|
8
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
9
|
+
__name: "SegmentedControl",
|
|
10
|
+
props: {
|
|
11
|
+
modelValue: {},
|
|
12
|
+
options: {},
|
|
13
|
+
variant: { default: "simple" },
|
|
14
|
+
size: { default: "md" },
|
|
15
|
+
fullWidth: { type: Boolean, default: true },
|
|
16
|
+
disabled: { type: Boolean, default: false }
|
|
17
|
+
},
|
|
18
|
+
emits: ["update:modelValue"],
|
|
19
|
+
setup(__props, { emit: __emit }) {
|
|
20
|
+
const props = __props;
|
|
21
|
+
const emit = __emit;
|
|
22
|
+
function handleSelect(option) {
|
|
23
|
+
if (props.disabled || option.disabled) return;
|
|
24
|
+
emit("update:modelValue", option.value);
|
|
25
|
+
}
|
|
26
|
+
function handleKeydown(event, option) {
|
|
27
|
+
if (event.key === "Enter" || event.key === " ") {
|
|
28
|
+
event.preventDefault();
|
|
29
|
+
handleSelect(option);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return (_ctx, _cache) => {
|
|
33
|
+
return openBlock(), createElementBlock("div", {
|
|
34
|
+
class: normalizeClass([
|
|
35
|
+
"mld-segmented-control",
|
|
36
|
+
`mld-segmented-control--${__props.variant}`,
|
|
37
|
+
`mld-segmented-control--${__props.size}`,
|
|
38
|
+
__props.fullWidth ? "mld-segmented-control--full-width" : "",
|
|
39
|
+
__props.disabled ? "mld-segmented-control--disabled" : ""
|
|
40
|
+
]),
|
|
41
|
+
role: "radiogroup"
|
|
42
|
+
}, [
|
|
43
|
+
(openBlock(true), createElementBlock(Fragment, null, renderList(__props.options, (option) => {
|
|
44
|
+
return openBlock(), createElementBlock("button", {
|
|
45
|
+
key: String(option.value),
|
|
46
|
+
type: "button",
|
|
47
|
+
role: "radio",
|
|
48
|
+
"aria-checked": __props.modelValue === option.value,
|
|
49
|
+
disabled: __props.disabled || option.disabled,
|
|
50
|
+
class: normalizeClass([
|
|
51
|
+
"mld-segmented-control__option",
|
|
52
|
+
`mld-segmented-control__option--${__props.variant}`,
|
|
53
|
+
`mld-segmented-control__option--${__props.size}`,
|
|
54
|
+
__props.modelValue === option.value ? "mld-segmented-control__option--active" : "",
|
|
55
|
+
option.disabled ? "mld-segmented-control__option--disabled" : ""
|
|
56
|
+
]),
|
|
57
|
+
onClick: ($event) => handleSelect(option),
|
|
58
|
+
onKeydown: ($event) => handleKeydown($event, option)
|
|
59
|
+
}, [
|
|
60
|
+
createElementVNode("span", _hoisted_2, toDisplayString(option.label), 1),
|
|
61
|
+
option.description && __props.variant === "card" ? (openBlock(), createElementBlock("span", _hoisted_3, toDisplayString(option.description), 1)) : createCommentVNode("", true)
|
|
62
|
+
], 42, _hoisted_1);
|
|
63
|
+
}), 128))
|
|
64
|
+
], 2);
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
export {
|
|
69
|
+
_sfc_main as default
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=SegmentedControl.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SegmentedControl.vue.js","sources":["../../src/components/SegmentedControl.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport type { SegmentedOption, SegmentedControlVariant, SegmentedControlSize } from '../types'\n\ninterface Props {\n modelValue: string | number\n options: SegmentedOption[]\n variant?: SegmentedControlVariant\n size?: SegmentedControlSize\n fullWidth?: boolean\n disabled?: boolean\n}\n\nconst props = withDefaults(defineProps<Props>(), {\n variant: 'simple',\n size: 'md',\n fullWidth: true,\n disabled: false,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string | number]\n}>()\n\nfunction handleSelect(option: SegmentedOption) {\n if (props.disabled || option.disabled) return\n emit('update:modelValue', option.value)\n}\n\nfunction handleKeydown(event: KeyboardEvent, option: SegmentedOption) {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault()\n handleSelect(option)\n }\n}\n</script>\n\n<template>\n <div\n :class=\"[\n 'mld-segmented-control',\n `mld-segmented-control--${variant}`,\n `mld-segmented-control--${size}`,\n fullWidth ? 'mld-segmented-control--full-width' : '',\n disabled ? 'mld-segmented-control--disabled' : '',\n ]\"\n role=\"radiogroup\"\n >\n <button\n v-for=\"option in options\"\n :key=\"String(option.value)\"\n type=\"button\"\n role=\"radio\"\n :aria-checked=\"modelValue === option.value\"\n :disabled=\"disabled || option.disabled\"\n :class=\"[\n 'mld-segmented-control__option',\n `mld-segmented-control__option--${variant}`,\n `mld-segmented-control__option--${size}`,\n modelValue === option.value ? 'mld-segmented-control__option--active' : '',\n option.disabled ? 'mld-segmented-control__option--disabled' : '',\n ]\"\n @click=\"handleSelect(option)\"\n @keydown=\"handleKeydown($event, option)\"\n >\n <span class=\"mld-segmented-control__label\">{{ option.label }}</span>\n <span\n v-if=\"option.description && variant === 'card'\"\n class=\"mld-segmented-control__description\"\n >\n {{ option.description }}\n </span>\n </button>\n </div>\n</template>\n\n<style>\n@import '../styles/components/segmented-control.css';\n</style>\n"],"names":["_createElementBlock","_normalizeClass","_Fragment","_renderList","_createElementVNode","_toDisplayString","_openBlock"],"mappings":";;;;;;;;;;;;;;;;;;;AAYA,UAAM,QAAQ;AAOd,UAAM,OAAO;AAIb,aAAS,aAAa,QAAyB;AAC7C,UAAI,MAAM,YAAY,OAAO,SAAU;AACvC,WAAK,qBAAqB,OAAO,KAAK;AAAA,IACxC;AAEA,aAAS,cAAc,OAAsB,QAAyB;AACpE,UAAI,MAAM,QAAQ,WAAW,MAAM,QAAQ,KAAK;AAC9C,cAAM,eAAA;AACN,qBAAa,MAAM;AAAA,MACrB;AAAA,IACF;;0BAIEA,mBAmCM,OAAA;AAAA,QAlCH,OAAKC,eAAA;AAAA;oCAAmE,QAAA,OAAO;AAAA,oCAAoC,QAAA,IAAI;AAAA,UAAU,QAAA,YAAS,sCAAA;AAAA,UAAmD,QAAA,WAAQ,oCAAA;AAAA,QAAA;QAOtM,MAAK;AAAA,MAAA;0BAELD,mBAwBSE,UAAA,MAAAC,WAvBU,QAAA,SAAO,CAAjB,WAAM;8BADfH,mBAwBS,UAAA;AAAA,YAtBN,KAAK,OAAO,OAAO,KAAK;AAAA,YACzB,MAAK;AAAA,YACL,MAAK;AAAA,YACJ,gBAAc,QAAA,eAAe,OAAO;AAAA,YACpC,UAAU,QAAA,YAAY,OAAO;AAAA,YAC7B,OAAKC,eAAA;AAAA;gDAAuF,QAAA,OAAO;AAAA,gDAA8C,QAAA,IAAI;AAAA,cAAY,QAAA,eAAe,OAAO,QAAK,0CAAA;AAAA,cAAyD,OAAO,WAAQ,4CAAA;AAAA,YAAA;YAOpQ,SAAK,CAAA,WAAE,aAAa,MAAM;AAAA,YAC1B,WAAO,CAAA,WAAE,cAAc,QAAQ,MAAM;AAAA,UAAA;YAEtCG,mBAAoE,QAApE,YAAoEC,gBAAtB,OAAO,KAAK,GAAA,CAAA;AAAA,YAElD,OAAO,eAAe,QAAA,YAAO,UADrCC,UAAA,GAAAN,mBAKO,QALP,YAKOK,gBADF,OAAO,WAAW,GAAA,CAAA;;;;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SegmentedControl.vue3.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { SequenceType, SequenceStats } from '../composables/useSequenceUtils';
|
|
2
|
+
interface Props {
|
|
3
|
+
modelValue?: string;
|
|
4
|
+
type?: SequenceType;
|
|
5
|
+
readonly?: boolean;
|
|
6
|
+
showStats?: boolean;
|
|
7
|
+
showTools?: boolean;
|
|
8
|
+
maxLength?: number;
|
|
9
|
+
placeholder?: string;
|
|
10
|
+
rows?: number;
|
|
11
|
+
error?: boolean;
|
|
12
|
+
disabled?: boolean;
|
|
13
|
+
}
|
|
14
|
+
declare function __VLS_template(): {
|
|
15
|
+
attrs: Partial<{}>;
|
|
16
|
+
slots: Readonly<{
|
|
17
|
+
tools?(props: {
|
|
18
|
+
sequence: string;
|
|
19
|
+
type: "dna" | "rna" | "protein";
|
|
20
|
+
stats: SequenceStats;
|
|
21
|
+
}): unknown;
|
|
22
|
+
}> & {
|
|
23
|
+
tools?(props: {
|
|
24
|
+
sequence: string;
|
|
25
|
+
type: "dna" | "rna" | "protein";
|
|
26
|
+
stats: SequenceStats;
|
|
27
|
+
}): unknown;
|
|
28
|
+
};
|
|
29
|
+
refs: {};
|
|
30
|
+
rootEl: HTMLDivElement;
|
|
31
|
+
};
|
|
32
|
+
type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
|
|
33
|
+
declare const __VLS_component: import('vue').DefineComponent<Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
34
|
+
"update:modelValue": (value: string) => any;
|
|
35
|
+
}, string, import('vue').PublicProps, Readonly<Props> & Readonly<{
|
|
36
|
+
"onUpdate:modelValue"?: ((value: string) => any) | undefined;
|
|
37
|
+
}>, {
|
|
38
|
+
error: boolean;
|
|
39
|
+
disabled: boolean;
|
|
40
|
+
type: SequenceType;
|
|
41
|
+
modelValue: string;
|
|
42
|
+
placeholder: string;
|
|
43
|
+
readonly: boolean;
|
|
44
|
+
rows: number;
|
|
45
|
+
showStats: boolean;
|
|
46
|
+
showTools: boolean;
|
|
47
|
+
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
|
|
48
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
|
|
49
|
+
export default _default;
|
|
50
|
+
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
51
|
+
new (): {
|
|
52
|
+
$slots: S;
|
|
53
|
+
};
|
|
54
|
+
};
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, renderSlot, createCommentVNode, createElementVNode, toDisplayString, Fragment, renderList } from "vue";
|
|
2
|
+
import { useSequenceUtils } from "../composables/useSequenceUtils.js";
|
|
3
|
+
const _hoisted_1 = {
|
|
4
|
+
key: 0,
|
|
5
|
+
class: "mld-sequence-input__toolbar"
|
|
6
|
+
};
|
|
7
|
+
const _hoisted_2 = ["disabled"];
|
|
8
|
+
const _hoisted_3 = ["disabled"];
|
|
9
|
+
const _hoisted_4 = ["disabled"];
|
|
10
|
+
const _hoisted_5 = ["disabled"];
|
|
11
|
+
const _hoisted_6 = { class: "mld-sequence-input__type-badge" };
|
|
12
|
+
const _hoisted_7 = {
|
|
13
|
+
key: 1,
|
|
14
|
+
class: "mld-sequence-input__editor"
|
|
15
|
+
};
|
|
16
|
+
const _hoisted_8 = ["value", "rows", "placeholder", "disabled", "maxlength"];
|
|
17
|
+
const _hoisted_9 = {
|
|
18
|
+
key: 2,
|
|
19
|
+
class: "mld-sequence-input__viewer"
|
|
20
|
+
};
|
|
21
|
+
const _hoisted_10 = { class: "mld-sequence-input__line-number" };
|
|
22
|
+
const _hoisted_11 = { class: "mld-sequence-input__line-content" };
|
|
23
|
+
const _hoisted_12 = {
|
|
24
|
+
key: 0,
|
|
25
|
+
class: "mld-sequence-input__viewer-line"
|
|
26
|
+
};
|
|
27
|
+
const _hoisted_13 = {
|
|
28
|
+
key: 3,
|
|
29
|
+
class: "mld-sequence-input__stats"
|
|
30
|
+
};
|
|
31
|
+
const _hoisted_14 = { class: "mld-sequence-input__stat-value" };
|
|
32
|
+
const _hoisted_15 = { key: 0 };
|
|
33
|
+
const _hoisted_16 = { class: "mld-sequence-input__stat-value" };
|
|
34
|
+
const _hoisted_17 = { key: 1 };
|
|
35
|
+
const _hoisted_18 = { class: "mld-sequence-input__stat-value" };
|
|
36
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
37
|
+
__name: "SequenceInput",
|
|
38
|
+
props: {
|
|
39
|
+
modelValue: { default: "" },
|
|
40
|
+
type: { default: "auto" },
|
|
41
|
+
readonly: { type: Boolean, default: false },
|
|
42
|
+
showStats: { type: Boolean, default: true },
|
|
43
|
+
showTools: { type: Boolean, default: true },
|
|
44
|
+
maxLength: {},
|
|
45
|
+
placeholder: { default: "Paste or type sequence..." },
|
|
46
|
+
rows: { default: 6 },
|
|
47
|
+
error: { type: Boolean, default: false },
|
|
48
|
+
disabled: { type: Boolean, default: false }
|
|
49
|
+
},
|
|
50
|
+
emits: ["update:modelValue"],
|
|
51
|
+
setup(__props, { emit: __emit }) {
|
|
52
|
+
const props = __props;
|
|
53
|
+
const emit = __emit;
|
|
54
|
+
const { detectSequenceType, validateSequence, reverseComplement, calculateStats, formatFasta } = useSequenceUtils();
|
|
55
|
+
const resolvedType = computed(() => {
|
|
56
|
+
if (props.type !== "auto") return props.type;
|
|
57
|
+
if (!props.modelValue) return "dna";
|
|
58
|
+
return detectSequenceType(props.modelValue);
|
|
59
|
+
});
|
|
60
|
+
const stats = computed(() => {
|
|
61
|
+
if (!props.modelValue) return { length: 0 };
|
|
62
|
+
return calculateStats(props.modelValue, resolvedType.value);
|
|
63
|
+
});
|
|
64
|
+
const viewerLines = computed(() => {
|
|
65
|
+
if (!props.modelValue) return [];
|
|
66
|
+
const formatted = formatFasta(props.modelValue, 60);
|
|
67
|
+
return formatted.split("\n").filter((l) => l.length > 0);
|
|
68
|
+
});
|
|
69
|
+
function handleInput(event) {
|
|
70
|
+
const target = event.target;
|
|
71
|
+
let value = target.value;
|
|
72
|
+
if (props.maxLength && value.length > props.maxLength) {
|
|
73
|
+
value = value.slice(0, props.maxLength);
|
|
74
|
+
}
|
|
75
|
+
value = validateSequence(value, resolvedType.value);
|
|
76
|
+
emit("update:modelValue", value);
|
|
77
|
+
}
|
|
78
|
+
function doReverseComplement() {
|
|
79
|
+
if (!props.modelValue || resolvedType.value === "protein") return;
|
|
80
|
+
emit("update:modelValue", reverseComplement(props.modelValue, resolvedType.value));
|
|
81
|
+
}
|
|
82
|
+
function doUppercase() {
|
|
83
|
+
if (!props.modelValue) return;
|
|
84
|
+
emit("update:modelValue", props.modelValue.toUpperCase());
|
|
85
|
+
}
|
|
86
|
+
function doClear() {
|
|
87
|
+
emit("update:modelValue", "");
|
|
88
|
+
}
|
|
89
|
+
function doCopy() {
|
|
90
|
+
if (!props.modelValue) return;
|
|
91
|
+
navigator.clipboard.writeText(props.modelValue);
|
|
92
|
+
}
|
|
93
|
+
function getBaseClass(char) {
|
|
94
|
+
const c = char.toLowerCase();
|
|
95
|
+
if (c === "a") return "mld-sequence-input__base--a";
|
|
96
|
+
if (c === "t") return "mld-sequence-input__base--t";
|
|
97
|
+
if (c === "u") return "mld-sequence-input__base--u";
|
|
98
|
+
if (c === "g") return "mld-sequence-input__base--g";
|
|
99
|
+
if (c === "c") return "mld-sequence-input__base--c";
|
|
100
|
+
if (c === "n") return "mld-sequence-input__base--n";
|
|
101
|
+
return "";
|
|
102
|
+
}
|
|
103
|
+
return (_ctx, _cache) => {
|
|
104
|
+
return openBlock(), createElementBlock("div", {
|
|
105
|
+
class: normalizeClass([
|
|
106
|
+
"mld-sequence-input",
|
|
107
|
+
__props.error ? "mld-sequence-input--error" : "",
|
|
108
|
+
__props.disabled ? "mld-sequence-input--disabled" : ""
|
|
109
|
+
])
|
|
110
|
+
}, [
|
|
111
|
+
__props.showTools && !__props.readonly ? (openBlock(), createElementBlock("div", _hoisted_1, [
|
|
112
|
+
renderSlot(_ctx.$slots, "tools", {
|
|
113
|
+
sequence: __props.modelValue || "",
|
|
114
|
+
type: resolvedType.value,
|
|
115
|
+
stats: stats.value
|
|
116
|
+
}, () => [
|
|
117
|
+
resolvedType.value !== "protein" ? (openBlock(), createElementBlock("button", {
|
|
118
|
+
key: 0,
|
|
119
|
+
type: "button",
|
|
120
|
+
class: "mld-sequence-input__tool-btn",
|
|
121
|
+
disabled: !__props.modelValue || __props.disabled,
|
|
122
|
+
onClick: doReverseComplement
|
|
123
|
+
}, " Rev Comp ", 8, _hoisted_2)) : createCommentVNode("", true),
|
|
124
|
+
createElementVNode("button", {
|
|
125
|
+
type: "button",
|
|
126
|
+
class: "mld-sequence-input__tool-btn",
|
|
127
|
+
disabled: !__props.modelValue || __props.disabled,
|
|
128
|
+
onClick: doUppercase
|
|
129
|
+
}, " Uppercase ", 8, _hoisted_3),
|
|
130
|
+
_cache[0] || (_cache[0] = createElementVNode("div", { class: "mld-sequence-input__tool-sep" }, null, -1)),
|
|
131
|
+
createElementVNode("button", {
|
|
132
|
+
type: "button",
|
|
133
|
+
class: "mld-sequence-input__tool-btn",
|
|
134
|
+
disabled: !__props.modelValue || __props.disabled,
|
|
135
|
+
onClick: doCopy
|
|
136
|
+
}, " Copy ", 8, _hoisted_4),
|
|
137
|
+
createElementVNode("button", {
|
|
138
|
+
type: "button",
|
|
139
|
+
class: "mld-sequence-input__tool-btn",
|
|
140
|
+
disabled: !__props.modelValue || __props.disabled,
|
|
141
|
+
onClick: doClear
|
|
142
|
+
}, " Clear ", 8, _hoisted_5)
|
|
143
|
+
]),
|
|
144
|
+
createElementVNode("span", _hoisted_6, toDisplayString(resolvedType.value), 1)
|
|
145
|
+
])) : createCommentVNode("", true),
|
|
146
|
+
!__props.readonly ? (openBlock(), createElementBlock("div", _hoisted_7, [
|
|
147
|
+
createElementVNode("textarea", {
|
|
148
|
+
value: __props.modelValue,
|
|
149
|
+
rows: __props.rows,
|
|
150
|
+
placeholder: __props.placeholder,
|
|
151
|
+
disabled: __props.disabled,
|
|
152
|
+
maxlength: __props.maxLength,
|
|
153
|
+
class: "mld-sequence-input__textarea",
|
|
154
|
+
spellcheck: "false",
|
|
155
|
+
autocomplete: "off",
|
|
156
|
+
onInput: handleInput
|
|
157
|
+
}, null, 40, _hoisted_8)
|
|
158
|
+
])) : (openBlock(), createElementBlock("div", _hoisted_9, [
|
|
159
|
+
(openBlock(true), createElementBlock(Fragment, null, renderList(viewerLines.value, (line, lineIdx) => {
|
|
160
|
+
return openBlock(), createElementBlock("div", {
|
|
161
|
+
key: lineIdx,
|
|
162
|
+
class: "mld-sequence-input__viewer-line"
|
|
163
|
+
}, [
|
|
164
|
+
createElementVNode("span", _hoisted_10, toDisplayString(lineIdx * 60 + 1), 1),
|
|
165
|
+
createElementVNode("span", _hoisted_11, [
|
|
166
|
+
(openBlock(true), createElementBlock(Fragment, null, renderList(line.split(""), (char, charIdx) => {
|
|
167
|
+
return openBlock(), createElementBlock("span", {
|
|
168
|
+
key: charIdx,
|
|
169
|
+
class: normalizeClass(getBaseClass(char))
|
|
170
|
+
}, toDisplayString(char), 3);
|
|
171
|
+
}), 128))
|
|
172
|
+
])
|
|
173
|
+
]);
|
|
174
|
+
}), 128)),
|
|
175
|
+
!__props.modelValue ? (openBlock(), createElementBlock("div", _hoisted_12, [..._cache[1] || (_cache[1] = [
|
|
176
|
+
createElementVNode("span", { class: "mld-sequence-input__line-number" }, null, -1),
|
|
177
|
+
createElementVNode("span", {
|
|
178
|
+
class: "mld-sequence-input__line-content",
|
|
179
|
+
style: { "color": "var(--text-muted)" }
|
|
180
|
+
}, "No sequence", -1)
|
|
181
|
+
])])) : createCommentVNode("", true)
|
|
182
|
+
])),
|
|
183
|
+
__props.showStats && __props.modelValue ? (openBlock(), createElementBlock("div", _hoisted_13, [
|
|
184
|
+
createElementVNode("span", null, [
|
|
185
|
+
_cache[2] || (_cache[2] = createElementVNode("span", { class: "mld-sequence-input__stat-label" }, "Length:", -1)),
|
|
186
|
+
createElementVNode("span", _hoisted_14, toDisplayString(stats.value.length), 1)
|
|
187
|
+
]),
|
|
188
|
+
stats.value.gcPercent !== void 0 ? (openBlock(), createElementBlock("span", _hoisted_15, [
|
|
189
|
+
_cache[3] || (_cache[3] = createElementVNode("span", { class: "mld-sequence-input__stat-label" }, "GC:", -1)),
|
|
190
|
+
createElementVNode("span", _hoisted_16, toDisplayString(stats.value.gcPercent.toFixed(1)) + "%", 1)
|
|
191
|
+
])) : createCommentVNode("", true),
|
|
192
|
+
stats.value.molecularWeight !== void 0 ? (openBlock(), createElementBlock("span", _hoisted_17, [
|
|
193
|
+
_cache[4] || (_cache[4] = createElementVNode("span", { class: "mld-sequence-input__stat-label" }, "MW:", -1)),
|
|
194
|
+
createElementVNode("span", _hoisted_18, "~" + toDisplayString((stats.value.molecularWeight / 1e3).toFixed(1)) + " kDa", 1)
|
|
195
|
+
])) : createCommentVNode("", true)
|
|
196
|
+
])) : createCommentVNode("", true)
|
|
197
|
+
], 2);
|
|
198
|
+
};
|
|
199
|
+
}
|
|
200
|
+
});
|
|
201
|
+
export {
|
|
202
|
+
_sfc_main as default
|
|
203
|
+
};
|
|
204
|
+
//# sourceMappingURL=SequenceInput.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceInput.vue.js","sources":["../../src/components/SequenceInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { useSequenceUtils, type SequenceType, type SequenceStats } from '../composables/useSequenceUtils'\n\ninterface Props {\n modelValue?: string\n type?: SequenceType\n readonly?: boolean\n showStats?: boolean\n showTools?: boolean\n maxLength?: number\n placeholder?: string\n rows?: number\n error?: boolean\n disabled?: boolean\n}\n\nconst props = withDefaults(defineProps<Props>(), {\n modelValue: '',\n type: 'auto',\n readonly: false,\n showStats: true,\n showTools: true,\n rows: 6,\n placeholder: 'Paste or type sequence...',\n error: false,\n disabled: false,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\ndefineSlots<{\n tools?(props: { sequence: string; type: 'dna' | 'rna' | 'protein'; stats: SequenceStats }): unknown\n}>()\n\nconst { detectSequenceType, validateSequence, reverseComplement, calculateStats, formatFasta } = useSequenceUtils()\n\nconst resolvedType = computed<'dna' | 'rna' | 'protein'>(() => {\n if (props.type !== 'auto') return props.type as 'dna' | 'rna' | 'protein'\n if (!props.modelValue) return 'dna'\n return detectSequenceType(props.modelValue)\n})\n\nconst stats = computed<SequenceStats>(() => {\n if (!props.modelValue) return { length: 0 }\n return calculateStats(props.modelValue, resolvedType.value)\n})\n\nconst viewerLines = computed(() => {\n if (!props.modelValue) return []\n const formatted = formatFasta(props.modelValue, 60)\n return formatted.split('\\n').filter(l => l.length > 0)\n})\n\nfunction handleInput(event: Event) {\n const target = event.target as HTMLTextAreaElement\n let value = target.value\n\n if (props.maxLength && value.length > props.maxLength) {\n value = value.slice(0, props.maxLength)\n }\n\n // Validate characters\n value = validateSequence(value, resolvedType.value)\n emit('update:modelValue', value)\n}\n\nfunction doReverseComplement() {\n if (!props.modelValue || resolvedType.value === 'protein') return\n emit('update:modelValue', reverseComplement(props.modelValue, resolvedType.value as 'dna' | 'rna'))\n}\n\nfunction doUppercase() {\n if (!props.modelValue) return\n emit('update:modelValue', props.modelValue.toUpperCase())\n}\n\nfunction doClear() {\n emit('update:modelValue', '')\n}\n\nfunction doCopy() {\n if (!props.modelValue) return\n navigator.clipboard.writeText(props.modelValue)\n}\n\nfunction getBaseClass(char: string): string {\n const c = char.toLowerCase()\n if (c === 'a') return 'mld-sequence-input__base--a'\n if (c === 't') return 'mld-sequence-input__base--t'\n if (c === 'u') return 'mld-sequence-input__base--u'\n if (c === 'g') return 'mld-sequence-input__base--g'\n if (c === 'c') return 'mld-sequence-input__base--c'\n if (c === 'n') return 'mld-sequence-input__base--n'\n return ''\n}\n</script>\n\n<template>\n <div\n :class=\"[\n 'mld-sequence-input',\n error ? 'mld-sequence-input--error' : '',\n disabled ? 'mld-sequence-input--disabled' : '',\n ]\"\n >\n <!-- Toolbar -->\n <div v-if=\"showTools && !readonly\" class=\"mld-sequence-input__toolbar\">\n <slot name=\"tools\" :sequence=\"modelValue || ''\" :type=\"resolvedType\" :stats=\"stats\">\n <button\n v-if=\"resolvedType !== 'protein'\"\n type=\"button\"\n class=\"mld-sequence-input__tool-btn\"\n :disabled=\"!modelValue || disabled\"\n @click=\"doReverseComplement\"\n >\n Rev Comp\n </button>\n <button\n type=\"button\"\n class=\"mld-sequence-input__tool-btn\"\n :disabled=\"!modelValue || disabled\"\n @click=\"doUppercase\"\n >\n Uppercase\n </button>\n <div class=\"mld-sequence-input__tool-sep\" />\n <button\n type=\"button\"\n class=\"mld-sequence-input__tool-btn\"\n :disabled=\"!modelValue || disabled\"\n @click=\"doCopy\"\n >\n Copy\n </button>\n <button\n type=\"button\"\n class=\"mld-sequence-input__tool-btn\"\n :disabled=\"!modelValue || disabled\"\n @click=\"doClear\"\n >\n Clear\n </button>\n </slot>\n\n <span class=\"mld-sequence-input__type-badge\">{{ resolvedType }}</span>\n </div>\n\n <!-- Editor (input mode) -->\n <div v-if=\"!readonly\" class=\"mld-sequence-input__editor\">\n <textarea\n :value=\"modelValue\"\n :rows=\"rows\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :maxlength=\"maxLength\"\n class=\"mld-sequence-input__textarea\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n @input=\"handleInput\"\n />\n </div>\n\n <!-- Viewer (readonly mode) -->\n <div v-else class=\"mld-sequence-input__viewer\">\n <div\n v-for=\"(line, lineIdx) in viewerLines\"\n :key=\"lineIdx\"\n class=\"mld-sequence-input__viewer-line\"\n >\n <span class=\"mld-sequence-input__line-number\">{{ lineIdx * 60 + 1 }}</span>\n <span class=\"mld-sequence-input__line-content\">\n <span\n v-for=\"(char, charIdx) in line.split('')\"\n :key=\"charIdx\"\n :class=\"getBaseClass(char)\"\n >{{ char }}</span>\n </span>\n </div>\n <div v-if=\"!modelValue\" class=\"mld-sequence-input__viewer-line\">\n <span class=\"mld-sequence-input__line-number\" />\n <span class=\"mld-sequence-input__line-content\" style=\"color: var(--text-muted);\">No sequence</span>\n </div>\n </div>\n\n <!-- Stats -->\n <div v-if=\"showStats && modelValue\" class=\"mld-sequence-input__stats\">\n <span>\n <span class=\"mld-sequence-input__stat-label\">Length:</span>\n <span class=\"mld-sequence-input__stat-value\">{{ stats.length }}</span>\n </span>\n <span v-if=\"stats.gcPercent !== undefined\">\n <span class=\"mld-sequence-input__stat-label\">GC:</span>\n <span class=\"mld-sequence-input__stat-value\">{{ stats.gcPercent.toFixed(1) }}%</span>\n </span>\n <span v-if=\"stats.molecularWeight !== undefined\">\n <span class=\"mld-sequence-input__stat-label\">MW:</span>\n <span class=\"mld-sequence-input__stat-value\">~{{ (stats.molecularWeight / 1000).toFixed(1) }} kDa</span>\n </span>\n </div>\n </div>\n</template>\n\n<style>\n@import '../styles/components/sequence-input.css';\n</style>\n"],"names":["_createElementBlock","_normalizeClass","_openBlock","_renderSlot","_createElementVNode","_toDisplayString","_Fragment","_renderList"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SequenceInput.vue3.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|