@conecli/cone-render 0.10.1-shop3.8 → 0.10.1-shop3.80

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 (109) hide show
  1. package/README.md +1 -1
  2. package/dist/api/index.ts +1 -1
  3. package/dist/common/accessibility.h5.ts +1 -0
  4. package/dist/common/accessibility.ts +0 -0
  5. package/dist/common/const.ts +1 -1
  6. package/dist/common/index.h5.ts +1 -1
  7. package/dist/common/index.jd.ts +1 -1
  8. package/dist/common/index.ts +1 -1
  9. package/dist/common/index.weapp.ts +1 -1
  10. package/dist/common/jdplayerSdk.weapp.tsx +1 -0
  11. package/dist/common/jssdk.ts +1 -1
  12. package/dist/common/jssdk.weapp.ts +1 -0
  13. package/dist/common/pageType.ts +1 -1
  14. package/dist/common/token/index.h5.ts +1 -1
  15. package/dist/common/token/token.jd.ts +1 -1
  16. package/dist/common/wxappApi.ts +1 -1
  17. package/dist/components/ErrorBoundary.tsx +1 -1
  18. package/dist/components/base/CommonFloorHead/index.tsx +1 -1
  19. package/dist/components/base/CountDown/index.tsx +1 -1
  20. package/dist/components/base/CustomScrollView/index.tsx +1 -1
  21. package/dist/components/base/CustomVideo/index.tsx +1 -1
  22. package/dist/components/base/CustomVideo/index.weapp.tsx +1 -0
  23. package/dist/components/base/ExposureSmart/index.h5.tsx +1 -1
  24. package/dist/components/base/ExposureSmart/reporter.tsx +1 -1
  25. package/dist/components/base/InOrOutViewObserver/index.weapp.tsx +1 -0
  26. package/dist/components/base/ItemViewExposureSmart/index.tsx +1 -1
  27. package/dist/components/base/LazyLayoutLoad/index.tsx +1 -1
  28. package/dist/components/base/LazyLoadImage/index.h5.tsx +1 -1
  29. package/dist/components/base/MobileCommonHeader/index.weapp.tsx +1 -0
  30. package/dist/components/base/NetworkDataError/const.ts +1 -1
  31. package/dist/components/base/NetworkDataError/index.module.scss +118 -72
  32. package/dist/components/base/NetworkDataError/index.tsx +1 -1
  33. package/dist/components/base/Price/Base/index.module.scss +12 -0
  34. package/dist/components/base/Price/Base/index.tsx +1 -1
  35. package/dist/components/base/Price/Double/index.module.scss +24 -0
  36. package/dist/components/base/Price/Double/index.tsx +1 -1
  37. package/dist/components/base/ShopLeGaoTag/index.h5.module.scss +35 -0
  38. package/dist/components/base/ShopLeGaoTag/index.h5.tsx +1 -0
  39. package/dist/components/base/ShopLeGaoTag/index.module.scss +33 -0
  40. package/dist/components/base/ShopLeGaoTag/index.tsx +1 -0
  41. package/dist/components/debug/DebugLayout/index.module.scss +2 -2
  42. package/dist/components/floorItem.tsx +1 -1
  43. package/dist/components/isv/Floor/index.tsx +1 -1
  44. package/dist/components/remoteFloorItem.tsx +1 -1
  45. package/dist/interface/common.ts +1 -1
  46. package/dist/interface/component.ts +1 -1
  47. package/dist/interface/jumpEventReport.ts +1 -1
  48. package/dist/interface/service.ts +1 -1
  49. package/dist/jumpEventReport/base.ts +1 -1
  50. package/dist/jumpEventReport/const.ts +1 -1
  51. package/dist/jumpEventReport/createReportFloorData.ts +1 -1
  52. package/dist/jumpEventReport/index.h5.ts +1 -1
  53. package/dist/jumpEventReport/index.jd.ts +1 -1
  54. package/dist/jumpEventReport/index.weapp.ts +1 -1
  55. package/dist/jumpEventReport/jdJumpJdApp.ts +1 -1
  56. package/dist/jumpEventReport/jumpUrlConfig/base.ts +1 -1
  57. package/dist/jumpEventReport/logEventConfig.h5.ts +1 -0
  58. package/dist/jumpEventReport/logEventConfig.ts +1 -1
  59. package/dist/jumpEventReport/web/report.ts +1 -1
  60. package/dist/jumpEventReport/web.base.ts +1 -1
  61. package/dist/jumpEventReport/web.jd.ts +1 -1
  62. package/dist/jumpEventReport/web.pc.ts +1 -1
  63. package/dist/jumpEventReport/web.tjm.ts +1 -1
  64. package/dist/jumpEventReport/web.wxapp.ts +1 -1
  65. package/dist/language/en_US.json +274 -0
  66. package/dist/language/zh_CN.json +274 -0
  67. package/dist/language/zh_HK.json +274 -0
  68. package/dist/libs/openShopBridge.js +161 -0
  69. package/dist/libs/openShopBridge.min.js +1 -0
  70. package/dist/libs/taroAppReport.js +2 -2
  71. package/dist/modules/ContainerFloorList/index.h5.module.scss +16 -2
  72. package/dist/modules/ContainerFloorList/index.h5.tsx +1 -1
  73. package/dist/modules/ContainerFloorList/index.tsx +1 -1
  74. package/dist/modules/DecorateContainerFloorList/index.weapp.tsx +1 -0
  75. package/dist/open/api/environment.ts +1 -1
  76. package/dist/open/api/shopMember.ts +1 -1
  77. package/dist/open/api/shopMember.weapp.ts +1 -0
  78. package/dist/open/api/track.ts +1 -1
  79. package/dist/open/api/util.ts +1 -1
  80. package/dist/open/components/index.ts +1 -1
  81. package/dist/open/index.ts +1 -1
  82. package/dist/sass/app.h5.scss +27 -1
  83. package/dist/service/fetchGateway.ts +1 -1
  84. package/dist/service/fetchGateway.weapp.ts +1 -1
  85. package/dist/service/fetchJsonp.weapp.ts +1 -0
  86. package/dist/service/http/const.ts +1 -1
  87. package/dist/service/http/h5Http.ts +1 -1
  88. package/dist/service/http/httpInterceptors.weapp.ts +1 -0
  89. package/dist/service/requestServer.h5.ts +1 -1
  90. package/dist/service/requestServer.ts +1 -1
  91. package/dist/service/requestServer.weapp.ts +1 -1
  92. package/dist/utils/connectNativeJsBridge.ts +1 -1
  93. package/dist/utils/h5Utils.ts +1 -1
  94. package/dist/utils/harmonyCallRouter.h5.ts +1 -0
  95. package/dist/utils/harmonyCallRouter.ts +0 -0
  96. package/dist/utils/index.h5.ts +1 -1
  97. package/dist/utils/index.ts +1 -1
  98. package/dist/utils/index.weapp.ts +1 -1
  99. package/dist/utils/jumpExtMapUtil.ts +1 -0
  100. package/dist/utils/log.ts +1 -0
  101. package/dist/utils/{sColor.js → sColor.ts} +1 -1
  102. package/dist/utils/sColor.weapp.ts +1 -0
  103. package/dist/utils/utils.ts +1 -1
  104. package/dist/wxapp/common/address_api/address_api_v2.js +1 -0
  105. package/dist/wxapp/common/user_info.js +1 -1
  106. package/package.json +162 -141
  107. package/dist/jumpEventReport/web/wqshop.report.ts +0 -1
  108. package/dist/utils/priceUtils.js +0 -1
  109. /package/dist/utils/{jumpExtMapUtil.js → jumpExtMapUtil.h5.ts} +0 -0
@@ -1 +1 @@
1
- import React from 'react';
2
1
  console.warn('🚗 ~~ file: index.tsx:22 ~~ reportException() ~~ {type, detail, text}:', {
3
2
  type,
4
3
  data,
5
4
  text,
6
5
  });
7
6
  sgmCustomReport({
8
7
  code: getSgmCustomCode(`${SgmCustomCode.PRICE_RENDER}_${type}`),
9
8
  msg: {
10
9
  type,
11
10
  data,
12
11
  text: '[双价格组件]' + text,
13
12
  },
14
13
  });
15
14
  return rest.some((item) => item === undefined || item === '');
16
15
  const numPrice = Number(strPrice);
17
16
  if (isNaN(numPrice)) {
18
17
  reportException({
19
18
  type: 'isNotNumericType',
20
19
  data: props,
21
20
  text: `传入价格字段值“${strPrice}”转换数字报错`,
22
21
  });
23
22
  return false;
24
23
  }
25
24
  else if (numPrice <= 0) {
26
25
  reportException({
27
26
  type: 'isNotPositiveNumber',
28
27
  data: props,
29
28
  text: `传入价格字段值“${strPrice}”不是一个正数`,
30
29
  });
31
30
  return false;
32
31
  }
33
32
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
34
33
  if (result && result[3]?.length > 2) {
35
34
  reportException({
36
35
  type: 'decimalPlaceTooLong',
37
36
  data: props,
38
37
  text: `传入价格字段值“${strPrice}”小数位不能超过2位`,
39
38
  });
40
39
  return false;
41
40
  }
42
41
  if (/^\d+(\.\d+)?[eE][+-]?\d+$/.test(strPrice)) {
43
42
  reportException({
44
43
  type: 'findScientificNotation',
45
44
  data: props,
46
45
  text: `传入价格字段值“${strPrice}”是一个科学计数法格式`,
47
46
  });
48
47
  }
49
48
  return true;
50
49
  const { jdPrice, finalPrice } = props;
51
50
  if (jdPrice && finalPrice && Number(jdPrice) <= Number(finalPrice)) {
52
51
  reportException({
53
52
  type: 'pricesCompareException',
54
53
  data: props,
55
54
  text: `身份/到手价必须小于松果价`,
56
55
  });
57
56
  return false;
58
57
  } else {
59
58
  return true;
60
59
  }
61
60
  const numPrice = Number(strPrice);
62
61
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
63
62
  if (result) {
64
63
  return {
65
64
  integerPrice: result[1],
66
65
  decimalPrice: (result[3] || '').replace(/0+$/, ''),
67
66
  };
68
67
  } else {
69
68
  reportException({
70
69
  type: 'deconstructException',
71
70
  data: props,
72
71
  text: `解构传入价格字段值“${strPrice}”解构发生异常`,
73
72
  });
74
73
  return null;
75
74
  }
76
75
  const {
77
76
  jdPrice,
78
77
  finalPrice,
79
78
  priceText = '',
80
79
  priceType,
81
80
  hitUserIdentity = false,
82
81
  fallbackRender = null,
83
82
  className = null,
84
83
  style = {},
85
84
  childrenClassName = null,
86
85
  bigNoPriceClassName = null,
87
86
  bigSymbolClassName = null,
88
87
  bigIntegerClassName = null,
89
88
  bigDecimalClassName = null,
90
89
  priceDescClassName = null,
91
90
  smallPriceClassName = null,
92
91
  lineNumber = 1,
93
92
  size = 'M',
94
93
  isDefaultRemoveSmallPrice = false,
95
94
  } = props;
96
95
  let useBackstop = false;
97
96
  if (isNull(props.jdPrice, props.priceType)) {
98
97
  useBackstop = true;
99
98
  reportException({
100
99
  type: 'paramMiss',
101
100
  data: props,
102
101
  text: '缺少必要入参:jdPrice、priceType',
103
102
  });
104
103
  } else if (
105
104
  !allowedNoHitUserIdentityTypes.includes(props.priceType) &&
106
105
  props.hitUserIdentity === undefined
107
106
  ) {
108
107
  useBackstop = true;
109
108
  reportException({
110
109
  type: 'paramMiss',
111
110
  data: props,
112
111
  text: `价格类型${props.priceType}缺少必要入参:hitUserIdentity`,
113
112
  });
114
113
  }
115
114
  const especialHitStyleType = {
116
115
  7: 'plusStyle',
117
116
  9: 'samStyle',
118
117
  };
119
118
  const especialMissStyleType = {
120
119
  7: 'plusStyle',
121
120
  8: 'fansStyle',
122
121
  9: 'samStyle',
123
122
  10: 'studentStyle',
124
123
  12: 'yhdStyle',
125
124
  13: 'memberStyle',
126
125
  };
127
126
  const isUseFinalPriceAsBigPrice = allowedNoHitUserIdentityTypes.includes(priceType);
128
127
  const isEquivalentHit = isUseFinalPriceAsBigPrice || hitUserIdentity;
129
128
  const isOnlyShowBigPrice = priceType === 3 || isNull(finalPrice);
130
129
  const smallPrice = isEquivalentHit ? jdPrice : finalPrice;
131
130
  const isHideSmallPrice =
132
131
  priceType === 14 || isDefaultRemoveSmallPrice || isNaN(Number(smallPrice));
133
132
  const isTextPrice = priceType === 4;
134
133
  if (!isTextPrice && !useBackstop) {
135
134
  if (finalPrice && !numericPriceValidate(finalPrice, props)) {
136
135
  useBackstop = true;
137
136
  } else if (!numericPriceValidate(jdPrice, props)) {
138
137
  useBackstop = true;
139
138
  }
140
139
  if (!useBackstop && !isOnlyShowBigPrice && !isHideSmallPrice && !pricesCompareValidate(props)) {
141
140
  useBackstop = true;
142
141
  }
143
142
  }
144
143
  const bigPriceObj =
145
144
  isTextPrice || useBackstop
146
145
  ? {}
147
146
  : getDeconstructPrice(isEquivalentHit && !isNull(finalPrice) ? finalPrice : jdPrice, props);
148
147
  const { integerPrice = '', decimalPrice = '' } = bigPriceObj || {};
149
148
  const isPriceDescInFront = isEquivalentHit;
150
149
  const hitColorStyle = isEquivalentHit ? styles[especialHitStyleType[priceType]] : null;
151
150
  const missColorStyle = isEquivalentHit ? null : styles[especialMissStyleType[priceType]];
152
151
  const isBigPriceHasDecimal = decimalPrice !== '' && !/^0+$/.test(decimalPrice);
153
152
  const sizeLineHeight = {
154
153
  XS: 28,
155
154
  S: 34,
156
155
  M: 40,
157
156
  L: 46,
158
157
  XL: 52,
159
158
  };
160
159
  const lineHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25);
161
160
  const wrapHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25 * lineNumber);
162
161
  const computedHeightStyle = {
163
162
  height: wrapHeight,
164
163
  };
165
164
  const itemCommonStyle = {
166
165
  height: lineHeight,
167
166
  };
168
167
  const needSizeStyles = [
169
168
  'bigNoPrice',
170
169
  'bigSymbol',
171
170
  'bigInteger',
172
171
  'bigDecimal',
173
172
  'priceDesc',
174
173
  'smallPrice',
175
174
  ];
176
175
  const sizeStyles = needSizeStyles.reduce((acc, cur) => {
177
176
  acc[cur] = styles[cur + size];
178
177
  return acc;
179
178
  }, {});
180
179
  const finalFallbackText = !isLanguageForEn ? '暂无报价' : 'Unpriced';
181
180
  const noPriceShowText =
182
181
  priceText || (/^[\u4e00-\u9fa5]+$/.test(jdPrice) ? jdPrice : finalFallbackText);
183
182
  if (useBackstop && fallbackRender) {
184
183
  return fallbackRender;
185
184
  }
186
185
  return (
187
186
  <View
188
187
  className={classNames(styles.wrap, className)}
189
188
  style={{ ...computedHeightStyle, ...style }}
190
189
  >
191
190
  {isTextPrice || useBackstop ? (
192
191
  <Text
193
192
  className={classNames(
194
193
  styles.childStyle,
195
194
  styles.bigStyle,
196
195
  styles.bigNoPrice,
197
196
  sizeStyles['bigNoPrice'],
198
197
  childrenClassName,
199
198
  bigNoPriceClassName,
200
199
  )}
201
200
  style={{ ...itemCommonStyle }}
202
201
  >
203
202
  {useBackstop ? finalFallbackText : noPriceShowText}
204
203
  </Text>
205
204
  ) : (
206
205
  [
207
206
  <Text
208
207
  className={classNames(
209
208
  styles.childStyle,
210
209
  styles.bigStyle,
211
210
  styles.bigSymbol,
212
211
  sizeStyles['bigSymbol'],
213
212
  hitColorStyle,
214
213
  childrenClassName,
215
214
  bigSymbolClassName,
216
215
  )}
217
216
  key="bigSymbol"
218
217
  style={{ ...itemCommonStyle }}
219
218
  >
220
219
  ¥
221
220
  </Text>,
222
221
  <Text
223
222
  className={classNames(
224
223
  styles.childStyle,
225
224
  styles.bigStyle,
226
225
  styles.bigInteger,
227
226
  sizeStyles['bigInteger'],
228
227
  hitColorStyle,
229
228
  !isOnlyShowBigPrice && !isBigPriceHasDecimal && !isPriceDescInFront
230
229
  ? styles.rightMargin
231
230
  : null,
232
231
  childrenClassName,
233
232
  bigIntegerClassName,
234
233
  )}
235
234
  key="bigInteger"
236
235
  style={{ ...itemCommonStyle }}
237
236
  >
238
237
  {integerPrice}
239
238
  </Text>,
240
239
  isBigPriceHasDecimal ? (
241
240
  <Text
242
241
  className={classNames(
243
242
  styles.childStyle,
244
243
  styles.bigStyle,
245
244
  styles.bigDecimal,
246
245
  sizeStyles['bigDecimal'],
247
246
  hitColorStyle,
248
247
  isPriceDescInFront ? null : styles.rightMargin,
249
248
  childrenClassName,
250
249
  bigDecimalClassName,
251
250
  )}
252
251
  key="bigDecimal"
253
252
  style={{ ...itemCommonStyle }}
254
253
  >
255
254
  .{decimalPrice}
256
255
  </Text>
257
256
  ) : null,
258
257
  !isOnlyShowBigPrice && [
259
258
  isPriceDescInFront && (
260
259
  <Text
261
260
  className={classNames(
262
261
  styles.childStyle,
263
262
  styles.priceDesc,
264
263
  {
265
264
  [styles['priceEnDesc']]: isLanguageForEn,
266
265
  },
267
266
  {
268
267
  [styles['priceHiddenDesc']]: priceText === '',
269
268
  },
270
269
  sizeStyles['priceDesc'],
271
270
  styles.bigStyle,
272
271
  hitColorStyle,
273
272
  isPriceDescInFront ? styles.rightMargin : null,
274
273
  childrenClassName,
275
274
  priceDescClassName,
276
275
  )}
277
276
  key="descFront"
278
277
  style={{ ...itemCommonStyle }}
279
278
  >
280
279
  {priceText === '' ? '_' : priceText}
281
280
  </Text>
282
281
  ),
283
282
  <View
284
283
  style={{
285
284
  display: 'inline-flex',
286
285
  }}
287
286
  >
288
287
  {smallPrice && !isHideSmallPrice ? (
289
288
  <Text
290
289
  className={classNames(
291
290
  styles.childStyle,
292
291
  styles.smallPrice,
293
292
  sizeStyles['smallPrice'],
294
293
  styles.smallStyle,
295
294
  missColorStyle,
296
295
  childrenClassName,
297
296
  smallPriceClassName,
298
297
  )}
299
298
  key="smallPrice"
300
299
  style={{ ...itemCommonStyle }}
301
300
  >
302
301
  ¥{Number(smallPrice)}
303
302
  </Text>
304
303
  ) : null}
305
304
  {!isPriceDescInFront && !isHideSmallPrice && (
306
305
  <Text
307
306
  className={classNames(
308
307
  styles.childStyle,
309
308
  styles.priceDesc,
310
309
  {
311
310
  [styles['priceEnDesc']]: isLanguageForEn,
312
311
  },
313
312
  {
314
313
  [styles['priceHiddenDesc']]: priceText === '',
315
314
  },
316
315
  sizeStyles['priceDesc'],
317
316
  styles.smallStyle,
318
317
  styles.missPriceDesc,
319
318
  missColorStyle,
320
319
  childrenClassName,
321
320
  priceDescClassName,
322
321
  )}
323
322
  key="descBack"
324
323
  style={{ ...itemCommonStyle }}
325
324
  >
326
325
  {priceText === '' ? '_' : priceText}
327
326
  </Text>
328
327
  )}
329
328
  </View>,
330
329
  ],
331
330
  ]
332
331
  )}
333
332
  </View>
334
333
  );
334
+ import React from 'react';
335
335
  console.warn('🚗 ~~ file: index.tsx:22 ~~ reportException() ~~ {type, detail, text}:', {
336
336
  type,
337
337
  data,
338
338
  text,
339
339
  });
340
340
  draBusinessCustomReport({
341
341
  eventName: 'business',
342
342
  errorName: getSgmCustomCode(`${SgmCustomCode.PRICE_RENDER}_${type}`),
343
343
  errorMessage: '[双价格组件]' + text,
344
344
  extraData: JSON.stringify({
345
345
  type,
346
346
  data,
347
347
  }),
348
348
  });
349
349
  return rest.some((item) => item === undefined || item === '');
350
350
  const numPrice = Number(strPrice);
351
351
  if (isNaN(numPrice)) {
352
352
  reportException({
353
353
  type: 'isNotNumericType',
354
354
  data: props,
355
355
  text: `传入价格字段值“${strPrice}”转换数字报错`,
356
356
  });
357
357
  return false;
358
358
  }
359
359
  else if (numPrice <= 0) {
360
360
  reportException({
361
361
  type: 'isNotPositiveNumber',
362
362
  data: props,
363
363
  text: `传入价格字段值“${strPrice}”不是一个正数`,
364
364
  });
365
365
  return false;
366
366
  }
367
367
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
368
368
  if (result && result[3]?.length > 2) {
369
369
  reportException({
370
370
  type: 'decimalPlaceTooLong',
371
371
  data: props,
372
372
  text: `传入价格字段值“${strPrice}”小数位不能超过2位`,
373
373
  });
374
374
  return false;
375
375
  }
376
376
  if (/^\d+(\.\d+)?[eE][+-]?\d+$/.test(strPrice)) {
377
377
  reportException({
378
378
  type: 'findScientificNotation',
379
379
  data: props,
380
380
  text: `传入价格字段值“${strPrice}”是一个科学计数法格式`,
381
381
  });
382
382
  }
383
383
  return true;
384
384
  const { jdPrice, finalPrice, forceShowFinalPrice } = props;
385
385
  if (jdPrice && finalPrice) {
386
386
  const getLastPassValidateState = forceShowFinalPrice || Number(finalPrice) < Number(jdPrice);
387
387
  !getLastPassValidateState &&
388
388
  reportException({
389
389
  type: 'pricesCompareException',
390
390
  data: props,
391
391
  text: `身份/到手价必须小于松果价`,
392
392
  });
393
393
  return getLastPassValidateState;
394
394
  } else {
395
395
  return true;
396
396
  }
397
397
  const numPrice = Number(strPrice);
398
398
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
399
399
  if (result) {
400
400
  return {
401
401
  integerPrice: result[1],
402
402
  decimalPrice: (result[3] || '').replace(/0+$/, ''),
403
403
  };
404
404
  } else {
405
405
  reportException({
406
406
  type: 'deconstructException',
407
407
  data: props,
408
408
  text: `解构传入价格字段值“${strPrice}”解构发生异常`,
409
409
  });
410
410
  return null;
411
411
  }
412
412
  const {
413
413
  jdPrice,
414
414
  finalPrice,
415
415
  priceText = '',
416
416
  priceTextColor = '',
417
417
  priceUnit = '',
418
418
  priceType,
419
419
  hitUserIdentity = false,
420
420
  forceShowFinalPrice = false,
421
421
  hideSmallPrice = false,
422
422
  fallbackRender = null,
423
423
  className = null,
424
424
  style = {},
425
425
  childrenClassName = null,
426
426
  bigNoPriceClassName = null,
427
427
  bigSymbolClassName = null,
428
428
  bigIntegerClassName = null,
429
429
  bigDecimalClassName = null,
430
430
  priceDescClassName = null,
431
431
  smallPriceClassName = null,
432
432
  smallPriceDescClassName = null,
433
433
  lineNumber = 1,
434
434
  size = 'M',
435
435
  isDefaultRemoveSmallPrice = false,
436
436
  useFontV2 = false,
437
437
  useFontV2Bold = false,
438
438
  useSmallFontV2 = false,
439
439
  useSmallFontV2Bold = false,
440
440
  } = props;
441
441
  let useBackstop = false;
442
442
  const isShowPriceUnit = priceUnit && priceUnit !== '';
443
443
  if (isNull(props.priceType)) {
444
444
  useBackstop = true;
445
445
  reportException({
446
446
  type: 'paramMiss',
447
447
  data: props,
448
448
  text: '缺少必要入参:priceType',
449
449
  });
450
450
  } else if (
451
451
  !allowedNoHitUserIdentityTypes.includes(props.priceType) &&
452
452
  props.hitUserIdentity === undefined
453
453
  ) {
454
454
  useBackstop = true;
455
455
  reportException({
456
456
  type: 'paramMiss',
457
457
  data: props,
458
458
  text: `价格类型${props.priceType}缺少必要入参:hitUserIdentity`,
459
459
  });
460
460
  }
461
461
  const especialHitStyleType = {
462
462
  7: 'plusStyle',
463
463
  9: 'samStyle',
464
464
  };
465
465
  const especialMissStyleType = {
466
466
  7: 'plusStyle',
467
467
  8: 'fansStyle',
468
468
  9: 'samStyle',
469
469
  10: 'studentStyle',
470
470
  12: 'yhdStyle',
471
471
  13: 'memberStyle',
472
472
  };
473
473
  const isUseFinalPriceAsBigPrice = allowedNoHitUserIdentityTypes.includes(priceType);
474
474
  const isEquivalentHit = isUseFinalPriceAsBigPrice || hitUserIdentity;
475
475
  const isOnlyShowBigPrice = priceType === 3 || isNull(finalPrice);
476
476
  const smallPrice = isEquivalentHit ? jdPrice : finalPrice;
477
477
  const isHideSmallPrice =
478
478
  hideSmallPrice || priceType === 14 || isDefaultRemoveSmallPrice || isNaN(Number(smallPrice));
479
479
  const isTextPrice = priceType === 4;
480
480
  if (!isTextPrice && !useBackstop) {
481
481
  if (finalPrice && !numericPriceValidate(finalPrice, props)) {
482
482
  useBackstop = true;
483
483
  } else if (jdPrice && !numericPriceValidate(jdPrice, props)) {
484
484
  useBackstop = true;
485
485
  }
486
486
  if (!useBackstop && !isOnlyShowBigPrice && !isHideSmallPrice && !pricesCompareValidate(props)) {
487
487
  useBackstop = true;
488
488
  }
489
489
  }
490
490
  const bigPriceObj =
491
491
  isTextPrice || useBackstop
492
492
  ? {}
493
493
  : getDeconstructPrice(isEquivalentHit && !isNull(finalPrice) ? finalPrice : jdPrice, props);
494
494
  const { integerPrice = '', decimalPrice = '' } = bigPriceObj || {};
495
495
  const isPriceDescInFront = isEquivalentHit;
496
496
  const hitColorStyle = isEquivalentHit ? styles[especialHitStyleType[priceType]] : null;
497
497
  const missColorStyle = isEquivalentHit ? null : styles[especialMissStyleType[priceType]];
498
498
  const isBigPriceHasDecimal = decimalPrice !== '' && !/^0+$/.test(decimalPrice);
499
499
  const sizeLineHeight = {
500
500
  XS: 28,
501
501
  S: 34,
502
502
  M: 40,
503
503
  L: 46,
504
504
  XL: 52,
505
505
  };
506
506
  const lineHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25);
507
507
  const wrapHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25 * lineNumber);
508
508
  const computedHeightStyle = {
509
509
  height: wrapHeight,
510
510
  };
511
511
  const itemCommonStyle = {
512
512
  height: lineHeight,
513
513
  };
514
514
  const priceTextStyle = priceTextColor ? { color: priceTextColor } : {};
515
515
  const needSizeStyles = [
516
516
  'bigNoPrice',
517
517
  'bigSymbol',
518
518
  'bigInteger',
519
519
  'bigDecimal',
520
520
  'priceDesc',
521
521
  'smallPrice',
522
522
  'priceUnit',
523
523
  ];
524
524
  const sizeStyles = needSizeStyles.reduce((acc, cur) => {
525
525
  acc[cur] = styles[cur + size];
526
526
  return acc;
527
527
  }, {});
528
528
  const finalFallbackText = global?.languageJsonData?.noPriceTip || '暂无报价';
529
529
  const noPriceShowText =
530
530
  priceText || (/^[\u4e00-\u9fa5]+$/.test(jdPrice) ? jdPrice : finalFallbackText);
531
531
  if (useBackstop && fallbackRender) {
532
532
  return fallbackRender;
533
533
  }
534
534
  return (
535
535
  <View
536
536
  className={classNames(styles.wrap, className)}
537
537
  style={{ ...computedHeightStyle, ...style }}
538
538
  >
539
539
  {isTextPrice || useBackstop ? (
540
540
  <Text
541
541
  className={classNames(
542
542
  styles.childStyle,
543
543
  styles.bigStyle,
544
544
  styles.bigNoPrice,
545
545
  sizeStyles['bigNoPrice'],
546
546
  childrenClassName,
547
547
  bigNoPriceClassName,
548
548
  )}
549
549
  style={{ ...itemCommonStyle }}
550
550
  >
551
551
  {useBackstop ? finalFallbackText : noPriceShowText}
552
552
  </Text>
553
553
  ) : (
554
554
  [
555
555
  <Text
556
556
  className={classNames(
557
557
  styles.childStyle,
558
558
  styles.bigStyle,
559
559
  styles.bigSymbol,
560
560
  sizeStyles['bigSymbol'],
561
561
  hitColorStyle,
562
562
  childrenClassName,
563
563
  bigSymbolClassName,
564
564
  {
565
565
  [styles.fontV2]: useFontV2,
566
566
  [styles.fontV2Bold]: useFontV2Bold,
567
567
  },
568
568
  )}
569
569
  key="bigSymbol"
570
570
  style={{ ...itemCommonStyle }}
571
571
  >
572
572
  ¥
573
573
  </Text>,
574
574
  <Text
575
575
  className={classNames(
576
576
  styles.childStyle,
577
577
  styles.bigStyle,
578
578
  styles.bigInteger,
579
579
  sizeStyles['bigInteger'],
580
580
  hitColorStyle,
581
581
  !isOnlyShowBigPrice &&
582
582
  !isBigPriceHasDecimal &&
583
583
  !isPriceDescInFront &&
584
584
  !isShowPriceUnit
585
585
  ? styles.rightMargin
586
586
  : null,
587
587
  childrenClassName,
588
588
  bigIntegerClassName,
589
589
  {
590
590
  [styles.fontV2]: useFontV2,
591
591
  [styles.fontV2Bold]: useFontV2Bold,
592
592
  },
593
593
  )}
594
594
  key="bigInteger"
595
595
  style={{ ...itemCommonStyle }}
596
596
  >
597
597
  {integerPrice}
598
598
  </Text>,
599
599
  isBigPriceHasDecimal ? (
600
600
  <Text
601
601
  className={classNames(
602
602
  styles.childStyle,
603
603
  styles.bigStyle,
604
604
  styles.bigDecimal,
605
605
  sizeStyles['bigDecimal'],
606
606
  hitColorStyle,
607
607
  isPriceDescInFront || priceText === '' || isShowPriceUnit
608
608
  ? null
609
609
  : styles.rightMargin,
610
610
  childrenClassName,
611
611
  bigDecimalClassName,
612
612
  {
613
613
  [styles.fontV2]: useFontV2,
614
614
  [styles.fontV2Bold]: useFontV2Bold,
615
615
  },
616
616
  )}
617
617
  key="bigDecimal"
618
618
  style={{ ...itemCommonStyle }}
619
619
  >
620
620
  .{decimalPrice}
621
621
  </Text>
622
622
  ) : null,
623
623
  isShowPriceUnit ? (
624
624
  <Text
625
625
  className={classNames(
626
626
  styles.childStyle,
627
627
  styles.priceUnit,
628
628
  styles.rightMargin,
629
629
  sizeStyles['priceUnit'],
630
630
  styles.bigStyle,
631
631
  hitColorStyle,
632
632
  childrenClassName,
633
633
  priceDescClassName,
634
634
  )}
635
635
  key="descFrontUnit"
636
636
  style={{ ...itemCommonStyle }}
637
637
  >
638
638
  {priceUnit}
639
639
  </Text>
640
640
  ) : null,
641
641
  !isOnlyShowBigPrice && [
642
642
  isPriceDescInFront && (
643
643
  <Text
644
644
  className={classNames(
645
645
  styles.childStyle,
646
646
  styles.priceDesc,
647
647
  {
648
648
  [styles['priceEnDesc']]: isLanguageForEn,
649
649
  },
650
650
  {
651
651
  [styles['priceHiddenDesc']]: priceText === '',
652
652
  },
653
653
  sizeStyles['priceDesc'],
654
654
  styles.bigStyle,
655
655
  hitColorStyle,
656
656
  isPriceDescInFront && !isShowPriceUnit && !isHideSmallPrice
657
657
  ? styles.rightMargin
658
658
  : null,
659
659
  childrenClassName,
660
660
  priceDescClassName,
661
661
  )}
662
662
  key="descFront"
663
663
  style={{ ...itemCommonStyle, ...priceTextStyle }}
664
664
  >
665
665
  {priceText === '' ? '_' : priceText}
666
666
  </Text>
667
667
  ),
668
668
  <View
669
669
  style={{
670
670
  display: 'inline-flex',
671
671
  }}
672
672
  >
673
673
  {smallPrice && !isHideSmallPrice ? (
674
674
  <Text
675
675
  className={classNames(
676
676
  styles.childStyle,
677
677
  styles.smallPrice,
678
678
  sizeStyles['smallPrice'],
679
679
  styles.smallStyle,
680
680
  missColorStyle,
681
681
  childrenClassName,
682
682
  smallPriceClassName,
683
683
  {
684
684
  [styles.fontV2]: useSmallFontV2Bold ? false : useSmallFontV2 || useFontV2,
685
685
  [styles.fontV2Bold]: useSmallFontV2
686
686
  ? false
687
687
  : useSmallFontV2Bold || useFontV2Bold,
688
688
  },
689
689
  )}
690
690
  key="smallPrice"
691
691
  style={{ ...itemCommonStyle }}
692
692
  >
693
693
  ¥{Number(smallPrice)}
694
694
  </Text>
695
695
  ) : null}
696
696
  {isShowPriceUnit && !isHideSmallPrice ? (
697
697
  <Text
698
698
  className={classNames(
699
699
  styles.childStyle,
700
700
  styles.priceUnit,
701
701
  sizeStyles['priceUnit'],
702
702
  styles.smallStyle,
703
703
  styles.missPriceDesc,
704
704
  missColorStyle,
705
705
  childrenClassName,
706
706
  smallPriceDescClassName || priceDescClassName,
707
707
  )}
708
708
  key="descFrontUnit"
709
709
  style={{ ...itemCommonStyle }}
710
710
  >
711
711
  {priceUnit}
712
712
  </Text>
713
713
  ) : null}
714
714
  {!isPriceDescInFront && !isHideSmallPrice && (
715
715
  <Text
716
716
  className={classNames(
717
717
  styles.childStyle,
718
718
  styles.priceDesc,
719
719
  {
720
720
  [styles['priceEnDesc']]: isLanguageForEn,
721
721
  },
722
722
  {
723
723
  [styles['priceHiddenDesc']]: priceText === '',
724
724
  },
725
725
  sizeStyles['priceDesc'],
726
726
  styles.smallStyle,
727
727
  styles.missPriceDesc,
728
728
  missColorStyle,
729
729
  childrenClassName,
730
730
  smallPriceDescClassName || priceDescClassName,
731
731
  )}
732
732
  key="descBack"
733
733
  style={{ ...itemCommonStyle }}
734
734
  >
735
735
  {priceText === '' ? '_' : priceText}
736
736
  </Text>
737
737
  )}
738
738
  </View>,
739
739
  ],
740
740
  ]
741
741
  )}
742
742
  </View>
743
743
  );