pb-sxp-ui 1.14.0 → 14.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/dist/index.cjs +581 -158
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +89 -0
  4. package/dist/index.js +581 -158
  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 +581 -158
  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 +39 -18
  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 +39 -18
  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,7 +736,7 @@
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
  }
@@ -755,7 +758,7 @@
755
758
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
756
759
  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
760
  }
758
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
761
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
759
762
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
760
763
  return undefined;
761
764
  }
@@ -805,6 +808,7 @@
805
808
  return expire;
806
809
  }, [data]);
807
810
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
811
+ var _a;
808
812
  // 关闭 BFF 事件上报
809
813
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
810
814
  return;
@@ -826,14 +830,23 @@
826
830
  console.log('userInfo:', userInfo);
827
831
  console.log('eventInfo:', ef);
828
832
  console.log('========= 结束 =========');
829
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
833
+ return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch(`v2/event/report/CLD/${(_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']}/${eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.eventSubject}`, {
830
834
  method: 'POST',
831
835
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
832
836
  type: 'beacon'
833
837
  });
834
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
838
+ }, [
839
+ bffFetch,
840
+ curReqInfo,
841
+ enableReportEvent,
842
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
843
+ layoutVariantId,
844
+ globalConfig,
845
+ playbookType,
846
+ bffDataSource
847
+ ]);
835
848
  const bffFbReport = React.useCallback(({ eventName, product }) => {
836
- var _a, _b, _c, _d, _e;
849
+ var _a, _b, _c, _d, _e, _f;
837
850
  if (!enableReportEvent ||
838
851
  !enabledMetaConversionApi ||
839
852
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -845,7 +858,7 @@
845
858
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
846
859
  const fix_par = {
847
860
  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(),
861
+ external_id: fakeUserId,
849
862
  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
863
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
851
864
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -897,22 +910,30 @@
897
910
  }
898
911
  };
899
912
  getEventParams(jsonParams);
900
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
913
+ 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
914
  method: 'POST',
902
915
  body: jsonParams,
903
916
  type: 'beacon'
904
917
  });
905
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
918
+ }, [
919
+ bffFetch,
920
+ enableReportEvent,
921
+ enabledMetaConversionApi,
922
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
923
+ globalConfig,
924
+ fakeUserId,
925
+ bffDataSource
926
+ ]);
906
927
  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 }));
928
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
908
929
  return res === null || res === void 0 ? void 0 : res.success;
909
930
  }), [bffFetch]);
910
931
  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 }));
932
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
912
933
  return res === null || res === void 0 ? void 0 : res.success;
913
934
  }), [bffFetch]);
914
935
  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 }));
936
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
916
937
  return res === null || res === void 0 ? void 0 : res.success;
917
938
  }), [bffFetch]);
918
939
  // 获取 Tag
@@ -927,7 +948,7 @@
927
948
  const key = val.split('=')[0];
928
949
  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
950
  })) === 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) } }));
951
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
931
952
  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
953
  }
933
954
  catch (e) {
@@ -1001,10 +1022,10 @@
1001
1022
  let curData;
1002
1023
  let gldata;
1003
1024
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1025
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1026
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1004
1027
  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
1028
  if (id) {
1006
- layId = id;
1007
- setLayoutVariantId(id);
1008
1029
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1009
1030
  if (curData) {
1010
1031
  setPageData(curData);
@@ -1390,7 +1411,7 @@
1390
1411
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1391
1412
  *
1392
1413
  */
1393
- var settingRender$d = [
1414
+ var settingRender$f = [
1394
1415
  {
1395
1416
  title: '弹窗背景',
1396
1417
  child: [
@@ -1826,7 +1847,7 @@
1826
1847
  category: 'popup',
1827
1848
  type: 'AppointForm',
1828
1849
  related: {
1829
- settingRender: settingRender$d,
1850
+ settingRender: settingRender$f,
1830
1851
  bindableProps: [],
1831
1852
  interactionRender: interactionRender$g
1832
1853
  },
@@ -1851,7 +1872,7 @@
1851
1872
  sort: 2
1852
1873
  });
1853
1874
 
1854
- var settingRender$c = [
1875
+ var settingRender$e = [
1855
1876
  {
1856
1877
  title: '弹窗背景',
1857
1878
  child: [
@@ -9740,7 +9761,7 @@
9740
9761
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9741
9762
  *
9742
9763
  */
9743
- const closeIcon$1 = '';
9764
+ const closeIcon$2 = '';
9744
9765
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9745
9766
  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
9767
  const touchRef = React.useRef(null);
@@ -9920,7 +9941,7 @@
9920
9941
  }
9921
9942
  })), child()),
9922
9943
  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);
9944
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9924
9945
  };
9925
9946
  var Modal$1 = React.memo(Modal);
9926
9947
 
@@ -10091,7 +10112,7 @@
10091
10112
  * @Author: binruan@chatlabs.com
10092
10113
  * @Date: 2024-03-20 14:56:16
10093
10114
  * @LastEditors: binruan@chatlabs.com
10094
- * @LastEditTime: 2024-10-24 17:51:19
10115
+ * @LastEditTime: 2024-12-20 14:32:26
10095
10116
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10096
10117
  *
10097
10118
  */
@@ -10129,14 +10150,16 @@
10129
10150
  };
10130
10151
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10131
10152
  var _a, _b, _c, _d, _e, _f, _g, _h;
10153
+ let text = '';
10132
10154
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10133
10155
  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 = '';
10156
+ 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);
10157
+ if (typeof price !== 'number')
10158
+ return text;
10136
10159
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10137
10160
  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
10161
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10139
- let decPic = price.toString();
10162
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10140
10163
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10141
10164
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10142
10165
  }
@@ -10448,7 +10471,7 @@
10448
10471
  category: 'popup',
10449
10472
  type: 'CommodityDetail',
10450
10473
  related: {
10451
- settingRender: settingRender$c,
10474
+ settingRender: settingRender$e,
10452
10475
  interactionRender: interactionRender$f
10453
10476
  },
10454
10477
  defaulSetting: {
@@ -10524,7 +10547,7 @@
10524
10547
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10525
10548
  *
10526
10549
  */
10527
- var settingRender$b = [
10550
+ var settingRender$d = [
10528
10551
  {
10529
10552
  title: '弹窗背景',
10530
10553
  child: [
@@ -10665,7 +10688,7 @@
10665
10688
  }
10666
10689
  ];
10667
10690
 
10668
- var img$5 = "";
10691
+ var img$7 = "";
10669
10692
 
10670
10693
  const Prompt$1 = (_a) => {
10671
10694
  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 +10711,7 @@
10688
10711
  };
10689
10712
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10690
10713
  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' })),
10714
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10692
10715
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10693
10716
  __html: setFontForText(content, contentStyle)
10694
10717
  } }),
@@ -10704,13 +10727,13 @@
10704
10727
  category: 'popup',
10705
10728
  type: 'Prompt',
10706
10729
  related: {
10707
- settingRender: settingRender$b,
10730
+ settingRender: settingRender$d,
10708
10731
  bindableProps: [],
10709
10732
  interactionRender: interactionRender$e
10710
10733
  },
10711
10734
  defaulSetting: {
10712
10735
  props: {
10713
- icon: img$5,
10736
+ icon: img$7,
10714
10737
  content: 'You have successfully completed the appointment!',
10715
10738
  btnText: 'OK'
10716
10739
  },
@@ -10729,7 +10752,7 @@
10729
10752
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10730
10753
  *
10731
10754
  */
10732
- var settingRender$a = [
10755
+ var settingRender$c = [
10733
10756
  {
10734
10757
  title: '弹窗背景',
10735
10758
  child: [
@@ -11408,7 +11431,7 @@ Made in Italy` })));
11408
11431
  category: 'popup',
11409
11432
  type: 'CommodityDetailDiroNew',
11410
11433
  related: {
11411
- settingRender: settingRender$a,
11434
+ settingRender: settingRender$c,
11412
11435
  interactionRender: interactionRender$d
11413
11436
  },
11414
11437
  defaulSetting: {
@@ -11472,7 +11495,7 @@ Made in Italy` })));
11472
11495
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11473
11496
  *
11474
11497
  */
11475
- var settingRender$9 = [
11498
+ var settingRender$b = [
11476
11499
  {
11477
11500
  title: '弹窗背景',
11478
11501
  child: [
@@ -11909,7 +11932,7 @@ Made in Italy` })));
11909
11932
  category: 'popup',
11910
11933
  type: 'CommodityList',
11911
11934
  related: {
11912
- settingRender: settingRender$9,
11935
+ settingRender: settingRender$b,
11913
11936
  interactionRender: interactionRender$c
11914
11937
  },
11915
11938
  defaulSetting: {
@@ -11954,11 +11977,11 @@ Made in Italy` })));
11954
11977
  * @Author: binruan@chatlabs.com
11955
11978
  * @Date: 2023-10-27 14:06:35
11956
11979
  * @LastEditors: binruan@chatlabs.com
11957
- * @LastEditTime: 2024-12-12 15:12:57
11980
+ * @LastEditTime: 2024-08-08 17:32:11
11958
11981
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
11959
11982
  *
11960
11983
  */
11961
- var settingRender$8 = [
11984
+ var settingRender$a = [
11962
11985
  {
11963
11986
  title: '背景样式',
11964
11987
  child: [
@@ -11968,32 +11991,16 @@ Made in Italy` })));
11968
11991
  name: ['style', 'backgroundColor']
11969
11992
  }
11970
11993
  ]
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
11994
  }
11987
11995
  ];
11988
11996
 
11989
11997
  const Iframe$1 = (_a) => {
11990
11998
  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"]);
11999
+ 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
12000
  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: {
12001
+ 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;
12002
+ return (React.createElement("div", Object.assign({ className: `${css.css(Object.assign({}, style))}` }, props),
12003
+ React.createElement("iframe", { src: iframeUrl, style: {
11997
12004
  width: '100%',
11998
12005
  height: 'calc(100% - 50px)',
11999
12006
  marginTop: '50px',
@@ -12008,7 +12015,7 @@ Made in Italy` })));
12008
12015
  category: 'popup',
12009
12016
  type: 'Iframe',
12010
12017
  related: {
12011
- settingRender: settingRender$8,
12018
+ settingRender: settingRender$a,
12012
12019
  bindableProps: []
12013
12020
  },
12014
12021
  defaulSetting: {
@@ -12028,7 +12035,7 @@ Made in Italy` })));
12028
12035
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12029
12036
  *
12030
12037
  */
12031
- var settingRender$7 = [
12038
+ var settingRender$9 = [
12032
12039
  {
12033
12040
  title: '弹窗文本',
12034
12041
  child: [
@@ -12041,22 +12048,22 @@ Made in Italy` })));
12041
12048
  ];
12042
12049
 
12043
12050
  const ConsentDetail$1 = (_a) => {
12044
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12051
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12045
12052
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12046
12053
  __html: typeof content === 'string' ? content : ''
12047
12054
  }, onClick: (e) => {
12048
12055
  e.stopPropagation();
12049
- } }));
12056
+ }, style: style }));
12050
12057
  };
12051
- var ConsentDetailComponent = React.memo(ConsentDetail$1);
12058
+ var ConsentDetail$2 = React.memo(ConsentDetail$1);
12052
12059
 
12053
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12060
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12054
12061
  displayName: '协议详情',
12055
12062
  icon: '',
12056
12063
  category: 'popup',
12057
12064
  type: 'ConsentDetail',
12058
12065
  related: {
12059
- settingRender: settingRender$7,
12066
+ settingRender: settingRender$9,
12060
12067
  bindableProps: []
12061
12068
  },
12062
12069
  defaulSetting: {
@@ -12076,7 +12083,7 @@ Made in Italy` })));
12076
12083
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12077
12084
  *
12078
12085
  */
12079
- var settingRender$6 = [
12086
+ var settingRender$8 = [
12080
12087
  {
12081
12088
  title: '主题样式',
12082
12089
  child: [
@@ -12430,7 +12437,7 @@ Made in Italy` })));
12430
12437
  related: {
12431
12438
  interactionRender: interactionRender$b,
12432
12439
  bindableProps: [],
12433
- settingRender: settingRender$6
12440
+ settingRender: settingRender$8
12434
12441
  },
12435
12442
  defaulSetting: {
12436
12443
  props: {
@@ -12512,7 +12519,7 @@ Made in Italy` })));
12512
12519
  type: 'Appoint',
12513
12520
  related: {
12514
12521
  interactionRender: interactionRender$a,
12515
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12522
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12516
12523
  bindableProps: []
12517
12524
  },
12518
12525
  defaulSetting: {
@@ -12718,7 +12725,7 @@ Made in Italy` })));
12718
12725
  category: 'template',
12719
12726
  type: 'Link',
12720
12727
  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),
12728
+ 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
12729
  bindableProps: [],
12723
12730
  interactionRender: interactionRender$9
12724
12731
  },
@@ -12821,7 +12828,7 @@ Made in Italy` })));
12821
12828
  type: 'CommodityDiro',
12822
12829
  related: {
12823
12830
  interactionRender: interactionRender$8,
12824
- settingRender: settingRender$6,
12831
+ settingRender: settingRender$8,
12825
12832
  bindableProps: []
12826
12833
  },
12827
12834
  defaulSetting: {
@@ -12918,7 +12925,7 @@ Made in Italy` })));
12918
12925
  related: {
12919
12926
  interactionRender: interactionRender$7,
12920
12927
  bindableProps: [],
12921
- settingRender: settingRender$6
12928
+ settingRender: settingRender$8
12922
12929
  },
12923
12930
  defaulSetting: {
12924
12931
  props: {
@@ -13018,7 +13025,7 @@ Made in Italy` })));
13018
13025
  related: {
13019
13026
  interactionRender: interactionRender$6,
13020
13027
  bindableProps: [],
13021
- settingRender: settingRender$6
13028
+ settingRender: settingRender$8
13022
13029
  },
13023
13030
  defaulSetting: {
13024
13031
  props: {
@@ -13116,7 +13123,7 @@ Made in Italy` })));
13116
13123
  type: 'MultiCommodity',
13117
13124
  related: {
13118
13125
  interactionRender: interactionRender$5,
13119
- settingRender: settingRender$6,
13126
+ settingRender: settingRender$8,
13120
13127
  bindableProps: []
13121
13128
  },
13122
13129
  defaulSetting: {
@@ -13225,7 +13232,7 @@ Made in Italy` })));
13225
13232
  related: {
13226
13233
  interactionRender: interactionRender$4,
13227
13234
  bindableProps: [],
13228
- settingRender: settingRender$6
13235
+ settingRender: settingRender$8
13229
13236
  },
13230
13237
  defaulSetting: {
13231
13238
  props: {
@@ -13274,7 +13281,7 @@ Made in Italy` })));
13274
13281
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13275
13282
  *
13276
13283
  */
13277
- var settingRender$5 = [
13284
+ var settingRender$7 = [
13278
13285
  {
13279
13286
  title: 'Banner',
13280
13287
  child: [
@@ -15102,7 +15109,7 @@ Made in Italy` })));
15102
15109
  } }))))));
15103
15110
  }
15104
15111
 
15105
- var img$4 = "";
15112
+ var img$6 = "";
15106
15113
 
15107
15114
  const WaterfallFlowItem = (props) => {
15108
15115
  var _a;
@@ -15423,7 +15430,7 @@ Made in Italy` })));
15423
15430
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15424
15431
  display: openHashtag ? 'block' : 'none'
15425
15432
  } },
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 }),
15433
+ 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
15434
  (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
15435
  };
15429
15436
  var WaterFall$1 = React.memo(WaterFall);
@@ -15455,7 +15462,7 @@ Made in Italy` })));
15455
15462
  category: 'base',
15456
15463
  type: 'HashTag',
15457
15464
  related: {
15458
- settingRender: settingRender$5,
15465
+ settingRender: settingRender$7,
15459
15466
  bindableProps: []
15460
15467
  },
15461
15468
  defaulSetting: {
@@ -15520,7 +15527,7 @@ Made in Italy` })));
15520
15527
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15521
15528
  *
15522
15529
  */
15523
- var settingRender$4 = [
15530
+ var settingRender$6 = [
15524
15531
  {
15525
15532
  title: '协议详情',
15526
15533
  child: [
@@ -15579,7 +15586,7 @@ Made in Italy` })));
15579
15586
  category: 'base',
15580
15587
  type: 'Consent',
15581
15588
  related: {
15582
- settingRender: settingRender$4
15589
+ settingRender: settingRender$6
15583
15590
  },
15584
15591
  defaulSetting: {
15585
15592
  props: {},
@@ -15598,7 +15605,7 @@ Made in Italy` })));
15598
15605
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15599
15606
  *
15600
15607
  */
15601
- var settingRender$3 = [
15608
+ var settingRender$5 = [
15602
15609
  {
15603
15610
  title: '主题样式',
15604
15611
  child: [
@@ -15859,7 +15866,7 @@ Made in Italy` })));
15859
15866
  category: 'cta',
15860
15867
  type: 'AniLink',
15861
15868
  related: {
15862
- settingRender: settingRender$3,
15869
+ settingRender: settingRender$5,
15863
15870
  bindableProps: [],
15864
15871
  interactionRender: interactionRender$3
15865
15872
  },
@@ -15903,7 +15910,7 @@ Made in Italy` })));
15903
15910
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15904
15911
  *
15905
15912
  */
15906
- var settingRender$2 = [
15913
+ var settingRender$4 = [
15907
15914
  {
15908
15915
  title: '主题样式',
15909
15916
  child: [
@@ -16161,7 +16168,7 @@ Made in Italy` })));
16161
16168
 
16162
16169
  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
16170
 
16164
- const closeIcon = '';
16171
+ const closeIcon$1 = '';
16165
16172
  const AniLinkPopup$1 = (_a) => {
16166
16173
  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
16174
  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 +16227,7 @@ Made in Italy` })));
16220
16227
  paddingLeft: '6px'
16221
16228
  } }, "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
16229
  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'] })),
16230
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16224
16231
  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
16232
  (!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
16233
  __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 +16314,7 @@ Made in Italy` })));
16307
16314
  category: 'cta',
16308
16315
  type: 'AniLinkPopup',
16309
16316
  related: {
16310
- settingRender: settingRender$2,
16317
+ settingRender: settingRender$4,
16311
16318
  bindableProps: [],
16312
16319
  interactionRender: interactionRender$2
16313
16320
  },
@@ -16386,7 +16393,7 @@ Made in Italy` })));
16386
16393
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16387
16394
  *
16388
16395
  */
16389
- var settingRender$1 = [
16396
+ var settingRender$3 = [
16390
16397
  {
16391
16398
  title: '全局设置',
16392
16399
  child: [
@@ -16527,74 +16534,27 @@ Made in Italy` })));
16527
16534
  }
16528
16535
  ];
16529
16536
 
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";
16537
+ 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
16538
 
16581
- var img$2 = "";
16539
+ var img$4 = "";
16582
16540
 
16583
16541
  const Display$1 = (_a) => {
16584
16542
  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();
16543
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16587
16544
  const [isClose, setIsClose] = React.useState(false);
16545
+ const contsentState = React.useMemo(() => {
16546
+ return getContsentState();
16547
+ }, []);
16588
16548
  const visivle = React.useMemo(() => {
16589
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16590
- }, [consentPopupCate, open, isClose]);
16549
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16550
+ }, [consentPopupCate, open, isClose, contsentState]);
16591
16551
  const handleClickClose = React.useCallback(() => {
16592
16552
  setIsClose(true);
16593
16553
  }, []);
16594
16554
  const handleClick = React.useCallback(() => {
16595
16555
  onClick === null || onClick === void 0 ? void 0 : onClick();
16596
16556
  }, []);
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 },
16557
+ 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
16558
  React.createElement("div", { style: { flex: 1 } },
16599
16559
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16600
16560
  __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 +16563,7 @@ Made in Italy` })));
16603
16563
  __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
16564
  }, onClick: handleClick })),
16605
16565
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16606
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16566
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16607
16567
  };
16608
16568
  var DisplayComponent = React.memo(Display$1);
16609
16569
 
@@ -16629,7 +16589,7 @@ Made in Italy` })));
16629
16589
  category: 'consentPopup',
16630
16590
  type: 'Display',
16631
16591
  related: {
16632
- settingRender: settingRender$1,
16592
+ settingRender: settingRender$3,
16633
16593
  bindableProps: [],
16634
16594
  interactionRender: interactionRender$1
16635
16595
  },
@@ -16660,6 +16620,415 @@ Made in Italy` })));
16660
16620
  sort: 1
16661
16621
  });
16662
16622
 
16623
+ /*
16624
+ * @Author: binruan@chatlabs.com
16625
+ * @Date: 2023-07-28 18:29:57
16626
+ * @LastEditors: binruan@chatlabs.com
16627
+ * @LastEditTime: 2025-01-15 10:14:40
16628
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16629
+ *
16630
+ */
16631
+ var settingRender$2 = [
16632
+ {
16633
+ title: '全局设置',
16634
+ child: [
16635
+ {
16636
+ type: 'Switch',
16637
+ label: '弹窗开关',
16638
+ name: ['props', 'open']
16639
+ },
16640
+ {
16641
+ type: 'Color',
16642
+ label: '背景色',
16643
+ name: ['style', 'backgroundColor']
16644
+ },
16645
+ {
16646
+ type: 'Number',
16647
+ label: '内边距',
16648
+ name: ['style', 'padding'],
16649
+ addonAfter: 'px'
16650
+ }
16651
+ ]
16652
+ },
16653
+ {
16654
+ title: '弹窗文本',
16655
+ child: [
16656
+ {
16657
+ type: 'RichText',
16658
+ name: ['props', 'content']
16659
+ }
16660
+ ]
16661
+ },
16662
+ {
16663
+ title: '接受按钮样式',
16664
+ child: [
16665
+ {
16666
+ type: 'Color',
16667
+ label: '背景色',
16668
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16669
+ },
16670
+ {
16671
+ type: 'Number',
16672
+ label: '尺寸',
16673
+ name: ['props', 'acceptButton', 'style', 'height'],
16674
+ addonAfter: 'H'
16675
+ },
16676
+ {
16677
+ type: 'Group',
16678
+ label: '圆角',
16679
+ child: [
16680
+ {
16681
+ type: 'Slider',
16682
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16683
+ max: 100
16684
+ },
16685
+ {
16686
+ type: 'Number',
16687
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16688
+ addonAfter: 'px',
16689
+ max: 100
16690
+ }
16691
+ ]
16692
+ },
16693
+ {
16694
+ type: 'TextMargin',
16695
+ label: '边距',
16696
+ name: ['props', 'acceptButton', 'style']
16697
+ },
16698
+ {
16699
+ type: 'Group',
16700
+ label: '字体',
16701
+ child: [
16702
+ {
16703
+ type: 'Select',
16704
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16705
+ bottomText: '中文字体'
16706
+ },
16707
+ {
16708
+ type: 'Select',
16709
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16710
+ bottomText: '英文/其他字体'
16711
+ }
16712
+ ]
16713
+ },
16714
+ {
16715
+ type: 'Group',
16716
+ label: '',
16717
+ child: [
16718
+ {
16719
+ type: 'Color',
16720
+ name: ['props', 'acceptButton', 'style', 'color']
16721
+ },
16722
+ {
16723
+ type: 'Number',
16724
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16725
+ addonAfter: 'px'
16726
+ }
16727
+ ]
16728
+ },
16729
+ {
16730
+ label: '样式',
16731
+ type: 'TextStyle',
16732
+ name: ['props', 'acceptButton', 'style']
16733
+ },
16734
+ {
16735
+ label: '对齐',
16736
+ type: 'TextAlign',
16737
+ name: ['props', 'acceptButton', 'style']
16738
+ },
16739
+ {
16740
+ label: '间距',
16741
+ type: 'TextSpace',
16742
+ name: ['props', 'acceptButton', 'style']
16743
+ },
16744
+ {
16745
+ label: '文本',
16746
+ type: 'TextArea',
16747
+ name: ['props', 'acceptButton', 'text']
16748
+ }
16749
+ ]
16750
+ },
16751
+ {
16752
+ title: '拒绝按钮样式',
16753
+ child: [
16754
+ {
16755
+ type: 'Color',
16756
+ label: '背景色',
16757
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16758
+ },
16759
+ {
16760
+ type: 'Number',
16761
+ label: '尺寸',
16762
+ name: ['props', 'rejectButton', 'style', 'height'],
16763
+ addonAfter: 'H'
16764
+ },
16765
+ {
16766
+ type: 'Group',
16767
+ label: '圆角',
16768
+ child: [
16769
+ {
16770
+ type: 'Slider',
16771
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16772
+ max: 100
16773
+ },
16774
+ {
16775
+ type: 'Number',
16776
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16777
+ addonAfter: 'px',
16778
+ max: 100
16779
+ }
16780
+ ]
16781
+ },
16782
+ {
16783
+ type: 'TextMargin',
16784
+ label: '边距',
16785
+ name: ['props', 'acceptButton', 'style']
16786
+ },
16787
+ {
16788
+ type: 'Group',
16789
+ label: '字体',
16790
+ child: [
16791
+ {
16792
+ type: 'Select',
16793
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16794
+ bottomText: '中文字体'
16795
+ },
16796
+ {
16797
+ type: 'Select',
16798
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16799
+ bottomText: '英文/其他字体'
16800
+ }
16801
+ ]
16802
+ },
16803
+ {
16804
+ type: 'Group',
16805
+ label: '',
16806
+ child: [
16807
+ {
16808
+ type: 'Color',
16809
+ name: ['props', 'rejectButton', 'style', 'color']
16810
+ },
16811
+ {
16812
+ type: 'Number',
16813
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16814
+ addonAfter: 'px'
16815
+ }
16816
+ ]
16817
+ },
16818
+ {
16819
+ label: '样式',
16820
+ type: 'TextStyle',
16821
+ name: ['props', 'rejectButton', 'style']
16822
+ },
16823
+ {
16824
+ label: '对齐',
16825
+ type: 'TextAlign',
16826
+ name: ['props', 'rejectButton', 'style']
16827
+ },
16828
+ {
16829
+ label: '间距',
16830
+ type: 'TextSpace',
16831
+ name: ['props', 'rejectButton', 'style']
16832
+ },
16833
+ {
16834
+ label: '文本',
16835
+ type: 'TextArea',
16836
+ name: ['props', 'rejectButton', 'text']
16837
+ }
16838
+ ]
16839
+ }
16840
+ ];
16841
+
16842
+ var img$3 = "";
16843
+
16844
+ const Click$1 = (_a) => {
16845
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16846
+ const visivle = React.useMemo(() => {
16847
+ return consentPopupCate || (open && style);
16848
+ }, [consentPopupCate, open]);
16849
+ const handleClickAccept = () => { };
16850
+ const handleClickReject = () => { };
16851
+ 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' },
16852
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16853
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16854
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16855
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16856
+ };
16857
+ var ClickComponent = React.memo(Click$1);
16858
+
16859
+ /*
16860
+ * @Author: binruan@chatlabs.com
16861
+ * @Date: 2025-01-14 16:22:35
16862
+ * @LastEditors: binruan@chatlabs.com
16863
+ * @LastEditTime: 2025-01-15 17:09:49
16864
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16865
+ *
16866
+ */
16867
+ const Click = createMaterial(ClickComponent, {
16868
+ displayName: 'Click Consent',
16869
+ icon: '',
16870
+ category: 'consentPopup',
16871
+ type: 'Click',
16872
+ related: {
16873
+ settingRender: settingRender$2,
16874
+ bindableProps: []
16875
+ },
16876
+ defaulSetting: {
16877
+ props: {
16878
+ 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>',
16879
+ acceptButton: {
16880
+ text: 'Accept all cookies',
16881
+ style: {
16882
+ backgroundColor: '#000',
16883
+ height: 45,
16884
+ color: '#fff',
16885
+ fontSize: 12,
16886
+ textAlign: 'center',
16887
+ marginTop: 5,
16888
+ marginBottom: 5
16889
+ }
16890
+ },
16891
+ rejectButton: {
16892
+ text: 'Reject all cookies',
16893
+ style: {
16894
+ backgroundColor: '#000',
16895
+ height: 45,
16896
+ color: '#fff',
16897
+ fontSize: 12,
16898
+ textAlign: 'center',
16899
+ marginTop: 5,
16900
+ marginBottom: 5
16901
+ }
16902
+ }
16903
+ },
16904
+ style: {
16905
+ backgroundColor: '#fff',
16906
+ padding: 18
16907
+ }
16908
+ },
16909
+ sort: 2
16910
+ });
16911
+
16912
+ /*
16913
+ * @Author: binruan@chatlabs.com
16914
+ * @Date: 2023-07-28 18:29:57
16915
+ * @LastEditors: binruan@chatlabs.com
16916
+ * @LastEditTime: 2025-01-15 17:39:28
16917
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16918
+ *
16919
+ */
16920
+ var settingRender$1 = [
16921
+ {
16922
+ title: '全局设置',
16923
+ child: [
16924
+ {
16925
+ type: 'Switch',
16926
+ label: '弹窗开关',
16927
+ name: ['props', 'open']
16928
+ },
16929
+ {
16930
+ type: 'Color',
16931
+ label: '背景色',
16932
+ name: ['style', 'backgroundColor']
16933
+ },
16934
+ {
16935
+ type: 'Number',
16936
+ label: '内边距',
16937
+ name: ['style', 'padding'],
16938
+ addonAfter: 'px'
16939
+ }
16940
+ ]
16941
+ },
16942
+ {
16943
+ title: '弹窗文本',
16944
+ child: [
16945
+ {
16946
+ type: 'RichText',
16947
+ name: ['props', 'content']
16948
+ }
16949
+ ]
16950
+ },
16951
+ {
16952
+ title: '滑动图标',
16953
+ child: [
16954
+ {
16955
+ type: 'Upload',
16956
+ label: '滑动图标',
16957
+ name: ['props', 'swipeIcon'],
16958
+ text: '建议尺寸:252 * 185'
16959
+ }
16960
+ ]
16961
+ }
16962
+ ];
16963
+
16964
+ var img$2 = "";
16965
+
16966
+ const closeIcon = '';
16967
+ const Swipe$1 = (_a) => {
16968
+ var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
16969
+ const touchInfo = React.useRef();
16970
+ const handleTouchStart = (event) => {
16971
+ const touch = event.touches[0];
16972
+ touchInfo.current = { y: touch.clientY, d: 0 };
16973
+ };
16974
+ const handleTouchMove = (event) => {
16975
+ var _a;
16976
+ if (!touchInfo.current)
16977
+ return;
16978
+ const touch = event.touches[0];
16979
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
16980
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
16981
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
16982
+ };
16983
+ const handleTouchEnd = () => {
16984
+ if (!touchInfo.current)
16985
+ return;
16986
+ touchInfo.current || {};
16987
+ touchInfo.current = {};
16988
+ };
16989
+ const handleClickReject = () => { };
16990
+ const visivle = React.useMemo(() => {
16991
+ return consentPopupCate || (open && style);
16992
+ }, [consentPopupCate, open]);
16993
+ 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 },
16994
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
16995
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16996
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
16997
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
16998
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
16999
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17000
+ };
17001
+ var SwipeComponent = React.memo(Swipe$1);
17002
+
17003
+ /*
17004
+ * @Author: binruan@chatlabs.com
17005
+ * @Date: 2025-01-14 16:22:35
17006
+ * @LastEditors: binruan@chatlabs.com
17007
+ * @LastEditTime: 2025-01-15 17:09:49
17008
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17009
+ *
17010
+ */
17011
+ const Swipe = createMaterial(SwipeComponent, {
17012
+ displayName: 'Swipe Consent',
17013
+ icon: '',
17014
+ category: 'consentPopup',
17015
+ type: 'Swipe',
17016
+ related: {
17017
+ settingRender: settingRender$1,
17018
+ bindableProps: []
17019
+ },
17020
+ defaulSetting: {
17021
+ props: {
17022
+ 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>'
17023
+ },
17024
+ style: {
17025
+ backgroundColor: '#fff',
17026
+ padding: 18
17027
+ }
17028
+ },
17029
+ sort: 3
17030
+ });
17031
+
16663
17032
  /*
16664
17033
  * @Author: binruan@chatlabs.com
16665
17034
  * @Date: 2024-06-13 10:08:32
@@ -16961,6 +17330,7 @@ Made in Italy` })));
16961
17330
  AniLinkPopup: AniLinkPopup,
16962
17331
  Appoint: Appoint,
16963
17332
  AppointForm: AppointForm,
17333
+ Click: Click,
16964
17334
  Commodity: Commodity,
16965
17335
  CommodityDetail: CommodityDetail,
16966
17336
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -16977,7 +17347,8 @@ Made in Italy` })));
16977
17347
  MultiCommodityDiro: MultiCommodityDiro,
16978
17348
  MultiCommodityDiroNew: MultiCommodityDiroNew,
16979
17349
  MultiPosts: MultiPosts,
16980
- Prompt: Prompt
17350
+ Prompt: Prompt,
17351
+ Swipe: Swipe
16981
17352
  });
16982
17353
 
16983
17354
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17847,23 +18218,72 @@ Made in Italy` })));
17847
18218
  };
17848
18219
  var Tagbar$1 = React.memo(Tagbar);
17849
18220
 
18221
+ /*
18222
+ * @Author: binruan@chatlabs.com
18223
+ * @Date: 2023-12-26 10:38:53
18224
+ * @LastEditors: binruan@chatlabs.com
18225
+ * @LastEditTime: 2024-12-11 18:24:31
18226
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18227
+ *
18228
+ */
18229
+ const EditorDataContext = React.createContext({});
18230
+ const EditorDataProvider = ({ children, data }) => {
18231
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18232
+ const [openHashtag, setOpenHashtag] = React.useState(false);
18233
+ const [openConsent, setOpenConsent] = React.useState(false);
18234
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
18235
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18236
+ return (React.createElement(EditorDataContext.Provider, { value: {
18237
+ sxpPrameter: {
18238
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18239
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18240
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18241
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18242
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18243
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18244
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18245
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18246
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18247
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18248
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18249
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18250
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18251
+ },
18252
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18253
+ openHashtag,
18254
+ setOpenHashtag,
18255
+ openConsent,
18256
+ setOpenConsent,
18257
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18258
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18259
+ consentPopupCate,
18260
+ setConsentPopupCate,
18261
+ openMultiPosts,
18262
+ setOpenMultiPosts,
18263
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18264
+ } }, children));
18265
+ };
18266
+ function useEditorDataProvider() {
18267
+ return React.useContext(EditorDataContext);
18268
+ }
18269
+
17850
18270
  /*
17851
18271
  * @Author: binruan@chatlabs.com
17852
18272
  * @Date: 2023-12-26 16:11:34
17853
18273
  * @LastEditors: binruan@chatlabs.com
17854
- * @LastEditTime: 2024-11-05 16:29:47
18274
+ * @LastEditTime: 2025-01-14 18:02:44
17855
18275
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17856
18276
  *
17857
18277
  */
17858
18278
  const Consent = ({ resolver, globalConfig }) => {
17859
18279
  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);
18280
+ const { consentPopupCate } = useEditorDataProvider();
17865
18281
  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 }));
18282
+ if (!value)
18283
+ return null;
18284
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18285
+ const Component = withBindDataSource(t);
18286
+ 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
18287
  };
17868
18288
  var ConsentPopup = React.memo(Consent);
17869
18289
 
@@ -17886,7 +18306,7 @@ Made in Italy` })));
17886
18306
  * @Author: binruan@chatlabs.com
17887
18307
  * @Date: 2024-03-20 10:27:31
17888
18308
  * @LastEditors: binruan@chatlabs.com
17889
- * @LastEditTime: 2024-12-18 10:24:20
18309
+ * @LastEditTime: 2025-01-20 18:46:32
17890
18310
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17891
18311
  *
17892
18312
  */
@@ -17981,7 +18401,7 @@ Made in Italy` })));
17981
18401
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
17982
18402
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
17983
18403
  position: activeIndex + '',
17984
- fromKName: fk ? fk : fromKName,
18404
+ fromKName: fk || fromKName,
17985
18405
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
17986
18406
  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
18407
  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 +18431,12 @@ Made in Italy` })));
18011
18431
  skipLinkRef.current = false;
18012
18432
  }
18013
18433
  // 页面可见时触发,注意页面初始化时不会触发
18434
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18014
18435
  handleH5EnterLink();
18015
18436
  if (repCond) {
18016
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18437
+ setTimeout(() => {
18438
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18439
+ });
18017
18440
  backMainFeed('external', selectTag);
18018
18441
  }
18019
18442
  }
@@ -18853,7 +19276,7 @@ Made in Italy` })));
18853
19276
  * @Author: binruan@chatlabs.com
18854
19277
  * @Date: 2023-10-31 10:56:01
18855
19278
  * @LastEditors: binruan@chatlabs.com
18856
- * @LastEditTime: 2024-12-12 14:48:31
19279
+ * @LastEditTime: 2024-10-23 15:07:29
18857
19280
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Popup\index.tsx
18858
19281
  *
18859
19282
  */