pb-sxp-ui 1.14.1 → 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/index.cjs CHANGED
@@ -677,12 +677,15 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
677
677
  const bffDataSource = React.useMemo(() => {
678
678
  return dataSources === null || dataSources === void 0 ? void 0 : dataSources.find((d) => d.type === DataSourceType.BFF);
679
679
  }, [dataSources]);
680
+ const fakeUserId = React.useMemo(() => {
681
+ var _a;
682
+ return ((_a = bffDataSource === null || bffDataSource === void 0 ? void 0 : bffDataSource.headers) === null || _a === void 0 ? void 0 : _a['x-app-id']) + storeAndLoadFeUserId();
683
+ }, [bffDataSource]);
680
684
  // bff API 请求方法
681
685
  const bffFetch = React.useCallback((path, options) => {
682
686
  if (!bffDataSource)
683
687
  return;
684
688
  const url = bffDataSource.url;
685
- const fakeUserId = storeAndLoadFeUserId();
686
689
  if (options === null || options === void 0 ? void 0 : options.query) {
687
690
  const queryString = qs.stringify(options.query);
688
691
  path = `${path}?${queryString}`;
@@ -690,19 +693,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
690
693
  // 事件上报优化
691
694
  // Beacon API 用于发送异步和非阻塞请求到服务器。这类请求不需要响应。
692
695
  if (options.type === 'beacon' && navigator.sendBeacon) {
693
- return navigator.sendBeacon(`${url}/api/v1${path}`, new Blob([
696
+ return navigator.sendBeacon(`${url}/api/${path}`, new Blob([
694
697
  JSON.stringify(Object.assign(Object.assign(Object.assign({}, options.body), bffDataSource.headers), { 'x-user-id': fakeUserId }))
695
698
  ], { type: 'application/json;charset=UTF-8' }));
696
699
  }
697
700
  return window
698
- .fetch(`${url}/api/v1${path}`, {
701
+ .fetch(`${url}/api/${path}`, {
699
702
  headers: Object.assign({ 'Content-Type': 'application/json', 'x-user-id': fakeUserId }, bffDataSource.headers),
700
703
  method: options.method,
701
704
  body: JSON.stringify(options.body)
702
705
  })
703
706
  .then((res) => res.json())
704
707
  .catch((err) => Promise.reject(err));
705
- }, [bffDataSource]);
708
+ }, [bffDataSource, fakeUserId]);
706
709
  // 获取推荐视频数据
707
710
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
708
711
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
@@ -740,7 +743,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
740
743
  const recurveRecList = (query) => __awaiter(void 0, void 0, void 0, function* () {
741
744
  var _v, _w, _x, _y, _z, _0;
742
745
  query.pageNum = pageNum;
743
- result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
746
+ result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
744
747
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
745
748
  return undefined;
746
749
  }
@@ -762,7 +765,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
762
765
  if (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) {
763
766
  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 });
764
767
  }
765
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'POST', body: query }));
768
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/list', { method: 'POST', body: query }));
766
769
  if (!(result === null || result === void 0 ? void 0 : result.success)) {
767
770
  return undefined;
768
771
  }
@@ -812,6 +815,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
812
815
  return expire;
813
816
  }, [data]);
814
817
  const bffEventReport = React.useCallback(({ userInfo, eventInfo, reportLayId = true }) => {
818
+ var _a;
815
819
  // 关闭 BFF 事件上报
816
820
  if (!enableReportEvent || (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview)) {
817
821
  return;
@@ -833,14 +837,23 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
833
837
  console.log('userInfo:', userInfo);
834
838
  console.log('eventInfo:', ef);
835
839
  console.log('========= 结束 =========');
836
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/event/report', {
840
+ 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}`, {
837
841
  method: 'POST',
838
842
  body: { userInfo: realUserInfo, eventInfo: realEventInfo },
839
843
  type: 'beacon'
840
844
  });
841
- }, [bffFetch, curReqInfo, enableReportEvent, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, layoutVariantId, globalConfig, playbookType]);
845
+ }, [
846
+ bffFetch,
847
+ curReqInfo,
848
+ enableReportEvent,
849
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
850
+ layoutVariantId,
851
+ globalConfig,
852
+ playbookType,
853
+ bffDataSource
854
+ ]);
842
855
  const bffFbReport = React.useCallback(({ eventName, product }) => {
843
- var _a, _b, _c, _d, _e;
856
+ var _a, _b, _c, _d, _e, _f;
844
857
  if (!enableReportEvent ||
845
858
  !enabledMetaConversionApi ||
846
859
  (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview) ||
@@ -852,7 +865,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
852
865
  const fbclid = urlParams === null || urlParams === void 0 ? void 0 : urlParams.get('fbclid');
853
866
  const fix_par = {
854
867
  event_source_url: (_c = window === null || window === void 0 ? void 0 : window.location) === null || _c === void 0 ? void 0 : _c.href,
855
- external_id: storeAndLoadFeUserId(),
868
+ external_id: fakeUserId,
856
869
  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 : '',
857
870
  fbc: fbclid ? `fb.2.${new Date().getTime()}.${fbclid}` : '',
858
871
  fbp: getCookie('_fbp') ? `fb.2.${new Date().getTime()}.${getCookie('_fbp')}` : '',
@@ -904,22 +917,30 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
904
917
  }
905
918
  };
906
919
  getEventParams(jsonParams);
907
- return bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/fb/events', {
920
+ 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}`, {
908
921
  method: 'POST',
909
922
  body: jsonParams,
910
923
  type: 'beacon'
911
924
  });
912
- }, [bffFetch, enableReportEvent, enabledMetaConversionApi, globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview, globalConfig]);
925
+ }, [
926
+ bffFetch,
927
+ enableReportEvent,
928
+ enabledMetaConversionApi,
929
+ globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.enablePreview,
930
+ globalConfig,
931
+ fakeUserId,
932
+ bffDataSource
933
+ ]);
913
934
  const bffMutateLike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
914
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/like', { method: 'POST', body }));
935
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/like', { method: 'POST', body }));
915
936
  return res === null || res === void 0 ? void 0 : res.success;
916
937
  }), [bffFetch]);
917
938
  const bffMutateUnlike = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
918
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/unlike', { method: 'POST', body }));
939
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/recommend/unlike', { method: 'POST', body }));
919
940
  return res === null || res === void 0 ? void 0 : res.success;
920
941
  }), [bffFetch]);
921
942
  const bffSubmitForm = React.useCallback((body) => __awaiter(void 0, void 0, void 0, function* () {
922
- const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/customform', { method: 'POST', body }));
943
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/customform', { method: 'POST', body }));
923
944
  return res === null || res === void 0 ? void 0 : res.success;
924
945
  }), [bffFetch]);
925
946
  // 获取 Tag
@@ -934,7 +955,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
934
955
  const key = val.split('=')[0];
935
956
  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);
936
957
  })) === null || _9 === void 0 ? void 0 : _9.join('&')) !== null && _10 !== void 0 ? _10 : '';
937
- const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
958
+ const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
938
959
  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 : []);
939
960
  }
940
961
  catch (e) {
@@ -1008,10 +1029,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1008
1029
  let curData;
1009
1030
  let gldata;
1010
1031
  if (data === null || data === void 0 ? void 0 : data.layoutVariantId) {
1032
+ layId = data === null || data === void 0 ? void 0 : data.layoutVariantId;
1033
+ setLayoutVariantId(data === null || data === void 0 ? void 0 : data.layoutVariantId);
1011
1034
  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];
1012
1035
  if (id) {
1013
- layId = id;
1014
- setLayoutVariantId(id);
1015
1036
  curData = dataList === null || dataList === void 0 ? void 0 : dataList.find((item) => (item === null || item === void 0 ? void 0 : item.id) === id);
1016
1037
  if (curData) {
1017
1038
  setPageData(curData);
@@ -1397,7 +1418,7 @@ var interactionRender$g = [
1397
1418
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1398
1419
  *
1399
1420
  */
1400
- var settingRender$d = [
1421
+ var settingRender$f = [
1401
1422
  {
1402
1423
  title: '弹窗背景',
1403
1424
  child: [
@@ -1833,7 +1854,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1833
1854
  category: 'popup',
1834
1855
  type: 'AppointForm',
1835
1856
  related: {
1836
- settingRender: settingRender$d,
1857
+ settingRender: settingRender$f,
1837
1858
  bindableProps: [],
1838
1859
  interactionRender: interactionRender$g
1839
1860
  },
@@ -1858,7 +1879,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
1858
1879
  sort: 2
1859
1880
  });
1860
1881
 
1861
- var settingRender$c = [
1882
+ var settingRender$e = [
1862
1883
  {
1863
1884
  title: '弹窗背景',
1864
1885
  child: [
@@ -9747,7 +9768,7 @@ SwiperSlide.displayName = 'SwiperSlide';
9747
9768
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9748
9769
  *
9749
9770
  */
9750
- const closeIcon$1 = '';
9771
+ const closeIcon$2 = '';
9751
9772
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9752
9773
  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;
9753
9774
  const touchRef = React.useRef(null);
@@ -9927,7 +9948,7 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema,
9927
9948
  }
9928
9949
  })), child()),
9929
9950
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9930
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9951
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9931
9952
  };
9932
9953
  var Modal$1 = React.memo(Modal);
9933
9954
 
@@ -10098,7 +10119,7 @@ var CommodityGroup$1 = React.memo(CommodityGroup);
10098
10119
  * @Author: binruan@chatlabs.com
10099
10120
  * @Date: 2024-03-20 14:56:16
10100
10121
  * @LastEditors: binruan@chatlabs.com
10101
- * @LastEditTime: 2024-10-24 17:51:19
10122
+ * @LastEditTime: 2024-12-20 14:32:26
10102
10123
  * @FilePath: \pb-sxp-ui\src\core\utils\materials.ts
10103
10124
  *
10104
10125
  */
@@ -10136,14 +10157,16 @@ const getBgStyle = (imgSrc) => {
10136
10157
  };
10137
10158
  const getPriceText = ({ product, enableFormattedPrice, globalConfig, isHiddenDef, style }) => {
10138
10159
  var _a, _b, _c, _d, _e, _f, _g, _h;
10160
+ let text = '';
10139
10161
  if ((!(product === null || product === void 0 ? void 0 : product.currency) || !(product === null || product === void 0 ? void 0 : product.price)) && isHiddenDef)
10140
10162
  return null;
10141
- 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;
10142
- let text = '';
10163
+ 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);
10164
+ if (typeof price !== 'number')
10165
+ return text;
10143
10166
  let priceSymbol = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.priceSymbol;
10144
10167
  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 : '' : '$';
10145
10168
  const isToLocStr = enableFormattedPrice === undefined || enableFormattedPrice;
10146
- let decPic = price.toString();
10169
+ let decPic = price === null || price === void 0 ? void 0 : price.toString();
10147
10170
  if (priceSymbol === null || priceSymbol === void 0 ? void 0 : priceSymbol.showTwoDecimalPoint) {
10148
10171
  decPic = price === null || price === void 0 ? void 0 : price.toFixed(2);
10149
10172
  }
@@ -10455,7 +10478,7 @@ const CommodityDetail = createMaterial(CommodityDetailComponent, {
10455
10478
  category: 'popup',
10456
10479
  type: 'CommodityDetail',
10457
10480
  related: {
10458
- settingRender: settingRender$c,
10481
+ settingRender: settingRender$e,
10459
10482
  interactionRender: interactionRender$f
10460
10483
  },
10461
10484
  defaulSetting: {
@@ -10531,7 +10554,7 @@ var interactionRender$e = [
10531
10554
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
10532
10555
  *
10533
10556
  */
10534
- var settingRender$b = [
10557
+ var settingRender$d = [
10535
10558
  {
10536
10559
  title: '弹窗背景',
10537
10560
  child: [
@@ -10672,7 +10695,7 @@ var settingRender$b = [
10672
10695
  }
10673
10696
  ];
10674
10697
 
10675
- var img$5 = "";
10698
+ var img$7 = "";
10676
10699
 
10677
10700
  const Prompt$1 = (_a) => {
10678
10701
  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"]);
@@ -10695,7 +10718,7 @@ const Prompt$1 = (_a) => {
10695
10718
  };
10696
10719
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
10697
10720
  React.createElement("div", { className: 'pb-prompt-icon' },
10698
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$5, alt: 'success image' })),
10721
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$7, alt: 'success image' })),
10699
10722
  React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
10700
10723
  __html: setFontForText(content, contentStyle)
10701
10724
  } }),
@@ -10711,13 +10734,13 @@ const Prompt = createMaterial(PromptComponent, {
10711
10734
  category: 'popup',
10712
10735
  type: 'Prompt',
10713
10736
  related: {
10714
- settingRender: settingRender$b,
10737
+ settingRender: settingRender$d,
10715
10738
  bindableProps: [],
10716
10739
  interactionRender: interactionRender$e
10717
10740
  },
10718
10741
  defaulSetting: {
10719
10742
  props: {
10720
- icon: img$5,
10743
+ icon: img$7,
10721
10744
  content: 'You have successfully completed the appointment!',
10722
10745
  btnText: 'OK'
10723
10746
  },
@@ -10736,7 +10759,7 @@ const Prompt = createMaterial(PromptComponent, {
10736
10759
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
10737
10760
  *
10738
10761
  */
10739
- var settingRender$a = [
10762
+ var settingRender$c = [
10740
10763
  {
10741
10764
  title: '弹窗背景',
10742
10765
  child: [
@@ -11415,7 +11438,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11415
11438
  category: 'popup',
11416
11439
  type: 'CommodityDetailDiroNew',
11417
11440
  related: {
11418
- settingRender: settingRender$a,
11441
+ settingRender: settingRender$c,
11419
11442
  interactionRender: interactionRender$d
11420
11443
  },
11421
11444
  defaulSetting: {
@@ -11479,7 +11502,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
11479
11502
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityList\settingRender.tsx
11480
11503
  *
11481
11504
  */
11482
- var settingRender$9 = [
11505
+ var settingRender$b = [
11483
11506
  {
11484
11507
  title: '弹窗背景',
11485
11508
  child: [
@@ -11916,7 +11939,7 @@ const CommodityList = createMaterial(CommodityListComponent, {
11916
11939
  category: 'popup',
11917
11940
  type: 'CommodityList',
11918
11941
  related: {
11919
- settingRender: settingRender$9,
11942
+ settingRender: settingRender$b,
11920
11943
  interactionRender: interactionRender$c
11921
11944
  },
11922
11945
  defaulSetting: {
@@ -11961,11 +11984,11 @@ const CommodityList = createMaterial(CommodityListComponent, {
11961
11984
  * @Author: binruan@chatlabs.com
11962
11985
  * @Date: 2023-10-27 14:06:35
11963
11986
  * @LastEditors: binruan@chatlabs.com
11964
- * @LastEditTime: 2024-12-12 15:12:57
11987
+ * @LastEditTime: 2024-08-08 17:32:11
11965
11988
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Iframe\settingRender.tsx
11966
11989
  *
11967
11990
  */
11968
- var settingRender$8 = [
11991
+ var settingRender$a = [
11969
11992
  {
11970
11993
  title: '背景样式',
11971
11994
  child: [
@@ -11975,32 +11998,16 @@ var settingRender$8 = [
11975
11998
  name: ['style', 'backgroundColor']
11976
11999
  }
11977
12000
  ]
11978
- },
11979
- {
11980
- title: 'iframe',
11981
- child: [
11982
- {
11983
- type: 'TextArea',
11984
- label: 'url',
11985
- name: ['props', 'iframe', 'src']
11986
- },
11987
- {
11988
- type: 'TextArea',
11989
- label: 'allow',
11990
- name: ['props', 'iframe', 'allow']
11991
- }
11992
- ]
11993
12001
  }
11994
12002
  ];
11995
12003
 
11996
12004
  const Iframe$1 = (_a) => {
11997
12005
  var _b, _c;
11998
- 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"]);
12006
+ 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"]);
11999
12007
  const { popupDetailData } = useSxpDataSource();
12000
- const { src, allow } = iframe || {};
12001
- 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);
12002
- return (React.createElement("div", Object.assign({ className: `${css.css(Object.assign(Object.assign({}, style), { overflow: 'hidden' }))}` }, props),
12003
- React.createElement("iframe", { src: iframeUrl, allow: allow, scrolling: 'no', style: {
12008
+ 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;
12009
+ return (React.createElement("div", Object.assign({ className: `${css.css(Object.assign({}, style))}` }, props),
12010
+ React.createElement("iframe", { src: iframeUrl, style: {
12004
12011
  width: '100%',
12005
12012
  height: 'calc(100% - 50px)',
12006
12013
  marginTop: '50px',
@@ -12015,7 +12022,7 @@ const Iframe = createMaterial(IframeComponent, {
12015
12022
  category: 'popup',
12016
12023
  type: 'Iframe',
12017
12024
  related: {
12018
- settingRender: settingRender$8,
12025
+ settingRender: settingRender$a,
12019
12026
  bindableProps: []
12020
12027
  },
12021
12028
  defaulSetting: {
@@ -12035,7 +12042,7 @@ const Iframe = createMaterial(IframeComponent, {
12035
12042
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\ConsentDetail\settingRender.tsx
12036
12043
  *
12037
12044
  */
12038
- var settingRender$7 = [
12045
+ var settingRender$9 = [
12039
12046
  {
12040
12047
  title: '弹窗文本',
12041
12048
  child: [
@@ -12048,22 +12055,22 @@ var settingRender$7 = [
12048
12055
  ];
12049
12056
 
12050
12057
  const ConsentDetail$1 = (_a) => {
12051
- var { content, isTel } = _a; __rest(_a, ["content", "isTel"]);
12058
+ var { content, isTel, style } = _a; __rest(_a, ["content", "isTel", "style"]);
12052
12059
  return (React.createElement("article", { className: 'consentDetail-article', dangerouslySetInnerHTML: {
12053
12060
  __html: typeof content === 'string' ? content : ''
12054
12061
  }, onClick: (e) => {
12055
12062
  e.stopPropagation();
12056
- } }));
12063
+ }, style: style }));
12057
12064
  };
12058
- var ConsentDetailComponent = React.memo(ConsentDetail$1);
12065
+ var ConsentDetail$2 = React.memo(ConsentDetail$1);
12059
12066
 
12060
- const ConsentDetail = createMaterial(ConsentDetailComponent, {
12067
+ const ConsentDetail = createMaterial(ConsentDetail$2, {
12061
12068
  displayName: '协议详情',
12062
12069
  icon: '',
12063
12070
  category: 'popup',
12064
12071
  type: 'ConsentDetail',
12065
12072
  related: {
12066
- settingRender: settingRender$7,
12073
+ settingRender: settingRender$9,
12067
12074
  bindableProps: []
12068
12075
  },
12069
12076
  defaulSetting: {
@@ -12083,7 +12090,7 @@ const ConsentDetail = createMaterial(ConsentDetailComponent, {
12083
12090
  * @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
12084
12091
  *
12085
12092
  */
12086
- var settingRender$6 = [
12093
+ var settingRender$8 = [
12087
12094
  {
12088
12095
  title: '主题样式',
12089
12096
  child: [
@@ -12437,7 +12444,7 @@ const Commodity = createMaterial(CommodityComponent, {
12437
12444
  related: {
12438
12445
  interactionRender: interactionRender$b,
12439
12446
  bindableProps: [],
12440
- settingRender: settingRender$6
12447
+ settingRender: settingRender$8
12441
12448
  },
12442
12449
  defaulSetting: {
12443
12450
  props: {
@@ -12519,7 +12526,7 @@ const Appoint = createMaterial(AppointComponent, {
12519
12526
  type: 'Appoint',
12520
12527
  related: {
12521
12528
  interactionRender: interactionRender$a,
12522
- settingRender: settingRender$6 === null || settingRender$6 === void 0 ? void 0 : settingRender$6.filter((i) => i.type !== 'commodityTitle'),
12529
+ settingRender: settingRender$8 === null || settingRender$8 === void 0 ? void 0 : settingRender$8.filter((i) => i.type !== 'commodityTitle'),
12523
12530
  bindableProps: []
12524
12531
  },
12525
12532
  defaulSetting: {
@@ -12725,7 +12732,7 @@ const Link = createMaterial(LinkComponent, {
12725
12732
  category: 'template',
12726
12733
  type: 'Link',
12727
12734
  related: {
12728
- 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),
12735
+ 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),
12729
12736
  bindableProps: [],
12730
12737
  interactionRender: interactionRender$9
12731
12738
  },
@@ -12828,7 +12835,7 @@ const CommodityDiro = createMaterial(CommodityDiroComponent, {
12828
12835
  type: 'CommodityDiro',
12829
12836
  related: {
12830
12837
  interactionRender: interactionRender$8,
12831
- settingRender: settingRender$6,
12838
+ settingRender: settingRender$8,
12832
12839
  bindableProps: []
12833
12840
  },
12834
12841
  defaulSetting: {
@@ -12925,7 +12932,7 @@ const CommodityDiroNew = createMaterial(CommodityDiroNewComponent, {
12925
12932
  related: {
12926
12933
  interactionRender: interactionRender$7,
12927
12934
  bindableProps: [],
12928
- settingRender: settingRender$6
12935
+ settingRender: settingRender$8
12929
12936
  },
12930
12937
  defaulSetting: {
12931
12938
  props: {
@@ -13025,7 +13032,7 @@ const MultiCommodityDiro = createMaterial(MultiCommodityDiroComponent, {
13025
13032
  related: {
13026
13033
  interactionRender: interactionRender$6,
13027
13034
  bindableProps: [],
13028
- settingRender: settingRender$6
13035
+ settingRender: settingRender$8
13029
13036
  },
13030
13037
  defaulSetting: {
13031
13038
  props: {
@@ -13123,7 +13130,7 @@ const MultiCommodity = createMaterial(MultiCommodityComponent, {
13123
13130
  type: 'MultiCommodity',
13124
13131
  related: {
13125
13132
  interactionRender: interactionRender$5,
13126
- settingRender: settingRender$6,
13133
+ settingRender: settingRender$8,
13127
13134
  bindableProps: []
13128
13135
  },
13129
13136
  defaulSetting: {
@@ -13232,7 +13239,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13232
13239
  related: {
13233
13240
  interactionRender: interactionRender$4,
13234
13241
  bindableProps: [],
13235
- settingRender: settingRender$6
13242
+ settingRender: settingRender$8
13236
13243
  },
13237
13244
  defaulSetting: {
13238
13245
  props: {
@@ -13281,7 +13288,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
13281
13288
  * @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
13282
13289
  *
13283
13290
  */
13284
- var settingRender$5 = [
13291
+ var settingRender$7 = [
13285
13292
  {
13286
13293
  title: 'Banner',
13287
13294
  child: [
@@ -15109,7 +15116,7 @@ function WaterfallList$1(_a) {
15109
15116
  } }))))));
15110
15117
  }
15111
15118
 
15112
- var img$4 = "";
15119
+ var img$6 = "";
15113
15120
 
15114
15121
  const WaterfallFlowItem = (props) => {
15115
15122
  var _a;
@@ -15430,7 +15437,7 @@ const WaterFall = (props) => {
15430
15437
  return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'waterfall', style: {
15431
15438
  display: openHashtag ? 'block' : 'none'
15432
15439
  } },
15433
- 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 }),
15440
+ 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 }),
15434
15441
  (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);
15435
15442
  };
15436
15443
  var WaterFall$1 = React.memo(WaterFall);
@@ -15462,7 +15469,7 @@ const HashTag = createMaterial(HashTagComponent, {
15462
15469
  category: 'base',
15463
15470
  type: 'HashTag',
15464
15471
  related: {
15465
- settingRender: settingRender$5,
15472
+ settingRender: settingRender$7,
15466
15473
  bindableProps: []
15467
15474
  },
15468
15475
  defaulSetting: {
@@ -15527,7 +15534,7 @@ const HashTag = createMaterial(HashTagComponent, {
15527
15534
  * @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
15528
15535
  *
15529
15536
  */
15530
- var settingRender$4 = [
15537
+ var settingRender$6 = [
15531
15538
  {
15532
15539
  title: '协议详情',
15533
15540
  child: [
@@ -15586,7 +15593,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15586
15593
  category: 'base',
15587
15594
  type: 'Consent',
15588
15595
  related: {
15589
- settingRender: settingRender$4
15596
+ settingRender: settingRender$6
15590
15597
  },
15591
15598
  defaulSetting: {
15592
15599
  props: {},
@@ -15605,7 +15612,7 @@ const Consent$1 = createMaterial(ConsentComponent, {
15605
15612
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLink\settingRender.tsx
15606
15613
  *
15607
15614
  */
15608
- var settingRender$3 = [
15615
+ var settingRender$5 = [
15609
15616
  {
15610
15617
  title: '主题样式',
15611
15618
  child: [
@@ -15866,7 +15873,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15866
15873
  category: 'cta',
15867
15874
  type: 'AniLink',
15868
15875
  related: {
15869
- settingRender: settingRender$3,
15876
+ settingRender: settingRender$5,
15870
15877
  bindableProps: [],
15871
15878
  interactionRender: interactionRender$3
15872
15879
  },
@@ -15910,7 +15917,7 @@ const AniLink = createMaterial(AniLinkComponent, {
15910
15917
  * @FilePath: \pb-sxp-ui\src\materials\sxp\cta\AniLinkPopup\settingRender.tsx
15911
15918
  *
15912
15919
  */
15913
- var settingRender$2 = [
15920
+ var settingRender$4 = [
15914
15921
  {
15915
15922
  title: '主题样式',
15916
15923
  child: [
@@ -16168,7 +16175,7 @@ var settingRender$2 = [
16168
16175
 
16169
16176
  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"};
16170
16177
 
16171
- const closeIcon = '';
16178
+ const closeIcon$1 = '';
16172
16179
  const AniLinkPopup$1 = (_a) => {
16173
16180
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16174
16181
  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"]);
@@ -16227,7 +16234,7 @@ const AniLinkPopup$1 = (_a) => {
16227
16234
  paddingLeft: '6px'
16228
16235
  } }, "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 }),
16229
16236
  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 } },
16230
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16237
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16231
16238
  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 }),
16232
16239
  (!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: {
16233
16240
  __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)
@@ -16314,7 +16321,7 @@ const AniLinkPopup = createMaterial(AniLinkPopupComponent, {
16314
16321
  category: 'cta',
16315
16322
  type: 'AniLinkPopup',
16316
16323
  related: {
16317
- settingRender: settingRender$2,
16324
+ settingRender: settingRender$4,
16318
16325
  bindableProps: [],
16319
16326
  interactionRender: interactionRender$2
16320
16327
  },
@@ -16393,7 +16400,7 @@ var interactionRender$1 = [
16393
16400
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Display\settingRender.tsx
16394
16401
  *
16395
16402
  */
16396
- var settingRender$1 = [
16403
+ var settingRender$3 = [
16397
16404
  {
16398
16405
  title: '全局设置',
16399
16406
  child: [
@@ -16534,74 +16541,27 @@ var settingRender$1 = [
16534
16541
  }
16535
16542
  ];
16536
16543
 
16537
- /*
16538
- * @Author: binruan@chatlabs.com
16539
- * @Date: 2023-12-26 10:38:53
16540
- * @LastEditors: binruan@chatlabs.com
16541
- * @LastEditTime: 2024-12-11 18:24:31
16542
- * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
16543
- *
16544
- */
16545
- const EditorDataContext = React.createContext({});
16546
- const EditorDataProvider = ({ children, data }) => {
16547
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
16548
- const [openHashtag, setOpenHashtag] = React.useState(false);
16549
- const [openConsent, setOpenConsent] = React.useState(false);
16550
- const [consentPopupCate, setConsentPopupCate] = React.useState('');
16551
- const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
16552
- return (React.createElement(EditorDataContext.Provider, { value: {
16553
- sxpPrameter: {
16554
- bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
16555
- defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
16556
- personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
16557
- placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
16558
- hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
16559
- loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
16560
- privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
16561
- privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
16562
- privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
16563
- privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
16564
- privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
16565
- template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
16566
- industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
16567
- },
16568
- appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
16569
- openHashtag,
16570
- setOpenHashtag,
16571
- openConsent,
16572
- setOpenConsent,
16573
- sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
16574
- utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
16575
- consentPopupCate,
16576
- setConsentPopupCate,
16577
- openMultiPosts,
16578
- setOpenMultiPosts,
16579
- pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
16580
- } }, children));
16581
- };
16582
- function useEditorDataProvider() {
16583
- return React.useContext(EditorDataContext);
16584
- }
16585
-
16586
- 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";
16544
+ 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";
16587
16545
 
16588
- var img$2 = "";
16546
+ var img$4 = "";
16589
16547
 
16590
16548
  const Display$1 = (_a) => {
16591
16549
  var _b, _c;
16592
- var { isTel, isShowOnce, open, content, interaction, style, onClick, contsentState, isShowClose } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "contsentState", "isShowClose"]);
16593
- const { consentPopupCate } = useEditorDataProvider();
16550
+ var { isTel, isShowOnce, open, content, interaction, style, onClick, isShowClose, consentPopupCate } = _a; __rest(_a, ["isTel", "isShowOnce", "open", "content", "interaction", "style", "onClick", "isShowClose", "consentPopupCate"]);
16594
16551
  const [isClose, setIsClose] = React.useState(false);
16552
+ const contsentState = React.useMemo(() => {
16553
+ return getContsentState();
16554
+ }, []);
16595
16555
  const visivle = React.useMemo(() => {
16596
- return consentPopupCate === 'Display' || (open && (isShowOnce || contsentState) && style && !isClose);
16597
- }, [consentPopupCate, open, isClose]);
16556
+ return consentPopupCate || (open && (isShowOnce || contsentState) && style && !isClose);
16557
+ }, [consentPopupCate, open, isClose, contsentState]);
16598
16558
  const handleClickClose = React.useCallback(() => {
16599
16559
  setIsClose(true);
16600
16560
  }, []);
16601
16561
  const handleClick = React.useCallback(() => {
16602
16562
  onClick === null || onClick === void 0 ? void 0 : onClick();
16603
16563
  }, []);
16604
- 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 },
16564
+ 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 },
16605
16565
  React.createElement("div", { style: { flex: 1 } },
16606
16566
  React.createElement("span", { style: content === null || content === void 0 ? void 0 : content.style, dangerouslySetInnerHTML: {
16607
16567
  __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)
@@ -16610,7 +16570,7 @@ const Display$1 = (_a) => {
16610
16570
  __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)
16611
16571
  }, onClick: handleClick })),
16612
16572
  isShowClose && (React.createElement("button", { "aria-label": 'close', className: 'consentPopupDisplay-close', onClick: handleClickClose },
16613
- React.createElement("img", { src: img$3, alt: 'close' })))))))));
16573
+ React.createElement("img", { src: img$5, alt: 'close' })))))))));
16614
16574
  };
16615
16575
  var DisplayComponent = React.memo(Display$1);
16616
16576
 
@@ -16636,7 +16596,7 @@ const Display = createMaterial(DisplayComponent, {
16636
16596
  category: 'consentPopup',
16637
16597
  type: 'Display',
16638
16598
  related: {
16639
- settingRender: settingRender$1,
16599
+ settingRender: settingRender$3,
16640
16600
  bindableProps: [],
16641
16601
  interactionRender: interactionRender$1
16642
16602
  },
@@ -16667,6 +16627,415 @@ const Display = createMaterial(DisplayComponent, {
16667
16627
  sort: 1
16668
16628
  });
16669
16629
 
16630
+ /*
16631
+ * @Author: binruan@chatlabs.com
16632
+ * @Date: 2023-07-28 18:29:57
16633
+ * @LastEditors: binruan@chatlabs.com
16634
+ * @LastEditTime: 2025-01-15 10:14:40
16635
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16636
+ *
16637
+ */
16638
+ var settingRender$2 = [
16639
+ {
16640
+ title: '全局设置',
16641
+ child: [
16642
+ {
16643
+ type: 'Switch',
16644
+ label: '弹窗开关',
16645
+ name: ['props', 'open']
16646
+ },
16647
+ {
16648
+ type: 'Color',
16649
+ label: '背景色',
16650
+ name: ['style', 'backgroundColor']
16651
+ },
16652
+ {
16653
+ type: 'Number',
16654
+ label: '内边距',
16655
+ name: ['style', 'padding'],
16656
+ addonAfter: 'px'
16657
+ }
16658
+ ]
16659
+ },
16660
+ {
16661
+ title: '弹窗文本',
16662
+ child: [
16663
+ {
16664
+ type: 'RichText',
16665
+ name: ['props', 'content']
16666
+ }
16667
+ ]
16668
+ },
16669
+ {
16670
+ title: '接受按钮样式',
16671
+ child: [
16672
+ {
16673
+ type: 'Color',
16674
+ label: '背景色',
16675
+ name: ['props', 'acceptButton', 'style', 'backgroundColor']
16676
+ },
16677
+ {
16678
+ type: 'Number',
16679
+ label: '尺寸',
16680
+ name: ['props', 'acceptButton', 'style', 'height'],
16681
+ addonAfter: 'H'
16682
+ },
16683
+ {
16684
+ type: 'Group',
16685
+ label: '圆角',
16686
+ child: [
16687
+ {
16688
+ type: 'Slider',
16689
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16690
+ max: 100
16691
+ },
16692
+ {
16693
+ type: 'Number',
16694
+ name: ['props', 'acceptButton', 'style', 'borderRadius'],
16695
+ addonAfter: 'px',
16696
+ max: 100
16697
+ }
16698
+ ]
16699
+ },
16700
+ {
16701
+ type: 'TextMargin',
16702
+ label: '边距',
16703
+ name: ['props', 'acceptButton', 'style']
16704
+ },
16705
+ {
16706
+ type: 'Group',
16707
+ label: '字体',
16708
+ child: [
16709
+ {
16710
+ type: 'Select',
16711
+ name: ['props', 'acceptButton', 'style', 'fontFamily-cn'],
16712
+ bottomText: '中文字体'
16713
+ },
16714
+ {
16715
+ type: 'Select',
16716
+ name: ['props', 'acceptButton', 'style', 'fontFamily-en'],
16717
+ bottomText: '英文/其他字体'
16718
+ }
16719
+ ]
16720
+ },
16721
+ {
16722
+ type: 'Group',
16723
+ label: '',
16724
+ child: [
16725
+ {
16726
+ type: 'Color',
16727
+ name: ['props', 'acceptButton', 'style', 'color']
16728
+ },
16729
+ {
16730
+ type: 'Number',
16731
+ name: ['props', 'acceptButton', 'style', 'fontSize'],
16732
+ addonAfter: 'px'
16733
+ }
16734
+ ]
16735
+ },
16736
+ {
16737
+ label: '样式',
16738
+ type: 'TextStyle',
16739
+ name: ['props', 'acceptButton', 'style']
16740
+ },
16741
+ {
16742
+ label: '对齐',
16743
+ type: 'TextAlign',
16744
+ name: ['props', 'acceptButton', 'style']
16745
+ },
16746
+ {
16747
+ label: '间距',
16748
+ type: 'TextSpace',
16749
+ name: ['props', 'acceptButton', 'style']
16750
+ },
16751
+ {
16752
+ label: '文本',
16753
+ type: 'TextArea',
16754
+ name: ['props', 'acceptButton', 'text']
16755
+ }
16756
+ ]
16757
+ },
16758
+ {
16759
+ title: '拒绝按钮样式',
16760
+ child: [
16761
+ {
16762
+ type: 'Color',
16763
+ label: '背景色',
16764
+ name: ['props', 'rejectButton', 'style', 'backgroundColor']
16765
+ },
16766
+ {
16767
+ type: 'Number',
16768
+ label: '尺寸',
16769
+ name: ['props', 'rejectButton', 'style', 'height'],
16770
+ addonAfter: 'H'
16771
+ },
16772
+ {
16773
+ type: 'Group',
16774
+ label: '圆角',
16775
+ child: [
16776
+ {
16777
+ type: 'Slider',
16778
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16779
+ max: 100
16780
+ },
16781
+ {
16782
+ type: 'Number',
16783
+ name: ['props', 'rejectButton', 'style', 'borderRadius'],
16784
+ addonAfter: 'px',
16785
+ max: 100
16786
+ }
16787
+ ]
16788
+ },
16789
+ {
16790
+ type: 'TextMargin',
16791
+ label: '边距',
16792
+ name: ['props', 'acceptButton', 'style']
16793
+ },
16794
+ {
16795
+ type: 'Group',
16796
+ label: '字体',
16797
+ child: [
16798
+ {
16799
+ type: 'Select',
16800
+ name: ['props', 'rejectButton', 'style', 'fontFamily-cn'],
16801
+ bottomText: '中文字体'
16802
+ },
16803
+ {
16804
+ type: 'Select',
16805
+ name: ['props', 'rejectButton', 'style', 'fontFamily-en'],
16806
+ bottomText: '英文/其他字体'
16807
+ }
16808
+ ]
16809
+ },
16810
+ {
16811
+ type: 'Group',
16812
+ label: '',
16813
+ child: [
16814
+ {
16815
+ type: 'Color',
16816
+ name: ['props', 'rejectButton', 'style', 'color']
16817
+ },
16818
+ {
16819
+ type: 'Number',
16820
+ name: ['props', 'rejectButton', 'style', 'fontSize'],
16821
+ addonAfter: 'px'
16822
+ }
16823
+ ]
16824
+ },
16825
+ {
16826
+ label: '样式',
16827
+ type: 'TextStyle',
16828
+ name: ['props', 'rejectButton', 'style']
16829
+ },
16830
+ {
16831
+ label: '对齐',
16832
+ type: 'TextAlign',
16833
+ name: ['props', 'rejectButton', 'style']
16834
+ },
16835
+ {
16836
+ label: '间距',
16837
+ type: 'TextSpace',
16838
+ name: ['props', 'rejectButton', 'style']
16839
+ },
16840
+ {
16841
+ label: '文本',
16842
+ type: 'TextArea',
16843
+ name: ['props', 'rejectButton', 'text']
16844
+ }
16845
+ ]
16846
+ }
16847
+ ];
16848
+
16849
+ var img$3 = "";
16850
+
16851
+ const Click$1 = (_a) => {
16852
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16853
+ const visivle = React.useMemo(() => {
16854
+ return consentPopupCate || (open && style);
16855
+ }, [consentPopupCate, open]);
16856
+ const handleClickAccept = () => { };
16857
+ const handleClickReject = () => { };
16858
+ 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' },
16859
+ React.createElement("div", { className: 'consentPopupClick-container', style: style },
16860
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16861
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16862
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16863
+ };
16864
+ var ClickComponent = React.memo(Click$1);
16865
+
16866
+ /*
16867
+ * @Author: binruan@chatlabs.com
16868
+ * @Date: 2025-01-14 16:22:35
16869
+ * @LastEditors: binruan@chatlabs.com
16870
+ * @LastEditTime: 2025-01-15 17:09:49
16871
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\material.tsx
16872
+ *
16873
+ */
16874
+ const Click = createMaterial(ClickComponent, {
16875
+ displayName: 'Click Consent',
16876
+ icon: '',
16877
+ category: 'consentPopup',
16878
+ type: 'Click',
16879
+ related: {
16880
+ settingRender: settingRender$2,
16881
+ bindableProps: []
16882
+ },
16883
+ defaulSetting: {
16884
+ props: {
16885
+ 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>',
16886
+ acceptButton: {
16887
+ text: 'Accept all cookies',
16888
+ style: {
16889
+ backgroundColor: '#000',
16890
+ height: 45,
16891
+ color: '#fff',
16892
+ fontSize: 12,
16893
+ textAlign: 'center',
16894
+ marginTop: 5,
16895
+ marginBottom: 5
16896
+ }
16897
+ },
16898
+ rejectButton: {
16899
+ text: 'Reject all cookies',
16900
+ style: {
16901
+ backgroundColor: '#000',
16902
+ height: 45,
16903
+ color: '#fff',
16904
+ fontSize: 12,
16905
+ textAlign: 'center',
16906
+ marginTop: 5,
16907
+ marginBottom: 5
16908
+ }
16909
+ }
16910
+ },
16911
+ style: {
16912
+ backgroundColor: '#fff',
16913
+ padding: 18
16914
+ }
16915
+ },
16916
+ sort: 2
16917
+ });
16918
+
16919
+ /*
16920
+ * @Author: binruan@chatlabs.com
16921
+ * @Date: 2023-07-28 18:29:57
16922
+ * @LastEditors: binruan@chatlabs.com
16923
+ * @LastEditTime: 2025-01-15 17:39:28
16924
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16925
+ *
16926
+ */
16927
+ var settingRender$1 = [
16928
+ {
16929
+ title: '全局设置',
16930
+ child: [
16931
+ {
16932
+ type: 'Switch',
16933
+ label: '弹窗开关',
16934
+ name: ['props', 'open']
16935
+ },
16936
+ {
16937
+ type: 'Color',
16938
+ label: '背景色',
16939
+ name: ['style', 'backgroundColor']
16940
+ },
16941
+ {
16942
+ type: 'Number',
16943
+ label: '内边距',
16944
+ name: ['style', 'padding'],
16945
+ addonAfter: 'px'
16946
+ }
16947
+ ]
16948
+ },
16949
+ {
16950
+ title: '弹窗文本',
16951
+ child: [
16952
+ {
16953
+ type: 'RichText',
16954
+ name: ['props', 'content']
16955
+ }
16956
+ ]
16957
+ },
16958
+ {
16959
+ title: '滑动图标',
16960
+ child: [
16961
+ {
16962
+ type: 'Upload',
16963
+ label: '滑动图标',
16964
+ name: ['props', 'swipeIcon'],
16965
+ text: '建议尺寸:252 * 185'
16966
+ }
16967
+ ]
16968
+ }
16969
+ ];
16970
+
16971
+ var img$2 = "";
16972
+
16973
+ const closeIcon = '';
16974
+ const Swipe$1 = (_a) => {
16975
+ var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
16976
+ const touchInfo = React.useRef();
16977
+ const handleTouchStart = (event) => {
16978
+ const touch = event.touches[0];
16979
+ touchInfo.current = { y: touch.clientY, d: 0 };
16980
+ };
16981
+ const handleTouchMove = (event) => {
16982
+ var _a;
16983
+ if (!touchInfo.current)
16984
+ return;
16985
+ const touch = event.touches[0];
16986
+ const dy = touch.clientY - ((_a = touchInfo === null || touchInfo === void 0 ? void 0 : touchInfo.current) === null || _a === void 0 ? void 0 : _a.y); // 计算Y轴移动距离
16987
+ const currentDistance = Math.abs(dy); // 计算触摸移动的总距离
16988
+ touchInfo.current = Object.assign(Object.assign({}, touchInfo.current), { d: currentDistance });
16989
+ };
16990
+ const handleTouchEnd = () => {
16991
+ if (!touchInfo.current)
16992
+ return;
16993
+ touchInfo.current || {};
16994
+ touchInfo.current = {};
16995
+ };
16996
+ const handleClickReject = () => { };
16997
+ const visivle = React.useMemo(() => {
16998
+ return consentPopupCate || (open && style);
16999
+ }, [consentPopupCate, open]);
17000
+ 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 },
17001
+ React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17002
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17003
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17004
+ React.createElement("img", { src: closeIcon, alt: 'close' })),
17005
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17006
+ React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17007
+ };
17008
+ var SwipeComponent = React.memo(Swipe$1);
17009
+
17010
+ /*
17011
+ * @Author: binruan@chatlabs.com
17012
+ * @Date: 2025-01-14 16:22:35
17013
+ * @LastEditors: binruan@chatlabs.com
17014
+ * @LastEditTime: 2025-01-15 17:09:49
17015
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17016
+ *
17017
+ */
17018
+ const Swipe = createMaterial(SwipeComponent, {
17019
+ displayName: 'Swipe Consent',
17020
+ icon: '',
17021
+ category: 'consentPopup',
17022
+ type: 'Swipe',
17023
+ related: {
17024
+ settingRender: settingRender$1,
17025
+ bindableProps: []
17026
+ },
17027
+ defaulSetting: {
17028
+ props: {
17029
+ 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>'
17030
+ },
17031
+ style: {
17032
+ backgroundColor: '#fff',
17033
+ padding: 18
17034
+ }
17035
+ },
17036
+ sort: 3
17037
+ });
17038
+
16670
17039
  /*
16671
17040
  * @Author: binruan@chatlabs.com
16672
17041
  * @Date: 2024-06-13 10:08:32
@@ -16968,6 +17337,7 @@ var _materials_ = /*#__PURE__*/Object.freeze({
16968
17337
  AniLinkPopup: AniLinkPopup,
16969
17338
  Appoint: Appoint,
16970
17339
  AppointForm: AppointForm,
17340
+ Click: Click,
16971
17341
  Commodity: Commodity,
16972
17342
  CommodityDetail: CommodityDetail,
16973
17343
  CommodityDetailDiroNew: CommodityDetailDiroNew,
@@ -16984,7 +17354,8 @@ var _materials_ = /*#__PURE__*/Object.freeze({
16984
17354
  MultiCommodityDiro: MultiCommodityDiro,
16985
17355
  MultiCommodityDiroNew: MultiCommodityDiroNew,
16986
17356
  MultiPosts: MultiPosts,
16987
- Prompt: Prompt
17357
+ Prompt: Prompt,
17358
+ Swipe: Swipe
16988
17359
  });
16989
17360
 
16990
17361
  const defaultUnLikeIconPath$1 = '/pb_static/f71266d2c64446c5ae6a5a7f5489cc0a.png';
@@ -17854,23 +18225,72 @@ const Tagbar = ({ tagList = [], setActiveIndex, style }) => {
17854
18225
  };
17855
18226
  var Tagbar$1 = React.memo(Tagbar);
17856
18227
 
18228
+ /*
18229
+ * @Author: binruan@chatlabs.com
18230
+ * @Date: 2023-12-26 10:38:53
18231
+ * @LastEditors: binruan@chatlabs.com
18232
+ * @LastEditTime: 2024-12-11 18:24:31
18233
+ * @FilePath: \pb-sxp-ui\src\core\context\EditorDataProvider.tsx
18234
+ *
18235
+ */
18236
+ const EditorDataContext = React.createContext({});
18237
+ const EditorDataProvider = ({ children, data }) => {
18238
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
18239
+ const [openHashtag, setOpenHashtag] = React.useState(false);
18240
+ const [openConsent, setOpenConsent] = React.useState(false);
18241
+ const [consentPopupCate, setConsentPopupCate] = React.useState('');
18242
+ const [openMultiPosts, setOpenMultiPosts] = React.useState(false);
18243
+ return (React.createElement(EditorDataContext.Provider, { value: {
18244
+ sxpPrameter: {
18245
+ bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
18246
+ defaultRecommend: (_b = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _b === void 0 ? void 0 : _b.default_recommend,
18247
+ personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
18248
+ placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
18249
+ hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
18250
+ loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
18251
+ privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
18252
+ privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
18253
+ privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
18254
+ privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
18255
+ privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
18256
+ template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
18257
+ industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
18258
+ },
18259
+ appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
18260
+ openHashtag,
18261
+ setOpenHashtag,
18262
+ openConsent,
18263
+ setOpenConsent,
18264
+ sxpFontLinks: data === null || data === void 0 ? void 0 : data.sxpFontLinks,
18265
+ utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter,
18266
+ consentPopupCate,
18267
+ setConsentPopupCate,
18268
+ openMultiPosts,
18269
+ setOpenMultiPosts,
18270
+ pageTypeList: (_p = data === null || data === void 0 ? void 0 : data.pageTypeList) !== null && _p !== void 0 ? _p : []
18271
+ } }, children));
18272
+ };
18273
+ function useEditorDataProvider() {
18274
+ return React.useContext(EditorDataContext);
18275
+ }
18276
+
17857
18277
  /*
17858
18278
  * @Author: binruan@chatlabs.com
17859
18279
  * @Date: 2023-12-26 16:11:34
17860
18280
  * @LastEditors: binruan@chatlabs.com
17861
- * @LastEditTime: 2024-11-05 16:29:47
18281
+ * @LastEditTime: 2025-01-14 18:02:44
17862
18282
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
17863
18283
  *
17864
18284
  */
17865
18285
  const Consent = ({ resolver, globalConfig }) => {
17866
18286
  var _a, _b;
17867
- const contsentState = React.useMemo(() => {
17868
- return getContsentState();
17869
- }, []);
17870
- const t = resolver === null || resolver === void 0 ? void 0 : resolver['Display'];
17871
- const Component = withBindDataSource(t);
18287
+ const { consentPopupCate } = useEditorDataProvider();
17872
18288
  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;
17873
- 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 }));
18289
+ if (!value)
18290
+ return null;
18291
+ const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18292
+ const Component = withBindDataSource(t);
18293
+ 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 })));
17874
18294
  };
17875
18295
  var ConsentPopup = React.memo(Consent);
17876
18296
 
@@ -17893,7 +18313,7 @@ var NavBack$1 = React.memo(NavBack);
17893
18313
  * @Author: binruan@chatlabs.com
17894
18314
  * @Date: 2024-03-20 10:27:31
17895
18315
  * @LastEditors: binruan@chatlabs.com
17896
- * @LastEditTime: 2024-12-18 10:24:20
18316
+ * @LastEditTime: 2025-01-20 18:46:32
17897
18317
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
17898
18318
  *
17899
18319
  */
@@ -17988,7 +18408,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
17988
18408
  contentId: (_m = item === null || item === void 0 ? void 0 : item.video) === null || _m === void 0 ? void 0 : _m.itemId,
17989
18409
  productId: (_o = item === null || item === void 0 ? void 0 : item.product) === null || _o === void 0 ? void 0 : _o.itemId,
17990
18410
  position: activeIndex + '',
17991
- fromKName: fk ? fk : fromKName,
18411
+ fromKName: fk || fromKName,
17992
18412
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
17993
18413
  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 : '',
17994
18414
  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 : ''
@@ -18018,9 +18438,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18018
18438
  skipLinkRef.current = false;
18019
18439
  }
18020
18440
  // 页面可见时触发,注意页面初始化时不会触发
18441
+ refreshFeSession === null || refreshFeSession === void 0 ? void 0 : refreshFeSession(false);
18021
18442
  handleH5EnterLink();
18022
18443
  if (repCond) {
18023
- SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18444
+ setTimeout(() => {
18445
+ SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
18446
+ });
18024
18447
  backMainFeed('external', selectTag);
18025
18448
  }
18026
18449
  }
@@ -18860,7 +19283,7 @@ var index$1 = React.memo(DiyPortalPreview);
18860
19283
  * @Author: binruan@chatlabs.com
18861
19284
  * @Date: 2023-10-31 10:56:01
18862
19285
  * @LastEditors: binruan@chatlabs.com
18863
- * @LastEditTime: 2024-12-12 14:48:31
19286
+ * @LastEditTime: 2024-10-23 15:07:29
18864
19287
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Popup\index.tsx
18865
19288
  *
18866
19289
  */