Skip to content

Commit

Permalink
chore: uppdated add model validation
Browse files Browse the repository at this point in the history
  • Loading branch information
mheggelund committed Oct 10, 2023
1 parent 1b8443f commit 1b7fc8a
Show file tree
Hide file tree
Showing 4 changed files with 148 additions and 123 deletions.
6 changes: 6 additions & 0 deletions src/features/AddModel/AddModelDialog/AddModelDialog.styled.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,12 @@ const StyledDialogCustomContent = styled(Dialog.CustomContent)`
flex-direction: column;
row-gap: ${spacings.X_LARGE};
height: 740px;
> p {
&.error {
color: red;
}
}
`

const StyledDialogActions = styled(Dialog.Actions)`
Expand Down
73 changes: 41 additions & 32 deletions src/features/AddModel/AddModelDialog/AddModelDialog.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/* eslint-disable max-lines-per-function */
import { Button } from '@equinor/eds-core-react'
import { useState } from 'react'
import { Button, Typography } from '@equinor/eds-core-react'
import { useEffect, useState } from 'react'
import { ModelInputFilesTable } from '../ModelInputFilesTable/ModelInputFilesTable'
import { ModelMetadata } from '../ModelMetadata/ModelMetadata'
import * as Styled from './AddModelDialog.styled'
Expand All @@ -19,6 +19,11 @@ export default interface MetadataProps {
analogue?: string[]
}

export type ErrorType = {
field?: string
formation?: string
file?: string
}
export const AddModelDialog = ({
isOpen,
confirm,
Expand All @@ -30,48 +35,50 @@ export const AddModelDialog = ({
INI: undefined,
})
const [metadata, setMetadata] = useState<Partial<MetadataProps>>()

const [fieldValidationError, setFieldValidationError] =
useState<boolean>(false)
const [formationValidationError, setFormationValidationError] =
useState<boolean>(false)
const [errors, setErrors] = useState({})
const [submitting, setSubmitting] = useState(false)

function toggleINIFileContent() {
setFileDisplay(!isFileDisplay)
}

const INIFileContent = () => <p>Not implemented yet...</p>

const validateFieldInput = () => {
if (metadata?.field === undefined) {
setFieldValidationError(true)
} else if (metadata?.field.length === 0) {
setFieldValidationError(true)
} else {
setFieldValidationError(false)
const validateValues = (inputValues: Partial<MetadataProps> | undefined) => {
const errors: ErrorType = {}
if (inputValues?.field === undefined || inputValues?.field?.length === 0) {
errors.field = 'Field not selected'
}
}
const validateFormationInput = () => {
if (metadata?.formation === undefined) {
setFormationValidationError(true)
} else if (metadata?.formation.length === 0) {
setFormationValidationError(true)
} else {
setFormationValidationError(false)

if (
inputValues?.formation === undefined ||
inputValues?.formation?.length === 0
) {
errors.formation = 'Formation not selected'
}
}

const uploadFile = () => {
if (files.NC) confirm(files.NC)
if (!files.NC) {
errors.file = 'NC file missing'
}
return errors
}

const submit = () => {
validateFieldInput()
validateFormationInput()
const handleSubmit = () => {
setErrors(validateValues(metadata))
setSubmitting(true)
}

if (!fieldValidationError || !formationValidationError) uploadFile()
const finishSubmit = () => {
if (files.NC) confirm(files.NC)
}

useEffect(() => {
if (Object.keys(errors).length === 0 && submitting) {
finishSubmit()
}
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [errors, submitting])

return (
<Styled.Dialog open={isOpen}>
<Styled.Dialog.Header>
Expand All @@ -88,14 +95,16 @@ export const AddModelDialog = ({
/>
{isFileDisplay && <INIFileContent />}
<ModelMetadata
fieldValidationError={fieldValidationError}
formationValidationError={formationValidationError}
errors={errors}
metadata={metadata}
setMetadata={setMetadata}
/>
{Object.keys(errors).includes('file') && (
<Typography className="error">NC file missing</Typography>
)}
</Styled.DialogCustomContent>
<Styled.DialogActions>
<Button onClick={submit}>Confirm and start uploading</Button>
<Button onClick={handleSubmit}>Confirm and start uploading</Button>
<Button variant="outlined" onClick={cancel}>
Cancel
</Button>
Expand Down
64 changes: 39 additions & 25 deletions src/features/AddModel/ModelMetadata/ModelMetadata.styled.ts
Original file line number Diff line number Diff line change
@@ -1,33 +1,47 @@
import { TextField } from '@equinor/eds-core-react'
import styled from 'styled-components'
import { spacings } from '../../../tokens/spacings'

export const ModelMetadata = styled.div`
&.model-metadata {
display: grid;
grid-template-columns: auto auto;
column-gap: ${spacings.MEDIUM}};
row-gap: ${spacings.MEDIUM};
display: flex;
flex-direction: column;
> .model-description {
grid-column: 1 / span 2;
}
row-gap: ${spacings.MEDIUM};
`

> .model-required {
border-style: solid;
border-width: 2px;
border-color: red;
}
> .required-div {
> label {
color: red !important;
}
> .model-required2 {
> div {
border-style: solid !important;
border-width: 2px !important;
border-color: red !important;
}
export const Form = styled.form`
display: flex;
flex-direction: column;
row-gap: ${spacings.MEDIUM};
`

export const AutocompleteWrapper = styled.div`
display: flex;
flex-direction: column;
row-gap: ${spacings.MEDIUM};
`
export const AutocompleteRow = styled.div`
display: flex;
flex-direction: row;
flex: end;
column-gap: ${spacings.MEDIUM};
> div {
flex-grow: 1;
}
`

export const TextInput = styled(TextField)`
display: flex;
flex-direction: column;
`
export const Required = styled.div`
> label {
color: red;
}
> .model-required {
> div {
> div {
border: solid 2px red;
}
}
}
Expand Down
128 changes: 62 additions & 66 deletions src/features/AddModel/ModelMetadata/ModelMetadata.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,21 +3,18 @@ import {
Autocomplete,
AutocompleteChanges,
Label,
TextField,
Typography,
} from '@equinor/eds-core-react'
import MetadataProps from '../AddModelDialog/AddModelDialog'
import MetadataProps, { ErrorType } from '../AddModelDialog/AddModelDialog'

import * as Styled from './ModelMetadata.styled'

export const ModelMetadata = ({
fieldValidationError,
formationValidationError,
errors,
metadata,
setMetadata,
}: {
fieldValidationError: boolean
formationValidationError: boolean
errors: ErrorType
metadata: Partial<MetadataProps> | undefined
setMetadata: (metadata: Partial<MetadataProps>) => void
}) => {
Expand All @@ -32,70 +29,69 @@ export const ModelMetadata = ({
const handleInput = (e: AutocompleteChanges<string>, target: string) => {
setMetadata({ ...metadata, [target]: e.selectedItems })
}

return (
<Styled.ModelMetadata className="model-metadata">
<Typography variant="h4">Description and metadata</Typography>
<TextField
id="model-description"
className="model-description"
label="Model description (optional)"
value={metadata?.description}
onChange={(e: React.ChangeEvent<HTMLTextAreaElement>) =>
setMetadata({ ...metadata, description: e.currentTarget.value })
}
multiline
/>
<div className="required-div">
<Autocomplete
id="field-select"
className={`${
fieldValidationError && 'model-required model-required2'
}`}
label="Field"
options={fields.field}
onOptionsChange={(e: AutocompleteChanges<string>) =>
handleInput(e, 'field')
}
></Autocomplete>
{fieldValidationError && (
<Label
label="This field is required"
className="required-lable"
></Label>
)}
</div>
<div className="required-div">
<Autocomplete
className={`${formationValidationError && 'model-required2'}`}
label="Formation"
options={fields.formation}
multiple
onOptionsChange={(e: AutocompleteChanges<string>) =>
handleInput(e, 'formation')
<Styled.Form>
<Styled.TextInput
id="model-description"
label="Model description (optional)"
value={metadata?.description}
onChange={(e: React.ChangeEvent<HTMLTextAreaElement>) =>
setMetadata({ ...metadata, description: e.currentTarget.value })
}
></Autocomplete>
{formationValidationError && (
<Label
label="This field is required"
className="required-lable"
></Label>
)}
</div>
<Autocomplete
label="Analogue (optional)"
options={fields.analogue}
multiple
onOptionsChange={(e: AutocompleteChanges<string>) =>
setMetadata({ ...metadata, analogue: e.selectedItems })
}
></Autocomplete>
<Autocomplete
label="Zone (optional)"
options={fields.zone}
onOptionsChange={(e: AutocompleteChanges<string>) =>
setMetadata({ ...metadata, zone: e.selectedItems })
}
></Autocomplete>{' '}
multiline
rows={4}
rowsMax={8}
/>
<Styled.AutocompleteWrapper>
<Styled.AutocompleteRow>
<Styled.Required>
<Autocomplete
className={`${errors.field && 'model-required'}`}
label="Field"
options={fields.field}
onOptionsChange={(e: AutocompleteChanges<string>) =>
handleInput(e, 'field')
}
></Autocomplete>
{errors.field && <Label label="This field is required"></Label>}
</Styled.Required>
<Styled.Required>
<Autocomplete
className={`${errors.formation && 'model-required'}`}
label="Formation"
options={fields.formation}
multiple
onOptionsChange={(e: AutocompleteChanges<string>) =>
handleInput(e, 'formation')
}
></Autocomplete>
{errors.formation && (
<Label label="This field is required"></Label>
)}
</Styled.Required>
</Styled.AutocompleteRow>
<Styled.AutocompleteRow>
<Autocomplete
label="Analogue (optional)"
options={fields.analogue}
multiple
onOptionsChange={(e: AutocompleteChanges<string>) =>
setMetadata({ ...metadata, analogue: e.selectedItems })
}
></Autocomplete>
<Autocomplete
label="Zone (optional)"
options={fields.zone}
onOptionsChange={(e: AutocompleteChanges<string>) =>
setMetadata({ ...metadata, zone: e.selectedItems })
}
></Autocomplete>
</Styled.AutocompleteRow>
</Styled.AutocompleteWrapper>
</Styled.Form>
</Styled.ModelMetadata>
)
}

0 comments on commit 1b7fc8a

Please sign in to comment.