diff --git a/src/components/AreaCoordinates/AreaCoordinates.styled.tsx b/src/components/AreaCoordinates/AreaCoordinates.styled.tsx new file mode 100644 index 00000000..8f5b4567 --- /dev/null +++ b/src/components/AreaCoordinates/AreaCoordinates.styled.tsx @@ -0,0 +1,41 @@ +import { Typography } from '@equinor/eds-core-react'; +import styled from 'styled-components'; +import { spacings } from '../../tokens/spacings'; + +export const SideSheet = styled.div` + display: flex; + flex-direction: column; + + row-gap: ${spacings.MEDIUM}; +`; +export const Form = styled.form` + display: flex; + flex-direction: column; + + row-gap: ${spacings.LARGE}; +`; + +export const CoordinateGroup = styled.div` + display: flex; + flex-direction: column; + + > .autocomplete-error { + > div { + > div { + border: solid 2px red; + } + } + } + + > .input-error { + > div { + > input { + border: solid 2px red; + } + } + } +`; + +export const ErrorMessage = styled(Typography)` + color: red; +`; diff --git a/src/components/AreaCoordinates/AreaCoordinates.tsx b/src/components/AreaCoordinates/AreaCoordinates.tsx index 3f9f02c0..39f15761 100644 --- a/src/components/AreaCoordinates/AreaCoordinates.tsx +++ b/src/components/AreaCoordinates/AreaCoordinates.tsx @@ -10,8 +10,8 @@ import { import { useQuery } from '@tanstack/react-query'; import { useEffect, useState } from 'react'; import { AnalogueModelsService } from '../../api/generated/services/AnalogueModelsService'; -import { ErrorType } from '../../features/AddModel/AddModelDialog/AddModelDialog'; import optionTypes from '../../features/Compute/ComputeVariogram/CaseCard/CaseCard'; +import * as Styled from './AreaCoordinates.styled'; interface CoordinateType { top: { @@ -23,6 +23,12 @@ interface CoordinateType { Y?: string; }; } + +type AreaErrorType = { + area?: string; + coordinateTop?: string; + coordinateBottom?: string; +}; export const AreaCoordinates = ({ modelId }: { modelId: string }) => { const [selectedArea, setSelectedArea] = useState(); const [areaCoordinats, setAreaCoordinats] = useState({ @@ -35,7 +41,7 @@ export const AreaCoordinates = ({ modelId }: { modelId: string }) => { Y: undefined, }, }); - const [errors, setErrors] = useState({}); + const [errors, setErrors] = useState({}); const [submitting, setSubmitting] = useState(false); const { data, isLoading } = useQuery({ @@ -53,9 +59,9 @@ export const AreaCoordinates = ({ modelId }: { modelId: string }) => { selectedArea?: optionTypes, areaCoordinats?: CoordinateType, ) => { - const errors: ErrorType = {}; + const errors: AreaErrorType = {}; if (selectedArea === undefined) { - errors.field = 'Area to define coordinates for not selected'; + errors.area = 'Area to define coordinates for not selected'; } if ( @@ -64,7 +70,7 @@ export const AreaCoordinates = ({ modelId }: { modelId: string }) => { areaCoordinats?.top.X.length < 1 || areaCoordinats?.top.Y.length < 1 ) { - errors.formation = 'Top coordinates not selected'; + errors.coordinateTop = 'Top coordinates not selected'; } if ( @@ -73,7 +79,7 @@ export const AreaCoordinates = ({ modelId }: { modelId: string }) => { areaCoordinats?.bottom.X.length < 1 || areaCoordinats?.bottom.Y.length < 1 ) { - errors.file = 'Bottom coordinates not selected'; + errors.coordinateBottom = 'Bottom coordinates not selected'; } console.log(errors); @@ -100,87 +106,96 @@ export const AreaCoordinates = ({ modelId }: { modelId: string }) => { if (isLoading)

Loading.....

; return ( - <> + {data?.success && {data.data.name}} - Set coordinates for model areas -
- option.name} - onOptionsChange={(changes: AutocompleteChanges) => - setSelectedArea(changes.selectedItems[0]) - } - > + Set coordinates: + + + Area to define -
- Bottom Right Corner -
+ option.name} + onOptionsChange={(changes: AutocompleteChanges) => + setSelectedArea(changes.selectedItems[0]) + } + > + + + + Top Left Corner +
-
+
-
- -
- Top Left Corner -
+ + + Bottom Right Corner +
-
+
-
+
+ {(errors.area || errors.coordinateBottom || errors.coordinateTop) && ( + + Highlighted fields required + + )} - - + + ); };