2022-04-28 23:01:50 +00:00
|
|
|
import { listContracts } from '../lib/firebase/contracts'
|
|
|
|
import { useEffect, useState } from 'react'
|
|
|
|
import { User } from '../../common/user'
|
|
|
|
|
|
|
|
export const useHasCreatedContractToday = (user: User | null | undefined) => {
|
|
|
|
const [hasCreatedContractToday, setHasCreatedContractToday] = useState(false)
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
// Uses utc time like the server.
|
2022-04-29 01:31:43 +00:00
|
|
|
const utcTimeString = new Date().toISOString()
|
|
|
|
const todayAtMidnight = new Date(utcTimeString).setUTCHours(0, 0, 0, 0)
|
2022-04-28 23:01:50 +00:00
|
|
|
|
|
|
|
async function listUserContractsForToday() {
|
|
|
|
if (!user) return
|
|
|
|
|
|
|
|
const contracts = await listContracts(user.id)
|
|
|
|
const todayContracts = contracts.filter(
|
|
|
|
(contract) => contract.createdTime > todayAtMidnight
|
|
|
|
)
|
|
|
|
setHasCreatedContractToday(todayContracts.length > 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
listUserContractsForToday()
|
|
|
|
}, [user])
|
|
|
|
|
|
|
|
return hasCreatedContractToday
|
|
|
|
}
|