pb-sxp-ui 1.0.46 → 1.0.48
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 +74 -75
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +2 -0
- package/dist/index.js +74 -75
- 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 +74 -75
- 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/DiyPortalPreview/index.js +5 -3
- package/es/core/components/SxpPageCore/index.d.ts +1 -0
- package/es/core/components/SxpPageCore/index.js +2 -2
- package/es/core/components/SxpPageRender/VideoWidget/index.js +54 -56
- package/es/core/components/SxpPageRender/WaterFall/List.js +6 -6
- package/es/core/components/SxpPageRender/index.d.ts +1 -0
- package/es/core/components/SxpPageRender/index.js +3 -3
- package/lib/core/components/DiyPortalPreview/index.js +5 -3
- package/lib/core/components/SxpPageCore/index.d.ts +1 -0
- package/lib/core/components/SxpPageCore/index.js +2 -2
- package/lib/core/components/SxpPageRender/VideoWidget/index.js +54 -56
- package/lib/core/components/SxpPageRender/WaterFall/List.js +6 -6
- package/lib/core/components/SxpPageRender/index.d.ts +1 -0
- package/lib/core/components/SxpPageRender/index.js +3 -3
- package/package.json +1 -1
package/dist/index.css
CHANGED
@@ -62,6 +62,7 @@
|
|
62
62
|
|
63
63
|
.pb-commondity {
|
64
64
|
position: relative;
|
65
|
+
height: 100%;
|
65
66
|
}
|
66
67
|
.pb-commondity-content {
|
67
68
|
padding: 21px 19px 80px;
|
@@ -659,6 +660,7 @@
|
|
659
660
|
position: absolute;
|
660
661
|
top: 0;
|
661
662
|
width: 100%;
|
663
|
+
height: 100%;
|
662
664
|
overflow: auto;
|
663
665
|
}
|
664
666
|
.list-info {
|
package/dist/index.js
CHANGED
@@ -11676,7 +11676,7 @@ const WaterfallFlowItem = (props) => {
|
|
11676
11676
|
React.createElement("div", { className: 'list-content-listItem-info-price', style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.price, hidden: !priceText }, priceText))));
|
11677
11677
|
};
|
11678
11678
|
function WaterfallList(_a) {
|
11679
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
11679
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
11680
11680
|
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
11681
11681
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
11682
11682
|
const [list, setList] = useState();
|
@@ -11753,16 +11753,12 @@ function WaterfallList(_a) {
|
|
11753
11753
|
return (React.createElement(WaterfallFlowItem, Object.assign({ key: ind, index: ind, rec: item, list: list, reportTagsView: reportTagsView }, props)));
|
11754
11754
|
})),
|
11755
11755
|
React.createElement("div", { hidden: !isLoadMore, style: { textAlign: 'center' } }, "loading..."),
|
11756
|
-
React.createElement("div", {
|
11757
|
-
|
11758
|
-
style: {
|
11759
|
-
height: ((_g = data === null || data === void 0 ? void 0 : data.tag) === null || _g === void 0 ? void 0 : _g.link) ? ((_h = props === null || props === void 0 ? void 0 : props.buttonBgStyle) === null || _h === void 0 ? void 0 : _h.height) || ((_j = props === null || props === void 0 ? void 0 : props.buttonStyle) === null || _j === void 0 ? void 0 : _j.height) || '100px' : 0
|
11756
|
+
React.createElement("div", { hidden: !((_g = data === null || data === void 0 ? void 0 : data.tag) === null || _g === void 0 ? void 0 : _g.link), style: {
|
11757
|
+
height: ((_h = data === null || data === void 0 ? void 0 : data.tag) === null || _h === void 0 ? void 0 : _h.link) ? ((_j = props === null || props === void 0 ? void 0 : props.buttonBgStyle) === null || _j === void 0 ? void 0 : _j.height) || ((_k = props === null || props === void 0 ? void 0 : props.buttonStyle) === null || _k === void 0 ? void 0 : _k.height) || '100px' : 0
|
11760
11758
|
} })),
|
11761
|
-
React.createElement("div", { className: 'list-bottom', style: props === null || props === void 0 ? void 0 : props.buttonBgStyle }),
|
11762
|
-
React.createElement("div", {
|
11763
|
-
|
11764
|
-
className: 'list-btn-wrap', style: Object.assign(Object.assign({}, props === null || props === void 0 ? void 0 : props.buttonBgStyle), { height: 'auto', backgroundColor: 'transparent' }) },
|
11765
|
-
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_k = data === null || data === void 0 ? void 0 : data.tag) === null || _k === void 0 ? void 0 : _k.linkTitle) || 'Shop the collection'))))));
|
11759
|
+
React.createElement("div", { className: 'list-bottom', hidden: !((_l = data === null || data === void 0 ? void 0 : data.tag) === null || _l === void 0 ? void 0 : _l.link), style: props === null || props === void 0 ? void 0 : props.buttonBgStyle }),
|
11760
|
+
React.createElement("div", { hidden: !((_m = data === null || data === void 0 ? void 0 : data.tag) === null || _m === void 0 ? void 0 : _m.link), className: 'list-btn-wrap', style: Object.assign(Object.assign({}, props === null || props === void 0 ? void 0 : props.buttonBgStyle), { height: 'auto', backgroundColor: 'transparent' }) },
|
11761
|
+
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_o = data === null || data === void 0 ? void 0 : data.tag) === null || _o === void 0 ? void 0 : _o.linkTitle) || 'Shop the collection'))))));
|
11766
11762
|
}
|
11767
11763
|
|
11768
11764
|
var img$1 = "";
|
@@ -12053,6 +12049,33 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
|
|
12053
12049
|
const [firstFrameSrc, setFirstFrameSrc] = useState('');
|
12054
12050
|
const videoId = `pb-cache-video-${index}`;
|
12055
12051
|
const videoEleRef = useRef(null);
|
12052
|
+
const blur = useMemo(() => {
|
12053
|
+
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.mode) === '2';
|
12054
|
+
}, [videoPostConfig]);
|
12055
|
+
const translateY = useMemo(() => {
|
12056
|
+
var _a;
|
12057
|
+
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.mode) === '2'
|
12058
|
+
? `translateY(-${50 + ((_a = videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.offsetTop) !== null && _a !== void 0 ? _a : 0)}%) translate3d(0px, 0px, 0px)`
|
12059
|
+
: 'translateY(-50%)';
|
12060
|
+
}, [videoPostConfig]);
|
12061
|
+
const blurBgSrc = useMemo(() => {
|
12062
|
+
var _a;
|
12063
|
+
return ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || firstFrameSrc;
|
12064
|
+
}, [firstFrameSrc, rec]);
|
12065
|
+
const blurStyle = useMemo(() => {
|
12066
|
+
return blur
|
12067
|
+
? {
|
12068
|
+
filter: 'blur(10px)',
|
12069
|
+
transform: 'translate3d(0px, 0px, 0px) scale(1.2)'
|
12070
|
+
}
|
12071
|
+
: {};
|
12072
|
+
}, [blur]);
|
12073
|
+
const isBgColor = useMemo(() => {
|
12074
|
+
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgWay) === '1';
|
12075
|
+
}, [videoPostConfig]);
|
12076
|
+
const bgStyle = useMemo(() => {
|
12077
|
+
return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
|
12078
|
+
}, [videoPostConfig, isBgColor]);
|
12056
12079
|
useEffect(() => {
|
12057
12080
|
if (!videoRef)
|
12058
12081
|
return;
|
@@ -12093,15 +12116,39 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
|
|
12093
12116
|
setIsFirstPlay(false);
|
12094
12117
|
}
|
12095
12118
|
}, [bffEventReport, data, index, isFirstPlay, videoRef]);
|
12119
|
+
const handLoadeddata = useCallback(() => {
|
12120
|
+
var _a;
|
12121
|
+
if (!videoRef || isBgColor || firstFrameSrc)
|
12122
|
+
return;
|
12123
|
+
const videoDomRef = document.getElementById('player-container-id_html5_api');
|
12124
|
+
if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !videoDomRef || !canvasRef.current)
|
12125
|
+
return;
|
12126
|
+
const setFrameImg = () => {
|
12127
|
+
const video = videoDomRef;
|
12128
|
+
const canvas = canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.current;
|
12129
|
+
const ctx = canvas.getContext('2d');
|
12130
|
+
const targetWidth = window === null || window === void 0 ? void 0 : window.innerWidth;
|
12131
|
+
const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
|
12132
|
+
canvas.height = targetHeight;
|
12133
|
+
canvas.width = targetWidth;
|
12134
|
+
ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
|
12135
|
+
setFirstFrameSrc(canvas.toDataURL());
|
12136
|
+
};
|
12137
|
+
setFrameImg();
|
12138
|
+
setTimeout(() => {
|
12139
|
+
setFrameImg();
|
12140
|
+
}, 500);
|
12141
|
+
}, [videoRef, isBgColor, rec, firstFrameSrc]);
|
12096
12142
|
const handleLoadedmetadata = useCallback(() => {
|
12097
12143
|
if (!videoRef)
|
12098
12144
|
return;
|
12099
|
-
|
12100
|
-
|
12101
|
-
|
12102
|
-
|
12145
|
+
handLoadeddata();
|
12146
|
+
// if (activeIndex !== index) {
|
12147
|
+
// videoRef?.play();
|
12148
|
+
// videoRef?.pause();
|
12149
|
+
// }
|
12103
12150
|
setIsLoadFinish(true);
|
12104
|
-
}, [
|
12151
|
+
}, [videoRef, handLoadeddata]);
|
12105
12152
|
const handleCanplay = useCallback(() => {
|
12106
12153
|
setIsLoadFinish(true);
|
12107
12154
|
}, []);
|
@@ -12162,57 +12209,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
|
|
12162
12209
|
}
|
12163
12210
|
});
|
12164
12211
|
}
|
12165
|
-
}, [data, index, bffEventReport, videoRef]);
|
12166
|
-
const blur = useMemo(() => {
|
12167
|
-
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.mode) === '2';
|
12168
|
-
}, [videoPostConfig]);
|
12169
|
-
const translateY = useMemo(() => {
|
12170
|
-
var _a;
|
12171
|
-
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.mode) === '2'
|
12172
|
-
? `translateY(-${50 + ((_a = videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.offsetTop) !== null && _a !== void 0 ? _a : 0)}%) translate3d(0px, 0px, 0px)`
|
12173
|
-
: 'translateY(-50%)';
|
12174
|
-
}, [videoPostConfig]);
|
12175
|
-
const blurBgSrc = useMemo(() => {
|
12176
|
-
var _a;
|
12177
|
-
return ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || firstFrameSrc;
|
12178
|
-
}, [firstFrameSrc, rec]);
|
12179
|
-
const blurStyle = useMemo(() => {
|
12180
|
-
return blur
|
12181
|
-
? {
|
12182
|
-
filter: 'blur(10px)',
|
12183
|
-
transform: 'translate3d(0px, 0px, 0px) scale(1.2)'
|
12184
|
-
}
|
12185
|
-
: {};
|
12186
|
-
}, [blur]);
|
12187
|
-
const isBgColor = useMemo(() => {
|
12188
|
-
return (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgWay) === '1';
|
12189
|
-
}, [videoPostConfig]);
|
12190
|
-
const bgStyle = useMemo(() => {
|
12191
|
-
return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
|
12192
|
-
}, [videoPostConfig, isBgColor]);
|
12193
|
-
const handLoadeddata = useCallback(() => {
|
12194
|
-
var _a;
|
12195
|
-
if (!videoRef || isBgColor)
|
12196
|
-
return;
|
12197
|
-
const videoDomRef = document.getElementById('player-container-id_html5_api');
|
12198
|
-
if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !videoDomRef || !canvasRef.current)
|
12199
|
-
return;
|
12200
|
-
const setFrameImg = () => {
|
12201
|
-
const video = videoDomRef;
|
12202
|
-
const canvas = canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.current;
|
12203
|
-
const ctx = canvas.getContext('2d');
|
12204
|
-
const targetWidth = window === null || window === void 0 ? void 0 : window.innerWidth;
|
12205
|
-
const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
|
12206
|
-
canvas.height = targetHeight;
|
12207
|
-
canvas.width = targetWidth;
|
12208
|
-
ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
|
12209
|
-
setFirstFrameSrc(canvas.toDataURL());
|
12210
|
-
};
|
12211
|
-
setFrameImg();
|
12212
|
-
setTimeout(() => {
|
12213
|
-
setFrameImg();
|
12214
|
-
}, 500);
|
12215
|
-
}, [videoRef, isBgColor, rec]);
|
12212
|
+
}, [data, index, bffEventReport, videoRef, activeIndex]);
|
12216
12213
|
useEffect(() => {
|
12217
12214
|
if (!isActive || !videoRef)
|
12218
12215
|
return;
|
@@ -12226,6 +12223,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
|
|
12226
12223
|
if (!dom && !dom2)
|
12227
12224
|
return;
|
12228
12225
|
videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
|
12226
|
+
videoRef.poster('https://graff-cdn.chatlabs.net/dev/img/8922b5b8-a954-4a61-9ffc-80edebdf02b4/sxp-portal/20240218/fsTan2fgYKJWrCpJtGZPogm0NnvdT1708239153661.jpeg');
|
12229
12227
|
videoRef === null || videoRef === void 0 ? void 0 : videoRef.src(videoSrc);
|
12230
12228
|
videoRef === null || videoRef === void 0 ? void 0 : videoRef.on('loadedmetadata', handleLoadedmetadata);
|
12231
12229
|
videoRef === null || videoRef === void 0 ? void 0 : videoRef.on('loadeddata', handLoadeddata);
|
@@ -12677,7 +12675,7 @@ var Tagbar$1 = memo(Tagbar);
|
|
12677
12675
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
|
12678
12676
|
*
|
12679
12677
|
*/
|
12680
|
-
const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.innerHeight, containerWidth = window.innerWidth, tempMap, resolver, data = [], ctaType, tipText, nudge, _schema, hashTagStyle, tagList = [] }) => {
|
12678
|
+
const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.innerHeight, containerWidth = window.innerWidth, tempMap, resolver, data = [], ctaType, tipText, nudge, _schema, hashTagStyle, tagList = [], licenseUrl }) => {
|
12681
12679
|
var _a, _b, _c, _d, _e, _f, _g;
|
12682
12680
|
const { schema } = useEditor();
|
12683
12681
|
const [activeIndex, setActiveIndex] = useState(0);
|
@@ -12733,7 +12731,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
12733
12731
|
if (!firstRef.current && !videoRef) {
|
12734
12732
|
firstRef.current = true;
|
12735
12733
|
const player = TCPlayer('player-container-id', {
|
12736
|
-
licenseUrl
|
12734
|
+
licenseUrl, // license 地址,参考准备工作部分,在视立方控制台申请 license 后可获得 licenseUrl
|
12737
12735
|
controls: false,
|
12738
12736
|
autoplay: false,
|
12739
12737
|
loop: false,
|
@@ -12746,7 +12744,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
12746
12744
|
setVideoRef(player);
|
12747
12745
|
});
|
12748
12746
|
}
|
12749
|
-
}, [videoRef]);
|
12747
|
+
}, [videoRef, licenseUrl]);
|
12750
12748
|
useEffect(() => {
|
12751
12749
|
if (!isInit)
|
12752
12750
|
handleH5EnterLink();
|
@@ -13479,15 +13477,16 @@ const DiyPortalPreview = ({ data = [], globalConfig, tipText, nudge, tempMap, de
|
|
13479
13477
|
renderBottom(rec, index),
|
13480
13478
|
renderLikeButton(rec, index)));
|
13481
13479
|
};
|
13482
|
-
return (React.createElement("div", {
|
13480
|
+
return (React.createElement("div", { className: css({
|
13483
13481
|
width: '100%',
|
13484
13482
|
height: containerHeight,
|
13485
13483
|
display: 'flex',
|
13486
13484
|
boxSizing: 'border-box',
|
13487
13485
|
gap: 16,
|
13488
13486
|
pointerEvents: 'none',
|
13489
|
-
userSelect: 'none'
|
13490
|
-
|
13487
|
+
userSelect: 'none',
|
13488
|
+
transform: 'scale(0.7) translateX(-22%) translateY(-140px)'
|
13489
|
+
}) }, data === null || data === void 0 ? void 0 : data.map((rec, index) => {
|
13491
13490
|
return renderView(rec, index);
|
13492
13491
|
})));
|
13493
13492
|
};
|
@@ -13562,7 +13561,7 @@ const Popup = () => {
|
|
13562
13561
|
* @Author: binruan@chatlabs.com
|
13563
13562
|
* @Date: 2024-01-15 19:03:09
|
13564
13563
|
* @LastEditors: binruan@chatlabs.com
|
13565
|
-
* @LastEditTime: 2024-
|
13564
|
+
* @LastEditTime: 2024-04-30 11:06:08
|
13566
13565
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageCore\index.tsx
|
13567
13566
|
*
|
13568
13567
|
*/
|
@@ -13578,7 +13577,7 @@ const RESOLVER = {};
|
|
13578
13577
|
Object.values(_materials_).forEach((v) => {
|
13579
13578
|
RESOLVER[v.extend.type] = v;
|
13580
13579
|
});
|
13581
|
-
const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, loadingImage, appDomain }) => {
|
13580
|
+
const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, loadingImage, appDomain, licenseUrl }) => {
|
13582
13581
|
var _a, _b, _c, _d, _e, _f;
|
13583
13582
|
const utmVal = useMemo(() => {
|
13584
13583
|
var _a;
|
@@ -13589,7 +13588,7 @@ const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, l
|
|
13589
13588
|
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, render: ({ rtcList, tagList }) => {
|
13590
13589
|
var _a;
|
13591
13590
|
return (React.createElement(React.Fragment, null,
|
13592
|
-
React.createElement(SxpPageRender, Object.assign({}, (_a = data === null || data === void 0 ? void 0 : data.data) === null || _a === void 0 ? void 0 : _a.sxpPageConf, { tagList: tagList, data: rtcList, resolver: RESOLVER })),
|
13591
|
+
React.createElement(SxpPageRender, Object.assign({}, (_a = data === null || data === void 0 ? void 0 : data.data) === null || _a === void 0 ? void 0 : _a.sxpPageConf, { tagList: tagList, data: rtcList, resolver: RESOLVER, licenseUrl: licenseUrl })),
|
13593
13592
|
React.createElement(Popup, null)));
|
13594
13593
|
} })));
|
13595
13594
|
};
|