hrp-ui-base 1.0.1 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. package/dist/components.cjs +1 -1
  2. package/dist/components.es.js +3595 -1224
  3. package/dist/index.cjs +1 -1
  4. package/dist/index.es.js +100 -67
  5. package/dist/style.css +1 -1
  6. package/package.json +16 -4
  7. package/packages/approval-process/.eslintrc +7 -0
  8. package/packages/approval-process/README.md +130 -0
  9. package/packages/approval-process/index.ts +65 -0
  10. package/packages/approval-process/package.json +17 -0
  11. package/packages/approval-process/packages/components/choose-member/BO/departBo.ts +8 -0
  12. package/packages/approval-process/packages/components/choose-member/BO/memberBo.ts +14 -0
  13. package/packages/approval-process/packages/components/choose-member/BO/role.svg +1 -0
  14. package/packages/approval-process/packages/components/choose-member/BO/roleBo.ts +16 -0
  15. package/packages/approval-process/packages/components/choose-member/index.vue +497 -0
  16. package/packages/approval-process/packages/components/choose-member/styles/common.scss +134 -0
  17. package/packages/approval-process/packages/components/comment/assets/avatar.svg +1 -0
  18. package/packages/approval-process/packages/components/comment/assets/download.svg +4 -0
  19. package/packages/approval-process/packages/components/comment/assets/mp3.svg +11 -0
  20. package/packages/approval-process/packages/components/comment/assets/mp4.svg +11 -0
  21. package/packages/approval-process/packages/components/comment/assets/other.svg +11 -0
  22. package/packages/approval-process/packages/components/comment/assets/pdf.svg +11 -0
  23. package/packages/approval-process/packages/components/comment/assets/ppt.svg +11 -0
  24. package/packages/approval-process/packages/components/comment/assets/preview.svg +4 -0
  25. package/packages/approval-process/packages/components/comment/assets/remove.png +0 -0
  26. package/packages/approval-process/packages/components/comment/assets/word.svg +11 -0
  27. package/packages/approval-process/packages/components/comment/assets/xls.svg +11 -0
  28. package/packages/approval-process/packages/components/comment/index.vue +843 -0
  29. package/packages/approval-process/packages/components/comment/modules/previewMp.vue +54 -0
  30. package/packages/approval-process/packages/components/comment/styles/comment-style.scss +304 -0
  31. package/packages/approval-process/packages/components/image-cropper/index.vue +202 -0
  32. package/packages/approval-process/packages/components/sign/index.vue +766 -0
  33. package/packages/approval-process/packages/components/sign/modules/full-screen-sign.vue +20 -0
  34. package/packages/approval-process/packages/components/urge-dialog/index.vue +121 -0
  35. package/packages/approval-process/packages/components/vue-esign/index.vue +289 -0
  36. package/packages/approval-process/packages/flow/approve-component/approve-success.vue +82 -0
  37. package/packages/approval-process/packages/flow/approve-component/route-params-error.vue +49 -0
  38. package/packages/approval-process/packages/flow/approve-component/submit-success.vue +59 -0
  39. package/packages/approval-process/packages/flow/examine-approve-itr.vue +978 -0
  40. package/packages/approval-process/packages/flow/examine-approve.vue +1065 -0
  41. package/packages/approval-process/packages/flow/form-component/associated-approval-form/README.md +38 -0
  42. package/packages/approval-process/packages/flow/form-component/associated-approval-form/assets/avatar.svg +1 -0
  43. package/packages/approval-process/packages/flow/form-component/associated-approval-form/index.vue +159 -0
  44. package/packages/approval-process/packages/flow/form-component/associated-approval-form/modules/associated-approval-form-mobile.vue +297 -0
  45. package/packages/approval-process/packages/flow/form-component/associated-approval-form/modules/associated-approval-form-pc.vue +314 -0
  46. package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/curd-area-mobile.scss +110 -0
  47. package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/curd-area.scss +96 -0
  48. package/packages/approval-process/packages/flow/form-component/associated-approval-form/style/out-put.scss +48 -0
  49. package/packages/approval-process/packages/flow/form-component/show-sign.vue +27 -0
  50. package/packages/approval-process/packages/flow/styles/common.scss +134 -0
  51. package/packages/approval-process/packages/flow/styles/examine-approve-pc.scss +465 -0
  52. package/packages/approval-process/packages/flow/styles/examine-approve-phone.scss +293 -0
  53. package/packages/approval-process/packages/flow/styles/submit-approve-pc.scss +379 -0
  54. package/packages/approval-process/packages/flow/styles/submit-approve-phone.scss +337 -0
  55. package/packages/approval-process/packages/flow/submit-approve-itr.vue +623 -0
  56. package/packages/approval-process/packages/flow/submit-approve.vue +628 -0
  57. package/packages/approval-process/packages/flow/systemCom/BO/departBo.ts +8 -0
  58. package/packages/approval-process/packages/flow/systemCom/BO/memberBo.ts +14 -0
  59. package/packages/approval-process/packages/flow/systemCom/BO/role.svg +1 -0
  60. package/packages/approval-process/packages/flow/systemCom/BO/roleBo.ts +16 -0
  61. package/packages/approval-process/packages/flow/systemCom/choose-depart.vue +399 -0
  62. package/packages/approval-process/packages/flow/systemCom/choose-member-phone.vue +515 -0
  63. package/packages/approval-process/packages/flow/systemCom/choose-member.vue +565 -0
  64. package/packages/approval-process/packages/flow/systemCom/choose-role.vue +301 -0
  65. package/packages/approval-process/packages/styles/common.scss +134 -0
  66. package/packages/approval-process/packages/styles/flex-common.scss +118 -0
  67. package/packages/approval-process/packages/styles/flexCommon.scss +73 -0
  68. package/packages/approval-process/packages/styles/main.css +216 -0
  69. package/packages/approval-process/packages/styles/router-page.scss +371 -0
  70. package/packages/approval-process/packages/styles/style-set.ts +207 -0
  71. package/packages/approval-process/packages/types.d.ts +4 -0
  72. package/packages/approval-process/packages/utils/base.ts +15 -0
  73. package/packages/approval-process/packages/utils/crypto.ts +67 -0
  74. package/packages/approval-process/packages/utils/ddUtils.ts +56 -0
  75. package/packages/approval-process/packages/utils/debounce.ts +36 -0
  76. package/packages/approval-process/packages/utils/des.js +1107 -0
  77. package/packages/approval-process/packages/utils/download.ts +38 -0
  78. package/packages/approval-process/packages/utils/editor.ts +37 -0
  79. package/packages/approval-process/packages/utils/getEnv.ts +36 -0
  80. package/packages/approval-process/packages/utils/os.ts +20 -0
  81. package/packages/approval-process/packages/utils/path-util.ts +31 -0
  82. package/packages/approval-process/packages/utils/routerUtil.ts +304 -0
  83. package/packages/approval-process/packages/utils/string-utils.ts +13 -0
  84. package/packages/approval-process/packages/utils/throttle.ts +44 -0
  85. package/packages/approval-process/packages/utils/validate.ts +92 -0
  86. package/packages/approval-process/packages/utils/ws.ts +218 -0
  87. package/packages/approval-process/tsconfig.json +72 -0
  88. package/packages/approval-process/vite.config.ts +56 -0
  89. package/src/api/bms/flow/FlowCommentController.ts +50 -0
  90. package/src/api/bms/flow/FlowInstanceController.ts +167 -0
  91. package/src/api/bms/flow/FlowProcessController.ts +55 -0
  92. package/src/api/bms/flow/FlowSheetController.ts +27 -0
  93. package/src/api/bms/flow/FlowSignController.ts +76 -0
  94. package/src/api/bms/flow/bo/AssociatedApprovalBO.ts +15 -0
  95. package/src/api/bms/flow/bo/AssociatedApprovalVO.ts +35 -0
  96. package/src/api/bms/flow/bo/AuditBaseInfo.ts +39 -0
  97. package/src/api/bms/flow/bo/ButtonVo.ts +7 -0
  98. package/src/api/bms/flow/bo/DingCallbackBo.ts +13 -0
  99. package/src/api/bms/flow/bo/FlowCommentBO.ts +12 -0
  100. package/src/api/bms/flow/bo/FlowCommentVO.ts +23 -0
  101. package/src/api/bms/flow/bo/FlowInstanceBO.ts +14 -0
  102. package/src/api/bms/flow/bo/FlowNodeVO.ts +24 -0
  103. package/src/api/bms/flow/bo/FlowNoticeBO.ts +17 -0
  104. package/src/api/bms/flow/bo/FlowProcessBO.ts +13 -0
  105. package/src/api/bms/flow/bo/FlowProcessVO.ts +9 -0
  106. package/src/api/bms/flow/bo/FlowReplyVO.ts +23 -0
  107. package/src/api/bms/flow/bo/FlowSheetVO.ts +16 -0
  108. package/src/api/bms/flow/bo/InstanceBackBO.ts +9 -0
  109. package/src/api/bms/flow/bo/InstanceNodeBO.ts +13 -0
  110. package/src/api/bms/flow/bo/InstanceNodeVO.ts +21 -0
  111. package/src/api/bms/flow/bo/NodeShowVo.ts +19 -0
  112. package/src/api/bms/flow/bo/ReviewBO.ts +11 -0
  113. package/src/api/bms/flow/bo/SheetSearchBO.ts +11 -0
  114. package/src/api/bms/flow/bo/SystemVO.ts +7 -0
  115. package/src/api/bms/flow/bo/TransmitBO.ts +9 -0
  116. package/src/api/bms/flow/bo/UrgeFlowBO.ts +7 -0
  117. package/src/api/bms/flow/bo/UserBaseInfoVo.ts +13 -0
  118. package/src/api/bms/flow/bo/UserInfoVo.ts +44 -0
  119. package/src/api/bms/flow/bo/UserResultVo.ts +17 -0
  120. package/src/api/bms/flow/bo/ValueMapBo.ts +7 -0
  121. package/src/api/bms/home/HomeController.ts +106 -0
  122. package/src/api/bms/home/bo/CollectedMenuBo.ts +9 -0
  123. package/src/api/bms/home/bo/DeptBaseVo.ts +9 -0
  124. package/src/api/bms/home/bo/DomainVO.ts +13 -0
  125. package/src/api/bms/home/bo/FunPermission.ts +17 -0
  126. package/src/api/bms/home/bo/GroupVO.ts +10 -0
  127. package/src/api/bms/home/bo/HomeMenu.ts +22 -0
  128. package/src/api/bms/home/bo/HomeMenuVo.ts +11 -0
  129. package/src/api/bms/home/bo/PersonalizationBo.ts +17 -0
  130. package/src/api/bms/home/bo/PersonalizationVo.ts +19 -0
  131. package/src/api/bms/home/bo/PhoneMenu.ts +14 -0
  132. package/src/api/bms/home/bo/SearchMenuVo.ts +10 -0
  133. package/src/api/bms/home/bo/UserBaseInfoVo.ts +11 -0
  134. package/src/api/hrms/dept/bo/DeptBaseVo.ts +6 -0
  135. package/src/api/hrms/dept/bo/DeptTreeVo.ts +23 -0
  136. package/src/api/hrms/dept/bo/DeptUserVo.ts +9 -0
  137. package/src/api/hrms/dept/bo/DeptUsersVo.ts +10 -0
  138. package/src/api/hrms/dept/bo/DeptVo.ts +19 -0
  139. package/src/api/hrms/dept/bo/UserBaseInfoVo.ts +8 -0
  140. package/src/api/hrms/dept/deptController.ts +100 -0
  141. package/src/api/hrms/role/bo/RoleBaseVo.ts +6 -0
  142. package/src/api/hrms/role/bo/RoleGroupVo.ts +11 -0
  143. package/src/api/hrms/role/bo/RoleVo.ts +22 -0
  144. package/src/api/hrms/role/roleController.ts +19 -0
  145. package/src/api/hrms/user/bo/UserBaseInfoVo.ts +11 -0
  146. package/src/api/hrms/user/bo/UserCardVO.ts +14 -0
  147. package/src/api/hrms/user/bo/UserDeptBO.ts +13 -0
  148. package/src/api/hrms/user/bo/UserRoleBO.ts +11 -0
  149. package/src/api/hrms/user/bo/UserVO.ts +23 -0
  150. package/src/api/hrms/user/userController.ts +86 -0
  151. package/src/api/notice/NoticeController.ts +73 -0
  152. package/src/api/notice/bo/NoticePageBO.ts +24 -0
  153. package/src/api/notice/bo/NoticeVO.ts +31 -0
  154. package/src/api/work-order-pc/flow/Bo/ValueMapBo.ts +7 -0
  155. package/src/api/work-order-pc/flow/ItrFlowProcessController.ts +42 -0
  156. package/src/api/work-order-pc/flow/Vo/FlowNodeVO.ts +24 -0
  157. package/src/api/work-order-pc/flow/Vo/UserInfoVo.ts +44 -0
  158. package/src/assets/layout/avatar-default.svg +6 -0
  159. package/src/assets/layout/collect-active.svg +7 -0
  160. package/src/assets/layout/collect-default.svg +7 -0
  161. package/src/assets/layout/download-active.svg +8 -0
  162. package/src/assets/layout/download-default.svg +8 -0
  163. package/src/assets/layout/export-dark.svg +7 -0
  164. package/src/assets/layout/export-default.svg +7 -0
  165. package/src/assets/layout/font-active.svg +6 -0
  166. package/src/assets/layout/font-default.svg +6 -0
  167. package/src/assets/layout/help-active.svg +10 -0
  168. package/src/assets/layout/help-default.svg +10 -0
  169. package/src/assets/layout/home-active.svg +6 -0
  170. package/src/assets/layout/home.svg +6 -0
  171. package/src/assets/layout/menu-expand.svg +6 -0
  172. package/src/assets/layout/menu-icon.png +0 -0
  173. package/src/assets/layout/menu-position-active.svg +6 -0
  174. package/src/assets/layout/menu-position-default.svg +6 -0
  175. package/src/assets/layout/message-active.svg +9 -0
  176. package/src/assets/layout/message-default.svg +9 -0
  177. package/src/assets/layout/moon.svg +8 -0
  178. package/src/assets/layout/router-all-dark.svg +11 -0
  179. package/src/assets/layout/router-all-default.svg +17 -0
  180. package/src/assets/layout/search-active.svg +20 -0
  181. package/src/assets/layout/search-default.svg +20 -0
  182. package/src/assets/layout/star-active.svg +1 -0
  183. package/src/assets/layout/star-default.svg +3 -0
  184. package/src/assets/layout/sun-active.svg +6 -0
  185. package/src/assets/layout/sun-default.svg +6 -0
  186. package/src/assets/layout/switch-moon.svg +3 -0
  187. package/src/assets/layout/switch-sun.svg +41 -0
  188. package/src/assets/layout/todo-active.svg +12 -0
  189. package/src/assets/layout/todo-default.svg +12 -0
  190. package/src/assets/layout/user-dark.svg +13 -0
  191. package/src/assets/layout/user-default.svg +13 -0
  192. package/src/assets/process/agree.png +0 -0
  193. package/src/assets/process/defaultAvatar.png +0 -0
  194. package/src/assets/process/drawer/departManagerJump.png +0 -0
  195. package/src/assets/process/drawer/manyLevel1close.svg +10 -0
  196. package/src/assets/process/drawer/manyLevel1open.svg +7 -0
  197. package/src/assets/process/drawer/manyLevel2close.svg +7 -0
  198. package/src/assets/process/drawer/manyLevel2open.svg +7 -0
  199. package/src/assets/process/inProcess.png +0 -0
  200. package/src/assets/process/manyPeople.png +0 -0
  201. package/src/assets/process/manyPeople2.png +0 -0
  202. package/src/assets/process/reject.png +0 -0
  203. package/src/assets/process/revoke.png +0 -0
  204. package/src/components/annex-img-upload/index.vue +4 -4
  205. package/src/components/annex-img-upload/modules/previewMp.vue +1 -1
  206. package/src/components/annex-upload/index.vue +4 -4
  207. package/src/components/annex-upload/modules/previewMp.vue +1 -1
  208. package/src/components/annex-upload-weijian/index.vue +4 -4
  209. package/src/components/annex-upload-weijian/modules/previewMp.vue +1 -1
  210. package/src/components/base-layout/index.vue +198 -0
  211. package/src/components/layout/SysHeader.vue +90 -0
  212. package/src/components/layout/SysHeaderLeft.vue +116 -0
  213. package/src/components/layout/SysHeaderRight.vue +112 -0
  214. package/src/components/layout/SysHeaderTabs.vue +289 -0
  215. package/src/components/layout/components/avatar-component.vue +77 -0
  216. package/src/components/layout/components/dark-component.vue +82 -0
  217. package/src/components/layout/components/download-component.vue +49 -0
  218. package/src/components/layout/components/font-size-component.vue +66 -0
  219. package/src/components/layout/components/menu-position-component.vue +97 -0
  220. package/src/components/layout/components/message-component.vue +64 -0
  221. package/src/components/layout/components/todo-component.vue +55 -0
  222. package/src/components/layout/index.ts +24 -0
  223. package/src/components/layout/message/message-dictionary.ts +27 -0
  224. package/src/components/layout/message/message-icon//345/205/250/351/203/250/351/200/232/347/237/245-/350/223/235.svg +8 -0
  225. package/src/components/layout/message/message-icon//345/205/250/351/203/250/351/200/232/347/237/245-/351/273/221.svg +8 -0
  226. package/src/components/layout/message/message-icon//345/205/250/351/203/250/351/200/232/347/237/245.svg +8 -0
  227. package/src/components/layout/message/message-icon//345/205/254/345/221/212/351/200/232/347/237/245-/350/223/235.svg +12 -0
  228. package/src/components/layout/message/message-icon//345/205/254/345/221/212/351/200/232/347/237/245-/351/273/221.svg +12 -0
  229. package/src/components/layout/message/message-icon//345/205/254/345/221/212/351/200/232/347/237/245.svg +12 -0
  230. package/src/components/layout/message/message-icon//345/256/241/346/211/271/351/200/232/347/237/245-/350/223/235.svg +8 -0
  231. package/src/components/layout/message/message-icon//345/256/241/346/211/271/351/200/232/347/237/245-/351/273/221.svg +8 -0
  232. package/src/components/layout/message/message-icon//345/256/241/346/211/271/351/200/232/347/237/245.svg +8 -0
  233. package/src/components/layout/message/message-icon//345/257/274/345/207/272/351/200/232/347/237/245-/350/223/235.svg +13 -0
  234. package/src/components/layout/message/message-icon//345/257/274/345/207/272/351/200/232/347/237/245-/351/273/221.svg +13 -0
  235. package/src/components/layout/message/message-icon//345/257/274/345/207/272/351/200/232/347/237/245.svg +13 -0
  236. package/src/components/layout/message/message-icon//346/234/252/350/257/273/351/200/232/347/237/245-/350/223/235.svg +11 -0
  237. package/src/components/layout/message/message-icon//346/234/252/350/257/273/351/200/232/347/237/245-/351/273/221.svg +11 -0
  238. package/src/components/layout/message/message-icon//346/234/252/350/257/273/351/200/232/347/237/245.svg +11 -0
  239. package/src/components/layout/message/message-icon//347/251/272/347/212/266/346/200/201.svg +17 -0
  240. package/src/components/layout/message/message-icon//347/263/273/347/273/237/351/200/232/347/237/245-/350/223/235.svg +13 -0
  241. package/src/components/layout/message/message-icon//347/263/273/347/273/237/351/200/232/347/237/245-/351/273/221.svg +13 -0
  242. package/src/components/layout/message/message-icon//347/263/273/347/273/237/351/200/232/347/237/245.svg +13 -0
  243. package/src/components/layout/message/message-notification-drawer.vue +529 -0
  244. package/src/components/layout/personalization-guide-dialog.vue +255 -0
  245. package/src/components/layout/sideMenu-global.scss +115 -0
  246. package/src/components/layout/sideMenu.scss +312 -0
  247. package/src/components/layout/sideMenu.vue +542 -0
  248. package/src/components/layout/sideMenuSonList.vue +185 -0
  249. package/src/components/layout/styles/icon.scss +72 -0
  250. package/src/components/layout/types.ts +98 -0
  251. package/src/components/list-search-content/components/search-date-range.vue +1 -1
  252. package/src/components/list-search-content/components/search-date-time-range.vue +1 -1
  253. package/src/components/list-search-content/components/search-date.vue +1 -1
  254. package/src/components/list-search-content/components/search-input-number.vue +1 -1
  255. package/src/components/list-search-content/components/search-input.vue +1 -1
  256. package/src/components/list-search-content/components/search-multiple_select.vue +1 -1
  257. package/src/components/list-search-content/components/search-select.vue +1 -1
  258. package/src/components/list-search-content/index.vue +6 -6
  259. package/src/components/list-search-content/modules/add-views-package-dialog.vue +3 -3
  260. package/src/components/list-search-content/modules/search-condition-area.vue +2 -2
  261. package/src/components/list-search-content/modules/views-package-manage-dialog.vue +5 -5
  262. package/src/components.ts +19 -4
  263. package/src/index.ts +1 -0
  264. package/src/utils/dd-utils.ts +1 -1
  265. package/src/utils/get-dict.ts +2 -2
  266. package/src/utils/permit-utils.ts +2 -2
  267. package/src/api/bms/dict/bo/TotalDictSearchBO.ts +0 -8
  268. package/src/api/bms/file/FileExportController.ts +0 -18
  269. package/src/api/bms/file/bo/FileExportVO.ts +0 -17
@@ -0,0 +1,399 @@
1
+ <!-- 选择部门 - 多选 - 单选 -->
2
+ <template>
3
+ <div @click="changeDigVis(true)" class="triggerArea flexRowStart">
4
+ <div class="triggerItem" v-for="(item, index) in checkedMember" :key="index"
5
+ v-if="checkedMember && checkedMember.length > 0 && !props.abbreviate">
6
+ {{ item.deptName }}
7
+ </div>
8
+
9
+ <div v-else-if="checkedMember && checkedMember.length > 0 && props.abbreviate" class="abbreviateItem flexRowCenter">
10
+ {{ `已选择(${checkedMember.length})` }}<el-icon style="font-size:16px;">
11
+ <UserFilled />
12
+ </el-icon>
13
+ </div>
14
+ <div v-else>请选择部门</div>
15
+ </div>
16
+ <el-dialog v-model="dialogVisible" title="选择部门" :width="800" style="height:588px;border-radius: 8px;" :footer="true"
17
+ :show-close="false" class="searchDialog">
18
+ <div class="flexRowStart searchBox">
19
+ <div class="flexColumnStart searchItem">
20
+ <el-input v-model="searchContent" class="w-50 m-2" placeholder="请输入" :suffix-icon="Search" size="large"
21
+ @blur="goSearch" v-if="false" />
22
+ <div class="companyNameBox">
23
+ <span v-for="(nameItem, nameIndex) in namebox" :key="nameIndex" class="companyNameBoxName"
24
+ @click="goPointLevel(nameItem, nameIndex)">
25
+ {{ nameItem.name }}
26
+ <span v-if="nameIndex != namebox.length - 1" class="companyNameBoxSymbol">
27
+ /
28
+ </span>
29
+ </span>
30
+ </div>
31
+ <el-checkbox v-model="checkAll" :indeterminate="isIndeterminate" @change="handleCheckAllChange" size="default"
32
+ v-if="multiple">全选</el-checkbox>
33
+
34
+ <el-checkbox-group v-model="checkedMember" @change="handleCheckedMemberChange" size="default"
35
+ class="flexColumnStart optionbox" v-if="multiple">
36
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
37
+ <el-checkbox :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
38
+ ">
39
+ {{
40
+ item.deptName
41
+ }}
42
+ </el-checkbox>
43
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;" class="flexRowStart"
44
+ @click.stop="goNextLevel(item)">
45
+ <el-icon style="margin-right:4px;">
46
+ <Expand />
47
+ </el-icon>{{ '下级' }}
48
+ </div>
49
+ </div>
50
+ </el-checkbox-group>
51
+ <el-radio-group v-if="!multiple" v-model="checkedMemberForRadio" size="default"
52
+ class="flexColumnStart optionbox" @change="radioChanged">
53
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
54
+ <el-radio :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 250px;min-height:24px;max-height: 24px;
55
+ ">
56
+ <div class="flexRowBetween" style="width:300px">
57
+ {{
58
+ item.deptName
59
+ }}
60
+ </div>
61
+
62
+ </el-radio>
63
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;" class="flexRowStart"
64
+ @click.stop="goNextLevel(item)">
65
+ <el-icon style="margin-right:4px;">
66
+ <Expand />
67
+ </el-icon>{{ '下级' }}
68
+ </div>
69
+ </div>
70
+ </el-radio-group>
71
+ </div>
72
+ <div class="flexColumnStart searchItem"
73
+ style="padding-left: 8px;border-left: 2px solid #e3e3e3;height: 464px;width:48%;margin-left: 2px;">
74
+ <div class="flexRowBetween" style="width:100%;margin-bottom: 18px;">
75
+ <div @click="showCeshi">已选择</div>
76
+ <div style="color:skyblue;cursor: pointer;" @click="resetChoose">清空</div>
77
+ </div>
78
+ <div class="flexRowStartCenter" style="flex-wrap: wrap;">
79
+ <div class="chooseItem flexRowStartCenter" v-for="(item, index) in checkedMember" :key="item.userId">
80
+ <el-icon style="font-size:17px">
81
+ <GobletFull />
82
+ </el-icon>
83
+ <div class="chooseItemName">{{ item.deptName }}</div>
84
+ <el-icon class="chooseItemIcon" @click="deleteCheckedItem(index)">
85
+ <Close />
86
+ </el-icon>
87
+ </div>
88
+ </div>
89
+ </div>
90
+ </div>
91
+ <template #footer>
92
+ <span class="dialog-footer">
93
+ <el-button @click="cancelDia">取消</el-button>
94
+ <el-button type="primary" @click="saveDia">
95
+ 确定
96
+ </el-button>
97
+ </span>
98
+ </template>
99
+ </el-dialog>
100
+ </template>
101
+ <script lang="ts" setup>
102
+ import { ref, onMounted, toRefs, watch, PropType } from 'vue'
103
+ import { Search } from '@element-plus/icons-vue'
104
+ import DeptController from "hrp-ui-base/api/hrms/dept/deptController"
105
+ import type { departBo, nameForSearchBo } from './BO/departBo'
106
+ const props = defineProps({
107
+ modelValue: {
108
+ type: Array as PropType<any>
109
+ },
110
+ multiple: {
111
+ type: Boolean,
112
+ default: true,
113
+ require: false
114
+ },
115
+ abbreviate: {
116
+ type: Boolean,
117
+ default: false,
118
+ require: false
119
+ }
120
+ })
121
+ const emits = defineEmits(['update:modelValue', 'changeCheckMemberId'])
122
+ const { modelValue, multiple } = toRefs(props)
123
+ const showCeshi = () => {
124
+ console.log(checkedMember, checkAll.value)
125
+ }
126
+ onMounted(() => {
127
+ setTimeout(() => {
128
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
129
+ if (!multiple.value) {
130
+ console.log(checkedMember.value)
131
+ checkedMemberForRadio.value = checkedMember.value[0]
132
+ }
133
+ }, 500)
134
+ // getList('1')
135
+ })
136
+ const getList = async (id: string) => {
137
+ console.log(id)
138
+ await DeptController.getDeptListByParentId(id).then((data) => {
139
+ if (data && data.res) {
140
+ let arr = <any>[]
141
+ if (data.res.length > 0) {
142
+ data.res.forEach((item) => {
143
+ arr.push({ ...item, id: item.deptId })
144
+ })
145
+ }
146
+ departs.value = arr
147
+ handleCheckedMemberChange(checkedMember.value)
148
+ }
149
+ // checkAll.value = false
150
+ })
151
+ }
152
+ const dialogVisible = ref(false)
153
+ const searchContent = ref('')
154
+ const checkAll = ref(false)
155
+ const isIndeterminate = ref(false)
156
+ const checkedMember = ref<any[]>([])
157
+ let members = ref<any>([])
158
+ let departs = ref<departBo[]>([])
159
+ // 点击多选
160
+ const handleCheckAllChange = (val: boolean) => {
161
+ let copyMembers = JSON.parse(JSON.stringify(checkedMember.value))
162
+ for (let j = checkedMember.value.length - 1; j >= 0; j--) {
163
+ departs.value.forEach((item, index) => {
164
+ if (item.deptId == checkedMember.value[j].deptId) {
165
+ console.log(item, checkedMember.value[j])
166
+ copyMembers.splice(j, 1)
167
+ }
168
+ })
169
+ }
170
+ if (val) {
171
+ departs.value.forEach((item, index) => {
172
+ copyMembers.push(item)
173
+ })
174
+ }
175
+ checkedMember.value = copyMembers
176
+ // checkedMember.value = val ? members.value : []
177
+ isIndeterminate.value = false
178
+ }
179
+ const handleCheckedMemberChange = (value: any) => {
180
+ console.log(value)
181
+ let chooseAllAll = true
182
+ let havaOneChoose = false
183
+ departs.value.forEach((j, jndex) => {
184
+ let havaValue = false
185
+ value.forEach((i: any, index: number) => {
186
+
187
+ if (i.deptId == j.deptId) {
188
+ havaValue = true
189
+ havaOneChoose = true
190
+ }
191
+ })
192
+ if (!havaValue) {
193
+ chooseAllAll = false
194
+ }
195
+ })
196
+ isIndeterminate.value = chooseAllAll ? false : havaOneChoose
197
+ checkAll.value = chooseAllAll
198
+ console.log(value, chooseAllAll, havaOneChoose, isIndeterminate.value, checkAll.value)
199
+
200
+ // let copyMembers = [...checkedMember]
201
+ // members.value.forEach((item,index)=>{
202
+ // value.forEach((id:string,idIndex:number)=>{
203
+ // if(item.userId == id){
204
+
205
+ // }
206
+ // })
207
+ // })
208
+
209
+ }
210
+ const goSearch = () => {
211
+
212
+ }
213
+ const namebox = ref([{ name: '全部', id: '1' }])
214
+ const resetChoose = () => {
215
+ checkedMember.value.length = 0
216
+ checkedMemberForRadio.value = undefined
217
+ checkAll.value = false
218
+ isIndeterminate.value = false
219
+ }
220
+ // 去下级
221
+ const goNextLevel = async (item: departBo) => {
222
+ await getList(item.deptId)
223
+ namebox.value.push({ id: item.deptId, name: item.deptName })
224
+ }
225
+ // 改变当前层级,点击部门名字
226
+ const goPointLevel = async (item: nameForSearchBo, index: number) => {
227
+ await getList(item.id)
228
+ namebox.value.splice(index + 1, namebox.value.length - index - 1)
229
+ }
230
+ const changeDigVis = async (value: boolean) => {
231
+ if (value) {
232
+ await getList('1')
233
+ }
234
+ dialogVisible.value = value
235
+ }
236
+ const cancelDia = () => {
237
+ console.log(checkedMemberForRadio.value)
238
+ // @ts-ignore
239
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
240
+ if (!multiple.value) {
241
+ checkedMemberForRadio.value = checkedMember.value[0]
242
+ }
243
+ console.log(checkedMemberForRadio.value)
244
+
245
+ changeDigVis(false)
246
+ }
247
+ const saveDia = () => {
248
+ let arr: Array<string> = []
249
+ checkedMember.value.forEach((item, index) => {
250
+ arr.push(item.userId)
251
+ })
252
+ emits('update:modelValue', checkedMember.value)
253
+ emits('changeCheckMemberId', arr)
254
+ changeDigVis(false)
255
+ }
256
+ // 删除某个以选项
257
+ const deleteCheckedItem = (index: number) => {
258
+ checkedMember.value.splice(index, 1)
259
+ }
260
+ // 单选绑定的值
261
+ const checkedMemberForRadio = ref<any>()
262
+ // 改变单选时将值赋给checkedMember
263
+ const radioChanged = (value: any) => {
264
+ console.debug(value)
265
+ // let chooseItem = {}
266
+ // members.value.forEach(i => {
267
+ // if (i.userId == value) {
268
+ // chooseItem = i
269
+ // }
270
+ // })
271
+ // console.log(chooseItem)
272
+ checkedMember.value.length = 0
273
+ checkedMember.value.push(value)
274
+ }
275
+ watch(() => props.modelValue, () => {
276
+ console.warn('modelValue改变了')
277
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
278
+ if (!multiple.value) {
279
+ console.log(checkedMember.value)
280
+ checkedMemberForRadio.value = checkedMember.value[0]
281
+ }
282
+ })
283
+ </script>
284
+ <style lang="scss">
285
+ @use '../styles/common.scss';
286
+
287
+ .el-button--text {
288
+ margin-right: 15px;
289
+ }
290
+
291
+ .dialog-footer button:first-child {
292
+ margin-right: 10px;
293
+ }
294
+
295
+ .searchBox {
296
+ width: 100%;
297
+ flex-grow: 0;
298
+ flex-shrink: 0;
299
+ font-size: 16px;
300
+ }
301
+
302
+ .searchItem {
303
+ width: 50%;
304
+ }
305
+
306
+ .chooseItem {
307
+ padding: 2px 6px;
308
+ margin: 0 10px 8px 0;
309
+ background-color: var(--custom-theme-info-6);
310
+
311
+ img {
312
+ border-radius: 50%;
313
+ margin-right: 4px;
314
+ width: 16px;
315
+ height: 16px;
316
+ }
317
+
318
+ &Name {
319
+ margin-right: 8px;
320
+ }
321
+
322
+ &Icon {
323
+ cursor: pointer;
324
+ }
325
+ }
326
+
327
+ .triggerArea {
328
+ width: 100%;
329
+ min-height: 32px;
330
+ height: min-content;
331
+ border: 1px solid rgb(229, 230, 232);
332
+ padding: 8px;
333
+
334
+ .triggerItem {
335
+ margin-right: 8px;
336
+ margin-bottom: 3px;
337
+ display: inline-block;
338
+ overflow: hidden;
339
+ text-overflow: ellipsis;
340
+ white-space: nowrap;
341
+ color: var(--custom-theme-text-2);
342
+ border-color: #cfd2d5;
343
+ background-color:var(--custom-theme-info-5);
344
+ padding: 2px 12px;
345
+ cursor: pointer;
346
+ }
347
+ }
348
+
349
+ .companyNameBox {
350
+ font-size: 18px;
351
+ line-height: 30px;
352
+ overflow: hidden;
353
+ // text-overflow: ellipsis;
354
+ white-space: nowrap;
355
+ overflow-x: auto;
356
+ width: 100%;
357
+
358
+ &Name {
359
+ color: #1890ff;
360
+ cursor: pointer;
361
+ }
362
+
363
+ &Symbol {
364
+ margin: 0 9px;
365
+ color: #a3a3a3
366
+ }
367
+ }
368
+
369
+ .optionbox {
370
+ overflow-y: auto;
371
+ height: 365px;
372
+ width: 100%;
373
+ flex-grow: 0;
374
+ flex-shrink: 0;
375
+ flex-wrap: nowrap;
376
+ }
377
+
378
+ .abbreviateItem {
379
+ font-size: 14px;
380
+ margin: 0 18px;
381
+ height: 20px;
382
+ line-height: 20px;
383
+ }
384
+ </style>
385
+ <style lang="scss">
386
+ .searchBox {
387
+ .el-checkbox {
388
+ margin-right: 0
389
+ }
390
+
391
+ }
392
+
393
+ .searchDialog {
394
+ .el-dialog__body {
395
+ padding-top: 10px;
396
+ padding-bottom: 10px;
397
+ }
398
+ }
399
+ </style>