react-science 0.27.1-pre.1696432898 → 0.28.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.
- package/lib-esm/app-data/loaders/cdfLoader.d.ts.map +1 -1
- package/lib-esm/app-data/loaders/cdfLoader.js +4 -4
- package/lib-esm/app-data/loaders/cdfLoader.js.map +1 -1
- package/lib-esm/components/info-panel/InfoPanel.d.ts +1 -1
- package/lib-esm/components/info-panel/InfoPanel.d.ts.map +1 -1
- package/lib-esm/components/info-panel/InfoPanel.js +30 -13
- package/lib-esm/components/info-panel/InfoPanel.js.map +1 -1
- package/lib-esm/components/value-renderers/Number.d.ts.map +1 -1
- package/lib-esm/components/value-renderers/Number.js +1 -1
- package/lib-esm/components/value-renderers/Number.js.map +1 -1
- package/package.json +45 -47
- package/src/app-data/loaders/cdfLoader.ts +21 -15
- package/src/components/info-panel/InfoPanel.tsx +45 -24
- package/src/components/value-renderers/Number.tsx +3 -1
- package/lib/app/about/AboutDialogToolbarButton.js +0 -19
- package/lib/app/about/index.js +0 -17
- package/lib/app/explorer/ExplorerPlotView.js +0 -26
- package/lib/app/explorer/MeasurementExplorer.js +0 -120
- package/lib/app/explorer/MeasurementExplorerWithState.js +0 -13
- package/lib/app/explorer/index.js +0 -18
- package/lib/app/helpers/MeasurementPlot.js +0 -42
- package/lib/app/helpers/MeasurementVariableSelect.js +0 -14
- package/lib/app/helpers/getColorFromConfig.js +0 -14
- package/lib/app/helpers/index.js +0 -21
- package/lib/app/helpers/react-plot.js +0 -50
- package/lib/app/helpers/splitEntries.js +0 -19
- package/lib/app/hooks/file-loading.js +0 -40
- package/lib/app/hooks/index.js +0 -17
- package/lib/app/index.js +0 -21
- package/lib/app/kinds/index.js +0 -19
- package/lib/app/kinds/ir/IrPeaksPanel.js +0 -42
- package/lib/app/kinds/ir/index.js +0 -17
- package/lib/app/kinds/iv/index.js +0 -17
- package/lib/app/kinds/iv/plot-view/IvMeasurementsPlot.js +0 -55
- package/lib/app/kinds/iv/plot-view/IvPlotVariablesSelector.js +0 -27
- package/lib/app/kinds/iv/plot-view/IvPlotView.js +0 -38
- package/lib/app/kinds/iv/plot-view/IvSeries.js +0 -25
- package/lib/app/kinds/mass/MassPlotView.js +0 -14
- package/lib/app/kinds/mass/MeasurementMassPlot.js +0 -79
- package/lib/app/kinds/mass/index.js +0 -18
- package/lib/app/panels/SignalProcessingPanel.js +0 -85
- package/lib/app/panels/index.js +0 -20
- package/lib/app/panels/measurement-config/MeasurementConfigPanel.js +0 -28
- package/lib/app/panels/measurement-config/MeasurementConfigPanelAccordion.js +0 -17
- package/lib/app/panels/measurement-config/index.js +0 -18
- package/lib/app/panels/measurement-info/MeasurementInfoPanel.js +0 -26
- package/lib/app/panels/measurement-info/MeasurementInfoPanelAccordion.js +0 -10
- package/lib/app/panels/measurement-info/index.js +0 -18
- package/lib/app/panels/measurements/MeasurementCheckbox.js +0 -28
- package/lib/app/panels/measurements/MeasurementColorPreview.js +0 -48
- package/lib/app/panels/measurements/MeasurementVisibilityToggle.js +0 -30
- package/lib/app/panels/measurements/MeasurementsPanel.js +0 -33
- package/lib/app/panels/measurements/MeasurementsPanelAccordion.js +0 -16
- package/lib/app/panels/measurements/MeasurementsTable.js +0 -159
- package/lib/app/panels/measurements/index.js +0 -18
- package/lib/app-data/enhancers/enhance.js +0 -16
- package/lib/app-data/enhancers/index.js +0 -17
- package/lib/app-data/helpers/index.js +0 -17
- package/lib/app-data/helpers/variables.js +0 -25
- package/lib/app-data/index.js +0 -22
- package/lib/app-data/kinds/index.js +0 -18
- package/lib/app-data/kinds/ir/IrMeasurement.js +0 -2
- package/lib/app-data/kinds/ir/IrPeak.js +0 -2
- package/lib/app-data/kinds/ir/index.js +0 -20
- package/lib/app-data/kinds/ir/irAutoPeakPickingEnhancer.js +0 -54
- package/lib/app-data/kinds/ir/irMeasurementEnhancer.js +0 -50
- package/lib/app-data/kinds/iv/IvMeasurement.js +0 -2
- package/lib/app-data/kinds/iv/index.js +0 -17
- package/lib/app-data/loaders/biologicLoader.js +0 -140
- package/lib/app-data/loaders/cdfLoader.js +0 -168
- package/lib/app-data/loaders/index.js +0 -24
- package/lib/app-data/loaders/jcampLoader.js +0 -104
- package/lib/app-data/loaders/loadMeasurements.js +0 -38
- package/lib/app-data/loaders/proprietary/agilent/cary500Loader.js +0 -77
- package/lib/app-data/loaders/spcLoader.js +0 -47
- package/lib/app-data/loaders/utility/getMeasurementInfoFromFile.js +0 -19
- package/lib/app-data/loaders/utility/index.js +0 -19
- package/lib/app-data/loaders/utility/measurementLoader.js +0 -17
- package/lib/app-data/loaders/utility/parserLog.js +0 -22
- package/lib/app-data/loaders/wdfLoader.js +0 -111
- package/lib/app-data/state/appState.js +0 -56
- package/lib/app-data/state/appStateActions.js +0 -2
- package/lib/app-data/state/data/AppData.js +0 -2
- package/lib/app-data/state/data/data.helpers.js +0 -135
- package/lib/app-data/state/data/getEmptyAppData.js +0 -20
- package/lib/app-data/state/data/index.js +0 -20
- package/lib/app-data/state/data/kinds.js +0 -16
- package/lib/app-data/state/index.js +0 -20
- package/lib/app-data/state/producers/appStateProducer.js +0 -42
- package/lib/app-data/state/producers/index.js +0 -17
- package/lib/app-data/state/producers/measurements/addMeasurements.js +0 -58
- package/lib/app-data/state/producers/measurements/measurements.js +0 -105
- package/lib/app-data/state/producers/plot-view/helpers/zoom.js +0 -48
- package/lib/app-data/state/producers/plot-view/plot-view.js +0 -25
- package/lib/app-data/state/producers/types.js +0 -2
- package/lib/app-data/state/settings/AppSettings.js +0 -2
- package/lib/app-data/state/settings/getEmptyAppSettings.js +0 -11
- package/lib/app-data/state/settings/index.js +0 -18
- package/lib/app-data/state/view/AppView.js +0 -2
- package/lib/app-data/state/view/getEmptyAppView.js +0 -11
- package/lib/app-data/state/view/index.js +0 -18
- package/lib/app-data/utils.js +0 -15
- package/lib/components/accordion/Accordion.js +0 -80
- package/lib/components/accordion/AccordionContext.js +0 -121
- package/lib/components/accordion/index.js +0 -18
- package/lib/components/button/Button.js +0 -37
- package/lib/components/button/ButtonGroup.js +0 -41
- package/lib/components/button/index.js +0 -18
- package/lib/components/color-picker/color-picker-dropdown/ColorPickerDropdown.js +0 -68
- package/lib/components/color-picker/gradient-select/GradientSelect.js +0 -86
- package/lib/components/color-picker/index.js +0 -21
- package/lib/components/color-picker/palette.js +0 -15
- package/lib/components/color-picker/preview/ColorPreview.js +0 -24
- package/lib/components/color-picker/preview/FixedColorPreview.js +0 -8
- package/lib/components/color-picker/preview/FixedGradientPreview.js +0 -23
- package/lib/components/color-picker/react-color/ColorPicker.js +0 -139
- package/lib/components/color-picker/react-color/common/Alpha.js +0 -110
- package/lib/components/color-picker/react-color/common/CheckBoard.js +0 -54
- package/lib/components/color-picker/react-color/common/EditableInput.js +0 -102
- package/lib/components/color-picker/react-color/common/Hue.js +0 -90
- package/lib/components/color-picker/react-color/common/Saturation.js +0 -91
- package/lib/components/color-picker/react-color/common/Swatch.js +0 -49
- package/lib/components/color-picker/react-color/common/index.js +0 -18
- package/lib/components/color-picker/react-color/common/interaction.js +0 -17
- package/lib/components/color-picker/react-color/common/useOnChange.js +0 -16
- package/lib/components/color-picker/react-color/helpers/alpha.js +0 -55
- package/lib/components/color-picker/react-color/helpers/checkBoard.js +0 -36
- package/lib/components/color-picker/react-color/helpers/color.js +0 -83
- package/lib/components/color-picker/react-color/helpers/hue.js +0 -57
- package/lib/components/color-picker/react-color/helpers/saturation.js +0 -32
- package/lib/components/color-picker/react-color/sketch/SketchFields.js +0 -104
- package/lib/components/color-picker/react-color/sketch/SketchPresetColors.js +0 -44
- package/lib/components/drop-zone/DropZone.js +0 -76
- package/lib/components/drop-zone/index.js +0 -17
- package/lib/components/dropdown-menu/DropdownMenu.js +0 -44
- package/lib/components/dropdown-menu/MenuItems.js +0 -83
- package/lib/components/dropdown-menu/index.js +0 -17
- package/lib/components/dropdown-menu/useContextMenuPlacement.js +0 -52
- package/lib/components/forms/Checkbox.js +0 -61
- package/lib/components/forms/Input.js +0 -66
- package/lib/components/forms/Select.js +0 -119
- package/lib/components/forms/TextArea.js +0 -25
- package/lib/components/forms/context/FieldsContext.js +0 -54
- package/lib/components/forms/context/index.js +0 -17
- package/lib/components/forms/index.js +0 -22
- package/lib/components/forms/radio-group/ButtonRadioItem.js +0 -76
- package/lib/components/forms/radio-group/ClassicRadioItem.js +0 -92
- package/lib/components/forms/radio-group/RadioGroup.js +0 -69
- package/lib/components/forms/radio-group/index.js +0 -17
- package/lib/components/forms/styles.js +0 -80
- package/lib/components/forms/utils/SubText.js +0 -20
- package/lib/components/forms/utils/index.js +0 -17
- package/lib/components/fullscreen/FullscreenContext.js +0 -78
- package/lib/components/fullscreen/FullscreenToolbarButton.js +0 -11
- package/lib/components/fullscreen/index.js +0 -18
- package/lib/components/header/Header.js +0 -20
- package/lib/components/header/PanelHeader.js +0 -51
- package/lib/components/header/index.js +0 -18
- package/lib/components/hooks/index.js +0 -22
- package/lib/components/hooks/useDoubleClick.js +0 -32
- package/lib/components/hooks/useHashSearchParams.js +0 -41
- package/lib/components/hooks/useModifiedPopper.js +0 -51
- package/lib/components/hooks/useOnClickOutside.js +0 -27
- package/lib/components/hooks/useOnOff.js +0 -12
- package/lib/components/hooks/useToggle.js +0 -9
- package/lib/components/index.js +0 -49
- package/lib/components/info-panel/InfoPanel.js +0 -94
- package/lib/components/info-panel/index.js +0 -17
- package/lib/components/layout-manager/LayoutManager.js +0 -52
- package/lib/components/layout-manager/index.js +0 -17
- package/lib/components/modal/ConfirmModal.js +0 -76
- package/lib/components/modal/Modal.js +0 -84
- package/lib/components/modal/ModalCloseButton.js +0 -13
- package/lib/components/modal/index.js +0 -18
- package/lib/components/modal/useDialog.js +0 -51
- package/lib/components/root-layout/Portal.js +0 -13
- package/lib/components/root-layout/RootLayout.js +0 -27
- package/lib/components/root-layout/RootLayoutContext.js +0 -16
- package/lib/components/root-layout/css-reset/customPreflight.js +0 -33
- package/lib/components/root-layout/index.js +0 -17
- package/lib/components/root-layout/queryClient.js +0 -13
- package/lib/components/spinner/FullSpinner.js +0 -30
- package/lib/components/spinner/index.js +0 -17
- package/lib/components/split-pane/SplitPane.js +0 -168
- package/lib/components/split-pane/index.js +0 -17
- package/lib/components/split-pane/useSplitPaneSize.js +0 -63
- package/lib/components/table/Table.js +0 -89
- package/lib/components/table/index.js +0 -17
- package/lib/components/tabs/Tabs.js +0 -98
- package/lib/components/tabs/TabsContext.js +0 -19
- package/lib/components/tabs/index.js +0 -17
- package/lib/components/toolbar/PanelPreferencesToolbar.js +0 -26
- package/lib/components/toolbar/Toolbar.js +0 -63
- package/lib/components/toolbar/index.js +0 -18
- package/lib/components/toolbar/toolbarContext.js +0 -13
- package/lib/components/utils/assert.js +0 -22
- package/lib/components/utils/index.js +0 -17
- package/lib/components/value-renderers/Boolean.js +0 -8
- package/lib/components/value-renderers/Color.js +0 -22
- package/lib/components/value-renderers/Component.js +0 -8
- package/lib/components/value-renderers/Header.js +0 -14
- package/lib/components/value-renderers/Number.js +0 -8
- package/lib/components/value-renderers/ObjectRenderer.js +0 -9
- package/lib/components/value-renderers/Text.js +0 -15
- package/lib/components/value-renderers/Title.js +0 -15
- package/lib/components/value-renderers/index.js +0 -19
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cdfLoader.d.ts","sourceRoot":"","sources":["../../../src/app-data/loaders/cdfLoader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"cdfLoader.d.ts","sourceRoot":"","sources":["../../../src/app-data/loaders/cdfLoader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAIrD,OAAO,KAAK,EAAmB,YAAY,EAAmB,MAAM,UAAU,CAAC;AAG/E,OAAO,EAAE,SAAS,EAAkB,MAAM,qBAAqB,CAAC;AAEhE,wBAAsB,SAAS,CAC7B,cAAc,EAAE,cAAc,EAC9B,IAAI,CAAC,EAAE,SAAS,EAAE,GACjB,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAkEhC"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
// @ts-expect-error netcdfjs has no types at the moment.
|
|
2
1
|
import { NetCDFReader } from 'netcdfjs';
|
|
3
2
|
import { assert } from '../../components/index';
|
|
4
3
|
import { getMeasurementInfoFromFile } from './utility/getMeasurementInfoFromFile';
|
|
@@ -9,9 +8,7 @@ export async function cdfLoader(fileCollection, logs) {
|
|
|
9
8
|
for (const file of fileCollection) {
|
|
10
9
|
if (/\.cdf$/i.test(file.name)) {
|
|
11
10
|
try {
|
|
12
|
-
const reader = new NetCDFReader(await file.arrayBuffer()
|
|
13
|
-
meta: true,
|
|
14
|
-
});
|
|
11
|
+
const reader = new NetCDFReader(await file.arrayBuffer());
|
|
15
12
|
if (reader.dataVariableExists('mass_values') &&
|
|
16
13
|
reader.dataVariableExists('time_values')) {
|
|
17
14
|
kind = 'gclcms';
|
|
@@ -30,6 +27,7 @@ export async function cdfLoader(fileCollection, logs) {
|
|
|
30
27
|
assert(newMeasurements[kind], 'Error while loading, kind is not defined');
|
|
31
28
|
const newMeasurement = {
|
|
32
29
|
...getMeasurementInfoFromFile(file, reader.getAttribute('experiment_title')),
|
|
30
|
+
// @ts-expect-error meta is not defined in reader.
|
|
33
31
|
meta: reader.header.meta,
|
|
34
32
|
data: kind === 'gclcms'
|
|
35
33
|
? chromatogramWithMassSpectra(reader)
|
|
@@ -157,8 +155,10 @@ function chromatogram(reader) {
|
|
|
157
155
|
return data;
|
|
158
156
|
}
|
|
159
157
|
function addMeta(reader, globalAttributes) {
|
|
158
|
+
// @ts-expect-error meta is not defined in reader.
|
|
160
159
|
reader.header.meta = {};
|
|
161
160
|
for (const item of globalAttributes) {
|
|
161
|
+
// @ts-expect-error meta is not defined in reader.
|
|
162
162
|
reader.header.meta[item.name] = item.value;
|
|
163
163
|
}
|
|
164
164
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cdfLoader.js","sourceRoot":"","sources":["../../../src/app-data/loaders/cdfLoader.ts"],"names":[],"mappings":"AACA,
|
|
1
|
+
{"version":3,"file":"cdfLoader.js","sourceRoot":"","sources":["../../../src/app-data/loaders/cdfLoader.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CSSProperties } from 'react';
|
|
2
2
|
export interface InfoPanelData {
|
|
3
3
|
description: string;
|
|
4
|
-
data: Record<string, string | number | object | any>;
|
|
4
|
+
data: Record<string, string | number | object | boolean | any>;
|
|
5
5
|
}
|
|
6
6
|
interface InfoPanelProps {
|
|
7
7
|
title?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InfoPanel.d.ts","sourceRoot":"","sources":["../../../src/components/info-panel/InfoPanel.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAY,MAAM,OAAO,CAAC;AAMhD,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,GAAG,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"InfoPanel.d.ts","sourceRoot":"","sources":["../../../src/components/info-panel/InfoPanel.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAY,MAAM,OAAO,CAAC;AAMhD,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,GAAG,CAAC,CAAC;CAChE;AAED,UAAU,cAAc;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,aAAa,EAAE,CAAC;IACvB,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,UAAU,CAAC,EAAE,aAAa,CAAC;IAC3B,UAAU,CAAC,EAAE,aAAa,CAAC;CAC5B;AAwBD,wBAAgB,SAAS,CAAC,KAAK,EAAE,cAAc,oDAgF9C"}
|
|
@@ -33,16 +33,29 @@ export function InfoPanel(props) {
|
|
|
33
33
|
const [search, setSearch] = useState('');
|
|
34
34
|
const { title = 'Information', data = [], titleStyle, inputStyle, tableStyle, } = props;
|
|
35
35
|
function viewData(data) {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
36
|
+
const exactMatch = [];
|
|
37
|
+
const startsWith = [];
|
|
38
|
+
const includes = [];
|
|
39
|
+
const valueContains = [];
|
|
40
|
+
for (const [key, value] of Object.entries(data)) {
|
|
41
|
+
if (key === search) {
|
|
42
|
+
exactMatch.push([key, value]);
|
|
43
|
+
continue;
|
|
42
44
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
45
|
+
if (key.startsWith(search)) {
|
|
46
|
+
startsWith.push([key, value]);
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
if (key.includes(search)) {
|
|
50
|
+
includes.push([key, value]);
|
|
51
|
+
continue;
|
|
52
|
+
}
|
|
53
|
+
if (valueSearch(value, search)) {
|
|
54
|
+
valueContains.push([key, value]);
|
|
55
|
+
continue;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return [...exactMatch, ...startsWith, ...includes, ...valueContains].map(([key, value]) => (_jsxs(Table.Row, { children: [_jsx(ValueRenderers.Text, { value: key }), valueCell(value)] }, key)));
|
|
46
59
|
}
|
|
47
60
|
return (_jsxs("div", { css: style.container, children: [_jsx("div", { style: titleStyle, children: title }), _jsx(Input, { placeholder: "search for a parameter ...", value: search, onChange: ({ target }) => {
|
|
48
61
|
if (target.value !== undefined)
|
|
@@ -59,6 +72,8 @@ export function InfoPanel(props) {
|
|
|
59
72
|
*/
|
|
60
73
|
function valueCell(value) {
|
|
61
74
|
switch (typeof value) {
|
|
75
|
+
case 'boolean':
|
|
76
|
+
return _jsx(ValueRenderers.Boolean, { value: value });
|
|
62
77
|
case 'number':
|
|
63
78
|
return _jsx(ValueRenderers.Number, { value: value });
|
|
64
79
|
case 'object':
|
|
@@ -79,13 +94,15 @@ function valueCell(value) {
|
|
|
79
94
|
function valueSearch(value, search) {
|
|
80
95
|
switch (typeof value) {
|
|
81
96
|
case 'number':
|
|
82
|
-
return String(value).includes(search
|
|
97
|
+
return String(value).includes(search);
|
|
98
|
+
case 'boolean':
|
|
99
|
+
return String(value).includes(search);
|
|
83
100
|
case 'object':
|
|
84
|
-
return JSON.stringify(value).
|
|
101
|
+
return JSON.stringify(value).includes(search);
|
|
85
102
|
case 'string':
|
|
86
|
-
return value.
|
|
103
|
+
return value.includes(search);
|
|
87
104
|
default:
|
|
88
|
-
return
|
|
105
|
+
return true;
|
|
89
106
|
}
|
|
90
107
|
}
|
|
91
108
|
//# sourceMappingURL=InfoPanel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InfoPanel.js","sourceRoot":"","sources":["../../../src/components/info-panel/InfoPanel.tsx"],"names":[],"mappings":";AAAA,sCAAsC;AACtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,wGAAwG;AACxG,aAAa;AACb,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAiB,QAAQ,EAAE,MAAM,OAAO,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhD,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAcvC,MAAM,KAAK,GAAG;IACZ,SAAS,EAAE,GAAG,CAAC;QACb,OAAO,EAAE,KAAK;KACf,CAAC;IACF,OAAO,EAAE,CAAC,IAAa,EAAE,EAAE,CACzB,GAAG,CAAC;QACF,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QAC/B,UAAU,EAAE,sBAAsB;KACnC,CAAC;IACJ,MAAM,EAAE,GAAG,CAAC;QACV,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,CAAC;QACN,OAAO,EAAE,SAAS;KACnB,CAAC;IACF,KAAK,EAAE,GAAG,CAAA;;;;;GAKT;CACF,CAAC;AAEF,MAAM,UAAU,SAAS,CAAC,KAAqB;IAC7C,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACzC,MAAM,EACJ,KAAK,GAAG,aAAa,EACrB,IAAI,GAAG,EAAE,EACT,UAAU,EACV,UAAU,EACV,UAAU,GACX,GAAG,KAAK,CAAC;IACV,SAAS,QAAQ,CAAC,IAA8C;QAC9D,
|
|
1
|
+
{"version":3,"file":"InfoPanel.js","sourceRoot":"","sources":["../../../src/components/info-panel/InfoPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Number.d.ts","sourceRoot":"","sources":["../../../src/components/value-renderers/Number.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,GAAG,CAAC;AAE7C,UAAU,WAAY,SAAQ,mBAAmB;IAC/C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"Number.d.ts","sourceRoot":"","sources":["../../../src/components/value-renderers/Number.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,GAAG,CAAC;AAE7C,UAAU,WAAY,SAAQ,mBAAmB;IAC/C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,WAAW,2CAM7D"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
export function Number({ value, fixed, ...other }) {
|
|
3
|
-
return (_jsx("div", { ...other, children: value ? (fixed ? value.toFixed(fixed) : value) : '' }));
|
|
3
|
+
return (_jsx("div", { ...other, children: value !== undefined ? (fixed ? value.toFixed(fixed) : value) : '' }));
|
|
4
4
|
}
|
|
5
5
|
//# sourceMappingURL=Number.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Number.js","sourceRoot":"","sources":["../../../src/components/value-renderers/Number.tsx"],"names":[],"mappings":";AAOA,MAAM,UAAU,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,KAAK,EAAe;IAC5D,OAAO,CACL,iBAAS,KAAK,
|
|
1
|
+
{"version":3,"file":"Number.js","sourceRoot":"","sources":["../../../src/components/value-renderers/Number.tsx"],"names":[],"mappings":";AAOA,MAAM,UAAU,MAAM,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,KAAK,EAAe;IAC5D,OAAO,CACL,iBAAS,KAAK,YACX,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,GAC9D,CACP,CAAC;AACJ,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,27 +1,23 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-science",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.28.1",
|
|
4
4
|
"description": "React components to build scientific applications UI",
|
|
5
5
|
"exports": {
|
|
6
6
|
"./app": {
|
|
7
7
|
"types": "./lib-esm/app/index.d.ts",
|
|
8
|
-
"require": "./lib/app/index.js",
|
|
9
8
|
"default": "./lib-esm/app/index.js"
|
|
10
9
|
},
|
|
11
10
|
"./app-data": {
|
|
12
11
|
"types": "./lib-esm/app-data/index.d.ts",
|
|
13
|
-
"require": "./lib/app-data/index.js",
|
|
14
12
|
"default": "./lib-esm/app-data/index.js"
|
|
15
13
|
},
|
|
16
14
|
"./ui": {
|
|
17
15
|
"types": "./lib-esm/components/index.d.ts",
|
|
18
|
-
"require": "./lib/components/index.js",
|
|
19
16
|
"default": "./lib-esm/components/index.js"
|
|
20
17
|
},
|
|
21
18
|
"./styles/*.css": "./styles/*.css"
|
|
22
19
|
},
|
|
23
20
|
"files": [
|
|
24
|
-
"lib",
|
|
25
21
|
"lib-esm",
|
|
26
22
|
"src",
|
|
27
23
|
"styles/preflight.css"
|
|
@@ -31,9 +27,9 @@
|
|
|
31
27
|
"build-all": "npm run build-app && npm run build-storybook && mv storybook-static dist/stories",
|
|
32
28
|
"build-app": "cross-env NO_MINIFY=true vite build",
|
|
33
29
|
"build-storybook": "storybook build",
|
|
34
|
-
"build-ts": "tsc -p tsconfig.
|
|
30
|
+
"build-ts": "tsc -p tsconfig.esm.json",
|
|
35
31
|
"check-types": "tsc --noEmit",
|
|
36
|
-
"clean": "rimraf lib
|
|
32
|
+
"clean": "rimraf lib-esm",
|
|
37
33
|
"createData": "npm run prepack && node scripts/createData",
|
|
38
34
|
"dev": "echo Use npm run dev-app or npm run storybook && exit 1",
|
|
39
35
|
"dev-app": "vite --open /pages/demo.html",
|
|
@@ -51,87 +47,89 @@
|
|
|
51
47
|
"test-only": "vitest run --coverage "
|
|
52
48
|
},
|
|
53
49
|
"volta": {
|
|
54
|
-
"node": "
|
|
50
|
+
"node": "20.8.1"
|
|
55
51
|
},
|
|
56
52
|
"overrides": {
|
|
57
53
|
"react": "^18.2.0",
|
|
58
54
|
"react-dom": "^18.2.0"
|
|
59
55
|
},
|
|
60
56
|
"peerDependencies": {
|
|
57
|
+
"@blueprintjs/core": "^5.3.2",
|
|
58
|
+
"@blueprintjs/icons": "^5.1.7",
|
|
61
59
|
"react": ">=18.0.0",
|
|
62
60
|
"react-dom": ">=18.0.0"
|
|
63
61
|
},
|
|
64
62
|
"dependencies": {
|
|
65
|
-
"@blueprintjs/core": "^5.3.2",
|
|
66
|
-
"@blueprintjs/icons": "^5.1.7",
|
|
67
63
|
"@emotion/react": "^11.11.1",
|
|
68
64
|
"@emotion/styled": "^11.11.0",
|
|
69
|
-
"@headlessui/react": "^1.7.
|
|
65
|
+
"@headlessui/react": "^1.7.17",
|
|
70
66
|
"@lukeed/uuid": "^2.0.1",
|
|
71
67
|
"@popperjs/core": "^2.11.8",
|
|
72
68
|
"@radix-ui/react-checkbox": "^1.0.4",
|
|
73
69
|
"@radix-ui/react-radio-group": "^1.1.3",
|
|
74
|
-
"@radix-ui/react-select": "^
|
|
75
|
-
"@tanstack/react-query": "^4.
|
|
76
|
-
"@tanstack/react-table": "^8.
|
|
70
|
+
"@radix-ui/react-select": "^2.0.0",
|
|
71
|
+
"@tanstack/react-query": "^4.36.1",
|
|
72
|
+
"@tanstack/react-table": "^8.10.7",
|
|
77
73
|
"biologic-converter": "^0.6.0",
|
|
78
74
|
"cheminfo-types": "^1.7.2",
|
|
79
75
|
"d3-scale-chromatic": "^3.0.0",
|
|
80
|
-
"filelist-utils": "^1.10.
|
|
81
|
-
"immer": "^10.0.
|
|
82
|
-
"jcampconverter": "^9.
|
|
76
|
+
"filelist-utils": "^1.10.2",
|
|
77
|
+
"immer": "^10.0.3",
|
|
78
|
+
"jcampconverter": "^9.2.2",
|
|
83
79
|
"lodash": "^4.17.21",
|
|
84
80
|
"ml-gsd": "^12.1.3",
|
|
85
81
|
"ml-peak-shape-generator": "^4.1.2",
|
|
86
82
|
"ml-signal-processing": "^1.0.3",
|
|
87
|
-
"ml-spectra-processing": "^12.
|
|
88
|
-
"ms-spectrum": "^
|
|
89
|
-
"netcdfjs": "^
|
|
83
|
+
"ml-spectra-processing": "^12.6.0",
|
|
84
|
+
"ms-spectrum": "^3.0.7",
|
|
85
|
+
"netcdfjs": "^3.0.0",
|
|
90
86
|
"react-d3-utils": "^1.0.0",
|
|
91
87
|
"react-dropzone": "^14.2.3",
|
|
92
88
|
"react-error-boundary": "^4.0.11",
|
|
93
|
-
"react-icons": "^4.
|
|
89
|
+
"react-icons": "^4.11.0",
|
|
94
90
|
"react-inspector": "^6.0.2",
|
|
95
91
|
"react-kbs": "^2.1.1",
|
|
96
92
|
"react-plot": "^1.4.2",
|
|
97
93
|
"react-popper": "^2.3.0",
|
|
98
|
-
"spc-parser": "^0.7.
|
|
94
|
+
"spc-parser": "^0.7.3",
|
|
99
95
|
"tinycolor2": "^1.6.0",
|
|
100
96
|
"use-resize-observer": "^9.1.0",
|
|
101
97
|
"wdf-parser": "^0.3.0"
|
|
102
98
|
},
|
|
103
99
|
"devDependencies": {
|
|
104
|
-
"@babel/core": "^7.
|
|
105
|
-
"@babel/eslint-parser": "^7.22.
|
|
106
|
-
"@
|
|
107
|
-
"@
|
|
108
|
-
"@
|
|
109
|
-
"@
|
|
110
|
-
"@storybook/
|
|
111
|
-
"@storybook/
|
|
112
|
-
"@storybook/
|
|
113
|
-
"@
|
|
100
|
+
"@babel/core": "^7.23.2",
|
|
101
|
+
"@babel/eslint-parser": "^7.22.15",
|
|
102
|
+
"@blueprintjs/core": "^5.5.1",
|
|
103
|
+
"@blueprintjs/icons": "^5.2.1",
|
|
104
|
+
"@playwright/experimental-ct-react": "^1.39.0",
|
|
105
|
+
"@playwright/test": "^1.39.0",
|
|
106
|
+
"@storybook/addon-essentials": "7.4.6",
|
|
107
|
+
"@storybook/addon-storysource": "7.4.6",
|
|
108
|
+
"@storybook/blocks": "7.4.6",
|
|
109
|
+
"@storybook/react": "7.4.6",
|
|
110
|
+
"@storybook/react-vite": "7.4.6",
|
|
111
|
+
"@types/babel__core": "^7.20.2",
|
|
114
112
|
"@types/d3-scale-chromatic": "^3.0.0",
|
|
115
|
-
"@types/lodash": "^4.14.
|
|
116
|
-
"@types/react": "^18.2.
|
|
117
|
-
"@types/react-dom": "^18.2.
|
|
118
|
-
"@types/react-inspector": "^4.0.
|
|
119
|
-
"@vitejs/plugin-react": "^4.0
|
|
120
|
-
"@vitest/coverage-v8": "^0.34.
|
|
121
|
-
"cheminfo-font": "^1.
|
|
113
|
+
"@types/lodash": "^4.14.199",
|
|
114
|
+
"@types/react": "^18.2.28",
|
|
115
|
+
"@types/react-dom": "^18.2.13",
|
|
116
|
+
"@types/react-inspector": "^4.0.3",
|
|
117
|
+
"@vitejs/plugin-react": "^4.1.0",
|
|
118
|
+
"@vitest/coverage-v8": "^0.34.6",
|
|
119
|
+
"cheminfo-font": "^1.12.0",
|
|
122
120
|
"cross-env": "^7.0.3",
|
|
123
|
-
"eslint": "^8.
|
|
121
|
+
"eslint": "^8.51.0",
|
|
124
122
|
"eslint-config-zakodium": "^8.0.2",
|
|
125
|
-
"eslint-plugin-storybook": "^0.6.
|
|
126
|
-
"prettier": "^3.0.
|
|
123
|
+
"eslint-plugin-storybook": "^0.6.15",
|
|
124
|
+
"prettier": "^3.0.3",
|
|
127
125
|
"react": "^18.2.0",
|
|
128
126
|
"react-dom": "^18.2.0",
|
|
129
127
|
"react-ocl": "^6.1.0",
|
|
130
|
-
"rimraf": "^5.0.
|
|
131
|
-
"storybook": "7.
|
|
132
|
-
"typescript": "^5.
|
|
133
|
-
"vite": "^4.4.
|
|
134
|
-
"vitest": "^0.34.
|
|
128
|
+
"rimraf": "^5.0.5",
|
|
129
|
+
"storybook": "7.4.6",
|
|
130
|
+
"typescript": "^5.2.2",
|
|
131
|
+
"vite": "^4.4.11",
|
|
132
|
+
"vitest": "^0.34.6"
|
|
135
133
|
},
|
|
136
134
|
"repository": {
|
|
137
135
|
"type": "git",
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import type { FileCollection } from 'filelist-utils';
|
|
2
|
-
// @ts-expect-error netcdfjs has no types at the moment.
|
|
3
2
|
import { NetCDFReader } from 'netcdfjs';
|
|
4
3
|
|
|
5
4
|
import { assert } from '../../components/index';
|
|
@@ -17,9 +16,7 @@ export async function cdfLoader(
|
|
|
17
16
|
for (const file of fileCollection) {
|
|
18
17
|
if (/\.cdf$/i.test(file.name)) {
|
|
19
18
|
try {
|
|
20
|
-
const reader = new NetCDFReader(await file.arrayBuffer()
|
|
21
|
-
meta: true,
|
|
22
|
-
});
|
|
19
|
+
const reader = new NetCDFReader(await file.arrayBuffer());
|
|
23
20
|
|
|
24
21
|
if (
|
|
25
22
|
reader.dataVariableExists('mass_values') &&
|
|
@@ -28,7 +25,9 @@ export async function cdfLoader(
|
|
|
28
25
|
kind = 'gclcms';
|
|
29
26
|
} else if (
|
|
30
27
|
reader.dataVariableExists('ordinate_values') &&
|
|
31
|
-
reader.getAttribute('detector_name')?.match(
|
|
28
|
+
(reader.getAttribute('detector_name') as string | null)?.match(
|
|
29
|
+
/dad|tic/i,
|
|
30
|
+
)
|
|
32
31
|
) {
|
|
33
32
|
kind = 'gclc';
|
|
34
33
|
} else {
|
|
@@ -46,8 +45,9 @@ export async function cdfLoader(
|
|
|
46
45
|
const newMeasurement = {
|
|
47
46
|
...getMeasurementInfoFromFile(
|
|
48
47
|
file,
|
|
49
|
-
reader.getAttribute('experiment_title'),
|
|
48
|
+
reader.getAttribute('experiment_title') as string,
|
|
50
49
|
),
|
|
50
|
+
// @ts-expect-error meta is not defined in reader.
|
|
51
51
|
meta: reader.header.meta,
|
|
52
52
|
data:
|
|
53
53
|
kind === 'gclcms'
|
|
@@ -82,9 +82,11 @@ function chromatogramWithMassSpectra(
|
|
|
82
82
|
reader: NetCDFReader,
|
|
83
83
|
): MeasurementBase['data'] {
|
|
84
84
|
// Taken from: https://github.com/cheminfo/netcdf-gcms
|
|
85
|
-
const pointCount = reader.getDataVariable('point_count');
|
|
86
|
-
const massValues = reader.getDataVariable('mass_values');
|
|
87
|
-
const intensityValues = reader.getDataVariable(
|
|
85
|
+
const pointCount = reader.getDataVariable('point_count') as number[];
|
|
86
|
+
const massValues = reader.getDataVariable('mass_values') as number[];
|
|
87
|
+
const intensityValues = reader.getDataVariable(
|
|
88
|
+
'intensity_values',
|
|
89
|
+
) as number[];
|
|
88
90
|
const times = reader.getDataVariable('scan_acquisition_time');
|
|
89
91
|
const tics = reader.getDataVariable('total_intensity');
|
|
90
92
|
|
|
@@ -130,9 +132,9 @@ function chromatogramWithMassSpectra(
|
|
|
130
132
|
function chromatogram(reader: NetCDFReader): MeasurementBase['data'] {
|
|
131
133
|
// Taken from: https://github.com/cheminfo/netcdf-gcms
|
|
132
134
|
const data: MeasurementBase['data'] = [];
|
|
133
|
-
const intensities
|
|
135
|
+
const intensities = reader.getDataVariable('ordinate_values') as number[];
|
|
134
136
|
const numberPoints = intensities.length;
|
|
135
|
-
const detector
|
|
137
|
+
const detector = reader.getAttribute('detector_name') as string;
|
|
136
138
|
let channel: string;
|
|
137
139
|
if (/dad/i.test(detector)) {
|
|
138
140
|
const uvNumber = detector.match(/.*Sig=(?<uvNumber>\d+).*/)?.groups
|
|
@@ -143,13 +145,15 @@ function chromatogram(reader: NetCDFReader): MeasurementBase['data'] {
|
|
|
143
145
|
} else {
|
|
144
146
|
channel = 'unknown';
|
|
145
147
|
}
|
|
146
|
-
const delayTime
|
|
148
|
+
const delayTime = reader.getDataVariable('actual_delay_time')[0] as number;
|
|
147
149
|
const runtimeLength: number = reader.getDataVariable(
|
|
148
150
|
'actual_run_time_length',
|
|
149
|
-
)[0];
|
|
151
|
+
)[0] as number;
|
|
150
152
|
let samplingInterval;
|
|
151
153
|
if (reader.dataVariableExists('actual_sampling_interval')) {
|
|
152
|
-
samplingInterval = reader.getDataVariable(
|
|
154
|
+
samplingInterval = reader.getDataVariable(
|
|
155
|
+
'actual_sampling_interval',
|
|
156
|
+
)[0] as number;
|
|
153
157
|
|
|
154
158
|
if (
|
|
155
159
|
Math.abs(delayTime + samplingInterval * numberPoints - runtimeLength) > 3
|
|
@@ -190,10 +194,12 @@ function chromatogram(reader: NetCDFReader): MeasurementBase['data'] {
|
|
|
190
194
|
|
|
191
195
|
function addMeta(
|
|
192
196
|
reader: NetCDFReader,
|
|
193
|
-
globalAttributes: NetCDFReader
|
|
197
|
+
globalAttributes: NetCDFReader['globalAttributes'],
|
|
194
198
|
) {
|
|
199
|
+
// @ts-expect-error meta is not defined in reader.
|
|
195
200
|
reader.header.meta = {};
|
|
196
201
|
for (const item of globalAttributes) {
|
|
202
|
+
// @ts-expect-error meta is not defined in reader.
|
|
197
203
|
reader.header.meta[item.name] = item.value;
|
|
198
204
|
}
|
|
199
205
|
}
|
|
@@ -11,7 +11,7 @@ import { Table } from '../table/Table';
|
|
|
11
11
|
|
|
12
12
|
export interface InfoPanelData {
|
|
13
13
|
description: string;
|
|
14
|
-
data: Record<string, string | number | object | any>;
|
|
14
|
+
data: Record<string, string | number | object | boolean | any>;
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
interface InfoPanelProps {
|
|
@@ -54,23 +54,37 @@ export function InfoPanel(props: InfoPanelProps) {
|
|
|
54
54
|
tableStyle,
|
|
55
55
|
} = props;
|
|
56
56
|
function viewData(data: Record<string, string | number | object>) {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
57
|
+
const exactMatch: Array<[string, string | number | object]> = [];
|
|
58
|
+
const startsWith: Array<[string, string | number | object]> = [];
|
|
59
|
+
const includes: Array<[string, string | number | object]> = [];
|
|
60
|
+
const valueContains: Array<[string, string | number | object]> = [];
|
|
61
|
+
|
|
62
|
+
for (const [key, value] of Object.entries(data)) {
|
|
63
|
+
if (key === search) {
|
|
64
|
+
exactMatch.push([key, value]);
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
if (key.startsWith(search)) {
|
|
68
|
+
startsWith.push([key, value]);
|
|
69
|
+
continue;
|
|
70
|
+
}
|
|
71
|
+
if (key.includes(search)) {
|
|
72
|
+
includes.push([key, value]);
|
|
73
|
+
continue;
|
|
74
|
+
}
|
|
75
|
+
if (valueSearch(value, search)) {
|
|
76
|
+
valueContains.push([key, value]);
|
|
77
|
+
continue;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return [...exactMatch, ...startsWith, ...includes, ...valueContains].map(
|
|
81
|
+
([key, value]) => (
|
|
82
|
+
<Table.Row key={key}>
|
|
83
|
+
<ValueRenderers.Text value={key} />
|
|
84
|
+
{valueCell(value)}
|
|
85
|
+
</Table.Row>
|
|
86
|
+
),
|
|
87
|
+
);
|
|
74
88
|
}
|
|
75
89
|
return (
|
|
76
90
|
<div css={style.container}>
|
|
@@ -116,8 +130,10 @@ export function InfoPanel(props: InfoPanelProps) {
|
|
|
116
130
|
* @param value - ValueRenderers value.
|
|
117
131
|
* @returns - ValueRenderers component.
|
|
118
132
|
*/
|
|
119
|
-
function valueCell(value: number | string | object) {
|
|
133
|
+
function valueCell(value: number | string | object | boolean) {
|
|
120
134
|
switch (typeof value) {
|
|
135
|
+
case 'boolean':
|
|
136
|
+
return <ValueRenderers.Boolean value={value} />;
|
|
121
137
|
case 'number':
|
|
122
138
|
return <ValueRenderers.Number value={value} />;
|
|
123
139
|
case 'object':
|
|
@@ -136,15 +152,20 @@ function valueCell(value: number | string | object) {
|
|
|
136
152
|
* @param search - Value to search for.
|
|
137
153
|
* @returns - If search exist in value
|
|
138
154
|
*/
|
|
139
|
-
function valueSearch(
|
|
155
|
+
function valueSearch(
|
|
156
|
+
value: number | string | object | boolean,
|
|
157
|
+
search: string,
|
|
158
|
+
): boolean {
|
|
140
159
|
switch (typeof value) {
|
|
141
160
|
case 'number':
|
|
142
|
-
return String(value).includes(search
|
|
161
|
+
return String(value).includes(search);
|
|
162
|
+
case 'boolean':
|
|
163
|
+
return String(value).includes(search);
|
|
143
164
|
case 'object':
|
|
144
|
-
return JSON.stringify(value).
|
|
165
|
+
return JSON.stringify(value).includes(search);
|
|
145
166
|
case 'string':
|
|
146
|
-
return value.
|
|
167
|
+
return value.includes(search);
|
|
147
168
|
default:
|
|
148
|
-
return
|
|
169
|
+
return true;
|
|
149
170
|
}
|
|
150
171
|
}
|
|
@@ -7,6 +7,8 @@ interface NumberProps extends ValueRenderersProps {
|
|
|
7
7
|
|
|
8
8
|
export function Number({ value, fixed, ...other }: NumberProps) {
|
|
9
9
|
return (
|
|
10
|
-
<div {...other}>
|
|
10
|
+
<div {...other}>
|
|
11
|
+
{value !== undefined ? (fixed ? value.toFixed(fixed) : value) : ''}
|
|
12
|
+
</div>
|
|
11
13
|
);
|
|
12
14
|
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.AboutDialogToolbarButton = void 0;
|
|
7
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
-
const styled_1 = __importDefault(require("@emotion/styled"));
|
|
9
|
-
const components_1 = require("../../components");
|
|
10
|
-
const ModalBody = styled_1.default.div `
|
|
11
|
-
max-width: 600px;
|
|
12
|
-
padding: 10px;
|
|
13
|
-
`;
|
|
14
|
-
function AboutDialogToolbarButton(props) {
|
|
15
|
-
const { name, icon, body } = props;
|
|
16
|
-
const [isOpenDialog, openDialog, closeDialog] = (0, components_1.useOnOff)(false);
|
|
17
|
-
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(components_1.Toolbar.Item, { title: `About ${name}`, onClick: openDialog, icon: icon }), (0, jsx_runtime_1.jsxs)(components_1.Modal, { isOpen: isOpenDialog, onRequestClose: closeDialog, children: [(0, jsx_runtime_1.jsx)(components_1.Modal.Header, { children: name }), (0, jsx_runtime_1.jsx)(components_1.Modal.Body, { children: (0, jsx_runtime_1.jsx)(ModalBody, { children: body }) })] })] }));
|
|
18
|
-
}
|
|
19
|
-
exports.AboutDialogToolbarButton = AboutDialogToolbarButton;
|
package/lib/app/about/index.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./AboutDialogToolbarButton"), exports);
|