jufubao-base 1.0.236-beta1 → 1.0.236-beta21

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 (103) 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 +332 -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/JfbBaseCardGive/JfbBaseCardGive.vue +39 -6
  9. package/src/components/JfbBaseCardReceiveCover/JfbBaseCardReceiveCover.vue +3 -0
  10. package/src/components/JfbBaseCodeOpenVip/Api.js +36 -0
  11. package/src/components/JfbBaseCodeOpenVip/Attr.js +281 -0
  12. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVip.vue +253 -0
  13. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVipLess.less +79 -0
  14. package/src/components/JfbBaseCodeOpenVip/JfbBaseCodeOpenVipMixin.js +30 -0
  15. package/src/components/JfbBaseCodeOpenVip/Mock.js +13 -0
  16. package/src/components/JfbBaseConsumpCode/Api.js +133 -0
  17. package/src/components/JfbBaseConsumpCode/Attr.js +61 -0
  18. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCode.vue +961 -0
  19. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCodeLess.less +79 -0
  20. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCodeMixin.js +30 -0
  21. package/src/components/JfbBaseConsumpCode/Mock.js +22 -0
  22. package/src/components/JfbBaseNotice/Attr.js +9 -6
  23. package/src/components/JfbBaseNotice/JfbBaseNotice.vue +40 -6
  24. package/src/components/JfbBaseNoticeDialog/Api.js +1 -1
  25. package/src/components/JfbBaseNoticeDialog/Attr.js +26 -0
  26. package/src/components/JfbBaseNoticeDialog/JfbBaseNoticeDialog.vue +25 -6
  27. package/src/components/JfbBaseOpenVip/Api.js +39 -0
  28. package/src/components/JfbBaseOpenVip/Attr.js +270 -0
  29. package/src/components/JfbBaseOpenVip/JfbBaseOpenVip.vue +424 -0
  30. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipLess.less +79 -0
  31. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipMixin.js +30 -0
  32. package/src/components/JfbBaseOpenVip/Mock.js +7 -0
  33. package/src/components/JfbBaseOpenVip/XdVipList.vue +125 -0
  34. package/src/components/JfbBaseOpenVipCard/Api.js +58 -0
  35. package/src/components/JfbBaseOpenVipCard/Attr.js +48 -0
  36. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCard.vue +111 -0
  37. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardLess.less +79 -0
  38. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardMixin.js +30 -0
  39. package/src/components/JfbBaseOpenVipCard/Mock.js +13 -0
  40. package/src/components/JfbBaseOpenVipDetail/Api.js +36 -0
  41. package/src/components/JfbBaseOpenVipDetail/Attr.js +37 -0
  42. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetail.vue +225 -0
  43. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailLess.less +79 -0
  44. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailMixin.js +30 -0
  45. package/src/components/JfbBaseOpenVipDetail/Mock.js +13 -0
  46. package/src/components/JfbBasePersonalData/Api.js +26 -0
  47. package/src/components/JfbBasePersonalData/Attr.js +12 -0
  48. package/src/components/JfbBasePersonalData/JfbBasePersonalData.vue +198 -0
  49. package/src/components/JfbBasePersonalData/JfbBasePersonalDataLess.less +79 -0
  50. package/src/components/JfbBasePersonalData/JfbBasePersonalDataMixin.js +30 -0
  51. package/src/components/JfbBasePersonalData/Mock.js +13 -0
  52. package/src/components/JfbBasePointsCard/Api.js +18 -0
  53. package/src/components/JfbBasePointsCard/Attr.js +187 -0
  54. package/src/components/JfbBasePointsCard/JfbBasePointsCard.vue +208 -0
  55. package/src/components/JfbBasePointsCard/JfbBasePointsCardLess.less +79 -0
  56. package/src/components/JfbBasePointsCard/JfbBasePointsCardMixin.js +30 -0
  57. package/src/components/JfbBasePointsCard/Mock.js +5 -0
  58. package/src/components/JfbBasePointsDetail/Api.js +48 -0
  59. package/src/components/JfbBasePointsDetail/Attr.js +304 -0
  60. package/src/components/JfbBasePointsDetail/JfbBasePointsDetail.vue +267 -0
  61. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailLess.less +79 -0
  62. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailMixin.js +30 -0
  63. package/src/components/JfbBasePointsDetail/Mock.js +6 -0
  64. package/src/components/JfbBasePosterType/Attr.js +1 -0
  65. package/src/components/JfbBaseSavingDetail/Api.js +41 -0
  66. package/src/components/JfbBaseSavingDetail/Attr.js +70 -0
  67. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetail.vue +679 -0
  68. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailLess.less +79 -0
  69. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailMixin.js +30 -0
  70. package/src/components/JfbBaseSavingDetail/Mock.js +10 -0
  71. package/src/components/JfbBaseSavingDetail/components/echarts.min.js +26 -0
  72. package/src/components/JfbBaseSavingDetail/components/echarts.vue +254 -0
  73. package/src/components/JfbBaseSavingDetail/components/wx-canvas.js +105 -0
  74. package/src/components/JfbBaseShare/Api.js +20 -0
  75. package/src/components/JfbBaseShare/Attr.js +48 -0
  76. package/src/components/JfbBaseShare/JfbBaseShare.vue +261 -0
  77. package/src/components/JfbBaseShare/JfbBaseShareLess.less +79 -0
  78. package/src/components/JfbBaseShare/JfbBaseShareMixin.js +30 -0
  79. package/src/components/JfbBaseShare/Mock.js +13 -0
  80. package/src/components/JfbBaseTfkSearch/ContentProduct.vue +11 -22
  81. package/src/components/JfbBaseTfkSearch/JfbBaseTfkSearch.vue +8 -1
  82. package/src/components/JfbBaseTfkSearch/Mock.js +51 -3
  83. package/src/components/JfbBaseTfkSearch/listMixins.js +1 -1
  84. package/src/components/JfbBaseUserInfo/Attr.js +102 -10
  85. package/src/components/JfbBaseUserInfo/JfbBaseUserInfo.vue +305 -114
  86. package/src/components/JfbBaseWithDrawAgain/Api.js +41 -0
  87. package/src/components/JfbBaseWithDrawAgain/Attr.js +92 -0
  88. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgain.vue +334 -0
  89. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainLess.less +79 -0
  90. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainMixin.js +30 -0
  91. package/src/components/JfbBaseWithDrawAgain/Mock.js +10 -0
  92. package/src/components/JfbBaseWithDrawRecord/Api.js +19 -0
  93. package/src/components/JfbBaseWithDrawRecord/Attr.js +79 -0
  94. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecord.vue +233 -0
  95. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordLess.less +79 -0
  96. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordMixin.js +30 -0
  97. package/src/components/JfbBaseWithDrawRecord/Mock.js +7 -0
  98. package/src/components/JfbBaseWithdraw/Api.js +48 -0
  99. package/src/components/JfbBaseWithdraw/Attr.js +328 -0
  100. package/src/components/JfbBaseWithdraw/JfbBaseWithdraw.vue +245 -0
  101. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawLess.less +79 -0
  102. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawMixin.js +30 -0
  103. package/src/components/JfbBaseWithdraw/Mock.js +7 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "jufubao-base",
3
- "version": "1.0.236-beta1",
3
+ "version": "1.0.236-beta21",
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,332 @@
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 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>可用:{{getAmout(amount)}}</view>
27
+ </view>
28
+ <xd-button v-if="isWithDraw==='Y'" style="margin: 0" size="mini" type="primary"
29
+ @click="handleWithdraw">提现</xd-button>
30
+ </view>
31
+ <view v-if="recordList&&recordList.length>0" :style="[bodyStyleComp]" class="jfb-base-balance__body-list">
32
+ <view v-for="(item,index) in recordList" :key="index" class="jfb-base-balance__body-list-item">
33
+ <view class="jfb-base-balance__body-list-item-info">
34
+ <view class="jfb-base-balance__body-list-item-info-label">{{item.trade_type_name}}</view>
35
+ <view :class="item.operate_type==='A'?'income':'expenses'"
36
+ class="jfb-base-balance__body-list-item-info-value">
37
+ <text>{{item.operate_type==='A'?'+':'-'}}</text>
38
+ {{getAmout(item.amount)}}
39
+ </view>
40
+ </view>
41
+ <view class="jfb-base-balance__body-list-item-date">{{item.created_time}}</view>
42
+ </view>
43
+ </view>
44
+ <XdNoData v-else></XdNoData>
45
+ <XdDailog :cancel="false" @onBtn="showDialog=false" confirmText="我知道了" title="积分说明" :show.sync="showDialog">
46
+ <xd-content-xss v-html="notice"></xd-content-xss>
47
+ </XdDailog>
48
+ </view>
49
+ </view>
50
+ </template>
51
+
52
+ <script>
53
+ import XdFontIcon from "@/components/XdFontIcon/XdFontIcon";
54
+ import XdButton from "@/components/XdButton/XdButton";
55
+ import XdDailog from '@/components/XdDailog/XdDailog.vue';
56
+ import XdNoData from "@/components/XdNoData/XdNoData";
57
+ import XdContentXss from '@/components/XdContentXss/XdContentXss';
58
+ import { jfbRootExec } from "@/utils/xd.event";
59
+ import JfbBaseBalanceMixin from "./JfbBaseBalanceMixin";
60
+ import { getContainerPropsValue } from "@/utils/xd.base";
61
+ import componentsMixins from "@/mixins/componentsMixins";
62
+ import extsMixins from "@/mixins/extsMixins";
63
+ export default {
64
+ name: "JfbBaseBalance",
65
+ components: {
66
+ XdFontIcon,
67
+ XdDailog,
68
+ XdContentXss,
69
+ XdButton,
70
+ XdNoData
71
+ },
72
+ mixins: [
73
+ componentsMixins, extsMixins, JfbBaseBalanceMixin
74
+ ],
75
+ data() {
76
+ return {
77
+ income: false,
78
+ radius: 0,
79
+ margin: {},
80
+ padding: {},
81
+ bgColor: '',
82
+ bodyBorder: {},
83
+ notice: '',
84
+ showDialog: false,
85
+ withDrawRoutePath: '',
86
+ wallet_type: '',
87
+ wallet_list: [],
88
+ amount: 0,
89
+ isWithDraw: 'N',
90
+ recordList: [],
91
+ hasNext: true,
92
+ page_token: 1,
93
+ next_page_token: ''
94
+ }
95
+ },
96
+ computed: {
97
+ bodyStyleComp() {
98
+ return {
99
+ borderRadius: `${this.radius}rpx`,
100
+ margin: this.getMarginAndPadding(this.margin, 20),
101
+ padding: this.getMarginAndPadding(this.padding, 40),
102
+ background: this.bgColor,
103
+ border: this.bodyBorder,
104
+ }
105
+ },
106
+ },
107
+ watch: {
108
+ container(value, oldValue) {
109
+ if (JSON.stringify(value) === JSON.stringify(oldValue)) return;
110
+ if (this.$configProject['isPreview']) this.init(value)
111
+ },
112
+ },
113
+ created() {
114
+ this.init(this.container);
115
+ },
116
+ methods: {
117
+ onJfbLoad(options) {
118
+ this.method = options.method
119
+ this.getContent()
120
+ this.getDetail()
121
+ },
122
+ getAmout(amount) {
123
+ return this.$xdUniHelper.divisionFloatNumber(amount, 100)
124
+ },
125
+ getDetail() {
126
+ jfbRootExec("getBalanceDetail", {
127
+ vm: this,
128
+ data: {
129
+ method: this.method
130
+ },
131
+ }).then(res => {
132
+ this.wallet_type = res.wallet_list[0].wallet_type
133
+ this.isWithDraw = res.wallet_list[0].is_support_withdraw;
134
+ this.amount = res.wallet_list[0].amount;
135
+ this.wallet_list = res.wallet_list
136
+ this.getBalanceRecord()
137
+ }).catch(err => {
138
+ console.log(err, 'err');
139
+
140
+ })
141
+ },
142
+ getBalanceRecord(type) {
143
+ jfbRootExec("getBalanceWalletTradeList", {
144
+ vm: this,
145
+ data: {
146
+ wallet_type: this.wallet_type,
147
+ page_size: 10,
148
+ page_token: this.page_token
149
+ },
150
+ }).then(res => {
151
+ let list = res.list.map(item => {
152
+ item["created_time"] = this.$xdUniHelper.getDate(
153
+ item["created_time"] * 1000
154
+ ).fullTime;
155
+ return item;
156
+ })
157
+ if (this.page_token === 1) {
158
+ this.recordList = list
159
+ } else {
160
+ this.recordList = this.recordList.concat(list);
161
+ }
162
+ this.next_page_token = res.next_page_token
163
+ this.hasNext = res.next_page_token !== "";
164
+ })
165
+ },
166
+ getContent() {
167
+ jfbRootExec("getListBaseNewsContent", {
168
+ vm: this,
169
+ data: {
170
+ page_id: this.pageAttr["page_id"], //页面ID
171
+ container_id: this.containerId, //组件ID
172
+ limit: 1,
173
+ },
174
+ })
175
+ .then((res) => {
176
+ if (res.list.length > 0) {
177
+ if (res.list && res.list.length > 0) {
178
+ this.notice = this.$xdUniHelper.filterHtml(res.list[0].content);
179
+ }
180
+ this.noticeStatus = true;
181
+ }
182
+ })
183
+ .catch((error) => {
184
+ console.error(error);
185
+ });
186
+ },
187
+ /**
188
+ * @description 监听事件变化
189
+ * @param container {object} 业务组件对象自己
190
+ */
191
+ init(container) {
192
+ this.radius = getContainerPropsValue(container, 'content.radius', '20');
193
+ this.margin = getContainerPropsValue(container, 'content.bodyMargin', {});
194
+ this.padding = getContainerPropsValue(container, 'content.bodyPadding', {});
195
+ this.bgColor = getContainerPropsValue(container, 'content.bgColor', '#fff');
196
+ this.bodyBorder = this.getXdBorder({}, getContainerPropsValue(container, 'content.bodyBorder', {}))
197
+ this.withDrawRoutePath = getContainerPropsValue(container, 'content.withDrawRoutePath', { value: '' }).value;
198
+ },
199
+ handleWithdraw() {
200
+ this.$xdUniHelper.navigateTo({ url: `${this.withDrawRoutePath}?wallet_type=${this.wallet_type}&method=${this.method}` })
201
+ },
202
+ handleSwitchTab(item) {
203
+ this.wallet_type = item.wallet_type;
204
+ this.isWithDraw = item.is_support_withdraw;
205
+ this.amount = item.amount;
206
+ this.next_page_token=''
207
+ this.hasNext = true;
208
+ this.page_token = 1;
209
+ this.recordList = [];
210
+ this.getBalanceRecord()
211
+ },
212
+ onJfbScroll(options) {
213
+ console.log('event.onJfbScroll', options)
214
+ },
215
+ onJfbReachBottom(options) {
216
+ if (this.hasNext) {
217
+ this.page_token = this.next_page_token;
218
+ this.getBalanceRecord()
219
+ }
220
+ },
221
+ onJfbShow(options) {
222
+ console.log('event.onJfbShow', options)
223
+ },
224
+ onJfbHide(options) {
225
+ console.log('event.onJfbHide', options)
226
+ },
227
+ onJfbBack(options) {
228
+ console.log('event.onJfbBack', options)
229
+ },
230
+ onJfbUpdate(...data) {
231
+ console.log('event.onJfbUpdate', data)
232
+ },
233
+ onJfbCustomEvent(options) {
234
+ console.log('event.onJfbReachBottom', options)
235
+ },
236
+ }
237
+ }
238
+
239
+ </script>
240
+
241
+ <style scoped lang="less">
242
+ @import "./JfbBaseBalanceLess.less";
243
+
244
+ .jfb-base-balance {
245
+ &__body {
246
+ &-tab {
247
+ display: flex;
248
+ justify-content: space-around;
249
+ align-items: center;
250
+ color: #666666;
251
+ font-size: 32rpx;
252
+ background: #fff;
253
+ padding: 24rpx 0;
254
+
255
+ &-item {
256
+ display: flex;
257
+ flex-direction: column;
258
+ align-items: center;
259
+ }
260
+
261
+ .check {
262
+ width: 60rpx;
263
+ height: 6rpx;
264
+ margin-top: 12rpx;
265
+ }
266
+ }
267
+
268
+ &-points {
269
+ background: #fff;
270
+
271
+ &>view:first-child {
272
+ display: flex;
273
+ align-items: center;
274
+ color: #333;
275
+ font-size: 24rpx;
276
+ }
277
+
278
+ &>view:nth-child(2) {
279
+ color: #333;
280
+ font-size: 64rpx;
281
+ font-weight: 500;
282
+ margin: 20rpx 0;
283
+ }
284
+
285
+ &>view:nth-child(3) {
286
+ color: #333333;
287
+ font-size: 28rpx;
288
+ }
289
+ }
290
+
291
+ &-list {
292
+ &-item {
293
+ margin-bottom: 40rpx;
294
+
295
+ &-info {
296
+ display: flex;
297
+ justify-content: space-between;
298
+ align-items: center;
299
+
300
+ &-label {
301
+ color: #333333;
302
+ font-size: 28rpx;
303
+ }
304
+
305
+ &-value {
306
+ font-size: 32rpx;
307
+ font-weight: 700;
308
+ }
309
+
310
+ .income {
311
+ color: #FF5A39;
312
+ }
313
+
314
+ .expenses {
315
+ color: #00C800;
316
+ }
317
+ }
318
+
319
+ &-date {
320
+ color: #999999;
321
+ font-size: 22rpx;
322
+ margin-top: 26rpx;
323
+ }
324
+ }
325
+
326
+ &-item:last-child {
327
+ margin-bottom: 0;
328
+ }
329
+ }
330
+ }
331
+ }
332
+ </style>