imatrix-ui 0.2.6-up → 0.2.7-up

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 (206) hide show
  1. package/README.md +7 -7
  2. package/index.html +13 -13
  3. package/lib/super-ui.css +1 -1
  4. package/lib/super-ui.js +2724 -1932
  5. package/lib/super-ui.umd.cjs +24 -24
  6. package/package.json +1 -1
  7. package/packages/IntervalSelection/index.js +6 -6
  8. package/packages/IntervalSelection/src/quarterScope.vue +405 -405
  9. package/packages/IntervalSelection/src/sectionDate.vue +475 -475
  10. package/packages/breadcrumb/index.js +6 -6
  11. package/packages/breadcrumb/src/breadcrumb.vue +81 -81
  12. package/packages/department-tree/index.js +6 -6
  13. package/packages/department-tree/src/department-tree.vue +113 -113
  14. package/packages/department-tree-inline/index.js +6 -6
  15. package/packages/department-tree-inline/src/department-multi-tree-inline.vue +472 -472
  16. package/packages/department-tree-inline/src/department-single-tree-inline.vue +340 -340
  17. package/packages/department-tree-inline/src/department-tree-inline.vue +86 -86
  18. package/packages/department-tree-inline/src/department-tree-service.js +344 -344
  19. package/packages/department-tree-inline/src/search-result.vue +235 -235
  20. package/packages/department-user-tree/index.js +6 -6
  21. package/packages/department-user-tree/src/department-user-multiple-tree.vue +129 -129
  22. package/packages/department-user-tree/src/department-user-single-tree.vue +94 -94
  23. package/packages/department-user-tree/src/department-user-tree.vue +114 -114
  24. package/packages/department-user-tree-inline/index.js +9 -9
  25. package/packages/department-user-tree-inline/src/department-user-multiple-tree-inline.vue +731 -731
  26. package/packages/department-user-tree-inline/src/department-user-single-tree-inline.vue +334 -334
  27. package/packages/department-user-tree-inline/src/department-user-tree-inline.vue +87 -87
  28. package/packages/department-user-tree-inline/src/department-user-tree-multi-service.js +309 -309
  29. package/packages/department-user-tree-inline/src/department-user-tree-single-service.js +179 -179
  30. package/packages/department-user-tree-inline/src/search-result.vue +273 -273
  31. package/packages/directives/prevent-reclick.js +22 -22
  32. package/packages/dynamic-source-select/index.js +6 -6
  33. package/packages/dynamic-source-select/src/dynamic-source-select-service.js +106 -106
  34. package/packages/dynamic-source-select/src/dynamic-source-select.vue +675 -675
  35. package/packages/dynamic-source-select/src/events.js +78 -78
  36. package/packages/fs-preview/index.js +6 -6
  37. package/packages/fs-preview/src/fs-preview.vue +287 -287
  38. package/packages/fs-upload/index.js +6 -6
  39. package/packages/fs-upload/src/fs-upload-multi.vue +443 -443
  40. package/packages/fs-upload/src/fs-upload-single.vue +353 -353
  41. package/packages/fs-upload/src/fs-upload.vue +191 -191
  42. package/packages/fs-upload/src/see-big-picture.vue +67 -67
  43. package/packages/fs-upload-list/index.js +6 -6
  44. package/packages/fs-upload-list/src/fs-upload-list.vue +372 -372
  45. package/packages/hamburger/index.js +6 -6
  46. package/packages/hamburger/src/hamburger.vue +40 -40
  47. package/packages/index.js +123 -123
  48. package/packages/multipart-upload/index.js +6 -6
  49. package/packages/multipart-upload/src/index.vue +66 -66
  50. package/packages/multipart-upload/src/multipart-upload-form.vue +377 -377
  51. package/packages/multipart-upload/src/multipart-upload-list.vue +517 -517
  52. package/packages/organization-input/index.js +6 -6
  53. package/packages/organization-input/src/organization-input.vue +583 -583
  54. package/packages/plugins/export-data-new.js +623 -623
  55. package/packages/plugins/export-data.js +431 -431
  56. package/packages/plugins/index.js +15 -15
  57. package/packages/plugins/public-method.js +47 -47
  58. package/packages/remove-department/index.js +6 -6
  59. package/packages/remove-department/src/remove-department.vue +200 -200
  60. package/packages/remove-department/src/remove-dept-service.js +31 -31
  61. package/packages/remove-user/index.js +6 -6
  62. package/packages/remove-user/src/remove-user-service.js +31 -31
  63. package/packages/remove-user/src/remove-user.vue +226 -226
  64. package/packages/remove-workgroup/index.js +6 -6
  65. package/packages/remove-workgroup/src/remove-workgroup-service.js +31 -31
  66. package/packages/remove-workgroup/src/remove-workgroup.vue +183 -183
  67. package/packages/rich-editor/index.js +7 -7
  68. package/packages/rich-editor/index.vue +297 -297
  69. package/packages/rich-editor/langs/zh-Hans.js +438 -438
  70. package/packages/rich-editor/viewer.vue +105 -105
  71. package/packages/scan-code-input/index.js +6 -6
  72. package/packages/scan-code-input/src/events.js +34 -34
  73. package/packages/scan-code-input/src/scan-code-input-colse.vue +140 -140
  74. package/packages/scan-code-input/src/scan-code-input.vue +132 -132
  75. package/packages/secret-info/index.js +7 -7
  76. package/packages/secret-info/index.vue +100 -100
  77. package/packages/super-grid/index.js +7 -7
  78. package/packages/super-grid/src/apis.js +1092 -1092
  79. package/packages/super-grid/src/columns-config.vue +427 -427
  80. package/packages/super-grid/src/custom-formatter.js +394 -394
  81. package/packages/super-grid/src/eventBus.js +2 -2
  82. package/packages/super-grid/src/events.js +56 -56
  83. package/packages/super-grid/src/formValidatorUtil.js +300 -300
  84. package/packages/super-grid/src/formatter.js +196 -196
  85. package/packages/super-grid/src/group-column.vue +99 -99
  86. package/packages/super-grid/src/header-context-menu.vue +82 -82
  87. package/packages/super-grid/src/index-column.vue +69 -69
  88. package/packages/super-grid/src/public-methods.js +30 -30
  89. package/packages/super-grid/src/row-operation.vue +193 -193
  90. package/packages/super-grid/src/search-button.vue +74 -74
  91. package/packages/super-grid/src/search-condition-input.vue +73 -73
  92. package/packages/super-grid/src/search-condition-list.vue +68 -68
  93. package/packages/super-grid/src/search-form-advancedQuery.vue +819 -819
  94. package/packages/super-grid/src/search-form-dialog.vue +77 -77
  95. package/packages/super-grid/src/search-form-item.vue +495 -495
  96. package/packages/super-grid/src/search-form-number.vue +111 -111
  97. package/packages/super-grid/src/search-form-ordinarySearch.vue +239 -239
  98. package/packages/super-grid/src/search-form.vue +762 -762
  99. package/packages/super-grid/src/search-methods.js +592 -592
  100. package/packages/super-grid/src/selection-column.vue +46 -46
  101. package/packages/super-grid/src/store.js +3 -3
  102. package/packages/super-grid/src/super-grid-service.js +728 -728
  103. package/packages/super-grid/src/super-grid.vue +3011 -3011
  104. package/packages/super-grid/src/utils.js +880 -880
  105. package/packages/super-grid/src/view-image-dialog.vue +176 -176
  106. package/packages/super-nine-grid/index.js +7 -7
  107. package/packages/super-nine-grid/src/apis.js +108 -108
  108. package/packages/super-nine-grid/src/custom-formatter.js +73 -73
  109. package/packages/super-nine-grid/src/formatter.js +134 -134
  110. package/packages/super-nine-grid/src/search-form-number.vue +35 -35
  111. package/packages/super-nine-grid/src/search-form.vue +700 -700
  112. package/packages/super-nine-grid/src/search-methods.js +151 -151
  113. package/packages/super-nine-grid/src/store.js +3 -3
  114. package/packages/super-nine-grid/src/super-grid-service.js +107 -107
  115. package/packages/svg-icon/index.js +6 -6
  116. package/packages/svg-icon/src/svg-icon.vue +43 -43
  117. package/packages/utils/date-util.js +292 -292
  118. package/packages/utils/dom.js +227 -227
  119. package/packages/utils/gogocodeTransfer.js +59 -59
  120. package/packages/utils/memory-cache-utils.js +117 -117
  121. package/packages/utils/utils.js +180 -180
  122. package/packages/utils/value-set.js +97 -97
  123. package/packages/valid-code/index.js +7 -7
  124. package/packages/valid-code/src/valid-code.vue +104 -104
  125. package/packages/workflow-button/index.js +6 -6
  126. package/packages/workflow-button/src/workflow-button.vue +550 -550
  127. package/packages/workflow-history-list/index.js +6 -6
  128. package/packages/workflow-history-list/src/api.js +7 -7
  129. package/packages/workflow-history-list/src/workflow-history-list.vue +291 -291
  130. package/packages/workgroup-tree/index.js +6 -6
  131. package/packages/workgroup-tree/src/workgroup-tree.vue +86 -86
  132. package/packages/workgroup-tree-inline/index.js +6 -6
  133. package/packages/workgroup-tree-inline/src/search-result.vue +222 -222
  134. package/packages/workgroup-tree-inline/src/workgroup-tree-inline.vue +516 -516
  135. package/packages/workgroup-tree-inline/src/workgroup-tree-service.js +93 -93
  136. package/packages/workgroup-user-tree/index.js +6 -6
  137. package/packages/workgroup-user-tree/src/workgroup-user-tree.vue +103 -103
  138. package/packages/workgroup-user-tree-inline/index.js +9 -9
  139. package/packages/workgroup-user-tree-inline/src/search-result.vue +266 -266
  140. package/packages/workgroup-user-tree-inline/src/workgroup-tree-inline-service.js +239 -239
  141. package/packages/workgroup-user-tree-inline/src/workgroup-user-tree-inline.vue +657 -657
  142. package/packages/year-range-picker/index.js +6 -6
  143. package/packages/year-range-picker/src/year-range-picker.vue +53 -53
  144. package/src/api/sso-service.js +172 -172
  145. package/src/api/tab.js +36 -36
  146. package/src/api/user-service.js +11 -11
  147. package/src/directives/permission/index.js +13 -13
  148. package/src/directives/permission/permission.js +20 -20
  149. package/src/i18n/langs/cn.js +259 -259
  150. package/src/i18n/langs/en.js +269 -269
  151. package/src/index.js +93 -93
  152. package/src/plugins.js +18 -18
  153. package/src/router/index.js +8 -26
  154. package/src/store/getters.js +15 -15
  155. package/src/store/index.js +19 -19
  156. package/src/store/modules/app.js +54 -54
  157. package/src/store/modules/tab-content.js +36 -36
  158. package/src/store/modules/user.js +285 -285
  159. package/src/utils/auth.js +61 -61
  160. package/src/utils/calculator/calculator-factory-wf.js +558 -558
  161. package/src/utils/calculator/calculator-factory.js +145 -145
  162. package/src/utils/calculator/calculator-util.js +166 -166
  163. package/src/utils/eventBus.js +2 -2
  164. package/src/utils/iconUtils.js +28 -28
  165. package/src/utils/index.js +102 -102
  166. package/src/utils/jump-page-utils.js +824 -824
  167. package/src/utils/menu.js +19 -19
  168. package/src/utils/permission.js +31 -31
  169. package/src/utils/permissionAuth.js +96 -96
  170. package/src/utils/range-selector.js +188 -188
  171. package/src/utils/request.js +269 -269
  172. package/src/utils/restful-interface-utils.js +57 -57
  173. package/src/utils/util.js +703 -703
  174. package/src/utils/validate.js +34 -34
  175. package/src/utils/watermark.js +108 -108
  176. package/src/utils/workflow-util.js +93 -93
  177. package/src/views/404.vue +248 -248
  178. package/src/views/dsc-component/Sidebar/Item.vue +84 -84
  179. package/src/views/dsc-component/Sidebar/Link.vue +38 -38
  180. package/src/views/dsc-component/Sidebar/SidebarItem.vue +198 -198
  181. package/src/views/dsc-component/Sidebar/index.vue +229 -229
  182. package/src/views/dsc-component/tabs/tab-content.vue +203 -203
  183. package/src/views/error-page/401.vue +106 -106
  184. package/src/views/error-page/404.vue +248 -248
  185. package/src/views/layout/EmptyLayout.vue +3 -3
  186. package/src/views/layout/Layout.vue +81 -81
  187. package/src/views/layout/NewLayout.vue +18 -18
  188. package/src/views/layout/components/AppMain.vue +39 -39
  189. package/src/views/layout/components/Breadcrumb/index.vue +158 -158
  190. package/src/views/layout/components/Menubar/Item.vue +79 -79
  191. package/src/views/layout/components/Menubar/Link.vue +38 -38
  192. package/src/views/layout/components/Menubar/index.vue +210 -210
  193. package/src/views/layout/components/Sidebar/Item.vue +53 -53
  194. package/src/views/layout/components/Sidebar/Link.vue +38 -38
  195. package/src/views/layout/components/Sidebar/index.vue +141 -141
  196. package/src/views/layout/components/iframe-page.vue +38 -38
  197. package/src/views/layout/components/index.js +4 -4
  198. package/src/views/layout/components/tabs/tab-content.vue +207 -207
  199. package/src/views/layout/mixin/ResizeHandler.js +41 -41
  200. package/src/views/layout/tab-content-iframe-index.vue +38 -38
  201. package/src/views/layout/tab-content-index.vue +93 -93
  202. package/src/views/login/authredirect.vue +10 -10
  203. package/src/views/login/index.vue +296 -296
  204. package/src/views/login/update-password.vue +243 -243
  205. package/src/views/redirect/index.vue +14 -14
  206. package/src/views/wf-history/tache-subprocess-history.vue +45 -45
@@ -1,583 +1,583 @@
1
- <template>
2
- <span style="width: 100%">
3
- <template v-if="disabled">
4
- <el-input
5
- :model-value="value"
6
- type="text"
7
- :size="size"
8
- :readonly="true"
9
- :disabled="true"
10
- >
11
- <template v-slot:append>
12
- <el-icon v-slot:suffix class="el-input__icon"><el-icon-search /></el-icon>
13
- <el-icon v-slot:suffix class="el-input__icon"><el-icon-delete /></el-icon>
14
- </template>
15
- </el-input>
16
- </template>
17
- <template v-else>
18
- <el-input
19
- :model-value="value"
20
- type="text"
21
- :size="size"
22
- :readonly="true"
23
- @focus="showOrganizationTree(false)"
24
- >
25
- <template v-slot:append>
26
- <el-icon class="el-input__icon" @click="showOrganizationTree(false)"><el-icon-search /></el-icon>
27
- <el-icon class="el-input__icon" @click="emptyOrganizationResult()"><el-icon-delete /></el-icon>
28
- </template>
29
- </el-input>
30
- </template>
31
- <!-- 部门人员树 -->
32
- <department-user-tree
33
- v-if="treeType && treeType === 'DeptUserTree' && showOrganizationTreeFlag"
34
- :multiple="typeof multiple === 'undefined' ? false : multiple"
35
- :department-info="departmentInfo"
36
- :select-user-info="selectOrganizationInfo"
37
- :search-field="searchField"
38
- :separator="separator"
39
- @close="closeOrganizationTree"
40
- />
41
- <!-- 部门树 -->
42
- <department-tree
43
- v-if="treeType && treeType === 'DeptTree' && showOrganizationTreeFlag"
44
- width="30%"
45
- :check-strictly="
46
- typeof checkStrictly === 'undefined' ? false : checkStrictly
47
- "
48
- :multiple="typeof multiple === 'undefined' ? false : multiple"
49
- :select-department-info="selectOrganizationInfo"
50
- :search-field="searchField"
51
- :separator="separator"
52
- @close="closeOrganizationTree"
53
- />
54
- <!-- 工作组树 -->
55
- <workgroup-tree
56
- v-if="treeType && treeType === 'WgTree' && showOrganizationTreeFlag"
57
- width="30%"
58
- :multiple="typeof multiple === 'undefined' ? false : multiple"
59
- :select-workgroup-info="selectOrganizationInfo"
60
- :search-field="searchField"
61
- :separator="separator"
62
- @close="closeOrganizationTree"
63
- />
64
- <!-- 工作组人员树 -->
65
- <workgroup-user-tree
66
- v-if="treeType && treeType === 'WgUserTree' && showOrganizationTreeFlag"
67
- width="30%"
68
- :multiple="typeof multiple === 'undefined' ? false : multiple"
69
- :branch-info="departmentInfo"
70
- :select-user-info="selectOrganizationInfo"
71
- :search-field="searchField"
72
- :separator="separator"
73
- @close="closeOrganizationTree"
74
- />
75
- <!-- <remove-user
76
- v-if="treeType && (treeType === 'DeptUserTree' || treeType === 'WgUserTree') && showRemoveComponent"
77
- :select-user-info="selectOrganizationInfo"
78
- :search-field="searchField"
79
- :separator="separator"
80
- @close="closeRemoveComponent"
81
- />
82
- <remove-department
83
- v-if="treeType && treeType === 'DeptTree' && showRemoveComponent"
84
- :select-department-info="selectOrganizationInfo"
85
- :search-field="searchField"
86
- :separator="separator"
87
- @close="closeRemoveComponent"
88
- /> -->
89
- <!-- <remove-workgroup
90
- v-if="treeType && treeType === 'WgTree' && showRemoveComponent"
91
- :select-workgroup-info="selectOrganizationInfo"
92
- :search-field="searchField"
93
- :separator="separator"
94
- @close="closeRemoveComponent"
95
- /> -->
96
- </span>
97
- </template>
98
-
99
- <script>
100
- import {
101
- Search as ElIconSearch,
102
- Delete as ElIconDelete,
103
- } from '@element-plus/icons-vue'
104
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
105
- // import Vue from 'vue'
106
- import {
107
- getPropNameWhenJoinTable,
108
- setEntityFieldValue,
109
- } from '../../../src/utils/util'
110
- export default {
111
- components: {
112
- ElIconSearch,
113
- ElIconDelete,
114
- },
115
- name: 'OrganizationInput',
116
- model: {
117
- prop: 'value',
118
- event: 'input',
119
- },
120
- props: {
121
- value: {
122
- type: String,
123
- default: '',
124
- },
125
- // 是否多选
126
- multiple: {
127
- type: Boolean,
128
- default: false,
129
- },
130
- // 是否 “不选中” 子部门
131
- checkStrictly: {
132
- type: Boolean,
133
- default: false,
134
- },
135
- // 树类型 部门人员树DeptUserTree、部门树DeptTree、工作组树WgTree、工作组人员树WgUserTree
136
- treeType: {
137
- type: String,
138
- default: 'DeptUserTree',
139
- },
140
- // 是否禁用
141
- disabled: {
142
- type: Boolean,
143
- default: false,
144
- },
145
- // 字段与组织结构对应信息集合,格式为:[{type:'loginName',model:'字段名'}]
146
- // 人员树时,type的可选值有:id、name、loginName、email、telephone、mainDeptName、mainDeptId、subCompanyName、subCompanyId
147
- // 部门/工作组树时:type的可选值有:id、name、code
148
- fields: {
149
- type: Array,
150
- default: null,
151
- },
152
- // 当前表单数据信息
153
- models: {
154
- type: Object,
155
- default: null,
156
- },
157
- // 文本框大小large/medium/small/mini
158
- size: {
159
- type: String,
160
- default: '',
161
- },
162
- // 列表组件行编辑使用,sql查询时数据表名称,用于自定义系统中列表组件中字段多表查询带有别名时,将点"."改成两个下划线"__"时使用
163
- tableName: {
164
- type: String,
165
- default: null,
166
- },
167
- // 列表组件行编辑使用,是否是关联表,用于确定属性名是否需要拼接tableName
168
- isJoinTable: {
169
- type: Boolean,
170
- default: false,
171
- },
172
- // 指定部门或者工作组
173
- departmentInfo: {
174
- type: Array,
175
- default: null,
176
- },
177
- // 多选树时结果之间的分隔符,默认是逗号分隔
178
- separator: {
179
- type: String,
180
- default: ',',
181
- },
182
- },
183
- data() {
184
- return {
185
- showOrganizationTreeFlag: false, // 选择组织树所用
186
- isAppendResult: false, // 是否添加用户、部门、工作组,默认是替换,false表示替换选择的结果,true表示追加选择的结果
187
- showRemoveComponent: false, // 实现显示移除用户、部门、工作组组件
188
- selectOrganizationInfo: null, // 已选择集合,多个信息之间以逗号隔开
189
- searchField: null, // 已选的集合是什么内容,id、loginName(登录名)、name(用户名称/部门名称/工作组名称)、code(部门编码/工作组编码)、email(邮箱)、telephone(电话)等等
190
- selectOrganizationAllInfo: {}, // 选择的所有信息,{id:'xx',name:'xx',loginName:'xx',code:'xx',email:'xx',telephone:'xx'}
191
- }
192
- },
193
- created() {},
194
- methods: {
195
- // 打开组织树
196
- showOrganizationTree() {
197
- let isMulti = this.multiple
198
- if (typeof isMulti === 'undefined') {
199
- isMulti = false
200
- }
201
- if (isMulti === true) {
202
- // 多选时才需要显示结果集合
203
- this.getSelectInfo()
204
- }
205
- $emit(this, 'focus')
206
- this.showOrganizationTreeFlag = true
207
- },
208
- getPropName(prop, isJoinTable, tableName) {
209
- return getPropNameWhenJoinTable(prop, isJoinTable, tableName)
210
- },
211
- // 清空已选的结果
212
- emptyOrganizationResult() {
213
- const orgFields = this.fields
214
- if (orgFields && orgFields.length > 0) {
215
- orgFields.forEach((orgField) => {
216
- // orgDataType的值:
217
- // 人员时:id、name、loginName、email、telephone
218
- // 部门或工作组时:id、name
219
- const model = this.getPropName(orgField.model)
220
- this.setValue(model, null)
221
- })
222
- this.selectOrganizationAllInfo = {}
223
- this.selectOrganizationInfo = null
224
- this.searchField = null
225
- }
226
- },
227
- // 关闭组织树
228
- closeOrganizationTree(selectNodeInfo) {
229
- if (selectNodeInfo) {
230
- // 是否是多选树
231
- this.setOrganizationData(selectNodeInfo)
232
- }
233
- this.showOrganizationTreeFlag = false
234
- },
235
- setOrganizationData(orgData, isRemove, removeItems) {
236
- let isMulti = this.multiple
237
- if (typeof isMulti === 'undefined') {
238
- isMulti = false
239
- }
240
- const treeType = this.treeType
241
- const orgFields = this.fields
242
- if (orgFields && orgFields.length > 0) {
243
- orgFields.forEach((orgField) => {
244
- // orgDataType的值:
245
- // 人员时:id、name、loginName、email、telephone
246
- // 部门或工作组时:id、name、code
247
- const orgDataType = orgField.type
248
- const orgSelectData = this.getOrgSelectData(
249
- orgDataType,
250
- orgData,
251
- this.isUserTree(treeType),
252
- isMulti
253
- )
254
- const model = this.getPropName(orgField.model)
255
- this.getOrgDataModel(
256
- model,
257
- orgSelectData,
258
- isMulti,
259
- orgDataType,
260
- isRemove,
261
- removeItems
262
- )
263
- })
264
- }
265
- },
266
- /**
267
- * @param orgDataType 字段属性:id、name、loginName、code、email、telephone
268
- */
269
- getOrgDataModel(
270
- model,
271
- orgSelectData,
272
- isMulti,
273
- orgDataType,
274
- isRemove,
275
- removeItems
276
- ) {
277
- if (isMulti) {
278
- // 表示是替换或添加操作
279
- const orgResult = this.getModelValue(model)
280
- // 表示替换结果
281
- this.selectOrganizationAllInfo[orgDataType] = orgSelectData
282
- this.setValue(model, orgSelectData)
283
- // 参数分别为:属性名、原来的值、新替换的值
284
- $emit(this, 'replace', model, orgResult, orgSelectData)
285
- } else {
286
- this.setValue(model, orgSelectData)
287
- }
288
- },
289
- getModelValue(model) {
290
- let modelValue = ''
291
- if (this.isJoinTable === false && model && model.indexOf('.') > 0) {
292
- const parentObj = this.getParentObject(model, this.models)
293
- modelValue = parentObj[model.substring(model.lastIndexOf('.') + 1)]
294
- } else {
295
- model = this.getPropName(model)
296
- modelValue = this.models[model]
297
- }
298
- return modelValue
299
- },
300
- // 是否是人员树
301
- isUserTree(treeType) {
302
- return treeType === 'DeptUserTree' || treeType === 'WgUserTree'
303
- },
304
- // 获得组织树选择的结果
305
- getOrgSelectData(orgDataType, selectNodeInfo, isUserTree, isMulti) {
306
- if (isMulti === true) {
307
- // 多选树时
308
- if (orgDataType === 'id') {
309
- if (isUserTree) {
310
- return selectNodeInfo.userIds.join(this.separator)
311
- } else {
312
- return selectNodeInfo.ids.join(this.separator)
313
- }
314
- } else if (orgDataType === 'name') {
315
- if (isUserTree) {
316
- return selectNodeInfo.userNames.join(this.separator)
317
- } else {
318
- return selectNodeInfo.names.join(this.separator)
319
- }
320
- } else if (orgDataType === 'code') {
321
- if (!isUserTree) {
322
- return selectNodeInfo.codes.join(this.separator)
323
- }
324
- } else if (orgDataType === 'loginName') {
325
- return selectNodeInfo.loginNames.join(this.separator)
326
- } else if (orgDataType === 'email') {
327
- return selectNodeInfo.emails.join(this.separator)
328
- } else if (orgDataType === 'telephone') {
329
- return selectNodeInfo.telephones.join(this.separator)
330
- } else if (orgDataType === 'mainDeptName') {
331
- // 正职部门名称
332
- const mainDeptNames = []
333
- if (isUserTree) {
334
- const users = selectNodeInfo.users
335
- if (users) {
336
- users.forEach((user) => {
337
- mainDeptNames.push(user.mainDepartmentName)
338
- })
339
- }
340
- }
341
- return mainDeptNames.join(this.separator)
342
- } else if (orgDataType === 'mainDeptId') {
343
- // 正职部门id
344
- const mainDeptIds = []
345
- if (isUserTree) {
346
- const users = selectNodeInfo.users
347
- if (users) {
348
- users.forEach((user) => {
349
- if (user.mainDepartmentId) {
350
- mainDeptIds.push(user.mainDepartmentId)
351
- }
352
- })
353
- }
354
- }
355
- return mainDeptIds.join(this.separator)
356
- } else if (orgDataType === 'mainDeptCode') {
357
- // 正职部门code
358
- const mainDeptCodes = []
359
- if (isUserTree) {
360
- const users = selectNodeInfo.users
361
- if (users) {
362
- users.forEach((user) => {
363
- if (user.mainDepartmentCode) {
364
- mainDeptCodes.push(user.mainDepartmentCode)
365
- }
366
- })
367
- }
368
- }
369
- return mainDeptCodes.join(this.separator)
370
- } else if (orgDataType === 'subCompanyName') {
371
- // 分支名称
372
- const branchNames = []
373
- if (isUserTree) {
374
- const users = selectNodeInfo.users
375
- if (users) {
376
- users.forEach((user) => {
377
- if (user.subCompanyName) {
378
- branchNames.push(user.subCompanyName)
379
- }
380
- })
381
- }
382
- }
383
- return branchNames.join(this.separator)
384
- } else if (orgDataType === 'subCompanyId') {
385
- // 分支id
386
- const branchDeptIds = []
387
- if (isUserTree) {
388
- const users = selectNodeInfo.users
389
- if (users) {
390
- users.forEach((user) => {
391
- if (user.subCompanyId) {
392
- branchDeptIds.push(user.subCompanyId)
393
- }
394
- })
395
- }
396
- }
397
- return branchDeptIds.join(this.separator)
398
- }
399
- } else {
400
- // 单选树时
401
- if (orgDataType === 'mainDeptName') {
402
- // 正职部门名称
403
- let mainDeptName = null
404
- if (isUserTree) {
405
- const user = selectNodeInfo.user
406
- if (user) {
407
- mainDeptName = user.mainDepartmentName
408
- }
409
- }
410
- return mainDeptName
411
- } else if (orgDataType === 'mainDeptId') {
412
- // 正职部门id
413
- let mainDeptId = null
414
- if (isUserTree) {
415
- const user = selectNodeInfo.user
416
- if (user) {
417
- mainDeptId = user.mainDepartmentId
418
- }
419
- }
420
- return mainDeptId
421
- } else if (orgDataType === 'mainDeptCode') {
422
- // 正职部门code
423
- let mainDeptCode = null
424
- if (isUserTree) {
425
- const user = selectNodeInfo.user
426
- if (user) {
427
- mainDeptCode = user.mainDepartmentCode
428
- }
429
- }
430
- return mainDeptCode
431
- } else if (orgDataType === 'subCompanyName') {
432
- // 分支名称
433
- let branchName = null
434
- if (isUserTree) {
435
- const user = selectNodeInfo.user
436
- if (user) {
437
- branchName = user.subCompanyName
438
- }
439
- }
440
- return branchName
441
- } else if (orgDataType === 'subCompanyId') {
442
- // 分支id
443
- let branchId = null
444
- if (isUserTree) {
445
- const user = selectNodeInfo.user
446
- if (user) {
447
- branchId = user.subCompanyId
448
- }
449
- }
450
- return branchId
451
- } else {
452
- return selectNodeInfo[orgDataType]
453
- }
454
- }
455
- },
456
- // 显示移除用户、部门、工作组组件
457
- showMyRemoveComponent() {
458
- this.getSelectInfo()
459
- if (
460
- !this.selectOrganizationInfo ||
461
- this.selectOrganizationInfo === null ||
462
- this.selectOrganizationInfo === ''
463
- ) {
464
- this.$message({
465
- showClose: true,
466
- type: 'warning',
467
- message: this.$t(
468
- 'imatrixUIMessage.organizationTreeNoResultNotRemove'
469
- ),
470
- })
471
- } else {
472
- this.showRemoveComponent = true
473
- }
474
- },
475
- getSelectInfo() {
476
- const searchFields = [
477
- 'id',
478
- 'code',
479
- 'loginName',
480
- 'email',
481
- 'telephone',
482
- 'name',
483
- ]
484
- const keys = Object.keys(this.selectOrganizationAllInfo)
485
- if (keys.length === 0) {
486
- // 表示是初始化时,从表单对象中获得信息
487
- for (let i = 0; i < searchFields.length; i++) {
488
- const prop = searchFields[i]
489
- const fieldSettings = this.fields.filter((field) => {
490
- return field.type === prop
491
- })
492
- if (fieldSettings && fieldSettings.length > 0) {
493
- const fieldSetting = fieldSettings[0]
494
- if (fieldSetting) {
495
- const model = this.getPropName(fieldSetting.model)
496
- const selectInfo = this.getModelValue(model)
497
- if (selectInfo && selectInfo !== null && selectInfo !== '') {
498
- this.selectOrganizationInfo = selectInfo
499
- this.searchField = prop
500
- break
501
- }
502
- }
503
- }
504
- }
505
- } else {
506
- // 表示是选择用户后
507
- for (let i = 0; i < searchFields.length; i++) {
508
- const prop = searchFields[i]
509
- const selectInfo = this.selectOrganizationAllInfo[prop]
510
- if (selectInfo && selectInfo !== null && selectInfo !== '') {
511
- this.selectOrganizationInfo = selectInfo
512
- this.searchField = prop
513
- break
514
- }
515
- }
516
- }
517
- },
518
- setValue(model, finallyOrgResult) {
519
- if (this.models) {
520
- if (this.isJoinTable === false && model && model.indexOf('.') > 0) {
521
- const parentObj = this.getParentObject(model, this.models)
522
- if (parentObj) {
523
- setEntityFieldValue(
524
- parentObj,
525
- model.substring(model.lastIndexOf('.') + 1),
526
- finallyOrgResult
527
- )
528
- // Vue.set(parentObj, model.substring(model.lastIndexOf('.') + 1), finallyOrgResult)
529
- }
530
- } else {
531
- model = this.getPropName(model)
532
- setEntityFieldValue(this.models, model, finallyOrgResult)
533
- // Vue.set(this.models, model, finallyOrgResult)
534
- }
535
- console.log('this.value', this.models)
536
- // 调用setValue事件
537
- $emit(this, 'setValue', model, finallyOrgResult)
538
- if (
539
- finallyOrgResult === undefined ||
540
- finallyOrgResult === null ||
541
- finallyOrgResult === ''
542
- ) {
543
- $emit(this, 'clear', model)
544
- }
545
- }
546
- },
547
- getParentObject(prop, models) {
548
- const nestedProp = prop.split('.')
549
- // 属性只有一个时父对象就是models
550
- if (nestedProp.length === 1) {
551
- return models
552
- } else {
553
- let parentObject
554
- // 属性超过2个时先找到最后一层属性的父对象
555
- for (let i = 0; i < nestedProp.length - 1; i++) {
556
- if (i === 0) {
557
- parentObject = this.getParentModelProp(nestedProp[i], models)
558
- } else {
559
- parentObject = this.getParentModelProp(nestedProp[i], parentObject)
560
- }
561
- }
562
- return parentObject
563
- }
564
- },
565
- getParentModelProp(prop, parentObj) {
566
- if (!parentObj) {
567
- parentObj = {}
568
- }
569
- if (!parentObj[prop]) {
570
- parentObj[prop] = {}
571
- }
572
- return parentObj[prop]
573
- },
574
- },
575
- emits: [
576
- 'replace',
577
- 'setValue',
578
- 'clear',
579
- 'focus',
580
- 'update:value',
581
- ],
582
- }
583
- </script>
1
+ <template>
2
+ <span style="width: 100%">
3
+ <template v-if="disabled">
4
+ <el-input
5
+ :model-value="value"
6
+ type="text"
7
+ :size="size"
8
+ :readonly="true"
9
+ :disabled="true"
10
+ >
11
+ <template v-slot:append>
12
+ <el-icon v-slot:suffix class="el-input__icon"><el-icon-search /></el-icon>
13
+ <el-icon v-slot:suffix class="el-input__icon"><el-icon-delete /></el-icon>
14
+ </template>
15
+ </el-input>
16
+ </template>
17
+ <template v-else>
18
+ <el-input
19
+ :model-value="value"
20
+ type="text"
21
+ :size="size"
22
+ :readonly="true"
23
+ @focus="showOrganizationTree(false)"
24
+ >
25
+ <template v-slot:append>
26
+ <el-icon class="el-input__icon" @click="showOrganizationTree(false)"><el-icon-search /></el-icon>
27
+ <el-icon class="el-input__icon" @click="emptyOrganizationResult()"><el-icon-delete /></el-icon>
28
+ </template>
29
+ </el-input>
30
+ </template>
31
+ <!-- 部门人员树 -->
32
+ <department-user-tree
33
+ v-if="treeType && treeType === 'DeptUserTree' && showOrganizationTreeFlag"
34
+ :multiple="typeof multiple === 'undefined' ? false : multiple"
35
+ :department-info="departmentInfo"
36
+ :select-user-info="selectOrganizationInfo"
37
+ :search-field="searchField"
38
+ :separator="separator"
39
+ @close="closeOrganizationTree"
40
+ />
41
+ <!-- 部门树 -->
42
+ <department-tree
43
+ v-if="treeType && treeType === 'DeptTree' && showOrganizationTreeFlag"
44
+ width="30%"
45
+ :check-strictly="
46
+ typeof checkStrictly === 'undefined' ? false : checkStrictly
47
+ "
48
+ :multiple="typeof multiple === 'undefined' ? false : multiple"
49
+ :select-department-info="selectOrganizationInfo"
50
+ :search-field="searchField"
51
+ :separator="separator"
52
+ @close="closeOrganizationTree"
53
+ />
54
+ <!-- 工作组树 -->
55
+ <workgroup-tree
56
+ v-if="treeType && treeType === 'WgTree' && showOrganizationTreeFlag"
57
+ width="30%"
58
+ :multiple="typeof multiple === 'undefined' ? false : multiple"
59
+ :select-workgroup-info="selectOrganizationInfo"
60
+ :search-field="searchField"
61
+ :separator="separator"
62
+ @close="closeOrganizationTree"
63
+ />
64
+ <!-- 工作组人员树 -->
65
+ <workgroup-user-tree
66
+ v-if="treeType && treeType === 'WgUserTree' && showOrganizationTreeFlag"
67
+ width="30%"
68
+ :multiple="typeof multiple === 'undefined' ? false : multiple"
69
+ :branch-info="departmentInfo"
70
+ :select-user-info="selectOrganizationInfo"
71
+ :search-field="searchField"
72
+ :separator="separator"
73
+ @close="closeOrganizationTree"
74
+ />
75
+ <!-- <remove-user
76
+ v-if="treeType && (treeType === 'DeptUserTree' || treeType === 'WgUserTree') && showRemoveComponent"
77
+ :select-user-info="selectOrganizationInfo"
78
+ :search-field="searchField"
79
+ :separator="separator"
80
+ @close="closeRemoveComponent"
81
+ />
82
+ <remove-department
83
+ v-if="treeType && treeType === 'DeptTree' && showRemoveComponent"
84
+ :select-department-info="selectOrganizationInfo"
85
+ :search-field="searchField"
86
+ :separator="separator"
87
+ @close="closeRemoveComponent"
88
+ /> -->
89
+ <!-- <remove-workgroup
90
+ v-if="treeType && treeType === 'WgTree' && showRemoveComponent"
91
+ :select-workgroup-info="selectOrganizationInfo"
92
+ :search-field="searchField"
93
+ :separator="separator"
94
+ @close="closeRemoveComponent"
95
+ /> -->
96
+ </span>
97
+ </template>
98
+
99
+ <script>
100
+ import {
101
+ Search as ElIconSearch,
102
+ Delete as ElIconDelete,
103
+ } from '@element-plus/icons-vue'
104
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
105
+ // import Vue from 'vue'
106
+ import {
107
+ getPropNameWhenJoinTable,
108
+ setEntityFieldValue,
109
+ } from '../../../src/utils/util'
110
+ export default {
111
+ components: {
112
+ ElIconSearch,
113
+ ElIconDelete,
114
+ },
115
+ name: 'OrganizationInput',
116
+ model: {
117
+ prop: 'value',
118
+ event: 'input',
119
+ },
120
+ props: {
121
+ value: {
122
+ type: String,
123
+ default: '',
124
+ },
125
+ // 是否多选
126
+ multiple: {
127
+ type: Boolean,
128
+ default: false,
129
+ },
130
+ // 是否 “不选中” 子部门
131
+ checkStrictly: {
132
+ type: Boolean,
133
+ default: false,
134
+ },
135
+ // 树类型 部门人员树DeptUserTree、部门树DeptTree、工作组树WgTree、工作组人员树WgUserTree
136
+ treeType: {
137
+ type: String,
138
+ default: 'DeptUserTree',
139
+ },
140
+ // 是否禁用
141
+ disabled: {
142
+ type: Boolean,
143
+ default: false,
144
+ },
145
+ // 字段与组织结构对应信息集合,格式为:[{type:'loginName',model:'字段名'}]
146
+ // 人员树时,type的可选值有:id、name、loginName、email、telephone、mainDeptName、mainDeptId、subCompanyName、subCompanyId
147
+ // 部门/工作组树时:type的可选值有:id、name、code
148
+ fields: {
149
+ type: Array,
150
+ default: null,
151
+ },
152
+ // 当前表单数据信息
153
+ models: {
154
+ type: Object,
155
+ default: null,
156
+ },
157
+ // 文本框大小large/medium/small/mini
158
+ size: {
159
+ type: String,
160
+ default: '',
161
+ },
162
+ // 列表组件行编辑使用,sql查询时数据表名称,用于自定义系统中列表组件中字段多表查询带有别名时,将点"."改成两个下划线"__"时使用
163
+ tableName: {
164
+ type: String,
165
+ default: null,
166
+ },
167
+ // 列表组件行编辑使用,是否是关联表,用于确定属性名是否需要拼接tableName
168
+ isJoinTable: {
169
+ type: Boolean,
170
+ default: false,
171
+ },
172
+ // 指定部门或者工作组
173
+ departmentInfo: {
174
+ type: Array,
175
+ default: null,
176
+ },
177
+ // 多选树时结果之间的分隔符,默认是逗号分隔
178
+ separator: {
179
+ type: String,
180
+ default: ',',
181
+ },
182
+ },
183
+ data() {
184
+ return {
185
+ showOrganizationTreeFlag: false, // 选择组织树所用
186
+ isAppendResult: false, // 是否添加用户、部门、工作组,默认是替换,false表示替换选择的结果,true表示追加选择的结果
187
+ showRemoveComponent: false, // 实现显示移除用户、部门、工作组组件
188
+ selectOrganizationInfo: null, // 已选择集合,多个信息之间以逗号隔开
189
+ searchField: null, // 已选的集合是什么内容,id、loginName(登录名)、name(用户名称/部门名称/工作组名称)、code(部门编码/工作组编码)、email(邮箱)、telephone(电话)等等
190
+ selectOrganizationAllInfo: {}, // 选择的所有信息,{id:'xx',name:'xx',loginName:'xx',code:'xx',email:'xx',telephone:'xx'}
191
+ }
192
+ },
193
+ created() {},
194
+ methods: {
195
+ // 打开组织树
196
+ showOrganizationTree() {
197
+ let isMulti = this.multiple
198
+ if (typeof isMulti === 'undefined') {
199
+ isMulti = false
200
+ }
201
+ if (isMulti === true) {
202
+ // 多选时才需要显示结果集合
203
+ this.getSelectInfo()
204
+ }
205
+ $emit(this, 'focus')
206
+ this.showOrganizationTreeFlag = true
207
+ },
208
+ getPropName(prop, isJoinTable, tableName) {
209
+ return getPropNameWhenJoinTable(prop, isJoinTable, tableName)
210
+ },
211
+ // 清空已选的结果
212
+ emptyOrganizationResult() {
213
+ const orgFields = this.fields
214
+ if (orgFields && orgFields.length > 0) {
215
+ orgFields.forEach((orgField) => {
216
+ // orgDataType的值:
217
+ // 人员时:id、name、loginName、email、telephone
218
+ // 部门或工作组时:id、name
219
+ const model = this.getPropName(orgField.model)
220
+ this.setValue(model, null)
221
+ })
222
+ this.selectOrganizationAllInfo = {}
223
+ this.selectOrganizationInfo = null
224
+ this.searchField = null
225
+ }
226
+ },
227
+ // 关闭组织树
228
+ closeOrganizationTree(selectNodeInfo) {
229
+ if (selectNodeInfo) {
230
+ // 是否是多选树
231
+ this.setOrganizationData(selectNodeInfo)
232
+ }
233
+ this.showOrganizationTreeFlag = false
234
+ },
235
+ setOrganizationData(orgData, isRemove, removeItems) {
236
+ let isMulti = this.multiple
237
+ if (typeof isMulti === 'undefined') {
238
+ isMulti = false
239
+ }
240
+ const treeType = this.treeType
241
+ const orgFields = this.fields
242
+ if (orgFields && orgFields.length > 0) {
243
+ orgFields.forEach((orgField) => {
244
+ // orgDataType的值:
245
+ // 人员时:id、name、loginName、email、telephone
246
+ // 部门或工作组时:id、name、code
247
+ const orgDataType = orgField.type
248
+ const orgSelectData = this.getOrgSelectData(
249
+ orgDataType,
250
+ orgData,
251
+ this.isUserTree(treeType),
252
+ isMulti
253
+ )
254
+ const model = this.getPropName(orgField.model)
255
+ this.getOrgDataModel(
256
+ model,
257
+ orgSelectData,
258
+ isMulti,
259
+ orgDataType,
260
+ isRemove,
261
+ removeItems
262
+ )
263
+ })
264
+ }
265
+ },
266
+ /**
267
+ * @param orgDataType 字段属性:id、name、loginName、code、email、telephone
268
+ */
269
+ getOrgDataModel(
270
+ model,
271
+ orgSelectData,
272
+ isMulti,
273
+ orgDataType,
274
+ isRemove,
275
+ removeItems
276
+ ) {
277
+ if (isMulti) {
278
+ // 表示是替换或添加操作
279
+ const orgResult = this.getModelValue(model)
280
+ // 表示替换结果
281
+ this.selectOrganizationAllInfo[orgDataType] = orgSelectData
282
+ this.setValue(model, orgSelectData)
283
+ // 参数分别为:属性名、原来的值、新替换的值
284
+ $emit(this, 'replace', model, orgResult, orgSelectData)
285
+ } else {
286
+ this.setValue(model, orgSelectData)
287
+ }
288
+ },
289
+ getModelValue(model) {
290
+ let modelValue = ''
291
+ if (this.isJoinTable === false && model && model.indexOf('.') > 0) {
292
+ const parentObj = this.getParentObject(model, this.models)
293
+ modelValue = parentObj[model.substring(model.lastIndexOf('.') + 1)]
294
+ } else {
295
+ model = this.getPropName(model)
296
+ modelValue = this.models[model]
297
+ }
298
+ return modelValue
299
+ },
300
+ // 是否是人员树
301
+ isUserTree(treeType) {
302
+ return treeType === 'DeptUserTree' || treeType === 'WgUserTree'
303
+ },
304
+ // 获得组织树选择的结果
305
+ getOrgSelectData(orgDataType, selectNodeInfo, isUserTree, isMulti) {
306
+ if (isMulti === true) {
307
+ // 多选树时
308
+ if (orgDataType === 'id') {
309
+ if (isUserTree) {
310
+ return selectNodeInfo.userIds.join(this.separator)
311
+ } else {
312
+ return selectNodeInfo.ids.join(this.separator)
313
+ }
314
+ } else if (orgDataType === 'name') {
315
+ if (isUserTree) {
316
+ return selectNodeInfo.userNames.join(this.separator)
317
+ } else {
318
+ return selectNodeInfo.names.join(this.separator)
319
+ }
320
+ } else if (orgDataType === 'code') {
321
+ if (!isUserTree) {
322
+ return selectNodeInfo.codes.join(this.separator)
323
+ }
324
+ } else if (orgDataType === 'loginName') {
325
+ return selectNodeInfo.loginNames.join(this.separator)
326
+ } else if (orgDataType === 'email') {
327
+ return selectNodeInfo.emails.join(this.separator)
328
+ } else if (orgDataType === 'telephone') {
329
+ return selectNodeInfo.telephones.join(this.separator)
330
+ } else if (orgDataType === 'mainDeptName') {
331
+ // 正职部门名称
332
+ const mainDeptNames = []
333
+ if (isUserTree) {
334
+ const users = selectNodeInfo.users
335
+ if (users) {
336
+ users.forEach((user) => {
337
+ mainDeptNames.push(user.mainDepartmentName)
338
+ })
339
+ }
340
+ }
341
+ return mainDeptNames.join(this.separator)
342
+ } else if (orgDataType === 'mainDeptId') {
343
+ // 正职部门id
344
+ const mainDeptIds = []
345
+ if (isUserTree) {
346
+ const users = selectNodeInfo.users
347
+ if (users) {
348
+ users.forEach((user) => {
349
+ if (user.mainDepartmentId) {
350
+ mainDeptIds.push(user.mainDepartmentId)
351
+ }
352
+ })
353
+ }
354
+ }
355
+ return mainDeptIds.join(this.separator)
356
+ } else if (orgDataType === 'mainDeptCode') {
357
+ // 正职部门code
358
+ const mainDeptCodes = []
359
+ if (isUserTree) {
360
+ const users = selectNodeInfo.users
361
+ if (users) {
362
+ users.forEach((user) => {
363
+ if (user.mainDepartmentCode) {
364
+ mainDeptCodes.push(user.mainDepartmentCode)
365
+ }
366
+ })
367
+ }
368
+ }
369
+ return mainDeptCodes.join(this.separator)
370
+ } else if (orgDataType === 'subCompanyName') {
371
+ // 分支名称
372
+ const branchNames = []
373
+ if (isUserTree) {
374
+ const users = selectNodeInfo.users
375
+ if (users) {
376
+ users.forEach((user) => {
377
+ if (user.subCompanyName) {
378
+ branchNames.push(user.subCompanyName)
379
+ }
380
+ })
381
+ }
382
+ }
383
+ return branchNames.join(this.separator)
384
+ } else if (orgDataType === 'subCompanyId') {
385
+ // 分支id
386
+ const branchDeptIds = []
387
+ if (isUserTree) {
388
+ const users = selectNodeInfo.users
389
+ if (users) {
390
+ users.forEach((user) => {
391
+ if (user.subCompanyId) {
392
+ branchDeptIds.push(user.subCompanyId)
393
+ }
394
+ })
395
+ }
396
+ }
397
+ return branchDeptIds.join(this.separator)
398
+ }
399
+ } else {
400
+ // 单选树时
401
+ if (orgDataType === 'mainDeptName') {
402
+ // 正职部门名称
403
+ let mainDeptName = null
404
+ if (isUserTree) {
405
+ const user = selectNodeInfo.user
406
+ if (user) {
407
+ mainDeptName = user.mainDepartmentName
408
+ }
409
+ }
410
+ return mainDeptName
411
+ } else if (orgDataType === 'mainDeptId') {
412
+ // 正职部门id
413
+ let mainDeptId = null
414
+ if (isUserTree) {
415
+ const user = selectNodeInfo.user
416
+ if (user) {
417
+ mainDeptId = user.mainDepartmentId
418
+ }
419
+ }
420
+ return mainDeptId
421
+ } else if (orgDataType === 'mainDeptCode') {
422
+ // 正职部门code
423
+ let mainDeptCode = null
424
+ if (isUserTree) {
425
+ const user = selectNodeInfo.user
426
+ if (user) {
427
+ mainDeptCode = user.mainDepartmentCode
428
+ }
429
+ }
430
+ return mainDeptCode
431
+ } else if (orgDataType === 'subCompanyName') {
432
+ // 分支名称
433
+ let branchName = null
434
+ if (isUserTree) {
435
+ const user = selectNodeInfo.user
436
+ if (user) {
437
+ branchName = user.subCompanyName
438
+ }
439
+ }
440
+ return branchName
441
+ } else if (orgDataType === 'subCompanyId') {
442
+ // 分支id
443
+ let branchId = null
444
+ if (isUserTree) {
445
+ const user = selectNodeInfo.user
446
+ if (user) {
447
+ branchId = user.subCompanyId
448
+ }
449
+ }
450
+ return branchId
451
+ } else {
452
+ return selectNodeInfo[orgDataType]
453
+ }
454
+ }
455
+ },
456
+ // 显示移除用户、部门、工作组组件
457
+ showMyRemoveComponent() {
458
+ this.getSelectInfo()
459
+ if (
460
+ !this.selectOrganizationInfo ||
461
+ this.selectOrganizationInfo === null ||
462
+ this.selectOrganizationInfo === ''
463
+ ) {
464
+ this.$message({
465
+ showClose: true,
466
+ type: 'warning',
467
+ message: this.$t(
468
+ 'imatrixUIMessage.organizationTreeNoResultNotRemove'
469
+ ),
470
+ })
471
+ } else {
472
+ this.showRemoveComponent = true
473
+ }
474
+ },
475
+ getSelectInfo() {
476
+ const searchFields = [
477
+ 'id',
478
+ 'code',
479
+ 'loginName',
480
+ 'email',
481
+ 'telephone',
482
+ 'name',
483
+ ]
484
+ const keys = Object.keys(this.selectOrganizationAllInfo)
485
+ if (keys.length === 0) {
486
+ // 表示是初始化时,从表单对象中获得信息
487
+ for (let i = 0; i < searchFields.length; i++) {
488
+ const prop = searchFields[i]
489
+ const fieldSettings = this.fields.filter((field) => {
490
+ return field.type === prop
491
+ })
492
+ if (fieldSettings && fieldSettings.length > 0) {
493
+ const fieldSetting = fieldSettings[0]
494
+ if (fieldSetting) {
495
+ const model = this.getPropName(fieldSetting.model)
496
+ const selectInfo = this.getModelValue(model)
497
+ if (selectInfo && selectInfo !== null && selectInfo !== '') {
498
+ this.selectOrganizationInfo = selectInfo
499
+ this.searchField = prop
500
+ break
501
+ }
502
+ }
503
+ }
504
+ }
505
+ } else {
506
+ // 表示是选择用户后
507
+ for (let i = 0; i < searchFields.length; i++) {
508
+ const prop = searchFields[i]
509
+ const selectInfo = this.selectOrganizationAllInfo[prop]
510
+ if (selectInfo && selectInfo !== null && selectInfo !== '') {
511
+ this.selectOrganizationInfo = selectInfo
512
+ this.searchField = prop
513
+ break
514
+ }
515
+ }
516
+ }
517
+ },
518
+ setValue(model, finallyOrgResult) {
519
+ if (this.models) {
520
+ if (this.isJoinTable === false && model && model.indexOf('.') > 0) {
521
+ const parentObj = this.getParentObject(model, this.models)
522
+ if (parentObj) {
523
+ setEntityFieldValue(
524
+ parentObj,
525
+ model.substring(model.lastIndexOf('.') + 1),
526
+ finallyOrgResult
527
+ )
528
+ // Vue.set(parentObj, model.substring(model.lastIndexOf('.') + 1), finallyOrgResult)
529
+ }
530
+ } else {
531
+ model = this.getPropName(model)
532
+ setEntityFieldValue(this.models, model, finallyOrgResult)
533
+ // Vue.set(this.models, model, finallyOrgResult)
534
+ }
535
+ console.log('this.value', this.models)
536
+ // 调用setValue事件
537
+ $emit(this, 'setValue', model, finallyOrgResult)
538
+ if (
539
+ finallyOrgResult === undefined ||
540
+ finallyOrgResult === null ||
541
+ finallyOrgResult === ''
542
+ ) {
543
+ $emit(this, 'clear', model)
544
+ }
545
+ }
546
+ },
547
+ getParentObject(prop, models) {
548
+ const nestedProp = prop.split('.')
549
+ // 属性只有一个时父对象就是models
550
+ if (nestedProp.length === 1) {
551
+ return models
552
+ } else {
553
+ let parentObject
554
+ // 属性超过2个时先找到最后一层属性的父对象
555
+ for (let i = 0; i < nestedProp.length - 1; i++) {
556
+ if (i === 0) {
557
+ parentObject = this.getParentModelProp(nestedProp[i], models)
558
+ } else {
559
+ parentObject = this.getParentModelProp(nestedProp[i], parentObject)
560
+ }
561
+ }
562
+ return parentObject
563
+ }
564
+ },
565
+ getParentModelProp(prop, parentObj) {
566
+ if (!parentObj) {
567
+ parentObj = {}
568
+ }
569
+ if (!parentObj[prop]) {
570
+ parentObj[prop] = {}
571
+ }
572
+ return parentObj[prop]
573
+ },
574
+ },
575
+ emits: [
576
+ 'replace',
577
+ 'setValue',
578
+ 'clear',
579
+ 'focus',
580
+ 'update:value',
581
+ ],
582
+ }
583
+ </script>