pb-sxp-ui 1.4.0 → 1.4.1

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 (30) hide show
  1. package/dist/index.cjs +49 -34
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +0 -4
  4. package/dist/index.js +49 -34
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +3 -3
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +3 -3
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +49 -34
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +3 -3
  13. package/dist/pb-ui.min.js.map +1 -1
  14. package/es/core/components/SxpPageRender/Modal/index.js +10 -4
  15. package/es/core/components/SxpPageRender/PictureGroup/index.js +3 -7
  16. package/es/core/components/SxpPageRender/index.d.ts +1 -0
  17. package/es/core/components/SxpPageRender/index.js +7 -7
  18. package/es/materials/sxp/popup/CommodityDetail/index.js +1 -5
  19. package/es/materials/sxp/popup/CommodityDetail/settingRender.js +10 -0
  20. package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -7
  21. package/es/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +10 -0
  22. package/lib/core/components/SxpPageRender/Modal/index.js +10 -4
  23. package/lib/core/components/SxpPageRender/PictureGroup/index.js +3 -7
  24. package/lib/core/components/SxpPageRender/index.d.ts +1 -0
  25. package/lib/core/components/SxpPageRender/index.js +7 -7
  26. package/lib/materials/sxp/popup/CommodityDetail/index.js +1 -5
  27. package/lib/materials/sxp/popup/CommodityDetail/settingRender.js +10 -0
  28. package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -7
  29. package/lib/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +10 -0
  30. package/package.json +1 -1
package/dist/pb-ui.js CHANGED
@@ -2046,6 +2046,16 @@
2046
2046
  addonAfter: 'px'
2047
2047
  }
2048
2048
  ]
2049
+ },
2050
+ {
2051
+ title: '关闭按钮',
2052
+ child: [
2053
+ {
2054
+ label: '跟随弹窗滚动',
2055
+ type: 'Switch',
2056
+ name: ['props', 'enableFixedCloseButton']
2057
+ }
2058
+ ]
2049
2059
  }
2050
2060
  ];
2051
2061
 
@@ -8875,13 +8885,13 @@
8875
8885
  * @Author: binruan@chatlabs.com
8876
8886
  * @Date: 2023-11-02 18:34:34
8877
8887
  * @LastEditors: binruan@chatlabs.com
8878
- * @LastEditTime: 2024-08-22 18:48:44
8888
+ * @LastEditTime: 2024-08-29 16:40:25
8879
8889
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8880
8890
  *
8881
8891
  */
8882
8892
  const closeIcon$1 = '';
8883
8893
  const Modal = ({ visible, onClose, children, modalStyle, padding, popup, schema, fullHeight = window.innerHeight, isFullScreen = false }) => {
8884
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
8894
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
8885
8895
  const touchRef = React.useRef(null);
8886
8896
  const fTouchRef = React.useRef(null);
8887
8897
  const touchMoveRef = React.useRef(null);
@@ -8893,6 +8903,7 @@
8893
8903
  const modalEleRef = React.useRef(null);
8894
8904
  const { globalConfig, popupDetailData } = useSxpDataSource();
8895
8905
  const { schema: _schema } = useEditor();
8906
+ const [scrollTop, setScrollTop] = React.useState(15);
8896
8907
  React.useEffect(() => {
8897
8908
  const parentNode = document.getElementById('sxp-render');
8898
8909
  const node = document.getElementById('pb-modal');
@@ -9003,12 +9014,17 @@
9003
9014
  onTouchStart: handleTouchStart,
9004
9015
  onTouchEnd: handleTouchEnd
9005
9016
  })),
9006
- React.createElement("div", { onClick: onClose, className: 'modal-icon-wrapper' },
9017
+ React.createElement("div", { className: 'modal-icon-wrapper', onClick: onClose, style: { top: scrollTop } },
9007
9018
  React.createElement("img", { src: (_t = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.popupCloseIcon) !== null && _t !== void 0 ? _t : closeIcon$1, alt: 'close', className: 'modal-icon' })),
9008
- React.createElement("div", { ref: ref, style: {
9019
+ React.createElement("div", Object.assign({ ref: ref, style: {
9009
9020
  height: isScrollFullScreen ? fullHeight : MODAL_DEF_CON_H,
9010
9021
  overflow: (isScrollFullScreen && modalTrans <= 0) || !isScrollFullScreen ? 'auto' : 'hidden'
9011
- } }, children)))))), modalEleRef.current);
9022
+ } }, (((_v = (_u = getPopupById === null || getPopupById === void 0 ? void 0 : getPopupById.item) === null || _u === void 0 ? void 0 : _u.props) === null || _v === void 0 ? void 0 : _v.enableFixedCloseButton) && {
9023
+ onScroll: (e) => {
9024
+ var _a;
9025
+ setScrollTop(15 - ((_a = e === null || e === void 0 ? void 0 : e.target) === null || _a === void 0 ? void 0 : _a.scrollTop));
9026
+ }
9027
+ })), children)))))), modalEleRef.current);
9012
9028
  };
9013
9029
  var Modal$1 = React.memo(Modal);
9014
9030
 
@@ -9305,11 +9321,7 @@
9305
9321
  clickableClass: getDotsAlign
9306
9322
  }, loop: true, autoplay: {
9307
9323
  delay: (swiper === null || swiper === void 0 ? void 0 : swiper.delay) * 1000
9308
- }, ref: ref, className: css.css(Object.assign(Object.assign(Object.assign({}, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) && {
9309
- '.swiper-pagination': {
9310
- bottom: swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom
9311
- }
9312
- })), ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
9324
+ }, ref: ref, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': Object.assign(Object.assign({}, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) && { bottom: swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom })), { fontSize: '14px' }) }, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
9313
9325
  '.swiper-pagination-bullet': {
9314
9326
  backgroundColor: swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor,
9315
9327
  opacity: 1
@@ -9708,7 +9720,7 @@
9708
9720
  * @Author: binruan@chatlabs.com
9709
9721
  * @Date: 2024-03-26 16:50:25
9710
9722
  * @LastEditors: binruan@chatlabs.com
9711
- * @LastEditTime: 2024-08-28 19:08:24
9723
+ * @LastEditTime: 2024-08-29 16:45:54
9712
9724
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
9713
9725
  *
9714
9726
  */
@@ -10044,6 +10056,16 @@
10044
10056
  addonAfter: 'px'
10045
10057
  }
10046
10058
  ]
10059
+ },
10060
+ {
10061
+ title: '关闭按钮',
10062
+ child: [
10063
+ {
10064
+ label: '跟随弹窗滚动',
10065
+ type: 'Switch',
10066
+ name: ['props', 'enableFixedCloseButton']
10067
+ }
10068
+ ]
10047
10069
  }
10048
10070
  ];
10049
10071
 
@@ -10206,15 +10228,11 @@ Made in Italy` })));
10206
10228
  React.createElement("div", { style: { position: 'relative' } },
10207
10229
  product && ((_w = product === null || product === void 0 ? void 0 : product.homePage) === null || _w === void 0 ? void 0 : _w.length) > 0 && (React.createElement(Swiper, { height: height, modules: [Pagination, Autoplay], pagination: {
10208
10230
  clickable: true,
10209
- bulletActiveClass: 'commondityDiroNew-swipe-item-active-bullet',
10231
+ bulletActiveClass: 'swipe-item-active-bullet',
10210
10232
  clickableClass: getDotsAlign
10211
10233
  }, loop: true, autoplay: {
10212
10234
  delay: (swiper === null || swiper === void 0 ? void 0 : swiper.delay) * 1000
10213
- }, ref: ref, className: css.css(Object.assign(Object.assign(Object.assign({}, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) && {
10214
- '.swiper-pagination': {
10215
- bottom: swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom
10216
- }
10217
- })), ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
10235
+ }, ref: ref, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': Object.assign(Object.assign({}, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom) && { bottom: swiper === null || swiper === void 0 ? void 0 : swiper.dotsMarginBottom })), { fontSize: '14px' }) }, ((swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor) && {
10218
10236
  '.swiper-pagination-bullet': {
10219
10237
  backgroundColor: swiper === null || swiper === void 0 ? void 0 : swiper.dotsBgColor,
10220
10238
  opacity: 1
@@ -10282,7 +10300,8 @@ Made in Italy` })));
10282
10300
  __html: setFontForText((_3 = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _3 !== void 0 ? _3 : 'Shop now', buttonStyle)
10283
10301
  } }))),
10284
10302
  productInfoText({ isPost }))),
10285
- React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText({ isPost: false })),
10303
+ React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) },
10304
+ React.createElement("div", { style: { paddingTop: '20px' } }, productInfoText({ isPost: false }))),
10286
10305
  React.createElement(Modal$1, { visible: show3DModal, padding: 0, isFullScreen: true, onClose: () => setShow3DModal(false) },
10287
10306
  React.createElement("div", { style: { backgroundColor: iframeBgColor, height: '100%' } },
10288
10307
  React.createElement("iframe", { src: iframeUrl, style: {
@@ -15832,11 +15851,11 @@ Made in Italy` })));
15832
15851
  * @Author: lewinlu@chatlabs.com
15833
15852
  * @Date: 2024-01-03 14:39:09
15834
15853
  * @LastEditors: binruan@chatlabs.com
15835
- * @LastEditTime: 2024-08-29 09:34:13
15854
+ * @LastEditTime: 2024-08-29 18:03:12
15836
15855
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
15837
15856
  */
15838
15857
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
15839
- var _a, _b;
15858
+ var _a;
15840
15859
  const ref = React.useRef();
15841
15860
  const { isActive } = useSwiperSlide();
15842
15861
  const { sxpParameter, openHashtag } = useSxpDataSource();
@@ -15866,11 +15885,7 @@ Made in Italy` })));
15866
15885
  return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: {
15867
15886
  clickable: true,
15868
15887
  bulletActiveClass: 'swipe-item-active-bullet'
15869
- }, className: css.css(Object.assign(Object.assign(Object.assign({}, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) && {
15870
- '.swiper-pagination': {
15871
- bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0
15872
- }
15873
- })), ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor) && {
15888
+ }, className: css.css(Object.assign(Object.assign({ '.swiper-pagination': Object.assign(Object.assign({}, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) && { bottom: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom })), { fontSize: '14px' }) }, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor) && {
15874
15889
  '.swiper-pagination-bullet': {
15875
15890
  backgroundColor: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsBgColor,
15876
15891
  opacity: 1
@@ -15880,7 +15895,7 @@ Made in Italy` })));
15880
15895
  backgroundColor: `${imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.dotsActiveColor}!important`,
15881
15896
  opacity: 1
15882
15897
  }
15883
- }))), height: height, loop: true, autoplay: { delay: ((_b = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _b !== void 0 ? _b : 3) * 1000 } }, imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, index) => {
15898
+ }))), height: height, loop: true, autoplay: { delay: ((_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _a !== void 0 ? _a : 3) * 1000 } }, imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, index) => {
15884
15899
  return (React.createElement(SwiperSlide, { key: index },
15885
15900
  React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
15886
15901
  })));
@@ -16134,12 +16149,12 @@ Made in Italy` })));
16134
16149
  * @Author: binruan@chatlabs.com
16135
16150
  * @Date: 2024-01-15 19:03:09
16136
16151
  * @LastEditors: binruan@chatlabs.com
16137
- * @LastEditTime: 2024-08-28 19:13:38
16152
+ * @LastEditTime: 2024-08-29 11:23:41
16138
16153
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
16139
16154
  *
16140
16155
  */
16141
16156
  const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.innerHeight, containerWidth = window.innerWidth, tempMap, resolver, data = [], ctaType, tipText, nudge, _schema, hashTagStyle, tagList = [], licenseUrl }) => {
16142
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
16157
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
16143
16158
  const mutedIcon = useIconLink('/pb_static/5beaaa5ce7f3477b99db3838619cc471.png');
16144
16159
  const unmutedIcon = useIconLink('/pb_static/fea8668a8a894e4aa3a86bcc775e895e.png');
16145
16160
  const { schema } = useEditor();
@@ -16151,6 +16166,7 @@ Made in Italy` })));
16151
16166
  const [isShowMore, setIsShowMore] = React.useState(false);
16152
16167
  const [isReload, setIsReload] = React.useState(new Date().getTime());
16153
16168
  const skipLinkRef = React.useRef(false);
16169
+ const [pageNum, setPageNum] = React.useState(2);
16154
16170
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag, isPreview, isEditor, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, isNoMoreData } = useSxpDataSource();
16155
16171
  const { backMainFeed, productView, jumpToWeb } = useEventReport();
16156
16172
  const isShowFingerTip = React.useMemo(() => {
@@ -16600,8 +16616,8 @@ Made in Italy` })));
16600
16616
  isReload,
16601
16617
  renderToggleButton
16602
16618
  ]);
16603
- return (React.createElement("div", { id: 'sxp-render', className: 'clc-sxp-container' },
16604
- waterFallData && (React.createElement(Navbar$1, { icon: img, styles: { background: 'rgba(0,0,0,.3)', color: '#fff' }, 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: () => {
16619
+ return (React.createElement("div", { id: 'sxp-render', className: 'clc-sxp-container', style: { textUnderlineOffset: `${(_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.textUnderlineOffset) !== null && _a !== void 0 ? _a : 0}px` } },
16620
+ waterFallData && (React.createElement(Navbar$1, { icon: img, styles: { background: 'rgba(0,0,0,.3)', color: '#fff' }, textStyle: Object.assign(Object.assign({}, (_f = (_e = (_d = (_c = (_b = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.item) === null || _d === void 0 ? void 0 : _d.props) === null || _e === void 0 ? void 0 : _e.textStyles) === null || _f === void 0 ? void 0 : _f.hashTagTitle), { color: '#fff' }), onClose: () => {
16605
16621
  const isEq = lodash.isEqual(rtcList, cacheRtcList);
16606
16622
  if (!isEq && cacheRtcList && (cacheRtcList === null || cacheRtcList === void 0 ? void 0 : cacheRtcList.length)) {
16607
16623
  setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(cacheRtcList);
@@ -16612,7 +16628,7 @@ Made in Italy` })));
16612
16628
  React.createElement(Tagbar$1, { tagList: tagList, setActiveIndex: setActiveIndex, style: {
16613
16629
  top: minusHeight
16614
16630
  } }),
16615
- isShowFingerTip ? (React.createElement(FingerSwipeTip, { imageUrl: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipIcon, style: { top: `${50 - ((_f = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipOffset) !== null && _f !== void 0 ? _f : 0)}%` }, duration: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swiperTipAniDur })) : null,
16631
+ isShowFingerTip ? (React.createElement(FingerSwipeTip, { imageUrl: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipIcon, style: { top: `${50 - ((_g = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipOffset) !== null && _g !== void 0 ? _g : 0)}%` }, duration: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swiperTipAniDur })) : null,
16616
16632
  React.createElement(Swiper, { style: {
16617
16633
  marginTop: tagHeight
16618
16634
  }, ref: swiperRef, onSlideChange: () => {
@@ -16630,13 +16646,12 @@ Made in Italy` })));
16630
16646
  return;
16631
16647
  if ((swiper === null || swiper === void 0 ? void 0 : swiper.activeIndex) + 1 >= (data === null || data === void 0 ? void 0 : data.length)) {
16632
16648
  if (!isLoadMore) {
16633
- let pageNum = 2;
16634
16649
  setIsLoadMore(true);
16635
16650
  loadVideos === null || loadVideos === void 0 ? void 0 : loadVideos(pageNum).then((res) => {
16636
16651
  var _a;
16637
16652
  setIsLoadMore(false);
16638
16653
  if (res && ((_a = res === null || res === void 0 ? void 0 : res.recList) === null || _a === void 0 ? void 0 : _a.length) > 0) {
16639
- pageNum++;
16654
+ setPageNum((pageNum + 1));
16640
16655
  }
16641
16656
  });
16642
16657
  }
@@ -16645,7 +16660,7 @@ Made in Italy` })));
16645
16660
  renderLikeButton(visList[activeIndex], activeIndex, !!(globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.likeIconFixed)),
16646
16661
  renderToggleButton(!!(globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconFixed)),
16647
16662
  renderView),
16648
- React.createElement(WaterFall$1, Object.assign({}, (_j = (_h = (_g = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _g === void 0 ? void 0 : _g[0]) === null || _h === void 0 ? void 0 : _h.item) === null || _j === void 0 ? void 0 : _j.props))));
16663
+ React.createElement(WaterFall$1, Object.assign({}, (_k = (_j = (_h = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _h === void 0 ? void 0 : _h[0]) === null || _j === void 0 ? void 0 : _j.item) === null || _k === void 0 ? void 0 : _k.props))));
16649
16664
  };
16650
16665
 
16651
16666
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {