pb-sxp-ui 1.15.3 → 1.15.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/index.cjs +98 -54
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +13 -1
  4. package/dist/index.js +98 -54
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +4 -4
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +4 -4
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +98 -54
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +4 -4
  13. package/dist/pb-ui.min.js.map +1 -1
  14. package/es/core/components/Consent/index.js +0 -1
  15. package/es/core/components/SxpPageRender/ConsentPopup.js +2 -2
  16. package/es/core/components/SxpPageRender/index.js +7 -7
  17. package/es/core/context/SxpDataSourceProvider.d.ts +2 -0
  18. package/es/core/context/SxpDataSourceProvider.js +23 -16
  19. package/es/materials/sxp/consentPopup/Click/index.js +28 -10
  20. package/es/materials/sxp/consentPopup/Click/settingRender.js +1 -1
  21. package/es/materials/sxp/consentPopup/Swipe/index.d.ts +1 -0
  22. package/es/materials/sxp/consentPopup/Swipe/index.js +26 -12
  23. package/es/materials/sxp/consentPopup/Swipe/material.js +2 -1
  24. package/es/materials/sxp/consentPopup/Swipe/settingRender.js +5 -0
  25. package/lib/core/components/Consent/index.js +0 -1
  26. package/lib/core/components/SxpPageRender/ConsentPopup.js +2 -2
  27. package/lib/core/components/SxpPageRender/index.js +7 -7
  28. package/lib/core/context/SxpDataSourceProvider.d.ts +2 -0
  29. package/lib/core/context/SxpDataSourceProvider.js +23 -16
  30. package/lib/materials/sxp/consentPopup/Click/index.js +26 -8
  31. package/lib/materials/sxp/consentPopup/Click/settingRender.js +1 -1
  32. package/lib/materials/sxp/consentPopup/Swipe/index.d.ts +1 -0
  33. package/lib/materials/sxp/consentPopup/Swipe/index.js +24 -10
  34. package/lib/materials/sxp/consentPopup/Swipe/material.js +2 -1
  35. package/lib/materials/sxp/consentPopup/Swipe/settingRender.js +5 -0
  36. package/package.json +1 -1
package/dist/index.css CHANGED
@@ -1439,8 +1439,10 @@ a:active {
1439
1439
  }
1440
1440
  .consentPopupDisplay-close img {
1441
1441
  width: 100%;
1442
+ height: 100%;
1442
1443
  -o-object-fit: cover;
1443
1444
  object-fit: cover;
1445
+ display: block;
1444
1446
  }
1445
1447
 
1446
1448
  .consentPopupClick {
@@ -1468,8 +1470,14 @@ a:active {
1468
1470
  -ms-flex-direction: column;
1469
1471
  flex-direction: column;
1470
1472
  }
1473
+ .consentPopupClick-container-content {
1474
+ overflow-y: auto;
1475
+ }
1471
1476
  .consentPopupClick-container button {
1472
1477
  display: block;
1478
+ -webkit-flex-shrink: 0;
1479
+ -ms-flex-negative: 0;
1480
+ flex-shrink: 0;
1473
1481
  }
1474
1482
 
1475
1483
  .consentPopupSwipe {
@@ -1483,7 +1491,7 @@ a:active {
1483
1491
  }
1484
1492
  .consentPopupSwipe-container {
1485
1493
  width: 90%;
1486
- max-height: 80%;
1494
+ max-height: 70%;
1487
1495
  margin: 20% auto 0;
1488
1496
  border-radius: 5px;
1489
1497
  display: -webkit-box;
@@ -1497,6 +1505,9 @@ a:active {
1497
1505
  flex-direction: column;
1498
1506
  position: relative;
1499
1507
  }
1508
+ .consentPopupSwipe-container-content {
1509
+ overflow-y: auto;
1510
+ }
1500
1511
  .consentPopupSwipe-container-close {
1501
1512
  width: 13px;
1502
1513
  height: 13px;
@@ -1513,6 +1524,7 @@ a:active {
1513
1524
  }
1514
1525
  .consentPopupSwipe-container-close img {
1515
1526
  width: 100%;
1527
+ height: 100%;
1516
1528
  -o-object-fit: cover;
1517
1529
  object-fit: cover;
1518
1530
  display: block;
package/dist/index.js CHANGED
@@ -529,7 +529,7 @@ var SXP_EVENT_TYPE;
529
529
  * @Author: binruan@chatlabs.com
530
530
  * @Date: 2024-06-13 15:16:53
531
531
  * @LastEditors: binruan@chatlabs.com
532
- * @LastEditTime: 2025-01-24 14:56:51
532
+ * @LastEditTime: 2025-02-20 11:20:58
533
533
  * @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
534
534
  *
535
535
  */
@@ -560,7 +560,6 @@ const Consent$3 = ({ width = window.innerWidth, height = window.innerHeight, pri
560
560
  utmCampaign: getUtmValue('utm_campaign'),
561
561
  utmId: getUtmValue('utm_id'),
562
562
  utmContent: getUtmValue('utm_content'),
563
- clSource: getUtmValue('cl_source'),
564
563
  enterTime: `${Date.now()}`,
565
564
  enterUrl: window.location.href,
566
565
  rtc: null,
@@ -635,6 +634,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
635
634
  const [channel, setChannel] = useState();
636
635
  const [eventTimeList, setEventTimeList] = useState([]);
637
636
  const [playbookType, setPlaybookType] = useState();
637
+ const [chatlabsId, setChatlabsId] = useState();
638
638
  const finalPageData = useMemo(() => pageData !== null && pageData !== void 0 ? pageData : data, [pageData, data]);
639
639
  const isShowConsent = useMemo(() => {
640
640
  var _a, _b, _c, _d;
@@ -724,16 +724,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
724
724
  // 获取推荐视频数据
725
725
  const getRecommendVideos = useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
726
726
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
727
- query = {
728
- maxSize: (_f = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _f !== void 0 ? _f : maxSize,
729
- defaultSize: (_g = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _g !== void 0 ? _g : defaultSize,
730
- hashTag: query === null || query === void 0 ? void 0 : query.hashTag,
731
- traceInfo: query === null || query === void 0 ? void 0 : query.traceInfo,
732
- themeTag: query === null || query === void 0 ? void 0 : query.themeTag,
733
- pageNum: query === null || query === void 0 ? void 0 : query.pageNum,
734
- contentFilter: query === null || query === void 0 ? void 0 : query.contentFilter,
735
- productFilter: query === null || query === void 0 ? void 0 : query.productFilter
736
- };
727
+ query = Object.assign({ maxSize: (_f = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _f !== void 0 ? _f : maxSize, defaultSize: (_g = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _g !== void 0 ? _g : defaultSize, hashTag: query === null || query === void 0 ? void 0 : query.hashTag, traceInfo: query === null || query === void 0 ? void 0 : query.traceInfo, themeTag: query === null || query === void 0 ? void 0 : query.themeTag, pageNum: query === null || query === void 0 ? void 0 : query.pageNum, contentFilter: query === null || query === void 0 ? void 0 : query.contentFilter, productFilter: query === null || query === void 0 ? void 0 : query.productFilter }, (chatlabsId && { chatlabsId }));
737
728
  if (channel) {
738
729
  query = Object.assign(Object.assign({}, query), { channel: decodeURIComponent(channel) });
739
730
  }
@@ -798,7 +789,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
798
789
  return Object.assign(Object.assign({}, result.data), { recList: list });
799
790
  }
800
791
  return result === null || result === void 0 ? void 0 : result.data;
801
- }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel]);
792
+ }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel, chatlabsId]);
802
793
  const loadVideos = useCallback((pageNum) => __awaiter(void 0, void 0, void 0, function* () {
803
794
  var _1, _2, _3, _4;
804
795
  if (rtcList.length <= 0) {
@@ -852,9 +843,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
852
843
  const value = val.split('=')[1];
853
844
  params[key] = value;
854
845
  });
855
- console.log(params, '111');
856
846
  const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
857
- const ef = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ sessionID, rtc: curReqInfo.rtc, requestId: curReqInfo.requestId }, { playbookType }), (layoutVariantId && reportLayId && { layoutVariantId })), eventInfo), ((eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) && channel && { position: Number(eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) + 1 + '' })), (cl_source && { cl_source }));
847
+ const ef = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ sessionID, rtc: curReqInfo.rtc, requestId: curReqInfo.requestId }, { playbookType }), (layoutVariantId && reportLayId && { layoutVariantId })), eventInfo), ((eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) && channel && { position: Number(eventInfo === null || eventInfo === void 0 ? void 0 : eventInfo.position) + 1 + '' })), (cl_source && { clSource: cl_source }));
858
848
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
859
849
  const realEventInfo = Object.entries(ef)
860
850
  .map(([k, v]) => v && { name: k, value: v })
@@ -1036,12 +1026,26 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1036
1026
  utmContent: getVal('utm_content'),
1037
1027
  enterTime: Math.floor(time / 1000) + '',
1038
1028
  requestId: null,
1039
- enterUrl: (_c = (_b = window === null || window === void 0 ? void 0 : window.location) === null || _b === void 0 ? void 0 : _b.href) !== null && _c !== void 0 ? _c : '',
1040
- clSource: getVal('cl_source')
1029
+ enterUrl: (_c = (_b = window === null || window === void 0 ? void 0 : window.location) === null || _b === void 0 ? void 0 : _b.href) !== null && _c !== void 0 ? _c : ''
1041
1030
  },
1042
1031
  reportLayId: false
1043
1032
  });
1044
1033
  }, [bffEventReport]);
1034
+ const getAccount = useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
1035
+ var _13, _14;
1036
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account', { method: 'GET' }));
1037
+ setChatlabsId((_13 = res === null || res === void 0 ? void 0 : res.data) === null || _13 === void 0 ? void 0 : _13.chatLabsId);
1038
+ return ((_14 = res === null || res === void 0 ? void 0 : res.data) === null || _14 === void 0 ? void 0 : _14.consentResult) === 'true';
1039
+ }), [bffFetch]);
1040
+ const accountSonsent = useCallback((consentResult) => __awaiter(void 0, void 0, void 0, function* () {
1041
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account/consent', {
1042
+ method: 'POST',
1043
+ body: {
1044
+ consentResult
1045
+ }
1046
+ }));
1047
+ return res === null || res === void 0 ? void 0 : res.success;
1048
+ }), [bffFetch]);
1045
1049
  useEffect(() => {
1046
1050
  if (!isShowConsent)
1047
1051
  h5EnterLink();
@@ -1190,7 +1194,9 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1190
1194
  eventTimeList,
1191
1195
  setEventTimeList,
1192
1196
  multiPostTimeRef,
1193
- refreshFeSession
1197
+ refreshFeSession,
1198
+ getAccount,
1199
+ accountSonsent
1194
1200
  } }, isShowConsent ? (React.createElement(Consent$4, Object.assign({}, (_e = (_d = (_c = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consent) === null || _c === void 0 ? void 0 : _c[0]) === null || _d === void 0 ? void 0 : _d.item) === null || _e === void 0 ? void 0 : _e.props))) : (render({
1195
1201
  rtcList,
1196
1202
  mutateLike: bffMutateLike,
@@ -9799,7 +9805,7 @@ SwiperSlide.displayName = 'SwiperSlide';
9799
9805
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9800
9806
  *
9801
9807
  */
9802
- const closeIcon$2 = '';
9808
+ const closeIcon$1 = '';
9803
9809
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9804
9810
  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;
9805
9811
  const touchRef = useRef(null);
@@ -9979,7 +9985,7 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema,
9979
9985
  }
9980
9986
  })), child()),
9981
9987
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
9982
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9988
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
9983
9989
  };
9984
9990
  var Modal$1 = memo(Modal);
9985
9991
 
@@ -16206,7 +16212,7 @@ var settingRender$4 = [
16206
16212
 
16207
16213
  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"};
16208
16214
 
16209
- const closeIcon$1 = '';
16215
+ const closeIcon = '';
16210
16216
  const AniLinkPopup$1 = (_a) => {
16211
16217
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16212
16218
  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"]);
@@ -16265,7 +16271,7 @@ const AniLinkPopup$1 = (_a) => {
16265
16271
  paddingLeft: '6px'
16266
16272
  } }, "Cta Title")) : (React.createElement("div", Object.assign({}, props, { className: `${css(Object.assign(Object.assign({}, style), { '--transY': `translateY(calc(100% + ${(_r = style === null || style === void 0 ? void 0 : style.margin) !== null && _r !== void 0 ? _r : 0}px))` }))} ${styles['aniLinkPopup']} ${aniNamStyle} ${css(aniTimStyle)}`, onClick: handleTo }),
16267
16273
  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 } },
16268
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16274
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16269
16275
  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 }),
16270
16276
  (!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: {
16271
16277
  __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)
@@ -16662,7 +16668,7 @@ const Display = createMaterial(DisplayComponent, {
16662
16668
  * @Author: binruan@chatlabs.com
16663
16669
  * @Date: 2023-07-28 18:29:57
16664
16670
  * @LastEditors: binruan@chatlabs.com
16665
- * @LastEditTime: 2025-01-15 10:14:40
16671
+ * @LastEditTime: 2025-02-07 14:23:57
16666
16672
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16667
16673
  *
16668
16674
  */
@@ -16820,7 +16826,7 @@ var settingRender$2 = [
16820
16826
  {
16821
16827
  type: 'TextMargin',
16822
16828
  label: '边距',
16823
- name: ['props', 'acceptButton', 'style']
16829
+ name: ['props', 'rejectButton', 'style']
16824
16830
  },
16825
16831
  {
16826
16832
  type: 'Group',
@@ -16881,16 +16887,32 @@ var img$3 = "
16881
16887
 
16882
16888
  const Click$1 = (_a) => {
16883
16889
  var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16890
+ const { getAccount, accountSonsent } = useSxpDataSource();
16891
+ const [consentResult, setConsentResult] = useState(false);
16892
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
16893
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
16894
+ setConsentResult(res);
16895
+ });
16896
+ useEffect(() => {
16897
+ handleGetAccount();
16898
+ }, []);
16884
16899
  const visivle = useMemo(() => {
16885
- return consentPopupCate || (open && style);
16886
- }, [consentPopupCate, open]);
16887
- const handleClickAccept = () => { };
16888
- const handleClickReject = () => { };
16900
+ return consentPopupCate || (open && style && !consentResult);
16901
+ }, [consentPopupCate, open, style, consentResult]);
16902
+ const handleClick = (v) => {
16903
+ accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(v);
16904
+ setConsentResult(true);
16905
+ };
16889
16906
  return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$3, style: { objectFit: 'cover', width: '100%', height: '100%' } })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupClick' },
16890
16907
  React.createElement("div", { className: 'consentPopupClick-container', style: style },
16891
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16892
- React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16893
- React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16908
+ React.createElement("div", { className: 'consentPopupClick-container-content' },
16909
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
16910
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: () => handleClick(true), dangerouslySetInnerHTML: {
16911
+ __html: setFontForText(acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style)
16912
+ } }),
16913
+ React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: () => handleClick(false), dangerouslySetInnerHTML: {
16914
+ __html: setFontForText(rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style)
16915
+ } }))))))));
16894
16916
  };
16895
16917
  var ClickComponent = memo(Click$1);
16896
16918
 
@@ -16951,7 +16973,7 @@ const Click = createMaterial(ClickComponent, {
16951
16973
  * @Author: binruan@chatlabs.com
16952
16974
  * @Date: 2023-07-28 18:29:57
16953
16975
  * @LastEditors: binruan@chatlabs.com
16954
- * @LastEditTime: 2025-01-15 17:39:28
16976
+ * @LastEditTime: 2025-02-07 11:28:40
16955
16977
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16956
16978
  *
16957
16979
  */
@@ -16974,6 +16996,11 @@ var settingRender$1 = [
16974
16996
  label: '内边距',
16975
16997
  name: ['style', 'padding'],
16976
16998
  addonAfter: 'px'
16999
+ },
17000
+ {
17001
+ label: '关闭按钮',
17002
+ type: 'Upload',
17003
+ name: ['props', 'closeIcon']
16977
17004
  }
16978
17005
  ]
16979
17006
  },
@@ -17001,10 +17028,26 @@ var settingRender$1 = [
17001
17028
 
17002
17029
  var img$2 = "";
17003
17030
 
17004
- const closeIcon = '';
17005
17031
  const Swipe$1 = (_a) => {
17006
- var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
17032
+ var { isTel, open, content, style, consentPopupCate, swipeIcon, closeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon", "closeIcon"]);
17007
17033
  const touchInfo = useRef();
17034
+ const threshold = 50; // 设置判断的距离阈值
17035
+ const { getAccount, accountSonsent } = useSxpDataSource();
17036
+ const [consentResult, setConsentResult] = useState(false);
17037
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
17038
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
17039
+ setConsentResult(res);
17040
+ });
17041
+ useEffect(() => {
17042
+ handleGetAccount();
17043
+ }, []);
17044
+ const visivle = useMemo(() => {
17045
+ return consentPopupCate || (open && style && !consentResult);
17046
+ }, [consentPopupCate, open, style, consentResult]);
17047
+ const handleClick = (v) => {
17048
+ accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(v);
17049
+ setConsentResult(true);
17050
+ };
17008
17051
  const handleTouchStart = (event) => {
17009
17052
  const touch = event.touches[0];
17010
17053
  touchInfo.current = { y: touch.clientY, d: 0 };
@@ -17021,19 +17064,19 @@ const Swipe$1 = (_a) => {
17021
17064
  const handleTouchEnd = () => {
17022
17065
  if (!touchInfo.current)
17023
17066
  return;
17024
- touchInfo.current || {};
17067
+ const { d } = touchInfo.current || {};
17068
+ if (d > threshold) {
17069
+ handleClick(true);
17070
+ }
17025
17071
  touchInfo.current = {};
17026
17072
  };
17027
- const handleClickReject = () => { };
17028
- const visivle = useMemo(() => {
17029
- return consentPopupCate || (open && style);
17030
- }, [consentPopupCate, open]);
17031
17073
  return (React.createElement(React.Fragment, null, isTel ? (React.createElement("img", { src: img$2, style: { objectFit: 'cover', width: '100%', height: '100%' } })) : (React.createElement(React.Fragment, null, visivle && (React.createElement("div", { className: 'consentPopupSwipe', onTouchStart: handleTouchStart, onTouchMove: handleTouchMove, onTouchEnd: handleTouchEnd },
17032
17074
  React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17033
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17034
- React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17075
+ React.createElement("div", { className: 'consentPopupSwipe-container-content' },
17076
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
17077
+ React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: () => handleClick(false) },
17035
17078
  React.createElement("img", { src: closeIcon, alt: 'close' })),
17036
- swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17079
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: () => handleClick(false) },
17037
17080
  React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17038
17081
  };
17039
17082
  var SwipeComponent = memo(Swipe$1);
@@ -17057,7 +17100,8 @@ const Swipe = createMaterial(SwipeComponent, {
17057
17100
  },
17058
17101
  defaulSetting: {
17059
17102
  props: {
17060
- content: '<p><span style="font- size: 14px"><strong><span style="line - height: 3">Your Cookie Preferences</span></strong></span></p><p><span style="line- height: 1"><span style="font- size: 12px">We use cookie, including third-party cookies, to</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">ensure the proper functioning and security of</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">this site, to analyse its use, and to show you</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">personalised content.</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">You can authorise the use of all cookies by</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">clicking on &#x27;Accept all cookies&#x27;. If you click on</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">&#x27;Reject all cookies&#x27;, we will only use cookies</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">necessary for the proper functioning and </span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">security of this site. To personalise or adjust</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">your preferences at any time, click on &#x27;Cookies</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">Settings&#x27; below or at the bottom of any</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">Fendi.com webpage.</span></span></p><p><span style="line - height: 1"><span style="font - size: 12px">For more information, <u>read our Cookie Policy</u>.</span></span></p>'
17103
+ 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>',
17104
+ closeIcon: ''
17061
17105
  },
17062
17106
  style: {
17063
17107
  backgroundColor: '#fff',
@@ -18309,15 +18353,15 @@ function useEditorDataProvider() {
18309
18353
  * @Author: binruan@chatlabs.com
18310
18354
  * @Date: 2023-12-26 16:11:34
18311
18355
  * @LastEditors: binruan@chatlabs.com
18312
- * @LastEditTime: 2025-01-14 18:02:44
18356
+ * @LastEditTime: 2025-02-20 16:32:44
18313
18357
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
18314
18358
  *
18315
18359
  */
18316
18360
  const Consent = ({ resolver, globalConfig }) => {
18317
- var _a, _b;
18361
+ var _a, _b, _c;
18318
18362
  const { consentPopupCate } = useEditorDataProvider();
18319
18363
  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;
18320
- if (!value)
18364
+ if (!value || (!consentPopupCate && !((_c = value === null || value === void 0 ? void 0 : value.props) === null || _c === void 0 ? void 0 : _c.open)))
18321
18365
  return null;
18322
18366
  const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18323
18367
  const Component = withBindDataSource(t);
@@ -18344,7 +18388,7 @@ var NavBack$1 = memo(NavBack);
18344
18388
  * @Author: binruan@chatlabs.com
18345
18389
  * @Date: 2024-03-20 10:27:31
18346
18390
  * @LastEditors: binruan@chatlabs.com
18347
- * @LastEditTime: 2025-01-20 18:46:32
18391
+ * @LastEditTime: 2025-02-20 14:00:43
18348
18392
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
18349
18393
  *
18350
18394
  */
@@ -18736,7 +18780,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18736
18780
  }
18737
18781
  };
18738
18782
  const handleScrollEvent = (swiper) => {
18739
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s;
18783
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w;
18740
18784
  const item = data[swiper.previousIndex];
18741
18785
  if (!item)
18742
18786
  return;
@@ -18755,9 +18799,9 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18755
18799
  contentId: (_e = (_d = item === null || item === void 0 ? void 0 : item.video) === null || _d === void 0 ? void 0 : _d.itemId) !== null && _e !== void 0 ? _e : '',
18756
18800
  productId: (_g = (_f = item === null || item === void 0 ? void 0 : item.product) === null || _f === void 0 ? void 0 : _f.itemId) !== null && _g !== void 0 ? _g : '',
18757
18801
  requestId: null,
18758
- traceInfo: (_j = (_h = item === null || item === void 0 ? void 0 : item.video) === null || _h === void 0 ? void 0 : _h.traceInfo) !== null && _j !== void 0 ? _j : '',
18802
+ traceInfo: (_l = (_j = (_h = item === null || item === void 0 ? void 0 : item.video) === null || _h === void 0 ? void 0 : _h.traceInfo) !== null && _j !== void 0 ? _j : (_k = item === null || item === void 0 ? void 0 : item.product) === null || _k === void 0 ? void 0 : _k.traceInfo) !== null && _l !== void 0 ? _l : '',
18759
18803
  contentFormat,
18760
- position: ((_k = swiper.previousIndex) !== null && _k !== void 0 ? _k : 0) + ''
18804
+ position: ((_m = swiper.previousIndex) !== null && _m !== void 0 ? _m : 0) + ''
18761
18805
  }
18762
18806
  });
18763
18807
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件
@@ -18769,12 +18813,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18769
18813
  eventInfo: {
18770
18814
  eventSubject: 'scrollUp',
18771
18815
  eventDescription: 'User scroll up',
18772
- contentId: (_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.itemId) !== null && _m !== void 0 ? _m : '',
18773
- productId: (_p = (_o = item.product) === null || _o === void 0 ? void 0 : _o.itemId) !== null && _p !== void 0 ? _p : '',
18816
+ contentId: (_p = (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.itemId) !== null && _p !== void 0 ? _p : '',
18817
+ productId: (_r = (_q = item.product) === null || _q === void 0 ? void 0 : _q.itemId) !== null && _r !== void 0 ? _r : '',
18774
18818
  requestId: null,
18775
- traceInfo: (_r = (_q = item === null || item === void 0 ? void 0 : item.video) === null || _q === void 0 ? void 0 : _q.traceInfo) !== null && _r !== void 0 ? _r : '',
18819
+ 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 : '',
18776
18820
  contentFormat,
18777
- position: ((_s = swiper.previousIndex) !== null && _s !== void 0 ? _s : 0) + ''
18821
+ position: ((_w = swiper.previousIndex) !== null && _w !== void 0 ? _w : 0) + ''
18778
18822
  }
18779
18823
  });
18780
18824
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件