pb-sxp-ui 15.0.1 → 15.0.2

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 (64) hide show
  1. package/dist/index.cjs +594 -144
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +90 -3
  4. package/dist/index.js +594 -144
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +4 -4
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +4 -4
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +594 -144
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +4 -4
  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/index.js +5 -2
  17. package/es/core/context/SxpDataSourceProvider.js +54 -22
  18. package/es/core/utils/materials.js +5 -3
  19. package/es/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  20. package/es/materials/sxp/consentPopup/Click/index.js +19 -0
  21. package/es/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  22. package/es/materials/sxp/consentPopup/Click/material.js +48 -0
  23. package/es/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  24. package/es/materials/sxp/consentPopup/Click/settingRender.js +210 -0
  25. package/es/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  26. package/es/materials/sxp/consentPopup/Display/index.js +7 -5
  27. package/es/materials/sxp/consentPopup/Swipe/index.d.ts +12 -0
  28. package/es/materials/sxp/consentPopup/Swipe/index.js +44 -0
  29. package/es/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  30. package/es/materials/sxp/consentPopup/Swipe/material.js +24 -0
  31. package/es/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  32. package/es/materials/sxp/consentPopup/Swipe/settingRender.js +43 -0
  33. package/es/materials/sxp/consentPopup/index.d.ts +2 -0
  34. package/es/materials/sxp/consentPopup/index.js +2 -0
  35. package/es/materials/sxp/cta/AniLink/index.js +1 -1
  36. package/es/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  37. package/es/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  38. package/es/materials/sxp/popup/ConsentDetail/index.js +2 -2
  39. package/lib/core/components/SxpPageRender/ConsentPopup.js +7 -7
  40. package/lib/core/components/SxpPageRender/Navbar.js +1 -1
  41. package/lib/core/components/SxpPageRender/index.js +5 -2
  42. package/lib/core/context/SxpDataSourceProvider.js +54 -22
  43. package/lib/core/utils/materials.js +5 -3
  44. package/lib/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  45. package/lib/materials/sxp/consentPopup/Click/index.js +21 -0
  46. package/lib/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  47. package/lib/materials/sxp/consentPopup/Click/material.js +52 -0
  48. package/lib/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  49. package/lib/materials/sxp/consentPopup/Click/settingRender.js +212 -0
  50. package/lib/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  51. package/lib/materials/sxp/consentPopup/Display/index.js +7 -5
  52. package/lib/materials/sxp/consentPopup/Swipe/index.d.ts +12 -0
  53. package/lib/materials/sxp/consentPopup/Swipe/index.js +46 -0
  54. package/lib/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  55. package/lib/materials/sxp/consentPopup/Swipe/material.js +28 -0
  56. package/lib/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  57. package/lib/materials/sxp/consentPopup/Swipe/settingRender.js +45 -0
  58. package/lib/materials/sxp/consentPopup/index.d.ts +2 -0
  59. package/lib/materials/sxp/consentPopup/index.js +2 -0
  60. package/lib/materials/sxp/cta/AniLink/index.js +1 -1
  61. package/lib/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  62. package/lib/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  63. package/lib/materials/sxp/popup/ConsentDetail/index.js +2 -2
  64. package/package.json +1 -1
package/dist/index.cjs CHANGED
@@ -714,12 +714,15 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
714
714
  const bffDataSource = React.useMemo(() => {
715
715
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
716
716
  }, [dataSources]);
717
+ const fakeUserId = React.useMemo(() => {
718
+ var _a;
719
+ return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
720
+ }, [bffDataSource]);
717
721
  // bff API 请求方法
718
722
  const bffFetch = React.useCallback((path, options) => {
719
723
  if (!bffDataSource)
720
724
  return;
721
725
  const url = bffDataSource.url;
722
- const fakeUserId = storeAndLoadFeUserId();
723
726
  if (options === null || options === void 0 ? void 0 : options.query) {
724
727
  const queryString = qs.stringify(options.query);
725
728
  path = `${path}?${queryString}`;
@@ -727,19 +730,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
727
730
  // 事件上报优化
728
731
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
729
732
  if (options.type === 'beacon' && navigator.sendBeacon) {
730
- return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
733
+ return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
731
734
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
732
735
  ], { type: 'application/json;charset=UTF-8' }));
733
736
  }
734
737
  return window
735
- .fetch(`${url}/api/v1${path}`, {
738
+ .fetch(`${url}/api/${path}`, {
736
739
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
737
740
  method: options.method,
738
741
  body: JSON.stringify(options.body)
739
742
  })
740
743
  .then((res) => res.json())
741
744
  .catch((err) => Promise.reject(err));
742
- }, [bffDataSource]);
745
+ }, [bffDataSource, fakeUserId]);
743
746
  // 获取推荐视频数据
744
747
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
745
748
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
@@ -777,14 +780,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
777
780
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
778
781
  var _v, _w, _x, _y, _z, _0;
779
782
  query.pageNum = pageNum;
780
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
783
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
781
784
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
782
785
  return undefined;
783
786
  }
784
787
  setLoading(false);
785
788
  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 : []);
786
- setRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
787
- setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
789
+ if ((rtcList === null || rtcList === void 0 ? void 0 : rtcList.length) === 0) {
790
+ setRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
791
+ setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
792
+ }
788
793
  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));
789
794
  if (isNotNullList) {
790
795
  pageNum = pageNum + 1;
@@ -794,12 +799,12 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
794
799
  yield recurveRecList(query);
795
800
  if (!(query === null || query === void 0 ? void 0 : query.hashTag) && result)
796
801
  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 });
797
- return Object.assign(Object.assign({}, result.data), { recList: list });
802
+ return Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list });
798
803
  }
799
804
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
800
805
  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 });
801
806
  }
802
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
807
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
803
808
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
804
809
  return undefined;
805
810
  }
@@ -849,6 +854,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
849
854
  return expire;
850
855
  }, [data]);
851
856
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
857
+ var _a, _b;
852
858
  // 关闭 BFF 事件上报
853
859
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
854
860
  return;
@@ -861,7 +867,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
861
867
  };
862
868
  }
863
869
  const sessionID = storeAndLoadFeSessionId();
864
- 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 + '' }));
870
+ const params = {};
871
+ const queryString = location.search.slice(1);
872
+ (_a = splitUrlParams(queryString)) === null || _a === void 0 ? void 0 : _a.map((val) => {
873
+ const key = val.split('=')[0];
874
+ const value = val.split('=')[1];
875
+ params[key] = value;
876
+ });
877
+ console.log(params, '111');
878
+ const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
879
+ 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 }));
865
880
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
866
881
  const realEventInfo = Object.entries(ef)
867
882
  .map(([k, v]) => v && { name: k, value: v })
@@ -870,14 +885,23 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
870
885
  console.log('userInfo:', userInfo);
871
886
  console.log('eventInfo:', ef);
872
887
  console.log('========= 结束 =========');
873
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
888
+ 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}`, {
874
889
  method: 'POST',
875
890
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
876
891
  type: 'beacon'
877
892
  });
878
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
893
+ }, [
894
+ bffFetch,
895
+ curReqInfo,
896
+ enableReportEvent,
897
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
898
+ layoutVariantId,
899
+ globalConfig,
900
+ playbookType,
901
+ bffDataSource
902
+ ]);
879
903
  const bffFbReport = React.useCallback(({ eventName, product }) => {
880
- var _a, _b, _c, _d, _e;
904
+ var _a, _b, _c, _d, _e, _f;
881
905
  if (!enableReportEvent ||
882
906
  !enabledMetaConversionApi ||
883
907
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -889,7 +913,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
889
913
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
890
914
  const fix_par = {
891
915
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
892
- external_id: storeAndLoadFeUserId(),
916
+ external_id: fakeUserId,
893
917
  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 : '',
894
918
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
895
919
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -941,22 +965,30 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
941
965
  }
942
966
  };
943
967
  getEventParams(jsonParams);
944
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
968
+ 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}`, {
945
969
  method: 'POST',
946
970
  body: jsonParams,
947
971
  type: 'beacon'
948
972
  });
949
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
973
+ }, [
974
+ bffFetch,
975
+ enableReportEvent,
976
+ enabledMetaConversionApi,
977
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
978
+ globalConfig,
979
+ fakeUserId,
980
+ bffDataSource
981
+ ]);
950
982
  const bffMutateLike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
951
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
983
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
952
984
  return res === null || res === void 0 ? void 0 : res.success;
953
985
  }), [bffFetch]);
954
986
  const bffMutateUnlike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
955
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
987
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
956
988
  return res === null || res === void 0 ? void 0 : res.success;
957
989
  }), [bffFetch]);
958
990
  const bffSubmitForm = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
959
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
991
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
960
992
  return res === null || res === void 0 ? void 0 : res.success;
961
993
  }), [bffFetch]);
962
994
  // 获取 Tag
@@ -971,7 +1003,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
971
1003
  const key = val.split('=')[0];
972
1004
  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);
973
1005
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
974
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
1006
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
975
1007
  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 : []);
976
1008
  }
977
1009
  catch (e) {
@@ -1050,10 +1082,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1050
1082
  let curData;
1051
1083
  let gldata;
1052
1084
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1085
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1086
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1053
1087
  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];
1054
1088
  if (id) {
1055
- layId = id;
1056
- setLayoutVariantId(id);
1057
1089
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1058
1090
  if (curData) {
1059
1091
  setPageData(curData);
@@ -1439,7 +1471,7 @@ var interactionRender$g = [
1439
1471
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1440
1472
  *
1441
1473
  */
1442
- var settingRender$d = [
1474
+ var settingRender$f = [
1443
1475
  {
1444
1476
  title: '弹窗背景',
1445
1477
  child: [
@@ -1875,7 +1907,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1875
1907
  category: 'popup',
1876
1908
  type: 'AppointForm',
1877
1909
  related: {
1878
- settingRender: settingRender$d,
1910
+ settingRender: settingRender$f,
1879
1911
  bindableProps: [],
1880
1912
  interactionRender: interactionRender$g
1881
1913
  },
@@ -1900,7 +1932,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1900
1932
  sort: 2
1901
1933
  });
1902
1934
 
1903
- var settingRender$c = [
1935
+ var settingRender$e = [
1904
1936
  {
1905
1937
  title: '弹窗背景',
1906
1938
  child: [
@@ -9789,7 +9821,7 @@ SwiperSlide.displayName = 'SwiperSlide';
9789
9821
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9790
9822
  *
9791
9823
  */
9792
- const closeIcon$1 = '';
9824
+ const closeIcon$2 = '';
9793
9825
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9794
9826
  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;
9795
9827
  const touchRef = React.useRef(null);
@@ -9969,7 +10001,7 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema,
9969
10001
  }
9970
10002
  })), child()),
9971
10003
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9972
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
10004
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9973
10005
  };
9974
10006
  var Modal$1 = React.memo(Modal);
9975
10007
 
@@ -10140,7 +10172,7 @@ var CommodityGroup$1 = React.memo(CommodityGroup);
10140
10172
  * @Author: binruan@chatlabs.com
10141
10173
  * @Date: 2024-03-20 14:56:16
10142
10174
  * @LastEditors: binruan@chatlabs.com
10143
- * @LastEditTime: 2024-10-24 17:51:19
10175
+ * @LastEditTime: 2024-12-20 14:32:26
10144
10176
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10145
10177
  *
10146
10178
  */
@@ -10178,14 +10210,16 @@ const getBgStyle = (imgSrc) => {
10178
10210
  };
10179
10211
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10180
10212
  var _a, _b, _c, _d, _e, _f, _g, _h;
10213
+ let text = '';
10181
10214
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10182
10215
  return null;
10183
- 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;
10184
- let text = '';
10216
+ 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);
10217
+ if (typeof price !== 'number')
10218
+ return text;
10185
10219
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10186
10220
  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 : '' : '$';
10187
10221
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10188
- let decPic = price.toString();
10222
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10189
10223
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10190
10224
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10191
10225
  }
@@ -10497,7 +10531,7 @@ const CommodityDetail = createMaterial(CommodityDetailComponent, {
10497
10531
  category: 'popup',
10498
10532
  type: 'CommodityDetail',
10499
10533
  related: {
10500
- settingRender: settingRender$c,
10534
+ settingRender: settingRender$e,
10501
10535
  interactionRender: interactionRender$f
10502
10536
  },
10503
10537
  defaulSetting: {
@@ -10573,7 +10607,7 @@ var interactionRender$e = [
10573
10607
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10574
10608
  *
10575
10609
  */
10576
- var settingRender$b = [
10610
+ var settingRender$d = [
10577
10611
  {
10578
10612
  title: '弹窗背景',
10579
10613
  child: [
@@ -10714,7 +10748,7 @@ var settingRender$b = [
10714
10748
  }
10715
10749
  ];
10716
10750
 
10717
- var img$5 = "";
10751
+ var img$7 = "";
10718
10752
 
10719
10753
  const Prompt$1 = (_a) => {
10720
10754
  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"]);
@@ -10737,7 +10771,7 @@ const Prompt$1 = (_a) => {
10737
10771
  };
10738
10772
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10739
10773
  React.createElement("div", { className: 'pb-prompt-icon' },
10740
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10774
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10741
10775
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10742
10776
  __html: setFontForText(content, contentStyle)
10743
10777
  } }),
@@ -10753,13 +10787,13 @@ const Prompt = createMaterial(PromptComponent, {
10753
10787
  category: 'popup',
10754
10788
  type: 'Prompt',
10755
10789
  related: {
10756
- settingRender: settingRender$b,
10790
+ settingRender: settingRender$d,
10757
10791
  bindableProps: [],
10758
10792
  interactionRender: interactionRender$e
10759
10793
  },
10760
10794
  defaulSetting: {
10761
10795
  props: {
10762
- icon: img$5,
10796
+ icon: img$7,
10763
10797
  content: 'You have successfully completed the appointment!',
10764
10798
  btnText: 'OK'
10765
10799
  },
@@ -10778,7 +10812,7 @@ const Prompt = createMaterial(PromptComponent, {
10778
10812
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10779
10813
  *
10780
10814
  */
10781
- var settingRender$a = [
10815
+ var settingRender$c = [
10782
10816
  {
10783
10817
  title: '弹窗背景',
10784
10818
  child: [
@@ -11457,7 +11491,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11457
11491
  category: 'popup',
11458
11492
  type: 'CommodityDetailDiroNew',
11459
11493
  related: {
11460
- settingRender: settingRender$a,
11494
+ settingRender: settingRender$c,
11461
11495
  interactionRender: interactionRender$d
11462
11496
  },
11463
11497
  defaulSetting: {
@@ -11521,7 +11555,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11521
11555
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11522
11556
  *
11523
11557
  */
11524
- var settingRender$9 = [
11558
+ var settingRender$b = [
11525
11559
  {
11526
11560
  title: '弹窗背景',
11527
11561
  child: [
@@ -11958,7 +11992,7 @@ const CommodityList = createMaterial(CommodityListComponent, {
11958
11992
  category: 'popup',
11959
11993
  type: 'CommodityList',
11960
11994
  related: {
11961
- settingRender: settingRender$9,
11995
+ settingRender: settingRender$b,
11962
11996
  interactionRender: interactionRender$c
11963
11997
  },
11964
11998
  defaulSetting: {
@@ -12007,7 +12041,7 @@ const CommodityList = createMaterial(CommodityListComponent, {
12007
12041
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
12008
12042
  *
12009
12043
  */
12010
- var settingRender$8 = [
12044
+ var settingRender$a = [
12011
12045
  {
12012
12046
  title: '背景样式',
12013
12047
  child: [
@@ -12041,7 +12075,7 @@ const Iframe = createMaterial(IframeComponent, {
12041
12075
  category: 'popup',
12042
12076
  type: 'Iframe',
12043
12077
  related: {
12044
- settingRender: settingRender$8,
12078
+ settingRender: settingRender$a,
12045
12079
  bindableProps: []
12046
12080
  },
12047
12081
  defaulSetting: {
@@ -12061,7 +12095,7 @@ const Iframe = createMaterial(IframeComponent, {
12061
12095
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12062
12096
  *
12063
12097
  */
12064
- var settingRender$7 = [
12098
+ var settingRender$9 = [
12065
12099
  {
12066
12100
  title: '弹窗文本',
12067
12101
  child: [
@@ -12074,22 +12108,22 @@ var settingRender$7 = [
12074
12108
  ];
12075
12109
 
12076
12110
  const ConsentDetail$1 = (_a) => {
12077
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12111
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12078
12112
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12079
12113
  __html: typeof content === 'string' ? content : ''
12080
12114
  }, onClick: (e) => {
12081
12115
  e.stopPropagation();
12082
- } }));
12116
+ }, style: style }));
12083
12117
  };
12084
- var ConsentDetailComponent = React.memo(ConsentDetail$1);
12118
+ var ConsentDetail$2 = React.memo(ConsentDetail$1);
12085
12119
 
12086
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12120
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12087
12121
  displayName: '协议详情',
12088
12122
  icon: '',
12089
12123
  category: 'popup',
12090
12124
  type: 'ConsentDetail',
12091
12125
  related: {
12092
- settingRender: settingRender$7,
12126
+ settingRender: settingRender$9,
12093
12127
  bindableProps: []
12094
12128
  },
12095
12129
  defaulSetting: {
@@ -12109,7 +12143,7 @@ const ConsentDetail = createMaterial(ConsentDetailComponent, {
12109
12143
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12110
12144
  *
12111
12145
  */
12112
- var settingRender$6 = [
12146
+ var settingRender$8 = [
12113
12147
  {
12114
12148
  title: '主题样式',
12115
12149
  child: [
@@ -12463,7 +12497,7 @@ const Commodity = createMaterial(CommodityComponent, {
12463
12497
  related: {
12464
12498
  interactionRender: interactionRender$b,
12465
12499
  bindableProps: [],
12466
- settingRender: settingRender$6
12500
+ settingRender: settingRender$8
12467
12501
  },
12468
12502
  defaulSetting: {
12469
12503
  props: {
@@ -12545,7 +12579,7 @@ const Appoint = createMaterial(AppointComponent, {
12545
12579
  type: 'Appoint',
12546
12580
  related: {
12547
12581
  interactionRender: interactionRender$a,
12548
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12582
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12549
12583
  bindableProps: []
12550
12584
  },
12551
12585
  defaulSetting: {
@@ -12751,7 +12785,7 @@ const Link = createMaterial(LinkComponent, {
12751
12785
  category: 'template',
12752
12786
  type: 'Link',
12753
12787
  related: {
12754
- 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),
12788
+ 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),
12755
12789
  bindableProps: [],
12756
12790
  interactionRender: interactionRender$9
12757
12791
  },
@@ -12854,7 +12888,7 @@ const CommodityDiro = createMaterial(CommodityDiroComponent, {
12854
12888
  type: 'CommodityDiro',
12855
12889
  related: {
12856
12890
  interactionRender: interactionRender$8,
12857
- settingRender: settingRender$6,
12891
+ settingRender: settingRender$8,
12858
12892
  bindableProps: []
12859
12893
  },
12860
12894
  defaulSetting: {
@@ -12951,7 +12985,7 @@ const CommodityDiroNew = createMaterial(CommodityDiroNewComponent, {
12951
12985
  related: {
12952
12986
  interactionRender: interactionRender$7,
12953
12987
  bindableProps: [],
12954
- settingRender: settingRender$6
12988
+ settingRender: settingRender$8
12955
12989
  },
12956
12990
  defaulSetting: {
12957
12991
  props: {
@@ -13051,7 +13085,7 @@ const MultiCommodityDiro = createMaterial(MultiCommodityDiroComponent, {
13051
13085
  related: {
13052
13086
  interactionRender: interactionRender$6,
13053
13087
  bindableProps: [],
13054
- settingRender: settingRender$6
13088
+ settingRender: settingRender$8
13055
13089
  },
13056
13090
  defaulSetting: {
13057
13091
  props: {
@@ -13149,7 +13183,7 @@ const MultiCommodity = createMaterial(MultiCommodityComponent, {
13149
13183
  type: 'MultiCommodity',
13150
13184
  related: {
13151
13185
  interactionRender: interactionRender$5,
13152
- settingRender: settingRender$6,
13186
+ settingRender: settingRender$8,
13153
13187
  bindableProps: []
13154
13188
  },
13155
13189
  defaulSetting: {
@@ -13258,7 +13292,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13258
13292
  related: {
13259
13293
  interactionRender: interactionRender$4,
13260
13294
  bindableProps: [],
13261
- settingRender: settingRender$6
13295
+ settingRender: settingRender$8
13262
13296
  },
13263
13297
  defaulSetting: {
13264
13298
  props: {
@@ -13307,7 +13341,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13307
13341
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13308
13342
  *
13309
13343
  */
13310
- var settingRender$5 = [
13344
+ var settingRender$7 = [
13311
13345
  {
13312
13346
  title: 'Banner',
13313
13347
  child: [
@@ -13539,7 +13573,7 @@ var settingRender$5 = [
13539
13573
  * @Author: binruan@chatlabs.com
13540
13574
  * @Date: 2023-12-26 16:11:34
13541
13575
  * @LastEditors: binruan@chatlabs.com
13542
- * @LastEditTime: 2024-10-11 18:22:21
13576
+ * @LastEditTime: 2025-01-17 18:55:14
13543
13577
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Navbar.tsx
13544
13578
  *
13545
13579
  */
@@ -13550,7 +13584,7 @@ const Navbar = ({ icon, styles, textStyle, onClose }) => {
13550
13584
  React.createElement("button", { className: 'clc-sxp-nav-left', role: 'button', "aria-label": 'back button', onClick: onClose },
13551
13585
  React.createElement("img", { src: icon, alt: 'back button' })),
13552
13586
  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: {
13553
- __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : '标题'}`, textStyle)
13587
+ __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : 'title'}`, textStyle)
13554
13588
  } })));
13555
13589
  };
13556
13590
  var Navbar$1 = React.memo(Navbar);
@@ -15134,7 +15168,7 @@ function WaterfallList$1(_a) {
15134
15168
  } }))))));
15135
15169
  }
15136
15170
 
15137
- var img$4 = "";
15171
+ var img$6 = "";
15138
15172
 
15139
15173
  const WaterfallFlowItem = (props) => {
15140
15174
  var _a;
@@ -15455,7 +15489,7 @@ const WaterFall = (props) => {
15455
15489
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15456
15490
  display: openHashtag ? 'block' : 'none'
15457
15491
  } },
15458
- 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 }),
15492
+ 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 }),
15459
15493
  ((_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);
15460
15494
  };
15461
15495
  var WaterFall$1 = React.memo(WaterFall);
@@ -15487,7 +15521,7 @@ const HashTag = createMaterial(HashTagComponent, {
15487
15521
  category: 'base',
15488
15522
  type: 'HashTag',
15489
15523
  related: {
15490
- settingRender: settingRender$5,
15524
+ settingRender: settingRender$7,
15491
15525
  bindableProps: []
15492
15526
  },
15493
15527
  defaulSetting: {
@@ -15553,7 +15587,7 @@ const HashTag = createMaterial(HashTagComponent, {
15553
15587
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15554
15588
  *
15555
15589
  */
15556
- var settingRender$4 = [
15590
+ var settingRender$6 = [
15557
15591
  {
15558
15592
  title: '协议详情',
15559
15593
  child: [
@@ -15612,7 +15646,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15612
15646
  category: 'base',
15613
15647
  type: 'Consent',
15614
15648
  related: {
15615
- settingRender: settingRender$4
15649
+ settingRender: settingRender$6
15616
15650
  },
15617
15651
  defaulSetting: {
15618
15652
  props: {},
@@ -15631,7 +15665,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15631
15665
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15632
15666
  *
15633
15667
  */
15634
- var settingRender$3 = [
15668
+ var settingRender$5 = [
15635
15669
  {
15636
15670
  title: '主题样式',
15637
15671
  child: [
@@ -15776,7 +15810,7 @@ const AniLink$1 = (_a) => {
15776
15810
  onClick === null || onClick === void 0 ? void 0 : onClick();
15777
15811
  }
15778
15812
  };
15779
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
15813
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
15780
15814
  const aniTimStyle = React.useMemo(() => {
15781
15815
  var _a, _b;
15782
15816
  const ani = event === null || event === void 0 ? void 0 : event.animation;
@@ -15892,7 +15926,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15892
15926
  category: 'cta',
15893
15927
  type: 'AniLink',
15894
15928
  related: {
15895
- settingRender: settingRender$3,
15929
+ settingRender: settingRender$5,
15896
15930
  bindableProps: [],
15897
15931
  interactionRender: interactionRender$3
15898
15932
  },
@@ -15936,7 +15970,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15936
15970
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15937
15971
  *
15938
15972
  */
15939
- var settingRender$2 = [
15973
+ var settingRender$4 = [
15940
15974
  {
15941
15975
  title: '主题样式',
15942
15976
  child: [
@@ -16194,7 +16228,7 @@ var settingRender$2 = [
16194
16228
 
16195
16229
  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"};
16196
16230
 
16197
- const closeIcon = '';
16231
+ const closeIcon$1 = '';
16198
16232
  const AniLinkPopup$1 = (_a) => {
16199
16233
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16200
16234
  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"]);
@@ -16223,7 +16257,7 @@ const AniLinkPopup$1 = (_a) => {
16223
16257
  onClick === null || onClick === void 0 ? void 0 : onClick();
16224
16258
  }
16225
16259
  };
16226
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
16260
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
16227
16261
  const aniTimStyle = React.useMemo(() => {
16228
16262
  const ani = event === null || event === void 0 ? void 0 : event.animation;
16229
16263
  if (ani) {
@@ -16253,7 +16287,7 @@ const AniLinkPopup$1 = (_a) => {
16253
16287
  paddingLeft: '6px'
16254
16288
  } }, "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 }),
16255
16289
  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 } },
16256
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16290
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16257
16291
  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 }),
16258
16292
  (!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: {
16259
16293
  __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)
@@ -16340,7 +16374,7 @@ const AniLinkPopup = createMaterial(AniLinkPopupComponent, {
16340
16374
  category: 'cta',
16341
16375
  type: 'AniLinkPopup',
16342
16376
  related: {
16343
- settingRender: settingRender$2,
16377
+ settingRender: settingRender$4,
16344
16378
  bindableProps: [],
16345
16379
  interactionRender: interactionRender$2
16346
16380
  },
@@ -16419,7 +16453,7 @@ var interactionRender$1 = [
16419
16453
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16420
16454
  *
16421
16455
  */
16422
- var settingRender$1 = [
16456
+ var settingRender$3 = [
16423
16457
  {
16424
16458
  title: '全局设置',
16425
16459
  child: [
@@ -16560,74 +16594,27 @@ var settingRender$1 = [
16560
16594
  }
16561
16595
  ];
16562
16596
 
16563
- /*
16564
- * @Author: binruan@chatlabs.com
16565
- * @Date: 2023-12-26 10:38:53
16566
- * @LastEditors: binruan@chatlabs.com
16567
- * @LastEditTime: 2024-12-11 18:24:31
16568
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16569
- *
16570
- */
16571
- const EditorDataContext = React.createContext({});
16572
- const EditorDataProvider = ({ children, data }) => {
16573
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16574
- const [openHashtag, setOpenHashtag] = React.useState(false);
16575
- const [openConsent, setOpenConsent] = React.useState(false);
16576
- const [consentPopupCate, setConsentPopupCate] = React.useState('');
16577
- const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
16578
- return (React.createElement(EditorDataContext.Provider, { value: {
16579
- sxpPrameter: {
16580
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16581
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16582
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16583
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16584
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16585
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16586
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16587
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16588
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16589
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16590
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16591
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16592
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16593
- },
16594
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16595
- openHashtag,
16596
- setOpenHashtag,
16597
- openConsent,
16598
- setOpenConsent,
16599
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16600
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16601
- consentPopupCate,
16602
- setConsentPopupCate,
16603
- openMultiPosts,
16604
- setOpenMultiPosts,
16605
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16606
- } }, children));
16607
- };
16608
- function useEditorDataProvider() {
16609
- return React.useContext(EditorDataContext);
16610
- }
16611
-
16612
- 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";
16597
+ 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";
16613
16598
 
16614
- var img$2 = "";
16599
+ var img$4 = "";
16615
16600
 
16616
16601
  const Display$1 = (_a) => {
16617
16602
  var _b, _c;
16618
- var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16619
- const { consentPopupCate } = useEditorDataProvider();
16603
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16620
16604
  const [isClose, setIsClose] = React.useState(false);
16605
+ const contsentState = React.useMemo(() => {
16606
+ return getContsentState();
16607
+ }, []);
16621
16608
  const visivle = React.useMemo(() => {
16622
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16623
- }, [consentPopupCate, open, isClose]);
16609
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16610
+ }, [consentPopupCate, open, isClose, contsentState]);
16624
16611
  const handleClickClose = React.useCallback(() => {
16625
16612
  setIsClose(true);
16626
16613
  }, []);
16627
16614
  const handleClick = React.useCallback(() => {
16628
16615
  onClick === null || onClick === void 0 ? void 0 : onClick();
16629
16616
  }, []);
16630
- 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 },
16617
+ 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 },
16631
16618
  React.createElement("div", { style: { flex: 1 } },
16632
16619
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16633
16620
  __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)
@@ -16636,7 +16623,7 @@ const Display$1 = (_a) => {
16636
16623
  __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)
16637
16624
  }, onClick: handleClick })),
16638
16625
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16639
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16626
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16640
16627
  };
16641
16628
  var DisplayComponent = React.memo(Display$1);
16642
16629
 
@@ -16662,7 +16649,7 @@ const Display = createMaterial(DisplayComponent, {
16662
16649
  category: 'consentPopup',
16663
16650
  type: 'Display',
16664
16651
  related: {
16665
- settingRender: settingRender$1,
16652
+ settingRender: settingRender$3,
16666
16653
  bindableProps: [],
16667
16654
  interactionRender: interactionRender$1
16668
16655
  },
@@ -16693,6 +16680,415 @@ const Display = createMaterial(DisplayComponent, {
16693
16680
  sort: 1
16694
16681
  });
16695
16682
 
16683
+ /*
16684
+ * @Author: binruan@chatlabs.com
16685
+ * @Date: 2023-07-28 18:29:57
16686
+ * @LastEditors: binruan@chatlabs.com
16687
+ * @LastEditTime: 2025-01-15 10:14:40
16688
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16689
+ *
16690
+ */
16691
+ var settingRender$2 = [
16692
+ {
16693
+ title: '全局设置',
16694
+ child: [
16695
+ {
16696
+ type: 'Switch',
16697
+ label: '弹窗开关',
16698
+ name: ['props', 'open']
16699
+ },
16700
+ {
16701
+ type: 'Color',
16702
+ label: '背景色',
16703
+ name: ['style', 'backgroundColor']
16704
+ },
16705
+ {
16706
+ type: 'Number',
16707
+ label: '内边距',
16708
+ name: ['style', 'padding'],
16709
+ addonAfter: 'px'
16710
+ }
16711
+ ]
16712
+ },
16713
+ {
16714
+ title: '弹窗文本',
16715
+ child: [
16716
+ {
16717
+ type: 'RichText',
16718
+ name: ['props', 'content']
16719
+ }
16720
+ ]
16721
+ },
16722
+ {
16723
+ title: '接受按钮样式',
16724
+ child: [
16725
+ {
16726
+ type: 'Color',
16727
+ label: '背景色',
16728
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16729
+ },
16730
+ {
16731
+ type: 'Number',
16732
+ label: '尺寸',
16733
+ name: ['props', 'acceptButton', 'style', 'height'],
16734
+ addonAfter: 'H'
16735
+ },
16736
+ {
16737
+ type: 'Group',
16738
+ label: '圆角',
16739
+ child: [
16740
+ {
16741
+ type: 'Slider',
16742
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16743
+ max: 100
16744
+ },
16745
+ {
16746
+ type: 'Number',
16747
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16748
+ addonAfter: 'px',
16749
+ max: 100
16750
+ }
16751
+ ]
16752
+ },
16753
+ {
16754
+ type: 'TextMargin',
16755
+ label: '边距',
16756
+ name: ['props', 'acceptButton', 'style']
16757
+ },
16758
+ {
16759
+ type: 'Group',
16760
+ label: '字体',
16761
+ child: [
16762
+ {
16763
+ type: 'Select',
16764
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16765
+ bottomText: '中文字体'
16766
+ },
16767
+ {
16768
+ type: 'Select',
16769
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16770
+ bottomText: '英文/其他字体'
16771
+ }
16772
+ ]
16773
+ },
16774
+ {
16775
+ type: 'Group',
16776
+ label: '',
16777
+ child: [
16778
+ {
16779
+ type: 'Color',
16780
+ name: ['props', 'acceptButton', 'style', 'color']
16781
+ },
16782
+ {
16783
+ type: 'Number',
16784
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16785
+ addonAfter: 'px'
16786
+ }
16787
+ ]
16788
+ },
16789
+ {
16790
+ label: '样式',
16791
+ type: 'TextStyle',
16792
+ name: ['props', 'acceptButton', 'style']
16793
+ },
16794
+ {
16795
+ label: '对齐',
16796
+ type: 'TextAlign',
16797
+ name: ['props', 'acceptButton', 'style']
16798
+ },
16799
+ {
16800
+ label: '间距',
16801
+ type: 'TextSpace',
16802
+ name: ['props', 'acceptButton', 'style']
16803
+ },
16804
+ {
16805
+ label: '文本',
16806
+ type: 'TextArea',
16807
+ name: ['props', 'acceptButton', 'text']
16808
+ }
16809
+ ]
16810
+ },
16811
+ {
16812
+ title: '拒绝按钮样式',
16813
+ child: [
16814
+ {
16815
+ type: 'Color',
16816
+ label: '背景色',
16817
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16818
+ },
16819
+ {
16820
+ type: 'Number',
16821
+ label: '尺寸',
16822
+ name: ['props', 'rejectButton', 'style', 'height'],
16823
+ addonAfter: 'H'
16824
+ },
16825
+ {
16826
+ type: 'Group',
16827
+ label: '圆角',
16828
+ child: [
16829
+ {
16830
+ type: 'Slider',
16831
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16832
+ max: 100
16833
+ },
16834
+ {
16835
+ type: 'Number',
16836
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16837
+ addonAfter: 'px',
16838
+ max: 100
16839
+ }
16840
+ ]
16841
+ },
16842
+ {
16843
+ type: 'TextMargin',
16844
+ label: '边距',
16845
+ name: ['props', 'acceptButton', 'style']
16846
+ },
16847
+ {
16848
+ type: 'Group',
16849
+ label: '字体',
16850
+ child: [
16851
+ {
16852
+ type: 'Select',
16853
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16854
+ bottomText: '中文字体'
16855
+ },
16856
+ {
16857
+ type: 'Select',
16858
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16859
+ bottomText: '英文/其他字体'
16860
+ }
16861
+ ]
16862
+ },
16863
+ {
16864
+ type: 'Group',
16865
+ label: '',
16866
+ child: [
16867
+ {
16868
+ type: 'Color',
16869
+ name: ['props', 'rejectButton', 'style', 'color']
16870
+ },
16871
+ {
16872
+ type: 'Number',
16873
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16874
+ addonAfter: 'px'
16875
+ }
16876
+ ]
16877
+ },
16878
+ {
16879
+ label: '样式',
16880
+ type: 'TextStyle',
16881
+ name: ['props', 'rejectButton', 'style']
16882
+ },
16883
+ {
16884
+ label: '对齐',
16885
+ type: 'TextAlign',
16886
+ name: ['props', 'rejectButton', 'style']
16887
+ },
16888
+ {
16889
+ label: '间距',
16890
+ type: 'TextSpace',
16891
+ name: ['props', 'rejectButton', 'style']
16892
+ },
16893
+ {
16894
+ label: '文本',
16895
+ type: 'TextArea',
16896
+ name: ['props', 'rejectButton', 'text']
16897
+ }
16898
+ ]
16899
+ }
16900
+ ];
16901
+
16902
+ var img$3 = "";
16903
+
16904
+ const Click$1 = (_a) => {
16905
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16906
+ const visivle = React.useMemo(() => {
16907
+ return consentPopupCate || (open && style);
16908
+ }, [consentPopupCate, open]);
16909
+ const handleClickAccept = () => { };
16910
+ const handleClickReject = () => { };
16911
+ 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' },
16912
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16913
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16914
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16915
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16916
+ };
16917
+ var ClickComponent = React.memo(Click$1);
16918
+
16919
+ /*
16920
+ * @Author: binruan@chatlabs.com
16921
+ * @Date: 2025-01-14 16:22:35
16922
+ * @LastEditors: binruan@chatlabs.com
16923
+ * @LastEditTime: 2025-01-15 17:09:49
16924
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16925
+ *
16926
+ */
16927
+ const Click = createMaterial(ClickComponent, {
16928
+ displayName: 'Click Consent',
16929
+ icon: '',
16930
+ category: 'consentPopup',
16931
+ type: 'Click',
16932
+ related: {
16933
+ settingRender: settingRender$2,
16934
+ bindableProps: []
16935
+ },
16936
+ defaulSetting: {
16937
+ props: {
16938
+ 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>',
16939
+ acceptButton: {
16940
+ text: 'Accept all cookies',
16941
+ style: {
16942
+ backgroundColor: '#000',
16943
+ height: 45,
16944
+ color: '#fff',
16945
+ fontSize: 12,
16946
+ textAlign: 'center',
16947
+ marginTop: 5,
16948
+ marginBottom: 5
16949
+ }
16950
+ },
16951
+ rejectButton: {
16952
+ text: 'Reject all cookies',
16953
+ style: {
16954
+ backgroundColor: '#000',
16955
+ height: 45,
16956
+ color: '#fff',
16957
+ fontSize: 12,
16958
+ textAlign: 'center',
16959
+ marginTop: 5,
16960
+ marginBottom: 5
16961
+ }
16962
+ }
16963
+ },
16964
+ style: {
16965
+ backgroundColor: '#fff',
16966
+ padding: 18
16967
+ }
16968
+ },
16969
+ sort: 2
16970
+ });
16971
+
16972
+ /*
16973
+ * @Author: binruan@chatlabs.com
16974
+ * @Date: 2023-07-28 18:29:57
16975
+ * @LastEditors: binruan@chatlabs.com
16976
+ * @LastEditTime: 2025-01-15 17:39:28
16977
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16978
+ *
16979
+ */
16980
+ var settingRender$1 = [
16981
+ {
16982
+ title: '全局设置',
16983
+ child: [
16984
+ {
16985
+ type: 'Switch',
16986
+ label: '弹窗开关',
16987
+ name: ['props', 'open']
16988
+ },
16989
+ {
16990
+ type: 'Color',
16991
+ label: '背景色',
16992
+ name: ['style', 'backgroundColor']
16993
+ },
16994
+ {
16995
+ type: 'Number',
16996
+ label: '内边距',
16997
+ name: ['style', 'padding'],
16998
+ addonAfter: 'px'
16999
+ }
17000
+ ]
17001
+ },
17002
+ {
17003
+ title: '弹窗文本',
17004
+ child: [
17005
+ {
17006
+ type: 'RichText',
17007
+ name: ['props', 'content']
17008
+ }
17009
+ ]
17010
+ },
17011
+ {
17012
+ title: '滑动图标',
17013
+ child: [
17014
+ {
17015
+ type: 'Upload',
17016
+ label: '滑动图标',
17017
+ name: ['props', 'swipeIcon'],
17018
+ text: '建议尺寸:252 * 185'
17019
+ }
17020
+ ]
17021
+ }
17022
+ ];
17023
+
17024
+ var img$2 = "";
17025
+
17026
+ const closeIcon = '';
17027
+ const Swipe$1 = (_a) => {
17028
+ var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
17029
+ const touchInfo = React.useRef();
17030
+ const handleTouchStart = (event) => {
17031
+ const touch = event.touches[0];
17032
+ touchInfo.current = { y: touch.clientY, d: 0 };
17033
+ };
17034
+ const handleTouchMove = (event) => {
17035
+ var _a;
17036
+ if (!touchInfo.current)
17037
+ return;
17038
+ const touch = event.touches[0];
17039
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
17040
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
17041
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
17042
+ };
17043
+ const handleTouchEnd = () => {
17044
+ if (!touchInfo.current)
17045
+ return;
17046
+ touchInfo.current || {};
17047
+ touchInfo.current = {};
17048
+ };
17049
+ const handleClickReject = () => { };
17050
+ const visivle = React.useMemo(() => {
17051
+ return consentPopupCate || (open && style);
17052
+ }, [consentPopupCate, open]);
17053
+ 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 },
17054
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17055
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17056
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17057
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
17058
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17059
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17060
+ };
17061
+ var SwipeComponent = React.memo(Swipe$1);
17062
+
17063
+ /*
17064
+ * @Author: binruan@chatlabs.com
17065
+ * @Date: 2025-01-14 16:22:35
17066
+ * @LastEditors: binruan@chatlabs.com
17067
+ * @LastEditTime: 2025-01-15 17:09:49
17068
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17069
+ *
17070
+ */
17071
+ const Swipe = createMaterial(SwipeComponent, {
17072
+ displayName: 'Swipe Consent',
17073
+ icon: '',
17074
+ category: 'consentPopup',
17075
+ type: 'Swipe',
17076
+ related: {
17077
+ settingRender: settingRender$1,
17078
+ bindableProps: []
17079
+ },
17080
+ defaulSetting: {
17081
+ props: {
17082
+ 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>'
17083
+ },
17084
+ style: {
17085
+ backgroundColor: '#fff',
17086
+ padding: 18
17087
+ }
17088
+ },
17089
+ sort: 3
17090
+ });
17091
+
16696
17092
  /*
16697
17093
  * @Author: binruan@chatlabs.com
16698
17094
  * @Date: 2024-06-13 10:08:32
@@ -16994,6 +17390,7 @@ var _materials_ = /*#__PURE__*/Object.freeze({
16994
17390
  AniLinkPopup: AniLinkPopup,
16995
17391
  Appoint: Appoint,
16996
17392
  AppointForm: AppointForm,
17393
+ Click: Click,
16997
17394
  Commodity: Commodity,
16998
17395
  CommodityDetail: CommodityDetail,
16999
17396
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -17010,7 +17407,8 @@ var _materials_ = /*#__PURE__*/Object.freeze({
17010
17407
  MultiCommodityDiro: MultiCommodityDiro,
17011
17408
  MultiCommodityDiroNew: MultiCommodityDiroNew,
17012
17409
  MultiPosts: MultiPosts,
17013
- Prompt: Prompt
17410
+ Prompt: Prompt,
17411
+ Swipe: Swipe
17014
17412
  });
17015
17413
 
17016
17414
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17880,23 +18278,72 @@ const Tagbar = ({ tagList = [], setActiveIndex, style }) => {
17880
18278
  };
17881
18279
  var Tagbar$1 = React.memo(Tagbar);
17882
18280
 
18281
+ /*
18282
+ * @Author: binruan@chatlabs.com
18283
+ * @Date: 2023-12-26 10:38:53
18284
+ * @LastEditors: binruan@chatlabs.com
18285
+ * @LastEditTime: 2024-12-11 18:24:31
18286
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18287
+ *
18288
+ */
18289
+ const EditorDataContext = React.createContext({});
18290
+ const EditorDataProvider = ({ children, data }) => {
18291
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18292
+ const [openHashtag, setOpenHashtag] = React.useState(false);
18293
+ const [openConsent, setOpenConsent] = React.useState(false);
18294
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
18295
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18296
+ return (React.createElement(EditorDataContext.Provider, { value: {
18297
+ sxpPrameter: {
18298
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18299
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18300
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18301
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18302
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18303
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18304
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18305
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18306
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18307
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18308
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18309
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18310
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18311
+ },
18312
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18313
+ openHashtag,
18314
+ setOpenHashtag,
18315
+ openConsent,
18316
+ setOpenConsent,
18317
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18318
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18319
+ consentPopupCate,
18320
+ setConsentPopupCate,
18321
+ openMultiPosts,
18322
+ setOpenMultiPosts,
18323
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18324
+ } }, children));
18325
+ };
18326
+ function useEditorDataProvider() {
18327
+ return React.useContext(EditorDataContext);
18328
+ }
18329
+
17883
18330
  /*
17884
18331
  * @Author: binruan@chatlabs.com
17885
18332
  * @Date: 2023-12-26 16:11:34
17886
18333
  * @LastEditors: binruan@chatlabs.com
17887
- * @LastEditTime: 2024-11-05 16:29:47
18334
+ * @LastEditTime: 2025-01-14 18:02:44
17888
18335
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17889
18336
  *
17890
18337
  */
17891
18338
  const Consent = ({ resolver, globalConfig }) => {
17892
18339
  var _a, _b;
17893
- const contsentState = React.useMemo(() => {
17894
- return getContsentState();
17895
- }, []);
17896
- const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
17897
- const Component = withBindDataSource(t);
18340
+ const { consentPopupCate } = useEditorDataProvider();
17898
18341
  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;
17899
- 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 }));
18342
+ if (!value)
18343
+ return null;
18344
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18345
+ const Component = withBindDataSource(t);
18346
+ 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 })));
17900
18347
  };
17901
18348
  var ConsentPopup = React.memo(Consent);
17902
18349
 
@@ -17919,7 +18366,7 @@ var NavBack$1 = React.memo(NavBack);
17919
18366
  * @Author: binruan@chatlabs.com
17920
18367
  * @Date: 2024-03-20 10:27:31
17921
18368
  * @LastEditors: binruan@chatlabs.com
17922
- * @LastEditTime: 2024-12-18 10:24:20
18369
+ * @LastEditTime: 2025-01-20 18:46:32
17923
18370
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17924
18371
  *
17925
18372
  */
@@ -18014,7 +18461,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18014
18461
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
18015
18462
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
18016
18463
  position: activeIndex + '',
18017
- fromKName: fk ? fk : fromKName,
18464
+ fromKName: fk || fromKName,
18018
18465
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
18019
18466
  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 : '',
18020
18467
  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 : ''
@@ -18044,9 +18491,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18044
18491
  skipLinkRef.current = false;
18045
18492
  }
18046
18493
  // 页面可见时触发,注意页面初始化时不会触发
18494
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18047
18495
  handleH5EnterLink();
18048
18496
  if (repCond) {
18049
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18497
+ setTimeout(() => {
18498
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18499
+ });
18050
18500
  backMainFeed('external', selectTag);
18051
18501
  }
18052
18502
  }