vue2-client 1.4.63 → 1.5.0

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 (111) hide show
  1. package/CHANGELOG.md +498 -484
  2. package/index.js +30 -30
  3. package/package.json +78 -78
  4. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  5. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +602 -601
  6. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +713 -782
  7. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +436 -310
  8. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +508 -553
  9. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +151 -151
  10. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  11. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  12. package/src/base-client/components/common/XAddForm/XAddForm.vue +325 -354
  13. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +277 -327
  14. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  15. package/src/base-client/components/common/XForm/XForm.vue +185 -274
  16. package/src/base-client/components/common/XForm/XFormItem.vue +485 -538
  17. package/src/base-client/components/common/XForm/index.md +177 -196
  18. package/src/base-client/components/common/XFormTable/XFormTable.vue +290 -570
  19. package/src/base-client/components/common/XFormTable/index.md +96 -96
  20. package/src/base-client/components/common/XTable/XTable.vue +504 -262
  21. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +109 -109
  22. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  23. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  24. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  25. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  26. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  27. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  28. package/src/base-client/plugins/AppData.js +73 -73
  29. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  30. package/src/base-client/plugins/PagedList.js +177 -177
  31. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  32. package/src/base-client/plugins/i18n-extend.js +32 -32
  33. package/src/components/Ellipsis/index.md +38 -38
  34. package/src/components/NumberInfo/index.md +43 -43
  35. package/src/components/STable/README.md +341 -341
  36. package/src/components/STable/index.js +318 -318
  37. package/src/components/Trend/index.md +45 -45
  38. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  39. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  40. package/src/components/exception/ExceptionPage.vue +70 -70
  41. package/src/components/form/FormRow.vue +52 -52
  42. package/src/components/index.js +36 -36
  43. package/src/components/menu/SideMenu.vue +62 -62
  44. package/src/components/menu/menu.js +273 -273
  45. package/src/components/page/header/index.less +40 -40
  46. package/src/components/setting/Setting.vue +235 -235
  47. package/src/components/table/StandardTable.vue +141 -141
  48. package/src/components/table/advance/ActionColumns.vue +158 -158
  49. package/src/components/table/advance/SearchArea.vue +355 -355
  50. package/src/components/tool/AStepItem.vue +60 -60
  51. package/src/components/tool/AvatarList.vue +68 -68
  52. package/src/components/tool/Drawer.vue +142 -142
  53. package/src/components/tool/TagSelect.vue +83 -83
  54. package/src/components/transition/PageToggleTransition.vue +97 -97
  55. package/src/config/CreateQueryConfig.js +307 -313
  56. package/src/config/default/admin.config.js +18 -18
  57. package/src/config/default/setting.config.js +44 -44
  58. package/src/config/replacer/resolve.config.js +67 -67
  59. package/src/layouts/AdminLayout.vue +174 -174
  60. package/src/layouts/CommonLayout.vue +42 -42
  61. package/src/layouts/ComponentLayoutOne.vue +47 -47
  62. package/src/layouts/PageLayout.vue +151 -151
  63. package/src/layouts/SinglePageView.vue +111 -111
  64. package/src/layouts/footer/PageFooter.vue +49 -49
  65. package/src/layouts/header/AdminHeader.vue +104 -104
  66. package/src/layouts/header/HeaderAvatar.vue +61 -60
  67. package/src/layouts/header/HeaderNotice.vue +167 -167
  68. package/src/layouts/header/HeaderSearch.vue +67 -67
  69. package/src/layouts/header/InstitutionDetail.vue +181 -181
  70. package/src/layouts/header/index.less +92 -92
  71. package/src/layouts/tabs/TabsHead.vue +190 -190
  72. package/src/layouts/tabs/TabsView.vue +379 -379
  73. package/src/mock/goods/index.js +108 -108
  74. package/src/pages/exception/404.vue +25 -25
  75. package/src/pages/login/Login.vue +363 -348
  76. package/src/pages/report/ReportTable.js +124 -124
  77. package/src/pages/report/ReportTableHome.vue +28 -28
  78. package/src/pages/resourceManage/orgListManage.vue +98 -98
  79. package/src/pages/system/dictionary/index.vue +43 -43
  80. package/src/pages/system/file/index.vue +317 -317
  81. package/src/pages/system/monitor/loginInfor/index.vue +36 -36
  82. package/src/pages/system/monitor/operLog/index.vue +36 -36
  83. package/src/pages/system/queryParams/index.vue +43 -43
  84. package/src/router/async/config.async.js +27 -27
  85. package/src/router/async/router.map.js +68 -68
  86. package/src/router/guards.js +113 -104
  87. package/src/router/index.js +27 -27
  88. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  89. package/src/services/api/LogDetailsViewApi.js +10 -10
  90. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  91. package/src/services/api/TicketDetailsViewApi.js +34 -34
  92. package/src/services/api/cas.js +79 -79
  93. package/src/services/api/commonTempTable.js +10 -10
  94. package/src/services/api/index.js +17 -17
  95. package/src/services/api/logininfor/index.js +6 -6
  96. package/src/services/api/manage.js +8 -8
  97. package/src/services/apiService.js +13 -13
  98. package/src/services/user.js +53 -53
  99. package/src/store/modules/index.js +4 -4
  100. package/src/theme/default/nprogress.less +76 -76
  101. package/src/theme/default/style.less +47 -47
  102. package/src/utils/colors.js +107 -107
  103. package/src/utils/excel/Blob.js +180 -180
  104. package/src/utils/excel/Export2Excel.js +141 -141
  105. package/src/utils/formatter.js +68 -68
  106. package/src/utils/i18n.js +80 -80
  107. package/src/utils/indexedDB.js +145 -146
  108. package/src/utils/theme-color-replacer-extend.js +91 -91
  109. package/src/utils/themeUtil.js +100 -100
  110. package/src/utils/util.js +230 -230
  111. package/vue.config.js +106 -111
@@ -1,64 +1,64 @@
1
- <template>
2
- <div>
3
- <a-card :body-style="{ margin: 0, padding: 0 }" :bordered="false">
4
- <a-skeleton v-show="loadState === 'loading'" active style="padding: 16px"/>
5
- <a-empty v-show="loadState === 'empty'">
6
- <a-button type="dashed" @click="retry">
7
- 重新加载
8
- </a-button>
9
- </a-empty>
10
- <a-card
11
- v-show="loadState === 'error'"
12
- :body-style="{ margin: '0 auto' }"
13
- :bordered="false"
14
- :hoverable="true"
15
- class="retryCard"
16
- @click="retry" >
17
- <a-icon :style="{ fontSize: '28px' }" type="global"/>
18
- <p class="noSelect" style="margin-top: 20px">网络好像开小差了,点击重新加载...</p>
19
- </a-card>
20
- <div v-show="loadState === 'success'">
21
- <slot></slot>
22
- </div>
23
- </a-card>
24
- </div>
25
- </template>
26
-
27
- <script>
28
-
29
- export default {
30
- name: 'XCard',
31
- props: {
32
- loadState: {
33
- type: String,
34
- default: 'success'
35
- },
36
- retry: {
37
- type: Function,
38
- default: () => {
39
- console.error('未实现重新加载')
40
- }
41
- }
42
- },
43
- data () {
44
- return {
45
-
46
- }
47
- }
48
- }
49
- </script>
50
-
51
- <style lang="less" scoped>
52
- .retryCard {
53
- text-align: center;
54
- }
55
- .noSelect {
56
- -webkit-touch-callout: none; /* iOS Safari */
57
- -webkit-user-select: none; /* Chrome/Safari/Opera */
58
- -khtml-user-select: none; /* Konqueror */
59
- -moz-user-select: none; /* Firefox */
60
- -ms-user-select: none; /* Internet Explorer/Edge */
61
- user-select: none; /* Non-prefixed version, currently
62
- not supported by any browser */
63
- }
64
- </style>
1
+ <template>
2
+ <div>
3
+ <a-card :body-style="{ margin: 0, padding: 0 }" :bordered="false">
4
+ <a-skeleton v-show="loadState === 'loading'" active style="padding: 16px"/>
5
+ <a-empty v-show="loadState === 'empty'">
6
+ <a-button type="dashed" @click="retry">
7
+ 重新加载
8
+ </a-button>
9
+ </a-empty>
10
+ <a-card
11
+ v-show="loadState === 'error'"
12
+ :body-style="{ margin: '0 auto' }"
13
+ :bordered="false"
14
+ :hoverable="true"
15
+ class="retryCard"
16
+ @click="retry" >
17
+ <a-icon :style="{ fontSize: '28px' }" type="global"/>
18
+ <p class="noSelect" style="margin-top: 20px">网络好像开小差了,点击重新加载...</p>
19
+ </a-card>
20
+ <div v-show="loadState === 'success'">
21
+ <slot></slot>
22
+ </div>
23
+ </a-card>
24
+ </div>
25
+ </template>
26
+
27
+ <script>
28
+
29
+ export default {
30
+ name: 'XCard',
31
+ props: {
32
+ loadState: {
33
+ type: String,
34
+ default: 'success'
35
+ },
36
+ retry: {
37
+ type: Function,
38
+ default: () => {
39
+ console.error('未实现重新加载')
40
+ }
41
+ }
42
+ },
43
+ data () {
44
+ return {
45
+
46
+ }
47
+ }
48
+ }
49
+ </script>
50
+
51
+ <style lang="less" scoped>
52
+ .retryCard {
53
+ text-align: center;
54
+ }
55
+ .noSelect {
56
+ -webkit-touch-callout: none; /* iOS Safari */
57
+ -webkit-user-select: none; /* Chrome/Safari/Opera */
58
+ -khtml-user-select: none; /* Konqueror */
59
+ -moz-user-select: none; /* Firefox */
60
+ -ms-user-select: none; /* Internet Explorer/Edge */
61
+ user-select: none; /* Non-prefixed version, currently
62
+ not supported by any browser */
63
+ }
64
+ </style>
@@ -1,274 +1,185 @@
1
- <template>
2
- <div v-show="isShow" class="table-page-search-wrapper">
3
- <div v-show="advanced" ref="drawerContainer"></div>
4
- <a-form-model
5
- v-if="loaded"
6
- ref="selectForm"
7
- :model="form"
8
- :rules="rules"
9
- layout="inline">
10
- <a-row :gutter="48">
11
- <x-form-item
12
- v-for="(item, index) in realJsonData.slice(0,6)"
13
- :key="index"
14
- :attr="item"
15
- :form="form"
16
- :selects-array="SelectsArray"
17
- :service-name="serviceName"
18
- @selectsItemCheck="selectsItemCheck"
19
- />
20
- <a-drawer
21
- :get-container="() => {return $refs.drawerContainer}"
22
- :header-style="{ textAlign: 'center' }"
23
- :visible="advanced"
24
- :wrap-style="{ position: 'absolute' }"
25
- placement="top"
26
- title="更多条件"
27
- @close="onClose"
28
- >
29
- <a-form-model :model="form" layout="inline">
30
- <x-form-item
31
- v-for="(item, index) in realJsonData.slice(6)"
32
- :key="'advanced'+index"
33
- :attr="item"
34
- :form="form"
35
- :selectsArray="SelectsArray"
36
- :service-name="serviceName"
37
- @selectsItemCheck="selectsItemCheck"
38
- />
39
- </a-form-model>
40
- </a-drawer>
41
- <a-col>
42
- <span
43
- :style="advanced && { float: 'right', overflow: 'hidden' } || {} "
44
- class="table-page-search-submitButtons">
45
- <a-button htmlType="submit" style="margin-left: 8px" type="primary" @click="onSubmit">
46
- <a-icon :style="iconStyle" type="search"/>查询
47
- </a-button>
48
- <a-button style="margin-left: 8px" @click="resetForm">
49
- <a-icon :style="iconStyle" type="redo" />重置
50
- </a-button>
51
- <slot></slot>
52
- <a v-if="jsonData.length > 6" style="margin-left: 8px" @click="toggleAdvanced">
53
- 更多条件
54
- <a-icon type="down"/>
55
- </a>
56
- </span>
57
- </a-col>
58
- </a-row>
59
- </a-form-model>
60
- <div class="next-divider-dashed" role="separator"></div>
61
- </div>
62
- </template>
63
- <script>
64
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
65
- import { post } from '@vue2-client/services/api'
66
-
67
- export default {
68
- name: 'XForm',
69
- components: {
70
- XFormItem
71
- },
72
- data () {
73
- return {
74
- // 内容加载是否完成
75
- loaded: false,
76
- // 是否展开条件
77
- advanced: false,
78
- // 表单Model
79
- form: undefined,
80
- // 多层下拉框组 数据储存
81
- SelectsArray: {},
82
- // 多层下拉框组 各组数量
83
- SelectsNumber: {},
84
- // 校验
85
- rules: {},
86
- // 图标样式
87
- iconStyle: {
88
- position: 'relative',
89
- top: '1px'
90
- }
91
- }
92
- },
93
- computed: {
94
- // 过滤掉仅用于新增/修改场景的表单项 以及多个下拉框得组
95
- realJsonData: function () {
96
- return this.jsonData.filter(item => !item.isOnlyAddOrEdit)
97
- },
98
- },
99
- props: {
100
- jsonData: {
101
- type: Array,
102
- default: () => {
103
- return []
104
- }
105
- },
106
- isExports: {
107
- type: Boolean,
108
- default: () => {
109
- return true
110
- }
111
- },
112
- isShow: {
113
- type: Boolean,
114
- default: () => {
115
- return true
116
- }
117
- },
118
- serviceName: {
119
- type: String,
120
- default: 'af-system'
121
- }
122
- },
123
- mounted () {
124
- this.formItemLoad()
125
- this.getSelectsArray()
126
- },
127
- methods: {
128
- // 初始化级联框数据
129
- getSelectsArray () {
130
- const selectSate = this.jsonData.filter(item => !item.isOnlyAddOrEdit && item.group)
131
- const groupName = [...new Set(selectSate.map(item => item.group))]
132
- // 初始化数据组
133
- groupName.forEach(groupName => {
134
- this.SelectsArray[groupName] = []
135
- const SelectsItem = selectSate.filter(item => {
136
- if (item.groupIndex === 1) {
137
- if (item.keyName.substring(0, 6) === 'logic@') {
138
- // 请求logic
139
- post('/api/' + this.serviceName + '/logic/' + item.keyName.substring(6), {}).then(res => {
140
- this.SelectsArray[item.group][item.groupIndex] = res
141
- this.SelectsArray = JSON.parse(JSON.stringify(this.SelectsArray))
142
- })
143
- } else {
144
- this.SelectsArray[item.group][item.groupIndex] = JSON.parse(item.keyName)
145
- this.SelectsArray = JSON.parse(JSON.stringify(this.SelectsArray))
146
- }
147
- }
148
- return item.group === groupName
149
- }
150
- )
151
- this.SelectsNumber[groupName] = SelectsItem.length ? SelectsItem.length : 0
152
- }
153
- )
154
- this.loaded = true
155
- },
156
- selectsItemCheck (callback, groupName, index, value) {
157
- const tem = { }
158
- const group = this.realJsonData.filter(item => !item.isOnlyAddOrEdit && item.group && item.group === groupName)
159
- // 获取当前下拉框子下拉框的数据
160
- this.SelectsArray[groupName][index + 1] = this.SelectsArray[groupName][index].filter(item => item.value === value)[0].children
161
- // 清空子下拉框的子们的数据
162
- for (let i = index; i < this.SelectsNumber[groupName]; i++) {
163
- tem[group[i].model] = undefined
164
- }
165
- this.form = Object.assign({}, this.form, tem)
166
- // 清空子下拉框的子们的数据源
167
- for (let i = index + 2; i <= this.SelectsNumber[groupName]; i++) {
168
- this.SelectsArray[groupName][i] = []
169
- }
170
- callback(this.SelectsArray)
171
- },
172
- formItemLoad () {
173
- const formData = {}
174
- for (let i = 0; i < this.realJsonData.length; i++) {
175
- const item = this.realJsonData[i]
176
- formData[item.model] = undefined
177
- if (item.keys && item.model === 'rowIdValue' && item.keys.length > 0) {
178
- // 处理综合筛选下拉框默认值情况
179
- formData.rowIdName = Object.keys(item.keys[0])[0]
180
- }
181
- // 处理表单校验情况
182
- if (item.rule) {
183
- this.rules[item.model] = []
184
- // const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
185
- // let trigger
186
- // let message
187
- // if (required) {
188
- // switch (item.type) {
189
- // case 'select':
190
- // message = '请选择' + item.name
191
- // trigger = 'change'
192
- // break
193
- // default:
194
- // message = '请输入' + item.name
195
- // trigger = 'blur'
196
- // }
197
- // this.rules[item.model].push({
198
- // required: true,
199
- // message: message,
200
- // trigger: trigger
201
- // })
202
- // }
203
-
204
- switch (item.rule.type) {
205
- case 'number':
206
- case 'integer':
207
- case 'float':
208
- let defaultValue
209
- let message
210
- switch (item.rule.type) {
211
- case 'number':
212
- message = '数字'
213
- defaultValue = 0
214
- break
215
- case 'integer':
216
- message = '整数'
217
- defaultValue = 0
218
- break
219
- case 'float':
220
- message = '小数'
221
- defaultValue = 0.0
222
- break
223
- }
224
- this.rules[item.model].push({
225
- type: item.rule.type,
226
- message: item.name + '必须为' + message,
227
- transform: (value) => {
228
- if (value && value.length !== 0) {
229
- return Number(value)
230
- } else {
231
- return defaultValue
232
- }
233
- },
234
- trigger: 'blur'
235
- })
236
- break
237
- }
238
- }
239
- }
240
- this.form = formData
241
- },
242
- toggleAdvanced () {
243
- this.advanced = !this.advanced
244
- },
245
- resetForm () {
246
- this.$refs.selectForm.resetFields()
247
- },
248
- onSubmit () {
249
- this.$refs.selectForm.validate(valid => {
250
- for (const key of Object.keys(this.form)) {
251
- if (this.form[key] === null || this.form[key] === '') {
252
- this.form[key] = undefined
253
- }
254
- if (Array.isArray(this.form[key]) && !this.form[key][0]) {
255
- this.form[key] = undefined
256
- }
257
- }
258
- const requestParameters = Object.assign({}, this.form)
259
- const data = {
260
- valid: valid,
261
- form: requestParameters
262
- }
263
- this.$emit('onSubmit', data)
264
- })
265
- },
266
- exports () {
267
- this.$emit('exports', this.form)
268
- },
269
- onClose () {
270
- this.advanced = false
271
- }
272
- }
273
- }
274
- </script>
1
+ <template>
2
+ <div v-show="visible" class="table-page-search-wrapper">
3
+ <div v-show="advanced" ref="drawerContainer"></div>
4
+ <a-form-model
5
+ v-if="loaded"
6
+ ref="form"
7
+ :model="form"
8
+ :rules="rules"
9
+ layout="inline">
10
+ <a-row :gutter="48">
11
+ <x-form-item
12
+ v-for="(item, index) in realJsonData.slice(0,6)"
13
+ :key="index"
14
+ :attr="item"
15
+ :form="form"
16
+ :service-name="serviceName"
17
+ />
18
+ <a-drawer
19
+ :get-container="() => {return $refs.drawerContainer}"
20
+ :header-style="{ textAlign: 'center' }"
21
+ :visible="advanced"
22
+ :wrap-style="{ position: 'absolute' }"
23
+ placement="top"
24
+ title="更多条件"
25
+ @close="onClose"
26
+ >
27
+ <a-form-model :model="form" layout="inline">
28
+ <x-form-item
29
+ v-for="(item, index) in realJsonData.slice(6)"
30
+ :key="'advanced'+index"
31
+ :attr="item"
32
+ :form="form"
33
+ :service-name="serviceName"
34
+ />
35
+ </a-form-model>
36
+ </a-drawer>
37
+ <a-col>
38
+ <span
39
+ :style="advanced && { float: 'right', overflow: 'hidden' } || {} "
40
+ class="table-page-search-submitButtons">
41
+ <a-button htmlType="submit" style="margin-left: 8px" type="primary" @click="onSubmit">
42
+ <a-icon :style="iconStyle" type="search"/>查询
43
+ </a-button>
44
+ <a-button style="margin-left: 8px" @click="resetForm">
45
+ <a-icon :style="iconStyle" type="redo" />重置
46
+ </a-button>
47
+ <slot></slot>
48
+ <a v-if="realJsonData.length > 6" style="margin-left: 8px" @click="toggleAdvanced">
49
+ 更多条件
50
+ <a-icon type="down"/>
51
+ </a>
52
+ </span>
53
+ </a-col>
54
+ </a-row>
55
+ </a-form-model>
56
+ <div class="next-divider-dashed" role="separator"></div>
57
+ </div>
58
+ </template>
59
+ <script>
60
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
61
+
62
+ export default {
63
+ name: 'XForm',
64
+ components: {
65
+ XFormItem
66
+ },
67
+ data () {
68
+ return {
69
+ // 内容加载是否完成
70
+ loaded: false,
71
+ // 服务名称
72
+ serviceName: 'af-system',
73
+ // 是否展开条件
74
+ advanced: false,
75
+ // 表单Model
76
+ form: undefined,
77
+ // 校验
78
+ rules: {},
79
+ // 图标样式
80
+ iconStyle: {
81
+ position: 'relative',
82
+ top: '1px'
83
+ },
84
+ // 表单项集合
85
+ formItems: [],
86
+ // 是否显示
87
+ visible: true
88
+ }
89
+ },
90
+ computed: {
91
+ // 过滤掉仅用于新增/修改场景的表单项
92
+ realJsonData: function () {
93
+ return this.formItems.filter(item => !item.isOnlyAddOrEdit)
94
+ },
95
+ },
96
+ methods: {
97
+ init (params) {
98
+ const {
99
+ formItems, serviceName = 'af-system'
100
+ } = params
101
+ this.loaded = false
102
+ this.formItems = JSON.parse(JSON.stringify(formItems))
103
+ this.serviceName = serviceName
104
+ const formData = {}
105
+ for (let i = 0; i < this.realJsonData.length; i++) {
106
+ const item = this.realJsonData[i]
107
+ formData[item.model] = undefined
108
+ // 处理表单校验情况
109
+ if (item.rule) {
110
+ this.rules[item.model] = []
111
+ switch (item.rule.type) {
112
+ case 'number':
113
+ case 'integer':
114
+ case 'float':
115
+ let defaultValue
116
+ let message
117
+ switch (item.rule.type) {
118
+ case 'number':
119
+ message = '数字'
120
+ defaultValue = 0
121
+ break
122
+ case 'integer':
123
+ message = '整数'
124
+ defaultValue = 0
125
+ break
126
+ case 'float':
127
+ message = '小数'
128
+ defaultValue = 0.0
129
+ break
130
+ }
131
+ this.rules[item.model].push({
132
+ type: item.rule.type,
133
+ message: item.name + '必须为' + message,
134
+ transform: (value) => {
135
+ if (value && value.length !== 0) {
136
+ return Number(value)
137
+ } else {
138
+ return defaultValue
139
+ }
140
+ },
141
+ trigger: 'blur'
142
+ })
143
+ break
144
+ }
145
+ }
146
+ }
147
+ this.form = formData
148
+ this.loaded = true
149
+ },
150
+ toggleAdvanced () {
151
+ this.advanced = !this.advanced
152
+ },
153
+ toggleVisible () {
154
+ this.visible = !this.visible
155
+ },
156
+ resetForm () {
157
+ this.$refs.form.resetFields()
158
+ },
159
+ onSubmit () {
160
+ this.$refs.form.validate(valid => {
161
+ for (const key of Object.keys(this.form)) {
162
+ if (this.form[key] === null || this.form[key] === '') {
163
+ this.form[key] = undefined
164
+ }
165
+ if (Array.isArray(this.form[key]) && !this.form[key][0]) {
166
+ this.form[key] = undefined
167
+ }
168
+ }
169
+ const requestParameters = Object.assign({}, this.form)
170
+ const data = {
171
+ valid: valid,
172
+ form: requestParameters
173
+ }
174
+ this.$emit('onSubmit', data)
175
+ })
176
+ },
177
+ exports () {
178
+ this.$emit('exports', this.form)
179
+ },
180
+ onClose () {
181
+ this.advanced = false
182
+ }
183
+ }
184
+ }
185
+ </script>