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,427 +1,427 @@
1
- <template>
2
- <el-dialog
3
- :title="$t('superGrid.columnConfig')"
4
- width="50%"
5
- top="5vh"
6
- append-to-body
7
- :close-on-click-modal="false"
8
- :model-value="true"
9
- :show-close="true"
10
- @open="$emit('open')"
11
- @opend="$emit('opend')"
12
- @close="$emit('close')"
13
- @closed="$emit('closed')"
14
- >
15
- <div class="operation-area">
16
- <el-button type="primary" size="small" @click="saveConfig">
17
- {{ $t('imatrixUIPublicModel.sure') }}
18
- </el-button>
19
- <el-button size="small" @click="resetConfig">
20
- {{ $t('imatrixUIPublicModel.reset') }}
21
- </el-button>
22
- <el-button size="small" @click="$emit('close')">
23
- {{ $t('imatrixUIPublicModel.cancel') }}
24
- </el-button>
25
- <span v-if="isDragColumn" style="padding-left: 10px; color: red"
26
- >({{ $t('superGrid.dragColumnOrderMessage') }})</span
27
- >
28
- </div>
29
- <el-table
30
- v-if="hasLoaded"
31
- :data="columns"
32
- max-height="450"
33
- class="custom-config-elTable"
34
- >
35
- <el-table-column
36
- property="label"
37
- :label="$t('superGrid.label')"
38
- width="220"
39
- >
40
- <template v-slot="scope">
41
- <span class="ellipsis cell--span" :title="scope.row.label">{{
42
- scope.row.label
43
- }}</span>
44
- </template>
45
- </el-table-column>
46
- <el-table-column
47
- property="showType"
48
- :label="$t('superGrid.isShow')"
49
- width="120"
50
- >
51
- <template v-slot="scope">
52
- <el-select
53
- v-model="scope.row.showType"
54
- :disabled="isDisabledShow(scope.row)"
55
- @change="changeShow(scope.row, $event)"
56
- >
57
- <el-option
58
- :label="
59
- isDisabledShow(scope.row)
60
- ? $t('superGrid.default')
61
- : $t('superGrid.show')
62
- "
63
- value="default"
64
- />
65
- <el-option :label="$t('superGrid.hidden')" value="false" />
66
- </el-select>
67
- </template>
68
- </el-table-column>
69
- <el-table-column
70
- property="exportType"
71
- :label="$t('superGrid.isExportable')"
72
- width="120"
73
- >
74
- <template v-slot="scope">
75
- <el-select
76
- v-model="scope.row.exportType"
77
- :disabled="isDisabledExport(scope.row)"
78
- @change="changeExport(scope.row, $event)"
79
- >
80
- <el-option
81
- :label="
82
- isDisabledExport(scope.row)
83
- ? $t('superGrid.default')
84
- : $t('superGrid.export')
85
- "
86
- value="default"
87
- />
88
- <el-option :label="$t('superGrid.unExport')" value="false" />
89
- </el-select>
90
- </template>
91
- </el-table-column>
92
- <el-table-column
93
- v-if="isDragColumn"
94
- property="displayOrderType"
95
- :label="$t('superGrid.displayOrder')"
96
- width="120"
97
- >
98
- <template v-slot="scope">
99
- <el-input
100
- v-if="
101
- scope.row.displayOrderType &&
102
- scope.row.displayOrderType === 'custom'
103
- "
104
- v-model="scope.row.displayOrder"
105
- clearable
106
- size="mini"
107
- @clear="clearDisplayOrder(scope.row)"
108
- />
109
- <el-select v-else v-model="scope.row.displayOrderType">
110
- <el-option :label="$t('superGrid.default')" value="default" />
111
- <el-option :label="$t('superGrid.custom')" value="custom" />
112
- </el-select>
113
- </template>
114
- </el-table-column>
115
- <el-table-column
116
- property="widthType"
117
- :label="$t('superGrid.width')"
118
- width="120"
119
- >
120
- <template v-slot="scope">
121
- <el-input
122
- v-if="scope.row.widthType && scope.row.widthType === 'custom'"
123
- v-model="scope.row.width"
124
- size="mini"
125
- clearable
126
- @clear="clearWidth(scope.row)"
127
- />
128
- <el-select v-else v-model="scope.row.widthType">
129
- <el-option :label="$t('superGrid.default')" value="default" />
130
- <el-option :label="$t('superGrid.custom')" value="custom" />
131
- </el-select>
132
- </template>
133
- </el-table-column>
134
- </el-table>
135
- </el-dialog>
136
- </template>
137
-
138
- <script>
139
- import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
140
- import * as Vue from 'vue'
141
- import store from './store'
142
- import Sortable from 'sortablejs'
143
- export default {
144
- name: 'ColumnsConfig',
145
- props: {
146
- listCode: {
147
- type: String,
148
- default: '',
149
- },
150
- },
151
- data() {
152
- return {
153
- columns: [],
154
- hasLoaded: false,
155
- }
156
- },
157
- created() {},
158
- mounted() {
159
- this.listAllColumns().then((columns) => {
160
- this.columns = columns
161
- this.hasLoaded = true
162
- this.$nextTick(() => {
163
- this.dragColumnDisplayOrder()
164
- })
165
- })
166
- },
167
- methods: {
168
- isDisabledShow(row) {
169
- // 序号、复选框列不可以配置是否显示;占位符列不可以设置是否显示;当不是自定义的显示状态为false时,不可配置是否显示
170
- return (
171
- (row.prop && (row.prop === '$index' || row.prop === '$selection')) ||
172
- row.custom === true ||
173
- (row.showType && row.showType !== 'false' && row.show === false)
174
- )
175
- },
176
- isDisabledExport(row) {
177
- // 序号、复选框列不可以配置是否导出;占位符列不可以设置是否导出;当不是自定义的导出状态为false时,不可配置是否导出
178
- return (
179
- (row.prop && (row.prop === '$index' || row.prop === '$selection')) ||
180
- row.custom === true ||
181
- (row.exportType &&
182
- row.exportType !== 'false' &&
183
- row.exportable === false)
184
- )
185
- },
186
- changeShow(row, value) {
187
- if (value !== undefined && value === 'false') {
188
- row.show = false
189
- } else {
190
- row.show = true
191
- }
192
- },
193
- changeExport(row, value) {
194
- if (value !== undefined && value === 'false') {
195
- row.exportable = false
196
- } else {
197
- row.exportable = true
198
- }
199
- },
200
- saveConfig() {
201
- const params = {
202
- settingColumns: this.columns,
203
- listCode: this.listCode,
204
- }
205
- this.$http
206
- .post(
207
- window.$vueApp.config.globalProperties.baseAPI +
208
- '/component/super-grids/setting-columns',
209
- params
210
- )
211
- .then((data) => {
212
- this.$message({
213
- type: 'success',
214
- message: this.$t('imatrixUIMessage.saveSuccessfully'),
215
- showClose: true,
216
- })
217
- $emit(this, 'close', true)
218
- })
219
- },
220
- resetConfig() {
221
- this.$confirm(
222
- this.$t('superGrid.whetherToConfirmReset'),
223
- this.$t('imatrixUIMessage.tips'),
224
- {
225
- confirmButtonText: this.$t('imatrixUIPublicModel.sure'),
226
- cancelButtonText: this.$t('imatrixUIPublicModel.cancel'),
227
- type: 'warning',
228
- }
229
- ).then(() => {
230
- const url =
231
- window.$vueApp.config.globalProperties.baseAPI +
232
- '/component/super-grids/reset-columns/' +
233
- this.listCode
234
- this.$http.delete(url).then(() => {
235
- this.$message({
236
- type: 'success',
237
- message: this.$t('superGrid.resetSuccessful'),
238
- showClose: true,
239
- })
240
- this.listAllColumns().then((columns) => {
241
- this.columns = columns
242
- $emit(this, 'reset', true)
243
- })
244
- })
245
- })
246
- },
247
- listAllColumns() {
248
- return new Promise((resolve, reject) => {
249
- const url =
250
- window.$vueApp.config.globalProperties.baseAPI +
251
- '/component/super-grids/all-list-columns/' +
252
- this.listCode
253
- const gridParams = store.get(this.listCode)
254
- const params = {}
255
- const isSql = gridParams.isSql
256
- this.isDragColumn = gridParams.colSetting.isDragColumn
257
- if (typeof isSql !== 'undefined') {
258
- params.isSql = isSql + ''
259
- }
260
- this.$http
261
- .post(url, params)
262
- .then((columns) => {
263
- resolve(columns)
264
- })
265
- .catch((error) => {
266
- reject(error)
267
- })
268
- })
269
- },
270
- clearDisplayOrder(row) {
271
- row.displayOrderType = 'default'
272
- },
273
- clearWidth(row) {
274
- row.widthType = 'default'
275
- },
276
- // 移动完成后的displayOrder设置
277
- indexAfterTheChangeUpdateDisplayOrder(dataList, oldIndex, newIndex, prop) {
278
- if (dataList && dataList.length > 0) {
279
- if (oldIndex != null && oldIndex !== undefined && oldIndex !== -1) {
280
- if (newIndex !== null && newIndex !== undefined && newIndex !== -1) {
281
- if (prop && prop !== '') {
282
- const selectCol = dataList[newIndex]
283
- selectCol.displayOrderType = 'custom'
284
- if (newIndex > oldIndex) {
285
- // 表示向后移动
286
- // 位置已经移动,所以参数要赋值给原始位置的下一个
287
- const afProp = dataList[newIndex - 1][prop]
288
- const arr = dataList.slice(oldIndex, newIndex)
289
- if (arr && arr.length > 0) {
290
- for (let i = arr.length - 1; i > -1; i--) {
291
- const col = arr[i]
292
- col.displayOrderType = 'custom'
293
- if (i === 0) {
294
- // 紧靠原始位置的上一个
295
- col[prop] = selectCol[prop]
296
- } else {
297
- col[prop] = arr[i - 1][prop]
298
- }
299
- }
300
- }
301
- selectCol[prop] = afProp
302
- } else {
303
- const befProp = dataList[newIndex + 1][prop]
304
- // 表示向前移动
305
- // 位置已经移动,所以参数要赋值给原始位置的上一个
306
- const arr = dataList.slice(newIndex + 1, oldIndex + 1)
307
- if (arr && arr.length > 0) {
308
- for (let i = 0; i < arr.length; i++) {
309
- const col = arr[i]
310
- col.displayOrderType = 'custom'
311
- if (i === arr.length - 1) {
312
- // 紧靠原始位置的上一个
313
- col[prop] = selectCol[prop]
314
- } else {
315
- col[prop] = arr[i + 1][prop]
316
- }
317
- }
318
- }
319
- selectCol[prop] = befProp
320
- }
321
- }
322
- }
323
- }
324
- }
325
- },
326
- // 拖动列顺序
327
- dragColumnDisplayOrder() {
328
- if (!this.isDragColumn) {
329
- return
330
- }
331
- return new Promise((resolve, reject) => {
332
- const tbody = document.querySelector(
333
- '.custom-config-elTable .el-table__body-wrapper tbody'
334
- )
335
- if (tbody != null) {
336
- const vm = this
337
- Sortable.create(tbody, {
338
- onEnd({ newIndex, oldIndex }) {
339
- if (
340
- oldIndex !== null &&
341
- oldIndex !== undefined &&
342
- oldIndex !== -1 &&
343
- newIndex !== null &&
344
- newIndex !== undefined &&
345
- newIndex !== -1
346
- ) {
347
- if (oldIndex > newIndex) {
348
- // 从后往前
349
- if (vm.columns && vm.columns.length > 0) {
350
- const item = vm.columns[oldIndex]
351
- for (var i = oldIndex - 1; i >= newIndex; i--) {
352
- const col = vm.columns[i]
353
- col.displayOrderType = 'custom'
354
- vm.columns[i + 1] = col
355
- }
356
- vm.columns[newIndex] = item
357
- }
358
- } else {
359
- // 从前往后
360
- if (vm.columns && vm.columns.length > 0) {
361
- const item = vm.columns[oldIndex]
362
- for (var k = oldIndex + 1; k <= newIndex; k++) {
363
- const col = vm.columns[k]
364
- col.displayOrderType = 'custom'
365
- vm.columns[k - 1] = col
366
- }
367
- vm.columns[newIndex] = item
368
- }
369
- }
370
- }
371
- console.log('config拖动字段', vm.columns)
372
- console.log('config拖动字段oldIndex', oldIndex)
373
- console.log('config拖动字段newIndex', newIndex)
374
- vm.hasLoaded = false
375
- setTimeout(function () {
376
- vm.hasLoaded = true
377
- vm.$nextTick(() => {
378
- vm.indexAfterTheChangeUpdateDisplayOrder(
379
- vm.columns,
380
- oldIndex,
381
- newIndex,
382
- 'displayOrder'
383
- )
384
- vm.dragColumnDisplayOrder()
385
- })
386
- }, 100)
387
-
388
- // vm.hasLoaded = false
389
- // // 添加setTimeout是解决拖动顺序后数组columns值改变了,但是列表没有重新渲染问题
390
- // setTimeout(function() {
391
- // vm.hasLoaded = true
392
- // vm.$nextTick(() => {
393
- // vm.dragColumnDisplayOrder()
394
- // })
395
- // const currentColumn = vm.columns[oldIndex]
396
- // const targetColumn = vm.columns[newIndex]
397
- // const currentDisplayOrder = currentColumn.displayOrder
398
- // const targetDisplayOrder = targetColumn.displayOrder
399
- // vm.columns.splice(oldIndex, 1)
400
- // vm.columns.splice(newIndex, 0, currentColumn)
401
- // vm.$set(currentColumn, 'displayOrder', targetDisplayOrder)
402
- // vm.$set(currentColumn, 'displayOrderType', 'custom')
403
- // vm.$set(targetColumn, 'displayOrder', currentDisplayOrder)
404
- // vm.$set(targetColumn, 'displayOrderType', 'custom')
405
- // vm.hasLoaded = true
406
- // vm.$nextTick(() => {
407
- // vm.dragColumnDisplayOrder()
408
- // })
409
- // }, 100)
410
- },
411
- })
412
- }
413
- })
414
- },
415
- },
416
- emits: [
417
- 'open',
418
- 'opend',
419
- 'close',
420
- 'closed',
421
- 'reset',
422
- 'opend',
423
- 'close',
424
- 'closed',
425
- ],
426
- }
427
- </script>
1
+ <template>
2
+ <el-dialog
3
+ :title="$t('superGrid.columnConfig')"
4
+ width="50%"
5
+ top="5vh"
6
+ append-to-body
7
+ :close-on-click-modal="false"
8
+ :model-value="true"
9
+ :show-close="true"
10
+ @open="$emit('open')"
11
+ @opend="$emit('opend')"
12
+ @close="$emit('close')"
13
+ @closed="$emit('closed')"
14
+ >
15
+ <div class="operation-area">
16
+ <el-button type="primary" size="small" @click="saveConfig">
17
+ {{ $t('imatrixUIPublicModel.sure') }}
18
+ </el-button>
19
+ <el-button size="small" @click="resetConfig">
20
+ {{ $t('imatrixUIPublicModel.reset') }}
21
+ </el-button>
22
+ <el-button size="small" @click="$emit('close')">
23
+ {{ $t('imatrixUIPublicModel.cancel') }}
24
+ </el-button>
25
+ <span v-if="isDragColumn" style="padding-left: 10px; color: red"
26
+ >({{ $t('superGrid.dragColumnOrderMessage') }})</span
27
+ >
28
+ </div>
29
+ <el-table
30
+ v-if="hasLoaded"
31
+ :data="columns"
32
+ max-height="450"
33
+ class="custom-config-elTable"
34
+ >
35
+ <el-table-column
36
+ property="label"
37
+ :label="$t('superGrid.label')"
38
+ width="220"
39
+ >
40
+ <template v-slot="scope">
41
+ <span class="ellipsis cell--span" :title="scope.row.label">{{
42
+ scope.row.label
43
+ }}</span>
44
+ </template>
45
+ </el-table-column>
46
+ <el-table-column
47
+ property="showType"
48
+ :label="$t('superGrid.isShow')"
49
+ width="120"
50
+ >
51
+ <template v-slot="scope">
52
+ <el-select
53
+ v-model="scope.row.showType"
54
+ :disabled="isDisabledShow(scope.row)"
55
+ @change="changeShow(scope.row, $event)"
56
+ >
57
+ <el-option
58
+ :label="
59
+ isDisabledShow(scope.row)
60
+ ? $t('superGrid.default')
61
+ : $t('superGrid.show')
62
+ "
63
+ value="default"
64
+ />
65
+ <el-option :label="$t('superGrid.hidden')" value="false" />
66
+ </el-select>
67
+ </template>
68
+ </el-table-column>
69
+ <el-table-column
70
+ property="exportType"
71
+ :label="$t('superGrid.isExportable')"
72
+ width="120"
73
+ >
74
+ <template v-slot="scope">
75
+ <el-select
76
+ v-model="scope.row.exportType"
77
+ :disabled="isDisabledExport(scope.row)"
78
+ @change="changeExport(scope.row, $event)"
79
+ >
80
+ <el-option
81
+ :label="
82
+ isDisabledExport(scope.row)
83
+ ? $t('superGrid.default')
84
+ : $t('superGrid.export')
85
+ "
86
+ value="default"
87
+ />
88
+ <el-option :label="$t('superGrid.unExport')" value="false" />
89
+ </el-select>
90
+ </template>
91
+ </el-table-column>
92
+ <el-table-column
93
+ v-if="isDragColumn"
94
+ property="displayOrderType"
95
+ :label="$t('superGrid.displayOrder')"
96
+ width="120"
97
+ >
98
+ <template v-slot="scope">
99
+ <el-input
100
+ v-if="
101
+ scope.row.displayOrderType &&
102
+ scope.row.displayOrderType === 'custom'
103
+ "
104
+ v-model="scope.row.displayOrder"
105
+ clearable
106
+ size="mini"
107
+ @clear="clearDisplayOrder(scope.row)"
108
+ />
109
+ <el-select v-else v-model="scope.row.displayOrderType">
110
+ <el-option :label="$t('superGrid.default')" value="default" />
111
+ <el-option :label="$t('superGrid.custom')" value="custom" />
112
+ </el-select>
113
+ </template>
114
+ </el-table-column>
115
+ <el-table-column
116
+ property="widthType"
117
+ :label="$t('superGrid.width')"
118
+ width="120"
119
+ >
120
+ <template v-slot="scope">
121
+ <el-input
122
+ v-if="scope.row.widthType && scope.row.widthType === 'custom'"
123
+ v-model="scope.row.width"
124
+ size="mini"
125
+ clearable
126
+ @clear="clearWidth(scope.row)"
127
+ />
128
+ <el-select v-else v-model="scope.row.widthType">
129
+ <el-option :label="$t('superGrid.default')" value="default" />
130
+ <el-option :label="$t('superGrid.custom')" value="custom" />
131
+ </el-select>
132
+ </template>
133
+ </el-table-column>
134
+ </el-table>
135
+ </el-dialog>
136
+ </template>
137
+
138
+ <script>
139
+ import { $on, $off, $once, $emit } from '../../utils/gogocodeTransfer'
140
+ import * as Vue from 'vue'
141
+ import store from './store'
142
+ import Sortable from 'sortablejs'
143
+ export default {
144
+ name: 'ColumnsConfig',
145
+ props: {
146
+ listCode: {
147
+ type: String,
148
+ default: '',
149
+ },
150
+ },
151
+ data() {
152
+ return {
153
+ columns: [],
154
+ hasLoaded: false,
155
+ }
156
+ },
157
+ created() {},
158
+ mounted() {
159
+ this.listAllColumns().then((columns) => {
160
+ this.columns = columns
161
+ this.hasLoaded = true
162
+ this.$nextTick(() => {
163
+ this.dragColumnDisplayOrder()
164
+ })
165
+ })
166
+ },
167
+ methods: {
168
+ isDisabledShow(row) {
169
+ // 序号、复选框列不可以配置是否显示;占位符列不可以设置是否显示;当不是自定义的显示状态为false时,不可配置是否显示
170
+ return (
171
+ (row.prop && (row.prop === '$index' || row.prop === '$selection')) ||
172
+ row.custom === true ||
173
+ (row.showType && row.showType !== 'false' && row.show === false)
174
+ )
175
+ },
176
+ isDisabledExport(row) {
177
+ // 序号、复选框列不可以配置是否导出;占位符列不可以设置是否导出;当不是自定义的导出状态为false时,不可配置是否导出
178
+ return (
179
+ (row.prop && (row.prop === '$index' || row.prop === '$selection')) ||
180
+ row.custom === true ||
181
+ (row.exportType &&
182
+ row.exportType !== 'false' &&
183
+ row.exportable === false)
184
+ )
185
+ },
186
+ changeShow(row, value) {
187
+ if (value !== undefined && value === 'false') {
188
+ row.show = false
189
+ } else {
190
+ row.show = true
191
+ }
192
+ },
193
+ changeExport(row, value) {
194
+ if (value !== undefined && value === 'false') {
195
+ row.exportable = false
196
+ } else {
197
+ row.exportable = true
198
+ }
199
+ },
200
+ saveConfig() {
201
+ const params = {
202
+ settingColumns: this.columns,
203
+ listCode: this.listCode,
204
+ }
205
+ this.$http
206
+ .post(
207
+ window.$vueApp.config.globalProperties.baseAPI +
208
+ '/component/super-grids/setting-columns',
209
+ params
210
+ )
211
+ .then((data) => {
212
+ this.$message({
213
+ type: 'success',
214
+ message: this.$t('imatrixUIMessage.saveSuccessfully'),
215
+ showClose: true,
216
+ })
217
+ $emit(this, 'close', true)
218
+ })
219
+ },
220
+ resetConfig() {
221
+ this.$confirm(
222
+ this.$t('superGrid.whetherToConfirmReset'),
223
+ this.$t('imatrixUIMessage.tips'),
224
+ {
225
+ confirmButtonText: this.$t('imatrixUIPublicModel.sure'),
226
+ cancelButtonText: this.$t('imatrixUIPublicModel.cancel'),
227
+ type: 'warning',
228
+ }
229
+ ).then(() => {
230
+ const url =
231
+ window.$vueApp.config.globalProperties.baseAPI +
232
+ '/component/super-grids/reset-columns/' +
233
+ this.listCode
234
+ this.$http.delete(url).then(() => {
235
+ this.$message({
236
+ type: 'success',
237
+ message: this.$t('superGrid.resetSuccessful'),
238
+ showClose: true,
239
+ })
240
+ this.listAllColumns().then((columns) => {
241
+ this.columns = columns
242
+ $emit(this, 'reset', true)
243
+ })
244
+ })
245
+ })
246
+ },
247
+ listAllColumns() {
248
+ return new Promise((resolve, reject) => {
249
+ const url =
250
+ window.$vueApp.config.globalProperties.baseAPI +
251
+ '/component/super-grids/all-list-columns/' +
252
+ this.listCode
253
+ const gridParams = store.get(this.listCode)
254
+ const params = {}
255
+ const isSql = gridParams.isSql
256
+ this.isDragColumn = gridParams.colSetting.isDragColumn
257
+ if (typeof isSql !== 'undefined') {
258
+ params.isSql = isSql + ''
259
+ }
260
+ this.$http
261
+ .post(url, params)
262
+ .then((columns) => {
263
+ resolve(columns)
264
+ })
265
+ .catch((error) => {
266
+ reject(error)
267
+ })
268
+ })
269
+ },
270
+ clearDisplayOrder(row) {
271
+ row.displayOrderType = 'default'
272
+ },
273
+ clearWidth(row) {
274
+ row.widthType = 'default'
275
+ },
276
+ // 移动完成后的displayOrder设置
277
+ indexAfterTheChangeUpdateDisplayOrder(dataList, oldIndex, newIndex, prop) {
278
+ if (dataList && dataList.length > 0) {
279
+ if (oldIndex != null && oldIndex !== undefined && oldIndex !== -1) {
280
+ if (newIndex !== null && newIndex !== undefined && newIndex !== -1) {
281
+ if (prop && prop !== '') {
282
+ const selectCol = dataList[newIndex]
283
+ selectCol.displayOrderType = 'custom'
284
+ if (newIndex > oldIndex) {
285
+ // 表示向后移动
286
+ // 位置已经移动,所以参数要赋值给原始位置的下一个
287
+ const afProp = dataList[newIndex - 1][prop]
288
+ const arr = dataList.slice(oldIndex, newIndex)
289
+ if (arr && arr.length > 0) {
290
+ for (let i = arr.length - 1; i > -1; i--) {
291
+ const col = arr[i]
292
+ col.displayOrderType = 'custom'
293
+ if (i === 0) {
294
+ // 紧靠原始位置的上一个
295
+ col[prop] = selectCol[prop]
296
+ } else {
297
+ col[prop] = arr[i - 1][prop]
298
+ }
299
+ }
300
+ }
301
+ selectCol[prop] = afProp
302
+ } else {
303
+ const befProp = dataList[newIndex + 1][prop]
304
+ // 表示向前移动
305
+ // 位置已经移动,所以参数要赋值给原始位置的上一个
306
+ const arr = dataList.slice(newIndex + 1, oldIndex + 1)
307
+ if (arr && arr.length > 0) {
308
+ for (let i = 0; i < arr.length; i++) {
309
+ const col = arr[i]
310
+ col.displayOrderType = 'custom'
311
+ if (i === arr.length - 1) {
312
+ // 紧靠原始位置的上一个
313
+ col[prop] = selectCol[prop]
314
+ } else {
315
+ col[prop] = arr[i + 1][prop]
316
+ }
317
+ }
318
+ }
319
+ selectCol[prop] = befProp
320
+ }
321
+ }
322
+ }
323
+ }
324
+ }
325
+ },
326
+ // 拖动列顺序
327
+ dragColumnDisplayOrder() {
328
+ if (!this.isDragColumn) {
329
+ return
330
+ }
331
+ return new Promise((resolve, reject) => {
332
+ const tbody = document.querySelector(
333
+ '.custom-config-elTable .el-table__body-wrapper tbody'
334
+ )
335
+ if (tbody != null) {
336
+ const vm = this
337
+ Sortable.create(tbody, {
338
+ onEnd({ newIndex, oldIndex }) {
339
+ if (
340
+ oldIndex !== null &&
341
+ oldIndex !== undefined &&
342
+ oldIndex !== -1 &&
343
+ newIndex !== null &&
344
+ newIndex !== undefined &&
345
+ newIndex !== -1
346
+ ) {
347
+ if (oldIndex > newIndex) {
348
+ // 从后往前
349
+ if (vm.columns && vm.columns.length > 0) {
350
+ const item = vm.columns[oldIndex]
351
+ for (var i = oldIndex - 1; i >= newIndex; i--) {
352
+ const col = vm.columns[i]
353
+ col.displayOrderType = 'custom'
354
+ vm.columns[i + 1] = col
355
+ }
356
+ vm.columns[newIndex] = item
357
+ }
358
+ } else {
359
+ // 从前往后
360
+ if (vm.columns && vm.columns.length > 0) {
361
+ const item = vm.columns[oldIndex]
362
+ for (var k = oldIndex + 1; k <= newIndex; k++) {
363
+ const col = vm.columns[k]
364
+ col.displayOrderType = 'custom'
365
+ vm.columns[k - 1] = col
366
+ }
367
+ vm.columns[newIndex] = item
368
+ }
369
+ }
370
+ }
371
+ console.log('config拖动字段', vm.columns)
372
+ console.log('config拖动字段oldIndex', oldIndex)
373
+ console.log('config拖动字段newIndex', newIndex)
374
+ vm.hasLoaded = false
375
+ setTimeout(function () {
376
+ vm.hasLoaded = true
377
+ vm.$nextTick(() => {
378
+ vm.indexAfterTheChangeUpdateDisplayOrder(
379
+ vm.columns,
380
+ oldIndex,
381
+ newIndex,
382
+ 'displayOrder'
383
+ )
384
+ vm.dragColumnDisplayOrder()
385
+ })
386
+ }, 100)
387
+
388
+ // vm.hasLoaded = false
389
+ // // 添加setTimeout是解决拖动顺序后数组columns值改变了,但是列表没有重新渲染问题
390
+ // setTimeout(function() {
391
+ // vm.hasLoaded = true
392
+ // vm.$nextTick(() => {
393
+ // vm.dragColumnDisplayOrder()
394
+ // })
395
+ // const currentColumn = vm.columns[oldIndex]
396
+ // const targetColumn = vm.columns[newIndex]
397
+ // const currentDisplayOrder = currentColumn.displayOrder
398
+ // const targetDisplayOrder = targetColumn.displayOrder
399
+ // vm.columns.splice(oldIndex, 1)
400
+ // vm.columns.splice(newIndex, 0, currentColumn)
401
+ // vm.$set(currentColumn, 'displayOrder', targetDisplayOrder)
402
+ // vm.$set(currentColumn, 'displayOrderType', 'custom')
403
+ // vm.$set(targetColumn, 'displayOrder', currentDisplayOrder)
404
+ // vm.$set(targetColumn, 'displayOrderType', 'custom')
405
+ // vm.hasLoaded = true
406
+ // vm.$nextTick(() => {
407
+ // vm.dragColumnDisplayOrder()
408
+ // })
409
+ // }, 100)
410
+ },
411
+ })
412
+ }
413
+ })
414
+ },
415
+ },
416
+ emits: [
417
+ 'open',
418
+ 'opend',
419
+ 'close',
420
+ 'closed',
421
+ 'reset',
422
+ 'opend',
423
+ 'close',
424
+ 'closed',
425
+ ],
426
+ }
427
+ </script>