jufubao-base 1.0.159 → 1.0.160-beta1

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 (85) hide show
  1. package/package.json +1 -1
  2. package/src/common/authorize.js +201 -70
  3. package/src/components/JfbBaseAddress/JfbBaseAddress.vue +7 -6
  4. package/src/components/JfbBaseAfterOrderDetail/JfbBaseAfterOrderDetail.vue +5 -3
  5. package/src/components/JfbBaseAfterOrderList/JfbBaseAfterOrderList.vue +3 -2
  6. package/src/components/JfbBaseBack/JfbBaseBack.vue +10 -8
  7. package/src/components/JfbBaseBackground/JfbBaseBackground.vue +3 -2
  8. package/src/components/JfbBaseBlock/JfbBaseBlock.vue +3 -2
  9. package/src/components/JfbBaseCard/JfbBaseCard.vue +10 -6
  10. package/src/components/JfbBaseCardBindV2/JfbBaseCardBindV2.vue +57 -26
  11. package/src/components/JfbBaseCardDetail/JfbBaseCardDetail.vue +14 -15
  12. package/src/components/JfbBaseCardDetailEntry/Attr.js +22 -0
  13. package/src/components/JfbBaseCardDetailEntry/JfbBaseCardDetailEntry.vue +393 -424
  14. package/src/components/JfbBaseCardDisabled/JfbBaseCardDisabled.vue +4 -4
  15. package/src/components/JfbBaseCardDisabledEntry/JfbBaseCardDisabledEntry.vue +7 -9
  16. package/src/components/JfbBaseCardEntry/Attr.js +22 -1
  17. package/src/components/JfbBaseCardEntry/JfbBaseCardEntry.vue +91 -36
  18. package/src/components/JfbBaseCardInfo/JfbBaseCardInfo.vue +38 -22
  19. package/src/components/JfbBaseCardInfoEntry/Attr.js +22 -0
  20. package/src/components/JfbBaseCardInfoEntry/JfbBaseCardInfoEntry.vue +285 -260
  21. package/src/components/JfbBaseCardMerge/JfbBaseCardMerge.vue +4 -3
  22. package/src/components/JfbBaseCardMergeEntry/JfbBaseCardMergeEntry.vue +23 -18
  23. package/src/components/JfbBaseCardShift/JfbBaseCardShift.vue +4 -11
  24. package/src/components/JfbBaseCardShiftEntry/JfbBaseCardShiftEntry.vue +16 -19
  25. package/src/components/JfbBaseCardSweepInfo/JfbBaseCardSweepInfo.vue +3 -2
  26. package/src/components/JfbBaseCardV2/JfbBaseCardV2.vue +34 -18
  27. package/src/components/JfbBaseCardV3/JfbBaseCardV3.vue +14 -14
  28. package/src/components/JfbBaseCity/JfbBaseCity.vue +3 -2
  29. package/src/components/JfbBaseClear/JfbBaseClear.vue +3 -2
  30. package/src/components/JfbBaseConList/JfbBaseConList.vue +4 -4
  31. package/src/components/JfbBaseConPhone/JfbBaseConPhone.vue +3 -2
  32. package/src/components/JfbBaseEntry/Attr.js +22 -0
  33. package/src/components/JfbBaseEntry/JfbBaseEntry.vue +84 -20
  34. package/src/components/JfbBaseExpressDetail/JfbBaseExpressDetail.vue +3 -4
  35. package/src/components/JfbBaseFastLink/JfbBaseFastLink.vue +33 -22
  36. package/src/components/JfbBaseFastLink/XdFastNav.vue +2 -2
  37. package/src/components/JfbBaseFooter/JfbBaseFooter.vue +0 -1
  38. package/src/components/JfbBaseHeader/JfbBaseHeader.vue +3 -2
  39. package/src/components/JfbBaseLogin/JfbBaseLogin.vue +28 -11
  40. package/src/components/JfbBaseLoginForgetPwd/JfbBaseLoginForgetPwd.vue +7 -9
  41. package/src/components/JfbBaseLoginSetPwd/JfbBaseLoginSetPwd.vue +9 -6
  42. package/src/components/JfbBaseMapOverlay/JfbBaseMapOverlay.vue +19 -5
  43. package/src/components/JfbBaseMapOverlay/XdMapOverlay.vue +52 -37
  44. package/src/components/JfbBaseMapSearch/JfbBaseMapSearch.vue +3 -2
  45. package/src/components/JfbBaseMergeUserCard/JfbBaseMergeUserCard.vue +28 -27
  46. package/src/components/JfbBaseMultipleExpress/JfbBaseMultipleExpress.vue +5 -5
  47. package/src/components/JfbBaseMy/JfbBaseMy.vue +3 -3
  48. package/src/components/JfbBaseMySetting/JfbBaseMySetting.vue +6 -4
  49. package/src/components/JfbBaseNotice/Attr.js +0 -2
  50. package/src/components/JfbBaseNotice/JfbBaseNotice.vue +36 -14
  51. package/src/components/JfbBaseNotice/XdNoticeBar.vue +17 -1
  52. package/src/components/JfbBaseNoticeBottom/JfbBaseNoticeBottom.vue +3 -2
  53. package/src/components/JfbBaseNoticeTop/JfbBaseNoticeTop.vue +3 -2
  54. package/src/components/JfbBaseOrderDetail/JfbBaseOrderDetail.vue +20 -31
  55. package/src/components/JfbBaseOrderList/JfbBaseOrderList.vue +9 -4
  56. package/src/components/JfbBasePay/JfbBasePay.vue +3 -2
  57. package/src/components/JfbBasePhoneCollect/JfbBasePhoneCollect.vue +22 -7
  58. package/src/components/JfbBasePhoneLogin/JfbBasePhoneLogin.vue +23 -7
  59. package/src/components/JfbBasePoster/JfbBasePoster.vue +118 -18
  60. package/src/components/JfbBasePoster/MoreScreen.vue +155 -37
  61. package/src/components/JfbBasePosterBigSmall/Attr.js +2 -5
  62. package/src/components/JfbBasePosterBigSmall/JfbBasePosterBigSmall.vue +191 -67
  63. package/src/components/JfbBasePosterEntry/JfbBasePosterEntry.vue +90 -20
  64. package/src/components/JfbBasePosterType/FourScreen.vue +162 -18
  65. package/src/components/JfbBasePosterType/JfbBasePosterType.vue +0 -35
  66. package/src/components/JfbBaseRecharge/JfbBaseRecharge.vue +4 -4
  67. package/src/components/JfbBaseRechargeOrder/JfbBaseRechargeOrder.vue +3 -4
  68. package/src/components/JfbBaseRechargeOrderDetail/JfbBaseRechargeOrderDetail.vue +4 -7
  69. package/src/components/JfbBaseRechargeSuccess/JfbBaseRechargeSuccess.vue +6 -9
  70. package/src/components/JfbBaseSearch/JfbBaseSearch.vue +3 -2
  71. package/src/components/JfbBaseSuccess/JfbBaseSuccess.vue +5 -4
  72. package/src/components/JfbBaseUserCenter/JfbBaseUserCenter.vue +3 -2
  73. package/src/components/JfbBaseUserInfo/JfbBaseUserInfo.vue +5 -3
  74. package/src/components/JfbBaseUserOrder/JfbBaseUserOrder.vue +4 -3
  75. package/src/components/JfbBaseVideo/JfbBaseVideo.vue +14 -11
  76. package/src/components/JfbBaseVideo/XdVideo.vue +0 -4
  77. package/src/components/JfbBaseWallet/JfbBaseWallet.vue +3 -2
  78. package/src/components/JfbBaseWalletDetail/JfbBaseWalletDetail.vue +5 -8
  79. package/src/components/JfbBaseWalletEffective/JfbBaseWalletEffective.vue +5 -8
  80. package/src/components/JfbBaseWalletIndex/JfbBaseWalletIndex.vue +7 -17
  81. package/src/components/JfbBaseWalletItem/JfbBaseWalletItem.vue +13 -21
  82. package/src/components/JfbBaseWebview/JfbBaseWebview.vue +4 -3
  83. package/src/components/JfbBaseWxAuthorize/JfbBaseWxAuthorize.vue +5 -4
  84. package/src/components/JfbBaseWxAuthorizeError/JfbBaseWxAuthorizeError.vue +3 -4
  85. package/src/mixins/colorCardMixins.js +1 -1
@@ -397,9 +397,7 @@
397
397
  </view>
398
398
  <view
399
399
  class="jfb-base-order-detail__body-num-info-copy"
400
- @click="copy(item.password)"
401
- >复制</view
402
- >
400
+ @click="copy(item.password)">复制</view>
403
401
  <view
404
402
  v-if="item.code_end_time"
405
403
  class="jfb-base-order-detail__body-cashier-code"
@@ -434,9 +432,7 @@
434
432
  color: mainColor,
435
433
  background: bgColor,
436
434
  }"
437
- >
438
- {{ item.code_end_time }}
439
- </view>
435
+ >{{ item.code_end_time }}</view>
440
436
  </view>
441
437
  </view>
442
438
 
@@ -460,9 +456,7 @@
460
456
  color: mainColor,
461
457
  background: bgColor,
462
458
  }"
463
- >
464
- {{ item.code_end_time }}
465
- </view>
459
+ >{{ item.code_end_time }}</view>
466
460
  </view>
467
461
  </view>
468
462
 
@@ -492,9 +486,7 @@
492
486
  color: mainColor,
493
487
  background: bgColor,
494
488
  }"
495
- >
496
- {{ item.code_end_time }}
497
- </view>
489
+ >{{ item.code_end_time }}</view>
498
490
  </view>
499
491
  </view>
500
492
  </view>
@@ -542,9 +534,7 @@
542
534
  <view class="jfb-base-order-detail__body-shop-name">
543
535
  {{ info.shop.shop_name }}
544
536
  </view>
545
- <view class="jfb-base-order-detail__body-shop-address"
546
- >地址: {{ info.shop.shop_address }}
547
- </view>
537
+ <view class="jfb-base-order-detail__body-shop-address">地址: {{ info.shop.shop_address }}</view>
548
538
  </view>
549
539
  <view
550
540
  :style="{
@@ -574,8 +564,7 @@
574
564
  v-if="item.type === 'copy'"
575
565
  class="jfb-base-order-detail__body-order-copy"
576
566
  @click="copy(item.value)"
577
- >复制</view
578
- >
567
+ >复制</view>
579
568
  </view>
580
569
  </view>
581
570
  <view
@@ -659,9 +648,7 @@
659
648
  v-for="(item, index) in info.contacts"
660
649
  :key="index"
661
650
  >
662
- <view class="jfb-base-order-detail__body-link-title">{{
663
- item.title
664
- }}</view>
651
+ <view class="jfb-base-order-detail__body-link-title">{{item.title }}</view>
665
652
  <view v-for="(Sitem, Sindex) in item.data" :key="Sindex">
666
653
  <view class="jfb-base-order-detail__body-link-item">
667
654
  <view v-html="Sitem.label"></view>
@@ -741,14 +728,17 @@
741
728
  radius="40rpx"
742
729
  :bg-color="mainColor"
743
730
  @click="handleAction(item)"
744
- >
745
- {{ item.text }}
746
- </xd-button>
731
+ >{{ item.text }}</xd-button>
747
732
  </view>
748
733
  </view>
749
734
  </view>
750
735
  </view>
751
- <xd-dailog :show.sync="showCode" :cancel="false" :confirm="false" title="">
736
+ <xd-dailog
737
+ :show.sync="showCode"
738
+ :cancel="false"
739
+ :confirm="false"
740
+ title="提示"
741
+ >
752
742
  <view
753
743
  :style="{
754
744
  display: 'flex',
@@ -770,9 +760,7 @@
770
760
  </image>
771
761
  </view>
772
762
  </view>
773
- <view v-if="dialogPassword" class="dialog_password">
774
- {{ dialogPassword }}
775
- </view>
763
+ <view v-if="dialogPassword" class="dialog_password">{{ dialogPassword }}</view>
776
764
  </xd-dailog>
777
765
  </view>
778
766
  </template>
@@ -858,8 +846,9 @@ export default {
858
846
  };
859
847
  },
860
848
  watch: {
861
- container(value) {
862
- this.init(value);
849
+ container(value,oldValue) {
850
+ if(JSON.stringify(value) === JSON.stringify(oldValue)) return;
851
+ if (this.$configProject['isPreview']) this.init(value)
863
852
  },
864
853
  viewStatus(n, o) {
865
854
  if (this.isPreview) {
@@ -1195,7 +1184,7 @@ export default {
1195
1184
  uni.setClipboardData({
1196
1185
  data: text,
1197
1186
  success: () => {
1198
- this.$xdAlert({ content: "复制成功" });
1187
+ //this.$xdAlert({ content: "复制成功" });
1199
1188
  },
1200
1189
  });
1201
1190
  // #endif
@@ -1254,7 +1243,7 @@ export default {
1254
1243
  });
1255
1244
  } else {
1256
1245
  this.$xdConfirm({
1257
- $vm: this,
1246
+ styles: this.styles,
1258
1247
  content: "是否取消订单",
1259
1248
  success: (action) => {
1260
1249
  if (action.confirm) {
@@ -136,7 +136,7 @@
136
136
  class="order-list-icon"
137
137
  :style="{ bottom: item['isOpen'] ? '-30rpx' : '-54rpx' }"
138
138
  v-if="item.products.length > showLen"
139
- @click.stop="item['isOpen'] = !item['isOpen']"
139
+ @click.stop="switchOpen(item)"
140
140
  >
141
141
  <view :style="{ background: backgroundColor }">
142
142
  <xd-font-icon
@@ -285,8 +285,9 @@ export default {
285
285
  },
286
286
  },
287
287
  watch: {
288
- container(value) {
289
- this.init(value);
288
+ container(value,oldValue) {
289
+ if(JSON.stringify(value) === JSON.stringify(oldValue)) return;
290
+ if (this.$configProject['isPreview']) this.init(value)
290
291
  },
291
292
  },
292
293
  created() {
@@ -387,9 +388,13 @@ export default {
387
388
  console.log("this.tabList", this.tabList);
388
389
  },
389
390
 
391
+ switchOpen(item){
392
+ item['isOpen'] = !item['isOpen']
393
+ },
394
+
390
395
  cancelUnPayOrder(main_order_id) {
391
396
  this.$xdConfirm({
392
- $vm: this,
397
+ styles: this.styles,
393
398
  content: "是否取消订单?",
394
399
  success: (res) => {
395
400
  if (res.confirm) {
@@ -216,8 +216,9 @@ export default {
216
216
  };
217
217
  },
218
218
  watch: {
219
- container(value) {
220
- this.init(value);
219
+ container(value,oldValue) {
220
+ if(JSON.stringify(value) === JSON.stringify(oldValue)) return;
221
+ if (this.$configProject['isPreview']) this.init(value)
221
222
  },
222
223
  },
223
224
  computed: {
@@ -13,9 +13,7 @@
13
13
  :class="{ editx: isEditx && active }"
14
14
  v-if="isEditx && active && !noBorder"
15
15
  >
16
- <view class="jfb-base-phone-collect__edit-icon" @click="delEdit"
17
- >删除</view
18
- >
16
+ <view class="jfb-base-phone-collect__edit-icon" @click="delEdit">删除</view>
19
17
  </view>
20
18
  <!-- #endif -->
21
19
  <view class="jfb-base-phone-collect__body">
@@ -57,7 +55,7 @@
57
55
  :localdata="[{ value: 1, text: '登录即同意《隐私政策》《用户服务协议》' },]"
58
56
  >
59
57
  <template slot="a1">
60
- <view>
58
+ <view class="text-content">
61
59
  <text>请阅读并同意</text>
62
60
  <text @click.stop="handlePrivacy('privacy_privacy')" :style="{color: mainColor}">《隐私政策》</text>
63
61
  <text @click.stop="handlePrivacy('privacy_service')" :style="{color: mainColor}">《用户服务协议》</text>
@@ -104,6 +102,10 @@ import XdFormCheckbox from "@/components/XdFormCheckbox/XdFormCheckbox";
104
102
  import JfbBasePhoneCollectMixin from "./JfbBasePhoneCollectMixin";
105
103
 
106
104
  export default {
105
+ // #ifdef MP-WEIXIN
106
+ options: { styleIsolation: 'shared' },
107
+ // #endif
108
+
107
109
  name: "JfbBasePhoneCollect",
108
110
  components: {
109
111
  XdFontIcon,
@@ -125,7 +127,6 @@ export default {
125
127
  interval: null,
126
128
  provider_id: "",
127
129
  callback_url: "",
128
- //todo
129
130
  };
130
131
  },
131
132
  computed: {
@@ -134,8 +135,9 @@ export default {
134
135
  },
135
136
  },
136
137
  watch: {
137
- container(value) {
138
- this.init(value);
138
+ container(value,oldValue) {
139
+ if(JSON.stringify(value) === JSON.stringify(oldValue)) return;
140
+ if (this.$configProject['isPreview']) this.init(value)
139
141
  },
140
142
  "accountForm.verification_code"(value) {
141
143
  if (value && value.length >= 8 && value.length % 2 === 0) {
@@ -330,4 +332,17 @@ export default {
330
332
  .align-center {
331
333
  align-items: center;
332
334
  }
335
+ /* #ifdef MP-WEIXIN */
336
+ /deep/ .xd-form-checkbox .checklist-group {
337
+ justify-content: center;
338
+ display: flex;
339
+ align-items: center;
340
+ }
341
+ .text-content {
342
+ width: 100%;
343
+ & > text {
344
+ font-size: 26rpx;
345
+ }
346
+ }
347
+ /* #endif */
333
348
  </style>
@@ -17,9 +17,7 @@
17
17
  </view>
18
18
  <!-- #endif -->
19
19
  <view class="jfb-base-phone-login__body">
20
- <view
21
- class="panel-login-password"
22
- >
20
+ <view class="panel-login-password">
23
21
  <xd-form label-width="128"
24
22
  style="margin-top: 40rpx;"
25
23
  label-align="right"
@@ -61,7 +59,7 @@
61
59
  :localdata="[{value: 1, text: '登录即同意《隐私政策》《用户服务协议》'}]"
62
60
  >
63
61
  <template slot="a1">
64
- <view>
62
+ <view class="text-content">
65
63
  <text>请阅读并同意</text>
66
64
  <text @click.stop="handlePrivacy('privacy_privacy')" :style="{color: mainColor}">《隐私政策》</text>
67
65
  <text @click.stop="handlePrivacy('privacy_service')" :style="{color: mainColor}">《用户服务协议》</text>
@@ -102,6 +100,10 @@
102
100
  import XdFormCheckbox from "@/components/XdFormCheckbox/XdFormCheckbox"
103
101
 
104
102
  export default {
103
+ // #ifdef MP-WEIXIN
104
+ options: { styleIsolation: 'shared' },
105
+ // #endif
106
+
105
107
  name: "JfbBasePhoneLogin",
106
108
  components: {
107
109
  XdFontIcon,
@@ -133,8 +135,9 @@
133
135
  }
134
136
  },
135
137
  watch: {
136
- container(value) {
137
- this.init(value)
138
+ container(value,oldValue) {
139
+ if(JSON.stringify(value) === JSON.stringify(oldValue)) return;
140
+ if (this.$configProject['isPreview']) this.init(value)
138
141
  },
139
142
  "accountForm.verification_code"(value) {
140
143
  if (value && value.length >= 8 && value.length % 2 === 0) {
@@ -167,7 +170,7 @@
167
170
  * @description 监听事件变化
168
171
  * @param container {object} 业务组件对象自己
169
172
  */
170
- init(value) {
173
+ init(container) {
171
174
  //this.bgcolor = getContainerPropsValue(value, 'content.bgcolor', '#fff');
172
175
  //this.height = getContainerPropsValue(value, 'content.height', 10);
173
176
  },
@@ -362,4 +365,17 @@
362
365
  .align-center{
363
366
  align-items: center;
364
367
  }
368
+ /* #ifdef MP-WEIXIN */
369
+ /deep/ .xd-form-checkbox .checklist-group {
370
+ justify-content: center;
371
+ display: flex;
372
+ align-items: center;
373
+ }
374
+ .text-content {
375
+ width: 100%;
376
+ & > text {
377
+ font-size: 26rpx;
378
+ }
379
+ }
380
+ /* #endif */
365
381
  </style>
@@ -15,7 +15,6 @@
15
15
  <!-- #endif -->
16
16
  <view class="jfb-base-poster__body" v-if="noData">
17
17
  <view class="x-line"></view>
18
-
19
18
  <view class="jfb-base-poster-cont" :style="getBodyStyle">
20
19
  <!--一分屏-->
21
20
  <template v-if="posterType === '1'">
@@ -50,6 +49,7 @@
50
49
  }"
51
50
  >
52
51
  <xd-swiper-dot
52
+ :style="{width: getOneWidth + 'rpx', height: getOneHeight + 'rpx'}"
53
53
  v-if="pageSwiperShow"
54
54
  :current="current"
55
55
  :info="info"
@@ -57,6 +57,24 @@
57
57
  :mode="mode"
58
58
  :dots-styles="dotStyleData"
59
59
  >
60
+ <!--#ifdef MP-WEIXIN-->
61
+ <swiper
62
+ class="swiper xd-swiper-content"
63
+ :style="{width: getOneWidth + 'rpx', height: getOneHeight + 'rpx'}"
64
+ :indicator-dots="false"
65
+ :autoplay="carouselTime>0"
66
+ :interval="carouselTime"
67
+ :duration="500"
68
+ :current="current"
69
+ circular
70
+ @animationfinish="handleAnimationfinish"
71
+ >
72
+ <swiper-item v-for="(item,index) in info" :key="index" @click.stop="handleClick(item,index)">
73
+ <image :style="{width: getOneWidth + 'rpx', height: getOneHeight + 'rpx'}" :src="item['image_url']" mode="aspectFill"></image>
74
+ </swiper-item>
75
+ </swiper>
76
+ <!--#endif-->
77
+ <!--#ifdef H5-->
60
78
  <xd-swiper
61
79
  :indicator-dots="false"
62
80
  :list="info"
@@ -71,6 +89,7 @@
71
89
  <image :src="item['image_url']" mode="aspectFill"></image>
72
90
  </template>
73
91
  </xd-swiper>
92
+ <!--#endif-->
74
93
  </xd-swiper-dot>
75
94
  <view v-if="isPreview" class="carousel-mask"></view>
76
95
  </view>
@@ -78,6 +97,7 @@
78
97
  <!--一分屏-->
79
98
  <!--多分屏-->
80
99
  <more-screen
100
+ style="width: 100%; height: 100%"
81
101
  v-if="posterType !== '1'"
82
102
  :config="getConfig"
83
103
  :content="info"
@@ -158,11 +178,11 @@
158
178
  backgroundSize: '100%',
159
179
  backgroundRepeat: 'no-repeat',
160
180
  }
161
- return {
162
- ...image,
181
+ image = Object.assign({},image,{
163
182
  margin: this.margin,
164
183
  padding: this.outPadding
165
- }
184
+ })
185
+ return this.styleObjectToString(image)
166
186
  },
167
187
  getOneWidth(){
168
188
  let margin = this.checkValue(this.mS.left, 0) + this.checkValue(this.mS.right, 0);
@@ -332,9 +352,9 @@
332
352
  },
333
353
  },
334
354
  created() {
335
- this.init(this.container);
336
355
  this.isPreview = this.$configProject.isPreview;
337
356
  this.pageSwiperShow = this.$root.$isShow;
357
+ this.init(this.container);
338
358
  },
339
359
 
340
360
  destroyed() {
@@ -345,6 +365,63 @@
345
365
  },
346
366
 
347
367
  methods: {
368
+ /**
369
+ * @description 过滤不可以用
370
+ * 当前项目未H5时,过滤所有小程序应用
371
+ * 当前项目未小程序时,过滤所有非当前小程序应用
372
+ * 站外地址直接返回
373
+ * 站内地址未选值直接返回
374
+ * 预览模式全过
375
+ */
376
+ filterItem(list){
377
+ let content = list.filter(item=>{
378
+ //预览模式
379
+ if( this.$configProject.isPreview) return true;
380
+
381
+ //非内部应用
382
+ if(item.redirect_type !== 'INN') return true
383
+
384
+ //没有配置链接
385
+ if(!item.redirect_data) return true;
386
+
387
+ //内部应用
388
+ else {
389
+ let redirect_data;
390
+ try {
391
+ redirect_data = JSON.parse(item.redirect_data);
392
+ if(!item['app_type']) item['app_type']= 'h5';
393
+
394
+ //#ifdef H5
395
+ return item['app_type'] !== 'wxmp';
396
+ //#endif
397
+
398
+ //#ifdef MP-WEIXIN
399
+ let actDir = this.$parent.projectAttr.deploy_dir;
400
+ let dir = this.getPathDir(redirect_data.page);
401
+ if(item['app_type'] === 'wxmp'){
402
+ return actDir === dir;
403
+ }
404
+ else if(item['app_type'] === 'h5') return true;
405
+ else return true
406
+ //#endif
407
+ }
408
+ catch (e) {
409
+ return true
410
+ }
411
+ }
412
+ });
413
+ console.warn(`PostersList:${JSON.stringify(content.map(item=>`${item.app_type}:${item.content_name}:${item.redirect_data}`), null,2)}`)
414
+ return content;
415
+
416
+ },
417
+
418
+ getPathDir(pathDir){
419
+ if(pathDir.indexOf('@site_domain@/') === 0) {
420
+ return pathDir.replace('@site_domain@/','').split('/')[0]
421
+ }
422
+ return ''
423
+ },
424
+
348
425
  getTestData(){
349
426
  let temp = [];
350
427
  for (let i = 0; i< this.useNumber; i++) {
@@ -382,52 +459,70 @@
382
459
  this.current = e.detail.current;
383
460
  }
384
461
  },
462
+
385
463
  handleClick(item) {
464
+ if(!item.redirect_data) {
465
+ console.warn(`未配置链接地址: ${item.redirect_data}`);
466
+ console.error(`未配置链接地址: ${item.redirect_data}`);
467
+ return
468
+ }
469
+
386
470
  //内部链接跳转地址
387
471
  if (item.redirect_type === 'INN') {
388
472
  try {
389
473
  let url = JSON.parse(item.redirect_data);
390
474
  let params = '';
391
- if (item['redirect_params']) params = `?${item['redirect_params']}`;
392
- this.$xdUniHelper.navigateTo({
393
- url: url.page + params
394
- })
475
+ if(url.page) {
476
+ if (item['redirect_params']) params = `?${item['redirect_params']}`;
477
+ this.$xdUniHelper.navigateTo({url: url.page + params})
478
+ }
479
+ else {
480
+ console.error(`应用链接配置错误: ${url.page}`)
481
+ }
395
482
  } catch (e) {
396
- console.error(e)
483
+ console.error(`应用链接配置错误: ${item.redirect_data}`)
397
484
  }
398
485
  }
399
486
 
400
487
  //外部链接
401
488
  if (item.redirect_type === 'URL') {
402
489
  let reg = /^(http:\/\/|https:\/\/|\/\/)+.+$/;
490
+ let spReg = /(-apiuri\/v)/;
403
491
  //#ifdef MP-WEIXIN
404
492
  try {
405
493
  let url = JSON.parse(item.redirect_data);
406
- if (reg.test(url.url) && this.$configProject.extras.webview) {
494
+ if (reg.test(url.url) || spReg.test(url.url)) {
407
495
  console.warn(`广告跳转外站: ${url.url}`)
408
- this.$xdUniHelper.navigateTo({
409
- url: `${this.$configProject.extras.webview}?seatUrl=${Base64.encodeURI(url.url)}`
410
- });
496
+ this.$xdUniHelper.navigateTo(url);
411
497
  } else {
412
- throw Error('地址错误')
498
+ console.error(`广告跳转外站配置错误: ${url.url}`)
413
499
  }
414
500
  } catch (e) {
415
- console.error(e)
501
+ console.error(`广告跳转外站配置错误: ${item.redirect_data}`)
416
502
  }
417
503
  //#endif
418
504
  //#ifdef H5
419
505
  try {
420
506
  let url = JSON.parse(item.redirect_data);
421
507
  console.warn(`广告跳转外站: ${url.url}`);
422
- this.$xdUniHelper.navigateTo(url)
508
+ this.$xdUniHelper.redirectTo(url, false)
423
509
  } catch (e) {
424
- console.error(e)
510
+ console.error(`广告跳转外站配置错误: ${item.redirect_data}`)
425
511
  }
426
512
  //#endif
427
513
 
428
514
  }
515
+
516
+ //无跳转地址
517
+ if(item.redirect_type === 'EMP') {
518
+ console.warn(`无跳转地址`);
519
+ }
429
520
  },
521
+
522
+
430
523
  handleImage(list){
524
+ list = this.filterItem(list);
525
+
431
526
  return list.map((item,index) => {
432
527
  return {
433
528
  ...item,
@@ -463,6 +558,11 @@
463
558
  this.isCarousel = getContainerPropsValue(container, 'content.isCarousel', 1);
464
559
  this.radius = getContainerPropsValue(container, 'content.radius', 0);
465
560
  this.padding = getContainerPropsValue(container, 'content.padding', 0);
561
+
562
+ //静态图,一分屏并且间距为0设置
563
+ if(this.isCarousel === 1 && this.posterType === '1' && this.padding === 0) {
564
+ this.padding = 20;
565
+ }
466
566
  this.rows = getContainerPropsValue(container, 'content.rows', 1);
467
567
  if(this.posterType === '1' && this.isCarousel === 2) this.isSupport = getContainerPropsValue(container, 'content.isSupport', 'Y');
468
568
  this.mS = getContainerPropsValue(container, 'content.margin', {});