ConceptPortal-public/rsconcept/frontend/src/features/ai/pages/prompt-templates-page/prompt-templates-page.tsx

59 lines
2.0 KiB
TypeScript
Raw Normal View History

2025-07-15 21:03:50 +03:00
import { ErrorBoundary } from 'react-error-boundary';
import { isAxiosError } from 'axios';
import { z } from 'zod';
import { useBlockNavigation } from '@/app';
import { routes } from '@/app/urls';
import { RequireAuth } from '@/features/auth/components/require-auth';
import { TextURL } from '@/components/control';
import { type ErrorData } from '@/components/info-error';
import { useQueryStrings } from '@/hooks/use-query-strings';
import { useModificationStore } from '@/stores/modification';
import { PromptTabID, TemplatesTabs } from './templates-tabs';
const paramsSchema = z.strictObject({
2025-07-24 12:32:58 +03:00
tab: z.preprocess(v => (v ? Number(v) : undefined), z.enum(PromptTabID).default(PromptTabID.LIST)),
2025-07-15 21:03:50 +03:00
active: z.preprocess(v => (v ? Number(v) : undefined), z.number().nullable().default(null))
});
export function PromptTemplatesPage() {
const query = useQueryStrings();
const urlData = paramsSchema.parse({
tab: query.get('tab'),
active: query.get('active')
});
const isModified = useModificationStore(state => state.isModified);
2025-07-15 21:03:50 +03:00
useBlockNavigation(isModified);
return (
<ErrorBoundary
FallbackComponent={({ error }) => <ProcessError error={error as ErrorData} itemID={urlData.active} />}
>
<RequireAuth>
<TemplatesTabs activeID={urlData.active} tab={urlData.tab} />
</RequireAuth>
</ErrorBoundary>
);
}
// ====== Internals =========
function ProcessError({ error, itemID }: { error: ErrorData; itemID?: number | null }): React.ReactElement | null {
if (isAxiosError(error) && error.response) {
if (error.response.status === 404) {
return (
<div className='flex flex-col items-center p-2 mx-auto'>
<p>{`Шаблон запроса с указанным идентификатором ${itemID} отсутствует`}</p>
<div className='flex justify-center'>
<TextURL text='Список шаблонов' href={`/${routes.prompt_templates}`} />
</div>
</div>
);
}
}
throw error as Error;
}