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,48 +1,48 @@
1
- <template>
2
- <div>
3
- <h1>Canvas Editor 示例</h1>
4
- <x-add-native-form ref="nativeForm" />
5
- </div>
6
- </template>
7
-
8
- <script>
9
- import XAddNativeForm from '@vue2-client/base-client/components/common/XAddNativeForm/XAddNativeForm.vue'
10
- import { getConfigByName } from '../../../../services/api/common'
11
-
12
- export default {
13
- components: {
14
- XAddNativeForm
15
- },
16
- mounted () {
17
- this.$nextTick(() => {
18
- getConfigByName('表单测试Form', 'af-his', (res) => {
19
- const modifyModelData = {
20
- data: {
21
- t_f_file_id: 1,
22
- t_f_path: '/usr/local/tomcat/files/af-his/txt/f7c758f6d5f14c53bb5246f82a25c0c4.txt'
23
- },
24
- images: [],
25
- files: []
26
- }
27
- this.$refs.nativeForm.init({
28
- serviceName: 'af-his',
29
- formItems: res.formJson,
30
- title: '收费',
31
- businessType: '新增',
32
- layout: 'inline',
33
- modifyModelData: modifyModelData
34
- })
35
- })
36
- })
37
- },
38
- methods: {
39
- submit () {
40
-
41
- }
42
- }
43
- }
44
- </script>
45
-
46
- <style>
47
- /* 在这里添加您的样式 */
48
- </style>
1
+ <template>
2
+ <div>
3
+ <h1>Canvas Editor 示例</h1>
4
+ <x-add-native-form ref="nativeForm" />
5
+ </div>
6
+ </template>
7
+
8
+ <script>
9
+ import XAddNativeForm from '@vue2-client/base-client/components/common/XAddNativeForm/XAddNativeForm.vue'
10
+ import { getConfigByName } from '../../../../services/api/common'
11
+
12
+ export default {
13
+ components: {
14
+ XAddNativeForm
15
+ },
16
+ mounted () {
17
+ this.$nextTick(() => {
18
+ getConfigByName('表单测试Form', 'af-his', (res) => {
19
+ const modifyModelData = {
20
+ data: {
21
+ t_f_file_id: 1,
22
+ t_f_path: '/usr/local/tomcat/files/af-his/txt/f7c758f6d5f14c53bb5246f82a25c0c4.txt'
23
+ },
24
+ images: [],
25
+ files: []
26
+ }
27
+ this.$refs.nativeForm.init({
28
+ serviceName: 'af-his',
29
+ formItems: res.formJson,
30
+ title: '收费',
31
+ businessType: '新增',
32
+ layout: 'inline',
33
+ modifyModelData: modifyModelData
34
+ })
35
+ })
36
+ })
37
+ },
38
+ methods: {
39
+ submit () {
40
+
41
+ }
42
+ }
43
+ }
44
+ </script>
45
+
46
+ <style>
47
+ /* 在这里添加您的样式 */
48
+ </style>
@@ -1,145 +1,145 @@
1
- <script>
2
- import XCharge from './XCharge.vue'
3
-
4
- export default {
5
- name: 'XChargeSimpleDemo',
6
- components: { XCharge },
7
- data () {
8
- return {
9
- queryParamsName: 'chargeConfig',
10
- methods: [],
11
- total: 0,
12
- lastAmountChange: null,
13
- lastAction: null,
14
- currentMode: 'manual' // 当前模式:manual, auto, single
15
- }
16
- },
17
- methods: {
18
- onMethod (value) { console.log('【事件】单选支付方式(method):', value) },
19
- onMethods (values) {
20
- console.log('【事件】多选支付方式(methods):', values)
21
- this.methods = values
22
- // 在自动模式下,由外部决定金额分配
23
- if (this.currentMode === 'auto') {
24
- this.autoDistributeAmounts(values)
25
- }
26
- },
27
- onTotal (total) { console.log('【事件】合计金额变更(totalPaymentAmount):', total); this.total = total },
28
- onAmountChange (payload) { console.log('【事件】单个方式金额变更(paymentAmountChange):', payload, '→ 方式:', payload.method, ' 金额:', payload.amount); this.lastAmountChange = payload },
29
- onAction (payload) { console.log('【事件】操作(action):', payload); this.lastAction = payload },
30
- switchMode (mode) {
31
- this.currentMode = mode
32
- // 根据模式切换配置
33
- switch (mode) {
34
- case 'manual':
35
- this.queryParamsName = 'testChargeConfig'
36
- break
37
- case 'auto':
38
- this.queryParamsName = 'testAutoMixedChargeConfig'
39
- break
40
- case 'single':
41
- this.queryParamsName = 'testSingleChargeConfig'
42
- break
43
- }
44
- },
45
- getModeText (mode) {
46
- const modeMap = {
47
- manual: '混合支付-手动模式',
48
- auto: '混合支付-自动模式',
49
- single: '单选模式'
50
- }
51
- return modeMap[mode] || mode
52
- },
53
- // 外部金额分配逻辑(示例:平均分配)
54
- autoDistributeAmounts (selectedMethods) {
55
- if (!selectedMethods || selectedMethods.length === 0) return
56
-
57
- // 示例:假设总金额为100,平均分配
58
- const totalAmount = 100
59
- const amountPerMethod = totalAmount / selectedMethods.length
60
-
61
- const amounts = {}
62
- selectedMethods.forEach(method => {
63
- amounts[method] = amountPerMethod
64
- })
65
-
66
- // 调用组件的setPaymentAmounts方法
67
- this.$refs.xCharge.setPaymentAmounts(amounts)
68
- }
69
- }
70
- }
71
- </script>
72
-
73
- <template>
74
- <div class="demo">
75
- <!-- 模式切换按钮 -->
76
- <div class="mode-switcher">
77
- <h3>XCharge 组件测试 - 混合支付模式切换</h3>
78
- <div class="mode-buttons">
79
- <a-button
80
- :type="currentMode === 'manual' ? 'primary' : 'default'"
81
- @click="switchMode('manual')"
82
- >
83
- 混合支付-手动模式
84
- </a-button>
85
- <a-button
86
- :type="currentMode === 'auto' ? 'primary' : 'default'"
87
- @click="switchMode('auto')"
88
- >
89
- 混合支付-自动模式
90
- </a-button>
91
- <a-button
92
- :type="currentMode === 'single' ? 'primary' : 'default'"
93
- @click="switchMode('single')"
94
- >
95
- 单选模式
96
- </a-button>
97
- </div>
98
- <p class="current-mode">当前模式:{{ getModeText(currentMode) }}</p>
99
- </div>
100
-
101
- <x-charge
102
- ref="xCharge"
103
- :queryParamsName="queryParamsName"
104
- @method="onMethod"
105
- @methods="onMethods"
106
- @totalPaymentAmount="onTotal"
107
- @paymentAmountChange="onAmountChange"
108
- @action="onAction"
109
- />
110
-
111
- <div class="info">
112
- <p>已选方式:{{ methods.join('、') || '无' }}</p>
113
- <p>合计金额:{{ total }}</p>
114
- <p v-if="lastAmountChange">最近金额变更:{{ lastAmountChange.method }} -> {{ lastAmountChange.amount }}</p>
115
- </div>
116
- </div>
117
- </template>
118
-
119
- <style scoped>
120
- .demo { padding: 16px; }
121
- .mode-switcher {
122
- margin-bottom: 24px;
123
- padding: 16px;
124
- background: #f8f9fa;
125
- border-radius: 8px;
126
- border: 1px solid #e9ecef;
127
- }
128
- .mode-switcher h3 {
129
- margin: 0 0 16px 0;
130
- color: #333;
131
- font-size: 18px;
132
- }
133
- .mode-buttons {
134
- display: flex;
135
- gap: 12px;
136
- margin-bottom: 12px;
137
- }
138
- .current-mode {
139
- margin: 0;
140
- color: #666;
141
- font-weight: 500;
142
- }
143
- .info { margin-top: 16px; color: #333; }
144
- .info p { margin: 6px 0; }
145
- </style>
1
+ <script>
2
+ import XCharge from './XCharge.vue'
3
+
4
+ export default {
5
+ name: 'XChargeSimpleDemo',
6
+ components: { XCharge },
7
+ data () {
8
+ return {
9
+ queryParamsName: 'chargeConfig',
10
+ methods: [],
11
+ total: 0,
12
+ lastAmountChange: null,
13
+ lastAction: null,
14
+ currentMode: 'manual' // 当前模式:manual, auto, single
15
+ }
16
+ },
17
+ methods: {
18
+ onMethod (value) { console.log('【事件】单选支付方式(method):', value) },
19
+ onMethods (values) {
20
+ console.log('【事件】多选支付方式(methods):', values)
21
+ this.methods = values
22
+ // 在自动模式下,由外部决定金额分配
23
+ if (this.currentMode === 'auto') {
24
+ this.autoDistributeAmounts(values)
25
+ }
26
+ },
27
+ onTotal (total) { console.log('【事件】合计金额变更(totalPaymentAmount):', total); this.total = total },
28
+ onAmountChange (payload) { console.log('【事件】单个方式金额变更(paymentAmountChange):', payload, '→ 方式:', payload.method, ' 金额:', payload.amount); this.lastAmountChange = payload },
29
+ onAction (payload) { console.log('【事件】操作(action):', payload); this.lastAction = payload },
30
+ switchMode (mode) {
31
+ this.currentMode = mode
32
+ // 根据模式切换配置
33
+ switch (mode) {
34
+ case 'manual':
35
+ this.queryParamsName = 'testChargeConfig'
36
+ break
37
+ case 'auto':
38
+ this.queryParamsName = 'testAutoMixedChargeConfig'
39
+ break
40
+ case 'single':
41
+ this.queryParamsName = 'testSingleChargeConfig'
42
+ break
43
+ }
44
+ },
45
+ getModeText (mode) {
46
+ const modeMap = {
47
+ manual: '混合支付-手动模式',
48
+ auto: '混合支付-自动模式',
49
+ single: '单选模式'
50
+ }
51
+ return modeMap[mode] || mode
52
+ },
53
+ // 外部金额分配逻辑(示例:平均分配)
54
+ autoDistributeAmounts (selectedMethods) {
55
+ if (!selectedMethods || selectedMethods.length === 0) return
56
+
57
+ // 示例:假设总金额为100,平均分配
58
+ const totalAmount = 100
59
+ const amountPerMethod = totalAmount / selectedMethods.length
60
+
61
+ const amounts = {}
62
+ selectedMethods.forEach(method => {
63
+ amounts[method] = amountPerMethod
64
+ })
65
+
66
+ // 调用组件的setPaymentAmounts方法
67
+ this.$refs.xCharge.setPaymentAmounts(amounts)
68
+ }
69
+ }
70
+ }
71
+ </script>
72
+
73
+ <template>
74
+ <div class="demo">
75
+ <!-- 模式切换按钮 -->
76
+ <div class="mode-switcher">
77
+ <h3>XCharge 组件测试 - 混合支付模式切换</h3>
78
+ <div class="mode-buttons">
79
+ <a-button
80
+ :type="currentMode === 'manual' ? 'primary' : 'default'"
81
+ @click="switchMode('manual')"
82
+ >
83
+ 混合支付-手动模式
84
+ </a-button>
85
+ <a-button
86
+ :type="currentMode === 'auto' ? 'primary' : 'default'"
87
+ @click="switchMode('auto')"
88
+ >
89
+ 混合支付-自动模式
90
+ </a-button>
91
+ <a-button
92
+ :type="currentMode === 'single' ? 'primary' : 'default'"
93
+ @click="switchMode('single')"
94
+ >
95
+ 单选模式
96
+ </a-button>
97
+ </div>
98
+ <p class="current-mode">当前模式:{{ getModeText(currentMode) }}</p>
99
+ </div>
100
+
101
+ <x-charge
102
+ ref="xCharge"
103
+ :queryParamsName="queryParamsName"
104
+ @method="onMethod"
105
+ @methods="onMethods"
106
+ @totalPaymentAmount="onTotal"
107
+ @paymentAmountChange="onAmountChange"
108
+ @action="onAction"
109
+ />
110
+
111
+ <div class="info">
112
+ <p>已选方式:{{ methods.join('、') || '无' }}</p>
113
+ <p>合计金额:{{ total }}</p>
114
+ <p v-if="lastAmountChange">最近金额变更:{{ lastAmountChange.method }} -> {{ lastAmountChange.amount }}</p>
115
+ </div>
116
+ </div>
117
+ </template>
118
+
119
+ <style scoped>
120
+ .demo { padding: 16px; }
121
+ .mode-switcher {
122
+ margin-bottom: 24px;
123
+ padding: 16px;
124
+ background: #f8f9fa;
125
+ border-radius: 8px;
126
+ border: 1px solid #e9ecef;
127
+ }
128
+ .mode-switcher h3 {
129
+ margin: 0 0 16px 0;
130
+ color: #333;
131
+ font-size: 18px;
132
+ }
133
+ .mode-buttons {
134
+ display: flex;
135
+ gap: 12px;
136
+ margin-bottom: 12px;
137
+ }
138
+ .current-mode {
139
+ margin: 0;
140
+ color: #666;
141
+ font-weight: 500;
142
+ }
143
+ .info { margin-top: 16px; color: #333; }
144
+ .info p { margin: 6px 0; }
145
+ </style>
@@ -1,3 +1,3 @@
1
- import XHisEditor from './XHisEditor.vue'
2
-
3
- export default XHisEditor
1
+ import XHisEditor from './XHisEditor.vue'
2
+
3
+ export default XHisEditor
@@ -1,51 +1,51 @@
1
- import XForm from './common/XForm'
2
- import XAddForm from './common/XAddForm'
3
- import XAddNativeForm from './common/XAddNativeForm'
4
- import XFormCol from './common/XFormCol'
5
- import XTable from './common/XTable'
6
- import XTreeOne from './common/XTreeOne'
7
- import XImportExcel from './common/XImportExcel'
8
- import XDataDrawer from './common/XDataDrawer'
9
- import XCard from './common/XCard'
10
- import XBadge from './common/XBadge'
11
- import Upload from './common/Upload'
12
- import JSONToTree from './common/JSONToTree'
13
- import FormGroupEdit from './common/FormGroupEdit'
14
- import FormGroupQuery from './common/FormGroupQuery'
15
- import AddressSearchCombobox from './common/AddressSearchCombobox'
16
- import AmapMarker from './common/AmapMarker'
17
- import PersonSetting from './common/PersonSetting'
18
- import XFormTable from './common/XFormTable'
19
- import XStepView from './common/XStepView'
20
- import Tree from './common/Tree'
21
- import CreateQuery from './common/CreateQuery'
22
- import CreateSimpleFormQuery from './common/CreateSimpleFormQuery'
23
- import XFormGroup from './common/XFormGroup'
24
- import XDescriptionsGroup from './common/XDescriptions/XDescriptionsGroup.vue'
25
-
26
- export default {
27
- AddressSearchCombobox,
28
- AmapMarker,
29
- CreateQuery,
30
- CreateSimpleFormQuery,
31
- FormGroupEdit,
32
- FormGroupQuery,
33
- JSONToTree,
34
- PersonSetting,
35
- Tree,
36
- Upload,
37
- XAddForm,
38
- XAddNativeForm,
39
- XBadge,
40
- XCard,
41
- XDataDrawer,
42
- XDescriptionsGroup,
43
- XForm,
44
- XFormCol,
45
- XFormGroup,
46
- XFormTable,
47
- XImportExcel,
48
- XStepView,
49
- XTable,
50
- XTreeOne
51
- }
1
+ import XForm from './common/XForm'
2
+ import XAddForm from './common/XAddForm'
3
+ import XAddNativeForm from './common/XAddNativeForm'
4
+ import XFormCol from './common/XFormCol'
5
+ import XTable from './common/XTable'
6
+ import XTreeOne from './common/XTreeOne'
7
+ import XImportExcel from './common/XImportExcel'
8
+ import XDataDrawer from './common/XDataDrawer'
9
+ import XCard from './common/XCard'
10
+ import XBadge from './common/XBadge'
11
+ import Upload from './common/Upload'
12
+ import JSONToTree from './common/JSONToTree'
13
+ import FormGroupEdit from './common/FormGroupEdit'
14
+ import FormGroupQuery from './common/FormGroupQuery'
15
+ import AddressSearchCombobox from './common/AddressSearchCombobox'
16
+ import AmapMarker from './common/AmapMarker'
17
+ import PersonSetting from './common/PersonSetting'
18
+ import XFormTable from './common/XFormTable'
19
+ import XStepView from './common/XStepView'
20
+ import Tree from './common/Tree'
21
+ import CreateQuery from './common/CreateQuery'
22
+ import CreateSimpleFormQuery from './common/CreateSimpleFormQuery'
23
+ import XFormGroup from './common/XFormGroup'
24
+ import XDescriptionsGroup from './common/XDescriptions/XDescriptionsGroup.vue'
25
+
26
+ export default {
27
+ AddressSearchCombobox,
28
+ AmapMarker,
29
+ CreateQuery,
30
+ CreateSimpleFormQuery,
31
+ FormGroupEdit,
32
+ FormGroupQuery,
33
+ JSONToTree,
34
+ PersonSetting,
35
+ Tree,
36
+ Upload,
37
+ XAddForm,
38
+ XAddNativeForm,
39
+ XBadge,
40
+ XCard,
41
+ XDataDrawer,
42
+ XDescriptionsGroup,
43
+ XForm,
44
+ XFormCol,
45
+ XFormGroup,
46
+ XFormTable,
47
+ XImportExcel,
48
+ XStepView,
49
+ XTable,
50
+ XTreeOne
51
+ }