vue2-client 1.16.20 → 1.16.21

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 (331) hide show
  1. package/.cursorrules +19 -19
  2. package/.env.apply +19 -19
  3. package/.env.gaslink +19 -19
  4. package/.env.his +19 -19
  5. package/.env.liuli +20 -20
  6. package/.env.scada +19 -19
  7. package/.eslintrc.js +90 -90
  8. package/CHANGELOG.md +824 -824
  9. package/Components.md +60 -60
  10. package/docs/LowCode/lowcode.md +155 -155
  11. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  12. package/docs/index.md +30 -30
  13. package/index.js +31 -31
  14. package/jest-transform-stub.js +8 -8
  15. package/jest.setup.js +7 -7
  16. package/jsconfig.json +19 -19
  17. package/package.json +112 -112
  18. package/public/his/editor/editor.html +51 -51
  19. package/public/his/editor/mock/bind_data.html +779 -779
  20. package/public/his/editor/mock/data_table.html +40 -40
  21. package/public/his/editor/mock/sign.html +75 -75
  22. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  23. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  24. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  25. package/public/his/editor/vender/date97/calendar.js +4 -4
  26. package/public/his/editor/vender/date97/lang/en.js +13 -13
  27. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  28. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  29. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  30. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  31. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  32. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  33. package/public/his/editor/vender/diff.js +1627 -1627
  34. package/public/his/editor/vender/editor.js +1 -1
  35. package/public/his/editor/vender/fabric.js +31187 -31187
  36. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  37. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  38. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  39. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  40. package/public/his/editor/vender/mui/mui.min.css +4 -4
  41. package/public/his/editor/vender/mui/mui.min.js +5 -5
  42. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  43. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  44. package/public/his/editor/vender/qrcode.js +7 -7
  45. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  46. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  47. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  48. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  49. package/public/his/editor/vender/validator.js +5094 -5094
  50. package/public/his/editor/vender/weui/weui.css +5659 -5659
  51. package/public/his/editor/vender/weui/weui.min.css +4 -4
  52. package/public/his/editor/vender/weui/weui.min.js +11 -11
  53. package/src/assets/img/querySlotDemo.svg +15 -15
  54. package/src/assets/svg/badtwo.svg +1 -1
  55. package/src/assets/svg/goodtwo.svg +1 -1
  56. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  57. package/src/base-client/components/AI/demo.vue +31 -31
  58. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  59. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  60. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  61. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  62. package/src/base-client/components/common/CitySelect/index.js +3 -3
  63. package/src/base-client/components/common/CitySelect/index.md +109 -109
  64. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  65. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  66. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  67. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  68. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  69. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  70. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  71. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  72. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  73. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  74. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  75. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  76. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  77. package/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm.vue +478 -466
  78. package/src/base-client/components/common/HIS/HAddNativeForm/index.js +3 -3
  79. package/src/base-client/components/common/HIS/HButtons/HButtons.vue +365 -365
  80. package/src/base-client/components/common/HIS/HFormTable/HFormTable.vue +219 -219
  81. package/src/base-client/components/common/HIS/HTab/HTab.vue +293 -293
  82. package/src/base-client/components/common/HIS/demo.vue +54 -54
  83. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  84. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  85. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  86. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  87. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  88. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  89. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  90. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  91. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  92. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  93. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  94. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  95. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  96. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  97. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  98. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  99. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  100. package/src/base-client/components/common/Recording/index.js +3 -3
  101. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  102. package/src/base-client/components/common/Tree/index.js +2 -2
  103. package/src/base-client/components/common/Upload/index.js +3 -3
  104. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  105. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  106. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  107. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  108. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  109. package/src/base-client/components/common/XAddReport/index.js +3 -3
  110. package/src/base-client/components/common/XAddReport/index.md +56 -56
  111. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  112. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  113. package/src/base-client/components/common/XButtons/index.js +3 -3
  114. package/src/base-client/components/common/XButtons/index.md +61 -61
  115. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  116. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  117. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  118. package/src/base-client/components/common/XDataCard/index.js +3 -3
  119. package/src/base-client/components/common/XDataCard/index.md +1 -1
  120. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  121. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  122. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  123. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  124. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  125. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  126. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  127. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  128. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  129. package/src/base-client/components/common/XForm/index.md +178 -178
  130. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  131. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  132. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  133. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  134. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  135. package/src/base-client/components/common/XFormTable/index.md +92 -92
  136. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  137. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  138. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  139. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  140. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  141. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  142. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  143. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  144. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  145. package/src/base-client/components/common/XPrint/index.vue +97 -97
  146. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  147. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  148. package/src/base-client/components/common/XReport/index.js +3 -3
  149. package/src/base-client/components/common/XReport/print.js +186 -186
  150. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  151. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +813 -813
  152. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  153. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  154. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  155. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  156. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  157. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  158. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  159. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  160. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  161. package/src/base-client/components/common/XStepView/index.js +3 -3
  162. package/src/base-client/components/common/XStepView/index.md +31 -31
  163. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  164. package/src/base-client/components/common/XTab/index.js +3 -3
  165. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  166. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  167. package/src/base-client/components/common/XTable/index.md +255 -255
  168. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  169. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  170. package/src/base-client/components/common/XTree/index.js +3 -3
  171. package/src/base-client/components/common/XTree/index.md +36 -36
  172. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  173. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  174. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  175. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  176. package/src/base-client/components/his/XCharge/XCharge.vue +610 -610
  177. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  178. package/src/base-client/components/his/XSidebar/XSidebar.vue +283 -283
  179. package/src/base-client/components/his/XSimpleTable/XSimpleTable.vue +119 -119
  180. package/src/base-client/components/his/threeTestOrders/threeTestOrders.vue +481 -481
  181. package/src/base-client/components/index.js +51 -51
  182. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  183. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  184. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  185. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  186. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  187. package/src/base-client/plugins/Config.js +19 -19
  188. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  189. package/src/base-client/plugins/Recording.js +258 -258
  190. package/src/base-client/plugins/index.js +23 -23
  191. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  192. package/src/components/Charts/Bar.vue +62 -62
  193. package/src/components/Charts/ChartCard.vue +134 -134
  194. package/src/components/Charts/Liquid.vue +67 -67
  195. package/src/components/Charts/MiniArea.vue +39 -39
  196. package/src/components/Charts/MiniBar.vue +39 -39
  197. package/src/components/Charts/MiniProgress.vue +75 -75
  198. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  199. package/src/components/Charts/Radar.vue +68 -68
  200. package/src/components/Charts/RankList.vue +77 -77
  201. package/src/components/Charts/TagCloud.vue +113 -113
  202. package/src/components/Charts/TransferBar.vue +64 -64
  203. package/src/components/Charts/Trend.vue +82 -82
  204. package/src/components/Charts/chart.less +12 -12
  205. package/src/components/Charts/smooth.area.less +13 -13
  206. package/src/components/CodeMirror/inedx.vue +118 -118
  207. package/src/components/CodeMirror/setting.js +40 -40
  208. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  209. package/src/components/NumberInfo/index.js +3 -3
  210. package/src/components/NumberInfo/index.less +54 -54
  211. package/src/components/NumberInfo/index.md +43 -43
  212. package/src/components/card/ChartCard.vue +79 -79
  213. package/src/components/chart/Bar.vue +60 -60
  214. package/src/components/chart/MiniArea.vue +67 -67
  215. package/src/components/chart/MiniBar.vue +59 -59
  216. package/src/components/chart/MiniProgress.vue +57 -57
  217. package/src/components/chart/Radar.vue +80 -80
  218. package/src/components/chart/RankingList.vue +60 -60
  219. package/src/components/chart/Trend.vue +79 -79
  220. package/src/components/chart/index.less +9 -9
  221. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  222. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  223. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  224. package/src/components/checkbox/index.js +9 -9
  225. package/src/components/exception/ExceptionPage.vue +70 -70
  226. package/src/components/g2Charts/constants.js +202 -202
  227. package/src/components/g2Charts/demo.vue +808 -808
  228. package/src/components/g2Charts/designer.vue +228 -228
  229. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  230. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  231. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  232. package/src/components/g2Charts/index.vue +397 -397
  233. package/src/components/index.js +36 -36
  234. package/src/components/input/IInput.vue +66 -66
  235. package/src/components/menu/SideMenu.vue +75 -75
  236. package/src/components/menu/menu.js +273 -273
  237. package/src/components/setting/Setting.vue +234 -234
  238. package/src/components/tool/AStepItem.vue +60 -60
  239. package/src/config/CreateQueryConfig.js +325 -325
  240. package/src/config/default/antd.config.js +89 -89
  241. package/src/config/default/setting.config.js +55 -55
  242. package/src/font-style/font.css +60 -60
  243. package/src/layouts/CommonLayout.vue +56 -56
  244. package/src/layouts/PageLayout.vue +151 -151
  245. package/src/layouts/SinglePageView.vue +136 -136
  246. package/src/layouts/header/AdminHeader.vue +132 -132
  247. package/src/layouts/header/HeaderNotice.vue +177 -177
  248. package/src/layouts/header/InstitutionDetail.vue +181 -181
  249. package/src/layouts/tabs/TabsHead.vue +189 -189
  250. package/src/lib.js +1 -1
  251. package/src/mock/extend/index.js +84 -84
  252. package/src/mock/goods/index.js +108 -108
  253. package/src/pages/DefaultExample/index.vue +77 -77
  254. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  255. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  256. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  257. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  258. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  259. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  260. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  261. package/src/pages/DynamicStatistics/index.vue +282 -282
  262. package/src/pages/Example/childIndex.vue +15 -15
  263. package/src/pages/Example/index.vue +30 -30
  264. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  265. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  266. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  267. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  268. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  269. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  270. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  271. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  272. package/src/pages/Recording/index.vue +77 -77
  273. package/src/pages/ServiceReview/index.vue +284 -284
  274. package/src/pages/SubExample/index.vue +26 -26
  275. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  276. package/src/pages/XReportView/index.vue +64 -64
  277. package/src/pages/XTreeOneProExample/index.vue +67 -67
  278. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  279. package/src/pages/login/Login.vue +379 -379
  280. package/src/pages/login/LoginV3.vue +389 -389
  281. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  282. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  283. package/src/pages/report/ReportTable.js +124 -124
  284. package/src/pages/resourceManage/orgListManage.vue +98 -98
  285. package/src/pages/system/dictionary/index.vue +44 -44
  286. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  287. package/src/pages/system/monitor/operLog/index.vue +37 -37
  288. package/src/pages/system/settings/modifyPassword.vue +117 -117
  289. package/src/pages/system/ticket/index.vue +480 -480
  290. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  291. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  292. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  293. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  294. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  295. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  296. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  297. package/src/plugins/EventLogPlugin.js +33 -33
  298. package/src/plugins/FindParentsData.js +17 -17
  299. package/src/router/async/config.async.js +35 -35
  300. package/src/router/async/router.map.js +129 -129
  301. package/src/router/index.js +27 -27
  302. package/src/services/DataModel.js +30 -30
  303. package/src/services/LodopFuncs.js +137 -137
  304. package/src/services/api/TicketDetailsViewApi.js +46 -46
  305. package/src/services/api/cas.js +79 -79
  306. package/src/services/api/common.js +346 -346
  307. package/src/services/api/entity.js +18 -18
  308. package/src/services/api/index.js +17 -17
  309. package/src/store/modules/account.js +115 -115
  310. package/src/store/modules/index.js +5 -5
  311. package/src/store/modules/lowCode.js +33 -33
  312. package/src/store/modules/setting.js +119 -119
  313. package/src/theme/default/style.less +58 -58
  314. package/src/utils/authority-utils.js +85 -85
  315. package/src/utils/errorCode.js +6 -6
  316. package/src/utils/formatter.js +74 -74
  317. package/src/utils/htmlToPDF.js +108 -108
  318. package/src/utils/htmlToPDFApi.js +5 -5
  319. package/src/utils/login.js +188 -188
  320. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  321. package/src/utils/lowcode/lowcodeLog.js +29 -29
  322. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  323. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  324. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  325. package/src/utils/map-utils.js +47 -47
  326. package/src/utils/reg.js +95 -95
  327. package/src/utils/runEvalFunction.js +14 -14
  328. package/src/utils/theme-color-replacer-extend.js +92 -92
  329. package/src/utils/util.js +329 -329
  330. package/src/utils/waterMark.js +31 -31
  331. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,413 +1,413 @@
1
- <template>
2
- <!-- 属性编辑 -->
3
- <a-card>
4
- <template v-if="editorPropertiesConfig === 'unregistered'">
5
- <p>所选组件并未注册</p>
6
- </template>
7
- <template v-else>
8
- <!-- 组件名 -->
9
- <template v-if="editorPropertiesConfig.name">
10
- <div class="select_title">
11
- <span style="font-size: 1.2em; margin-right: 10%; font-weight: bold">组件名</span>
12
- <a-tag
13
- v-if="editorPropertiesConfig.name || editorPropertiesConfig.id"
14
- :color="determineComponentColorAndText(editorPropertiesConfig.type).color">
15
- {{ determineComponentColorAndText(editorPropertiesConfig.type).text }}
16
- </a-tag>
17
- </div>
18
- <h4>{{ editorPropertiesConfig.name }}</h4>
19
- </template>
20
- <template v-else-if="editorPropertiesConfig.id">
21
- <div class="select_title">
22
- <span style="font-size: 1.2em; margin-right: 10%; font-weight: bold">组件ID</span>
23
- <a-tag
24
- style="height: 100%"
25
- v-if="editorPropertiesConfig.name || editorPropertiesConfig.id"
26
- :color="determineComponentColorAndText(editorPropertiesConfig.type).color">
27
- {{ determineComponentColorAndText(editorPropertiesConfig.type).text }}
28
- </a-tag>
29
- </div>
30
- <h4>{{ editorPropertiesConfig.id }}</h4>
31
- </template>
32
- <!-- 切换 -->
33
- <a-menu v-model="editorPanelCurrent" mode="horizontal" @click="() => null">
34
- <a-menu-item key="properties">属性</a-menu-item>
35
- <a-menu-item key="events" :disabled="disableEventEditor">事件</a-menu-item>
36
- </a-menu>
37
- <!-- 属性编辑 -->
38
- <div v-if="editorPanelCurrent[0] === 'properties'">
39
- <!-- 组件属性编辑 -->
40
- <div v-if="editorPropertiesConfig.props !== undefined">
41
- <div v-if="editorPropertiesConfig.type === 'tabs'" style="border: 2px solid rgba(0,0,0,0.2); padding: 10%; margin: 5%">
42
- <p>标签</p>
43
- <template v-for="(tab, tabIndex) in editorPropertiesConfig.body">
44
- <div :key="tab.key" style="border-bottom: 1px solid rgb(200,229,255)">
45
- 标签名: <a-input :default-value="tab.label" @change="handleTabPropChange($event, tabIndex, 'label')"/>
46
- </div>
47
- </template>
48
- <a-button icon="plus" @click="addNewTab"/>
49
- </div>
50
- <div v-if="editorPropertiesConfig.span">
51
- 栅格数:
52
- <a-row>
53
- <a-col :span="16">
54
- <a-slider
55
- :id="editorPropertiesConfig.id"
56
- :max="24"
57
- :min="1"
58
- v-model="editorPropertiesConfig.span"
59
- @change="changeSpan" />
60
- </a-col>
61
- <a-col :span="7">
62
- <a-input-number v-model="editorPropertiesConfig.span" :min="1" :max="24" style="margin-left: 16px; width: 100%" />
63
- </a-col>
64
- </a-row>
65
- </div>
66
- <template v-for="(value,key) in editorPropertiesConfig.props">
67
- <div :key="editorPropertiesConfig.id + '_' + key">
68
- <a-tooltip>
69
- <template slot="title" v-if="resolveEditorPropsLabel(editorPropertiesConfig.type, key).desc">
70
- {{ resolveEditorPropsLabel(editorPropertiesConfig.type, key).desc }}
71
- </template>
72
- {{ resolveEditorPropsLabel(editorPropertiesConfig.type, key).label }}
73
- <span v-if="resolveEditorPropsLabel(editorPropertiesConfig.type, key).required" style="color: red">*</span>
74
- :
75
- </a-tooltip>
76
- <a-input :default-value="value" @change="editorPropertiesInputChange($event, key)"/>
77
- </div>
78
- </template>
79
- </div>
80
- <!-- 行属性编辑 -->
81
- <div v-if="editorPropertiesConfig.config !== undefined">
82
- <div>
83
- 垂直对齐方式:
84
- <a-select style="width: 100%" @change="rowPropertiesAlignChange" :default-value="editorPropertiesConfig.config.align">
85
- <a-select-option value="top">
86
- 顶部对齐
87
- </a-select-option>
88
- <a-select-option value="middle">
89
- 居中对齐
90
- </a-select-option>
91
- <a-select-option value="bottom">
92
- 底部对齐
93
- </a-select-option>
94
- </a-select>
95
- </div>
96
- <div>
97
- 栅格间隔:
98
- <a-input :default-value="editorPropertiesConfig.config.gutter" @change="rowPropertiesGutterChange($event)"/>
99
- </div>
100
- <div>
101
- 水平排列方式:
102
- <a-select style="width: 100%" @change="rowPropertiesJustifyChange" :default-value="editorPropertiesConfig.config.justify">
103
- <a-select-option value="start">
104
- 对齐开始
105
- </a-select-option>
106
- <a-select-option value="end">
107
- 对齐结尾
108
- </a-select-option>
109
- <a-select-option value="center">
110
- 居中
111
- </a-select-option>
112
- <a-select-option value="space-around">
113
- 空隙环绕
114
- </a-select-option>
115
- <a-select-option value="space-between">
116
- 空隙间隔
117
- </a-select-option>
118
- </a-select>
119
- </div>
120
- </div>
121
- </div>
122
- <!-- 事件编辑 -->
123
- <div v-else-if="editorPanelCurrent[0] === 'events' && showEventEditor">
124
- <template v-if="editorPropertiesConfig.onEvent !== undefined">
125
- <a-collapse v-model="eventCollapseActive">
126
- <a-collapse-panel
127
- v-for="(eventConfig,eventType) in editorPropertiesConfig.onEvent"
128
- :key="eventType"
129
- :header="resolveEventType(eventType)">
130
- <div v-for="(singleEvent,singleEventIndex) in eventConfig" :key="singleEventIndex" class="singleEvent">
131
- <p>
132
- <span style="color:rgb( 24,144,255)">{{ resolveEventName(singleEvent) }}</span>
133
- </p>
134
- <!-- 事件 编辑/删除 按钮 -->
135
- <div style="display: flex; justify-content: space-evenly">
136
- <a-icon type="edit" theme="twoTone" class="edit_icon" @click="editEventIconClick(eventType,singleEventIndex)"/>
137
- <a-popconfirm title="确认删除" ok-text="确认删除" cancel-text="取消" @confirm="removeEventClick(eventType,singleEventIndex)" @cancel="() => null">
138
- <a-icon type="delete" theme="twoTone" class="edit_icon"/>
139
- </a-popconfirm>
140
- </div>
141
- </div>
142
- </a-collapse-panel>
143
- </a-collapse>
144
- </template>
145
- <a-button v-if="editorPropertiesConfig.id !== undefined" @click="addEvent">添加事件</a-button>
146
- <p v-else>您未选择任何组件</p>
147
- </div>
148
- </template>
149
- </a-card>
150
- </template>
151
-
152
- <script>
153
-
154
- import * as lowcodeUtils from '@vue2-client/utils/lowcode/lowcodeUtils'
155
- import lowcodeLog from '@vue2-client/utils/lowcode/lowcodeLog'
156
-
157
- export default {
158
- name: 'LowCodeEditorPanel',
159
- props: {
160
- // 用于保存右侧编辑组件的属性
161
- // eslint-disable-next-line vue/require-default-prop
162
- editorPropertiesConfig: {
163
- type: Object,
164
- require: true
165
- },
166
- disableEventEditor: {
167
- type: Boolean,
168
- default: false
169
- }
170
- },
171
- methods: {
172
- refresh () {
173
- this.showEventEditor = false
174
- this.$nextTick(() => {
175
- this.showEventEditor = true
176
- })
177
- },
178
- // 根据组件类型,返回标签颜色和文字
179
- determineComponentColorAndText (type) {
180
- switch (type) {
181
- case 'container':
182
- return {
183
- color: 'blue',
184
- text: '容器'
185
- }
186
- case 'container_page':
187
- return {
188
- color: 'blue',
189
- text: '容器'
190
- }
191
- case 'row':
192
- return {
193
- color: 'orange',
194
- text: '行'
195
- }
196
- case 'tabs':
197
- return {
198
- color: 'cyan',
199
- text: '标签页'
200
- }
201
- default:
202
- return {
203
- color: 'green',
204
- text: '组件'
205
- }
206
- }
207
- },
208
- // 修改标签名
209
- handleTabPropChange (event, index, type) {
210
- // 找到目标配置
211
- const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
212
- // 新输入的值
213
- targetConfig.body[index][type] = event.target.value
214
- },
215
- // 添加新标签
216
- addNewTab () {
217
- // 找到目标配置
218
- const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
219
- const pageId = lowcodeUtils.nanoidWithoutSymbol(2)
220
- targetConfig.body.push({
221
- key: targetConfig.body.length.toString(),
222
- label: targetConfig.body.length.toString(),
223
- type: 'tab',
224
- body: {
225
- type: 'container_page',
226
- span: 24,
227
- id: 'container_' + lowcodeUtils.nanoidWithoutSymbol(6),
228
- page: [
229
- {
230
- id: 'container_page_' + pageId,
231
- type: 'page',
232
- body: [
233
- {
234
- id: 'container_page_' + pageId + '_0',
235
- type: 'row',
236
- config: {
237
- align: 'top',
238
- gutter: 0,
239
- justify: 'start'
240
- },
241
- body: [
242
- {
243
- type: 'container',
244
- selected: false,
245
- span: 24,
246
- id: 'container_' + lowcodeUtils.nanoidWithoutSymbol(6),
247
- props: {}
248
- }
249
- ]
250
- }
251
- ]
252
- }
253
- ]
254
- }
255
- })
256
- },
257
- // 事件编辑器中,点击编辑按钮
258
- editEventIconClick (eventType, eventIndex) {
259
- // 找到目标配置
260
- const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
261
- // 将目标对应的配置赋值到事件编辑器缓存
262
- this.eventEditorContent = { ...targetConfig.onEvent[eventType][eventIndex] }
263
- this.eventEditorContent.emitType = eventType
264
- this.eventEditorCurrent = {
265
- type: eventType,
266
- index: eventIndex
267
- }
268
- this.$store.commit('setEventEditorContent', this.eventEditorContent)
269
- this.$emit('openModal', 'eventEditor')
270
- },
271
- // 删除事件
272
- removeEventClick (eventType, eventIndex) {
273
- const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
274
- targetConfig.onEvent[eventType].splice(eventIndex, 1)
275
- if (targetConfig.onEvent[eventType].length === 0) {
276
- delete targetConfig.onEvent[eventType]
277
- }
278
- this.$forceUpdate()
279
- },
280
- // 添加事件
281
- addEvent () {
282
- this.$emit('openModal', 'eventEditor')
283
- },
284
- resolveEventType (eventType) {
285
- if (eventType === 'lifeCycle') {
286
- return '生命周期函数'
287
- } else {
288
- return eventType
289
- }
290
- },
291
- resolveEventName (eventConfig) {
292
- if (eventConfig.emitType === 'lifeCycle') {
293
- return eventConfig.lifeCycle
294
- } else {
295
- switch (eventConfig.eventType) {
296
- case 'runFunction':
297
- return '调用组件方法'
298
- case 'changeProps':
299
- return '修改组件Props'
300
- case 'runLogic':
301
- return '发送请求'
302
- case 'log':
303
- return '打印日志'
304
- case 'customJSFunction':
305
- return '自定义JS'
306
- case 'showModal':
307
- return '修改组件显隐'
308
- case 'showDraw':
309
- return '修改组件显隐'
310
- }
311
- }
312
- },
313
- // 行修改Justify
314
- rowPropertiesJustifyChange (justify) {
315
- const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
316
- target.config.justify = justify
317
- },
318
- // 行修改Align
319
- rowPropertiesAlignChange (align) {
320
- const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
321
- target.config.align = align
322
- },
323
- // 行修改Gutter
324
- rowPropertiesGutterChange (event) {
325
- const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
326
- target.config.gutter = Number(event.target.value)
327
- },
328
- // 组件属性编辑
329
- editorPropertiesInputChange (event, key) {
330
- this.$emit('controlRender', false)
331
- // 如果当前有定时器,清除该定时器,并设置新的定时器
332
- // 也就是说:每次操作间隔指定时间后才会触发更新
333
- // 如果在此期间又进行了操作,则重新开始计时
334
- if (this.inputTimeout) {
335
- clearTimeout(this.inputTimeout)
336
- }
337
- this.inputTimeout = setTimeout(() => {
338
- const target = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
339
- lowcodeLog('组件属性修改', '触发更新', target.id, true, false)
340
- // 拿到组件注册的配置
341
- const editorConfig = lowcodeUtils.getEditorConfigById(this.editorPropertiesConfig.id, this.config.page)
342
- // 根据类型,将input框中的内容赋值
343
- if (editorConfig.properties[key].type === 'object') {
344
- target.props[key] = JSON.parse(event.target.value)
345
- } else if (editorConfig.properties[key].type === 'string') {
346
- target.props[key] = event.target.value
347
- } else if (editorConfig.properties[key].type === 'boolean') {
348
- const input = event.target.value.toLowerCase()
349
- target.props[key] = input === 'true' || input !== '0'
350
- }
351
- this.$emit('controlRender', true)
352
- }, 1500)
353
- },
354
- // span属性通过input框修改
355
- changeSpan (event) {
356
- this.editorPropertiesConfig.span = event
357
- },
358
- // 通过组件类型和key解析出该key对应的中文定义
359
- resolveEditorPropsLabel (type, key) {
360
- // 获取配置中的定义
361
- const def = lowcodeUtils.getEditorConfigByType(type)
362
- const propsDef = def.properties
363
- const targetDef = propsDef[key]
364
- if (!targetDef.label) {
365
- targetDef.label = key
366
- } else {
367
- targetDef.label = targetDef.label + '(' + key + ')'
368
- }
369
- if (!targetDef.desc) {
370
- targetDef.desc = '未配置该参数的说明!'
371
- }
372
- return targetDef
373
- },
374
- },
375
- data () {
376
- return {
377
- // 控制右侧编辑器切换标签页
378
- editorPanelCurrent: ['properties'],
379
- // 控制右侧事件编辑刷新
380
- showEventEditor: true,
381
- // 当前激活的是组件事件中哪一类触发属性,对应事件编辑中的手风琴面板
382
- eventCollapseActive: undefined,
383
- // 事件编辑弹框内容回显
384
- eventEditorContent: {},
385
- // 编辑属性时用到的定时器
386
- inputTimeout: undefined,
387
- }
388
- },
389
- computed: {
390
- config () {
391
- return this.$store.state.lowCode.config
392
- }
393
- }
394
- }
395
- </script>
396
-
397
- <style scoped lang="less">
398
- .select_title {
399
- width: 100%;
400
- justify-content: space-between;
401
- display: flex;
402
- align-items: center;
403
- margin-bottom: 3%
404
- }
405
- .singleEvent {
406
- border: black dashed 1px;
407
- padding: 10%;
408
- margin-bottom: 3%;
409
- }
410
- .edit_icon:hover {
411
- cursor: pointer;
412
- }
413
- </style>
1
+ <template>
2
+ <!-- 属性编辑 -->
3
+ <a-card>
4
+ <template v-if="editorPropertiesConfig === 'unregistered'">
5
+ <p>所选组件并未注册</p>
6
+ </template>
7
+ <template v-else>
8
+ <!-- 组件名 -->
9
+ <template v-if="editorPropertiesConfig.name">
10
+ <div class="select_title">
11
+ <span style="font-size: 1.2em; margin-right: 10%; font-weight: bold">组件名</span>
12
+ <a-tag
13
+ v-if="editorPropertiesConfig.name || editorPropertiesConfig.id"
14
+ :color="determineComponentColorAndText(editorPropertiesConfig.type).color">
15
+ {{ determineComponentColorAndText(editorPropertiesConfig.type).text }}
16
+ </a-tag>
17
+ </div>
18
+ <h4>{{ editorPropertiesConfig.name }}</h4>
19
+ </template>
20
+ <template v-else-if="editorPropertiesConfig.id">
21
+ <div class="select_title">
22
+ <span style="font-size: 1.2em; margin-right: 10%; font-weight: bold">组件ID</span>
23
+ <a-tag
24
+ style="height: 100%"
25
+ v-if="editorPropertiesConfig.name || editorPropertiesConfig.id"
26
+ :color="determineComponentColorAndText(editorPropertiesConfig.type).color">
27
+ {{ determineComponentColorAndText(editorPropertiesConfig.type).text }}
28
+ </a-tag>
29
+ </div>
30
+ <h4>{{ editorPropertiesConfig.id }}</h4>
31
+ </template>
32
+ <!-- 切换 -->
33
+ <a-menu v-model="editorPanelCurrent" mode="horizontal" @click="() => null">
34
+ <a-menu-item key="properties">属性</a-menu-item>
35
+ <a-menu-item key="events" :disabled="disableEventEditor">事件</a-menu-item>
36
+ </a-menu>
37
+ <!-- 属性编辑 -->
38
+ <div v-if="editorPanelCurrent[0] === 'properties'">
39
+ <!-- 组件属性编辑 -->
40
+ <div v-if="editorPropertiesConfig.props !== undefined">
41
+ <div v-if="editorPropertiesConfig.type === 'tabs'" style="border: 2px solid rgba(0,0,0,0.2); padding: 10%; margin: 5%">
42
+ <p>标签</p>
43
+ <template v-for="(tab, tabIndex) in editorPropertiesConfig.body">
44
+ <div :key="tab.key" style="border-bottom: 1px solid rgb(200,229,255)">
45
+ 标签名: <a-input :default-value="tab.label" @change="handleTabPropChange($event, tabIndex, 'label')"/>
46
+ </div>
47
+ </template>
48
+ <a-button icon="plus" @click="addNewTab"/>
49
+ </div>
50
+ <div v-if="editorPropertiesConfig.span">
51
+ 栅格数:
52
+ <a-row>
53
+ <a-col :span="16">
54
+ <a-slider
55
+ :id="editorPropertiesConfig.id"
56
+ :max="24"
57
+ :min="1"
58
+ v-model="editorPropertiesConfig.span"
59
+ @change="changeSpan" />
60
+ </a-col>
61
+ <a-col :span="7">
62
+ <a-input-number v-model="editorPropertiesConfig.span" :min="1" :max="24" style="margin-left: 16px; width: 100%" />
63
+ </a-col>
64
+ </a-row>
65
+ </div>
66
+ <template v-for="(value,key) in editorPropertiesConfig.props">
67
+ <div :key="editorPropertiesConfig.id + '_' + key">
68
+ <a-tooltip>
69
+ <template slot="title" v-if="resolveEditorPropsLabel(editorPropertiesConfig.type, key).desc">
70
+ {{ resolveEditorPropsLabel(editorPropertiesConfig.type, key).desc }}
71
+ </template>
72
+ {{ resolveEditorPropsLabel(editorPropertiesConfig.type, key).label }}
73
+ <span v-if="resolveEditorPropsLabel(editorPropertiesConfig.type, key).required" style="color: red">*</span>
74
+ :
75
+ </a-tooltip>
76
+ <a-input :default-value="value" @change="editorPropertiesInputChange($event, key)"/>
77
+ </div>
78
+ </template>
79
+ </div>
80
+ <!-- 行属性编辑 -->
81
+ <div v-if="editorPropertiesConfig.config !== undefined">
82
+ <div>
83
+ 垂直对齐方式:
84
+ <a-select style="width: 100%" @change="rowPropertiesAlignChange" :default-value="editorPropertiesConfig.config.align">
85
+ <a-select-option value="top">
86
+ 顶部对齐
87
+ </a-select-option>
88
+ <a-select-option value="middle">
89
+ 居中对齐
90
+ </a-select-option>
91
+ <a-select-option value="bottom">
92
+ 底部对齐
93
+ </a-select-option>
94
+ </a-select>
95
+ </div>
96
+ <div>
97
+ 栅格间隔:
98
+ <a-input :default-value="editorPropertiesConfig.config.gutter" @change="rowPropertiesGutterChange($event)"/>
99
+ </div>
100
+ <div>
101
+ 水平排列方式:
102
+ <a-select style="width: 100%" @change="rowPropertiesJustifyChange" :default-value="editorPropertiesConfig.config.justify">
103
+ <a-select-option value="start">
104
+ 对齐开始
105
+ </a-select-option>
106
+ <a-select-option value="end">
107
+ 对齐结尾
108
+ </a-select-option>
109
+ <a-select-option value="center">
110
+ 居中
111
+ </a-select-option>
112
+ <a-select-option value="space-around">
113
+ 空隙环绕
114
+ </a-select-option>
115
+ <a-select-option value="space-between">
116
+ 空隙间隔
117
+ </a-select-option>
118
+ </a-select>
119
+ </div>
120
+ </div>
121
+ </div>
122
+ <!-- 事件编辑 -->
123
+ <div v-else-if="editorPanelCurrent[0] === 'events' && showEventEditor">
124
+ <template v-if="editorPropertiesConfig.onEvent !== undefined">
125
+ <a-collapse v-model="eventCollapseActive">
126
+ <a-collapse-panel
127
+ v-for="(eventConfig,eventType) in editorPropertiesConfig.onEvent"
128
+ :key="eventType"
129
+ :header="resolveEventType(eventType)">
130
+ <div v-for="(singleEvent,singleEventIndex) in eventConfig" :key="singleEventIndex" class="singleEvent">
131
+ <p>
132
+ <span style="color:rgb( 24,144,255)">{{ resolveEventName(singleEvent) }}</span>
133
+ </p>
134
+ <!-- 事件 编辑/删除 按钮 -->
135
+ <div style="display: flex; justify-content: space-evenly">
136
+ <a-icon type="edit" theme="twoTone" class="edit_icon" @click="editEventIconClick(eventType,singleEventIndex)"/>
137
+ <a-popconfirm title="确认删除" ok-text="确认删除" cancel-text="取消" @confirm="removeEventClick(eventType,singleEventIndex)" @cancel="() => null">
138
+ <a-icon type="delete" theme="twoTone" class="edit_icon"/>
139
+ </a-popconfirm>
140
+ </div>
141
+ </div>
142
+ </a-collapse-panel>
143
+ </a-collapse>
144
+ </template>
145
+ <a-button v-if="editorPropertiesConfig.id !== undefined" @click="addEvent">添加事件</a-button>
146
+ <p v-else>您未选择任何组件</p>
147
+ </div>
148
+ </template>
149
+ </a-card>
150
+ </template>
151
+
152
+ <script>
153
+
154
+ import * as lowcodeUtils from '@vue2-client/utils/lowcode/lowcodeUtils'
155
+ import lowcodeLog from '@vue2-client/utils/lowcode/lowcodeLog'
156
+
157
+ export default {
158
+ name: 'LowCodeEditorPanel',
159
+ props: {
160
+ // 用于保存右侧编辑组件的属性
161
+ // eslint-disable-next-line vue/require-default-prop
162
+ editorPropertiesConfig: {
163
+ type: Object,
164
+ require: true
165
+ },
166
+ disableEventEditor: {
167
+ type: Boolean,
168
+ default: false
169
+ }
170
+ },
171
+ methods: {
172
+ refresh () {
173
+ this.showEventEditor = false
174
+ this.$nextTick(() => {
175
+ this.showEventEditor = true
176
+ })
177
+ },
178
+ // 根据组件类型,返回标签颜色和文字
179
+ determineComponentColorAndText (type) {
180
+ switch (type) {
181
+ case 'container':
182
+ return {
183
+ color: 'blue',
184
+ text: '容器'
185
+ }
186
+ case 'container_page':
187
+ return {
188
+ color: 'blue',
189
+ text: '容器'
190
+ }
191
+ case 'row':
192
+ return {
193
+ color: 'orange',
194
+ text: '行'
195
+ }
196
+ case 'tabs':
197
+ return {
198
+ color: 'cyan',
199
+ text: '标签页'
200
+ }
201
+ default:
202
+ return {
203
+ color: 'green',
204
+ text: '组件'
205
+ }
206
+ }
207
+ },
208
+ // 修改标签名
209
+ handleTabPropChange (event, index, type) {
210
+ // 找到目标配置
211
+ const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
212
+ // 新输入的值
213
+ targetConfig.body[index][type] = event.target.value
214
+ },
215
+ // 添加新标签
216
+ addNewTab () {
217
+ // 找到目标配置
218
+ const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
219
+ const pageId = lowcodeUtils.nanoidWithoutSymbol(2)
220
+ targetConfig.body.push({
221
+ key: targetConfig.body.length.toString(),
222
+ label: targetConfig.body.length.toString(),
223
+ type: 'tab',
224
+ body: {
225
+ type: 'container_page',
226
+ span: 24,
227
+ id: 'container_' + lowcodeUtils.nanoidWithoutSymbol(6),
228
+ page: [
229
+ {
230
+ id: 'container_page_' + pageId,
231
+ type: 'page',
232
+ body: [
233
+ {
234
+ id: 'container_page_' + pageId + '_0',
235
+ type: 'row',
236
+ config: {
237
+ align: 'top',
238
+ gutter: 0,
239
+ justify: 'start'
240
+ },
241
+ body: [
242
+ {
243
+ type: 'container',
244
+ selected: false,
245
+ span: 24,
246
+ id: 'container_' + lowcodeUtils.nanoidWithoutSymbol(6),
247
+ props: {}
248
+ }
249
+ ]
250
+ }
251
+ ]
252
+ }
253
+ ]
254
+ }
255
+ })
256
+ },
257
+ // 事件编辑器中,点击编辑按钮
258
+ editEventIconClick (eventType, eventIndex) {
259
+ // 找到目标配置
260
+ const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
261
+ // 将目标对应的配置赋值到事件编辑器缓存
262
+ this.eventEditorContent = { ...targetConfig.onEvent[eventType][eventIndex] }
263
+ this.eventEditorContent.emitType = eventType
264
+ this.eventEditorCurrent = {
265
+ type: eventType,
266
+ index: eventIndex
267
+ }
268
+ this.$store.commit('setEventEditorContent', this.eventEditorContent)
269
+ this.$emit('openModal', 'eventEditor')
270
+ },
271
+ // 删除事件
272
+ removeEventClick (eventType, eventIndex) {
273
+ const targetConfig = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
274
+ targetConfig.onEvent[eventType].splice(eventIndex, 1)
275
+ if (targetConfig.onEvent[eventType].length === 0) {
276
+ delete targetConfig.onEvent[eventType]
277
+ }
278
+ this.$forceUpdate()
279
+ },
280
+ // 添加事件
281
+ addEvent () {
282
+ this.$emit('openModal', 'eventEditor')
283
+ },
284
+ resolveEventType (eventType) {
285
+ if (eventType === 'lifeCycle') {
286
+ return '生命周期函数'
287
+ } else {
288
+ return eventType
289
+ }
290
+ },
291
+ resolveEventName (eventConfig) {
292
+ if (eventConfig.emitType === 'lifeCycle') {
293
+ return eventConfig.lifeCycle
294
+ } else {
295
+ switch (eventConfig.eventType) {
296
+ case 'runFunction':
297
+ return '调用组件方法'
298
+ case 'changeProps':
299
+ return '修改组件Props'
300
+ case 'runLogic':
301
+ return '发送请求'
302
+ case 'log':
303
+ return '打印日志'
304
+ case 'customJSFunction':
305
+ return '自定义JS'
306
+ case 'showModal':
307
+ return '修改组件显隐'
308
+ case 'showDraw':
309
+ return '修改组件显隐'
310
+ }
311
+ }
312
+ },
313
+ // 行修改Justify
314
+ rowPropertiesJustifyChange (justify) {
315
+ const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
316
+ target.config.justify = justify
317
+ },
318
+ // 行修改Align
319
+ rowPropertiesAlignChange (align) {
320
+ const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
321
+ target.config.align = align
322
+ },
323
+ // 行修改Gutter
324
+ rowPropertiesGutterChange (event) {
325
+ const target = lowcodeUtils.getRowConfigById(this.editorPropertiesConfig.id, this.config)
326
+ target.config.gutter = Number(event.target.value)
327
+ },
328
+ // 组件属性编辑
329
+ editorPropertiesInputChange (event, key) {
330
+ this.$emit('controlRender', false)
331
+ // 如果当前有定时器,清除该定时器,并设置新的定时器
332
+ // 也就是说:每次操作间隔指定时间后才会触发更新
333
+ // 如果在此期间又进行了操作,则重新开始计时
334
+ if (this.inputTimeout) {
335
+ clearTimeout(this.inputTimeout)
336
+ }
337
+ this.inputTimeout = setTimeout(() => {
338
+ const target = lowcodeUtils.getComponentConfig(this.editorPropertiesConfig.id, this.config.page)
339
+ lowcodeLog('组件属性修改', '触发更新', target.id, true, false)
340
+ // 拿到组件注册的配置
341
+ const editorConfig = lowcodeUtils.getEditorConfigById(this.editorPropertiesConfig.id, this.config.page)
342
+ // 根据类型,将input框中的内容赋值
343
+ if (editorConfig.properties[key].type === 'object') {
344
+ target.props[key] = JSON.parse(event.target.value)
345
+ } else if (editorConfig.properties[key].type === 'string') {
346
+ target.props[key] = event.target.value
347
+ } else if (editorConfig.properties[key].type === 'boolean') {
348
+ const input = event.target.value.toLowerCase()
349
+ target.props[key] = input === 'true' || input !== '0'
350
+ }
351
+ this.$emit('controlRender', true)
352
+ }, 1500)
353
+ },
354
+ // span属性通过input框修改
355
+ changeSpan (event) {
356
+ this.editorPropertiesConfig.span = event
357
+ },
358
+ // 通过组件类型和key解析出该key对应的中文定义
359
+ resolveEditorPropsLabel (type, key) {
360
+ // 获取配置中的定义
361
+ const def = lowcodeUtils.getEditorConfigByType(type)
362
+ const propsDef = def.properties
363
+ const targetDef = propsDef[key]
364
+ if (!targetDef.label) {
365
+ targetDef.label = key
366
+ } else {
367
+ targetDef.label = targetDef.label + '(' + key + ')'
368
+ }
369
+ if (!targetDef.desc) {
370
+ targetDef.desc = '未配置该参数的说明!'
371
+ }
372
+ return targetDef
373
+ },
374
+ },
375
+ data () {
376
+ return {
377
+ // 控制右侧编辑器切换标签页
378
+ editorPanelCurrent: ['properties'],
379
+ // 控制右侧事件编辑刷新
380
+ showEventEditor: true,
381
+ // 当前激活的是组件事件中哪一类触发属性,对应事件编辑中的手风琴面板
382
+ eventCollapseActive: undefined,
383
+ // 事件编辑弹框内容回显
384
+ eventEditorContent: {},
385
+ // 编辑属性时用到的定时器
386
+ inputTimeout: undefined,
387
+ }
388
+ },
389
+ computed: {
390
+ config () {
391
+ return this.$store.state.lowCode.config
392
+ }
393
+ }
394
+ }
395
+ </script>
396
+
397
+ <style scoped lang="less">
398
+ .select_title {
399
+ width: 100%;
400
+ justify-content: space-between;
401
+ display: flex;
402
+ align-items: center;
403
+ margin-bottom: 3%
404
+ }
405
+ .singleEvent {
406
+ border: black dashed 1px;
407
+ padding: 10%;
408
+ margin-bottom: 3%;
409
+ }
410
+ .edit_icon:hover {
411
+ cursor: pointer;
412
+ }
413
+ </style>