jufubao-base 1.0.237-beta1 → 1.0.237-beta10

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 (126) hide show
  1. package/package.json +1 -1
  2. package/src/components/JfbBaseBalance/Api.js +46 -0
  3. package/src/components/JfbBaseBalance/Attr.js +316 -0
  4. package/src/components/JfbBaseBalance/JfbBaseBalance.vue +334 -0
  5. package/src/components/JfbBaseBalance/JfbBaseBalanceLess.less +79 -0
  6. package/src/components/JfbBaseBalance/JfbBaseBalanceMixin.js +30 -0
  7. package/src/components/JfbBaseBalance/Mock.js +9 -0
  8. package/src/components/JfbBaseCodeOpenVip/Api.js +35 -0
  9. package/src/components/JfbBaseCodeOpenVip/Attr.js +281 -0
  10. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVip.vue +251 -0
  11. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVipLess.less +79 -0
  12. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVipMixin.js +30 -0
  13. package/src/components/JfbBaseCodeOpenVip/Mock.js +13 -0
  14. package/src/components/JfbBaseConsumpCode/Api.js +133 -0
  15. package/src/components/JfbBaseConsumpCode/Attr.js +61 -0
  16. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCode.vue +973 -0
  17. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCodeLess.less +79 -0
  18. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCodeMixin.js +30 -0
  19. package/src/components/JfbBaseConsumpCode/Mock.js +22 -0
  20. package/src/components/JfbBaseFastLink/Attr.js +12 -1
  21. package/src/components/JfbBaseFastLink/JfbBaseFastLink.vue +66 -0
  22. package/src/components/JfbBaseHeader/Attr.js +82 -0
  23. package/src/components/JfbBaseHeader/JfbBaseHeader.vue +47 -1
  24. package/src/components/JfbBaseHeaderColumn/Attr.js +82 -0
  25. package/src/components/JfbBaseHeaderColumn/JfbBaseHeaderColumn.vue +48 -2
  26. package/src/components/JfbBaseLogin/JfbBaseLogin.vue +11 -0
  27. package/src/components/JfbBaseNoticeDialog/Api.js +1 -1
  28. package/src/components/JfbBaseNoticeDialog/Attr.js +26 -0
  29. package/src/components/JfbBaseNoticeDialog/JfbBaseNoticeDialog.vue +27 -8
  30. package/src/components/JfbBaseNoticeGroup/Api.js +58 -0
  31. package/src/components/JfbBaseNoticeGroup/Attr.js +48 -0
  32. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroup.vue +111 -0
  33. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroupLess.less +79 -0
  34. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroupMixin.js +30 -0
  35. package/src/components/JfbBaseNoticeGroup/Mock.js +13 -0
  36. package/src/components/JfbBaseOpenVip/Api.js +39 -0
  37. package/src/components/JfbBaseOpenVip/Attr.js +331 -0
  38. package/src/components/JfbBaseOpenVip/JfbBaseOpenVip.vue +457 -0
  39. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipLess.less +79 -0
  40. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipMixin.js +30 -0
  41. package/src/components/JfbBaseOpenVip/Mock.js +7 -0
  42. package/src/components/JfbBaseOpenVip/XdVipList.vue +131 -0
  43. package/src/components/JfbBaseOpenVipCard/Api.js +58 -0
  44. package/src/components/JfbBaseOpenVipCard/Attr.js +48 -0
  45. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCard.vue +111 -0
  46. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardLess.less +79 -0
  47. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardMixin.js +30 -0
  48. package/src/components/JfbBaseOpenVipCard/Mock.js +13 -0
  49. package/src/components/JfbBaseOpenVipDetail/Api.js +35 -0
  50. package/src/components/JfbBaseOpenVipDetail/Attr.js +37 -0
  51. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetail.vue +234 -0
  52. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailLess.less +79 -0
  53. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailMixin.js +30 -0
  54. package/src/components/JfbBaseOpenVipDetail/Mock.js +15 -0
  55. package/src/components/JfbBasePay/Attr.js +52 -0
  56. package/src/components/JfbBasePay/JfbBasePay.vue +14 -4
  57. package/src/components/JfbBasePay/Mock.js +0 -9
  58. package/src/components/JfbBasePersonalData/Api.js +26 -0
  59. package/src/components/JfbBasePersonalData/Attr.js +36 -0
  60. package/src/components/JfbBasePersonalData/JfbBasePersonalData.vue +198 -0
  61. package/src/components/JfbBasePersonalData/JfbBasePersonalDataLess.less +79 -0
  62. package/src/components/JfbBasePersonalData/JfbBasePersonalDataMixin.js +30 -0
  63. package/src/components/JfbBasePersonalData/Mock.js +13 -0
  64. package/src/components/JfbBasePhoneLogin/JfbBasePhoneLogin.vue +9 -0
  65. package/src/components/JfbBasePointsCard/Api.js +18 -0
  66. package/src/components/JfbBasePointsCard/Attr.js +187 -0
  67. package/src/components/JfbBasePointsCard/JfbBasePointsCard.vue +212 -0
  68. package/src/components/JfbBasePointsCard/JfbBasePointsCardLess.less +79 -0
  69. package/src/components/JfbBasePointsCard/JfbBasePointsCardMixin.js +30 -0
  70. package/src/components/JfbBasePointsCard/Mock.js +5 -0
  71. package/src/components/JfbBasePointsDetail/Api.js +48 -0
  72. package/src/components/JfbBasePointsDetail/Attr.js +304 -0
  73. package/src/components/JfbBasePointsDetail/JfbBasePointsDetail.vue +267 -0
  74. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailLess.less +79 -0
  75. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailMixin.js +30 -0
  76. package/src/components/JfbBasePointsDetail/Mock.js +6 -0
  77. package/src/components/JfbBasePoster/Attr.js +1 -1
  78. package/src/components/JfbBasePosterBigSmall/JfbBasePosterBigSmall.vue +2 -2
  79. package/src/components/JfbBasePosterGroup/Api.js +22 -0
  80. package/src/components/JfbBasePosterGroup/Attr.js +156 -0
  81. package/src/components/JfbBasePosterGroup/JfbBasePosterGroup.vue +268 -0
  82. package/src/components/JfbBasePosterGroup/JfbBasePosterGroupLess.less +79 -0
  83. package/src/components/JfbBasePosterGroup/JfbBasePosterGroupMixin.js +30 -0
  84. package/src/components/JfbBasePosterGroup/Mock.js +13 -0
  85. package/src/components/JfbBaseSavingDetail/Api.js +41 -0
  86. package/src/components/JfbBaseSavingDetail/Attr.js +70 -0
  87. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetail.vue +702 -0
  88. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailLess.less +79 -0
  89. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailMixin.js +30 -0
  90. package/src/components/JfbBaseSavingDetail/Mock.js +10 -0
  91. package/src/components/JfbBaseSavingDetail/components/echarts.min.js +26 -0
  92. package/src/components/JfbBaseSavingDetail/components/echarts.vue +254 -0
  93. package/src/components/JfbBaseSavingDetail/components/wx-canvas.js +105 -0
  94. package/src/components/JfbBaseShare/Api.js +20 -0
  95. package/src/components/JfbBaseShare/Attr.js +14 -0
  96. package/src/components/JfbBaseShare/JfbBaseShare.vue +272 -0
  97. package/src/components/JfbBaseShare/JfbBaseShareLess.less +79 -0
  98. package/src/components/JfbBaseShare/JfbBaseShareMixin.js +30 -0
  99. package/src/components/JfbBaseShare/Mock.js +16 -0
  100. package/src/components/JfbBaseTfkSearch/ContentProduct.vue +12 -22
  101. package/src/components/JfbBaseTfkSearch/JfbBaseTfkSearch.vue +12 -1
  102. package/src/components/JfbBaseTfkSearch/Mock.js +51 -3
  103. package/src/components/JfbBaseTfkSearch/listMixins.js +2 -1
  104. package/src/components/JfbBaseUserInfo/Attr.js +175 -11
  105. package/src/components/JfbBaseUserInfo/JfbBaseUserInfo.vue +337 -115
  106. package/src/components/JfbBaseUserOrder/Attr.js +16 -0
  107. package/src/components/JfbBaseUserOrder/JfbBaseUserOrder.vue +11 -2
  108. package/src/components/JfbBaseWithDrawAgain/Api.js +41 -0
  109. package/src/components/JfbBaseWithDrawAgain/Attr.js +92 -0
  110. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgain.vue +334 -0
  111. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainLess.less +79 -0
  112. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainMixin.js +30 -0
  113. package/src/components/JfbBaseWithDrawAgain/Mock.js +10 -0
  114. package/src/components/JfbBaseWithDrawRecord/Api.js +19 -0
  115. package/src/components/JfbBaseWithDrawRecord/Attr.js +79 -0
  116. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecord.vue +233 -0
  117. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordLess.less +79 -0
  118. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordMixin.js +30 -0
  119. package/src/components/JfbBaseWithDrawRecord/Mock.js +7 -0
  120. package/src/components/JfbBaseWithdraw/Api.js +48 -0
  121. package/src/components/JfbBaseWithdraw/Attr.js +328 -0
  122. package/src/components/JfbBaseWithdraw/JfbBaseWithdraw.vue +261 -0
  123. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawLess.less +79 -0
  124. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawMixin.js +30 -0
  125. package/src/components/JfbBaseWithdraw/Mock.js +7 -0
  126. package/src/components/JfbBaseWxAuthorize/JfbBaseWxAuthorize.vue +10 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "jufubao-base",
3
- "version": "1.0.237-beta1",
3
+ "version": "1.0.237-beta10",
4
4
  "private": false,
5
5
  "description": "聚福宝业务组件基础插件包",
6
6
  "main": "index.js",
@@ -0,0 +1,46 @@
1
+ 'use strict';
2
+ /**
3
+ * @description 接口配置,
4
+ * 在设置方法名字当时候,别忘记加上【模块名字】:Points
5
+ * @type {*[]}
6
+ */
7
+ module.exports = [
8
+ {
9
+ mapFnName: 'getListBaseNewsContent', //自定义方法名字(必选)
10
+ title: '获取内容',
11
+ path: '/cms/v1/news-content',
12
+ isRule: false,
13
+ params: {
14
+ scene: ['使用场景', 'String', '选填'],
15
+ container_id: ['插件ID', 'String', '必填'],
16
+ page_id: ['页面ID', 'String', '必填'],
17
+ page_size: ['记录条数', 'Number', '必填', 1],
18
+ code: ['业务线id', 'String', '选填'],
19
+ },
20
+ isConsole: true,
21
+ disabled: true,
22
+ },
23
+ {
24
+ mapFnName: 'getBalanceDetail',
25
+ title: '用户资产 - 获取钱包(或积分)余额详情',
26
+ path: '/pay/v1/property/wallet-detail',
27
+ isRule: false,
28
+ params: {
29
+ method: ['wallet 余额; score 积分;', 'Number', '非必选'],
30
+ },
31
+ isConsole: true,
32
+ disabled: true,
33
+ },
34
+ {
35
+ mapFnName: 'getBalanceWalletTradeList',
36
+ title: '用户资产 - 获取钱包(或积分)交易记录列表',
37
+ path: '/pay/v1/property/wallet-trade/list',
38
+ isRule: false,
39
+ params: {
40
+ wallet_type: ['钱包类型', 'Number', '必选'],
41
+ page_size: ['每页条数', 'Number', '必选'],
42
+ },
43
+ isConsole: true,
44
+ disabled: true,
45
+ },
46
+ ];
@@ -0,0 +1,316 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ * @description 当表单组件中有联动操作时候,使用方法进行返回
5
+ */
6
+ export default {
7
+ style: [],
8
+ content: (data) => {
9
+ return [
10
+ {
11
+ label: '外边距:',
12
+ ele: 'xd-margin-padding',
13
+ valueKey: 'bodyMargin',
14
+ groupKey: 'style',
15
+ value: data['bodyMargin'] || null,
16
+ setting: {
17
+ type: 'margin',
18
+ },
19
+ placeholder: '请设置外边距',
20
+ inline: false,
21
+ notice: '设置外边距,<span style="color: red">单位:像素</span>。默认值:<span style="color: red">0</span>像素',
22
+ },
23
+ {
24
+ label: '外填充:',
25
+ ele: 'xd-margin-padding',
26
+ valueKey: 'bodyPadding',
27
+ groupKey: 'style',
28
+ value: data['bodyPadding'] || null,
29
+ setting: {
30
+ type: 'padding',
31
+ },
32
+ placeholder: '请设置外填充',
33
+ inline: false,
34
+ notice: '设置填充值,<span style="color: red">单位:像素</span>。默认值:<span style="color: red">20</span>像素',
35
+ },
36
+ {
37
+ label: '圆角设置:',
38
+ ele: 'xd-site-select-list',
39
+ valueKey: 'radius',
40
+ value: data['radius'] || '20',
41
+ labelInline: true,
42
+ groupKey: 'style',
43
+ placeholder: '请选择圆角设置',
44
+ multiple: false,
45
+ className: 'input60',
46
+ handleCustom({ action, data }) {
47
+ XdBus.getParentApi('getOptionsSettingList')({
48
+ setting_id: 'edtix_style_radius',
49
+ key: Date.now()
50
+ })
51
+ .then(res => {
52
+ data.cb(res.list)
53
+ })
54
+ .catch(error => {
55
+ console.error(error);
56
+ });
57
+ },
58
+ },
59
+ {
60
+ label: "边框设置:",
61
+ ele: "xd-border",
62
+ valueKey: "bodyBorder",
63
+ value: data['bodyBorder'] || { type: 'Y', value: { color: '#eee', style: "solid", width: '1' } },
64
+ className: 'input80',
65
+ groupKey: 'style',
66
+ },
67
+ {
68
+ label: '背景颜色:',
69
+ ele: 'xd-color',
70
+ valueKey: 'bgColor',
71
+ groupKey: 'style',
72
+ value: data['bgColor'] || null,
73
+ placeholder: '请选择背景颜色',
74
+ labelInline: true,
75
+ classNmae: 'input80',
76
+ },
77
+ {
78
+ label: '公告内容:',
79
+ ele: 'xd-site-news',
80
+ valueKey: 'notice',
81
+ groupKey: 'content',
82
+ value: data.notice || null,
83
+ className: 'input70',
84
+ setting: {
85
+ config: {
86
+ sort: true,
87
+ maxlen: 100,
88
+ action: 'aliyun',
89
+ size: 5,
90
+ tipsformet: '上传文件格式:@imageType@,不超过@size@MB.',
91
+ uploadType: 'aliyun',
92
+ type: ['jpg', 'png', 'jpeg']
93
+ },
94
+ },
95
+ handleCustom({ action, data }) {
96
+ if (data && data.params) {
97
+ //当一个插件中出现使用内容分类时候需要设置code值,在页面引用时候容器id + code进行拼接
98
+ //data.params = Object.assign({}, data.params, {code: 'g_test_id'});
99
+ }
100
+
101
+ //获取返回参数(场景类型名称为必填)
102
+ //获取返回参数(场景类型名称为必填)
103
+ let loading = { close() { } }
104
+
105
+ //获取显示内容
106
+ if (action === 'screen') {
107
+ XdBus.getParentApi('getOptionsSettingList')({ setting_id: 'edtix_bucket_content_tip' })
108
+ .then(res => {
109
+ loading.close();
110
+ data.cb(res['list'])
111
+ })
112
+ .catch(error => {
113
+ console.error(error);
114
+ loading.close();
115
+ });
116
+
117
+ }
118
+
119
+ //获取返回参数(广告位高度必选项)
120
+ if (action === 'getNewsInfo') {
121
+ XdBus.getParentApi('cmsGetPublishEditxContent')(data.params)
122
+ .then(res => {
123
+ loading.close()
124
+ data.cb({ list: res.list, selectId: res.selected })
125
+ })
126
+ .catch(error => {
127
+ loading.close()
128
+ console.error(error);
129
+ });
130
+ }
131
+
132
+ //获取产品业务线列表
133
+ if (action === 'namespace') {
134
+ XdBus.getParentApi('getOptionsNamespaces')({})
135
+ .then(res => {
136
+ loading.close()
137
+ data.cb(res['list'])
138
+ })
139
+ .catch(error => {
140
+ loading.close()
141
+ console.error(error);
142
+ });
143
+ }
144
+
145
+ //使用内容分类
146
+ if (action === 'cmsPublishEditxContent') {
147
+ loading = XdBus.getParentApi('loading')({});
148
+ XdBus.getParentApi('cmsPublishEditxContent')(data.params)
149
+ .then(res => {
150
+ console.log('cmsPublishEditxContent', res)
151
+ loading.close();
152
+ data.cb(res)
153
+ })
154
+ .catch(error => {
155
+ loading.close();
156
+ console.error(error);
157
+ });
158
+ }
159
+
160
+ //位置列表
161
+ if (action === 'getListPostion') {
162
+ loading = XdBus.getParentApi('loading')({});
163
+ XdBus.getParentApi('getListNewsPosition')(data.params)
164
+ .then(res => {
165
+ loading.close();
166
+ data.cb(res)
167
+ })
168
+ .catch(error => {
169
+ loading.close();
170
+ console.error(error);
171
+ });
172
+ }
173
+
174
+ //位置创建
175
+ if (action === 'addPostion') {
176
+ loading = XdBus.getParentApi('loading')({});
177
+ XdBus.getParentApi('addNewsPosition')(data.params)
178
+ .then(res => {
179
+ loading.close();
180
+ data.cb(true)
181
+ })
182
+ .catch(error => {
183
+ console.error(error);
184
+ loading.close();
185
+ data.cb(false)
186
+ });
187
+ }
188
+
189
+ //位置编辑
190
+ if (action === 'editPostion') {
191
+ loading = XdBus.getParentApi('loading')({});
192
+ XdBus.getParentApi('updateNewsPosition')(data.params)
193
+ .then(res => {
194
+ loading.close();
195
+ data.cb(true)
196
+ })
197
+ .catch(error => {
198
+ console.error(error);
199
+ loading.close();
200
+ data.cb(false)
201
+ });
202
+ }
203
+
204
+ //位置删除
205
+ if (action === 'deleltePostion') {
206
+ loading = XdBus.getParentApi('loading')({});
207
+ XdBus.getParentApi('deleteNewsPosition')(data.params)
208
+ .then(res => {
209
+ loading.close();
210
+ data.cb(true)
211
+ })
212
+ .catch(error => {
213
+ console.error(error);
214
+ loading.close();
215
+ data.cb(false)
216
+ });
217
+ }
218
+
219
+ //获取广告位内容列表
220
+ if (action === 'getListContent') {
221
+ loading = XdBus.getParentApi('loading')({});
222
+ XdBus.getParentApi('getListNewsContent')(data.params)
223
+ .then(res => {
224
+ loading.close();
225
+ data.cb(res)
226
+ })
227
+ .catch(error => {
228
+ loading.close();
229
+ console.error(error);
230
+ });
231
+ }
232
+
233
+ //广告内容创建
234
+ if (action === 'addContent') {
235
+ loading = XdBus.getParentApi('loading')({});
236
+ XdBus.getParentApi('addNewsContent')(data.params)
237
+ .then(res => {
238
+ loading.close();
239
+ data.cb(true)
240
+ })
241
+ .catch(error => {
242
+ console.error(error);
243
+ loading.close();
244
+ data.cb(false)
245
+ });
246
+ }
247
+
248
+ //广告内容编辑
249
+ if (action === 'editContent') {
250
+ loading = XdBus.getParentApi('loading')({});
251
+ XdBus.getParentApi('updateNewsContent')(data.params)
252
+ .then(res => {
253
+ loading.close();
254
+ data.cb(true)
255
+ })
256
+ .catch(error => {
257
+ console.error(error);
258
+ loading.close();
259
+ data.cb(false)
260
+ });
261
+ }
262
+
263
+ //广告内容删除
264
+ if (action === 'deleteContent') {
265
+ loading = XdBus.getParentApi('loading')({});
266
+ XdBus.getParentApi('deleteNewsContent')(data.params)
267
+ .then(res => {
268
+ loading.close();
269
+ data.cb(true)
270
+ })
271
+ .catch(error => {
272
+ console.error(error);
273
+ loading.close();
274
+ data.cb(false)
275
+ });
276
+ }
277
+
278
+ //内容发布
279
+ if (action === 'publish') {
280
+ loading = XdBus.getParentApi('loading')({});
281
+ console.log('publish', data.params)
282
+ XdBus.getParentApi('cmsPublishContent')(data.params)
283
+ .then(res => {
284
+ loading.close();
285
+ data.cb(res)
286
+ })
287
+ .catch(error => {
288
+ loading.close();
289
+ console.error(error);
290
+ });
291
+ }
292
+
293
+ //通知页面进行刷新
294
+ if (action === 'update') {
295
+ loading = XdBus.getParentApi('loading')({});
296
+ XdBus.getParentApi('getXdBusUpdateView')('onUpdateView', {});
297
+ loading.close()
298
+ }
299
+ },
300
+ },
301
+ {
302
+ label: '提现入口路径:',
303
+ ele: 'xd-select-pages-path',
304
+ valueKey: 'withDrawRoutePath',
305
+ groupKey:'advanced',
306
+ placeholder: '请选择提现入口路径',
307
+ value: data['withDrawRoutePath'] || {},
308
+ setting: {
309
+ router: XdBus.getParentApi('getPagesTree'),
310
+ },
311
+ inline: false,
312
+ },
313
+ ].filter(i => i)
314
+ },
315
+ advanced: [],
316
+ };
@@ -0,0 +1,334 @@
1
+ <template>
2
+ <view class="jfb-base-balance" @click="handleEditxSelect" :class="{ editx : isEditx && active }">
3
+ <!--#ifdef H5-->
4
+ <view class="jfb-base-balance__edit" :class="{ editx : isEditx && active }" v-if="isEditx && active">
5
+ <view class="jfb-base-balance__edit-icon" @click="delEdit">删除</view>
6
+ </view>
7
+ <!-- #endif -->
8
+ <view class="jfb-base-balance__body">
9
+ <view class="jfb-base-balance__body-tab">
10
+ <view :style="{color:wallet_type===item.wallet_type?mainColor:'#333333'}" v-for="(item,index) in wallet_list" :key="index" @click="handleSwitchTab(item)"
11
+ class="jfb-base-balance__body-tab-item">
12
+ {{item.show_name}}
13
+ <view v-if="wallet_type===item.wallet_type" class="check" :style="{background: mainColor
14
+ }"></view>
15
+ <view class="check" v-else></view>
16
+ </view>
17
+ </view>
18
+ <view style="display: flex;justify-content: space-between;align-items: center;" :style="[bodyStyleComp]">
19
+ <view class="jfb-base-balance__body-points">
20
+ <view>
21
+ 我的余额
22
+ <XdFontIcon @click="showDialog=true" style="margin-left: 10rpx" size="20" icon="iconmingchengtubiao">
23
+ </XdFontIcon>
24
+ </view>
25
+ <view>{{getAmout(amount)}}</view>
26
+ </view>
27
+ <xd-button v-if="isWithDraw==='Y'" style="margin: 0" size="mini" type="primary"
28
+ @click="handleWithdraw">提现</xd-button>
29
+ </view>
30
+ <view v-if="recordList&&recordList.length>0" :style="[bodyStyleComp]" class="jfb-base-balance__body-list">
31
+ <view v-for="(item,index) in recordList" :key="index" class="jfb-base-balance__body-list-item">
32
+ <view class="jfb-base-balance__body-list-item-info">
33
+ <view class="jfb-base-balance__body-list-item-info-label">{{item.trade_type_name}}</view>
34
+ <view :class="item.operate_type==='A'?'income':'expenses'"
35
+ class="jfb-base-balance__body-list-item-info-value">
36
+ <text>{{item.operate_type==='A'?'+':'-'}}</text>
37
+ {{getAmout(item.amount)}}
38
+ </view>
39
+ </view>
40
+ <view class="jfb-base-balance__body-list-item-date">{{item.created_time}}</view>
41
+ </view>
42
+ </view>
43
+ <XdNoData v-else></XdNoData>
44
+ <XdDailog :cancel="false" @onBtn="showDialog=false" confirmText="我知道了" title="积分说明" :show.sync="showDialog">
45
+ <xd-content-xss v-html="notice"></xd-content-xss>
46
+ </XdDailog>
47
+ </view>
48
+ </view>
49
+ </template>
50
+
51
+ <script>
52
+ import XdFontIcon from "@/components/XdFontIcon/XdFontIcon";
53
+ import XdButton from "@/components/XdButton/XdButton";
54
+ import XdDailog from '@/components/XdDailog/XdDailog.vue';
55
+ import XdNoData from "@/components/XdNoData/XdNoData";
56
+ import XdContentXss from '@/components/XdContentXss/XdContentXss';
57
+ import { jfbRootExec } from "@/utils/xd.event";
58
+ import JfbBaseBalanceMixin from "./JfbBaseBalanceMixin";
59
+ import { getContainerPropsValue } from "@/utils/xd.base";
60
+ import componentsMixins from "@/mixins/componentsMixins";
61
+ import extsMixins from "@/mixins/extsMixins";
62
+ export default {
63
+ name: "JfbBaseBalance",
64
+ components: {
65
+ XdFontIcon,
66
+ XdDailog,
67
+ XdContentXss,
68
+ XdButton,
69
+ XdNoData
70
+ },
71
+ mixins: [
72
+ componentsMixins, extsMixins, JfbBaseBalanceMixin
73
+ ],
74
+ data() {
75
+ return {
76
+ income: false,
77
+ radius: 0,
78
+ margin: {},
79
+ padding: {},
80
+ bgColor: '',
81
+ bodyBorder: {},
82
+ notice: '',
83
+ showDialog: false,
84
+ withDrawRoutePath: '',
85
+ wallet_type: '',
86
+ wallet_list: [],
87
+ amount: 0,
88
+ isWithDraw: 'N',
89
+ recordList: [],
90
+ hasNext: true,
91
+ page_token: 1,
92
+ next_page_token: ''
93
+ }
94
+ },
95
+ computed: {
96
+ bodyStyleComp() {
97
+ return {
98
+ borderRadius: `${this.radius}rpx`,
99
+ margin: this.getMarginAndPadding(this.margin, 20),
100
+ padding: this.getMarginAndPadding(this.padding, 40),
101
+ background: this.bgColor,
102
+ border: this.bodyBorder,
103
+ }
104
+ },
105
+ },
106
+ watch: {
107
+ container(value, oldValue) {
108
+ if (JSON.stringify(value) === JSON.stringify(oldValue)) return;
109
+ if (this.$configProject['isPreview']) this.init(value)
110
+ },
111
+ },
112
+ created() {
113
+ this.init(this.container);
114
+ },
115
+ methods: {
116
+ onJfbLoad(options) {
117
+ this.method = options.method
118
+ this.getContent()
119
+ this.getDetail()
120
+ },
121
+ getAmout(amount) {
122
+ return this.$xdUniHelper.divisionFloatNumber(amount, 100)
123
+ },
124
+ getDetail() {
125
+ jfbRootExec("getBalanceDetail", {
126
+ vm: this,
127
+ data: {
128
+ method: this.method
129
+ },
130
+ }).then(res => {
131
+ this.wallet_type = res.wallet_list[0].wallet_type
132
+ this.isWithDraw = res.wallet_list[0].is_support_withdraw;
133
+ this.amount = res.wallet_list[0].amount;
134
+ this.wallet_list = res.wallet_list
135
+ this.getBalanceRecord()
136
+ }).catch(err => {
137
+ console.log(err, 'err');
138
+
139
+ })
140
+ },
141
+ getBalanceRecord(type) {
142
+ jfbRootExec("getBalanceWalletTradeList", {
143
+ vm: this,
144
+ data: {
145
+ wallet_type: this.wallet_type,
146
+ page_size: 10,
147
+ page_token: this.page_token
148
+ },
149
+ }).then(res => {
150
+ let list = res.list.map(item => {
151
+ item["created_time"] = this.$xdUniHelper.getDate(
152
+ item["created_time"] * 1000
153
+ ).fullTime;
154
+ return item;
155
+ })
156
+ if (this.page_token === 1) {
157
+ this.recordList = list
158
+ } else {
159
+ this.recordList = this.recordList.concat(list);
160
+ }
161
+ this.next_page_token = res.next_page_token
162
+ this.hasNext = res.next_page_token !== "";
163
+ })
164
+ },
165
+ getContent() {
166
+ jfbRootExec("getListBaseNewsContent", {
167
+ vm: this,
168
+ data: {
169
+ page_id: this.pageAttr["page_id"], //页面ID
170
+ container_id: this.containerId, //组件ID
171
+ limit: 1,
172
+ },
173
+ })
174
+ .then((res) => {
175
+ if (res.list.length > 0) {
176
+ if (res.list && res.list.length > 0) {
177
+ this.notice = this.$xdUniHelper.filterHtml(res.list[0].content);
178
+ }
179
+ this.noticeStatus = true;
180
+ }
181
+ })
182
+ .catch((error) => {
183
+ console.error(error);
184
+ });
185
+ },
186
+ /**
187
+ * @description 监听事件变化
188
+ * @param container {object} 业务组件对象自己
189
+ */
190
+ init(container) {
191
+ this.radius = getContainerPropsValue(container, 'content.radius', '20');
192
+ this.margin = getContainerPropsValue(container, 'content.bodyMargin', {});
193
+ this.padding = getContainerPropsValue(container, 'content.bodyPadding', {});
194
+ this.bgColor = getContainerPropsValue(container, 'content.bgColor', '#fff');
195
+ this.bodyBorder = this.getXdBorder({}, getContainerPropsValue(container, 'content.bodyBorder', {}))
196
+ this.withDrawRoutePath = getContainerPropsValue(container, 'content.withDrawRoutePath', { value: '' }).value;
197
+ },
198
+ handleWithdraw() {
199
+ this.$xdUniHelper.navigateTo({ url: `${this.withDrawRoutePath}?wallet_type=${this.wallet_type}&method=${this.method}` })
200
+ },
201
+ handleSwitchTab(item) {
202
+ this.wallet_type = item.wallet_type;
203
+ this.isWithDraw = item.is_support_withdraw;
204
+ this.amount = item.amount;
205
+ this.next_page_token=''
206
+ this.hasNext = true;
207
+ this.page_token = 1;
208
+ this.recordList = [];
209
+ this.getBalanceRecord()
210
+ },
211
+ onJfbScroll(options) {
212
+ console.log('event.onJfbScroll', options)
213
+ },
214
+ onJfbReachBottom(options) {
215
+ if (this.hasNext) {
216
+ this.page_token = this.next_page_token;
217
+ this.getBalanceRecord()
218
+ }
219
+ },
220
+ onJfbShow(options) {
221
+ console.log('event.onJfbShow', options)
222
+ this.method = options.method
223
+ this.getContent()
224
+ this.getDetail()
225
+ },
226
+ onJfbHide(options) {
227
+ console.log('event.onJfbHide', options)
228
+ },
229
+ onJfbBack(options) {
230
+ console.log('event.onJfbBack', options)
231
+ },
232
+ onJfbUpdate(...data) {
233
+ console.log('event.onJfbUpdate', data)
234
+ },
235
+ onJfbCustomEvent(options) {
236
+ console.log('event.onJfbReachBottom', options)
237
+ },
238
+ }
239
+ }
240
+
241
+ </script>
242
+
243
+ <style scoped lang="less">
244
+ @import "./JfbBaseBalanceLess.less";
245
+
246
+ .jfb-base-balance {
247
+ &__body {
248
+ &-tab {
249
+ display: flex;
250
+ justify-content: space-around;
251
+ align-items: center;
252
+ color: #666666;
253
+ font-size: 32rpx;
254
+ background: #fff;
255
+ padding: 24rpx 0;
256
+
257
+ &-item {
258
+ display: flex;
259
+ flex-direction: column;
260
+ align-items: center;
261
+ }
262
+
263
+ .check {
264
+ width: 60rpx;
265
+ height: 6rpx;
266
+ margin-top: 12rpx;
267
+ }
268
+ }
269
+
270
+ &-points {
271
+ background: #fff;
272
+
273
+ &>view:first-child {
274
+ display: flex;
275
+ align-items: center;
276
+ color: #333;
277
+ font-size: 24rpx;
278
+ }
279
+
280
+ &>view:nth-child(2) {
281
+ color: #333;
282
+ font-size: 64rpx;
283
+ font-weight: 500;
284
+ margin: 20rpx 0;
285
+ }
286
+
287
+ &>view:nth-child(3) {
288
+ color: #333333;
289
+ font-size: 28rpx;
290
+ }
291
+ }
292
+
293
+ &-list {
294
+ &-item {
295
+ margin-bottom: 40rpx;
296
+
297
+ &-info {
298
+ display: flex;
299
+ justify-content: space-between;
300
+ align-items: center;
301
+
302
+ &-label {
303
+ color: #333333;
304
+ font-size: 28rpx;
305
+ }
306
+
307
+ &-value {
308
+ font-size: 32rpx;
309
+ font-weight: 700;
310
+ }
311
+
312
+ .income {
313
+ color: #FF5A39;
314
+ }
315
+
316
+ .expenses {
317
+ color: #00C800;
318
+ }
319
+ }
320
+
321
+ &-date {
322
+ color: #999999;
323
+ font-size: 22rpx;
324
+ margin-top: 26rpx;
325
+ }
326
+ }
327
+
328
+ &-item:last-child {
329
+ margin-bottom: 0;
330
+ }
331
+ }
332
+ }
333
+ }
334
+ </style>