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,344 +1,344 @@
1
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
2
- import * as Vue from 'vue'
3
- import { getI18n } from '../../../src/utils/util'
4
- const departmentTreeService = {
5
- // 后台查询部门,并拼接树节点
6
- filterAppendNodes(value) {
7
- this.$http
8
- .post(
9
- window.$vueApp.config.globalProperties.baseAPI +
10
- '/component/organization-trees/search-pc-depts',
11
- this.searchParam
12
- )
13
- .then((result) => {
14
- if (result) {
15
- if (result.length === 0) {
16
- this.searchResult = []
17
- this.$message({
18
- showClose: true,
19
- type: 'error',
20
- message: getI18n().t('imatrixUIMessage.queryResultIsEmpty'),
21
- })
22
- return
23
- }
24
- this.searchResult = result
25
- // result的格式为[DEPARTMENT~1,DEPARTMENT~1/DEPARTMENT~4,DEPARTMENT~10]
26
- // result.forEach(nodeIds => {
27
- // // nodeId的分隔符
28
- // var nodeIdSeparator = '/'
29
- // const nodeIdArr = nodeIds.split(nodeIdSeparator)
30
- // if (nodeIdArr.length > 0) {
31
- // this.loadDepartmentWhenSearch(0, nodeIdArr)
32
- // }
33
- // })
34
- } else {
35
- this.$message({
36
- showClose: true,
37
- type: 'error',
38
- message: getI18n().t('imatrixUIMessage.queryResultIsEmpty'),
39
- })
40
- }
41
- })
42
- },
43
- search(value) {
44
- this.searchValue = value
45
- let mySearchValue = value
46
- if (mySearchValue) {
47
- mySearchValue = mySearchValue.trim()
48
- }
49
- this.searchParam.searchValue = mySearchValue
50
- this.searchParam.departmentInfo = this.departmentInfo
51
- // 后台查询部门,并拼接树节点
52
- this.filterAppendNodes(value)
53
- },
54
- handleSelect(item) {
55
- // this.handleSelectUtil(item, localStorage)
56
- // 查询最新部门信息替换,缓存为历史数据 数据库可能发生变化
57
- this.$http
58
- .get(
59
- window.$vueApp.config.globalProperties.baseAPI +
60
- '/api/departments?departmentCode=' +
61
- item.code
62
- )
63
- .then((departmentDTO) => {
64
- if (departmentDTO !== null) {
65
- for (const dtoKey in departmentDTO) {
66
- if (item.hasOwnProperty(dtoKey)) {
67
- item[dtoKey] = departmentDTO[dtoKey]
68
- }
69
- }
70
- }
71
- this.filterText = ''
72
- this.searchValue = ''
73
- this.setMemoryCacheData(item, 'department')
74
- if (this.multiple) {
75
- const index = this.selectResult.findIndex(
76
- (selectEntity) => selectEntity.code === item.code
77
- )
78
- if (index < 0) {
79
- this.selectResult.push(item)
80
- }
81
- } else {
82
- this.packageSelectResult(item)
83
- // 关闭弹窗
84
- $emit(this, 'result', this.selectNodeInfo)
85
- }
86
- })
87
- },
88
- querySearch(queryString, cb) {
89
- if (!this.filterText && this.filterText.length === 0) {
90
- this.memorySearch(queryString, cb)
91
- } else {
92
- this.search(this.filterText)
93
- cb([])
94
- }
95
- },
96
- // 点击查询按钮调用的方法
97
- clickSearch() {
98
- this.storeSeachValue()
99
- this.search(this.filterText)
100
- },
101
- loadDepartmentWhenSearch(n, nodeIdArr) {
102
- return new Promise((resolve, reject) => {
103
- if (nodeIdArr.length === n) {
104
- resolve()
105
- } else {
106
- const nodeId = nodeIdArr[n]
107
- let dataId = nodeId
108
- // 节点类型和数据id的分隔符
109
- const nodeTypeAndDataIdSeparator = '~'
110
- // nodeId格式为DEPARTMENT~4
111
- if (nodeId.indexOf(nodeTypeAndDataIdSeparator) > -1) {
112
- dataId = nodeId.substring(nodeId.indexOf('~') + 1)
113
- }
114
- this.loadDepartment(dataId)
115
- .then(() => {
116
- this.loadDepartmentWhenSearch(++n, nodeIdArr)
117
- })
118
- .catch((error) => {
119
- reject(error)
120
- })
121
- }
122
- })
123
- },
124
- // 点击复选框时处理
125
- handleCheckNode(data, checkObj) {
126
- if (checkObj.checkedKeys.indexOf(data.id) > -1) {
127
- // 表示正选中data节点
128
- this.isloading = true
129
- if (data.nodeType && data.nodeType === 'DEPARTMENT' && data.data) {
130
- // 表示当前选中的节点是部门
131
- const department = JSON.parse(data.data)
132
- this.selectUser(null, department)
133
- }
134
- if (data.childDepartments) {
135
- // 如果已展开,不需要再走后台获得其子节点。只需要选中已有子节点
136
- // 展开当前选中的节点
137
- this.$refs.deparmentTree.store.nodesMap[data.id].expanded = true
138
- // 选中当前节点及其子节点
139
- this.checkedNodeAndChildren(data)
140
- this.isloading = false
141
- } else {
142
- // 当前节点未展开。需要走后台获得当前节点的子节点,然后展开当前节点,然后选中这些子节点
143
- if (!data.leaf) {
144
- // 不是叶子节点,并且没有加载过该父节点的子节点时,需要走后台展开子节点
145
- this.$http
146
- .get(
147
- window.$vueApp.config.globalProperties.baseAPI +
148
- '/component/organization-trees/departments/' +
149
- data.id
150
- )
151
- .then((result) => {
152
- // 更新当前点击的节点的子节点
153
- this.$refs.deparmentTree.updateKeyChildren(data.id, result)
154
- // 展开当前选中的节点
155
- this.$refs.deparmentTree.store.nodesMap[data.id].expanded = true
156
- // 获得所有应该选中的节点
157
- this.checkedNodeAndChildren(data)
158
- })
159
- this.$http
160
- .get(
161
- window.$vueApp.config.globalProperties.baseAPI +
162
- '/component/organization-trees/child-departments/' +
163
- data.id
164
- )
165
- .then((childDepts) => {
166
- if (childDepts && !this.checkStrictly) {
167
- childDepts.forEach((item) => {
168
- this.selectUser(null, item)
169
- })
170
- this.isloading = false
171
- }
172
- })
173
- } else {
174
- // 如果是叶子节点则不需要loading状态
175
- this.isloading = false
176
- }
177
- }
178
- } else {
179
- // 表示正取消选中data节点,同时要取消其子节点的选中状态
180
- this.cancelChildCheckedNodes(data)
181
- }
182
- },
183
- // 初始化树 或 点击三角展开节点时动态加载子节点
184
- loadNode(node, resolve) {
185
- var parentId = 0
186
- if (node.level === 0) {
187
- // 表示初始化树
188
- parentId = 0
189
- } else {
190
- parentId = node.data.id
191
- }
192
- var checkedKeys = []
193
- if (this.$refs.deparmentTree) {
194
- checkedKeys = this.$refs.deparmentTree.getCheckedKeys()
195
- }
196
- // 初始化部门树
197
- this.initLoadDepartment(parentId, node, resolve, checkedKeys)
198
- },
199
- // 初始化部门树
200
- initLoadDepartment(parentId, node, resolve, checkedKeys) {
201
- this.$http
202
- .get(
203
- window.$vueApp.config.globalProperties.baseAPI +
204
- '/component/organization-trees/departments/' +
205
- parentId
206
- )
207
- .then((data) => {
208
- resolve(data)
209
- // 更新当前点击的节点的子节点
210
- this.$refs.deparmentTree.updateKeyChildren(parentId, data)
211
- if (parentId === 0) {
212
- // 初始化树时,展开公司节点
213
- const tenantData = data[0].data
214
- data[0].disable = true
215
- this.tenantInfo = JSON.parse(tenantData)
216
- this.containBranch = data[0].containBranch
217
- if (this.departmentInfo && this.departmentInfo.length > 0) {
218
- // 加载指定部门时,展开公司节点
219
- this.loadPointDepartments()
220
- } else {
221
- // 加载整个组织结构树时,展开公司节点
222
- this.loadDepartment(this.tenantNodeId)
223
- }
224
- }
225
-
226
- if (this.isClickNode) {
227
- // 点击当前节点时,加载树节点时
228
- // 注意不是点击复选框时
229
- this.isClickNode = false
230
- this.checkedNodeAndChildren(node.data)
231
- } else {
232
- // 表示是点击三角展开节点时
233
- if (checkedKeys && checkedKeys.indexOf(parentId) > -1) {
234
- // 点击部门名称前的三角标识展开节点时,保持当前节点的选中状态
235
- // 表示当前展开的节点是选中状态,则应保持其选中状态,并选中其子节点
236
- this.checkedNodeAndChildren(node.data)
237
- }
238
- }
239
- })
240
- },
241
- // 加载当前节点的子节点
242
- loadDepartment(parentId, isSearch, searchValue) {
243
- return new Promise((resolve, reject) => {
244
- this.$http
245
- .get(
246
- window.$vueApp.config.globalProperties.baseAPI +
247
- '/component/organization-trees/departments/' +
248
- parentId
249
- )
250
- .then((children) => {
251
- this.$refs.deparmentTree.updateKeyChildren(parentId, children)
252
- if (this.$refs.deparmentTree.store.nodesMap[parentId]) {
253
- this.$refs.deparmentTree.store.nodesMap[parentId].expanded = true
254
- }
255
- resolve()
256
- })
257
- .catch((error) => {
258
- console.log('error', error)
259
- })
260
- })
261
- },
262
- // 加载指定部门节点
263
- loadPointDepartments() {
264
- this.$http
265
- .post(
266
- window.$vueApp.config.globalProperties.baseAPI +
267
- '/component/organization-trees/point-departments',
268
- this.departmentInfo
269
- )
270
- .then((children) => {
271
- this.$refs.deparmentTree.updateKeyChildren(this.tenantNodeId, children)
272
- if (this.$refs.deparmentTree.store.nodesMap[this.tenantNodeId]) {
273
- this.$refs.deparmentTree.store.nodesMap[this.tenantNodeId].expanded =
274
- true
275
- }
276
- })
277
- },
278
- getSelectDepts(searchField, selectDeptInfo, separator) {
279
- return new Promise((resolve, reject) => {
280
- if (!searchField) {
281
- resolve([])
282
- } else if (!selectDeptInfo) {
283
- resolve([])
284
- } else {
285
- this.$http
286
- .get(
287
- window.$vueApp.config.globalProperties.baseAPI +
288
- '/component/organization-trees/select-departments?searchField=' +
289
- searchField +
290
- '&selectDeptInfo=' +
291
- selectDeptInfo +
292
- '&separator=' +
293
- separator
294
- )
295
- .then((departments) => {
296
- resolve(departments)
297
- })
298
- .catch((error) => {
299
- reject(error)
300
- })
301
- }
302
- })
303
- },
304
- // 选中了组织结构树的根节点
305
- packageAllDept() {
306
- // 表示集合中不存在该用户,则封装该用户
307
- var allDept = {
308
- id: this.tenantNodeId,
309
- name: '所有部门',
310
- }
311
- return allDept
312
- },
313
- initSelectDepts() {
314
- return new Promise((resolve, reject) => {
315
- const selectDepts = []
316
- if (this.selectDepartmentInfo) {
317
- if (
318
- this.selectDepartmentInfo === this.tenantNodeId ||
319
- this.selectDepartmentInfo === '所有部门'
320
- ) {
321
- // 表示已选择所有用户
322
- selectDepts.push(this.packageAllDept())
323
- resolve(selectDepts)
324
- } else {
325
- // 表示不是选择的所有用户
326
- this.getSelectDepts(
327
- this.searchField,
328
- this.selectDepartmentInfo,
329
- this.separator
330
- )
331
- .then((departments) => {
332
- resolve(departments)
333
- })
334
- .catch((error) => {
335
- reject(error)
336
- })
337
- }
338
- } else {
339
- resolve(selectDepts)
340
- }
341
- })
342
- },
343
- }
344
- export default departmentTreeService
1
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
2
+ import * as Vue from 'vue'
3
+ import { getI18n } from '../../../src/utils/util'
4
+ const departmentTreeService = {
5
+ // 后台查询部门,并拼接树节点
6
+ filterAppendNodes(value) {
7
+ this.$http
8
+ .post(
9
+ window.$vueApp.config.globalProperties.baseAPI +
10
+ '/component/organization-trees/search-pc-depts',
11
+ this.searchParam
12
+ )
13
+ .then((result) => {
14
+ if (result) {
15
+ if (result.length === 0) {
16
+ this.searchResult = []
17
+ this.$message({
18
+ showClose: true,
19
+ type: 'error',
20
+ message: getI18n().t('imatrixUIMessage.queryResultIsEmpty'),
21
+ })
22
+ return
23
+ }
24
+ this.searchResult = result
25
+ // result的格式为[DEPARTMENT~1,DEPARTMENT~1/DEPARTMENT~4,DEPARTMENT~10]
26
+ // result.forEach(nodeIds => {
27
+ // // nodeId的分隔符
28
+ // var nodeIdSeparator = '/'
29
+ // const nodeIdArr = nodeIds.split(nodeIdSeparator)
30
+ // if (nodeIdArr.length > 0) {
31
+ // this.loadDepartmentWhenSearch(0, nodeIdArr)
32
+ // }
33
+ // })
34
+ } else {
35
+ this.$message({
36
+ showClose: true,
37
+ type: 'error',
38
+ message: getI18n().t('imatrixUIMessage.queryResultIsEmpty'),
39
+ })
40
+ }
41
+ })
42
+ },
43
+ search(value) {
44
+ this.searchValue = value
45
+ let mySearchValue = value
46
+ if (mySearchValue) {
47
+ mySearchValue = mySearchValue.trim()
48
+ }
49
+ this.searchParam.searchValue = mySearchValue
50
+ this.searchParam.departmentInfo = this.departmentInfo
51
+ // 后台查询部门,并拼接树节点
52
+ this.filterAppendNodes(value)
53
+ },
54
+ handleSelect(item) {
55
+ // this.handleSelectUtil(item, localStorage)
56
+ // 查询最新部门信息替换,缓存为历史数据 数据库可能发生变化
57
+ this.$http
58
+ .get(
59
+ window.$vueApp.config.globalProperties.baseAPI +
60
+ '/api/departments?departmentCode=' +
61
+ item.code
62
+ )
63
+ .then((departmentDTO) => {
64
+ if (departmentDTO !== null) {
65
+ for (const dtoKey in departmentDTO) {
66
+ if (item.hasOwnProperty(dtoKey)) {
67
+ item[dtoKey] = departmentDTO[dtoKey]
68
+ }
69
+ }
70
+ }
71
+ this.filterText = ''
72
+ this.searchValue = ''
73
+ this.setMemoryCacheData(item, 'department')
74
+ if (this.multiple) {
75
+ const index = this.selectResult.findIndex(
76
+ (selectEntity) => selectEntity.code === item.code
77
+ )
78
+ if (index < 0) {
79
+ this.selectResult.push(item)
80
+ }
81
+ } else {
82
+ this.packageSelectResult(item)
83
+ // 关闭弹窗
84
+ $emit(this, 'result', this.selectNodeInfo)
85
+ }
86
+ })
87
+ },
88
+ querySearch(queryString, cb) {
89
+ if (!this.filterText && this.filterText.length === 0) {
90
+ this.memorySearch(queryString, cb)
91
+ } else {
92
+ this.search(this.filterText)
93
+ cb([])
94
+ }
95
+ },
96
+ // 点击查询按钮调用的方法
97
+ clickSearch() {
98
+ this.storeSeachValue()
99
+ this.search(this.filterText)
100
+ },
101
+ loadDepartmentWhenSearch(n, nodeIdArr) {
102
+ return new Promise((resolve, reject) => {
103
+ if (nodeIdArr.length === n) {
104
+ resolve()
105
+ } else {
106
+ const nodeId = nodeIdArr[n]
107
+ let dataId = nodeId
108
+ // 节点类型和数据id的分隔符
109
+ const nodeTypeAndDataIdSeparator = '~'
110
+ // nodeId格式为DEPARTMENT~4
111
+ if (nodeId.indexOf(nodeTypeAndDataIdSeparator) > -1) {
112
+ dataId = nodeId.substring(nodeId.indexOf('~') + 1)
113
+ }
114
+ this.loadDepartment(dataId)
115
+ .then(() => {
116
+ this.loadDepartmentWhenSearch(++n, nodeIdArr)
117
+ })
118
+ .catch((error) => {
119
+ reject(error)
120
+ })
121
+ }
122
+ })
123
+ },
124
+ // 点击复选框时处理
125
+ handleCheckNode(data, checkObj) {
126
+ if (checkObj.checkedKeys.indexOf(data.id) > -1) {
127
+ // 表示正选中data节点
128
+ this.isloading = true
129
+ if (data.nodeType && data.nodeType === 'DEPARTMENT' && data.data) {
130
+ // 表示当前选中的节点是部门
131
+ const department = JSON.parse(data.data)
132
+ this.selectUser(null, department)
133
+ }
134
+ if (data.childDepartments) {
135
+ // 如果已展开,不需要再走后台获得其子节点。只需要选中已有子节点
136
+ // 展开当前选中的节点
137
+ this.$refs.deparmentTree.store.nodesMap[data.id].expanded = true
138
+ // 选中当前节点及其子节点
139
+ this.checkedNodeAndChildren(data)
140
+ this.isloading = false
141
+ } else {
142
+ // 当前节点未展开。需要走后台获得当前节点的子节点,然后展开当前节点,然后选中这些子节点
143
+ if (!data.leaf) {
144
+ // 不是叶子节点,并且没有加载过该父节点的子节点时,需要走后台展开子节点
145
+ this.$http
146
+ .get(
147
+ window.$vueApp.config.globalProperties.baseAPI +
148
+ '/component/organization-trees/departments/' +
149
+ data.id
150
+ )
151
+ .then((result) => {
152
+ // 更新当前点击的节点的子节点
153
+ this.$refs.deparmentTree.updateKeyChildren(data.id, result)
154
+ // 展开当前选中的节点
155
+ this.$refs.deparmentTree.store.nodesMap[data.id].expanded = true
156
+ // 获得所有应该选中的节点
157
+ this.checkedNodeAndChildren(data)
158
+ })
159
+ this.$http
160
+ .get(
161
+ window.$vueApp.config.globalProperties.baseAPI +
162
+ '/component/organization-trees/child-departments/' +
163
+ data.id
164
+ )
165
+ .then((childDepts) => {
166
+ if (childDepts && !this.checkStrictly) {
167
+ childDepts.forEach((item) => {
168
+ this.selectUser(null, item)
169
+ })
170
+ this.isloading = false
171
+ }
172
+ })
173
+ } else {
174
+ // 如果是叶子节点则不需要loading状态
175
+ this.isloading = false
176
+ }
177
+ }
178
+ } else {
179
+ // 表示正取消选中data节点,同时要取消其子节点的选中状态
180
+ this.cancelChildCheckedNodes(data)
181
+ }
182
+ },
183
+ // 初始化树 或 点击三角展开节点时动态加载子节点
184
+ loadNode(node, resolve) {
185
+ var parentId = 0
186
+ if (node.level === 0) {
187
+ // 表示初始化树
188
+ parentId = 0
189
+ } else {
190
+ parentId = node.data.id
191
+ }
192
+ var checkedKeys = []
193
+ if (this.$refs.deparmentTree) {
194
+ checkedKeys = this.$refs.deparmentTree.getCheckedKeys()
195
+ }
196
+ // 初始化部门树
197
+ this.initLoadDepartment(parentId, node, resolve, checkedKeys)
198
+ },
199
+ // 初始化部门树
200
+ initLoadDepartment(parentId, node, resolve, checkedKeys) {
201
+ this.$http
202
+ .get(
203
+ window.$vueApp.config.globalProperties.baseAPI +
204
+ '/component/organization-trees/departments/' +
205
+ parentId
206
+ )
207
+ .then((data) => {
208
+ resolve(data)
209
+ // 更新当前点击的节点的子节点
210
+ this.$refs.deparmentTree.updateKeyChildren(parentId, data)
211
+ if (parentId === 0) {
212
+ // 初始化树时,展开公司节点
213
+ const tenantData = data[0].data
214
+ data[0].disable = true
215
+ this.tenantInfo = JSON.parse(tenantData)
216
+ this.containBranch = data[0].containBranch
217
+ if (this.departmentInfo && this.departmentInfo.length > 0) {
218
+ // 加载指定部门时,展开公司节点
219
+ this.loadPointDepartments()
220
+ } else {
221
+ // 加载整个组织结构树时,展开公司节点
222
+ this.loadDepartment(this.tenantNodeId)
223
+ }
224
+ }
225
+
226
+ if (this.isClickNode) {
227
+ // 点击当前节点时,加载树节点时
228
+ // 注意不是点击复选框时
229
+ this.isClickNode = false
230
+ this.checkedNodeAndChildren(node.data)
231
+ } else {
232
+ // 表示是点击三角展开节点时
233
+ if (checkedKeys && checkedKeys.indexOf(parentId) > -1) {
234
+ // 点击部门名称前的三角标识展开节点时,保持当前节点的选中状态
235
+ // 表示当前展开的节点是选中状态,则应保持其选中状态,并选中其子节点
236
+ this.checkedNodeAndChildren(node.data)
237
+ }
238
+ }
239
+ })
240
+ },
241
+ // 加载当前节点的子节点
242
+ loadDepartment(parentId, isSearch, searchValue) {
243
+ return new Promise((resolve, reject) => {
244
+ this.$http
245
+ .get(
246
+ window.$vueApp.config.globalProperties.baseAPI +
247
+ '/component/organization-trees/departments/' +
248
+ parentId
249
+ )
250
+ .then((children) => {
251
+ this.$refs.deparmentTree.updateKeyChildren(parentId, children)
252
+ if (this.$refs.deparmentTree.store.nodesMap[parentId]) {
253
+ this.$refs.deparmentTree.store.nodesMap[parentId].expanded = true
254
+ }
255
+ resolve()
256
+ })
257
+ .catch((error) => {
258
+ console.log('error', error)
259
+ })
260
+ })
261
+ },
262
+ // 加载指定部门节点
263
+ loadPointDepartments() {
264
+ this.$http
265
+ .post(
266
+ window.$vueApp.config.globalProperties.baseAPI +
267
+ '/component/organization-trees/point-departments',
268
+ this.departmentInfo
269
+ )
270
+ .then((children) => {
271
+ this.$refs.deparmentTree.updateKeyChildren(this.tenantNodeId, children)
272
+ if (this.$refs.deparmentTree.store.nodesMap[this.tenantNodeId]) {
273
+ this.$refs.deparmentTree.store.nodesMap[this.tenantNodeId].expanded =
274
+ true
275
+ }
276
+ })
277
+ },
278
+ getSelectDepts(searchField, selectDeptInfo, separator) {
279
+ return new Promise((resolve, reject) => {
280
+ if (!searchField) {
281
+ resolve([])
282
+ } else if (!selectDeptInfo) {
283
+ resolve([])
284
+ } else {
285
+ this.$http
286
+ .get(
287
+ window.$vueApp.config.globalProperties.baseAPI +
288
+ '/component/organization-trees/select-departments?searchField=' +
289
+ searchField +
290
+ '&selectDeptInfo=' +
291
+ selectDeptInfo +
292
+ '&separator=' +
293
+ separator
294
+ )
295
+ .then((departments) => {
296
+ resolve(departments)
297
+ })
298
+ .catch((error) => {
299
+ reject(error)
300
+ })
301
+ }
302
+ })
303
+ },
304
+ // 选中了组织结构树的根节点
305
+ packageAllDept() {
306
+ // 表示集合中不存在该用户,则封装该用户
307
+ var allDept = {
308
+ id: this.tenantNodeId,
309
+ name: '所有部门',
310
+ }
311
+ return allDept
312
+ },
313
+ initSelectDepts() {
314
+ return new Promise((resolve, reject) => {
315
+ const selectDepts = []
316
+ if (this.selectDepartmentInfo) {
317
+ if (
318
+ this.selectDepartmentInfo === this.tenantNodeId ||
319
+ this.selectDepartmentInfo === '所有部门'
320
+ ) {
321
+ // 表示已选择所有用户
322
+ selectDepts.push(this.packageAllDept())
323
+ resolve(selectDepts)
324
+ } else {
325
+ // 表示不是选择的所有用户
326
+ this.getSelectDepts(
327
+ this.searchField,
328
+ this.selectDepartmentInfo,
329
+ this.separator
330
+ )
331
+ .then((departments) => {
332
+ resolve(departments)
333
+ })
334
+ .catch((error) => {
335
+ reject(error)
336
+ })
337
+ }
338
+ } else {
339
+ resolve(selectDepts)
340
+ }
341
+ })
342
+ },
343
+ }
344
+ export default departmentTreeService