@morscherlab/mint-sdk 1.0.0-alpha.8 → 1.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (217) hide show
  1. package/README.md +15 -15
  2. package/dist/{auth-BYmxZdJl.js → auth-DsI0rQ7_.js} +6 -6
  3. package/dist/auth-DsI0rQ7_.js.map +1 -0
  4. package/dist/components/index.js +2 -2
  5. package/dist/{components-CKf-UpGi.js → components-CzbQQPCb.js} +1429 -1429
  6. package/dist/components-CzbQQPCb.js.map +1 -0
  7. package/dist/composables/index.js +2 -2
  8. package/dist/composables/usePlatformContext.d.ts +3 -3
  9. package/dist/{composables-D0QfFzq1.js → composables-BXklV5ii.js} +3 -3
  10. package/dist/{composables-D0QfFzq1.js.map → composables-BXklV5ii.js.map} +1 -1
  11. package/dist/index.js +4 -4
  12. package/dist/install.d.ts +3 -3
  13. package/dist/install.js +5 -5
  14. package/dist/install.js.map +1 -1
  15. package/dist/stores/auth.d.ts +1 -1
  16. package/dist/stores/index.js +1 -1
  17. package/dist/stores/settings.d.ts +1 -1
  18. package/dist/styles.css +5388 -5388
  19. package/dist/types/platform.d.ts +1 -1
  20. package/dist/{useScheduleDrag-DAJueTbK.js → useScheduleDrag-CxBeqYcu.js} +331 -331
  21. package/dist/useScheduleDrag-CxBeqYcu.js.map +1 -0
  22. package/package.json +2 -2
  23. package/src/__tests__/components/AppLayout.test.ts +23 -23
  24. package/src/__tests__/components/AppSidebar.test.ts +29 -29
  25. package/src/__tests__/components/AppTopBar.test.ts +45 -45
  26. package/src/__tests__/components/BaseInput.test.ts +2 -2
  27. package/src/__tests__/components/BasePill.test.ts +37 -37
  28. package/src/__tests__/components/Calendar.test.ts +52 -52
  29. package/src/__tests__/components/CollapsibleCard.test.ts +81 -81
  30. package/src/__tests__/components/DataFrame.test.ts +80 -80
  31. package/src/__tests__/components/DropdownButton.test.ts +80 -80
  32. package/src/__tests__/composables/usePlatformContext.test.ts +1 -1
  33. package/src/components/AlertBox.story.vue +1 -1
  34. package/src/components/AlertBox.vue +14 -14
  35. package/src/components/AppAvatarMenu.vue +26 -26
  36. package/src/components/AppContainer.vue +3 -3
  37. package/src/components/AppLayout.vue +7 -7
  38. package/src/components/AppPageSelector.vue +30 -30
  39. package/src/components/AppPillNav.vue +10 -10
  40. package/src/components/AppPluginSwitcher.vue +31 -31
  41. package/src/components/AppSidebar.vue +8 -8
  42. package/src/components/AppTopBar.story.vue +7 -7
  43. package/src/components/AppTopBar.vue +102 -102
  44. package/src/components/AuditTrail.vue +19 -19
  45. package/src/components/AutoGroupModal.vue +76 -76
  46. package/src/components/Avatar.vue +6 -6
  47. package/src/components/BaseButton.vue +6 -6
  48. package/src/components/BaseCheckbox.vue +9 -9
  49. package/src/components/BaseInput.vue +4 -4
  50. package/src/components/BaseModal.story.vue +1 -1
  51. package/src/components/BaseModal.vue +14 -14
  52. package/src/components/BasePill.vue +9 -9
  53. package/src/components/BaseRadioGroup.vue +21 -21
  54. package/src/components/BaseSelect.vue +6 -6
  55. package/src/components/BaseSlider.vue +8 -8
  56. package/src/components/BaseTabs.vue +7 -7
  57. package/src/components/BaseTextarea.vue +5 -5
  58. package/src/components/BaseToggle.vue +10 -10
  59. package/src/components/BatchProgressList.vue +25 -25
  60. package/src/components/Breadcrumb.vue +8 -8
  61. package/src/components/Calendar.vue +19 -19
  62. package/src/components/ChartContainer.vue +9 -9
  63. package/src/components/ChemicalFormula.vue +7 -7
  64. package/src/components/CollapsibleCard.vue +20 -20
  65. package/src/components/ColorSlider.vue +6 -6
  66. package/src/components/ConcentrationInput.vue +12 -12
  67. package/src/components/ConfirmDialog.story.vue +1 -1
  68. package/src/components/ConfirmDialog.vue +7 -7
  69. package/src/components/DataFrame.vue +40 -40
  70. package/src/components/DatePicker.vue +29 -29
  71. package/src/components/DateTimePicker.vue +41 -41
  72. package/src/components/Divider.vue +9 -9
  73. package/src/components/DoseCalculator.vue +66 -66
  74. package/src/components/DropdownButton.vue +19 -19
  75. package/src/components/EmptyState.vue +9 -9
  76. package/src/components/ExperimentCodeBadge.vue +3 -3
  77. package/src/components/ExperimentDataViewer.vue +25 -25
  78. package/src/components/ExperimentPopover.vue +35 -35
  79. package/src/components/ExperimentSelectorModal.vue +40 -40
  80. package/src/components/ExperimentTimeline.vue +48 -48
  81. package/src/components/FileUploader.vue +31 -31
  82. package/src/components/FitPanel.vue +9 -9
  83. package/src/components/FormActions.vue +1 -1
  84. package/src/components/FormBuilder.vue +2 -2
  85. package/src/components/FormField.vue +7 -7
  86. package/src/components/FormSection.vue +7 -7
  87. package/src/components/FormulaInput.vue +10 -10
  88. package/src/components/GroupAssigner.vue +40 -40
  89. package/src/components/GroupingModal.vue +45 -45
  90. package/src/components/IconButton.vue +6 -6
  91. package/src/components/LoadingSpinner.vue +5 -5
  92. package/src/components/MoleculeInput.vue +21 -21
  93. package/src/components/MultiSelect.vue +13 -13
  94. package/src/components/NumberInput.vue +13 -13
  95. package/src/components/PlateMapEditor.vue +63 -63
  96. package/src/components/ProgressBar.vue +18 -18
  97. package/src/components/ProtocolStepEditor.vue +57 -57
  98. package/src/components/RackEditor.vue +28 -28
  99. package/src/components/ReagentEditor.vue +61 -61
  100. package/src/components/ReagentList.vue +49 -49
  101. package/src/components/ResourceCard.vue +28 -28
  102. package/src/components/SampleHierarchyTree.vue +13 -13
  103. package/src/components/SampleLegend.vue +12 -12
  104. package/src/components/SampleSelector.vue +104 -104
  105. package/src/components/ScheduleCalendar.vue +42 -42
  106. package/src/components/ScientificNumber.vue +11 -11
  107. package/src/components/SegmentedControl.vue +12 -12
  108. package/src/components/SequenceInput.vue +32 -32
  109. package/src/components/SettingsButton.vue +5 -5
  110. package/src/components/SettingsModal.vue +17 -17
  111. package/src/components/StatusIndicator.vue +5 -5
  112. package/src/components/StepWizard.vue +16 -16
  113. package/src/components/TagsInput.vue +20 -20
  114. package/src/components/ThemeToggle.vue +3 -3
  115. package/src/components/TimePicker.vue +21 -21
  116. package/src/components/TimeRangeInput.vue +5 -5
  117. package/src/components/ToastNotification.vue +8 -8
  118. package/src/components/Tooltip.vue +7 -7
  119. package/src/components/UnitInput.vue +12 -12
  120. package/src/components/WellEditPopup.vue +28 -28
  121. package/src/components/WellPlate.vue +37 -37
  122. package/src/composables/useAppExperiment.ts +1 -1
  123. package/src/composables/usePlatformContext.ts +16 -16
  124. package/src/composables/useProtocolTemplates.ts +1 -1
  125. package/src/install.ts +3 -3
  126. package/src/stores/auth.ts +3 -3
  127. package/src/stores/settings.ts +2 -2
  128. package/src/styles/components/alert-box.css +30 -30
  129. package/src/styles/components/app-avatar-menu.css +23 -23
  130. package/src/styles/components/app-container.css +6 -6
  131. package/src/styles/components/app-layout.css +15 -15
  132. package/src/styles/components/app-page-selector.css +26 -26
  133. package/src/styles/components/app-pill-nav.css +7 -7
  134. package/src/styles/components/app-plugin-switcher.css +27 -27
  135. package/src/styles/components/app-sidebar.css +24 -24
  136. package/src/styles/components/app-top-bar.css +65 -65
  137. package/src/styles/components/audit-trail.css +29 -29
  138. package/src/styles/components/auto-group-modal.css +91 -91
  139. package/src/styles/components/avatar.css +15 -15
  140. package/src/styles/components/batch-progress-list.css +40 -40
  141. package/src/styles/components/breadcrumb.css +8 -8
  142. package/src/styles/components/button.css +31 -31
  143. package/src/styles/components/calendar.css +27 -27
  144. package/src/styles/components/chart-container.css +9 -9
  145. package/src/styles/components/checkbox.css +20 -20
  146. package/src/styles/components/chemical-formula.css +8 -8
  147. package/src/styles/components/collapsible-card.css +35 -35
  148. package/src/styles/components/color-slider.css +8 -8
  149. package/src/styles/components/concentration-input.css +27 -27
  150. package/src/styles/components/confirm-dialog.css +32 -32
  151. package/src/styles/components/dataframe.css +66 -66
  152. package/src/styles/components/date-picker.css +40 -40
  153. package/src/styles/components/datetime-picker.css +37 -37
  154. package/src/styles/components/divider.css +13 -13
  155. package/src/styles/components/dose-calculator.css +43 -43
  156. package/src/styles/components/dropdown-button.css +46 -46
  157. package/src/styles/components/empty-state.css +44 -44
  158. package/src/styles/components/experiment-code-badge.css +8 -8
  159. package/src/styles/components/experiment-data-viewer.css +23 -23
  160. package/src/styles/components/experiment-popover.css +97 -97
  161. package/src/styles/components/experiment-selector-modal.css +39 -39
  162. package/src/styles/components/experiment-timeline.css +98 -98
  163. package/src/styles/components/file-uploader.css +44 -44
  164. package/src/styles/components/fit-panel.css +12 -12
  165. package/src/styles/components/form-builder.css +11 -11
  166. package/src/styles/components/form-field.css +7 -7
  167. package/src/styles/components/formula-input.css +17 -17
  168. package/src/styles/components/group-assigner.css +26 -26
  169. package/src/styles/components/grouping-modal.css +51 -51
  170. package/src/styles/components/icon-button.css +41 -41
  171. package/src/styles/components/input.css +13 -13
  172. package/src/styles/components/loading-spinner.css +12 -12
  173. package/src/styles/components/modal.css +69 -69
  174. package/src/styles/components/molecule-input.css +27 -27
  175. package/src/styles/components/multi-select.css +23 -23
  176. package/src/styles/components/number-input.css +32 -32
  177. package/src/styles/components/pill.css +37 -37
  178. package/src/styles/components/plate-map-editor.css +67 -67
  179. package/src/styles/components/progress-bar.css +41 -41
  180. package/src/styles/components/protocol-step-editor.css +63 -63
  181. package/src/styles/components/rack-editor.css +34 -34
  182. package/src/styles/components/radio-group.css +41 -41
  183. package/src/styles/components/reagent-editor.css +70 -70
  184. package/src/styles/components/reagent-list.css +65 -65
  185. package/src/styles/components/resource-card.css +52 -52
  186. package/src/styles/components/sample-hierarchy-tree.css +56 -56
  187. package/src/styles/components/sample-legend.css +37 -37
  188. package/src/styles/components/sample-selector.css +121 -121
  189. package/src/styles/components/schedule-calendar.css +67 -67
  190. package/src/styles/components/scientific-number.css +11 -11
  191. package/src/styles/components/segmented-control.css +33 -33
  192. package/src/styles/components/select.css +11 -11
  193. package/src/styles/components/sequence-input.css +29 -29
  194. package/src/styles/components/settings-button.css +16 -16
  195. package/src/styles/components/settings-modal.css +14 -14
  196. package/src/styles/components/skeleton.css +2 -2
  197. package/src/styles/components/slider.css +10 -10
  198. package/src/styles/components/status-indicator.css +12 -12
  199. package/src/styles/components/step-wizard.css +32 -32
  200. package/src/styles/components/tabs.css +16 -16
  201. package/src/styles/components/tags-input.css +46 -46
  202. package/src/styles/components/textarea.css +17 -17
  203. package/src/styles/components/theme-toggle.css +13 -13
  204. package/src/styles/components/time-picker.css +28 -28
  205. package/src/styles/components/time-range-input.css +8 -8
  206. package/src/styles/components/toast.css +18 -18
  207. package/src/styles/components/toggle.css +27 -27
  208. package/src/styles/components/tooltip.css +18 -18
  209. package/src/styles/components/unit-input.css +25 -25
  210. package/src/styles/components/well-edit-popup.css +32 -32
  211. package/src/styles/components/well-plate.css +49 -49
  212. package/src/styles/index.css +1 -1
  213. package/src/styles/variables.css +3 -3
  214. package/src/types/platform.ts +6 -6
  215. package/dist/auth-BYmxZdJl.js.map +0 -1
  216. package/dist/components-CKf-UpGi.js.map +0 -1
  217. package/dist/useScheduleDrag-DAJueTbK.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  /* BasePill Component Styles */
2
2
 
3
- .mld-pill {
3
+ .mint-pill {
4
4
  display: inline-flex;
5
5
  align-items: center;
6
6
  gap: 0.25rem;
@@ -13,70 +13,70 @@
13
13
  }
14
14
 
15
15
  /* Sizes */
16
- .mld-pill--sm {
16
+ .mint-pill--sm {
17
17
  padding: 0.125rem 0.5rem;
18
18
  font-size: 0.6875rem;
19
19
  }
20
20
 
21
- .mld-pill--md {
21
+ .mint-pill--md {
22
22
  padding: 0.25rem 0.625rem;
23
23
  font-size: 0.75rem;
24
24
  }
25
25
 
26
- .mld-pill--lg {
26
+ .mint-pill--lg {
27
27
  padding: 0.375rem 0.75rem;
28
28
  font-size: 0.8125rem;
29
29
  }
30
30
 
31
31
  /* Variants */
32
- .mld-pill--default,
33
- .mld-pill--neutral {
32
+ .mint-pill--default,
33
+ .mint-pill--neutral {
34
34
  background-color: var(--bg-tertiary);
35
35
  color: var(--text-secondary);
36
36
  }
37
37
 
38
- .mld-pill--primary {
38
+ .mint-pill--primary {
39
39
  background-color: rgba(59, 130, 246, 0.1);
40
40
  color: var(--color-primary);
41
41
  }
42
42
 
43
- html.dark .mld-pill--primary {
43
+ html.dark .mint-pill--primary {
44
44
  background-color: rgba(59, 130, 246, 0.2);
45
45
  }
46
46
 
47
- .mld-pill--success {
47
+ .mint-pill--success {
48
48
  background-color: rgba(16, 185, 129, 0.1);
49
49
  color: var(--mint-success);
50
50
  }
51
51
 
52
- html.dark .mld-pill--success {
52
+ html.dark .mint-pill--success {
53
53
  background-color: rgba(16, 185, 129, 0.2);
54
54
  }
55
55
 
56
- .mld-pill--warning {
56
+ .mint-pill--warning {
57
57
  background-color: rgba(245, 158, 11, 0.1);
58
58
  color: var(--mint-warning);
59
59
  }
60
60
 
61
- html.dark .mld-pill--warning {
61
+ html.dark .mint-pill--warning {
62
62
  background-color: rgba(245, 158, 11, 0.2);
63
63
  }
64
64
 
65
- .mld-pill--error {
65
+ .mint-pill--error {
66
66
  background-color: rgba(239, 68, 68, 0.1);
67
67
  color: var(--mint-error);
68
68
  }
69
69
 
70
- html.dark .mld-pill--error {
70
+ html.dark .mint-pill--error {
71
71
  background-color: rgba(239, 68, 68, 0.2);
72
72
  }
73
73
 
74
- .mld-pill--info {
74
+ .mint-pill--info {
75
75
  background-color: rgba(59, 130, 246, 0.1);
76
76
  color: var(--mint-info);
77
77
  }
78
78
 
79
- html.dark .mld-pill--info {
79
+ html.dark .mint-pill--info {
80
80
  background-color: rgba(59, 130, 246, 0.2);
81
81
  }
82
82
 
@@ -88,61 +88,61 @@ html.dark .mld-pill--info {
88
88
  clash.
89
89
  ======================================================================== */
90
90
 
91
- .mld-pill--outline {
91
+ .mint-pill--outline {
92
92
  background-color: transparent;
93
93
  border: 1px solid var(--border-color);
94
94
  color: var(--text-secondary);
95
95
  }
96
96
 
97
- .mld-pill--outline.mld-pill--neutral { border-color: var(--text-muted); color: var(--text-primary); }
98
- .mld-pill--outline.mld-pill--primary { border-color: var(--color-primary); color: var(--color-primary); }
99
- .mld-pill--outline.mld-pill--success { border-color: var(--mint-success); color: var(--mint-success); }
97
+ .mint-pill--outline.mint-pill--neutral { border-color: var(--text-muted); color: var(--text-primary); }
98
+ .mint-pill--outline.mint-pill--primary { border-color: var(--color-primary); color: var(--color-primary); }
99
+ .mint-pill--outline.mint-pill--success { border-color: var(--mint-success); color: var(--mint-success); }
100
100
  /* Warning text uses -hover (darker) so AA contrast holds on white; border uses the lighter primary warning tone. */
101
- .mld-pill--outline.mld-pill--warning { border-color: var(--mint-warning); color: var(--mint-warning-hover); }
102
- .mld-pill--outline.mld-pill--error { border-color: var(--mint-error); color: var(--mint-error); }
103
- .mld-pill--outline.mld-pill--info { border-color: var(--mint-info); color: var(--mint-info); }
101
+ .mint-pill--outline.mint-pill--warning { border-color: var(--mint-warning); color: var(--mint-warning-hover); }
102
+ .mint-pill--outline.mint-pill--error { border-color: var(--mint-error); color: var(--mint-error); }
103
+ .mint-pill--outline.mint-pill--info { border-color: var(--mint-info); color: var(--mint-info); }
104
104
 
105
105
  /* Disabled */
106
- .mld-pill--disabled {
106
+ .mint-pill--disabled {
107
107
  opacity: var(--mint-disabled-opacity);
108
108
  cursor: default;
109
109
  }
110
110
 
111
111
  /* Icon slot */
112
- .mld-pill__icon {
112
+ .mint-pill__icon {
113
113
  display: inline-flex;
114
114
  align-items: center;
115
115
  flex-shrink: 0;
116
116
  }
117
117
 
118
- .mld-pill--sm .mld-pill__icon {
118
+ .mint-pill--sm .mint-pill__icon {
119
119
  width: 0.75rem;
120
120
  height: 0.75rem;
121
121
  }
122
122
 
123
- .mld-pill--md .mld-pill__icon {
123
+ .mint-pill--md .mint-pill__icon {
124
124
  width: 0.875rem;
125
125
  height: 0.875rem;
126
126
  }
127
127
 
128
- .mld-pill--lg .mld-pill__icon {
128
+ .mint-pill--lg .mint-pill__icon {
129
129
  width: 1rem;
130
130
  height: 1rem;
131
131
  }
132
132
 
133
- .mld-pill__icon > svg {
133
+ .mint-pill__icon > svg {
134
134
  width: 100%;
135
135
  height: 100%;
136
136
  }
137
137
 
138
138
  /* Label */
139
- .mld-pill__label {
139
+ .mint-pill__label {
140
140
  display: inline-flex;
141
141
  align-items: center;
142
142
  }
143
143
 
144
144
  /* Remove button */
145
- .mld-pill__remove {
145
+ .mint-pill__remove {
146
146
  display: inline-flex;
147
147
  align-items: center;
148
148
  justify-content: center;
@@ -158,31 +158,31 @@ html.dark .mld-pill--info {
158
158
  transition: opacity 0.15s ease, background-color 0.15s ease;
159
159
  }
160
160
 
161
- .mld-pill__remove:hover {
161
+ .mint-pill__remove:hover {
162
162
  opacity: 1;
163
163
  background-color: rgba(0, 0, 0, 0.1);
164
164
  }
165
165
 
166
- html.dark .mld-pill__remove:hover {
166
+ html.dark .mint-pill__remove:hover {
167
167
  background-color: rgba(255, 255, 255, 0.1);
168
168
  }
169
169
 
170
- .mld-pill__remove:focus-visible {
170
+ .mint-pill__remove:focus-visible {
171
171
  outline: none;
172
172
  box-shadow: var(--focus-ring);
173
173
  }
174
174
 
175
- .mld-pill__remove-icon {
175
+ .mint-pill__remove-icon {
176
176
  width: 0.75rem;
177
177
  height: 0.75rem;
178
178
  }
179
179
 
180
- .mld-pill--sm .mld-pill__remove-icon {
180
+ .mint-pill--sm .mint-pill__remove-icon {
181
181
  width: 0.625rem;
182
182
  height: 0.625rem;
183
183
  }
184
184
 
185
- .mld-pill--lg .mld-pill__remove-icon {
185
+ .mint-pill--lg .mint-pill__remove-icon {
186
186
  width: 0.875rem;
187
187
  height: 0.875rem;
188
188
  }
@@ -1,21 +1,21 @@
1
1
  /* PlateMapEditor Component Styles */
2
2
 
3
- .mld-plate-editor {
3
+ .mint-plate-editor {
4
4
  display: flex;
5
5
  }
6
6
 
7
- .mld-plate-editor--with-sidebar {
7
+ .mint-plate-editor--with-sidebar {
8
8
  gap: 1rem;
9
9
  }
10
10
 
11
11
  /* Main plate area */
12
- .mld-plate-editor__main {
12
+ .mint-plate-editor__main {
13
13
  flex: 1;
14
14
  min-width: 0;
15
15
  }
16
16
 
17
17
  /* Toolbar */
18
- .mld-plate-editor__toolbar {
18
+ .mint-plate-editor__toolbar {
19
19
  display: flex;
20
20
  flex-wrap: wrap;
21
21
  align-items: center;
@@ -28,14 +28,14 @@
28
28
  }
29
29
 
30
30
  /* Plate tabs */
31
- .mld-plate-editor__tabs {
31
+ .mint-plate-editor__tabs {
32
32
  display: flex;
33
33
  align-items: center;
34
34
  gap: 0.25rem;
35
35
  flex-wrap: wrap;
36
36
  }
37
37
 
38
- .mld-plate-editor__tab {
38
+ .mint-plate-editor__tab {
39
39
  position: relative;
40
40
  display: flex;
41
41
  align-items: center;
@@ -50,24 +50,24 @@
50
50
  transition: all 0.2s ease;
51
51
  }
52
52
 
53
- .mld-plate-editor__tab--active {
53
+ .mint-plate-editor__tab--active {
54
54
  background-color: var(--color-primary);
55
55
  color: white;
56
56
  border-color: transparent;
57
57
  }
58
58
 
59
- .mld-plate-editor__tab-slot {
59
+ .mint-plate-editor__tab-slot {
60
60
  width: 0.625rem;
61
61
  height: 0.625rem;
62
62
  border-radius: 9999px;
63
63
  flex-shrink: 0;
64
64
  }
65
65
 
66
- .mld-plate-editor__tab-name {
66
+ .mint-plate-editor__tab-name {
67
67
  font-weight: 500;
68
68
  }
69
69
 
70
- .mld-plate-editor__tab-count {
70
+ .mint-plate-editor__tab-count {
71
71
  padding: 0 0.375rem;
72
72
  min-width: 1.25rem;
73
73
  text-align: center;
@@ -78,12 +78,12 @@
78
78
  color: var(--text-muted);
79
79
  }
80
80
 
81
- .mld-plate-editor__tab--active .mld-plate-editor__tab-count {
81
+ .mint-plate-editor__tab--active .mint-plate-editor__tab-count {
82
82
  background-color: rgba(255, 255, 255, 0.2);
83
83
  color: white;
84
84
  }
85
85
 
86
- .mld-plate-editor__tab-remove {
86
+ .mint-plate-editor__tab-remove {
87
87
  opacity: 0;
88
88
  margin-left: 0.25rem;
89
89
  background: transparent;
@@ -93,21 +93,21 @@
93
93
  transition: opacity 0.15s ease;
94
94
  }
95
95
 
96
- .mld-plate-editor__tab:hover .mld-plate-editor__tab-remove {
96
+ .mint-plate-editor__tab:hover .mint-plate-editor__tab-remove {
97
97
  opacity: 1;
98
98
  }
99
99
 
100
- .mld-plate-editor__tab--active .mld-plate-editor__tab-remove {
100
+ .mint-plate-editor__tab--active .mint-plate-editor__tab-remove {
101
101
  color: rgba(255, 255, 255, 0.7);
102
102
  }
103
103
 
104
- .mld-plate-editor__tab-remove svg {
104
+ .mint-plate-editor__tab-remove svg {
105
105
  width: 0.875rem;
106
106
  height: 0.875rem;
107
107
  }
108
108
 
109
109
  /* Add plate button */
110
- .mld-plate-editor__add-plate {
110
+ .mint-plate-editor__add-plate {
111
111
  display: flex;
112
112
  align-items: center;
113
113
  gap: 0.25rem;
@@ -121,29 +121,29 @@
121
121
  transition: color 0.15s ease, border-color 0.15s ease;
122
122
  }
123
123
 
124
- .mld-plate-editor__add-plate:hover {
124
+ .mint-plate-editor__add-plate:hover {
125
125
  color: var(--color-primary);
126
126
  border-color: var(--color-primary);
127
127
  }
128
128
 
129
- .mld-plate-editor__add-plate svg {
129
+ .mint-plate-editor__add-plate svg {
130
130
  width: 1rem;
131
131
  height: 1rem;
132
132
  }
133
133
 
134
134
  /* Toolbar spacer */
135
- .mld-plate-editor__spacer {
135
+ .mint-plate-editor__spacer {
136
136
  flex: 1;
137
137
  }
138
138
 
139
139
  /* Toolbar actions */
140
- .mld-plate-editor__actions {
140
+ .mint-plate-editor__actions {
141
141
  display: flex;
142
142
  align-items: center;
143
143
  gap: 0.25rem;
144
144
  }
145
145
 
146
- .mld-plate-editor__action-btn {
146
+ .mint-plate-editor__action-btn {
147
147
  padding: 0.375rem;
148
148
  border-radius: var(--radius-sm);
149
149
  background: transparent;
@@ -153,21 +153,21 @@
153
153
  transition: background-color 0.15s ease, color 0.15s ease;
154
154
  }
155
155
 
156
- .mld-plate-editor__action-btn:hover {
156
+ .mint-plate-editor__action-btn:hover {
157
157
  background-color: rgba(128, 128, 128, 0.1);
158
158
  }
159
159
 
160
- .mld-plate-editor__action-btn:disabled {
160
+ .mint-plate-editor__action-btn:disabled {
161
161
  opacity: 0.4;
162
162
  cursor: not-allowed;
163
163
  }
164
164
 
165
- .mld-plate-editor__action-btn svg {
165
+ .mint-plate-editor__action-btn svg {
166
166
  width: 1rem;
167
167
  height: 1rem;
168
168
  }
169
169
 
170
- .mld-plate-editor__divider {
170
+ .mint-plate-editor__divider {
171
171
  width: 1px;
172
172
  height: 1rem;
173
173
  margin: 0 0.25rem;
@@ -175,7 +175,7 @@
175
175
  }
176
176
 
177
177
  /* Selection info bar */
178
- .mld-plate-editor__selection-bar {
178
+ .mint-plate-editor__selection-bar {
179
179
  margin-top: 0.75rem;
180
180
  display: flex;
181
181
  align-items: center;
@@ -187,15 +187,15 @@
187
187
  border: 1px solid var(--border-color);
188
188
  }
189
189
 
190
- .mld-plate-editor__selection-count {
190
+ .mint-plate-editor__selection-count {
191
191
  color: var(--text-secondary);
192
192
  }
193
193
 
194
- .mld-plate-editor__selection-count strong {
194
+ .mint-plate-editor__selection-count strong {
195
195
  font-weight: 600;
196
196
  }
197
197
 
198
- .mld-plate-editor__assign-btn {
198
+ .mint-plate-editor__assign-btn {
199
199
  padding: 0.25rem 0.75rem;
200
200
  font-size: 0.875rem;
201
201
  font-weight: 500;
@@ -207,11 +207,11 @@
207
207
  transition: background-color 0.15s ease;
208
208
  }
209
209
 
210
- .mld-plate-editor__assign-btn:hover {
210
+ .mint-plate-editor__assign-btn:hover {
211
211
  opacity: 0.9;
212
212
  }
213
213
 
214
- .mld-plate-editor__clear-btn {
214
+ .mint-plate-editor__clear-btn {
215
215
  padding: 0.25rem 0.75rem;
216
216
  font-size: 0.875rem;
217
217
  font-weight: 500;
@@ -223,12 +223,12 @@
223
223
  transition: background-color 0.15s ease;
224
224
  }
225
225
 
226
- .mld-plate-editor__clear-btn:hover {
226
+ .mint-plate-editor__clear-btn:hover {
227
227
  background-color: rgba(239, 68, 68, 0.1);
228
228
  }
229
229
 
230
230
  /* Legend */
231
- .mld-plate-editor__legend {
231
+ .mint-plate-editor__legend {
232
232
  margin-top: 0.75rem;
233
233
  display: flex;
234
234
  align-items: center;
@@ -236,30 +236,30 @@
236
236
  padding: 0 0.25rem;
237
237
  }
238
238
 
239
- .mld-plate-editor__legend-items {
239
+ .mint-plate-editor__legend-items {
240
240
  display: flex;
241
241
  align-items: center;
242
242
  gap: 1rem;
243
243
  }
244
244
 
245
- .mld-plate-editor__legend-item {
245
+ .mint-plate-editor__legend-item {
246
246
  display: flex;
247
247
  align-items: center;
248
248
  gap: 0.375rem;
249
249
  }
250
250
 
251
- .mld-plate-editor__legend-swatch {
251
+ .mint-plate-editor__legend-swatch {
252
252
  width: 0.875rem;
253
253
  height: 0.875rem;
254
254
  border-radius: var(--radius-sm);
255
255
  }
256
256
 
257
- .mld-plate-editor__legend-label {
257
+ .mint-plate-editor__legend-label {
258
258
  font-size: 0.75rem;
259
259
  color: var(--text-muted);
260
260
  }
261
261
 
262
- .mld-plate-editor__legend-hint {
262
+ .mint-plate-editor__legend-hint {
263
263
  font-size: 0.75rem;
264
264
  color: var(--text-muted);
265
265
  display: flex;
@@ -267,25 +267,25 @@
267
267
  gap: 0.375rem;
268
268
  }
269
269
 
270
- .mld-plate-editor__legend-hint svg {
270
+ .mint-plate-editor__legend-hint svg {
271
271
  width: 0.875rem;
272
272
  height: 0.875rem;
273
273
  }
274
274
 
275
275
  /* Sidebar */
276
- .mld-plate-editor__sidebar {
276
+ .mint-plate-editor__sidebar {
277
277
  width: 13rem;
278
278
  flex-shrink: 0;
279
279
  }
280
280
 
281
- .mld-plate-editor__sidebar-panel {
281
+ .mint-plate-editor__sidebar-panel {
282
282
  border-radius: var(--radius-md);
283
283
  padding: 0.75rem;
284
284
  background-color: var(--bg-secondary);
285
285
  border: 1px solid var(--border-color);
286
286
  }
287
287
 
288
- .mld-plate-editor__sidebar-title {
288
+ .mint-plate-editor__sidebar-title {
289
289
  font-size: 0.875rem;
290
290
  font-weight: 500;
291
291
  margin-bottom: 0.75rem;
@@ -293,18 +293,18 @@
293
293
  }
294
294
 
295
295
  /* Add sample form */
296
- .mld-plate-editor__add-sample {
296
+ .mint-plate-editor__add-sample {
297
297
  margin-top: 0.75rem;
298
298
  padding-top: 0.75rem;
299
299
  border-top: 1px solid var(--border-color);
300
300
  }
301
301
 
302
- .mld-plate-editor__add-sample-form {
302
+ .mint-plate-editor__add-sample-form {
303
303
  display: flex;
304
304
  gap: 0.5rem;
305
305
  }
306
306
 
307
- .mld-plate-editor__add-sample-input {
307
+ .mint-plate-editor__add-sample-input {
308
308
  flex: 1;
309
309
  padding: 0.25rem 0.5rem;
310
310
  font-size: 0.875rem;
@@ -314,12 +314,12 @@
314
314
  color: var(--text-primary);
315
315
  }
316
316
 
317
- .mld-plate-editor__add-sample-input:focus-visible {
317
+ .mint-plate-editor__add-sample-input:focus-visible {
318
318
  outline: none;
319
319
  box-shadow: 0 0 0 1px var(--color-primary);
320
320
  }
321
321
 
322
- .mld-plate-editor__add-sample-btn {
322
+ .mint-plate-editor__add-sample-btn {
323
323
  padding: 0.25rem 0.5rem;
324
324
  font-size: 0.875rem;
325
325
  font-weight: 500;
@@ -331,26 +331,26 @@
331
331
  transition: opacity 0.15s ease;
332
332
  }
333
333
 
334
- .mld-plate-editor__add-sample-btn:disabled {
334
+ .mint-plate-editor__add-sample-btn:disabled {
335
335
  opacity: 0.4;
336
336
  cursor: not-allowed;
337
337
  }
338
338
 
339
339
  /* Shortcuts */
340
- .mld-plate-editor__shortcuts {
340
+ .mint-plate-editor__shortcuts {
341
341
  margin-top: 1rem;
342
342
  padding-top: 0.75rem;
343
343
  border-top: 1px solid var(--border-color);
344
344
  }
345
345
 
346
- .mld-plate-editor__shortcuts-title {
346
+ .mint-plate-editor__shortcuts-title {
347
347
  font-size: 0.75rem;
348
348
  font-weight: 500;
349
349
  margin-bottom: 0.5rem;
350
350
  color: var(--text-muted);
351
351
  }
352
352
 
353
- .mld-plate-editor__shortcuts-list {
353
+ .mint-plate-editor__shortcuts-list {
354
354
  display: flex;
355
355
  flex-direction: column;
356
356
  gap: 0.25rem;
@@ -358,14 +358,14 @@
358
358
  color: var(--text-muted);
359
359
  }
360
360
 
361
- .mld-plate-editor__shortcut-key {
361
+ .mint-plate-editor__shortcut-key {
362
362
  padding: 0 0.25rem;
363
363
  border-radius: var(--radius-sm);
364
364
  background-color: var(--bg-primary);
365
365
  }
366
366
 
367
367
  /* Import modal */
368
- .mld-plate-editor__modal-overlay {
368
+ .mint-plate-editor__modal-overlay {
369
369
  position: fixed;
370
370
  inset: 0;
371
371
  background-color: rgba(0, 0, 0, 0.5);
@@ -375,7 +375,7 @@
375
375
  z-index: 50;
376
376
  }
377
377
 
378
- .mld-plate-editor__modal {
378
+ .mint-plate-editor__modal {
379
379
  width: 100%;
380
380
  max-width: 28rem;
381
381
  padding: 1rem;
@@ -385,26 +385,26 @@
385
385
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
386
386
  }
387
387
 
388
- .mld-plate-editor__modal-title {
388
+ .mint-plate-editor__modal-title {
389
389
  font-size: 1.125rem;
390
390
  font-weight: 500;
391
391
  margin-bottom: 0.75rem;
392
392
  color: var(--text-primary);
393
393
  }
394
394
 
395
- .mld-plate-editor__modal-field {
395
+ .mint-plate-editor__modal-field {
396
396
  margin-bottom: 0.75rem;
397
397
  }
398
398
 
399
- .mld-plate-editor__modal-label {
399
+ .mint-plate-editor__modal-label {
400
400
  display: block;
401
401
  font-size: 0.875rem;
402
402
  margin-bottom: 0.25rem;
403
403
  color: var(--text-secondary);
404
404
  }
405
405
 
406
- .mld-plate-editor__modal-select,
407
- .mld-plate-editor__modal-textarea {
406
+ .mint-plate-editor__modal-select,
407
+ .mint-plate-editor__modal-textarea {
408
408
  width: 100%;
409
409
  padding: 0.5rem 0.75rem;
410
410
  border-radius: var(--radius);
@@ -413,26 +413,26 @@
413
413
  color: var(--text-primary);
414
414
  }
415
415
 
416
- .mld-plate-editor__modal-select:focus-visible,
417
- .mld-plate-editor__modal-textarea:focus-visible {
416
+ .mint-plate-editor__modal-select:focus-visible,
417
+ .mint-plate-editor__modal-textarea:focus-visible {
418
418
  outline: none;
419
419
  box-shadow: 0 0 0 1px var(--color-primary);
420
420
  }
421
421
 
422
- .mld-plate-editor__modal-textarea {
422
+ .mint-plate-editor__modal-textarea {
423
423
  font-family: monospace;
424
424
  font-size: 0.875rem;
425
425
  resize: none;
426
426
  }
427
427
 
428
- .mld-plate-editor__modal-actions {
428
+ .mint-plate-editor__modal-actions {
429
429
  display: flex;
430
430
  justify-content: flex-end;
431
431
  gap: 0.5rem;
432
432
  margin-top: 1rem;
433
433
  }
434
434
 
435
- .mld-plate-editor__modal-cancel {
435
+ .mint-plate-editor__modal-cancel {
436
436
  padding: 0.5rem 1rem;
437
437
  font-size: 0.875rem;
438
438
  border-radius: var(--radius);
@@ -443,11 +443,11 @@
443
443
  transition: background-color 0.15s ease;
444
444
  }
445
445
 
446
- .mld-plate-editor__modal-cancel:hover {
446
+ .mint-plate-editor__modal-cancel:hover {
447
447
  background-color: var(--bg-tertiary);
448
448
  }
449
449
 
450
- .mld-plate-editor__modal-submit {
450
+ .mint-plate-editor__modal-submit {
451
451
  padding: 0.5rem 1rem;
452
452
  font-size: 0.875rem;
453
453
  border-radius: var(--radius);
@@ -458,7 +458,7 @@
458
458
  transition: opacity 0.15s ease;
459
459
  }
460
460
 
461
- .mld-plate-editor__modal-submit:disabled {
461
+ .mint-plate-editor__modal-submit:disabled {
462
462
  opacity: 0.4;
463
463
  cursor: not-allowed;
464
464
  }