vue2-client 0.1.0 → 1.1.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 (395) hide show
  1. package/.editorconfig +9 -0
  2. package/.env +14 -0
  3. package/.env.development +1 -0
  4. package/.eslintrc.js +81 -0
  5. package/.eslintrc.json +5 -0
  6. package/README.md +54 -36
  7. package/babel.config.js +11 -2
  8. package/docs/index.md +29 -0
  9. package/jest.config.js +3 -0
  10. package/package.json +68 -22
  11. package/public/index.html +13 -3
  12. package/src/App.vue +93 -0
  13. package/src/assets/img/alipay.png +0 -0
  14. package/src/assets/img/defect.png +0 -0
  15. package/src/assets/img/error.png +0 -0
  16. package/src/assets/img/logo.png +0 -0
  17. package/src/assets/img/preview-nine.png +0 -0
  18. package/src/assets/img/preview.png +0 -0
  19. package/src/assets/img/success.png +0 -0
  20. package/src/assets/img/success1.png +0 -0
  21. package/src/assets/img/wechatpay.png +0 -0
  22. package/src/base-client/all.js +57 -0
  23. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +1159 -0
  24. package/src/base-client/components/common/CreateQuery/index.js +3 -0
  25. package/src/base-client/components/common/CreateQuery/index.md +42 -0
  26. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +540 -0
  27. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -0
  28. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -0
  29. package/src/{components → base-client/components/common}/CustomColumnsDrawer/CustomColumnsDrawer.vue +21 -15
  30. package/src/{components → base-client/components/common}/CustomColumnsDrawer/index.js +0 -0
  31. package/src/{components → base-client/components/common}/CustomColumnsDrawer/index.md +0 -0
  32. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +150 -0
  33. package/src/base-client/components/common/FormGroupEdit/index.js +3 -0
  34. package/src/base-client/components/common/FormGroupEdit/index.md +43 -0
  35. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +163 -0
  36. package/src/base-client/components/common/FormGroupQuery/index.js +3 -0
  37. package/src/base-client/components/common/FormGroupQuery/index.md +43 -0
  38. package/src/base-client/components/common/JSONToTree/index.js +3 -0
  39. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -0
  40. package/src/base-client/components/common/XAddForm/XAddForm.vue +323 -0
  41. package/src/base-client/components/common/XAddForm/index.js +3 -0
  42. package/src/base-client/components/common/XAddForm/index.md +60 -0
  43. package/src/base-client/components/common/XBadge/XBadge.vue +61 -0
  44. package/src/base-client/components/common/XBadge/index.js +3 -0
  45. package/src/base-client/components/common/XBadge/index.md +39 -0
  46. package/src/base-client/components/common/XCard/XCard.vue +59 -0
  47. package/src/base-client/components/common/XCard/index.js +3 -0
  48. package/src/base-client/components/common/XCard/index.md +43 -0
  49. package/src/base-client/components/common/XForm/XForm.vue +275 -0
  50. package/src/base-client/components/common/XForm/XFormItem.vue +217 -0
  51. package/src/base-client/components/common/XForm/index.js +3 -0
  52. package/src/base-client/components/common/XForm/index.md +196 -0
  53. package/src/{components/FormItem/FormItem.vue → base-client/components/common/XFormCol/XFormCol.vue} +16 -14
  54. package/src/base-client/components/common/XFormCol/index.js +3 -0
  55. package/src/{components/FormItem → base-client/components/common/XFormCol}/index.md +2 -2
  56. package/src/base-client/components/common/XFormTable/XFormTable.vue +405 -0
  57. package/src/base-client/components/common/XFormTable/index.js +3 -0
  58. package/src/base-client/components/common/XFormTable/index.md +89 -0
  59. package/src/base-client/components/common/XTable/XTable.vue +262 -0
  60. package/src/base-client/components/common/XTable/index.js +3 -0
  61. package/src/base-client/components/common/XTable/index.md +255 -0
  62. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +105 -0
  63. package/src/base-client/components/common/XTreeOne/index.js +3 -0
  64. package/src/base-client/components/iot/CustomerDetailsView/CustomerDetailsView.vue +226 -0
  65. package/src/base-client/components/iot/CustomerDetailsView/index.js +3 -0
  66. package/src/base-client/components/iot/CustomerDetailsView/index.md +41 -0
  67. package/src/base-client/components/iot/DataAnalysisUser/DataAnalysisUser.vue +127 -0
  68. package/src/base-client/components/iot/DataAnalysisUser/index.js +3 -0
  69. package/src/base-client/components/iot/DataAnalysisView/DataAnalysisView.vue +250 -0
  70. package/src/base-client/components/iot/DataAnalysisView/index.js +3 -0
  71. package/src/base-client/components/iot/DataAnalysisViewGD/DataAnalysisViewGD.vue +548 -0
  72. package/src/base-client/components/iot/DataAnalysisViewGD/WindowTemplate/WindowInfotemp.vue +99 -0
  73. package/src/base-client/components/iot/DataAnalysisViewGD/WindowTemplate/index.js +3 -0
  74. package/src/base-client/components/iot/DataAnalysisViewGD/index.js +3 -0
  75. package/src/base-client/components/iot/DeviceBrandDetailsView/DeviceBrandDetailsView.vue +453 -0
  76. package/src/base-client/components/iot/DeviceBrandDetailsView/index.js +3 -0
  77. package/src/base-client/components/iot/DeviceDetailsView/DeviceDetailsView.vue +231 -0
  78. package/src/base-client/components/iot/DeviceDetailsView/index.js +3 -0
  79. package/src/base-client/components/iot/DeviceDetailsView/index.md +43 -0
  80. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsCount.vue +330 -0
  81. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsException.vue +57 -0
  82. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstruct.vue +122 -0
  83. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsInstructOperate.vue +122 -0
  84. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsMain.vue +225 -0
  85. package/src/base-client/components/iot/DeviceDetailsView/part/DeviceDetailsRead.vue +135 -0
  86. package/src/base-client/components/iot/DeviceDetailsView/part/index.js +8 -0
  87. package/src/base-client/components/iot/DeviceTypeDetailsView/DeviceTypeDetailsView.vue +277 -0
  88. package/src/base-client/components/iot/DeviceTypeDetailsView/index.js +3 -0
  89. package/src/base-client/components/iot/InstructDetailsView/InstructDetailsView.vue +472 -0
  90. package/src/{components → base-client/components/iot}/InstructDetailsView/index.js +0 -0
  91. package/src/base-client/components/iot/InstructDetailsView/index.md +45 -0
  92. package/src/base-client/components/iot/LogDetailsView/LogDetailsView.vue +380 -0
  93. package/src/base-client/components/iot/LogDetailsView/index.js +3 -0
  94. package/src/base-client/components/iot/LogDetailsView/index.md +43 -0
  95. package/src/base-client/components/iot/MeterDetailsView/MeterDetailsView.vue +360 -0
  96. package/src/{components → base-client/components/iot}/MeterDetailsView/index.js +0 -0
  97. package/src/base-client/components/iot/MeterDetailsView/index.md +43 -0
  98. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsCount.vue +335 -381
  99. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsException.vue +185 -204
  100. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsHandPlan.vue +292 -320
  101. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsInstruct.vue +237 -278
  102. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsMain.vue +257 -247
  103. package/src/{components → base-client/components/iot}/MeterDetailsView/part/MeterDetailsSellGas.vue +190 -211
  104. package/src/base-client/components/iot/MeterDetailsView/part/index.js +9 -0
  105. package/src/base-client/components/iot/WebmeterAnalysisView/WebmeterAnalysisView.vue +723 -0
  106. package/src/base-client/components/iot/WebmeterAnalysisView/index.js +3 -0
  107. package/src/base-client/components/iot/WebmeterAnalysisView/index.md +48 -0
  108. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -0
  109. package/src/base-client/components/system/DictionaryDetailsView/index.js +3 -0
  110. package/src/base-client/components/system/DictionaryDetailsView/index.md +41 -0
  111. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +248 -0
  112. package/src/base-client/components/system/QueryParamsDetailsView/index.js +3 -0
  113. package/src/base-client/components/ticket/EmployeeDetailsView/EmployeeDetailsView.vue +406 -0
  114. package/src/base-client/components/ticket/EmployeeDetailsView/index.js +3 -0
  115. package/src/base-client/components/ticket/EmployeeDetailsView/index.md +28 -0
  116. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +486 -0
  117. package/src/base-client/components/ticket/TicketDetailsView/index.js +3 -0
  118. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -0
  119. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +184 -0
  120. package/src/base-client/components/ticket/TicketDetailsView/part/index.js +3 -0
  121. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +303 -0
  122. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.js +3 -0
  123. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -0
  124. package/src/base-client/plugins/AppData.js +69 -0
  125. package/src/{plugins → base-client/plugins}/Config.js +1 -1
  126. package/src/base-client/plugins/GetLoginInfoService.js +221 -0
  127. package/src/{plugins → base-client/plugins}/PagedList.js +0 -0
  128. package/src/base-client/plugins/authority-plugin.js +167 -0
  129. package/src/base-client/plugins/i18n-extend.js +32 -0
  130. package/src/base-client/plugins/index.js +21 -0
  131. package/src/{plugins → base-client/plugins}/moment.js +8 -8
  132. package/src/base-client/plugins/tabs-page-plugin.js +38 -0
  133. package/src/bootstrap.js +27 -0
  134. package/src/components/Charts/Bar.vue +62 -0
  135. package/src/components/Charts/ChartCard.vue +120 -0
  136. package/src/components/Charts/DataUserOrderSituation.vue +77 -0
  137. package/src/components/Charts/DataUserReporting.vue +74 -0
  138. package/src/components/Charts/DataUserSituation.vue +107 -0
  139. package/src/components/Charts/Liquid.vue +67 -0
  140. package/src/components/Charts/MiniArea.vue +39 -0
  141. package/src/components/Charts/MiniBar.vue +39 -0
  142. package/src/components/Charts/MiniProgress.vue +75 -0
  143. package/src/components/Charts/MiniSmoothArea.vue +40 -0
  144. package/src/components/Charts/Radar.vue +68 -0
  145. package/src/components/Charts/RankList.vue +77 -0
  146. package/src/components/Charts/TagCloud.vue +113 -0
  147. package/src/components/Charts/TransferBar.vue +64 -0
  148. package/src/components/Charts/Trend.vue +82 -0
  149. package/src/components/Charts/chart.less +13 -0
  150. package/src/components/Charts/smooth.area.less +14 -0
  151. package/src/components/Ellipsis/Ellipsis.vue +64 -0
  152. package/src/components/Ellipsis/index.js +3 -0
  153. package/src/components/Ellipsis/index.md +38 -0
  154. package/src/components/NumberInfo/NumberInfo.vue +54 -0
  155. package/src/components/NumberInfo/index.js +3 -0
  156. package/src/components/NumberInfo/index.less +55 -0
  157. package/src/components/NumberInfo/index.md +43 -0
  158. package/src/components/STable/README.md +341 -0
  159. package/src/components/STable/index.js +316 -0
  160. package/src/components/Trend/Trend.vue +41 -0
  161. package/src/components/Trend/index.js +3 -0
  162. package/src/components/Trend/index.less +42 -0
  163. package/src/components/Trend/index.md +45 -0
  164. package/src/components/_util/util.js +46 -0
  165. package/src/components/cache/AKeepAlive.js +172 -0
  166. package/src/components/card/ChartCard.vue +79 -0
  167. package/src/components/chart/Bar.vue +60 -0
  168. package/src/components/chart/MiniArea.vue +67 -0
  169. package/src/components/chart/MiniBar.vue +59 -0
  170. package/src/components/chart/MiniProgress.vue +57 -0
  171. package/src/components/chart/Radar.vue +80 -0
  172. package/src/components/chart/RankingList.vue +60 -0
  173. package/src/components/chart/Trend.vue +79 -0
  174. package/src/components/chart/index.less +9 -0
  175. package/src/components/checkbox/ColorCheckbox.vue +157 -0
  176. package/src/components/checkbox/ImgCheckbox.vue +163 -0
  177. package/src/components/checkbox/index.js +7 -0
  178. package/src/components/dataAnalysisView/UserData.vue +61 -0
  179. package/src/components/exception/ExceptionPage.vue +70 -0
  180. package/src/components/exception/typeConfig.js +19 -0
  181. package/src/components/form/FormRow.vue +52 -0
  182. package/src/components/index.js +36 -0
  183. package/src/components/index.less +6 -0
  184. package/src/components/input/IInput.vue +66 -0
  185. package/src/components/menu/Contextmenu.vue +84 -0
  186. package/src/components/menu/SideMenu.vue +62 -0
  187. package/src/components/menu/index.less +38 -0
  188. package/src/components/menu/menu.js +273 -0
  189. package/src/components/page/header/PageHeader.vue +64 -0
  190. package/src/components/page/header/index.less +40 -0
  191. package/src/components/result/Result.vue +77 -0
  192. package/src/components/setting/Setting.vue +237 -0
  193. package/src/components/setting/SettingItem.vue +26 -0
  194. package/src/components/setting/i18n.js +117 -0
  195. package/src/components/table/StandardTable.vue +142 -0
  196. package/src/components/table/advance/ActionColumns.vue +158 -0
  197. package/src/components/table/advance/ActionSize.vue +45 -0
  198. package/src/components/table/advance/AdvanceTable.vue +275 -0
  199. package/src/components/table/advance/SearchArea.vue +355 -0
  200. package/src/components/table/advance/index.js +2 -0
  201. package/src/components/table/api/ApiTable.vue +50 -0
  202. package/src/components/task/TaskGroup.vue +80 -0
  203. package/src/components/task/TaskItem.vue +26 -0
  204. package/src/components/tool/AStepItem.vue +60 -0
  205. package/src/components/tool/AvatarList.vue +69 -0
  206. package/src/components/tool/DetailList.vue +157 -0
  207. package/src/components/tool/Drawer.vue +142 -0
  208. package/src/components/tool/FooterToolBar.vue +30 -0
  209. package/src/components/tool/HeadInfo.vue +35 -0
  210. package/src/components/tool/TagSelect.vue +83 -0
  211. package/src/components/tool/TagSelectOption.vue +33 -0
  212. package/src/components/transition/PageToggleTransition.vue +97 -0
  213. package/src/config/config.js +13 -0
  214. package/src/config/default/admin.config.js +18 -0
  215. package/src/config/default/animate.config.js +21 -0
  216. package/src/config/default/antd.config.js +84 -0
  217. package/src/config/default/index.js +6 -0
  218. package/src/config/default/setting.config.js +33 -0
  219. package/src/config/index.js +6 -0
  220. package/src/config/replacer/index.js +10 -0
  221. package/src/config/replacer/resolve.config.js +67 -0
  222. package/src/index.js +28 -35
  223. package/src/layouts/AdminLayout.vue +174 -0
  224. package/src/layouts/BlankView.vue +22 -0
  225. package/src/layouts/CommonLayout.vue +42 -0
  226. package/src/layouts/ComponentLayoutOne.vue +47 -0
  227. package/src/layouts/PageLayout.vue +151 -0
  228. package/src/layouts/PageView.vue +55 -0
  229. package/src/layouts/SinglePageView.vue +74 -0
  230. package/src/layouts/footer/PageFooter.vue +46 -0
  231. package/src/layouts/header/AdminHeader.vue +109 -0
  232. package/src/layouts/header/HeaderAvatar.vue +60 -0
  233. package/src/layouts/header/HeaderNotice.vue +97 -0
  234. package/src/layouts/header/HeaderSearch.vue +67 -0
  235. package/src/layouts/header/index.less +92 -0
  236. package/src/layouts/tabs/TabsHead.vue +190 -0
  237. package/src/layouts/tabs/TabsView.vue +355 -0
  238. package/src/layouts/tabs/i18n.js +25 -0
  239. package/src/layouts/tabs/index.js +2 -0
  240. package/src/main.js +15 -7
  241. package/src/mock/common/activityData.js +32 -0
  242. package/src/mock/common/index.js +89 -0
  243. package/src/mock/common/reportData.js +20 -0
  244. package/src/mock/common/tableData.js +118 -0
  245. package/src/mock/extend/index.js +83 -0
  246. package/src/mock/goods/index.js +108 -0
  247. package/src/mock/index.js +12 -0
  248. package/src/mock/project/index.js +17 -0
  249. package/src/mock/user/current.js +13 -0
  250. package/src/mock/user/login.js +39 -0
  251. package/src/mock/user/routes.js +61 -0
  252. package/src/mock/workplace/index.js +15 -0
  253. package/src/pages/exception/403.vue +25 -0
  254. package/src/pages/exception/404.vue +25 -0
  255. package/src/pages/exception/500.vue +25 -0
  256. package/src/pages/login/Login.vue +194 -0
  257. package/src/pages/login/index.js +2 -0
  258. package/src/pages/report/ReportTable.js +125 -0
  259. package/src/pages/report/ReportTableHome.vue +28 -0
  260. package/src/pages/resourceManage/resourceManageMain.vue +55 -0
  261. package/src/pages/system/applyInstallView/Core.vue +570 -0
  262. package/src/pages/system/applyInstallView/LFComponents/AddPanel.vue +52 -0
  263. package/src/pages/system/applyInstallView/LFComponents/Control.vue +78 -0
  264. package/src/pages/system/applyInstallView/LFComponents/DataDialog.vue +24 -0
  265. package/src/pages/system/applyInstallView/LFComponents/NodePanel.vue +103 -0
  266. package/src/pages/system/applyInstallView/PropertySetting/Base.vue +124 -0
  267. package/src/pages/system/applyInstallView/PropertySetting/CommonProperty.vue +104 -0
  268. package/src/pages/system/applyInstallView/PropertySetting/PropertyDialog.vue +43 -0
  269. package/src/pages/system/applyInstallView/background/base.png +0 -0
  270. package/src/pages/system/applyInstallView/background/click.png +0 -0
  271. package/src/pages/system/applyInstallView/background/download.png +0 -0
  272. package/src/pages/system/applyInstallView/background/end.png +0 -0
  273. package/src/pages/system/applyInstallView/background/push.png +0 -0
  274. package/src/pages/system/applyInstallView/background/start.png +0 -0
  275. package/src/pages/system/applyInstallView/background/step.png +0 -0
  276. package/src/pages/system/applyInstallView/background/time.png +0 -0
  277. package/src/pages/system/applyInstallView/config.js +22 -0
  278. package/src/pages/system/applyInstallView/data.json +1284 -0
  279. package/src/pages/system/applyInstallView/index.vue +34 -0
  280. package/src/pages/system/applyInstallView/registerNode/Connect.vue +43 -0
  281. package/src/pages/system/applyInstallView/registerNode/index.js +16 -0
  282. package/src/pages/system/applyInstallView/registerNode/registerBackEdge.js +44 -0
  283. package/src/pages/system/applyInstallView/registerNode/registerBase.js +139 -0
  284. package/src/pages/system/applyInstallView/registerNode/registerConnect.js +60 -0
  285. package/src/pages/system/applyInstallView/registerNode/registerDownload.js +92 -0
  286. package/src/pages/system/applyInstallView/registerNode/registerEnd.js +110 -0
  287. package/src/pages/system/applyInstallView/registerNode/registerPolyline.js +14 -0
  288. package/src/pages/system/applyInstallView/registerNode/registerPush.js +127 -0
  289. package/src/pages/system/applyInstallView/registerNode/registerStart.js +105 -0
  290. package/src/pages/system/applyInstallView/registerNode/registerStep.js +209 -0
  291. package/src/pages/system/applyInstallView/registerNode/registerTask.js +29 -0
  292. package/src/pages/system/dictionary/index.vue +41 -0
  293. package/src/pages/system/queryParams/index.vue +41 -0
  294. package/src/router/async/config.async.js +25 -0
  295. package/src/router/async/router.map.js +59 -0
  296. package/src/router/config.js +23 -0
  297. package/src/router/guards.js +104 -0
  298. package/src/router/i18n.js +57 -0
  299. package/src/router/index.js +27 -0
  300. package/src/services/api/CustomerDetailsViewApi.js +6 -0
  301. package/src/services/api/DeviceBrandDetailsViewApi.js +14 -0
  302. package/src/services/api/DeviceDetailsViewApi.js +10 -0
  303. package/src/services/api/DeviceTypeDetailsViewApi.js +6 -0
  304. package/src/services/api/DictionaryDetailsViewApi.js +6 -0
  305. package/src/services/api/EmployeeDetailsViewApi.js +16 -0
  306. package/src/services/api/FormGroupEditApi.js +6 -0
  307. package/src/services/api/InstructDetailsViewApi.js +12 -0
  308. package/src/services/api/LogDetailsViewApi.js +10 -0
  309. package/src/services/api/MeterDetailsViewApi.js +24 -0
  310. package/src/services/api/QueryParamsDetailsViewApi.js +6 -0
  311. package/src/services/api/TicketDetailsViewApi.js +30 -0
  312. package/src/services/api/WebmeterAnalysisViewApi.js +30 -0
  313. package/src/services/api/common.js +39 -0
  314. package/src/services/api/iot.js +7 -0
  315. package/src/services/api/manage.js +12 -0
  316. package/src/services/api/restTools.js +23 -0
  317. package/src/services/api/service.js +12 -0
  318. package/src/services/api.js +11 -0
  319. package/src/services/dataSource.js +12 -0
  320. package/src/services/index.js +7 -0
  321. package/src/services/user.js +34 -0
  322. package/src/store/index.js +5 -0
  323. package/src/store/modules/account.js +103 -0
  324. package/src/store/modules/index.js +4 -0
  325. package/src/store/modules/setting.js +114 -0
  326. package/src/store/mutation-types.js +1 -0
  327. package/src/theme/antd/ant-menu.less +3 -0
  328. package/src/theme/antd/ant-message.less +3 -0
  329. package/src/theme/antd/ant-table.less +22 -0
  330. package/src/theme/antd/ant-time-picker.less +3 -0
  331. package/src/theme/antd/index.less +4 -0
  332. package/src/theme/default/color.less +43 -0
  333. package/src/theme/default/index.less +3 -0
  334. package/src/theme/default/nprogress.less +76 -0
  335. package/src/theme/default/style.less +33 -0
  336. package/src/theme/global.less +130 -0
  337. package/src/theme/index.less +5 -0
  338. package/src/theme/reportTable.less +58 -0
  339. package/src/theme/theme.less +1 -0
  340. package/src/utils/Objects.js +25 -0
  341. package/src/utils/authority-utils.js +85 -0
  342. package/src/utils/axios-interceptors.js +82 -0
  343. package/src/utils/colors.js +103 -0
  344. package/src/utils/excel/Blob.js +181 -0
  345. package/src/utils/excel/Export2Excel.js +142 -0
  346. package/src/utils/filter.js +21 -0
  347. package/src/utils/formatter.js +68 -0
  348. package/src/utils/i18n.js +80 -0
  349. package/src/utils/indexedDB.js +146 -0
  350. package/src/utils/request.js +197 -0
  351. package/src/utils/routerUtil.js +353 -0
  352. package/src/utils/theme-color-replacer-extend.js +92 -0
  353. package/src/utils/themeUtil.js +102 -0
  354. package/src/utils/util.js +134 -0
  355. package/tests/unit/ReportTable.spec.js +15 -0
  356. package/vue.config.js +152 -0
  357. package/webpack.config.js +12 -0
  358. package/src/api/business.js +0 -30
  359. package/src/api/common.js +0 -6
  360. package/src/assets/logo.png +0 -0
  361. package/src/components/Criteria/Criteria.vue +0 -191
  362. package/src/components/Criteria/CriteriaPaged.vue +0 -50
  363. package/src/components/Criteria/index.js +0 -7
  364. package/src/components/Criteria/index.md +0 -120
  365. package/src/components/DataGrid/DataGrid.vue +0 -206
  366. package/src/components/DataGrid/index.js +0 -3
  367. package/src/components/DataGrid/index.md +0 -195
  368. package/src/components/ExportExcel/ExportExcel.vue +0 -246
  369. package/src/components/ExportExcel/index.js +0 -3
  370. package/src/components/ExportExcel/index.md +0 -76
  371. package/src/components/FormItem/index.js +0 -3
  372. package/src/components/InstructDetailsView/InstructDetailsView.vue +0 -518
  373. package/src/components/InstructDetailsView/index.md +0 -40
  374. package/src/components/MetaAnalysis/MetaAnalysis.vue +0 -183
  375. package/src/components/MetaAnalysis/demo/A.vue +0 -31
  376. package/src/components/MetaAnalysis/demo/B.vue +0 -31
  377. package/src/components/MetaAnalysis/demo/C.vue +0 -31
  378. package/src/components/MetaAnalysis/demo/MetaTest.vue +0 -44
  379. package/src/components/MetaAnalysis/index.js +0 -3
  380. package/src/components/MetaAnalysis/index.md +0 -255
  381. package/src/components/MeterDetailsView/MeterDetailsView.vue +0 -317
  382. package/src/components/MeterDetailsView/index.md +0 -40
  383. package/src/components/MeterDetailsView/part/index.js +0 -9
  384. package/src/components/ModalView/Modal.vue +0 -100
  385. package/src/components/ModalView/index.js +0 -3
  386. package/src/components/WCriteria/WCriteria.vue +0 -191
  387. package/src/components/WCriteria/WCriteriaPaged.vue +0 -95
  388. package/src/components/WCriteria/index.js +0 -7
  389. package/src/components/WCriteria/index.md +0 -120
  390. package/src/components/WTable/WTable.vue +0 -216
  391. package/src/components/WTable/index.js +0 -3
  392. package/src/components/WTable/index.md +0 -195
  393. package/src/plugins/AppData.js +0 -39
  394. package/src/plugins/GetLoginInfoService.js +0 -475
  395. package/src/plugins/MessageBox.js +0 -15
@@ -0,0 +1,275 @@
1
+ <template>
2
+ <div class="table-page-search-wrapper" v-show="isShow">
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
+ :attr="item"
14
+ :form="form"
15
+ :key="index"
16
+ />
17
+ <a-drawer
18
+ title="更多条件"
19
+ placement="top"
20
+ :get-container="() => {return $refs.drawerContainer}"
21
+ :wrap-style="{ position: 'absolute' }"
22
+ :header-style="{ textAlign: 'center' }"
23
+ :visible="advanced"
24
+ @close="onClose"
25
+ >
26
+ <a-form-model :model="form" layout="inline">
27
+ <x-form-item
28
+ v-for="(item, index) in realJsonData.slice(6)"
29
+ v-if="!item.isOnlyAddOrEdit"
30
+ :attr="item"
31
+ :form="form"
32
+ :key="'advanced'+index"
33
+ />
34
+ <div v-for="group in realJsonSelectsData" :key="group[0].group">
35
+ <x-form-col v-for="groupItem in group" :key="groupItem.group + groupItem.groupIndex">
36
+ <a-form-model-item :label="groupItem.name">
37
+ <a-select v-model="form[groupItem.model]" :disabled="itemDisabledPlus(groupItem.group,groupItem.groupIndex)" :allowClear="true" @change="selectsItemCheck(groupItem.group,groupItem.groupIndex,form[groupItem.model],group)" placeholder="请选择">
38
+ <template v-for="option in SelectsArray[groupItem.group][groupItem.groupIndex]" >
39
+ <a-select-option :key="option.label" :value="option.value">
40
+ {{ option.label }}
41
+ </a-select-option>
42
+ </template>
43
+ </a-select>
44
+ </a-form-model-item>
45
+ </x-form-col>
46
+ </div>
47
+ </a-form-model>
48
+ </a-drawer>
49
+ <a-col>
50
+ <span
51
+ class="table-page-search-submitButtons"
52
+ :style="advanced && { float: 'right', overflow: 'hidden' } || {} ">
53
+ <a-button htmlType="submit" style="margin-left: 8px" type="primary" @click="onSubmit">
54
+ <a-icon :style="iconStyle" type="search"/>查询
55
+ </a-button>
56
+ <a-button style="margin-left: 8px" @click="resetForm">
57
+ <a-icon :style="iconStyle" type="redo" />重置
58
+ </a-button>
59
+ <slot></slot>
60
+ <a @click="toggleAdvanced" style="margin-left: 8px" v-if="jsonData.length > 6 || realJsonSelectsData.length > 0">
61
+ 更多条件
62
+ <a-icon type="down"/>
63
+ </a>
64
+ </span>
65
+ </a-col>
66
+ </a-row>
67
+ </a-form-model>
68
+ <div role="separator" class="next-divider-dashed"></div>
69
+ </div>
70
+ </template>
71
+ <script>
72
+ import XFormItem from '@/base-client/components/common/XForm/XFormItem'
73
+ import { post } from '@/services/api/restTools'
74
+
75
+ export default {
76
+ name: 'XForm',
77
+ components: {
78
+ XFormItem
79
+ },
80
+ data () {
81
+ return {
82
+ // 内容加载是否完成
83
+ loaded: false,
84
+ // 是否展开条件
85
+ advanced: false,
86
+ // 表单Model
87
+ form: undefined,
88
+ // 多层下拉框组 数据储存
89
+ SelectsArray: {},
90
+ // 多层下拉框组 各组数量
91
+ SelectsNumber: {},
92
+ // 校验
93
+ rules: {},
94
+ // 图标样式
95
+ iconStyle: {
96
+ position: 'relative',
97
+ top: '1px'
98
+ }
99
+ }
100
+ },
101
+ computed: {
102
+ // 过滤掉仅用于新增/修改场景的表单项 以及多个下拉框得组
103
+ realJsonData: function () {
104
+ return this.jsonData.filter(item => !item.isOnlyAddOrEdit && !item.group)
105
+ },
106
+ // 过滤出多个下拉框分组级联得数据
107
+ realJsonSelectsData: function () {
108
+ const Selectsata = this.jsonData.filter(item => !item.isOnlyAddOrEdit && item.group)
109
+ const groupName = [...new Set(Selectsata.map(item => item.group))]
110
+ // 初始化数据组
111
+ groupName.forEach(item => {
112
+ this.SelectsArray[item] = []
113
+ })
114
+ return groupName.map(groupName => {
115
+ const SelectsItem = Selectsata.filter(item => {
116
+ if (item.groupIndex === 1) {
117
+ if (item.keyName.substring(0, 6) === 'logic@') {
118
+ // 请求logic
119
+ post('/webmeterapi/' + item.keyName.substring(6), {}).then(res => {
120
+ this.SelectsArray[item.group][item.groupIndex] = res
121
+ })
122
+ } else {
123
+ this.SelectsArray[item.group][item.groupIndex] = JSON.parse(item.keyName)
124
+ }
125
+ }
126
+ return item.group === groupName
127
+ }
128
+ )
129
+ this.SelectsNumber[groupName] = SelectsItem.length ? SelectsItem.length : 0
130
+ return SelectsItem
131
+ })
132
+ }
133
+ },
134
+ props: {
135
+ jsonData: {
136
+ type: Array,
137
+ default: () => {
138
+ return []
139
+ }
140
+ },
141
+ isExports: {
142
+ type: Boolean,
143
+ default: () => {
144
+ return true
145
+ }
146
+ },
147
+ isShow: {
148
+ type: Boolean,
149
+ default: () => {
150
+ return true
151
+ }
152
+ }
153
+ },
154
+ mounted () {
155
+ this.formItemLoad()
156
+ },
157
+ methods: {
158
+ itemDisabledPlus (group, index) {
159
+ return (!this.SelectsArray[group][index]) || (this.SelectsArray[group][index] && this.SelectsArray[group][index].length === 0)
160
+ },
161
+ selectsItemCheck (groupName, index, value, group) {
162
+ const tem = { }
163
+ // 获取当前下拉框子下拉框的数据
164
+ this.SelectsArray[groupName][index + 1] = this.SelectsArray[groupName][index].filter(item => item.value === value)[0].children
165
+ // 清空子下拉框的子们的数据
166
+ for (let i = index; i < this.SelectsNumber[groupName]; i++) {
167
+ tem[group[i].model] = undefined
168
+ }
169
+ this.form = Object.assign({}, this.form, tem)
170
+ // 清空子下拉框的子们的数据源
171
+ for (let i = index + 2; i <= this.SelectsNumber[groupName]; i++) {
172
+ this.SelectsArray[groupName][i] = []
173
+ }
174
+ },
175
+ formItemLoad () {
176
+ const formData = {}
177
+ for (let i = 0; i < this.realJsonData.length; i++) {
178
+ const item = this.realJsonData[i]
179
+ formData[item.model] = undefined
180
+ if (item.keys && item.model === 'rowIdValue' && item.keys.length > 0) {
181
+ // 处理综合筛选下拉框默认值情况
182
+ formData.rowIdName = Object.keys(item.keys[0])[0]
183
+ }
184
+ // 处理表单校验情况
185
+ if (item.rule) {
186
+ this.rules[item.model] = []
187
+ // const required = item.rule.required ? item.rule.required === true || item.rule.required === 'true' : false
188
+ // let trigger
189
+ // let message
190
+ // if (required) {
191
+ // switch (item.type) {
192
+ // case 'select':
193
+ // message = '请选择' + item.name
194
+ // trigger = 'change'
195
+ // break
196
+ // default:
197
+ // message = '请输入' + item.name
198
+ // trigger = 'blur'
199
+ // }
200
+ // this.rules[item.model].push({
201
+ // required: true,
202
+ // message: message,
203
+ // trigger: trigger
204
+ // })
205
+ // }
206
+
207
+ switch (item.rule.type) {
208
+ case 'number':
209
+ case 'integer':
210
+ case 'float':
211
+ let defaultValue
212
+ let message
213
+ switch (item.rule.type) {
214
+ case 'number':
215
+ message = '数字'
216
+ defaultValue = 0
217
+ break
218
+ case 'integer':
219
+ message = '整数'
220
+ defaultValue = 0
221
+ break
222
+ case 'float':
223
+ message = '小数'
224
+ defaultValue = 0.0
225
+ break
226
+ }
227
+ this.rules[item.model].push({
228
+ type: item.rule.type,
229
+ message: item.name + '必须为' + message,
230
+ transform: (value) => {
231
+ if (value && value.length !== 0) {
232
+ return Number(value)
233
+ } else {
234
+ return defaultValue
235
+ }
236
+ },
237
+ trigger: 'blur'
238
+ })
239
+ break
240
+ }
241
+ }
242
+ }
243
+ this.form = formData
244
+ this.loaded = true
245
+ },
246
+ toggleAdvanced () {
247
+ this.advanced = !this.advanced
248
+ },
249
+ resetForm () {
250
+ this.$refs.selectForm.resetFields()
251
+ },
252
+ onSubmit () {
253
+ this.$refs.selectForm.validate(valid => {
254
+ for (const key of Object.keys(this.form)) {
255
+ if (this.form[key] === null || this.form[key] === '') {
256
+ this.form[key] = undefined
257
+ }
258
+ }
259
+ const requestParameters = Object.assign({}, this.form)
260
+ const data = {
261
+ valid: valid,
262
+ form: requestParameters
263
+ }
264
+ this.$emit('onSubmit', data)
265
+ })
266
+ },
267
+ exports () {
268
+ this.$emit('exports', this.form)
269
+ },
270
+ onClose () {
271
+ this.advanced = false
272
+ }
273
+ }
274
+ }
275
+ </script>
@@ -0,0 +1,217 @@
1
+ <template>
2
+ <!-- 综合筛选 -->
3
+ <x-form-col
4
+ :xl="xl"
5
+ :xxl="xxl"
6
+ v-if="attr.type === 'select' && attr.model === 'rowIdValue'">
7
+ <a-form-model-item
8
+ :ref="attr.model"
9
+ :label="attr.name"
10
+ :prop="attr.model">
11
+ <a-input :disabled="disabled" v-model="form[attr.model]">
12
+ <a-select
13
+ slot="addonBefore"
14
+ v-model="form['rowIdName']"
15
+ style="width: 100px">
16
+ <a-select-option
17
+ v-for="(item,index) in attr.keys"
18
+ :key="index"
19
+ :value="Object.keys(item)[0]">{{ item[Object.keys(item)[0]] }}
20
+ </a-select-option>
21
+ </a-select>
22
+ </a-input>
23
+ </a-form-model-item>
24
+ </x-form-col>
25
+ <!-- 输入框 -->
26
+ <x-form-col
27
+ :xl="xl"
28
+ :xxl="xxl"
29
+ v-else-if="attr.type === 'input'">
30
+ <a-form-model-item
31
+ :ref="attr.model"
32
+ :label="attr.name"
33
+ :prop="attr.model">
34
+ <a-input :disabled="disabled" v-model="form[attr.model]" :placeholder="attr.placeholder ? attr.placeholder : '请输入'+attr.name.replace(/\s*/g, '')"/>
35
+ </a-form-model-item>
36
+ </x-form-col>
37
+ <!-- 下拉框 -->
38
+ <x-form-col
39
+ :xl="xl"
40
+ :xxl="xxl"
41
+ v-else-if="attr.type === 'select'">
42
+ <a-form-model-item
43
+ :ref="attr.model"
44
+ :label="attr.name"
45
+ :prop="attr.model">
46
+ <a-select
47
+ v-model="form[attr.model]"
48
+ :disabled="disabled"
49
+ show-search
50
+ :placeholder="attr.placeholder ? attr.placeholder : '请选择'"
51
+ :filter-option="filterOption"
52
+ >
53
+ <a-select-option
54
+ v-if="mode === '查询'"
55
+ key="999999"
56
+ value="全部">全部
57
+ </a-select-option>
58
+ <template v-if="attr.keys">
59
+ <a-select-option
60
+ v-for="(item,index) in attr.keys"
61
+ :key="index"
62
+ :value="Object.keys(item)[0]">
63
+ {{ item[Object.keys(item)[0]] }}
64
+ </a-select-option>
65
+ </template>
66
+ <template v-else>
67
+ <template v-if="attr.keyName.indexOf('logic@') !== -1">
68
+ <a-select-option
69
+ v-for="(item,index) in option"
70
+ :key="index"
71
+ :value="Object.keys(item)[0]">{{ item[Object.keys(item)[0]] }}
72
+ </a-select-option>
73
+ </template>
74
+ <template v-else>
75
+ <a-select-option
76
+ v-for="item in $appdata.getDictionaryList(attr.keyName)"
77
+ :key="item.value"
78
+ :value="item.value">
79
+ <!-- 徽标(badge) -->
80
+ <x-badge :badge-key="attr.keyName" :value="item.value" :replaceText="item.text"/>
81
+ </a-select-option>
82
+ </template>
83
+ </template>
84
+ </a-select>
85
+ </a-form-model-item>
86
+ </x-form-col>
87
+ <!-- TODO 多选框 -->
88
+ <!-- TODO 单选框 -->
89
+ <!-- 日期范围选择器 -->
90
+ <x-form-col
91
+ :xl="xl"
92
+ :xxl="xxl"
93
+ v-else-if="attr.type === 'rangePicker'">
94
+ <a-form-model-item :ref="attr.model" :label="attr.name" :prop="attr.model">
95
+ <a-range-picker :disabled="disabled" :show-time="true" v-model="form[attr.model]" valueFormat="YYYY-MM-DD HH:mm:ss"/>
96
+ </a-form-model-item>
97
+ </x-form-col>
98
+ <!-- 月份选择器 -->
99
+ <x-form-col
100
+ :xl="xl"
101
+ :xxl="xxl"
102
+ v-else-if="attr.type === 'monthPicker'">
103
+ <a-form-model-item :ref="attr.model" :label="attr.name" :prop="attr.model">
104
+ <a-month-picker :disabled="disabled" :show-time="true" v-model="form[attr.model]" valueFormat="YYYY-MM"/>
105
+ </a-form-model-item>
106
+ </x-form-col>
107
+ <!-- 日期选择器 -->
108
+ <x-form-col
109
+ :xl="xl"
110
+ :xxl="xxl"
111
+ v-else-if="attr.type === 'datePicker'">
112
+ <a-form-model-item :ref="attr.model" :label="attr.name" :prop="attr.model">
113
+ <a-date-picker :disabled="disabled" :show-time="true" v-model="form[attr.model]" valueFormat="YYYY-MM-DD"/>
114
+ </a-form-model-item>
115
+ </x-form-col>
116
+ <!-- 级联选择器 -->
117
+ <x-form-col
118
+ :xl="xl"
119
+ :xxl="xxl"
120
+ v-else-if="attr.type === 'cascader'">
121
+ <a-form-model-item :ref="attr.model" :label="attr.name" :prop="attr.model">
122
+ <template v-if="attr.keys">
123
+ <a-dcascader :disabled="disabled" :option="attr.keys" :value="form[attr.model]"/>
124
+ </template>
125
+ <template v-else>
126
+ <a-dcascader :disabled="disabled" :option="option" :value="form[attr.model]"/>
127
+ </template>
128
+ </a-form-model-item>
129
+ </x-form-col>
130
+ <!-- 文本域 -->
131
+ <x-form-col
132
+ :xl="24"
133
+ :xxl="24"
134
+ :xs="24"
135
+ :sm="24"
136
+ :md="24"
137
+ :lg="24"
138
+ v-else-if="attr.type === 'textarea'">
139
+ <a-form-model-item
140
+ :ref="attr.model"
141
+ :label="attr.name"
142
+ :prop="attr.model">
143
+ <a-textarea :rows="4" :disabled="disabled" v-model="form[attr.model]" :placeholder="attr.placeholder ? attr.placeholder : '请输入'+attr.name.replace(/\s*/g, '')"/>
144
+ </a-form-model-item>
145
+ </x-form-col>
146
+ <!-- TODO 文件上传 -->
147
+ <!-- TODO 图片上传 -->
148
+ </template>
149
+ <script>
150
+
151
+ import { post } from '@/services/api/restTools'
152
+
153
+ export default {
154
+ name: 'XFormItem',
155
+ data () {
156
+ return {
157
+ option: []
158
+ }
159
+ },
160
+ props: {
161
+ attr: {
162
+ type: Object,
163
+ default: () => {
164
+ return {}
165
+ }
166
+ },
167
+ form: {
168
+ type: Object,
169
+ default: () => {
170
+ return {}
171
+ }
172
+ },
173
+ disabled: {
174
+ type: Boolean,
175
+ default: () => {
176
+ return false
177
+ }
178
+ },
179
+ mode: {
180
+ type: String,
181
+ default: () => {
182
+ return '查询'
183
+ }
184
+ },
185
+ xl: {
186
+ type: Number,
187
+ default: undefined
188
+ },
189
+ xxl: {
190
+ type: Number,
191
+ default: undefined
192
+ }
193
+ },
194
+ created () {
195
+ if (this.attr.keyName && this.attr.keyName.indexOf('logic@') !== -1) {
196
+ const logicName = this.attr.keyName
197
+ const logic = logicName.substring(6)
198
+ post('/webmeterapi/' + logic, {}).then(res => {
199
+ this.option = res
200
+ })
201
+ }
202
+ },
203
+ methods: {
204
+ filterOption (input, option) {
205
+ if (option.componentOptions.children[0].text) {
206
+ return (
207
+ option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
208
+ )
209
+ } else {
210
+ return (
211
+ option.componentOptions.children[0].child.value.toLowerCase().indexOf(input.toLowerCase()) >= 0
212
+ )
213
+ }
214
+ }
215
+ }
216
+ }
217
+ </script>
@@ -0,0 +1,3 @@
1
+ import XForm from './XForm'
2
+
3
+ export default XForm
@@ -0,0 +1,196 @@
1
+ # XForm
2
+
3
+ 动态表单控件,根据JSON配置生成一个完整的动态表单
4
+
5
+
6
+ ## 何时使用
7
+
8
+ 当需要一个动态生成的表单时
9
+
10
+
11
+ 引用方式:
12
+
13
+ ```javascript
14
+ import XForm from '@/base-client/components/XForm/XForm'
15
+
16
+ export default {
17
+ components: {
18
+ XForm
19
+ }
20
+ }
21
+ ```
22
+
23
+
24
+
25
+ ## 代码演示
26
+
27
+ ```html
28
+ <x-form
29
+ :json-data="json"
30
+ :isExports="true"
31
+ @onSubmit="onSubmit">
32
+ </x-form>
33
+ ```
34
+
35
+ ## API
36
+
37
+ | 参数 | 说明 | 类型 | 默认值 |
38
+ |-----------|--------------------------|---------|------|
39
+ | jsonData | JSON配置,根据[工具>查询配置生成]功能生成 | Object | {} |
40
+ | isExports | 是否显示导出按钮 | Boolean | true |
41
+ | @onSubmit | 表单的提交事件 | event | - |
42
+
43
+ ## 例子1
44
+ ----
45
+ (基础使用)
46
+
47
+ ```vue
48
+ <template>
49
+ <x-form
50
+ v-if="loaded"
51
+ :json-data="formItemJson"
52
+ :isExports="false"
53
+ @onSubmit="onSubmit">
54
+ </x-form>
55
+ </template>
56
+
57
+ <script>
58
+ import XForm from '@/base-client/components/XForm/XForm'
59
+
60
+ export default {
61
+ components: {
62
+ XForm
63
+ },
64
+ data () {
65
+ return {
66
+ // 加载查询参数JSON配置文件是否完成
67
+ loaded: false,
68
+ // 从查询参数JSON配置中得到的生成表单的JSON
69
+ formItemJson: undefined,
70
+ // 表单
71
+ form: {}
72
+ }
73
+ },
74
+ created () {
75
+ this.getQueryJson()
76
+ },
77
+ methods: {
78
+ // 加载查询参数JSON配置文件
79
+ getQueryJson () {
80
+ this.formItemJson = [
81
+ {
82
+ "keys":[
83
+ {
84
+ "f_userinfo_code":"用户编号"
85
+ },
86
+ {
87
+ "f_user_name":"用户姓名"
88
+ },
89
+ {
90
+ "f_meternumber":"表号"
91
+ },
92
+ {
93
+ "f_address":"用户地址"
94
+ }
95
+ ],
96
+ "name":"综合筛选",
97
+ "model":"rowIdValue",
98
+ "type":"select"
99
+ },
100
+ {
101
+ "name":"燃气公司",
102
+ "keyName":"orgList",
103
+ "model":"orgName",
104
+ "placeholder":"请选择",
105
+ "type":"select"
106
+ },
107
+ {
108
+ "name":"用户地址",
109
+ "model":"f_address",
110
+ "type":"input"
111
+ },
112
+ {
113
+ "name":"指令类型",
114
+ "keyName":"指令类型",
115
+ "model":"f_instruct_type",
116
+ "placeholder":"请选择",
117
+ "type":"select"
118
+ },
119
+ {
120
+ "name":"指令说明",
121
+ "model":"f_instruct_title",
122
+ "placeholder":"请输入指令说明",
123
+ "type":"input"
124
+ },
125
+ {
126
+ "name":"指令状态",
127
+ "keyName":"指令状态",
128
+ "model":"f_instruct_state",
129
+ "placeholder":"请选择",
130
+ "type":"select"
131
+ },
132
+ {
133
+ "name":"响应结果",
134
+ "model":"f_receive_state",
135
+ "placeholder":"请输入响应结果",
136
+ "type":"input"
137
+ },
138
+ {
139
+ "name":"生成时间",
140
+ "model":"f_instruct_date",
141
+ "type":"rangePicker"
142
+ },
143
+ {
144
+ "name":"操作人",
145
+ "model":"f_inputtor",
146
+ "placeholder":"请输入操作人员",
147
+ "type":"input"
148
+ }
149
+ ]
150
+ this.loaded = true
151
+ },
152
+ // 表单提交方法
153
+ onSubmit (res) {
154
+ // 如果通过校验
155
+ if (res.valid) {
156
+ // 表单赋值
157
+ this.form = res.form
158
+ } else {
159
+ return false
160
+ }
161
+ }
162
+ }
163
+ }
164
+ </script>
165
+ ```
166
+
167
+ 注意事项
168
+ ----
169
+
170
+ > 本组件已经实现了自适应布局,在不同分辨率下的设备均可得到基本理想的展示效果
171
+ >
172
+ > 以上示例查询参数配置为后台生成后的结果,此处为了方便调试,所以直接写在了代码中,实际使用请通过发起请求获取查询参数配置,如下:
173
+ ```vue
174
+ <script>
175
+ import { commonApi } from '@/base-client/api/common'
176
+ import Vue from 'vue'
177
+
178
+ export default {
179
+ data () {
180
+ return {
181
+ // 查询配置文件名
182
+ queryParamsName: 'instructQueryParams'
183
+ }
184
+ },
185
+ methods: {
186
+ getColumnsJson () {
187
+ Vue.resetpost(commonApi.getColumnsJson, {str: this.queryParamsName}).then((res) => {
188
+ this.formItemJson = res.formJson
189
+ this.columnItemJson = res.columnJson
190
+ this.loaded = true
191
+ })
192
+ }
193
+ }
194
+ }
195
+ </script>
196
+ ```