@conecli/cone-render 0.10.1-shop-beta.11 → 0.10.1-shop-beta.13

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 (78) hide show
  1. package/README.md +1 -1
  2. package/dist/common/const.ts +1 -1
  3. package/dist/common/index.dynamic.ts +1 -0
  4. package/dist/common/index.h5.ts +1 -1
  5. package/dist/common/index.jd.ts +1 -1
  6. package/dist/common/index.ts +1 -1
  7. package/dist/common/index.weapp.ts +1 -1
  8. package/dist/common/jssdk.ts +1 -1
  9. package/dist/common/token/index.h5.ts +1 -1
  10. package/dist/common/wxappApi.ts +1 -1
  11. package/dist/components/base/CommonFloorHead/index.tsx +1 -1
  12. package/dist/components/base/CountDown/index.tsx +1 -1
  13. package/dist/components/base/CustomScrollView/index.tsx +1 -1
  14. package/dist/components/base/Dialog/index.dynamic.module.scss +126 -0
  15. package/dist/components/base/Dialog/index.dynamic.tsx +1 -0
  16. package/dist/components/base/DynamicTest/index.dynamic.module.scss +15 -0
  17. package/dist/components/base/DynamicTest/index.module.scss +16 -0
  18. package/dist/components/base/DynamicTest/index.tsx +1 -0
  19. package/dist/components/base/ExposureSmart/index.tsx +1 -1
  20. package/dist/components/base/ItemViewExposureSmart/index.tsx +1 -1
  21. package/dist/components/base/JdLoading/index.module.scss +2 -0
  22. package/dist/components/base/JdLoading/index.tsx +1 -1
  23. package/dist/components/base/LazyLoadImage/index.tsx +1 -1
  24. package/dist/components/base/NetworkDataError/const.ts +1 -1
  25. package/dist/components/base/NetworkDataError/index.module.scss +116 -70
  26. package/dist/components/base/NetworkDataError/index.tsx +1 -1
  27. package/dist/components/base/Price/Base/index.dynamic.module.scss +63 -0
  28. package/dist/components/base/Price/Base/index.dynamic.tsx +1 -0
  29. package/dist/components/base/Price/Base/index.module.scss +6 -0
  30. package/dist/components/base/Price/Base/index.tsx +1 -1
  31. package/dist/components/base/Price/Double/index.dynamic.module.scss +172 -0
  32. package/dist/components/base/Price/Double/index.dynamic.tsx +1 -0
  33. package/dist/components/base/Price/Double/index.module.scss +6 -0
  34. package/dist/components/base/Price/Double/index.tsx +1 -1
  35. package/dist/components/debug/DebugLayout/index.module.scss +2 -2
  36. package/dist/config/env.ts +1 -1
  37. package/dist/interface/common.ts +1 -1
  38. package/dist/interface/component.ts +1 -1
  39. package/dist/interface/jumpEventReport.ts +1 -1
  40. package/dist/jumpEventReport/const.ts +1 -1
  41. package/dist/jumpEventReport/index.dynamic.ts +1 -0
  42. package/dist/jumpEventReport/index.h5.ts +1 -1
  43. package/dist/jumpEventReport/jdJumpJdApp.ts +1 -1
  44. package/dist/jumpEventReport/jumpUrlConfig/base.ts +1 -1
  45. package/dist/jumpEventReport/logEventConfig.ts +1 -1
  46. package/dist/jumpEventReport/web.base.ts +1 -1
  47. package/dist/jumpEventReport/web.jd.ts +1 -1
  48. package/dist/language/zh_CN.json +162 -0
  49. package/dist/open/api/index.ts +1 -1
  50. package/dist/open/api/shopMember.dynamic.ts +1 -0
  51. package/dist/open/api/shopMember.ts +1 -1
  52. package/dist/open/components/index.dynamic.ts +1 -0
  53. package/dist/open/components/index.ts +1 -1
  54. package/dist/sass/app.dynamic.scss +306 -0
  55. package/dist/service/fetchGateway.h5.ts +1 -0
  56. package/dist/service/fetchGateway.ts +1 -1
  57. package/dist/service/fetchGateway.weapp.ts +1 -1
  58. package/dist/service/fetchJsonp.h5.ts +1 -0
  59. package/dist/service/fetchJsonp.ts +1 -1
  60. package/dist/service/http/colorSign.dynamic.ts +1 -0
  61. package/dist/service/http/http.ts +1 -1
  62. package/dist/service/requestServer.h5.ts +1 -1
  63. package/dist/service/requestServer.ts +1 -1
  64. package/dist/service/requestServer.weapp.ts +1 -1
  65. package/dist/utils/connectNativeJsBridge.dynamic.ts +1 -0
  66. package/dist/utils/connectNativeJsBridge.ts +1 -1
  67. package/dist/utils/h5Utils.ts +1 -1
  68. package/dist/utils/index.h5.ts +1 -1
  69. package/dist/utils/index.ts +1 -1
  70. package/dist/utils/index.weapp.ts +1 -1
  71. package/dist/utils/intersectionObserver.ts +1 -1
  72. package/dist/utils/jumpExtMapUtil.ts +1 -0
  73. package/dist/utils/log.ts +1 -0
  74. package/dist/utils/utils.ts +1 -1
  75. package/dist/wxapp/common/address_api/address_api_v2.js +1 -0
  76. package/dist/wxapp/common/user_info.js +1 -1
  77. package/package.json +51 -31
  78. /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
  sgmCustomReport({
341
341
  code: getSgmCustomCode(`${SgmCustomCode.PRICE_RENDER}_${type}`),
342
342
  msg: {
343
343
  type,
344
344
  data,
345
345
  text: '[双价格组件]' + text,
346
346
  },
347
347
  });
348
348
  return rest.some((item) => item === undefined || item === '');
349
349
  const numPrice = Number(strPrice);
350
350
  if (isNaN(numPrice)) {
351
351
  reportException({
352
352
  type: 'isNotNumericType',
353
353
  data: props,
354
354
  text: `传入价格字段值“${strPrice}”转换数字报错`,
355
355
  });
356
356
  return false;
357
357
  }
358
358
  else if (numPrice <= 0) {
359
359
  reportException({
360
360
  type: 'isNotPositiveNumber',
361
361
  data: props,
362
362
  text: `传入价格字段值“${strPrice}”不是一个正数`,
363
363
  });
364
364
  return false;
365
365
  }
366
366
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
367
367
  if (result && result[3]?.length > 2) {
368
368
  reportException({
369
369
  type: 'decimalPlaceTooLong',
370
370
  data: props,
371
371
  text: `传入价格字段值“${strPrice}”小数位不能超过2位`,
372
372
  });
373
373
  return false;
374
374
  }
375
375
  if (/^\d+(\.\d+)?[eE][+-]?\d+$/.test(strPrice)) {
376
376
  reportException({
377
377
  type: 'findScientificNotation',
378
378
  data: props,
379
379
  text: `传入价格字段值“${strPrice}”是一个科学计数法格式`,
380
380
  });
381
381
  }
382
382
  return true;
383
383
  const { jdPrice, finalPrice } = props;
384
384
  if (jdPrice && finalPrice && Number(jdPrice) <= Number(finalPrice)) {
385
385
  reportException({
386
386
  type: 'pricesCompareException',
387
387
  data: props,
388
388
  text: `身份/到手价必须小于松果价`,
389
389
  });
390
390
  return false;
391
391
  } else {
392
392
  return true;
393
393
  }
394
394
  const numPrice = Number(strPrice);
395
395
  const result = numPrice.toString().match(/(\d+)(\.(\d+))?/);
396
396
  if (result) {
397
397
  return {
398
398
  integerPrice: result[1],
399
399
  decimalPrice: (result[3] || '').replace(/0+$/, ''),
400
400
  };
401
401
  } else {
402
402
  reportException({
403
403
  type: 'deconstructException',
404
404
  data: props,
405
405
  text: `解构传入价格字段值“${strPrice}”解构发生异常`,
406
406
  });
407
407
  return null;
408
408
  }
409
409
  const {
410
410
  jdPrice,
411
411
  finalPrice,
412
412
  priceText = '',
413
413
  priceType,
414
414
  hitUserIdentity = false,
415
415
  fallbackRender = null,
416
416
  className = null,
417
417
  style = {},
418
418
  childrenClassName = null,
419
419
  bigNoPriceClassName = null,
420
420
  bigSymbolClassName = null,
421
421
  bigIntegerClassName = null,
422
422
  bigDecimalClassName = null,
423
423
  priceDescClassName = null,
424
424
  smallPriceClassName = null,
425
425
  lineNumber = 1,
426
426
  size = 'M',
427
427
  isDefaultRemoveSmallPrice = false,
428
428
  useFontV2 = false,
429
429
  useFontV2Bold = false,
430
430
  useFontV2ForMain = false,
431
431
  useFontV2BoldForMain = false,
432
432
  } = props;
433
433
  let useBackstop = false;
434
434
  if (isNull(props.jdPrice, props.priceType)) {
435
435
  useBackstop = true;
436
436
  reportException({
437
437
  type: 'paramMiss',
438
438
  data: props,
439
439
  text: '缺少必要入参:jdPrice、priceType',
440
440
  });
441
441
  } else if (
442
442
  !allowedNoHitUserIdentityTypes.includes(props.priceType) &&
443
443
  props.hitUserIdentity === undefined
444
444
  ) {
445
445
  useBackstop = true;
446
446
  reportException({
447
447
  type: 'paramMiss',
448
448
  data: props,
449
449
  text: `价格类型${props.priceType}缺少必要入参:hitUserIdentity`,
450
450
  });
451
451
  }
452
452
  const especialHitStyleType = {
453
453
  7: 'plusStyle',
454
454
  9: 'samStyle',
455
455
  };
456
456
  const especialMissStyleType = {
457
457
  7: 'plusStyle',
458
458
  8: 'fansStyle',
459
459
  9: 'samStyle',
460
460
  10: 'studentStyle',
461
461
  12: 'yhdStyle',
462
462
  13: 'memberStyle',
463
463
  };
464
464
  const isUseFinalPriceAsBigPrice = allowedNoHitUserIdentityTypes.includes(priceType);
465
465
  const isEquivalentHit = isUseFinalPriceAsBigPrice || hitUserIdentity;
466
466
  const isOnlyShowBigPrice = priceType === 3 || isNull(finalPrice);
467
467
  const smallPrice = isEquivalentHit ? jdPrice : finalPrice;
468
468
  const isHideSmallPrice =
469
469
  priceType === 14 || isDefaultRemoveSmallPrice || isNaN(Number(smallPrice));
470
470
  const isTextPrice = priceType === 4;
471
471
  if (!isTextPrice && !useBackstop) {
472
472
  if (finalPrice && !numericPriceValidate(finalPrice, props)) {
473
473
  useBackstop = true;
474
474
  } else if (!numericPriceValidate(jdPrice, props)) {
475
475
  useBackstop = true;
476
476
  }
477
477
  if (!useBackstop && !isOnlyShowBigPrice && !isHideSmallPrice && !pricesCompareValidate(props)) {
478
478
  useBackstop = true;
479
479
  }
480
480
  }
481
481
  const bigPriceObj =
482
482
  isTextPrice || useBackstop
483
483
  ? {}
484
484
  : getDeconstructPrice(isEquivalentHit && !isNull(finalPrice) ? finalPrice : jdPrice, props);
485
485
  const { integerPrice = '', decimalPrice = '' } = bigPriceObj || {};
486
486
  const isPriceDescInFront = isEquivalentHit;
487
487
  const hitColorStyle = isEquivalentHit ? styles[especialHitStyleType[priceType]] : null;
488
488
  const missColorStyle = isEquivalentHit ? null : styles[especialMissStyleType[priceType]];
489
489
  const isBigPriceHasDecimal = decimalPrice !== '' && !/^0+$/.test(decimalPrice);
490
490
  const sizeLineHeight = {
491
491
  XS: 28,
492
492
  S: 34,
493
493
  M: 40,
494
494
  L: 46,
495
495
  XL: 52,
496
496
  };
497
497
  const lineHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25);
498
498
  const wrapHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25 * lineNumber);
499
499
  const computedHeightStyle = {
500
500
  height: wrapHeight,
501
501
  };
502
502
  const itemCommonStyle = {
503
503
  height: lineHeight,
504
504
  };
505
505
  const needSizeStyles = [
506
506
  'bigNoPrice',
507
507
  'bigSymbol',
508
508
  'bigInteger',
509
509
  'bigDecimal',
510
510
  'priceDesc',
511
511
  'smallPrice',
512
512
  ];
513
513
  const sizeStyles = needSizeStyles.reduce((acc, cur) => {
514
514
  acc[cur] = styles[cur + size];
515
515
  return acc;
516
516
  }, {});
517
517
  const finalFallbackText = global?.languageJsonData?.noPriceTip || '暂无报价';
518
518
  const noPriceShowText =
519
519
  priceText || (/^[\u4e00-\u9fa5]+$/.test(jdPrice) ? jdPrice : finalFallbackText);
520
520
  if (useBackstop && fallbackRender) {
521
521
  return fallbackRender;
522
522
  }
523
523
  return (
524
524
  <View
525
525
  className={classNames(styles.wrap, className)}
526
526
  style={{ ...computedHeightStyle, ...style }}
527
527
  >
528
528
  {isTextPrice || useBackstop ? (
529
529
  <Text
530
530
  className={classNames(
531
531
  styles.childStyle,
532
532
  styles.bigStyle,
533
533
  styles.bigNoPrice,
534
534
  sizeStyles['bigNoPrice'],
535
535
  childrenClassName,
536
536
  bigNoPriceClassName,
537
537
  )}
538
538
  style={{ ...itemCommonStyle }}
539
539
  >
540
540
  {useBackstop ? finalFallbackText : noPriceShowText}
541
541
  </Text>
542
542
  ) : (
543
543
  [
544
544
  <Text
545
545
  className={classNames(
546
546
  styles.childStyle,
547
547
  styles.bigStyle,
548
548
  styles.bigSymbol,
549
549
  sizeStyles['bigSymbol'],
550
550
  hitColorStyle,
551
551
  childrenClassName,
552
552
  bigSymbolClassName,
553
553
  {
554
554
  [styles.fontV2]: useFontV2 || useFontV2ForMain,
555
555
  [styles.fontV2Bold]: useFontV2Bold || useFontV2BoldForMain,
556
556
  },
557
557
  )}
558
558
  key="bigSymbol"
559
559
  style={{ ...itemCommonStyle }}
560
560
  >
561
561
  ¥
562
562
  </Text>,
563
563
  <Text
564
564
  className={classNames(
565
565
  styles.childStyle,
566
566
  styles.bigStyle,
567
567
  styles.bigInteger,
568
568
  sizeStyles['bigInteger'],
569
569
  hitColorStyle,
570
570
  !isOnlyShowBigPrice && !isBigPriceHasDecimal && !isPriceDescInFront
571
571
  ? styles.rightMargin
572
572
  : null,
573
573
  childrenClassName,
574
574
  bigIntegerClassName,
575
575
  {
576
576
  [styles.fontV2]: useFontV2 || useFontV2ForMain,
577
577
  [styles.fontV2Bold]: useFontV2Bold || useFontV2BoldForMain,
578
578
  },
579
579
  )}
580
580
  key="bigInteger"
581
581
  style={{ ...itemCommonStyle }}
582
582
  >
583
583
  {integerPrice}
584
584
  </Text>,
585
585
  isBigPriceHasDecimal ? (
586
586
  <Text
587
587
  className={classNames(
588
588
  styles.childStyle,
589
589
  styles.bigStyle,
590
590
  styles.bigDecimal,
591
591
  sizeStyles['bigDecimal'],
592
592
  hitColorStyle,
593
593
  isPriceDescInFront ? null : styles.rightMargin,
594
594
  childrenClassName,
595
595
  bigDecimalClassName,
596
596
  {
597
597
  [styles.fontV2]: useFontV2 || useFontV2ForMain,
598
598
  [styles.fontV2Bold]: useFontV2Bold || useFontV2BoldForMain,
599
599
  },
600
600
  )}
601
601
  key="bigDecimal"
602
602
  style={{ ...itemCommonStyle }}
603
603
  >
604
604
  .{decimalPrice}
605
605
  </Text>
606
606
  ) : null,
607
607
  !isOnlyShowBigPrice && [
608
608
  isPriceDescInFront && (
609
609
  <Text
610
610
  className={classNames(
611
611
  styles.childStyle,
612
612
  styles.priceDesc,
613
613
  {
614
614
  [styles['priceEnDesc']]: isLanguageForEn,
615
615
  },
616
616
  {
617
617
  [styles['priceHiddenDesc']]: priceText === '',
618
618
  },
619
619
  sizeStyles['priceDesc'],
620
620
  styles.bigStyle,
621
621
  hitColorStyle,
622
622
  isPriceDescInFront ? styles.rightMargin : null,
623
623
  childrenClassName,
624
624
  priceDescClassName,
625
625
  )}
626
626
  key="descFront"
627
627
  style={{ ...itemCommonStyle }}
628
628
  >
629
629
  {priceText === '' ? '_' : priceText}
630
630
  </Text>
631
631
  ),
632
632
  <View
633
633
  style={{
634
634
  display: 'inline-flex',
635
635
  }}
636
636
  >
637
637
  {smallPrice && !isHideSmallPrice ? (
638
638
  <Text
639
639
  className={classNames(
640
640
  styles.childStyle,
641
641
  styles.smallPrice,
642
642
  sizeStyles['smallPrice'],
643
643
  styles.smallStyle,
644
644
  missColorStyle,
645
645
  childrenClassName,
646
646
  smallPriceClassName,
647
647
  {
648
648
  [styles.fontV2]: useFontV2,
649
649
  [styles.fontV2Bold]: useFontV2Bold,
650
650
  },
651
651
  )}
652
652
  key="smallPrice"
653
653
  style={{ ...itemCommonStyle }}
654
654
  >
655
655
  ¥{Number(smallPrice)}
656
656
  </Text>
657
657
  ) : null}
658
658
  {!isPriceDescInFront && !isHideSmallPrice && (
659
659
  <Text
660
660
  className={classNames(
661
661
  styles.childStyle,
662
662
  styles.priceDesc,
663
663
  {
664
664
  [styles['priceEnDesc']]: isLanguageForEn,
665
665
  },
666
666
  {
667
667
  [styles['priceHiddenDesc']]: priceText === '',
668
668
  },
669
669
  sizeStyles['priceDesc'],
670
670
  styles.smallStyle,
671
671
  styles.missPriceDesc,
672
672
  missColorStyle,
673
673
  childrenClassName,
674
674
  priceDescClassName,
675
675
  )}
676
676
  key="descBack"
677
677
  style={{ ...itemCommonStyle }}
678
678
  >
679
679
  {priceText === '' ? '_' : priceText}
680
680
  </Text>
681
681
  )}
682
682
  </View>,
683
683
  ],
684
684
  ]
685
685
  )}
686
686
  </View>
687
687
  );