Skip to content

Commit

Permalink
Add time delay before displaying the error and warning messages
Browse files Browse the repository at this point in the history
  • Loading branch information
csillag committed Jul 7, 2023
1 parent 403dadd commit b1bf146
Showing 1 changed file with 21 additions and 10 deletions.
31 changes: 21 additions & 10 deletions src/app/components/Search/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@ import { SearchScope } from '../../../types/searchScope'
import { textSearchMininumLength } from './search-utils'
import Typography from '@mui/material/Typography'
import { isValidBlockHeight } from '../../utils/helpers'
import { isValidMnemonic } from '../../utils/helpers'
import { tooltipDelay } from '../../../styles/theme'
// import { isValidMnemonic } from '../../utils/helpers'

export type SearchVariant = 'button' | 'icon' | 'expandable'

Expand Down Expand Up @@ -106,6 +107,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
const [value, setValue] = useState('')
const [isFocused, setIsFocused] = useState(false)
const valueInSearchParams = useSearchParams()[0].get('q') ?? ''
const [itsTimeToAct, setItsTimeToAct] = useState(false)

const wordsOfPower = t('search.wordsOfPower')
const hasWordsOfPower = value.trim().toLowerCase().startsWith(wordsOfPower.toLowerCase())
Expand Down Expand Up @@ -163,6 +165,19 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
: undefined
const hasWarning = !!warningMessage

const hasProblem = hasError || hasWarning

useEffect(() => {
if (hasProblem) {
const timeout = setTimeout(() => {
setItsTimeToAct(true)
}, tooltipDelay * 2)
return () => clearTimeout(timeout)
} else {
setItsTimeToAct(false)
}
}, [hasProblem])

return (
<SearchForm
searchVariant={variant}
Expand All @@ -172,7 +187,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
>
<TextField
sx={{
...(hasWarning && !hasError
...(itsTimeToAct && hasWarning && !hasError
? {
[`& .${outlinedInputClasses.error} .${outlinedInputClasses.notchedOutline}`]: {
borderColor: COLORS.warningColor,
Expand All @@ -182,7 +197,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
}}
value={value}
onChange={e => onChange(e.target.value)}
error={hasError || hasWarning}
error={itsTimeToAct && hasProblem}
onFocus={() => onFocusChange(true)}
onBlur={() => onFocusChange(false)}
InputProps={{
Expand All @@ -198,11 +213,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
<HighlightOffIcon />
</IconButton>
)}
<SearchButton
disabled={disabled || hasError || hasWarning}
searchVariant={variant}
type="submit"
>
<SearchButton disabled={disabled || hasProblem} searchVariant={variant} type="submit">
{searchButtonContent}
</SearchButton>
</>
Expand All @@ -223,7 +234,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
value &&
value !== valueInSearchParams && (
<>
{hasError && (
{itsTimeToAct && hasError && (
<>
<Typography
component="span"
Expand All @@ -244,7 +255,7 @@ const SearchCmp: FC<SearchProps> = ({ scope, variant, disabled, onFocusChange: o
<br />
</>
)}
{hasWarning && (
{itsTimeToAct && hasWarning && (
<>
<Typography
component="span"
Expand Down

0 comments on commit b1bf146

Please sign in to comment.