Files
mtdb_movie/resources/client/user-lists/pages/edit-user-list-page.tsx
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

64 lines
2.0 KiB
TypeScript
Executable File

import React, {Fragment, ReactNode} from 'react';
import {PageStatus} from '@common/http/page-status';
import {useForm} from 'react-hook-form';
import {CrupdateResourceLayout} from '@common/admin/crupdate-resource-layout';
import {Trans} from '@common/i18n/trans';
import {StaticPageTitle} from '@common/seo/static-page-title';
import {useUpdateList} from '@app/user-lists/requests/use-update-list';
import {CrupdateUserListForm} from '@app/user-lists/pages/crupdate-user-list-form';
import {IconButton} from '@common/ui/buttons/icon-button';
import {ArrowBackIcon} from '@common/icons/material/ArrowBack';
import {Link} from 'react-router-dom';
import {CreateChannelPayload} from '@common/admin/channels/requests/use-create-channel';
import {useChannel} from '@common/channels/requests/use-channel';
import {Channel} from '@common/channels/channel';
export function EditUserListPage() {
const query = useChannel(undefined, 'editUserListPage');
return query.data ? (
<Fragment>
<StaticPageTitle>
<Trans message="Edit list" />
</StaticPageTitle>
<PageContent list={query.data.channel}>
<CrupdateUserListForm />
</PageContent>
</Fragment>
) : (
<PageStatus query={query} loaderClassName="absolute m-auto inset-0" />
);
}
interface PageContentProps {
list: Channel;
children: ReactNode;
}
function PageContent({list, children}: PageContentProps) {
const form = useForm<CreateChannelPayload>({
// @ts-ignore
defaultValues: {
...list,
},
});
const updateList = useUpdateList(form);
return (
<CrupdateResourceLayout
backButton={
<IconButton elementType={Link} relative="path" to="../../">
<ArrowBackIcon />
</IconButton>
}
form={form}
onSubmit={values => {
updateList.mutate(values);
}}
title={<Trans message="Edit “:name“ List" values={{name: list.name}} />}
isLoading={updateList.isPending}
>
{children}
</CrupdateResourceLayout>
);
}