pb-sxp-ui 1.15.2 → 1.15.4

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 (68) hide show
  1. package/dist/index.cjs +658 -164
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +101 -0
  4. package/dist/index.js +658 -164
  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 +658 -164
  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/Consent/index.js +0 -1
  15. package/es/core/components/SxpPageRender/ConsentPopup.js +9 -9
  16. package/es/core/components/SxpPageRender/Navbar.js +1 -1
  17. package/es/core/components/SxpPageRender/index.js +12 -9
  18. package/es/core/context/SxpDataSourceProvider.d.ts +2 -0
  19. package/es/core/context/SxpDataSourceProvider.js +75 -36
  20. package/es/core/utils/materials.js +5 -3
  21. package/es/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  22. package/es/materials/sxp/consentPopup/Click/index.js +37 -0
  23. package/es/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  24. package/es/materials/sxp/consentPopup/Click/material.js +48 -0
  25. package/es/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  26. package/es/materials/sxp/consentPopup/Click/settingRender.js +210 -0
  27. package/es/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  28. package/es/materials/sxp/consentPopup/Display/index.js +7 -5
  29. package/es/materials/sxp/consentPopup/Swipe/index.d.ts +13 -0
  30. package/es/materials/sxp/consentPopup/Swipe/index.js +58 -0
  31. package/es/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  32. package/es/materials/sxp/consentPopup/Swipe/material.js +25 -0
  33. package/es/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  34. package/es/materials/sxp/consentPopup/Swipe/settingRender.js +48 -0
  35. package/es/materials/sxp/consentPopup/index.d.ts +2 -0
  36. package/es/materials/sxp/consentPopup/index.js +2 -0
  37. package/es/materials/sxp/cta/AniLink/index.js +1 -1
  38. package/es/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  39. package/es/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  40. package/es/materials/sxp/popup/ConsentDetail/index.js +2 -2
  41. package/lib/core/components/Consent/index.js +0 -1
  42. package/lib/core/components/SxpPageRender/ConsentPopup.js +8 -8
  43. package/lib/core/components/SxpPageRender/Navbar.js +1 -1
  44. package/lib/core/components/SxpPageRender/index.js +12 -9
  45. package/lib/core/context/SxpDataSourceProvider.d.ts +2 -0
  46. package/lib/core/context/SxpDataSourceProvider.js +75 -36
  47. package/lib/core/utils/materials.js +5 -3
  48. package/lib/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  49. package/lib/materials/sxp/consentPopup/Click/index.js +39 -0
  50. package/lib/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  51. package/lib/materials/sxp/consentPopup/Click/material.js +52 -0
  52. package/lib/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  53. package/lib/materials/sxp/consentPopup/Click/settingRender.js +212 -0
  54. package/lib/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  55. package/lib/materials/sxp/consentPopup/Display/index.js +7 -5
  56. package/lib/materials/sxp/consentPopup/Swipe/index.d.ts +13 -0
  57. package/lib/materials/sxp/consentPopup/Swipe/index.js +60 -0
  58. package/lib/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  59. package/lib/materials/sxp/consentPopup/Swipe/material.js +29 -0
  60. package/lib/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  61. package/lib/materials/sxp/consentPopup/Swipe/settingRender.js +50 -0
  62. package/lib/materials/sxp/consentPopup/index.d.ts +2 -0
  63. package/lib/materials/sxp/consentPopup/index.js +2 -0
  64. package/lib/materials/sxp/cta/AniLink/index.js +1 -1
  65. package/lib/materials/sxp/cta/AniLinkPopup/index.js +1 -1
  66. package/lib/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  67. package/lib/materials/sxp/popup/ConsentDetail/index.js +2 -2
  68. package/package.json +1 -1
package/dist/pb-ui.js CHANGED
@@ -544,7 +544,7 @@
544
544
  * @Author: binruan@chatlabs.com
545
545
  * @Date: 2024-06-13 15:16:53
546
546
  * @LastEditors: binruan@chatlabs.com
547
- * @LastEditTime: 2025-01-24 14:56:51
547
+ * @LastEditTime: 2025-02-20 11:20:58
548
548
  * @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
549
549
  *
550
550
  */
@@ -575,7 +575,6 @@
575
575
  utmCampaign: getUtmValue('utm_campaign'),
576
576
  utmId: getUtmValue('utm_id'),
577
577
  utmContent: getUtmValue('utm_content'),
578
- clSource: getUtmValue('cl_source'),
579
578
  enterTime: `${Date.now()}`,
580
579
  enterUrl: window.location.href,
581
580
  rtc: null,
@@ -650,6 +649,7 @@
650
649
  const [channel, setChannel] = React.useState();
651
650
  const [eventTimeList, setEventTimeList] = React.useState([]);
652
651
  const [playbookType, setPlaybookType] = React.useState();
652
+ const [chatlabsId, setChatlabsId] = React.useState();
653
653
  const finalPageData = React.useMemo(() => pageData !== null && pageData !== void 0 ? pageData : data, [pageData, data]);
654
654
  const isShowConsent = React.useMemo(() => {
655
655
  var _a, _b, _c, _d;
@@ -707,12 +707,15 @@
707
707
  const bffDataSource = React.useMemo(() => {
708
708
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
709
709
  }, [dataSources]);
710
+ const fakeUserId = React.useMemo(() => {
711
+ var _a;
712
+ return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
713
+ }, [bffDataSource]);
710
714
  // bff API 请求方法
711
715
  const bffFetch = React.useCallback((path, options) => {
712
716
  if (!bffDataSource)
713
717
  return;
714
718
  const url = bffDataSource.url;
715
- const fakeUserId = storeAndLoadFeUserId();
716
719
  if (options === null || options === void 0 ? void 0 : options.query) {
717
720
  const queryString = qs.stringify(options.query);
718
721
  path = `${path}?${queryString}`;
@@ -720,32 +723,23 @@
720
723
  // 事件上报优化
721
724
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
722
725
  if (options.type === 'beacon' && navigator.sendBeacon) {
723
- return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
726
+ return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
724
727
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
725
728
  ], { type: 'application/json;charset=UTF-8' }));
726
729
  }
727
730
  return window
728
- .fetch(`${url}/api/v1${path}`, {
731
+ .fetch(`${url}/api/${path}`, {
729
732
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
730
733
  method: options.method,
731
734
  body: JSON.stringify(options.body)
732
735
  })
733
736
  .then((res) => res.json())
734
737
  .catch((err) => Promise.reject(err));
735
- }, [bffDataSource]);
738
+ }, [bffDataSource, fakeUserId]);
736
739
  // 获取推荐视频数据
737
740
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
738
741
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
739
- query = {
740
- maxSize: (_f = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _f !== void 0 ? _f : maxSize,
741
- defaultSize: (_g = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _g !== void 0 ? _g : defaultSize,
742
- hashTag: query === null || query === void 0 ? void 0 : query.hashTag,
743
- traceInfo: query === null || query === void 0 ? void 0 : query.traceInfo,
744
- themeTag: query === null || query === void 0 ? void 0 : query.themeTag,
745
- pageNum: query === null || query === void 0 ? void 0 : query.pageNum,
746
- contentFilter: query === null || query === void 0 ? void 0 : query.contentFilter,
747
- productFilter: query === null || query === void 0 ? void 0 : query.productFilter
748
- };
742
+ query = Object.assign({ maxSize: (_f = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _f !== void 0 ? _f : maxSize, defaultSize: (_g = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _g !== void 0 ? _g : defaultSize, hashTag: query === null || query === void 0 ? void 0 : query.hashTag, traceInfo: query === null || query === void 0 ? void 0 : query.traceInfo, themeTag: query === null || query === void 0 ? void 0 : query.themeTag, pageNum: query === null || query === void 0 ? void 0 : query.pageNum, contentFilter: query === null || query === void 0 ? void 0 : query.contentFilter, productFilter: query === null || query === void 0 ? void 0 : query.productFilter }, (chatlabsId && { chatlabsId }));
749
743
  if (channel) {
750
744
  query = Object.assign(Object.assign({}, query), { channel: decodeURIComponent(channel) });
751
745
  }
@@ -770,14 +764,16 @@
770
764
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
771
765
  var _v, _w, _x, _y, _z, _0;
772
766
  query.pageNum = pageNum;
773
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
767
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
774
768
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
775
769
  return undefined;
776
770
  }
777
771
  setLoading(false);
778
772
  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 : []);
779
- setRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
780
- setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
773
+ if ((rtcList === null || rtcList === void 0 ? void 0 : rtcList.length) === 0) {
774
+ setRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
775
+ setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
776
+ }
781
777
  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));
782
778
  if (isNotNullList) {
783
779
  pageNum = pageNum + 1;
@@ -787,12 +783,12 @@
787
783
  yield recurveRecList(query);
788
784
  if (!(query === null || query === void 0 ? void 0 : query.hashTag) && result)
789
785
  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 });
790
- return Object.assign(Object.assign({}, result.data), { recList: list });
786
+ return Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list });
791
787
  }
792
788
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
793
789
  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 });
794
790
  }
795
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
791
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
796
792
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
797
793
  return undefined;
798
794
  }
@@ -808,7 +804,7 @@
808
804
  return Object.assign(Object.assign({}, result.data), { recList: list });
809
805
  }
810
806
  return result === null || result === void 0 ? void 0 : result.data;
811
- }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel]);
807
+ }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel, chatlabsId]);
812
808
  const loadVideos = React.useCallback((pageNum) => __awaiter(void 0, void 0, void 0, function* () {
813
809
  var _1, _2, _3, _4;
814
810
  if (rtcList.length <= 0) {
@@ -842,6 +838,7 @@
842
838
  return expire;
843
839
  }, [data]);
844
840
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
841
+ var _a, _b;
845
842
  // 关闭 BFF 事件上报
846
843
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
847
844
  return;
@@ -854,7 +851,15 @@
854
851
  };
855
852
  }
856
853
  const sessionID = storeAndLoadFeSessionId();
857
- const ef = Object.assign(Object.assign(Object.assign(Object.assign({ sessionID, rtc: curReqInfo.rtc, requestId: curReqInfo.requestId }, { playbookType }), (layoutVariantId && reportLayId && { layoutVariantId })), eventInfo), ((eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) && channel && { position: Number(eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) + 1 + '' }));
854
+ const params = {};
855
+ const queryString = location.search.slice(1);
856
+ (_a = splitUrlParams(queryString)) === null || _a === void 0 ? void 0 : _a.map((val) => {
857
+ const key = val.split('=')[0];
858
+ const value = val.split('=')[1];
859
+ params[key] = value;
860
+ });
861
+ const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
862
+ 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 && { clSource: cl_source }));
858
863
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
859
864
  const realEventInfo = Object.entries(ef)
860
865
  .map(([k, v]) => v && { name: k, value: v })
@@ -863,14 +868,23 @@
863
868
  console.log('userInfo:', userInfo);
864
869
  console.log('eventInfo:', ef);
865
870
  console.log('========= 结束 =========');
866
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
871
+ 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}`, {
867
872
  method: 'POST',
868
873
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
869
874
  type: 'beacon'
870
875
  });
871
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
876
+ }, [
877
+ bffFetch,
878
+ curReqInfo,
879
+ enableReportEvent,
880
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
881
+ layoutVariantId,
882
+ globalConfig,
883
+ playbookType,
884
+ bffDataSource
885
+ ]);
872
886
  const bffFbReport = React.useCallback(({ eventName, product }) => {
873
- var _a, _b, _c, _d, _e;
887
+ var _a, _b, _c, _d, _e, _f;
874
888
  if (!enableReportEvent ||
875
889
  !enabledMetaConversionApi ||
876
890
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -882,7 +896,7 @@
882
896
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
883
897
  const fix_par = {
884
898
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
885
- external_id: storeAndLoadFeUserId(),
899
+ external_id: fakeUserId,
886
900
  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 : '',
887
901
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
888
902
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -934,22 +948,30 @@
934
948
  }
935
949
  };
936
950
  getEventParams(jsonParams);
937
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
951
+ 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}`, {
938
952
  method: 'POST',
939
953
  body: jsonParams,
940
954
  type: 'beacon'
941
955
  });
942
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
956
+ }, [
957
+ bffFetch,
958
+ enableReportEvent,
959
+ enabledMetaConversionApi,
960
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
961
+ globalConfig,
962
+ fakeUserId,
963
+ bffDataSource
964
+ ]);
943
965
  const bffMutateLike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
944
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
966
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
945
967
  return res === null || res === void 0 ? void 0 : res.success;
946
968
  }), [bffFetch]);
947
969
  const bffMutateUnlike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
948
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
970
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
949
971
  return res === null || res === void 0 ? void 0 : res.success;
950
972
  }), [bffFetch]);
951
973
  const bffSubmitForm = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
952
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
974
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
953
975
  return res === null || res === void 0 ? void 0 : res.success;
954
976
  }), [bffFetch]);
955
977
  // 获取 Tag
@@ -964,7 +986,7 @@
964
986
  const key = val.split('=')[0];
965
987
  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);
966
988
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
967
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
989
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
968
990
  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 : []);
969
991
  }
970
992
  catch (e) {
@@ -1019,12 +1041,26 @@
1019
1041
  utmContent: getVal('utm_content'),
1020
1042
  enterTime: Math.floor(time / 1000) + '',
1021
1043
  requestId: null,
1022
- enterUrl: (_c = (_b = window === null || window === void 0 ? void 0 : window.location) === null || _b === void 0 ? void 0 : _b.href) !== null && _c !== void 0 ? _c : '',
1023
- clSource: getVal('cl_source')
1044
+ enterUrl: (_c = (_b = window === null || window === void 0 ? void 0 : window.location) === null || _b === void 0 ? void 0 : _b.href) !== null && _c !== void 0 ? _c : ''
1024
1045
  },
1025
1046
  reportLayId: false
1026
1047
  });
1027
1048
  }, [bffEventReport]);
1049
+ const getAccount = React.useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
1050
+ var _13, _14;
1051
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account', { method: 'GET' }));
1052
+ setChatlabsId((_13 = res === null || res === void 0 ? void 0 : res.data) === null || _13 === void 0 ? void 0 : _13.chatLabsId);
1053
+ return ((_14 = res === null || res === void 0 ? void 0 : res.data) === null || _14 === void 0 ? void 0 : _14.consentResult) === 'true';
1054
+ }), [bffFetch]);
1055
+ const accountSonsent = React.useCallback((consentResult) => __awaiter(void 0, void 0, void 0, function* () {
1056
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account/consent', {
1057
+ method: 'POST',
1058
+ body: {
1059
+ consentResult
1060
+ }
1061
+ }));
1062
+ return res === null || res === void 0 ? void 0 : res.success;
1063
+ }), [bffFetch]);
1028
1064
  React.useEffect(() => {
1029
1065
  if (!isShowConsent)
1030
1066
  h5EnterLink();
@@ -1043,10 +1079,10 @@
1043
1079
  let curData;
1044
1080
  let gldata;
1045
1081
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1082
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1083
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1046
1084
  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];
1047
1085
  if (id) {
1048
- layId = id;
1049
- setLayoutVariantId(id);
1050
1086
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1051
1087
  if (curData) {
1052
1088
  setPageData(curData);
@@ -1173,7 +1209,9 @@
1173
1209
  eventTimeList,
1174
1210
  setEventTimeList,
1175
1211
  multiPostTimeRef,
1176
- refreshFeSession
1212
+ refreshFeSession,
1213
+ getAccount,
1214
+ accountSonsent
1177
1215
  } }, isShowConsent ? (React.createElement(Consent$4, Object.assign({}, (_e = (_d = (_c = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consent) === null || _c === void 0 ? void 0 : _c[0]) === null || _d === void 0 ? void 0 : _d.item) === null || _e === void 0 ? void 0 : _e.props))) : (render({
1178
1216
  rtcList,
1179
1217
  mutateLike: bffMutateLike,
@@ -1432,7 +1470,7 @@
1432
1470
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1433
1471
  *
1434
1472
  */
1435
- var settingRender$d = [
1473
+ var settingRender$f = [
1436
1474
  {
1437
1475
  title: '弹窗背景',
1438
1476
  child: [
@@ -1868,7 +1906,7 @@
1868
1906
  category: 'popup',
1869
1907
  type: 'AppointForm',
1870
1908
  related: {
1871
- settingRender: settingRender$d,
1909
+ settingRender: settingRender$f,
1872
1910
  bindableProps: [],
1873
1911
  interactionRender: interactionRender$g
1874
1912
  },
@@ -1893,7 +1931,7 @@
1893
1931
  sort: 2
1894
1932
  });
1895
1933
 
1896
- var settingRender$c = [
1934
+ var settingRender$e = [
1897
1935
  {
1898
1936
  title: '弹窗背景',
1899
1937
  child: [
@@ -10133,7 +10171,7 @@
10133
10171
  * @Author: binruan@chatlabs.com
10134
10172
  * @Date: 2024-03-20 14:56:16
10135
10173
  * @LastEditors: binruan@chatlabs.com
10136
- * @LastEditTime: 2024-10-24 17:51:19
10174
+ * @LastEditTime: 2024-12-20 14:32:26
10137
10175
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10138
10176
  *
10139
10177
  */
@@ -10171,14 +10209,16 @@
10171
10209
  };
10172
10210
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10173
10211
  var _a, _b, _c, _d, _e, _f, _g, _h;
10212
+ let text = '';
10174
10213
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10175
10214
  return null;
10176
- let price = (product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price) ? product === null || product === void 0 ? void 0 : product.price : 7000;
10177
- let text = '';
10215
+ 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);
10216
+ if (typeof price !== 'number')
10217
+ return text;
10178
10218
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10179
10219
  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 : '' : '$';
10180
10220
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10181
- let decPic = price.toString();
10221
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10182
10222
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10183
10223
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10184
10224
  }
@@ -10490,7 +10530,7 @@
10490
10530
  category: 'popup',
10491
10531
  type: 'CommodityDetail',
10492
10532
  related: {
10493
- settingRender: settingRender$c,
10533
+ settingRender: settingRender$e,
10494
10534
  interactionRender: interactionRender$f
10495
10535
  },
10496
10536
  defaulSetting: {
@@ -10566,7 +10606,7 @@
10566
10606
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10567
10607
  *
10568
10608
  */
10569
- var settingRender$b = [
10609
+ var settingRender$d = [
10570
10610
  {
10571
10611
  title: '弹窗背景',
10572
10612
  child: [
@@ -10707,7 +10747,7 @@
10707
10747
  }
10708
10748
  ];
10709
10749
 
10710
- var img$5 = "";
10750
+ var img$7 = "";
10711
10751
 
10712
10752
  const Prompt$1 = (_a) => {
10713
10753
  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"]);
@@ -10730,7 +10770,7 @@
10730
10770
  };
10731
10771
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10732
10772
  React.createElement("div", { className: 'pb-prompt-icon' },
10733
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10773
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10734
10774
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10735
10775
  __html: setFontForText(content, contentStyle)
10736
10776
  } }),
@@ -10746,13 +10786,13 @@
10746
10786
  category: 'popup',
10747
10787
  type: 'Prompt',
10748
10788
  related: {
10749
- settingRender: settingRender$b,
10789
+ settingRender: settingRender$d,
10750
10790
  bindableProps: [],
10751
10791
  interactionRender: interactionRender$e
10752
10792
  },
10753
10793
  defaulSetting: {
10754
10794
  props: {
10755
- icon: img$5,
10795
+ icon: img$7,
10756
10796
  content: 'You have successfully completed the appointment!',
10757
10797
  btnText: 'OK'
10758
10798
  },
@@ -10771,7 +10811,7 @@
10771
10811
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10772
10812
  *
10773
10813
  */
10774
- var settingRender$a = [
10814
+ var settingRender$c = [
10775
10815
  {
10776
10816
  title: '弹窗背景',
10777
10817
  child: [
@@ -11450,7 +11490,7 @@ Made in Italy` })));
11450
11490
  category: 'popup',
11451
11491
  type: 'CommodityDetailDiroNew',
11452
11492
  related: {
11453
- settingRender: settingRender$a,
11493
+ settingRender: settingRender$c,
11454
11494
  interactionRender: interactionRender$d
11455
11495
  },
11456
11496
  defaulSetting: {
@@ -11514,7 +11554,7 @@ Made in Italy` })));
11514
11554
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11515
11555
  *
11516
11556
  */
11517
- var settingRender$9 = [
11557
+ var settingRender$b = [
11518
11558
  {
11519
11559
  title: '弹窗背景',
11520
11560
  child: [
@@ -11951,7 +11991,7 @@ Made in Italy` })));
11951
11991
  category: 'popup',
11952
11992
  type: 'CommodityList',
11953
11993
  related: {
11954
- settingRender: settingRender$9,
11994
+ settingRender: settingRender$b,
11955
11995
  interactionRender: interactionRender$c
11956
11996
  },
11957
11997
  defaulSetting: {
@@ -12000,7 +12040,7 @@ Made in Italy` })));
12000
12040
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
12001
12041
  *
12002
12042
  */
12003
- var settingRender$8 = [
12043
+ var settingRender$a = [
12004
12044
  {
12005
12045
  title: '背景样式',
12006
12046
  child: [
@@ -12034,7 +12074,7 @@ Made in Italy` })));
12034
12074
  category: 'popup',
12035
12075
  type: 'Iframe',
12036
12076
  related: {
12037
- settingRender: settingRender$8,
12077
+ settingRender: settingRender$a,
12038
12078
  bindableProps: []
12039
12079
  },
12040
12080
  defaulSetting: {
@@ -12054,7 +12094,7 @@ Made in Italy` })));
12054
12094
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12055
12095
  *
12056
12096
  */
12057
- var settingRender$7 = [
12097
+ var settingRender$9 = [
12058
12098
  {
12059
12099
  title: '弹窗文本',
12060
12100
  child: [
@@ -12067,22 +12107,22 @@ Made in Italy` })));
12067
12107
  ];
12068
12108
 
12069
12109
  const ConsentDetail$1 = (_a) => {
12070
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12110
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12071
12111
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12072
12112
  __html: typeof content === 'string' ? content : ''
12073
12113
  }, onClick: (e) => {
12074
12114
  e.stopPropagation();
12075
- } }));
12115
+ }, style: style }));
12076
12116
  };
12077
- var ConsentDetailComponent = React.memo(ConsentDetail$1);
12117
+ var ConsentDetail$2 = React.memo(ConsentDetail$1);
12078
12118
 
12079
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12119
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12080
12120
  displayName: '协议详情',
12081
12121
  icon: '',
12082
12122
  category: 'popup',
12083
12123
  type: 'ConsentDetail',
12084
12124
  related: {
12085
- settingRender: settingRender$7,
12125
+ settingRender: settingRender$9,
12086
12126
  bindableProps: []
12087
12127
  },
12088
12128
  defaulSetting: {
@@ -12102,7 +12142,7 @@ Made in Italy` })));
12102
12142
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12103
12143
  *
12104
12144
  */
12105
- var settingRender$6 = [
12145
+ var settingRender$8 = [
12106
12146
  {
12107
12147
  title: '主题样式',
12108
12148
  child: [
@@ -12456,7 +12496,7 @@ Made in Italy` })));
12456
12496
  related: {
12457
12497
  interactionRender: interactionRender$b,
12458
12498
  bindableProps: [],
12459
- settingRender: settingRender$6
12499
+ settingRender: settingRender$8
12460
12500
  },
12461
12501
  defaulSetting: {
12462
12502
  props: {
@@ -12538,7 +12578,7 @@ Made in Italy` })));
12538
12578
  type: 'Appoint',
12539
12579
  related: {
12540
12580
  interactionRender: interactionRender$a,
12541
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12581
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12542
12582
  bindableProps: []
12543
12583
  },
12544
12584
  defaulSetting: {
@@ -12744,7 +12784,7 @@ Made in Italy` })));
12744
12784
  category: 'template',
12745
12785
  type: 'Link',
12746
12786
  related: {
12747
- settingRender: (_a = settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle')) === null || _a === void 0 ? void 0 : _a.concat(linkSettingRender),
12787
+ 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),
12748
12788
  bindableProps: [],
12749
12789
  interactionRender: interactionRender$9
12750
12790
  },
@@ -12847,7 +12887,7 @@ Made in Italy` })));
12847
12887
  type: 'CommodityDiro',
12848
12888
  related: {
12849
12889
  interactionRender: interactionRender$8,
12850
- settingRender: settingRender$6,
12890
+ settingRender: settingRender$8,
12851
12891
  bindableProps: []
12852
12892
  },
12853
12893
  defaulSetting: {
@@ -12944,7 +12984,7 @@ Made in Italy` })));
12944
12984
  related: {
12945
12985
  interactionRender: interactionRender$7,
12946
12986
  bindableProps: [],
12947
- settingRender: settingRender$6
12987
+ settingRender: settingRender$8
12948
12988
  },
12949
12989
  defaulSetting: {
12950
12990
  props: {
@@ -13044,7 +13084,7 @@ Made in Italy` })));
13044
13084
  related: {
13045
13085
  interactionRender: interactionRender$6,
13046
13086
  bindableProps: [],
13047
- settingRender: settingRender$6
13087
+ settingRender: settingRender$8
13048
13088
  },
13049
13089
  defaulSetting: {
13050
13090
  props: {
@@ -13142,7 +13182,7 @@ Made in Italy` })));
13142
13182
  type: 'MultiCommodity',
13143
13183
  related: {
13144
13184
  interactionRender: interactionRender$5,
13145
- settingRender: settingRender$6,
13185
+ settingRender: settingRender$8,
13146
13186
  bindableProps: []
13147
13187
  },
13148
13188
  defaulSetting: {
@@ -13251,7 +13291,7 @@ Made in Italy` })));
13251
13291
  related: {
13252
13292
  interactionRender: interactionRender$4,
13253
13293
  bindableProps: [],
13254
- settingRender: settingRender$6
13294
+ settingRender: settingRender$8
13255
13295
  },
13256
13296
  defaulSetting: {
13257
13297
  props: {
@@ -13300,7 +13340,7 @@ Made in Italy` })));
13300
13340
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13301
13341
  *
13302
13342
  */
13303
- var settingRender$5 = [
13343
+ var settingRender$7 = [
13304
13344
  {
13305
13345
  title: 'Banner',
13306
13346
  child: [
@@ -13532,7 +13572,7 @@ Made in Italy` })));
13532
13572
  * @Author: binruan@chatlabs.com
13533
13573
  * @Date: 2023-12-26 16:11:34
13534
13574
  * @LastEditors: binruan@chatlabs.com
13535
- * @LastEditTime: 2024-10-11 18:22:21
13575
+ * @LastEditTime: 2025-01-17 18:55:14
13536
13576
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Navbar.tsx
13537
13577
  *
13538
13578
  */
@@ -13543,7 +13583,7 @@ Made in Italy` })));
13543
13583
  React.createElement("button", { className: 'clc-sxp-nav-left', role: 'button', "aria-label": 'back button', onClick: onClose },
13544
13584
  React.createElement("img", { src: icon, alt: 'back button' })),
13545
13585
  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: {
13546
- __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : '标题'}`, textStyle)
13586
+ __html: setFontForText(`#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : 'title'}`, textStyle)
13547
13587
  } })));
13548
13588
  };
13549
13589
  var Navbar$1 = React.memo(Navbar);
@@ -15127,7 +15167,7 @@ Made in Italy` })));
15127
15167
  } }))))));
15128
15168
  }
15129
15169
 
15130
- var img$4 = "";
15170
+ var img$6 = "";
15131
15171
 
15132
15172
  const WaterfallFlowItem = (props) => {
15133
15173
  var _a;
@@ -15448,7 +15488,7 @@ Made in Italy` })));
15448
15488
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15449
15489
  display: openHashtag ? 'block' : 'none'
15450
15490
  } },
15451
- React.createElement(Navbar$1, { icon: img$4, styles: { top: '32px' }, textStyle: (_a = props === null || props === void 0 ? void 0 : props.textStyles) === null || _a === void 0 ? void 0 : _a.hashTagTitle, onClose: handleClose }),
15491
+ 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 }),
15452
15492
  ((_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);
15453
15493
  };
15454
15494
  var WaterFall$1 = React.memo(WaterFall);
@@ -15480,7 +15520,7 @@ Made in Italy` })));
15480
15520
  category: 'base',
15481
15521
  type: 'HashTag',
15482
15522
  related: {
15483
- settingRender: settingRender$5,
15523
+ settingRender: settingRender$7,
15484
15524
  bindableProps: []
15485
15525
  },
15486
15526
  defaulSetting: {
@@ -15546,7 +15586,7 @@ Made in Italy` })));
15546
15586
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15547
15587
  *
15548
15588
  */
15549
- var settingRender$4 = [
15589
+ var settingRender$6 = [
15550
15590
  {
15551
15591
  title: '协议详情',
15552
15592
  child: [
@@ -15605,7 +15645,7 @@ Made in Italy` })));
15605
15645
  category: 'base',
15606
15646
  type: 'Consent',
15607
15647
  related: {
15608
- settingRender: settingRender$4
15648
+ settingRender: settingRender$6
15609
15649
  },
15610
15650
  defaulSetting: {
15611
15651
  props: {},
@@ -15624,7 +15664,7 @@ Made in Italy` })));
15624
15664
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15625
15665
  *
15626
15666
  */
15627
- var settingRender$3 = [
15667
+ var settingRender$5 = [
15628
15668
  {
15629
15669
  title: '主题样式',
15630
15670
  child: [
@@ -15769,7 +15809,7 @@ Made in Italy` })));
15769
15809
  onClick === null || onClick === void 0 ? void 0 : onClick();
15770
15810
  }
15771
15811
  };
15772
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
15812
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
15773
15813
  const aniTimStyle = React.useMemo(() => {
15774
15814
  var _a, _b;
15775
15815
  const ani = event === null || event === void 0 ? void 0 : event.animation;
@@ -15885,7 +15925,7 @@ Made in Italy` })));
15885
15925
  category: 'cta',
15886
15926
  type: 'AniLink',
15887
15927
  related: {
15888
- settingRender: settingRender$3,
15928
+ settingRender: settingRender$5,
15889
15929
  bindableProps: [],
15890
15930
  interactionRender: interactionRender$3
15891
15931
  },
@@ -15929,7 +15969,7 @@ Made in Italy` })));
15929
15969
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15930
15970
  *
15931
15971
  */
15932
- var settingRender$2 = [
15972
+ var settingRender$4 = [
15933
15973
  {
15934
15974
  title: '主题样式',
15935
15975
  child: [
@@ -16216,7 +16256,7 @@ Made in Italy` })));
16216
16256
  onClick === null || onClick === void 0 ? void 0 : onClick();
16217
16257
  }
16218
16258
  };
16219
- const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || '查看详情';
16259
+ const title = (cta === null || cta === void 0 ? void 0 : cta.enTitle) || 'Show More';
16220
16260
  const aniTimStyle = React.useMemo(() => {
16221
16261
  const ani = event === null || event === void 0 ? void 0 : event.animation;
16222
16262
  if (ani) {
@@ -16333,7 +16373,7 @@ Made in Italy` })));
16333
16373
  category: 'cta',
16334
16374
  type: 'AniLinkPopup',
16335
16375
  related: {
16336
- settingRender: settingRender$2,
16376
+ settingRender: settingRender$4,
16337
16377
  bindableProps: [],
16338
16378
  interactionRender: interactionRender$2
16339
16379
  },
@@ -16412,7 +16452,7 @@ Made in Italy` })));
16412
16452
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16413
16453
  *
16414
16454
  */
16415
- var settingRender$1 = [
16455
+ var settingRender$3 = [
16416
16456
  {
16417
16457
  title: '全局设置',
16418
16458
  child: [
@@ -16553,74 +16593,27 @@ Made in Italy` })));
16553
16593
  }
16554
16594
  ];
16555
16595
 
16556
- /*
16557
- * @Author: binruan@chatlabs.com
16558
- * @Date: 2023-12-26 10:38:53
16559
- * @LastEditors: binruan@chatlabs.com
16560
- * @LastEditTime: 2024-12-11 18:24:31
16561
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16562
- *
16563
- */
16564
- const EditorDataContext = React.createContext({});
16565
- const EditorDataProvider = ({ children, data }) => {
16566
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16567
- const [openHashtag, setOpenHashtag] = React.useState(false);
16568
- const [openConsent, setOpenConsent] = React.useState(false);
16569
- const [consentPopupCate, setConsentPopupCate] = React.useState('');
16570
- const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
16571
- return (React.createElement(EditorDataContext.Provider, { value: {
16572
- sxpPrameter: {
16573
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16574
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16575
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16576
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16577
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16578
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16579
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16580
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16581
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16582
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16583
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16584
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16585
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16586
- },
16587
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16588
- openHashtag,
16589
- setOpenHashtag,
16590
- openConsent,
16591
- setOpenConsent,
16592
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16593
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16594
- consentPopupCate,
16595
- setConsentPopupCate,
16596
- openMultiPosts,
16597
- setOpenMultiPosts,
16598
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16599
- } }, children));
16600
- };
16601
- function useEditorDataProvider() {
16602
- return React.useContext(EditorDataContext);
16603
- }
16604
-
16605
- var img$3 = "data:image/svg+xml,%3c%3fxml version='1.0' standalone='no'%3f%3e%3c!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'%3e%3csvg t='1730260080030' class='icon' viewBox='0 0 1024 1024' version='1.1' xmlns='http://www.w3.org/2000/svg' p-id='4241' xmlns:xlink='http://www.w3.org/1999/xlink' width='64' height='64'%3e%3cpath d='M895.156706 86.256941a30.177882 30.177882 0 0 1 42.767059-0.180706c11.745882 11.745882 11.745882 30.870588-0.180706 42.767059L128.843294 937.743059c-11.866353 11.866353-30.930824 12.047059-42.767059 0.180706-11.745882-11.745882-11.745882-30.870588 0.180706-42.767059L895.156706 86.256941z' fill='white' p-id='4242'%3e%3c/path%3e%3cpath d='M86.076235 86.076235c11.745882-11.745882 30.870588-11.745882 42.767059 0.180706l808.899765 808.899765c11.866353 11.866353 12.047059 30.930824 0.180706 42.767059-11.745882 11.745882-30.870588 11.745882-42.767059-0.180706L86.256941 128.843294a30.177882 30.177882 0 0 1-0.180706-42.767059z' fill='white' p-id='4243'%3e%3c/path%3e%3cpath d='M0 0h1024v1024H0z' fill='white' fill-opacity='0' p-id='4244'%3e%3c/path%3e%3c/svg%3e";
16596
+ 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";
16606
16597
 
16607
- var img$2 = "";
16598
+ var img$4 = "";
16608
16599
 
16609
16600
  const Display$1 = (_a) => {
16610
16601
  var _b, _c;
16611
- var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16612
- const { consentPopupCate } = useEditorDataProvider();
16602
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16613
16603
  const [isClose, setIsClose] = React.useState(false);
16604
+ const contsentState = React.useMemo(() => {
16605
+ return getContsentState();
16606
+ }, []);
16614
16607
  const visivle = React.useMemo(() => {
16615
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16616
- }, [consentPopupCate, open, isClose]);
16608
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16609
+ }, [consentPopupCate, open, isClose, contsentState]);
16617
16610
  const handleClickClose = React.useCallback(() => {
16618
16611
  setIsClose(true);
16619
16612
  }, []);
16620
16613
  const handleClick = React.useCallback(() => {
16621
16614
  onClick === null || onClick === void 0 ? void 0 : onClick();
16622
16615
  }, []);
16623
- return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$2, width: '100%' })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupDisplay', style: style },
16616
+ 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 },
16624
16617
  React.createElement("div", { style: { flex: 1 } },
16625
16618
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16626
16619
  __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)
@@ -16629,7 +16622,7 @@ Made in Italy` })));
16629
16622
  __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)
16630
16623
  }, onClick: handleClick })),
16631
16624
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16632
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16625
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16633
16626
  };
16634
16627
  var DisplayComponent = React.memo(Display$1);
16635
16628
 
@@ -16655,7 +16648,7 @@ Made in Italy` })));
16655
16648
  category: 'consentPopup',
16656
16649
  type: 'Display',
16657
16650
  related: {
16658
- settingRender: settingRender$1,
16651
+ settingRender: settingRender$3,
16659
16652
  bindableProps: [],
16660
16653
  interactionRender: interactionRender$1
16661
16654
  },
@@ -16686,6 +16679,453 @@ Made in Italy` })));
16686
16679
  sort: 1
16687
16680
  });
16688
16681
 
16682
+ /*
16683
+ * @Author: binruan@chatlabs.com
16684
+ * @Date: 2023-07-28 18:29:57
16685
+ * @LastEditors: binruan@chatlabs.com
16686
+ * @LastEditTime: 2025-02-07 14:23:57
16687
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16688
+ *
16689
+ */
16690
+ var settingRender$2 = [
16691
+ {
16692
+ title: '全局设置',
16693
+ child: [
16694
+ {
16695
+ type: 'Switch',
16696
+ label: '弹窗开关',
16697
+ name: ['props', 'open']
16698
+ },
16699
+ {
16700
+ type: 'Color',
16701
+ label: '背景色',
16702
+ name: ['style', 'backgroundColor']
16703
+ },
16704
+ {
16705
+ type: 'Number',
16706
+ label: '内边距',
16707
+ name: ['style', 'padding'],
16708
+ addonAfter: 'px'
16709
+ }
16710
+ ]
16711
+ },
16712
+ {
16713
+ title: '弹窗文本',
16714
+ child: [
16715
+ {
16716
+ type: 'RichText',
16717
+ name: ['props', 'content']
16718
+ }
16719
+ ]
16720
+ },
16721
+ {
16722
+ title: '接受按钮样式',
16723
+ child: [
16724
+ {
16725
+ type: 'Color',
16726
+ label: '背景色',
16727
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16728
+ },
16729
+ {
16730
+ type: 'Number',
16731
+ label: '尺寸',
16732
+ name: ['props', 'acceptButton', 'style', 'height'],
16733
+ addonAfter: 'H'
16734
+ },
16735
+ {
16736
+ type: 'Group',
16737
+ label: '圆角',
16738
+ child: [
16739
+ {
16740
+ type: 'Slider',
16741
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16742
+ max: 100
16743
+ },
16744
+ {
16745
+ type: 'Number',
16746
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16747
+ addonAfter: 'px',
16748
+ max: 100
16749
+ }
16750
+ ]
16751
+ },
16752
+ {
16753
+ type: 'TextMargin',
16754
+ label: '边距',
16755
+ name: ['props', 'acceptButton', 'style']
16756
+ },
16757
+ {
16758
+ type: 'Group',
16759
+ label: '字体',
16760
+ child: [
16761
+ {
16762
+ type: 'Select',
16763
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16764
+ bottomText: '中文字体'
16765
+ },
16766
+ {
16767
+ type: 'Select',
16768
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16769
+ bottomText: '英文/其他字体'
16770
+ }
16771
+ ]
16772
+ },
16773
+ {
16774
+ type: 'Group',
16775
+ label: '',
16776
+ child: [
16777
+ {
16778
+ type: 'Color',
16779
+ name: ['props', 'acceptButton', 'style', 'color']
16780
+ },
16781
+ {
16782
+ type: 'Number',
16783
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16784
+ addonAfter: 'px'
16785
+ }
16786
+ ]
16787
+ },
16788
+ {
16789
+ label: '样式',
16790
+ type: 'TextStyle',
16791
+ name: ['props', 'acceptButton', 'style']
16792
+ },
16793
+ {
16794
+ label: '对齐',
16795
+ type: 'TextAlign',
16796
+ name: ['props', 'acceptButton', 'style']
16797
+ },
16798
+ {
16799
+ label: '间距',
16800
+ type: 'TextSpace',
16801
+ name: ['props', 'acceptButton', 'style']
16802
+ },
16803
+ {
16804
+ label: '文本',
16805
+ type: 'TextArea',
16806
+ name: ['props', 'acceptButton', 'text']
16807
+ }
16808
+ ]
16809
+ },
16810
+ {
16811
+ title: '拒绝按钮样式',
16812
+ child: [
16813
+ {
16814
+ type: 'Color',
16815
+ label: '背景色',
16816
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16817
+ },
16818
+ {
16819
+ type: 'Number',
16820
+ label: '尺寸',
16821
+ name: ['props', 'rejectButton', 'style', 'height'],
16822
+ addonAfter: 'H'
16823
+ },
16824
+ {
16825
+ type: 'Group',
16826
+ label: '圆角',
16827
+ child: [
16828
+ {
16829
+ type: 'Slider',
16830
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16831
+ max: 100
16832
+ },
16833
+ {
16834
+ type: 'Number',
16835
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16836
+ addonAfter: 'px',
16837
+ max: 100
16838
+ }
16839
+ ]
16840
+ },
16841
+ {
16842
+ type: 'TextMargin',
16843
+ label: '边距',
16844
+ name: ['props', 'rejectButton', 'style']
16845
+ },
16846
+ {
16847
+ type: 'Group',
16848
+ label: '字体',
16849
+ child: [
16850
+ {
16851
+ type: 'Select',
16852
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16853
+ bottomText: '中文字体'
16854
+ },
16855
+ {
16856
+ type: 'Select',
16857
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16858
+ bottomText: '英文/其他字体'
16859
+ }
16860
+ ]
16861
+ },
16862
+ {
16863
+ type: 'Group',
16864
+ label: '',
16865
+ child: [
16866
+ {
16867
+ type: 'Color',
16868
+ name: ['props', 'rejectButton', 'style', 'color']
16869
+ },
16870
+ {
16871
+ type: 'Number',
16872
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16873
+ addonAfter: 'px'
16874
+ }
16875
+ ]
16876
+ },
16877
+ {
16878
+ label: '样式',
16879
+ type: 'TextStyle',
16880
+ name: ['props', 'rejectButton', 'style']
16881
+ },
16882
+ {
16883
+ label: '对齐',
16884
+ type: 'TextAlign',
16885
+ name: ['props', 'rejectButton', 'style']
16886
+ },
16887
+ {
16888
+ label: '间距',
16889
+ type: 'TextSpace',
16890
+ name: ['props', 'rejectButton', 'style']
16891
+ },
16892
+ {
16893
+ label: '文本',
16894
+ type: 'TextArea',
16895
+ name: ['props', 'rejectButton', 'text']
16896
+ }
16897
+ ]
16898
+ }
16899
+ ];
16900
+
16901
+ var img$3 = "";
16902
+
16903
+ const Click$1 = (_a) => {
16904
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16905
+ const { getAccount, accountSonsent } = useSxpDataSource();
16906
+ const [consentResult, setConsentResult] = React.useState(false);
16907
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
16908
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
16909
+ setConsentResult(res);
16910
+ });
16911
+ React.useEffect(() => {
16912
+ handleGetAccount();
16913
+ }, []);
16914
+ const visivle = React.useMemo(() => {
16915
+ return consentPopupCate || (open && style && !consentResult);
16916
+ }, [consentPopupCate, open, style, consentResult]);
16917
+ const handleClick = (v) => {
16918
+ accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(v);
16919
+ setConsentResult(true);
16920
+ };
16921
+ 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' },
16922
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16923
+ React.createElement("div", { className: 'consentPopupClick-container-content' },
16924
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
16925
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: () => handleClick(true), dangerouslySetInnerHTML: {
16926
+ __html: setFontForText(acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style)
16927
+ } }),
16928
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: () => handleClick(false), dangerouslySetInnerHTML: {
16929
+ __html: setFontForText(rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style)
16930
+ } }))))))));
16931
+ };
16932
+ var ClickComponent = React.memo(Click$1);
16933
+
16934
+ /*
16935
+ * @Author: binruan@chatlabs.com
16936
+ * @Date: 2025-01-14 16:22:35
16937
+ * @LastEditors: binruan@chatlabs.com
16938
+ * @LastEditTime: 2025-01-15 17:09:49
16939
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16940
+ *
16941
+ */
16942
+ const Click = createMaterial(ClickComponent, {
16943
+ displayName: 'Click Consent',
16944
+ icon: '',
16945
+ category: 'consentPopup',
16946
+ type: 'Click',
16947
+ related: {
16948
+ settingRender: settingRender$2,
16949
+ bindableProps: []
16950
+ },
16951
+ defaulSetting: {
16952
+ props: {
16953
+ 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>',
16954
+ acceptButton: {
16955
+ text: 'Accept all cookies',
16956
+ style: {
16957
+ backgroundColor: '#000',
16958
+ height: 45,
16959
+ color: '#fff',
16960
+ fontSize: 12,
16961
+ textAlign: 'center',
16962
+ marginTop: 5,
16963
+ marginBottom: 5
16964
+ }
16965
+ },
16966
+ rejectButton: {
16967
+ text: 'Reject all cookies',
16968
+ style: {
16969
+ backgroundColor: '#000',
16970
+ height: 45,
16971
+ color: '#fff',
16972
+ fontSize: 12,
16973
+ textAlign: 'center',
16974
+ marginTop: 5,
16975
+ marginBottom: 5
16976
+ }
16977
+ }
16978
+ },
16979
+ style: {
16980
+ backgroundColor: '#fff',
16981
+ padding: 18
16982
+ }
16983
+ },
16984
+ sort: 2
16985
+ });
16986
+
16987
+ /*
16988
+ * @Author: binruan@chatlabs.com
16989
+ * @Date: 2023-07-28 18:29:57
16990
+ * @LastEditors: binruan@chatlabs.com
16991
+ * @LastEditTime: 2025-02-07 11:28:40
16992
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16993
+ *
16994
+ */
16995
+ var settingRender$1 = [
16996
+ {
16997
+ title: '全局设置',
16998
+ child: [
16999
+ {
17000
+ type: 'Switch',
17001
+ label: '弹窗开关',
17002
+ name: ['props', 'open']
17003
+ },
17004
+ {
17005
+ type: 'Color',
17006
+ label: '背景色',
17007
+ name: ['style', 'backgroundColor']
17008
+ },
17009
+ {
17010
+ type: 'Number',
17011
+ label: '内边距',
17012
+ name: ['style', 'padding'],
17013
+ addonAfter: 'px'
17014
+ },
17015
+ {
17016
+ label: '关闭按钮',
17017
+ type: 'Upload',
17018
+ name: ['props', 'closeIcon']
17019
+ }
17020
+ ]
17021
+ },
17022
+ {
17023
+ title: '弹窗文本',
17024
+ child: [
17025
+ {
17026
+ type: 'RichText',
17027
+ name: ['props', 'content']
17028
+ }
17029
+ ]
17030
+ },
17031
+ {
17032
+ title: '滑动图标',
17033
+ child: [
17034
+ {
17035
+ type: 'Upload',
17036
+ label: '滑动图标',
17037
+ name: ['props', 'swipeIcon'],
17038
+ text: '建议尺寸:252 * 185'
17039
+ }
17040
+ ]
17041
+ }
17042
+ ];
17043
+
17044
+ var img$2 = "";
17045
+
17046
+ const Swipe$1 = (_a) => {
17047
+ var { isTel, open, content, style, consentPopupCate, swipeIcon, closeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon", "closeIcon"]);
17048
+ const touchInfo = React.useRef();
17049
+ const threshold = 50; // 设置判断的距离阈值
17050
+ const { getAccount, accountSonsent } = useSxpDataSource();
17051
+ const [consentResult, setConsentResult] = React.useState(false);
17052
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
17053
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
17054
+ setConsentResult(res);
17055
+ });
17056
+ React.useEffect(() => {
17057
+ handleGetAccount();
17058
+ }, []);
17059
+ const visivle = React.useMemo(() => {
17060
+ return consentPopupCate || (open && style && !consentResult);
17061
+ }, [consentPopupCate, open, style, consentResult]);
17062
+ const handleClick = (v) => {
17063
+ accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(v);
17064
+ setConsentResult(true);
17065
+ };
17066
+ const handleTouchStart = (event) => {
17067
+ const touch = event.touches[0];
17068
+ touchInfo.current = { y: touch.clientY, d: 0 };
17069
+ };
17070
+ const handleTouchMove = (event) => {
17071
+ var _a;
17072
+ if (!touchInfo.current)
17073
+ return;
17074
+ const touch = event.touches[0];
17075
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
17076
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
17077
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
17078
+ };
17079
+ const handleTouchEnd = () => {
17080
+ if (!touchInfo.current)
17081
+ return;
17082
+ const { d } = touchInfo.current || {};
17083
+ if (d > threshold) {
17084
+ handleClick(true);
17085
+ }
17086
+ touchInfo.current = {};
17087
+ };
17088
+ 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 },
17089
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17090
+ React.createElement("div", { className: 'consentPopupSwipe-container-content' },
17091
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
17092
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: () => handleClick(false) },
17093
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
17094
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: () => handleClick(false) },
17095
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17096
+ };
17097
+ var SwipeComponent = React.memo(Swipe$1);
17098
+
17099
+ /*
17100
+ * @Author: binruan@chatlabs.com
17101
+ * @Date: 2025-01-14 16:22:35
17102
+ * @LastEditors: binruan@chatlabs.com
17103
+ * @LastEditTime: 2025-01-15 17:09:49
17104
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17105
+ *
17106
+ */
17107
+ const Swipe = createMaterial(SwipeComponent, {
17108
+ displayName: 'Swipe Consent',
17109
+ icon: '',
17110
+ category: 'consentPopup',
17111
+ type: 'Swipe',
17112
+ related: {
17113
+ settingRender: settingRender$1,
17114
+ bindableProps: []
17115
+ },
17116
+ defaulSetting: {
17117
+ props: {
17118
+ 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>',
17119
+ closeIcon: ''
17120
+ },
17121
+ style: {
17122
+ backgroundColor: '#fff',
17123
+ padding: 18
17124
+ }
17125
+ },
17126
+ sort: 3
17127
+ });
17128
+
16689
17129
  /*
16690
17130
  * @Author: binruan@chatlabs.com
16691
17131
  * @Date: 2024-06-13 10:08:32
@@ -16987,6 +17427,7 @@ Made in Italy` })));
16987
17427
  AniLinkPopup: AniLinkPopup,
16988
17428
  Appoint: Appoint,
16989
17429
  AppointForm: AppointForm,
17430
+ Click: Click,
16990
17431
  Commodity: Commodity,
16991
17432
  CommodityDetail: CommodityDetail,
16992
17433
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -17003,7 +17444,8 @@ Made in Italy` })));
17003
17444
  MultiCommodityDiro: MultiCommodityDiro,
17004
17445
  MultiCommodityDiroNew: MultiCommodityDiroNew,
17005
17446
  MultiPosts: MultiPosts,
17006
- Prompt: Prompt
17447
+ Prompt: Prompt,
17448
+ Swipe: Swipe
17007
17449
  });
17008
17450
 
17009
17451
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17873,23 +18315,72 @@ Made in Italy` })));
17873
18315
  };
17874
18316
  var Tagbar$1 = React.memo(Tagbar);
17875
18317
 
18318
+ /*
18319
+ * @Author: binruan@chatlabs.com
18320
+ * @Date: 2023-12-26 10:38:53
18321
+ * @LastEditors: binruan@chatlabs.com
18322
+ * @LastEditTime: 2024-12-11 18:24:31
18323
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18324
+ *
18325
+ */
18326
+ const EditorDataContext = React.createContext({});
18327
+ const EditorDataProvider = ({ children, data }) => {
18328
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18329
+ const [openHashtag, setOpenHashtag] = React.useState(false);
18330
+ const [openConsent, setOpenConsent] = React.useState(false);
18331
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
18332
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18333
+ return (React.createElement(EditorDataContext.Provider, { value: {
18334
+ sxpPrameter: {
18335
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18336
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18337
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18338
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18339
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18340
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18341
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18342
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18343
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18344
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18345
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18346
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18347
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18348
+ },
18349
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18350
+ openHashtag,
18351
+ setOpenHashtag,
18352
+ openConsent,
18353
+ setOpenConsent,
18354
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18355
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18356
+ consentPopupCate,
18357
+ setConsentPopupCate,
18358
+ openMultiPosts,
18359
+ setOpenMultiPosts,
18360
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18361
+ } }, children));
18362
+ };
18363
+ function useEditorDataProvider() {
18364
+ return React.useContext(EditorDataContext);
18365
+ }
18366
+
17876
18367
  /*
17877
18368
  * @Author: binruan@chatlabs.com
17878
18369
  * @Date: 2023-12-26 16:11:34
17879
18370
  * @LastEditors: binruan@chatlabs.com
17880
- * @LastEditTime: 2024-11-05 16:29:47
18371
+ * @LastEditTime: 2025-02-20 16:32:44
17881
18372
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17882
18373
  *
17883
18374
  */
17884
18375
  const Consent = ({ resolver, globalConfig }) => {
17885
- var _a, _b;
17886
- const contsentState = React.useMemo(() => {
17887
- return getContsentState();
17888
- }, []);
17889
- const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
17890
- const Component = withBindDataSource(t);
18376
+ var _a, _b, _c;
18377
+ const { consentPopupCate } = useEditorDataProvider();
17891
18378
  const value = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consentPopup) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item;
17892
- return React.createElement(Component, Object.assign({}, value === null || value === void 0 ? void 0 : value.props, { style: value === null || value === void 0 ? void 0 : value.style, event: (value === null || value === void 0 ? void 0 : value.event) || {}, contsentState: contsentState }));
18379
+ if (!value || (!consentPopupCate && !((_c = value === null || value === void 0 ? void 0 : value.props) === null || _c === void 0 ? void 0 : _c.open)))
18380
+ return null;
18381
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18382
+ const Component = withBindDataSource(t);
18383
+ 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 })));
17893
18384
  };
17894
18385
  var ConsentPopup = React.memo(Consent);
17895
18386
 
@@ -17912,7 +18403,7 @@ Made in Italy` })));
17912
18403
  * @Author: binruan@chatlabs.com
17913
18404
  * @Date: 2024-03-20 10:27:31
17914
18405
  * @LastEditors: binruan@chatlabs.com
17915
- * @LastEditTime: 2024-12-18 10:24:20
18406
+ * @LastEditTime: 2025-02-20 14:00:43
17916
18407
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17917
18408
  *
17918
18409
  */
@@ -18007,7 +18498,7 @@ Made in Italy` })));
18007
18498
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
18008
18499
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
18009
18500
  position: activeIndex + '',
18010
- fromKName: fk ? fk : fromKName,
18501
+ fromKName: fk || fromKName,
18011
18502
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
18012
18503
  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 : '',
18013
18504
  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 : ''
@@ -18037,9 +18528,12 @@ Made in Italy` })));
18037
18528
  skipLinkRef.current = false;
18038
18529
  }
18039
18530
  // 页面可见时触发,注意页面初始化时不会触发
18531
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18040
18532
  handleH5EnterLink();
18041
18533
  if (repCond) {
18042
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18534
+ setTimeout(() => {
18535
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18536
+ });
18043
18537
  backMainFeed('external', selectTag);
18044
18538
  }
18045
18539
  }
@@ -18301,7 +18795,7 @@ Made in Italy` })));
18301
18795
  }
18302
18796
  };
18303
18797
  const handleScrollEvent = (swiper) => {
18304
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s;
18798
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w;
18305
18799
  const item = data[swiper.previousIndex];
18306
18800
  if (!item)
18307
18801
  return;
@@ -18320,9 +18814,9 @@ Made in Italy` })));
18320
18814
  contentId: (_e = (_d = item === null || item === void 0 ? void 0 : item.video) === null || _d === void 0 ? void 0 : _d.itemId) !== null && _e !== void 0 ? _e : '',
18321
18815
  productId: (_g = (_f = item === null || item === void 0 ? void 0 : item.product) === null || _f === void 0 ? void 0 : _f.itemId) !== null && _g !== void 0 ? _g : '',
18322
18816
  requestId: null,
18323
- traceInfo: (_j = (_h = item === null || item === void 0 ? void 0 : item.video) === null || _h === void 0 ? void 0 : _h.traceInfo) !== null && _j !== void 0 ? _j : '',
18817
+ traceInfo: (_l = (_j = (_h = item === null || item === void 0 ? void 0 : item.video) === null || _h === void 0 ? void 0 : _h.traceInfo) !== null && _j !== void 0 ? _j : (_k = item === null || item === void 0 ? void 0 : item.product) === null || _k === void 0 ? void 0 : _k.traceInfo) !== null && _l !== void 0 ? _l : '',
18324
18818
  contentFormat,
18325
- position: ((_k = swiper.previousIndex) !== null && _k !== void 0 ? _k : 0) + ''
18819
+ position: ((_m = swiper.previousIndex) !== null && _m !== void 0 ? _m : 0) + ''
18326
18820
  }
18327
18821
  });
18328
18822
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件
@@ -18334,12 +18828,12 @@ Made in Italy` })));
18334
18828
  eventInfo: {
18335
18829
  eventSubject: 'scrollUp',
18336
18830
  eventDescription: 'User scroll up',
18337
- contentId: (_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.itemId) !== null && _m !== void 0 ? _m : '',
18338
- productId: (_p = (_o = item.product) === null || _o === void 0 ? void 0 : _o.itemId) !== null && _p !== void 0 ? _p : '',
18831
+ contentId: (_p = (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.itemId) !== null && _p !== void 0 ? _p : '',
18832
+ productId: (_r = (_q = item.product) === null || _q === void 0 ? void 0 : _q.itemId) !== null && _r !== void 0 ? _r : '',
18339
18833
  requestId: null,
18340
- traceInfo: (_r = (_q = item === null || item === void 0 ? void 0 : item.video) === null || _q === void 0 ? void 0 : _q.traceInfo) !== null && _r !== void 0 ? _r : '',
18834
+ 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 : '',
18341
18835
  contentFormat,
18342
- position: ((_s = swiper.previousIndex) !== null && _s !== void 0 ? _s : 0) + ''
18836
+ position: ((_w = swiper.previousIndex) !== null && _w !== void 0 ? _w : 0) + ''
18343
18837
  }
18344
18838
  });
18345
18839
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件