pb-sxp-ui 14.0.7 → 15.0.1

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 (76) hide show
  1. package/dist/index.cjs +157 -607
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +15 -89
  4. package/dist/index.js +157 -607
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +5 -5
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +5 -5
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +157 -607
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +5 -5
  13. package/dist/pb-ui.min.js.map +1 -1
  14. package/es/core/components/SxpPageRender/ConsentPopup.js +8 -8
  15. package/es/core/components/SxpPageRender/Navbar.js +1 -1
  16. package/es/core/components/SxpPageRender/WaterFall/List.js +3 -3
  17. package/es/core/components/SxpPageRender/WaterFall/index.js +2 -2
  18. package/es/core/components/SxpPageRender/index.js +2 -5
  19. package/es/core/context/SxpDataSourceProvider.js +22 -54
  20. package/es/core/utils/materials.js +3 -5
  21. package/es/materials/sxp/HashTag/index.d.ts +4 -1
  22. package/es/materials/sxp/HashTag/material.js +2 -1
  23. package/es/materials/sxp/HashTag/settingRender.d.ts +0 -2
  24. package/es/materials/sxp/HashTag/settingRender.js +2 -3
  25. package/es/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  26. package/es/materials/sxp/consentPopup/Display/index.js +5 -7
  27. package/es/materials/sxp/consentPopup/index.d.ts +0 -2
  28. package/es/materials/sxp/consentPopup/index.js +0 -2
  29. package/es/materials/sxp/cta/AniLink/index.js +1 -1
  30. package/es/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  31. package/es/materials/sxp/popup/ConsentDetail/index.d.ts +1 -2
  32. package/es/materials/sxp/popup/ConsentDetail/index.js +2 -2
  33. package/lib/core/components/SxpPageRender/ConsentPopup.js +7 -7
  34. package/lib/core/components/SxpPageRender/Navbar.js +1 -1
  35. package/lib/core/components/SxpPageRender/WaterFall/List.js +3 -3
  36. package/lib/core/components/SxpPageRender/WaterFall/index.js +2 -2
  37. package/lib/core/components/SxpPageRender/index.js +2 -5
  38. package/lib/core/context/SxpDataSourceProvider.js +22 -54
  39. package/lib/core/utils/materials.js +3 -5
  40. package/lib/materials/sxp/HashTag/index.d.ts +4 -1
  41. package/lib/materials/sxp/HashTag/material.js +2 -1
  42. package/lib/materials/sxp/HashTag/settingRender.d.ts +0 -2
  43. package/lib/materials/sxp/HashTag/settingRender.js +2 -3
  44. package/lib/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  45. package/lib/materials/sxp/consentPopup/Display/index.js +5 -7
  46. package/lib/materials/sxp/consentPopup/index.d.ts +0 -2
  47. package/lib/materials/sxp/consentPopup/index.js +0 -2
  48. package/lib/materials/sxp/cta/AniLink/index.js +1 -1
  49. package/lib/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  50. package/lib/materials/sxp/popup/ConsentDetail/index.d.ts +1 -2
  51. package/lib/materials/sxp/popup/ConsentDetail/index.js +2 -2
  52. package/package.json +1 -1
  53. package/es/materials/sxp/consentPopup/Click/index.d.ts +0 -19
  54. package/es/materials/sxp/consentPopup/Click/index.js +0 -19
  55. package/es/materials/sxp/consentPopup/Click/material.d.ts +0 -2
  56. package/es/materials/sxp/consentPopup/Click/material.js +0 -48
  57. package/es/materials/sxp/consentPopup/Click/settingRender.d.ts +0 -63
  58. package/es/materials/sxp/consentPopup/Click/settingRender.js +0 -210
  59. package/es/materials/sxp/consentPopup/Swipe/index.d.ts +0 -12
  60. package/es/materials/sxp/consentPopup/Swipe/index.js +0 -44
  61. package/es/materials/sxp/consentPopup/Swipe/material.d.ts +0 -2
  62. package/es/materials/sxp/consentPopup/Swipe/material.js +0 -24
  63. package/es/materials/sxp/consentPopup/Swipe/settingRender.d.ts +0 -29
  64. package/es/materials/sxp/consentPopup/Swipe/settingRender.js +0 -43
  65. package/lib/materials/sxp/consentPopup/Click/index.d.ts +0 -19
  66. package/lib/materials/sxp/consentPopup/Click/index.js +0 -21
  67. package/lib/materials/sxp/consentPopup/Click/material.d.ts +0 -2
  68. package/lib/materials/sxp/consentPopup/Click/material.js +0 -52
  69. package/lib/materials/sxp/consentPopup/Click/settingRender.d.ts +0 -63
  70. package/lib/materials/sxp/consentPopup/Click/settingRender.js +0 -212
  71. package/lib/materials/sxp/consentPopup/Swipe/index.d.ts +0 -12
  72. package/lib/materials/sxp/consentPopup/Swipe/index.js +0 -46
  73. package/lib/materials/sxp/consentPopup/Swipe/material.d.ts +0 -2
  74. package/lib/materials/sxp/consentPopup/Swipe/material.js +0 -28
  75. package/lib/materials/sxp/consentPopup/Swipe/settingRender.d.ts +0 -29
  76. package/lib/materials/sxp/consentPopup/Swipe/settingRender.js +0 -45
package/dist/pb-ui.js CHANGED
@@ -707,15 +707,12 @@
707
707
  const bffDataSource = React.useMemo(() => {
708
708
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
709
709
  }, [dataSources]);
710
- const fakeUserId = React.useMemo(() => {
711
- var _a;
712
- return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
713
- }, [bffDataSource]);
714
710
  // bff API 请求方法
715
711
  const bffFetch = React.useCallback((path, options) => {
716
712
  if (!bffDataSource)
717
713
  return;
718
714
  const url = bffDataSource.url;
715
+ const fakeUserId = storeAndLoadFeUserId();
719
716
  if (options === null || options === void 0 ? void 0 : options.query) {
720
717
  const queryString = qs.stringify(options.query);
721
718
  path = `${path}?${queryString}`;
@@ -723,19 +720,19 @@
723
720
  // 事件上报优化
724
721
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
725
722
  if (options.type === 'beacon' && navigator.sendBeacon) {
726
- return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
723
+ return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
727
724
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
728
725
  ], { type: 'application/json;charset=UTF-8' }));
729
726
  }
730
727
  return window
731
- .fetch(`${url}/api/${path}`, {
728
+ .fetch(`${url}/api/v1${path}`, {
732
729
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
733
730
  method: options.method,
734
731
  body: JSON.stringify(options.body)
735
732
  })
736
733
  .then((res) => res.json())
737
734
  .catch((err) => Promise.reject(err));
738
- }, [bffDataSource, fakeUserId]);
735
+ }, [bffDataSource]);
739
736
  // 获取推荐视频数据
740
737
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
741
738
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
@@ -773,16 +770,14 @@
773
770
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
774
771
  var _v, _w, _x, _y, _z, _0;
775
772
  query.pageNum = pageNum;
776
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
773
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
777
774
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
778
775
  return undefined;
779
776
  }
780
777
  setLoading(false);
781
778
  list = list.concat((_y = (_x = (_w = (_v = result === null || result === void 0 ? void 0 : result.data) === null || _v === void 0 ? void 0 : _v.recList) === null || _w === void 0 ? void 0 : _w.filter) === null || _x === void 0 ? void 0 : _x.call(_w, (item) => (item === null || item === void 0 ? void 0 : item.product) || (item === null || item === void 0 ? void 0 : item.video))) !== null && _y !== void 0 ? _y : []);
782
- if ((rtcList === null || rtcList === void 0 ? void 0 : rtcList.length) === 0) {
783
- setRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
784
- setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
785
- }
779
+ setRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
780
+ setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
786
781
  const isNotNullList = (_0 = (_z = result === null || result === void 0 ? void 0 : result.data) === null || _z === void 0 ? void 0 : _z.recList) === null || _0 === void 0 ? void 0 : _0.some((item) => (item === null || item === void 0 ? void 0 : item.product) || (item === null || item === void 0 ? void 0 : item.video));
787
782
  if (isNotNullList) {
788
783
  pageNum = pageNum + 1;
@@ -792,12 +787,12 @@
792
787
  yield recurveRecList(query);
793
788
  if (!(query === null || query === void 0 ? void 0 : query.hashTag) && result)
794
789
  setCurReqInfo({ rtc: (_l = result === null || result === void 0 ? void 0 : result.data) === null || _l === void 0 ? void 0 : _l.rtc, requestId: (_m = result === null || result === void 0 ? void 0 : result.data) === null || _m === void 0 ? void 0 : _m.requestId });
795
- return Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list });
790
+ return Object.assign(Object.assign({}, result.data), { recList: list });
796
791
  }
797
792
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
798
793
  query = Object.assign(Object.assign({}, query), { directPage: true, level: 1, pageNum: (_o = query === null || query === void 0 ? void 0 : query.pageNum) !== null && _o !== void 0 ? _o : 1 });
799
794
  }
800
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
795
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
801
796
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
802
797
  return undefined;
803
798
  }
@@ -847,7 +842,6 @@
847
842
  return expire;
848
843
  }, [data]);
849
844
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
850
- var _a, _b;
851
845
  // 关闭 BFF 事件上报
852
846
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
853
847
  return;
@@ -860,16 +854,7 @@
860
854
  };
861
855
  }
862
856
  const sessionID = storeAndLoadFeSessionId();
863
- const params = {};
864
- const queryString = location.search.slice(1);
865
- (_a = splitUrlParams(queryString)) === null || _a === void 0 ? void 0 : _a.map((val) => {
866
- const key = val.split('=')[0];
867
- const value = val.split('=')[1];
868
- params[key] = value;
869
- });
870
- console.log(params, '111');
871
- const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
872
- const ef = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ sessionID, rtc: curReqInfo.rtc, requestId: curReqInfo.requestId }, { playbookType }), (layoutVariantId && reportLayId && { layoutVariantId })), eventInfo), ((eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) && channel && { position: Number(eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) + 1 + '' })), (cl_source && { cl_source }));
857
+ const ef = Object.assign(Object.assign(Object.assign(Object.assign({ sessionID, rtc: curReqInfo.rtc, requestId: curReqInfo.requestId }, { playbookType }), (layoutVariantId && reportLayId && { layoutVariantId })), eventInfo), ((eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) && channel && { position: Number(eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) + 1 + '' }));
873
858
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
874
859
  const realEventInfo = Object.entries(ef)
875
860
  .map(([k, v]) => v && { name: k, value: v })
@@ -878,23 +863,14 @@
878
863
  console.log('userInfo:', userInfo);
879
864
  console.log('eventInfo:', ef);
880
865
  console.log('========= 结束 =========');
881
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch(`v2/event/report/CLD/${(_b = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _b === void 0 ? void 0 : _b['x-app-id']}/${eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.eventSubject}`, {
866
+ return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
882
867
  method: 'POST',
883
868
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
884
869
  type: 'beacon'
885
870
  });
886
- }, [
887
- bffFetch,
888
- curReqInfo,
889
- enableReportEvent,
890
- globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
891
- layoutVariantId,
892
- globalConfig,
893
- playbookType,
894
- bffDataSource
895
- ]);
871
+ }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
896
872
  const bffFbReport = React.useCallback(({ eventName, product }) => {
897
- var _a, _b, _c, _d, _e, _f;
873
+ var _a, _b, _c, _d, _e;
898
874
  if (!enableReportEvent ||
899
875
  !enabledMetaConversionApi ||
900
876
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -906,7 +882,7 @@
906
882
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
907
883
  const fix_par = {
908
884
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
909
- external_id: fakeUserId,
885
+ external_id: storeAndLoadFeUserId(),
910
886
  client_user_agent: (_e = (_d = window === null || window === void 0 ? void 0 : window.navigator) === null || _d === void 0 ? void 0 : _d.userAgent) !== null && _e !== void 0 ? _e : '',
911
887
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
912
888
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -958,30 +934,22 @@
958
934
  }
959
935
  };
960
936
  getEventParams(jsonParams);
961
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch(`v2/event/report/FB/${(_f = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _f === void 0 ? void 0 : _f['x-app-id']}/${eventName}`, {
937
+ return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
962
938
  method: 'POST',
963
939
  body: jsonParams,
964
940
  type: 'beacon'
965
941
  });
966
- }, [
967
- bffFetch,
968
- enableReportEvent,
969
- enabledMetaConversionApi,
970
- globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
971
- globalConfig,
972
- fakeUserId,
973
- bffDataSource
974
- ]);
942
+ }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
975
943
  const bffMutateLike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
976
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
944
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
977
945
  return res === null || res === void 0 ? void 0 : res.success;
978
946
  }), [bffFetch]);
979
947
  const bffMutateUnlike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
980
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
948
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
981
949
  return res === null || res === void 0 ? void 0 : res.success;
982
950
  }), [bffFetch]);
983
951
  const bffSubmitForm = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
984
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
952
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
985
953
  return res === null || res === void 0 ? void 0 : res.success;
986
954
  }), [bffFetch]);
987
955
  // 获取 Tag
@@ -996,7 +964,7 @@
996
964
  const key = val.split('=')[0];
997
965
  return (_b = ((_a = utmParameter === null || utmParameter === void 0 ? void 0 : utmParameter.channels) !== null && _a !== void 0 ? _a : [])) === null || _b === void 0 ? void 0 : _b.includes(key);
998
966
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
999
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
967
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
1000
968
  setTagList((_12 = (_11 = result === null || result === void 0 ? void 0 : result.data) === null || _11 === void 0 ? void 0 : _11.tags) !== null && _12 !== void 0 ? _12 : []);
1001
969
  }
1002
970
  catch (e) {
@@ -1075,10 +1043,10 @@
1075
1043
  let curData;
1076
1044
  let gldata;
1077
1045
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1078
- layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1079
- setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1080
1046
  const id = (_b = (_a = data === null || data === void 0 ? void 0 : data.layoutVariantId) === null || _a === void 0 ? void 0 : _a.split('-')) === null || _b === void 0 ? void 0 : _b[1];
1081
1047
  if (id) {
1048
+ layId = id;
1049
+ setLayoutVariantId(id);
1082
1050
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1083
1051
  if (curData) {
1084
1052
  setPageData(curData);
@@ -1464,7 +1432,7 @@
1464
1432
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1465
1433
  *
1466
1434
  */
1467
- var settingRender$f = [
1435
+ var settingRender$d = [
1468
1436
  {
1469
1437
  title: '弹窗背景',
1470
1438
  child: [
@@ -1900,7 +1868,7 @@
1900
1868
  category: 'popup',
1901
1869
  type: 'AppointForm',
1902
1870
  related: {
1903
- settingRender: settingRender$f,
1871
+ settingRender: settingRender$d,
1904
1872
  bindableProps: [],
1905
1873
  interactionRender: interactionRender$g
1906
1874
  },
@@ -1925,7 +1893,7 @@
1925
1893
  sort: 2
1926
1894
  });
1927
1895
 
1928
- var settingRender$e = [
1896
+ var settingRender$c = [
1929
1897
  {
1930
1898
  title: '弹窗背景',
1931
1899
  child: [
@@ -9814,7 +9782,7 @@
9814
9782
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9815
9783
  *
9816
9784
  */
9817
- const closeIcon$2 = '';
9785
+ const closeIcon$1 = '';
9818
9786
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9819
9787
  var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
9820
9788
  const touchRef = React.useRef(null);
@@ -9994,7 +9962,7 @@
9994
9962
  }
9995
9963
  })), child()),
9996
9964
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9997
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9965
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9998
9966
  };
9999
9967
  var Modal$1 = React.memo(Modal);
10000
9968
 
@@ -10165,7 +10133,7 @@
10165
10133
  * @Author: binruan@chatlabs.com
10166
10134
  * @Date: 2024-03-20 14:56:16
10167
10135
  * @LastEditors: binruan@chatlabs.com
10168
- * @LastEditTime: 2024-12-20 14:32:26
10136
+ * @LastEditTime: 2024-10-24 17:51:19
10169
10137
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10170
10138
  *
10171
10139
  */
@@ -10203,16 +10171,14 @@
10203
10171
  };
10204
10172
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10205
10173
  var _a, _b, _c, _d, _e, _f, _g, _h;
10206
- let text = '';
10207
10174
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10208
10175
  return null;
10209
- let price = Number((product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price) ? product === null || product === void 0 ? void 0 : product.price : 7000);
10210
- if (typeof price !== 'number')
10211
- return text;
10176
+ let price = (product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price) ? product === null || product === void 0 ? void 0 : product.price : 7000;
10177
+ let text = '';
10212
10178
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10213
10179
  let currency = (product === null || product === void 0 ? void 0 : product.currency) ? (_c = (_b = (_a = product === null || product === void 0 ? void 0 : product.currency) === null || _a === void 0 ? void 0 : _a.split('-')[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase()) !== null && _c !== void 0 ? _c : '' : '$';
10214
10180
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10215
- let decPic = price === null || price === void 0 ? void 0 : price.toString();
10181
+ let decPic = price.toString();
10216
10182
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10217
10183
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10218
10184
  }
@@ -10524,7 +10490,7 @@
10524
10490
  category: 'popup',
10525
10491
  type: 'CommodityDetail',
10526
10492
  related: {
10527
- settingRender: settingRender$e,
10493
+ settingRender: settingRender$c,
10528
10494
  interactionRender: interactionRender$f
10529
10495
  },
10530
10496
  defaulSetting: {
@@ -10600,7 +10566,7 @@
10600
10566
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10601
10567
  *
10602
10568
  */
10603
- var settingRender$d = [
10569
+ var settingRender$b = [
10604
10570
  {
10605
10571
  title: '弹窗背景',
10606
10572
  child: [
@@ -10741,7 +10707,7 @@
10741
10707
  }
10742
10708
  ];
10743
10709
 
10744
- var img$7 = "";
10710
+ var img$5 = "";
10745
10711
 
10746
10712
  const Prompt$1 = (_a) => {
10747
10713
  var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle, contentStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle", "contentStyle"]);
@@ -10764,7 +10730,7 @@
10764
10730
  };
10765
10731
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10766
10732
  React.createElement("div", { className: 'pb-prompt-icon' },
10767
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10733
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10768
10734
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10769
10735
  __html: setFontForText(content, contentStyle)
10770
10736
  } }),
@@ -10780,13 +10746,13 @@
10780
10746
  category: 'popup',
10781
10747
  type: 'Prompt',
10782
10748
  related: {
10783
- settingRender: settingRender$d,
10749
+ settingRender: settingRender$b,
10784
10750
  bindableProps: [],
10785
10751
  interactionRender: interactionRender$e
10786
10752
  },
10787
10753
  defaulSetting: {
10788
10754
  props: {
10789
- icon: img$7,
10755
+ icon: img$5,
10790
10756
  content: 'You have successfully completed the appointment!',
10791
10757
  btnText: 'OK'
10792
10758
  },
@@ -10805,7 +10771,7 @@
10805
10771
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10806
10772
  *
10807
10773
  */
10808
- var settingRender$c = [
10774
+ var settingRender$a = [
10809
10775
  {
10810
10776
  title: '弹窗背景',
10811
10777
  child: [
@@ -11484,7 +11450,7 @@ Made in Italy` })));
11484
11450
  category: 'popup',
11485
11451
  type: 'CommodityDetailDiroNew',
11486
11452
  related: {
11487
- settingRender: settingRender$c,
11453
+ settingRender: settingRender$a,
11488
11454
  interactionRender: interactionRender$d
11489
11455
  },
11490
11456
  defaulSetting: {
@@ -11548,7 +11514,7 @@ Made in Italy` })));
11548
11514
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11549
11515
  *
11550
11516
  */
11551
- var settingRender$b = [
11517
+ var settingRender$9 = [
11552
11518
  {
11553
11519
  title: '弹窗背景',
11554
11520
  child: [
@@ -11985,7 +11951,7 @@ Made in Italy` })));
11985
11951
  category: 'popup',
11986
11952
  type: 'CommodityList',
11987
11953
  related: {
11988
- settingRender: settingRender$b,
11954
+ settingRender: settingRender$9,
11989
11955
  interactionRender: interactionRender$c
11990
11956
  },
11991
11957
  defaulSetting: {
@@ -12034,7 +12000,7 @@ Made in Italy` })));
12034
12000
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
12035
12001
  *
12036
12002
  */
12037
- var settingRender$a = [
12003
+ var settingRender$8 = [
12038
12004
  {
12039
12005
  title: '背景样式',
12040
12006
  child: [
@@ -12068,7 +12034,7 @@ Made in Italy` })));
12068
12034
  category: 'popup',
12069
12035
  type: 'Iframe',
12070
12036
  related: {
12071
- settingRender: settingRender$a,
12037
+ settingRender: settingRender$8,
12072
12038
  bindableProps: []
12073
12039
  },
12074
12040
  defaulSetting: {
@@ -12088,7 +12054,7 @@ Made in Italy` })));
12088
12054
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12089
12055
  *
12090
12056
  */
12091
- var settingRender$9 = [
12057
+ var settingRender$7 = [
12092
12058
  {
12093
12059
  title: '弹窗文本',
12094
12060
  child: [
@@ -12101,22 +12067,22 @@ Made in Italy` })));
12101
12067
  ];
12102
12068
 
12103
12069
  const ConsentDetail$1 = (_a) => {
12104
- var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12070
+ var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12105
12071
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12106
12072
  __html: typeof content === 'string' ? content : ''
12107
12073
  }, onClick: (e) => {
12108
12074
  e.stopPropagation();
12109
- }, style: style }));
12075
+ } }));
12110
12076
  };
12111
- var ConsentDetail$2 = React.memo(ConsentDetail$1);
12077
+ var ConsentDetailComponent = React.memo(ConsentDetail$1);
12112
12078
 
12113
- const ConsentDetail = createMaterial(ConsentDetail$2, {
12079
+ const ConsentDetail = createMaterial(ConsentDetailComponent, {
12114
12080
  displayName: '协议详情',
12115
12081
  icon: '',
12116
12082
  category: 'popup',
12117
12083
  type: 'ConsentDetail',
12118
12084
  related: {
12119
- settingRender: settingRender$9,
12085
+ settingRender: settingRender$7,
12120
12086
  bindableProps: []
12121
12087
  },
12122
12088
  defaulSetting: {
@@ -12136,7 +12102,7 @@ Made in Italy` })));
12136
12102
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12137
12103
  *
12138
12104
  */
12139
- var settingRender$8 = [
12105
+ var settingRender$6 = [
12140
12106
  {
12141
12107
  title: '主题样式',
12142
12108
  child: [
@@ -12490,7 +12456,7 @@ Made in Italy` })));
12490
12456
  related: {
12491
12457
  interactionRender: interactionRender$b,
12492
12458
  bindableProps: [],
12493
- settingRender: settingRender$8
12459
+ settingRender: settingRender$6
12494
12460
  },
12495
12461
  defaulSetting: {
12496
12462
  props: {
@@ -12572,7 +12538,7 @@ Made in Italy` })));
12572
12538
  type: 'Appoint',
12573
12539
  related: {
12574
12540
  interactionRender: interactionRender$a,
12575
- settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12541
+ settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12576
12542
  bindableProps: []
12577
12543
  },
12578
12544
  defaulSetting: {
@@ -12778,7 +12744,7 @@ Made in Italy` })));
12778
12744
  category: 'template',
12779
12745
  type: 'Link',
12780
12746
  related: {
12781
- settingRender: (_a = settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle')) === null || _a === void 0 ? void 0 : _a.concat(linkSettingRender),
12747
+ settingRender: (_a = settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle')) === null || _a === void 0 ? void 0 : _a.concat(linkSettingRender),
12782
12748
  bindableProps: [],
12783
12749
  interactionRender: interactionRender$9
12784
12750
  },
@@ -12881,7 +12847,7 @@ Made in Italy` })));
12881
12847
  type: 'CommodityDiro',
12882
12848
  related: {
12883
12849
  interactionRender: interactionRender$8,
12884
- settingRender: settingRender$8,
12850
+ settingRender: settingRender$6,
12885
12851
  bindableProps: []
12886
12852
  },
12887
12853
  defaulSetting: {
@@ -12978,7 +12944,7 @@ Made in Italy` })));
12978
12944
  related: {
12979
12945
  interactionRender: interactionRender$7,
12980
12946
  bindableProps: [],
12981
- settingRender: settingRender$8
12947
+ settingRender: settingRender$6
12982
12948
  },
12983
12949
  defaulSetting: {
12984
12950
  props: {
@@ -13078,7 +13044,7 @@ Made in Italy` })));
13078
13044
  related: {
13079
13045
  interactionRender: interactionRender$6,
13080
13046
  bindableProps: [],
13081
- settingRender: settingRender$8
13047
+ settingRender: settingRender$6
13082
13048
  },
13083
13049
  defaulSetting: {
13084
13050
  props: {
@@ -13176,7 +13142,7 @@ Made in Italy` })));
13176
13142
  type: 'MultiCommodity',
13177
13143
  related: {
13178
13144
  interactionRender: interactionRender$5,
13179
- settingRender: settingRender$8,
13145
+ settingRender: settingRender$6,
13180
13146
  bindableProps: []
13181
13147
  },
13182
13148
  defaulSetting: {
@@ -13285,7 +13251,7 @@ Made in Italy` })));
13285
13251
  related: {
13286
13252
  interactionRender: interactionRender$4,
13287
13253
  bindableProps: [],
13288
- settingRender: settingRender$8
13254
+ settingRender: settingRender$6
13289
13255
  },
13290
13256
  defaulSetting: {
13291
13257
  props: {
@@ -13330,11 +13296,11 @@ Made in Italy` })));
13330
13296
  * @Author: binruan@chatlabs.com
13331
13297
  * @Date: 2024-04-07 14:07:12
13332
13298
  * @LastEditors: binruan@chatlabs.com
13333
- * @LastEditTime: 2024-08-22 10:14:36
13299
+ * @LastEditTime: 2025-02-17 17:16:56
13334
13300
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13335
13301
  *
13336
13302
  */
13337
- var settingRender$7 = [
13303
+ var settingRender$5 = [
13338
13304
  {
13339
13305
  title: 'Banner',
13340
13306
  child: [
@@ -13355,10 +13321,9 @@ Made in Italy` })));
13355
13321
  addonAfter: 'px'
13356
13322
  },
13357
13323
  {
13358
- type: 'Switch',
13324
+ type: 'HashTagFixedSize',
13359
13325
  label: '固定宽高',
13360
- name: ['props', 'openFixedSize'],
13361
- initialValue: true
13326
+ name: ['props', 'openFixedSize']
13362
13327
  }
13363
13328
  ]
13364
13329
  },
@@ -13567,7 +13532,7 @@ Made in Italy` })));
13567
13532
  * @Author: binruan@chatlabs.com
13568
13533
  * @Date: 2023-12-26 16:11:34
13569
13534
  * @LastEditors: binruan@chatlabs.com
13570
- * @LastEditTime: 2025-01-17 18:55:14
13535
+ * @LastEditTime: 2024-10-11 18:22:21
13571
13536
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Navbar.tsx
13572
13537
  *
13573
13538
  */
@@ -13578,7 +13543,7 @@ Made in Italy` })));
13578
13543
  React.createElement("button", { className: 'clc-sxp-nav-left', role: 'button', "aria-label": 'back button', onClick: onClose },
13579
13544
  React.createElement("img", { src: icon, alt: 'back button' })),
13580
13545
  React.createElement("div", { className: 'clc-sxp-nav-title', style: Object.assign(Object.assign({}, textStyle), { paddingLeft: (textStyle === null || textStyle === void 0 ? void 0 : textStyle.textAlign) === 'left' ? '35px' : 0 }), dangerouslySetInnerHTML: {
13581
- __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : 'title'}`, textStyle)
13546
+ __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : '标题'}`, textStyle)
13582
13547
  } })));
13583
13548
  };
13584
13549
  var Navbar$1 = React.memo(Navbar);
@@ -15162,11 +15127,11 @@ Made in Italy` })));
15162
15127
  } }))))));
15163
15128
  }
15164
15129
 
15165
- var img$6 = "";
15130
+ var img$4 = "";
15166
15131
 
15167
15132
  const WaterfallFlowItem = (props) => {
15168
15133
  var _a;
15169
- const { rec, index, list, reportTagsView, textStyles, space } = props;
15134
+ const { rec, index, list, reportTagsView, textStyles, space, openFixedSize } = props;
15170
15135
  const { swiperRef, setRtcList, setOpenHashtag, sxpParameter, globalConfig } = useSxpDataSource();
15171
15136
  const [showVideo, setShowVideo] = React.useState(false);
15172
15137
  const imgDom = React.useRef(null);
@@ -15275,11 +15240,11 @@ Made in Italy` })));
15275
15240
  }, 0);
15276
15241
  };
15277
15242
  return (React.createElement("div", { ref: ref, className: 'list-content-listItem', key: index, onClick: handleClickToDetail, style: { marginBottom: space } },
15278
- React.createElement("div", { className: 'list-content-listItem-picture' },
15243
+ React.createElement("div", { className: (openFixedSize === null || openFixedSize === void 0 ? void 0 : openFixedSize.ratio) === '1' ? 'list-content-listItem-picture' : 'list-content-listItem-picture1609' },
15279
15244
  showVideo && (React.createElement("div", { style: { display: 'none' } },
15280
15245
  React.createElement("video", { ref: videoDom, crossOrigin: 'anonymous', className: 'list-content-listItem-picture-img' }),
15281
15246
  React.createElement("canvas", { ref: canvasRef }))),
15282
- React.createElement(FormatImage$1, { loading: 'lazy', className: 'list-content-listItem-picture-img', ref: imgDom })),
15247
+ React.createElement(FormatImage$1, { loading: 'lazy', className: (openFixedSize === null || openFixedSize === void 0 ? void 0 : openFixedSize.ratio) === '1' ? 'list-content-listItem-picture-img' : 'list-content-listItem-picture1609-img', ref: imgDom })),
15283
15248
  React.createElement("div", { className: 'list-content-listItem-info' },
15284
15249
  React.createElement("div", { className: `${'list-content-listItem-info-title'} ${priceText ? 'list-content-listItem-info-nowrap' : ''}`, style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.title, dangerouslySetInnerHTML: {
15285
15250
  __html: setFontForText(title, textStyles === null || textStyles === void 0 ? void 0 : textStyles.title)
@@ -15390,12 +15355,12 @@ Made in Italy` })));
15390
15355
  * @Author: binruan@chatlabs.com
15391
15356
  * @Date: 2024-01-10 10:58:24
15392
15357
  * @LastEditors: binruan@chatlabs.com
15393
- * @LastEditTime: 2024-12-09 11:18:32
15358
+ * @LastEditTime: 2025-02-17 16:25:30
15394
15359
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
15395
15360
  *
15396
15361
  */
15397
15362
  const WaterFall = (props) => {
15398
- var _a;
15363
+ var _a, _b;
15399
15364
  const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport, themeTag, selectTag, bffFbReport } = useSxpDataSource();
15400
15365
  const { backMainFeed } = useEventReport();
15401
15366
  const modalEleRef = React.useRef(null);
@@ -15483,8 +15448,8 @@ Made in Italy` })));
15483
15448
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15484
15449
  display: openHashtag ? 'block' : 'none'
15485
15450
  } },
15486
- React.createElement(Navbar$1, { icon: img$6, styles: { top: '32px' }, textStyle: (_a = props === null || props === void 0 ? void 0 : props.textStyles) === null || _a === void 0 ? void 0 : _a.hashTagTitle, onClose: handleClose }),
15487
- (props === null || props === void 0 ? void 0 : props.openFixedSize) === true || (props === null || props === void 0 ? void 0 : props.openFixedSize) === undefined ? (React.createElement(WaterfallList, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList$1, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props)))), modalEleRef.current);
15451
+ React.createElement(Navbar$1, { icon: img$4, styles: { top: '32px' }, textStyle: (_a = props === null || props === void 0 ? void 0 : props.textStyles) === null || _a === void 0 ? void 0 : _a.hashTagTitle, onClose: handleClose }),
15452
+ ((_b = props === null || props === void 0 ? void 0 : props.openFixedSize) === null || _b === void 0 ? void 0 : _b.open) === true || (props === null || props === void 0 ? void 0 : props.openFixedSize) === undefined ? (React.createElement(WaterfallList, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList$1, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props)))), modalEleRef.current);
15488
15453
  };
15489
15454
  var WaterFall$1 = React.memo(WaterFall);
15490
15455
 
@@ -15492,7 +15457,7 @@ Made in Italy` })));
15492
15457
  * @Author: binruan@chatlabs.com
15493
15458
  * @Date: 2024-01-15 19:03:09
15494
15459
  * @LastEditors: binruan@chatlabs.com
15495
- * @LastEditTime: 2024-08-22 10:15:23
15460
+ * @LastEditTime: 2025-02-17 16:24:14
15496
15461
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\index.tsx
15497
15462
  *
15498
15463
  */
@@ -15505,7 +15470,7 @@ Made in Italy` })));
15505
15470
  * @Author: binruan@chatlabs.com
15506
15471
  * @Date: 2023-07-28 18:29:57
15507
15472
  * @LastEditors: binruan@chatlabs.com
15508
- * @LastEditTime: 2024-09-18 10:48:44
15473
+ * @LastEditTime: 2025-02-17 17:45:40
15509
15474
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\material.tsx
15510
15475
  *
15511
15476
  */
@@ -15515,7 +15480,7 @@ Made in Italy` })));
15515
15480
  category: 'base',
15516
15481
  type: 'HashTag',
15517
15482
  related: {
15518
- settingRender: settingRender$7,
15483
+ settingRender: settingRender$5,
15519
15484
  bindableProps: []
15520
15485
  },
15521
15486
  defaulSetting: {
@@ -15564,7 +15529,8 @@ Made in Italy` })));
15564
15529
  paddingLeft: 20,
15565
15530
  paddingRight: 20,
15566
15531
  paddingBottom: 20
15567
- }
15532
+ },
15533
+ openFixedSize: { open: true, ratio: '1' }
15568
15534
  }
15569
15535
  },
15570
15536
  w: 100,
@@ -15580,7 +15546,7 @@ Made in Italy` })));
15580
15546
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15581
15547
  *
15582
15548
  */
15583
- var settingRender$6 = [
15549
+ var settingRender$4 = [
15584
15550
  {
15585
15551
  title: '协议详情',
15586
15552
  child: [
@@ -15639,7 +15605,7 @@ Made in Italy` })));
15639
15605
  category: 'base',
15640
15606
  type: 'Consent',
15641
15607
  related: {
15642
- settingRender: settingRender$6
15608
+ settingRender: settingRender$4
15643
15609
  },
15644
15610
  defaulSetting: {
15645
15611
  props: {},
@@ -15658,7 +15624,7 @@ Made in Italy` })));
15658
15624
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15659
15625
  *
15660
15626
  */
15661
- var settingRender$5 = [
15627
+ var settingRender$3 = [
15662
15628
  {
15663
15629
  title: '主题样式',
15664
15630
  child: [
@@ -15803,7 +15769,7 @@ Made in Italy` })));
15803
15769
  onClick === null || onClick === void 0 ? void 0 : onClick();
15804
15770
  }
15805
15771
  };
15806
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
15772
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
15807
15773
  const aniTimStyle = React.useMemo(() => {
15808
15774
  var _a, _b;
15809
15775
  const ani = event === null || event === void 0 ? void 0 : event.animation;
@@ -15919,7 +15885,7 @@ Made in Italy` })));
15919
15885
  category: 'cta',
15920
15886
  type: 'AniLink',
15921
15887
  related: {
15922
- settingRender: settingRender$5,
15888
+ settingRender: settingRender$3,
15923
15889
  bindableProps: [],
15924
15890
  interactionRender: interactionRender$3
15925
15891
  },
@@ -15963,7 +15929,7 @@ Made in Italy` })));
15963
15929
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15964
15930
  *
15965
15931
  */
15966
- var settingRender$4 = [
15932
+ var settingRender$2 = [
15967
15933
  {
15968
15934
  title: '主题样式',
15969
15935
  child: [
@@ -16221,7 +16187,7 @@ Made in Italy` })));
16221
16187
 
16222
16188
  var styles = {"aniLinkPopup":"index-module_aniLinkPopup__YT7kj","animated-fadeIn":"index-module_animated-fadeIn__8ZCbq","fadeIn":"index-module_fadeIn__2E-dk","animated-fadeOut":"index-module_animated-fadeOut__iK4oc","fadeOut":"index-module_fadeOut__MgevT","one-line-ellipsis":"index-module_one-line-ellipsis__NRiVV","two-line-ellipsis":"index-module_two-line-ellipsis__k-YGB","modal-icon-wrapper":"index-module_modal-icon-wrapper__tu3BY","modal-icon-wrapper-img":"index-module_modal-icon-wrapper-img__4b7qZ"};
16223
16189
 
16224
- const closeIcon$1 = '';
16190
+ const closeIcon = '';
16225
16191
  const AniLinkPopup$1 = (_a) => {
16226
16192
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16227
16193
  var { style, recData, ctaTempStyles, index, event, bottom_image, translateY, isTel, onClick, isExternalLink = false, isActive } = _a, props = __rest(_a, ["style", "recData", "ctaTempStyles", "index", "event", "bottom_image", "translateY", "isTel", "onClick", "isExternalLink", "isActive"]);
@@ -16250,7 +16216,7 @@ Made in Italy` })));
16250
16216
  onClick === null || onClick === void 0 ? void 0 : onClick();
16251
16217
  }
16252
16218
  };
16253
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
16219
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
16254
16220
  const aniTimStyle = React.useMemo(() => {
16255
16221
  const ani = event === null || event === void 0 ? void 0 : event.animation;
16256
16222
  if (ani) {
@@ -16280,7 +16246,7 @@ Made in Italy` })));
16280
16246
  paddingLeft: '6px'
16281
16247
  } }, "Cta Title")) : (React.createElement("div", Object.assign({}, props, { className: `${css.css(Object.assign(Object.assign({}, style), { '--transY': `translateY(calc(100% + ${(_r = style === null || style === void 0 ? void 0 : style.margin) !== null && _r !== void 0 ? _r : 0}px))` }))} ${styles['aniLinkPopup']} ${aniNamStyle} ${css.css(aniTimStyle)}`, onClick: handleTo }),
16282
16248
  React.createElement("div", { onClick: onClose, className: styles['modal-icon-wrapper'], style: { padding: (_s = style === null || style === void 0 ? void 0 : style['padding']) !== null && _s !== void 0 ? _s : 0 } },
16283
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16249
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16284
16250
  React.createElement(Img$1, { src: src, rec: recData, item: (_x = (_v = (_u = (_t = recData === null || recData === void 0 ? void 0 : recData.video) === null || _t === void 0 ? void 0 : _t.bindProducts) === null || _u === void 0 ? void 0 : _u[0]) !== null && _v !== void 0 ? _v : (_w = recData === null || recData === void 0 ? void 0 : recData.video) === null || _w === void 0 ? void 0 : _w.bindProduct) !== null && _x !== void 0 ? _x : recData === null || recData === void 0 ? void 0 : recData.video, index: index, translateY: translateY, imgStyle: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.img, isActive: isActive }),
16285
16251
  (!recData || (product === null || product === void 0 ? void 0 : product.title)) && (React.createElement("div", { className: styles['one-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.title, dangerouslySetInnerHTML: {
16286
16252
  __html: setFontForText((_y = product === null || product === void 0 ? void 0 : product.title) !== null && _y !== void 0 ? _y : 'Product Name', ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.title)
@@ -16367,7 +16333,7 @@ Made in Italy` })));
16367
16333
  category: 'cta',
16368
16334
  type: 'AniLinkPopup',
16369
16335
  related: {
16370
- settingRender: settingRender$4,
16336
+ settingRender: settingRender$2,
16371
16337
  bindableProps: [],
16372
16338
  interactionRender: interactionRender$2
16373
16339
  },
@@ -16446,7 +16412,7 @@ Made in Italy` })));
16446
16412
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16447
16413
  *
16448
16414
  */
16449
- var settingRender$3 = [
16415
+ var settingRender$1 = [
16450
16416
  {
16451
16417
  title: '全局设置',
16452
16418
  child: [
@@ -16587,27 +16553,74 @@ Made in Italy` })));
16587
16553
  }
16588
16554
  ];
16589
16555
 
16590
- var img$5 = "data:image/svg+xml,%3c%3fxml version='1.0' standalone='no'%3f%3e%3c!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3csvg t='1730260080030' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4241' xmlns:xlink='http://www.w3.org/1999/xlink' width='64' height='64'%3e%3cpath d='M895.156706 86.256941a30.177882 30.177882 0 0 1 42.767059-0.180706c11.745882 11.745882 11.745882 30.870588-0.180706 42.767059L128.843294 937.743059c-11.866353 11.866353-30.930824 12.047059-42.767059 0.180706-11.745882-11.745882-11.745882-30.870588 0.180706-42.767059L895.156706 86.256941z' fill='white' p-id='4242'%3e%3c/path%3e%3cpath d='M86.076235 86.076235c11.745882-11.745882 30.870588-11.745882 42.767059 0.180706l808.899765 808.899765c11.866353 11.866353 12.047059 30.930824 0.180706 42.767059-11.745882 11.745882-30.870588 11.745882-42.767059-0.180706L86.256941 128.843294a30.177882 30.177882 0 0 1-0.180706-42.767059z' fill='white' p-id='4243'%3e%3c/path%3e%3cpath d='M0 0h1024v1024H0z' fill='white' fill-opacity='0' p-id='4244'%3e%3c/path%3e%3c/svg%3e";
16556
+ /*
16557
+ * @Author: binruan@chatlabs.com
16558
+ * @Date: 2023-12-26 10:38:53
16559
+ * @LastEditors: binruan@chatlabs.com
16560
+ * @LastEditTime: 2024-12-11 18:24:31
16561
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16562
+ *
16563
+ */
16564
+ const EditorDataContext = React.createContext({});
16565
+ const EditorDataProvider = ({ children, data }) => {
16566
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16567
+ const [openHashtag, setOpenHashtag] = React.useState(false);
16568
+ const [openConsent, setOpenConsent] = React.useState(false);
16569
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
16570
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
16571
+ return (React.createElement(EditorDataContext.Provider, { value: {
16572
+ sxpPrameter: {
16573
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16574
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16575
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16576
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16577
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16578
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16579
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16580
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16581
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16582
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16583
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16584
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16585
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16586
+ },
16587
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16588
+ openHashtag,
16589
+ setOpenHashtag,
16590
+ openConsent,
16591
+ setOpenConsent,
16592
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16593
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16594
+ consentPopupCate,
16595
+ setConsentPopupCate,
16596
+ openMultiPosts,
16597
+ setOpenMultiPosts,
16598
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16599
+ } }, children));
16600
+ };
16601
+ function useEditorDataProvider() {
16602
+ return React.useContext(EditorDataContext);
16603
+ }
16591
16604
 
16592
- var img$4 = "";
16605
+ var img$3 = "data:image/svg+xml,%3c%3fxml version='1.0' standalone='no'%3f%3e%3c!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3csvg t='1730260080030' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4241' xmlns:xlink='http://www.w3.org/1999/xlink' width='64' height='64'%3e%3cpath d='M895.156706 86.256941a30.177882 30.177882 0 0 1 42.767059-0.180706c11.745882 11.745882 11.745882 30.870588-0.180706 42.767059L128.843294 937.743059c-11.866353 11.866353-30.930824 12.047059-42.767059 0.180706-11.745882-11.745882-11.745882-30.870588 0.180706-42.767059L895.156706 86.256941z' fill='white' p-id='4242'%3e%3c/path%3e%3cpath d='M86.076235 86.076235c11.745882-11.745882 30.870588-11.745882 42.767059 0.180706l808.899765 808.899765c11.866353 11.866353 12.047059 30.930824 0.180706 42.767059-11.745882 11.745882-30.870588 11.745882-42.767059-0.180706L86.256941 128.843294a30.177882 30.177882 0 0 1-0.180706-42.767059z' fill='white' p-id='4243'%3e%3c/path%3e%3cpath d='M0 0h1024v1024H0z' fill='white' fill-opacity='0' p-id='4244'%3e%3c/path%3e%3c/svg%3e";
16606
+
16607
+ var img$2 = "";
16593
16608
 
16594
16609
  const Display$1 = (_a) => {
16595
16610
  var _b, _c;
16596
- var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16611
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16612
+ const { consentPopupCate } = useEditorDataProvider();
16597
16613
  const [isClose, setIsClose] = React.useState(false);
16598
- const contsentState = React.useMemo(() => {
16599
- return getContsentState();
16600
- }, []);
16601
16614
  const visivle = React.useMemo(() => {
16602
- return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16603
- }, [consentPopupCate, open, isClose, contsentState]);
16615
+ return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16616
+ }, [consentPopupCate, open, isClose]);
16604
16617
  const handleClickClose = React.useCallback(() => {
16605
16618
  setIsClose(true);
16606
16619
  }, []);
16607
16620
  const handleClick = React.useCallback(() => {
16608
16621
  onClick === null || onClick === void 0 ? void 0 : onClick();
16609
16622
  }, []);
16610
- return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$4, width: '100%' })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupDisplay', style: style },
16623
+ return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$2, width: '100%' })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupDisplay', style: style },
16611
16624
  React.createElement("div", { style: { flex: 1 } },
16612
16625
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16613
16626
  __html: setFontForText((_b = content === null || content === void 0 ? void 0 : content.text) === null || _b === void 0 ? void 0 : _b.replace(/\n/g, '</br>'), content === null || content === void 0 ? void 0 : content.style)
@@ -16616,7 +16629,7 @@ Made in Italy` })));
16616
16629
  __html: setFontForText((_c = interaction === null || interaction === void 0 ? void 0 : interaction.text) === null || _c === void 0 ? void 0 : _c.replace(/\n/g, '</br>'), interaction === null || interaction === void 0 ? void 0 : interaction.style)
16617
16630
  }, onClick: handleClick })),
16618
16631
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16619
- React.createElement("img", { src: img$5, alt: 'close' })))))))));
16632
+ React.createElement("img", { src: img$3, alt: 'close' })))))))));
16620
16633
  };
16621
16634
  var DisplayComponent = React.memo(Display$1);
16622
16635
 
@@ -16642,7 +16655,7 @@ Made in Italy` })));
16642
16655
  category: 'consentPopup',
16643
16656
  type: 'Display',
16644
16657
  related: {
16645
- settingRender: settingRender$3,
16658
+ settingRender: settingRender$1,
16646
16659
  bindableProps: [],
16647
16660
  interactionRender: interactionRender$1
16648
16661
  },
@@ -16673,415 +16686,6 @@ Made in Italy` })));
16673
16686
  sort: 1
16674
16687
  });
16675
16688
 
16676
- /*
16677
- * @Author: binruan@chatlabs.com
16678
- * @Date: 2023-07-28 18:29:57
16679
- * @LastEditors: binruan@chatlabs.com
16680
- * @LastEditTime: 2025-01-15 10:14:40
16681
- * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16682
- *
16683
- */
16684
- var settingRender$2 = [
16685
- {
16686
- title: '全局设置',
16687
- child: [
16688
- {
16689
- type: 'Switch',
16690
- label: '弹窗开关',
16691
- name: ['props', 'open']
16692
- },
16693
- {
16694
- type: 'Color',
16695
- label: '背景色',
16696
- name: ['style', 'backgroundColor']
16697
- },
16698
- {
16699
- type: 'Number',
16700
- label: '内边距',
16701
- name: ['style', 'padding'],
16702
- addonAfter: 'px'
16703
- }
16704
- ]
16705
- },
16706
- {
16707
- title: '弹窗文本',
16708
- child: [
16709
- {
16710
- type: 'RichText',
16711
- name: ['props', 'content']
16712
- }
16713
- ]
16714
- },
16715
- {
16716
- title: '接受按钮样式',
16717
- child: [
16718
- {
16719
- type: 'Color',
16720
- label: '背景色',
16721
- name: ['props', 'acceptButton', 'style', 'backgroundColor']
16722
- },
16723
- {
16724
- type: 'Number',
16725
- label: '尺寸',
16726
- name: ['props', 'acceptButton', 'style', 'height'],
16727
- addonAfter: 'H'
16728
- },
16729
- {
16730
- type: 'Group',
16731
- label: '圆角',
16732
- child: [
16733
- {
16734
- type: 'Slider',
16735
- name: ['props', 'acceptButton', 'style', 'borderRadius'],
16736
- max: 100
16737
- },
16738
- {
16739
- type: 'Number',
16740
- name: ['props', 'acceptButton', 'style', 'borderRadius'],
16741
- addonAfter: 'px',
16742
- max: 100
16743
- }
16744
- ]
16745
- },
16746
- {
16747
- type: 'TextMargin',
16748
- label: '边距',
16749
- name: ['props', 'acceptButton', 'style']
16750
- },
16751
- {
16752
- type: 'Group',
16753
- label: '字体',
16754
- child: [
16755
- {
16756
- type: 'Select',
16757
- name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16758
- bottomText: '中文字体'
16759
- },
16760
- {
16761
- type: 'Select',
16762
- name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16763
- bottomText: '英文/其他字体'
16764
- }
16765
- ]
16766
- },
16767
- {
16768
- type: 'Group',
16769
- label: '',
16770
- child: [
16771
- {
16772
- type: 'Color',
16773
- name: ['props', 'acceptButton', 'style', 'color']
16774
- },
16775
- {
16776
- type: 'Number',
16777
- name: ['props', 'acceptButton', 'style', 'fontSize'],
16778
- addonAfter: 'px'
16779
- }
16780
- ]
16781
- },
16782
- {
16783
- label: '样式',
16784
- type: 'TextStyle',
16785
- name: ['props', 'acceptButton', 'style']
16786
- },
16787
- {
16788
- label: '对齐',
16789
- type: 'TextAlign',
16790
- name: ['props', 'acceptButton', 'style']
16791
- },
16792
- {
16793
- label: '间距',
16794
- type: 'TextSpace',
16795
- name: ['props', 'acceptButton', 'style']
16796
- },
16797
- {
16798
- label: '文本',
16799
- type: 'TextArea',
16800
- name: ['props', 'acceptButton', 'text']
16801
- }
16802
- ]
16803
- },
16804
- {
16805
- title: '拒绝按钮样式',
16806
- child: [
16807
- {
16808
- type: 'Color',
16809
- label: '背景色',
16810
- name: ['props', 'rejectButton', 'style', 'backgroundColor']
16811
- },
16812
- {
16813
- type: 'Number',
16814
- label: '尺寸',
16815
- name: ['props', 'rejectButton', 'style', 'height'],
16816
- addonAfter: 'H'
16817
- },
16818
- {
16819
- type: 'Group',
16820
- label: '圆角',
16821
- child: [
16822
- {
16823
- type: 'Slider',
16824
- name: ['props', 'rejectButton', 'style', 'borderRadius'],
16825
- max: 100
16826
- },
16827
- {
16828
- type: 'Number',
16829
- name: ['props', 'rejectButton', 'style', 'borderRadius'],
16830
- addonAfter: 'px',
16831
- max: 100
16832
- }
16833
- ]
16834
- },
16835
- {
16836
- type: 'TextMargin',
16837
- label: '边距',
16838
- name: ['props', 'acceptButton', 'style']
16839
- },
16840
- {
16841
- type: 'Group',
16842
- label: '字体',
16843
- child: [
16844
- {
16845
- type: 'Select',
16846
- name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16847
- bottomText: '中文字体'
16848
- },
16849
- {
16850
- type: 'Select',
16851
- name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16852
- bottomText: '英文/其他字体'
16853
- }
16854
- ]
16855
- },
16856
- {
16857
- type: 'Group',
16858
- label: '',
16859
- child: [
16860
- {
16861
- type: 'Color',
16862
- name: ['props', 'rejectButton', 'style', 'color']
16863
- },
16864
- {
16865
- type: 'Number',
16866
- name: ['props', 'rejectButton', 'style', 'fontSize'],
16867
- addonAfter: 'px'
16868
- }
16869
- ]
16870
- },
16871
- {
16872
- label: '样式',
16873
- type: 'TextStyle',
16874
- name: ['props', 'rejectButton', 'style']
16875
- },
16876
- {
16877
- label: '对齐',
16878
- type: 'TextAlign',
16879
- name: ['props', 'rejectButton', 'style']
16880
- },
16881
- {
16882
- label: '间距',
16883
- type: 'TextSpace',
16884
- name: ['props', 'rejectButton', 'style']
16885
- },
16886
- {
16887
- label: '文本',
16888
- type: 'TextArea',
16889
- name: ['props', 'rejectButton', 'text']
16890
- }
16891
- ]
16892
- }
16893
- ];
16894
-
16895
- var img$3 = "";
16896
-
16897
- const Click$1 = (_a) => {
16898
- var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16899
- const visivle = React.useMemo(() => {
16900
- return consentPopupCate || (open && style);
16901
- }, [consentPopupCate, open]);
16902
- const handleClickAccept = () => { };
16903
- const handleClickReject = () => { };
16904
- return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$3, style: { objectFit: 'cover', width: '100%', height: '100%' } })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupClick' },
16905
- React.createElement("div", { className: 'consentPopupClick-container', style: style },
16906
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16907
- React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16908
- React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16909
- };
16910
- var ClickComponent = React.memo(Click$1);
16911
-
16912
- /*
16913
- * @Author: binruan@chatlabs.com
16914
- * @Date: 2025-01-14 16:22:35
16915
- * @LastEditors: binruan@chatlabs.com
16916
- * @LastEditTime: 2025-01-15 17:09:49
16917
- * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16918
- *
16919
- */
16920
- const Click = createMaterial(ClickComponent, {
16921
- displayName: 'Click Consent',
16922
- icon: '',
16923
- category: 'consentPopup',
16924
- type: 'Click',
16925
- related: {
16926
- settingRender: settingRender$2,
16927
- bindableProps: []
16928
- },
16929
- defaulSetting: {
16930
- props: {
16931
- content: '<p><strong><span style="font-size:14px"><span style="line-height:3">Your Cookie Preferences</span></span></strong></p><p>We use cookie, including third-party cookies, to ensure the proper functioning and security of this site, to analyse its use, and to show you personalised content. You can authorise the use of all cookies by clicking on &quot;Accept all cookies&quot;. If you click on &quot;Reject all cookies&quot;, we will only use cookies necessary for the proper functioning and security of this site. To personalise on adjust your preferences at any time, click on &quot;Cookies Settings&quot; below or at the bottom of any Fendi.com webpage. For more information, read our Cookie Policy.</p><p></p>',
16932
- acceptButton: {
16933
- text: 'Accept all cookies',
16934
- style: {
16935
- backgroundColor: '#000',
16936
- height: 45,
16937
- color: '#fff',
16938
- fontSize: 12,
16939
- textAlign: 'center',
16940
- marginTop: 5,
16941
- marginBottom: 5
16942
- }
16943
- },
16944
- rejectButton: {
16945
- text: 'Reject all cookies',
16946
- style: {
16947
- backgroundColor: '#000',
16948
- height: 45,
16949
- color: '#fff',
16950
- fontSize: 12,
16951
- textAlign: 'center',
16952
- marginTop: 5,
16953
- marginBottom: 5
16954
- }
16955
- }
16956
- },
16957
- style: {
16958
- backgroundColor: '#fff',
16959
- padding: 18
16960
- }
16961
- },
16962
- sort: 2
16963
- });
16964
-
16965
- /*
16966
- * @Author: binruan@chatlabs.com
16967
- * @Date: 2023-07-28 18:29:57
16968
- * @LastEditors: binruan@chatlabs.com
16969
- * @LastEditTime: 2025-01-15 17:39:28
16970
- * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16971
- *
16972
- */
16973
- var settingRender$1 = [
16974
- {
16975
- title: '全局设置',
16976
- child: [
16977
- {
16978
- type: 'Switch',
16979
- label: '弹窗开关',
16980
- name: ['props', 'open']
16981
- },
16982
- {
16983
- type: 'Color',
16984
- label: '背景色',
16985
- name: ['style', 'backgroundColor']
16986
- },
16987
- {
16988
- type: 'Number',
16989
- label: '内边距',
16990
- name: ['style', 'padding'],
16991
- addonAfter: 'px'
16992
- }
16993
- ]
16994
- },
16995
- {
16996
- title: '弹窗文本',
16997
- child: [
16998
- {
16999
- type: 'RichText',
17000
- name: ['props', 'content']
17001
- }
17002
- ]
17003
- },
17004
- {
17005
- title: '滑动图标',
17006
- child: [
17007
- {
17008
- type: 'Upload',
17009
- label: '滑动图标',
17010
- name: ['props', 'swipeIcon'],
17011
- text: '建议尺寸:252 * 185'
17012
- }
17013
- ]
17014
- }
17015
- ];
17016
-
17017
- var img$2 = "";
17018
-
17019
- const closeIcon = '';
17020
- const Swipe$1 = (_a) => {
17021
- var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
17022
- const touchInfo = React.useRef();
17023
- const handleTouchStart = (event) => {
17024
- const touch = event.touches[0];
17025
- touchInfo.current = { y: touch.clientY, d: 0 };
17026
- };
17027
- const handleTouchMove = (event) => {
17028
- var _a;
17029
- if (!touchInfo.current)
17030
- return;
17031
- const touch = event.touches[0];
17032
- const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
17033
- const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
17034
- touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
17035
- };
17036
- const handleTouchEnd = () => {
17037
- if (!touchInfo.current)
17038
- return;
17039
- touchInfo.current || {};
17040
- touchInfo.current = {};
17041
- };
17042
- const handleClickReject = () => { };
17043
- const visivle = React.useMemo(() => {
17044
- return consentPopupCate || (open && style);
17045
- }, [consentPopupCate, open]);
17046
- return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$2, style: { objectFit: 'cover', width: '100%', height: '100%' } })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupSwipe', onTouchStart: handleTouchStart, onTouchMove: handleTouchMove, onTouchEnd: handleTouchEnd },
17047
- React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17048
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17049
- React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17050
- React.createElement("img", { src: closeIcon, alt: 'close' })),
17051
- swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17052
- React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17053
- };
17054
- var SwipeComponent = React.memo(Swipe$1);
17055
-
17056
- /*
17057
- * @Author: binruan@chatlabs.com
17058
- * @Date: 2025-01-14 16:22:35
17059
- * @LastEditors: binruan@chatlabs.com
17060
- * @LastEditTime: 2025-01-15 17:09:49
17061
- * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17062
- *
17063
- */
17064
- const Swipe = createMaterial(SwipeComponent, {
17065
- displayName: 'Swipe Consent',
17066
- icon: '',
17067
- category: 'consentPopup',
17068
- type: 'Swipe',
17069
- related: {
17070
- settingRender: settingRender$1,
17071
- bindableProps: []
17072
- },
17073
- defaulSetting: {
17074
- props: {
17075
- content: '<p><span style="font- size: 14px"><strong><span style="line - height: 3">Your Cookie Preferences</span></strong></span></p><p><span style="line- height: 1"><span style="font- size: 12px">We use cookie, including third-party cookies, to</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">ensure the proper functioning and security of</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">this site, to analyse its use, and to show you</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">personalised content.</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">You can authorise the use of all cookies by</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">clicking on &#x27;Accept all cookies&#x27;. If you click on</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">&#x27;Reject all cookies&#x27;, we will only use cookies</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">necessary for the proper functioning and </span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">security of this site. To personalise or adjust</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">your preferences at any time, click on &#x27;Cookies</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">Settings&#x27; below or at the bottom of any</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">Fendi.com webpage.</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">For more information, <u>read our Cookie Policy</u>.</span></span></p>'
17076
- },
17077
- style: {
17078
- backgroundColor: '#fff',
17079
- padding: 18
17080
- }
17081
- },
17082
- sort: 3
17083
- });
17084
-
17085
16689
  /*
17086
16690
  * @Author: binruan@chatlabs.com
17087
16691
  * @Date: 2024-06-13 10:08:32
@@ -17383,7 +16987,6 @@ Made in Italy` })));
17383
16987
  AniLinkPopup: AniLinkPopup,
17384
16988
  Appoint: Appoint,
17385
16989
  AppointForm: AppointForm,
17386
- Click: Click,
17387
16990
  Commodity: Commodity,
17388
16991
  CommodityDetail: CommodityDetail,
17389
16992
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -17400,8 +17003,7 @@ Made in Italy` })));
17400
17003
  MultiCommodityDiro: MultiCommodityDiro,
17401
17004
  MultiCommodityDiroNew: MultiCommodityDiroNew,
17402
17005
  MultiPosts: MultiPosts,
17403
- Prompt: Prompt,
17404
- Swipe: Swipe
17006
+ Prompt: Prompt
17405
17007
  });
17406
17008
 
17407
17009
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -18271,72 +17873,23 @@ Made in Italy` })));
18271
17873
  };
18272
17874
  var Tagbar$1 = React.memo(Tagbar);
18273
17875
 
18274
- /*
18275
- * @Author: binruan@chatlabs.com
18276
- * @Date: 2023-12-26 10:38:53
18277
- * @LastEditors: binruan@chatlabs.com
18278
- * @LastEditTime: 2024-12-11 18:24:31
18279
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18280
- *
18281
- */
18282
- const EditorDataContext = React.createContext({});
18283
- const EditorDataProvider = ({ children, data }) => {
18284
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18285
- const [openHashtag, setOpenHashtag] = React.useState(false);
18286
- const [openConsent, setOpenConsent] = React.useState(false);
18287
- const [consentPopupCate, setConsentPopupCate] = React.useState('');
18288
- const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18289
- return (React.createElement(EditorDataContext.Provider, { value: {
18290
- sxpPrameter: {
18291
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18292
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18293
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18294
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18295
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18296
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18297
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18298
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18299
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18300
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18301
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18302
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18303
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18304
- },
18305
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18306
- openHashtag,
18307
- setOpenHashtag,
18308
- openConsent,
18309
- setOpenConsent,
18310
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18311
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18312
- consentPopupCate,
18313
- setConsentPopupCate,
18314
- openMultiPosts,
18315
- setOpenMultiPosts,
18316
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18317
- } }, children));
18318
- };
18319
- function useEditorDataProvider() {
18320
- return React.useContext(EditorDataContext);
18321
- }
18322
-
18323
17876
  /*
18324
17877
  * @Author: binruan@chatlabs.com
18325
17878
  * @Date: 2023-12-26 16:11:34
18326
17879
  * @LastEditors: binruan@chatlabs.com
18327
- * @LastEditTime: 2025-01-14 18:02:44
17880
+ * @LastEditTime: 2024-11-05 16:29:47
18328
17881
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
18329
17882
  *
18330
17883
  */
18331
17884
  const Consent = ({ resolver, globalConfig }) => {
18332
17885
  var _a, _b;
18333
- const { consentPopupCate } = useEditorDataProvider();
18334
- const value = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consentPopup) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item;
18335
- if (!value)
18336
- return null;
18337
- const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
17886
+ const contsentState = React.useMemo(() => {
17887
+ return getContsentState();
17888
+ }, []);
17889
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
18338
17890
  const Component = withBindDataSource(t);
18339
- return (React.createElement(Component, Object.assign({}, value === null || value === void 0 ? void 0 : value.props, { style: value === null || value === void 0 ? void 0 : value.style, event: (value === null || value === void 0 ? void 0 : value.event) || {}, consentPopupCate: consentPopupCate })));
17891
+ const value = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consentPopup) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item;
17892
+ return React.createElement(Component, Object.assign({}, value === null || value === void 0 ? void 0 : value.props, { style: value === null || value === void 0 ? void 0 : value.style, event: (value === null || value === void 0 ? void 0 : value.event) || {}, contsentState: contsentState }));
18340
17893
  };
18341
17894
  var ConsentPopup = React.memo(Consent);
18342
17895
 
@@ -18359,7 +17912,7 @@ Made in Italy` })));
18359
17912
  * @Author: binruan@chatlabs.com
18360
17913
  * @Date: 2024-03-20 10:27:31
18361
17914
  * @LastEditors: binruan@chatlabs.com
18362
- * @LastEditTime: 2025-01-20 18:46:32
17915
+ * @LastEditTime: 2024-12-18 10:24:20
18363
17916
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
18364
17917
  *
18365
17918
  */
@@ -18454,7 +18007,7 @@ Made in Italy` })));
18454
18007
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
18455
18008
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
18456
18009
  position: activeIndex + '',
18457
- fromKName: fk || fromKName,
18010
+ fromKName: fk ? fk : fromKName,
18458
18011
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
18459
18012
  ctatId: (_r = (_q = (_p = item === null || item === void 0 ? void 0 : item.video) === null || _p === void 0 ? void 0 : _p.bindCta) === null || _q === void 0 ? void 0 : _q.itemId) !== null && _r !== void 0 ? _r : '',
18460
18013
  traceInfo: (_v = (_t = (_s = item === null || item === void 0 ? void 0 : item.video) === null || _s === void 0 ? void 0 : _s.traceInfo) !== null && _t !== void 0 ? _t : (_u = item === null || item === void 0 ? void 0 : item.product) === null || _u === void 0 ? void 0 : _u.traceInfo) !== null && _v !== void 0 ? _v : ''
@@ -18484,12 +18037,9 @@ Made in Italy` })));
18484
18037
  skipLinkRef.current = false;
18485
18038
  }
18486
18039
  // 页面可见时触发,注意页面初始化时不会触发
18487
- refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18488
18040
  handleH5EnterLink();
18489
18041
  if (repCond) {
18490
- setTimeout(() => {
18491
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18492
- });
18042
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18493
18043
  backMainFeed('external', selectTag);
18494
18044
  }
18495
18045
  }