pay-admin/src/pages/meter/readings/modals/ResetReading.tsx

221 lines
6.6 KiB
TypeScript
Raw Normal View History

2025-09-25 20:20:46 +08:00
import {
MyBetaModalFormProps,
MyButtons,
2025-10-01 15:38:37 +08:00
MyFormItems,
2025-09-25 20:20:46 +08:00
MyModalFormProps,
rulesHelper,
} from '@/common';
import { Selects } from '@/components/Select';
import { Apis } from '@/gen/Apis';
2025-10-01 15:38:37 +08:00
import {
HouseMeterReadingsOperationTypeEnum,
HouseMetersMeterTypeEnum,
HouseMetersUsageTypeEnum,
} from '@/gen/Enums';
2025-09-25 20:20:46 +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.Meter.HouseMeterReadings.Store>
{...MyModalFormProps.props}
2025-10-01 15:38:37 +08:00
title={`重置抄表数据`}
2025-09-25 20:20:46 +08:00
layout="horizontal"
labelCol={{ span: 6 }}
wrapperCol={{ span: 18 }}
labelAlign="left"
width="600px"
key={new Date().getTime()}
2025-10-01 15:38:37 +08:00
trigger={
<MyButtons.Default
title={props.item?.title || `重置读数`}
type="primary"
size={props.item?.size || 'middle'}
danger
/>
}
2025-09-25 20:20:46 +08:00
form={form}
onOpenChange={(open: any) => {
if (open && props.item) {
form.resetFields(); // 清空表单数据
form.setFieldsValue({
...props.item,
2025-10-01 15:38:37 +08:00
house_meters_id: props.item?.id,
2025-09-25 20:20:46 +08:00
latest_value:
props.item?.latest_value === '0.00'
? props.item?.initial_value
: props.item?.latest_value,
latest_time: props.item?.latest_time || props.item?.initial_time,
});
}
}}
onFinish={async (values) =>
Apis.Meter.HouseMeterReadings.Store({
...values,
2025-10-01 15:38:37 +08:00
house_meters_id: props.item?.id,
2025-09-25 20:20:46 +08:00
operation_type:
2025-10-01 15:38:37 +08:00
HouseMeterReadingsOperationTypeEnum.ResetReading.value,
2025-09-25 20:20:46 +08:00
})
.then(() => {
props.reload?.();
message.success(props.title + '成功');
return true;
})
.catch(() => false)
}
columns={[
2025-10-01 15:38:37 +08:00
{
key: 'name',
title: '仪表名称',
colProps: { span: 24 },
fieldProps: { disabled: true },
formItemProps: { ...rulesHelper.text },
},
MyFormItems.EnumRadio({
key: 'meter_type',
title: '仪表类型',
colProps: { span: 24 },
valueEnum: HouseMetersMeterTypeEnum,
required: true,
fieldProps: { disabled: true },
}),
MyFormItems.EnumRadio({
key: 'usage_type',
title: '使用类型',
colProps: { span: 24 },
valueEnum: HouseMetersUsageTypeEnum,
required: true,
fieldProps: { disabled: true },
}),
2025-09-25 20:20:46 +08:00
{
key: 'latest_value',
title: '上次抄表读数',
colProps: { span: 24 },
fieldProps: { disabled: true },
},
{
key: 'latest_time',
title: '上次抄表时间',
2025-10-01 15:38:37 +08:00
valueType: 'dateTime',
2025-09-25 20:20:46 +08:00
colProps: { span: 24 },
fieldProps: { disabled: true },
},
{
key: 'current_reading',
2025-10-01 15:38:37 +08:00
title: '重置抄表读数',
2025-09-25 20:20:46 +08:00
valueType: 'number',
colProps: { span: 24 },
formItemProps: {
...rulesHelper.number,
},
},
{
key: 'reading_time',
2025-10-01 15:38:37 +08:00
title: '重置抄表时间',
valueType: 'dateTime',
2025-09-25 20:20:46 +08:00
colProps: { span: 24 },
formItemProps: {
...rulesHelper.text,
rules: [
...rulesHelper.text.rules,
{
validator: (_, value) => {
const latestTime = form.getFieldValue('latest_time');
if (value && latestTime) {
const currentTime = new Date(value);
const lastTime = new Date(latestTime);
if (currentTime <= lastTime) {
return Promise.reject(
new Error('本次抄表时间必须大于上次抄表时间'),
);
}
}
return Promise.resolve();
},
},
],
},
2025-10-01 15:38:37 +08:00
fieldProps: {
disabledDate: (current: any) => {
// 禁用未来的日期
return current && current > new Date();
},
disabledTime: (current: any) => {
// 如果是今天,禁用未来的时间
if (
current &&
current.format('YYYY-MM-DD') ===
new Date().toISOString().split('T')[0]
) {
const now = new Date();
return {
disabledHours: () => {
const hours = [];
for (let i = now.getHours() + 1; i < 24; i++) {
hours.push(i);
}
return hours;
},
disabledMinutes: (selectedHour: number) => {
if (selectedHour === now.getHours()) {
const minutes = [];
for (let i = now.getMinutes() + 1; i < 60; i++) {
minutes.push(i);
}
return minutes;
}
return [];
},
disabledSeconds: (
selectedHour: number,
selectedMinute: number,
) => {
if (
selectedHour === now.getHours() &&
selectedMinute === now.getMinutes()
) {
const seconds = [];
for (let i = now.getSeconds() + 1; i < 60; i++) {
seconds.push(i);
}
return seconds;
}
return [];
},
};
}
return {};
},
},
2025-09-25 20:20:46 +08:00
},
Selects?.Employees({
key: 'company_employees_id',
title: '抄表人',
params: {
companies_id: props.item?.companies_id,
},
colProps: { span: 24 },
required: true,
fieldProps: {
showSearch: true,
fieldNames: {
label: 'label',
value: 'value',
},
},
}),
{
key: 'remark',
title: '备注',
valueType: 'textarea',
colProps: { span: 24 },
},
]}
/>
);
}