vue2-client 1.8.310 → 1.8.311

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 (215) hide show
  1. package/.env +19 -19
  2. package/.eslintrc.js +90 -90
  3. package/CHANGELOG.md +824 -824
  4. package/Components.md +60 -60
  5. package/babel.config.js +21 -21
  6. package/docs/LowCode/lowcode.md +155 -155
  7. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  8. package/docs/index.md +30 -30
  9. package/index.js +31 -31
  10. package/jest-transform-stub.js +8 -8
  11. package/jest.config.js +21 -21
  12. package/jest.setup.js +7 -7
  13. package/package.json +97 -97
  14. package/public/index.html +27 -27
  15. package/src/App.vue +188 -188
  16. package/src/ReportView.js +19 -19
  17. package/src/assets/img/querySlotDemo.svg +15 -15
  18. package/src/assets/svg/badtwo.svg +1 -1
  19. package/src/assets/svg/goodtwo.svg +1 -1
  20. package/src/base-client/components/common/AMisRender/index.js +3 -3
  21. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  22. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +438 -416
  23. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  24. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  25. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  26. package/src/base-client/components/common/CitySelect/CitySelect.vue +342 -342
  27. package/src/base-client/components/common/CitySelect/index.js +3 -3
  28. package/src/base-client/components/common/CitySelect/index.md +109 -109
  29. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  30. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  31. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  32. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  33. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  34. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  35. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  36. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  37. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  38. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  39. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  40. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  41. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  42. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  43. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  44. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  45. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +350 -350
  46. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  47. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +699 -699
  48. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  49. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +162 -162
  50. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  51. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  52. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  53. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  54. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  55. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  56. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  57. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  58. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  59. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  60. package/src/base-client/components/common/Tree/index.js +2 -2
  61. package/src/base-client/components/common/Upload/Upload.vue +239 -239
  62. package/src/base-client/components/common/Upload/index.js +3 -3
  63. package/src/base-client/components/common/XAddForm/XAddForm.vue +105 -105
  64. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +807 -807
  65. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  66. package/src/base-client/components/common/XAddNativeForm/lowcodeEditorRegister.js +16 -16
  67. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  68. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  69. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  70. package/src/base-client/components/common/XBadge/XBadge.vue +78 -78
  71. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  72. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  73. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  74. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  75. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +187 -187
  76. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +306 -306
  77. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  78. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  79. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  80. package/src/base-client/components/common/XDescriptions/lowcodeEditorRegister.js +31 -31
  81. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +214 -214
  82. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  83. package/src/base-client/components/common/XForm/XForm.vue +294 -294
  84. package/src/base-client/components/common/XForm/XFormItem.vue +911 -911
  85. package/src/base-client/components/common/XForm/XTreeSelect.vue +207 -207
  86. package/src/base-client/components/common/XForm/index.md +178 -178
  87. package/src/base-client/components/common/XFormCol/XFormCol.vue +36 -36
  88. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +241 -241
  89. package/src/base-client/components/common/XFormGroup/demo.vue +40 -40
  90. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  91. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  92. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  93. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  94. package/src/base-client/components/common/XFormTable/XFormTable.vue +539 -539
  95. package/src/base-client/components/common/XFormTable/demo.vue +72 -72
  96. package/src/base-client/components/common/XFormTable/index.md +98 -98
  97. package/src/base-client/components/common/XFormTable/lowcodeEditorRegister.js +30 -30
  98. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +147 -147
  99. package/src/base-client/components/common/XReport/XReport.vue +858 -858
  100. package/src/base-client/components/common/XReport/XReportDemo.vue +266 -266
  101. package/src/base-client/components/common/XReport/XReportDesign.vue +509 -509
  102. package/src/base-client/components/common/XReport/XReportJsonRender.vue +295 -295
  103. package/src/base-client/components/common/XReport/XReportTrGroup.vue +801 -801
  104. package/src/base-client/components/common/XReport/index.js +3 -3
  105. package/src/base-client/components/common/XReport/index.md +44 -44
  106. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  107. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  108. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  109. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  110. package/src/base-client/components/common/XStepView/index.js +3 -3
  111. package/src/base-client/components/common/XStepView/index.md +31 -31
  112. package/src/base-client/components/common/XTable/XTable.vue +676 -676
  113. package/src/base-client/components/common/XTable/index.md +255 -255
  114. package/src/base-client/components/common/XTree/XTree.vue +423 -423
  115. package/src/base-client/components/common/XTree/index.js +3 -3
  116. package/src/base-client/components/common/XTree/index.md +36 -36
  117. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +114 -114
  118. package/src/base-client/components/common/XTreeOne/lowcodeEditorRegister.js +11 -11
  119. package/src/base-client/components/index.js +51 -51
  120. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  121. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  122. package/src/base-client/plugins/AppData.js +121 -121
  123. package/src/base-client/plugins/Config.js +19 -19
  124. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  125. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  126. package/src/bootstrap.js +39 -39
  127. package/src/components/FilePreview/FilePreview.vue +166 -166
  128. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  129. package/src/components/STable/index.js +361 -361
  130. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  131. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  132. package/src/components/menu/SideMenu.vue +75 -75
  133. package/src/components/menu/menu.js +273 -273
  134. package/src/components/tool/AStepItem.vue +60 -60
  135. package/src/config/default/antd.config.js +89 -89
  136. package/src/config/default/setting.config.js +55 -55
  137. package/src/font-style/font.css +4 -4
  138. package/src/layouts/CommonLayout.vue +56 -56
  139. package/src/layouts/PageLayout.vue +151 -151
  140. package/src/layouts/SinglePageView.vue +138 -138
  141. package/src/layouts/header/AdminHeader.vue +132 -132
  142. package/src/layouts/header/HeaderNotice.vue +177 -177
  143. package/src/layouts/tabs/TabsHead.vue +189 -189
  144. package/src/layouts/tabs/TabsView.vue +387 -387
  145. package/src/lib.js +1 -1
  146. package/src/main.js +26 -26
  147. package/src/mock/extend/index.js +84 -84
  148. package/src/mock/goods/index.js +108 -108
  149. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  150. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  151. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  152. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  153. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  154. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  155. package/src/pages/DynamicStatistics/FavoriteList.vue +51 -51
  156. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  157. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  158. package/src/pages/DynamicStatistics/index.vue +282 -282
  159. package/src/pages/Example/index.vue +33 -33
  160. package/src/pages/ServiceReview/index.vue +284 -284
  161. package/src/pages/XReportView/index.vue +62 -62
  162. package/src/pages/login/Login.vue +378 -378
  163. package/src/pages/login/LoginV3.vue +389 -389
  164. package/src/pages/lowCode/lowCodeEditor.vue +1030 -1030
  165. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  166. package/src/pages/resourceManage/orgListManage.vue +98 -98
  167. package/src/pages/system/dictionary/index.vue +44 -44
  168. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  169. package/src/pages/system/monitor/operLog/index.vue +37 -37
  170. package/src/pages/system/settings/modifyPassword.vue +117 -117
  171. package/src/pages/system/ticket/index.vue +480 -480
  172. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  173. package/src/router/async/config.async.js +34 -34
  174. package/src/router/async/router.map.js +104 -104
  175. package/src/router/guards.js +223 -223
  176. package/src/router/index.js +27 -27
  177. package/src/router.js +19 -19
  178. package/src/services/api/TicketDetailsViewApi.js +46 -46
  179. package/src/services/api/cas.js +79 -79
  180. package/src/services/api/common.js +307 -307
  181. package/src/services/api/entity.js +18 -18
  182. package/src/services/api/index.js +17 -17
  183. package/src/services/api/restTools.js +46 -46
  184. package/src/services/apiService.js +14 -14
  185. package/src/services/user.js +71 -71
  186. package/src/services/v3Api.js +81 -81
  187. package/src/store/modules/index.js +5 -5
  188. package/src/store/modules/lowCode.js +33 -33
  189. package/src/store/modules/setting.js +119 -119
  190. package/src/theme/default/style.less +58 -58
  191. package/src/theme/global.less +139 -139
  192. package/src/utils/authority-utils.js +85 -85
  193. package/src/utils/errorCode.js +6 -6
  194. package/src/utils/formatter.js +80 -80
  195. package/src/utils/htmlToPDF.js +108 -108
  196. package/src/utils/htmlToPDFApi.js +5 -5
  197. package/src/utils/indexedDB.js +258 -258
  198. package/src/utils/login.js +188 -188
  199. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  200. package/src/utils/lowcode/lowcodeLog.js +29 -29
  201. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  202. package/src/utils/lowcode/registerComponentForEditor.js +11 -11
  203. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  204. package/src/utils/map-utils.js +47 -47
  205. package/src/utils/reg.js +95 -95
  206. package/src/utils/request.js +347 -347
  207. package/src/utils/routerUtil.js +435 -435
  208. package/src/utils/runEvalFunction.js +6 -6
  209. package/src/utils/util.js +241 -241
  210. package/src/utils/waterMark.js +31 -31
  211. package/test/Amis.spec.js +163 -163
  212. package/test/Tree.spec.js +167 -167
  213. package/test/myDialog.spec.js +46 -46
  214. package/vue.config.js +181 -181
  215. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,294 +1,294 @@
1
- <template>
2
- <div :style="{marginBottom: !visible ? '12px':''}">
3
- <div v-show="visible && realJsonData.length > 0" class="table-page-search-wrapper">
4
- <a-form-model
5
- v-if="loaded"
6
- ref="form"
7
- :model="form"
8
- :rules="rules"
9
- layout="inline">
10
- <a-row :gutter="24">
11
- <x-form-item
12
- v-for="(item, index) in realJsonData.slice(0,7)"
13
- :key="index"
14
- :attr="item"
15
- :form="form"
16
- :service-name="serviceName"
17
- :get-data-params="getDataParams"
18
- :env="env"
19
- :setForm="setForm"
20
- />
21
- <div v-for="(groupItem, groupIndex) in groupJsonData" :key="'group-' + groupIndex">
22
- <x-form-item
23
- v-for="(item, index) in groupItem.groupItems"
24
- :key="index"
25
- :attr="item"
26
- :form="form"
27
- :service-name="serviceName"
28
- :get-data-params="getDataParams"
29
- :env="env"
30
- :setForm="setForm"
31
- />
32
- </div>
33
- <div v-show="advanced">
34
- <x-form-item
35
- v-for="(item, index) in realJsonData.slice(7)"
36
- :key="'advanced'+index"
37
- :attr="item"
38
- :form="form"
39
- :service-name="serviceName"
40
- :get-data-params="getDataParams"
41
- :env="env"
42
- :setForm="setForm"
43
- />
44
- </div>
45
- <a-col>
46
- <span
47
- :style="advanced && { float: 'right', overflow: 'hidden' } || {} "
48
- class="table-page-search-submitButtons">
49
- <template v-if="realJsonData.length >7">
50
- <a @click="toggleAdvanced">
51
- <span v-show="!advanced" style="display: inline-flex; align-items: center;">
52
- <a-icon type="eye" :style="iconStyle"/>&nbsp;更多条件
53
- </span>
54
- <span v-show="advanced" style="display: inline-flex; align-items: center;">
55
- <a-icon type="eye-invisible" :style="iconStyle"/>&nbsp;收起更多
56
- </span>
57
- </a>
58
- <a-divider type="vertical"/>
59
- </template>
60
- <a-button
61
- htmlType="submit"
62
- type="primary"
63
- @click="onSubmit">
64
- <a-icon :style="iconStyle" type="search"/>查询
65
- </a-button>
66
- <a-button style="margin-left: 8px" @click="resetForm">重置</a-button>
67
- <slot></slot>
68
- </span>
69
- </a-col>
70
- </a-row>
71
- </a-form-model>
72
- <div class="next-divider-dashed" role="separator"></div>
73
- </div>
74
- </div>
75
- </template>
76
- <script>
77
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
78
- import { mapState } from 'vuex'
79
- import moment from 'moment'
80
-
81
- export default {
82
- name: 'XForm',
83
- components: {
84
- XFormItem
85
- },
86
- props: {},
87
- data () {
88
- return {
89
- // 内容加载是否完成
90
- loaded: false,
91
- // 服务名称
92
- serviceName: undefined,
93
- // 是否展开条件
94
- advanced: false,
95
- // 表单Model
96
- form: undefined,
97
- // 校验
98
- rules: {},
99
- // 图标样式
100
- iconStyle: {
101
- position: 'relative',
102
- top: '1px'
103
- },
104
- // 表单项集合
105
- formItems: [],
106
- // 是否显示
107
- visible: true,
108
- // 调用logic获取数据源的追加参数
109
- getDataParams: {},
110
- // 当前环境
111
- env: 'prod',
112
- // 暂存 form 的默认值
113
- defaultMap: {}
114
- }
115
- },
116
- computed: {
117
- ...mapState('account', { currUser: 'user' }),
118
- // 过滤掉仅用于新增/修改场景的表单项
119
- realJsonData: function () {
120
- return this.formItems.filter(item => (!item.isOnlyAddOrEdit && item.type !== 'group') || (item.type === 'group' && item.groupItems.some(groupItem => !groupItem.isOnlyAddOrEdit)))
121
- },
122
- // 过滤出用于新增/修改场景的表单项
123
- groupJsonData: function () {
124
- return this.formItems.filter((item) => {
125
- return item.type === 'group'
126
- }).map((item) => {
127
- item.groupItems = item.groupItems.filter(item => !item.isOnlyAddOrEdit).map((groupItem) => {
128
- // 只保留第一个下划线后面的内容
129
- // groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
130
- return groupItem
131
- })
132
- return item
133
- }
134
- )
135
- },
136
- },
137
- methods: {
138
- init (params) {
139
- const {
140
- formItems, serviceName, getDataParams = {}, env = 'prod'
141
- } = params
142
- this.loaded = false
143
- this.formItems = JSON.parse(JSON.stringify(formItems))
144
- this.serviceName = serviceName
145
- this.env = env
146
- const formData = {}
147
- for (let i = 0; i < this.realJsonData.length; i++) {
148
- const item = this.realJsonData[i]
149
- this.setFormProps(formData, item)
150
- }
151
- // 处理分组数据表单
152
- for (let i = 0; i < this.groupJsonData.length; i++) {
153
- const groupItem = this.groupJsonData[i]
154
- for (let j = 0; j < groupItem.groupItems.length; j++) {
155
- const item = groupItem.groupItems[j]
156
- this.setFormProps(formData, item)
157
- }
158
- }
159
- this.form = formData
160
- this.getDataParams = getDataParams
161
- this.loaded = true
162
- },
163
- // 时间组件赋默认值
164
- getDateRange (type, defaultValue) {
165
- const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
166
- let start, end
167
-
168
- switch (defaultValue) {
169
- case 'curYear':
170
- start = moment().startOf('year').format(format)
171
- end = moment().endOf('year').format(format)
172
- break
173
- case 'curMonth':
174
- start = moment().startOf('month').format(format)
175
- end = moment().endOf('month').format(format)
176
- break
177
- case 'curDay':
178
- start = moment().startOf('day').format(format)
179
- end = moment().endOf('day').format(format)
180
- break
181
- default:
182
- return defaultValue
183
- }
184
-
185
- return [start, end]
186
- },
187
- setFormProps (formData, item) {
188
- formData[item.model] = undefined
189
- if (item.queryFormDefault) {
190
- if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker'].includes(item.type)) {
191
- formData[item.model] = this.getDateRange(item.type, item.queryFormDefault)
192
- } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.queryFormDefault)) {
193
- if (item.queryFormDefault === 'curOrgId') {
194
- formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
195
- }
196
- if (item.queryFormDefault === 'curDepId') {
197
- formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
198
- }
199
- if (item.queryFormDefault === 'curUserId') {
200
- formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
201
- }
202
- } else {
203
- formData[item.model] = item.queryFormDefault
204
- }
205
- this.defaultMap[item.model] = formData[item.model]
206
- }
207
- if (item.rule) {
208
- this.rules[item.model] = []
209
- const required = item.rule.queryRequired ? item.rule.queryRequired === true || item.rule.queryRequired === 'true' : false
210
- let trigger
211
- let message
212
- if (required) {
213
- switch (item.type) {
214
- case 'select':
215
- case 'checkbox':
216
- case 'radio':
217
- case 'treeSelect':
218
- case 'rangePicker':
219
- case 'monthPicker':
220
- case 'yearPicker':
221
- case 'datePicker':
222
- case 'file':
223
- case 'image':
224
- case 'citySelect':
225
- case 'addressSearch':
226
- case 'personSetting':
227
- message = '请选择' + item.name
228
- trigger = 'change'
229
- break
230
- default:
231
- message = '请输入' + item.name
232
- trigger = 'blur'
233
- }
234
- this.rules[item.model].push({
235
- required: true,
236
- message: message,
237
- trigger: trigger
238
- })
239
- }
240
- }
241
- },
242
- toggleAdvanced () {
243
- this.advanced = !this.advanced
244
- this.$emit('toggleAdvanced')
245
- },
246
- toggleVisible () {
247
- this.visible = !this.visible
248
- return this.visible
249
- },
250
- resetForm () {
251
- this.$refs.form.resetFields()
252
- },
253
- onSubmit () {
254
- this.$refs.form.validate(valid => {
255
- for (const key of Object.keys(this.form)) {
256
- if (this.form[key] === null || this.form[key] === '') {
257
- this.form[key] = undefined
258
- }
259
- if (Array.isArray(this.form[key]) && !this.form[key][0]) {
260
- this.form[key] = undefined
261
- }
262
- // 如果 form 中没有值,但是有默认值
263
- if (this.form[key] === undefined && this.defaultMap[key] !== undefined) {
264
- this.form = Object.assign({}, this.form, this.defaultMap)
265
- }
266
- }
267
- const requestParameters = Object.assign({}, this.form)
268
- const data = {
269
- valid: valid,
270
- form: requestParameters
271
- }
272
- this.$emit('onSubmit', data)
273
- })
274
- },
275
- exports () {
276
- this.$emit('exports', this.form)
277
- },
278
- setForm (obj) {
279
- this.form = Object.assign(this.form, obj)
280
- },
281
- }
282
- }
283
- </script>
284
- <style lang="less" scoped>
285
- :deep(.ant-form-inline .ant-form-item) {
286
- margin-right: 0px;
287
- margin-top: 0px;
288
- margin-bottom: 12px;
289
- }
290
-
291
- :deep(.table-page-search-wrapper .table-page-search-submitButtons) {
292
- margin-top: 0px;
293
- }
294
- </style>
1
+ <template>
2
+ <div :style="{marginBottom: !visible ? '12px':''}">
3
+ <div v-show="visible && realJsonData.length > 0" class="table-page-search-wrapper">
4
+ <a-form-model
5
+ v-if="loaded"
6
+ ref="form"
7
+ :model="form"
8
+ :rules="rules"
9
+ layout="inline">
10
+ <a-row :gutter="24">
11
+ <x-form-item
12
+ v-for="(item, index) in realJsonData.slice(0,7)"
13
+ :key="index"
14
+ :attr="item"
15
+ :form="form"
16
+ :service-name="serviceName"
17
+ :get-data-params="getDataParams"
18
+ :env="env"
19
+ :setForm="setForm"
20
+ />
21
+ <div v-for="(groupItem, groupIndex) in groupJsonData" :key="'group-' + groupIndex">
22
+ <x-form-item
23
+ v-for="(item, index) in groupItem.groupItems"
24
+ :key="index"
25
+ :attr="item"
26
+ :form="form"
27
+ :service-name="serviceName"
28
+ :get-data-params="getDataParams"
29
+ :env="env"
30
+ :setForm="setForm"
31
+ />
32
+ </div>
33
+ <div v-show="advanced">
34
+ <x-form-item
35
+ v-for="(item, index) in realJsonData.slice(7)"
36
+ :key="'advanced'+index"
37
+ :attr="item"
38
+ :form="form"
39
+ :service-name="serviceName"
40
+ :get-data-params="getDataParams"
41
+ :env="env"
42
+ :setForm="setForm"
43
+ />
44
+ </div>
45
+ <a-col>
46
+ <span
47
+ :style="advanced && { float: 'right', overflow: 'hidden' } || {} "
48
+ class="table-page-search-submitButtons">
49
+ <template v-if="realJsonData.length >7">
50
+ <a @click="toggleAdvanced">
51
+ <span v-show="!advanced" style="display: inline-flex; align-items: center;">
52
+ <a-icon type="eye" :style="iconStyle"/>&nbsp;更多条件
53
+ </span>
54
+ <span v-show="advanced" style="display: inline-flex; align-items: center;">
55
+ <a-icon type="eye-invisible" :style="iconStyle"/>&nbsp;收起更多
56
+ </span>
57
+ </a>
58
+ <a-divider type="vertical"/>
59
+ </template>
60
+ <a-button
61
+ htmlType="submit"
62
+ type="primary"
63
+ @click="onSubmit">
64
+ <a-icon :style="iconStyle" type="search"/>查询
65
+ </a-button>
66
+ <a-button style="margin-left: 8px" @click="resetForm">重置</a-button>
67
+ <slot></slot>
68
+ </span>
69
+ </a-col>
70
+ </a-row>
71
+ </a-form-model>
72
+ <div class="next-divider-dashed" role="separator"></div>
73
+ </div>
74
+ </div>
75
+ </template>
76
+ <script>
77
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
78
+ import { mapState } from 'vuex'
79
+ import moment from 'moment'
80
+
81
+ export default {
82
+ name: 'XForm',
83
+ components: {
84
+ XFormItem
85
+ },
86
+ props: {},
87
+ data () {
88
+ return {
89
+ // 内容加载是否完成
90
+ loaded: false,
91
+ // 服务名称
92
+ serviceName: undefined,
93
+ // 是否展开条件
94
+ advanced: false,
95
+ // 表单Model
96
+ form: undefined,
97
+ // 校验
98
+ rules: {},
99
+ // 图标样式
100
+ iconStyle: {
101
+ position: 'relative',
102
+ top: '1px'
103
+ },
104
+ // 表单项集合
105
+ formItems: [],
106
+ // 是否显示
107
+ visible: true,
108
+ // 调用logic获取数据源的追加参数
109
+ getDataParams: {},
110
+ // 当前环境
111
+ env: 'prod',
112
+ // 暂存 form 的默认值
113
+ defaultMap: {}
114
+ }
115
+ },
116
+ computed: {
117
+ ...mapState('account', { currUser: 'user' }),
118
+ // 过滤掉仅用于新增/修改场景的表单项
119
+ realJsonData: function () {
120
+ return this.formItems.filter(item => (!item.isOnlyAddOrEdit && item.type !== 'group') || (item.type === 'group' && item.groupItems.some(groupItem => !groupItem.isOnlyAddOrEdit)))
121
+ },
122
+ // 过滤出用于新增/修改场景的表单项
123
+ groupJsonData: function () {
124
+ return this.formItems.filter((item) => {
125
+ return item.type === 'group'
126
+ }).map((item) => {
127
+ item.groupItems = item.groupItems.filter(item => !item.isOnlyAddOrEdit).map((groupItem) => {
128
+ // 只保留第一个下划线后面的内容
129
+ // groupItem.model = groupItem.model.substring(groupItem.model.indexOf('_') + 1)
130
+ return groupItem
131
+ })
132
+ return item
133
+ }
134
+ )
135
+ },
136
+ },
137
+ methods: {
138
+ init (params) {
139
+ const {
140
+ formItems, serviceName, getDataParams = {}, env = 'prod'
141
+ } = params
142
+ this.loaded = false
143
+ this.formItems = JSON.parse(JSON.stringify(formItems))
144
+ this.serviceName = serviceName
145
+ this.env = env
146
+ const formData = {}
147
+ for (let i = 0; i < this.realJsonData.length; i++) {
148
+ const item = this.realJsonData[i]
149
+ this.setFormProps(formData, item)
150
+ }
151
+ // 处理分组数据表单
152
+ for (let i = 0; i < this.groupJsonData.length; i++) {
153
+ const groupItem = this.groupJsonData[i]
154
+ for (let j = 0; j < groupItem.groupItems.length; j++) {
155
+ const item = groupItem.groupItems[j]
156
+ this.setFormProps(formData, item)
157
+ }
158
+ }
159
+ this.form = formData
160
+ this.getDataParams = getDataParams
161
+ this.loaded = true
162
+ },
163
+ // 时间组件赋默认值
164
+ getDateRange (type, defaultValue) {
165
+ const format = type === 'datePicker' ? 'YYYY-MM-DD' : 'YYYY-MM-DD HH:mm:ss'
166
+ let start, end
167
+
168
+ switch (defaultValue) {
169
+ case 'curYear':
170
+ start = moment().startOf('year').format(format)
171
+ end = moment().endOf('year').format(format)
172
+ break
173
+ case 'curMonth':
174
+ start = moment().startOf('month').format(format)
175
+ end = moment().endOf('month').format(format)
176
+ break
177
+ case 'curDay':
178
+ start = moment().startOf('day').format(format)
179
+ end = moment().endOf('day').format(format)
180
+ break
181
+ default:
182
+ return defaultValue
183
+ }
184
+
185
+ return [start, end]
186
+ },
187
+ setFormProps (formData, item) {
188
+ formData[item.model] = undefined
189
+ if (item.queryFormDefault) {
190
+ if (['datePicker', 'rangePicker', 'yearPicker', 'monthPicker'].includes(item.type)) {
191
+ formData[item.model] = this.getDateRange(item.type, item.queryFormDefault)
192
+ } else if (['treeSelect', 'select', 'checkbox'].includes(item.type) && ['curOrgId', 'curDepId', 'curUserId'].includes(item.queryFormDefault)) {
193
+ if (item.queryFormDefault === 'curOrgId') {
194
+ formData[item.model] = item.type === 'select' ? this.currUser.orgid : [this.currUser.orgid]
195
+ }
196
+ if (item.queryFormDefault === 'curDepId') {
197
+ formData[item.model] = item.type === 'select' ? this.currUser.depids : [this.currUser.depids]
198
+ }
199
+ if (item.queryFormDefault === 'curUserId') {
200
+ formData[item.model] = item.type === 'select' ? this.currUser.id : [this.currUser.id]
201
+ }
202
+ } else {
203
+ formData[item.model] = item.queryFormDefault
204
+ }
205
+ this.defaultMap[item.model] = formData[item.model]
206
+ }
207
+ if (item.rule) {
208
+ this.rules[item.model] = []
209
+ const required = item.rule.queryRequired ? item.rule.queryRequired === true || item.rule.queryRequired === 'true' : false
210
+ let trigger
211
+ let message
212
+ if (required) {
213
+ switch (item.type) {
214
+ case 'select':
215
+ case 'checkbox':
216
+ case 'radio':
217
+ case 'treeSelect':
218
+ case 'rangePicker':
219
+ case 'monthPicker':
220
+ case 'yearPicker':
221
+ case 'datePicker':
222
+ case 'file':
223
+ case 'image':
224
+ case 'citySelect':
225
+ case 'addressSearch':
226
+ case 'personSetting':
227
+ message = '请选择' + item.name
228
+ trigger = 'change'
229
+ break
230
+ default:
231
+ message = '请输入' + item.name
232
+ trigger = 'blur'
233
+ }
234
+ this.rules[item.model].push({
235
+ required: true,
236
+ message: message,
237
+ trigger: trigger
238
+ })
239
+ }
240
+ }
241
+ },
242
+ toggleAdvanced () {
243
+ this.advanced = !this.advanced
244
+ this.$emit('toggleAdvanced')
245
+ },
246
+ toggleVisible () {
247
+ this.visible = !this.visible
248
+ return this.visible
249
+ },
250
+ resetForm () {
251
+ this.$refs.form.resetFields()
252
+ },
253
+ onSubmit () {
254
+ this.$refs.form.validate(valid => {
255
+ for (const key of Object.keys(this.form)) {
256
+ if (this.form[key] === null || this.form[key] === '') {
257
+ this.form[key] = undefined
258
+ }
259
+ if (Array.isArray(this.form[key]) && !this.form[key][0]) {
260
+ this.form[key] = undefined
261
+ }
262
+ // 如果 form 中没有值,但是有默认值
263
+ if (this.form[key] === undefined && this.defaultMap[key] !== undefined) {
264
+ this.form = Object.assign({}, this.form, this.defaultMap)
265
+ }
266
+ }
267
+ const requestParameters = Object.assign({}, this.form)
268
+ const data = {
269
+ valid: valid,
270
+ form: requestParameters
271
+ }
272
+ this.$emit('onSubmit', data)
273
+ })
274
+ },
275
+ exports () {
276
+ this.$emit('exports', this.form)
277
+ },
278
+ setForm (obj) {
279
+ this.form = Object.assign(this.form, obj)
280
+ },
281
+ }
282
+ }
283
+ </script>
284
+ <style lang="less" scoped>
285
+ :deep(.ant-form-inline .ant-form-item) {
286
+ margin-right: 0px;
287
+ margin-top: 0px;
288
+ margin-bottom: 12px;
289
+ }
290
+
291
+ :deep(.table-page-search-wrapper .table-page-search-submitButtons) {
292
+ margin-top: 0px;
293
+ }
294
+ </style>