imatrix-ui 0.2.0-up → 0.2.2-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 (213) 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 +787 -366
  5. package/lib/super-ui.umd.cjs +18 -18
  6. package/package.json +34 -34
  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 +350 -350
  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 +125 -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 -587
  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 +388 -388
  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/normal-column.vue +1221 -1221
  89. package/packages/super-grid/src/public-methods.js +30 -30
  90. package/packages/super-grid/src/row-operation.vue +193 -193
  91. package/packages/super-grid/src/search-button.vue +74 -74
  92. package/packages/super-grid/src/search-condition-input.vue +73 -73
  93. package/packages/super-grid/src/search-condition-list.vue +68 -68
  94. package/packages/super-grid/src/search-form-advancedQuery.vue +819 -826
  95. package/packages/super-grid/src/search-form-dialog.vue +77 -77
  96. package/packages/super-grid/src/search-form-item.vue +495 -495
  97. package/packages/super-grid/src/search-form-number.vue +111 -111
  98. package/packages/super-grid/src/search-form-open.vue +167 -159
  99. package/packages/super-grid/src/search-form-ordinarySearch.vue +239 -233
  100. package/packages/super-grid/src/search-form.vue +762 -765
  101. package/packages/super-grid/src/search-methods.js +592 -592
  102. package/packages/super-grid/src/selection-column.vue +46 -46
  103. package/packages/super-grid/src/super-grid-service.js +728 -728
  104. package/packages/super-grid/src/super-grid.vue +3009 -3009
  105. package/packages/super-grid/src/utils.js +880 -880
  106. package/packages/super-grid/src/view-image-dialog.vue +176 -176
  107. package/packages/super-nine-grid/index.js +7 -7
  108. package/packages/super-nine-grid/src/apis.js +108 -108
  109. package/packages/super-nine-grid/src/custom-formatter.js +73 -73
  110. package/packages/super-nine-grid/src/formatter.js +134 -134
  111. package/packages/super-nine-grid/src/search-form-number.vue +35 -35
  112. package/packages/super-nine-grid/src/search-form.vue +700 -703
  113. package/packages/super-nine-grid/src/search-methods.js +151 -151
  114. package/packages/super-nine-grid/src/super-grid-service.js +107 -107
  115. package/packages/super-nine-grid/src/super-nine-grid.vue +1164 -1164
  116. package/packages/super-nine-grid/src/utils.js +264 -264
  117. package/packages/svg-icon/index.js +6 -6
  118. package/packages/svg-icon/src/svg-icon.vue +43 -43
  119. package/packages/utils/date-util.js +292 -292
  120. package/packages/utils/dom.js +227 -227
  121. package/packages/utils/gogocodeTransfer.js +59 -59
  122. package/packages/utils/memory-cache-utils.js +117 -117
  123. package/packages/utils/utils.js +180 -180
  124. package/packages/utils/value-set.js +97 -97
  125. package/packages/valid-code/index.js +7 -7
  126. package/packages/valid-code/src/valid-code.vue +104 -104
  127. package/packages/workflow-button/index.js +6 -6
  128. package/packages/workflow-button/src/workflow-button.vue +550 -550
  129. package/packages/workflow-history-list/index.js +6 -6
  130. package/packages/workflow-history-list/src/api.js +7 -7
  131. package/packages/workflow-history-list/src/workflow-history-list.vue +291 -291
  132. package/packages/workgroup-tree/index.js +6 -6
  133. package/packages/workgroup-tree/src/workgroup-tree.vue +86 -86
  134. package/packages/workgroup-tree-inline/index.js +6 -6
  135. package/packages/workgroup-tree-inline/src/search-result.vue +222 -222
  136. package/packages/workgroup-tree-inline/src/workgroup-tree-inline.vue +516 -516
  137. package/packages/workgroup-tree-inline/src/workgroup-tree-service.js +93 -93
  138. package/packages/workgroup-user-tree/index.js +6 -6
  139. package/packages/workgroup-user-tree/src/workgroup-user-tree.vue +103 -103
  140. package/packages/workgroup-user-tree-inline/index.js +9 -9
  141. package/packages/workgroup-user-tree-inline/src/search-result.vue +266 -266
  142. package/packages/workgroup-user-tree-inline/src/workgroup-tree-inline-service.js +239 -239
  143. package/packages/workgroup-user-tree-inline/src/workgroup-user-tree-inline.vue +657 -657
  144. package/packages/year-range-picker/index.js +6 -6
  145. package/packages/year-range-picker/src/year-range-picker.vue +53 -53
  146. package/src/api/sso-service.js +172 -172
  147. package/src/api/tab.js +36 -36
  148. package/src/api/user-service.js +11 -11
  149. package/src/directives/permission/index.js +13 -13
  150. package/src/directives/permission/permission.js +20 -20
  151. package/src/i18n/langs/cn.js +259 -259
  152. package/src/i18n/langs/en.js +269 -269
  153. package/src/index.js +93 -93
  154. package/src/permission.js +160 -158
  155. package/src/plugins.js +18 -18
  156. package/src/router/index.js +110 -116
  157. package/src/store/getters.js +15 -15
  158. package/src/store/index.js +19 -19
  159. package/src/store/modules/app.js +54 -54
  160. package/src/store/modules/permission.js +145 -145
  161. package/src/store/modules/tab-content.js +36 -36
  162. package/src/store/modules/user.js +285 -285
  163. package/src/utils/auth-api.js +159 -159
  164. package/src/utils/calculator/calculator-factory-wf.js +558 -558
  165. package/src/utils/calculator/calculator-factory.js +145 -145
  166. package/src/utils/calculator/calculator-util.js +166 -166
  167. package/src/utils/eventBus.js +2 -2
  168. package/src/utils/iconUtils.js +28 -28
  169. package/src/utils/index.js +102 -102
  170. package/src/utils/jump-page-utils.js +824 -824
  171. package/src/utils/local-storage.js +7 -7
  172. package/src/utils/permission.js +31 -31
  173. package/src/utils/permissionAuth.js +96 -96
  174. package/src/utils/range-selector.js +188 -188
  175. package/src/utils/request.js +269 -269
  176. package/src/utils/restful-interface-utils.js +57 -57
  177. package/src/utils/util.js +698 -698
  178. package/src/utils/validate.js +34 -34
  179. package/src/utils/watermark.js +108 -108
  180. package/src/utils/workflow-util.js +93 -93
  181. package/src/views/404.vue +248 -248
  182. package/src/views/dsc-component/Sidebar/Item.vue +84 -84
  183. package/src/views/dsc-component/Sidebar/Link.vue +38 -38
  184. package/src/views/dsc-component/Sidebar/SidebarItem.vue +198 -198
  185. package/src/views/dsc-component/Sidebar/index.vue +228 -228
  186. package/src/views/dsc-component/tabs/tab-content.vue +203 -203
  187. package/src/views/error-page/401.vue +106 -106
  188. package/src/views/error-page/404.vue +248 -248
  189. package/src/views/layout/EmptyLayout.vue +3 -3
  190. package/src/views/layout/Layout.vue +81 -81
  191. package/src/views/layout/NewLayout.vue +18 -18
  192. package/src/views/layout/components/AppMain.vue +39 -39
  193. package/src/views/layout/components/Breadcrumb/index.vue +156 -156
  194. package/src/views/layout/components/Menubar/Item.vue +79 -79
  195. package/src/views/layout/components/Menubar/Link.vue +38 -38
  196. package/src/views/layout/components/Menubar/SidebarItem.vue +164 -164
  197. package/src/views/layout/components/Menubar/index.vue +210 -210
  198. package/src/views/layout/components/Sidebar/Item.vue +53 -53
  199. package/src/views/layout/components/Sidebar/Link.vue +38 -38
  200. package/src/views/layout/components/Sidebar/SidebarItem.vue +135 -135
  201. package/src/views/layout/components/Sidebar/index.vue +141 -141
  202. package/src/views/layout/components/iframe-page.vue +38 -38
  203. package/src/views/layout/components/index.js +4 -4
  204. package/src/views/layout/components/tabs/tab-content.vue +207 -207
  205. package/src/views/layout/mixin/ResizeHandler.js +41 -41
  206. package/src/views/layout/tab-content-iframe-index.vue +38 -38
  207. package/src/views/layout/tab-content-index.vue +93 -93
  208. package/src/views/login/authredirect.vue +10 -10
  209. package/src/views/login/index.vue +296 -296
  210. package/src/views/login/update-password.vue +243 -243
  211. package/src/views/redirect/index.vue +14 -14
  212. package/src/views/wf-history/tache-subprocess-history.vue +45 -45
  213. package/.vscode/extensions.json +0 -3
@@ -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>