first commit
This commit is contained in:
@@ -0,0 +1,39 @@
|
||||
import { useEffect, useState } from 'react'
|
||||
import { getJSON } from '../../../infrastructure/fetch-json'
|
||||
import useAbortController from '../../../shared/hooks/use-abort-controller'
|
||||
|
||||
export function useUserContacts() {
|
||||
const [loading, setLoading] = useState(true)
|
||||
const [data, setData] = useState(null)
|
||||
const [error, setError] = useState(false)
|
||||
|
||||
const { signal } = useAbortController()
|
||||
|
||||
useEffect(() => {
|
||||
getJSON('/user/contacts', { signal })
|
||||
.then(data => {
|
||||
setData(data.contacts.map(buildContact))
|
||||
})
|
||||
.catch(error => setError(error))
|
||||
.finally(() => setLoading(false))
|
||||
}, [signal])
|
||||
|
||||
return { loading, data, error }
|
||||
}
|
||||
|
||||
function buildContact(contact) {
|
||||
const [emailPrefix] = contact.email.split('@')
|
||||
|
||||
// the name is not just the default "email prefix as first name"
|
||||
const hasName = contact.last_name || contact.first_name !== emailPrefix
|
||||
|
||||
const name = hasName
|
||||
? [contact.first_name, contact.last_name].filter(Boolean).join(' ')
|
||||
: ''
|
||||
|
||||
return {
|
||||
...contact,
|
||||
name,
|
||||
display: name ? `${name} <${contact.email}>` : contact.email,
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user