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,196 +1,196 @@
1
- import { isDynamicDataSourceSource } from './utils'
2
- const formatter = {
3
- number: function (inputValue, options) {
4
- // 小数位数
5
- const precision = options.precision
6
- // 数字符号
7
- const sign = options.sign
8
- // 是否显示千分位
9
- const isDelimiter = options.delimiter
10
- // 是否显示科学计数法
11
- const scientific = options.scientific
12
- // 几位开始计算
13
- let scientificNum = options.scientificNum
14
- if (inputValue !== undefined && inputValue != null) {
15
- if (precision > 0) {
16
- // 表示有小数
17
- inputValue = parseFloat(inputValue)
18
- inputValue = inputValue.toFixed(precision)
19
- }
20
- if (isDelimiter) {
21
- const inputValueStr = inputValue + ''
22
- const value = inputValueStr.replace(
23
- /\d{1,3}(?=(\d{3})+(\.\d*)?$)/g,
24
- '$&,'
25
- )
26
- if (sign) {
27
- return value + sign
28
- } else {
29
- return value
30
- }
31
- } else if (scientific != null) {
32
- let isScientific = false
33
- if (scientificNum) {
34
- scientificNum = parseInt(scientificNum)
35
- } else {
36
- scientificNum = 11
37
- }
38
- if (inputValue.length >= scientificNum) {
39
- isScientific = true
40
- }
41
- if (isScientific) {
42
- inputValue = '' + inputValue
43
- inputValue = parseFloat(inputValue)
44
- inputValue = inputValue.toExponential() // 转换为标准的科学计数法形式(字符串)
45
- // const tmpArray = eformat.match(/\d(?:\.(\d*))?e([+-]\d+)/) // 分离出小数值和指数值
46
- // inputValue = inputValue.toFixed(Math.max(0, (tmpArray[1] || '').length - tmpArray[2]))
47
- }
48
- } else {
49
- if (sign && !options.isCurrency) {
50
- return inputValue + sign
51
- } else {
52
- return inputValue
53
- }
54
- }
55
- }
56
-
57
- return inputValue
58
- },
59
- currency: function (value, options) {
60
- // 单位:$ 或 ¥
61
- const sign = options.sign
62
- options.isCurrency = true
63
- return sign + this.number(value, options)
64
- },
65
- date: function (value, options) {
66
- // format格式,例如:yyyy-m-d,yyyy-m-d hh:mm:ss等等
67
- const format = options.format
68
- if (value != null) {
69
- const date = new Date(value)
70
- var y = date.getFullYear()
71
- var m = date.getMonth() + 1
72
- var d = date.getDate()
73
- var h = date.getHours()
74
- var min = date.getMinutes()
75
- var s = date.getSeconds()
76
- if (m < 10) {
77
- m = '0' + m
78
- }
79
- if (d < 10) {
80
- d = '0' + d
81
- }
82
- // if (format.indexOf('hh') >= 0) {
83
- // h = h > 12 ? h - 12 : h
84
- // } else {
85
- if (h < 10) {
86
- h = '0' + h
87
- }
88
- // }
89
- if (min < 10) {
90
- min = '0' + min
91
- }
92
- if (s < 10) {
93
- s = '0' + s
94
- }
95
- const newValue = format
96
- .replace('yyyy', y)
97
- .replace('mm', min)
98
- .replace('M', m)
99
- .replace('m', m)
100
- .replace('d', d)
101
- .replace('hh', h)
102
- .replace('HH', h)
103
- .replace('ss', s)
104
- // 判断格式化的值是否包含NaN,如果包含NaN取数据库的值
105
- if (newValue.indexOf('NaN') === -1) {
106
- return newValue
107
- }
108
- return value
109
- }
110
- return value
111
- },
112
- time: function (value, options) {
113
- return this.date(value, options)
114
- },
115
- percent: function (value, options) {
116
- if (value || value >= 0) {
117
- return this.number(value, options) + '%'
118
- }
119
- return value
120
- },
121
- }
122
-
123
- export function doFormat(column, value) {
124
- value = doFormatWithValueSet(column, value)
125
- if (value === undefined || value === null) {
126
- return
127
- }
128
- // 获得默认的格式设置
129
- if (column.formatter === undefined) {
130
- if (column.dataType === 'DATE') {
131
- // 默认的“DATE”类型的格式设置
132
- column.formatter = {
133
- type: 'date',
134
- options: {
135
- format: 'yyyy-m-d',
136
- },
137
- }
138
- } else if (column.dataType === 'TIME') {
139
- // 默认的“TIME”类型的格式设置
140
- column.formatter = {
141
- type: 'time',
142
- options: {
143
- format: 'yyyy-m-d hh:mm:ss',
144
- },
145
- }
146
- }
147
- }
148
- const columnFormatter = column.formatter
149
- if (
150
- columnFormatter !== undefined &&
151
- formatter[columnFormatter.type] !== undefined
152
- ) {
153
- return formatter[columnFormatter.type](value, columnFormatter.options)
154
- } else {
155
- return value
156
- }
157
- }
158
-
159
- export function doFormatWithValueSet(column, value) {
160
- if (value === undefined || value === null) {
161
- return value
162
- }
163
- const valueSet = column.valueSet
164
- // 先处理值设置再处理格式化设置:即会对值设置的结果进行格式化设置
165
- if (valueSet !== undefined) {
166
- if (
167
- column.componentType === 'multiselect' &&
168
- !isDynamicDataSourceSource(column)
169
- ) {
170
- if (typeof value === 'number') {
171
- // 当value是0时, value instanceof Number 为false
172
- value += ''
173
- }
174
- const beforeLabel = (value + '').split(',')
175
- const label = []
176
- beforeLabel.forEach((element) => {
177
- const item = valueSet.filter((item) => {
178
- return item.value === element + ''
179
- })
180
- if (item.length > 0) {
181
- label.push(item[0].label)
182
- }
183
- })
184
- value = label.join(',')
185
- } else {
186
- const item = valueSet.filter((item) => {
187
- return item.value === value + ''
188
- })
189
- if (item.length > 0) {
190
- // 数据库的原始值要显示成label值,后续对这个label进行格式化(不是处理原始值)
191
- value = item[0].label
192
- }
193
- }
194
- }
195
- return value
196
- }
1
+ import { isDynamicDataSourceSource } from './utils'
2
+ const formatter = {
3
+ number: function (inputValue, options) {
4
+ // 小数位数
5
+ const precision = options.precision
6
+ // 数字符号
7
+ const sign = options.sign
8
+ // 是否显示千分位
9
+ const isDelimiter = options.delimiter
10
+ // 是否显示科学计数法
11
+ const scientific = options.scientific
12
+ // 几位开始计算
13
+ let scientificNum = options.scientificNum
14
+ if (inputValue !== undefined && inputValue != null) {
15
+ if (precision > 0) {
16
+ // 表示有小数
17
+ inputValue = parseFloat(inputValue)
18
+ inputValue = inputValue.toFixed(precision)
19
+ }
20
+ if (isDelimiter) {
21
+ const inputValueStr = inputValue + ''
22
+ const value = inputValueStr.replace(
23
+ /\d{1,3}(?=(\d{3})+(\.\d*)?$)/g,
24
+ '$&,'
25
+ )
26
+ if (sign) {
27
+ return value + sign
28
+ } else {
29
+ return value
30
+ }
31
+ } else if (scientific != null) {
32
+ let isScientific = false
33
+ if (scientificNum) {
34
+ scientificNum = parseInt(scientificNum)
35
+ } else {
36
+ scientificNum = 11
37
+ }
38
+ if (inputValue.length >= scientificNum) {
39
+ isScientific = true
40
+ }
41
+ if (isScientific) {
42
+ inputValue = '' + inputValue
43
+ inputValue = parseFloat(inputValue)
44
+ inputValue = inputValue.toExponential() // 转换为标准的科学计数法形式(字符串)
45
+ // const tmpArray = eformat.match(/\d(?:\.(\d*))?e([+-]\d+)/) // 分离出小数值和指数值
46
+ // inputValue = inputValue.toFixed(Math.max(0, (tmpArray[1] || '').length - tmpArray[2]))
47
+ }
48
+ } else {
49
+ if (sign && !options.isCurrency) {
50
+ return inputValue + sign
51
+ } else {
52
+ return inputValue
53
+ }
54
+ }
55
+ }
56
+
57
+ return inputValue
58
+ },
59
+ currency: function (value, options) {
60
+ // 单位:$ 或 ¥
61
+ const sign = options.sign
62
+ options.isCurrency = true
63
+ return sign + this.number(value, options)
64
+ },
65
+ date: function (value, options) {
66
+ // format格式,例如:yyyy-m-d,yyyy-m-d hh:mm:ss等等
67
+ const format = options.format
68
+ if (value != null) {
69
+ const date = new Date(value)
70
+ var y = date.getFullYear()
71
+ var m = date.getMonth() + 1
72
+ var d = date.getDate()
73
+ var h = date.getHours()
74
+ var min = date.getMinutes()
75
+ var s = date.getSeconds()
76
+ if (m < 10) {
77
+ m = '0' + m
78
+ }
79
+ if (d < 10) {
80
+ d = '0' + d
81
+ }
82
+ // if (format.indexOf('hh') >= 0) {
83
+ // h = h > 12 ? h - 12 : h
84
+ // } else {
85
+ if (h < 10) {
86
+ h = '0' + h
87
+ }
88
+ // }
89
+ if (min < 10) {
90
+ min = '0' + min
91
+ }
92
+ if (s < 10) {
93
+ s = '0' + s
94
+ }
95
+ const newValue = format
96
+ .replace('yyyy', y)
97
+ .replace('mm', min)
98
+ .replace('M', m)
99
+ .replace('m', m)
100
+ .replace('d', d)
101
+ .replace('hh', h)
102
+ .replace('HH', h)
103
+ .replace('ss', s)
104
+ // 判断格式化的值是否包含NaN,如果包含NaN取数据库的值
105
+ if (newValue.indexOf('NaN') === -1) {
106
+ return newValue
107
+ }
108
+ return value
109
+ }
110
+ return value
111
+ },
112
+ time: function (value, options) {
113
+ return this.date(value, options)
114
+ },
115
+ percent: function (value, options) {
116
+ if (value || value >= 0) {
117
+ return this.number(value, options) + '%'
118
+ }
119
+ return value
120
+ },
121
+ }
122
+
123
+ export function doFormat(column, value) {
124
+ value = doFormatWithValueSet(column, value)
125
+ if (value === undefined || value === null) {
126
+ return
127
+ }
128
+ // 获得默认的格式设置
129
+ if (column.formatter === undefined) {
130
+ if (column.dataType === 'DATE') {
131
+ // 默认的“DATE”类型的格式设置
132
+ column.formatter = {
133
+ type: 'date',
134
+ options: {
135
+ format: 'yyyy-m-d',
136
+ },
137
+ }
138
+ } else if (column.dataType === 'TIME') {
139
+ // 默认的“TIME”类型的格式设置
140
+ column.formatter = {
141
+ type: 'time',
142
+ options: {
143
+ format: 'yyyy-m-d hh:mm:ss',
144
+ },
145
+ }
146
+ }
147
+ }
148
+ const columnFormatter = column.formatter
149
+ if (
150
+ columnFormatter !== undefined &&
151
+ formatter[columnFormatter.type] !== undefined
152
+ ) {
153
+ return formatter[columnFormatter.type](value, columnFormatter.options)
154
+ } else {
155
+ return value
156
+ }
157
+ }
158
+
159
+ export function doFormatWithValueSet(column, value) {
160
+ if (value === undefined || value === null) {
161
+ return value
162
+ }
163
+ const valueSet = column.valueSet
164
+ // 先处理值设置再处理格式化设置:即会对值设置的结果进行格式化设置
165
+ if (valueSet !== undefined) {
166
+ if (
167
+ column.componentType === 'multiselect' &&
168
+ !isDynamicDataSourceSource(column)
169
+ ) {
170
+ if (typeof value === 'number') {
171
+ // 当value是0时, value instanceof Number 为false
172
+ value += ''
173
+ }
174
+ const beforeLabel = (value + '').split(',')
175
+ const label = []
176
+ beforeLabel.forEach((element) => {
177
+ const item = valueSet.filter((item) => {
178
+ return item.value === element + ''
179
+ })
180
+ if (item.length > 0) {
181
+ label.push(item[0].label)
182
+ }
183
+ })
184
+ value = label.join(',')
185
+ } else {
186
+ const item = valueSet.filter((item) => {
187
+ return item.value === value + ''
188
+ })
189
+ if (item.length > 0) {
190
+ // 数据库的原始值要显示成label值,后续对这个label进行格式化(不是处理原始值)
191
+ value = item[0].label
192
+ }
193
+ }
194
+ }
195
+ return value
196
+ }
@@ -1,99 +1,99 @@
1
- <template>
2
- <el-table-column width="150" :align="column.groupHeader ? 'center' : ''">
3
- <template v-slot:header>
4
- <span class="cell--span" :title="label" v-html="label" />
5
- </template>
6
- <template v-if="customFormat">
7
- <component
8
- :is="child.prop ? 'NormalColumn' : 'GroupColumn'"
9
- v-for="(child, index) in visibleChildren"
10
- :key="child.label + index"
11
- :column="child"
12
- :is-sql="isSql"
13
- :custom-format="child.prop ? customFormat[child.prop] : customFormat"
14
- :list-code="listCode"
15
- @findIndex="findIndex(scope.$index)"
16
- @refresData="refresData"
17
- @refresPortData="refresPortData"
18
- @refresPortsData="refresPortsData"
19
- @refresMainTableFields="refresMainTableFields"
20
- />
21
- </template>
22
- <template v-else>
23
- <component
24
- :is="child.prop ? 'NormalColumn' : 'GroupColumn'"
25
- v-for="(child, index) in visibleChildren"
26
- :key="child.label + index"
27
- :is-sql="isSql"
28
- :column="child"
29
- :list-code="listCode"
30
- />
31
- </template>
32
- </el-table-column>
33
- </template>
34
-
35
- <script>
36
- import NormalColumn from './normal-column.vue'
37
- // import GroupColumn from './group-column.vue'
38
- import { doFormatWithValueSet } from './formatter'
39
- export default {
40
- name: 'GroupColumn',
41
- components: {
42
- NormalColumn,
43
- // GroupColumn,
44
- },
45
- props: {
46
- column: {
47
- type: Object,
48
- default: null,
49
- },
50
- // 操作列、占位符列内容显示的函数,格式为:{'属性名':方法},例如:{'name':viewUser,'operation':showOperation}
51
- customFormat: {
52
- type: Object,
53
- default: null,
54
- },
55
- listCode: {
56
- type: String,
57
- default: null,
58
- },
59
- isSql: {
60
- type: Boolean,
61
- default: false,
62
- },
63
- },
64
- data() {
65
- return {
66
- label: null, // 标题
67
- }
68
- },
69
- computed: {
70
- visibleChildren() {
71
- if (this.column.children) {
72
- return this.column.children.filter((column) => {
73
- return column.show === undefined || column.show
74
- })
75
- } else {
76
- return []
77
- }
78
- },
79
- },
80
- created() {
81
- this.label = this.getHeader()
82
- },
83
- methods: {
84
- getHeader() {
85
- if (!this.column.titleValueSet) {
86
- return this.column.label.replace(/\\n/g, '</br>')
87
- } else {
88
- return this.formatHeader()
89
- }
90
- },
91
- formatHeader() {
92
- return doFormatWithValueSet(
93
- this.column.titleValueSetValue,
94
- this.column.label
95
- )
96
- },
97
- },
98
- }
99
- </script>
1
+ <template>
2
+ <el-table-column width="150" :align="column.groupHeader ? 'center' : ''">
3
+ <template v-slot:header>
4
+ <span class="cell--span" :title="label" v-html="label" />
5
+ </template>
6
+ <template v-if="customFormat">
7
+ <component
8
+ :is="child.prop ? 'NormalColumn' : 'GroupColumn'"
9
+ v-for="(child, index) in visibleChildren"
10
+ :key="child.label + index"
11
+ :column="child"
12
+ :is-sql="isSql"
13
+ :custom-format="child.prop ? customFormat[child.prop] : customFormat"
14
+ :list-code="listCode"
15
+ @findIndex="findIndex(scope.$index)"
16
+ @refresData="refresData"
17
+ @refresPortData="refresPortData"
18
+ @refresPortsData="refresPortsData"
19
+ @refresMainTableFields="refresMainTableFields"
20
+ />
21
+ </template>
22
+ <template v-else>
23
+ <component
24
+ :is="child.prop ? 'NormalColumn' : 'GroupColumn'"
25
+ v-for="(child, index) in visibleChildren"
26
+ :key="child.label + index"
27
+ :is-sql="isSql"
28
+ :column="child"
29
+ :list-code="listCode"
30
+ />
31
+ </template>
32
+ </el-table-column>
33
+ </template>
34
+
35
+ <script>
36
+ import NormalColumn from './normal-column.vue'
37
+ // import GroupColumn from './group-column.vue'
38
+ import { doFormatWithValueSet } from './formatter'
39
+ export default {
40
+ name: 'GroupColumn',
41
+ components: {
42
+ NormalColumn,
43
+ // GroupColumn,
44
+ },
45
+ props: {
46
+ column: {
47
+ type: Object,
48
+ default: null,
49
+ },
50
+ // 操作列、占位符列内容显示的函数,格式为:{'属性名':方法},例如:{'name':viewUser,'operation':showOperation}
51
+ customFormat: {
52
+ type: Object,
53
+ default: null,
54
+ },
55
+ listCode: {
56
+ type: String,
57
+ default: null,
58
+ },
59
+ isSql: {
60
+ type: Boolean,
61
+ default: false,
62
+ },
63
+ },
64
+ data() {
65
+ return {
66
+ label: null, // 标题
67
+ }
68
+ },
69
+ computed: {
70
+ visibleChildren() {
71
+ if (this.column.children) {
72
+ return this.column.children.filter((column) => {
73
+ return column.show === undefined || column.show
74
+ })
75
+ } else {
76
+ return []
77
+ }
78
+ },
79
+ },
80
+ created() {
81
+ this.label = this.getHeader()
82
+ },
83
+ methods: {
84
+ getHeader() {
85
+ if (!this.column.titleValueSet) {
86
+ return this.column.label.replace(/\\n/g, '</br>')
87
+ } else {
88
+ return this.formatHeader()
89
+ }
90
+ },
91
+ formatHeader() {
92
+ return doFormatWithValueSet(
93
+ this.column.titleValueSetValue,
94
+ this.column.label
95
+ )
96
+ },
97
+ },
98
+ }
99
+ </script>