You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

550 lines
14 KiB
TypeScript

import React, { useState, useRef } from "react";
import { message, Button, Popconfirm, FormInstance, InputNumber, Input } from "antd";
import { TableListItem, TableListPagination } from "./data";
import { queryRule, updateRule, removeRule, addRule, getAllInfoSettingValueBySettingName, exportEmployee } from "./service";
import UpdateForm, { FormValueType } from './components/UpdateForm';
import ProTable, { ActionType, ProColumns } from "@ant-design/pro-table";
import Import from "@/components/Import/Import";
import Authorized from "@/utils/Authorized";
/**
* 更新节点
* @param fields
*/
const handleUpdate = async (fields: FormValueType) => {
const hide = message.loading('正在保存');
if (!fields.id) {
// eslint-disable-next-line no-param-reassign
delete fields.id
try {
const msg = await addRule({...fields});
hide();
if (msg.retcode) {
message.success('添加成功');
} else {
message.error('添加失败请重试!');
}
return true;
} catch (error) {
hide();
message.error('添加失败请重试!');
return false;
}
} else {
try {
const msg = await updateRule({...fields});
hide();
if (msg.retcode) {
message.success('保存成功');
} else {
message.error('保存失败请重试!');
}
return true;
} catch (error) {
hide();
message.error('保存失败请重试!');
return false;
}
}
};
/**
* 批量导出
* @param selectedRows
*/
const handleExportEmployee = async ({ ...params }: any) => {
const hide = message.loading('正在导出');
try {
await exportEmployee(params);
hide();
return true;
} catch (error) {
hide();
message.error('处理失败,请重试');
return false;
}
};
/**
* 删除节点
* @param id
*/
const handleRemove = async (id?: number) => {
const hide = message.loading('正在删除');
if (!id) return false;
try {
const msg = await removeRule({
id
});
hide();
if (msg.retcode) {
message.success('删除成功,即将刷新');
} else {
message.error('删除失败,请重试');
}
return true;
} catch (error) {
hide();
message.error('删除失败,请重试');
return false;
}
};
const fetchData = async ({ ...params }: any) => {
const msg = await queryRule(params);
console.log(msg.data?.list)
return {
data: msg.data?.list || [],
total: msg.data?.total || 0,
success: msg.retcode,
};
};
const UserList: React.FC<{}> = () => {
const actionRef = useRef<ActionType>();
const [updateModalVisible, handleUpdateModalVisible] = useState<boolean>(false);
const [currentRow, setCurrentRow] = useState({});
const ref = useRef<FormInstance<TableListItem>>();
const columns: ProColumns<TableListItem>[] = [
{
title: '姓名',
width: 70,
dataIndex: 'employeeName',
},
{
title: '员工编号',
width: 80,
dataIndex: 'employeeNo',
},
{
title: '手机号',
width: 100,
dataIndex: 'mobile',
},
{
title: '出生日期',
width: 80,
dataIndex: 'birthday',
search: false
},
{
title: '性别',
width: 60,
dataIndex: 'sex',
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'sexes'
},
valueEnum: {
1: '男',
2: '女'
}
},
{
title: '年龄',
width: 60,
dataIndex: 'age',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'ages'
},
renderFormItem: (_, { type }, form) => {
if (type === 'form') {
return null;
}
let value1 = form.getFieldValue('ages') ? form.getFieldValue('ages')[0] : '';
let value2 = form.getFieldValue('ages') ? form.getFieldValue('ages')[1] : '';
return (
<Input.Group compact>
<InputNumber
{...{
value: value1,
min: 0,
onChange: (e) => {
value1 = e;
const newValues: any = {};
newValues.ages = [value1, value2];
form.setFieldsValue(newValues);
},
}}
style={{ width: 100, textAlign: 'center' }}
/>
<Input
style={{
width: 30,
borderLeft: 0,
borderRight: 0,
pointerEvents: 'none',
}}
placeholder="~"
disabled
/>
<InputNumber
{...{
value: value2,
min: 0,
onChange: (e) => {
value2 = e;
const newValues: any = {};
newValues.ages = [value1, value2];
form.setFieldsValue(newValues);
},
}}
style={{
width: 100,
textAlign: 'center',
}}
/>
</Input.Group>
);
},
},
{
title: '部门',
dataIndex: 'departmentId',
width: 120,
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'departmentIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '部门'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '单位',
width: 320,
dataIndex: 'unitId',
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'unitIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '单位'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '现岗位',
width: 110,
dataIndex: 'postId',
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'postIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '岗位'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '班组',
width: 140,
dataIndex: 'groupsId',
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'groupsIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '班组'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '最高学历',
dataIndex: 'highestEducationId',
width: 110,
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'highestEducationIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '学历'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '专业技术资格',
dataIndex: 'ptqId',
valueType: 'select',
width: 130,
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'ptqIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '专业技术资格'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '技能等级',
dataIndex: 'skillLevelId',
valueType: 'select',
width: 80,
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'skillLevelIds'
},
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '技能等级'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.id
}
})
}
return []
}
},
{
title: '奖惩等级',
dataIndex: 'honorLevel',
valueType: 'select',
fieldProps: {
mode: "multiple"
},
formItemProps: {
name: 'honorLevels'
},
hideInTable: true,
request: async () => {
const msg = await getAllInfoSettingValueBySettingName({settingName: '奖惩等级'})
if (msg.retcode && msg.data) {
return msg.data.map((e: any) => {
return {
label: e.settingValue,
value: e.settingValue
}
})
}
return []
}
},
{
title: '奖惩内容',
dataIndex: 'honorDescription',
hideInTable: true,
},
{
title: "操作",
dataIndex: "option",
width: 80,
hideInSearch: true,
render: (text: any, record: TableListItem) => (
<span>
<a style={{ marginRight: 8 }} onClick={()=>{
handleUpdateModalVisible(true);
setCurrentRow(record);
}}></a>
<Authorized authority="employeeSave" noMatch={<span />}>
<Popconfirm title="确定删除?" onConfirm={async () => {
const success = await handleRemove(record.id)
if (success) actionRef.current?.reload()
}}>
<a style={{color: 'red'}}></a>
</Popconfirm>
</Authorized>
</span>
)
}
];
return (
<>
<ProTable<TableListItem, TableListPagination>
headerTitle={null}
actionRef={actionRef}
rowKey="id"
options={false}
formRef={ref}
scroll={{
y: 'calc(100vh - 500px)'
}}
pagination={{
defaultPageSize: 10,
showSizeChanger: true,
}}
search={{
collapsed: false,
collapseRender: false,
labelWidth: 'auto'
}}
toolBarRender={() => [
<Authorized authority="employeeSave" noMatch={<span />}>
<Button
type="primary"
key="primary"
onClick={() => {
handleUpdateModalVisible(true);
setCurrentRow({
id: undefined,
});
}}
>
</Button>
</Authorized>,
<Authorized authority="employeeSave" noMatch={<span />}>
<Import
api={'/api/employee/importEmployee'}
text="批量导入员工基本信息"
uploaded={() => {
actionRef.current?.reload();
}}
/>
</Authorized>,
<Authorized authority="employeeSave" noMatch={<span />}>
<Import
api={'/api/educationResume/importEducationResume'}
text="批量导入员工教育履历"
uploaded={() => {
actionRef.current?.reload();
}}
/>
</Authorized>,
<Authorized authority="employeeSave" noMatch={<span />}>
<Import
api={'/api/familyMembers/importFamilyMembers'}
text="批量导入员工家庭成员"
uploaded={() => {
actionRef.current?.reload();
}}
/>
</Authorized>,
<Authorized authority="employeeSave" noMatch={<span />}>
<Import
api={'/api/workExperience/importWorkExperience'}
text="批量导入员工工作经历记录"
uploaded={() => {
actionRef.current?.reload();
}}
/>
</Authorized>,
<Authorized authority="employeeSave" noMatch={<span />}>
<Import
api={'/api/honor/importHonor'}
text="批量导入员工奖惩记录"
uploaded={() => {
actionRef.current?.reload();
}}
/>
</Authorized>,
<Button
key="export"
type="primary"
onClick={() => {
const values = ref.current?.getFieldsValue();
handleExportEmployee(values);
}}
>
</Button>,
]}
request={fetchData}
columns={columns}
/>
{currentRow && Object.keys(currentRow).length ? (
<UpdateForm
onSubmit={async value => {
const success = await handleUpdate(value);
if (success) {
handleUpdateModalVisible(false);
setCurrentRow({});
actionRef.current?.reload()
}
}}
onCancel={() => {
handleUpdateModalVisible(false);
setCurrentRow({});
}}
updateModalVisible={updateModalVisible}
values={currentRow}
/>
) : null}
</>
)
}
export default UserList;