@conecli/cone-render 0.10.1-shop3.4 → 0.10.1-shop3.6

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 (36) hide show
  1. package/dist/common/const.ts +1 -1
  2. package/dist/common/index.h5.ts +1 -1
  3. package/dist/common/index.jd.ts +1 -1
  4. package/dist/common/index.ts +1 -1
  5. package/dist/common/index.weapp.ts +1 -1
  6. package/dist/components/base/CommonFloorHead/index.module.scss +126 -111
  7. package/dist/components/base/CommonFloorHead/index.tsx +1 -1
  8. package/dist/components/base/CustomScrollView/index-back.tsx +1 -0
  9. package/dist/components/base/CustomScrollView/index.tsx +1 -1
  10. package/dist/components/base/Dialog/index.module.scss +11 -0
  11. package/dist/components/base/InViewRender/index.tsx +1 -1
  12. package/dist/components/floorItem.weapp.tsx +1 -1
  13. package/dist/interface/common.ts +1 -1
  14. package/dist/jumpEventReport/const.ts +1 -1
  15. package/dist/jumpEventReport/jdJumpJdApp.ts +1 -1
  16. package/dist/jumpEventReport/web.jd.ts +1 -1
  17. package/dist/libs/taroAppReport.js +2 -2
  18. package/dist/modules/ContainerFloorList/index.h5.module.scss +66 -56
  19. package/dist/modules/ContainerFloorList/index.h5.tsx +1 -1
  20. package/dist/modules/ContainerFloorList/index.tsx +1 -1
  21. package/dist/open/api/shopMember.ts +1 -1
  22. package/dist/sass/app.h5.scss +252 -224
  23. package/dist/service/fetchGateway.ts +1 -1
  24. package/dist/service/fetchGateway.weapp.ts +1 -0
  25. package/dist/service/http/colorSign.ts +1 -1
  26. package/dist/service/http/const.ts +1 -1
  27. package/dist/service/http/h5Http.ts +1 -1
  28. package/dist/service/requestServer.h5.ts +1 -1
  29. package/dist/service/requestServer.ts +1 -1
  30. package/dist/utils/h5Utils.ts +1 -1
  31. package/dist/utils/index.h5.ts +1 -1
  32. package/dist/utils/index.ts +1 -1
  33. package/dist/utils/index.weapp.ts +1 -1
  34. package/dist/utils/jumpExtMapUtil.js +1 -0
  35. package/dist/utils/utils.ts +1 -1
  36. package/package.json +1 -1
@@ -1 +1 @@
1
- import Taro from '@tarojs/taro';
2
1
  SHOP_MENU_ID_TYPE,
3
2
  SHOP_MENU_ID_QUERY_NAME,
4
3
  SECTION_HOME_TAB_TYPE,
5
4
  SECTION_HOME_TAB_NAME_TYPE,
6
5
  SECTION_HOME_TAB_QUERY_TYPE,
7
6
  CHANNEL_TYPE,
8
7
  JDShopViewBusinessPathType,
9
8
  FloorModuleType,
10
9
  RemoteLoadFloorList,
11
10
  FLOOR_KIND,
12
11
  getBundleUrl,
13
12
  getBundleFileName,
14
13
  formatPackResult,
15
14
  getTaroVersion,
16
15
  key: string,
17
16
  value: string | object,
18
17
  successBack?: any,
19
18
  failBack?: any,
20
19
  try{
21
20
  if(isH5 && window && !window.localStorage){
22
21
  console.log(`setTaroStorage key:${key} window.localStorage不存在:`);
23
22
  return Promise.resolve(null);
24
23
  }
25
24
  return Taro.setStorage({
26
25
  key: key,
27
26
  data: value,
28
27
  success: successBack,
29
28
  fail: failBack,
30
29
  }).catch((e) => {
31
30
  console.log(`setTaroStorage key:${key} 报错:`, e);
32
31
  return null;
33
32
  });
34
33
  }
35
34
  catch(e){
36
35
  console.log(`setTaroStorage key:${key} 报错:`, e)
37
36
  return Promise.resolve(null)
38
37
  }
39
38
  try {
40
39
  if (isH5 && window && !window.localStorage) {
41
40
  console.log(`getTaroStorageKeyValue key:${key} window.localStorage不存在:`);
42
41
  return Promise.resolve(null);
43
42
  }
44
43
  return Taro.getStorageSync(key);
45
44
  } catch (e) {
46
45
  console.log(`getTaroStorageKeyValue key:${key} 报错:`, e);
47
46
  return null;
48
47
  }
49
48
  try {
50
49
  if (isH5 && window && !window.localStorage) {
51
50
  console.log(`removeTaroStorageKey key:${key} window.localStorage不存在:`);
52
51
  return Promise.resolve(null);
53
52
  }
54
53
  return Taro.removeStorage({
55
54
  key: key,
56
55
  }).catch((e) => {
57
56
  console.log(`removeTaroStorageKey key:${key} 报错:`, e);
58
57
  });
59
58
  } catch (e) {
60
59
  console.log(`removeTaroStorageKey key:${key} 报错:`, e);
61
60
  }
62
61
  try {
63
62
  if (isH5 && window && !window.localStorage) {
64
63
  console.log(`clearTaroStorageKey window.localStorage不存在`);
65
64
  return Promise.resolve(null);
66
65
  }
67
66
  return Taro.clearStorage().catch((e) => {
68
67
  console.log('clearTaroStorageKey报错:', e);
69
68
  });
70
69
  } catch (e) {
71
70
  console.log('clearTaroStorageKey报错:', e);
72
71
  }
73
72
  let hasChecked = false;
74
73
  if (isH5) {
75
74
  const avifCache = getTaroStorageKeyValue(KEY_AVIF);
76
75
  if (avifCache === null || avifCache === '' || forceUpdate) {
77
76
  hasChecked = true;
78
77
  const img = new Image();
79
78
  img.onload = function () {
80
79
  if (img.height > 0 && img.width > 0) {
81
80
  setTaroStorage(KEY_AVIF, '1');
82
81
  } else {
83
82
  setTaroStorage(KEY_AVIF, '0');
84
83
  }
85
84
  };
86
85
  img.onerror = () => {
87
86
  setTaroStorage(KEY_AVIF, '0');
88
87
  };
89
88
  img.src =
90
89
  '';
91
90
  }
92
91
  const webpCache = getTaroStorageKeyValue(KEY_WEBP);
93
92
  if (webpCache === null || webpCache === '' || forceUpdate) {
94
93
  hasChecked = true;
95
94
  const img = new Image();
96
95
  img.onload = function () {
97
96
  if (img.height > 0 && img.width > 0) {
98
97
  setTaroStorage(KEY_WEBP, '1');
99
98
  } else {
100
99
  setTaroStorage(KEY_WEBP, '0');
101
100
  }
102
101
  };
103
102
  img.onerror = () => {
104
103
  setTaroStorage(KEY_WEBP, '0');
105
104
  };
106
105
  img.src =
107
106
  '';
108
107
  }
109
108
  }
110
109
  return hasChecked;
111
110
  const hasChecked = imageFormatSupport(false);
112
111
  if (!hasChecked) {
113
112
  setTimeout(imageFormatSupport, 5000);
114
113
  }
115
114
  const resultList: Array<any> = [],
116
115
  arrLen = arr.length;
117
116
  if (arrLen) {
118
117
  if (arrLen > size) {
119
118
  for (let i = 0; i < arrLen; i = i + size) {
120
119
  resultList.push(arr.slice(i, i + size));
121
120
  }
122
121
  } else {
123
122
  resultList.push(arr);
124
123
  }
125
124
  }
126
125
  return resultList;
127
126
  let _address = ids;
128
127
  const _areaAreaSplit = ids.split('.');
129
128
  const _areaAreaSplit2 = ids.split('_');
130
129
  _address = _areaAreaSplit.length === 2 ? _areaAreaSplit[0] : _address;
131
130
  _address = _areaAreaSplit2.length === 3 ? `${_areaAreaSplit2}_0` : _address;
132
131
  return _address;
133
132
  let paramStr = '';
134
133
  obj &&
135
134
  Object.keys(obj).forEach((key, index) => {
136
135
  const getValue = `${obj[key]}`.replace(/undefined/, '').replace(/null/, '');
137
136
  paramStr += `${index === 0 ? '' : '&'}${key}=${encodeURIComponent(getValue)}`;
138
137
  });
139
138
  return paramStr;
140
139
  const result = {};
141
140
  if (
142
141
  !urlOrQueryStr ||
143
142
  ('string' !== typeof urlOrQueryStr && String !== urlOrQueryStr.constructor)
144
143
  ) {
145
144
  return result;
146
145
  }
147
146
  if (urlOrQueryStr.indexOf('?') > -1) {
148
147
  const queryStr = urlOrQueryStr.split('?');
149
148
  const queryItemList = queryStr && queryStr.length > 1 ? queryStr[1].split('&') : [];
150
149
  const queryItemListLen = queryItemList.length;
151
150
  queryItemListLen > 0 &&
152
151
  queryItemList.forEach((item) => {
153
152
  const thisItemList = item.split('=');
154
153
  result[thisItemList[0]] = thisItemList[1];
155
154
  });
156
155
  } else {
157
156
  const queryItemList =
158
157
  urlOrQueryStr.indexOf('&') > -1 ? urlOrQueryStr.split('&') : [urlOrQueryStr];
159
158
  const queryItemListLen = queryItemList.length;
160
159
  queryItemListLen > 0 &&
161
160
  queryItemList.forEach((item) => {
162
161
  const thisItemList = item.split('=');
163
162
  result[thisItemList[0]] = thisItemList[1];
164
163
  });
165
164
  }
166
165
  return result;
167
166
  url: string,
168
167
  size?: {
169
168
  w: number;
170
169
  h: number;
171
170
  },
172
171
  quality?: number,
173
172
  if (url && size) {
174
173
  const _w = Math.floor(size.w);
175
174
  const _h = Math.floor(size.h);
176
175
  if (url.match(/gif$/i)) {
177
176
  return url;
178
177
  } else {
179
178
  if (_w > 0 && _h > 0) {
180
179
  url = url.replace('jfs/', `s${_w}x${_h}_jfs/`);
181
180
  }
182
181
  url += quality != null ? `!q${quality}.dpg` : '.dpg';
183
182
  }
184
183
  }
185
184
  return url;
186
185
  if (url.match(/\.(jpg|png|dpg)$/i)) {
187
186
  const { width, height, quality } = jfsImgInfo;
188
187
  if (typeof width === 'number' || typeof height === 'number') {
189
188
  url = url.replace('/jfs/', `/s${Math.floor(width || 0)}x${Math.floor(height || 0)}_jfs/`);
190
189
  }
191
190
  if (typeof quality === 'number' && quality > 0 && quality < 100 && url.match(/\.jpg$/i)) {
192
191
  url += `!q${quality}.dpg`;
193
192
  }
194
193
  }
195
194
  return addHttps(url);
196
195
  if (imgUrl) {
197
196
  if (
198
197
  !imgUrl.match(
199
198
  /(storage\.360buyimg\.com)|(jdcloud-oss\.com)|(imgcps\.jd\.com)|((\w+)\.300hu\.com)|(thirdwx\.qlogo\.cn)|(!q)|gif|dpg$/i,
200
199
  )
201
200
  ) {
202
201
  if (!imgUrl.includes('360buyimg.com')) {
203
202
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
204
203
  }
205
204
  if (quality != 100) imgUrl += /\.png/.test(imgUrl) ? '.dpg' : `!q${quality}`;
206
205
  }
207
206
  imgUrl = imgUrl.match(/^\/\//) ? `https:${imgUrl}` : imgUrl;
208
207
  }
209
208
  return imgUrl;
210
209
  const result = value % step;
211
210
  return result === 0 ? value : Math.ceil(value / step) * step;
212
211
  const MAX = 3.5;
213
212
  return Math.min(window?.devicePixelRatio ?? 2, MAX);
214
213
  isSkuImage: boolean;
215
214
  size: number;
216
215
  imgUrl: string,
217
216
  options: QualityOptions,
218
217
  isIgnoreOptimizeFromServer: boolean = false,
219
218
  if (!imgUrl) {
220
219
  console.error('The input parameter imageUrl for the getQualityImage() cannot be empty!');
221
220
  return imgUrl;
222
221
  }
223
222
  if (isIgnoreOptimizeFromServer) {
224
223
  imgUrl = imgUrl.replace(/\.(jpe?g|png).*/, '.$1');
225
224
  }
226
225
  if (!/^((https?):)?\/\//.test(imgUrl)) {
227
226
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
228
227
  }
229
228
  const imgServerRegExp = /(img|m)\d{0,2}\.360buyimg\.com\/.*\.(jpe?g|png)/i;
230
229
  if (!imgServerRegExp.test(imgUrl)) {
231
230
  return imgUrl;
232
231
  }
233
232
  imgUrl = /^\/\//.test(imgUrl) ? `https:${imgUrl}` : imgUrl;
234
233
  const { isSkuImage, size } = options || {};
235
234
  const needReduceSize = isSkuImage && size;
236
235
  if (needReduceSize) {
237
236
  const devicePixelRatio = getDevicePixelRatio();
238
237
  const useWidth = getValueByStep(size * devicePixelRatio, 40);
239
238
  imgUrl = imgUrl.replace(/\/[^\/]*jfs\//, `/s${useWidth}x${useWidth}_jfs/`);
240
239
  }
241
240
  const needCompress = !global?.info?.pageInfo?.isVipShop;
242
241
  const result = imgUrl.match(/\/\w+\.(jpe?g|png)$/);
243
242
  if (needCompress && result) {
244
243
  if (getAvifSupport() === '1') {
245
244
  imgUrl += '.avif';
246
245
  } else if (getWebpSupport() === '1') {
247
246
  imgUrl += '.webp';
248
247
  } else if (/jpe?g/.test(result[1])) {
249
248
  imgUrl += '!q80';
250
249
  }
251
250
  }
252
251
  if (needReduceSize) {
253
252
  imgUrl += '!z2';
254
253
  }
255
254
  return imgUrl;
256
255
  if (imgUrl) {
257
256
  if (
258
257
  !imgUrl.match(
259
258
  /(storage\.360buyimg\.com)|(jdcloud-oss\.com)|((\w+)\.300hu\.com)|(thirdwx\.qlogo\.cn)|(!q)|gif|dpg$/i,
260
259
  )
261
260
  ) {
262
261
  if (!imgUrl.includes('360buyimg.com')) {
263
262
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
264
263
  }
265
264
  if (quality != 100) imgUrl += /\.png/.test(imgUrl) ? '.dpg' : `!q${quality}`;
266
265
  }
267
266
  imgUrl = imgUrl.match(/^\/\//) ? `https:${imgUrl}` : imgUrl;
268
267
  }
269
268
  return imgUrl;
270
269
  return getTaroStorageKeyValue(KEY_AVIF) || '0';
271
270
  return getTaroStorageKeyValue(KEY_WEBP) || '0';
272
271
  count: number,
273
272
  fixedNum = 1,
274
273
  unit = '万',
275
274
  maxNum = 10000,
276
275
  count = Number(count);
277
276
  const getMaxNum = count > 100000000 ? 100000000 : maxNum;
278
277
  const getUnit = count > 100000000 ? '亿' : unit;
279
278
  if (count >= getMaxNum) {
280
279
  return (count / getMaxNum).toFixed(fixedNum) + getUnit;
281
280
  }
282
281
  return count;
283
282
  const systemInfo: UtilsInterFace.taroGetSystemInfoSyncRes = getSystemInfo || {
284
283
  platform: '',
285
284
  model: '',
286
285
  system: '',
287
286
  };
288
287
  const isIOS = !!systemInfo.system.match(/ios/i);
289
288
  const isAndroid = !!systemInfo.system.match(/android/i);
290
289
  if (!systemInfo.statusBarHeight) {
291
290
  systemInfo.statusBarHeight = screenHeight - windowHeight - 20;
292
291
  systemInfo.navBarExtendHeight = 0;
293
292
  } else {
294
293
  if (isIOS) {
295
294
  systemInfo.navBarExtendHeight = 4;
296
295
  } else {
297
296
  systemInfo.navBarExtendHeight = 0;
298
297
  }
299
298
  }
300
299
  let rect = Taro.getMenuButtonBoundingClientRect ? Taro.getMenuButtonBoundingClientRect() : null;
301
300
  if (!rect || !rect.width || !rect.top || !rect.left || !rect.height) {
302
301
  let gap = 0;
303
302
  let width = 96;
304
303
  if (systemInfo.platform === 'android') {
305
304
  gap = 8;
306
305
  width = 96;
307
306
  } else if (systemInfo.platform === 'devtools') {
308
307
  if (isIOS) {
309
308
  gap = 5.5;
310
309
  } else {
311
310
  gap = 7.5;
312
311
  }
313
312
  } else {
314
313
  gap = 4;
315
314
  width = 88;
316
315
  }
317
316
  rect = {
318
317
  bottom: systemInfo.statusBarHeight + gap + 32,
319
318
  height: 32,
320
319
  left: systemInfo.windowWidth - width - 10,
321
320
  right: systemInfo.windowWidth - 10,
322
321
  top: systemInfo.statusBarHeight + gap,
323
322
  width,
324
323
  };
325
324
  }
326
325
  const gap = rect.top - systemInfo.statusBarHeight;
327
326
  systemInfo.navBarTopToStatusBar = gap;
328
327
  systemInfo.navBarHeight = 2 * gap + rect.height;
329
328
  systemInfo.capsulePosition = rect;
330
329
  systemInfo.isIOS = isIOS;
331
330
  systemInfo.isAndroid = isAndroid;
332
331
  return systemInfo;
333
332
  if (str.match(/^\/\//)) {
334
333
  str = 'https:' + str;
335
334
  }
336
335
  return str;
337
336
  dateTimeOrdate: Date | string | number | null,
338
337
  format = 'yyyy-MM-dd HH:mm:ss',
339
338
  noPadStart = {
340
339
  M: '0',
341
340
  d: '0',
342
341
  H: '0',
343
342
  m: '0',
344
343
  s: '0',
345
344
  },
346
345
  let dateResult = '';
347
346
  const padStarts = Object.assign(
348
347
  {
349
348
  M: '0',
350
349
  d: '0',
351
350
  H: '0',
352
351
  m: '0',
353
352
  s: '0',
354
353
  },
355
354
  noPadStart,
356
355
  );
357
356
  if (dateTimeOrdate) {
358
357
  let changeDateTimeOrdate = dateTimeOrdate;
359
358
  const getChangeDateTimeToNumber = Number(changeDateTimeOrdate);
360
359
  if (getChangeDateTimeToNumber) {
361
360
  changeDateTimeOrdate = getChangeDateTimeToNumber;
362
361
  } else {
363
362
  changeDateTimeOrdate = `${changeDateTimeOrdate}`.replace(/-/g, '/').replace(/\./g, '/');
364
363
  }
365
364
  const nowDate =
366
365
  dateTimeOrdate instanceof Date ? dateTimeOrdate : new Date(changeDateTimeOrdate);
367
366
  const dateMap = {
368
367
  y: `${nowDate.getFullYear()}`,
369
368
  M: `${nowDate.getMonth() + 1}`.padStart(2, padStarts['M']),
370
369
  d: `${nowDate.getDate()}`.padStart(2, padStarts['d']),
371
370
  H: `${nowDate.getHours()}`.padStart(2, padStarts['H']),
372
371
  m: `${nowDate.getMinutes()}`.padStart(2, padStarts['m']),
373
372
  s: `${nowDate.getSeconds()}`.padStart(2, padStarts['s']),
374
373
  };
375
374
  const regDate = new RegExp('y+|M+|d+|H+|m+|s+', 'g');
376
375
  const regYear = new RegExp('y');
377
376
  dateResult = format.replace(regDate, (v) => {
378
377
  let changeValue = v;
379
378
  if (regYear.test(changeValue)) {
380
379
  const thisYear = dateMap.y;
381
380
  const subValueLen = 4 - changeValue.length;
382
381
  changeValue = thisYear.substr(subValueLen);
383
382
  } else {
384
383
  const dateKey = v.substr(0, 1);
385
384
  changeValue = dateMap[dateKey];
386
385
  }
387
386
  return changeValue;
388
387
  });
389
388
  }
390
389
  return dateResult;
391
390
  let timer: any = null;
392
391
  let startTime = Date.now();
393
392
  return function () {
394
393
  const curTime = Date.now();
395
394
  const remaining = delay - (curTime - startTime);
396
395
  const context = this;
397
396
  const args = arguments;
398
397
  clearTimeout(timer);
399
398
  if (remaining <= 0) {
400
399
  func.apply(context, args);
401
400
  startTime = Date.now();
402
401
  } else {
403
402
  timer = setTimeout(func, remaining);
404
403
  }
405
404
  };
406
405
  let context, args, result;
407
406
  let timeout = null;
408
407
  let previous = 0;
409
408
  if (!options) options = {};
410
409
  const later = function () {
411
410
  previous = options.leading === false ? 0 : Date.now();
412
411
  timeout = null;
413
412
  result = func.apply(context, args);
414
413
  if (!timeout) context = args = null;
415
414
  };
416
415
  return function () {
417
416
  const now = Date.now();
418
417
  if (!previous && options.leading === false) previous = now;
419
418
  const remaining = wait - (now - previous);
420
419
  context = this;
421
420
  args = arguments;
422
421
  if (remaining <= 0 || remaining > wait) {
423
422
  if (timeout) {
424
423
  clearTimeout(timeout);
425
424
  timeout = null;
426
425
  }
427
426
  previous = now;
428
427
  result = func.apply(context, args);
429
428
  if (!timeout) context = args = null;
430
429
  } else if (!timeout && options.trailing !== false) {
431
430
  timeout = setTimeout(later, remaining);
432
431
  }
433
432
  return result;
434
433
  };
435
434
  let timer: any = null;
436
435
  return function () {
437
436
  const context: any = this;
438
437
  const args = arguments;
439
438
  timer && clearTimeout(timer);
440
439
  timer = setTimeout(function () {
441
440
  fn.apply(context, args);
442
441
  }, delay);
443
442
  };
444
443
  if (txt) {
445
444
  txt = txt.trim();
446
445
  const reg = new RegExp(/[\d-]+/);
447
446
  const res = reg.exec(txt);
448
447
  if (res && res.length > 0) {
449
448
  let tel = res[0];
450
449
  if (tel && delSeparator) {
451
450
  tel = tel.replace(/-/g, '');
452
451
  }
453
452
  return tel;
454
453
  }
455
454
  }
456
455
  return '';
457
456
  if (rgb) {
458
457
  const reg = /^(rgb|RGB)/;
459
458
  const color = rgb;
460
459
  if (reg.test(color)) {
461
460
  let strHex = '#';
462
461
  const colorArr = color.replace(/(?:\(|\)|rgb|RGB)*/g, '').split(',');
463
462
  for (let i = 0; i < colorArr.length; i++) {
464
463
  let hex = Number(colorArr[i]).toString(16);
465
464
  if (hex === '0') {
466
465
  hex += hex;
467
466
  }
468
467
  strHex += hex;
469
468
  }
470
469
  return strHex;
471
470
  } else {
472
471
  return String(color);
473
472
  }
474
473
  } else {
475
474
  return '';
476
475
  }
477
476
  if (hex) {
478
477
  const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
479
478
  let color = hex.toLowerCase();
480
479
  if (reg.test(color)) {
481
480
  if (color.length === 4) {
482
481
  let colorNew = '#';
483
482
  for (let i = 1; i < 4; i += 1) {
484
483
  colorNew += color.slice(i, i + 1).concat(color.slice(i, i + 1));
485
484
  }
486
485
  color = colorNew;
487
486
  }
488
487
  const colorChange: number[] = [];
489
488
  for (let i = 1; i < 7; i += 2) {
490
489
  colorChange.push(parseInt('0x' + color.slice(i, i + 2)));
491
490
  }
492
491
  if (returnList) {
493
492
  return colorChange;
494
493
  } else {
495
494
  return 'RGB(' + colorChange.join(',') + ')';
496
495
  }
497
496
  } else {
498
497
  return color;
499
498
  }
500
499
  } else {
501
500
  return '';
502
501
  }
503
502
  const c = m - n + 1;
504
503
  const res = Math.floor(Math.random() * c + n);
505
504
  if (filterNum && filterNum == res) {
506
505
  console.log('随机数二次开始', res, filterNum);
507
506
  return getRandom(n, m, filterNum);
508
507
  } else {
509
508
  return res;
510
509
  }
511
510
  wqCookieStr: string;
512
511
  wqCookie: {
513
512
  pin?: string;
514
513
  visitkey?: string;
515
514
  [key: string]: any;
516
515
  };
517
516
  const {
518
517
  jdpin,
519
518
  pinStatus,
520
519
  visitkey,
521
520
  unionid,
522
521
  skey,
523
522
  __jda,
524
523
  __jdv,
525
524
  __wga,
526
525
  wid,
527
526
  wq_skey,
528
527
  wq_uin,
529
528
  wq_auth_token,
530
529
  wxapp_scene,
531
530
  wq_unionid,
532
531
  wxapp_openid,
533
532
  wxapp_version,
534
533
  wxapp_type,
535
534
  appType,
536
535
  } = cookie;
537
536
  const ret: string[] = [];
538
537
  const getUserCookieObj = {};
539
538
  const createUseCookieArr = [
540
539
  jdpin,
541
540
  pinStatus,
542
541
  visitkey,
543
542
  unionid,
544
543
  skey,
545
544
  __jda,
546
545
  __jdv,
547
546
  __wga,
548
547
  wid,
549
548
  wq_skey,
550
549
  wq_uin,
551
550
  wq_auth_token,
552
551
  wxapp_scene,
553
552
  wq_unionid,
554
553
  wxapp_openid,
555
554
  wxapp_version,
556
555
  wxapp_type,
557
556
  appType,
558
557
  ];
559
558
  createUseCookieArr.forEach((keyItem) => {
560
559
  if (keyItem && keyItem['name']) {
561
560
  let { name, value } = keyItem;
562
561
  name = name === 'jdpin' ? 'pin' : name;
563
562
  name === 'pin' && ret.push(`pt_pin=${encodeURIComponent(value)}`);
564
563
  ret.push(`${name}=${encodeURIComponent(value)}`);
565
564
  getUserCookieObj[name] = value;
566
565
  }
567
566
  });
568
567
  return {
569
568
  wqCookieStr: ret.join(';'),
570
569
  wqCookie: getUserCookieObj,
571
570
  };
572
571
  const getNum = Number(num);
573
572
  return Math.round((getNum / widthSize) * layoutWidth);
574
573
  let checkState = false;
575
574
  const couponFloorModuleType = floorData?.floorExtInfo?.moduleFlag;
576
575
  if (couponFloorModuleType === FloorModuleType.COUPON) {
577
576
  try {
578
577
  const dataDefines = getFloorDataToDataDefines(floorData);
579
578
  const couponDataDefine = dataDefines
580
579
  ? dataDefines.filter((item) => {
581
580
  return item.type === 'coupon';
582
581
  })
583
582
  : [],
584
583
  couponList = couponDataDefine[0]?.nodeText?.data ? couponDataDefine[0]?.nodeText?.data : [],
585
584
  couponLength = couponList.length,
586
585
  numShowPerLine = couponDataDefine[0]?.nodeText?.numShowPerLine
587
586
  ? couponDataDefine[0]?.nodeText?.numShowPerLine
588
587
  : 0;
589
588
  if (numShowPerLine === 0 && couponLength > 3) {
590
589
  checkState = true;
591
590
  }
592
591
  } catch (e) {
593
592
  checkState = false;
594
593
  }
595
594
  return checkState;
596
595
  }
597
596
  const {
598
597
  containers = [],
599
598
  floors = [],
600
599
  clearFirstContaierMarginTop = false,
601
600
  } = pageData;
602
601
  console.log('dealShopContentData:', pageData, 'isvdev:', isvdev);
603
602
  const getThisTimeKey = Date.now();
604
603
  let shopContentContainerListData = containers?.filter(
605
604
  (item) => (!isvdev && item.typeCode !== 'mShopHeader') || isvdev,
606
605
  );
607
606
  const shopContentFloorListData = floors?.filter(
608
607
  ({ floorPosition }) =>
609
608
  (!isvdev && floorPosition !== 'header' && floorPosition !== 'footer') || isvdev,
610
609
  );
611
610
  const unableIsvContainerListData = getUnableIsvContainerListData(
612
611
  shopContentFloorListData,
613
612
  shopContentContainerListData,
614
613
  exceptionReportFn,
615
614
  );
616
615
  shopContentContainerListData.forEach((item, index) => {
617
616
  item.key = `${getThisTimeKey + index}`;
618
617
  item.floors = [];
619
618
  item.includeUids &&
620
619
  item.includeUids.forEach((floorUid) => {
621
620
  const getFloorData = shopContentFloorListData.find(
622
621
  (floorItem) => floorItem.uid === floorUid,
623
622
  );
624
623
  if (getFloorData) {
625
624
  const changeFloorData = {
626
625
  containerId: item.containerId,
627
626
  containerIndex: index,
628
627
  ...getFloorData,
629
628
  };
630
629
  const getCheckMoreCouponState = checkCouponAndChangeContainerSetData(getFloorData);
631
630
  if (getCheckMoreCouponState) {
632
631
  item.marginLeft && (item.marginLeft = 0);
633
632
  item.marginRight && (item.marginRight = 0);
634
633
  item.borderRadius && (item.borderRadius = 0);
635
634
  }
636
635
  if (getFloorData?.floorExtInfo?.floorLoadWay === 2) {
637
636
  const getSysFloorToLoadTypeRes = isIsvFloorUseable(getFloorData, exceptionReportFn);
638
637
  !getSysFloorToLoadTypeRes && (getFloorData.floorExtInfo.floorLoadWay = 1);
639
638
  }
640
639
  item.floors.push(changeFloorData);
641
640
  }
642
641
  });
643
642
  if (
644
643
  ((!isvdev && index === 0) || (isvdev && index === 1)) &&
645
644
  item?.containerPosition == 'content' &&
646
645
  item?.marginBottom > 0 &&
647
646
  !clearFirstContaierMarginTop
648
647
  ) {
649
648
  item.marginTop = item.marginBottom;
650
649
  }
651
650
  });
652
651
  shopContentContainerListData = shopContentContainerListData.filter(
653
652
  (item) =>
654
653
  item.floors.length > 0 &&
655
654
  unableIsvContainerListData.every(
656
655
  (containerItem) => containerItem.containerId != item.containerId,
657
656
  ),
658
657
  );
659
658
  console.log(
660
659
  'dealShopContentData isWxMinAndWxapp:',
661
660
  isWxMinAndWxapp,
662
661
  'weappJumpToH5:',
663
662
  pageData?.homeExtInfo?.weappJumpToH5,
664
663
  );
665
664
  if (isProd && isWxMinAndWxapp) {
666
665
  shopContentContainerListData = shopContentContainerListData.filter(
667
666
  (item) =>
668
667
  item.floors.length > 0 &&
669
668
  !isIsvContainer(item.containerId, shopContentFloorListData, shopContentContainerListData),
670
669
  );
671
670
  }
672
671
  shopContentContainerListData = [].concat(shopContentContainerListData);
673
672
  return {
674
673
  shopContentContainerListData,
675
674
  shopContentFloorListData,
676
675
  };
677
676
  const changeOpts = {
678
677
  title: '',
679
678
  icon: 'success',
680
679
  duration: 1500,
681
680
  mask: true,
682
681
  ...options,
683
682
  };
684
683
  if (changeOpts.title.length > 7) {
685
684
  showNormalToast(options);
686
685
  } else {
687
686
  Taro.showToast(changeOpts as any);
688
687
  }
689
688
  const changeOpts = {
690
689
  title: '',
691
690
  icon: 'error',
692
691
  duration: 1500,
693
692
  mask: true,
694
693
  ...options,
695
694
  };
696
695
  if (changeOpts.title.length > 7) {
697
696
  showNormalToast(options);
698
697
  } else {
699
698
  Taro.showToast(changeOpts as any);
700
699
  }
701
700
  Taro.showToast({
702
701
  title: '',
703
702
  icon: 'none',
704
703
  duration: 1500,
705
704
  mask: true,
706
705
  ...options,
707
706
  });
708
707
  return Taro.showLoading({
709
708
  title: text,
710
709
  });
711
710
  return new Promise(() => {
712
711
  Taro.nextTick(() => {
713
712
  setTimeout(() => {
714
713
  Taro.hideLoading(options);
715
714
  }, 300);
716
715
  });
717
716
  });
718
717
  return CHANNEL_TYPE[JDShopViewBusinessPathType.HOME];
719
718
  const {
720
719
  tabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN],
721
720
  sceneId,
722
721
  } = query;
723
722
  let changeTabActive = tabActive;
724
723
  if (sceneId) {
725
724
  if (isH5) {
726
725
  if (sceneId == '1002') {
727
726
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PRODUCT];
728
727
  }
729
728
  else if (sceneId == '1003') {
730
729
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_ACTIVITY];
731
730
  }
732
731
  } else if (isWxMinAndWxapp) {
733
732
  if (sceneId == '1001' || sceneId == '1002') {
734
733
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PRODUCT];
735
734
  }
736
735
  else if (sceneId == '1003') {
737
736
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PROMOTION];
738
737
  }
739
738
  }
740
739
  }
741
740
  if (SECTION_HOME_TAB_QUERY_TYPE[changeTabActive]) {
742
741
  return {
743
742
  menuType: SHOP_MENU_ID_TYPE.HOME,
744
743
  tabActiveType: SECTION_HOME_TAB_QUERY_TYPE[changeTabActive],
745
744
  queryMenuTabActiveStr: `${SHOP_MENU_ID_TYPE.HOME}@${SECTION_HOME_TAB_QUERY_TYPE[changeTabActive]}`,
746
745
  };
747
746
  } else if (SHOP_MENU_ID_QUERY_NAME[changeTabActive]) {
748
747
  return {
749
748
  menuType: SHOP_MENU_ID_QUERY_NAME[changeTabActive],
750
749
  tabActiveType: 0,
751
750
  queryMenuTabActiveStr: `${SHOP_MENU_ID_QUERY_NAME[changeTabActive]}@0`,
752
751
  };
753
752
  } else {
754
753
  return {
755
754
  menuType: SHOP_MENU_ID_TYPE.HOME,
756
755
  tabActiveType: SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN,
757
756
  queryMenuTabActiveStr: `${SHOP_MENU_ID_TYPE.HOME}@${SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN}`,
758
757
  };
759
758
  }
760
759
  const deleteKeyList = [
761
760
  '$taroTimestamp',
762
761
  'cookie',
763
762
  'wdref',
764
763
  'navStart',
765
764
  'originOpts',
766
765
  'originParams',
767
766
  'originUrl',
768
767
  'referer',
769
768
  'stamp',
770
769
  'hybrid',
771
770
  'sr',
772
771
  'navh',
773
772
  'stath',
774
773
  ];
775
774
  let changeQueryData: any = { ...queryData };
776
775
  const qrCodeScene = changeQueryData?.scene ? changeQueryData?.scene : false;
777
776
  const sceneQuery =
778
777
  qrCodeScene && typeof qrCodeScene === 'string'
779
778
  ? parseQueryUrlString(decodeURIComponent(qrCodeScene))
780
779
  : {};
781
780
  changeQueryData = { ...changeQueryData, ...sceneQuery };
782
781
  deleteKeyList.forEach((key) => {
783
782
  changeQueryData[key] && delete changeQueryData[key];
784
783
  });
785
784
  changeQueryData['shopid'] &&
786
785
  (changeQueryData['shopId'] = changeQueryData['shopid']) &&
787
786
  delete changeQueryData['shopid'];
788
787
  changeQueryData['venderid'] &&
789
788
  (changeQueryData['venderId'] = changeQueryData['venderid']) &&
790
789
  delete changeQueryData['venderid'];
791
790
  changeQueryData['vendorId'] &&
792
791
  (changeQueryData['venderId'] = changeQueryData['vendorId']) &&
793
792
  delete changeQueryData['vendorId'];
794
793
  changeQueryData['shopId'] &&
795
794
  changeQueryData['shopId'] === 'undefined' &&
796
795
  delete changeQueryData['shopId'];
797
796
  changeQueryData['venderId'] &&
798
797
  changeQueryData['venderId'] === 'undefined' &&
799
798
  delete changeQueryData['venderId'];
800
799
  return changeQueryData;
801
800
  let isUsable = false;
802
801
  const modularPackResult = floorData?.floorExtInfo?.modularPackResult;
803
802
  const modularPackResultObj = formatPackResult(modularPackResult);
804
803
  const bundleUrl = getBundleUrl(modularPackResultObj);
805
804
  const bundleFileName = getBundleFileName(modularPackResultObj);
806
805
  const taroVersion = getTaroVersion(modularPackResultObj);
807
806
  if (bundleUrl && bundleFileName) {
808
807
  isUsable = true;
809
808
  }
810
809
  if (!isUsable && typeof exceptionReportFn === 'function') {
811
810
  exceptionReportFn({
812
811
  code: `${NO_ENVIRONMENT_AND_PAGE_TYPE_FLAG}${
813
812
  floorData?.floorExtInfo?.floorKind === FLOOR_KIND.PDC_SYSTEM_MODULE
814
813
  ? SgmCustomCode.SYSTEMPDCMODULE_DATA
815
814
  : SgmCustomCode.REMOTEMODULE_DATA
816
815
  }`,
817
816
  msg: {
818
817
  msg: `店铺h5楼层隐藏不显示。原因:模块数据不完备,楼层过滤。`,
819
818
  floorIdx: floorData?.floorIdx,
820
819
  uid: floorData?.uid,
821
820
  shopId: floorData?.floorExtInfo?.shopId,
822
821
  moduleId: floorData?.moduleId,
823
822
  moduleDesignerType: floorData?.floorExtInfo?.moduleDesignerType,
824
823
  floorLoadWay: floorData?.floorExtInfo?.floorLoadWay,
825
824
  floorKind: floorData?.floorExtInfo?.floorKind,
826
825
  middleTemplateId: floorData?.middleTemplateId,
827
826
  modularPackResult: {
828
827
  bundleUrl,
829
828
  taroVersion,
830
829
  },
831
830
  },
832
831
  });
833
832
  }
834
833
  return isUsable;
835
834
  const objContainer = containerListData.find((item) => item.containerId === containerId);
836
835
  return (
837
836
  objContainer?.includeUids?.some((itemUid) => {
838
837
  const objectFloor = floorListData.find((floorItem) => itemUid === floorItem.uid);
839
838
  return RemoteLoadFloorList.includes(objectFloor?.floorExtInfo?.moduleFlag);
840
839
  }) ?? false
841
840
  );
842
841
  const unableIsvFloorListData = floorListData.filter(
843
842
  (floorItem) =>
844
843
  RemoteLoadFloorList.includes(floorItem?.floorExtInfo?.moduleFlag) &&
845
844
  !isIsvFloorUseable(floorItem, exceptionReportFn),
846
845
  );
847
846
  const unableIsvFloorUidList = unableIsvFloorListData.map((floorItem) => floorItem.uid);
848
847
  const unableIsvContainerListData = containerListData.filter(
849
848
  (item) =>
850
849
  item.includeUids &&
851
850
  item.includeUids.every((itemUid) => unableIsvFloorUidList.indexOf(itemUid) != -1),
852
851
  );
853
852
  return unableIsvContainerListData;
854
853
  return -2;
855
854
  return customObj;
856
855
  return customObj;
857
856
  return customObj;
858
857
  return customObj;
859
858
  return customObj;
860
859
  return /openApp\.jdMobile:\/\/virtual\?params=/i.test(openAppUrl);
861
860
  let getParams = false;
862
861
  if (isOpenJdAppUrl(openAppUrl)) {
863
862
  try {
864
863
  getParams = openAppUrl.replace(/openApp\.jdMobile:\/\/virtual\?params=/i, '');
865
864
  getParams = JSON.parse(String(getParams));
866
865
  } catch (e) {
867
866
  console.log(e);
868
867
  }
869
868
  }
870
869
  return getParams;
871
870
  const getLastParams = Object.assign({}, openParams);
872
871
  return `openapp.jdmobile://virtual?params=${JSON.stringify(getLastParams)}`;
873
872
  if (val === null || val === '' || typeof val === 'undefined') {
874
873
  return true;
875
874
  }
876
875
  return false;
877
876
  const {
878
877
  moduleId = 'none',
879
878
  entrance = 'none',
880
879
  sourceType = 'none',
881
880
  sourceValue = 'none',
882
881
  } = params;
883
882
  if (isIosDevice) {
884
883
  return `${moduleId}#${entrance}`;
885
884
  } else if (isAndroidDevice) {
886
885
  return `${sourceType}#${sourceValue}`;
887
886
  }
888
887
  return 'none#none';
889
888
  if (data && typeof data === 'object') {
890
889
  let getOpenAppData = { ...data };
891
890
  try {
892
891
  const { sourceInfo, designerId, templateId, source } = getOpenAppData;
893
892
  if (designerId && templateId) {
894
893
  getOpenAppData = Object.assign({}, getOpenAppData, {
895
894
  sourceInfo: {
896
895
  entrance: '设计师预览',
897
896
  },
898
897
  });
899
898
  } else if (sourceInfo) {
900
899
  const { entrance } = sourceInfo;
901
900
  getOpenAppData.sourceInfo.entrance = entrance && entrance.length > 0 ? entrance : '其他';
902
901
  } else if (source && !sourceInfo) {
903
902
  if (typeof source === 'object') {
904
903
  const { sourceType, entrance, sourceValue, moduleId } = source;
905
904
  getOpenAppData = Object.assign({}, getOpenAppData, {
906
905
  sourceInfo: {
907
906
  entrance: sourceType || entrance || '其他',
908
907
  moduleId: sourceValue || moduleId || '-100',
909
908
  },
910
909
  });
911
910
  if (sourceType === 'shop_from_product_detail' && sourceValue) {
912
911
  getOpenAppData.sourceSku = sourceValue;
913
912
  }
914
913
  } else {
915
914
  getOpenAppData = Object.assign({}, getOpenAppData, {
916
915
  sourceInfo: {
917
916
  entrance: source,
918
917
  },
919
918
  });
920
919
  }
921
920
  } else {
922
921
  getOpenAppData = Object.assign({}, getOpenAppData, {
923
922
  sourceInfo: {
924
923
  entrance: '其他',
925
924
  },
926
925
  });
927
926
  }
928
927
  } catch (e) {
929
928
  console.log(e);
930
929
  }
931
930
  return getOpenAppData;
932
931
  }
933
932
  return data;
934
933
  return displayObj;
935
934
  if (typeof input === 'string') {
936
935
  try {
937
936
  return JSON.parse(input);
938
937
  } catch (e) {
939
938
  console.error('JSON解析失败', e);
940
939
  return {};
941
940
  }
942
941
  }
943
942
  return input || {};
944
943
  return false;
945
944
  const borderStyle: { [key: string]: any } = {};
946
945
  if (item?.borderRadius) {
947
946
  let borderTopRadius = 0;
948
947
  let borderBottomRadius = 0;
949
948
  if (index === 0) {
950
949
  borderTopRadius = item.borderRadius;
951
950
  borderBottomRadius = floorDataLen === 1 || item?.marginBottom !== 0 ? item.borderRadius : 0;
952
951
  } else if (index === floorDataLen - 1) {
953
952
  borderTopRadius = floorData[index - 1]?.marginBottom === 0 ? 0 : item.borderRadius;
954
953
  borderBottomRadius = item.borderRadius;
955
954
  } else {
956
955
  borderTopRadius = floorData[index - 1]?.marginBottom === 0 ? 0 : item.borderRadius;
957
956
  borderBottomRadius = item?.marginBottom === 0 ? 0 : item.borderRadius;
958
957
  }
959
958
  borderStyle.borderTopLeftRadius = item?.borderTopLeftRadius
960
959
  ? `${item?.borderTopLeftRadius}px`
961
960
  : `${borderTopRadius}px`;
962
961
  borderStyle.borderTopRightRadius = item?.borderTopRightRadius
963
962
  ? `${item?.borderTopRightRadius}px`
964
963
  : `${borderTopRadius}px`;
965
964
  borderStyle.borderBottomLeftRadius = `${borderBottomRadius}px`;
966
965
  borderStyle.borderBottomRightRadius = `${borderBottomRadius}px`;
967
966
  } else {
968
967
  borderStyle.borderTopLeftRadius = borderStyle?.borderTopLeftRadius || '0px';
969
968
  borderStyle.borderTopRightRadius = borderStyle?.borderTopRightRadius || '0px';
970
969
  borderStyle.borderBottomRightRadius = borderStyle?.borderBottomRightRadius || '0px';
971
970
  borderStyle.borderBottomLeftRadius = borderStyle?.borderBottomLeftRadius || '0px';
972
971
  }
973
972
  return borderStyle;
974
973
  return customObj;
975
974
  isJdApp,
976
975
  isWxApp,
977
976
  isIosDevice,
978
977
  isAndroidDevice,
979
978
  isJdAndIosDevice,
980
979
  isJdAndAndroidDevice,
981
980
  isWxMin,
982
981
  isWxMinAndWxapp,
983
982
  isJdMin,
984
983
  isMin,
985
984
  isJdMinAndHarmony,
986
985
  isH5,
987
986
  isH5AndJdShopView,
988
987
  isImageOptimizeEnable,
989
988
  isChartH5,
990
989
  isH5AndJdShopViewNativeScroll,
991
990
  isH5AndJdShopViewH5Scroll,
992
991
  isH5AndJdShopH5CustomScrollView,
993
992
  isWxMiniH5View,
994
993
  sliceArrToChunkList,
995
994
  dealAddress,
996
995
  objectToUrlEncode,
997
996
  parseQueryUrlString,
998
997
  setLowSmallPicUrl,
999
998
  getJfsImage,
1000
999
  getQualityImage,
1001
1000
  countStringify,
1002
1001
  setTaroStorage,
1003
1002
  getTaroStorageKeyValue,
1004
1003
  removeTaroStorageKey,
1005
1004
  clearTaroStorageKey,
1006
1005
  getSystemInfos,
1007
1006
  addHttps,
1008
1007
  dateFormat,
1009
1008
  throttle,
1010
1009
  lodashThrottle,
1011
1010
  debounce,
1012
1011
  getTelephone,
1013
1012
  rgbToHex,
1014
1013
  hexToRgb,
1015
1014
  getRandom,
1016
1015
  getWxAppCookieStr,
1017
1016
  pxTransformFromData,
1018
1017
  dealShopContentData,
1019
1018
  showSuccessToast,
1020
1019
  showFailToast,
1021
1020
  showNormalToast,
1022
1021
  showShopLoading,
1023
1022
  hideShopLoading,
1024
1023
  getAppChannelType,
1025
1024
  formatTabActiveMenuType,
1026
1025
  filterUrlQueryData,
1027
1026
  getAvifSupport,
1028
1027
  getWebpSupport,
1029
1028
  isMemberPage,
1030
1029
  sgmCustomReport,
1031
1030
  draCustomReport,
1032
1031
  remoteCustomReport,
1033
1032
  draInterfaceCustomReport,
1034
1033
  draBusinessCustomReport,
1035
1034
  isOpenJdAppUrl,
1036
1035
  jdOpenAppParams,
1037
1036
  createJdOpenAppUrl,
1038
1037
  dealJdOpenAppData,
1039
1038
  isEmpty,
1040
1039
  getJdAppReportPageSource,
1041
1040
  isAppClassifyPage,
1042
1041
  getQualityImageNew,
1043
1042
  getQualityImageOld,
1044
1043
  isPc,
1045
1044
  ipLoc_djd,
1046
1045
  jdAppVersionCompare,
1047
1046
  dealNativePixelToCssPixel,
1048
1047
  isAppStowShop,
1049
1048
  isIpadDevice,
1050
1049
  getBorderStyle,
1051
1050
  isLanguageForEn,
1052
1051
  sColor,
1053
1052
  draInterfaceDSMCustomReport,
1053
+ import Taro from '@tarojs/taro';
1054
1054
  SHOP_MENU_ID_TYPE,
1055
1055
  SHOP_MENU_ID_QUERY_NAME,
1056
1056
  SECTION_HOME_TAB_TYPE,
1057
1057
  SECTION_HOME_TAB_NAME_TYPE,
1058
1058
  SECTION_HOME_TAB_QUERY_TYPE,
1059
1059
  CHANNEL_TYPE,
1060
1060
  JDShopViewBusinessPathType,
1061
1061
  FloorModuleType,
1062
1062
  RemoteLoadFloorList,
1063
1063
  FLOOR_KIND,
1064
1064
  getBundleUrl,
1065
1065
  getBundleFileName,
1066
1066
  formatPackResult,
1067
1067
  getTaroVersion,
1068
1068
  /ipad/i.test(system) || (/android/i.test(system) && !/mobi|mini|fennec/i.test(system));
1069
1069
  isTablet: isJdTabletDevice,
1070
1070
  isLandscape: false,
1071
1071
  key: string,
1072
1072
  value: string | object,
1073
1073
  successBack?: any,
1074
1074
  failBack?: any,
1075
1075
  try {
1076
1076
  if (isH5 && window && !window.localStorage) {
1077
1077
  console.log(`setTaroStorage key:${key} window.localStorage不存在:`);
1078
1078
  return Promise.resolve(null);
1079
1079
  }
1080
1080
  return Taro.setStorage({
1081
1081
  key: key,
1082
1082
  data: value,
1083
1083
  success: successBack,
1084
1084
  fail: failBack,
1085
1085
  }).catch((e) => {
1086
1086
  console.log(`setTaroStorage key:${key} 报错:`, e);
1087
1087
  return null;
1088
1088
  });
1089
1089
  } catch (e) {
1090
1090
  console.log(`setTaroStorage key:${key} 报错:`, e);
1091
1091
  return Promise.resolve(null);
1092
1092
  }
1093
1093
  try {
1094
1094
  if (isH5 && window && !window.localStorage) {
1095
1095
  console.log(`getTaroStorageKeyValue key:${key} window.localStorage不存在:`);
1096
1096
  return Promise.resolve(null);
1097
1097
  }
1098
1098
  return Taro.getStorageSync(key);
1099
1099
  } catch (e) {
1100
1100
  console.log(`getTaroStorageKeyValue key:${key} 报错:`, e);
1101
1101
  return null;
1102
1102
  }
1103
1103
  try {
1104
1104
  if (isH5 && window && !window.localStorage) {
1105
1105
  console.log(`removeTaroStorageKey key:${key} window.localStorage不存在:`);
1106
1106
  return Promise.resolve(null);
1107
1107
  }
1108
1108
  return Taro.removeStorage({
1109
1109
  key: key,
1110
1110
  }).catch((e) => {
1111
1111
  console.log(`removeTaroStorageKey key:${key} 报错:`, e);
1112
1112
  });
1113
1113
  } catch (e) {
1114
1114
  console.log(`removeTaroStorageKey key:${key} 报错:`, e);
1115
1115
  }
1116
1116
  try {
1117
1117
  if (isH5 && window && !window.localStorage) {
1118
1118
  console.log(`clearTaroStorageKey window.localStorage不存在`);
1119
1119
  return Promise.resolve(null);
1120
1120
  }
1121
1121
  return Taro.clearStorage().catch((e) => {
1122
1122
  console.log('clearTaroStorageKey报错:', e);
1123
1123
  });
1124
1124
  } catch (e) {
1125
1125
  console.log('clearTaroStorageKey报错:', e);
1126
1126
  }
1127
1127
  let hasChecked = false;
1128
1128
  if (isH5) {
1129
1129
  const avifCache = getTaroStorageKeyValue(KEY_AVIF);
1130
1130
  if (avifCache === null || avifCache === '' || forceUpdate) {
1131
1131
  hasChecked = true;
1132
1132
  const img = new Image();
1133
1133
  img.onload = function () {
1134
1134
  if (img.height > 0 && img.width > 0) {
1135
1135
  setTaroStorage(KEY_AVIF, '1');
1136
1136
  } else {
1137
1137
  setTaroStorage(KEY_AVIF, '0');
1138
1138
  }
1139
1139
  };
1140
1140
  img.onerror = () => {
1141
1141
  setTaroStorage(KEY_AVIF, '0');
1142
1142
  };
1143
1143
  img.src =
1144
1144
  '';
1145
1145
  }
1146
1146
  const webpCache = getTaroStorageKeyValue(KEY_WEBP);
1147
1147
  if (webpCache === null || webpCache === '' || forceUpdate) {
1148
1148
  hasChecked = true;
1149
1149
  const img = new Image();
1150
1150
  img.onload = function () {
1151
1151
  if (img.height > 0 && img.width > 0) {
1152
1152
  setTaroStorage(KEY_WEBP, '1');
1153
1153
  } else {
1154
1154
  setTaroStorage(KEY_WEBP, '0');
1155
1155
  }
1156
1156
  };
1157
1157
  img.onerror = () => {
1158
1158
  setTaroStorage(KEY_WEBP, '0');
1159
1159
  };
1160
1160
  img.src =
1161
1161
  '';
1162
1162
  }
1163
1163
  }
1164
1164
  return hasChecked;
1165
1165
  const hasChecked = imageFormatSupport(false);
1166
1166
  if (!hasChecked) {
1167
1167
  setTimeout(imageFormatSupport, 5000);
1168
1168
  }
1169
1169
  const resultList: Array<any> = [],
1170
1170
  arrLen = arr.length;
1171
1171
  if (arrLen) {
1172
1172
  if (arrLen > size) {
1173
1173
  for (let i = 0; i < arrLen; i = i + size) {
1174
1174
  resultList.push(arr.slice(i, i + size));
1175
1175
  }
1176
1176
  } else {
1177
1177
  resultList.push(arr);
1178
1178
  }
1179
1179
  }
1180
1180
  return resultList;
1181
1181
  let _address = ids;
1182
1182
  const _areaAreaSplit = ids.split('.');
1183
1183
  const _areaAreaSplit2 = ids.split('_');
1184
1184
  _address = _areaAreaSplit.length === 2 ? _areaAreaSplit[0] : _address;
1185
1185
  _address = _areaAreaSplit2.length === 3 ? `${_areaAreaSplit2}_0` : _address;
1186
1186
  return _address;
1187
1187
  let paramStr = '';
1188
1188
  obj &&
1189
1189
  Object.keys(obj).forEach((key, index) => {
1190
1190
  const getValue = `${obj[key]}`.replace(/undefined/, '').replace(/null/, '');
1191
1191
  paramStr += `${index === 0 ? '' : '&'}${key}=${encodeURIComponent(getValue)}`;
1192
1192
  });
1193
1193
  return paramStr;
1194
1194
  const result = {};
1195
1195
  if (
1196
1196
  !urlOrQueryStr ||
1197
1197
  ('string' !== typeof urlOrQueryStr && String !== urlOrQueryStr.constructor)
1198
1198
  ) {
1199
1199
  return result;
1200
1200
  }
1201
1201
  if (urlOrQueryStr.indexOf('?') > -1) {
1202
1202
  const queryStr = urlOrQueryStr.split('?');
1203
1203
  const queryItemList = queryStr && queryStr.length > 1 ? queryStr[1].split('&') : [];
1204
1204
  const queryItemListLen = queryItemList.length;
1205
1205
  queryItemListLen > 0 &&
1206
1206
  queryItemList.forEach((item) => {
1207
1207
  const thisItemList = item.split('=');
1208
1208
  result[thisItemList[0]] = thisItemList[1];
1209
1209
  });
1210
1210
  } else {
1211
1211
  const queryItemList =
1212
1212
  urlOrQueryStr.indexOf('&') > -1 ? urlOrQueryStr.split('&') : [urlOrQueryStr];
1213
1213
  const queryItemListLen = queryItemList.length;
1214
1214
  queryItemListLen > 0 &&
1215
1215
  queryItemList.forEach((item) => {
1216
1216
  const thisItemList = item.split('=');
1217
1217
  result[thisItemList[0]] = thisItemList[1];
1218
1218
  });
1219
1219
  }
1220
1220
  return result;
1221
1221
  url: string,
1222
1222
  size?: {
1223
1223
  w: number;
1224
1224
  h: number;
1225
1225
  },
1226
1226
  quality?: number,
1227
1227
  if (url && size) {
1228
1228
  const _w = Math.floor(size.w);
1229
1229
  const _h = Math.floor(size.h);
1230
1230
  if (url.match(/gif$/i)) {
1231
1231
  return url;
1232
1232
  } else {
1233
1233
  if (_w > 0 && _h > 0) {
1234
1234
  url = url.replace('jfs/', `s${_w}x${_h}_jfs/`);
1235
1235
  }
1236
1236
  url += quality != null ? `!q${quality}.dpg` : '.dpg';
1237
1237
  }
1238
1238
  }
1239
1239
  return url;
1240
1240
  if (url.match(/\.(jpg|png|dpg)$/i)) {
1241
1241
  const { width, height, quality } = jfsImgInfo;
1242
1242
  if (typeof width === 'number' || typeof height === 'number') {
1243
1243
  url = url.replace('/jfs/', `/s${Math.floor(width || 0)}x${Math.floor(height || 0)}_jfs/`);
1244
1244
  }
1245
1245
  if (typeof quality === 'number' && quality > 0 && quality < 100 && url.match(/\.jpg$/i)) {
1246
1246
  url += `!q${quality}.dpg`;
1247
1247
  }
1248
1248
  }
1249
1249
  return addHttps(url);
1250
1250
  if (imgUrl) {
1251
1251
  if (
1252
1252
  !imgUrl.match(
1253
1253
  /(storage\.360buyimg\.com)|(jdcloud-oss\.com)|(imgcps\.jd\.com)|((\w+)\.300hu\.com)|(thirdwx\.qlogo\.cn)|(!q)|gif|dpg$/i,
1254
1254
  )
1255
1255
  ) {
1256
1256
  if (!imgUrl.includes('360buyimg.com')) {
1257
1257
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
1258
1258
  }
1259
1259
  if (quality != 100) imgUrl += /\.png/.test(imgUrl) ? '.dpg' : `!q${quality}`;
1260
1260
  }
1261
1261
  imgUrl = imgUrl.match(/^\/\//) ? `https:${imgUrl}` : imgUrl;
1262
1262
  }
1263
1263
  return imgUrl;
1264
1264
  const result = value % step;
1265
1265
  return result === 0 ? value : Math.ceil(value / step) * step;
1266
1266
  const MAX = 3.5;
1267
1267
  return Math.min(window?.devicePixelRatio ?? 2, MAX);
1268
1268
  isSkuImage: boolean;
1269
1269
  size: number;
1270
1270
  imgUrl: string,
1271
1271
  options: QualityOptions,
1272
1272
  isIgnoreOptimizeFromServer: boolean = false,
1273
1273
  if (!imgUrl) {
1274
1274
  console.error('The input parameter imageUrl for the getQualityImage() cannot be empty!');
1275
1275
  return imgUrl;
1276
1276
  }
1277
1277
  if (isIgnoreOptimizeFromServer) {
1278
1278
  imgUrl = imgUrl.replace(/\.(jpe?g|png).*/, '.$1');
1279
1279
  }
1280
1280
  if (!/^((https?):)?\/\//.test(imgUrl)) {
1281
1281
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
1282
1282
  }
1283
1283
  const imgServerRegExp = /(img|m)\d{0,2}\.360buyimg\.com\/.*\.(jpe?g|png)/i;
1284
1284
  if (!imgServerRegExp.test(imgUrl)) {
1285
1285
  return imgUrl;
1286
1286
  }
1287
1287
  imgUrl = /^\/\//.test(imgUrl) ? `https:${imgUrl}` : imgUrl;
1288
1288
  const { isSkuImage, size } = options || {};
1289
1289
  const needReduceSize = isSkuImage && size;
1290
1290
  if (needReduceSize) {
1291
1291
  const devicePixelRatio = getDevicePixelRatio();
1292
1292
  const useWidth = getValueByStep(size * devicePixelRatio, 40);
1293
1293
  imgUrl = imgUrl.replace(/\/[^\/]*jfs\//, `/s${useWidth}x${useWidth}_jfs/`);
1294
1294
  }
1295
1295
  const needCompress = !global?.info?.pageInfo?.isVipShop;
1296
1296
  const result = imgUrl.match(/\/\w+\.(jpe?g|png)$/);
1297
1297
  if (needCompress && result) {
1298
1298
  if (getAvifSupport() === '1') {
1299
1299
  imgUrl += '.avif';
1300
1300
  } else if (getWebpSupport() === '1') {
1301
1301
  imgUrl += '.webp';
1302
1302
  } else if (/jpe?g/.test(result[1])) {
1303
1303
  imgUrl += '!q80';
1304
1304
  }
1305
1305
  }
1306
1306
  if (needReduceSize) {
1307
1307
  imgUrl += '!z2';
1308
1308
  }
1309
1309
  return imgUrl;
1310
1310
  if (imgUrl) {
1311
1311
  if (
1312
1312
  !imgUrl.match(
1313
1313
  /(storage\.360buyimg\.com)|(jdcloud-oss\.com)|((\w+)\.300hu\.com)|(thirdwx\.qlogo\.cn)|(!q)|gif|dpg$/i,
1314
1314
  )
1315
1315
  ) {
1316
1316
  if (!imgUrl.includes('360buyimg.com')) {
1317
1317
  imgUrl = '//m.360buyimg.com/cms/' + imgUrl;
1318
1318
  }
1319
1319
  if (quality != 100) imgUrl += /\.png/.test(imgUrl) ? '.dpg' : `!q${quality}`;
1320
1320
  }
1321
1321
  imgUrl = imgUrl.match(/^\/\//) ? `https:${imgUrl}` : imgUrl;
1322
1322
  }
1323
1323
  return imgUrl;
1324
1324
  return getTaroStorageKeyValue(KEY_AVIF) || '0';
1325
1325
  return getTaroStorageKeyValue(KEY_WEBP) || '0';
1326
1326
  count: number,
1327
1327
  fixedNum = 1,
1328
1328
  unit = '万',
1329
1329
  maxNum = 10000,
1330
1330
  count = Number(count);
1331
1331
  const getMaxNum = count > 100000000 ? 100000000 : maxNum;
1332
1332
  const getUnit = count > 100000000 ? '亿' : unit;
1333
1333
  if (count >= getMaxNum) {
1334
1334
  return (count / getMaxNum).toFixed(fixedNum) + getUnit;
1335
1335
  }
1336
1336
  return count;
1337
1337
  const systemInfo: UtilsInterFace.taroGetSystemInfoSyncRes = getSystemInfo || {
1338
1338
  platform: '',
1339
1339
  model: '',
1340
1340
  system: '',
1341
1341
  };
1342
1342
  const isIOS = !!systemInfo.system.match(/ios/i);
1343
1343
  const isAndroid = !!systemInfo.system.match(/android/i);
1344
1344
  if (!systemInfo.statusBarHeight) {
1345
1345
  systemInfo.statusBarHeight = screenHeight - windowHeight - 20;
1346
1346
  systemInfo.navBarExtendHeight = 0;
1347
1347
  } else {
1348
1348
  if (isIOS) {
1349
1349
  systemInfo.navBarExtendHeight = 4;
1350
1350
  } else {
1351
1351
  systemInfo.navBarExtendHeight = 0;
1352
1352
  }
1353
1353
  }
1354
1354
  let rect = Taro.getMenuButtonBoundingClientRect ? Taro.getMenuButtonBoundingClientRect() : null;
1355
1355
  if (!rect || !rect.width || !rect.top || !rect.left || !rect.height) {
1356
1356
  let gap = 0;
1357
1357
  let width = 96;
1358
1358
  if (systemInfo.platform === 'android') {
1359
1359
  gap = 8;
1360
1360
  width = 96;
1361
1361
  } else if (systemInfo.platform === 'devtools') {
1362
1362
  if (isIOS) {
1363
1363
  gap = 5.5;
1364
1364
  } else {
1365
1365
  gap = 7.5;
1366
1366
  }
1367
1367
  } else {
1368
1368
  gap = 4;
1369
1369
  width = 88;
1370
1370
  }
1371
1371
  rect = {
1372
1372
  bottom: systemInfo.statusBarHeight + gap + 32,
1373
1373
  height: 32,
1374
1374
  left: systemInfo.windowWidth - width - 10,
1375
1375
  right: systemInfo.windowWidth - 10,
1376
1376
  top: systemInfo.statusBarHeight + gap,
1377
1377
  width,
1378
1378
  };
1379
1379
  }
1380
1380
  const gap = rect.top - systemInfo.statusBarHeight;
1381
1381
  systemInfo.navBarTopToStatusBar = gap;
1382
1382
  systemInfo.navBarHeight = 2 * gap + rect.height;
1383
1383
  systemInfo.capsulePosition = rect;
1384
1384
  systemInfo.isIOS = isIOS;
1385
1385
  systemInfo.isAndroid = isAndroid;
1386
1386
  return systemInfo;
1387
1387
  if (str.match(/^\/\//)) {
1388
1388
  str = 'https:' + str;
1389
1389
  }
1390
1390
  return str;
1391
1391
  dateTimeOrdate: Date | string | number | null,
1392
1392
  format = 'yyyy-MM-dd HH:mm:ss',
1393
1393
  noPadStart = {
1394
1394
  M: '0',
1395
1395
  d: '0',
1396
1396
  H: '0',
1397
1397
  m: '0',
1398
1398
  s: '0',
1399
1399
  },
1400
1400
  let dateResult = '';
1401
1401
  const padStarts = Object.assign(
1402
1402
  {
1403
1403
  M: '0',
1404
1404
  d: '0',
1405
1405
  H: '0',
1406
1406
  m: '0',
1407
1407
  s: '0',
1408
1408
  },
1409
1409
  noPadStart,
1410
1410
  );
1411
1411
  if (dateTimeOrdate) {
1412
1412
  let changeDateTimeOrdate = dateTimeOrdate;
1413
1413
  const getChangeDateTimeToNumber = Number(changeDateTimeOrdate);
1414
1414
  if (getChangeDateTimeToNumber) {
1415
1415
  changeDateTimeOrdate = getChangeDateTimeToNumber;
1416
1416
  } else {
1417
1417
  changeDateTimeOrdate = `${changeDateTimeOrdate}`.replace(/-/g, '/').replace(/\./g, '/');
1418
1418
  }
1419
1419
  const nowDate =
1420
1420
  dateTimeOrdate instanceof Date ? dateTimeOrdate : new Date(changeDateTimeOrdate);
1421
1421
  const dateMap = {
1422
1422
  y: `${nowDate.getFullYear()}`,
1423
1423
  M: `${nowDate.getMonth() + 1}`.padStart(2, padStarts['M']),
1424
1424
  d: `${nowDate.getDate()}`.padStart(2, padStarts['d']),
1425
1425
  H: `${nowDate.getHours()}`.padStart(2, padStarts['H']),
1426
1426
  m: `${nowDate.getMinutes()}`.padStart(2, padStarts['m']),
1427
1427
  s: `${nowDate.getSeconds()}`.padStart(2, padStarts['s']),
1428
1428
  };
1429
1429
  const regDate = new RegExp('y+|M+|d+|H+|m+|s+', 'g');
1430
1430
  const regYear = new RegExp('y');
1431
1431
  dateResult = format.replace(regDate, (v) => {
1432
1432
  let changeValue = v;
1433
1433
  if (regYear.test(changeValue)) {
1434
1434
  const thisYear = dateMap.y;
1435
1435
  const subValueLen = 4 - changeValue.length;
1436
1436
  changeValue = thisYear.substr(subValueLen);
1437
1437
  } else {
1438
1438
  const dateKey = v.substr(0, 1);
1439
1439
  changeValue = dateMap[dateKey];
1440
1440
  }
1441
1441
  return changeValue;
1442
1442
  });
1443
1443
  }
1444
1444
  return dateResult;
1445
1445
  let timer: any = null;
1446
1446
  let startTime = Date.now();
1447
1447
  return function () {
1448
1448
  const curTime = Date.now();
1449
1449
  const remaining = delay - (curTime - startTime);
1450
1450
  const context = this;
1451
1451
  const args = arguments;
1452
1452
  clearTimeout(timer);
1453
1453
  if (remaining <= 0) {
1454
1454
  func.apply(context, args);
1455
1455
  startTime = Date.now();
1456
1456
  } else {
1457
1457
  timer = setTimeout(func, remaining);
1458
1458
  }
1459
1459
  };
1460
1460
  let context, args, result;
1461
1461
  let timeout = null;
1462
1462
  let previous = 0;
1463
1463
  if (!options) options = {};
1464
1464
  const later = function () {
1465
1465
  previous = options.leading === false ? 0 : Date.now();
1466
1466
  timeout = null;
1467
1467
  result = func.apply(context, args);
1468
1468
  if (!timeout) context = args = null;
1469
1469
  };
1470
1470
  return function () {
1471
1471
  const now = Date.now();
1472
1472
  if (!previous && options.leading === false) previous = now;
1473
1473
  const remaining = wait - (now - previous);
1474
1474
  context = this;
1475
1475
  args = arguments;
1476
1476
  if (remaining <= 0 || remaining > wait) {
1477
1477
  if (timeout) {
1478
1478
  clearTimeout(timeout);
1479
1479
  timeout = null;
1480
1480
  }
1481
1481
  previous = now;
1482
1482
  result = func.apply(context, args);
1483
1483
  if (!timeout) context = args = null;
1484
1484
  } else if (!timeout && options.trailing !== false) {
1485
1485
  timeout = setTimeout(later, remaining);
1486
1486
  }
1487
1487
  return result;
1488
1488
  };
1489
1489
  let timer: any = null;
1490
1490
  return function () {
1491
1491
  const context: any = this;
1492
1492
  const args = arguments;
1493
1493
  timer && clearTimeout(timer);
1494
1494
  timer = setTimeout(function () {
1495
1495
  fn.apply(context, args);
1496
1496
  }, delay);
1497
1497
  };
1498
1498
  if (txt) {
1499
1499
  txt = txt.trim();
1500
1500
  const reg = new RegExp(/[\d-]+/);
1501
1501
  const res = reg.exec(txt);
1502
1502
  if (res && res.length > 0) {
1503
1503
  let tel = res[0];
1504
1504
  if (tel && delSeparator) {
1505
1505
  tel = tel.replace(/-/g, '');
1506
1506
  }
1507
1507
  return tel;
1508
1508
  }
1509
1509
  }
1510
1510
  return '';
1511
1511
  if (rgb) {
1512
1512
  const reg = /^(rgb|RGB)/;
1513
1513
  const color = rgb;
1514
1514
  if (reg.test(color)) {
1515
1515
  let strHex = '#';
1516
1516
  const colorArr = color.replace(/(?:\(|\)|rgb|RGB)*/g, '').split(',');
1517
1517
  for (let i = 0; i < colorArr.length; i++) {
1518
1518
  let hex = Number(colorArr[i]).toString(16);
1519
1519
  if (hex === '0') {
1520
1520
  hex += hex;
1521
1521
  }
1522
1522
  strHex += hex;
1523
1523
  }
1524
1524
  return strHex;
1525
1525
  } else {
1526
1526
  return String(color);
1527
1527
  }
1528
1528
  } else {
1529
1529
  return '';
1530
1530
  }
1531
1531
  if (hex) {
1532
1532
  const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
1533
1533
  let color = hex.toLowerCase();
1534
1534
  if (reg.test(color)) {
1535
1535
  if (color.length === 4) {
1536
1536
  let colorNew = '#';
1537
1537
  for (let i = 1; i < 4; i += 1) {
1538
1538
  colorNew += color.slice(i, i + 1).concat(color.slice(i, i + 1));
1539
1539
  }
1540
1540
  color = colorNew;
1541
1541
  }
1542
1542
  const colorChange: number[] = [];
1543
1543
  for (let i = 1; i < 7; i += 2) {
1544
1544
  colorChange.push(parseInt('0x' + color.slice(i, i + 2)));
1545
1545
  }
1546
1546
  if (returnList) {
1547
1547
  return colorChange;
1548
1548
  } else {
1549
1549
  return 'RGB(' + colorChange.join(',') + ')';
1550
1550
  }
1551
1551
  } else {
1552
1552
  return color;
1553
1553
  }
1554
1554
  } else {
1555
1555
  return '';
1556
1556
  }
1557
1557
  const c = m - n + 1;
1558
1558
  const res = Math.floor(Math.random() * c + n);
1559
1559
  if (filterNum && filterNum == res) {
1560
1560
  console.log('随机数二次开始', res, filterNum);
1561
1561
  return getRandom(n, m, filterNum);
1562
1562
  } else {
1563
1563
  return res;
1564
1564
  }
1565
1565
  wqCookieStr: string;
1566
1566
  wqCookie: {
1567
1567
  pin?: string;
1568
1568
  visitkey?: string;
1569
1569
  [key: string]: any;
1570
1570
  };
1571
1571
 
1572
1572
  const {
1573
1573
  jdpin,
1574
1574
  pinStatus,
1575
1575
  visitkey,
1576
1576
  unionid,
1577
1577
  skey,
1578
1578
  __jda,
1579
1579
  __jdv,
1580
1580
  __wga,
1581
1581
  wid,
1582
1582
  wq_skey,
1583
1583
  wq_uin,
1584
1584
  wq_auth_token,
1585
1585
  wxapp_scene,
1586
1586
  wq_unionid,
1587
1587
  wxapp_openid,
1588
1588
  wxapp_version,
1589
1589
  wxapp_type,
1590
1590
  appType,
1591
1591
  } = cookie;
1592
1592
  const ret: string[] = [];
1593
1593
  const getUserCookieObj = {};
1594
1594
  const createUseCookieArr = [
1595
1595
  jdpin,
1596
1596
  pinStatus,
1597
1597
  visitkey,
1598
1598
  unionid,
1599
1599
  skey,
1600
1600
  __jda,
1601
1601
  __jdv,
1602
1602
  __wga,
1603
1603
  wid,
1604
1604
  wq_skey,
1605
1605
  wq_uin,
1606
1606
  wq_auth_token,
1607
1607
  wxapp_scene,
1608
1608
  wq_unionid,
1609
1609
  wxapp_openid,
1610
1610
  wxapp_version,
1611
1611
  wxapp_type,
1612
1612
  appType,
1613
1613
  ];
1614
1614
 
1615
1615
  createUseCookieArr.forEach((keyItem) => {
1616
1616
  if (keyItem && keyItem['name']) {
1617
1617
  let { name, value } = keyItem;
1618
1618
  name = name === 'jdpin' ? 'pin' : name;
1619
1619
  name === 'pin' && ret.push(`pt_pin=${encodeURIComponent(value)}`);
1620
1620
  ret.push(`${name}=${encodeURIComponent(value)}`);
1621
1621
  getUserCookieObj[name] = value;
1622
1622
  }
1623
1623
  });
1624
1624
  return {
1625
1625
  wqCookieStr: ret.join(';'),
1626
1626
  wqCookie: getUserCookieObj,
1627
1627
  };
1628
1628
  const getLayoutWidth = layoutWidth || global.info?.sysInfo?.windowWidth || windowWidth;
1629
1629
  const getNum = Number(num);
1630
1630
  return Math.round((getNum / widthSize) * getLayoutWidth);
1631
1631
  let checkState = false;
1632
1632
  const couponFloorModuleType = floorData?.floorExtInfo?.moduleFlag;
1633
1633
  if (couponFloorModuleType === FloorModuleType.COUPON) {
1634
1634
  try {
1635
1635
  const dataDefines = getFloorDataToDataDefines(floorData);
1636
1636
  const couponDataDefine = dataDefines
1637
1637
  ? dataDefines.filter((item) => {
1638
1638
  return item.type === 'coupon';
1639
1639
  })
1640
1640
  : [],
1641
1641
  couponList = couponDataDefine[0]?.nodeText?.data ? couponDataDefine[0]?.nodeText?.data : [],
1642
1642
  couponLength = couponList.length,
1643
1643
  numShowPerLine = couponDataDefine[0]?.nodeText?.numShowPerLine
1644
1644
  ? couponDataDefine[0]?.nodeText?.numShowPerLine
1645
1645
  : 0;
1646
1646
  if (numShowPerLine === 0 && couponLength > 3) {
1647
1647
  checkState = true;
1648
1648
  }
1649
1649
  } catch (e) {
1650
1650
  checkState = false;
1651
1651
  }
1652
1652
  return checkState;
1653
1653
  }
1654
1654
  const {
1655
1655
  containers = [],
1656
1656
  floors = [],
1657
1657
  clearFirstContaierMarginTop = false,
1658
1658
  } = pageData;
1659
1659
  console.log('dealShopContentData:', pageData, 'isvdev:', isvdev);
1660
1660
  const getThisTimeKey = Date.now();
1661
1661
  let shopContentContainerListData = containers?.filter(
1662
1662
  (item) => (!isvdev && item.typeCode !== 'mShopHeader') || isvdev,
1663
1663
  );
1664
1664
  const shopContentFloorListData = floors?.filter(
1665
1665
  ({ floorPosition }) =>
1666
1666
  (!isvdev && floorPosition !== 'header' && floorPosition !== 'footer') || isvdev,
1667
1667
  );
1668
1668
  const unableIsvContainerListData = getUnableIsvContainerListData(
1669
1669
  shopContentFloorListData,
1670
1670
  shopContentContainerListData,
1671
1671
  exceptionReportFn,
1672
1672
  );
1673
1673
  shopContentContainerListData.forEach((item, index) => {
1674
1674
  item.key = `${getThisTimeKey + index}`;
1675
1675
  item.floors = [];
1676
1676
  item.includeUids &&
1677
1677
  item.includeUids.forEach((floorUid) => {
1678
1678
  const getFloorData = shopContentFloorListData.find(
1679
1679
  (floorItem) => floorItem.uid === floorUid,
1680
1680
  );
1681
1681
  if (getFloorData) {
1682
1682
  const changeFloorData = {
1683
1683
  containerId: item.containerId,
1684
1684
  containerIndex: index,
1685
1685
  ...getFloorData,
1686
1686
  };
1687
1687
  const getCheckMoreCouponState = checkCouponAndChangeContainerSetData(getFloorData);
1688
1688
  if (getCheckMoreCouponState) {
1689
1689
  item.marginLeft && (item.marginLeft = 0);
1690
1690
  item.marginRight && (item.marginRight = 0);
1691
1691
  item.borderRadius && (item.borderRadius = 0);
1692
1692
  }
1693
1693
  if (getFloorData?.floorExtInfo?.floorLoadWay === 2) {
1694
1694
  const getSysFloorToLoadTypeRes = isIsvFloorUseable(getFloorData, exceptionReportFn);
1695
1695
  !getSysFloorToLoadTypeRes && (getFloorData.floorExtInfo.floorLoadWay = 1);
1696
1696
  }
1697
1697
  item.floors.push(changeFloorData);
1698
1698
  }
1699
1699
  });
1700
1700
  if (
1701
1701
  ((!isvdev && index === 0) || (isvdev && index === 1)) &&
1702
1702
  item?.containerPosition == 'content' &&
1703
1703
  item?.marginBottom > 0 &&
1704
1704
  !clearFirstContaierMarginTop
1705
1705
  ) {
1706
1706
  item.marginTop = item.marginBottom;
1707
1707
  }
1708
1708
  });
1709
1709
  shopContentContainerListData = shopContentContainerListData.filter(
1710
1710
  (item) =>
1711
1711
  item.floors.length > 0 &&
1712
1712
  unableIsvContainerListData.every(
1713
1713
  (containerItem) => containerItem.containerId != item.containerId,
1714
1714
  ),
1715
1715
  );
1716
1716
  console.log(
1717
1717
  'dealShopContentData isWxMinAndWxapp:',
1718
1718
  isWxMinAndWxapp,
1719
1719
  'weappJumpToH5:',
1720
1720
  pageData?.homeExtInfo?.weappJumpToH5,
1721
1721
  );
1722
1722
  if (isProd && isWxMinAndWxapp) {
1723
1723
  shopContentContainerListData = shopContentContainerListData.filter(
1724
1724
  (item) =>
1725
1725
  item.floors.length > 0 &&
1726
1726
  !isIsvContainer(item.containerId, shopContentFloorListData, shopContentContainerListData),
1727
1727
  );
1728
1728
  }
1729
1729
  shopContentContainerListData = [].concat(shopContentContainerListData);
1730
1730
  return {
1731
1731
  shopContentContainerListData,
1732
1732
  shopContentFloorListData,
1733
1733
  };
1734
1734
  const changeOpts = {
1735
1735
  title: '',
1736
1736
  icon: 'success',
1737
1737
  duration: 1500,
1738
1738
  mask: true,
1739
1739
  ...options,
1740
1740
  };
1741
1741
  if (changeOpts.title.length > 7) {
1742
1742
  showNormalToast(options);
1743
1743
  } else {
1744
1744
  Taro.showToast(changeOpts as any);
1745
1745
  }
1746
1746
  const changeOpts = {
1747
1747
  title: '',
1748
1748
  icon: 'error',
1749
1749
  duration: 1500,
1750
1750
  mask: true,
1751
1751
  ...options,
1752
1752
  };
1753
1753
  if (changeOpts.title.length > 7) {
1754
1754
  showNormalToast(options);
1755
1755
  } else {
1756
1756
  Taro.showToast(changeOpts as any);
1757
1757
  }
1758
1758
  Taro.showToast({
1759
1759
  title: '',
1760
1760
  icon: 'none',
1761
1761
  duration: 1500,
1762
1762
  mask: true,
1763
1763
  ...options,
1764
1764
  });
1765
1765
  return Taro.showLoading({
1766
1766
  title: text,
1767
1767
  });
1768
1768
  return new Promise(() => {
1769
1769
  Taro.nextTick(() => {
1770
1770
  setTimeout(() => {
1771
1771
  Taro.hideLoading(options);
1772
1772
  }, 300);
1773
1773
  });
1774
1774
  });
1775
1775
  return CHANNEL_TYPE[JDShopViewBusinessPathType.HOME];
1776
1776
  const {
1777
1777
  tabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN],
1778
1778
  sceneId,
1779
1779
  } = query;
1780
1780
  let changeTabActive = tabActive;
1781
1781
  if (sceneId) {
1782
1782
  if (isH5) {
1783
1783
  if (sceneId == '1002') {
1784
1784
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PRODUCT];
1785
1785
  }
1786
1786
  else if (sceneId == '1003') {
1787
1787
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_ACTIVITY];
1788
1788
  }
1789
1789
  } else if (isWxMinAndWxapp) {
1790
1790
  if (sceneId == '1001' || sceneId == '1002') {
1791
1791
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PRODUCT];
1792
1792
  }
1793
1793
  else if (sceneId == '1003') {
1794
1794
  changeTabActive = SECTION_HOME_TAB_NAME_TYPE[SECTION_HOME_TAB_TYPE.HOME_PROMOTION];
1795
1795
  }
1796
1796
  }
1797
1797
  }
1798
1798
  if (SECTION_HOME_TAB_QUERY_TYPE[changeTabActive]) {
1799
1799
  return {
1800
1800
  menuType: SHOP_MENU_ID_TYPE.HOME,
1801
1801
  tabActiveType: SECTION_HOME_TAB_QUERY_TYPE[changeTabActive],
1802
1802
  queryMenuTabActiveStr: `${SHOP_MENU_ID_TYPE.HOME}@${SECTION_HOME_TAB_QUERY_TYPE[changeTabActive]}`,
1803
1803
  };
1804
1804
  } else if (SHOP_MENU_ID_QUERY_NAME[changeTabActive]) {
1805
1805
  return {
1806
1806
  menuType: SHOP_MENU_ID_QUERY_NAME[changeTabActive],
1807
1807
  tabActiveType: 0,
1808
1808
  queryMenuTabActiveStr: `${SHOP_MENU_ID_QUERY_NAME[changeTabActive]}@0`,
1809
1809
  };
1810
1810
  } else {
1811
1811
  return {
1812
1812
  menuType: SHOP_MENU_ID_TYPE.HOME,
1813
1813
  tabActiveType: SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN,
1814
1814
  queryMenuTabActiveStr: `${SHOP_MENU_ID_TYPE.HOME}@${SECTION_HOME_TAB_TYPE.HOME_WELL_CHOSEN}`,
1815
1815
  };
1816
1816
  }
1817
1817
  const deleteKeyList = [
1818
1818
  '$taroTimestamp',
1819
1819
  'cookie',
1820
1820
  'wdref',
1821
1821
  'navStart',
1822
1822
  'originOpts',
1823
1823
  'originParams',
1824
1824
  'originUrl',
1825
1825
  'referer',
1826
1826
  'stamp',
1827
1827
  'hybrid',
1828
1828
  'sr',
1829
1829
  'navh',
1830
1830
  'stath',
1831
1831
  ];
1832
1832
  let changeQueryData: any = { ...queryData };
1833
1833
  const qrCodeScene = changeQueryData?.scene ? changeQueryData?.scene : false;
1834
1834
  const sceneQuery =
1835
1835
  qrCodeScene && typeof qrCodeScene === 'string'
1836
1836
  ? parseQueryUrlString(decodeURIComponent(qrCodeScene))
1837
1837
  : {};
1838
1838
  changeQueryData = { ...changeQueryData, ...sceneQuery };
1839
1839
  deleteKeyList.forEach((key) => {
1840
1840
  changeQueryData[key] && delete changeQueryData[key];
1841
1841
  });
1842
1842
  changeQueryData['shopid'] &&
1843
1843
  (changeQueryData['shopId'] = changeQueryData['shopid']) &&
1844
1844
  delete changeQueryData['shopid'];
1845
1845
  changeQueryData['venderid'] &&
1846
1846
  (changeQueryData['venderId'] = changeQueryData['venderid']) &&
1847
1847
  delete changeQueryData['venderid'];
1848
1848
  changeQueryData['vendorId'] &&
1849
1849
  (changeQueryData['venderId'] = changeQueryData['vendorId']) &&
1850
1850
  delete changeQueryData['vendorId'];
1851
1851
  changeQueryData['shopId'] &&
1852
1852
  changeQueryData['shopId'] === 'undefined' &&
1853
1853
  delete changeQueryData['shopId'];
1854
1854
  changeQueryData['venderId'] &&
1855
1855
  changeQueryData['venderId'] === 'undefined' &&
1856
1856
  delete changeQueryData['venderId'];
1857
1857
  return changeQueryData;
1858
1858
  let isUsable = false;
1859
1859
  const modularPackResult = floorData?.floorExtInfo?.modularPackResult;
1860
1860
  const modularPackResultObj = formatPackResult(modularPackResult);
1861
1861
  const bundleUrl = getBundleUrl(modularPackResultObj);
1862
1862
  const bundleFileName = getBundleFileName(modularPackResultObj);
1863
1863
  const taroVersion = getTaroVersion(modularPackResultObj);
1864
1864
  if (bundleUrl && bundleFileName) {
1865
1865
  isUsable = true;
1866
1866
  }
1867
1867
  if (!isUsable && typeof exceptionReportFn === 'function') {
1868
1868
  exceptionReportFn({
1869
1869
  code: `${NO_ENVIRONMENT_AND_PAGE_TYPE_FLAG}${
1870
1870
  floorData?.floorExtInfo?.floorKind === FLOOR_KIND.PDC_SYSTEM_MODULE
1871
1871
  ? SgmCustomCode.SYSTEMPDCMODULE_DATA
1872
1872
  : SgmCustomCode.REMOTEMODULE_DATA
1873
1873
  }`,
1874
1874
  msg: {
1875
1875
  msg: `店铺h5楼层隐藏不显示。原因:模块数据不完备,楼层过滤。`,
1876
1876
  floorIdx: floorData?.floorIdx,
1877
1877
  uid: floorData?.uid,
1878
1878
  shopId: floorData?.floorExtInfo?.shopId,
1879
1879
  moduleId: floorData?.moduleId,
1880
1880
  moduleDesignerType: floorData?.floorExtInfo?.moduleDesignerType,
1881
1881
  floorLoadWay: floorData?.floorExtInfo?.floorLoadWay,
1882
1882
  floorKind: floorData?.floorExtInfo?.floorKind,
1883
1883
  middleTemplateId: floorData?.middleTemplateId,
1884
1884
  modularPackResult: {
1885
1885
  bundleUrl,
1886
1886
  taroVersion,
1887
1887
  },
1888
1888
  },
1889
1889
  });
1890
1890
  }
1891
1891
  return isUsable;
1892
1892
  const objContainer = containerListData.find((item) => item.containerId === containerId);
1893
1893
  return (
1894
1894
  objContainer?.includeUids?.some((itemUid) => {
1895
1895
  const objectFloor = floorListData.find((floorItem) => itemUid === floorItem.uid);
1896
1896
  return RemoteLoadFloorList.includes(objectFloor?.floorExtInfo?.moduleFlag);
1897
1897
  }) ?? false
1898
1898
  );
1899
1899
  const unableIsvFloorListData = floorListData.filter(
1900
1900
  (floorItem) =>
1901
1901
  RemoteLoadFloorList.includes(floorItem?.floorExtInfo?.moduleFlag) &&
1902
1902
  !isIsvFloorUseable(floorItem, exceptionReportFn),
1903
1903
  );
1904
1904
  const unableIsvFloorUidList = unableIsvFloorListData.map((floorItem) => floorItem.uid);
1905
1905
  const unableIsvContainerListData = containerListData.filter(
1906
1906
  (item) =>
1907
1907
  item.includeUids &&
1908
1908
  item.includeUids.every((itemUid) => unableIsvFloorUidList.indexOf(itemUid) != -1),
1909
1909
  );
1910
1910
  return unableIsvContainerListData;
1911
1911
  console.log('暂无对应渠道比较', compareVersion, nowVersion);
1912
1912
  return -2;
1913
1913
  return customObj;
1914
1914
  return customObj;
1915
1915
  return customObj;
1916
1916
  return customObj;
1917
1917
  return customObj;
1918
1918
  return /openApp\.jdMobile:\/\/virtual\?params=/i.test(openAppUrl);
1919
1919
  let getParams = false;
1920
1920
  if (isOpenJdAppUrl(openAppUrl)) {
1921
1921
  try {
1922
1922
  getParams = openAppUrl.replace(/openApp\.jdMobile:\/\/virtual\?params=/i, '');
1923
1923
  getParams = JSON.parse(String(getParams));
1924
1924
  } catch (e) {
1925
1925
  console.log(e);
1926
1926
  }
1927
1927
  }
1928
1928
  return getParams;
1929
1929
  const getLastParams = Object.assign({}, openParams);
1930
1930
  return `openapp.jdmobile://virtual?params=${JSON.stringify(getLastParams)}`;
1931
1931
  if (val === null || val === '' || typeof val === 'undefined') {
1932
1932
  return true;
1933
1933
  }
1934
1934
  return false;
1935
1935
  const {
1936
1936
  moduleId = 'none',
1937
1937
  entrance = 'none',
1938
1938
  sourceType = 'none',
1939
1939
  sourceValue = 'none',
1940
1940
  } = params;
1941
1941
  if (isIosDevice) {
1942
1942
  return `${moduleId}#${entrance}`;
1943
1943
  } else if (isAndroidDevice) {
1944
1944
  return `${sourceType}#${sourceValue}`;
1945
1945
  }
1946
1946
  return 'none#none';
1947
1947
  if (data && typeof data === 'object') {
1948
1948
  let getOpenAppData = { ...data };
1949
1949
  try {
1950
1950
  const { sourceInfo, designerId, templateId, source } = getOpenAppData;
1951
1951
  if (designerId && templateId) {
1952
1952
  getOpenAppData = Object.assign({}, getOpenAppData, {
1953
1953
  sourceInfo: {
1954
1954
  entrance: '设计师预览',
1955
1955
  },
1956
1956
  });
1957
1957
  } else if (sourceInfo) {
1958
1958
  const { entrance } = sourceInfo;
1959
1959
  getOpenAppData.sourceInfo.entrance = entrance && entrance.length > 0 ? entrance : '其他';
1960
1960
  } else if (source && !sourceInfo) {
1961
1961
  if (typeof source === 'object') {
1962
1962
  const { sourceType, entrance, sourceValue, moduleId } = source;
1963
1963
  getOpenAppData = Object.assign({}, getOpenAppData, {
1964
1964
  sourceInfo: {
1965
1965
  entrance: sourceType || entrance || '其他',
1966
1966
  moduleId: sourceValue || moduleId || '-100',
1967
1967
  },
1968
1968
  });
1969
1969
  if (sourceType === 'shop_from_product_detail' && sourceValue) {
1970
1970
  getOpenAppData.sourceSku = sourceValue;
1971
1971
  }
1972
1972
  } else {
1973
1973
  getOpenAppData = Object.assign({}, getOpenAppData, {
1974
1974
  sourceInfo: {
1975
1975
  entrance: source,
1976
1976
  },
1977
1977
  });
1978
1978
  }
1979
1979
  } else {
1980
1980
  getOpenAppData = Object.assign({}, getOpenAppData, {
1981
1981
  sourceInfo: {
1982
1982
  entrance: '其他',
1983
1983
  },
1984
1984
  });
1985
1985
  }
1986
1986
  } catch (e) {
1987
1987
  console.log(e);
1988
1988
  }
1989
1989
  return getOpenAppData;
1990
1990
  }
1991
1991
  return data;
1992
1992
  return displayObj;
1993
1993
  if (typeof input === 'string') {
1994
1994
  try {
1995
1995
  return JSON.parse(input);
1996
1996
  } catch (e) {
1997
1997
  console.error('JSON解析失败', e);
1998
1998
  return {};
1999
1999
  }
2000
2000
  }
2001
2001
  return input || {};
2002
2002
  return false;
2003
2003
  const borderStyle: { [key: string]: any } = {};
2004
2004
  if (item?.borderRadius) {
2005
2005
  let borderTopRadius = 0;
2006
2006
  let borderBottomRadius = 0;
2007
2007
  if (index === 0) {
2008
2008
  borderTopRadius = item.borderRadius;
2009
2009
  borderBottomRadius = floorDataLen === 1 || item?.marginBottom !== 0 ? item.borderRadius : 0;
2010
2010
  } else if (index === floorDataLen - 1) {
2011
2011
  borderTopRadius = floorData[index - 1]?.marginBottom === 0 ? 0 : item.borderRadius;
2012
2012
  borderBottomRadius = item.borderRadius;
2013
2013
  } else {
2014
2014
  borderTopRadius = floorData[index - 1]?.marginBottom === 0 ? 0 : item.borderRadius;
2015
2015
  borderBottomRadius = item?.marginBottom === 0 ? 0 : item.borderRadius;
2016
2016
  }
2017
2017
  borderStyle.borderTopLeftRadius = item?.borderTopLeftRadius
2018
2018
  ? `${item?.borderTopLeftRadius}px`
2019
2019
  : `${borderTopRadius}px`;
2020
2020
  borderStyle.borderTopRightRadius = item?.borderTopRightRadius
2021
2021
  ? `${item?.borderTopRightRadius}px`
2022
2022
  : `${borderTopRadius}px`;
2023
2023
  borderStyle.borderBottomLeftRadius = `${borderBottomRadius}px`;
2024
2024
  borderStyle.borderBottomRightRadius = `${borderBottomRadius}px`;
2025
2025
  } else {
2026
2026
  borderStyle.borderTopLeftRadius = borderStyle?.borderTopLeftRadius || '0px';
2027
2027
  borderStyle.borderTopRightRadius = borderStyle?.borderTopRightRadius || '0px';
2028
2028
  borderStyle.borderBottomRightRadius = borderStyle?.borderBottomRightRadius || '0px';
2029
2029
  borderStyle.borderBottomLeftRadius = borderStyle?.borderBottomLeftRadius || '0px';
2030
2030
  }
2031
2031
  return borderStyle;
2032
2032
  return customObj;
2033
2033
  isJdApp,
2034
2034
  isWxApp,
2035
2035
  isIosDevice,
2036
2036
  isAndroidDevice,
2037
2037
  isJdAndIosDevice,
2038
2038
  isJdAndAndroidDevice,
2039
2039
  isWxMin,
2040
2040
  isWxMinAndWxapp,
2041
2041
  isJdMin,
2042
2042
  isMin,
2043
2043
  isJdMinAndHarmony,
2044
2044
  isH5,
2045
2045
  isH5AndJdShopView,
2046
2046
  isImageOptimizeEnable,
2047
2047
  isChartH5,
2048
2048
  isH5AndJdShopViewNativeScroll,
2049
2049
  isH5AndJdShopViewH5Scroll,
2050
2050
  isH5AndJdShopH5CustomScrollView,
2051
2051
  isWxMiniH5View,
2052
2052
  sliceArrToChunkList,
2053
2053
  dealAddress,
2054
2054
  objectToUrlEncode,
2055
2055
  parseQueryUrlString,
2056
2056
  setLowSmallPicUrl,
2057
2057
  getJfsImage,
2058
2058
  getQualityImage,
2059
2059
  countStringify,
2060
2060
  setTaroStorage,
2061
2061
  getTaroStorageKeyValue,
2062
2062
  removeTaroStorageKey,
2063
2063
  clearTaroStorageKey,
2064
2064
  getSystemInfos,
2065
2065
  addHttps,
2066
2066
  dateFormat,
2067
2067
  throttle,
2068
2068
  lodashThrottle,
2069
2069
  debounce,
2070
2070
  getTelephone,
2071
2071
  rgbToHex,
2072
2072
  hexToRgb,
2073
2073
  getRandom,
2074
2074
  getWxAppCookieStr,
2075
2075
  pxTransformFromData,
2076
2076
  dealShopContentData,
2077
2077
  showSuccessToast,
2078
2078
  showFailToast,
2079
2079
  showNormalToast,
2080
2080
  showShopLoading,
2081
2081
  hideShopLoading,
2082
2082
  getAppChannelType,
2083
2083
  formatTabActiveMenuType,
2084
2084
  filterUrlQueryData,
2085
2085
  getAvifSupport,
2086
2086
  getWebpSupport,
2087
2087
  isMemberPage,
2088
2088
  sgmCustomReport,
2089
2089
  draCustomReport,
2090
2090
  remoteCustomReport,
2091
2091
  draInterfaceCustomReport,
2092
2092
  draBusinessCustomReport,
2093
2093
  isOpenJdAppUrl,
2094
2094
  jdOpenAppParams,
2095
2095
  createJdOpenAppUrl,
2096
2096
  dealJdOpenAppData,
2097
2097
  isEmpty,
2098
2098
  getJdAppReportPageSource,
2099
2099
  isAppClassifyPage,
2100
2100
  getQualityImageNew,
2101
2101
  getQualityImageOld,
2102
2102
  isPc,
2103
2103
  ipLoc_djd,
2104
2104
  jdAppVersionCompare,
2105
2105
  dealNativePixelToCssPixel,
2106
2106
  isAppStowShop,
2107
2107
  isIpadDevice,
2108
2108
  getBorderStyle,
2109
2109
  isLanguageForEn,
2110
2110
  sColor,
2111
2111
  draInterfaceDSMCustomReport,
2112
2112
  isTabletDevice,
2113
2113
  isJdTabletDevice,
2114
2114
  jdTabletDeviceInfo,