Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use nullish coalescing operator #1782

Merged
merged 8 commits into from
Dec 23, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
### Fixed

- Observations were not included in exported borehole JSON file.
- Fixed bug where values of 0 were not displayed in numeric input fields.

## v2.1.993 - 2024-12-13

Expand Down
29 changes: 29 additions & 0 deletions src/client/cypress/e2e/detailPage/boreholeform.cy.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { clickOnRowWithText, showTableAndWaitForData, sortBy } from "../helpers/
import { evaluateInput, evaluateSelect, isDisabled, setInput, setSelect } from "../helpers/formHelpers";
import {
createBorehole,
getElementByDataCy,
goToRouteAndAcceptTerms,
handlePrompt,
newEditableBorehole,
Expand Down Expand Up @@ -212,6 +213,34 @@ describe("Test for the borehole form.", () => {
});
});

it("displays 0 in input fields", () => {
// create borehole with 0 in all numeric inputs
createBorehole({
"extended.original_name": "AAA_RINO",
"custom.alternate_name": "AAA_RINO",
total_depth: 0,
"extended.top_bedrock_fresh_md": 0.0,
"custom.top_bedrock_weathered_md": 0.0,
elevation_z: 0,
reference_elevation: 0.0,
}).as("borehole_id");
cy.get("@borehole_id").then(id => {
goToRouteAndAcceptTerms(`/${id}/location`);
evaluateInput("elevationZ", "0");
evaluateInput("referenceElevation", "0");

getElementByDataCy("borehole-menu-item").click();

evaluateInput("totalDepth", "0");
evaluateInput("topBedrockWeatheredMd", "0");
evaluateInput("topBedrockFreshMd", "0");

evaluateInput("total_depth_tvd", "0");
evaluateInput("top_bedrock_fresh_tvd", "0");
evaluateInput("top_bedrock_weathered_tvd", "0");
});
});

it("stops editing when going back to overview", () => {
createBorehole({ "extended.original_name": "AAA_HIPPOPOTHAMUS", "custom.alternate_name": "AAA_HIPPOPOTHAMUS" }).as(
"borehole_id",
Expand Down
2 changes: 1 addition & 1 deletion src/client/src/components/buttons/buttonSelect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ export const ButtonSelect: FC<ButtonSelectProps> = ({
onClick={handleClick}
startIcon={startIcon}
endIcon={anchorEl ? <ChevronUp /> : <ChevronDown />}
className={`${isOpen ? "Mui-active" : ""} ${className || ""}`}
className={`${isOpen ? "Mui-active" : ""} ${className ?? ""}`}
data-cy={`${fieldName}-button-select`}
sx={{ ...sx }}>
{selectedItem?.value}
Expand Down
2 changes: 1 addition & 1 deletion src/client/src/components/form/formCoordinate.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ export const FormCoordinate: FC<FormCoordinateProps> = ({
required={required || false}
error={!className?.includes("ai") && !disabled && getFormFieldError(fieldName, formState.errors)}
sx={{ ...sx }}
className={`${readonly ? "readonly" : ""} ${className || ""}`}
className={`${readonly ? "readonly" : ""} ${className ?? ""}`}
label={t(`location_${direction.toLowerCase()}_${referenceSystem}`)}
{...register(fieldName, {
required: required || false,
Expand Down
2 changes: 1 addition & 1 deletion src/client/src/components/form/formDisplay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ export const FormDisplay: FC<FormDisplayProps> = ({ prefix, label, value, type,
...sx,
}}>
<Typography variant="subtitle2">{t(label)}</Typography>
<Typography marginBottom={"1em"} variant="subtitle1" data-cy={(prefix || "") + label + "-formDisplay"}>
<Typography marginBottom={"1em"} variant="subtitle1" data-cy={(prefix ?? "") + label + "-formDisplay"}>
{formatValue(value)}
</Typography>
</Stack>
Expand Down
2 changes: 1 addition & 1 deletion src/client/src/components/form/formInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ export const FormInput: FC<FormInputProps> = ({
required={required || false}
error={getFormFieldError(fieldName, formState.errors)}
sx={{ ...sx }}
className={`${readonly ? "readonly" : ""} ${className || ""}`}
className={`${readonly ? "readonly" : ""} ${className ?? ""}`}
type={type || FormValueType.Text}
multiline={multiline || false}
rows={rows}
Expand Down
4 changes: 2 additions & 2 deletions src/client/src/components/form/formMultiSelect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ export const FormMultiSelect: FC<FormMultiSelectProps> = ({
InputProps={{ readOnly: readonly, disabled: disabled }}
required={required || false}
sx={{ ...sx }}
className={`${readonly ? "readonly" : ""} ${className || ""}`}
className={`${readonly ? "readonly" : ""} ${className ?? ""}`}
label={t(label)}
{...register(fieldName, {
required: required || false,
Expand Down Expand Up @@ -135,7 +135,7 @@ export const FormMultiSelect: FC<FormMultiSelectProps> = ({
required={required || false}
error={getFormFieldError(fieldName, formState.errors)}
sx={{ ...sx }}
className={`${readonly ? "readonly" : ""} ${className || ""}`}
className={`${readonly ? "readonly" : ""} ${className ?? ""}`}
label={t(label)}
{...register(fieldName, {
required: required || false,
Expand Down
2 changes: 1 addition & 1 deletion src/client/src/components/form/formSelect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ export const FormSelect: FC<FormSelectProps> = ({
required={required ?? false}
error={getFormFieldError(fieldName, formState.errors)}
sx={{ ...sx }}
className={`${readonly ? "readonly" : ""} ${className || ""}`}
className={`${readonly ? "readonly" : ""} ${className ?? ""}`}
label={t(label)}
name={field.name}
onChange={field.onChange}
Expand Down
12 changes: 8 additions & 4 deletions src/client/src/pages/detail/form/borehole/boreholeForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,10 @@ export const BoreholeForm = forwardRef(({ borehole, editingEnabled, onSubmit }:

const fetchDepthTVD = useCallback(
async (fieldValue: number | null) => {
// check if fieldValue is effectively zero
if (fieldValue !== null && Math.abs(fieldValue) === 0) {
return fieldValue;
}
if (!fieldValue) return null;
const getDepthTVD = async (depthMD: number | null) => {
if (depthMD == null) {
Expand Down Expand Up @@ -124,7 +128,7 @@ export const BoreholeForm = forwardRef(({ borehole, editingEnabled, onSubmit }:
<FormInput
fieldName={"totalDepth"}
label={"totaldepth"}
value={borehole?.totalDepth || ""}
value={borehole?.totalDepth}
withThousandSeparator={true}
readonly={!editingEnabled}
/>
Expand All @@ -142,7 +146,7 @@ export const BoreholeForm = forwardRef(({ borehole, editingEnabled, onSubmit }:
<FormInput
fieldName={"topBedrockWeatheredMd"}
label={"top_bedrock_weathered_md"}
value={borehole?.topBedrockWeatheredMd || ""}
value={borehole?.topBedrockWeatheredMd}
withThousandSeparator={true}
readonly={!editingEnabled}
/>
Expand All @@ -156,7 +160,7 @@ export const BoreholeForm = forwardRef(({ borehole, editingEnabled, onSubmit }:
<FormInput
fieldName={"topBedrockFreshMd"}
label={"top_bedrock_fresh_md"}
value={borehole?.topBedrockFreshMd || ""}
value={borehole?.topBedrockFreshMd}
withThousandSeparator={true}
readonly={!editingEnabled}
/>
Expand Down Expand Up @@ -202,7 +206,7 @@ export const BoreholeForm = forwardRef(({ borehole, editingEnabled, onSubmit }:
fieldName={"remarks"}
multiline={true}
label={"remarks"}
value={borehole?.remarks || ""}
value={borehole?.remarks}
readonly={!editingEnabled}
/>
</FormContainer>
Expand Down
4 changes: 2 additions & 2 deletions src/client/src/pages/detail/form/completion/casingDisplay.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -55,10 +55,10 @@ const CasingDisplay = props => {
</TableCell>
<TableCell data-cy={`casingElements.${index}.toDepth-formDisplay`}>{element.toDepth}</TableCell>
<TableCell data-cy={`casingElements.${index}.kindId-formDisplay`}>
{domains?.data?.find(d => d.id === element.kindId)?.[i18n.language] || ""}
{domains?.data?.find(d => d.id === element.kindId)?.[i18n.language] ?? ""}
</TableCell>
<TableCell data-cy={`casingElements.${index}.materialId-formDisplay`}>
{domains?.data?.find(d => d.id === element.materialId)?.[i18n.language] || ""}
{domains?.data?.find(d => d.id === element.materialId)?.[i18n.language] ?? ""}
</TableCell>
<TableCell data-cy={`casingElements.${index}.innerDiameter-formDisplay`}>
{element.innerDiameter}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ const FieldMeasurementDisplay = props => {
renderBody={(result, index, styles) => (
<>
<TableCell sx={styles} data-cy={`fieldMeasurementResult.${index}.sampleType-formDisplay`}>
{domains?.data?.find(d => d.id === result.sampleTypeId)?.[i18n.language] || ""}
{domains?.data?.find(d => d.id === result.sampleTypeId)?.[i18n.language] ?? ""}
</TableCell>
<TableCell
component="th"
Expand All @@ -44,7 +44,7 @@ const FieldMeasurementDisplay = props => {
minWidth: "200px",
}}
data-cy={`fieldMeasurementResult.${index}.parameter-formDisplay`}>
{domains?.data?.find(d => d.id === result.parameterId)?.[i18n.language] || ""}
{domains?.data?.find(d => d.id === result.parameterId)?.[i18n.language] ?? ""}
</TableCell>
<TableCell sx={styles} data-cy={`fieldMeasurementResult.${index}.value-formDisplay`}>
{result?.value && (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ const HydrotestDisplay = props => {
minWidth: "200px",
}}
data-cy={`hydrotestResult.${index}.parameter-formDisplay`}>
{domains?.data?.find(d => d.id === result.parameterId)?.[i18n.language] || ""}
{domains?.data?.find(d => d.id === result.parameterId)?.[i18n.language] ?? ""}
</TableCell>
<TableCell sx={styles} data-cy={`hydrotestResult.${index}.value-formDisplay`}>
{result?.value && (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const ElevationSegment: FC<ElevationSegmentProps> = ({ borehole, editingEnabled,
fieldName={"elevationZ"}
label={"elevation_z"}
value={borehole.elevationZ}
controlledValue={formMethods.watch("elevationZ") || ""}
controlledValue={formMethods.watch("elevationZ") ?? ""}
withThousandSeparator={true}
readonly={!editingEnabled}
/>
Expand All @@ -39,7 +39,7 @@ const ElevationSegment: FC<ElevationSegmentProps> = ({ borehole, editingEnabled,
<FormInput
fieldName={"referenceElevation"}
label={"reference_elevation"}
value={borehole?.referenceElevation || ""}
value={borehole?.referenceElevation}
withThousandSeparator={true}
readonly={!editingEnabled}
/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ const IdentifierSegment = ({ borehole, editingEnabled, formMethods }: Identifier
fieldName={`boreholeCodelists.${index}.value`}
readonly={!editingEnabled}
label="borehole_identifier_value"
value={field.value || ""}
value={field.value}
type={FormValueType.Text}
/>
</Grid>
Expand Down
8 changes: 4 additions & 4 deletions src/client/src/pages/detail/form/location/locationPanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,10 @@ export const LocationPanel = forwardRef(
country: borehole.country,
canton: borehole.canton,
municipality: borehole.municipality,
locationX: borehole.locationX?.toFixed(borehole.precisionLocationX) || "",
locationY: borehole.locationY?.toFixed(borehole.precisionLocationY) || "",
locationXLV03: borehole.locationXLV03?.toFixed(borehole.precisionLocationXLV03) || "",
locationYLV03: borehole.locationYLV03?.toFixed(borehole.precisionLocationYLV03) || "",
locationX: borehole.locationX?.toFixed(borehole.precisionLocationX) ?? "",
locationY: borehole.locationY?.toFixed(borehole.precisionLocationY) ?? "",
locationXLV03: borehole.locationXLV03?.toFixed(borehole.precisionLocationXLV03) ?? "",
locationYLV03: borehole.locationYLV03?.toFixed(borehole.precisionLocationYLV03) ?? "",
locationPrecisionId: borehole.locationPrecisionId,
originalReferenceSystem: borehole.originalReferenceSystem,
boreholeCodelists: borehole?.boreholeCodelists,
Expand Down
13 changes: 4 additions & 9 deletions src/client/src/pages/detail/form/location/nameSegment.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ const NameSegment = ({ borehole, editingEnabled, formMethods }: NameSegmentProps
<FormInput
fieldName={"originalName"}
label={"original_name"}
value={borehole?.originalName || ""}
value={borehole?.originalName}
readonly={!editingEnabled}
/>
<TextField
Expand All @@ -39,21 +39,16 @@ const NameSegment = ({ borehole, editingEnabled, formMethods }: NameSegmentProps
}}
className="readonly"
label={t("workgroup")}
value={borehole?.workgroup?.name || ""}
value={borehole?.workgroup?.name}
/>
</FormContainer>
)}
<FormContainer direction="row">
<FormInput
fieldName={"name"}
label={"alternate_name"}
readonly={!editingEnabled}
value={borehole?.name || ""}
/>
<FormInput fieldName={"name"} label={"alternate_name"} readonly={!editingEnabled} value={borehole?.name} />
<FormInput
fieldName={"projectName"}
label={"project_name"}
value={borehole?.projectName || ""}
value={borehole?.projectName}
readonly={!editingEnabled}
/>
</FormContainer>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,7 @@ const DescriptionInput = props => {
variant="outlined"
size="small"
label={t("description_quality")}
defaultValue={item.descriptionQualityId || ""}
defaultValue={item.descriptionQualityId ?? ""}
data-cy="qt-decription-select"
InputLabelProps={{ shrink: true }}
onChange={e => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ const WorkgroupSelect = ({ workgroupId, enabledWorkgroups, setWorkgroupId, sx, h
data-cy="workgroup-formSelect"
value={workgroupId}
onChange={e => setWorkgroupId(e.target.value as string)}
renderValue={selected => options.find(o => o.value === selected)?.text || ""}>
renderValue={selected => options.find(o => o.value === selected)?.text ?? ""}>
{options.map(o => (
<MenuItem key={o.key} value={o.value}>
{o.text}
Expand Down
Loading