A1ILack.tsx 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  1. import React, { useCallback, useEffect, useState } from "react";
  2. import styles from "./index.module.scss";
  3. import { Button, Checkbox, Empty, Input, Modal, Popconfirm } from "antd";
  4. import { A1_APIIgetLack, A1_APIIsaveLack } from "@/store/action/A1Project";
  5. import { A1IlackType } from "@/types";
  6. import classNames from "classnames";
  7. import { MessageFu } from "@/utils/message";
  8. type Props = {
  9. closeFu: () => void;
  10. addSuFu: () => void;
  11. projectId: number;
  12. };
  13. function A1ILack({ closeFu, addSuFu, projectId }: Props) {
  14. // 进来获取 根据 项目id 获取 列表信息
  15. const getInfoFu = useCallback(async () => {
  16. const res = await A1_APIIgetLack(projectId);
  17. if (res.code === 0) {
  18. const arr: A1IlackType[] = res.data;
  19. setData(
  20. arr.map((v) => ({
  21. ...v,
  22. done: false,
  23. }))
  24. );
  25. }
  26. }, [projectId]);
  27. useEffect(() => {
  28. getInfoFu();
  29. }, [getInfoFu]);
  30. // 渲染的数组
  31. const [data, setData] = useState<A1IlackType[]>([]);
  32. // 勾选框的变化
  33. const selceFu = useCallback(
  34. (id: number, val: boolean) => {
  35. setData(
  36. data.map((v) => ({
  37. ...v,
  38. done: v.attributeId === id ? val : v.done,
  39. desc:v.attributeId === id&&v.desc==='-未填信息'?'':v.desc
  40. }))
  41. );
  42. },
  43. [data]
  44. );
  45. // 输入框的变化
  46. // setValue(e.target.value.replace(/\s+/g, ""))
  47. const descChangeFu = useCallback(
  48. (id: number, val: string) => {
  49. setData(
  50. data.map((v) => ({
  51. ...v,
  52. desc: v.attributeId === id ? val.replace(/\s+/g, "") : v.desc,
  53. }))
  54. );
  55. },
  56. [data]
  57. );
  58. // 点击确定
  59. const btnOk = useCallback(async () => {
  60. // 过滤掉已经 上传的 没有输入的
  61. const arr = data.filter((v) => v.done);
  62. const arr2 = arr.map((v) => ({
  63. attributeId: v.attributeId,
  64. description: v.desc || "-未填信息",
  65. }));
  66. const res = await A1_APIIsaveLack(projectId, arr2);
  67. if (res.code === 0) {
  68. if (arr.length > 0) MessageFu.success("登记成功!");
  69. addSuFu();
  70. closeFu();
  71. }
  72. }, [addSuFu, closeFu, data, projectId]);
  73. return (
  74. <Modal
  75. wrapClassName={styles.A1ILack}
  76. destroyOnClose
  77. open={true}
  78. title="登记缺失文件"
  79. footer={
  80. [] // 设置footer为空,去掉 取消 确定默认按钮
  81. }
  82. >
  83. <div className="A1ILmain">
  84. <div className="A1ILmain1">请勾选后再填写</div>
  85. {/* 主体 */}
  86. {data.length >= 1 ? (
  87. <div className="A1ILmainC">
  88. {data.map((v) => (
  89. <div className="A1ILmainCRow" key={v.attributeId}>
  90. <div
  91. className={classNames(
  92. "A1ILmainCRow1",
  93. v.hasUpload ? "A1ILmainCRow1No" : ""
  94. )}
  95. >
  96. <Checkbox
  97. checked={v.done}
  98. onChange={(e) => selceFu(v.attributeId, e.target.checked)}
  99. >
  100. <div className="A1ILmainCRow1Txt" title={v.attributeName}>
  101. {v.attributeName}
  102. </div>
  103. <div className="A1ILmainCRow1Txt2">:</div>
  104. </Checkbox>
  105. </div>
  106. <div
  107. className={classNames(
  108. "A1ILmainCRow2",
  109. v.desc === "-未填信息" ? "A1ILmainCRow2NoTxt" : ""
  110. )}
  111. >
  112. {v.hasUpload ? (
  113. "已上传"
  114. ) : (
  115. <Input
  116. disabled={!v.done}
  117. placeholder="请输入缺失原因"
  118. maxLength={100}
  119. showCount
  120. value={v.desc}
  121. onChange={(e) =>
  122. descChangeFu(v.attributeId, e.target.value)
  123. }
  124. />
  125. )}
  126. </div>
  127. </div>
  128. ))}
  129. </div>
  130. ) : (
  131. <Empty image={Empty.PRESENTED_IMAGE_SIMPLE} />
  132. )}
  133. {/* 底部按钮 */}
  134. <div className="A1ILbtn">
  135. {data.length >= 1 ? (
  136. <>
  137. <Popconfirm
  138. title="放弃编辑后,信息将不会保存!"
  139. okText="放弃"
  140. cancelText="取消"
  141. onConfirm={closeFu}
  142. okButtonProps={{ loading: false }}
  143. >
  144. <Button>取消</Button>
  145. </Popconfirm>
  146. &emsp;
  147. <Button
  148. type="primary"
  149. onClick={btnOk}
  150. disabled={data.filter((v) => v.done).length < 1}
  151. >
  152. 确定
  153. </Button>
  154. </>
  155. ) : (
  156. <Button onClick={closeFu}> 取消</Button>
  157. )}
  158. </div>
  159. </div>
  160. </Modal>
  161. );
  162. }
  163. const MemoA1ILack = React.memo(A1ILack);
  164. export default MemoA1ILack;