54 lines
No EOL
1.6 KiB
TypeScript
54 lines
No EOL
1.6 KiB
TypeScript
import { useEffect } from 'react';
|
|
import { useHistory } from 'react-router-dom';
|
|
|
|
import { Entities } from 'soapbox/entity-store/entities';
|
|
import { useEntityLookup } from 'soapbox/entity-store/hooks';
|
|
import { useFeatures, useLoggedIn } from 'soapbox/hooks';
|
|
import { useApi } from 'soapbox/hooks/useApi';
|
|
import { type Account, accountSchema } from 'soapbox/schemas';
|
|
|
|
import { useRelationship } from './useRelationship';
|
|
|
|
interface UseAccountLookupOpts {
|
|
withRelationship?: boolean
|
|
}
|
|
|
|
function useAccountLookup(acct: string | undefined, opts: UseAccountLookupOpts = {}) {
|
|
const api = useApi();
|
|
const features = useFeatures();
|
|
const history = useHistory();
|
|
const { me } = useLoggedIn();
|
|
const { withRelationship } = opts;
|
|
|
|
const { entity: account, isUnauthorized, ...result } = useEntityLookup<Account>(
|
|
Entities.ACCOUNTS,
|
|
(account) => account.acct.toLowerCase() === acct?.toLowerCase(),
|
|
() => api.get(`/api/v1/accounts/lookup?acct=${acct}`),
|
|
{ schema: accountSchema, enabled: !!acct },
|
|
);
|
|
|
|
const {
|
|
relationship,
|
|
isLoading: isRelationshipLoading,
|
|
} = useRelationship(account?.id, { enabled: withRelationship });
|
|
|
|
const isBlocked = account?.relationship?.blocked_by === true;
|
|
const isUnavailable = (me === account?.id) ? false : (isBlocked && !features.blockersVisible);
|
|
|
|
useEffect(() => {
|
|
if (isUnauthorized) {
|
|
history.push('/login');
|
|
}
|
|
}, [isUnauthorized]);
|
|
|
|
return {
|
|
...result,
|
|
isLoading: result.isLoading,
|
|
isRelationshipLoading,
|
|
isUnauthorized,
|
|
isUnavailable,
|
|
account: account ? { ...account, relationship } : undefined,
|
|
};
|
|
}
|
|
|
|
export { useAccountLookup }; |