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.
- package/dist/index.cjs +49 -34
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +0 -4
- package/dist/index.js +49 -34
- package/dist/index.js.map +1 -1
- package/dist/index.min.cjs +3 -3
- package/dist/index.min.cjs.map +1 -1
- package/dist/index.min.js +3 -3
- package/dist/index.min.js.map +1 -1
- package/dist/pb-ui.js +49 -34
- package/dist/pb-ui.js.map +1 -1
- package/dist/pb-ui.min.js +3 -3
- package/dist/pb-ui.min.js.map +1 -1
- package/es/core/components/SxpPageRender/Modal/index.js +10 -4
- package/es/core/components/SxpPageRender/PictureGroup/index.js +3 -7
- package/es/core/components/SxpPageRender/index.d.ts +1 -0
- package/es/core/components/SxpPageRender/index.js +7 -7
- package/es/materials/sxp/popup/CommodityDetail/index.js +1 -5
- package/es/materials/sxp/popup/CommodityDetail/settingRender.js +10 -0
- package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -7
- package/es/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +10 -0
- package/lib/core/components/SxpPageRender/Modal/index.js +10 -4
- package/lib/core/components/SxpPageRender/PictureGroup/index.js +3 -7
- package/lib/core/components/SxpPageRender/index.d.ts +1 -0
- package/lib/core/components/SxpPageRender/index.js +7 -7
- package/lib/materials/sxp/popup/CommodityDetail/index.js +1 -5
- package/lib/materials/sxp/popup/CommodityDetail/settingRender.js +10 -0
- package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -7
- package/lib/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +10 -0
- 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-
|
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", {
|
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
|
-
} },
|
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-
|
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: '
|
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) },
|
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
|
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
|
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: ((
|
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-
|
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 =
|
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 - ((
|
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({}, (
|
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 }) => {
|