2022-04-28 13:53:34 -07:00
import React , { useState , useEffect } from 'react' ;
import { defineMessages , useIntl } from 'react-intl' ;
import { fetchUsers } from 'soapbox/actions/admin' ;
2022-11-15 08:00:49 -08:00
import ScrollableList from 'soapbox/components/scrollable-list' ;
2022-04-28 13:53:34 -07:00
import { useAppSelector , useAppDispatch } from 'soapbox/hooks' ;
2022-11-15 09:23:36 -08:00
import UnapprovedAccount from '../components/unapproved-account' ;
2022-04-28 13:53:34 -07:00
const messages = defineMessages ( {
heading : { id : 'column.admin.awaiting_approval' , defaultMessage : 'Awaiting Approval' } ,
emptyMessage : { id : 'admin.awaiting_approval.empty_message' , defaultMessage : 'There is nobody waiting for approval. When a new user signs up, you can review them here.' } ,
} ) ;
const AwaitingApproval : React.FC = ( ) = > {
const intl = useIntl ( ) ;
const dispatch = useAppDispatch ( ) ;
const accountIds = useAppSelector ( state = > state . admin . awaitingApproval ) ;
const [ isLoading , setLoading ] = useState ( true ) ;
useEffect ( ( ) = > {
dispatch ( fetchUsers ( [ 'local' , 'need_approval' ] ) )
. then ( ( ) = > setLoading ( false ) )
. catch ( ( ) = > { } ) ;
} , [ ] ) ;
const showLoading = isLoading && accountIds . count ( ) === 0 ;
return (
< ScrollableList
isLoading = { isLoading }
showLoading = { showLoading }
scrollKey = 'awaiting-approval'
emptyMessage = { intl . formatMessage ( messages . emptyMessage ) }
>
{ accountIds . map ( id = > (
< UnapprovedAccount accountId = { id } key = { id } / >
) ) }
< / ScrollableList >
) ;
} ;
export default AwaitingApproval ;