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,515 @@
1
+ <!-- 选择人员-手机端 - 多选 - 单选 -->
2
+ <template>
3
+ <el-icon class="iconBoxForSubmitAdd" @click="changePopShow(true)" v-if="props.submitAdd">
4
+ <Plus />
5
+ </el-icon>
6
+ <div @click="changePopShow(true)" class="triggerArea flexRowStart" :style="props.submitAdd ? { padding: 0 } : {}"
7
+ v-if="!props.submitAdd">
8
+ <div class="triggerItem" v-for="(item, index) in checkedMember" :key="index"
9
+ v-if="checkedMember && checkedMember.length > 0 && !props.abbreviate && !props.submitAdd">
10
+ {{ item.userName }}
11
+ </div>
12
+ <div v-else-if="checkedMember && checkedMember.length > 0 && props.abbreviate && !props.submitAdd"
13
+ class="abbreviateItem flexRowCenter">
14
+ {{ `已选择(${checkedMember.length})` }}<el-icon style="font-size:16px;">
15
+ <UserFilled />
16
+ </el-icon>
17
+ </div>
18
+
19
+ <div v-else>请选择人员</div>
20
+ </div>
21
+ <van-popup v-model:show="popupShow" closeable position="bottom"
22
+ :style="{ height: '70%', 'z-index': '8888', position: 'fixed', bottom: props.posBottom || props.posBottom == 0 ? props.posBottom + 'px' : '50px', left: 0, right: 0 }">
23
+ <div class="popupBox flexColumnStart">
24
+ <div class="popupBoxHeader">选择成员:</div>
25
+ <div class="popupBoxContent">
26
+ <div class="popCheckedItemBox">
27
+ 当前已选:
28
+ <div class="flexRowStartCenter" style="flex-wrap: wrap;">
29
+ <div class="chooseItem flexRowStartCenter" v-for="(item, index) in checkedMember" :key="item.userId">
30
+ <img :src="item.avatar" alt="" v-if="item.avatar">
31
+ <img src="hrp-ui-base/assets/process/defaultAvatar.png" alt="" v-if="!item.avatar">
32
+ <div class="chooseItemName">{{ item.userName }}</div>
33
+ <el-icon class="chooseItemIcon" @click="deleteCheckedItem(index)">
34
+ <Close />
35
+ </el-icon>
36
+ </div>
37
+ </div>
38
+ </div>
39
+ <div class="companyNameBox flexRowStart">
40
+ <span v-for="(nameItem, nameIndex) in namebox" :key="nameIndex" class="companyNameBoxName"
41
+ @click="goPointLevel(nameItem, nameIndex)">
42
+ {{ nameItem.name }}
43
+ <span v-if="nameIndex != namebox.length - 1" class="companyNameBoxSymbol">
44
+ /
45
+ </span>
46
+ </span>
47
+ </div>
48
+ <div class="popMemberList">
49
+ <el-checkbox-group v-model="checkedMember" @change="handleCheckedMemberChange" size="default"
50
+ class="flexColumnStart optionbox" v-if="multiple">
51
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
52
+ <el-checkbox :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
53
+ " disabled>
54
+ {{
55
+ item.deptName
56
+ }}
57
+ </el-checkbox>
58
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;"
59
+ class="flexRowStart" @click.stop="goNextLevel(item)">
60
+ <el-icon style="margin-right:4px;">
61
+ <Expand />
62
+ </el-icon>{{ '下级' }}
63
+ </div>
64
+ </div>
65
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in members" :key="item.userId">
66
+ <el-checkbox :label="item" size="default" style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;
67
+ ">
68
+ {{
69
+ item.userName
70
+ }}
71
+ </el-checkbox>
72
+ </div>
73
+ </el-checkbox-group>
74
+ <el-radio-group v-model="radioMemeber" @change="handleRadioMemberChange" size="default"
75
+ class="flexColumnStart optionbox" v-if="!multiple">
76
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in departs" :key="item.deptId">
77
+ <el-radio :label="item" size="default"
78
+ style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;" disabled>
79
+ {{
80
+ item.deptName
81
+ }}
82
+ </el-radio>
83
+ <div style="width:100px;height:24px;font-size: 16px;line-height: 16px;cursor: pointer;"
84
+ class="flexRowStart" @click.stop="goNextLevel(item)">
85
+ <el-icon style="margin-right:4px;">
86
+ <Expand />
87
+ </el-icon>{{ '下级' }}
88
+ </div>
89
+ </div>
90
+ <div class="flexRowBetween" style="width:100%" v-for="(item, index) in members" :key="item.userId">
91
+ <el-radio :label="item" size="default"
92
+ style="margin-bottom: 8px;font-size:18px;width: 340px;min-height:24px;max-height: 24px;">
93
+ {{
94
+ item.userName
95
+ }}
96
+ </el-radio>
97
+ </div>
98
+ </el-radio-group>
99
+ </div>
100
+ </div>
101
+ <div class="popupButton flexRowCenter">
102
+ <van-button type="primary" style="margin-right:28px;width:30%" @click="saveDia">保存</van-button>
103
+ <van-button type="default" style="width:30%" @click="saveDia">关闭</van-button>
104
+ </div>
105
+ </div>
106
+ </van-popup>
107
+ </template>
108
+ <script lang="ts" setup>
109
+ import { reactive, ref, onMounted, shallowRef, toRefs, watch ,PropType} from 'vue'
110
+ import { Search, Watch } from '@element-plus/icons-vue'
111
+ import DeptController from "hrp-ui-base/api/hrms/dept/deptController";
112
+ import RoleController from "hrp-ui-base/api/hrms/role/roleController";
113
+ import UserController from "hrp-ui-base/api/hrms/user/userController";
114
+
115
+ import type { userBo, departBo, nameForSearchBo } from './BO/memberBo'
116
+ const props = defineProps({
117
+ modelValue: {
118
+ type:Array as PropType<any>
119
+ },
120
+ // 选择了那些审批人 具体的人名
121
+ multiple: {
122
+ type: Boolean,
123
+ default: true,
124
+ require: false
125
+ },
126
+ // 选择了N位审批人 ,缩略图
127
+ abbreviate: {
128
+ type: Boolean,
129
+ default: false,
130
+ require: false
131
+ },
132
+ // 显示add - 审批提交时
133
+ submitAdd: {
134
+ type: Boolean,
135
+ default: false,
136
+ require: false
137
+ },
138
+ posBottom: {
139
+ type: Number,
140
+ require: false,
141
+ default: 50
142
+ },
143
+ // 数据来源范围 全公司 指定成员 指定角色
144
+ dataSources: {
145
+ type: String,
146
+ default: 'all',
147
+ require: false
148
+ },
149
+ // 数据来源范围具体的条件 全公司 指定成员 指定角色
150
+ dataSourcesCondition: {
151
+ type: Array<string>,
152
+ default: [],
153
+ require: false
154
+ }
155
+ })
156
+ const emits = defineEmits(['update:modelValue', 'changeCheckMemberId', 'changeButtonShow'])
157
+ const { modelValue, multiple } = toRefs(props)
158
+ const popupShow = ref(false)
159
+ const changePopShow = (value: boolean) => {
160
+ popupShow.value = value
161
+ if (value) {
162
+ getList('1')
163
+ }
164
+ }
165
+ watch(() => { popupShow.value }, () => {
166
+ emits('changeButtonShow', !popupShow.value)
167
+ }, { deep: true })
168
+ watch(() => multiple.value, () => {
169
+ console.warn('多选改变了')
170
+ })
171
+
172
+ onMounted(() => {
173
+ console.log(props)
174
+ setTimeout(() => {
175
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
176
+ if (!multiple.value) {
177
+ console.log(checkedMember.value)
178
+ checkedMemberForRadio.value = checkedMember.value[0]
179
+ }
180
+ }, 500)
181
+ // getList('1')
182
+ })
183
+ /** 复制出的数据 */
184
+ const copyMembers = ref<userBo[]>([])
185
+ const getList = async (id: string) => {
186
+ if (props.dataSources == 'user') {
187
+ let userIds = <any>[]
188
+ if (props.dataSourcesCondition && props.dataSourcesCondition.length > 0) {
189
+ userIds = props.dataSourcesCondition
190
+ }
191
+ await UserController.getLivingUserListByIds(userIds).then((data) => {
192
+ console.log(data)
193
+
194
+ if (data.res) {
195
+ let arr = <any>[]
196
+ if (data.res.length > 0) {
197
+ data.res.forEach((item) => {
198
+ arr.push({ ...item, id: item.userId })
199
+ })
200
+ }
201
+ members.value = arr
202
+ copyMembers.value = JSON.parse(JSON.stringify(arr))
203
+ }
204
+ // if (data.res && data.res.deptVoList) {
205
+ // departs.value = data.res?.deptVoList
206
+ // }
207
+ // checkAll.value = false
208
+ })
209
+ } else if (props.dataSources == 'role') {
210
+ let roleIds = <any>[]
211
+ if (props.dataSourcesCondition && props.dataSourcesCondition.length > 0) {
212
+ roleIds = props.dataSourcesCondition
213
+ }
214
+ await UserController.getUserListByRoleIds(roleIds).then((data) => {
215
+ console.log(data)
216
+ if (data.res) {
217
+ let arr = <any>[]
218
+ if (data.res.length > 0) {
219
+ data.res.forEach((item) => {
220
+ arr.push({ ...item, id: item.userId })
221
+ })
222
+ }
223
+ members.value = arr
224
+ }
225
+ // if (data.res && data.res.userList) {
226
+ // let arr = <any>[]
227
+ // if (data.res.userList.length > 0) {
228
+ // data.res.userList.forEach((item) => {
229
+ // arr.push({ ...item, id: item.userId })
230
+ // })
231
+ // }
232
+ // members.value = arr
233
+ // }
234
+ // if (data.res && data.res.deptVoList) {
235
+ // departs.value = data.res?.deptVoList
236
+ // }
237
+ // checkAll.value = false
238
+ })
239
+ } else {
240
+ await DeptController.getDeptUserListByParentId(id).then((data) => {
241
+ if (data.res && data.res.userList) {
242
+ let arr = <any>[]
243
+ if (data.res.userList.length > 0) {
244
+ data.res.userList.forEach((item) => {
245
+ arr.push({ ...item, id: item.userId })
246
+ })
247
+ }
248
+ members.value = arr
249
+ }
250
+ if (data.res && data.res.deptVoList) {
251
+ departs.value = data.res?.deptVoList
252
+ }
253
+ checkAll.value = false
254
+ })
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
+
266
+ const handleCheckAllChange = (val: boolean) => {
267
+ let copyMembers = JSON.parse(JSON.stringify(checkedMember.value))
268
+ for (let j = checkedMember.value.length - 1; j >= 0; j--) {
269
+ members.value.forEach((item, index) => {
270
+ if (item.userId == checkedMember.value[j].userId) {
271
+ console.log(item, checkedMember.value[j])
272
+ copyMembers.splice(j, 1)
273
+ }
274
+ })
275
+ }
276
+ if (val) {
277
+ members.value.forEach((item, index) => {
278
+ copyMembers.push(item)
279
+ })
280
+ }
281
+ checkedMember.value = copyMembers
282
+ // checkedMember.value = val ? members.value : []
283
+ isIndeterminate.value = false
284
+ }
285
+ const handleCheckedMemberChange = (value: any) => {
286
+
287
+ let chooseAllAll = true
288
+ let havaOneChoose = false
289
+ members.value.forEach((j, jndex) => {
290
+ let havaValue = false
291
+ value.forEach((i: any, index: number) => {
292
+
293
+ if (i.userId == j.userId) {
294
+ havaValue = true
295
+ havaOneChoose = true
296
+ }
297
+ })
298
+ if (!havaValue) {
299
+ chooseAllAll = false
300
+ }
301
+ })
302
+ console.log(value, chooseAllAll, havaOneChoose)
303
+ isIndeterminate.value = chooseAllAll ? false : havaOneChoose
304
+ checkAll.value = chooseAllAll
305
+
306
+ // let copyMembers = [...checkedMember]
307
+ // members.value.forEach((item,index)=>{
308
+ // value.forEach((id:string,idIndex:number)=>{
309
+ // if(item.userId == id){
310
+
311
+ // }
312
+ // })
313
+ // })
314
+
315
+ }
316
+ const radioMemeber = ref<any>()
317
+ const handleRadioMemberChange = (value: any) => {
318
+ console.log(value);
319
+
320
+ // @ts-ignore
321
+ checkedMember.value = [value]
322
+ }
323
+ const goSearch = () => {
324
+
325
+ }
326
+ const namebox = ref([{ name: '全部', id: '1' }])
327
+ const resetChoose = () => {
328
+ checkedMember.value.length = 0
329
+ checkedMemberForRadio.value = undefined
330
+ }
331
+ // 去下级
332
+ const goNextLevel = async (item: departBo) => {
333
+ await getList(item.deptId)
334
+ namebox.value.push({ id: item.deptId, name: item.deptName })
335
+ }
336
+ // 改变当前层级,点击部门名字
337
+ const goPointLevel = async (item: nameForSearchBo, index: number) => {
338
+ await getList(item.id)
339
+ namebox.value.splice(index + 1, namebox.value.length - index - 1)
340
+ }
341
+ const changeDigVis = async (value: boolean) => {
342
+ if (value) {
343
+ await getList('1')
344
+ }
345
+ dialogVisible.value = value
346
+ }
347
+ const cancelDia = () => {
348
+ console.log(checkedMemberForRadio.value)
349
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
350
+ if (!multiple.value) {
351
+ checkedMemberForRadio.value = checkedMember.value[0]
352
+ }
353
+ console.log(checkedMemberForRadio.value)
354
+ changeDigVis(false)
355
+ changePopShow(false)
356
+ }
357
+ const saveDia = () => {
358
+ let arr: Array<string> = []
359
+
360
+ checkedMember.value.forEach((item, index) => {
361
+ arr.push(item.userId)
362
+ })
363
+ emits('update:modelValue', checkedMember.value)
364
+ emits('changeCheckMemberId', arr)
365
+ changeDigVis(false)
366
+
367
+ changePopShow(false)
368
+ }
369
+ // 删除某个以选项
370
+ const deleteCheckedItem = (index: number) => {
371
+ checkedMember.value.splice(index, 1)
372
+ }
373
+ // 单选绑定的值
374
+ const checkedMemberForRadio = ref<userBo>()
375
+ // 改变单选时将值赋给checkedMember
376
+ const radioChanged = (value: userBo) => {
377
+ console.debug(value)
378
+ // let chooseItem = {}
379
+ // members.value.forEach(i => {
380
+ // if (i.userId == value) {
381
+ // chooseItem = i
382
+ // }
383
+ // })
384
+ // console.log(chooseItem)
385
+ checkedMember.value.length = 0
386
+ checkedMember.value.push(value)
387
+ }
388
+ watch(() => props.modelValue, () => {
389
+ console.warn('modelValue改变了')
390
+ checkedMember.value = modelValue && modelValue.value ? modelValue.value : []
391
+ if (!multiple.value) {
392
+ console.log(checkedMember.value)
393
+ checkedMemberForRadio.value = checkedMember.value[0]
394
+ }
395
+ })
396
+ defineExpose({
397
+ popupShow
398
+ })
399
+ </script>
400
+ <style lang="scss" scoped>
401
+ @use '../styles/common.scss';
402
+
403
+ .iconBoxForSubmitAdd {
404
+ border-radius: 6px;
405
+ background-color: #d8d8d8;
406
+ background-size: cover;
407
+ border-radius: 6px;
408
+ float: left;
409
+ height: 40px;
410
+ margin-right: 12px;
411
+ width: 40px;
412
+ overflow: hidden;
413
+ text-align: center;
414
+ line-height: 40px;
415
+ font-size: 28px;
416
+ color: #878f95;
417
+ }
418
+
419
+ .popupBox {
420
+ padding: 0 18px;
421
+ width: calc(100% - 0px);
422
+ height: 100%;
423
+
424
+ .popupBoxHeader {
425
+ height: 60px;
426
+ line-height: 60px;
427
+ font-size: 16px;
428
+ font-weight: bold;
429
+ }
430
+
431
+ .popupBoxContent {
432
+ height: calc(100% - 60px - 80px);
433
+ width: 100%;
434
+ overflow-y: auto;
435
+ }
436
+
437
+ .popupButton {
438
+ width: 100%;
439
+ height: 80px;
440
+ line-height: 80px;
441
+ }
442
+ }
443
+
444
+ .companyNameBox {
445
+ font-size: 18px;
446
+ line-height: 30px;
447
+ overflow: hidden;
448
+ // text-overflow: ellipsis;
449
+ white-space: nowrap;
450
+ overflow-x: auto;
451
+ width: 100%;
452
+
453
+ &Name {
454
+ color: #1890ff;
455
+ cursor: pointer;
456
+ }
457
+
458
+ &Symbol {
459
+ margin: 0 9px;
460
+ color: #a3a3a3
461
+ }
462
+ }
463
+
464
+ .triggerArea {
465
+ width: 100%;
466
+ min-height: 32px;
467
+ height: min-content;
468
+ border: 1px solid rgb(229, 230, 232);
469
+ padding: 8px;
470
+
471
+ .triggerItem {
472
+ margin-right: 8px;
473
+ margin-bottom: 3px;
474
+ display: inline-block;
475
+ overflow: hidden;
476
+ text-overflow: ellipsis;
477
+ white-space: nowrap;
478
+ color: #747677;
479
+ border-color: #cfd2d5;
480
+ background-color: #e5e6e8;
481
+ padding: 2px 12px;
482
+ cursor: pointer;
483
+ }
484
+ }
485
+
486
+ .optionbox {
487
+ width: 100%;
488
+ flex-grow: 0;
489
+ flex-shrink: 0;
490
+ flex-wrap: nowrap;
491
+ }
492
+
493
+ .chooseItem {
494
+ padding: 2px 6px;
495
+ margin: 0 10px 8px 0;
496
+ background-color: #f1f2f3;
497
+ height: 30px;
498
+ max-height: 30px;
499
+
500
+ img {
501
+ border-radius: 50%;
502
+ margin-right: 4px;
503
+ width: 16px;
504
+ height: 16px;
505
+ }
506
+
507
+ &Name {
508
+ margin-right: 8px;
509
+ }
510
+
511
+ &Icon {
512
+ cursor: pointer;
513
+ }
514
+ }
515
+ </style>