Skip to content

Commit

Permalink
fix(console): improve audit log error handling if the related user ha…
Browse files Browse the repository at this point in the history
…s been removed
  • Loading branch information
charIeszhao committed May 16, 2024
1 parent 1246d2b commit 15efd79
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 8 deletions.
8 changes: 8 additions & 0 deletions .changeset/sixty-scissors-tell.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
---
"@logto/console": patch
---

improve error handling on audit logs

- No longer toasts error messages if the audit log related user entity has been removed.
- Display a fallback `user-id (deleted)` information instead.
30 changes: 22 additions & 8 deletions packages/console/src/components/UserName/index.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
import type { User } from '@logto/schemas';
import { conditionalString } from '@silverhand/essentials';
import classNames from 'classnames';
import { useMemo } from 'react';
import { useTranslation } from 'react-i18next';
import { Link } from 'react-router-dom';
import useSWR from 'swr';

import type { RequestError } from '@/hooks/use-api';
import useApi from '@/hooks/use-api';
import useSwrFetcher from '@/hooks/use-swr-fetcher';
import useTenantPathname from '@/hooks/use-tenant-pathname';
import { shouldRetryOnError } from '@/utils/request';
import { getUserTitle } from '@/utils/user';

import UserAvatar from '../UserAvatar';
Expand All @@ -18,18 +22,28 @@ type Props = {
};

function UserName({ userId, isLink = false }: Props) {
const { data, error } = useSWR<User, RequestError>(`api/users/${userId}`);
const isLoading = !data && !error;
const name = conditionalString(data && getUserTitle(data));
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
const fetchApi = useApi({ hideErrorToast: true });
const fetcher = useSwrFetcher<User>(fetchApi);
const { data, isLoading, error } = useSWR<User, RequestError>(`api/users/${userId}`, {
fetcher,
shouldRetryOnError: shouldRetryOnError({ ignore: [404] }),
});
const { getTo } = useTenantPathname();

if (isLoading) {
return null;
}
const name = useMemo(() => {
if (data) {
return getUserTitle(data);
}
if (error?.status === 404) {
return `${userId} (${t('general.deleted')})`;
}
return '-';
}, [userId, data, error?.status, t]);

return (
<div className={styles.userName}>
{isLink ? (
{isLink && data ? (
<Link to={getTo(`/users/${userId}`)} className={classNames(styles.title, styles.link)}>
<UserAvatar hasTooltip size="micro" user={data} />
<span>{name}</span>
Expand Down

0 comments on commit 15efd79

Please sign in to comment.