pb-sxp-ui 1.0.78 → 1.0.80
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 +430 -60
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +187 -1
- package/dist/index.js +430 -60
- 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 +430 -60
- 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/PictureGroup/Picture.d.ts +1 -0
- package/es/core/components/SxpPageRender/PictureGroup/Picture.js +2 -2
- package/es/core/components/SxpPageRender/PictureGroup/index.js +9 -5
- package/es/core/components/SxpPageRender/WaterFall/WaterfallList.js +52 -37
- package/es/core/components/SxpPageRender/WaterFall/index.js +3 -2
- package/es/core/components/SxpPageRender/index.js +1 -21
- package/es/core/context/SxpDataSourceProvider.js +30 -0
- package/es/materials/sxp/HashTag/index.d.ts +2 -0
- package/es/materials/sxp/HashTag/settingRender.d.ts +15 -1
- package/es/materials/sxp/HashTag/settingRender.js +16 -0
- package/lib/core/components/SxpPageRender/PictureGroup/Picture.d.ts +1 -0
- package/lib/core/components/SxpPageRender/PictureGroup/Picture.js +2 -2
- package/lib/core/components/SxpPageRender/PictureGroup/index.js +8 -4
- package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.js +52 -37
- package/lib/core/components/SxpPageRender/WaterFall/index.js +3 -2
- package/lib/core/components/SxpPageRender/index.js +1 -21
- package/lib/core/context/SxpDataSourceProvider.js +30 -0
- package/lib/materials/sxp/HashTag/index.d.ts +2 -0
- package/lib/materials/sxp/HashTag/settingRender.d.ts +15 -1
- package/lib/materials/sxp/HashTag/settingRender.js +16 -0
- package/package.json +1 -1
package/dist/index.js
CHANGED
@@ -617,6 +617,30 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
617
617
|
eventInfo: Object.assign(Object.assign({}, eventInfo), { ctaId: (_h = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _h !== void 0 ? _h : '', ctaName: (_j = cta === null || cta === void 0 ? void 0 : cta.title) !== null && _j !== void 0 ? _j : '', contentTags: JSON.stringify(cta === null || cta === void 0 ? void 0 : cta.tags), position: position + '', contentId: (_l = (_k = rec === null || rec === void 0 ? void 0 : rec.video) === null || _k === void 0 ? void 0 : _k.itemId) !== null && _l !== void 0 ? _l : '', productId: isProd ? product === null || product === void 0 ? void 0 : product.itemId : '', traceInfo: (_m = cta === null || cta === void 0 ? void 0 : cta.traceInfo) !== null && _m !== void 0 ? _m : '', fromKName })
|
618
618
|
});
|
619
619
|
}, [bffEventReport, isFromHashtag]);
|
620
|
+
useEffect(() => {
|
621
|
+
var _a, _b;
|
622
|
+
const queryString = location.search.slice(1);
|
623
|
+
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
624
|
+
for (const key in params) {
|
625
|
+
params[key] = params[key].replace(/%2B/g, '+');
|
626
|
+
}
|
627
|
+
const getVal = (key) => { var _a; return (_a = params[key]) !== null && _a !== void 0 ? _a : ''; };
|
628
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
629
|
+
eventInfo: {
|
630
|
+
eventSubject: 'h5LinkEnterFeed',
|
631
|
+
eventDescription: 'User enter h5 link',
|
632
|
+
utmSource: getVal('utm_source'),
|
633
|
+
utmMedium: getVal('utm_medium'),
|
634
|
+
utmCampaign: getVal('utm_campaign'),
|
635
|
+
utmId: getVal('utm_id'),
|
636
|
+
utmContent: getVal('utm_content'),
|
637
|
+
enterTime: `${Date.now()}`,
|
638
|
+
requestId: null,
|
639
|
+
enterUrl: (_b = (_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.href) !== null && _b !== void 0 ? _b : '',
|
640
|
+
clSource: getVal('cl_sourc')
|
641
|
+
}
|
642
|
+
});
|
643
|
+
}, []);
|
620
644
|
useEffect(() => {
|
621
645
|
setLoading(true);
|
622
646
|
bffGetTagList();
|
@@ -627,6 +651,12 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
627
651
|
setCacheRtcList((_b = data === null || data === void 0 ? void 0 : data.recList) !== null && _b !== void 0 ? _b : []);
|
628
652
|
})
|
629
653
|
.finally(() => {
|
654
|
+
bffEventReport({
|
655
|
+
eventInfo: {
|
656
|
+
eventSubject: 'apiRequest',
|
657
|
+
eventDescription: 'api request succeed'
|
658
|
+
}
|
659
|
+
});
|
630
660
|
setLoading(false);
|
631
661
|
isInit.current = true;
|
632
662
|
});
|
@@ -10333,24 +10363,35 @@ var _a, _b;
|
|
10333
10363
|
* @Author: binruan@chatlabs.com
|
10334
10364
|
* @Date: 2024-04-07 14:07:12
|
10335
10365
|
* @LastEditors: binruan@chatlabs.com
|
10336
|
-
* @LastEditTime: 2024-
|
10366
|
+
* @LastEditTime: 2024-06-07 15:51:49
|
10337
10367
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
|
10338
10368
|
*
|
10339
10369
|
*/
|
10340
10370
|
var settingRender = [
|
10371
|
+
{
|
10372
|
+
title: 'Banner',
|
10373
|
+
child: [
|
10374
|
+
{
|
10375
|
+
type: 'Switch',
|
10376
|
+
label: 'Banner图开关',
|
10377
|
+
name: ['props', 'showBanner']
|
10378
|
+
}
|
10379
|
+
]
|
10380
|
+
},
|
10341
10381
|
{
|
10342
10382
|
title: '卡片样式',
|
10343
10383
|
child: [
|
10344
|
-
// {
|
10345
|
-
// type: 'Number',
|
10346
|
-
// label: '文本行数',
|
10347
|
-
// name: ['props', 'lineClamp']
|
10348
|
-
// },
|
10349
10384
|
{
|
10350
10385
|
type: 'Number',
|
10351
10386
|
label: '上下边距',
|
10352
10387
|
name: ['props', 'space'],
|
10353
10388
|
addonAfter: 'px'
|
10389
|
+
},
|
10390
|
+
{
|
10391
|
+
type: 'Switch',
|
10392
|
+
label: '固定宽高',
|
10393
|
+
name: ['props', 'isWaterfallFlow'],
|
10394
|
+
initialValue: true
|
10354
10395
|
}
|
10355
10396
|
]
|
10356
10397
|
},
|
@@ -11819,6 +11860,374 @@ var previewData = {
|
|
11819
11860
|
hashTag: hashTag
|
11820
11861
|
};
|
11821
11862
|
|
11863
|
+
const WaterfallFlowItem$1 = (props) => {
|
11864
|
+
const { rec, style = {}, sizeChange = () => { }, unitWidth, index, showBorder, list, reportTagsView, textStyles, space } = props;
|
11865
|
+
const { swiperRef, setRtcList, setOpenHashtag, sxpParameter } = useSxpDataSource();
|
11866
|
+
const [showVideo, setShowVideo] = useState(false);
|
11867
|
+
const [isLoading, setIsLoading] = useState(false);
|
11868
|
+
const [imgInfo, setImgInfo] = useState({
|
11869
|
+
height: 1,
|
11870
|
+
width: 1
|
11871
|
+
});
|
11872
|
+
const imgDom = useRef(null);
|
11873
|
+
const ref = useRef(null);
|
11874
|
+
const videoDom = useRef(null);
|
11875
|
+
const canvasRef = useRef(null);
|
11876
|
+
const [firstFrameSrc, setFirstFrameSrc] = useState('');
|
11877
|
+
const src = useMemo(() => {
|
11878
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
11879
|
+
if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) {
|
11880
|
+
return (_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.cover;
|
11881
|
+
}
|
11882
|
+
else if ((_d = (_c = rec === null || rec === void 0 ? void 0 : rec.video) === null || _c === void 0 ? void 0 : _c.imgUrls) === null || _d === void 0 ? void 0 : _d.length) {
|
11883
|
+
return (_f = (_e = rec === null || rec === void 0 ? void 0 : rec.video) === null || _e === void 0 ? void 0 : _e.imgUrls) === null || _f === void 0 ? void 0 : _f[0];
|
11884
|
+
}
|
11885
|
+
else if ((_h = (_g = rec === null || rec === void 0 ? void 0 : rec.product) === null || _g === void 0 ? void 0 : _g.homePage) === null || _h === void 0 ? void 0 : _h.length) {
|
11886
|
+
return (_k = (_j = rec === null || rec === void 0 ? void 0 : rec.product) === null || _j === void 0 ? void 0 : _j.homePage) === null || _k === void 0 ? void 0 : _k[0];
|
11887
|
+
}
|
11888
|
+
else {
|
11889
|
+
return (sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) || '';
|
11890
|
+
}
|
11891
|
+
}, [rec, sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image]);
|
11892
|
+
const title = useMemo(() => {
|
11893
|
+
var _a, _b;
|
11894
|
+
return ((_a = rec === null || rec === void 0 ? void 0 : rec.product) === null || _a === void 0 ? void 0 : _a.title) || ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.title) || null;
|
11895
|
+
}, [rec]);
|
11896
|
+
/** 离父亲上边框的距离 */
|
11897
|
+
const top = useMemo(() => {
|
11898
|
+
var _a;
|
11899
|
+
const y = style.transform
|
11900
|
+
? Number((_a = style.transform) === null || _a === void 0 ? void 0 : _a.substring(style.transform.indexOf(',', 0) + 1, style.transform.length - 3))
|
11901
|
+
: undefined;
|
11902
|
+
return y;
|
11903
|
+
}, [style]);
|
11904
|
+
/** 是否加载图片 */
|
11905
|
+
const isImgShow = useMemo(() => {
|
11906
|
+
if (top === undefined) {
|
11907
|
+
return false;
|
11908
|
+
}
|
11909
|
+
if (top <= showBorder) {
|
11910
|
+
return true;
|
11911
|
+
}
|
11912
|
+
else {
|
11913
|
+
return false;
|
11914
|
+
}
|
11915
|
+
}, [top, showBorder]);
|
11916
|
+
const priceText = useMemo(() => {
|
11917
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
11918
|
+
if (((_a = rec === null || rec === void 0 ? void 0 : rec.product) === null || _a === void 0 ? void 0 : _a.currency) && ((_b = rec === null || rec === void 0 ? void 0 : rec.product) === null || _b === void 0 ? void 0 : _b.price)) {
|
11919
|
+
return `${(_f = (_e = (_d = (_c = rec === null || rec === void 0 ? void 0 : rec.product) === null || _c === void 0 ? void 0 : _c.currency) === null || _d === void 0 ? void 0 : _d.split('-')[1]) === null || _e === void 0 ? void 0 : _e.toUpperCase()) !== null && _f !== void 0 ? _f : ''}${(_j = (_h = (_g = rec === null || rec === void 0 ? void 0 : rec.product) === null || _g === void 0 ? void 0 : _g.price) === null || _h === void 0 ? void 0 : _h.toLocaleString('zh', {
|
11920
|
+
minimumFractionDigits: 0
|
11921
|
+
})) !== null && _j !== void 0 ? _j : ''}`;
|
11922
|
+
}
|
11923
|
+
else {
|
11924
|
+
return null;
|
11925
|
+
}
|
11926
|
+
}, [rec]);
|
11927
|
+
useEffect(() => {
|
11928
|
+
if (imgDom.current === null || src === '') {
|
11929
|
+
return;
|
11930
|
+
}
|
11931
|
+
const img = new Image();
|
11932
|
+
if (showVideo && firstFrameSrc) {
|
11933
|
+
img.src = firstFrameSrc;
|
11934
|
+
}
|
11935
|
+
else {
|
11936
|
+
img.src = src;
|
11937
|
+
}
|
11938
|
+
img.onload = () => {
|
11939
|
+
setImgInfo({
|
11940
|
+
height: img.height,
|
11941
|
+
width: img.width
|
11942
|
+
});
|
11943
|
+
setIsLoading(true);
|
11944
|
+
};
|
11945
|
+
imgDom.current.setSrc(img.src);
|
11946
|
+
}, [src, showVideo, firstFrameSrc, isImgShow]);
|
11947
|
+
useEffect(() => {
|
11948
|
+
// 通过宽度比例获取图片高度
|
11949
|
+
const height = imgInfo.height * (unitWidth / imgInfo.width);
|
11950
|
+
if (isLoading) {
|
11951
|
+
// 加40是因为下方文字部分高度为40,可以自己设置
|
11952
|
+
sizeChange(height + 76 + space, index);
|
11953
|
+
}
|
11954
|
+
}, [imgInfo, index, unitWidth, isLoading, space]); /* 增加sizeChange依赖项会导致在admin预览编辑时无限刷新 */
|
11955
|
+
const calculateHeightForWidth = (videoWidth, videoHeight, targetWidth) => {
|
11956
|
+
const aspectRatio = videoWidth / videoHeight;
|
11957
|
+
const targetHeight = targetWidth / aspectRatio;
|
11958
|
+
return targetHeight;
|
11959
|
+
};
|
11960
|
+
useEffect(() => {
|
11961
|
+
const video = videoDom === null || videoDom === void 0 ? void 0 : videoDom.current;
|
11962
|
+
if (video === null || src === '' || !showVideo) {
|
11963
|
+
return;
|
11964
|
+
}
|
11965
|
+
video.src = src;
|
11966
|
+
video.currentTime = 1;
|
11967
|
+
video.crossOrigin = 'anonymous';
|
11968
|
+
video.onloadeddata = () => {
|
11969
|
+
const canvas = canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.current;
|
11970
|
+
if (!canvas)
|
11971
|
+
return;
|
11972
|
+
const ctx = canvas.getContext('2d');
|
11973
|
+
const targetWidth = (window === null || window === void 0 ? void 0 : window.innerWidth) / 2;
|
11974
|
+
const targetHeight = calculateHeightForWidth(video.videoWidth, video.videoHeight, targetWidth);
|
11975
|
+
canvas.height = targetHeight;
|
11976
|
+
canvas.width = targetWidth;
|
11977
|
+
ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
|
11978
|
+
setFirstFrameSrc(canvas.toDataURL());
|
11979
|
+
video.remove();
|
11980
|
+
canvas.remove();
|
11981
|
+
};
|
11982
|
+
}, [src, showVideo]);
|
11983
|
+
const handleClickToDetail = () => {
|
11984
|
+
reportTagsView();
|
11985
|
+
setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(list);
|
11986
|
+
setTimeout(() => {
|
11987
|
+
var _a;
|
11988
|
+
(_a = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _a === void 0 ? void 0 : _a.swiper.slideTo(index, 0, false);
|
11989
|
+
setOpenHashtag === null || setOpenHashtag === void 0 ? void 0 : setOpenHashtag(false);
|
11990
|
+
}, 0);
|
11991
|
+
};
|
11992
|
+
return (React.createElement("div", { ref: ref, style: Object.assign({}, style), className: 'waterFallList-content-listItem', key: index, onClick: handleClickToDetail },
|
11993
|
+
React.createElement("div", { className: 'waterFallList-content-listItem-picture' },
|
11994
|
+
showVideo && (React.createElement("div", { style: { display: 'none' } },
|
11995
|
+
React.createElement("video", { ref: videoDom, src: src, crossOrigin: 'anonymous', className: 'waterFallList-content-listItem-picture-img' }),
|
11996
|
+
React.createElement("canvas", { ref: canvasRef }))),
|
11997
|
+
React.createElement(FormatImage$1, { loading: 'lazy', className: 'waterFallList-content-listItem-picture-img', ref: imgDom })),
|
11998
|
+
React.createElement("div", { className: 'waterFallList-content-listItem-info' },
|
11999
|
+
React.createElement("div", { className: `${'waterFallList-content-listItem-info-title'} ${priceText ? 'waterFallList-content-listItem-info-nowrap' : ''}`, style: Object.assign({}, textStyles === null || textStyles === void 0 ? void 0 : textStyles.title) }, title && title),
|
12000
|
+
React.createElement("div", { className: 'waterFallList-content-listItem-info-price', hidden: !priceText, style: textStyles.price }, priceText))));
|
12001
|
+
};
|
12002
|
+
function WaterfallList$1(_a) {
|
12003
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
|
12004
|
+
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
12005
|
+
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12006
|
+
/** 滚动的父元素 */
|
12007
|
+
const scrollParent = useRef(null);
|
12008
|
+
/** 向上滚动的距离 */
|
12009
|
+
const [scrollTop, setScrollTop] = useState(0);
|
12010
|
+
/** 数据列表 */
|
12011
|
+
const [data, setData] = useState();
|
12012
|
+
const waterfallFlowDom = useRef(null);
|
12013
|
+
/** 样式列表 */
|
12014
|
+
const [styleList, setStyleList] = useState([]);
|
12015
|
+
const styleListRef = useRef();
|
12016
|
+
/** 自定义骨架屏高度 */
|
12017
|
+
const heightList = [170, 230, 300];
|
12018
|
+
/** 到达底部 */
|
12019
|
+
const [isLoadingData, setIsLoadingData] = useState(false);
|
12020
|
+
const [list, setList] = useState([]);
|
12021
|
+
const buttonRef = useRef();
|
12022
|
+
/** 生成随机数 */
|
12023
|
+
const createRandomNum = useCallback((min, max) => {
|
12024
|
+
return Math.floor(Math.random() * (max - min + 1)) + min;
|
12025
|
+
}, []);
|
12026
|
+
const waterfallFlowListInfo = useRef([]);
|
12027
|
+
/** 当前容器信息 */
|
12028
|
+
const [frameInfo, setFrameInfoInfo] = useState({ width: 0 });
|
12029
|
+
/** 每行个数 */
|
12030
|
+
const rowsNum = useMemo(() => {
|
12031
|
+
const width = frameInfo.width || 0;
|
12032
|
+
if (width >= 1200) {
|
12033
|
+
return 6;
|
12034
|
+
}
|
12035
|
+
else if (width >= 768 && width <= 1199) {
|
12036
|
+
return 4;
|
12037
|
+
}
|
12038
|
+
else {
|
12039
|
+
return 2;
|
12040
|
+
}
|
12041
|
+
}, [frameInfo]);
|
12042
|
+
/** 每一个的宽度 */
|
12043
|
+
const unitWidth = useMemo(() => {
|
12044
|
+
return frameInfo.width / rowsNum - 2;
|
12045
|
+
}, [rowsNum, frameInfo]);
|
12046
|
+
/** 获取位置 */
|
12047
|
+
const getStyleList = useCallback(() => {
|
12048
|
+
var _a;
|
12049
|
+
const temporaryStyleList = (_a = styleListRef.current) !== null && _a !== void 0 ? _a : [];
|
12050
|
+
/** 目前最下一行的index */
|
12051
|
+
const bottomItemIndex = [];
|
12052
|
+
for (let i = 0; i < (list === null || list === void 0 ? void 0 : list.length); i++) {
|
12053
|
+
// 原本应对应的行数
|
12054
|
+
const currentRow = Math.floor(i / rowsNum);
|
12055
|
+
//
|
12056
|
+
const remainder = (i % rowsNum) + 1;
|
12057
|
+
// 最低item下标
|
12058
|
+
let minHeightInd = 0;
|
12059
|
+
// 最低高度
|
12060
|
+
let minHeight = 9999999999;
|
12061
|
+
// 寻找最低高度的下标
|
12062
|
+
if (currentRow === 0) {
|
12063
|
+
bottomItemIndex[i] = i;
|
12064
|
+
}
|
12065
|
+
else {
|
12066
|
+
for (let j = 0; j < bottomItemIndex.length; j++) {
|
12067
|
+
if (waterfallFlowListInfo.current[bottomItemIndex[j]].top +
|
12068
|
+
waterfallFlowListInfo.current[bottomItemIndex[j]].height <
|
12069
|
+
minHeight) {
|
12070
|
+
minHeightInd = j;
|
12071
|
+
minHeight =
|
12072
|
+
waterfallFlowListInfo.current[bottomItemIndex[j]].top +
|
12073
|
+
waterfallFlowListInfo.current[bottomItemIndex[j]].height;
|
12074
|
+
}
|
12075
|
+
}
|
12076
|
+
bottomItemIndex[minHeightInd] = i;
|
12077
|
+
}
|
12078
|
+
if (waterfallFlowListInfo.current[i] === undefined) {
|
12079
|
+
waterfallFlowListInfo.current[i] = {};
|
12080
|
+
}
|
12081
|
+
// 第一行特殊处理,一定是从左到右铺的
|
12082
|
+
if (currentRow === 0) {
|
12083
|
+
if (remainder === 1) {
|
12084
|
+
waterfallFlowListInfo.current[i].left = 0;
|
12085
|
+
}
|
12086
|
+
else {
|
12087
|
+
waterfallFlowListInfo.current[i].left = waterfallFlowListInfo.current[i - 1].left + unitWidth + 4;
|
12088
|
+
}
|
12089
|
+
waterfallFlowListInfo.current[i].top = 0;
|
12090
|
+
}
|
12091
|
+
// 剩下的行数,铺在当前最低高度下面
|
12092
|
+
else {
|
12093
|
+
waterfallFlowListInfo.current[i].left = waterfallFlowListInfo.current[minHeightInd].left;
|
12094
|
+
waterfallFlowListInfo.current[i].top = minHeight;
|
12095
|
+
}
|
12096
|
+
// 是否已经有高度,有高度使用已有高度,否则随机生成
|
12097
|
+
waterfallFlowListInfo.current[i].height =
|
12098
|
+
waterfallFlowListInfo.current[i].height || heightList[createRandomNum(0, 2)];
|
12099
|
+
temporaryStyleList[i] = {
|
12100
|
+
transform: `translate(${waterfallFlowListInfo.current[i].left}px,${waterfallFlowListInfo.current[i].top}px)`,
|
12101
|
+
width: `${unitWidth}px`,
|
12102
|
+
height: waterfallFlowListInfo.current[i].height
|
12103
|
+
};
|
12104
|
+
}
|
12105
|
+
setStyleList([...temporaryStyleList]);
|
12106
|
+
return [...temporaryStyleList];
|
12107
|
+
}, [unitWidth, rowsNum, heightList, createRandomNum, list]);
|
12108
|
+
/** 图片加载完更新高度 */
|
12109
|
+
const onSizeChange = useCallback((height, index) => {
|
12110
|
+
if (waterfallFlowListInfo.current[index] === undefined) {
|
12111
|
+
waterfallFlowListInfo.current[index] = {};
|
12112
|
+
}
|
12113
|
+
waterfallFlowListInfo.current[index].height = height;
|
12114
|
+
styleListRef.current = getStyleList();
|
12115
|
+
}, [getStyleList]);
|
12116
|
+
/** 大小、数量发生变化时触发 */
|
12117
|
+
useEffect(() => {
|
12118
|
+
styleListRef.current = getStyleList();
|
12119
|
+
}, [unitWidth, rowsNum, list]); /* 增加getStyleList依赖项会导致在admin预览编辑时无限刷新 */
|
12120
|
+
/** 初始化请求数据 */
|
12121
|
+
useEffect(() => {
|
12122
|
+
var _a, _b;
|
12123
|
+
setIsLoadingData(true);
|
12124
|
+
waterFallData &&
|
12125
|
+
(getRecommendVideos === null || getRecommendVideos === void 0 ? void 0 : getRecommendVideos({
|
12126
|
+
hashTag: waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag,
|
12127
|
+
'itemFilter.itemId': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemId,
|
12128
|
+
'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType,
|
12129
|
+
defaultSize: hashTagSize,
|
12130
|
+
maxSize: hashTagSize
|
12131
|
+
}).then((res) => {
|
12132
|
+
var _a, _b;
|
12133
|
+
setData(res);
|
12134
|
+
setList((_b = (_a = res === null || res === void 0 ? void 0 : res.recList) === null || _a === void 0 ? void 0 : _a.filter((item) => (item === null || item === void 0 ? void 0 : item.video) !== null || (item === null || item === void 0 ? void 0 : item.product) !== null)) !== null && _b !== void 0 ? _b : []);
|
12135
|
+
setIsLoadingData(false);
|
12136
|
+
}));
|
12137
|
+
if (isOpenHashTag) {
|
12138
|
+
const res = previewData;
|
12139
|
+
setData(res);
|
12140
|
+
setList((_b = (_a = res === null || res === void 0 ? void 0 : res.recList) === null || _a === void 0 ? void 0 : _a.filter((item) => (item === null || item === void 0 ? void 0 : item.video) !== null || (item === null || item === void 0 ? void 0 : item.product) !== null)) !== null && _b !== void 0 ? _b : []);
|
12141
|
+
setIsLoadingData(false);
|
12142
|
+
}
|
12143
|
+
}, [waterFallData, getRecommendVideos, hashTagSize, isOpenHashTag]);
|
12144
|
+
const onResize = useCallback(() => {
|
12145
|
+
if (waterfallFlowDom.current === null) {
|
12146
|
+
return;
|
12147
|
+
}
|
12148
|
+
setFrameInfoInfo({
|
12149
|
+
width: waterfallFlowDom.current.getBoundingClientRect().width
|
12150
|
+
});
|
12151
|
+
}, []);
|
12152
|
+
/** 监听列表容器大小变化 */
|
12153
|
+
useEffect(() => {
|
12154
|
+
if (waterfallFlowDom.current === null) {
|
12155
|
+
return;
|
12156
|
+
}
|
12157
|
+
const resizeObserver = new ResizeObserver((entries) => {
|
12158
|
+
onResize();
|
12159
|
+
});
|
12160
|
+
resizeObserver.observe(waterfallFlowDom.current);
|
12161
|
+
return () => {
|
12162
|
+
resizeObserver.disconnect();
|
12163
|
+
};
|
12164
|
+
}, [onResize]);
|
12165
|
+
useCallback(() => {
|
12166
|
+
setIsLoadingData(true);
|
12167
|
+
waterFallData &&
|
12168
|
+
(getRecommendVideos === null || getRecommendVideos === void 0 ? void 0 : getRecommendVideos({
|
12169
|
+
hashTag: waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag,
|
12170
|
+
'itemFilter.itemId': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemId,
|
12171
|
+
'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType
|
12172
|
+
}).then((res) => {
|
12173
|
+
var _a, _b;
|
12174
|
+
setList(list === null || list === void 0 ? void 0 : list.concat((_b = (_a = res === null || res === void 0 ? void 0 : res.recList) === null || _a === void 0 ? void 0 : _a.filter((item) => !(item === null || item === void 0 ? void 0 : item.video))) !== null && _b !== void 0 ? _b : []));
|
12175
|
+
setIsLoadingData(false);
|
12176
|
+
}));
|
12177
|
+
}, [waterFallData, getRecommendVideos, list]);
|
12178
|
+
const onScroll = useCallback(() => {
|
12179
|
+
// 记录滚动值
|
12180
|
+
setScrollTop(scrollParent.current.scrollTop);
|
12181
|
+
// const top = (scrollParent.current as any).scrollTop;
|
12182
|
+
// const clientHeight = (scrollParent.current as any).clientHeight;
|
12183
|
+
// const scrollHeight = (scrollParent.current as any).scrollHeight;
|
12184
|
+
// // 做底部加载
|
12185
|
+
// if (scrollHeight <= top + clientHeight && !isLoadingData) {
|
12186
|
+
// loadMoreData();
|
12187
|
+
// }
|
12188
|
+
}, []);
|
12189
|
+
/** 监听滚动 */
|
12190
|
+
useEffect(() => {
|
12191
|
+
var _a;
|
12192
|
+
(_a = scrollParent === null || scrollParent === void 0 ? void 0 : scrollParent.current) === null || _a === void 0 ? void 0 : _a.addEventListener('scroll', onScroll);
|
12193
|
+
return () => {
|
12194
|
+
var _a;
|
12195
|
+
(_a = scrollParent === null || scrollParent === void 0 ? void 0 : scrollParent.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('scroll', onScroll);
|
12196
|
+
};
|
12197
|
+
}, [onScroll, scrollParent]);
|
12198
|
+
const handleClickLink = () => {
|
12199
|
+
var _a, _b;
|
12200
|
+
if ((_a = data === null || data === void 0 ? void 0 : data.tag) === null || _a === void 0 ? void 0 : _a.link) {
|
12201
|
+
reportTagsView();
|
12202
|
+
window.location.href = (_b = data === null || data === void 0 ? void 0 : data.tag) === null || _b === void 0 ? void 0 : _b.link;
|
12203
|
+
}
|
12204
|
+
};
|
12205
|
+
return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
|
12206
|
+
React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'waterFallList', ref: waterfallFlowDom },
|
12207
|
+
React.createElement("div", { className: 'waterFallList-scroll', ref: scrollParent },
|
12208
|
+
React.createElement("div", { className: 'waterFallList-info', style: (_b = props === null || props === void 0 ? void 0 : props.textStyles) === null || _b === void 0 ? void 0 : _b.hashTagDesc }, (_c = data === null || data === void 0 ? void 0 : data.tag) === null || _c === void 0 ? void 0 : _c.info),
|
12209
|
+
React.createElement("div", { hidden: !((_d = data === null || data === void 0 ? void 0 : data.tag) === null || _d === void 0 ? void 0 : _d.link), className: 'waterFallList-collection', style: Object.assign({}, (_e = props === null || props === void 0 ? void 0 : props.textStyles) === null || _e === void 0 ? void 0 : _e.hashTagLink), onClick: handleClickLink }, ((_f = data === null || data === void 0 ? void 0 : data.tag) === null || _f === void 0 ? void 0 : _f.linkTitle) || 'Shop the collection'),
|
12210
|
+
React.createElement("div", { className: 'waterFallList-content' }, list === null || list === void 0 ? void 0 :
|
12211
|
+
list.map((item, ind) => {
|
12212
|
+
var _a;
|
12213
|
+
return (React.createElement(WaterfallFlowItem$1, Object.assign({ key: ind, index: ind, rec: item, list: list, showBorder: scrollTop + ((_a = scrollParent === null || scrollParent === void 0 ? void 0 : scrollParent.current) === null || _a === void 0 ? void 0 : _a.clientHeight), style: styleList[ind], sizeChange: onSizeChange, unitWidth: unitWidth, reportTagsView: reportTagsView }, props)));
|
12214
|
+
}),
|
12215
|
+
React.createElement("div", { hidden: !((_g = data === null || data === void 0 ? void 0 : data.tag) === null || _g === void 0 ? void 0 : _g.link), style: {
|
12216
|
+
position: 'absolute',
|
12217
|
+
width: '100%',
|
12218
|
+
transform: `translate(0px,${(_m = ((_j = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current[((_h = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current) === null || _h === void 0 ? void 0 : _h.length) - 1]) === null || _j === void 0 ? void 0 : _j.top) +
|
12219
|
+
((_l = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current[((_k = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current) === null || _k === void 0 ? void 0 : _k.length) - 1]) === null || _l === void 0 ? void 0 : _l.height)) !== null && _m !== void 0 ? _m : 0}px)`,
|
12220
|
+
height: ((_o = data === null || data === void 0 ? void 0 : data.tag) === null || _o === void 0 ? void 0 : _o.link)
|
12221
|
+
? ((_p = buttonRef === null || buttonRef === void 0 ? void 0 : buttonRef.current) === null || _p === void 0 ? void 0 : _p.offsetHeight) || ((_q = props === null || props === void 0 ? void 0 : props.buttonBgStyle) === null || _q === void 0 ? void 0 : _q.height) || '100px'
|
12222
|
+
: 0
|
12223
|
+
} }))),
|
12224
|
+
React.createElement("div", { className: 'waterFallList-bottom', hidden: !((_r = data === null || data === void 0 ? void 0 : data.tag) === null || _r === void 0 ? void 0 : _r.link), style: props === null || props === void 0 ? void 0 : props.buttonBgStyle }),
|
12225
|
+
React.createElement("div", { ref: buttonRef, hidden: !((_s = data === null || data === void 0 ? void 0 : data.tag) === null || _s === void 0 ? void 0 : _s.link), className: 'waterFallList-btn-wrap', style: Object.assign(Object.assign({}, props === null || props === void 0 ? void 0 : props.buttonBgStyle), { height: 'auto', backgroundColor: 'transparent' }) },
|
12226
|
+
React.createElement("button", { className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_t = data === null || data === void 0 ? void 0 : data.tag) === null || _t === void 0 ? void 0 : _t.linkTitle) || 'Shop the collection'))))));
|
12227
|
+
}
|
12228
|
+
|
12229
|
+
var img$1 = "";
|
12230
|
+
|
11822
12231
|
const WaterfallFlowItem = (props) => {
|
11823
12232
|
const { rec, index, list, reportTagsView, textStyles, space } = props;
|
11824
12233
|
const { swiperRef, setRtcList, setOpenHashtag, bffEventReport, sxpParameter } = useSxpDataSource();
|
@@ -12029,13 +12438,11 @@ function WaterfallList(_a) {
|
|
12029
12438
|
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'))))));
|
12030
12439
|
}
|
12031
12440
|
|
12032
|
-
var img$1 = "";
|
12033
|
-
|
12034
12441
|
/*
|
12035
12442
|
* @Author: binruan@chatlabs.com
|
12036
12443
|
* @Date: 2024-01-10 10:58:24
|
12037
12444
|
* @LastEditors: binruan@chatlabs.com
|
12038
|
-
* @LastEditTime: 2024-
|
12445
|
+
* @LastEditTime: 2024-06-07 15:57:29
|
12039
12446
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
|
12040
12447
|
*
|
12041
12448
|
*/
|
@@ -12129,7 +12536,7 @@ const WaterFall = (props) => {
|
|
12129
12536
|
display: openHashtag ? 'block' : 'none'
|
12130
12537
|
} },
|
12131
12538
|
React.createElement(Navbar$1, { icon: img$1, styles: { top: '32px' }, textStyle: (_a = props === null || props === void 0 ? void 0 : props.textStyles) === null || _a === void 0 ? void 0 : _a.hashTagTitle, onClose: handleClose }),
|
12132
|
-
React.createElement(WaterfallList, Object.assign({ reportTagsView: reportTagsView }, props))), modalEleRef.current);
|
12539
|
+
(props === null || props === void 0 ? void 0 : props.isWaterfallFlow) === true || (props === null || props === void 0 ? void 0 : props.isWaterfallFlow) === undefined ? (React.createElement(WaterfallList, Object.assign({ reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList$1, Object.assign({ reportTagsView: reportTagsView }, props)))), modalEleRef.current);
|
12133
12540
|
};
|
12134
12541
|
var WaterFall$1 = memo(WaterFall);
|
12135
12542
|
|
@@ -12653,7 +13060,7 @@ const FingerSwipeTip = ({ imageUrl, style }) => {
|
|
12653
13060
|
*
|
12654
13061
|
*/
|
12655
13062
|
const Picture = (props) => {
|
12656
|
-
const { src, height, imgUrlsPostConfig } = props;
|
13063
|
+
const { src, height, imgUrlsPostConfig, onShowFirstImage } = props;
|
12657
13064
|
const blur = useMemo(() => {
|
12658
13065
|
return (imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.mode) === '2';
|
12659
13066
|
}, [imgUrlsPostConfig]);
|
@@ -12678,7 +13085,7 @@ const Picture = (props) => {
|
|
12678
13085
|
return isBgColor && (imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.bgColor) ? { backgroundColor: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.bgColor } : {};
|
12679
13086
|
}, [imgUrlsPostConfig, isBgColor]);
|
12680
13087
|
return (React.createElement("div", { style: Object.assign({ overflow: 'hidden', height, width: '100%', position: 'relative' }, bgStyle) },
|
12681
|
-
(!blur || !isBgColor) && (React.createElement(FormatImage$1, { src: src, style: Object.assign({ height: '100%', width: '100%', objectFit: 'cover' }, blurStyle) })),
|
13088
|
+
(!blur || !isBgColor) && (React.createElement(FormatImage$1, { src: src, style: Object.assign({ height: '100%', width: '100%', objectFit: 'cover' }, blurStyle), onLoad: onShowFirstImage })),
|
12682
13089
|
blur && (React.createElement(FormatImage$1, { src: src, style: {
|
12683
13090
|
width: '100%',
|
12684
13091
|
height: '100%',
|
@@ -12695,7 +13102,7 @@ const Picture = (props) => {
|
|
12695
13102
|
* @Author: lewinlu@chatlabs.com
|
12696
13103
|
* @Date: 2024-01-03 14:39:09
|
12697
13104
|
* @LastEditors: binruan@chatlabs.com
|
12698
|
-
* @LastEditTime: 2024-
|
13105
|
+
* @LastEditTime: 2024-06-07 14:05:08
|
12699
13106
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
|
12700
13107
|
*/
|
12701
13108
|
const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
|
@@ -12715,16 +13122,20 @@ const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageE
|
|
12715
13122
|
}
|
12716
13123
|
}
|
12717
13124
|
else {
|
12718
|
-
setIsLoad(true);
|
12719
13125
|
(ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.swiper.autoplay.stop();
|
12720
13126
|
}
|
12721
13127
|
}, [rec, isActive, onReportViewImageEnd, openHashtag, index, onViewImageStartEvent, isLoad]);
|
13128
|
+
const showFirstImageFn = useCallback(() => {
|
13129
|
+
if (!isLoad) {
|
13130
|
+
setIsLoad(true);
|
13131
|
+
}
|
13132
|
+
}, [isLoad]);
|
12722
13133
|
// if (!isActive) {
|
12723
13134
|
// return <img src={sxpParameter?.placeholder_image} style={{ width, height, objectFit: 'cover' }} />;
|
12724
13135
|
// }
|
12725
|
-
return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: { clickable: true, bulletActiveClass: 'swipe-item-active-bullet' }, 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) => {
|
12726
|
-
return (React.createElement(SwiperSlide, { key:
|
12727
|
-
React.createElement(Picture, { src: url, height: height, imgUrlsPostConfig: imgUrlsPostConfig })));
|
13136
|
+
return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: { clickable: true, bulletActiveClass: 'swipe-item-active-bullet' }, 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) => {
|
13137
|
+
return (React.createElement(SwiperSlide, { key: index },
|
13138
|
+
React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
|
12728
13139
|
})));
|
12729
13140
|
};
|
12730
13141
|
var PictureGroup$3 = memo(PictureGroup$2);
|
@@ -12944,7 +13355,7 @@ var Tagbar$1 = memo(Tagbar);
|
|
12944
13355
|
* @Author: binruan@chatlabs.com
|
12945
13356
|
* @Date: 2024-01-15 19:03:09
|
12946
13357
|
* @LastEditors: binruan@chatlabs.com
|
12947
|
-
* @LastEditTime: 2024-06-
|
13358
|
+
* @LastEditTime: 2024-06-07 11:10:42
|
12948
13359
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
|
12949
13360
|
*
|
12950
13361
|
*/
|
@@ -12971,32 +13382,11 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
12971
13382
|
return;
|
12972
13383
|
}
|
12973
13384
|
initTime();
|
12974
|
-
// 刷新 sessionId
|
12975
|
-
// refreshFeSessionId();
|
12976
|
-
const queryString = location.search.slice(1);
|
12977
|
-
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
12978
|
-
for (const key in params) {
|
12979
|
-
params[key] = params[key].replace(/%2B/g, '+');
|
12980
|
-
}
|
12981
|
-
const getVal = (key) => { var _a; return (_a = params[key]) !== null && _a !== void 0 ? _a : ''; };
|
12982
|
-
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
12983
|
-
eventInfo: {
|
12984
|
-
eventSubject: 'h5LinkEnterFeed',
|
12985
|
-
eventDescription: 'User enter h5 link',
|
12986
|
-
utmSource: getVal('utm_source'),
|
12987
|
-
utmMedium: getVal('utm_medium'),
|
12988
|
-
utmCampaign: getVal('utm_campaign'),
|
12989
|
-
utmId: getVal('utm_id'),
|
12990
|
-
utmContent: getVal('utm_content'),
|
12991
|
-
enterTime: `${Date.now()}`,
|
12992
|
-
requestId: null
|
12993
|
-
}
|
12994
|
-
});
|
12995
13385
|
bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
|
12996
13386
|
eventName: 'PageView'
|
12997
13387
|
});
|
12998
13388
|
setIsInit(true);
|
12999
|
-
}, [
|
13389
|
+
}, [data.length, bffFbReport]);
|
13000
13390
|
const initTime = () => {
|
13001
13391
|
curTime.current = new Date();
|
13002
13392
|
viewTime.current = new Date();
|
@@ -13049,26 +13439,6 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13049
13439
|
})) || 0;
|
13050
13440
|
(_a = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _a === void 0 ? void 0 : _a.swiper.slideTo(index);
|
13051
13441
|
}, [ctaType, swiperRef]);
|
13052
|
-
// useEffect(() => {
|
13053
|
-
// const handleBeforeUnload = (event: any) => {
|
13054
|
-
// event.preventDefault();
|
13055
|
-
// const item = data?.[activeIndex];
|
13056
|
-
// bffEventReport?.({
|
13057
|
-
// eventInfo: {
|
13058
|
-
// sessionDuration: Math.floor(((new Date() as any) - curTime) / 1000) + '',
|
13059
|
-
// eventSubject: 'sessionCompleted',
|
13060
|
-
// eventDescription: 'Session completed',
|
13061
|
-
// contentId: item?.video?.itemId,
|
13062
|
-
// productId: item?.product?.itemId,
|
13063
|
-
// position: item?.position
|
13064
|
-
// }
|
13065
|
-
// });
|
13066
|
-
// };
|
13067
|
-
// window.addEventListener('beforeunload', handleBeforeUnload);
|
13068
|
-
// return () => {
|
13069
|
-
// window.removeEventListener('beforeunload', handleBeforeUnload);
|
13070
|
-
// };
|
13071
|
-
// }, [activeIndex, data, bffEventReport, curTime]);
|
13072
13442
|
useEffect(() => {
|
13073
13443
|
const item = data === null || data === void 0 ? void 0 : data[activeIndex];
|
13074
13444
|
const visibleChange = () => {
|