From 5f819ae33b47c793fc785802b58a933e20b9e01f Mon Sep 17 00:00:00 2001 From: "alex.hill@gmail.com" Date: Wed, 11 Dec 2024 13:53:17 +0000 Subject: [PATCH 1/2] add series type --- src/components/ChoosePlot.tsx | 14 +++++++++++--- src/components/ChooseSeriesType.tsx | 24 ++++++++++++++++++++++++ src/components/SideBar.tsx | 11 +++++++++-- src/components/UploadDataset.tsx | 17 +++++++++++++++++ src/generated.d.ts | 4 +--- test/mocks.ts | 1 + 6 files changed, 63 insertions(+), 8 deletions(-) create mode 100644 src/components/ChooseSeriesType.tsx diff --git a/src/components/ChoosePlot.tsx b/src/components/ChoosePlot.tsx index 0c55fa5..34b59f0 100644 --- a/src/components/ChoosePlot.tsx +++ b/src/components/ChoosePlot.tsx @@ -4,9 +4,14 @@ import React from "react"; interface Props { selectedPlot: string; selectPlot: (name: string) => void + seriesType: "surveillance" | "post-exposure" } -export default function ChoosePlot({selectedPlot, selectPlot}: Props) { +export default function ChoosePlot({ + selectedPlot, + selectPlot, + seriesType + }: Props) { const onSelectPlot = (event: any) => { selectPlot(event.target.value); @@ -17,8 +22,11 @@ export default function ChoosePlot({selectedPlot, selectPlot}: Props) { plot - - + + {seriesType === "post-exposure" && + + } + } diff --git a/src/components/ChooseSeriesType.tsx b/src/components/ChooseSeriesType.tsx new file mode 100644 index 0000000..68eaaa6 --- /dev/null +++ b/src/components/ChooseSeriesType.tsx @@ -0,0 +1,24 @@ +import Form from "react-bootstrap/Form"; +import React from "react"; + +interface Props { + selectedType: "surveillance" | "post-exposure"; + selectType: (name: "surveillance" | "post-exposure") => void +} + +export default function ChooseSeriesType({selectedType, selectType}: Props) { + + const onSelectType = (event: any) => { + selectType(event.target.value); + } + + return + Choose + dataset + + + + + +} diff --git a/src/components/SideBar.tsx b/src/components/SideBar.tsx index ce748be..eb03f3b 100644 --- a/src/components/SideBar.tsx +++ b/src/components/SideBar.tsx @@ -33,14 +33,21 @@ export default function SideBar() {
- + + + Time series type
{state.datasetMetadata?.type} + +
Detected biomarkers
{state.datasetMetadata?.biomarkers.join(", ")}
+
diff --git a/src/components/UploadDataset.tsx b/src/components/UploadDataset.tsx index 0600ff0..e6352a7 100644 --- a/src/components/UploadDataset.tsx +++ b/src/components/UploadDataset.tsx @@ -12,12 +12,14 @@ export default function UploadDataset() { const apiService = api(state.language, dispatch); const [timeColumnHeader, setTimeColumnHeader] = useState("day"); + const [dataType, setDataType] = useState("surveillance"); const [datasetName, setDatasetName] = useState(""); const [validName, setValidName] = useState(true); const [selectedFile, selectFile] = useState(""); const [isUploading, setIsUploading] = useState(false); const onSelectTimeColumnHeader = (e: any) => setTimeColumnHeader(e.target.value); + const onSelectDataType = (e: any) => setDataType(e.target.value); const onSelectDatasetName = (e: any) => { setDatasetName(e.target.value); setValidName(isAlphaNumeric(e.target.value)); @@ -52,6 +54,7 @@ export default function UploadDataset() { formData.append('file', selectedFile); formData.append('xcol', timeColumnHeader); formData.append('name', datasetName); + formData.append('series_type', dataType); const dataService = new DataService(apiService); @@ -118,6 +121,20 @@ export default function UploadDataset() { + + Time series type + + + + + + + Is this an absolute (surveillance) or a relative + (post-exposure) time series? + + +
{state.uploadError && state.uploadError.detail} diff --git a/src/generated.d.ts b/src/generated.d.ts index 5460a8c..15a4a59 100644 --- a/src/generated.d.ts +++ b/src/generated.d.ts @@ -20,6 +20,7 @@ export interface DatasetMetadata { variables: VariableSchema[]; biomarkers: string[]; xcol: string; + type: "surveillance" | "post-exposure"; } export interface VariableSchema { name: string; @@ -29,7 +30,6 @@ export type DatasetNames = string[]; export interface ErrorDetail { error: string; detail: string | null; - [k: string]: unknown; } export interface Plotly { data: { @@ -48,12 +48,10 @@ export interface ResponseFailure { status: "failure"; data: null; errors: ErrorDetailSchema[]; - [k: string]: unknown; } export interface ErrorDetailSchema { error: string; detail: string | null; - [k: string]: unknown; } export interface ResponseSuccess { status: "success"; diff --git a/test/mocks.ts b/test/mocks.ts index 4ec36f6..a82a70e 100644 --- a/test/mocks.ts +++ b/test/mocks.ts @@ -36,6 +36,7 @@ export function mockDatasetMetadata(datasetMetadata: Partial = variables: [mockVariable()], xcol: "day", biomarkers: ["ab"], + type: "surveillance", ...datasetMetadata } } From 3112bf6e468887f480f8937b04d74e83a9688eaf Mon Sep 17 00:00:00 2001 From: "alex.hill@gmail.com" Date: Wed, 11 Dec 2024 14:30:33 +0000 Subject: [PATCH 2/2] comment out hiustogram plot type --- src/components/ChoosePlot.tsx | 6 +++--- src/components/ChooseSeriesType.tsx | 24 ------------------------ test/components/SideBar.test.tsx | 5 +++-- 3 files changed, 6 insertions(+), 29 deletions(-) delete mode 100644 src/components/ChooseSeriesType.tsx diff --git a/src/components/ChoosePlot.tsx b/src/components/ChoosePlot.tsx index 34b59f0..de0ec3b 100644 --- a/src/components/ChoosePlot.tsx +++ b/src/components/ChoosePlot.tsx @@ -23,9 +23,9 @@ export default function ChoosePlot({ - {seriesType === "post-exposure" && - - } + {/*{seriesType === "post-exposure" &&*/} + {/* */} + {/*}*/} diff --git a/src/components/ChooseSeriesType.tsx b/src/components/ChooseSeriesType.tsx deleted file mode 100644 index 68eaaa6..0000000 --- a/src/components/ChooseSeriesType.tsx +++ /dev/null @@ -1,24 +0,0 @@ -import Form from "react-bootstrap/Form"; -import React from "react"; - -interface Props { - selectedType: "surveillance" | "post-exposure"; - selectType: (name: "surveillance" | "post-exposure") => void -} - -export default function ChooseSeriesType({selectedType, selectType}: Props) { - - const onSelectType = (event: any) => { - selectType(event.target.value); - } - - return - Choose - dataset - - - - - -} diff --git a/test/components/SideBar.test.tsx b/test/components/SideBar.test.tsx index d498972..694d1b9 100644 --- a/test/components/SideBar.test.tsx +++ b/test/components/SideBar.test.tsx @@ -14,7 +14,7 @@ import { import {userEvent} from "@testing-library/user-event"; describe("", () => { - test("it renders detected biomarkers", () => { + test("it renders detected biomarkers and series type", () => { const state = mockAppState({ datasetMetadata: mockDatasetMetadata({ biomarkers: ["ab", "ba"] @@ -26,7 +26,8 @@ describe("", () => { ); - expect(container.textContent).toContain("Detected biomarkers ab, ba") + expect(container.textContent).toContain("Detected biomarkers ab, ba"); + expect(container.textContent).toContain("Time series type surveillance"); }); test("user can change dataset", async () => {