@complat/react-spectra-editor 1.3.4 → 1.4.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.
Files changed (95) hide show
  1. package/dist/__tests__/fixtures/nmr1h_2_jcamp.js +3199 -1944
  2. package/dist/__tests__/units/components/cmd_bar/01_viewer.test.js +21 -18
  3. package/dist/__tests__/units/components/cmd_bar/02_zoom.test.js +15 -13
  4. package/dist/__tests__/units/components/cmd_bar/03_peak.test.js +35 -26
  5. package/dist/__tests__/units/components/cmd_bar/07_pecker.test.js +17 -14
  6. package/dist/__tests__/units/components/cmd_bar/r08_change_axes.test.js +15 -13
  7. package/dist/__tests__/units/components/common/comps.test.js +9 -8
  8. package/dist/__tests__/units/components/common/draw.test.js +26 -34
  9. package/dist/__tests__/units/components/panel/graph_selection.test.js +25 -22
  10. package/dist/__tests__/units/components/panel/info.test.js +30 -25
  11. package/dist/__tests__/units/components/panel/peaks.test.js +29 -24
  12. package/dist/actions/manager.js +6 -2
  13. package/dist/actions/ui.js +13 -21
  14. package/dist/app.js +47 -47
  15. package/dist/components/cmd_bar/01_viewer.js +38 -31
  16. package/dist/components/cmd_bar/02_zoom.js +34 -27
  17. package/dist/components/cmd_bar/03_peak.js +85 -64
  18. package/dist/components/cmd_bar/04_integration.js +97 -76
  19. package/dist/components/cmd_bar/05_multiplicity.js +94 -67
  20. package/dist/components/cmd_bar/06_undo_redo.js +41 -32
  21. package/dist/components/cmd_bar/07_pecker.js +70 -47
  22. package/dist/components/cmd_bar/common.js +8 -8
  23. package/dist/components/cmd_bar/index.js +20 -21
  24. package/dist/components/cmd_bar/r01_layout.js +201 -137
  25. package/dist/components/cmd_bar/r02_scan.js +63 -51
  26. package/dist/components/cmd_bar/r03_threshold.js +95 -69
  27. package/dist/components/cmd_bar/r04_submit.js +155 -133
  28. package/dist/components/cmd_bar/r05_submit_btn.js +39 -36
  29. package/dist/components/cmd_bar/r06_predict_btn.js +66 -52
  30. package/dist/components/cmd_bar/r07_wavelength_btn.js +35 -31
  31. package/dist/components/cmd_bar/r08_change_axes.js +65 -56
  32. package/dist/components/cmd_bar/r09_detector.js +38 -33
  33. package/dist/components/cmd_bar/tri_btn.js +37 -25
  34. package/dist/components/common/comps.js +5 -6
  35. package/dist/components/d3_line/index.js +2 -1
  36. package/dist/components/d3_line/line_focus.js +32 -34
  37. package/dist/components/d3_multi/index.js +2 -1
  38. package/dist/components/d3_multi/multi_focus.js +60 -37
  39. package/dist/components/d3_rect/index.js +2 -1
  40. package/dist/components/d3_rect/rect_focus.js +18 -20
  41. package/dist/components/forecast/comps.js +169 -132
  42. package/dist/components/forecast/ir_comps.js +88 -69
  43. package/dist/components/forecast/ir_viewer.js +35 -28
  44. package/dist/components/forecast/nmr_comps.js +105 -76
  45. package/dist/components/forecast/nmr_viewer.js +36 -29
  46. package/dist/components/forecast/section_loading.js +22 -17
  47. package/dist/components/forecast_viewer.js +19 -17
  48. package/dist/components/multi_jcamps_viewer.js +46 -40
  49. package/dist/components/panel/compare.js +92 -76
  50. package/dist/components/panel/cyclic_voltamery_data.js +171 -122
  51. package/dist/components/panel/graph_selection.js +113 -90
  52. package/dist/components/panel/index.js +45 -41
  53. package/dist/components/panel/info.js +204 -157
  54. package/dist/components/panel/multiplicity.js +85 -63
  55. package/dist/components/panel/multiplicity_coupling.js +36 -29
  56. package/dist/components/panel/multiplicity_select.js +20 -19
  57. package/dist/components/panel/peaks.js +78 -56
  58. package/dist/constants/action_type.js +2 -1
  59. package/dist/helpers/cfg.js +1 -2
  60. package/dist/helpers/chem.js +5 -13
  61. package/dist/helpers/converter.js +1 -2
  62. package/dist/helpers/extractParams.js +1 -2
  63. package/dist/helpers/extractPeaksEdit.js +3 -6
  64. package/dist/helpers/format.js +27 -62
  65. package/dist/helpers/init.js +5 -9
  66. package/dist/helpers/integration.js +1 -2
  67. package/dist/helpers/mount.js +1 -2
  68. package/dist/index.js +306 -276
  69. package/dist/layer_content.js +14 -14
  70. package/dist/layer_init.js +17 -16
  71. package/dist/layer_prism.js +84 -73
  72. package/dist/reducers/reducer_axes.js +2 -5
  73. package/dist/reducers/reducer_curve.js +8 -6
  74. package/dist/reducers/reducer_detector.js +1 -3
  75. package/dist/reducers/reducer_edit_peak.js +1 -3
  76. package/dist/reducers/reducer_forecast.js +1 -3
  77. package/dist/reducers/reducer_integration.js +1 -3
  78. package/dist/reducers/reducer_jcamp.js +5 -8
  79. package/dist/reducers/reducer_layout.js +1 -3
  80. package/dist/reducers/reducer_manager.js +1 -3
  81. package/dist/reducers/reducer_meta.js +1 -3
  82. package/dist/reducers/reducer_multiplicity.js +3 -3
  83. package/dist/reducers/reducer_scan.js +1 -3
  84. package/dist/reducers/reducer_shift.js +1 -3
  85. package/dist/reducers/reducer_simulation.js +1 -3
  86. package/dist/reducers/reducer_status.js +1 -3
  87. package/dist/reducers/reducer_submit.js +1 -3
  88. package/dist/reducers/reducer_threshold.js +199 -29
  89. package/dist/reducers/reducer_ui.js +1 -3
  90. package/dist/reducers/reducer_voltammetry.js +3 -7
  91. package/dist/reducers/reducer_wavelength.js +1 -3
  92. package/dist/sagas/saga_multi_entities.js +35 -14
  93. package/dist/sagas/saga_multiplicity.js +1 -2
  94. package/dist/third_party/jAnalyzer.js +1 -1
  95. package/package.json +18 -1
@@ -17,6 +17,7 @@ var _ExpandMore = _interopRequireDefault(require("@mui/icons-material/ExpandMore
17
17
  var _styles = require("@mui/styles");
18
18
  var _format = _interopRequireDefault(require("../../helpers/format"));
19
19
  var _meta = require("../../actions/meta");
20
+ var _jsxRuntime = require("react/jsx-runtime");
20
21
  /* eslint-disable no-mixed-operators, react/function-component-definition,
21
22
  react/require-default-props, max-len */
22
23
 
@@ -110,13 +111,12 @@ const aucValue = integration => {
110
111
  }
111
112
  return values.join(', ');
112
113
  };
113
- const SECData = _ref => {
114
- let {
115
- classes,
116
- layout,
117
- detector,
118
- secData
119
- } = _ref;
114
+ const SECData = ({
115
+ classes,
116
+ layout,
117
+ detector,
118
+ secData
119
+ }) => {
120
120
  if (_format.default.isSECLayout(layout) && secData) {
121
121
  const {
122
122
  d,
@@ -124,37 +124,54 @@ const SECData = _ref => {
124
124
  mp,
125
125
  mw
126
126
  } = secData;
127
- return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
128
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
129
- }, /*#__PURE__*/_react.default.createElement("span", {
130
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
131
- }, "Detector: "), /*#__PURE__*/_react.default.createElement("span", {
132
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
133
- }, detector)), /*#__PURE__*/_react.default.createElement("div", {
134
- className: (0, _classnames.default)(classes.rowRoot, classes.rowEven)
135
- }, /*#__PURE__*/_react.default.createElement("span", {
136
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
137
- }, "D: "), /*#__PURE__*/_react.default.createElement("span", {
138
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
139
- }, d)), /*#__PURE__*/_react.default.createElement("div", {
140
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
141
- }, /*#__PURE__*/_react.default.createElement("span", {
142
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
143
- }, "MN: "), /*#__PURE__*/_react.default.createElement("span", {
144
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
145
- }, mn)), /*#__PURE__*/_react.default.createElement("div", {
146
- className: (0, _classnames.default)(classes.rowRoot, classes.rowEven)
147
- }, /*#__PURE__*/_react.default.createElement("span", {
148
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
149
- }, "MP: "), /*#__PURE__*/_react.default.createElement("span", {
150
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
151
- }, mp)), /*#__PURE__*/_react.default.createElement("div", {
152
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
153
- }, /*#__PURE__*/_react.default.createElement("span", {
154
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
155
- }, "MW: "), /*#__PURE__*/_react.default.createElement("span", {
156
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
157
- }, mw)));
127
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
128
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
129
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
130
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
131
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
132
+ children: "Detector: "
133
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
134
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
135
+ children: detector
136
+ })]
137
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
138
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowEven),
139
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
140
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
141
+ children: "D: "
142
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
143
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
144
+ children: d
145
+ })]
146
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
147
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
148
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
149
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
150
+ children: "MN: "
151
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
152
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
153
+ children: mn
154
+ })]
155
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
156
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowEven),
157
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
158
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
159
+ children: "MP: "
160
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
161
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
162
+ children: mp
163
+ })]
164
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
165
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
166
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
167
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
168
+ children: "MW: "
169
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
170
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
171
+ children: mw
172
+ })]
173
+ })]
174
+ });
158
175
  }
159
176
  return null;
160
177
  };
@@ -164,13 +181,12 @@ SECData.propTypes = {
164
181
  detector: _propTypes.default.object.isRequired,
165
182
  secData: _propTypes.default.object.isRequired
166
183
  };
167
- const DSCData = _ref2 => {
168
- let {
169
- classes,
170
- layout,
171
- dscMetaData,
172
- updateAction
173
- } = _ref2;
184
+ const DSCData = ({
185
+ classes,
186
+ layout,
187
+ dscMetaData,
188
+ updateAction
189
+ }) => {
174
190
  if (_format.default.isDSCLayout(layout) && dscMetaData !== undefined) {
175
191
  const {
176
192
  meltingPoint,
@@ -188,27 +204,33 @@ const DSCData = _ref2 => {
188
204
  dataToUpdate[name] = value;
189
205
  updateAction(dataToUpdate);
190
206
  };
191
- return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
192
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
193
- }, /*#__PURE__*/_react.default.createElement("span", {
194
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
195
- }, "Melting Point: "), /*#__PURE__*/_react.default.createElement("input", {
196
- type: "text",
197
- name: "meltingPoint",
198
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
199
- value: meltingPoint,
200
- onChange: onChange
201
- })), /*#__PURE__*/_react.default.createElement("div", {
202
- className: (0, _classnames.default)(classes.rowRoot, classes.rowEven)
203
- }, /*#__PURE__*/_react.default.createElement("span", {
204
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
205
- }, "TG: "), /*#__PURE__*/_react.default.createElement("input", {
206
- type: "text",
207
- name: "tg",
208
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
209
- value: tg,
210
- onChange: onChange
211
- })));
207
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
208
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
209
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
210
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
211
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
212
+ children: "Melting Point: "
213
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("input", {
214
+ type: "text",
215
+ name: "meltingPoint",
216
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
217
+ value: meltingPoint,
218
+ onChange: onChange
219
+ })]
220
+ }), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
221
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowEven),
222
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
223
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
224
+ children: "TG: "
225
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("input", {
226
+ type: "text",
227
+ name: "tg",
228
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
229
+ value: tg,
230
+ onChange: onChange
231
+ })]
232
+ })]
233
+ });
212
234
  }
213
235
  return null;
214
236
  };
@@ -218,27 +240,26 @@ DSCData.propTypes = {
218
240
  dscMetaData: _propTypes.default.object.isRequired,
219
241
  updateAction: _propTypes.default.func.isRequired
220
242
  };
221
- const InfoPanel = _ref3 => {
222
- let {
223
- classes,
224
- expand,
225
- feature,
226
- integration,
227
- editorOnly,
228
- molSvg,
229
- descriptions,
230
- layoutSt,
231
- simulationSt,
232
- shiftSt,
233
- curveSt,
234
- theoryMass,
235
- onExapnd,
236
- canChangeDescription,
237
- onDescriptionChanged,
238
- detectorSt,
239
- metaSt,
240
- updateDSCMetaDataAct
241
- } = _ref3;
243
+ const InfoPanel = ({
244
+ classes,
245
+ expand,
246
+ feature,
247
+ integration,
248
+ editorOnly,
249
+ molSvg,
250
+ descriptions,
251
+ layoutSt,
252
+ simulationSt,
253
+ shiftSt,
254
+ curveSt,
255
+ exactMass,
256
+ onExapnd,
257
+ canChangeDescription,
258
+ onDescriptionChanged,
259
+ detectorSt,
260
+ metaSt,
261
+ updateDSCMetaDataAct
262
+ }) => {
242
263
  if (!feature) return null;
243
264
  const {
244
265
  title,
@@ -278,7 +299,7 @@ const InfoPanel = _ref3 => {
278
299
  if (integration) {
279
300
  originStack = integration.originStack; // eslint-disable-line
280
301
  }
281
- return /*#__PURE__*/_react.default.createElement(_material.Accordion, {
302
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_material.Accordion, {
282
303
  "data-testid": "PanelInfo",
283
304
  expanded: expand,
284
305
  onChange: onExapnd,
@@ -286,74 +307,100 @@ const InfoPanel = _ref3 => {
286
307
  TransitionProps: {
287
308
  unmountOnExit: true
288
309
  } // increase Accordion performance
289
- }, /*#__PURE__*/_react.default.createElement(_material.AccordionSummary, {
290
- expandIcon: /*#__PURE__*/_react.default.createElement(_ExpandMore.default, null),
291
- className: (0, _classnames.default)(classes.panelSummary)
292
- }, /*#__PURE__*/_react.default.createElement(_material.Typography, {
293
- className: "txt-panel-header"
294
- }, /*#__PURE__*/_react.default.createElement("span", {
295
- className: (0, _classnames.default)(classes.txtBadge, 'txt-sv-panel-title')
296
- }, "Info"))), /*#__PURE__*/_react.default.createElement(_material.Divider, null), /*#__PURE__*/_react.default.createElement("div", {
297
- className: (0, _classnames.default)(classes.panelDetail)
298
- }, /*#__PURE__*/_react.default.createElement("div", {
299
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
300
- }, /*#__PURE__*/_react.default.createElement("span", {
301
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
302
- }, "Title : "), /*#__PURE__*/_react.default.createElement("span", {
303
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
304
- }, title)), _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/_react.default.createElement("div", {
305
- className: (0, _classnames.default)(classes.rowRoot, classes.rowEven)
306
- }, /*#__PURE__*/_react.default.createElement("span", {
307
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
308
- }, "Freq : "), /*#__PURE__*/_react.default.createElement("span", {
309
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
310
- }, `${parseInt(observeFrequency, 10)} Hz` || ' - ')) : null, _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/_react.default.createElement("div", {
311
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
312
- }, /*#__PURE__*/_react.default.createElement("span", {
313
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
314
- }, "Solv : "), /*#__PURE__*/_react.default.createElement("span", {
315
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
316
- }, showSolvName)) : null, _format.default.isMsLayout(layoutSt) && theoryMass ? /*#__PURE__*/_react.default.createElement("div", {
317
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd)
318
- }, /*#__PURE__*/_react.default.createElement("span", {
319
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
320
- }, "Theoretical mass: "), /*#__PURE__*/_react.default.createElement("span", {
321
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
322
- }, `${parseFloat(theoryMass).toFixed(6)} g/mol`)) : null, /*#__PURE__*/_react.default.createElement(SECData, {
323
- classes: classes,
324
- layout: layoutSt,
325
- detector: selectedDetector,
326
- secData: secData
327
- }), !molSvg ? null : /*#__PURE__*/_react.default.createElement(_reactSvgFileZoomPan.default, {
328
- svg: molSvg,
329
- duration: 300,
330
- resize: true
331
- }), _format.default.isHplcUvVisLayout(layoutSt) ? /*#__PURE__*/_react.default.createElement("div", {
332
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOddSim)
333
- }, /*#__PURE__*/_react.default.createElement("span", {
334
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
335
- }, "Area under curve (AUC):"), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("span", {
336
- className: (0, _classnames.default)(classes.tTxt, classes.tTxtSim, 'txt-sv-panel-txt')
337
- }, aucValue(integration))) : null, /*#__PURE__*/_react.default.createElement(DSCData, {
338
- classes: classes,
339
- layout: layoutSt,
340
- dscMetaData: dscMetaData,
341
- updateAction: updateDSCMetaDataAct
342
- })), !_format.default.isCyclicVoltaLayout(layoutSt) ? /*#__PURE__*/_react.default.createElement(_reactQuill.default, {
343
- className: (0, _classnames.default)(classes.quill, 'card-sv-quill'),
344
- value: descriptions,
345
- modules: {
346
- toolbar: false
347
- },
348
- onChange: onDescriptionChanged,
349
- readOnly: canChangeDescription !== undefined ? !canChangeDescription : true
350
- }) : null, /*#__PURE__*/_react.default.createElement("div", null, !editorOnly && _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/_react.default.createElement("div", {
351
- className: (0, _classnames.default)(classes.rowRoot, classes.rowOddSim)
352
- }, /*#__PURE__*/_react.default.createElement("span", {
353
- className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt')
354
- }, simTitle(), ":"), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("span", {
355
- className: (0, _classnames.default)(classes.tTxt, classes.tTxtSim, 'txt-sv-panel-txt')
356
- }, simContent(simulationSt.nmrSimPeaks))) : null));
310
+ ,
311
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_material.AccordionSummary, {
312
+ expandIcon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_ExpandMore.default, {}),
313
+ className: (0, _classnames.default)(classes.panelSummary),
314
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Typography, {
315
+ className: "txt-panel-header",
316
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
317
+ className: (0, _classnames.default)(classes.txtBadge, 'txt-sv-panel-title'),
318
+ children: "Info"
319
+ })
320
+ })
321
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Divider, {}), /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
322
+ className: (0, _classnames.default)(classes.panelDetail),
323
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
324
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
325
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
326
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
327
+ children: "Title : "
328
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
329
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
330
+ children: title
331
+ })]
332
+ }), _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
333
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowEven),
334
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
335
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
336
+ children: "Freq : "
337
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
338
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
339
+ children: `${parseInt(observeFrequency, 10)} Hz` || ' - '
340
+ })]
341
+ }) : null, _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
342
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
343
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
344
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
345
+ children: "Solv : "
346
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
347
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
348
+ children: showSolvName
349
+ })]
350
+ }) : null, _format.default.isMsLayout(layoutSt) && exactMass ? /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
351
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOdd),
352
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
353
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
354
+ children: "Exact mass: "
355
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
356
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
357
+ children: `${parseFloat(exactMass).toFixed(6)} g/mol`
358
+ })]
359
+ }) : null, /*#__PURE__*/(0, _jsxRuntime.jsx)(SECData, {
360
+ classes: classes,
361
+ layout: layoutSt,
362
+ detector: selectedDetector,
363
+ secData: secData
364
+ }), !molSvg ? null : /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactSvgFileZoomPan.default, {
365
+ svg: molSvg,
366
+ duration: 300,
367
+ resize: true
368
+ }), _format.default.isHplcUvVisLayout(layoutSt) ? /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
369
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOddSim),
370
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
371
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
372
+ children: "Area under curve (AUC):"
373
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("br", {}), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
374
+ className: (0, _classnames.default)(classes.tTxt, classes.tTxtSim, 'txt-sv-panel-txt'),
375
+ children: aucValue(integration)
376
+ })]
377
+ }) : null, /*#__PURE__*/(0, _jsxRuntime.jsx)(DSCData, {
378
+ classes: classes,
379
+ layout: layoutSt,
380
+ dscMetaData: dscMetaData,
381
+ updateAction: updateDSCMetaDataAct
382
+ })]
383
+ }), !_format.default.isCyclicVoltaLayout(layoutSt) ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactQuill.default, {
384
+ className: (0, _classnames.default)(classes.quill, 'card-sv-quill'),
385
+ value: descriptions,
386
+ modules: {
387
+ toolbar: false
388
+ },
389
+ onChange: onDescriptionChanged,
390
+ readOnly: canChangeDescription !== undefined ? !canChangeDescription : true
391
+ }) : null, /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
392
+ children: !editorOnly && _format.default.isNmrLayout(layoutSt) ? /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
393
+ className: (0, _classnames.default)(classes.rowRoot, classes.rowOddSim),
394
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("span", {
395
+ className: (0, _classnames.default)(classes.tTxt, classes.tHead, 'txt-sv-panel-txt'),
396
+ children: [simTitle(), ":"]
397
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("br", {}), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
398
+ className: (0, _classnames.default)(classes.tTxt, classes.tTxtSim, 'txt-sv-panel-txt'),
399
+ children: simContent(simulationSt.nmrSimPeaks)
400
+ })]
401
+ }) : null
402
+ })]
403
+ });
357
404
  };
358
405
  const mapStateToProps = (state, props) => (
359
406
  // eslint-disable-line
@@ -383,7 +430,7 @@ InfoPanel.propTypes = {
383
430
  onExapnd: _propTypes.default.func.isRequired,
384
431
  canChangeDescription: _propTypes.default.bool.isRequired,
385
432
  onDescriptionChanged: _propTypes.default.func,
386
- theoryMass: _propTypes.default.string,
433
+ exactMass: _propTypes.default.string,
387
434
  detectorSt: _propTypes.default.object.isRequired,
388
435
  metaSt: _propTypes.default.object.isRequired,
389
436
  updateDSCMetaDataAct: _propTypes.default.func.isRequired
@@ -19,6 +19,7 @@ var _multiplicity = require("../../actions/multiplicity");
19
19
  var _multiplicity_select = _interopRequireDefault(require("./multiplicity_select"));
20
20
  var _multiplicity_coupling = _interopRequireDefault(require("./multiplicity_coupling"));
21
21
  var _multiplicity_calc = require("../../helpers/multiplicity_calc");
22
+ var _jsxRuntime = require("react/jsx-runtime");
22
23
  /* eslint-disable function-paren-newline,
23
24
  function-call-argument-newline, react/function-component-definition */
24
25
 
@@ -138,31 +139,36 @@ const pkList = (classes, row, shift, digits, rmMpyPeakByPanelAct) => row.peaks.m
138
139
  peak: pk,
139
140
  xExtent
140
141
  });
141
- const rmBtn = /*#__PURE__*/_react.default.createElement(_HighlightOff.default, {
142
+ const rmBtn = /*#__PURE__*/(0, _jsxRuntime.jsx)(_HighlightOff.default, {
142
143
  onClick: cb,
143
144
  className: classes.rmBtn
144
145
  });
145
- return /*#__PURE__*/_react.default.createElement(_material.TableRow, {
146
- key: pk.x,
146
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_material.TableRow, {
147
147
  className: classes.tRow,
148
- hover: true
149
- }, /*#__PURE__*/_react.default.createElement(_material.TableCell, {
150
- align: "right",
151
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
152
- }, `(${(pk.x - shift).toFixed(digits)}, ${pk.y.toExponential(2)})`), /*#__PURE__*/_react.default.createElement(_material.TableCell, {
153
- align: "right",
154
- className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt')
155
- }, rmBtn));
148
+ hover: true,
149
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_material.TableCell, {
150
+ align: "right",
151
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
152
+ children: `(${(pk.x - shift).toFixed(digits)}, ${pk.y.toExponential(2)})`
153
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.TableCell, {
154
+ align: "right",
155
+ className: (0, _classnames.default)(classes.tTxt, 'txt-sv-panel-txt'),
156
+ children: rmBtn
157
+ })]
158
+ }, pk.x);
156
159
  });
157
- const refreshBtn = (classes, onRefresh) => /*#__PURE__*/_react.default.createElement(_material.Tooltip, {
160
+ const refreshBtn = (classes, onRefresh) => /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Tooltip, {
158
161
  placement: "left",
159
- title: /*#__PURE__*/_react.default.createElement("span", {
160
- className: "txt-sv-tp"
161
- }, "Calculate Multiplicity")
162
- }, /*#__PURE__*/_react.default.createElement(_material.Button, {
163
- className: classes.btnRf,
164
- onClick: onRefresh
165
- }, /*#__PURE__*/_react.default.createElement(_RefreshOutlined.default, null)));
162
+ title: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
163
+ className: "txt-sv-tp",
164
+ children: "Calculate Multiplicity"
165
+ }),
166
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Button, {
167
+ className: classes.btnRf,
168
+ onClick: onRefresh,
169
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_RefreshOutlined.default, {})
170
+ })
171
+ });
166
172
  const mpyList = (classes, digits, multiplicitySt, curveSt, clickMpyOneAct, rmMpyPeakByPanelAct, resetMpyOneAct) => {
167
173
  const {
168
174
  curveIdx
@@ -203,58 +209,74 @@ const mpyList = (classes, digits, multiplicitySt, curveSt, clickMpyOneAct, rmMpy
203
209
  };
204
210
  return createData(idx, xExtent, peaks, shift, smExtext, mpyType, js, onClick, onRefresh);
205
211
  });
206
- return /*#__PURE__*/_react.default.createElement("div", null, rows.map(row => /*#__PURE__*/_react.default.createElement("div", {
207
- className: classes.moCard,
208
- key: row.idx
209
- }, /*#__PURE__*/_react.default.createElement("div", {
210
- className: classes.moCardHead
211
- }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(MUCheckbox, {
212
- className: classes.moCBox,
213
- checked: row.isCheck,
214
- onChange: row.onClick
215
- }), /*#__PURE__*/_react.default.createElement("span", {
216
- className: (0, _classnames.default)(classes.moExtTxt, classes.moExtId, 'txt-sv-panel-head')
217
- }, row.idx), /*#__PURE__*/_react.default.createElement("span", {
218
- className: (0, _classnames.default)(classes.moExtTxt, 'txt-sv-panel-head')
219
- }, `${row.center.toFixed(3)} (ppm)`), /*#__PURE__*/_react.default.createElement("span", {
220
- className: (0, _classnames.default)(classes.moSelect, 'txt-sv-panel-head')
221
- }, /*#__PURE__*/_react.default.createElement(_multiplicity_select.default, {
222
- target: row
223
- })), refreshBtn(classes, row.onRefresh)), /*#__PURE__*/_react.default.createElement(_multiplicity_coupling.default, {
224
- row: row
225
- })), /*#__PURE__*/_react.default.createElement(_material.Table, {
226
- className: classes.table
227
- }, /*#__PURE__*/_react.default.createElement(_material.TableBody, null, pkList(classes, row, shift, digits, rmMpyPeakByPanelAct))))));
212
+ return /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
213
+ children: rows.map(row => /*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
214
+ className: classes.moCard,
215
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
216
+ className: classes.moCardHead,
217
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)("div", {
218
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(MUCheckbox, {
219
+ className: classes.moCBox,
220
+ checked: row.isCheck,
221
+ onChange: row.onClick
222
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
223
+ className: (0, _classnames.default)(classes.moExtTxt, classes.moExtId, 'txt-sv-panel-head'),
224
+ children: row.idx
225
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
226
+ className: (0, _classnames.default)(classes.moExtTxt, 'txt-sv-panel-head'),
227
+ children: `${row.center.toFixed(3)} (ppm)`
228
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
229
+ className: (0, _classnames.default)(classes.moSelect, 'txt-sv-panel-head'),
230
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_multiplicity_select.default, {
231
+ target: row
232
+ })
233
+ }), refreshBtn(classes, row.onRefresh)]
234
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_multiplicity_coupling.default, {
235
+ row: row
236
+ })]
237
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Table, {
238
+ className: classes.table,
239
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.TableBody, {
240
+ children: pkList(classes, row, shift, digits, rmMpyPeakByPanelAct)
241
+ })
242
+ })]
243
+ }, row.idx))
244
+ });
228
245
  };
229
- const MultiplicityPanel = _ref => {
230
- let {
231
- classes,
232
- expand,
233
- onExapnd,
234
- multiplicitySt,
235
- curveSt,
236
- clickMpyOneAct,
237
- rmMpyPeakByPanelAct,
238
- resetMpyOneAct
239
- } = _ref;
246
+ const MultiplicityPanel = ({
247
+ classes,
248
+ expand,
249
+ onExapnd,
250
+ multiplicitySt,
251
+ curveSt,
252
+ clickMpyOneAct,
253
+ rmMpyPeakByPanelAct,
254
+ resetMpyOneAct
255
+ }) => {
240
256
  const digits = 4;
241
- return /*#__PURE__*/_react.default.createElement(_material.Accordion, {
257
+ return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_material.Accordion, {
242
258
  expanded: expand,
243
259
  onChange: onExapnd,
244
260
  className: (0, _classnames.default)(classes.panel),
245
261
  TransitionProps: {
246
262
  unmountOnExit: true
247
263
  } // increase Accordion performance
248
- }, /*#__PURE__*/_react.default.createElement(_material.AccordionSummary, {
249
- expandIcon: /*#__PURE__*/_react.default.createElement(_ExpandMore.default, null),
250
- className: (0, _classnames.default)(classes.panelSummary)
251
- }, /*#__PURE__*/_react.default.createElement(_material.Typography, {
252
- className: "txt-panel-header"
253
- }, /*#__PURE__*/_react.default.createElement("span", {
254
- className: (0, _classnames.default)(classes.txtBadge, 'txt-sv-panel-title')
255
- }, "Multiplicity"))), /*#__PURE__*/_react.default.createElement(_material.Divider, null), /*#__PURE__*/_react.default.createElement("div", {
256
- className: (0, _classnames.default)(classes.panelDetail)
257
- }, mpyList(classes, digits, multiplicitySt, curveSt, clickMpyOneAct, rmMpyPeakByPanelAct, resetMpyOneAct)));
264
+ ,
265
+ children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_material.AccordionSummary, {
266
+ expandIcon: /*#__PURE__*/(0, _jsxRuntime.jsx)(_ExpandMore.default, {}),
267
+ className: (0, _classnames.default)(classes.panelSummary),
268
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Typography, {
269
+ className: "txt-panel-header",
270
+ children: /*#__PURE__*/(0, _jsxRuntime.jsx)("span", {
271
+ className: (0, _classnames.default)(classes.txtBadge, 'txt-sv-panel-title'),
272
+ children: "Multiplicity"
273
+ })
274
+ })
275
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_material.Divider, {}), /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
276
+ className: (0, _classnames.default)(classes.panelDetail),
277
+ children: mpyList(classes, digits, multiplicitySt, curveSt, clickMpyOneAct, rmMpyPeakByPanelAct, resetMpyOneAct)
278
+ })]
279
+ });
258
280
  };
259
281
  const mapStateToProps = (state, props) => (
260
282
  // eslint-disable-line