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

Infinite FETCH_STTS #2720

Merged
merged 9 commits into from
Nov 7, 2023
92 changes: 70 additions & 22 deletions tdrs-frontend/src/components/STTComboBox/STTComboBox.jsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
import React, { useEffect } from 'react'
import React, { useEffect, useState, useRef } from 'react'
import PropTypes from 'prop-types'
import { useDispatch, useSelector } from 'react-redux'
import { fetchSttList } from '../../actions/sttList'
import ComboBox from '../ComboBox'
import Button from '../Button'

/**
* @param {function} selectStt - Function to reference and change the
Expand All @@ -12,36 +13,83 @@ import ComboBox from '../ComboBox'
* @param {function} handleBlur - Runs on blur of combo box element.
* @param {function} error - Reference to stt errors object.
*/

function STTComboBox({ selectStt, selectedStt, handleBlur, error }) {
const sttList = useSelector((state) => state?.stts?.sttList)
const sttReduction = useSelector((state) => state?.stts)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

minor point but i'd go with something like sttListRequest for the variable name to indicate what's present in the data structure rather than where in the redux stack it comes from

const dispatch = useDispatch()
const [numTries, setNumTries] = useState(0)
const [reachedMaxTries, setReachedMaxTries] = useState(false)

useEffect(() => {
if (sttList.length === 0) {
if (
sttReduction.sttList.length === 0 &&
numTries <= 3 &&
!sttReduction.loading
) {
dispatch(fetchSttList())
setNumTries(numTries + 1)
} else if (
sttReduction.sttList.length === 0 &&
numTries > 3 &&
!reachedMaxTries
) {
setReachedMaxTries(true)
}
}, [dispatch, sttList])
}, [dispatch, sttReduction.sttList, numTries, reachedMaxTries])

const modalRef = useRef()
const headerRef = useRef()
const onSignOut = () => {
window.location.href = `${process.env.REACT_APP_BACKEND_URL}/logout/oidc`
}

return (
<ComboBox
name="stt"
label="Associated State, Tribe, or Territory*"
error={error ? 'A state, tribe, or territory is required' : undefined}
handleSelect={selectStt}
selected={selectedStt}
handleBlur={handleBlur}
placeholder="- Select or Search -"
aria-required="true"
>
<option value="" disabled hidden>
- Select or Search -
</option>
{sttList.map((stt) => (
<option className="sttOption" key={stt.id} value={stt.name}>
{stt.name}
<>
<ComboBox
name="stt"
label="Associated State, Tribe, or Territory*"
error={error ? 'A state, tribe, or territory is required' : undefined}
handleSelect={selectStt}
selected={selectedStt}
handleBlur={handleBlur}
placeholder="- Select or Search -"
aria-required="true"
>
<option value="" disabled hidden>
- Select or Search -
</option>
))}
</ComboBox>
{sttReduction.sttList.map((stt) => (
<option className="sttOption" key={stt.id} value={stt.name}>
{stt.name}
</option>
))}
</ComboBox>
<div
id="emptySttListModal"
className={`modal ${
reachedMaxTries ? 'display-block' : 'display-none'
}`}
>
<div className="modal-content" ref={modalRef}>
<h1
className="font-serif-xl margin-4 margin-bottom-0 text-normal"
tabIndex="-1"
ref={headerRef}
>
TDP systems are currently experiencing technical difficulties.
</h1>
<p className="margin-4 margin-top-1">
Please sign out and try signing in again. If the issue persists
contact support at tanfdata@acf.hhs.gov.
</p>
<div className="margin-x-4 margin-bottom-4">
<Button type="button" className="sign-out" onClick={onSignOut}>
Sign Out Now
</Button>
</div>
</div>
</div>
</>
)
}

Expand Down