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,15 +1,15 @@
1
- import ExportService from './export-data'
2
- import ExportNewService from './export-data-new'
3
- import publicMethodService from './public-method'
4
-
5
- export default {
6
- install: function (Vue, options) {
7
- Vue.config.globalProperties.$exportData = ExportService.exportData
8
- Vue.config.globalProperties.$isInIframe = publicMethodService.isInIframe
9
- Vue.config.globalProperties.$escapeHtml = publicMethodService.escapeHtml
10
- Vue.config.globalProperties.$download = ExportService.download
11
- Vue.config.globalProperties.$refreshList = publicMethodService.refreshList
12
- Vue.config.globalProperties.$exportDataNew = ExportNewService.exportData
13
- Vue.config.globalProperties.$downloadNew = ExportNewService.download
14
- },
15
- }
1
+ import ExportService from './export-data'
2
+ import ExportNewService from './export-data-new'
3
+ import publicMethodService from './public-method'
4
+
5
+ export default {
6
+ install: function (Vue, options) {
7
+ Vue.config.globalProperties.$exportData = ExportService.exportData
8
+ Vue.config.globalProperties.$isInIframe = publicMethodService.isInIframe
9
+ Vue.config.globalProperties.$escapeHtml = publicMethodService.escapeHtml
10
+ Vue.config.globalProperties.$download = ExportService.download
11
+ Vue.config.globalProperties.$refreshList = publicMethodService.refreshList
12
+ Vue.config.globalProperties.$exportDataNew = ExportNewService.exportData
13
+ Vue.config.globalProperties.$downloadNew = ExportNewService.download
14
+ },
15
+ }
@@ -1,47 +1,47 @@
1
- /**
2
- * 判断当前元素是否在iframe内,如果在iframe内则返回true,否则返回false
3
- */
4
- function isInIframe() {
5
- // if (window.frames.length !== parent.frames.length) {
6
- // // 在iframe内
7
- // return true
8
- // } else {
9
- // // 不在iframe内
10
- // return false
11
- // }
12
- if (self !== top) {
13
- // 在iframe内
14
- return true
15
- } else {
16
- // 不在iframe内
17
- return false
18
- }
19
- }
20
-
21
- // 多个列表编码之间以逗号隔开;如果一个页面中有多个九宫格列表,且使用的是一个列表编码,listCode的格式应为:listCode~gridId,例如:MMS_BUSSINESS_SYSTEM~grid1
22
- function refreshList(listCodes) {
23
- if (listCodes) {
24
- const listCodesArr = listCodes.split(',')
25
- listCodesArr.forEach((listCode) => {
26
- window.sessionStorage.setItem('refreshList-' + listCode, 'true')
27
- })
28
- }
29
- }
30
-
31
- // 处理xss攻击
32
- function escapeHtml(content) {
33
- if (
34
- content !== undefined &&
35
- content !== null &&
36
- typeof content === 'string'
37
- ) {
38
- content = content.replace(/</g, '&lt;').replace(/>/g, '&gt;')
39
- }
40
- return content
41
- }
42
-
43
- export default {
44
- isInIframe,
45
- refreshList,
46
- escapeHtml,
47
- }
1
+ /**
2
+ * 判断当前元素是否在iframe内,如果在iframe内则返回true,否则返回false
3
+ */
4
+ function isInIframe() {
5
+ // if (window.frames.length !== parent.frames.length) {
6
+ // // 在iframe内
7
+ // return true
8
+ // } else {
9
+ // // 不在iframe内
10
+ // return false
11
+ // }
12
+ if (self !== top) {
13
+ // 在iframe内
14
+ return true
15
+ } else {
16
+ // 不在iframe内
17
+ return false
18
+ }
19
+ }
20
+
21
+ // 多个列表编码之间以逗号隔开;如果一个页面中有多个九宫格列表,且使用的是一个列表编码,listCode的格式应为:listCode~gridId,例如:MMS_BUSSINESS_SYSTEM~grid1
22
+ function refreshList(listCodes) {
23
+ if (listCodes) {
24
+ const listCodesArr = listCodes.split(',')
25
+ listCodesArr.forEach((listCode) => {
26
+ window.sessionStorage.setItem('refreshList-' + listCode, 'true')
27
+ })
28
+ }
29
+ }
30
+
31
+ // 处理xss攻击
32
+ function escapeHtml(content) {
33
+ if (
34
+ content !== undefined &&
35
+ content !== null &&
36
+ typeof content === 'string'
37
+ ) {
38
+ content = content.replace(/</g, '&lt;').replace(/>/g, '&gt;')
39
+ }
40
+ return content
41
+ }
42
+
43
+ export default {
44
+ isInIframe,
45
+ refreshList,
46
+ escapeHtml,
47
+ }
@@ -1,6 +1,6 @@
1
- import RemoveDepartment from './src/remove-department.vue'
2
- RemoveDepartment.install = function (Vue) {
3
- Vue.component(RemoveDepartment.name, RemoveDepartment)
4
- }
5
-
6
- export default RemoveDepartment
1
+ import RemoveDepartment from './src/remove-department.vue'
2
+ RemoveDepartment.install = function (Vue) {
3
+ Vue.component(RemoveDepartment.name, RemoveDepartment)
4
+ }
5
+
6
+ export default RemoveDepartment
@@ -1,200 +1,200 @@
1
- <template>
2
- <div>
3
- <el-dialog
4
- class="user-tree"
5
- model-value
6
- :title="$t('departmentTreeInline.removeDepartment')"
7
- append-to-body
8
- :close-on-click-modal="false"
9
- :width="width"
10
- @open="$emit('open')"
11
- @opend="$emit('opend')"
12
- @close="$emit('close')"
13
- @closed="$emit('closed')"
14
- >
15
- <div style="margin-bottom: 10px">
16
- <el-button
17
- type="danger"
18
- size="mini"
19
- :icon="ElIconDelete"
20
- @click="removeAllDept()"
21
- >
22
- {{ $t('imatrixUIPublicModel.clear') }}
23
- </el-button>
24
- </div>
25
-
26
- <el-table
27
- ref="removeDeptGrid"
28
- :data="departments"
29
- row-key="id"
30
- border
31
- :height="height"
32
- >
33
- <el-table-column :label="$t('departmentTreeInline.name')" prop="name" />
34
- <el-table-column :label="$t('departmentTreeInline.code')" prop="code" />
35
- <el-table-column
36
- :label="$t('imatrixUIPublicModel.edit')"
37
- align="center"
38
- width="60px"
39
- >
40
- <template v-slot="scope">
41
- <div>
42
- <el-button
43
- type="danger"
44
- size="mini"
45
- :icon="ElIconDelete"
46
- circle
47
- @click="removeDept(scope.$index)"
48
- />
49
- </div>
50
- </template>
51
- </el-table-column>
52
- </el-table>
53
- <template v-slot:footer>
54
- <div class="dialog-footer">
55
- <el-button size="small" @click="$emit('close')">
56
- {{ $t('imatrixUIPublicModel.cancel') }}
57
- </el-button>
58
- <el-button size="small" type="primary" @click="confirmSelectDept">
59
- {{ $t('imatrixUIPublicModel.sure') }}
60
- </el-button>
61
- </div>
62
- </template>
63
- </el-dialog>
64
- </div>
65
- </template>
66
-
67
- <script>
68
- import { Delete as ElIconDelete } from '@element-plus/icons-vue'
69
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
70
- import removeDeptService from './remove-dept-service'
71
- export default {
72
- data() {
73
- return {
74
- departments: [],
75
- // 原来选择的部门集合
76
- originalDepts: [],
77
- // 是否包含分支
78
- containBranch: false,
79
- // 公司节点的id
80
- tenantNodeId: -1,
81
- ElIconDelete,
82
- }
83
- },
84
- name: 'RemoveDepartment',
85
- components: {},
86
- props: {
87
- // 多选部门树时,已选择部门id或部门名称或编码集合,多个之间以逗号隔开
88
- selectDepartmentInfo: {
89
- type: [String, Number],
90
- default: null,
91
- },
92
- // 移除部门时,部门属性名称:id、name、code,默认是id
93
- searchField: {
94
- type: String,
95
- default: 'id',
96
- },
97
- // 弹框的宽度
98
- width: {
99
- type: String,
100
- default: '30%',
101
- },
102
- // 弹框的高度
103
- height: {
104
- type: String,
105
- default: '300px',
106
- },
107
- // 多选树时结果之间的分隔符,默认是逗号分隔
108
- separator: {
109
- type: String,
110
- default: ',',
111
- },
112
- },
113
- created() {
114
- if (this.selectDepartmentInfo) {
115
- if (
116
- this.selectDepartmentInfo === this.tenantNodeId ||
117
- this.selectDepartmentInfo === '所有部门'
118
- ) {
119
- // 表示已选择所有用户
120
- this.departments.push(this.packageAllDept())
121
- } else {
122
- // 表示不是选择的所有用户
123
- this.getSelectDepts(
124
- this.searchField,
125
- this.selectDepartmentInfo,
126
- this.separator
127
- ).then((departments) => {
128
- this.originalDepts = departments
129
- this.departments = departments
130
- })
131
- }
132
- }
133
- },
134
- methods: {
135
- ...removeDeptService,
136
- confirmSelectDept() {
137
- const searchFieldValues = []
138
- var retainSelectDepts = {
139
- ids: [],
140
- names: [],
141
- codes: [],
142
- departments: [],
143
- }
144
- for (var i = 0; i < this.departments.length; i++) {
145
- var dept = this.departments[i]
146
- // 不存在该用户则放到结果集合中,去掉重复使用
147
- retainSelectDepts.ids.push(dept.id)
148
- retainSelectDepts.codes.push(dept.code)
149
- retainSelectDepts.departments.push(dept)
150
- var name = dept.name
151
- if (this.containBranch && dept.branchName) {
152
- // 如果包含分支机构,则拼接分支机构名称
153
- name = name + '(' + dept.branchName + ')'
154
- }
155
- retainSelectDepts.names.push(name)
156
- // 将用于查询的字段的值存到数组中,获得移除的元素时使用
157
- searchFieldValues.push(dept[this.searchField])
158
- }
159
- const removeItems = this.getRemoveItems(
160
- this.originalDepts,
161
- searchFieldValues,
162
- this.searchField
163
- )
164
- $emit(this, 'close', retainSelectDepts, removeItems)
165
- },
166
- // 选中了组织结构树的根节点
167
- packageAllDept() {
168
- // 表示集合中不存在该用户,则封装该用户
169
- var allDept = {
170
- id: this.tenantNodeId,
171
- name: '所有部门',
172
- }
173
- return allDept
174
- },
175
- // 移除用户
176
- removeDept(index) {
177
- this.departments.splice(index, 1)
178
- },
179
- // 清空用户
180
- removeAllDept() {
181
- this.departments = []
182
- },
183
- // 获得移除的元素集合
184
- getRemoveItems(allValues, retainValues, searchField) {
185
- if (retainValues === undefined || retainValues.length === 0) {
186
- // 表示没有保留任何一条记录,即移除了所有元素
187
- return allValues
188
- }
189
- if (allValues) {
190
- // 根据id筛选出
191
- return allValues.filter(
192
- (item) => retainValues.indexOf(item[searchField]) === -1
193
- )
194
- }
195
- return []
196
- },
197
- },
198
- emits: ['open', 'opend', 'close', 'closed', 'opend', 'close', 'closed'],
199
- }
200
- </script>
1
+ <template>
2
+ <div>
3
+ <el-dialog
4
+ class="user-tree"
5
+ model-value
6
+ :title="$t('departmentTreeInline.removeDepartment')"
7
+ append-to-body
8
+ :close-on-click-modal="false"
9
+ :width="width"
10
+ @open="$emit('open')"
11
+ @opend="$emit('opend')"
12
+ @close="$emit('close')"
13
+ @closed="$emit('closed')"
14
+ >
15
+ <div style="margin-bottom: 10px">
16
+ <el-button
17
+ type="danger"
18
+ size="mini"
19
+ :icon="ElIconDelete"
20
+ @click="removeAllDept()"
21
+ >
22
+ {{ $t('imatrixUIPublicModel.clear') }}
23
+ </el-button>
24
+ </div>
25
+
26
+ <el-table
27
+ ref="removeDeptGrid"
28
+ :data="departments"
29
+ row-key="id"
30
+ border
31
+ :height="height"
32
+ >
33
+ <el-table-column :label="$t('departmentTreeInline.name')" prop="name" />
34
+ <el-table-column :label="$t('departmentTreeInline.code')" prop="code" />
35
+ <el-table-column
36
+ :label="$t('imatrixUIPublicModel.edit')"
37
+ align="center"
38
+ width="60px"
39
+ >
40
+ <template v-slot="scope">
41
+ <div>
42
+ <el-button
43
+ type="danger"
44
+ size="mini"
45
+ :icon="ElIconDelete"
46
+ circle
47
+ @click="removeDept(scope.$index)"
48
+ />
49
+ </div>
50
+ </template>
51
+ </el-table-column>
52
+ </el-table>
53
+ <template v-slot:footer>
54
+ <div class="dialog-footer">
55
+ <el-button size="small" @click="$emit('close')">
56
+ {{ $t('imatrixUIPublicModel.cancel') }}
57
+ </el-button>
58
+ <el-button size="small" type="primary" @click="confirmSelectDept">
59
+ {{ $t('imatrixUIPublicModel.sure') }}
60
+ </el-button>
61
+ </div>
62
+ </template>
63
+ </el-dialog>
64
+ </div>
65
+ </template>
66
+
67
+ <script>
68
+ import { Delete as ElIconDelete } from '@element-plus/icons-vue'
69
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
70
+ import removeDeptService from './remove-dept-service'
71
+ export default {
72
+ data() {
73
+ return {
74
+ departments: [],
75
+ // 原来选择的部门集合
76
+ originalDepts: [],
77
+ // 是否包含分支
78
+ containBranch: false,
79
+ // 公司节点的id
80
+ tenantNodeId: -1,
81
+ ElIconDelete,
82
+ }
83
+ },
84
+ name: 'RemoveDepartment',
85
+ components: {},
86
+ props: {
87
+ // 多选部门树时,已选择部门id或部门名称或编码集合,多个之间以逗号隔开
88
+ selectDepartmentInfo: {
89
+ type: [String, Number],
90
+ default: null,
91
+ },
92
+ // 移除部门时,部门属性名称:id、name、code,默认是id
93
+ searchField: {
94
+ type: String,
95
+ default: 'id',
96
+ },
97
+ // 弹框的宽度
98
+ width: {
99
+ type: String,
100
+ default: '30%',
101
+ },
102
+ // 弹框的高度
103
+ height: {
104
+ type: String,
105
+ default: '300px',
106
+ },
107
+ // 多选树时结果之间的分隔符,默认是逗号分隔
108
+ separator: {
109
+ type: String,
110
+ default: ',',
111
+ },
112
+ },
113
+ created() {
114
+ if (this.selectDepartmentInfo) {
115
+ if (
116
+ this.selectDepartmentInfo === this.tenantNodeId ||
117
+ this.selectDepartmentInfo === '所有部门'
118
+ ) {
119
+ // 表示已选择所有用户
120
+ this.departments.push(this.packageAllDept())
121
+ } else {
122
+ // 表示不是选择的所有用户
123
+ this.getSelectDepts(
124
+ this.searchField,
125
+ this.selectDepartmentInfo,
126
+ this.separator
127
+ ).then((departments) => {
128
+ this.originalDepts = departments
129
+ this.departments = departments
130
+ })
131
+ }
132
+ }
133
+ },
134
+ methods: {
135
+ ...removeDeptService,
136
+ confirmSelectDept() {
137
+ const searchFieldValues = []
138
+ var retainSelectDepts = {
139
+ ids: [],
140
+ names: [],
141
+ codes: [],
142
+ departments: [],
143
+ }
144
+ for (var i = 0; i < this.departments.length; i++) {
145
+ var dept = this.departments[i]
146
+ // 不存在该用户则放到结果集合中,去掉重复使用
147
+ retainSelectDepts.ids.push(dept.id)
148
+ retainSelectDepts.codes.push(dept.code)
149
+ retainSelectDepts.departments.push(dept)
150
+ var name = dept.name
151
+ if (this.containBranch && dept.branchName) {
152
+ // 如果包含分支机构,则拼接分支机构名称
153
+ name = name + '(' + dept.branchName + ')'
154
+ }
155
+ retainSelectDepts.names.push(name)
156
+ // 将用于查询的字段的值存到数组中,获得移除的元素时使用
157
+ searchFieldValues.push(dept[this.searchField])
158
+ }
159
+ const removeItems = this.getRemoveItems(
160
+ this.originalDepts,
161
+ searchFieldValues,
162
+ this.searchField
163
+ )
164
+ $emit(this, 'close', retainSelectDepts, removeItems)
165
+ },
166
+ // 选中了组织结构树的根节点
167
+ packageAllDept() {
168
+ // 表示集合中不存在该用户,则封装该用户
169
+ var allDept = {
170
+ id: this.tenantNodeId,
171
+ name: '所有部门',
172
+ }
173
+ return allDept
174
+ },
175
+ // 移除用户
176
+ removeDept(index) {
177
+ this.departments.splice(index, 1)
178
+ },
179
+ // 清空用户
180
+ removeAllDept() {
181
+ this.departments = []
182
+ },
183
+ // 获得移除的元素集合
184
+ getRemoveItems(allValues, retainValues, searchField) {
185
+ if (retainValues === undefined || retainValues.length === 0) {
186
+ // 表示没有保留任何一条记录,即移除了所有元素
187
+ return allValues
188
+ }
189
+ if (allValues) {
190
+ // 根据id筛选出
191
+ return allValues.filter(
192
+ (item) => retainValues.indexOf(item[searchField]) === -1
193
+ )
194
+ }
195
+ return []
196
+ },
197
+ },
198
+ emits: ['open', 'opend', 'close', 'closed', 'opend', 'close', 'closed'],
199
+ }
200
+ </script>
@@ -1,31 +1,31 @@
1
- import * as Vue from 'vue'
2
- const removeUserService = {
3
- // 根据指定部门信息获得部门集合
4
- getSelectDepts(searchField, selectDeptInfo, separator) {
5
- return new Promise((resolve, reject) => {
6
- if (!searchField) {
7
- resolve([])
8
- } else if (!selectDeptInfo) {
9
- resolve([])
10
- } else {
11
- this.$http
12
- .get(
13
- window.$vueApp.config.globalProperties.baseAPI +
14
- '/component/organization-trees/select-departments?searchField=' +
15
- searchField +
16
- '&selectDeptInfo=' +
17
- selectDeptInfo +
18
- '&separator=' +
19
- separator
20
- )
21
- .then((departments) => {
22
- resolve(departments)
23
- })
24
- .catch((error) => {
25
- reject(error)
26
- })
27
- }
28
- })
29
- },
30
- }
31
- export default removeUserService
1
+ import * as Vue from 'vue'
2
+ const removeUserService = {
3
+ // 根据指定部门信息获得部门集合
4
+ getSelectDepts(searchField, selectDeptInfo, separator) {
5
+ return new Promise((resolve, reject) => {
6
+ if (!searchField) {
7
+ resolve([])
8
+ } else if (!selectDeptInfo) {
9
+ resolve([])
10
+ } else {
11
+ this.$http
12
+ .get(
13
+ window.$vueApp.config.globalProperties.baseAPI +
14
+ '/component/organization-trees/select-departments?searchField=' +
15
+ searchField +
16
+ '&selectDeptInfo=' +
17
+ selectDeptInfo +
18
+ '&separator=' +
19
+ separator
20
+ )
21
+ .then((departments) => {
22
+ resolve(departments)
23
+ })
24
+ .catch((error) => {
25
+ reject(error)
26
+ })
27
+ }
28
+ })
29
+ },
30
+ }
31
+ export default removeUserService
@@ -1,6 +1,6 @@
1
- import RemoveUser from './src/remove-user.vue'
2
- RemoveUser.install = function (Vue) {
3
- Vue.component(RemoveUser.name, RemoveUser)
4
- }
5
-
6
- export default RemoveUser
1
+ import RemoveUser from './src/remove-user.vue'
2
+ RemoveUser.install = function (Vue) {
3
+ Vue.component(RemoveUser.name, RemoveUser)
4
+ }
5
+
6
+ export default RemoveUser