jufubao-base 1.0.243-beta1 → 1.0.243-beta1002

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 (130) 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 +336 -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 +74 -0
  16. package/src/components/JfbBaseConsumpCode/JfbBaseConsumpCode.vue +1111 -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/JfbBaseFooter/Attr.js +12 -0
  23. package/src/components/JfbBaseFooter/JfbBaseFooter.vue +13 -0
  24. package/src/components/JfbBaseHeader/Attr.js +82 -0
  25. package/src/components/JfbBaseHeader/JfbBaseHeader.vue +47 -1
  26. package/src/components/JfbBaseHeaderColumn/Attr.js +82 -0
  27. package/src/components/JfbBaseHeaderColumn/JfbBaseHeaderColumn.vue +48 -2
  28. package/src/components/JfbBaseLogin/JfbBaseLogin.vue +17 -3
  29. package/src/components/JfbBaseNoticeDialog/Api.js +1 -1
  30. package/src/components/JfbBaseNoticeDialog/Attr.js +26 -0
  31. package/src/components/JfbBaseNoticeDialog/JfbBaseNoticeDialog.vue +38 -15
  32. package/src/components/JfbBaseNoticeGroup/Api.js +23 -0
  33. package/src/components/JfbBaseNoticeGroup/Attr.js +237 -0
  34. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroup.vue +174 -0
  35. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroupLess.less +79 -0
  36. package/src/components/JfbBaseNoticeGroup/JfbBaseNoticeGroupMixin.js +30 -0
  37. package/src/components/JfbBaseNoticeGroup/Mock.js +13 -0
  38. package/src/components/JfbBaseOpenVip/Api.js +39 -0
  39. package/src/components/JfbBaseOpenVip/Attr.js +331 -0
  40. package/src/components/JfbBaseOpenVip/JfbBaseOpenVip.vue +459 -0
  41. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipLess.less +79 -0
  42. package/src/components/JfbBaseOpenVip/JfbBaseOpenVipMixin.js +30 -0
  43. package/src/components/JfbBaseOpenVip/Mock.js +7 -0
  44. package/src/components/JfbBaseOpenVip/XdVipList.vue +130 -0
  45. package/src/components/JfbBaseOpenVipCard/Api.js +58 -0
  46. package/src/components/JfbBaseOpenVipCard/Attr.js +48 -0
  47. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCard.vue +111 -0
  48. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardLess.less +79 -0
  49. package/src/components/JfbBaseOpenVipCard/JfbBaseOpenVipCardMixin.js +30 -0
  50. package/src/components/JfbBaseOpenVipCard/Mock.js +13 -0
  51. package/src/components/JfbBaseOpenVipDetail/Api.js +35 -0
  52. package/src/components/JfbBaseOpenVipDetail/Attr.js +37 -0
  53. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetail.vue +234 -0
  54. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailLess.less +79 -0
  55. package/src/components/JfbBaseOpenVipDetail/JfbBaseOpenVipDetailMixin.js +30 -0
  56. package/src/components/JfbBaseOpenVipDetail/Mock.js +15 -0
  57. package/src/components/JfbBaseOrderDetail/JfbBaseOrderDetail.vue +177 -18
  58. package/src/components/JfbBasePay/Attr.js +52 -0
  59. package/src/components/JfbBasePay/JfbBasePay.vue +23 -6
  60. package/src/components/JfbBasePay/Mock.js +0 -9
  61. package/src/components/JfbBasePersonalData/Api.js +26 -0
  62. package/src/components/JfbBasePersonalData/Attr.js +13 -0
  63. package/src/components/JfbBasePersonalData/JfbBasePersonalData.vue +278 -0
  64. package/src/components/JfbBasePersonalData/JfbBasePersonalDataLess.less +79 -0
  65. package/src/components/JfbBasePersonalData/JfbBasePersonalDataMixin.js +30 -0
  66. package/src/components/JfbBasePersonalData/Mock.js +13 -0
  67. package/src/components/JfbBasePhoneLogin/JfbBasePhoneLogin.vue +35 -14
  68. package/src/components/JfbBasePointsCard/Api.js +18 -0
  69. package/src/components/JfbBasePointsCard/Attr.js +187 -0
  70. package/src/components/JfbBasePointsCard/JfbBasePointsCard.vue +212 -0
  71. package/src/components/JfbBasePointsCard/JfbBasePointsCardLess.less +79 -0
  72. package/src/components/JfbBasePointsCard/JfbBasePointsCardMixin.js +30 -0
  73. package/src/components/JfbBasePointsCard/Mock.js +5 -0
  74. package/src/components/JfbBasePointsDetail/Api.js +48 -0
  75. package/src/components/JfbBasePointsDetail/Attr.js +305 -0
  76. package/src/components/JfbBasePointsDetail/JfbBasePointsDetail.vue +267 -0
  77. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailLess.less +79 -0
  78. package/src/components/JfbBasePointsDetail/JfbBasePointsDetailMixin.js +30 -0
  79. package/src/components/JfbBasePointsDetail/Mock.js +6 -0
  80. package/src/components/JfbBasePoster/Attr.js +1 -1
  81. package/src/components/JfbBasePosterBigSmall/JfbBasePosterBigSmall.vue +2 -2
  82. package/src/components/JfbBasePosterGroup/Api.js +22 -0
  83. package/src/components/JfbBasePosterGroup/Attr.js +156 -0
  84. package/src/components/JfbBasePosterGroup/JfbBasePosterGroup.vue +268 -0
  85. package/src/components/JfbBasePosterGroup/JfbBasePosterGroupLess.less +79 -0
  86. package/src/components/JfbBasePosterGroup/JfbBasePosterGroupMixin.js +30 -0
  87. package/src/components/JfbBasePosterGroup/Mock.js +13 -0
  88. package/src/components/JfbBaseSavingDetail/Api.js +41 -0
  89. package/src/components/JfbBaseSavingDetail/Attr.js +70 -0
  90. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetail.vue +724 -0
  91. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailLess.less +79 -0
  92. package/src/components/JfbBaseSavingDetail/JfbBaseSavingDetailMixin.js +30 -0
  93. package/src/components/JfbBaseSavingDetail/Mock.js +10 -0
  94. package/src/components/JfbBaseSavingDetail/components/echarts.min.js +26 -0
  95. package/src/components/JfbBaseSavingDetail/components/echarts.vue +254 -0
  96. package/src/components/JfbBaseSavingDetail/components/wx-canvas.js +105 -0
  97. package/src/components/JfbBaseShare/Api.js +20 -0
  98. package/src/components/JfbBaseShare/Attr.js +59 -0
  99. package/src/components/JfbBaseShare/JfbBaseShare.vue +282 -0
  100. package/src/components/JfbBaseShare/JfbBaseShareLess.less +79 -0
  101. package/src/components/JfbBaseShare/JfbBaseShareMixin.js +30 -0
  102. package/src/components/JfbBaseShare/Mock.js +16 -0
  103. package/src/components/JfbBaseSuccess/JfbBaseSuccess.vue +9 -3
  104. package/src/components/JfbBaseTfkSearch/ContentProduct.vue +12 -22
  105. package/src/components/JfbBaseTfkSearch/JfbBaseTfkSearch.vue +12 -1
  106. package/src/components/JfbBaseTfkSearch/Mock.js +51 -3
  107. package/src/components/JfbBaseTfkSearch/listMixins.js +2 -1
  108. package/src/components/JfbBaseUserInfo/Attr.js +175 -11
  109. package/src/components/JfbBaseUserInfo/JfbBaseUserInfo.vue +341 -118
  110. package/src/components/JfbBaseUserOrder/Attr.js +16 -0
  111. package/src/components/JfbBaseUserOrder/JfbBaseUserOrder.vue +11 -2
  112. package/src/components/JfbBaseWithDrawAgain/Api.js +41 -0
  113. package/src/components/JfbBaseWithDrawAgain/Attr.js +92 -0
  114. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgain.vue +354 -0
  115. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainLess.less +79 -0
  116. package/src/components/JfbBaseWithDrawAgain/JfbBaseWithDrawAgainMixin.js +30 -0
  117. package/src/components/JfbBaseWithDrawAgain/Mock.js +10 -0
  118. package/src/components/JfbBaseWithDrawRecord/Api.js +19 -0
  119. package/src/components/JfbBaseWithDrawRecord/Attr.js +79 -0
  120. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecord.vue +233 -0
  121. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordLess.less +79 -0
  122. package/src/components/JfbBaseWithDrawRecord/JfbBaseWithDrawRecordMixin.js +30 -0
  123. package/src/components/JfbBaseWithDrawRecord/Mock.js +7 -0
  124. package/src/components/JfbBaseWithdraw/Api.js +48 -0
  125. package/src/components/JfbBaseWithdraw/Attr.js +328 -0
  126. package/src/components/JfbBaseWithdraw/JfbBaseWithdraw.vue +272 -0
  127. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawLess.less +79 -0
  128. package/src/components/JfbBaseWithdraw/JfbBaseWithdrawMixin.js +30 -0
  129. package/src/components/JfbBaseWithdraw/Mock.js +7 -0
  130. package/src/components/JfbBaseWxAuthorize/JfbBaseWxAuthorize.vue +10 -0
@@ -0,0 +1,187 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ * @description 当表单组件中有联动操作时候,使用方法进行返回
5
+ */
6
+ export default {
7
+ style: [],
8
+ content: (data) => {
9
+ return [
10
+ {
11
+ label: '预览plus样式:',
12
+ ele: 'xd-radio',
13
+ valueKey: 'is_plus_preview',
14
+ value: data['is_plus_preview'] || 'Y',
15
+ groupKey: 'content',
16
+ placeholder: '请选择预览plus样式',
17
+ multiple: false,
18
+ className: 'input80',
19
+ list: [
20
+ { label: 'plus用户样式', value: 'Y' },
21
+ { label: '普通用户样式', value: 'N' },
22
+ ]
23
+ },
24
+ {
25
+ label: '外边距:',
26
+ ele: 'xd-margin-padding',
27
+ valueKey: 'bodyMargin',
28
+ groupKey: 'style',
29
+ value: data['bodyMargin'] || null,
30
+ setting: {
31
+ type: 'margin',
32
+ },
33
+ placeholder: '请设置外边距',
34
+ inline: false,
35
+ notice: '设置外边距,<span style="color: red">单位:像素</span>。默认值:<span style="color: red">0</span>像素',
36
+ },
37
+ {
38
+ label: '外填充:',
39
+ ele: 'xd-margin-padding',
40
+ valueKey: 'bodyPadding',
41
+ groupKey: 'style',
42
+ value: data['bodyPadding'] || null,
43
+ setting: {
44
+ type: 'padding',
45
+ },
46
+ placeholder: '请设置外填充',
47
+ inline: false,
48
+ notice: '设置填充值,<span style="color: red">单位:像素</span>。默认值:<span style="color: red">20</span>像素',
49
+ },
50
+ {
51
+ ele: 'title',
52
+ label: '主体设置',
53
+ size: 'small',
54
+ groupKey: 'style',
55
+ },
56
+ {
57
+ label: '主体圆角设置:',
58
+ ele: 'xd-site-select-list',
59
+ valueKey: 'radius',
60
+ value: data['radius'] || '20',
61
+ labelInline: true,
62
+ groupKey: 'style',
63
+ placeholder: '请选择圆角设置',
64
+ multiple: false,
65
+ className: 'input60',
66
+ handleCustom({ action, data }) {
67
+ XdBus.getParentApi('getOptionsSettingList')({
68
+ setting_id: 'edtix_style_radius',
69
+ key: Date.now()
70
+ })
71
+ .then(res => {
72
+ data.cb(res.list)
73
+ })
74
+ .catch(error => {
75
+ console.error(error);
76
+ });
77
+ },
78
+ },
79
+ {
80
+ label: 'plus用户主体背景颜色:',
81
+ ele: 'el-input',
82
+ valueKey: 'plusBodyBgColor',
83
+ groupKey: 'style',
84
+ value: data['plusBodyBgColor'] || null,
85
+ placeholder: '请选择背景颜色',
86
+ labelInline: true,
87
+ classNmae: 'input80',
88
+ },
89
+ {
90
+ label: '普通用户主体背景颜色:',
91
+ ele: 'el-input',
92
+ valueKey: 'normalBodyBgColor',
93
+ groupKey: 'style',
94
+ value: data['normalBodyBgColor'] || null,
95
+ placeholder: '请选择背景颜色',
96
+ labelInline: true,
97
+ classNmae: 'input80',
98
+ },
99
+ {
100
+ ele: 'title',
101
+ label: '入口设置',
102
+ size: 'small',
103
+ groupKey: 'style',
104
+ },
105
+ {
106
+ label: '入口圆角设置:',
107
+ ele: 'xd-site-select-list',
108
+ valueKey: 'itemRadius',
109
+ value: data['itemRadius'] || '16',
110
+ labelInline: true,
111
+ groupKey: 'style',
112
+ placeholder: '请选择圆角设置',
113
+ multiple: false,
114
+ className: 'input60',
115
+ handleCustom({ action, data }) {
116
+ XdBus.getParentApi('getOptionsSettingList')({
117
+ setting_id: 'edtix_style_radius',
118
+ key: Date.now()
119
+ })
120
+ .then(res => {
121
+ data.cb(res.list)
122
+ })
123
+ .catch(error => {
124
+ console.error(error);
125
+ });
126
+ },
127
+ },
128
+ {
129
+ label: 'plus用户入口背景颜色:',
130
+ ele: 'el-input',
131
+ valueKey: 'plusItemBgColor',
132
+ groupKey: 'style',
133
+ value: data['plusItemBgColor'] || null,
134
+ placeholder: '请选择背景颜色',
135
+ labelInline: true,
136
+ classNmae: 'input80',
137
+ },
138
+ {
139
+ label: '普通用户入口背景颜色:',
140
+ ele: 'el-input',
141
+ valueKey: 'normalItemBgColor',
142
+ groupKey: 'style',
143
+ value: data['normalItemBgColor'] || null,
144
+ placeholder: '请选择背景颜色',
145
+ labelInline: true,
146
+ classNmae: 'input80',
147
+ },
148
+ {
149
+ label: '余额提现路径:',
150
+ ele: 'xd-select-pages-path',
151
+ valueKey: 'withdrawPath',
152
+ groupKey:'advanced',
153
+ placeholder: '请选择余额提现路径',
154
+ value: data['withdrawPath'] || null,
155
+ setting: {
156
+ router: XdBus.getParentApi('getPagesTree'),
157
+ },
158
+ inline: false,
159
+ },
160
+ {
161
+ label: '积分详情路径:',
162
+ ele: 'xd-select-pages-path',
163
+ valueKey: 'pointsPath',
164
+ groupKey:'advanced',
165
+ placeholder: '请选择积分详情路径',
166
+ value: data['pointsPath'] || null,
167
+ setting: {
168
+ router: XdBus.getParentApi('getPagesTree'),
169
+ },
170
+ inline: false,
171
+ },
172
+ {
173
+ label: '优惠券路径:',
174
+ ele: 'xd-select-pages-path',
175
+ valueKey: 'couponPath',
176
+ groupKey:'advanced',
177
+ placeholder: '请选择余额提现路径',
178
+ value: data['couponPath'] || null,
179
+ setting: {
180
+ router: XdBus.getParentApi('getPagesTree'),
181
+ },
182
+ inline: false,
183
+ },
184
+ ].filter(i => i)
185
+ },
186
+ advanced: [],
187
+ };
@@ -0,0 +1,212 @@
1
+ <template>
2
+ <view class="jfb-base-points-card" @click="handleEditxSelect" :class="{ editx : isEditx && active }">
3
+ <!--#ifdef H5-->
4
+ <view class="jfb-base-points-card__edit" :class="{ editx : isEditx && active }" v-if="isEditx && active">
5
+ <view class="jfb-base-points-card__edit-icon" @click="delEdit">删除</view>
6
+ </view>
7
+ <!-- #endif -->
8
+ <view class="jfb-base-points-card__body">
9
+ <view :style="[bodyStyleComp]" class="jfb-base-points-card__body-list">
10
+ <view :style="[itemStyleComp]" @click="handleTo(item)" v-for="(item,index) in typeList" :key="index"
11
+ class="jfb-base-points-card__body-list-item">
12
+ <view class="jfb-base-points-card__body-list-item-label">
13
+ {{item.name}}
14
+ </view>
15
+ <view v-if="item.method!=='coupon'" class="jfb-base-points-card__body-list-item-value">{{getAmout(item.amount)}}</view>
16
+ <view v-else class="jfb-base-points-card__body-list-item-value">{{item.coupon_count}}</view>
17
+ </view>
18
+ </view>
19
+ </view>
20
+ </view>
21
+ </template>
22
+
23
+ <script>
24
+ import XdFontIcon from "@/components/XdFontIcon/XdFontIcon";
25
+ import { jfbRootExec } from "@/utils/xd.event";
26
+ import JfbBasePointsCardMixin from "./JfbBasePointsCardMixin";
27
+ import { getContainerPropsValue } from "@/utils/xd.base";
28
+ import componentsMixins from "@/mixins/componentsMixins";
29
+ import extsMixins from "@/mixins/extsMixins";
30
+ export default {
31
+ name: "JfbBasePointsCard",
32
+ components: {
33
+ XdFontIcon
34
+ },
35
+ mixins: [
36
+ componentsMixins, extsMixins, JfbBasePointsCardMixin
37
+ ],
38
+ computed: {
39
+ bodyStyleComp() {
40
+ return {
41
+ background: this.is_vip === 'Y' ? this.plusBodyBgColor : this.normalBodyBgColor,
42
+ borderRadius: `${this.radius}rpx`,
43
+ margin: this.getMarginAndPadding(this.margin, 20),
44
+ padding: this.getMarginAndPadding(this.padding, 32),
45
+ }
46
+ },
47
+ itemStyleComp() {
48
+ return {
49
+ background: this.is_vip === 'Y' ? this.plusItemBgColor : this.normalItemBgColor,
50
+ borderRadius: `${this.itemRadius}rpx`,
51
+ }
52
+ }
53
+ },
54
+ data() {
55
+ return {
56
+ typeList: [],
57
+ plusBodyBgColor: '',
58
+ plusItemBgColor: '',
59
+ normalBodyBgColor: '',
60
+ normalItemBgColor: '',
61
+ is_plus_preview: 'N',
62
+ radius: 0,
63
+ itemRadius: 0,
64
+ margin: {},
65
+ padding: {},
66
+ is_vip: 'N',
67
+ pointsPath: '',
68
+ withdrawPath: '',
69
+ couponPath: '',
70
+ }
71
+ },
72
+ watch: {
73
+ container(value, oldValue) {
74
+ if (JSON.stringify(value) === JSON.stringify(oldValue)) return;
75
+ if (this.$configProject['isPreview']) this.init(value)
76
+ },
77
+ is_plus_preview() {
78
+ if (this.$configProject['isPreview']) {
79
+ this.is_vip = this.is_plus_preview
80
+ }
81
+ }
82
+ },
83
+ created() {
84
+ console.log(this.getTokenForKey('user_level'), 'user_leveluser_level');
85
+ this.is_vip = this.getTokenForKey('user_level') && this.getTokenForKey('user_level') === 'VIP' ? 'Y' : 'N'
86
+ this.init(this.container);
87
+ },
88
+ methods: {
89
+ onJfbLoad(options) {
90
+ this.getList()
91
+ },
92
+ /**
93
+ * @description 监听事件变化
94
+ * @param container {object} 业务组件对象自己
95
+ */
96
+ init(container) {
97
+ this.plusBodyBgColor = getContainerPropsValue(container, 'content.plusBodyBgColor', 'linear-gradient(180deg, #FFFCF8 0%, #FFF3E2 100%)');
98
+ this.plusItemBgColor = getContainerPropsValue(container, 'content.plusItemBgColor', 'linear-gradient(136.55deg, #FFECD1 0%, #F6D6AB 100%)');
99
+ this.normalBodyBgColor = getContainerPropsValue(container, 'content.normalBodyBgColor', '#fff');
100
+ this.normalItemBgColor = getContainerPropsValue(container, 'content.normalItemBgColor', '#F7F7F7');
101
+ this.is_plus_preview = getContainerPropsValue(container, 'content.is_plus_preview', 'N');
102
+ this.radius = getContainerPropsValue(container, 'content.radius', '20');
103
+ this.itemRadius = getContainerPropsValue(container, 'content.itemRadius', '16');
104
+ this.margin = getContainerPropsValue(container, 'content.bodyMargin', {});
105
+ this.padding = getContainerPropsValue(container, 'content.bodyPadding', {});
106
+ this.pointsPath = getContainerPropsValue(container, 'content.pointsPath', { value: "" }).value;
107
+ this.withdrawPath = getContainerPropsValue(container, 'content.withdrawPath', { value: "" }).value;
108
+ this.couponPath = getContainerPropsValue(container, 'content.couponPath', { value: "" }).value;
109
+ },
110
+ getList(){
111
+ jfbRootExec("getPointsPropertyList", {
112
+ vm: this,
113
+ data: {},
114
+ }).then(res => {
115
+ this.typeList = res.list
116
+ }).catch(err => {
117
+ console.log(err, "err");
118
+ })
119
+ },
120
+ getAmout(amount) {
121
+ return this.$xdUniHelper.divisionFloatNumber(amount, 100)
122
+ },
123
+ handleTo(item) {
124
+ if (item.method === 'score') {
125
+ this.$xdUniHelper.navigateTo({ url: `${this.pointsPath}?method=score` })
126
+ }
127
+ if (item.method === 'wallet') {
128
+ this.$xdUniHelper.navigateTo({ url: `${this.withdrawPath}?method=wallet` })
129
+ }
130
+ if (item.method === 'coupon') {
131
+ this.$xdUniHelper.navigateTo({ url: this.couponPath })
132
+ }
133
+ },
134
+ onJfbScroll(options) {
135
+ console.log('event.onJfbScroll', options)
136
+ },
137
+ onJfbReachBottom(options) {
138
+ console.log('event.onJfbReachBottom', options)
139
+ },
140
+ onJfbShow(options) {
141
+ console.log('event.onJfbShow', options)
142
+ this.getList()
143
+ },
144
+ onJfbHide(options) {
145
+ console.log('event.onJfbHide', options)
146
+ },
147
+ onJfbBack(options) {
148
+ console.log('event.onJfbBack', options)
149
+ },
150
+ onJfbUpdate(...data) {
151
+ console.log('event.onJfbUpdate', data)
152
+ },
153
+ onJfbCustomEvent(options) {
154
+ console.log('event.onJfbReachBottom', options)
155
+ },
156
+ }
157
+ }
158
+
159
+ </script>
160
+
161
+ <style scoped lang="less">
162
+ @import "./JfbBasePointsCardLess.less";
163
+
164
+ .jfb-base-points-card {
165
+ &__body {
166
+ &-list {
167
+ display: flex;
168
+ justify-content: center;
169
+ align-items: center;
170
+ background: linear-gradient(180deg, #FFFCF8 0%, #FFF3E2 100%);
171
+
172
+ &-item:last-child {
173
+ margin-right: 0;
174
+ }
175
+
176
+ &-item {
177
+ flex: 1;
178
+ display: flex;
179
+ flex-direction: column;
180
+ justify-content: center;
181
+ align-items: center;
182
+ padding: 20rpx 0;
183
+ margin-right: 32rpx;
184
+ background: linear-gradient(136.55deg, #FFECD1 0%, #F6D6AB 100%);
185
+ border-radius: 16rpx;
186
+ font-size: 24rpx;
187
+
188
+ &-label {
189
+ display: flex;
190
+ margin-bottom: 8rpx;
191
+ }
192
+
193
+ &-operate {
194
+ background: linear-gradient(90deg, #333231 0%, #6C5A46 100%);
195
+ border-radius: 24rpx;
196
+ padding: 4rpx 8rpx;
197
+ color: #F8DCB4;
198
+ font-size: 20rpx;
199
+ margin-left: 8rpx;
200
+ text-align: center;
201
+ vertical-align: middle;
202
+ }
203
+
204
+ &-value {
205
+ color: #333332;
206
+ font-weight: 700;
207
+ }
208
+ }
209
+ }
210
+ }
211
+ }
212
+ </style>
@@ -0,0 +1,79 @@
1
+ /**
2
+ * @desc 获取绝对路径完整地址
3
+ * @param @path
4
+ **/
5
+ //例如:https://image.jufubao.cn/20220501010108/image/bg/default_gonghui_bg.png
6
+ @basePath: 'business/';
7
+ @doMain: '//sandbox-img.jufubao.cn/';
8
+
9
+ .getBusinessImageUrl(@path, @size: 'size8') {
10
+ @url: "@{doMain}@{basePath}@{path}?x-oss-process=style/@{size}";
11
+ background-image: url(@url);
12
+ }
13
+
14
+ //start
15
+ .jfb-base-points-card {
16
+ box-sizing: border-box;
17
+
18
+ &__body{
19
+ position: relative;
20
+ overflow: hidden;
21
+ z-index: 2
22
+ }
23
+
24
+ &.editx,&.editx:hover {
25
+ position: relative;
26
+ min-height: unit(100, rpx);
27
+ z-index: 3;
28
+ &::after {
29
+ border: 2rpx dashed blue;
30
+ content: " ";
31
+ position: absolute;
32
+ top:0;
33
+ left:0;
34
+ bottom:0;
35
+ right:0;
36
+ z-index: 4;
37
+ cursor: pointer;
38
+ }
39
+
40
+ }
41
+
42
+
43
+ &__edit {
44
+ cursor: pointer;
45
+ position: absolute;
46
+ right: unit(0, rpx);
47
+ top: unit(-52, rpx);
48
+ height: unit(50, rpx);
49
+ line-height: unit(50, rpx);
50
+ display: flex;
51
+ justify-content: center;
52
+ align-items: center;
53
+ background: rgba(0, 0, 0, .6);
54
+ border-radius: unit(10, rpx);
55
+ box-shadow: 0 0 10px rbga(0, 0, 0, 0.3);
56
+ color: #fff;
57
+ font-size: unit(22, rpx);
58
+
59
+ &-icon{
60
+ padding: 0 unit(20, rpx);
61
+ }
62
+
63
+ &.editx {
64
+ box-sizing: border-box;
65
+
66
+ }
67
+ }
68
+ }
69
+ //end
70
+
71
+
72
+ /**notPreview**/
73
+ .jfb-base-points-card {
74
+ //&:before {
75
+ //content: " ";
76
+ //display: table;
77
+ //}
78
+ }
79
+ /**endNotPreview**/
@@ -0,0 +1,30 @@
1
+ 'use strict';
2
+
3
+
4
+ //@AttrImport
5
+ import Attr from "./Attr";
6
+ //@EndAttrImport
7
+
8
+
9
+ export default {
10
+ data() {
11
+ return {
12
+ //#ifdef H5
13
+
14
+ //@AttrData
15
+ Attr:{}, //对外开发编辑属性
16
+ //@EndAttrData
17
+
18
+ // #endif
19
+ cssRoot: 'jfb-base-points-card'
20
+ }
21
+ },
22
+ created() {
23
+
24
+ //@AttrDataCreated
25
+ this.Attr = this.$xdUniHelper.customClone(Attr);
26
+ //@EndAttrDataCreated
27
+
28
+
29
+ },
30
+ }
@@ -0,0 +1,5 @@
1
+ 'use strict';
2
+
3
+ module.exports = {
4
+ getPointsPropertyList:{"list":[{"method":"wallet","coupon_count":0,"amount":20000,"name":"余额"},{"method":"score","coupon_count":0,"amount":10000,"name":"积分"},{"method":"coupon","coupon_count":0,"amount":0,"name":"优惠券"}],"request_id":"2b0ac6cb23abdbbb"},
5
+ }
@@ -0,0 +1,48 @@
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
+ //设置方法名字当别忘记加上【模块名字】:Points
25
+ mapFnName: 'getPointsWalletDetail',
26
+ title: '用户资产 - 获取钱包(或积分)余额详情',
27
+ path: '/pay/v1/property/wallet-detail',
28
+ isRule: false,
29
+ params: {
30
+ method: ['wallet 余额; score 积分;', 'Number', '非必选'],
31
+ },
32
+ isConsole: true,
33
+ disabled: true,
34
+ },
35
+ {
36
+ //设置方法名字当别忘记加上【模块名字】:Points
37
+ mapFnName: 'getPointsWalletTradeList',
38
+ title: '用户资产 - 获取钱包(或积分)交易记录列表',
39
+ path: '/pay/v1/property/wallet-trade/list',
40
+ isRule: false,
41
+ params: {
42
+ wallet_type: ['钱包类型', 'Number', '必选'],
43
+ page_size: ['每页条数', 'Number', '必选'],
44
+ },
45
+ isConsole: true,
46
+ disabled: true,
47
+ },
48
+ ];