groupLeft.tsx 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. import { useAjax } from "@/Hook/useAjax"
  2. import { addGroupApi, delGroupApi, editGroupApi, getGroupListApi } from "@/services/launchAdq/subgroup"
  3. import { DeleteOutlined, FormOutlined, PlusOutlined } from "@ant-design/icons"
  4. import { Button, Input, message, Popconfirm, Space, Spin } from "antd"
  5. import React, { useEffect, useRef, useState } from "react"
  6. import { useModel } from "umi"
  7. import './index.less'
  8. /**
  9. * 分组管理Left 菜单
  10. */
  11. interface Props {
  12. onChange?: (groupId?: number) => void
  13. value?: number
  14. }
  15. const GroupLeft: React.FC<Props> = (props) => {
  16. /*************************/
  17. const { onChange, value } = props
  18. const [isNewGrouping, setIsNewGrouping] = useState<boolean>(false); // 是否新增分组
  19. const inputRef = useRef<any>(null);
  20. const [groupData, setGroupData] = useState<{ groupName: string, remark?: string, groupId?: number }>({ groupName: '' }) // 分组添加
  21. const [selectAccData, setSelectAccData] = useState<{ id: number, mpName: string }[]>([]) // 选中
  22. const [groupId, setGroupId] = useState<number>(value || 0)
  23. const { getGroupList } = useModel('useLaunchAdq.useAdAuthorize')
  24. const addGroup = useAjax((params) => addGroupApi(params))
  25. const editGroup = useAjax((params) => editGroupApi(params))
  26. const delGroup = useAjax((params) => delGroupApi(params))
  27. /*************************/
  28. useEffect(() => {
  29. if (value) {
  30. setGroupId(value || 0)
  31. }
  32. }, [value])
  33. /** 点击新增处理聚焦 */
  34. useEffect(() => {
  35. if (isNewGrouping && inputRef?.current) {
  36. inputRef.current!.focus({
  37. cursor: 'end',
  38. });
  39. }
  40. }, [inputRef, isNewGrouping])
  41. /** 新增修改分组 */
  42. const addEditHandle = () => {
  43. if (groupData?.groupName) {
  44. if (groupData?.groupId) {
  45. editGroup.run(groupData).then((res: any) => {
  46. message.success('修改成功')
  47. setGroupData({ groupName: '' })
  48. setIsNewGrouping(false)
  49. getGroupList.refresh()
  50. })
  51. } else {
  52. addGroup.run(groupData).then((res: any) => {
  53. message.success('添加成功')
  54. setGroupData({ groupName: '' })
  55. setIsNewGrouping(false)
  56. getGroupList.refresh()
  57. })
  58. }
  59. } else {
  60. message.error('请填写分组名称')
  61. }
  62. }
  63. /** 删除分组 */
  64. const delGroupHandle = (id: number) => {
  65. delGroup.run({ groupId: id }).then(res => {
  66. message.success('删除成功')
  67. getGroupList.refresh()
  68. if (groupId === id) {
  69. setGroupId(0)
  70. onChange?.(undefined)
  71. }
  72. })
  73. }
  74. return <div className="groupLeft">
  75. <div className="groupLeft_header">
  76. <div>全部分组</div>
  77. <Button type="link" icon={<PlusOutlined />} className="stop" onClick={(e) => {
  78. e.stopPropagation()
  79. setGroupData({ groupName: '' })
  80. setIsNewGrouping(true)
  81. }}>新增分组</Button>
  82. </div>
  83. <div className="groupLeft_content">
  84. {isNewGrouping && <div className="groupLeft_content_item">
  85. <div className="edit stop">
  86. <Space direction="vertical" className="stop">
  87. <Space className="stop">
  88. <div style={{ width: 30 }} className="stop">组名</div>
  89. <Input placeholder="输入分组名称(最多10个字)" className="stop" maxLength={10} ref={inputRef} onChange={(e) => { setGroupData({ ...groupData, groupName: e.target.value }) }} value={groupData?.groupName} />
  90. </Space>
  91. <div style={{ display: 'flex', justifyContent: 'flex-end' }} className="stop">
  92. <Space className="stop">
  93. <Button size="small" className="stop" onClick={() => { setIsNewGrouping(false); setGroupData({ groupName: '' }) }}>取消</Button>
  94. <Button type="primary" className="stop" size="small" onClick={addEditHandle} loading={getGroupList?.loading}>确定</Button>
  95. </Space>
  96. </div>
  97. </Space>
  98. </div>
  99. </div>}
  100. <Spin spinning={getGroupList.loading}>
  101. <div className="groupLeft_content_item">
  102. <div className={`con ${groupId === 0 ? 'select' : ''}`} onClick={() => { setGroupId(0); onChange?.(undefined); setSelectAccData([]) }}>
  103. <div className="left">
  104. <div className="title">全部</div>
  105. </div>
  106. </div>
  107. </div>
  108. {getGroupList && Array.isArray(getGroupList?.data) && getGroupList?.data?.map((item: { groupName: string, groupId: number }, index: number) => <div className="groupLeft_content_item" key={item.groupId || index}>
  109. {groupData?.groupId && groupData?.groupId === item?.groupId ? <div className="edit stop">
  110. <Space direction="vertical" className="stop">
  111. <Space className="stop">
  112. <div style={{ width: 40 }} className="stop">组名</div>
  113. <Input placeholder="输入分组名称(最多10个字)" className="stop" maxLength={10} ref={inputRef} onChange={(e) => { setGroupData({ ...groupData, groupName: e.target.value }) }} value={groupData?.groupName} />
  114. </Space>
  115. <div style={{ display: 'flex', justifyContent: 'flex-end' }} className="stop">
  116. <Space className="stop">
  117. <Button size="small" className="stop" onClick={() => { setIsNewGrouping(false); setGroupData({ groupName: '' }) }}>取消</Button>
  118. <Button type="primary" className="stop" size="small" onClick={addEditHandle} loading={editGroup?.loading}>修改</Button>
  119. </Space>
  120. </div>
  121. </Space>
  122. </div> : <div className={`con ${groupId === item.groupId ? 'select' : ''}`} onClick={() => { setGroupId(item.groupId); onChange?.(item.groupId); setSelectAccData([]) }} key={item.groupId || index}>
  123. <div className="left">
  124. <div className="title">{item.groupName}</div>
  125. </div>
  126. <div className="right">
  127. <Space>
  128. <FormOutlined onClick={(e) => { e.stopPropagation(); setGroupData({ ...item }); setIsNewGrouping(false) }} />
  129. <Popconfirm
  130. title="确定删除?"
  131. onConfirm={() => { delGroupHandle(item.groupId) }}
  132. okText="确定"
  133. cancelText="取消"
  134. >
  135. <DeleteOutlined style={{ color: 'red' }} />
  136. </Popconfirm>
  137. </Space>
  138. </div>
  139. </div>}
  140. </div>)}
  141. </Spin>
  142. </div>
  143. </div>
  144. }
  145. export default React.memo(GroupLeft)