mirror of
https://gitlab.com/MrFry/qmining-page
synced 2025-04-01 20:23:44 +02:00
all questions: showing loading indicator on new db select, loading indicator update
This commit is contained in:
parent
230f069aa4
commit
e563e503c9
3 changed files with 50 additions and 11 deletions
|
@ -1,10 +1,12 @@
|
||||||
import React, { PureComponent } from 'react'
|
import React, { PureComponent } from 'react'
|
||||||
|
|
||||||
|
import styles from './LoadingIndicator.module.css'
|
||||||
|
|
||||||
class LoadingIndicator extends PureComponent {
|
class LoadingIndicator extends PureComponent {
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<div className='loadingindicator'>
|
<div className={styles.loadContainer}>
|
||||||
Loading...
|
<div className={styles.load} />
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
24
src/components/LoadingIndicator.module.css
Normal file
24
src/components/LoadingIndicator.module.css
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
.load {
|
||||||
|
border: 4px solid #f3f3f3;
|
||||||
|
border-top: 4px solid #99f;
|
||||||
|
border-radius: 50%;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
animation: spin 2s linear infinite;
|
||||||
|
|
||||||
|
margin: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes spin {
|
||||||
|
0% {
|
||||||
|
transform: rotate(0deg);
|
||||||
|
}
|
||||||
|
100% {
|
||||||
|
transform: rotate(360deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.loadContainer {
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
|
@ -70,11 +70,12 @@ function fetchDbs() {
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function AllQuestions({ router }) {
|
export default function AllQuestions({ router }) {
|
||||||
const [asd, setAsd] = useState(false)
|
const [subjectsShowing, setSubjectsShowing] = useState(false)
|
||||||
const [data, setData] = useState(null)
|
|
||||||
const [dbs, setDbs] = useState(null)
|
|
||||||
const [searchTerm, setSearchTerm] = useState('')
|
const [searchTerm, setSearchTerm] = useState('')
|
||||||
const [activeSubjName, setActiveSubjName] = useState('')
|
const [activeSubjName, setActiveSubjName] = useState('')
|
||||||
|
const [dbs, setDbs] = useState(null)
|
||||||
|
const [data, setData] = useState(null)
|
||||||
|
const [fetchingData, setFetchingData] = useState(false)
|
||||||
const subjectCount = data ? data.length : 0
|
const subjectCount = data ? data.length : 0
|
||||||
const questionCount = data ? data.reduce(countReducer, 0) : 0
|
const questionCount = data ? data.reduce(countReducer, 0) : 0
|
||||||
|
|
||||||
|
@ -102,13 +103,17 @@ export default function AllQuestions({ router }) {
|
||||||
defaultValue={-1}
|
defaultValue={-1}
|
||||||
onChange={(event) => {
|
onChange={(event) => {
|
||||||
const key = event.target.value
|
const key = event.target.value
|
||||||
|
setData(null)
|
||||||
|
setFetchingData(true)
|
||||||
if (key === 'all') {
|
if (key === 'all') {
|
||||||
fetchAllData(dbs).then((res) => {
|
fetchAllData(dbs).then((res) => {
|
||||||
setData(mergeData(res))
|
setData(mergeData(res))
|
||||||
|
setFetchingData(false)
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
fetchData(dbs[key]).then((res) => {
|
fetchData(dbs[key]).then((res) => {
|
||||||
setData(res.data)
|
setData(res.data)
|
||||||
|
setFetchingData(false)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}}
|
}}
|
||||||
|
@ -241,19 +246,27 @@ export default function AllQuestions({ router }) {
|
||||||
{data && `${questionCount} kérdés, ${subjectCount} tárgy`}
|
{data && `${questionCount} kérdés, ${subjectCount} tárgy`}
|
||||||
<div className={styles.typeSelector}>
|
<div className={styles.typeSelector}>
|
||||||
<div
|
<div
|
||||||
className={!asd ? styles.activeTypeSelector : ''}
|
className={!subjectsShowing ? styles.activeTypeSelector : ''}
|
||||||
onClick={() => setAsd(false)}
|
onClick={() => setSubjectsShowing(false)}
|
||||||
>
|
>
|
||||||
Kérdések
|
Kérdések
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
className={asd ? styles.activeTypeSelector : ''}
|
className={subjectsShowing ? styles.activeTypeSelector : ''}
|
||||||
onClick={() => setAsd(true)}
|
onClick={() => setSubjectsShowing(true)}
|
||||||
>
|
>
|
||||||
Tárgyak
|
Tárgyak
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div>{asd ? renderSubjectBrowser() : renderQuestionBrowser()}</div>
|
{fetchingData ? (
|
||||||
|
<LoadingIndicator />
|
||||||
|
) : (
|
||||||
|
<div>
|
||||||
|
{subjectsShowing
|
||||||
|
? renderSubjectBrowser()
|
||||||
|
: renderQuestionBrowser()}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</>
|
</>
|
||||||
) : (
|
) : (
|
||||||
<LoadingIndicator />
|
<LoadingIndicator />
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue