pb-sxp-ui 1.14.1 → 14.0.3

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 +590 -163
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +89 -0
  4. package/dist/index.js +590 -163
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +6 -6
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +6 -6
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +590 -163
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +6 -6
  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/index.js +5 -2
  16. package/es/core/context/SxpDataSourceProvider.js +49 -24
  17. package/es/core/utils/materials.js +5 -3
  18. package/es/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  19. package/es/materials/sxp/consentPopup/Click/index.js +19 -0
  20. package/es/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  21. package/es/materials/sxp/consentPopup/Click/material.js +48 -0
  22. package/es/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  23. package/es/materials/sxp/consentPopup/Click/settingRender.js +210 -0
  24. package/es/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  25. package/es/materials/sxp/consentPopup/Display/index.js +7 -5
  26. package/es/materials/sxp/consentPopup/Swipe/index.d.ts +12 -0
  27. package/es/materials/sxp/consentPopup/Swipe/index.js +44 -0
  28. package/es/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  29. package/es/materials/sxp/consentPopup/Swipe/material.js +24 -0
  30. package/es/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  31. package/es/materials/sxp/consentPopup/Swipe/settingRender.js +43 -0
  32. package/es/materials/sxp/consentPopup/index.d.ts +2 -0
  33. package/es/materials/sxp/consentPopup/index.js +2 -0
  34. package/es/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  35. package/es/materials/sxp/popup/ConsentDetail/index.js +2 -2
  36. package/es/materials/sxp/popup/Iframe/index.d.ts +0 -4
  37. package/es/materials/sxp/popup/Iframe/index.js +4 -5
  38. package/es/materials/sxp/popup/Iframe/settingRender.js +0 -15
  39. package/lib/core/components/SxpPageRender/ConsentPopup.js +7 -7
  40. package/lib/core/components/SxpPageRender/index.js +5 -2
  41. package/lib/core/context/SxpDataSourceProvider.js +49 -24
  42. package/lib/core/utils/materials.js +5 -3
  43. package/lib/materials/sxp/consentPopup/Click/index.d.ts +19 -0
  44. package/lib/materials/sxp/consentPopup/Click/index.js +21 -0
  45. package/lib/materials/sxp/consentPopup/Click/material.d.ts +2 -0
  46. package/lib/materials/sxp/consentPopup/Click/material.js +52 -0
  47. package/lib/materials/sxp/consentPopup/Click/settingRender.d.ts +63 -0
  48. package/lib/materials/sxp/consentPopup/Click/settingRender.js +212 -0
  49. package/lib/materials/sxp/consentPopup/Display/index.d.ts +2 -2
  50. package/lib/materials/sxp/consentPopup/Display/index.js +7 -5
  51. package/lib/materials/sxp/consentPopup/Swipe/index.d.ts +12 -0
  52. package/lib/materials/sxp/consentPopup/Swipe/index.js +46 -0
  53. package/lib/materials/sxp/consentPopup/Swipe/material.d.ts +2 -0
  54. package/lib/materials/sxp/consentPopup/Swipe/material.js +28 -0
  55. package/lib/materials/sxp/consentPopup/Swipe/settingRender.d.ts +29 -0
  56. package/lib/materials/sxp/consentPopup/Swipe/settingRender.js +45 -0
  57. package/lib/materials/sxp/consentPopup/index.d.ts +2 -0
  58. package/lib/materials/sxp/consentPopup/index.js +2 -0
  59. package/lib/materials/sxp/popup/ConsentDetail/index.d.ts +2 -1
  60. package/lib/materials/sxp/popup/ConsentDetail/index.js +2 -2
  61. package/lib/materials/sxp/popup/Iframe/index.d.ts +0 -4
  62. package/lib/materials/sxp/popup/Iframe/index.js +4 -5
  63. package/lib/materials/sxp/popup/Iframe/settingRender.js +0 -15
  64. package/package.json +1 -1
package/dist/pb-ui.js CHANGED
@@ -670,12 +670,15 @@
670
670
  const bffDataSource = React.useMemo(() => {
671
671
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
672
672
  }, [dataSources]);
673
+ const fakeUserId = React.useMemo(() => {
674
+ var _a;
675
+ return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
676
+ }, [bffDataSource]);
673
677
  // bff API 请求方法
674
678
  const bffFetch = React.useCallback((path, options) => {
675
679
  if (!bffDataSource)
676
680
  return;
677
681
  const url = bffDataSource.url;
678
- const fakeUserId = storeAndLoadFeUserId();
679
682
  if (options === null || options === void 0 ? void 0 : options.query) {
680
683
  const queryString = qs.stringify(options.query);
681
684
  path = `${path}?${queryString}`;
@@ -683,19 +686,19 @@
683
686
  // 事件上报优化
684
687
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
685
688
  if (options.type === 'beacon' && navigator.sendBeacon) {
686
- return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
689
+ return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
687
690
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
688
691
  ], { type: 'application/json;charset=UTF-8' }));
689
692
  }
690
693
  return window
691
- .fetch(`${url}/api/v1${path}`, {
694
+ .fetch(`${url}/api/${path}`, {
692
695
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
693
696
  method: options.method,
694
697
  body: JSON.stringify(options.body)
695
698
  })
696
699
  .then((res) => res.json())
697
700
  .catch((err) => Promise.reject(err));
698
- }, [bffDataSource]);
701
+ }, [bffDataSource, fakeUserId]);
699
702
  // 获取推荐视频数据
700
703
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
701
704
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
@@ -733,14 +736,16 @@
733
736
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
734
737
  var _v, _w, _x, _y, _z, _0;
735
738
  query.pageNum = pageNum;
736
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
739
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
737
740
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
738
741
  return undefined;
739
742
  }
740
743
  setLoading(false);
741
744
  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 : []);
742
- setRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
743
- setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result.data), { recList: list })));
745
+ if ((rtcList === null || rtcList === void 0 ? void 0 : rtcList.length) === 0) {
746
+ setRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
747
+ setCacheRtcList(getFilterRecList(Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list })));
748
+ }
744
749
  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));
745
750
  if (isNotNullList) {
746
751
  pageNum = pageNum + 1;
@@ -750,12 +755,12 @@
750
755
  yield recurveRecList(query);
751
756
  if (!(query === null || query === void 0 ? void 0 : query.hashTag) && result)
752
757
  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 });
753
- return Object.assign(Object.assign({}, result.data), { recList: list });
758
+ return Object.assign(Object.assign({}, result === null || result === void 0 ? void 0 : result.data), { recList: list });
754
759
  }
755
760
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
756
761
  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 });
757
762
  }
758
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
763
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
759
764
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
760
765
  return undefined;
761
766
  }
@@ -805,6 +810,7 @@
805
810
  return expire;
806
811
  }, [data]);
807
812
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
813
+ var _a, _b;
808
814
  // 关闭 BFF 事件上报
809
815
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
810
816
  return;
@@ -817,7 +823,9 @@
817
823
  };
818
824
  }
819
825
  const sessionID = storeAndLoadFeSessionId();
820
- 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 + '' }));
826
+ const urlParams = new URLSearchParams((_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.search);
827
+ const cl_source = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('cl_source');
828
+ 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 }));
821
829
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
822
830
  const realEventInfo = Object.entries(ef)
823
831
  .map(([k, v]) => v && { name: k, value: v })
@@ -826,26 +834,35 @@
826
834
  console.log('userInfo:', userInfo);
827
835
  console.log('eventInfo:', ef);
828
836
  console.log('========= 结束 =========');
829
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
837
+ 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}`, {
830
838
  method: 'POST',
831
839
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
832
840
  type: 'beacon'
833
841
  });
834
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
842
+ }, [
843
+ bffFetch,
844
+ curReqInfo,
845
+ enableReportEvent,
846
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
847
+ layoutVariantId,
848
+ globalConfig,
849
+ playbookType,
850
+ bffDataSource
851
+ ]);
835
852
  const bffFbReport = React.useCallback(({ eventName, product }) => {
836
- var _a, _b, _c, _d, _e;
853
+ var _a, _b, _c, _d, _e, _f;
837
854
  if (!enableReportEvent ||
838
855
  !enabledMetaConversionApi ||
839
856
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
840
857
  !((_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.converApi) === null || _a === void 0 ? void 0 : _a[eventName])) {
841
858
  return;
842
859
  }
843
- let jsonParams = lodash.cloneDeep((_b = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.converApi) === null || _b === void 0 ? void 0 : _b[eventName]);
860
+ const jsonParams = lodash.cloneDeep((_b = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.converApi) === null || _b === void 0 ? void 0 : _b[eventName]);
844
861
  const urlParams = new URLSearchParams(window.location.search);
845
862
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
846
863
  const fix_par = {
847
864
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
848
- external_id: storeAndLoadFeUserId(),
865
+ external_id: fakeUserId,
849
866
  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 : '',
850
867
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
851
868
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -897,22 +914,30 @@
897
914
  }
898
915
  };
899
916
  getEventParams(jsonParams);
900
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
917
+ 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}`, {
901
918
  method: 'POST',
902
919
  body: jsonParams,
903
920
  type: 'beacon'
904
921
  });
905
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
922
+ }, [
923
+ bffFetch,
924
+ enableReportEvent,
925
+ enabledMetaConversionApi,
926
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
927
+ globalConfig,
928
+ fakeUserId,
929
+ bffDataSource
930
+ ]);
906
931
  const bffMutateLike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
907
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
932
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
908
933
  return res === null || res === void 0 ? void 0 : res.success;
909
934
  }), [bffFetch]);
910
935
  const bffMutateUnlike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
911
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
936
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
912
937
  return res === null || res === void 0 ? void 0 : res.success;
913
938
  }), [bffFetch]);
914
939
  const bffSubmitForm = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
915
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
940
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
916
941
  return res === null || res === void 0 ? void 0 : res.success;
917
942
  }), [bffFetch]);
918
943
  // 获取 Tag
@@ -927,7 +952,7 @@
927
952
  const key = val.split('=')[0];
928
953
  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);
929
954
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
930
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
955
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
931
956
  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 : []);
932
957
  }
933
958
  catch (e) {
@@ -1001,10 +1026,10 @@
1001
1026
  let curData;
1002
1027
  let gldata;
1003
1028
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1029
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1030
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1004
1031
  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];
1005
1032
  if (id) {
1006
- layId = id;
1007
- setLayoutVariantId(id);
1008
1033
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1009
1034
  if (curData) {
1010
1035
  setPageData(curData);
@@ -1390,7 +1415,7 @@
1390
1415
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1391
1416
  *
1392
1417
  */
1393
- var settingRender$d = [
1418
+ var settingRender$f = [
1394
1419
  {
1395
1420
  title: '弹窗背景',
1396
1421
  child: [
@@ -1826,7 +1851,7 @@
1826
1851
  category: 'popup',
1827
1852
  type: 'AppointForm',
1828
1853
  related: {
1829
- settingRender: settingRender$d,
1854
+ settingRender: settingRender$f,
1830
1855
  bindableProps: [],
1831
1856
  interactionRender: interactionRender$g
1832
1857
  },
@@ -1851,7 +1876,7 @@
1851
1876
  sort: 2
1852
1877
  });
1853
1878
 
1854
- var settingRender$c = [
1879
+ var settingRender$e = [
1855
1880
  {
1856
1881
  title: '弹窗背景',
1857
1882
  child: [
@@ -9740,7 +9765,7 @@
9740
9765
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9741
9766
  *
9742
9767
  */
9743
- const closeIcon$1 = '';
9768
+ const closeIcon$2 = '';
9744
9769
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9745
9770
  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;
9746
9771
  const touchRef = React.useRef(null);
@@ -9920,7 +9945,7 @@
9920
9945
  }
9921
9946
  })), child()),
9922
9947
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9923
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9948
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9924
9949
  };
9925
9950
  var Modal$1 = React.memo(Modal);
9926
9951
 
@@ -10091,7 +10116,7 @@
10091
10116
  * @Author: binruan@chatlabs.com
10092
10117
  * @Date: 2024-03-20 14:56:16
10093
10118
  * @LastEditors: binruan@chatlabs.com
10094
- * @LastEditTime: 2024-10-24 17:51:19
10119
+ * @LastEditTime: 2024-12-20 14:32:26
10095
10120
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10096
10121
  *
10097
10122
  */
@@ -10129,14 +10154,16 @@
10129
10154
  };
10130
10155
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10131
10156
  var _a, _b, _c, _d, _e, _f, _g, _h;
10157
+ let text = '';
10132
10158
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10133
10159
  return null;
10134
- 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;
10135
- let text = '';
10160
+ 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);
10161
+ if (typeof price !== 'number')
10162
+ return text;
10136
10163
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10137
10164
  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 : '' : '$';
10138
10165
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10139
- let decPic = price.toString();
10166
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10140
10167
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10141
10168
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10142
10169
  }
@@ -10448,7 +10475,7 @@
10448
10475
  category: 'popup',
10449
10476
  type: 'CommodityDetail',
10450
10477
  related: {
10451
- settingRender: settingRender$c,
10478
+ settingRender: settingRender$e,
10452
10479
  interactionRender: interactionRender$f
10453
10480
  },
10454
10481
  defaulSetting: {
@@ -10524,7 +10551,7 @@
10524
10551
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10525
10552
  *
10526
10553
  */
10527
- var settingRender$b = [
10554
+ var settingRender$d = [
10528
10555
  {
10529
10556
  title: '弹窗背景',
10530
10557
  child: [
@@ -10665,7 +10692,7 @@
10665
10692
  }
10666
10693
  ];
10667
10694
 
10668
- var img$5 = "";
10695
+ var img$7 = "";
10669
10696
 
10670
10697
  const Prompt$1 = (_a) => {
10671
10698
  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"]);
@@ -10688,7 +10715,7 @@
10688
10715
  };
10689
10716
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10690
10717
  React.createElement("div", { className: 'pb-prompt-icon' },
10691
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10718
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10692
10719
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10693
10720
  __html: setFontForText(content, contentStyle)
10694
10721
  } }),
@@ -10704,13 +10731,13 @@
10704
10731
  category: 'popup',
10705
10732
  type: 'Prompt',
10706
10733
  related: {
10707
- settingRender: settingRender$b,
10734
+ settingRender: settingRender$d,
10708
10735
  bindableProps: [],
10709
10736
  interactionRender: interactionRender$e
10710
10737
  },
10711
10738
  defaulSetting: {
10712
10739
  props: {
10713
- icon: img$5,
10740
+ icon: img$7,
10714
10741
  content: 'You have successfully completed the appointment!',
10715
10742
  btnText: 'OK'
10716
10743
  },
@@ -10729,7 +10756,7 @@
10729
10756
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10730
10757
  *
10731
10758
  */
10732
- var settingRender$a = [
10759
+ var settingRender$c = [
10733
10760
  {
10734
10761
  title: '弹窗背景',
10735
10762
  child: [
@@ -11408,7 +11435,7 @@ Made in Italy` })));
11408
11435
  category: 'popup',
11409
11436
  type: 'CommodityDetailDiroNew',
11410
11437
  related: {
11411
- settingRender: settingRender$a,
11438
+ settingRender: settingRender$c,
11412
11439
  interactionRender: interactionRender$d
11413
11440
  },
11414
11441
  defaulSetting: {
@@ -11472,7 +11499,7 @@ Made in Italy` })));
11472
11499
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11473
11500
  *
11474
11501
  */
11475
- var settingRender$9 = [
11502
+ var settingRender$b = [
11476
11503
  {
11477
11504
  title: '弹窗背景',
11478
11505
  child: [
@@ -11909,7 +11936,7 @@ Made in Italy` })));
11909
11936
  category: 'popup',
11910
11937
  type: 'CommodityList',
11911
11938
  related: {
11912
- settingRender: settingRender$9,
11939
+ settingRender: settingRender$b,
11913
11940
  interactionRender: interactionRender$c
11914
11941
  },
11915
11942
  defaulSetting: {
@@ -11954,11 +11981,11 @@ Made in Italy` })));
11954
11981
  * @Author: binruan@chatlabs.com
11955
11982
  * @Date: 2023-10-27 14:06:35
11956
11983
  * @LastEditors: binruan@chatlabs.com
11957
- * @LastEditTime: 2024-12-12 15:12:57
11984
+ * @LastEditTime: 2024-08-08 17:32:11
11958
11985
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
11959
11986
  *
11960
11987
  */
11961
- var settingRender$8 = [
11988
+ var settingRender$a = [
11962
11989
  {
11963
11990
  title: '背景样式',
11964
11991
  child: [
@@ -11968,32 +11995,16 @@ Made in Italy` })));
11968
11995
  name: ['style', 'backgroundColor']
11969
11996
  }
11970
11997
  ]
11971
- },
11972
- {
11973
- title: 'iframe',
11974
- child: [
11975
- {
11976
- type: 'TextArea',
11977
- label: 'url',
11978
- name: ['props', 'iframe', 'src']
11979
- },
11980
- {
11981
- type: 'TextArea',
11982
- label: 'allow',
11983
- name: ['props', 'iframe', 'allow']
11984
- }
11985
- ]
11986
11998
  }
11987
11999
  ];
11988
12000
 
11989
12001
  const Iframe$1 = (_a) => {
11990
12002
  var _b, _c;
11991
- var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle, contentStyle, isTel, iframe } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle", "contentStyle", "isTel", "iframe"]);
12003
+ var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle, contentStyle, isTel } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle", "contentStyle", "isTel"]);
11992
12004
  const { popupDetailData } = useSxpDataSource();
11993
- const { src, allow } = iframe || {};
11994
- const iframeUrl = src || ((_c = (_b = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.video) === null || _b === void 0 ? void 0 : _b.bindCta) === null || _c === void 0 ? void 0 : _c.remark);
11995
- return (React.createElement("div", Object.assign({ className: `${css.css(Object.assign(Object.assign({}, style), { overflow: 'hidden' }))}` }, props),
11996
- React.createElement("iframe", { src: iframeUrl, allow: allow, scrolling: 'no', style: {
12005
+ const iframeUrl = (_c = (_b = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.video) === null || _b === void 0 ? void 0 : _b.bindCta) === null || _c === void 0 ? void 0 : _c.remark;
12006
+ return (React.createElement("div", Object.assign({ className: `${css.css(Object.assign({}, style))}` }, props),
12007
+ React.createElement("iframe", { src: iframeUrl, style: {
11997
12008
  width: '100%',
11998
12009
  height: 'calc(100% - 50px)',
11999
12010
  marginTop: '50px',
@@ -12008,7 +12019,7 @@ Made in Italy` })));
12008
12019
  category: 'popup',
12009
12020
  type: 'Iframe',
12010
12021
  related: {
12011
- settingRender: settingRender$8,
12022
+ settingRender: settingRender$a,
12012
12023
  bindableProps: []
12013
12024
  },
12014
12025
  defaulSetting: {
@@ -12028,7 +12039,7 @@ Made in Italy` })));
12028
12039
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12029
12040
  *
12030
12041
  */
12031
- var settingRender$7 = [
12042
+ var settingRender$9 = [
12032
12043
  {
12033
12044
  title: '弹窗文本',
12034
12045
  child: [
@@ -12041,22 +12052,22 @@ Made in Italy` })));
12041
12052
  ];
12042
12053
 
12043
12054
  const ConsentDetail$1 = (_a) => {
12044
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12055
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12045
12056
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12046
12057
  __html: typeof content === 'string' ? content : ''
12047
12058
  }, onClick: (e) => {
12048
12059
  e.stopPropagation();
12049
- } }));
12060
+ }, style: style }));
12050
12061
  };
12051
- var ConsentDetailComponent = React.memo(ConsentDetail$1);
12062
+ var ConsentDetail$2 = React.memo(ConsentDetail$1);
12052
12063
 
12053
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12064
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12054
12065
  displayName: '协议详情',
12055
12066
  icon: '',
12056
12067
  category: 'popup',
12057
12068
  type: 'ConsentDetail',
12058
12069
  related: {
12059
- settingRender: settingRender$7,
12070
+ settingRender: settingRender$9,
12060
12071
  bindableProps: []
12061
12072
  },
12062
12073
  defaulSetting: {
@@ -12076,7 +12087,7 @@ Made in Italy` })));
12076
12087
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12077
12088
  *
12078
12089
  */
12079
- var settingRender$6 = [
12090
+ var settingRender$8 = [
12080
12091
  {
12081
12092
  title: '主题样式',
12082
12093
  child: [
@@ -12430,7 +12441,7 @@ Made in Italy` })));
12430
12441
  related: {
12431
12442
  interactionRender: interactionRender$b,
12432
12443
  bindableProps: [],
12433
- settingRender: settingRender$6
12444
+ settingRender: settingRender$8
12434
12445
  },
12435
12446
  defaulSetting: {
12436
12447
  props: {
@@ -12512,7 +12523,7 @@ Made in Italy` })));
12512
12523
  type: 'Appoint',
12513
12524
  related: {
12514
12525
  interactionRender: interactionRender$a,
12515
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12526
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12516
12527
  bindableProps: []
12517
12528
  },
12518
12529
  defaulSetting: {
@@ -12718,7 +12729,7 @@ Made in Italy` })));
12718
12729
  category: 'template',
12719
12730
  type: 'Link',
12720
12731
  related: {
12721
- 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),
12732
+ 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),
12722
12733
  bindableProps: [],
12723
12734
  interactionRender: interactionRender$9
12724
12735
  },
@@ -12821,7 +12832,7 @@ Made in Italy` })));
12821
12832
  type: 'CommodityDiro',
12822
12833
  related: {
12823
12834
  interactionRender: interactionRender$8,
12824
- settingRender: settingRender$6,
12835
+ settingRender: settingRender$8,
12825
12836
  bindableProps: []
12826
12837
  },
12827
12838
  defaulSetting: {
@@ -12918,7 +12929,7 @@ Made in Italy` })));
12918
12929
  related: {
12919
12930
  interactionRender: interactionRender$7,
12920
12931
  bindableProps: [],
12921
- settingRender: settingRender$6
12932
+ settingRender: settingRender$8
12922
12933
  },
12923
12934
  defaulSetting: {
12924
12935
  props: {
@@ -13018,7 +13029,7 @@ Made in Italy` })));
13018
13029
  related: {
13019
13030
  interactionRender: interactionRender$6,
13020
13031
  bindableProps: [],
13021
- settingRender: settingRender$6
13032
+ settingRender: settingRender$8
13022
13033
  },
13023
13034
  defaulSetting: {
13024
13035
  props: {
@@ -13116,7 +13127,7 @@ Made in Italy` })));
13116
13127
  type: 'MultiCommodity',
13117
13128
  related: {
13118
13129
  interactionRender: interactionRender$5,
13119
- settingRender: settingRender$6,
13130
+ settingRender: settingRender$8,
13120
13131
  bindableProps: []
13121
13132
  },
13122
13133
  defaulSetting: {
@@ -13225,7 +13236,7 @@ Made in Italy` })));
13225
13236
  related: {
13226
13237
  interactionRender: interactionRender$4,
13227
13238
  bindableProps: [],
13228
- settingRender: settingRender$6
13239
+ settingRender: settingRender$8
13229
13240
  },
13230
13241
  defaulSetting: {
13231
13242
  props: {
@@ -13274,7 +13285,7 @@ Made in Italy` })));
13274
13285
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13275
13286
  *
13276
13287
  */
13277
- var settingRender$5 = [
13288
+ var settingRender$7 = [
13278
13289
  {
13279
13290
  title: 'Banner',
13280
13291
  child: [
@@ -15102,7 +15113,7 @@ Made in Italy` })));
15102
15113
  } }))))));
15103
15114
  }
15104
15115
 
15105
- var img$4 = "";
15116
+ var img$6 = "";
15106
15117
 
15107
15118
  const WaterfallFlowItem = (props) => {
15108
15119
  var _a;
@@ -15423,7 +15434,7 @@ Made in Italy` })));
15423
15434
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15424
15435
  display: openHashtag ? 'block' : 'none'
15425
15436
  } },
15426
- 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 }),
15437
+ 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 }),
15427
15438
  (props === null || props === void 0 ? void 0 : props.openFixedSize) === true || (props === null || props === void 0 ? void 0 : props.openFixedSize) === undefined ? (React.createElement(WaterfallList, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList$1, Object.assign({ key: waterFallData, reportTagsView: reportTagsView }, props)))), modalEleRef.current);
15428
15439
  };
15429
15440
  var WaterFall$1 = React.memo(WaterFall);
@@ -15455,7 +15466,7 @@ Made in Italy` })));
15455
15466
  category: 'base',
15456
15467
  type: 'HashTag',
15457
15468
  related: {
15458
- settingRender: settingRender$5,
15469
+ settingRender: settingRender$7,
15459
15470
  bindableProps: []
15460
15471
  },
15461
15472
  defaulSetting: {
@@ -15520,7 +15531,7 @@ Made in Italy` })));
15520
15531
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15521
15532
  *
15522
15533
  */
15523
- var settingRender$4 = [
15534
+ var settingRender$6 = [
15524
15535
  {
15525
15536
  title: '协议详情',
15526
15537
  child: [
@@ -15579,7 +15590,7 @@ Made in Italy` })));
15579
15590
  category: 'base',
15580
15591
  type: 'Consent',
15581
15592
  related: {
15582
- settingRender: settingRender$4
15593
+ settingRender: settingRender$6
15583
15594
  },
15584
15595
  defaulSetting: {
15585
15596
  props: {},
@@ -15598,7 +15609,7 @@ Made in Italy` })));
15598
15609
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15599
15610
  *
15600
15611
  */
15601
- var settingRender$3 = [
15612
+ var settingRender$5 = [
15602
15613
  {
15603
15614
  title: '主题样式',
15604
15615
  child: [
@@ -15859,7 +15870,7 @@ Made in Italy` })));
15859
15870
  category: 'cta',
15860
15871
  type: 'AniLink',
15861
15872
  related: {
15862
- settingRender: settingRender$3,
15873
+ settingRender: settingRender$5,
15863
15874
  bindableProps: [],
15864
15875
  interactionRender: interactionRender$3
15865
15876
  },
@@ -15903,7 +15914,7 @@ Made in Italy` })));
15903
15914
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15904
15915
  *
15905
15916
  */
15906
- var settingRender$2 = [
15917
+ var settingRender$4 = [
15907
15918
  {
15908
15919
  title: '主题样式',
15909
15920
  child: [
@@ -16161,7 +16172,7 @@ Made in Italy` })));
16161
16172
 
16162
16173
  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"};
16163
16174
 
16164
- const closeIcon = '';
16175
+ const closeIcon$1 = '';
16165
16176
  const AniLinkPopup$1 = (_a) => {
16166
16177
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16167
16178
  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"]);
@@ -16220,7 +16231,7 @@ Made in Italy` })));
16220
16231
  paddingLeft: '6px'
16221
16232
  } }, "Cta Title")) : (React.createElement("div", Object.assign({}, props, { className: `${css.css(Object.assign(Object.assign({}, style), { '--transY': `translateY(calc(100% + ${(_r = style === null || style === void 0 ? void 0 : style.margin) !== null && _r !== void 0 ? _r : 0}px))` }))} ${styles['aniLinkPopup']} ${aniNamStyle} ${css.css(aniTimStyle)}`, onClick: handleTo }),
16222
16233
  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 } },
16223
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16234
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16224
16235
  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 }),
16225
16236
  (!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: {
16226
16237
  __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)
@@ -16307,7 +16318,7 @@ Made in Italy` })));
16307
16318
  category: 'cta',
16308
16319
  type: 'AniLinkPopup',
16309
16320
  related: {
16310
- settingRender: settingRender$2,
16321
+ settingRender: settingRender$4,
16311
16322
  bindableProps: [],
16312
16323
  interactionRender: interactionRender$2
16313
16324
  },
@@ -16386,7 +16397,7 @@ Made in Italy` })));
16386
16397
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16387
16398
  *
16388
16399
  */
16389
- var settingRender$1 = [
16400
+ var settingRender$3 = [
16390
16401
  {
16391
16402
  title: '全局设置',
16392
16403
  child: [
@@ -16527,74 +16538,27 @@ Made in Italy` })));
16527
16538
  }
16528
16539
  ];
16529
16540
 
16530
- /*
16531
- * @Author: binruan@chatlabs.com
16532
- * @Date: 2023-12-26 10:38:53
16533
- * @LastEditors: binruan@chatlabs.com
16534
- * @LastEditTime: 2024-12-11 18:24:31
16535
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16536
- *
16537
- */
16538
- const EditorDataContext = React.createContext({});
16539
- const EditorDataProvider = ({ children, data }) => {
16540
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16541
- const [openHashtag, setOpenHashtag] = React.useState(false);
16542
- const [openConsent, setOpenConsent] = React.useState(false);
16543
- const [consentPopupCate, setConsentPopupCate] = React.useState('');
16544
- const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
16545
- return (React.createElement(EditorDataContext.Provider, { value: {
16546
- sxpPrameter: {
16547
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16548
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16549
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16550
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16551
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16552
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16553
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16554
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16555
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16556
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16557
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16558
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16559
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16560
- },
16561
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16562
- openHashtag,
16563
- setOpenHashtag,
16564
- openConsent,
16565
- setOpenConsent,
16566
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16567
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16568
- consentPopupCate,
16569
- setConsentPopupCate,
16570
- openMultiPosts,
16571
- setOpenMultiPosts,
16572
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16573
- } }, children));
16574
- };
16575
- function useEditorDataProvider() {
16576
- return React.useContext(EditorDataContext);
16577
- }
16578
-
16579
- 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";
16541
+ 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";
16580
16542
 
16581
- var img$2 = "";
16543
+ var img$4 = "";
16582
16544
 
16583
16545
  const Display$1 = (_a) => {
16584
16546
  var _b, _c;
16585
- var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16586
- const { consentPopupCate } = useEditorDataProvider();
16547
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16587
16548
  const [isClose, setIsClose] = React.useState(false);
16549
+ const contsentState = React.useMemo(() => {
16550
+ return getContsentState();
16551
+ }, []);
16588
16552
  const visivle = React.useMemo(() => {
16589
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16590
- }, [consentPopupCate, open, isClose]);
16553
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16554
+ }, [consentPopupCate, open, isClose, contsentState]);
16591
16555
  const handleClickClose = React.useCallback(() => {
16592
16556
  setIsClose(true);
16593
16557
  }, []);
16594
16558
  const handleClick = React.useCallback(() => {
16595
16559
  onClick === null || onClick === void 0 ? void 0 : onClick();
16596
16560
  }, []);
16597
- 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 },
16561
+ 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 },
16598
16562
  React.createElement("div", { style: { flex: 1 } },
16599
16563
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16600
16564
  __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)
@@ -16603,7 +16567,7 @@ Made in Italy` })));
16603
16567
  __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)
16604
16568
  }, onClick: handleClick })),
16605
16569
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16606
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16570
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16607
16571
  };
16608
16572
  var DisplayComponent = React.memo(Display$1);
16609
16573
 
@@ -16629,7 +16593,7 @@ Made in Italy` })));
16629
16593
  category: 'consentPopup',
16630
16594
  type: 'Display',
16631
16595
  related: {
16632
- settingRender: settingRender$1,
16596
+ settingRender: settingRender$3,
16633
16597
  bindableProps: [],
16634
16598
  interactionRender: interactionRender$1
16635
16599
  },
@@ -16660,6 +16624,415 @@ Made in Italy` })));
16660
16624
  sort: 1
16661
16625
  });
16662
16626
 
16627
+ /*
16628
+ * @Author: binruan@chatlabs.com
16629
+ * @Date: 2023-07-28 18:29:57
16630
+ * @LastEditors: binruan@chatlabs.com
16631
+ * @LastEditTime: 2025-01-15 10:14:40
16632
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16633
+ *
16634
+ */
16635
+ var settingRender$2 = [
16636
+ {
16637
+ title: '全局设置',
16638
+ child: [
16639
+ {
16640
+ type: 'Switch',
16641
+ label: '弹窗开关',
16642
+ name: ['props', 'open']
16643
+ },
16644
+ {
16645
+ type: 'Color',
16646
+ label: '背景色',
16647
+ name: ['style', 'backgroundColor']
16648
+ },
16649
+ {
16650
+ type: 'Number',
16651
+ label: '内边距',
16652
+ name: ['style', 'padding'],
16653
+ addonAfter: 'px'
16654
+ }
16655
+ ]
16656
+ },
16657
+ {
16658
+ title: '弹窗文本',
16659
+ child: [
16660
+ {
16661
+ type: 'RichText',
16662
+ name: ['props', 'content']
16663
+ }
16664
+ ]
16665
+ },
16666
+ {
16667
+ title: '接受按钮样式',
16668
+ child: [
16669
+ {
16670
+ type: 'Color',
16671
+ label: '背景色',
16672
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16673
+ },
16674
+ {
16675
+ type: 'Number',
16676
+ label: '尺寸',
16677
+ name: ['props', 'acceptButton', 'style', 'height'],
16678
+ addonAfter: 'H'
16679
+ },
16680
+ {
16681
+ type: 'Group',
16682
+ label: '圆角',
16683
+ child: [
16684
+ {
16685
+ type: 'Slider',
16686
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16687
+ max: 100
16688
+ },
16689
+ {
16690
+ type: 'Number',
16691
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16692
+ addonAfter: 'px',
16693
+ max: 100
16694
+ }
16695
+ ]
16696
+ },
16697
+ {
16698
+ type: 'TextMargin',
16699
+ label: '边距',
16700
+ name: ['props', 'acceptButton', 'style']
16701
+ },
16702
+ {
16703
+ type: 'Group',
16704
+ label: '字体',
16705
+ child: [
16706
+ {
16707
+ type: 'Select',
16708
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16709
+ bottomText: '中文字体'
16710
+ },
16711
+ {
16712
+ type: 'Select',
16713
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16714
+ bottomText: '英文/其他字体'
16715
+ }
16716
+ ]
16717
+ },
16718
+ {
16719
+ type: 'Group',
16720
+ label: '',
16721
+ child: [
16722
+ {
16723
+ type: 'Color',
16724
+ name: ['props', 'acceptButton', 'style', 'color']
16725
+ },
16726
+ {
16727
+ type: 'Number',
16728
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16729
+ addonAfter: 'px'
16730
+ }
16731
+ ]
16732
+ },
16733
+ {
16734
+ label: '样式',
16735
+ type: 'TextStyle',
16736
+ name: ['props', 'acceptButton', 'style']
16737
+ },
16738
+ {
16739
+ label: '对齐',
16740
+ type: 'TextAlign',
16741
+ name: ['props', 'acceptButton', 'style']
16742
+ },
16743
+ {
16744
+ label: '间距',
16745
+ type: 'TextSpace',
16746
+ name: ['props', 'acceptButton', 'style']
16747
+ },
16748
+ {
16749
+ label: '文本',
16750
+ type: 'TextArea',
16751
+ name: ['props', 'acceptButton', 'text']
16752
+ }
16753
+ ]
16754
+ },
16755
+ {
16756
+ title: '拒绝按钮样式',
16757
+ child: [
16758
+ {
16759
+ type: 'Color',
16760
+ label: '背景色',
16761
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16762
+ },
16763
+ {
16764
+ type: 'Number',
16765
+ label: '尺寸',
16766
+ name: ['props', 'rejectButton', 'style', 'height'],
16767
+ addonAfter: 'H'
16768
+ },
16769
+ {
16770
+ type: 'Group',
16771
+ label: '圆角',
16772
+ child: [
16773
+ {
16774
+ type: 'Slider',
16775
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16776
+ max: 100
16777
+ },
16778
+ {
16779
+ type: 'Number',
16780
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16781
+ addonAfter: 'px',
16782
+ max: 100
16783
+ }
16784
+ ]
16785
+ },
16786
+ {
16787
+ type: 'TextMargin',
16788
+ label: '边距',
16789
+ name: ['props', 'acceptButton', 'style']
16790
+ },
16791
+ {
16792
+ type: 'Group',
16793
+ label: '字体',
16794
+ child: [
16795
+ {
16796
+ type: 'Select',
16797
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16798
+ bottomText: '中文字体'
16799
+ },
16800
+ {
16801
+ type: 'Select',
16802
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16803
+ bottomText: '英文/其他字体'
16804
+ }
16805
+ ]
16806
+ },
16807
+ {
16808
+ type: 'Group',
16809
+ label: '',
16810
+ child: [
16811
+ {
16812
+ type: 'Color',
16813
+ name: ['props', 'rejectButton', 'style', 'color']
16814
+ },
16815
+ {
16816
+ type: 'Number',
16817
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16818
+ addonAfter: 'px'
16819
+ }
16820
+ ]
16821
+ },
16822
+ {
16823
+ label: '样式',
16824
+ type: 'TextStyle',
16825
+ name: ['props', 'rejectButton', 'style']
16826
+ },
16827
+ {
16828
+ label: '对齐',
16829
+ type: 'TextAlign',
16830
+ name: ['props', 'rejectButton', 'style']
16831
+ },
16832
+ {
16833
+ label: '间距',
16834
+ type: 'TextSpace',
16835
+ name: ['props', 'rejectButton', 'style']
16836
+ },
16837
+ {
16838
+ label: '文本',
16839
+ type: 'TextArea',
16840
+ name: ['props', 'rejectButton', 'text']
16841
+ }
16842
+ ]
16843
+ }
16844
+ ];
16845
+
16846
+ var img$3 = "";
16847
+
16848
+ const Click$1 = (_a) => {
16849
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16850
+ const visivle = React.useMemo(() => {
16851
+ return consentPopupCate || (open && style);
16852
+ }, [consentPopupCate, open]);
16853
+ const handleClickAccept = () => { };
16854
+ const handleClickReject = () => { };
16855
+ 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' },
16856
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16857
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16858
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16859
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16860
+ };
16861
+ var ClickComponent = React.memo(Click$1);
16862
+
16863
+ /*
16864
+ * @Author: binruan@chatlabs.com
16865
+ * @Date: 2025-01-14 16:22:35
16866
+ * @LastEditors: binruan@chatlabs.com
16867
+ * @LastEditTime: 2025-01-15 17:09:49
16868
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16869
+ *
16870
+ */
16871
+ const Click = createMaterial(ClickComponent, {
16872
+ displayName: 'Click Consent',
16873
+ icon: '',
16874
+ category: 'consentPopup',
16875
+ type: 'Click',
16876
+ related: {
16877
+ settingRender: settingRender$2,
16878
+ bindableProps: []
16879
+ },
16880
+ defaulSetting: {
16881
+ props: {
16882
+ 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>',
16883
+ acceptButton: {
16884
+ text: 'Accept all cookies',
16885
+ style: {
16886
+ backgroundColor: '#000',
16887
+ height: 45,
16888
+ color: '#fff',
16889
+ fontSize: 12,
16890
+ textAlign: 'center',
16891
+ marginTop: 5,
16892
+ marginBottom: 5
16893
+ }
16894
+ },
16895
+ rejectButton: {
16896
+ text: 'Reject all cookies',
16897
+ style: {
16898
+ backgroundColor: '#000',
16899
+ height: 45,
16900
+ color: '#fff',
16901
+ fontSize: 12,
16902
+ textAlign: 'center',
16903
+ marginTop: 5,
16904
+ marginBottom: 5
16905
+ }
16906
+ }
16907
+ },
16908
+ style: {
16909
+ backgroundColor: '#fff',
16910
+ padding: 18
16911
+ }
16912
+ },
16913
+ sort: 2
16914
+ });
16915
+
16916
+ /*
16917
+ * @Author: binruan@chatlabs.com
16918
+ * @Date: 2023-07-28 18:29:57
16919
+ * @LastEditors: binruan@chatlabs.com
16920
+ * @LastEditTime: 2025-01-15 17:39:28
16921
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16922
+ *
16923
+ */
16924
+ var settingRender$1 = [
16925
+ {
16926
+ title: '全局设置',
16927
+ child: [
16928
+ {
16929
+ type: 'Switch',
16930
+ label: '弹窗开关',
16931
+ name: ['props', 'open']
16932
+ },
16933
+ {
16934
+ type: 'Color',
16935
+ label: '背景色',
16936
+ name: ['style', 'backgroundColor']
16937
+ },
16938
+ {
16939
+ type: 'Number',
16940
+ label: '内边距',
16941
+ name: ['style', 'padding'],
16942
+ addonAfter: 'px'
16943
+ }
16944
+ ]
16945
+ },
16946
+ {
16947
+ title: '弹窗文本',
16948
+ child: [
16949
+ {
16950
+ type: 'RichText',
16951
+ name: ['props', 'content']
16952
+ }
16953
+ ]
16954
+ },
16955
+ {
16956
+ title: '滑动图标',
16957
+ child: [
16958
+ {
16959
+ type: 'Upload',
16960
+ label: '滑动图标',
16961
+ name: ['props', 'swipeIcon'],
16962
+ text: '建议尺寸:252 * 185'
16963
+ }
16964
+ ]
16965
+ }
16966
+ ];
16967
+
16968
+ var img$2 = "";
16969
+
16970
+ const closeIcon = '';
16971
+ const Swipe$1 = (_a) => {
16972
+ var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
16973
+ const touchInfo = React.useRef();
16974
+ const handleTouchStart = (event) => {
16975
+ const touch = event.touches[0];
16976
+ touchInfo.current = { y: touch.clientY, d: 0 };
16977
+ };
16978
+ const handleTouchMove = (event) => {
16979
+ var _a;
16980
+ if (!touchInfo.current)
16981
+ return;
16982
+ const touch = event.touches[0];
16983
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
16984
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
16985
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
16986
+ };
16987
+ const handleTouchEnd = () => {
16988
+ if (!touchInfo.current)
16989
+ return;
16990
+ touchInfo.current || {};
16991
+ touchInfo.current = {};
16992
+ };
16993
+ const handleClickReject = () => { };
16994
+ const visivle = React.useMemo(() => {
16995
+ return consentPopupCate || (open && style);
16996
+ }, [consentPopupCate, open]);
16997
+ 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 },
16998
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
16999
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17000
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17001
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
17002
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17003
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17004
+ };
17005
+ var SwipeComponent = React.memo(Swipe$1);
17006
+
17007
+ /*
17008
+ * @Author: binruan@chatlabs.com
17009
+ * @Date: 2025-01-14 16:22:35
17010
+ * @LastEditors: binruan@chatlabs.com
17011
+ * @LastEditTime: 2025-01-15 17:09:49
17012
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17013
+ *
17014
+ */
17015
+ const Swipe = createMaterial(SwipeComponent, {
17016
+ displayName: 'Swipe Consent',
17017
+ icon: '',
17018
+ category: 'consentPopup',
17019
+ type: 'Swipe',
17020
+ related: {
17021
+ settingRender: settingRender$1,
17022
+ bindableProps: []
17023
+ },
17024
+ defaulSetting: {
17025
+ props: {
17026
+ 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>'
17027
+ },
17028
+ style: {
17029
+ backgroundColor: '#fff',
17030
+ padding: 18
17031
+ }
17032
+ },
17033
+ sort: 3
17034
+ });
17035
+
16663
17036
  /*
16664
17037
  * @Author: binruan@chatlabs.com
16665
17038
  * @Date: 2024-06-13 10:08:32
@@ -16961,6 +17334,7 @@ Made in Italy` })));
16961
17334
  AniLinkPopup: AniLinkPopup,
16962
17335
  Appoint: Appoint,
16963
17336
  AppointForm: AppointForm,
17337
+ Click: Click,
16964
17338
  Commodity: Commodity,
16965
17339
  CommodityDetail: CommodityDetail,
16966
17340
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -16977,7 +17351,8 @@ Made in Italy` })));
16977
17351
  MultiCommodityDiro: MultiCommodityDiro,
16978
17352
  MultiCommodityDiroNew: MultiCommodityDiroNew,
16979
17353
  MultiPosts: MultiPosts,
16980
- Prompt: Prompt
17354
+ Prompt: Prompt,
17355
+ Swipe: Swipe
16981
17356
  });
16982
17357
 
16983
17358
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17847,23 +18222,72 @@ Made in Italy` })));
17847
18222
  };
17848
18223
  var Tagbar$1 = React.memo(Tagbar);
17849
18224
 
18225
+ /*
18226
+ * @Author: binruan@chatlabs.com
18227
+ * @Date: 2023-12-26 10:38:53
18228
+ * @LastEditors: binruan@chatlabs.com
18229
+ * @LastEditTime: 2024-12-11 18:24:31
18230
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18231
+ *
18232
+ */
18233
+ const EditorDataContext = React.createContext({});
18234
+ const EditorDataProvider = ({ children, data }) => {
18235
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18236
+ const [openHashtag, setOpenHashtag] = React.useState(false);
18237
+ const [openConsent, setOpenConsent] = React.useState(false);
18238
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
18239
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18240
+ return (React.createElement(EditorDataContext.Provider, { value: {
18241
+ sxpPrameter: {
18242
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18243
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18244
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18245
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18246
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18247
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18248
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18249
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18250
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18251
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18252
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18253
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18254
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18255
+ },
18256
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18257
+ openHashtag,
18258
+ setOpenHashtag,
18259
+ openConsent,
18260
+ setOpenConsent,
18261
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18262
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18263
+ consentPopupCate,
18264
+ setConsentPopupCate,
18265
+ openMultiPosts,
18266
+ setOpenMultiPosts,
18267
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18268
+ } }, children));
18269
+ };
18270
+ function useEditorDataProvider() {
18271
+ return React.useContext(EditorDataContext);
18272
+ }
18273
+
17850
18274
  /*
17851
18275
  * @Author: binruan@chatlabs.com
17852
18276
  * @Date: 2023-12-26 16:11:34
17853
18277
  * @LastEditors: binruan@chatlabs.com
17854
- * @LastEditTime: 2024-11-05 16:29:47
18278
+ * @LastEditTime: 2025-01-14 18:02:44
17855
18279
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17856
18280
  *
17857
18281
  */
17858
18282
  const Consent = ({ resolver, globalConfig }) => {
17859
18283
  var _a, _b;
17860
- const contsentState = React.useMemo(() => {
17861
- return getContsentState();
17862
- }, []);
17863
- const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
17864
- const Component = withBindDataSource(t);
18284
+ const { consentPopupCate } = useEditorDataProvider();
17865
18285
  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;
17866
- 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 }));
18286
+ if (!value)
18287
+ return null;
18288
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18289
+ const Component = withBindDataSource(t);
18290
+ 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 })));
17867
18291
  };
17868
18292
  var ConsentPopup = React.memo(Consent);
17869
18293
 
@@ -17886,7 +18310,7 @@ Made in Italy` })));
17886
18310
  * @Author: binruan@chatlabs.com
17887
18311
  * @Date: 2024-03-20 10:27:31
17888
18312
  * @LastEditors: binruan@chatlabs.com
17889
- * @LastEditTime: 2024-12-18 10:24:20
18313
+ * @LastEditTime: 2025-01-20 18:46:32
17890
18314
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17891
18315
  *
17892
18316
  */
@@ -17981,7 +18405,7 @@ Made in Italy` })));
17981
18405
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
17982
18406
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
17983
18407
  position: activeIndex + '',
17984
- fromKName: fk ? fk : fromKName,
18408
+ fromKName: fk || fromKName,
17985
18409
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
17986
18410
  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 : '',
17987
18411
  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 : ''
@@ -18011,9 +18435,12 @@ Made in Italy` })));
18011
18435
  skipLinkRef.current = false;
18012
18436
  }
18013
18437
  // 页面可见时触发,注意页面初始化时不会触发
18438
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18014
18439
  handleH5EnterLink();
18015
18440
  if (repCond) {
18016
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18441
+ setTimeout(() => {
18442
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18443
+ });
18017
18444
  backMainFeed('external', selectTag);
18018
18445
  }
18019
18446
  }
@@ -18853,7 +19280,7 @@ Made in Italy` })));
18853
19280
  * @Author: binruan@chatlabs.com
18854
19281
  * @Date: 2023-10-31 10:56:01
18855
19282
  * @LastEditors: binruan@chatlabs.com
18856
- * @LastEditTime: 2024-12-12 14:48:31
19283
+ * @LastEditTime: 2024-10-23 15:07:29
18857
19284
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Popup\index.tsx
18858
19285
  *
18859
19286
  */