212 lines
6.5 KiB
TypeScript
Raw Normal View History

import {
MyButtons,
MyColumns,
2026-04-27 10:37:21 +08:00
MyPageContainer,
MyProTableProps,
MyTableActions,
MyToolBarActions,
} from '@/common';
import { Selects } from '@/components/Select';
import { Apis } from '@/gen/Apis';
import {
RenovationAppliesConstructionStatusEnum,
RenovationAppliesStatusEnum,
} from '@/gen/Enums';
import { PlusOutlined } from '@ant-design/icons';
import { ProTable } from '@ant-design/pro-components';
import { useNavigate } from '@umijs/max';
import { Space } from 'antd';
2026-04-29 17:03:35 +08:00
import AuditModal from './modals/AuditModal';
import DepositPay from './modals/DepositPay';
import DepositRefund from './modals/DepositRefund';
2026-04-29 17:03:35 +08:00
import InspectionRulesModal from './modals/InspectionRulesModal';
import MyWorkerCreate from './modals/WorkerCreate';
2026-04-27 10:37:21 +08:00
export default function Index({ title = '装修管理' }) {
const navigate = useNavigate();
2026-04-14 21:36:19 +08:00
return (
2026-04-27 10:37:21 +08:00
<MyPageContainer
title={title}
enableTabs={true}
tabKey="renovation_applies"
tabLabel={title}
>
<ProTable
{...MyProTableProps.props}
request={async (params, sort) =>
MyProTableProps.request(
params,
sort,
Apis.Renovation.RenovationApplies.List,
)
}
headerTitle="装修申请列表"
toolBarRender={(action) => [
<MyToolBarActions
key="toolbar"
actions={{
add: (
<MyButtons.Default
key="Create"
size="middle"
type="primary"
icon={<PlusOutlined />}
onClick={() => {
navigate('/quality/renovation/pages/create');
}}
title="装修申请"
/>
),
2026-04-29 17:03:35 +08:00
rules: <InspectionRulesModal key="InspectionRulesModal" />,
audit: <AuditModal key="AuditModal" />,
2026-04-27 10:37:21 +08:00
}}
/>,
]}
columns={[
MyColumns.ID({ search: false }),
Selects?.AssetProjects({
title: '选择项目',
2026-06-23 17:00:34 +08:00
key: 'asset_projects_id',
2026-04-27 10:37:21 +08:00
hidden: true,
}),
MyColumns.EnumTag({
title: '登记状态',
dataIndex: 'status',
valueEnum: RenovationAppliesStatusEnum,
search: false,
}),
{
title: '关联项目',
dataIndex: ['asset_project', 'name'],
search: false,
},
{
title: '房屋',
dataIndex: ['asset_house', 'full_name'],
search: {
transform: (value) => {
return { full_name: value };
},
},
},
2026-04-27 10:37:21 +08:00
{
title: '装修人',
dataIndex: 'owner_name',
},
{
title: '装修公司',
dataIndex: 'company_name',
search: false,
},
2026-04-27 10:37:21 +08:00
{
title: '施工负责人',
dataIndex: 'construction_principal_name',
search: false,
},
MyColumns.EnumTag({
title: '施工状态',
dataIndex: 'construction_status',
valueEnum: RenovationAppliesConstructionStatusEnum,
search: false,
}),
{
title: '保证金',
dataIndex: 'deposit_amount',
search: false,
},
{
title: '施工时间',
search: false,
render: (_, item: any) => {
return (
<div>
{item?.construction_start_date || ''}
{item?.construction_end_date || ''}
</div>
);
},
},
MyColumns.CreatedAt(),
MyColumns.Option({
render: (_, item: any, index, action) => (
<Space key={index}>
<MyTableActions
actions={{
show: (
<MyButtons.Default
key="Show"
size="small"
type="primary"
onClick={() => {
navigate(
`/quality/renovation/pages/show?id=${item.id}`,
);
}}
title="查看"
/>
),
2026-06-23 17:00:34 +08:00
worker:
item.construction_status === 'PendingConstruction' ||
item.construction_status === 'NormalConstruction' ? (
<MyWorkerCreate
item={{
...item,
size: 'small',
}}
title="装修工人"
key="WorkerCreate"
/>
) : (
''
),
2026-04-27 10:37:21 +08:00
update: (
<MyButtons.Default
key="Update"
size="small"
type="primary"
disabled={item.status !== 'Draft'}
onClick={() => {
navigate(
`/quality/renovation/pages/update?id=${item.id}`,
);
}}
title="编辑"
/>
),
pay: (
<DepositPay
key="DepositPay"
item={item}
reload={action?.reload}
/>
),
refund: (
<DepositRefund
key="DepositRefund"
item={item}
reload={action?.reload}
/>
),
delete: (
<MyButtons.Delete
disabled={item.status !== 'Draft'}
onConfirm={() =>
Apis.Renovation.RenovationApplies.Delete({
id: item.id,
}).then(() => action?.reload())
}
/>
),
}}
maxVisible={3}
/>
</Space>
),
}),
]}
/>
</MyPageContainer>
2026-04-14 21:36:19 +08:00
);
}