Skip to content

Commit

Permalink
implement label system for region dropdown
Browse files Browse the repository at this point in the history
  • Loading branch information
ducku committed Dec 2, 2023
1 parent 1082ccd commit 85842e3
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 34 deletions.
81 changes: 49 additions & 32 deletions src/components/RegionInput.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import PropTypes from "prop-types";
import TextField from "@mui/material/TextField";
import Autocomplete from "@mui/material/Autocomplete";
import FormHelperText from "@mui/material/FormHelperText";
import Tooltip from "@mui/material/Tooltip";
import "../config-client.js";
import "../config-global.mjs";
import { isEmpty } from "../common.mjs";
Expand All @@ -19,52 +20,68 @@ export const RegionInput = ({
// Generate autocomplete options for regions from regionInfo
// Add : to pathNames
console.log("rendering with pathnames: ", pathNames);
const pathNamesColon = pathNames.map((name) => name + ":");
const pathNamesColon = pathNames.map((name) => {
return {label: name + ":", value: name + ":"};
});
const pathsWithRegion = [];

const regionToDesc = new Map();

if (regionInfo && !isEmpty(regionInfo)) {
// Stitch path name + region start and end
for (const [index, path] of regionInfo["chr"].entries()) {
pathsWithRegion.push(
path + ":" + regionInfo.start[index] + "-" + regionInfo.end[index]
);
const pathWithRegion = path + ":" + regionInfo.start[index] + "-" + regionInfo.end[index]
pathsWithRegion.push({
label: pathWithRegion + " " + regionInfo.desc[index],
value: pathWithRegion
});
regionToDesc.set(pathWithRegion, regionInfo.desc[index]);
}

// Add descriptions
pathsWithRegion.push(...regionInfo["desc"]);

}

// Autocomplete selectable options
const displayRegions = [...pathsWithRegion, ...pathNamesColon];
const displayRegions = [...pathsWithRegion, ...pathNamesColon].filter(option => option.label !== "none:");

let descLabel = "Region";
if (regionToDesc.get(region)) {
descLabel = regionToDesc.get(region);
}

return (
<>
<Autocomplete
disablePortal
freeSolo // Allows custom input outside of the options
getOptionLabel={(option) => option.title || option.toString()}
value={region}
inputValue={region}
data-testid="autocomplete"
id="regionInput"
<Tooltip title={descLabel} placement="top-start">
<Autocomplete
disablePortal
freeSolo // Allows custom input outside of the options
getOptionLabel={(option) => option.label || option.toString()}
value={region}
inputValue={region}
data-testid="autocomplete"
id="regionInput"

onInputChange={(event, newInputValue) => {
handleRegionChange(newInputValue);
}}
onInputChange={(event, newInput) => {
let regionValue = newInput;
const regionObject = displayRegions.find((option) => option.label === newInput);
// IF input is selected from one of the options
if (regionObject) {
regionValue = regionObject.value
}
handleRegionChange(regionValue);
}}

options={displayRegions}
renderInput={(params) => (
<TextField
{...params}
label="Region"
name="Region Input"
inputProps={{
...params.inputProps,
}}
/>
)}
/>
options={displayRegions}
renderInput={(params) => (
<TextField
{...params}
label={"Region"}
name="Region Input"
inputProps={{
...params.inputProps,
}}
/>
)}
/>
</Tooltip>
<FormHelperText id="comboBoxHelperText">
{`
Input a data segment to select with format <path>:<regionRange> and hit 'Go'. See ? for more information.
Expand Down
4 changes: 2 additions & 2 deletions src/end-to-end.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ describe("When we wait for it to load", () => {
userEvent.click(getRegionInput());
});
// Make sure that option in RegionInput dropdown (17_1_100) is visible
expect(screen.getByText("17_1_100")).toBeInTheDocument();
expect(screen.getByText("17:1-100 17_1_100")).toBeInTheDocument();
});
it("the region options in autocomplete are cleared after selecting new data", async () => {
// Input data dropdown
Expand All @@ -230,7 +230,7 @@ describe("When we wait for it to load", () => {
userEvent.click(getRegionInput());
});
// Make sure that old option in RegionInput dropdown (17_...) is not visible
expect(screen.queryByText("17_1_100")).not.toBeInTheDocument();
expect(screen.queryByText("1-100 17_1_100")).not.toBeInTheDocument();
await act(async () => {
userEvent.click(regionInput);
});
Expand Down

0 comments on commit 85842e3

Please sign in to comment.