diff --git a/package.json b/package.json index cc3ea43a..f382f2a6 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "hhd-ui", - "version": "0.17.5", + "version": "0.17.6", "private": true, "dependencies": { "@ag-grid-community/client-side-row-model": "^30.0.3", diff --git a/src/app-components/navigation/secondaryNavBar.jsx b/src/app-components/navigation/secondaryNavBar.jsx index 7cfc9e36..5979fda7 100644 --- a/src/app-components/navigation/secondaryNavBar.jsx +++ b/src/app-components/navigation/secondaryNavBar.jsx @@ -19,7 +19,7 @@ const CustomTabPanel = props => { )} ); -} +}; const SecondaryNavBar = connect( 'selectHashStripQuery', diff --git a/src/app-pages/instrument/formula/formula.jsx b/src/app-pages/instrument/formula/formula.jsx index 7773c099..b36f50d0 100644 --- a/src/app-pages/instrument/formula/formula.jsx +++ b/src/app-pages/instrument/formula/formula.jsx @@ -1,9 +1,35 @@ -import React, { useState } from 'react'; +import React, { useMemo, useState } from 'react'; import { connect } from 'redux-bundler-react'; +import { Accordion, AccordionDetails, AccordionSummary, Autocomplete, TextField } from '@mui/material'; +import { ArrowDropDown } from '@mui/icons-material'; import Button from '../../../app-components/button'; import FormulaCard from './formulaCard'; +const generateTimeseriesOptions = timeseries => { + return timeseries.map(ts => ({ + label: `${ts.instrument} - ${ts.name}`, + value: ts.id, + variable: ts.variable, + instrumentName: ts.instrument, + })); +}; + +const groupTimeseries = (timeseries = []) => { + return timeseries.reduce((accum, current) => { + const { instrument_id, instrument } = current; + + + return { + ...accum, + [instrument_id]: { + name: instrument, + timeseries: [...(accum[instrument_id]?.timeseries || []), current], + }, + }; + }, {}); +}; + export default connect( 'doModalOpen', 'doInstrumentFormulasSave', @@ -19,7 +45,11 @@ export default connect( nonComputedTimeseriesItemsByRoute: timeseries, }) => { const [activeFormula, setActiveFormula] = useState(null); - const sortedTimeseries = timeseries.sort((a, b) => String(a.variable).localeCompare(b.variable)); + const [searchString, setSeachString] = useState(undefined); + + const groupedTs = groupTimeseries(timeseries); + const groupKeys = Object.keys(groupedTs).sort((a, b) => groupedTs[a].name.localeCompare(groupedTs[b].name)); + const options = useMemo(() => generateTimeseriesOptions(timeseries).sort((a, b) => -b.label.localeCompare(a.label)), [timeseries]); const createNewFormula = () => { doInstrumentFormulasSave({ @@ -30,6 +60,7 @@ export default connect( }; const insertParam = (param) => { + if (!activeFormula) return; const { input, formula, setFormula } = activeFormula; const start = input.current.selectionStart; @@ -51,17 +82,50 @@ export default connect( Available parameters