react-science 10.0.0 → 11.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/accordion/accordion.d.ts +5 -0
- package/lib/components/accordion/accordion.d.ts.map +1 -1
- package/lib/components/accordion/accordion.js +6 -3
- package/lib/components/accordion/accordion.js.map +1 -1
- package/lib/components/accordion/accordion_context.d.ts +1 -0
- package/lib/components/accordion/accordion_context.d.ts.map +1 -1
- package/lib/components/accordion/accordion_context.js +2 -1
- package/lib/components/accordion/accordion_context.js.map +1 -1
- package/lib/components/accordion/accordion_context.provider.d.ts +1 -0
- package/lib/components/accordion/accordion_context.provider.d.ts.map +1 -1
- package/lib/components/accordion/accordion_context.provider.js +4 -2
- package/lib/components/accordion/accordion_context.provider.js.map +1 -1
- package/lib/components/accordion/accordion_context.state.d.ts +1 -0
- package/lib/components/accordion/accordion_context.state.d.ts.map +1 -1
- package/lib/components/accordion/accordion_context.state.js.map +1 -1
- package/lib/components/color-picker/preview/ColorPreview.d.ts +8 -1
- package/lib/components/color-picker/preview/ColorPreview.d.ts.map +1 -1
- package/lib/components/color-picker/preview/ColorPreview.js.map +1 -1
- package/package.json +39 -47
- package/src/components/accordion/accordion.tsx +31 -17
- package/src/components/accordion/accordion_context.provider.tsx +8 -3
- package/src/components/accordion/accordion_context.state.ts +1 -0
- package/src/components/accordion/accordion_context.ts +2 -1
- package/src/components/color-picker/preview/ColorPreview.tsx +5 -1
- package/lib/app/about/AboutDialogToolbarButton.d.ts +0 -10
- package/lib/app/about/AboutDialogToolbarButton.d.ts.map +0 -1
- package/lib/app/about/AboutDialogToolbarButton.js +0 -9
- package/lib/app/about/AboutDialogToolbarButton.js.map +0 -1
- package/lib/app/about/index.d.ts +0 -2
- package/lib/app/about/index.d.ts.map +0 -1
- package/lib/app/about/index.js +0 -2
- package/lib/app/about/index.js.map +0 -1
- package/lib/app/explorer/ExplorerPlotView.d.ts +0 -2
- package/lib/app/explorer/ExplorerPlotView.d.ts.map +0 -1
- package/lib/app/explorer/ExplorerPlotView.js +0 -16
- package/lib/app/explorer/ExplorerPlotView.js.map +0 -1
- package/lib/app/explorer/MeasurementExplorer.d.ts +0 -11
- package/lib/app/explorer/MeasurementExplorer.d.ts.map +0 -1
- package/lib/app/explorer/MeasurementExplorer.js +0 -114
- package/lib/app/explorer/MeasurementExplorer.js.map +0 -1
- package/lib/app/explorer/MeasurementExplorerWithState.d.ts +0 -2
- package/lib/app/explorer/MeasurementExplorerWithState.d.ts.map +0 -1
- package/lib/app/explorer/MeasurementExplorerWithState.js +0 -11
- package/lib/app/explorer/MeasurementExplorerWithState.js.map +0 -1
- package/lib/app/explorer/index.d.ts +0 -3
- package/lib/app/explorer/index.d.ts.map +0 -1
- package/lib/app/explorer/index.js +0 -3
- package/lib/app/explorer/index.js.map +0 -1
- package/lib/app/helpers/MeasurementPlot.d.ts +0 -22
- package/lib/app/helpers/MeasurementPlot.d.ts.map +0 -1
- package/lib/app/helpers/MeasurementPlot.js +0 -39
- package/lib/app/helpers/MeasurementPlot.js.map +0 -1
- package/lib/app/helpers/MeasurementVariableSelect.d.ts +0 -9
- package/lib/app/helpers/MeasurementVariableSelect.d.ts.map +0 -1
- package/lib/app/helpers/MeasurementVariableSelect.js +0 -11
- package/lib/app/helpers/MeasurementVariableSelect.js.map +0 -1
- package/lib/app/helpers/getColorFromConfig.d.ts +0 -3
- package/lib/app/helpers/getColorFromConfig.d.ts.map +0 -1
- package/lib/app/helpers/getColorFromConfig.js +0 -11
- package/lib/app/helpers/getColorFromConfig.js.map +0 -1
- package/lib/app/helpers/index.d.ts +0 -6
- package/lib/app/helpers/index.d.ts.map +0 -1
- package/lib/app/helpers/index.js +0 -6
- package/lib/app/helpers/index.js.map +0 -1
- package/lib/app/helpers/react-plot.d.ts +0 -8
- package/lib/app/helpers/react-plot.d.ts.map +0 -1
- package/lib/app/helpers/react-plot.js +0 -44
- package/lib/app/helpers/react-plot.js.map +0 -1
- package/lib/app/helpers/splitEntries.d.ts +0 -6
- package/lib/app/helpers/splitEntries.d.ts.map +0 -1
- package/lib/app/helpers/splitEntries.js +0 -16
- package/lib/app/helpers/splitEntries.js.map +0 -1
- package/lib/app/hooks/file-loading.d.ts +0 -9
- package/lib/app/hooks/file-loading.d.ts.map +0 -1
- package/lib/app/hooks/file-loading.js +0 -36
- package/lib/app/hooks/file-loading.js.map +0 -1
- package/lib/app/hooks/index.d.ts +0 -2
- package/lib/app/hooks/index.d.ts.map +0 -1
- package/lib/app/hooks/index.js +0 -2
- package/lib/app/hooks/index.js.map +0 -1
- package/lib/app/index.d.ts +0 -6
- package/lib/app/index.d.ts.map +0 -1
- package/lib/app/index.js +0 -6
- package/lib/app/index.js.map +0 -1
- package/lib/app/kinds/index.d.ts +0 -4
- package/lib/app/kinds/index.d.ts.map +0 -1
- package/lib/app/kinds/index.js +0 -4
- package/lib/app/kinds/index.js.map +0 -1
- package/lib/app/kinds/ir/IrPeaksPanel.d.ts +0 -25
- package/lib/app/kinds/ir/IrPeaksPanel.d.ts.map +0 -1
- package/lib/app/kinds/ir/IrPeaksPanel.js +0 -28
- package/lib/app/kinds/ir/IrPeaksPanel.js.map +0 -1
- package/lib/app/kinds/ir/index.d.ts +0 -2
- package/lib/app/kinds/ir/index.d.ts.map +0 -1
- package/lib/app/kinds/ir/index.js +0 -2
- package/lib/app/kinds/ir/index.js.map +0 -1
- package/lib/app/kinds/iv/index.d.ts +0 -2
- package/lib/app/kinds/iv/index.d.ts.map +0 -1
- package/lib/app/kinds/iv/index.js +0 -2
- package/lib/app/kinds/iv/index.js.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvMeasurementsPlot.d.ts +0 -2
- package/lib/app/kinds/iv/plot-view/IvMeasurementsPlot.d.ts.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvMeasurementsPlot.js +0 -50
- package/lib/app/kinds/iv/plot-view/IvMeasurementsPlot.js.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvPlotVariablesSelector.d.ts +0 -2
- package/lib/app/kinds/iv/plot-view/IvPlotVariablesSelector.d.ts.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvPlotVariablesSelector.js +0 -30
- package/lib/app/kinds/iv/plot-view/IvPlotVariablesSelector.js.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvPlotView.d.ts +0 -2
- package/lib/app/kinds/iv/plot-view/IvPlotView.d.ts.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvPlotView.js +0 -32
- package/lib/app/kinds/iv/plot-view/IvPlotView.js.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvSeries.d.ts +0 -11
- package/lib/app/kinds/iv/plot-view/IvSeries.d.ts.map +0 -1
- package/lib/app/kinds/iv/plot-view/IvSeries.js +0 -23
- package/lib/app/kinds/iv/plot-view/IvSeries.js.map +0 -1
- package/lib/app/kinds/mass/MassPlotView.d.ts +0 -2
- package/lib/app/kinds/mass/MassPlotView.d.ts.map +0 -1
- package/lib/app/kinds/mass/MassPlotView.js +0 -11
- package/lib/app/kinds/mass/MassPlotView.js.map +0 -1
- package/lib/app/kinds/mass/MeasurementMassPlot.d.ts +0 -3
- package/lib/app/kinds/mass/MeasurementMassPlot.d.ts.map +0 -1
- package/lib/app/kinds/mass/MeasurementMassPlot.js +0 -75
- package/lib/app/kinds/mass/MeasurementMassPlot.js.map +0 -1
- package/lib/app/kinds/mass/index.d.ts +0 -3
- package/lib/app/kinds/mass/index.d.ts.map +0 -1
- package/lib/app/kinds/mass/index.js +0 -3
- package/lib/app/kinds/mass/index.js.map +0 -1
- package/lib/app/panels/SignalProcessingPanel.d.ts +0 -11
- package/lib/app/panels/SignalProcessingPanel.d.ts.map +0 -1
- package/lib/app/panels/SignalProcessingPanel.js +0 -104
- package/lib/app/panels/SignalProcessingPanel.js.map +0 -1
- package/lib/app/panels/index.d.ts +0 -5
- package/lib/app/panels/index.d.ts.map +0 -1
- package/lib/app/panels/index.js +0 -5
- package/lib/app/panels/index.js.map +0 -1
- package/lib/app/panels/measurement-config/MeasurementConfigPanel.d.ts +0 -2
- package/lib/app/panels/measurement-config/MeasurementConfigPanel.d.ts.map +0 -1
- package/lib/app/panels/measurement-config/MeasurementConfigPanel.js +0 -25
- package/lib/app/panels/measurement-config/MeasurementConfigPanel.js.map +0 -1
- package/lib/app/panels/measurement-config/MeasurementConfigPanelAccordion.d.ts +0 -2
- package/lib/app/panels/measurement-config/MeasurementConfigPanelAccordion.d.ts.map +0 -1
- package/lib/app/panels/measurement-config/MeasurementConfigPanelAccordion.js +0 -14
- package/lib/app/panels/measurement-config/MeasurementConfigPanelAccordion.js.map +0 -1
- package/lib/app/panels/measurement-config/index.d.ts +0 -3
- package/lib/app/panels/measurement-config/index.d.ts.map +0 -1
- package/lib/app/panels/measurement-config/index.js +0 -3
- package/lib/app/panels/measurement-config/index.js.map +0 -1
- package/lib/app/panels/measurement-info/MeasurementInfoPanel.d.ts +0 -2
- package/lib/app/panels/measurement-info/MeasurementInfoPanel.d.ts.map +0 -1
- package/lib/app/panels/measurement-info/MeasurementInfoPanel.js +0 -23
- package/lib/app/panels/measurement-info/MeasurementInfoPanel.js.map +0 -1
- package/lib/app/panels/measurement-info/MeasurementInfoPanelAccordion.d.ts +0 -2
- package/lib/app/panels/measurement-info/MeasurementInfoPanelAccordion.d.ts.map +0 -1
- package/lib/app/panels/measurement-info/MeasurementInfoPanelAccordion.js +0 -7
- package/lib/app/panels/measurement-info/MeasurementInfoPanelAccordion.js.map +0 -1
- package/lib/app/panels/measurement-info/index.d.ts +0 -3
- package/lib/app/panels/measurement-info/index.d.ts.map +0 -1
- package/lib/app/panels/measurement-info/index.js +0 -3
- package/lib/app/panels/measurement-info/index.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementCheckbox.d.ts +0 -8
- package/lib/app/panels/measurements/MeasurementCheckbox.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementCheckbox.js +0 -22
- package/lib/app/panels/measurements/MeasurementCheckbox.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementColorPreview.d.ts +0 -9
- package/lib/app/panels/measurements/MeasurementColorPreview.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementColorPreview.js +0 -45
- package/lib/app/panels/measurements/MeasurementColorPreview.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementVisibilityToggle.d.ts +0 -12
- package/lib/app/panels/measurements/MeasurementVisibilityToggle.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementVisibilityToggle.js +0 -26
- package/lib/app/panels/measurements/MeasurementVisibilityToggle.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementsPanel.d.ts +0 -4
- package/lib/app/panels/measurements/MeasurementsPanel.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementsPanel.js +0 -42
- package/lib/app/panels/measurements/MeasurementsPanel.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementsPanelAccordion.d.ts +0 -2
- package/lib/app/panels/measurements/MeasurementsPanelAccordion.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementsPanelAccordion.js +0 -20
- package/lib/app/panels/measurements/MeasurementsPanelAccordion.js.map +0 -1
- package/lib/app/panels/measurements/MeasurementsTable.d.ts +0 -6
- package/lib/app/panels/measurements/MeasurementsTable.d.ts.map +0 -1
- package/lib/app/panels/measurements/MeasurementsTable.js +0 -159
- package/lib/app/panels/measurements/MeasurementsTable.js.map +0 -1
- package/lib/app/panels/measurements/index.d.ts +0 -9
- package/lib/app/panels/measurements/index.d.ts.map +0 -1
- package/lib/app/panels/measurements/index.js +0 -9
- package/lib/app/panels/measurements/index.js.map +0 -1
- package/lib/app/panels/measurements/measurement_panel_context.d.ts +0 -7
- package/lib/app/panels/measurements/measurement_panel_context.d.ts.map +0 -1
- package/lib/app/panels/measurements/measurement_panel_context.js +0 -10
- package/lib/app/panels/measurements/measurement_panel_context.js.map +0 -1
- package/lib/app/panels/measurements/measurement_panel_context.provider.d.ts +0 -7
- package/lib/app/panels/measurements/measurement_panel_context.provider.d.ts.map +0 -1
- package/lib/app/panels/measurements/measurement_panel_context.provider.js +0 -6
- package/lib/app/panels/measurements/measurement_panel_context.provider.js.map +0 -1
- package/lib/app-data/enhancers/enhance.d.ts +0 -8
- package/lib/app-data/enhancers/enhance.d.ts.map +0 -1
- package/lib/app-data/enhancers/enhance.js +0 -13
- package/lib/app-data/enhancers/enhance.js.map +0 -1
- package/lib/app-data/enhancers/index.d.ts +0 -2
- package/lib/app-data/enhancers/index.d.ts.map +0 -1
- package/lib/app-data/enhancers/index.js +0 -2
- package/lib/app-data/enhancers/index.js.map +0 -1
- package/lib/app-data/helpers/index.d.ts +0 -2
- package/lib/app-data/helpers/index.d.ts.map +0 -1
- package/lib/app-data/helpers/index.js +0 -2
- package/lib/app-data/helpers/index.js.map +0 -1
- package/lib/app-data/helpers/variables.d.ts +0 -6
- package/lib/app-data/helpers/variables.d.ts.map +0 -1
- package/lib/app-data/helpers/variables.js +0 -20
- package/lib/app-data/helpers/variables.js.map +0 -1
- package/lib/app-data/index.d.ts +0 -7
- package/lib/app-data/index.d.ts.map +0 -1
- package/lib/app-data/index.js +0 -7
- package/lib/app-data/index.js.map +0 -1
- package/lib/app-data/kinds/index.d.ts +0 -3
- package/lib/app-data/kinds/index.d.ts.map +0 -1
- package/lib/app-data/kinds/index.js +0 -3
- package/lib/app-data/kinds/index.js.map +0 -1
- package/lib/app-data/kinds/ir/IrMeasurement.d.ts +0 -13
- package/lib/app-data/kinds/ir/IrMeasurement.d.ts.map +0 -1
- package/lib/app-data/kinds/ir/IrMeasurement.js +0 -2
- package/lib/app-data/kinds/ir/IrMeasurement.js.map +0 -1
- package/lib/app-data/kinds/ir/IrPeak.d.ts +0 -8
- package/lib/app-data/kinds/ir/IrPeak.d.ts.map +0 -1
- package/lib/app-data/kinds/ir/IrPeak.js +0 -2
- package/lib/app-data/kinds/ir/IrPeak.js.map +0 -1
- package/lib/app-data/kinds/ir/index.d.ts +0 -5
- package/lib/app-data/kinds/ir/index.d.ts.map +0 -1
- package/lib/app-data/kinds/ir/index.js +0 -5
- package/lib/app-data/kinds/ir/index.js.map +0 -1
- package/lib/app-data/kinds/ir/irAutoPeakPickingEnhancer.d.ts +0 -20
- package/lib/app-data/kinds/ir/irAutoPeakPickingEnhancer.d.ts.map +0 -1
- package/lib/app-data/kinds/ir/irAutoPeakPickingEnhancer.js +0 -50
- package/lib/app-data/kinds/ir/irAutoPeakPickingEnhancer.js.map +0 -1
- package/lib/app-data/kinds/ir/irMeasurementEnhancer.d.ts +0 -8
- package/lib/app-data/kinds/ir/irMeasurementEnhancer.d.ts.map +0 -1
- package/lib/app-data/kinds/ir/irMeasurementEnhancer.js +0 -47
- package/lib/app-data/kinds/ir/irMeasurementEnhancer.js.map +0 -1
- package/lib/app-data/kinds/iv/IvMeasurement.d.ts +0 -3
- package/lib/app-data/kinds/iv/IvMeasurement.d.ts.map +0 -1
- package/lib/app-data/kinds/iv/IvMeasurement.js +0 -2
- package/lib/app-data/kinds/iv/IvMeasurement.js.map +0 -1
- package/lib/app-data/kinds/iv/index.d.ts +0 -2
- package/lib/app-data/kinds/iv/index.d.ts.map +0 -1
- package/lib/app-data/kinds/iv/index.js +0 -2
- package/lib/app-data/kinds/iv/index.js.map +0 -1
- package/lib/app-data/loaders/biologicLoader.d.ts +0 -11
- package/lib/app-data/loaders/biologicLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/biologicLoader.js +0 -141
- package/lib/app-data/loaders/biologicLoader.js.map +0 -1
- package/lib/app-data/loaders/cdfLoader.d.ts +0 -5
- package/lib/app-data/loaders/cdfLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/cdfLoader.js +0 -164
- package/lib/app-data/loaders/cdfLoader.js.map +0 -1
- package/lib/app-data/loaders/index.d.ts +0 -9
- package/lib/app-data/loaders/index.d.ts.map +0 -1
- package/lib/app-data/loaders/index.js +0 -9
- package/lib/app-data/loaders/index.js.map +0 -1
- package/lib/app-data/loaders/jcampLoader.d.ts +0 -11
- package/lib/app-data/loaders/jcampLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/jcampLoader.js +0 -100
- package/lib/app-data/loaders/jcampLoader.js.map +0 -1
- package/lib/app-data/loaders/loadMeasurements.d.ts +0 -14
- package/lib/app-data/loaders/loadMeasurements.d.ts.map +0 -1
- package/lib/app-data/loaders/loadMeasurements.js +0 -37
- package/lib/app-data/loaders/loadMeasurements.js.map +0 -1
- package/lib/app-data/loaders/proprietary/agilent/cary500Loader.d.ts +0 -5
- package/lib/app-data/loaders/proprietary/agilent/cary500Loader.d.ts.map +0 -1
- package/lib/app-data/loaders/proprietary/agilent/cary500Loader.js +0 -71
- package/lib/app-data/loaders/proprietary/agilent/cary500Loader.js.map +0 -1
- package/lib/app-data/loaders/spcLoader.d.ts +0 -11
- package/lib/app-data/loaders/spcLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/spcLoader.js +0 -41
- package/lib/app-data/loaders/spcLoader.js.map +0 -1
- package/lib/app-data/loaders/utility/getMeasurementInfoFromFile.d.ts +0 -20
- package/lib/app-data/loaders/utility/getMeasurementInfoFromFile.d.ts.map +0 -1
- package/lib/app-data/loaders/utility/getMeasurementInfoFromFile.js +0 -17
- package/lib/app-data/loaders/utility/getMeasurementInfoFromFile.js.map +0 -1
- package/lib/app-data/loaders/utility/index.d.ts +0 -4
- package/lib/app-data/loaders/utility/index.d.ts.map +0 -1
- package/lib/app-data/loaders/utility/index.js +0 -4
- package/lib/app-data/loaders/utility/index.js.map +0 -1
- package/lib/app-data/loaders/utility/measurementLoader.d.ts +0 -6
- package/lib/app-data/loaders/utility/measurementLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/utility/measurementLoader.js +0 -14
- package/lib/app-data/loaders/utility/measurementLoader.js.map +0 -1
- package/lib/app-data/loaders/utility/parserLog.d.ts +0 -10
- package/lib/app-data/loaders/utility/parserLog.d.ts.map +0 -1
- package/lib/app-data/loaders/utility/parserLog.js +0 -19
- package/lib/app-data/loaders/utility/parserLog.js.map +0 -1
- package/lib/app-data/loaders/wdfLoader.d.ts +0 -11
- package/lib/app-data/loaders/wdfLoader.d.ts.map +0 -1
- package/lib/app-data/loaders/wdfLoader.js +0 -104
- package/lib/app-data/loaders/wdfLoader.js.map +0 -1
- package/lib/app-data/state/app_state.actions.d.ts +0 -38
- package/lib/app-data/state/app_state.actions.d.ts.map +0 -1
- package/lib/app-data/state/app_state.actions.js +0 -2
- package/lib/app-data/state/app_state.actions.js.map +0 -1
- package/lib/app-data/state/app_state.d.ts +0 -1323
- package/lib/app-data/state/app_state.d.ts.map +0 -1
- package/lib/app-data/state/app_state.js +0 -43
- package/lib/app-data/state/app_state.js.map +0 -1
- package/lib/app-data/state/app_state.provider.d.ts +0 -5
- package/lib/app-data/state/app_state.provider.d.ts.map +0 -1
- package/lib/app-data/state/app_state.provider.js +0 -8
- package/lib/app-data/state/app_state.provider.js.map +0 -1
- package/lib/app-data/state/data/AppData.d.ts +0 -69
- package/lib/app-data/state/data/AppData.d.ts.map +0 -1
- package/lib/app-data/state/data/AppData.js +0 -2
- package/lib/app-data/state/data/AppData.js.map +0 -1
- package/lib/app-data/state/data/data.helpers.d.ts +0 -54
- package/lib/app-data/state/data/data.helpers.d.ts.map +0 -1
- package/lib/app-data/state/data/data.helpers.js +0 -119
- package/lib/app-data/state/data/data.helpers.js.map +0 -1
- package/lib/app-data/state/data/getEmptyAppData.d.ts +0 -3
- package/lib/app-data/state/data/getEmptyAppData.d.ts.map +0 -1
- package/lib/app-data/state/data/getEmptyAppData.js +0 -17
- package/lib/app-data/state/data/getEmptyAppData.js.map +0 -1
- package/lib/app-data/state/data/index.d.ts +0 -5
- package/lib/app-data/state/data/index.d.ts.map +0 -1
- package/lib/app-data/state/data/index.js +0 -5
- package/lib/app-data/state/data/index.js.map +0 -1
- package/lib/app-data/state/data/kinds.d.ts +0 -4
- package/lib/app-data/state/data/kinds.d.ts.map +0 -1
- package/lib/app-data/state/data/kinds.js +0 -14
- package/lib/app-data/state/data/kinds.js.map +0 -1
- package/lib/app-data/state/index.d.ts +0 -6
- package/lib/app-data/state/index.d.ts.map +0 -1
- package/lib/app-data/state/index.js +0 -6
- package/lib/app-data/state/index.js.map +0 -1
- package/lib/app-data/state/producers/app_state_producer.d.ts +0 -7
- package/lib/app-data/state/producers/app_state_producer.d.ts.map +0 -1
- package/lib/app-data/state/producers/app_state_producer.js +0 -38
- package/lib/app-data/state/producers/app_state_producer.js.map +0 -1
- package/lib/app-data/state/producers/index.d.ts +0 -2
- package/lib/app-data/state/producers/index.d.ts.map +0 -1
- package/lib/app-data/state/producers/index.js +0 -2
- package/lib/app-data/state/producers/index.js.map +0 -1
- package/lib/app-data/state/producers/measurements/addMeasurements.d.ts +0 -3
- package/lib/app-data/state/producers/measurements/addMeasurements.d.ts.map +0 -1
- package/lib/app-data/state/producers/measurements/addMeasurements.js +0 -55
- package/lib/app-data/state/producers/measurements/addMeasurements.js.map +0 -1
- package/lib/app-data/state/producers/measurements/measurements.d.ts +0 -10
- package/lib/app-data/state/producers/measurements/measurements.d.ts.map +0 -1
- package/lib/app-data/state/producers/measurements/measurements.js +0 -95
- package/lib/app-data/state/producers/measurements/measurements.js.map +0 -1
- package/lib/app-data/state/producers/plot-view/helpers/zoom.d.ts +0 -5
- package/lib/app-data/state/producers/plot-view/helpers/zoom.d.ts.map +0 -1
- package/lib/app-data/state/producers/plot-view/helpers/zoom.js +0 -43
- package/lib/app-data/state/producers/plot-view/helpers/zoom.js.map +0 -1
- package/lib/app-data/state/producers/plot-view/plot-view.d.ts +0 -5
- package/lib/app-data/state/producers/plot-view/plot-view.d.ts.map +0 -1
- package/lib/app-data/state/producers/plot-view/plot-view.js +0 -20
- package/lib/app-data/state/producers/plot-view/plot-view.js.map +0 -1
- package/lib/app-data/state/producers/types.d.ts +0 -8
- package/lib/app-data/state/producers/types.d.ts.map +0 -1
- package/lib/app-data/state/producers/types.js +0 -2
- package/lib/app-data/state/producers/types.js.map +0 -1
- package/lib/app-data/state/settings/app_settings.d.ts +0 -9
- package/lib/app-data/state/settings/app_settings.d.ts.map +0 -1
- package/lib/app-data/state/settings/app_settings.js +0 -2
- package/lib/app-data/state/settings/app_settings.js.map +0 -1
- package/lib/app-data/state/settings/get_empty_app_settings.d.ts +0 -3
- package/lib/app-data/state/settings/get_empty_app_settings.d.ts.map +0 -1
- package/lib/app-data/state/settings/get_empty_app_settings.js +0 -8
- package/lib/app-data/state/settings/get_empty_app_settings.js.map +0 -1
- package/lib/app-data/state/settings/index.d.ts +0 -3
- package/lib/app-data/state/settings/index.d.ts.map +0 -1
- package/lib/app-data/state/settings/index.js +0 -3
- package/lib/app-data/state/settings/index.js.map +0 -1
- package/lib/app-data/state/view/app_view.d.ts +0 -35
- package/lib/app-data/state/view/app_view.d.ts.map +0 -1
- package/lib/app-data/state/view/app_view.js +0 -2
- package/lib/app-data/state/view/app_view.js.map +0 -1
- package/lib/app-data/state/view/get_empty_app_view.d.ts +0 -3
- package/lib/app-data/state/view/get_empty_app_view.d.ts.map +0 -1
- package/lib/app-data/state/view/get_empty_app_view.js +0 -8
- package/lib/app-data/state/view/get_empty_app_view.js.map +0 -1
- package/lib/app-data/state/view/index.d.ts +0 -3
- package/lib/app-data/state/view/index.d.ts.map +0 -1
- package/lib/app-data/state/view/index.js +0 -3
- package/lib/app-data/state/view/index.js.map +0 -1
- package/lib/app-data/utils.d.ts +0 -2
- package/lib/app-data/utils.d.ts.map +0 -1
- package/lib/app-data/utils.js +0 -12
- package/lib/app-data/utils.js.map +0 -1
- package/src/app/about/AboutDialogToolbarButton.tsx +0 -35
- package/src/app/about/index.ts +0 -1
- package/src/app/explorer/ExplorerPlotView.tsx +0 -17
- package/src/app/explorer/MeasurementExplorer.tsx +0 -196
- package/src/app/explorer/MeasurementExplorerWithState.tsx +0 -19
- package/src/app/explorer/index.ts +0 -2
- package/src/app/helpers/MeasurementPlot.tsx +0 -92
- package/src/app/helpers/MeasurementVariableSelect.tsx +0 -33
- package/src/app/helpers/getColorFromConfig.ts +0 -12
- package/src/app/helpers/index.ts +0 -5
- package/src/app/helpers/react-plot.tsx +0 -130
- package/src/app/helpers/splitEntries.ts +0 -26
- package/src/app/hooks/file-loading.ts +0 -53
- package/src/app/hooks/index.ts +0 -1
- package/src/app/index.ts +0 -5
- package/src/app/kinds/index.ts +0 -3
- package/src/app/kinds/ir/IrPeaksPanel.tsx +0 -65
- package/src/app/kinds/ir/index.ts +0 -1
- package/src/app/kinds/iv/index.ts +0 -1
- package/src/app/kinds/iv/plot-view/IvMeasurementsPlot.tsx +0 -112
- package/src/app/kinds/iv/plot-view/IvPlotVariablesSelector.tsx +0 -63
- package/src/app/kinds/iv/plot-view/IvPlotView.tsx +0 -55
- package/src/app/kinds/iv/plot-view/IvSeries.tsx +0 -37
- package/src/app/kinds/mass/MassPlotView.tsx +0 -19
- package/src/app/kinds/mass/MeasurementMassPlot.tsx +0 -142
- package/src/app/kinds/mass/index.ts +0 -2
- package/src/app/panels/SignalProcessingPanel.tsx +0 -218
- package/src/app/panels/index.ts +0 -4
- package/src/app/panels/measurement-config/MeasurementConfigPanel.tsx +0 -98
- package/src/app/panels/measurement-config/MeasurementConfigPanelAccordion.tsx +0 -26
- package/src/app/panels/measurement-config/index.ts +0 -2
- package/src/app/panels/measurement-info/MeasurementInfoPanel.tsx +0 -28
- package/src/app/panels/measurement-info/MeasurementInfoPanelAccordion.tsx +0 -11
- package/src/app/panels/measurement-info/index.ts +0 -2
- package/src/app/panels/measurements/MeasurementCheckbox.tsx +0 -37
- package/src/app/panels/measurements/MeasurementColorPreview.tsx +0 -99
- package/src/app/panels/measurements/MeasurementVisibilityToggle.tsx +0 -60
- package/src/app/panels/measurements/MeasurementsPanel.tsx +0 -86
- package/src/app/panels/measurements/MeasurementsPanelAccordion.tsx +0 -35
- package/src/app/panels/measurements/MeasurementsTable.tsx +0 -350
- package/src/app/panels/measurements/index.ts +0 -11
- package/src/app/panels/measurements/measurement_panel_context.provider.tsx +0 -18
- package/src/app/panels/measurements/measurement_panel_context.ts +0 -18
- package/src/app-data/enhancers/enhance.ts +0 -26
- package/src/app-data/enhancers/index.ts +0 -1
- package/src/app-data/helpers/index.ts +0 -1
- package/src/app-data/helpers/variables.ts +0 -29
- package/src/app-data/index.ts +0 -6
- package/src/app-data/kinds/index.ts +0 -2
- package/src/app-data/kinds/ir/IrMeasurement.ts +0 -15
- package/src/app-data/kinds/ir/IrPeak.ts +0 -8
- package/src/app-data/kinds/ir/index.ts +0 -4
- package/src/app-data/kinds/ir/irAutoPeakPickingEnhancer.ts +0 -94
- package/src/app-data/kinds/ir/irMeasurementEnhancer.ts +0 -51
- package/src/app-data/kinds/iv/IvMeasurement.ts +0 -3
- package/src/app-data/kinds/iv/index.ts +0 -1
- package/src/app-data/loaders/biologicLoader.ts +0 -166
- package/src/app-data/loaders/cdfLoader.ts +0 -206
- package/src/app-data/loaders/index.ts +0 -8
- package/src/app-data/loaders/jcampLoader.ts +0 -105
- package/src/app-data/loaders/loadMeasurements.ts +0 -53
- package/src/app-data/loaders/proprietary/agilent/cary500Loader.ts +0 -82
- package/src/app-data/loaders/spcLoader.ts +0 -55
- package/src/app-data/loaders/utility/getMeasurementInfoFromFile.ts +0 -21
- package/src/app-data/loaders/utility/index.ts +0 -3
- package/src/app-data/loaders/utility/measurementLoader.ts +0 -26
- package/src/app-data/loaders/utility/parserLog.ts +0 -39
- package/src/app-data/loaders/wdfLoader.ts +0 -140
- package/src/app-data/state/app_state.actions.ts +0 -49
- package/src/app-data/state/app_state.provider.tsx +0 -24
- package/src/app-data/state/app_state.ts +0 -70
- package/src/app-data/state/data/AppData.ts +0 -77
- package/src/app-data/state/data/data.helpers.ts +0 -192
- package/src/app-data/state/data/getEmptyAppData.ts +0 -18
- package/src/app-data/state/data/index.ts +0 -4
- package/src/app-data/state/data/kinds.ts +0 -16
- package/src/app-data/state/index.ts +0 -14
- package/src/app-data/state/producers/app_state_producer.ts +0 -65
- package/src/app-data/state/producers/index.ts +0 -1
- package/src/app-data/state/producers/measurements/addMeasurements.ts +0 -83
- package/src/app-data/state/producers/measurements/measurements.ts +0 -143
- package/src/app-data/state/producers/plot-view/helpers/zoom.ts +0 -63
- package/src/app-data/state/producers/plot-view/plot-view.ts +0 -29
- package/src/app-data/state/producers/types.ts +0 -11
- package/src/app-data/state/settings/app_settings.ts +0 -8
- package/src/app-data/state/settings/get_empty_app_settings.ts +0 -9
- package/src/app-data/state/settings/index.ts +0 -2
- package/src/app-data/state/view/app_view.ts +0 -29
- package/src/app-data/state/view/get_empty_app_view.ts +0 -9
- package/src/app-data/state/view/index.ts +0 -2
- package/src/app-data/utils.ts +0 -13
- package/src/test-utils.ts +0 -11
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
import styled from '@emotion/styled';
|
|
2
|
-
import { useMemo, useState } from 'react';
|
|
3
|
-
import { FaArrowsAltH, FaExchangeAlt } from 'react-icons/fa';
|
|
4
|
-
|
|
5
|
-
import type { MeasurementPlotProps } from '../helpers/index.js';
|
|
6
|
-
import { MeasurementPlot } from '../helpers/index.js';
|
|
7
|
-
|
|
8
|
-
export type MeasurementExplorerProps = Omit<
|
|
9
|
-
MeasurementPlotProps,
|
|
10
|
-
keyof ExplorerInfo
|
|
11
|
-
>;
|
|
12
|
-
interface ExplorerInfo {
|
|
13
|
-
dataIndex: number;
|
|
14
|
-
xVariableName: string;
|
|
15
|
-
yVariableName: string;
|
|
16
|
-
flipHorizontalAxis: boolean;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const MeasurementExplorerRoot = styled.div`
|
|
20
|
-
display: flex;
|
|
21
|
-
flex-direction: column;
|
|
22
|
-
`;
|
|
23
|
-
|
|
24
|
-
const MeasurementExplorerContent = styled.div`
|
|
25
|
-
display: flex;
|
|
26
|
-
justify-content: space-around;
|
|
27
|
-
margin-bottom: 20px;
|
|
28
|
-
`;
|
|
29
|
-
|
|
30
|
-
const MeasurementExplorerSelect = styled.select`
|
|
31
|
-
cursor: pointer;
|
|
32
|
-
border: 1px solid black;
|
|
33
|
-
padding: 1px;
|
|
34
|
-
margin-left: 2px;
|
|
35
|
-
`;
|
|
36
|
-
|
|
37
|
-
const MeasurementExplorerAction = styled.div`
|
|
38
|
-
padding: 1px;
|
|
39
|
-
display: flex;
|
|
40
|
-
`;
|
|
41
|
-
|
|
42
|
-
export function MeasurementExplorer(props: MeasurementExplorerProps) {
|
|
43
|
-
const { measurement, width = '100%', height = '100%' } = props;
|
|
44
|
-
const measurementsArray = useMemo(
|
|
45
|
-
() => (Array.isArray(measurement) ? measurement : [measurement]),
|
|
46
|
-
[measurement],
|
|
47
|
-
);
|
|
48
|
-
const varNames = useMemo(() => {
|
|
49
|
-
const varNames: string[][] = [];
|
|
50
|
-
for (const [i, { data }] of measurementsArray.entries()) {
|
|
51
|
-
for (const { variables } of data) {
|
|
52
|
-
const names: string[] = [];
|
|
53
|
-
for (const varName in variables) {
|
|
54
|
-
if (i === 0) {
|
|
55
|
-
names.push(varName);
|
|
56
|
-
} else if (!varNames.flat().includes(varName)) {
|
|
57
|
-
throw new Error(
|
|
58
|
-
`Measurements selected does not have the same variables `,
|
|
59
|
-
);
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
varNames.push(names);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
return varNames;
|
|
66
|
-
}, [measurementsArray]);
|
|
67
|
-
|
|
68
|
-
function defaultInfo(dataIndex: number) {
|
|
69
|
-
return {
|
|
70
|
-
dataIndex,
|
|
71
|
-
xVariableName: varNames[dataIndex].includes('x')
|
|
72
|
-
? 'x'
|
|
73
|
-
: varNames[dataIndex][0],
|
|
74
|
-
yVariableName: varNames[dataIndex].includes('y')
|
|
75
|
-
? 'y'
|
|
76
|
-
: varNames[dataIndex][1],
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
const [info, setInfo] = useState<ExplorerInfo>({
|
|
81
|
-
flipHorizontalAxis: false,
|
|
82
|
-
...defaultInfo(0),
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
/* variables for this measurement are mapped into `id - label (units)`
|
|
86
|
-
`id` necessary bc files may have repeated labels
|
|
87
|
-
*/
|
|
88
|
-
function dropdownVariables(axis: 'x' | 'y') {
|
|
89
|
-
function formatVar(varKey: string) {
|
|
90
|
-
const { label, units } = variables[varKey];
|
|
91
|
-
const formatUnit = units ? ` (${units})` : '';
|
|
92
|
-
const formatVarKey = `${varKey} - `;
|
|
93
|
-
return formatVarKey + label + formatUnit;
|
|
94
|
-
}
|
|
95
|
-
const { variables } = measurementsArray[0].data[info.dataIndex];
|
|
96
|
-
const oppositeAxis = axis === 'x' ? 'yVariableName' : 'xVariableName';
|
|
97
|
-
return varNames[info.dataIndex].map((d) => {
|
|
98
|
-
if (d !== info[oppositeAxis]) {
|
|
99
|
-
return (
|
|
100
|
-
<option key={d} value={d}>
|
|
101
|
-
{formatVar(d)}
|
|
102
|
-
</option>
|
|
103
|
-
);
|
|
104
|
-
}
|
|
105
|
-
return null;
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
return (
|
|
110
|
-
<MeasurementExplorerRoot style={{ width, height }}>
|
|
111
|
-
<MeasurementExplorerContent>
|
|
112
|
-
<div>
|
|
113
|
-
<label>dataIndex: </label>
|
|
114
|
-
<MeasurementExplorerSelect
|
|
115
|
-
onChange={({ target }) => {
|
|
116
|
-
const value = Number(target.value);
|
|
117
|
-
if (value !== undefined && !Number.isNaN(value)) {
|
|
118
|
-
setInfo(({ flipHorizontalAxis }) => ({
|
|
119
|
-
flipHorizontalAxis,
|
|
120
|
-
...defaultInfo(value),
|
|
121
|
-
}));
|
|
122
|
-
}
|
|
123
|
-
}}
|
|
124
|
-
>
|
|
125
|
-
{measurementsArray[0].data.map((d, i) => (
|
|
126
|
-
// eslint-disable-next-line react/no-array-index-key
|
|
127
|
-
<option key={i} value={i}>
|
|
128
|
-
{i}
|
|
129
|
-
</option>
|
|
130
|
-
))}
|
|
131
|
-
</MeasurementExplorerSelect>
|
|
132
|
-
</div>
|
|
133
|
-
<div>
|
|
134
|
-
<label>xVariable: </label>
|
|
135
|
-
<MeasurementExplorerSelect
|
|
136
|
-
onChange={({ target }) => {
|
|
137
|
-
const value = target.value;
|
|
138
|
-
if (value) {
|
|
139
|
-
setInfo((info) => ({ ...info, xVariableName: value }));
|
|
140
|
-
}
|
|
141
|
-
}}
|
|
142
|
-
value={info.xVariableName}
|
|
143
|
-
>
|
|
144
|
-
{dropdownVariables('x')}
|
|
145
|
-
</MeasurementExplorerSelect>
|
|
146
|
-
</div>
|
|
147
|
-
<div>
|
|
148
|
-
<FaExchangeAlt
|
|
149
|
-
style={{ marginTop: 2, cursor: 'pointer' }}
|
|
150
|
-
size="20"
|
|
151
|
-
onClick={() =>
|
|
152
|
-
setInfo(({ xVariableName, yVariableName, ...info }) => ({
|
|
153
|
-
...info,
|
|
154
|
-
xVariableName: yVariableName,
|
|
155
|
-
yVariableName: xVariableName,
|
|
156
|
-
}))
|
|
157
|
-
}
|
|
158
|
-
/>
|
|
159
|
-
</div>
|
|
160
|
-
<div>
|
|
161
|
-
<label>yVariable :</label>
|
|
162
|
-
<MeasurementExplorerSelect
|
|
163
|
-
onChange={({ target }) => {
|
|
164
|
-
const value = target.value;
|
|
165
|
-
if (value) {
|
|
166
|
-
setInfo((info) => ({ ...info, yVariableName: value }));
|
|
167
|
-
}
|
|
168
|
-
}}
|
|
169
|
-
value={info.yVariableName}
|
|
170
|
-
>
|
|
171
|
-
{dropdownVariables('y')}
|
|
172
|
-
</MeasurementExplorerSelect>
|
|
173
|
-
</div>
|
|
174
|
-
<MeasurementExplorerAction>
|
|
175
|
-
Flip horizontal axis:
|
|
176
|
-
<FaArrowsAltH
|
|
177
|
-
style={{
|
|
178
|
-
cursor: 'pointer',
|
|
179
|
-
border: '1px solid black',
|
|
180
|
-
padding: 1,
|
|
181
|
-
marginLeft: 2,
|
|
182
|
-
}}
|
|
183
|
-
size="28"
|
|
184
|
-
onClick={() =>
|
|
185
|
-
setInfo(({ flipHorizontalAxis, ...other }) => ({
|
|
186
|
-
flipHorizontalAxis: !flipHorizontalAxis,
|
|
187
|
-
...other,
|
|
188
|
-
}))
|
|
189
|
-
}
|
|
190
|
-
/>
|
|
191
|
-
</MeasurementExplorerAction>
|
|
192
|
-
</MeasurementExplorerContent>
|
|
193
|
-
<MeasurementPlot {...props} {...info} />
|
|
194
|
-
</MeasurementExplorerRoot>
|
|
195
|
-
);
|
|
196
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getCurrentMeasurementData,
|
|
3
|
-
useAppState,
|
|
4
|
-
} from '../../app-data/index.js';
|
|
5
|
-
|
|
6
|
-
import { MeasurementExplorer } from './MeasurementExplorer.js';
|
|
7
|
-
|
|
8
|
-
export default function MeasurementExplorerWithState() {
|
|
9
|
-
const appState = useAppState();
|
|
10
|
-
const data = getCurrentMeasurementData(appState);
|
|
11
|
-
|
|
12
|
-
if (!data) return <div>No selected measurement</div>;
|
|
13
|
-
return (
|
|
14
|
-
<MeasurementExplorer
|
|
15
|
-
measurement={data.data}
|
|
16
|
-
measurementDisplay={data.display}
|
|
17
|
-
/>
|
|
18
|
-
);
|
|
19
|
-
}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { xyToXYObject } from 'ml-spectra-processing';
|
|
2
|
-
import { useMemo } from 'react';
|
|
3
|
-
import { LineSeries, PlotController } from 'react-plot';
|
|
4
|
-
|
|
5
|
-
import type {
|
|
6
|
-
MeasurementAppView,
|
|
7
|
-
MeasurementBase,
|
|
8
|
-
} from '../../app-data/index.js';
|
|
9
|
-
|
|
10
|
-
import { BasicComponent } from './index.js';
|
|
11
|
-
|
|
12
|
-
type Measurement = Pick<MeasurementBase, 'meta' | 'info' | 'data' | 'id'>;
|
|
13
|
-
export interface MeasurementPlotProps {
|
|
14
|
-
measurement: Measurement[] | Measurement;
|
|
15
|
-
measurementDisplay: MeasurementAppView[] | MeasurementAppView;
|
|
16
|
-
dataIndex?: number;
|
|
17
|
-
xVariableName?: string;
|
|
18
|
-
yVariableName?: string;
|
|
19
|
-
width?: number | `${number}%`;
|
|
20
|
-
height?: number | `${number}%`;
|
|
21
|
-
zoom?: 'horizontal' | 'vertical' | 'rectangular' | '';
|
|
22
|
-
wheelZoom?: 'vertical' | 'horizontal' | '';
|
|
23
|
-
crossHair?: boolean;
|
|
24
|
-
showHorizontalAxis?: boolean;
|
|
25
|
-
showVerticalAxis?: boolean;
|
|
26
|
-
showHorizontalGrid?: boolean;
|
|
27
|
-
showVerticalGrid?: boolean;
|
|
28
|
-
flipHorizontalAxis?: boolean;
|
|
29
|
-
}
|
|
30
|
-
export function MeasurementPlot(props: MeasurementPlotProps) {
|
|
31
|
-
return (
|
|
32
|
-
<PlotController>
|
|
33
|
-
<MeasurementComponent {...props} />
|
|
34
|
-
</PlotController>
|
|
35
|
-
);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function MeasurementComponent(props: MeasurementPlotProps) {
|
|
39
|
-
const {
|
|
40
|
-
measurementDisplay,
|
|
41
|
-
measurement,
|
|
42
|
-
dataIndex = 0,
|
|
43
|
-
xVariableName = 'x',
|
|
44
|
-
yVariableName = 'y',
|
|
45
|
-
} = props;
|
|
46
|
-
|
|
47
|
-
const dataXY = useMemo(() => {
|
|
48
|
-
const measurementsArray = Array.isArray(measurement)
|
|
49
|
-
? measurement
|
|
50
|
-
: [measurement];
|
|
51
|
-
return measurementsArray.map(({ data, id }) => {
|
|
52
|
-
const { variables } = data[dataIndex];
|
|
53
|
-
const { [xVariableName]: x, [yVariableName]: y } = variables;
|
|
54
|
-
if (x === undefined || y === undefined) {
|
|
55
|
-
throw new Error(
|
|
56
|
-
`Variable "${
|
|
57
|
-
x === undefined ? xVariableName : yVariableName
|
|
58
|
-
}" is not available in data. Only ${Object.keys(
|
|
59
|
-
data[dataIndex].variables,
|
|
60
|
-
).join(', ')} are available`,
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
return { x, y, id };
|
|
64
|
-
});
|
|
65
|
-
}, [dataIndex, measurement, xVariableName, yVariableName]);
|
|
66
|
-
|
|
67
|
-
return (
|
|
68
|
-
<BasicComponent {...props}>
|
|
69
|
-
{dataXY.map(({ x, y, id }, i) => {
|
|
70
|
-
const { color } = Array.isArray(measurementDisplay)
|
|
71
|
-
? measurementDisplay[i]
|
|
72
|
-
: measurementDisplay;
|
|
73
|
-
if (color.kind !== 'fixed') {
|
|
74
|
-
throw new Error(`unimplemented stroke for kind ${color.kind}`);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
return (
|
|
78
|
-
<LineSeries
|
|
79
|
-
key={id}
|
|
80
|
-
lineStyle={{
|
|
81
|
-
stroke: color.color,
|
|
82
|
-
}}
|
|
83
|
-
data={xyToXYObject({
|
|
84
|
-
x: x.data,
|
|
85
|
-
y: y.data,
|
|
86
|
-
})}
|
|
87
|
-
/>
|
|
88
|
-
);
|
|
89
|
-
})}
|
|
90
|
-
</BasicComponent>
|
|
91
|
-
);
|
|
92
|
-
}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
interface MeasurementVariableSelectProps {
|
|
2
|
-
label: string;
|
|
3
|
-
value: string;
|
|
4
|
-
options: string[];
|
|
5
|
-
onSelect: (value: string) => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export function MeasurementVariableSelect(
|
|
9
|
-
props: MeasurementVariableSelectProps,
|
|
10
|
-
) {
|
|
11
|
-
const { label, value, options, onSelect } = props;
|
|
12
|
-
return (
|
|
13
|
-
<label>
|
|
14
|
-
{`${label}: `}
|
|
15
|
-
<select
|
|
16
|
-
value={value}
|
|
17
|
-
onChange={(event) => {
|
|
18
|
-
const value = event.target.value;
|
|
19
|
-
if (value) {
|
|
20
|
-
onSelect(value);
|
|
21
|
-
}
|
|
22
|
-
}}
|
|
23
|
-
>
|
|
24
|
-
<option value="">{`<select a variable>`}</option>
|
|
25
|
-
{options.map((option) => (
|
|
26
|
-
<option key={option} value={option}>
|
|
27
|
-
{option}
|
|
28
|
-
</option>
|
|
29
|
-
))}
|
|
30
|
-
</select>
|
|
31
|
-
</label>
|
|
32
|
-
);
|
|
33
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { ColorConfig } from '../../app-data/index.js';
|
|
2
|
-
|
|
3
|
-
// import { fixedGradientScales } from '../../components/index';
|
|
4
|
-
|
|
5
|
-
export function getColorFromConfig(config: ColorConfig) {
|
|
6
|
-
if (config.kind === 'fixed') {
|
|
7
|
-
return config.color;
|
|
8
|
-
} else {
|
|
9
|
-
throw new Error(`Unsupported color config: ${config.kind}`);
|
|
10
|
-
// const scale = fixedGradientScales[config.gradient];
|
|
11
|
-
}
|
|
12
|
-
}
|
package/src/app/helpers/index.ts
DELETED
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
import styled from '@emotion/styled';
|
|
2
|
-
import type { ReactNode } from 'react';
|
|
3
|
-
import { useMemo } from 'react';
|
|
4
|
-
import { ResponsiveChart } from 'react-d3-utils';
|
|
5
|
-
import {
|
|
6
|
-
Annotations,
|
|
7
|
-
Axis,
|
|
8
|
-
Heading,
|
|
9
|
-
Plot,
|
|
10
|
-
useAxisWheelZoom,
|
|
11
|
-
useAxisZoom,
|
|
12
|
-
useCrossHair,
|
|
13
|
-
usePan,
|
|
14
|
-
useRectangularZoom,
|
|
15
|
-
} from 'react-plot';
|
|
16
|
-
|
|
17
|
-
import type { MeasurementPlotProps } from './MeasurementPlot.js';
|
|
18
|
-
|
|
19
|
-
interface BasicComponentProps extends MeasurementPlotProps {
|
|
20
|
-
children: ReactNode[] | ReactNode;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const BasicComponentRoot = styled.div`
|
|
24
|
-
user-drag: none;
|
|
25
|
-
-webkit-user-drag: none;
|
|
26
|
-
user-select: none;
|
|
27
|
-
-moz-user-select: none;
|
|
28
|
-
-webkit-user-select: none;
|
|
29
|
-
-ms-user-select: none;
|
|
30
|
-
`;
|
|
31
|
-
|
|
32
|
-
export function BasicComponent(props: BasicComponentProps) {
|
|
33
|
-
const {
|
|
34
|
-
children,
|
|
35
|
-
measurement,
|
|
36
|
-
dataIndex = 0,
|
|
37
|
-
xVariableName = 'x',
|
|
38
|
-
yVariableName = 'y',
|
|
39
|
-
width = '100%',
|
|
40
|
-
height = '100%',
|
|
41
|
-
zoom = 'horizontal',
|
|
42
|
-
wheelZoom = 'vertical',
|
|
43
|
-
crossHair = true,
|
|
44
|
-
showHorizontalAxis = true,
|
|
45
|
-
showVerticalAxis = true,
|
|
46
|
-
showHorizontalGrid = true,
|
|
47
|
-
showVerticalGrid = true,
|
|
48
|
-
flipHorizontalAxis = false,
|
|
49
|
-
} = props;
|
|
50
|
-
|
|
51
|
-
const [
|
|
52
|
-
{
|
|
53
|
-
info: { title },
|
|
54
|
-
data,
|
|
55
|
-
},
|
|
56
|
-
] = Array.isArray(measurement) ? measurement : [measurement];
|
|
57
|
-
|
|
58
|
-
const { x, y } = useMemo(() => {
|
|
59
|
-
const { variables } = data[dataIndex];
|
|
60
|
-
const { [xVariableName]: x, [yVariableName]: y } = variables;
|
|
61
|
-
if (x === undefined || y === undefined) {
|
|
62
|
-
throw new Error(
|
|
63
|
-
`Variable "${
|
|
64
|
-
x === undefined ? xVariableName : yVariableName
|
|
65
|
-
}" is not available in data. Only ${Object.keys(
|
|
66
|
-
data[dataIndex].variables,
|
|
67
|
-
).join(', ')} are available`,
|
|
68
|
-
);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
return { x, y };
|
|
72
|
-
}, [data, dataIndex, xVariableName, yVariableName]);
|
|
73
|
-
|
|
74
|
-
const direction = new Set(['vertical', 'horizontal']);
|
|
75
|
-
|
|
76
|
-
const rectZoom = useRectangularZoom({
|
|
77
|
-
disabled: zoom !== 'rectangular',
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
const axisZoom = useAxisZoom({
|
|
81
|
-
direction: zoom === 'vertical' ? 'vertical' : 'horizontal',
|
|
82
|
-
disabled: !direction.has(zoom),
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
useAxisWheelZoom({
|
|
86
|
-
direction: wheelZoom === 'vertical' ? 'vertical' : 'horizontal',
|
|
87
|
-
axisId: wheelZoom === 'vertical' ? 'y' : 'x',
|
|
88
|
-
disabled: !direction.has(wheelZoom),
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
const crossHairAnnot = useCrossHair({
|
|
92
|
-
disabled: !crossHair,
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
usePan();
|
|
96
|
-
|
|
97
|
-
return (
|
|
98
|
-
<BasicComponentRoot style={{ width, height }}>
|
|
99
|
-
<ResponsiveChart width={width} height={height}>
|
|
100
|
-
{({ width, height }) => (
|
|
101
|
-
<Plot width={width} height={height}>
|
|
102
|
-
<Heading title={title} />
|
|
103
|
-
{children}
|
|
104
|
-
<Annotations>
|
|
105
|
-
{rectZoom.annotations}
|
|
106
|
-
{axisZoom.annotations}
|
|
107
|
-
{crossHairAnnot.annotations}
|
|
108
|
-
</Annotations>
|
|
109
|
-
<Axis
|
|
110
|
-
hidden={!showHorizontalAxis}
|
|
111
|
-
displayPrimaryGridLines={showVerticalGrid}
|
|
112
|
-
flip={flipHorizontalAxis}
|
|
113
|
-
position="bottom"
|
|
114
|
-
label={`${x.label}${x.units ? `(${x.units})` : ''}`}
|
|
115
|
-
paddingEnd="20"
|
|
116
|
-
/>
|
|
117
|
-
<Axis
|
|
118
|
-
hidden={!showVerticalAxis}
|
|
119
|
-
displayPrimaryGridLines={showHorizontalGrid}
|
|
120
|
-
position="left"
|
|
121
|
-
label={`${y.label}${y.units ? `(${y.units})` : ''}`}
|
|
122
|
-
paddingStart="10"
|
|
123
|
-
paddingEnd="10"
|
|
124
|
-
/>
|
|
125
|
-
</Plot>
|
|
126
|
-
)}
|
|
127
|
-
</ResponsiveChart>
|
|
128
|
-
</BasicComponentRoot>
|
|
129
|
-
);
|
|
130
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
AppState,
|
|
3
|
-
MeasurementAndView,
|
|
4
|
-
MeasurementKind,
|
|
5
|
-
} from '../../app-data/index.js';
|
|
6
|
-
import { iterateKindMeasurementsAndView } from '../../app-data/index.js';
|
|
7
|
-
|
|
8
|
-
export function splitEntries<Kind extends MeasurementKind>(
|
|
9
|
-
appState: AppState,
|
|
10
|
-
kind: Kind,
|
|
11
|
-
) {
|
|
12
|
-
const selectedEntries: Array<MeasurementAndView<Kind>> = [];
|
|
13
|
-
const unselectedEntries: Array<MeasurementAndView<Kind>> = [];
|
|
14
|
-
const selectedMeasurements: string[] =
|
|
15
|
-
appState.view.selectedMeasurements[kind] ?? [];
|
|
16
|
-
|
|
17
|
-
for (const entry of iterateKindMeasurementsAndView(appState, kind)) {
|
|
18
|
-
if (selectedMeasurements.includes(entry.measurement.id)) {
|
|
19
|
-
selectedEntries.push(entry);
|
|
20
|
-
} else {
|
|
21
|
-
unselectedEntries.push(entry);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
return { selectedEntries, unselectedEntries };
|
|
26
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import type { UseQueryResult } from '@tanstack/react-query';
|
|
2
|
-
import { useQuery } from '@tanstack/react-query';
|
|
3
|
-
import type { FifoLogger } from 'fifo-logger';
|
|
4
|
-
import type { FileCollection } from 'filelist-utils';
|
|
5
|
-
import { fileCollectionFromWebSource } from 'filelist-utils';
|
|
6
|
-
import { useCallback } from 'react';
|
|
7
|
-
|
|
8
|
-
import type { AppDispatch } from '../../app-data/index.js';
|
|
9
|
-
import { useAppDispatch } from '../../app-data/index.js';
|
|
10
|
-
import { useFifoLogger, useHashSearchParams } from '../../components/index.js';
|
|
11
|
-
|
|
12
|
-
type LoadFn = (
|
|
13
|
-
files: File[] | FileCollection,
|
|
14
|
-
logger: FifoLogger,
|
|
15
|
-
dispatch: AppDispatch,
|
|
16
|
-
) => Promise<void>;
|
|
17
|
-
|
|
18
|
-
export function useLoadFileCollectionFromHash(
|
|
19
|
-
onLoad: LoadFn,
|
|
20
|
-
): UseQueryResult<true | null> {
|
|
21
|
-
const logger = useFifoLogger();
|
|
22
|
-
const appDispatch = useAppDispatch();
|
|
23
|
-
const hashParams = useHashSearchParams();
|
|
24
|
-
const filelistUrl = hashParams.get('filelist');
|
|
25
|
-
return useQuery({
|
|
26
|
-
queryKey: ['filelist', filelistUrl],
|
|
27
|
-
queryFn: async () => {
|
|
28
|
-
if (!filelistUrl) {
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
const request = await fetch(filelistUrl);
|
|
32
|
-
const data = await request.json();
|
|
33
|
-
const baseURL = filelistUrl.replace(/\/[^/]*$/, '/');
|
|
34
|
-
const fileCollection = await fileCollectionFromWebSource({
|
|
35
|
-
entries: data,
|
|
36
|
-
baseURL,
|
|
37
|
-
});
|
|
38
|
-
void onLoad(fileCollection, logger, appDispatch);
|
|
39
|
-
return true;
|
|
40
|
-
},
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export function useDropFiles(onLoad: LoadFn) {
|
|
45
|
-
const dispatch = useAppDispatch();
|
|
46
|
-
const logger = useFifoLogger();
|
|
47
|
-
return useCallback(
|
|
48
|
-
(files: File[]) => {
|
|
49
|
-
void onLoad(files, logger, dispatch);
|
|
50
|
-
},
|
|
51
|
-
[dispatch, onLoad, logger],
|
|
52
|
-
);
|
|
53
|
-
}
|
package/src/app/hooks/index.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './file-loading.js';
|
package/src/app/index.ts
DELETED
package/src/app/kinds/index.ts
DELETED
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import type { ColumnDef, SortingState } from '@tanstack/react-table';
|
|
2
|
-
import { useState } from 'react';
|
|
3
|
-
|
|
4
|
-
import type { IrPeak } from '../../../app-data/index.js';
|
|
5
|
-
import { Table } from '../../../components/index.js';
|
|
6
|
-
|
|
7
|
-
export interface IrColumnPreferences<T extends keyof IrPeak = keyof IrPeak> {
|
|
8
|
-
visible?: boolean;
|
|
9
|
-
format?: (val: IrPeak[T]) => string | number;
|
|
10
|
-
accessorKey: T;
|
|
11
|
-
label?: string;
|
|
12
|
-
}
|
|
13
|
-
interface IrPeakPanelPreferences {
|
|
14
|
-
columns?: IrColumnPreferences[];
|
|
15
|
-
}
|
|
16
|
-
export interface IrPeaksPanelProps {
|
|
17
|
-
/**
|
|
18
|
-
* peaks to display in the panel
|
|
19
|
-
*
|
|
20
|
-
*/
|
|
21
|
-
peaks: IrPeak[];
|
|
22
|
-
/**
|
|
23
|
-
* The columns to display in the table.
|
|
24
|
-
* @default {}
|
|
25
|
-
*/
|
|
26
|
-
preferences?: IrPeakPanelPreferences;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export function IrPeaksPanel(props: IrPeaksPanelProps) {
|
|
30
|
-
const { peaks, preferences = {} } = props;
|
|
31
|
-
const { columns = [] } = preferences;
|
|
32
|
-
|
|
33
|
-
const defaultColumns: Array<ColumnDef<IrPeak, number>> = columns.map(
|
|
34
|
-
({ accessorKey, label = accessorKey, format = (x: number) => x }) => ({
|
|
35
|
-
header: label,
|
|
36
|
-
accessorKey,
|
|
37
|
-
cell: ({ getValue }) => format(getValue()),
|
|
38
|
-
}),
|
|
39
|
-
);
|
|
40
|
-
|
|
41
|
-
function getColumnVisibility() {
|
|
42
|
-
const columnVisibility: Record<string, boolean> = {};
|
|
43
|
-
for (const { accessorKey, visible = true } of columns) {
|
|
44
|
-
columnVisibility[accessorKey] = visible;
|
|
45
|
-
}
|
|
46
|
-
return columnVisibility;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
const [sorting, setSorting] = useState<SortingState>([]);
|
|
50
|
-
|
|
51
|
-
return (
|
|
52
|
-
<Table
|
|
53
|
-
bordered
|
|
54
|
-
data={peaks}
|
|
55
|
-
columns={defaultColumns}
|
|
56
|
-
reactTable={{
|
|
57
|
-
state: {
|
|
58
|
-
sorting,
|
|
59
|
-
columnVisibility: getColumnVisibility(),
|
|
60
|
-
},
|
|
61
|
-
onSortingChange: setSorting,
|
|
62
|
-
}}
|
|
63
|
-
/>
|
|
64
|
-
);
|
|
65
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './IrPeaksPanel.js';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './plot-view/IvPlotView.js';
|