@conecli/cone-render 0.10.1-shop3.2 → 0.10.1-shop3.21

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 (75) hide show
  1. package/dist/api/index.ts +1 -1
  2. package/dist/common/const.ts +1 -1
  3. package/dist/common/index.h5.ts +1 -1
  4. package/dist/common/index.jd.ts +1 -1
  5. package/dist/common/index.ts +1 -1
  6. package/dist/common/index.weapp.ts +1 -1
  7. package/dist/common/jssdk.ts +1 -1
  8. package/dist/common/token/index.h5.ts +1 -1
  9. package/dist/common/token/token.jd.ts +1 -1
  10. package/dist/common/wxappApi.ts +1 -1
  11. package/dist/components/base/CommonFloorHead/index.module.scss +126 -111
  12. package/dist/components/base/CommonFloorHead/index.tsx +1 -1
  13. package/dist/components/base/CountDown/index.tsx +1 -1
  14. package/dist/components/base/CustomScrollView/index-back.tsx +1 -0
  15. package/dist/components/base/CustomScrollView/index.tsx +1 -1
  16. package/dist/components/base/Dialog/index.module.scss +11 -0
  17. package/dist/components/base/ExposureSmart/index.h5.module.scss +12 -2
  18. package/dist/components/base/ExposureSmart/index.h5.tsx +1 -1
  19. package/dist/components/base/ExposureSmart/reporter.tsx +1 -1
  20. package/dist/components/base/InViewRender/index.tsx +1 -1
  21. package/dist/components/base/ItemViewExposureSmart/index.module.scss +2 -2
  22. package/dist/components/base/ItemViewExposureSmart/index.tsx +1 -1
  23. package/dist/components/base/NetworkDataError/const.ts +1 -1
  24. package/dist/components/base/NetworkDataError/index.module.scss +116 -70
  25. package/dist/components/base/NetworkDataError/index.tsx +1 -1
  26. package/dist/components/base/Price/Base/index.module.scss +6 -0
  27. package/dist/components/base/Price/Base/index.tsx +1 -1
  28. package/dist/components/base/Price/Double/index.module.scss +6 -0
  29. package/dist/components/base/Price/Double/index.tsx +1 -1
  30. package/dist/components/debug/DebugLayout/index.module.scss +2 -2
  31. package/dist/components/floorItem.weapp.tsx +1 -1
  32. package/dist/interface/common.ts +1 -1
  33. package/dist/interface/component.ts +1 -1
  34. package/dist/interface/jumpEventReport.ts +1 -1
  35. package/dist/interface/service.ts +1 -1
  36. package/dist/jumpEventReport/base.ts +1 -1
  37. package/dist/jumpEventReport/const.ts +1 -1
  38. package/dist/jumpEventReport/index.h5.ts +1 -1
  39. package/dist/jumpEventReport/index.weapp.ts +1 -1
  40. package/dist/jumpEventReport/jdJumpJdApp.ts +1 -1
  41. package/dist/jumpEventReport/jumpUrlConfig/base.ts +1 -1
  42. package/dist/jumpEventReport/logEventConfig.ts +1 -1
  43. package/dist/jumpEventReport/web/report.ts +1 -1
  44. package/dist/jumpEventReport/web.base.ts +1 -1
  45. package/dist/jumpEventReport/web.jd.ts +1 -1
  46. package/dist/jumpEventReport/web.wxapp.ts +1 -1
  47. package/dist/libs/taroAppReport.js +2 -2
  48. package/dist/modules/ContainerFloorList/index.h5.module.scss +66 -53
  49. package/dist/modules/ContainerFloorList/index.h5.tsx +1 -1
  50. package/dist/modules/ContainerFloorList/index.tsx +1 -1
  51. package/dist/open/api/environment.ts +1 -1
  52. package/dist/open/api/shopMember.ts +1 -1
  53. package/dist/open/api/util.ts +1 -1
  54. package/dist/sass/app.h5.scss +273 -224
  55. package/dist/service/fetchGateway.ts +1 -1
  56. package/dist/service/fetchGateway.weapp.ts +1 -0
  57. package/dist/service/http/colorSign.ts +1 -1
  58. package/dist/service/http/const.ts +1 -1
  59. package/dist/service/http/h5Http.ts +1 -1
  60. package/dist/service/requestServer.h5.ts +1 -1
  61. package/dist/service/requestServer.ts +1 -1
  62. package/dist/service/requestServer.weapp.ts +1 -0
  63. package/dist/utils/connectNativeJsBridge.ts +1 -1
  64. package/dist/utils/h5Utils.ts +1 -1
  65. package/dist/utils/index.h5.ts +1 -1
  66. package/dist/utils/index.ts +1 -1
  67. package/dist/utils/index.weapp.ts +1 -1
  68. package/dist/utils/jumpExtMapUtil.h5.ts +1 -0
  69. package/dist/utils/jumpExtMapUtil.ts +1 -0
  70. package/dist/utils/log.ts +1 -0
  71. package/dist/utils/sColor.js +1 -0
  72. package/dist/utils/utils.ts +1 -1
  73. package/dist/wxapp/common/address_api/address_api_v2.js +1 -0
  74. package/dist/wxapp/common/user_info.js +1 -1
  75. package/package.json +158 -141
@@ -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
  } = props;
431
431
  let useBackstop = false;
432
432
  if (isNull(props.jdPrice, props.priceType)) {
433
433
  useBackstop = true;
434
434
  reportException({
435
435
  type: 'paramMiss',
436
436
  data: props,
437
437
  text: '缺少必要入参:jdPrice、priceType',
438
438
  });
439
439
  } else if (
440
440
  !allowedNoHitUserIdentityTypes.includes(props.priceType) &&
441
441
  props.hitUserIdentity === undefined
442
442
  ) {
443
443
  useBackstop = true;
444
444
  reportException({
445
445
  type: 'paramMiss',
446
446
  data: props,
447
447
  text: `价格类型${props.priceType}缺少必要入参:hitUserIdentity`,
448
448
  });
449
449
  }
450
450
  const especialHitStyleType = {
451
451
  7: 'plusStyle',
452
452
  9: 'samStyle',
453
453
  };
454
454
  const especialMissStyleType = {
455
455
  7: 'plusStyle',
456
456
  8: 'fansStyle',
457
457
  9: 'samStyle',
458
458
  10: 'studentStyle',
459
459
  12: 'yhdStyle',
460
460
  13: 'memberStyle',
461
461
  };
462
462
  const isUseFinalPriceAsBigPrice = allowedNoHitUserIdentityTypes.includes(priceType);
463
463
  const isEquivalentHit = isUseFinalPriceAsBigPrice || hitUserIdentity;
464
464
  const isOnlyShowBigPrice = priceType === 3 || isNull(finalPrice);
465
465
  const smallPrice = isEquivalentHit ? jdPrice : finalPrice;
466
466
  const isHideSmallPrice =
467
467
  priceType === 14 || isDefaultRemoveSmallPrice || isNaN(Number(smallPrice));
468
468
  const isTextPrice = priceType === 4;
469
469
  if (!isTextPrice && !useBackstop) {
470
470
  if (finalPrice && !numericPriceValidate(finalPrice, props)) {
471
471
  useBackstop = true;
472
472
  } else if (!numericPriceValidate(jdPrice, props)) {
473
473
  useBackstop = true;
474
474
  }
475
475
  if (!useBackstop && !isOnlyShowBigPrice && !isHideSmallPrice && !pricesCompareValidate(props)) {
476
476
  useBackstop = true;
477
477
  }
478
478
  }
479
479
  const bigPriceObj =
480
480
  isTextPrice || useBackstop
481
481
  ? {}
482
482
  : getDeconstructPrice(isEquivalentHit && !isNull(finalPrice) ? finalPrice : jdPrice, props);
483
483
  const { integerPrice = '', decimalPrice = '' } = bigPriceObj || {};
484
484
  const isPriceDescInFront = isEquivalentHit;
485
485
  const hitColorStyle = isEquivalentHit ? styles[especialHitStyleType[priceType]] : null;
486
486
  const missColorStyle = isEquivalentHit ? null : styles[especialMissStyleType[priceType]];
487
487
  const isBigPriceHasDecimal = decimalPrice !== '' && !/^0+$/.test(decimalPrice);
488
488
  const sizeLineHeight = {
489
489
  XS: 28,
490
490
  S: 34,
491
491
  M: 40,
492
492
  L: 46,
493
493
  XL: 52,
494
494
  };
495
495
  const lineHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25);
496
496
  const wrapHeight = Taro.pxTransform(sizeLineHeight[size] * 1.25 * lineNumber);
497
497
  const computedHeightStyle = {
498
498
  height: wrapHeight,
499
499
  };
500
500
  const itemCommonStyle = {
501
501
  height: lineHeight,
502
502
  };
503
503
  const needSizeStyles = [
504
504
  'bigNoPrice',
505
505
  'bigSymbol',
506
506
  'bigInteger',
507
507
  'bigDecimal',
508
508
  'priceDesc',
509
509
  'smallPrice',
510
510
  ];
511
511
  const sizeStyles = needSizeStyles.reduce((acc, cur) => {
512
512
  acc[cur] = styles[cur + size];
513
513
  return acc;
514
514
  }, {});
515
515
  const finalFallbackText = !isLanguageForEn ? '暂无报价' : 'Unpriced';
516
516
  const noPriceShowText =
517
517
  priceText || (/^[\u4e00-\u9fa5]+$/.test(jdPrice) ? jdPrice : finalFallbackText);
518
518
  if (useBackstop && fallbackRender) {
519
519
  return fallbackRender;
520
520
  }
521
521
  return (
522
522
  <View
523
523
  className={classNames(styles.wrap, className)}
524
524
  style={{ ...computedHeightStyle, ...style }}
525
525
  >
526
526
  {isTextPrice || useBackstop ? (
527
527
  <Text
528
528
  className={classNames(
529
529
  styles.childStyle,
530
530
  styles.bigStyle,
531
531
  styles.bigNoPrice,
532
532
  sizeStyles['bigNoPrice'],
533
533
  childrenClassName,
534
534
  bigNoPriceClassName,
535
535
  )}
536
536
  style={{ ...itemCommonStyle }}
537
537
  >
538
538
  {useBackstop ? finalFallbackText : noPriceShowText}
539
539
  </Text>
540
540
  ) : (
541
541
  [
542
542
  <Text
543
543
  className={classNames(
544
544
  styles.childStyle,
545
545
  styles.bigStyle,
546
546
  styles.bigSymbol,
547
547
  sizeStyles['bigSymbol'],
548
548
  hitColorStyle,
549
549
  childrenClassName,
550
550
  bigSymbolClassName,
551
551
  {
552
552
  [styles.fontV2]: useFontV2,
553
553
  [styles.fontV2Bold]: useFontV2Bold,
554
554
  },
555
555
  )}
556
556
  key="bigSymbol"
557
557
  style={{ ...itemCommonStyle }}
558
558
  >
559
559
  ¥
560
560
  </Text>,
561
561
  <Text
562
562
  className={classNames(
563
563
  styles.childStyle,
564
564
  styles.bigStyle,
565
565
  styles.bigInteger,
566
566
  sizeStyles['bigInteger'],
567
567
  hitColorStyle,
568
568
  !isOnlyShowBigPrice && !isBigPriceHasDecimal && !isPriceDescInFront
569
569
  ? styles.rightMargin
570
570
  : null,
571
571
  childrenClassName,
572
572
  bigIntegerClassName,
573
573
  {
574
574
  [styles.fontV2]: useFontV2,
575
575
  [styles.fontV2Bold]: useFontV2Bold,
576
576
  },
577
577
  )}
578
578
  key="bigInteger"
579
579
  style={{ ...itemCommonStyle }}
580
580
  >
581
581
  {integerPrice}
582
582
  </Text>,
583
583
  isBigPriceHasDecimal ? (
584
584
  <Text
585
585
  className={classNames(
586
586
  styles.childStyle,
587
587
  styles.bigStyle,
588
588
  styles.bigDecimal,
589
589
  sizeStyles['bigDecimal'],
590
590
  hitColorStyle,
591
591
  isPriceDescInFront ? null : styles.rightMargin,
592
592
  childrenClassName,
593
593
  bigDecimalClassName,
594
594
  {
595
595
  [styles.fontV2]: useFontV2,
596
596
  [styles.fontV2Bold]: useFontV2Bold,
597
597
  },
598
598
  )}
599
599
  key="bigDecimal"
600
600
  style={{ ...itemCommonStyle }}
601
601
  >
602
602
  .{decimalPrice}
603
603
  </Text>
604
604
  ) : null,
605
605
  !isOnlyShowBigPrice && [
606
606
  isPriceDescInFront && (
607
607
  <Text
608
608
  className={classNames(
609
609
  styles.childStyle,
610
610
  styles.priceDesc,
611
611
  {
612
612
  [styles['priceEnDesc']]: isLanguageForEn,
613
613
  },
614
614
  {
615
615
  [styles['priceHiddenDesc']]: priceText === '',
616
616
  },
617
617
  sizeStyles['priceDesc'],
618
618
  styles.bigStyle,
619
619
  hitColorStyle,
620
620
  isPriceDescInFront ? styles.rightMargin : null,
621
621
  childrenClassName,
622
622
  priceDescClassName,
623
623
  )}
624
624
  key="descFront"
625
625
  style={{ ...itemCommonStyle }}
626
626
  >
627
627
  {priceText === '' ? '_' : priceText}
628
628
  </Text>
629
629
  ),
630
630
  <View
631
631
  style={{
632
632
  display: 'inline-flex',
633
633
  }}
634
634
  >
635
635
  {smallPrice && !isHideSmallPrice ? (
636
636
  <Text
637
637
  className={classNames(
638
638
  styles.childStyle,
639
639
  styles.smallPrice,
640
640
  sizeStyles['smallPrice'],
641
641
  styles.smallStyle,
642
642
  missColorStyle,
643
643
  childrenClassName,
644
644
  smallPriceClassName,
645
645
  {
646
646
  [styles.fontV2]: useFontV2,
647
647
  [styles.fontV2Bold]: useFontV2Bold,
648
648
  },
649
649
  )}
650
650
  key="smallPrice"
651
651
  style={{ ...itemCommonStyle }}
652
652
  >
653
653
  ¥{Number(smallPrice)}
654
654
  </Text>
655
655
  ) : null}
656
656
  {!isPriceDescInFront && !isHideSmallPrice && (
657
657
  <Text
658
658
  className={classNames(
659
659
  styles.childStyle,
660
660
  styles.priceDesc,
661
661
  {
662
662
  [styles['priceEnDesc']]: isLanguageForEn,
663
663
  },
664
664
  {
665
665
  [styles['priceHiddenDesc']]: priceText === '',
666
666
  },
667
667
  sizeStyles['priceDesc'],
668
668
  styles.smallStyle,
669
669
  styles.missPriceDesc,
670
670
  missColorStyle,
671
671
  childrenClassName,
672
672
  priceDescClassName,
673
673
  )}
674
674
  key="descBack"
675
675
  style={{ ...itemCommonStyle }}
676
676
  >
677
677
  {priceText === '' ? '_' : priceText}
678
678
  </Text>
679
679
  )}
680
680
  </View>,
681
681
  ],
682
682
  ]
683
683
  )}
684
684
  </View>
685
685
  );
@@ -6,7 +6,7 @@
6
6
  left: 0;
7
7
  right: 0;
8
8
  bottom: 0;
9
- z-index: 50;
9
+ z-index: 9999;
10
10
 
11
11
  .debug-layout {
12
12
  position: absolute;
@@ -58,7 +58,7 @@
58
58
  .d-info {
59
59
  position: relative;
60
60
  cursor: pointer;
61
- z-index: 3;
61
+ z-index: 9999;
62
62
  margin: 3PX 3PX;
63
63
  width: 22PX;
64
64
  height: 22PX;