@teselagen/ove 0.7.28 → 0.7.30-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 (301) hide show
  1. package/CreateAnnotationsPage.d.ts +4 -3
  2. package/README.md +1 -1
  3. package/fileUtils.d.ts +12 -0
  4. package/html2canvas.esm--JN4fLQL.js +7891 -0
  5. package/html2canvas.esm-B7d7VJmQ.cjs +7891 -0
  6. package/index.cjs.js +1305 -1121
  7. package/index.es.js +1305 -1121
  8. package/index.umd.js +189161 -0
  9. package/ove.css +17 -4
  10. package/package.json +5 -9
  11. package/redux/findTool.d.ts +1 -0
  12. package/selectors/searchLayersSelector.d.ts +1 -1
  13. package/src/AutoAnnotate.js +1 -1
  14. package/src/CreateAnnotationsPage.js +1 -2
  15. package/src/Editor/style.css +8 -3
  16. package/src/FindBar/index.js +32 -1
  17. package/src/RowItem/SelectionLayer/index.js +42 -4
  18. package/src/RowItem/SelectionLayer/style.css +8 -0
  19. package/src/fileUtils.js +103 -0
  20. package/src/helperComponents/PropertiesDialog/TranslationProperties.js +1 -1
  21. package/src/redux/findTool.js +9 -0
  22. package/src/selectors/searchLayersSelector.js +40 -2
  23. package/style.css +12098 -1
  24. package/AASliver.js +0 -187
  25. package/AddLaddersDialog.js +0 -82
  26. package/AdditionalCutsiteInfoDialog.js +0 -599
  27. package/AlignmentVisibilityTool.js +0 -105
  28. package/AnnotationContainerHolder.js +0 -20
  29. package/AnnotationPositioner.js +0 -27
  30. package/AutoAnnotate.js +0 -501
  31. package/AutoAnnotateBpMatchingDialog.js +0 -208
  32. package/Axis.js +0 -151
  33. package/AxisNumbers.js +0 -35
  34. package/Browser.js +0 -106
  35. package/Caret.js +0 -63
  36. package/Chromatogram.js +0 -293
  37. package/CircularDnaSequence.js +0 -73
  38. package/CircularZoomMinimap.js +0 -16
  39. package/ColorPicker.js +0 -30
  40. package/CommandHotkeyHandler.js +0 -44
  41. package/CreateAnnotationsPage.js +0 -98
  42. package/Cutsite.js +0 -18
  43. package/CutsiteProperties.js +0 -176
  44. package/CutsiteSelectionLayers.js +0 -47
  45. package/Cutsites.js +0 -271
  46. package/DeletionLayer.js +0 -28
  47. package/DropHandler.css +0 -21
  48. package/DropHandler.js +0 -64
  49. package/EditCaretPosition.js +0 -234
  50. package/EditTrackNameDialog.js +0 -30
  51. package/Feature.js +0 -83
  52. package/FeatureProperties.js +0 -6
  53. package/FillWindow.js +0 -47
  54. package/GenbankView.js +0 -74
  55. package/GeneralProperties.js +0 -117
  56. package/GenericAnnotationProperties.js +0 -406
  57. package/GlobalDialog.js +0 -73
  58. package/GlobalDialogUtils.js +0 -110
  59. package/GoToDialog.js +0 -25
  60. package/HorizontalPanelDragHandle.js +0 -35
  61. package/Keyboard.js +0 -85
  62. package/Labels.js +0 -327
  63. package/Ladder.css +0 -20
  64. package/Ladder.js +0 -303
  65. package/MeltingTemp.js +0 -85
  66. package/Menlo.ttf +0 -0
  67. package/Minimap.js +0 -515
  68. package/Mismatches.js +0 -134
  69. package/Monaco.ttf +0 -0
  70. package/MultipleSeqsDetectedOnImportDialog.js +0 -74
  71. package/Orf.js +0 -109
  72. package/OrfProperties.js +0 -117
  73. package/Orfs.js +0 -35
  74. package/PCRTool.js +0 -179
  75. package/PairwiseAlignmentView.js +0 -68
  76. package/Part.js +0 -34
  77. package/PartProperties.js +0 -9
  78. package/PassThrough.js +0 -3
  79. package/PerformantSelectionLayer.js +0 -32
  80. package/PinchHelper.js +0 -24
  81. package/PointedAnnotation.js +0 -347
  82. package/PositionAnnotationOnCircle.js +0 -26
  83. package/Primer.js +0 -41
  84. package/PrimerProperties.js +0 -19
  85. package/ReflexContainer.js +0 -802
  86. package/ReflexElement.js +0 -160
  87. package/ReflexEvents.js +0 -77
  88. package/ReflexSplitter.js +0 -205
  89. package/RenameSequenceDialog.js +0 -7
  90. package/RotateCircularViewSlider.js +0 -93
  91. package/SelectDialog.js +0 -150
  92. package/SequenceName.js +0 -15
  93. package/SimpleCircularOrLinearView.js +0 -381
  94. package/SimpleOligoPreview.js +0 -39
  95. package/SingleEnzymeCutsiteInfo.js +0 -139
  96. package/ToolbarItem.js +0 -192
  97. package/Translation.js +0 -198
  98. package/TranslationProperties.js +0 -149
  99. package/UncontrolledSliderWithPlusMinusBtns.css +0 -5
  100. package/UncontrolledSliderWithPlusMinusBtns.js +0 -134
  101. package/VeTopRightContainer.js +0 -12
  102. package/ZoomCircularViewSlider.js +0 -62
  103. package/ZoomLinearView.js +0 -47
  104. package/addAlignment.js +0 -6
  105. package/addMetaToActionCreators.js +0 -12
  106. package/addWrappedAddons.js +0 -20
  107. package/alignmentTool.js +0 -503
  108. package/alignments.js +0 -379
  109. package/annotationLabelVisibility.js +0 -2
  110. package/annotationSearchSelector.js +0 -24
  111. package/annotationTypes.js +0 -35
  112. package/annotationVisibility.js +0 -196
  113. package/annotationsToSupport.js +0 -104
  114. package/arrayToObjWithIds.js +0 -17
  115. package/arrayUtils.js +0 -19
  116. package/array_move.js +0 -10
  117. package/calculateTickMarkPositionsForGivenRange.js +0 -47
  118. package/caretPosition.js +0 -27
  119. package/cdsFeaturesSelector.js +0 -9
  120. package/charWidth.js +0 -22
  121. package/circular.js +0 -19
  122. package/circularSelector.js +0 -4
  123. package/clickAndDragUtils.js +0 -576
  124. package/coerceInitialValue.js +0 -7
  125. package/combineReducersDontIgnoreKeys.js +0 -12
  126. package/commandUtils.js +0 -20
  127. package/constants.js +0 -2
  128. package/copyOptions.js +0 -34
  129. package/createFragmentLines.js +0 -120
  130. package/createMergedDefaultStateReducer.js +0 -30
  131. package/createMetaAction.js +0 -12
  132. package/createSequenceInputPopup.js +0 -290
  133. package/createSequenceInputPopupStyle.css +0 -87
  134. package/createSimpleDialog.js +0 -89
  135. package/createYourOwnEnzyme.js +0 -39
  136. package/cutsiteLabelColorSelector.js +0 -6
  137. package/cutsiteTool.js +0 -88
  138. package/cutsitesByRangeSelector.js +0 -5
  139. package/cutsitesSelector.js +0 -61
  140. package/darkmode.css +0 -98
  141. package/defaultConfig.js +0 -150
  142. package/deletionLayers.js +0 -36
  143. package/description.js +0 -21
  144. package/digestTool.js +0 -34
  145. package/dnaToColor.js +0 -17
  146. package/downloadTool.js +0 -39
  147. package/draggableClassnames.js +0 -5
  148. package/drawAnnotations.js +0 -440
  149. package/drawDirectedPiePiece.js +0 -142
  150. package/editTool.js +0 -49
  151. package/editorSelector.js +0 -2
  152. package/editorUtils.js +0 -205
  153. package/estimateRowHeight.js +0 -184
  154. package/featureLengthsToHide.js +0 -27
  155. package/featureTool.js +0 -34
  156. package/features.js +0 -19
  157. package/featuresSelector.js +0 -8
  158. package/filteredCutsitesSelector.js +0 -136
  159. package/filteredFeaturesSelector.js +0 -32
  160. package/filteredPartsSelector.js +0 -57
  161. package/filteredPrimersSelector.js +0 -27
  162. package/filteredRestrictionEnzymesSelector.js +0 -1
  163. package/find.png +0 -0
  164. package/findTool.js +0 -79
  165. package/findToolConstants.js +0 -1
  166. package/frameTranslations.js +0 -52
  167. package/fullscreen.png +0 -0
  168. package/getAdditionalEnzymesSelector.js +0 -46
  169. package/getAngleForPositionMidpoint.js +0 -3
  170. package/getAnnotationClassnames.js +0 -12
  171. package/getAnnotationNameAndStartStopString.js +0 -61
  172. package/getBpsPerRow.js +0 -19
  173. package/getCutsiteLabelHeights.js +0 -56
  174. package/getGapMap.js +0 -12
  175. package/getGaps.js +0 -27
  176. package/getInternalLabel.js +0 -40
  177. package/getOveHotkeyDefs.js +0 -12
  178. package/getPairwiseOverviewLinearViewOptions.js +0 -38
  179. package/getRangeAnglesSpecial.js +0 -12
  180. package/getStructuredBases.js +0 -97
  181. package/getTrackFromEvent.js +0 -25
  182. package/getVisibleStartEnd.js +0 -7
  183. package/getXStartAndWidthFromNonCircularRange.js +0 -12
  184. package/getXStartAndWidthOfRangeWrtRow.js +0 -27
  185. package/getXStartAndWidthOfRowAnnotation.js +0 -19
  186. package/getYOffset.js +0 -15
  187. package/hoveredAnnotation.js +0 -24
  188. package/importTool.js +0 -27
  189. package/index.js +0 -71
  190. package/inlineFindTool.js +0 -38
  191. package/isElementInViewport.js +0 -29
  192. package/isEnzymeFilterAndSelector.js +0 -1
  193. package/isTargetWithinEl.js +0 -6
  194. package/labelLineIntensity.js +0 -25
  195. package/labelSize.js +0 -23
  196. package/ladderDefaults.js +0 -25
  197. package/lastSavedId.js +0 -20
  198. package/lineageLines.js +0 -11
  199. package/linear.png +0 -0
  200. package/makeStore.js +0 -34
  201. package/massageTickSpacing.js +0 -19
  202. package/materiallyAvailable.js +0 -19
  203. package/middleware.js +0 -112
  204. package/minimumOrfSize.js +0 -24
  205. package/minimumOrfSizeSelector.js +0 -2
  206. package/modalActions.js +0 -3
  207. package/moveCaret.js +0 -58
  208. package/name.js +0 -19
  209. package/normalizeAngle.js +0 -3
  210. package/normalizeAngleRange.js +0 -9
  211. package/oligoTool.js +0 -30
  212. package/onlyUpdateForKeysDeep.js +0 -31
  213. package/orfFrameToColorMap.js +0 -10
  214. package/orfTool.js +0 -136
  215. package/orfsSelector.js +0 -15
  216. package/panelsShown.js +0 -294
  217. package/partLengthsToHide.js +0 -23
  218. package/partOverhangs.js +0 -6
  219. package/partTagSearch.js +0 -69
  220. package/partTool.js +0 -45
  221. package/parts.js +0 -19
  222. package/partsSelector.js +0 -8
  223. package/pie.png +0 -0
  224. package/polarToSpecialCartesian.js +0 -7
  225. package/positionCutsites.js +0 -6
  226. package/prepareRowData.js +0 -64
  227. package/primerBases.js +0 -221
  228. package/primerLengthsToHide.js +0 -27
  229. package/primers.js +0 -19
  230. package/primersSelector.js +0 -8
  231. package/print.png +0 -0
  232. package/printTool.js +0 -31
  233. package/propertiesTool.js +0 -40
  234. package/proteinUtils.js +0 -3
  235. package/pureNoFunc.js +0 -18
  236. package/readOnly.js +0 -25
  237. package/redoTool.js +0 -30
  238. package/reflex-styles.css +0 -128
  239. package/reflex-styles.css.map +0 -9
  240. package/relaxLabelAngles.js +0 -157
  241. package/relaxLabels_DEPRECATED.js +0 -105
  242. package/replacementLayers.js +0 -36
  243. package/restrictionEnzymes.js +0 -52
  244. package/restrictionEnzymesSelector.js +0 -34
  245. package/rowviewContants.js +0 -3
  246. package/ruler.css +0 -89
  247. package/save.png +0 -0
  248. package/saveTool.js +0 -44
  249. package/searchLayersSelector.js +0 -71
  250. package/selectedAnnotations.js +0 -89
  251. package/selectedAnnotationsSelector.js +0 -1
  252. package/selectedCutsitesSelector.js +0 -21
  253. package/selectedPartTags.js +0 -21
  254. package/selectionLayer.js +0 -25
  255. package/sequence.js +0 -12
  256. package/sequenceDataHistory.js +0 -43
  257. package/sequenceDataSelector.js +0 -2
  258. package/sequenceLengthSelector.js +0 -5
  259. package/sequenceSelector.js +0 -4
  260. package/sharedActionCreators.js +0 -0
  261. package/shouldFlipText.js +0 -4
  262. package/shouldRerender.js +0 -27
  263. package/showFileDialog.js +0 -25
  264. package/showGCContent.js +0 -23
  265. package/show_cut_sites.png +0 -0
  266. package/show_features.png +0 -0
  267. package/show_orfs.png +0 -0
  268. package/show_primers.png +0 -0
  269. package/simpleDialog.css +0 -13
  270. package/specialCutsiteFilterOptions.js +0 -22
  271. package/tagsToBoldSelector.js +0 -2
  272. package/toggle_views.svg +0 -1
  273. package/toolBar.js +0 -23
  274. package/translationSearchMatchesSelector.js +0 -14
  275. package/translations.js +0 -20
  276. package/translationsRawSelector.js +0 -8
  277. package/translationsSelector.js +0 -137
  278. package/typeField.js +0 -24
  279. package/undoTool.js +0 -30
  280. package/updateEditor.js +0 -200
  281. package/updateLabelsForInViewFeatures.js +0 -55
  282. package/updateLabelsForInViewFeaturesCircView.js +0 -41
  283. package/updateTrackHelper.js +0 -58
  284. package/uppercaseSequenceMapFont.js +0 -25
  285. package/upsertDeleteActionGenerator.js +0 -31
  286. package/useAAColorType.js +0 -8
  287. package/useAdditionalOrfStartCodons.js +0 -24
  288. package/useAnnotationLimits.js +0 -42
  289. package/useChromatogramPrefs.js +0 -31
  290. package/useFormValue.js +0 -7
  291. package/useLadders.js +0 -6
  292. package/useMeltingTemp.js +0 -7
  293. package/useTmType.js +0 -10
  294. package/userDefinedHandlersAndOpts.js +0 -61
  295. package/utils.js +0 -37
  296. package/versionHistory.js +0 -26
  297. package/versionHistoryTool.js +0 -21
  298. package/viewSubmenu.js +0 -479
  299. package/visibilityTool.js +0 -39
  300. package/withHover.js +0 -113
  301. package/withRestrictionEnzymes.js +0 -15
package/Ladder.js DELETED
@@ -1,303 +0,0 @@
1
- /* eslint-disable react/jsx-no-bind */
2
- import React, { useState } from "react";
3
- import { showConfirmationDialog, TgSelect } from "@teselagen/ui";
4
-
5
- import "./Ladder.css";
6
- import { Button, Tooltip } from "@blueprintjs/core";
7
- import { showDialog } from "../GlobalDialogUtils";
8
- import { AddLaddersDialog } from "./AddLaddersDialog";
9
- import { ladderDefaults } from "./ladderDefaults";
10
- import useLadders from "../utils/useLadders";
11
- import { map } from "lodash-es";
12
- import { filter } from "lodash-es";
13
-
14
- export default function Ladder({
15
- // gelDigestEnzymes = [],
16
- boxHeight = 550,
17
- lanes = [],
18
- digestLaneRightClicked,
19
- selectedFragment,
20
- ladders = ladderDefaults
21
- }) {
22
- const [additionalLadders, setLadders] = useLadders();
23
- const laddersToUse = [
24
- ...ladders,
25
- ...map(additionalLadders, (l, i) => ({
26
- ...l,
27
- label: (
28
- <div
29
- key={i}
30
- style={{
31
- display: "flex",
32
- alignItems: "center",
33
- justifyContent: "space-between",
34
- width: "100%"
35
- }}
36
- >
37
- {l.label}{" "}
38
- <Button
39
- onClick={async e => {
40
- e.preventDefault();
41
- e.stopPropagation();
42
- const confirm = await showConfirmationDialog({
43
- text: "Are you sure you want to delete this custom ladder? You cannot undo this action",
44
- intent: "danger",
45
- confirmButtonText: "Delete",
46
- cancelButtonText: "Cancel",
47
- canEscapeKeyCancel: true
48
- });
49
- if (!confirm) {
50
- return;
51
- }
52
- setSelectedLadder(ladders[0].value);
53
- setLadders(
54
- filter(additionalLadders, lad => lad.value !== l.value)
55
- );
56
- }}
57
- intent="danger"
58
- small
59
- minimal
60
- icon="trash"
61
- ></Button>
62
- </div>
63
- )
64
- }))
65
- ];
66
- const [highlightedFragment, setHighlightedFragment] = useState();
67
- const [selectedLadder, setSelectedLadder] = useState(ladders[0].value);
68
- let ladderInfo;
69
- laddersToUse.forEach(ladder => {
70
- if (ladder.value === selectedLadder)
71
- ladderInfo = {
72
- ...ladder,
73
- markings: ladder.markings.sort((a, b) => {
74
- return b - a;
75
- })
76
- };
77
- });
78
- if (!ladderInfo) {
79
- return console.error("Uh oh there needs to be ladder info here!");
80
- }
81
- const sharedStyle = { color: "white", background: "black" }; //use a shared style to get the copy image to look nice
82
- const upperBoundary = ladderInfo.markings[0];
83
- return (
84
- <div>
85
- Ladder:
86
- <div style={{ display: "flex" }}>
87
- <TgSelect
88
- className="tg-ladder-selector"
89
- value={selectedLadder}
90
- onChange={val => setSelectedLadder(val.value)}
91
- options={laddersToUse}
92
- />
93
- <Button
94
- onClick={() => {
95
- showDialog({
96
- ModalComponent: AddLaddersDialog,
97
- props: {
98
- setSelectedLadder
99
- }
100
- });
101
- }}
102
- style={{ minWidth: 150 }}
103
- minimal
104
- small
105
- icon="plus"
106
- intent="primary"
107
- >
108
- Add Ladder
109
- </Button>
110
- </div>
111
- <br />
112
- <div
113
- className="ve-digest-outer-container"
114
- style={{
115
- position: "relative",
116
- width: "fit-content",
117
- ...sharedStyle
118
- }}
119
- >
120
- {navigator.clipboard && window.isSecureContext && (
121
- <Button
122
- icon="duplicate"
123
- minimal
124
- style={{ position: "absolute", top: 5, right: 5, color: "white" }}
125
- onClick={async () => {
126
- try {
127
- const canvas = await import("html2canvas");
128
- canvas
129
- .default(document.querySelector(".ve-digest-container"))
130
- .then(canvas => {
131
- canvas.toBlob(blob =>
132
- navigator.clipboard.write([
133
- new window.ClipboardItem({ "image/png": blob })
134
- ])
135
- );
136
- window.toastr.success("Image copied to clipboard!");
137
- });
138
- } catch (e) {
139
- window.toastr.error(
140
- "Error copying the image, try just taking a screenshot instead ;)"
141
- );
142
- }
143
- }}
144
- ></Button>
145
- )}
146
- <div style={{ padding: 3, paddingLeft: 7, width: 290 }}>
147
- Highlighted Fragment:{" "}
148
- {highlightedFragment ? highlightedFragment.size : "--"}{" "}
149
- </div>
150
- <div
151
- style={{ height: boxHeight, ...sharedStyle }}
152
- className="ve-digest-container"
153
- >
154
- <div
155
- style={{ width: 100 }}
156
- className="ve-digest-column ve-digest-ladder"
157
- >
158
- <div className="ve-digest-header"> </div>
159
- {ladderInfo.markings.map((val, index) => {
160
- return (
161
- <div
162
- key={index}
163
- style={{
164
- fontSize: 12,
165
- position: "absolute",
166
- width: "100%",
167
- display: "flex",
168
- alignItems: "center",
169
- color: "white",
170
- bottom: calculateOffset(boxHeight, val, upperBoundary) - 3 //subtract 3 to get the labels to align better
171
- }}
172
- >
173
- <span
174
- style={{
175
- color: "white",
176
- paddingLeft: 6,
177
- paddingRight: 4
178
- }}
179
- >
180
- {val}{" "}
181
- </span>
182
- <span style={{ color: "white", paddingRight: 4 }}> bp </span>
183
- </div>
184
- );
185
- })}
186
- </div>
187
- <div className="ve-digest-column ve-digest-ladder">
188
- <div className="ve-digest-header">Ladder </div>
189
- {ladderInfo.markings.map((val, index) => {
190
- return (
191
- <div
192
- key={index}
193
- style={{
194
- fontSize: 12,
195
- position: "absolute",
196
- width: "100%",
197
- display: "flex",
198
- alignItems: "center",
199
- color: "white",
200
- height: "2px",
201
- background: "white",
202
- bottom: calculateOffset(boxHeight, val, upperBoundary)
203
- }}
204
- />
205
- );
206
- })}
207
- </div>
208
- {lanes.map((fragments, index) => {
209
- return (
210
- <Lane
211
- key={index}
212
- {...{
213
- onMouseOver: fragment => setHighlightedFragment(fragment),
214
- onMouseOut: () => setHighlightedFragment(undefined),
215
- digestLaneRightClicked,
216
- laneNumber: index + 1,
217
- fragments,
218
- highlightedFragment,
219
- selectedFragment,
220
- boxHeight,
221
- upperBoundary
222
- }}
223
- />
224
- );
225
- })}
226
- </div>
227
- </div>
228
- </div>
229
- );
230
- }
231
-
232
- function Lane({
233
- laneNumber,
234
- onMouseOver,
235
- onMouseOut,
236
- digestLaneRightClicked,
237
- fragments,
238
- highlightedFragment,
239
- selectedFragment,
240
- boxHeight,
241
- upperBoundary
242
- }) {
243
- return (
244
- <div
245
- style={{ marginLeft: 20, marginRight: 20 }}
246
- className="ve-digest-column ve-digest-lane"
247
- >
248
- <div className="ve-digest-header">Lane {laneNumber} </div>
249
- {fragments.map((fragment, index) => {
250
- const { size, id, name } = fragment;
251
- const isHighlighted =
252
- (highlightedFragment && id === highlightedFragment.id) ||
253
- (selectedFragment && id === highlightedFragment.id);
254
- return (
255
- <div
256
- key={index}
257
- onMouseOver={() => {
258
- onMouseOver(fragment);
259
- }}
260
- onMouseOut={() => {
261
- onMouseOut(fragment);
262
- }}
263
- onClick={() => {
264
- fragment.onFragmentSelect();
265
- }}
266
- onContextMenu={e => {
267
- fragment.onFragmentSelect();
268
- digestLaneRightClicked(e);
269
- }}
270
- data-test={name}
271
- style={{
272
- fontSize: 12,
273
- position: "absolute",
274
- display: "flex",
275
- alignItems: "center",
276
- color: isHighlighted ? "#fdffdd" : "white",
277
- width: "90%",
278
- height: isHighlighted ? "3px" : "2px",
279
- background: "white",
280
- bottom: calculateOffset(boxHeight, size, upperBoundary)
281
- }}
282
- >
283
- <Tooltip
284
- className="ve-digest-fragment-tooltip"
285
- content={<div>{name}</div>}
286
- >
287
- <div
288
- style={{
289
- width: "100%",
290
- height: isHighlighted ? "3px" : "2px"
291
- }}
292
- />
293
- </Tooltip>
294
- </div>
295
- );
296
- })}
297
- </div>
298
- );
299
- }
300
-
301
- function calculateOffset(boxHeight, size, upperBoundary) {
302
- return (boxHeight * Math.log(size)) / Math.log(upperBoundary) - 55;
303
- }
package/MeltingTemp.js DELETED
@@ -1,85 +0,0 @@
1
- import React from "react";
2
- import { Button, Icon, Popover, RadioGroup } from "@blueprintjs/core";
3
-
4
- import { calculateTm, calculateNebTm } from "@teselagen/sequence-utils";
5
-
6
- import { isNumber, isString } from "lodash-es";
7
- import { popoverOverflowModifiers } from "@teselagen/ui";
8
- import useTmType from "../utils/useTmType";
9
-
10
- export default function MeltingTemp({
11
- sequence,
12
- WrapperToUse = p => <div>{p.children}</div>,
13
- InnerWrapper = p => (
14
- <Button minimal small>
15
- {p.children}
16
- </Button>
17
- )
18
- }) {
19
- const [primerConc /* , setPrimerConcentration */] = React.useState(0.0000005);
20
- const [monovalentCationConc /* , setMonovalentCationConc */] =
21
- React.useState(0.05);
22
- const [tmType, setTmType] = useTmType();
23
- let tm = (tmType === "neb_tm" ? calculateNebTm : calculateTm)(sequence, {
24
- monovalentCationConc,
25
- primerConc
26
- });
27
- if (isNumber(tm)) {
28
- tm = tm.toFixed(1);
29
- }
30
- const hasWarning = isString(tm) && tm.length > 7 && tm;
31
- return (
32
- <WrapperToUse dataTest="veStatusBar-selection-tm">
33
- <Popover
34
- modifiers={popoverOverflowModifiers}
35
- content={
36
- <div style={{ maxWidth: 300, padding: 20 }}>
37
- Using Tm calculations based on these{" "}
38
- <a
39
- rel="noopener noreferrer"
40
- target="_blank"
41
- href="https://github.com/TeselaGen/tg-oss/blob/master/packages/sequence-utils/src/calculateNebTm.js"
42
- >
43
- algorithms
44
- </a>
45
- <br></br>
46
- <br></br>
47
- <RadioGroup
48
- label="Choose Tm Type:"
49
- options={[
50
- { value: "default", label: "Default Tm (Breslauer)" },
51
- { value: "neb_tm", label: "NEB Tm (SantaLucia)" }
52
- ]}
53
- onChange={e => setTmType(e.target.value)}
54
- selectedValue={tmType}
55
- ></RadioGroup>
56
- {hasWarning && (
57
- <div>
58
- <Icon
59
- style={{ marginLeft: 5, marginRight: 5 }}
60
- size={10}
61
- icon="warning-sign"
62
- ></Icon>
63
- {hasWarning}
64
- <br></br>
65
- <br></br>
66
- Try using the Default Tm
67
- </div>
68
- )}
69
- </div>
70
- }
71
- >
72
- <React.Fragment>
73
- <InnerWrapper>Melting Temp: {Number(tm) || 0} </InnerWrapper>
74
- {hasWarning && (
75
- <Icon
76
- style={{ marginLeft: 5, marginRight: 5 }}
77
- size={10}
78
- icon="warning-sign"
79
- ></Icon>
80
- )}
81
- </React.Fragment>
82
- </Popover>
83
- </WrapperToUse>
84
- );
85
- }
package/Menlo.ttf DELETED
Binary file