edit.tsx 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428
  1. import React, { useEffect, useState } from 'react';
  2. // import type { UploadProps } from 'antd';
  3. // import { Cascader } from 'antd';
  4. import { Cascader, Checkbox, Col, Form, Input, InputNumber, message, Modal, Row } from 'antd';
  5. import { createUser, editUser, queryTreeList } from '@/services/setting';
  6. // import { LoadingOutlined, PlusOutlined } from '@ant-design/icons';
  7. import md5 from 'js-md5';
  8. import { queryRoleList } from '@/services/role';
  9. import { infoQuery } from '@/services/ReportingManagement';
  10. interface userEditPros {
  11. visible: boolean;
  12. editCallback: () => void;
  13. detailData: any;
  14. }
  15. /**
  16. * 用户管理编辑
  17. * @param props
  18. * @constructor
  19. */
  20. const Edit: React.FC<userEditPros> = (props) => {
  21. const { visible, editCallback, detailData } = props;
  22. const [form] = Form.useForm();
  23. // const uploadHeaders = { Authorization: `${localStorage.getItem('token')}` };
  24. // const [fileUrl, setFileUrl]: any = useState(
  25. // detailData && detailData.photo ? detailData.photo : '',
  26. // );
  27. // const [loading, setLoading] = useState(false);
  28. const [roleList, setRoleList] = useState([]);
  29. // const [selectList, setSelectList] = useState([]);
  30. const [areaList, setAreaList] = useState([]);
  31. const [isCurrent, setIsCurrent] = useState(false);
  32. // const getBase64 = (img: any) => {
  33. // const reader = new FileReader();
  34. // reader.readAsDataURL(img);
  35. // reader.onloadend = () => {
  36. // const url = reader.result;
  37. // setFileUrl(url);
  38. // };
  39. // };
  40. useEffect(() => {
  41. // 编辑时
  42. if (detailData) {
  43. infoQuery().then((res) => {
  44. if (res?.code === 0) {
  45. // 判断当前编辑用户数据和登录账号是否为同一个
  46. // 同一个则直接显示用户数据中user_role(角色名称)和parent_name(所属名称)
  47. if (res.data.record_id === detailData.record_id) {
  48. setIsCurrent(true);
  49. const user_role_list: any = [];
  50. const obj = {
  51. name: '',
  52. record_id: '',
  53. };
  54. detailData.user_role.forEach((el: { role_id: string; role_name: string }) => {
  55. obj.name = el.role_name;
  56. obj.record_id = el.role_id;
  57. user_role_list.push(obj);
  58. });
  59. setRoleList(user_role_list);
  60. } else {
  61. // 角色列表
  62. queryRoleList({ q: 'list' }).then((item) => {
  63. if (item.code === 0) {
  64. setRoleList(item.data.list);
  65. }
  66. });
  67. }
  68. }
  69. });
  70. // 编辑时,所属地区根据角色id回显数据
  71. // const data = [...detailData?.user_role].sort((a: any, b: any) => b.level - a.level);
  72. // if (data && data.length) {
  73. // const param = {
  74. // q: 'list',
  75. // role_id: data[0].role_id,
  76. // user_id: detailData.record_id,
  77. // };
  78. // // 根据角色id请求用户列表接口 保证所属名称字段编辑时回显
  79. // queryRoleUser(param).then((item) => {
  80. // if (item.code === 0) {
  81. // setSelectList(item?.data || []);
  82. // }
  83. // });
  84. // }
  85. } else {
  86. // 新增
  87. // 角色列表
  88. queryRoleList({ q: 'list' }).then((res) => {
  89. if (res.code === 0) {
  90. setRoleList(res.data.list);
  91. }
  92. });
  93. }
  94. // 地区列表
  95. queryTreeList({ q: 'tree', level: '3' }).then((res) => {
  96. if (res && res.code === 0) {
  97. setAreaList(res.data.list || []);
  98. }
  99. });
  100. }, []);
  101. // const handleLevel = (values: any) => {
  102. // const data: any = roleList.filter((option: { record_id: string }) =>
  103. // values.includes(option.record_id),
  104. // );
  105. // return [...data].sort((a: any, b: any) => b.level - a.level);
  106. // };
  107. // 角色选择
  108. // const onRoleChange = (selectedValues: any) => {
  109. // // 切换角色时,所属名称要清空重新选择
  110. // form.setFieldsValue({ parent_id: '' });
  111. // const sortedData = handleLevel(selectedValues);
  112. // if (sortedData && sortedData.length > 0) {
  113. // const maxLevelObject = sortedData[0];
  114. // const param = {
  115. // q: 'list',
  116. // role_id: maxLevelObject.record_id,
  117. // };
  118. // queryRoleUser(param).then((res) => {
  119. // if (res.code === 0) {
  120. // setSelectList(res?.data || []);
  121. // }
  122. // });
  123. // } else {
  124. // setSelectList([]);
  125. // }
  126. // };
  127. // const filesProps: UploadProps = {
  128. // maxCount: 1,
  129. // action: '/web/v1/files',
  130. // headers: uploadHeaders,
  131. // listType: 'picture-card',
  132. // showUploadList: false,
  133. // onChange(info) {
  134. // if (info.file.status === 'uploading') {
  135. // setLoading(true);
  136. // return;
  137. // }
  138. // if (info.file.status === 'done') {
  139. // setLoading(false);
  140. // getBase64(info.file.originFileObj);
  141. // } else if (info.file.status === 'error') {
  142. // setLoading(false);
  143. // message.error('文件上传失败');
  144. // }
  145. // },
  146. // };
  147. /**
  148. * 确定
  149. */
  150. const onOk = () => {
  151. form.validateFields().then((values) => {
  152. if (values) {
  153. const data = { ...values };
  154. if (values?.photo) {
  155. data.photo = values?.photo?.file?.response?.data?.url;
  156. }
  157. if (values?.password) {
  158. data.password = md5(values.password);
  159. }
  160. if (values?.role_id) {
  161. const user_role: { role_id: any }[] = [];
  162. values?.role_id.forEach((el: any) => {
  163. user_role.push({ role_id: el });
  164. });
  165. data.user_role = user_role;
  166. delete data.role_id;
  167. }
  168. // if (values?.area) {
  169. // data.province = values.area[0];
  170. // data.city = values.area[1];
  171. // data.district = values.area[2];
  172. // delete data.area;
  173. // }
  174. if (values.districts) {
  175. const arr: any[] = [];
  176. values.districts.forEach((el: any) => {
  177. arr.push({
  178. district_id: el[1],
  179. });
  180. });
  181. data.districts = arr;
  182. }
  183. if (values?.parent_id) {
  184. data.parent_id = values?.parent_id;
  185. }
  186. if (detailData) {
  187. data.record_id = detailData.record_id;
  188. // 编辑
  189. editUser(data)
  190. .then((res) => {
  191. if (res.code === 0) {
  192. message.success('编辑成功');
  193. editCallback();
  194. } else {
  195. message.error(res?.message);
  196. editCallback();
  197. }
  198. })
  199. .catch((e) => {
  200. message.error(e?.message);
  201. editCallback();
  202. });
  203. } else {
  204. // 新增
  205. createUser(data)
  206. .then((res) => {
  207. if (res.code === 0) {
  208. message.success('保存成功');
  209. editCallback();
  210. } else {
  211. message.error(res?.message);
  212. editCallback();
  213. }
  214. })
  215. .catch((e) => {
  216. message.error(e?.message);
  217. editCallback();
  218. });
  219. }
  220. }
  221. });
  222. };
  223. /**
  224. * 取消
  225. */
  226. const onCancel = () => {
  227. editCallback();
  228. };
  229. const formItemLayout = {
  230. labelCol: {
  231. span: 6,
  232. },
  233. wrapperCol: {
  234. span: 16,
  235. },
  236. };
  237. const formItemLayoutTwo = {
  238. labelCol: {
  239. span: 3,
  240. },
  241. wrapperCol: {
  242. span: 21,
  243. },
  244. };
  245. // const uploadButton = (
  246. // <div>
  247. // {loading ? <LoadingOutlined /> : <PlusOutlined />}
  248. // <div className="ant-upload-text">上传</div>
  249. // </div>
  250. // );
  251. return (
  252. <Modal
  253. title={`${detailData ? '编辑' : '新增'}`}
  254. open={visible}
  255. onOk={onOk}
  256. onCancel={onCancel}
  257. width={800}
  258. >
  259. <Form form={form}>
  260. <Row>
  261. <Col span={12}>
  262. <Form.Item
  263. {...formItemLayout}
  264. name="user_name"
  265. label="用户姓名"
  266. rules={[{ required: true, message: '请输入用户姓名' }]}
  267. initialValue={detailData?.user_name || ''}
  268. >
  269. <Input placeholder="请输入用户姓名" />
  270. </Form.Item>
  271. </Col>
  272. <Col span={12}>
  273. <Form.Item {...formItemLayout} name="password" label="密码">
  274. <Input type="password" placeholder="请输入密码" />
  275. </Form.Item>
  276. </Col>
  277. <Col span={12}>
  278. <Form.Item
  279. {...formItemLayout}
  280. name="phone"
  281. label="手机号"
  282. rules={[
  283. { required: true, message: '请输入手机号' },
  284. {
  285. pattern:
  286. /^1((34[0-8])|(8\d{2})|(([35][0-35-9]|4[579]|66|7[35678]|9[1389])\d{1}))\d{7}$/,
  287. message: '请输入正确的手机号',
  288. },
  289. ]}
  290. initialValue={detailData?.phone || ''}
  291. >
  292. <Input placeholder="请输入手机号" />
  293. </Form.Item>
  294. </Col>
  295. <Col span={12}>
  296. <Form.Item
  297. {...formItemLayout}
  298. name="company"
  299. label="公司名称"
  300. initialValue={detailData?.company || ''}
  301. >
  302. <Input placeholder="请输入公司名称" />
  303. </Form.Item>
  304. </Col>
  305. <Col span={24}>
  306. <Form.Item
  307. {...formItemLayoutTwo}
  308. name="role_id"
  309. label="角色名称"
  310. rules={[{ required: true, message: '请选择角色名称' }]}
  311. initialValue={
  312. detailData && detailData?.user_role && detailData?.user_role.length
  313. ? detailData?.user_role?.map((item: any) => item.role_id)
  314. : []
  315. }
  316. >
  317. <Checkbox.Group
  318. options={roleList.map((option: { record_id: string; name: string }) => ({
  319. label: option.name,
  320. value: option.record_id,
  321. record_id: option.record_id,
  322. }))}
  323. disabled={isCurrent}
  324. // onChange={onRoleChange}
  325. />
  326. </Form.Item>
  327. </Col>
  328. <Col span={12}>
  329. <Form.Item
  330. {...formItemLayout}
  331. name="quota"
  332. label="配额"
  333. rules={[{ required: true, message: '请输入配额' }]}
  334. initialValue={detailData?.quota || ''}
  335. >
  336. <InputNumber min={0} placeholder="请输入配额" style={{ width: '100%' }} />
  337. </Form.Item>
  338. </Col>
  339. <Col span={12}>
  340. <Form.Item
  341. {...formItemLayout}
  342. name="districts"
  343. label="地区"
  344. rules={[{ required: true, message: '请选择地区' }]}
  345. initialValue={detailData?.districts || []}
  346. >
  347. <Cascader
  348. style={{ width: '100%' }}
  349. options={areaList}
  350. multiple
  351. placeholder="请选择地区"
  352. maxTagCount="responsive"
  353. fieldNames={{ label: 'name', value: 'record_id', children: 'children' }}
  354. />
  355. </Form.Item>
  356. </Col>
  357. {/*<Col span={24}>*/}
  358. {/* <Form.Item*/}
  359. {/* {...formItemLayoutTwo}*/}
  360. {/* name="parent_id"*/}
  361. {/* label="上级用户"*/}
  362. {/* initialValue={detailData?.parent_id || ''}*/}
  363. {/* >*/}
  364. {/* <Select placeholder="请选择所属名称" disabled={isCurrent}>*/}
  365. {/* {selectList && selectList.length*/}
  366. {/* ? selectList.map(*/}
  367. {/* (res: { user_name: string; record_id: string; parent_id: string }) => {*/}
  368. {/* return (*/}
  369. {/* <Select.Option key={res.record_id} value={res.record_id}>*/}
  370. {/* {res?.user_name}*/}
  371. {/* </Select.Option>*/}
  372. {/* );*/}
  373. {/* },*/}
  374. {/* )*/}
  375. {/* : null}*/}
  376. {/* </Select>*/}
  377. {/* </Form.Item>*/}
  378. {/*</Col>*/}
  379. {/*<Col span={24}>*/}
  380. {/* <Form.Item*/}
  381. {/* {...formItemLayoutTwo}*/}
  382. {/* name="area"*/}
  383. {/* label="所属地区"*/}
  384. {/* initialValue={*/}
  385. {/* detailData?.province || detailData?.city || detailData?.district*/}
  386. {/* ? [detailData?.province, detailData?.city, detailData?.district]*/}
  387. {/* : []*/}
  388. {/* }*/}
  389. {/* >*/}
  390. {/* <Cascader*/}
  391. {/* options={areaList}*/}
  392. {/* placeholder="请选择所属地区"*/}
  393. {/* fieldNames={{ label: 'name', value: 'name', children: 'children' }}*/}
  394. {/* />*/}
  395. {/* </Form.Item>*/}
  396. {/*</Col>*/}
  397. {/*<Col span={12}>*/}
  398. {/* <Form.Item {...formItemLayout} name="photo" label="头像" initialValue={[]}>*/}
  399. {/* <Upload {...filesProps}>*/}
  400. {/* {fileUrl === '' ? (*/}
  401. {/* uploadButton*/}
  402. {/* ) : (*/}
  403. {/* <img src={fileUrl} alt="data" style={{ width: '100%' }} />*/}
  404. {/* )}*/}
  405. {/* </Upload>*/}
  406. {/* </Form.Item>*/}
  407. {/*</Col>*/}
  408. </Row>
  409. </Form>
  410. </Modal>
  411. );
  412. };
  413. export default Edit;