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.js CHANGED
@@ -692,12 +692,15 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
692
692
  const bffDataSource = useMemo(() => {
693
693
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
694
694
  }, [dataSources]);
695
+ const fakeUserId = useMemo(() => {
696
+ var _a;
697
+ return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
698
+ }, [bffDataSource]);
695
699
  // bff API 请求方法
696
700
  const bffFetch = useCallback((path, options) => {
697
701
  if (!bffDataSource)
698
702
  return;
699
703
  const url = bffDataSource.url;
700
- const fakeUserId = storeAndLoadFeUserId();
701
704
  if (options === null || options === void 0 ? void 0 : options.query) {
702
705
  const queryString = qs.stringify(options.query);
703
706
  path = `${path}?${queryString}`;
@@ -705,19 +708,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
705
708
  // 事件上报优化
706
709
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
707
710
  if (options.type === 'beacon' && navigator.sendBeacon) {
708
- return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
711
+ return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
709
712
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
710
713
  ], { type: 'application/json;charset=UTF-8' }));
711
714
  }
712
715
  return window
713
- .fetch(`${url}/api/v1${path}`, {
716
+ .fetch(`${url}/api/${path}`, {
714
717
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
715
718
  method: options.method,
716
719
  body: JSON.stringify(options.body)
717
720
  })
718
721
  .then((res) => res.json())
719
722
  .catch((err) => Promise.reject(err));
720
- }, [bffDataSource]);
723
+ }, [bffDataSource, fakeUserId]);
721
724
  // 获取推荐视频数据
722
725
  const getRecommendVideos = useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
723
726
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
@@ -755,14 +758,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
755
758
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
756
759
  var _v, _w, _x, _y, _z, _0;
757
760
  query.pageNum = pageNum;
758
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
761
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
759
762
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
760
763
  return undefined;
761
764
  }
762
765
  setLoading(false);
763
766
  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 : []);
764
- setRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
765
- setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
767
+ if ((rtcList === null || rtcList === void 0 ? void 0 : rtcList.length) === 0) {
768
+ setRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
769
+ setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
770
+ }
766
771
  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));
767
772
  if (isNotNullList) {
768
773
  pageNum = pageNum + 1;
@@ -772,12 +777,12 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
772
777
  yield recurveRecList(query);
773
778
  if (!(query === null || query === void 0 ? void 0 : query.hashTag) && result)
774
779
  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 });
775
- return Object.assign(Object.assign({}, result.data), { recList: list });
780
+ return Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list });
776
781
  }
777
782
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
778
783
  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 });
779
784
  }
780
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
785
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
781
786
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
782
787
  return undefined;
783
788
  }
@@ -827,6 +832,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
827
832
  return expire;
828
833
  }, [data]);
829
834
  const bffEventReport = useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
835
+ var _a, _b;
830
836
  // 关闭 BFF 事件上报
831
837
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
832
838
  return;
@@ -839,7 +845,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
839
845
  };
840
846
  }
841
847
  const sessionID = storeAndLoadFeSessionId();
842
- 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 + '' }));
848
+ const params = {};
849
+ const queryString = location.search.slice(1);
850
+ (_a = splitUrlParams(queryString)) === null || _a === void 0 ? void 0 : _a.map((val) => {
851
+ const key = val.split('=')[0];
852
+ const value = val.split('=')[1];
853
+ params[key] = value;
854
+ });
855
+ console.log(params, '111');
856
+ const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
857
+ 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 }));
843
858
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
844
859
  const realEventInfo = Object.entries(ef)
845
860
  .map(([k, v]) => v && { name: k, value: v })
@@ -848,14 +863,23 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
848
863
  console.log('userInfo:', userInfo);
849
864
  console.log('eventInfo:', ef);
850
865
  console.log('========= 结束 =========');
851
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
866
+ 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}`, {
852
867
  method: 'POST',
853
868
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
854
869
  type: 'beacon'
855
870
  });
856
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
871
+ }, [
872
+ bffFetch,
873
+ curReqInfo,
874
+ enableReportEvent,
875
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
876
+ layoutVariantId,
877
+ globalConfig,
878
+ playbookType,
879
+ bffDataSource
880
+ ]);
857
881
  const bffFbReport = useCallback(({ eventName, product }) => {
858
- var _a, _b, _c, _d, _e;
882
+ var _a, _b, _c, _d, _e, _f;
859
883
  if (!enableReportEvent ||
860
884
  !enabledMetaConversionApi ||
861
885
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -867,7 +891,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
867
891
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
868
892
  const fix_par = {
869
893
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
870
- external_id: storeAndLoadFeUserId(),
894
+ external_id: fakeUserId,
871
895
  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 : '',
872
896
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
873
897
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -919,22 +943,30 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
919
943
  }
920
944
  };
921
945
  getEventParams(jsonParams);
922
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
946
+ 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}`, {
923
947
  method: 'POST',
924
948
  body: jsonParams,
925
949
  type: 'beacon'
926
950
  });
927
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
951
+ }, [
952
+ bffFetch,
953
+ enableReportEvent,
954
+ enabledMetaConversionApi,
955
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
956
+ globalConfig,
957
+ fakeUserId,
958
+ bffDataSource
959
+ ]);
928
960
  const bffMutateLike = useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
929
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
961
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
930
962
  return res === null || res === void 0 ? void 0 : res.success;
931
963
  }), [bffFetch]);
932
964
  const bffMutateUnlike = useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
933
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
965
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
934
966
  return res === null || res === void 0 ? void 0 : res.success;
935
967
  }), [bffFetch]);
936
968
  const bffSubmitForm = useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
937
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
969
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
938
970
  return res === null || res === void 0 ? void 0 : res.success;
939
971
  }), [bffFetch]);
940
972
  // 获取 Tag
@@ -949,7 +981,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
949
981
  const key = val.split('=')[0];
950
982
  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);
951
983
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
952
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
984
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
953
985
  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 : []);
954
986
  }
955
987
  catch (e) {
@@ -1028,10 +1060,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1028
1060
  let curData;
1029
1061
  let gldata;
1030
1062
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1063
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1064
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1031
1065
  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];
1032
1066
  if (id) {
1033
- layId = id;
1034
- setLayoutVariantId(id);
1035
1067
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1036
1068
  if (curData) {
1037
1069
  setPageData(curData);
@@ -1417,7 +1449,7 @@ var interactionRender$g = [
1417
1449
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1418
1450
  *
1419
1451
  */
1420
- var settingRender$d = [
1452
+ var settingRender$f = [
1421
1453
  {
1422
1454
  title: '弹窗背景',
1423
1455
  child: [
@@ -1853,7 +1885,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1853
1885
  category: 'popup',
1854
1886
  type: 'AppointForm',
1855
1887
  related: {
1856
- settingRender: settingRender$d,
1888
+ settingRender: settingRender$f,
1857
1889
  bindableProps: [],
1858
1890
  interactionRender: interactionRender$g
1859
1891
  },
@@ -1878,7 +1910,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1878
1910
  sort: 2
1879
1911
  });
1880
1912
 
1881
- var settingRender$c = [
1913
+ var settingRender$e = [
1882
1914
  {
1883
1915
  title: '弹窗背景',
1884
1916
  child: [
@@ -9767,7 +9799,7 @@ SwiperSlide.displayName = 'SwiperSlide';
9767
9799
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9768
9800
  *
9769
9801
  */
9770
- const closeIcon$1 = '';
9802
+ const closeIcon$2 = '';
9771
9803
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9772
9804
  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;
9773
9805
  const touchRef = useRef(null);
@@ -9947,7 +9979,7 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema,
9947
9979
  }
9948
9980
  })), child()),
9949
9981
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9950
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9982
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9951
9983
  };
9952
9984
  var Modal$1 = memo(Modal);
9953
9985
 
@@ -10118,7 +10150,7 @@ var CommodityGroup$1 = memo(CommodityGroup);
10118
10150
  * @Author: binruan@chatlabs.com
10119
10151
  * @Date: 2024-03-20 14:56:16
10120
10152
  * @LastEditors: binruan@chatlabs.com
10121
- * @LastEditTime: 2024-10-24 17:51:19
10153
+ * @LastEditTime: 2024-12-20 14:32:26
10122
10154
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10123
10155
  *
10124
10156
  */
@@ -10156,14 +10188,16 @@ const getBgStyle = (imgSrc) => {
10156
10188
  };
10157
10189
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10158
10190
  var _a, _b, _c, _d, _e, _f, _g, _h;
10191
+ let text = '';
10159
10192
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10160
10193
  return null;
10161
- 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;
10162
- let text = '';
10194
+ 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);
10195
+ if (typeof price !== 'number')
10196
+ return text;
10163
10197
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10164
10198
  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 : '' : '$';
10165
10199
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10166
- let decPic = price.toString();
10200
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10167
10201
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10168
10202
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10169
10203
  }
@@ -10475,7 +10509,7 @@ const CommodityDetail = createMaterial(CommodityDetailComponent, {
10475
10509
  category: 'popup',
10476
10510
  type: 'CommodityDetail',
10477
10511
  related: {
10478
- settingRender: settingRender$c,
10512
+ settingRender: settingRender$e,
10479
10513
  interactionRender: interactionRender$f
10480
10514
  },
10481
10515
  defaulSetting: {
@@ -10551,7 +10585,7 @@ var interactionRender$e = [
10551
10585
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10552
10586
  *
10553
10587
  */
10554
- var settingRender$b = [
10588
+ var settingRender$d = [
10555
10589
  {
10556
10590
  title: '弹窗背景',
10557
10591
  child: [
@@ -10692,7 +10726,7 @@ var settingRender$b = [
10692
10726
  }
10693
10727
  ];
10694
10728
 
10695
- var img$5 = "";
10729
+ var img$7 = "";
10696
10730
 
10697
10731
  const Prompt$1 = (_a) => {
10698
10732
  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"]);
@@ -10715,7 +10749,7 @@ const Prompt$1 = (_a) => {
10715
10749
  };
10716
10750
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css(Object.assign({}, style))}` }, props),
10717
10751
  React.createElement("div", { className: 'pb-prompt-icon' },
10718
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10752
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10719
10753
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10720
10754
  __html: setFontForText(content, contentStyle)
10721
10755
  } }),
@@ -10731,13 +10765,13 @@ const Prompt = createMaterial(PromptComponent, {
10731
10765
  category: 'popup',
10732
10766
  type: 'Prompt',
10733
10767
  related: {
10734
- settingRender: settingRender$b,
10768
+ settingRender: settingRender$d,
10735
10769
  bindableProps: [],
10736
10770
  interactionRender: interactionRender$e
10737
10771
  },
10738
10772
  defaulSetting: {
10739
10773
  props: {
10740
- icon: img$5,
10774
+ icon: img$7,
10741
10775
  content: 'You have successfully completed the appointment!',
10742
10776
  btnText: 'OK'
10743
10777
  },
@@ -10756,7 +10790,7 @@ const Prompt = createMaterial(PromptComponent, {
10756
10790
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10757
10791
  *
10758
10792
  */
10759
- var settingRender$a = [
10793
+ var settingRender$c = [
10760
10794
  {
10761
10795
  title: '弹窗背景',
10762
10796
  child: [
@@ -11435,7 +11469,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11435
11469
  category: 'popup',
11436
11470
  type: 'CommodityDetailDiroNew',
11437
11471
  related: {
11438
- settingRender: settingRender$a,
11472
+ settingRender: settingRender$c,
11439
11473
  interactionRender: interactionRender$d
11440
11474
  },
11441
11475
  defaulSetting: {
@@ -11499,7 +11533,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11499
11533
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11500
11534
  *
11501
11535
  */
11502
- var settingRender$9 = [
11536
+ var settingRender$b = [
11503
11537
  {
11504
11538
  title: '弹窗背景',
11505
11539
  child: [
@@ -11936,7 +11970,7 @@ const CommodityList = createMaterial(CommodityListComponent, {
11936
11970
  category: 'popup',
11937
11971
  type: 'CommodityList',
11938
11972
  related: {
11939
- settingRender: settingRender$9,
11973
+ settingRender: settingRender$b,
11940
11974
  interactionRender: interactionRender$c
11941
11975
  },
11942
11976
  defaulSetting: {
@@ -11985,7 +12019,7 @@ const CommodityList = createMaterial(CommodityListComponent, {
11985
12019
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
11986
12020
  *
11987
12021
  */
11988
- var settingRender$8 = [
12022
+ var settingRender$a = [
11989
12023
  {
11990
12024
  title: '背景样式',
11991
12025
  child: [
@@ -12019,7 +12053,7 @@ const Iframe = createMaterial(IframeComponent, {
12019
12053
  category: 'popup',
12020
12054
  type: 'Iframe',
12021
12055
  related: {
12022
- settingRender: settingRender$8,
12056
+ settingRender: settingRender$a,
12023
12057
  bindableProps: []
12024
12058
  },
12025
12059
  defaulSetting: {
@@ -12039,7 +12073,7 @@ const Iframe = createMaterial(IframeComponent, {
12039
12073
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12040
12074
  *
12041
12075
  */
12042
- var settingRender$7 = [
12076
+ var settingRender$9 = [
12043
12077
  {
12044
12078
  title: '弹窗文本',
12045
12079
  child: [
@@ -12052,22 +12086,22 @@ var settingRender$7 = [
12052
12086
  ];
12053
12087
 
12054
12088
  const ConsentDetail$1 = (_a) => {
12055
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12089
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12056
12090
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12057
12091
  __html: typeof content === 'string' ? content : ''
12058
12092
  }, onClick: (e) => {
12059
12093
  e.stopPropagation();
12060
- } }));
12094
+ }, style: style }));
12061
12095
  };
12062
- var ConsentDetailComponent = memo(ConsentDetail$1);
12096
+ var ConsentDetail$2 = memo(ConsentDetail$1);
12063
12097
 
12064
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12098
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12065
12099
  displayName: '协议详情',
12066
12100
  icon: '',
12067
12101
  category: 'popup',
12068
12102
  type: 'ConsentDetail',
12069
12103
  related: {
12070
- settingRender: settingRender$7,
12104
+ settingRender: settingRender$9,
12071
12105
  bindableProps: []
12072
12106
  },
12073
12107
  defaulSetting: {
@@ -12087,7 +12121,7 @@ const ConsentDetail = createMaterial(ConsentDetailComponent, {
12087
12121
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12088
12122
  *
12089
12123
  */
12090
- var settingRender$6 = [
12124
+ var settingRender$8 = [
12091
12125
  {
12092
12126
  title: '主题样式',
12093
12127
  child: [
@@ -12441,7 +12475,7 @@ const Commodity = createMaterial(CommodityComponent, {
12441
12475
  related: {
12442
12476
  interactionRender: interactionRender$b,
12443
12477
  bindableProps: [],
12444
- settingRender: settingRender$6
12478
+ settingRender: settingRender$8
12445
12479
  },
12446
12480
  defaulSetting: {
12447
12481
  props: {
@@ -12523,7 +12557,7 @@ const Appoint = createMaterial(AppointComponent, {
12523
12557
  type: 'Appoint',
12524
12558
  related: {
12525
12559
  interactionRender: interactionRender$a,
12526
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12560
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12527
12561
  bindableProps: []
12528
12562
  },
12529
12563
  defaulSetting: {
@@ -12729,7 +12763,7 @@ const Link = createMaterial(LinkComponent, {
12729
12763
  category: 'template',
12730
12764
  type: 'Link',
12731
12765
  related: {
12732
- 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),
12766
+ 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),
12733
12767
  bindableProps: [],
12734
12768
  interactionRender: interactionRender$9
12735
12769
  },
@@ -12832,7 +12866,7 @@ const CommodityDiro = createMaterial(CommodityDiroComponent, {
12832
12866
  type: 'CommodityDiro',
12833
12867
  related: {
12834
12868
  interactionRender: interactionRender$8,
12835
- settingRender: settingRender$6,
12869
+ settingRender: settingRender$8,
12836
12870
  bindableProps: []
12837
12871
  },
12838
12872
  defaulSetting: {
@@ -12929,7 +12963,7 @@ const CommodityDiroNew = createMaterial(CommodityDiroNewComponent, {
12929
12963
  related: {
12930
12964
  interactionRender: interactionRender$7,
12931
12965
  bindableProps: [],
12932
- settingRender: settingRender$6
12966
+ settingRender: settingRender$8
12933
12967
  },
12934
12968
  defaulSetting: {
12935
12969
  props: {
@@ -13029,7 +13063,7 @@ const MultiCommodityDiro = createMaterial(MultiCommodityDiroComponent, {
13029
13063
  related: {
13030
13064
  interactionRender: interactionRender$6,
13031
13065
  bindableProps: [],
13032
- settingRender: settingRender$6
13066
+ settingRender: settingRender$8
13033
13067
  },
13034
13068
  defaulSetting: {
13035
13069
  props: {
@@ -13127,7 +13161,7 @@ const MultiCommodity = createMaterial(MultiCommodityComponent, {
13127
13161
  type: 'MultiCommodity',
13128
13162
  related: {
13129
13163
  interactionRender: interactionRender$5,
13130
- settingRender: settingRender$6,
13164
+ settingRender: settingRender$8,
13131
13165
  bindableProps: []
13132
13166
  },
13133
13167
  defaulSetting: {
@@ -13236,7 +13270,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13236
13270
  related: {
13237
13271
  interactionRender: interactionRender$4,
13238
13272
  bindableProps: [],
13239
- settingRender: settingRender$6
13273
+ settingRender: settingRender$8
13240
13274
  },
13241
13275
  defaulSetting: {
13242
13276
  props: {
@@ -13285,7 +13319,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13285
13319
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13286
13320
  *
13287
13321
  */
13288
- var settingRender$5 = [
13322
+ var settingRender$7 = [
13289
13323
  {
13290
13324
  title: 'Banner',
13291
13325
  child: [
@@ -13517,7 +13551,7 @@ var settingRender$5 = [
13517
13551
  * @Author: binruan@chatlabs.com
13518
13552
  * @Date: 2023-12-26 16:11:34
13519
13553
  * @LastEditors: binruan@chatlabs.com
13520
- * @LastEditTime: 2024-10-11 18:22:21
13554
+ * @LastEditTime: 2025-01-17 18:55:14
13521
13555
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Navbar.tsx
13522
13556
  *
13523
13557
  */
@@ -13528,7 +13562,7 @@ const Navbar = ({ icon, styles, textStyle, onClose }) => {
13528
13562
  React.createElement("button", { className: 'clc-sxp-nav-left', role: 'button', "aria-label": 'back button', onClick: onClose },
13529
13563
  React.createElement("img", { src: icon, alt: 'back button' })),
13530
13564
  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: {
13531
- __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : '标题'}`, textStyle)
13565
+ __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : 'title'}`, textStyle)
13532
13566
  } })));
13533
13567
  };
13534
13568
  var Navbar$1 = memo(Navbar);
@@ -15112,7 +15146,7 @@ function WaterfallList$1(_a) {
15112
15146
  } }))))));
15113
15147
  }
15114
15148
 
15115
- var img$4 = "";
15149
+ var img$6 = "";
15116
15150
 
15117
15151
  const WaterfallFlowItem = (props) => {
15118
15152
  var _a;
@@ -15433,7 +15467,7 @@ const WaterFall = (props) => {
15433
15467
  return ReactDOM.createPortal(React.createElement("div", { className: 'waterfall', style: {
15434
15468
  display: openHashtag ? 'block' : 'none'
15435
15469
  } },
15436
- 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 }),
15470
+ 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 }),
15437
15471
  ((_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);
15438
15472
  };
15439
15473
  var WaterFall$1 = memo(WaterFall);
@@ -15465,7 +15499,7 @@ const HashTag = createMaterial(HashTagComponent, {
15465
15499
  category: 'base',
15466
15500
  type: 'HashTag',
15467
15501
  related: {
15468
- settingRender: settingRender$5,
15502
+ settingRender: settingRender$7,
15469
15503
  bindableProps: []
15470
15504
  },
15471
15505
  defaulSetting: {
@@ -15531,7 +15565,7 @@ const HashTag = createMaterial(HashTagComponent, {
15531
15565
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15532
15566
  *
15533
15567
  */
15534
- var settingRender$4 = [
15568
+ var settingRender$6 = [
15535
15569
  {
15536
15570
  title: '协议详情',
15537
15571
  child: [
@@ -15590,7 +15624,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15590
15624
  category: 'base',
15591
15625
  type: 'Consent',
15592
15626
  related: {
15593
- settingRender: settingRender$4
15627
+ settingRender: settingRender$6
15594
15628
  },
15595
15629
  defaulSetting: {
15596
15630
  props: {},
@@ -15609,7 +15643,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15609
15643
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15610
15644
  *
15611
15645
  */
15612
- var settingRender$3 = [
15646
+ var settingRender$5 = [
15613
15647
  {
15614
15648
  title: '主题样式',
15615
15649
  child: [
@@ -15754,7 +15788,7 @@ const AniLink$1 = (_a) => {
15754
15788
  onClick === null || onClick === void 0 ? void 0 : onClick();
15755
15789
  }
15756
15790
  };
15757
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
15791
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
15758
15792
  const aniTimStyle = useMemo(() => {
15759
15793
  var _a, _b;
15760
15794
  const ani = event === null || event === void 0 ? void 0 : event.animation;
@@ -15870,7 +15904,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15870
15904
  category: 'cta',
15871
15905
  type: 'AniLink',
15872
15906
  related: {
15873
- settingRender: settingRender$3,
15907
+ settingRender: settingRender$5,
15874
15908
  bindableProps: [],
15875
15909
  interactionRender: interactionRender$3
15876
15910
  },
@@ -15914,7 +15948,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15914
15948
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15915
15949
  *
15916
15950
  */
15917
- var settingRender$2 = [
15951
+ var settingRender$4 = [
15918
15952
  {
15919
15953
  title: '主题样式',
15920
15954
  child: [
@@ -16172,7 +16206,7 @@ var settingRender$2 = [
16172
16206
 
16173
16207
  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"};
16174
16208
 
16175
- const closeIcon = '';
16209
+ const closeIcon$1 = '';
16176
16210
  const AniLinkPopup$1 = (_a) => {
16177
16211
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16178
16212
  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"]);
@@ -16201,7 +16235,7 @@ const AniLinkPopup$1 = (_a) => {
16201
16235
  onClick === null || onClick === void 0 ? void 0 : onClick();
16202
16236
  }
16203
16237
  };
16204
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
16238
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
16205
16239
  const aniTimStyle = useMemo(() => {
16206
16240
  const ani = event === null || event === void 0 ? void 0 : event.animation;
16207
16241
  if (ani) {
@@ -16231,7 +16265,7 @@ const AniLinkPopup$1 = (_a) => {
16231
16265
  paddingLeft: '6px'
16232
16266
  } }, "Cta Title")) : (React.createElement("div", Object.assign({}, props, { className: `${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(aniTimStyle)}`, onClick: handleTo }),
16233
16267
  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 } },
16234
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16268
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16235
16269
  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 }),
16236
16270
  (!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: {
16237
16271
  __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)
@@ -16318,7 +16352,7 @@ const AniLinkPopup = createMaterial(AniLinkPopupComponent, {
16318
16352
  category: 'cta',
16319
16353
  type: 'AniLinkPopup',
16320
16354
  related: {
16321
- settingRender: settingRender$2,
16355
+ settingRender: settingRender$4,
16322
16356
  bindableProps: [],
16323
16357
  interactionRender: interactionRender$2
16324
16358
  },
@@ -16397,7 +16431,7 @@ var interactionRender$1 = [
16397
16431
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16398
16432
  *
16399
16433
  */
16400
- var settingRender$1 = [
16434
+ var settingRender$3 = [
16401
16435
  {
16402
16436
  title: '全局设置',
16403
16437
  child: [
@@ -16538,74 +16572,27 @@ var settingRender$1 = [
16538
16572
  }
16539
16573
  ];
16540
16574
 
16541
- /*
16542
- * @Author: binruan@chatlabs.com
16543
- * @Date: 2023-12-26 10:38:53
16544
- * @LastEditors: binruan@chatlabs.com
16545
- * @LastEditTime: 2024-12-11 18:24:31
16546
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16547
- *
16548
- */
16549
- const EditorDataContext = createContext({});
16550
- const EditorDataProvider = ({ children, data }) => {
16551
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16552
- const [openHashtag, setOpenHashtag] = useState(false);
16553
- const [openConsent, setOpenConsent] = useState(false);
16554
- const [consentPopupCate, setConsentPopupCate] = useState('');
16555
- const [openMultiPosts, setOpenMultiPosts] = useState(false);
16556
- return (React.createElement(EditorDataContext.Provider, { value: {
16557
- sxpPrameter: {
16558
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16559
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16560
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16561
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16562
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16563
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16564
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16565
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16566
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16567
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16568
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16569
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16570
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16571
- },
16572
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16573
- openHashtag,
16574
- setOpenHashtag,
16575
- openConsent,
16576
- setOpenConsent,
16577
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16578
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16579
- consentPopupCate,
16580
- setConsentPopupCate,
16581
- openMultiPosts,
16582
- setOpenMultiPosts,
16583
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16584
- } }, children));
16585
- };
16586
- function useEditorDataProvider() {
16587
- return useContext(EditorDataContext);
16588
- }
16589
-
16590
- 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";
16575
+ 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";
16591
16576
 
16592
- var img$2 = "";
16577
+ var img$4 = "";
16593
16578
 
16594
16579
  const Display$1 = (_a) => {
16595
16580
  var _b, _c;
16596
- var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16597
- const { consentPopupCate } = useEditorDataProvider();
16581
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16598
16582
  const [isClose, setIsClose] = useState(false);
16583
+ const contsentState = useMemo(() => {
16584
+ return getContsentState();
16585
+ }, []);
16599
16586
  const visivle = useMemo(() => {
16600
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16601
- }, [consentPopupCate, open, isClose]);
16587
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16588
+ }, [consentPopupCate, open, isClose, contsentState]);
16602
16589
  const handleClickClose = useCallback(() => {
16603
16590
  setIsClose(true);
16604
16591
  }, []);
16605
16592
  const handleClick = useCallback(() => {
16606
16593
  onClick === null || onClick === void 0 ? void 0 : onClick();
16607
16594
  }, []);
16608
- 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 },
16595
+ 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 },
16609
16596
  React.createElement("div", { style: { flex: 1 } },
16610
16597
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16611
16598
  __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)
@@ -16614,7 +16601,7 @@ const Display$1 = (_a) => {
16614
16601
  __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)
16615
16602
  }, onClick: handleClick })),
16616
16603
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16617
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16604
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16618
16605
  };
16619
16606
  var DisplayComponent = memo(Display$1);
16620
16607
 
@@ -16640,7 +16627,7 @@ const Display = createMaterial(DisplayComponent, {
16640
16627
  category: 'consentPopup',
16641
16628
  type: 'Display',
16642
16629
  related: {
16643
- settingRender: settingRender$1,
16630
+ settingRender: settingRender$3,
16644
16631
  bindableProps: [],
16645
16632
  interactionRender: interactionRender$1
16646
16633
  },
@@ -16671,6 +16658,415 @@ const Display = createMaterial(DisplayComponent, {
16671
16658
  sort: 1
16672
16659
  });
16673
16660
 
16661
+ /*
16662
+ * @Author: binruan@chatlabs.com
16663
+ * @Date: 2023-07-28 18:29:57
16664
+ * @LastEditors: binruan@chatlabs.com
16665
+ * @LastEditTime: 2025-01-15 10:14:40
16666
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16667
+ *
16668
+ */
16669
+ var settingRender$2 = [
16670
+ {
16671
+ title: '全局设置',
16672
+ child: [
16673
+ {
16674
+ type: 'Switch',
16675
+ label: '弹窗开关',
16676
+ name: ['props', 'open']
16677
+ },
16678
+ {
16679
+ type: 'Color',
16680
+ label: '背景色',
16681
+ name: ['style', 'backgroundColor']
16682
+ },
16683
+ {
16684
+ type: 'Number',
16685
+ label: '内边距',
16686
+ name: ['style', 'padding'],
16687
+ addonAfter: 'px'
16688
+ }
16689
+ ]
16690
+ },
16691
+ {
16692
+ title: '弹窗文本',
16693
+ child: [
16694
+ {
16695
+ type: 'RichText',
16696
+ name: ['props', 'content']
16697
+ }
16698
+ ]
16699
+ },
16700
+ {
16701
+ title: '接受按钮样式',
16702
+ child: [
16703
+ {
16704
+ type: 'Color',
16705
+ label: '背景色',
16706
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16707
+ },
16708
+ {
16709
+ type: 'Number',
16710
+ label: '尺寸',
16711
+ name: ['props', 'acceptButton', 'style', 'height'],
16712
+ addonAfter: 'H'
16713
+ },
16714
+ {
16715
+ type: 'Group',
16716
+ label: '圆角',
16717
+ child: [
16718
+ {
16719
+ type: 'Slider',
16720
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16721
+ max: 100
16722
+ },
16723
+ {
16724
+ type: 'Number',
16725
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16726
+ addonAfter: 'px',
16727
+ max: 100
16728
+ }
16729
+ ]
16730
+ },
16731
+ {
16732
+ type: 'TextMargin',
16733
+ label: '边距',
16734
+ name: ['props', 'acceptButton', 'style']
16735
+ },
16736
+ {
16737
+ type: 'Group',
16738
+ label: '字体',
16739
+ child: [
16740
+ {
16741
+ type: 'Select',
16742
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16743
+ bottomText: '中文字体'
16744
+ },
16745
+ {
16746
+ type: 'Select',
16747
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16748
+ bottomText: '英文/其他字体'
16749
+ }
16750
+ ]
16751
+ },
16752
+ {
16753
+ type: 'Group',
16754
+ label: '',
16755
+ child: [
16756
+ {
16757
+ type: 'Color',
16758
+ name: ['props', 'acceptButton', 'style', 'color']
16759
+ },
16760
+ {
16761
+ type: 'Number',
16762
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16763
+ addonAfter: 'px'
16764
+ }
16765
+ ]
16766
+ },
16767
+ {
16768
+ label: '样式',
16769
+ type: 'TextStyle',
16770
+ name: ['props', 'acceptButton', 'style']
16771
+ },
16772
+ {
16773
+ label: '对齐',
16774
+ type: 'TextAlign',
16775
+ name: ['props', 'acceptButton', 'style']
16776
+ },
16777
+ {
16778
+ label: '间距',
16779
+ type: 'TextSpace',
16780
+ name: ['props', 'acceptButton', 'style']
16781
+ },
16782
+ {
16783
+ label: '文本',
16784
+ type: 'TextArea',
16785
+ name: ['props', 'acceptButton', 'text']
16786
+ }
16787
+ ]
16788
+ },
16789
+ {
16790
+ title: '拒绝按钮样式',
16791
+ child: [
16792
+ {
16793
+ type: 'Color',
16794
+ label: '背景色',
16795
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16796
+ },
16797
+ {
16798
+ type: 'Number',
16799
+ label: '尺寸',
16800
+ name: ['props', 'rejectButton', 'style', 'height'],
16801
+ addonAfter: 'H'
16802
+ },
16803
+ {
16804
+ type: 'Group',
16805
+ label: '圆角',
16806
+ child: [
16807
+ {
16808
+ type: 'Slider',
16809
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16810
+ max: 100
16811
+ },
16812
+ {
16813
+ type: 'Number',
16814
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16815
+ addonAfter: 'px',
16816
+ max: 100
16817
+ }
16818
+ ]
16819
+ },
16820
+ {
16821
+ type: 'TextMargin',
16822
+ label: '边距',
16823
+ name: ['props', 'acceptButton', 'style']
16824
+ },
16825
+ {
16826
+ type: 'Group',
16827
+ label: '字体',
16828
+ child: [
16829
+ {
16830
+ type: 'Select',
16831
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16832
+ bottomText: '中文字体'
16833
+ },
16834
+ {
16835
+ type: 'Select',
16836
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16837
+ bottomText: '英文/其他字体'
16838
+ }
16839
+ ]
16840
+ },
16841
+ {
16842
+ type: 'Group',
16843
+ label: '',
16844
+ child: [
16845
+ {
16846
+ type: 'Color',
16847
+ name: ['props', 'rejectButton', 'style', 'color']
16848
+ },
16849
+ {
16850
+ type: 'Number',
16851
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16852
+ addonAfter: 'px'
16853
+ }
16854
+ ]
16855
+ },
16856
+ {
16857
+ label: '样式',
16858
+ type: 'TextStyle',
16859
+ name: ['props', 'rejectButton', 'style']
16860
+ },
16861
+ {
16862
+ label: '对齐',
16863
+ type: 'TextAlign',
16864
+ name: ['props', 'rejectButton', 'style']
16865
+ },
16866
+ {
16867
+ label: '间距',
16868
+ type: 'TextSpace',
16869
+ name: ['props', 'rejectButton', 'style']
16870
+ },
16871
+ {
16872
+ label: '文本',
16873
+ type: 'TextArea',
16874
+ name: ['props', 'rejectButton', 'text']
16875
+ }
16876
+ ]
16877
+ }
16878
+ ];
16879
+
16880
+ var img$3 = "";
16881
+
16882
+ const Click$1 = (_a) => {
16883
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16884
+ const visivle = useMemo(() => {
16885
+ return consentPopupCate || (open && style);
16886
+ }, [consentPopupCate, open]);
16887
+ const handleClickAccept = () => { };
16888
+ const handleClickReject = () => { };
16889
+ 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' },
16890
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16891
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16892
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16893
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16894
+ };
16895
+ var ClickComponent = memo(Click$1);
16896
+
16897
+ /*
16898
+ * @Author: binruan@chatlabs.com
16899
+ * @Date: 2025-01-14 16:22:35
16900
+ * @LastEditors: binruan@chatlabs.com
16901
+ * @LastEditTime: 2025-01-15 17:09:49
16902
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16903
+ *
16904
+ */
16905
+ const Click = createMaterial(ClickComponent, {
16906
+ displayName: 'Click Consent',
16907
+ icon: '',
16908
+ category: 'consentPopup',
16909
+ type: 'Click',
16910
+ related: {
16911
+ settingRender: settingRender$2,
16912
+ bindableProps: []
16913
+ },
16914
+ defaulSetting: {
16915
+ props: {
16916
+ 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>',
16917
+ acceptButton: {
16918
+ text: 'Accept all cookies',
16919
+ style: {
16920
+ backgroundColor: '#000',
16921
+ height: 45,
16922
+ color: '#fff',
16923
+ fontSize: 12,
16924
+ textAlign: 'center',
16925
+ marginTop: 5,
16926
+ marginBottom: 5
16927
+ }
16928
+ },
16929
+ rejectButton: {
16930
+ text: 'Reject all cookies',
16931
+ style: {
16932
+ backgroundColor: '#000',
16933
+ height: 45,
16934
+ color: '#fff',
16935
+ fontSize: 12,
16936
+ textAlign: 'center',
16937
+ marginTop: 5,
16938
+ marginBottom: 5
16939
+ }
16940
+ }
16941
+ },
16942
+ style: {
16943
+ backgroundColor: '#fff',
16944
+ padding: 18
16945
+ }
16946
+ },
16947
+ sort: 2
16948
+ });
16949
+
16950
+ /*
16951
+ * @Author: binruan@chatlabs.com
16952
+ * @Date: 2023-07-28 18:29:57
16953
+ * @LastEditors: binruan@chatlabs.com
16954
+ * @LastEditTime: 2025-01-15 17:39:28
16955
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16956
+ *
16957
+ */
16958
+ var settingRender$1 = [
16959
+ {
16960
+ title: '全局设置',
16961
+ child: [
16962
+ {
16963
+ type: 'Switch',
16964
+ label: '弹窗开关',
16965
+ name: ['props', 'open']
16966
+ },
16967
+ {
16968
+ type: 'Color',
16969
+ label: '背景色',
16970
+ name: ['style', 'backgroundColor']
16971
+ },
16972
+ {
16973
+ type: 'Number',
16974
+ label: '内边距',
16975
+ name: ['style', 'padding'],
16976
+ addonAfter: 'px'
16977
+ }
16978
+ ]
16979
+ },
16980
+ {
16981
+ title: '弹窗文本',
16982
+ child: [
16983
+ {
16984
+ type: 'RichText',
16985
+ name: ['props', 'content']
16986
+ }
16987
+ ]
16988
+ },
16989
+ {
16990
+ title: '滑动图标',
16991
+ child: [
16992
+ {
16993
+ type: 'Upload',
16994
+ label: '滑动图标',
16995
+ name: ['props', 'swipeIcon'],
16996
+ text: '建议尺寸:252 * 185'
16997
+ }
16998
+ ]
16999
+ }
17000
+ ];
17001
+
17002
+ var img$2 = "";
17003
+
17004
+ const closeIcon = '';
17005
+ const Swipe$1 = (_a) => {
17006
+ var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
17007
+ const touchInfo = useRef();
17008
+ const handleTouchStart = (event) => {
17009
+ const touch = event.touches[0];
17010
+ touchInfo.current = { y: touch.clientY, d: 0 };
17011
+ };
17012
+ const handleTouchMove = (event) => {
17013
+ var _a;
17014
+ if (!touchInfo.current)
17015
+ return;
17016
+ const touch = event.touches[0];
17017
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
17018
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
17019
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
17020
+ };
17021
+ const handleTouchEnd = () => {
17022
+ if (!touchInfo.current)
17023
+ return;
17024
+ touchInfo.current || {};
17025
+ touchInfo.current = {};
17026
+ };
17027
+ const handleClickReject = () => { };
17028
+ const visivle = useMemo(() => {
17029
+ return consentPopupCate || (open && style);
17030
+ }, [consentPopupCate, open]);
17031
+ 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 },
17032
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17033
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17034
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17035
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
17036
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17037
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17038
+ };
17039
+ var SwipeComponent = memo(Swipe$1);
17040
+
17041
+ /*
17042
+ * @Author: binruan@chatlabs.com
17043
+ * @Date: 2025-01-14 16:22:35
17044
+ * @LastEditors: binruan@chatlabs.com
17045
+ * @LastEditTime: 2025-01-15 17:09:49
17046
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17047
+ *
17048
+ */
17049
+ const Swipe = createMaterial(SwipeComponent, {
17050
+ displayName: 'Swipe Consent',
17051
+ icon: '',
17052
+ category: 'consentPopup',
17053
+ type: 'Swipe',
17054
+ related: {
17055
+ settingRender: settingRender$1,
17056
+ bindableProps: []
17057
+ },
17058
+ defaulSetting: {
17059
+ props: {
17060
+ 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>'
17061
+ },
17062
+ style: {
17063
+ backgroundColor: '#fff',
17064
+ padding: 18
17065
+ }
17066
+ },
17067
+ sort: 3
17068
+ });
17069
+
16674
17070
  /*
16675
17071
  * @Author: binruan@chatlabs.com
16676
17072
  * @Date: 2024-06-13 10:08:32
@@ -16972,6 +17368,7 @@ var _materials_ = /*#__PURE__*/Object.freeze({
16972
17368
  AniLinkPopup: AniLinkPopup,
16973
17369
  Appoint: Appoint,
16974
17370
  AppointForm: AppointForm,
17371
+ Click: Click,
16975
17372
  Commodity: Commodity,
16976
17373
  CommodityDetail: CommodityDetail,
16977
17374
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -16988,7 +17385,8 @@ var _materials_ = /*#__PURE__*/Object.freeze({
16988
17385
  MultiCommodityDiro: MultiCommodityDiro,
16989
17386
  MultiCommodityDiroNew: MultiCommodityDiroNew,
16990
17387
  MultiPosts: MultiPosts,
16991
- Prompt: Prompt
17388
+ Prompt: Prompt,
17389
+ Swipe: Swipe
16992
17390
  });
16993
17391
 
16994
17392
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17858,23 +18256,72 @@ const Tagbar = ({ tagList = [], setActiveIndex, style }) => {
17858
18256
  };
17859
18257
  var Tagbar$1 = memo(Tagbar);
17860
18258
 
18259
+ /*
18260
+ * @Author: binruan@chatlabs.com
18261
+ * @Date: 2023-12-26 10:38:53
18262
+ * @LastEditors: binruan@chatlabs.com
18263
+ * @LastEditTime: 2024-12-11 18:24:31
18264
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18265
+ *
18266
+ */
18267
+ const EditorDataContext = createContext({});
18268
+ const EditorDataProvider = ({ children, data }) => {
18269
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18270
+ const [openHashtag, setOpenHashtag] = useState(false);
18271
+ const [openConsent, setOpenConsent] = useState(false);
18272
+ const [consentPopupCate, setConsentPopupCate] = useState('');
18273
+ const [openMultiPosts, setOpenMultiPosts] = useState(false);
18274
+ return (React.createElement(EditorDataContext.Provider, { value: {
18275
+ sxpPrameter: {
18276
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18277
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18278
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18279
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18280
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18281
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18282
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18283
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18284
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18285
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18286
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18287
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18288
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18289
+ },
18290
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18291
+ openHashtag,
18292
+ setOpenHashtag,
18293
+ openConsent,
18294
+ setOpenConsent,
18295
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18296
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18297
+ consentPopupCate,
18298
+ setConsentPopupCate,
18299
+ openMultiPosts,
18300
+ setOpenMultiPosts,
18301
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18302
+ } }, children));
18303
+ };
18304
+ function useEditorDataProvider() {
18305
+ return useContext(EditorDataContext);
18306
+ }
18307
+
17861
18308
  /*
17862
18309
  * @Author: binruan@chatlabs.com
17863
18310
  * @Date: 2023-12-26 16:11:34
17864
18311
  * @LastEditors: binruan@chatlabs.com
17865
- * @LastEditTime: 2024-11-05 16:29:47
18312
+ * @LastEditTime: 2025-01-14 18:02:44
17866
18313
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17867
18314
  *
17868
18315
  */
17869
18316
  const Consent = ({ resolver, globalConfig }) => {
17870
18317
  var _a, _b;
17871
- const contsentState = useMemo(() => {
17872
- return getContsentState();
17873
- }, []);
17874
- const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
17875
- const Component = withBindDataSource(t);
18318
+ const { consentPopupCate } = useEditorDataProvider();
17876
18319
  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;
17877
- 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 }));
18320
+ if (!value)
18321
+ return null;
18322
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18323
+ const Component = withBindDataSource(t);
18324
+ 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 })));
17878
18325
  };
17879
18326
  var ConsentPopup = memo(Consent);
17880
18327
 
@@ -17897,7 +18344,7 @@ var NavBack$1 = memo(NavBack);
17897
18344
  * @Author: binruan@chatlabs.com
17898
18345
  * @Date: 2024-03-20 10:27:31
17899
18346
  * @LastEditors: binruan@chatlabs.com
17900
- * @LastEditTime: 2024-12-18 10:24:20
18347
+ * @LastEditTime: 2025-01-20 18:46:32
17901
18348
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17902
18349
  *
17903
18350
  */
@@ -17992,7 +18439,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
17992
18439
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
17993
18440
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
17994
18441
  position: activeIndex + '',
17995
- fromKName: fk ? fk : fromKName,
18442
+ fromKName: fk || fromKName,
17996
18443
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
17997
18444
  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 : '',
17998
18445
  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 : ''
@@ -18022,9 +18469,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18022
18469
  skipLinkRef.current = false;
18023
18470
  }
18024
18471
  // 页面可见时触发,注意页面初始化时不会触发
18472
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18025
18473
  handleH5EnterLink();
18026
18474
  if (repCond) {
18027
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18475
+ setTimeout(() => {
18476
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18477
+ });
18028
18478
  backMainFeed('external', selectTag);
18029
18479
  }
18030
18480
  }