vue2-client 1.18.3 → 1.18.5

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 (244) hide show
  1. package/.claude/settings.local.json +20 -20
  2. package/.cursorrules +19 -19
  3. package/.env.apply +19 -19
  4. package/.env.gaslink +19 -19
  5. package/.env.his +19 -19
  6. package/.env.liuli +20 -20
  7. package/.env.scada +19 -19
  8. package/.serena/memories/code_style_conventions.md +217 -217
  9. package/.serena/memories/project_overview.md +54 -54
  10. package/.serena/memories/project_structure.md +329 -329
  11. package/.serena/memories/suggested_commands.md +127 -127
  12. package/.serena/memories/task_completion_checklist.md +183 -183
  13. package/.serena/memories/tech_stack.md +94 -94
  14. package/CHANGELOG.md +830 -830
  15. package/CLAUDE.md +97 -97
  16. package/docs/LowCode/lowcode.md +155 -155
  17. package/docs/LowCode/lowcodeForDeveloper.md +230 -230
  18. package/jsconfig.json +19 -19
  19. package/package.json +1 -1
  20. package/public/his/editor/editor.html +51 -51
  21. package/public/his/editor/mock/bind_data.html +779 -779
  22. package/public/his/editor/mock/data_table.html +40 -40
  23. package/public/his/editor/mock/sign.html +75 -75
  24. package/public/his/editor/vender/JsBarcode.all.js +3669 -3669
  25. package/public/his/editor/vender/date97/My97DatePicker.htm +65 -65
  26. package/public/his/editor/vender/date97/WdatePicker.js +677 -677
  27. package/public/his/editor/vender/date97/calendar.js +4 -4
  28. package/public/his/editor/vender/date97/lang/en.js +13 -13
  29. package/public/his/editor/vender/date97/lang/zh-cn.js +13 -13
  30. package/public/his/editor/vender/date97/lang/zh-tw.js +13 -13
  31. package/public/his/editor/vender/date97/skin/WdatePicker.css +10 -10
  32. package/public/his/editor/vender/date97/skin/default/datepicker.css +328 -328
  33. package/public/his/editor/vender/date97/skin/ext/datepicker.css +308 -308
  34. package/public/his/editor/vender/date97/skin/whyGreen/datepicker.css +255 -255
  35. package/public/his/editor/vender/diff.js +1627 -1627
  36. package/public/his/editor/vender/editor.js +1 -1
  37. package/public/his/editor/vender/fabric.js +31187 -31187
  38. package/public/his/editor/vender/jquery/jquery.base64.js +190 -190
  39. package/public/his/editor/vender/jquery/jquery.js +10872 -10872
  40. package/public/his/editor/vender/jquery/jquery.print.js +255 -255
  41. package/public/his/editor/vender/jquery/zTreeStyle/zTreeStyle.css +96 -96
  42. package/public/his/editor/vender/mui/mui.min.css +4 -4
  43. package/public/his/editor/vender/mui/mui.min.js +5 -5
  44. package/public/his/editor/vender/mui/mui.picker.min.css +6 -6
  45. package/public/his/editor/vender/mui/mui.picker.min.js +6 -6
  46. package/public/his/editor/vender/qrcode.js +7 -7
  47. package/public/his/editor/vender/requirejs/require.js +2145 -2145
  48. package/public/his/editor/vender/signature/jSignature.CompressorSVG.js +518 -518
  49. package/public/his/editor/vender/signature/jSignature.UndoButton.js +164 -164
  50. package/public/his/editor/vender/signature/jSignature.js +1486 -1486
  51. package/public/his/editor/vender/validator.js +5094 -5094
  52. package/public/his/editor/vender/weui/weui.css +5659 -5659
  53. package/public/his/editor/vender/weui/weui.min.css +4 -4
  54. package/public/his/editor/vender/weui/weui.min.js +11 -11
  55. package/src/assets/img/paymentMethod/package.info +1 -1
  56. package/src/assets/svg/badtwo.svg +1 -1
  57. package/src/assets/svg/goodtwo.svg +1 -1
  58. package/src/base-client/components/AI/AskAiBtn.vue +136 -136
  59. package/src/base-client/components/AI/demo.vue +31 -31
  60. package/src/base-client/components/common/AddressSearchCombobox/IcMapIcon.vue +16 -16
  61. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  62. package/src/base-client/components/common/AddressSearchCombobox/ic_map.svg +6 -6
  63. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  64. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  65. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  66. package/src/base-client/components/common/HIS/demo.vue +61 -61
  67. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorModal.vue +108 -108
  68. package/src/base-client/components/common/LowCodeComponent/LowCodeEditorPanel.vue +413 -413
  69. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +502 -502
  70. package/src/base-client/components/common/LowCodeComponent/LowCodeRender.vue +728 -728
  71. package/src/base-client/components/common/LowCodeComponent/LowCodeRenderEnter.vue +29 -29
  72. package/src/base-client/components/common/LowCodeComponent/LowCodeUIStore.vue +219 -219
  73. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeAddPageModal.vue +117 -117
  74. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeCustomJSModal.vue +80 -80
  75. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeEventEditorModal.vue +398 -398
  76. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLifeCycleModal.vue +65 -65
  77. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicCallbackModal.vue +64 -64
  78. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeLogicParamModal.vue +73 -73
  79. package/src/base-client/components/common/LowCodeComponent/modal/lowCodeRunFunctionParamModal.vue +76 -76
  80. package/src/base-client/components/common/Recording/Recording.vue +243 -243
  81. package/src/base-client/components/common/Recording/index.js +3 -3
  82. package/src/base-client/components/common/XAddForm/XAddForm.vue +113 -113
  83. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +304 -304
  84. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  85. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  86. package/src/base-client/components/common/XAddReport/index.js +3 -3
  87. package/src/base-client/components/common/XAddReport/index.md +56 -56
  88. package/src/base-client/components/common/XBadge/XBadge.vue +94 -94
  89. package/src/base-client/components/common/XButtons/XButtonDemo.vue +28 -28
  90. package/src/base-client/components/common/XButtons/index.js +3 -3
  91. package/src/base-client/components/common/XButtons/index.md +61 -61
  92. package/src/base-client/components/common/XCalendar/XCalendar.vue +4 -4
  93. package/src/base-client/components/common/XCheckList/XCheckList.vue +106 -106
  94. package/src/base-client/components/common/XCheckList/XCheckListDemo.vue +41 -41
  95. package/src/base-client/components/common/XDataCard/index.js +3 -3
  96. package/src/base-client/components/common/XDataCard/index.md +1 -1
  97. package/src/base-client/components/common/XDatePicker/demo.vue +153 -153
  98. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +238 -238
  99. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  100. package/src/base-client/components/common/XForm/XStatusButton.vue +54 -54
  101. package/src/base-client/components/common/XForm/itemComponent/XClickChangeBtn/index.vue +49 -49
  102. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  103. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  104. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  105. package/src/base-client/components/common/XFormTable/XFormTable.vue +1258 -1257
  106. package/src/base-client/components/common/XFormTable/index.md +92 -92
  107. package/src/base-client/components/common/XLabelSelect/XLabelSelect.vue +110 -110
  108. package/src/base-client/components/common/XLabelSelect/XLabelSelectDemo.vue +35 -35
  109. package/src/base-client/components/common/XLicensePlate/XLicensePlate.vue +193 -193
  110. package/src/base-client/components/common/XLicensePlate/XLicensePlateDemo.vue +48 -48
  111. package/src/base-client/components/common/XPrint/OpenInvoice.vue +21 -21
  112. package/src/base-client/components/common/XPrint/PrintHtml.js +98 -98
  113. package/src/base-client/components/common/XPrint/css/hiPrintCss.js +359 -359
  114. package/src/base-client/components/common/XPrint/css/lodopCss.js +26 -26
  115. package/src/base-client/components/common/XPrint/css/print-lock.css +351 -351
  116. package/src/base-client/components/common/XPrint/index.vue +97 -97
  117. package/src/base-client/components/common/XReport/XReportDesign.vue +463 -463
  118. package/src/base-client/components/common/XReport/XReportJsonRender.vue +381 -381
  119. package/src/base-client/components/common/XReport/index.js +3 -3
  120. package/src/base-client/components/common/XReport/print.js +186 -186
  121. package/src/base-client/components/common/XReportDrawer/index.js +3 -3
  122. package/src/base-client/components/common/XReportGrid/index.js +3 -3
  123. package/src/base-client/components/common/XReportGrid/index.md +44 -44
  124. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  125. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  126. package/src/base-client/components/common/XReportSlot/index.md +48 -48
  127. package/src/base-client/components/common/XSimpleDescriptions/XSimpleDescriptions.vue +166 -166
  128. package/src/base-client/components/common/XSimpleDescriptions/index.js +3 -3
  129. package/src/base-client/components/common/XSimpleDescriptions/index.md +7 -7
  130. package/src/base-client/components/common/XTab/XTabDemo.vue +22 -22
  131. package/src/base-client/components/common/XTab/index.js +3 -3
  132. package/src/base-client/components/common/XTable/CustomFuncCel.vue +51 -51
  133. package/src/base-client/components/common/XTable/TableCellRenderer.vue +161 -161
  134. package/src/base-client/components/common/XTable/XTableWrapper.vue +1 -1
  135. package/src/base-client/components/common/XTagGroup/index.vue +52 -52
  136. package/src/base-client/components/common/XTree/XTree.vue +424 -424
  137. package/src/base-client/components/common/XTree/index.js +3 -3
  138. package/src/base-client/components/common/XTree/index.md +36 -36
  139. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +113 -113
  140. package/src/base-client/components/common/XTreeOne/XTreeOnePro.vue +128 -128
  141. package/src/base-client/components/common/richTextModal/index.vue +56 -56
  142. package/src/base-client/components/common/richTextModal/richDemo.vue +48 -48
  143. package/src/base-client/components/his/XCharge/XChargeDemo.vue +145 -145
  144. package/src/base-client/components/his/XHisEditor/index.js +3 -3
  145. package/src/base-client/components/index.js +51 -51
  146. package/src/base-client/components/layout/XTreeView/XTreeView.vue +130 -130
  147. package/src/base-client/components/layout/XTreeView/index.js +3 -3
  148. package/src/base-client/components/layout/XTreeView/index.md +46 -46
  149. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  150. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  151. package/src/base-client/plugins/Recording.js +258 -258
  152. package/src/base-client/plugins/index.js +23 -23
  153. package/src/components/CodeMirror/inedx.vue +118 -118
  154. package/src/components/CodeMirror/setting.js +40 -40
  155. package/src/components/checkbox/ImgCheckbox.vue +117 -117
  156. package/src/components/checkbox/ImgCheckboxGroup.vue +76 -76
  157. package/src/components/checkbox/index.js +9 -9
  158. package/src/components/exception/ExceptionPage.vue +70 -70
  159. package/src/components/g2Charts/constants.js +202 -202
  160. package/src/components/g2Charts/demo.vue +808 -808
  161. package/src/components/g2Charts/designer.vue +228 -228
  162. package/src/components/g2Charts/designerBaseConfig.vue +61 -61
  163. package/src/components/g2Charts/designerDataConfig.vue +259 -259
  164. package/src/components/g2Charts/designerStyleConfig.vue +16 -16
  165. package/src/components/g2Charts/index.vue +397 -397
  166. package/src/components/setting/Setting.vue +234 -234
  167. package/src/config/CreateQueryConfig.js +325 -325
  168. package/src/config/default/antd.config.js +89 -89
  169. package/src/config/default/setting.config.js +55 -55
  170. package/src/font-style/font.css +60 -60
  171. package/src/layouts/PageLayout.vue +151 -151
  172. package/src/layouts/SinglePageView.vue +136 -136
  173. package/src/layouts/header/AdminHeader.vue +132 -132
  174. package/src/layouts/header/InstitutionDetail.vue +181 -181
  175. package/src/layouts/tabs/TabsHead.vue +189 -189
  176. package/src/pages/DefaultExample/index.vue +77 -77
  177. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  178. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  179. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  180. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  181. package/src/pages/DynamicStatistics/FavoriteList.vue +50 -50
  182. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  183. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  184. package/src/pages/DynamicStatistics/index.vue +282 -282
  185. package/src/pages/Example/childIndex.vue +15 -15
  186. package/src/pages/Example/index.vue +30 -30
  187. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  188. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  189. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  190. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  191. package/src/pages/NewDynamicStatistics/FavoriteList.vue +50 -50
  192. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  193. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  194. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  195. package/src/pages/Recording/index.vue +77 -77
  196. package/src/pages/ServiceReview/index.vue +284 -284
  197. package/src/pages/SubExample/index.vue +26 -26
  198. package/src/pages/WorkflowDetail/WorkflowPageDetail/TrimTextTail.vue +23 -23
  199. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowHandle.vue +1815 -1815
  200. package/src/pages/WorkflowDetail/WorkflowPageDetail/WorkFlowTimeline.vue +1014 -1014
  201. package/src/pages/XReportView/index.vue +64 -64
  202. package/src/pages/XTreeOneProExample/index.vue +67 -67
  203. package/src/pages/login/Login.vue +379 -379
  204. package/src/pages/login/LoginV3.vue +389 -389
  205. package/src/pages/lowCode/lowCodeEditor.vue +1219 -1219
  206. package/src/pages/lowCode/lowCodeRenderPage.vue +43 -43
  207. package/src/pages/report/ReportTable.js +124 -124
  208. package/src/pages/resourceManage/orgListManage.vue +98 -98
  209. package/src/pages/system/settings/modifyPassword.vue +117 -117
  210. package/src/pages/system/ticket/index.vue +480 -480
  211. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  212. package/src/pages/userInfoDetailManage/ChangeMeterRecordQuery/index.vue +64 -64
  213. package/src/pages/userInfoDetailManage/InfoChangeRecordQuery/index.vue +64 -64
  214. package/src/pages/userInfoDetailManage/InstructRecordQuery/index.vue +64 -64
  215. package/src/pages/userInfoDetailManage/MeterParamRecordQuery/index.vue +64 -64
  216. package/src/pages/userInfoDetailManage/TransferRecordQuery/index.vue +66 -66
  217. package/src/pages/userInfoDetailManage/WatchCollectionRecordQuery/index.vue +64 -64
  218. package/src/plugins/EventLogPlugin.js +33 -33
  219. package/src/plugins/FindParentsData.js +17 -17
  220. package/src/services/DataModel.js +30 -30
  221. package/src/services/LodopFuncs.js +137 -137
  222. package/src/services/api/TicketDetailsViewApi.js +46 -46
  223. package/src/services/api/entity.js +18 -18
  224. package/src/services/api/index.js +17 -17
  225. package/src/store/modules/account.js +121 -121
  226. package/src/store/modules/index.js +5 -5
  227. package/src/store/modules/lowCode.js +33 -33
  228. package/src/theme/default/style.less +58 -58
  229. package/src/theme/global.less +313 -313
  230. package/src/utils/formatter.js +74 -74
  231. package/src/utils/htmlToPDF.js +108 -108
  232. package/src/utils/htmlToPDFApi.js +5 -5
  233. package/src/utils/login.js +188 -188
  234. package/src/utils/lowcode/lowcodeComponentMixin.js +120 -120
  235. package/src/utils/lowcode/lowcodeLog.js +29 -29
  236. package/src/utils/lowcode/lowcodeUtils.js +373 -373
  237. package/src/utils/lowcode/registerComponentForEditor.js +1 -1
  238. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  239. package/src/utils/map-utils.js +47 -47
  240. package/src/utils/reg.js +95 -95
  241. package/src/utils/runEvalFunction.js +14 -14
  242. package/src/utils/theme-color-replacer-extend.js +92 -92
  243. package/src/utils/util.js +329 -329
  244. package/src/utils/waterMark.js +31 -31
@@ -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>