import { Button, Form, Input, message, Popconfirm, Tabs } from 'antd'; import React from 'react'; import { useNavigate, useParams } from 'react-router'; import { deleteWorkspaceWebsite, useWorkspaceWebsiteInfo, } from '../api/model/website'; import { useRequest } from '../hooks/useRequest'; import { useCurrentWorkspaceId } from '../store/user'; import { ErrorTip } from './ErrorTip'; import { Loading } from './Loading'; import { NoWorkspaceTip } from './NoWorkspaceTip'; import { defaultErrorHandler, defaultSuccessHandler, trpc } from '../api/trpc'; import { useQueryClient } from '@tanstack/react-query'; import { useEvent } from '../hooks/useEvent'; export const WebsiteInfo: React.FC = React.memo(() => { const workspaceId = useCurrentWorkspaceId(); const { websiteId } = useParams<{ websiteId: string; }>(); const { website, isLoading } = useWorkspaceWebsiteInfo( workspaceId, websiteId! ); const navigate = useNavigate(); const queryClient = useQueryClient(); const updateMutation = trpc.website.updateInfo.useMutation({ onSuccess: () => { queryClient.resetQueries(['websites', workspaceId]); // TODO: translation to trpc defaultSuccessHandler(); }, onError: defaultErrorHandler, }); const handleSave = useEvent( async (values: { name: string; domain: string }) => { await updateMutation.mutateAsync({ workspaceId, websiteId: websiteId!, name: values.name, domain: values.domain, }); } ); const [, handleDeleteWebsite] = useRequest(async () => { await deleteWorkspaceWebsite(workspaceId, websiteId!); message.success('Delete Success'); navigate('/settings/websites'); }); if (!workspaceId) { return ; } if (!websiteId) { return ; } if (isLoading) { return ; } if (!website) { return ; } return (
Website Info
handleDeleteWebsite()} >
); }); WebsiteInfo.displayName = 'WebsiteInfo';