pay-admin/src/pages/asset/announcement/modals/AnnouncementCreate.tsx

144 lines
4.1 KiB
TypeScript
Raw Normal View History

2025-09-08 17:22:58 +08:00
import {
MyBetaModalFormProps,
MyButtons,
MyFormItems,
2025-09-08 17:22:58 +08:00
MyModalFormProps,
rulesHelper,
} from '@/common';
import MyEditor from '@/common/components/Editor';
2025-09-18 19:40:30 +08:00
import { Selects } from '@/components/Select';
2025-09-08 17:22:58 +08:00
import { Apis } from '@/gen/Apis';
import { MsgPropertyAnnouncementsPublishTypeEnum } from '@/gen/Enums';
2025-09-08 17:22:58 +08:00
import { BetaSchemaForm } from '@ant-design/pro-components';
import { Form, message } from 'antd';
export default function Create(props: MyBetaModalFormProps) {
const [form] = Form.useForm();
return (
<BetaSchemaForm<ApiTypes.Msg.MsgPropertyAnnouncements.Store>
{...MyModalFormProps.props}
title={`添加公告`}
layout="horizontal"
labelCol={{ span: 4 }}
wrapperCol={{ span: 20 }}
labelAlign="left"
width="950px"
2025-09-08 17:22:58 +08:00
trigger={<MyButtons.Create title={`添加公告`} />}
key={new Date().getTime()}
form={form}
onOpenChange={(open: any) => {
if (open) {
form.resetFields(); // 清空表单数据
form.setFieldValue('is_publish', 1);
2025-09-08 17:22:58 +08:00
}
}}
onFinish={async (values) =>
Apis.Msg.MsgPropertyAnnouncements.Store({
...values,
2025-09-18 19:40:30 +08:00
asset_projects_id: values?.asset_projects_id || props.item?.id,
2025-09-08 17:22:58 +08:00
})
.then(() => {
props.reload?.();
message.success('添加公告内容成功');
return true;
})
.catch(() => false)
}
columns={[
2025-09-18 19:40:30 +08:00
...(props?.item?.id
? []
: [
Selects?.AssetProjects({
key: 'asset_projects_id',
title: '关联项目',
colProps: { span: 24 },
required: true,
}),
]),
2025-09-08 17:22:58 +08:00
{
key: 'title',
title: '公告标题',
colProps: { span: 24 },
required: true,
formItemProps: {
labelCol: { span: 4 },
wrapperCol: { span: 20 },
...rulesHelper.text,
},
},
MyFormItems.EnumRadio({
key: 'publish_type',
title: '发布方式',
colProps: { span: 8 },
valueEnum: MsgPropertyAnnouncementsPublishTypeEnum,
formItemProps: {
labelCol: { span: 12 },
wrapperCol: { span: 12 },
...rulesHelper.text,
},
}),
{
name: ['publish_type'],
valueType: 'dependency',
columns: ({ publish_type }) => {
return publish_type ===
MsgPropertyAnnouncementsPublishTypeEnum.Schedule.value
? [
{
key: 'schedule_publish_at',
// title: '定时发布时间',
valueType: 'dateTime',
colProps: { span: 16 },
fieldProps: {
style: { width: '40%' },
format: 'YYYY-MM-DD HH:mm',
},
formItemProps: {
...rulesHelper.text,
wrapperCol: { span: 24 },
placeholder: '请设置定时发布时间',
},
},
]
: [];
},
2025-09-08 17:22:58 +08:00
},
{
key: 'content',
title: '公告内容',
colProps: { span: 24 },
fieldProps: {
mode: 'simple',
2025-09-08 17:22:58 +08:00
},
renderFormItem: () => <MyEditor />,
2025-09-08 17:22:58 +08:00
},
{
key: 'publish_at',
title: '落款日期',
2025-09-08 17:22:58 +08:00
valueType: 'date',
colProps: { span: 24 },
2025-09-08 17:22:58 +08:00
fieldProps: {
style: { width: '40%' },
2025-09-08 17:22:58 +08:00
},
formItemProps: { ...rulesHelper.text },
},
// {
// key: 'sort',
// title: '排序',
// valueType: 'digit',
2025-09-08 17:22:58 +08:00
// colProps: { span: 12 },
// tooltip: '数值越大越靠前',
// fieldProps: {
// placeholder: '数值越大越靠前',
// min: 0,
// style: { width: '100%' },
// },
// initialValue: 0,
// },
2025-09-08 17:22:58 +08:00
]}
/>
);
}