hrp-ui-base 1.0.1 → 1.0.2

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 (190) hide show
  1. package/dist/components.cjs +1 -1
  2. package/dist/components.es.js +4 -4
  3. package/dist/index.cjs +1 -1
  4. package/dist/index.es.js +83 -67
  5. package/dist/style.css +1 -1
  6. package/package.json +15 -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/work-order-pc/flow/Bo/ValueMapBo.ts +7 -0
  152. package/src/api/work-order-pc/flow/ItrFlowProcessController.ts +42 -0
  153. package/src/api/work-order-pc/flow/Vo/FlowNodeVO.ts +24 -0
  154. package/src/api/work-order-pc/flow/Vo/UserInfoVo.ts +44 -0
  155. package/src/assets/process/agree.png +0 -0
  156. package/src/assets/process/defaultAvatar.png +0 -0
  157. package/src/assets/process/drawer/departManagerJump.png +0 -0
  158. package/src/assets/process/drawer/manyLevel1close.svg +10 -0
  159. package/src/assets/process/drawer/manyLevel1open.svg +7 -0
  160. package/src/assets/process/drawer/manyLevel2close.svg +7 -0
  161. package/src/assets/process/drawer/manyLevel2open.svg +7 -0
  162. package/src/assets/process/inProcess.png +0 -0
  163. package/src/assets/process/manyPeople.png +0 -0
  164. package/src/assets/process/manyPeople2.png +0 -0
  165. package/src/assets/process/reject.png +0 -0
  166. package/src/assets/process/revoke.png +0 -0
  167. package/src/components/annex-img-upload/index.vue +4 -4
  168. package/src/components/annex-img-upload/modules/previewMp.vue +1 -1
  169. package/src/components/annex-upload/index.vue +4 -4
  170. package/src/components/annex-upload/modules/previewMp.vue +1 -1
  171. package/src/components/annex-upload-weijian/index.vue +4 -4
  172. package/src/components/annex-upload-weijian/modules/previewMp.vue +1 -1
  173. package/src/components/list-search-content/components/search-date-range.vue +1 -1
  174. package/src/components/list-search-content/components/search-date-time-range.vue +1 -1
  175. package/src/components/list-search-content/components/search-date.vue +1 -1
  176. package/src/components/list-search-content/components/search-input-number.vue +1 -1
  177. package/src/components/list-search-content/components/search-input.vue +1 -1
  178. package/src/components/list-search-content/components/search-multiple_select.vue +1 -1
  179. package/src/components/list-search-content/components/search-select.vue +1 -1
  180. package/src/components/list-search-content/index.vue +6 -6
  181. package/src/components/list-search-content/modules/add-views-package-dialog.vue +3 -3
  182. package/src/components/list-search-content/modules/search-condition-area.vue +2 -2
  183. package/src/components/list-search-content/modules/views-package-manage-dialog.vue +5 -5
  184. package/src/index.ts +1 -0
  185. package/src/utils/dd-utils.ts +1 -1
  186. package/src/utils/get-dict.ts +2 -2
  187. package/src/utils/permit-utils.ts +2 -2
  188. package/src/api/bms/dict/bo/TotalDictSearchBO.ts +0 -8
  189. package/src/api/bms/file/FileExportController.ts +0 -18
  190. package/src/api/bms/file/bo/FileExportVO.ts +0 -17
@@ -0,0 +1,565 @@
1
+ <!-- 选择人员 - 多选 - 单选 -->
2
+ <template>
3
+ <div @click="changeDigVis(true)" class="triggerArea flexRowStart" :style="props.submitAdd ? { padding: 0 } : {}">
4
+ <div class="triggerItem" v-for="(item, index) in checkedMember" :key="index"
5
+ v-if="checkedMember && checkedMember.length > 0 && !props.abbreviate && !props.submitAdd">
6
+ {{ item.userName }}
7
+ </div>
8
+ <div v-else-if="checkedMember && checkedMember.length > 0 && props.abbreviate && !props.submitAdd"
9
+ class="abbreviateItem flexRowCenter">
10
+ {{ `已选择(${checkedMember.length})` }}<el-icon style="font-size:16px;">
11
+ <UserFilled />
12
+ </el-icon>
13
+ </div>
14
+ <div v-else-if="props.submitAdd">
15
+ <el-icon class="iconBoxForSubmitAdd">
16
+ <Plus />
17
+ </el-icon>
18
+ </div>
19
+ <div v-else>请选择人员</div>
20
+ </div>
21
+ <el-dialog v-model="dialogVisible" title="选择人员" :width="800" style="min-height:588px;border-radius: 8px;"
22
+ :footer="true" :show-close="false" class="searchDialog">
23
+ <div class="flexRowStart searchBox" v-loading="formLoading">
24
+ <div class="flexColumnStart searchItem">
25
+ <el-input v-model="searchContent" placeholder="请输入用户名称查询" :suffix-icon="Search"
26
+ @input="goSearch" clearable v-if=" props.dataSources != 'role'" style="width: 100%"/>
27
+ <div class="companyNameBox flexRowStart" v-if="props.dataSources != 'user' && props.dataSources != 'role'">
28
+ <span v-for="(nameItem, nameIndex) in namebox" :key="nameIndex" class="companyNameBoxName"
29
+ @click="goPointLevel(nameItem, nameIndex)">
30
+ {{ nameItem.name }}
31
+ <span v-if="nameIndex != namebox.length - 1" class="companyNameBoxSymbol">
32
+ /
33
+ </span>
34
+ </span>
35
+ </div>
36
+ <el-checkbox v-model="checkAll" :indeterminate="isIndeterminate" @change="handleCheckAllChange" size="default"
37
+ v-if="props.multiple">全选</el-checkbox>
38
+
39
+ <el-checkbox-group v-model="checkedMember" @change="handleCheckedMemberChange" size="default"
40
+ class="flexColumnStart optionbox" v-if="props.multiple">
41
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
42
+ <el-checkbox :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
43
+ " disabled>
44
+ {{
45
+ item.deptName
46
+ }}
47
+ </el-checkbox>
48
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;" class="flexRowStart"
49
+ @click.stop="goNextLevel(item)">
50
+ <el-icon style="margin-right:4px;">
51
+ <Expand />
52
+ </el-icon>{{ '下级' }}
53
+ </div>
54
+ </div>
55
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in members" :key="item.userId">
56
+ <el-checkbox :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
57
+ ">
58
+ {{
59
+ item.userName
60
+ }}
61
+ </el-checkbox>
62
+ </div>
63
+ </el-checkbox-group>
64
+ <el-radio-group v-if="!props.multiple" v-model="checkedMemberForRadio" size="default"
65
+ class="flexColumnStart optionbox" @change="radioChanged">
66
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
67
+ <el-radio :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 250px;min-height:24px;max-height: 24px;
68
+ " disabled>
69
+ <div class="flexRowBetween" style="width:300px">
70
+ {{
71
+ item.deptName
72
+ }}
73
+ </div>
74
+
75
+ </el-radio>
76
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;" class="flexRowStart"
77
+ @click.stop="goNextLevel(item)">
78
+ <el-icon style="margin-right:4px;">
79
+ <Expand />
80
+ </el-icon>{{ '下级' }}
81
+ </div>
82
+ </div>
83
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in members" :key="item.userId">
84
+ <el-radio :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
85
+ ">
86
+ {{
87
+ item.userName
88
+ }}
89
+ </el-radio>
90
+ </div>
91
+ </el-radio-group>
92
+ </div>
93
+ <div class="flexColumnStart searchItem"
94
+ style="padding-left: 8px;border-left: 2px solid #e3e3e3;height: 464px;width:48%;margin-left: 2px;">
95
+ <div class="flexRowBetween" style="width:100%;margin-bottom: 18px;">
96
+ <div>已选择</div>
97
+ <div style="color:skyblue;cursor: pointer;" @click="resetChoose">清空</div>
98
+ </div>
99
+ <div class="flexRowStartCenter" style="flex-wrap: wrap;">
100
+ <div class="chooseItem flexRowStartCenter" v-for="(item, index) in checkedMember" :key="item.userId">
101
+ <img :src="item.avatar" alt="" v-if="item.avatar">
102
+ <img src="hrp-ui-base/assets/process/defaultAvatar.png" alt="" v-if="!item.avatar">
103
+ <div class="chooseItemName">{{ item.userName }}</div>
104
+ <el-icon class="chooseItemIcon" @click="deleteCheckedItem(index)">
105
+ <Close />
106
+ </el-icon>
107
+ </div>
108
+ </div>
109
+ </div>
110
+ </div>
111
+ <template #footer>
112
+ <span class="dialog-footer">
113
+ <el-button @click="cancelDia">取消</el-button>
114
+ <el-button type="primary" @click="saveDia">
115
+ 确定
116
+ </el-button>
117
+ </span>
118
+ </template>
119
+ </el-dialog>
120
+ </template>
121
+ <script lang="ts" setup>
122
+ import { reactive, ref, onMounted, shallowRef, toRefs, watch } from 'vue'
123
+ import { Search, Watch } from '@element-plus/icons-vue'
124
+ // import SystemUserController from 'hrp-ui-base/api/system/controller/user/SystemUserController'
125
+ import DeptController from "hrp-ui-base/api/hrms/dept/deptController";
126
+ import RoleController from "hrp-ui-base/api/hrms/role/roleController";
127
+ import UserController from "hrp-ui-base/api/hrms/user/userController";
128
+ import type { userBo, departBo, nameForSearchBo } from './BO/memberBo'
129
+ import { debounce } from 'lodash';
130
+ const props = defineProps({
131
+ modelValue: {},
132
+ // 选择了那些审批人 具体的人名
133
+ multiple: {
134
+ type: Boolean,
135
+ default: true,
136
+ require: false
137
+ },
138
+ // 选择了N位审批人 ,缩略图
139
+ abbreviate: {
140
+ type: Boolean,
141
+ default: false,
142
+ require: false
143
+ },
144
+ // 显示add - 审批提交时
145
+ submitAdd: {
146
+ type: Boolean,
147
+ default: false,
148
+ require: false
149
+ },
150
+ // 数据来源范围 全公司 指定成员 指定角色
151
+ dataSources: {
152
+ type: String,
153
+ default: 'all',
154
+ require: false
155
+ },
156
+ // 数据来源范围具体的条件 全公司 指定成员 指定角色
157
+ dataSourcesCondition: {
158
+ type: Array<string>,
159
+ default: [],
160
+ require: false
161
+ }
162
+ })
163
+ const emits = defineEmits(['update:modelValue', 'changeCheckMemberId'])
164
+ const { modelValue, multiple } = toRefs(props)
165
+ watch(() => { return props.multiple }, () => {
166
+ console.warn('多选改变了')
167
+ })
168
+
169
+ onMounted(() => {
170
+ setTimeout(() => {
171
+ // @ts-ignore
172
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
173
+ if (!props.multiple) {
174
+ console.log(checkedMember.value)
175
+ checkedMemberForRadio.value = checkedMember.value[0]
176
+ }
177
+ }, 500)
178
+ // getList('1')
179
+ })
180
+ /** 复制出的数据 */
181
+ const copyMembers = ref<userBo[]>([])
182
+ const getList =async (id: string) => {
183
+ formLoading.value = true
184
+ if (props.dataSources == 'user') {
185
+ let userIds = <any>[]
186
+ if (props.dataSourcesCondition && props.dataSourcesCondition.length > 0) {
187
+ userIds = props.dataSourcesCondition
188
+ }
189
+ await UserController.getLivingUserListByIds(userIds).then((data) => {
190
+ console.log(data)
191
+
192
+ if (data.res) {
193
+ let arr = <any>[]
194
+ if (data.res.length > 0) {
195
+ data.res.forEach((item) => {
196
+ arr.push({ ...item, id: item.userId })
197
+ })
198
+ }
199
+ members.value = arr
200
+ copyMembers.value = JSON.parse(JSON.stringify(arr))
201
+ }
202
+ // if (data.res && data.res.deptVoList) {
203
+ // departs.value = data.res?.deptVoList
204
+ // }
205
+ // checkAll.value = false
206
+ })
207
+ } else if (props.dataSources == 'role') {
208
+ let roleIds = <any>[]
209
+ if (props.dataSourcesCondition && props.dataSourcesCondition.length > 0) {
210
+ roleIds = props.dataSourcesCondition
211
+ }
212
+ await UserController.getUserListByRoleIds(roleIds).then((data) => {
213
+ console.log(data)
214
+ if (data.res) {
215
+ let arr = <any>[]
216
+ if (data.res.length > 0) {
217
+ data.res.forEach((item) => {
218
+ arr.push({ ...item, id: item.userId })
219
+ })
220
+ }
221
+ members.value = arr
222
+ }
223
+ // if (data.res && data.res.userList) {
224
+ // let arr = <any>[]
225
+ // if (data.res.userList.length > 0) {
226
+ // data.res.userList.forEach((item) => {
227
+ // arr.push({ ...item, id: item.userId })
228
+ // })
229
+ // }
230
+ // members.value = arr
231
+ // }
232
+ // if (data.res && data.res.deptVoList) {
233
+ // departs.value = data.res?.deptVoList
234
+ // }
235
+ // checkAll.value = false
236
+ })
237
+ } else {
238
+ await DeptController.getDeptUserListByParentId(id).then((data) => {
239
+ if (data.res && data.res.userList) {
240
+ let arr = <any>[]
241
+ if (data.res.userList.length > 0) {
242
+ data.res.userList.forEach((item) => {
243
+ arr.push({ ...item, id: item.userId })
244
+ })
245
+ }
246
+ members.value = arr
247
+ }
248
+ if (data.res && data.res.deptVoList) {
249
+ departs.value = data.res?.deptVoList
250
+ }
251
+ checkAll.value = false
252
+ })
253
+ }
254
+ formLoading.value = false
255
+
256
+ }
257
+ const dialogVisible = ref(false)
258
+ const searchContent = ref('')
259
+ const checkAll = ref(false)
260
+ const isIndeterminate = ref(false)
261
+ const checkedMember = ref<userBo[]>([])
262
+ let members = ref<userBo[]>([])
263
+ let departs = ref<departBo[]>([])
264
+ // 点击多选
265
+ const handleCheckAllChange = (val: boolean) => {
266
+ let copyMembers = JSON.parse(JSON.stringify(checkedMember.value))
267
+ for (let j = checkedMember.value.length - 1; j >= 0; j--) {
268
+ members.value.forEach((item, index) => {
269
+ if (item.userId == checkedMember.value[j].userId) {
270
+ console.log(item, checkedMember.value[j])
271
+ copyMembers.splice(j, 1)
272
+ }
273
+ })
274
+ }
275
+ if (val) {
276
+ members.value.forEach((item, index) => {
277
+ copyMembers.push(item)
278
+ })
279
+ }
280
+ checkedMember.value = copyMembers
281
+ // checkedMember.value = val ? members.value : []
282
+ isIndeterminate.value = false
283
+ }
284
+ const handleCheckedMemberChange = (value: any) => {
285
+
286
+ let chooseAllAll = true
287
+ let havaOneChoose = false
288
+ members.value.forEach((j, jndex) => {
289
+ let havaValue = false
290
+ value.forEach((i: any, index: number) => {
291
+
292
+ if (i.userId == j.userId) {
293
+ havaValue = true
294
+ havaOneChoose = true
295
+ }
296
+ })
297
+ if (!havaValue) {
298
+ chooseAllAll = false
299
+ }
300
+ })
301
+ console.log(value, chooseAllAll, havaOneChoose)
302
+ isIndeterminate.value = chooseAllAll ? false : havaOneChoose
303
+ checkAll.value = chooseAllAll
304
+
305
+ // let copyMembers = [...checkedMember]
306
+ // members.value.forEach((item,index)=>{
307
+ // value.forEach((id:string,idIndex:number)=>{
308
+ // if(item.userId == id){
309
+
310
+ // }
311
+ // })
312
+ // })
313
+
314
+ }
315
+ /** loading */
316
+ const formLoading = ref<boolean>(false)
317
+ /** 当前的数据的来源类型 dept-组织架构 search-直接搜索 */
318
+ const currentType = ref<'dept' | 'search'>('dept')
319
+ /** 输入用户名搜索用户列表 */
320
+ const goSearch = debounce(async (value: string) => {
321
+ formLoading.value = true
322
+ if (props.dataSources == 'user') {
323
+ if (copyMembers.value && Array.isArray(copyMembers.value) && copyMembers.value.length > 0) {
324
+
325
+ members.value = copyMembers.value.filter((item) => {
326
+ return item.userName.includes(value)
327
+ })
328
+ console.log(members.value)
329
+ }
330
+ } else {
331
+ if (value) {
332
+ currentType.value = 'search'
333
+ /** 调用查询函数 */
334
+ await UserController.selectUserByName(value).then((data) => {
335
+ if (data.code === 200 && data.res) {
336
+ members.value = data.res.map((item) => { return { ...item, id: item.userId } })
337
+ departs.value = []
338
+ } else {
339
+ members.value = []
340
+ departs.value = []
341
+ }
342
+ })
343
+ } else {
344
+ // 切换为dept类型
345
+ currentType.value = 'dept'
346
+ await getList('1')
347
+ }
348
+ }
349
+ formLoading.value = false
350
+ }, 1000)
351
+ const namebox = ref([{ name: '全部', id: '1' }])
352
+ const resetChoose = () => {
353
+ checkedMember.value.length = 0
354
+ checkedMemberForRadio.value = undefined
355
+ checkAll.value = false
356
+ isIndeterminate.value = false
357
+ }
358
+ // 去下级
359
+ const goNextLevel = async (item: departBo) => {
360
+ await getList(item.deptId)
361
+ namebox.value.push({ id: item.deptId, name: item.deptName })
362
+ }
363
+ // 改变当前层级,点击部门名字
364
+ const goPointLevel = async (item: nameForSearchBo, index: number) => {
365
+ await getList(item.id)
366
+ namebox.value.splice(index + 1, namebox.value.length - index - 1)
367
+ }
368
+ const changeDigVis = async (value: boolean) => {
369
+ if (value) {
370
+ await getList('1')
371
+ namebox.value = [{ name: '全部', id: '1' }]
372
+ searchContent.value = ""
373
+ }
374
+ dialogVisible.value = value
375
+ }
376
+ const cancelDia = () => {
377
+ console.log(checkedMemberForRadio.value)
378
+ // @ts-ignore
379
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
380
+ if (!props.multiple) {
381
+ checkedMemberForRadio.value = checkedMember.value[0]
382
+ }
383
+ console.log(checkedMemberForRadio.value)
384
+
385
+ changeDigVis(false)
386
+ }
387
+ const saveDia = () => {
388
+
389
+ let arr: Array<string> = []
390
+
391
+ checkedMember.value.forEach((item, index) => {
392
+ arr.push(item.userId)
393
+ })
394
+ emits('update:modelValue', checkedMember.value)
395
+ emits('changeCheckMemberId', arr)
396
+ changeDigVis(false)
397
+
398
+ }
399
+ // 删除某个以选项
400
+ const deleteCheckedItem = (index: number) => {
401
+ checkedMember.value.splice(index, 1)
402
+ }
403
+ // 单选绑定的值
404
+ const checkedMemberForRadio = ref<userBo>()
405
+ // 改变单选时将值赋给checkedMember
406
+ const radioChanged = (value: userBo) => {
407
+ console.debug(value)
408
+ // let chooseItem = {}
409
+ // members.value.forEach(i => {
410
+ // if (i.userId == value) {
411
+ // chooseItem = i
412
+ // }
413
+ // })
414
+ // console.log(chooseItem)
415
+ checkedMember.value.length = 0
416
+ checkedMember.value.push(value)
417
+ }
418
+ watch(() => props.modelValue, () => {
419
+ console.warn('modelValue改变了')
420
+ // @ts-ignore
421
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
422
+ if (!props.multiple) {
423
+ console.log(checkedMember.value)
424
+ checkedMemberForRadio.value = checkedMember.value[0]
425
+ }
426
+ })
427
+ </script>
428
+ <style lang="scss" scoped>
429
+ @use '../styles/common.scss';
430
+
431
+
432
+ .el-button--text {
433
+ margin-right: 15px;
434
+ }
435
+
436
+ .dialog-footer button:first-child {
437
+ margin-right: 10px;
438
+ }
439
+
440
+ .searchBox {
441
+ width: 100%;
442
+ flex-grow: 0;
443
+ flex-shrink: 0;
444
+ font-size: var(--font-size-body);
445
+ }
446
+
447
+ .searchItem {
448
+ width: 50%;
449
+ }
450
+
451
+ .chooseItem {
452
+ padding: 2px 6px;
453
+ margin: 0 10px 8px 0;
454
+ background-color: var(--custom-theme-info-6);
455
+ height: 30px;
456
+ max-height: 30px;
457
+
458
+ img {
459
+ border-radius: 50%;
460
+ margin-right: 4px;
461
+ width: 16px;
462
+ height: 16px;
463
+ }
464
+
465
+ &Name {
466
+ margin-right: 8px;
467
+ }
468
+
469
+ &Icon {
470
+ cursor: pointer;
471
+ }
472
+ }
473
+
474
+ .triggerArea {
475
+ width: 100%;
476
+ min-height: 32px;
477
+ height: min-content;
478
+ border: 1px solid rgb(229, 230, 232);
479
+ padding: 8px;
480
+
481
+ .triggerItem {
482
+ margin-right: 8px;
483
+ margin-bottom: 3px;
484
+ display: inline-block;
485
+ overflow: hidden;
486
+ text-overflow: ellipsis;
487
+ white-space: nowrap;
488
+ color: var(--custom-theme-text-2);
489
+ border-color: #cfd2d5;
490
+ background-color: var(--custom-theme-info-5);
491
+
492
+ padding: 2px 12px;
493
+ cursor: pointer;
494
+ font-size: var(--font-size-body);
495
+ }
496
+ }
497
+
498
+ .companyNameBox {
499
+ font-size: var(--font-size-h2);
500
+ line-height: 30px;
501
+ overflow: hidden;
502
+ // text-overflow: ellipsis;
503
+ white-space: nowrap;
504
+ overflow-x: auto;
505
+ width: 100%;
506
+
507
+ &Name {
508
+ color: #1890ff;
509
+ cursor: pointer;
510
+ }
511
+
512
+ &Symbol {
513
+ margin: 0 9px;
514
+ color: #a3a3a3
515
+ }
516
+ }
517
+
518
+ .optionbox {
519
+ overflow-y: auto;
520
+ height: 365px;
521
+ width: 100%;
522
+ flex-grow: 0;
523
+ flex-shrink: 0;
524
+ flex-wrap: nowrap;
525
+ }
526
+
527
+ .abbreviateItem {
528
+ font-size: var(--el-font-size-base);
529
+ margin: 0 18px;
530
+ height: 20px;
531
+ line-height: 20px;
532
+ }
533
+
534
+ .iconBoxForSubmitAdd {
535
+ border-radius: 6px;
536
+ background-color: #d8d8d8;
537
+ background-size: cover;
538
+ border-radius: 6px;
539
+ float: left;
540
+ height: 40px;
541
+ margin-right: 12px;
542
+ width: 40px;
543
+ overflow: hidden;
544
+ text-align: center;
545
+ line-height: 40px;
546
+ font-size: 28px;
547
+ color: #878f95;
548
+ }
549
+ </style>
550
+ <style lang="scss">
551
+ .searchBox {
552
+ .el-checkbox {
553
+ margin-right: 0;
554
+ --el-checkbox-font-size:var(--font-size-description)
555
+ }
556
+
557
+ }
558
+
559
+ .searchDialog {
560
+ .el-dialog__body {
561
+ padding-top: 10px;
562
+ padding-bottom: 10px;
563
+ }
564
+ }
565
+ </style>