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 ) }
2022-12-17 13:48:45 -08:00
className = 'divide-y divide-solid divide-gray-200 dark:divide-gray-800'
2022-04-28 13:53:34 -07:00
>
{ accountIds . map ( id = > (
2023-04-01 11:37:34 -07:00
< div key = { id } className = 'px-5 py-4' >
2022-12-17 13:48:45 -08:00
< UnapprovedAccount accountId = { id } / >
< / div >
2022-04-28 13:53:34 -07:00
) ) }
< / ScrollableList >
) ;
} ;
export default AwaitingApproval ;