pb-sxp-ui 1.15.3 → 1.15.5

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 +108 -61
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +13 -1
  4. package/dist/index.js +108 -61
  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 +108 -61
  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/Consent/index.js +0 -1
  15. package/es/core/components/SxpPageCore/index.js +1 -1
  16. package/es/core/components/SxpPageRender/ConsentPopup.js +2 -2
  17. package/es/core/components/SxpPageRender/index.d.ts +1 -0
  18. package/es/core/components/SxpPageRender/index.js +11 -10
  19. package/es/core/context/SxpDataSourceProvider.d.ts +2 -0
  20. package/es/core/context/SxpDataSourceProvider.js +24 -17
  21. package/es/materials/sxp/consentPopup/Click/index.d.ts +1 -0
  22. package/es/materials/sxp/consentPopup/Click/index.js +33 -11
  23. package/es/materials/sxp/consentPopup/Click/settingRender.js +6 -1
  24. package/es/materials/sxp/consentPopup/Swipe/index.js +25 -12
  25. package/lib/core/components/Consent/index.js +0 -1
  26. package/lib/core/components/SxpPageCore/index.js +1 -1
  27. package/lib/core/components/SxpPageRender/ConsentPopup.js +2 -2
  28. package/lib/core/components/SxpPageRender/index.d.ts +1 -0
  29. package/lib/core/components/SxpPageRender/index.js +11 -10
  30. package/lib/core/context/SxpDataSourceProvider.d.ts +2 -0
  31. package/lib/core/context/SxpDataSourceProvider.js +24 -17
  32. package/lib/materials/sxp/consentPopup/Click/index.d.ts +1 -0
  33. package/lib/materials/sxp/consentPopup/Click/index.js +31 -9
  34. package/lib/materials/sxp/consentPopup/Click/settingRender.js +6 -1
  35. package/lib/materials/sxp/consentPopup/Swipe/index.js +23 -10
  36. package/package.json +1 -1
package/dist/index.cjs CHANGED
@@ -551,7 +551,7 @@ var SXP_EVENT_TYPE;
551
551
  * @Author: binruan@chatlabs.com
552
552
  * @Date: 2024-06-13 15:16:53
553
553
  * @LastEditors: binruan@chatlabs.com
554
- * @LastEditTime: 2025-01-24 14:56:51
554
+ * @LastEditTime: 2025-02-20 11:20:58
555
555
  * @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
556
556
  *
557
557
  */
@@ -582,7 +582,6 @@ const Consent$3 = ({ width = window.innerWidth, height = window.innerHeight, pri
582
582
  utmCampaign: getUtmValue('utm_campaign'),
583
583
  utmId: getUtmValue('utm_id'),
584
584
  utmContent: getUtmValue('utm_content'),
585
- clSource: getUtmValue('cl_source'),
586
585
  enterTime: `${Date.now()}`,
587
586
  enterUrl: window.location.href,
588
587
  rtc: null,
@@ -630,7 +629,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
630
629
  var _a, _b, _c, _d, _e;
631
630
  const [rtcList, setRtcList] = React.useState([]);
632
631
  const [tagList, setTagList] = React.useState([]);
633
- const [loading, setLoading] = React.useState(false);
632
+ const [loading, setLoading] = React.useState(true);
634
633
  const [curReqInfo, setCurReqInfo] = React.useState({ rtc: '', requestId: '' });
635
634
  const swiperRef = React.useRef(null);
636
635
  const isInit = React.useRef(false);
@@ -657,6 +656,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
657
656
  const [channel, setChannel] = React.useState();
658
657
  const [eventTimeList, setEventTimeList] = React.useState([]);
659
658
  const [playbookType, setPlaybookType] = React.useState();
659
+ const [chatlabsId, setChatlabsId] = React.useState();
660
660
  const finalPageData = React.useMemo(() => pageData !== null && pageData !== void 0 ? pageData : data, [pageData, data]);
661
661
  const isShowConsent = React.useMemo(() => {
662
662
  var _a, _b, _c, _d;
@@ -746,16 +746,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
746
746
  // 获取推荐视频数据
747
747
  const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
748
748
  var _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u;
749
- query = {
750
- maxSize: (_f = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _f !== void 0 ? _f : maxSize,
751
- defaultSize: (_g = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _g !== void 0 ? _g : defaultSize,
752
- hashTag: query === null || query === void 0 ? void 0 : query.hashTag,
753
- traceInfo: query === null || query === void 0 ? void 0 : query.traceInfo,
754
- themeTag: query === null || query === void 0 ? void 0 : query.themeTag,
755
- pageNum: query === null || query === void 0 ? void 0 : query.pageNum,
756
- contentFilter: query === null || query === void 0 ? void 0 : query.contentFilter,
757
- productFilter: query === null || query === void 0 ? void 0 : query.productFilter
758
- };
749
+ 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 }));
759
750
  if (channel) {
760
751
  query = Object.assign(Object.assign({}, query), { channel: decodeURIComponent(channel) });
761
752
  }
@@ -820,7 +811,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
820
811
  return Object.assign(Object.assign({}, result.data), { recList: list });
821
812
  }
822
813
  return result === null || result === void 0 ? void 0 : result.data;
823
- }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel]);
814
+ }), [bffFetch, utmVal, maxSize, defaultSize, channelQueryList, channel, chatlabsId]);
824
815
  const loadVideos = React.useCallback((pageNum) => __awaiter(void 0, void 0, void 0, function* () {
825
816
  var _1, _2, _3, _4;
826
817
  if (rtcList.length <= 0) {
@@ -874,9 +865,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
874
865
  const value = val.split('=')[1];
875
866
  params[key] = value;
876
867
  });
877
- console.log(params, '111');
878
868
  const cl_source = params === null || params === void 0 ? void 0 : params.cl_source;
879
- 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 }));
869
+ 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 }));
880
870
  const realUserInfo = Object.entries(userInfo).map(([k, v]) => ({ name: k, value: v }));
881
871
  const realEventInfo = Object.entries(ef)
882
872
  .map(([k, v]) => v && { name: k, value: v })
@@ -1058,12 +1048,26 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1058
1048
  utmContent: getVal('utm_content'),
1059
1049
  enterTime: Math.floor(time / 1000) + '',
1060
1050
  requestId: null,
1061
- 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 : '',
1062
- clSource: getVal('cl_source')
1051
+ 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 : ''
1063
1052
  },
1064
1053
  reportLayId: false
1065
1054
  });
1066
1055
  }, [bffEventReport]);
1056
+ const getAccount = React.useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
1057
+ var _13, _14;
1058
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account', { method: 'GET' }));
1059
+ setChatlabsId((_13 = res === null || res === void 0 ? void 0 : res.data) === null || _13 === void 0 ? void 0 : _13.chatLabsId);
1060
+ return ((_14 = res === null || res === void 0 ? void 0 : res.data) === null || _14 === void 0 ? void 0 : _14.consentResult) === 'true';
1061
+ }), [bffFetch]);
1062
+ const accountSonsent = React.useCallback((consentResult) => __awaiter(void 0, void 0, void 0, function* () {
1063
+ const res = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('v1/account/consent', {
1064
+ method: 'POST',
1065
+ body: {
1066
+ consentResult
1067
+ }
1068
+ }));
1069
+ return res === null || res === void 0 ? void 0 : res.success;
1070
+ }), [bffFetch]);
1067
1071
  React.useEffect(() => {
1068
1072
  if (!isShowConsent)
1069
1073
  h5EnterLink();
@@ -1212,7 +1216,9 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
1212
1216
  eventTimeList,
1213
1217
  setEventTimeList,
1214
1218
  multiPostTimeRef,
1215
- refreshFeSession
1219
+ refreshFeSession,
1220
+ getAccount,
1221
+ accountSonsent
1216
1222
  } }, 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({
1217
1223
  rtcList,
1218
1224
  mutateLike: bffMutateLike,
@@ -9821,7 +9827,7 @@ SwiperSlide.displayName = 'SwiperSlide';
9821
9827
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
9822
9828
  *
9823
9829
  */
9824
- const closeIcon$2 = '';
9830
+ const closeIcon$1 = '';
9825
9831
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false, openState }) => {
9826
9832
  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;
9827
9833
  const touchRef = React.useRef(null);
@@ -10001,7 +10007,7 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema,
10001
10007
  }
10002
10008
  })), child()),
10003
10009
  React.createElement("button", { className: 'modal-icon-wrapper', role: 'button', "aria-label": 'close button', onClick: onClose, style: { top: scrollTop } },
10004
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$2, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
10010
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close button', className: 'modal-icon' }))))))), modalEleRef.current);
10005
10011
  };
10006
10012
  var Modal$1 = React.memo(Modal);
10007
10013
 
@@ -16228,7 +16234,7 @@ var settingRender$4 = [
16228
16234
 
16229
16235
  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"};
16230
16236
 
16231
- const closeIcon$1 = '';
16237
+ const closeIcon = '';
16232
16238
  const AniLinkPopup$1 = (_a) => {
16233
16239
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z;
16234
16240
  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"]);
@@ -16287,7 +16293,7 @@ const AniLinkPopup$1 = (_a) => {
16287
16293
  paddingLeft: '6px'
16288
16294
  } }, "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 }),
16289
16295
  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 } },
16290
- React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon$1, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16296
+ React.createElement("img", { src: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) || closeIcon, alt: 'close', className: styles['modal-icon-wrapper-img'] })),
16291
16297
  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 }),
16292
16298
  (!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: {
16293
16299
  __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)
@@ -16684,7 +16690,7 @@ const Display = createMaterial(DisplayComponent, {
16684
16690
  * @Author: binruan@chatlabs.com
16685
16691
  * @Date: 2023-07-28 18:29:57
16686
16692
  * @LastEditors: binruan@chatlabs.com
16687
- * @LastEditTime: 2025-01-15 10:14:40
16693
+ * @LastEditTime: 2025-02-24 14:01:56
16688
16694
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Click\settingRender.tsx
16689
16695
  *
16690
16696
  */
@@ -16811,6 +16817,11 @@ var settingRender$2 = [
16811
16817
  {
16812
16818
  title: '拒绝按钮样式',
16813
16819
  child: [
16820
+ {
16821
+ type: 'Switch',
16822
+ label: '开启',
16823
+ name: ['props', 'showRejectButton']
16824
+ },
16814
16825
  {
16815
16826
  type: 'Color',
16816
16827
  label: '背景色',
@@ -16842,7 +16853,7 @@ var settingRender$2 = [
16842
16853
  {
16843
16854
  type: 'TextMargin',
16844
16855
  label: '边距',
16845
- name: ['props', 'acceptButton', 'style']
16856
+ name: ['props', 'rejectButton', 'style']
16846
16857
  },
16847
16858
  {
16848
16859
  type: 'Group',
@@ -16902,17 +16913,37 @@ var settingRender$2 = [
16902
16913
  var img$3 = "";
16903
16914
 
16904
16915
  const Click$1 = (_a) => {
16905
- var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton"]);
16916
+ var { isTel, open, content, style, consentPopupCate, acceptButton, rejectButton, showRejectButton } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "acceptButton", "rejectButton", "showRejectButton"]);
16917
+ const { getAccount, accountSonsent } = useSxpDataSource();
16918
+ const [consentResult, setConsentResult] = React.useState(true);
16919
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
16920
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
16921
+ setConsentResult(res);
16922
+ });
16906
16923
  const visivle = React.useMemo(() => {
16907
- return consentPopupCate || (open && style);
16908
- }, [consentPopupCate, open]);
16909
- const handleClickAccept = () => { };
16910
- const handleClickReject = () => { };
16924
+ return consentPopupCate || (open && style && !consentResult);
16925
+ }, [consentPopupCate, open, style, consentResult]);
16926
+ React.useEffect(() => {
16927
+ !consentPopupCate && open && style && handleGetAccount();
16928
+ }, []);
16929
+ const handleClickAccept = () => __awaiter(void 0, void 0, void 0, function* () {
16930
+ const res = yield (accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(true));
16931
+ if (res)
16932
+ setConsentResult(true);
16933
+ });
16934
+ const handleClickReject = () => {
16935
+ history === null || history === void 0 ? void 0 : history.back();
16936
+ };
16911
16937
  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' },
16912
16938
  React.createElement("div", { className: 'consentPopupClick-container', style: style },
16913
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
16914
- React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept }, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text),
16915
- React.createElement("button", { style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject }, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text))))))));
16939
+ React.createElement("div", { className: 'consentPopupClick-container-content' },
16940
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
16941
+ React.createElement("button", { style: acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style, onClick: handleClickAccept, dangerouslySetInnerHTML: {
16942
+ __html: setFontForText(acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.text, acceptButton === null || acceptButton === void 0 ? void 0 : acceptButton.style)
16943
+ } }),
16944
+ React.createElement("button", { hidden: !showRejectButton, style: rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style, onClick: handleClickReject, dangerouslySetInnerHTML: {
16945
+ __html: setFontForText(rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.text, rejectButton === null || rejectButton === void 0 ? void 0 : rejectButton.style)
16946
+ } }))))))));
16916
16947
  };
16917
16948
  var ClickComponent = React.memo(Click$1);
16918
16949
 
@@ -16973,7 +17004,7 @@ const Click = createMaterial(ClickComponent, {
16973
17004
  * @Author: binruan@chatlabs.com
16974
17005
  * @Date: 2023-07-28 18:29:57
16975
17006
  * @LastEditors: binruan@chatlabs.com
16976
- * @LastEditTime: 2025-01-15 17:39:28
17007
+ * @LastEditTime: 2025-02-07 11:28:40
16977
17008
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\settingRender.tsx
16978
17009
  *
16979
17010
  */
@@ -17023,10 +17054,27 @@ var settingRender$1 = [
17023
17054
 
17024
17055
  var img$2 = "";
17025
17056
 
17026
- const closeIcon = '';
17027
17057
  const Swipe$1 = (_a) => {
17028
17058
  var { isTel, open, content, style, consentPopupCate, swipeIcon } = _a; __rest(_a, ["isTel", "open", "content", "style", "consentPopupCate", "swipeIcon"]);
17029
17059
  const touchInfo = React.useRef();
17060
+ const threshold = 50; // 设置判断的距离阈值
17061
+ const { getAccount, accountSonsent } = useSxpDataSource();
17062
+ const [consentResult, setConsentResult] = React.useState(true);
17063
+ const handleGetAccount = () => __awaiter(void 0, void 0, void 0, function* () {
17064
+ const res = yield (getAccount === null || getAccount === void 0 ? void 0 : getAccount());
17065
+ setConsentResult(res);
17066
+ });
17067
+ const visivle = React.useMemo(() => {
17068
+ return consentPopupCate || (open && style && !consentResult);
17069
+ }, [consentPopupCate, open, style, consentResult]);
17070
+ React.useEffect(() => {
17071
+ !consentPopupCate && open && style && handleGetAccount();
17072
+ }, []);
17073
+ const handleClickAccept = () => __awaiter(void 0, void 0, void 0, function* () {
17074
+ const res = yield (accountSonsent === null || accountSonsent === void 0 ? void 0 : accountSonsent(true));
17075
+ if (res)
17076
+ setConsentResult(true);
17077
+ });
17030
17078
  const handleTouchStart = (event) => {
17031
17079
  const touch = event.touches[0];
17032
17080
  touchInfo.current = { y: touch.clientY, d: 0 };
@@ -17043,19 +17091,17 @@ const Swipe$1 = (_a) => {
17043
17091
  const handleTouchEnd = () => {
17044
17092
  if (!touchInfo.current)
17045
17093
  return;
17046
- touchInfo.current || {};
17094
+ const { d } = touchInfo.current || {};
17095
+ if (d > threshold) {
17096
+ handleClickAccept();
17097
+ }
17047
17098
  touchInfo.current = {};
17048
17099
  };
17049
- const handleClickReject = () => { };
17050
- const visivle = React.useMemo(() => {
17051
- return consentPopupCate || (open && style);
17052
- }, [consentPopupCate, open]);
17053
17100
  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 },
17054
17101
  React.createElement("div", { className: 'consentPopupSwipe-container', style: style },
17055
- React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } }),
17056
- React.createElement("button", { "aria-label": 'close', className: 'consentPopupSwipe-container-close', onClick: handleClickReject },
17057
- React.createElement("img", { src: closeIcon, alt: 'close' })),
17058
- swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon', onClick: handleClickReject },
17102
+ React.createElement("div", { className: 'consentPopupSwipe-container-content' },
17103
+ React.createElement(ConsentDetail$2, { content: content, style: { padding: 0 } })),
17104
+ swipeIcon && (React.createElement("div", { className: 'consentPopupSwipe-container-swipeIcon' },
17059
17105
  React.createElement("img", { src: swipeIcon, alt: 'Swipe Icon' }))))))))));
17060
17106
  };
17061
17107
  var SwipeComponent = React.memo(Swipe$1);
@@ -17064,7 +17110,7 @@ var SwipeComponent = React.memo(Swipe$1);
17064
17110
  * @Author: binruan@chatlabs.com
17065
17111
  * @Date: 2025-01-14 16:22:35
17066
17112
  * @LastEditors: binruan@chatlabs.com
17067
- * @LastEditTime: 2025-01-15 17:09:49
17113
+ * @LastEditTime: 2025-02-24 14:09:52
17068
17114
  * @FilePath: \pb-sxp-ui\src\materials\sxp\consentPopup\Swipe\material.tsx
17069
17115
  *
17070
17116
  */
@@ -18331,15 +18377,15 @@ function useEditorDataProvider() {
18331
18377
  * @Author: binruan@chatlabs.com
18332
18378
  * @Date: 2023-12-26 16:11:34
18333
18379
  * @LastEditors: binruan@chatlabs.com
18334
- * @LastEditTime: 2025-01-14 18:02:44
18380
+ * @LastEditTime: 2025-02-21 14:59:49
18335
18381
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ConsentPopup.tsx
18336
18382
  *
18337
18383
  */
18338
18384
  const Consent = ({ resolver, globalConfig }) => {
18339
- var _a, _b;
18385
+ var _a, _b, _c;
18340
18386
  const { consentPopupCate } = useEditorDataProvider();
18341
18387
  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;
18342
- if (!value)
18388
+ if (!value || (!consentPopupCate && !((_c = value === null || value === void 0 ? void 0 : value.props) === null || _c === void 0 ? void 0 : _c.open)))
18343
18389
  return null;
18344
18390
  const t = resolver === null || resolver === void 0 ? void 0 : resolver[value === null || value === void 0 ? void 0 : value.type];
18345
18391
  const Component = withBindDataSource(t);
@@ -18366,11 +18412,11 @@ var NavBack$1 = React.memo(NavBack);
18366
18412
  * @Author: binruan@chatlabs.com
18367
18413
  * @Date: 2024-03-20 10:27:31
18368
18414
  * @LastEditors: binruan@chatlabs.com
18369
- * @LastEditTime: 2025-01-20 18:46:32
18415
+ * @LastEditTime: 2025-02-21 17:25:25
18370
18416
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
18371
18417
  *
18372
18418
  */
18373
- const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.innerHeight, containerWidth = window.innerWidth, tempMap, resolver, data = [], ctaType, tipText, nudge, _schema, hashTagStyle, hashTagRightMargin, tagList = [], defaultData }) => {
18419
+ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.innerHeight, containerWidth = window.innerWidth, tempMap, resolver, data = [], ctaType, tipText, nudge, _schema, hashTagStyle, hashTagRightMargin, tagList = [], defaultData, isAbTestPage }) => {
18374
18420
  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, _0;
18375
18421
  const mutedIcon = useIconLink('/pb_static/5beaaa5ce7f3477b99db3838619cc471.png');
18376
18422
  const unmutedIcon = useIconLink('/pb_static/fea8668a8a894e4aa3a86bcc775e895e.png');
@@ -18758,7 +18804,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18758
18804
  }
18759
18805
  };
18760
18806
  const handleScrollEvent = (swiper) => {
18761
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s;
18807
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w;
18762
18808
  const item = data[swiper.previousIndex];
18763
18809
  if (!item)
18764
18810
  return;
@@ -18777,9 +18823,9 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18777
18823
  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 : '',
18778
18824
  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 : '',
18779
18825
  requestId: null,
18780
- 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 : '',
18826
+ 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 : '',
18781
18827
  contentFormat,
18782
- position: ((_k = swiper.previousIndex) !== null && _k !== void 0 ? _k : 0) + ''
18828
+ position: ((_m = swiper.previousIndex) !== null && _m !== void 0 ? _m : 0) + ''
18783
18829
  }
18784
18830
  });
18785
18831
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件
@@ -18791,12 +18837,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18791
18837
  eventInfo: {
18792
18838
  eventSubject: 'scrollUp',
18793
18839
  eventDescription: 'User scroll up',
18794
- 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 : '',
18795
- productId: (_p = (_o = item.product) === null || _o === void 0 ? void 0 : _o.itemId) !== null && _p !== void 0 ? _p : '',
18840
+ 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 : '',
18841
+ productId: (_r = (_q = item.product) === null || _q === void 0 ? void 0 : _q.itemId) !== null && _r !== void 0 ? _r : '',
18796
18842
  requestId: null,
18797
- 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 : '',
18843
+ 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 : '',
18798
18844
  contentFormat,
18799
- position: ((_s = swiper.previousIndex) !== null && _s !== void 0 ? _s : 0) + ''
18845
+ position: ((_w = swiper.previousIndex) !== null && _w !== void 0 ? _w : 0) + ''
18800
18846
  }
18801
18847
  });
18802
18848
  // 如果上一个商品是图片集,需上报 浏览图片集结结束 事件
@@ -18905,7 +18951,8 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18905
18951
  isReload,
18906
18952
  renderToggleButton
18907
18953
  ]);
18908
- return (React.createElement("div", { id: 'sxp-render', className: 'clc-sxp-container', style: Object.assign({}, ((globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.textUnderlineOffset) && { textUnderlineOffset: `${globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.textUnderlineOffset}px` })) },
18954
+ return (React.createElement(React.Fragment, null, isAbTestPage && loading ? (React.createElement("div", { style: { height, width: containerWidth, display: 'flex', justifyContent: 'center', alignItems: 'center' } },
18955
+ React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { id: 'sxp-render', className: 'clc-sxp-container', style: Object.assign({}, ((globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.textUnderlineOffset) && { textUnderlineOffset: `${globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.textUnderlineOffset}px` })) },
18909
18956
  waterFallData && (React.createElement(Navbar$1, { icon: img, styles: { background: 'rgba(0,0,0,.3)', color: '#fff', top: `${minusHeight}px` }, textStyle: Object.assign(Object.assign({}, (_e = (_d = (_c = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item) === null || _c === void 0 ? void 0 : _c.props) === null || _d === void 0 ? void 0 : _d.textStyles) === null || _e === void 0 ? void 0 : _e.hashTagTitle), { color: '#fff' }), onClose: () => {
18910
18957
  const isEq = lodash.isEqual(rtcList, cacheRtcList);
18911
18958
  if (!isEq && cacheRtcList && (cacheRtcList === null || cacheRtcList === void 0 ? void 0 : cacheRtcList.length)) {
@@ -18965,7 +19012,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
18965
19012
  renderToggleButton(!!(globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconFixed))),
18966
19013
  React.createElement(WaterFall$1, Object.assign({}, (_u = (_t = (_s = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _s === void 0 ? void 0 : _s[0]) === null || _t === void 0 ? void 0 : _t.item) === null || _u === void 0 ? void 0 : _u.props)),
18967
19014
  React.createElement(ConsentPopup, { resolver: resolver, globalConfig: globalConfig }),
18968
- openMultiPosts && (React.createElement(MultiPosts$2, Object.assign({}, (_x = (_w = (_v = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.multiPosts) === null || _v === void 0 ? void 0 : _v[0]) === null || _w === void 0 ? void 0 : _w.item) === null || _x === void 0 ? void 0 : _x.props, (_0 = (_z = (_y = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.multiPosts) === null || _y === void 0 ? void 0 : _y[0]) === null || _z === void 0 ? void 0 : _z.item) === null || _0 === void 0 ? void 0 : _0.event, { style: { position: 'fixed', top: 0, left: 0, right: 0 } })))));
19015
+ openMultiPosts && (React.createElement(MultiPosts$2, Object.assign({}, (_x = (_w = (_v = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.multiPosts) === null || _v === void 0 ? void 0 : _v[0]) === null || _w === void 0 ? void 0 : _w.item) === null || _x === void 0 ? void 0 : _x.props, (_0 = (_z = (_y = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.multiPosts) === null || _y === void 0 ? void 0 : _y[0]) === null || _z === void 0 ? void 0 : _z.item) === null || _0 === void 0 ? void 0 : _0.event, { style: { position: 'fixed', top: 0, left: 0, right: 0 } })))))));
18969
19016
  };
18970
19017
 
18971
19018
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {
@@ -19430,7 +19477,7 @@ const Popup = () => {
19430
19477
  * @Author: binruan@chatlabs.com
19431
19478
  * @Date: 2024-01-15 19:03:09
19432
19479
  * @LastEditors: binruan@chatlabs.com
19433
- * @LastEditTime: 2024-11-27 16:58:32
19480
+ * @LastEditTime: 2025-02-21 17:44:37
19434
19481
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageCore\index.tsx
19435
19482
  *
19436
19483
  */
@@ -19459,7 +19506,7 @@ const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, l
19459
19506
  React.createElement(SxpDataSourceProvider$1, { utmVal: utmVal, dataSources: data === null || data === void 0 ? void 0 : data.data_sources, sxpParameter: data === null || data === void 0 ? void 0 : data.sxp_parameter, maxSize: (_b = (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.personalized_recommend) !== null && _b !== void 0 ? _b : maxSize, defaultSize: (_d = (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.default_recommend) !== null && _d !== void 0 ? _d : defaultSize, hashTagSize: (_f = (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size) !== null && _f !== void 0 ? _f : hashTagSize, loadingImage: loadingImage, appDomain: appDomain, enabledMetaConversionApi: enabledMetaConversionApi, utmParameter: data === null || data === void 0 ? void 0 : data.utm_parameter, data: data, dataList: dataList, onUpdateSchema: (d) => setSchema(d), onUpdateChannel: (d) => setChannel(d), render: ({ rtcList, tagList, pageData }) => {
19460
19507
  var _a;
19461
19508
  return (React.createElement(React.Fragment, null,
19462
- React.createElement(SxpPageRender, Object.assign({ defaultData: data }, (_a = pageData === null || pageData === void 0 ? void 0 : pageData.data) === null || _a === void 0 ? void 0 : _a.sxpPageConf, { tagList: tagList, data: rtcList, resolver: RESOLVER })),
19509
+ React.createElement(SxpPageRender, Object.assign({ defaultData: data }, (_a = pageData === null || pageData === void 0 ? void 0 : pageData.data) === null || _a === void 0 ? void 0 : _a.sxpPageConf, { tagList: tagList, data: rtcList, resolver: RESOLVER, isAbTestPage: dataList && (dataList === null || dataList === void 0 ? void 0 : dataList.length) > 1 })),
19463
19510
  React.createElement(Popup, null)));
19464
19511
  } })));
19465
19512
  };