pb-sxp-ui 1.0.77 → 1.0.79

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.css CHANGED
@@ -836,6 +836,124 @@
836
836
  box-sizing: border-box;
837
837
  }
838
838
 
839
+ .list {
840
+ position: absolute;
841
+ bottom: 0;
842
+ left: 0;
843
+ right: 0;
844
+ top: 70px;
845
+ }
846
+ .list-scroll {
847
+ position: absolute;
848
+ top: 0;
849
+ width: 100%;
850
+ height: 100%;
851
+ overflow: auto;
852
+ }
853
+ .list-info {
854
+ font-size: 13px;
855
+ line-height: 20px;
856
+ padding: 0 54px;
857
+ text-align: center;
858
+ }
859
+ .list-collection {
860
+ margin-top: 4px;
861
+ margin-left: auto;
862
+ margin-right: auto;
863
+ margin-bottom: 40px;
864
+ text-align: center;
865
+ color: #757575;
866
+ font-size: 12px;
867
+ text-decoration: underline;
868
+ cursor: pointer;
869
+ }
870
+ .list-content {
871
+ display: -webkit-box;
872
+ display: -webkit-flex;
873
+ display: -ms-flexbox;
874
+ display: flex;
875
+ -webkit-flex-wrap: wrap;
876
+ -ms-flex-wrap: wrap;
877
+ flex-wrap: wrap;
878
+ -webkit-box-pack: justify;
879
+ -webkit-justify-content: space-between;
880
+ -ms-flex-pack: justify;
881
+ justify-content: space-between;
882
+ }
883
+ .list-content-listItem {
884
+ width: 49.5%;
885
+ margin-bottom: 40px;
886
+ cursor: pointer;
887
+ }
888
+ .list-content-listItem-picture {
889
+ position: relative;
890
+ width: 100%;
891
+ padding-bottom: 100%;
892
+ overflow: hidden;
893
+ }
894
+ .list-content-listItem-picture-img {
895
+ position: absolute;
896
+ width: 100%;
897
+ height: 100%;
898
+ -o-object-fit: cover;
899
+ object-fit: cover;
900
+ }
901
+ .list-content-listItem-info {
902
+ padding: 8px;
903
+ }
904
+ .list-content-listItem-info-title {
905
+ font-size: 13px;
906
+ line-height: 20px;
907
+ line-clamp: 2;
908
+ overflow: hidden;
909
+ text-overflow: ellipsis;
910
+ display: -webkit-box;
911
+ -webkit-box-orient: vertical;
912
+ -webkit-line-clamp: 2;
913
+ }
914
+ .list-content-listItem-info-nowrap {
915
+ line-clamp: 1 !important;
916
+ -webkit-line-clamp: 1 !important;
917
+ }
918
+ .list-content-listItem-info-price {
919
+ font-size: 13px;
920
+ line-height: 20px;
921
+ font-weight: bold;
922
+ }
923
+ .list-bottom {
924
+ position: absolute;
925
+ left: 0;
926
+ right: 0;
927
+ bottom: 0;
928
+ background-color: #fff;
929
+ -webkit-box-sizing: content-box;
930
+ box-sizing: content-box;
931
+ height: 92px;
932
+ }
933
+ .list-btn-wrap {
934
+ position: absolute;
935
+ left: 0;
936
+ right: 0;
937
+ bottom: 0;
938
+ padding: 20px;
939
+ -webkit-box-sizing: border-box;
940
+ box-sizing: border-box;
941
+ }
942
+ .list-btn {
943
+ height: 52px;
944
+ width: 100%;
945
+ background: #000000;
946
+ border-radius: 25px;
947
+ font-size: 13px;
948
+ line-height: 100%;
949
+ font-weight: bold;
950
+ color: #fff;
951
+ border: none;
952
+ cursor: pointer;
953
+ -webkit-box-sizing: border-box;
954
+ box-sizing: border-box;
955
+ }
956
+
839
957
  /**
840
958
  * Swiper 11.0.7
841
959
  * Most modern mobile touch slider and framework with hardware accelerated transitions
package/dist/index.js CHANGED
@@ -627,6 +627,12 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
627
627
  setCacheRtcList((_b = data === null || data === void 0 ? void 0 : data.recList) !== null && _b !== void 0 ? _b : []);
628
628
  })
629
629
  .finally(() => {
630
+ bffEventReport({
631
+ eventInfo: {
632
+ eventSubject: 'apiRequest',
633
+ eventDescription: 'api request succeed'
634
+ }
635
+ });
630
636
  setLoading(false);
631
637
  isInit.current = true;
632
638
  });
@@ -11829,7 +11835,7 @@ var previewData = {
11829
11835
  hashTag: hashTag
11830
11836
  };
11831
11837
 
11832
- const WaterfallFlowItem = (props) => {
11838
+ const WaterfallFlowItem$1 = (props) => {
11833
11839
  const { rec, style = {}, sizeChange = () => { }, unitWidth, index, showBorder, list, reportTagsView, textStyles, space } = props;
11834
11840
  const { swiperRef, setRtcList, setOpenHashtag, sxpParameter } = useSxpDataSource();
11835
11841
  const [showVideo, setShowVideo] = useState(false);
@@ -11893,29 +11899,8 @@ const WaterfallFlowItem = (props) => {
11893
11899
  return null;
11894
11900
  }
11895
11901
  }, [rec]);
11896
- // useEffect(() => {
11897
- // const observer = new IntersectionObserver((entries) => {
11898
- // entries.forEach((entry) => {
11899
- // if (entry.isIntersecting) {
11900
- // if (ref.current === null || src === '') {
11901
- // return;
11902
- // }
11903
- // if (showVideo && firstFrameSrc) {
11904
- // imgDom.current.setSrc(firstFrameSrc);
11905
- // } else {
11906
- // imgDom.current.setSrc(src);
11907
- // }
11908
- // observer.unobserve(ref.current);
11909
- // }
11910
- // });
11911
- // });
11912
- // observer.observe(ref.current);
11913
- // return () => {
11914
- // observer.disconnect();
11915
- // };
11916
- // }, [src, showVideo, firstFrameSrc]);
11917
11902
  useEffect(() => {
11918
- if (imgDom.current === null || src === '' || isImgShow === false) {
11903
+ if (imgDom.current === null || src === '') {
11919
11904
  return;
11920
11905
  }
11921
11906
  const img = new Image();
@@ -11932,8 +11917,7 @@ const WaterfallFlowItem = (props) => {
11932
11917
  });
11933
11918
  setIsLoading(true);
11934
11919
  };
11935
- // imgDom.current.setSrc(img.src);
11936
- imgDom.current.src = img.src;
11920
+ imgDom.current.setSrc(img.src);
11937
11921
  }, [src, showVideo, firstFrameSrc, isImgShow]);
11938
11922
  useEffect(() => {
11939
11923
  // 通过宽度比例获取图片高度
@@ -11985,12 +11969,12 @@ const WaterfallFlowItem = (props) => {
11985
11969
  showVideo && (React.createElement("div", { style: { display: 'none' } },
11986
11970
  React.createElement("video", { ref: videoDom, src: src, crossOrigin: 'anonymous', className: 'waterFallList-content-listItem-picture-img' }),
11987
11971
  React.createElement("canvas", { ref: canvasRef }))),
11988
- React.createElement("img", { loading: 'lazy', className: 'waterFallList-content-listItem-picture-img', ref: imgDom })),
11972
+ React.createElement(FormatImage$1, { loading: 'lazy', className: 'waterFallList-content-listItem-picture-img', ref: imgDom })),
11989
11973
  React.createElement("div", { className: 'waterFallList-content-listItem-info' },
11990
11974
  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),
11991
11975
  React.createElement("div", { className: 'waterFallList-content-listItem-info-price', hidden: !priceText, style: textStyles.price }, priceText))));
11992
11976
  };
11993
- function WaterfallList(_a) {
11977
+ function WaterfallList$1(_a) {
11994
11978
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
11995
11979
  var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
11996
11980
  const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
@@ -12201,7 +12185,7 @@ function WaterfallList(_a) {
12201
12185
  React.createElement("div", { className: 'waterFallList-content' }, list === null || list === void 0 ? void 0 :
12202
12186
  list.map((item, ind) => {
12203
12187
  var _a;
12204
- return (React.createElement(WaterfallFlowItem, 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)));
12188
+ 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)));
12205
12189
  }),
12206
12190
  React.createElement("div", { hidden: !((_g = data === null || data === void 0 ? void 0 : data.tag) === null || _g === void 0 ? void 0 : _g.link), style: {
12207
12191
  position: 'absolute',
@@ -12219,11 +12203,221 @@ function WaterfallList(_a) {
12219
12203
 
12220
12204
  var img$1 = "";
12221
12205
 
12206
+ const WaterfallFlowItem = (props) => {
12207
+ const { rec, index, list, reportTagsView, textStyles, space } = props;
12208
+ const { swiperRef, setRtcList, setOpenHashtag, bffEventReport, sxpParameter } = useSxpDataSource();
12209
+ const [showVideo, setShowVideo] = useState(false);
12210
+ const imgDom = useRef(null);
12211
+ const ref = useRef(null);
12212
+ const videoDom = useRef(null);
12213
+ const canvasRef = useRef(null);
12214
+ const [firstFrameSrc, setFirstFrameSrc] = useState('');
12215
+ const src = useMemo(() => {
12216
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
12217
+ if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) {
12218
+ return (_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.cover;
12219
+ }
12220
+ 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) {
12221
+ 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];
12222
+ }
12223
+ 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) {
12224
+ 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];
12225
+ }
12226
+ else {
12227
+ return (sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) || '';
12228
+ }
12229
+ }, [rec, sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image]);
12230
+ const title = useMemo(() => {
12231
+ var _a, _b;
12232
+ 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;
12233
+ }, [rec]);
12234
+ const priceText = useMemo(() => {
12235
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
12236
+ 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)) {
12237
+ 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', {
12238
+ minimumFractionDigits: 0
12239
+ })) !== null && _j !== void 0 ? _j : ''}`;
12240
+ }
12241
+ else {
12242
+ return null;
12243
+ }
12244
+ }, [rec]);
12245
+ // useEffect(() => {
12246
+ // if (imgDom.current === null || src === '') {
12247
+ // return;
12248
+ // }
12249
+ // const img = new Image();
12250
+ // if (showVideo && firstFrameSrc) {
12251
+ // img.src = firstFrameSrc;
12252
+ // } else {
12253
+ // img.src = src;
12254
+ // }
12255
+ // // img.onload = () => {
12256
+ // // setIsLoading(true);
12257
+ // // };
12258
+ // imgDom.current.src = img.src;
12259
+ // }, [src, showVideo, firstFrameSrc]);
12260
+ useEffect(() => {
12261
+ const observer = new IntersectionObserver((entries) => {
12262
+ entries.forEach((entry) => {
12263
+ if (entry.isIntersecting) {
12264
+ if (ref.current === null || src === '') {
12265
+ return;
12266
+ }
12267
+ if (showVideo && firstFrameSrc) {
12268
+ imgDom.current.setSrc(firstFrameSrc);
12269
+ }
12270
+ else {
12271
+ imgDom.current.setSrc(src);
12272
+ }
12273
+ observer.unobserve(ref.current);
12274
+ }
12275
+ });
12276
+ });
12277
+ observer.observe(ref.current);
12278
+ return () => {
12279
+ observer.disconnect();
12280
+ };
12281
+ }, [src, showVideo, firstFrameSrc]);
12282
+ const calculateHeightForWidth = (videoWidth, videoHeight, targetWidth) => {
12283
+ const aspectRatio = videoWidth / videoHeight;
12284
+ const targetHeight = targetWidth / aspectRatio;
12285
+ return targetHeight;
12286
+ };
12287
+ useEffect(() => {
12288
+ const video = videoDom === null || videoDom === void 0 ? void 0 : videoDom.current;
12289
+ if (video === null || src === '' || !showVideo) {
12290
+ return;
12291
+ }
12292
+ video.src = src;
12293
+ video.currentTime = 1;
12294
+ video.crossOrigin = 'anonymous';
12295
+ video.onloadeddata = () => {
12296
+ const canvas = canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.current;
12297
+ if (!canvas)
12298
+ return;
12299
+ const ctx = canvas.getContext('2d');
12300
+ const targetWidth = (window === null || window === void 0 ? void 0 : window.innerWidth) / 2;
12301
+ const targetHeight = calculateHeightForWidth(video.videoWidth, video.videoHeight, targetWidth);
12302
+ canvas.height = targetHeight;
12303
+ canvas.width = targetWidth;
12304
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
12305
+ setFirstFrameSrc(canvas.toDataURL());
12306
+ video.remove();
12307
+ canvas.remove();
12308
+ };
12309
+ }, [src, showVideo]);
12310
+ const handleClickToDetail = () => {
12311
+ reportTagsView();
12312
+ setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(list);
12313
+ setTimeout(() => {
12314
+ var _a;
12315
+ (_a = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _a === void 0 ? void 0 : _a.swiper.slideTo(index, 0, false);
12316
+ setOpenHashtag === null || setOpenHashtag === void 0 ? void 0 : setOpenHashtag(false);
12317
+ }, 0);
12318
+ };
12319
+ return (React.createElement("div", { ref: ref, className: 'list-content-listItem', key: index, onClick: handleClickToDetail, style: { marginBottom: space } },
12320
+ React.createElement("div", { className: 'list-content-listItem-picture' },
12321
+ showVideo && (React.createElement("div", { style: { display: 'none' } },
12322
+ React.createElement("video", { ref: videoDom, crossOrigin: 'anonymous', className: 'list-content-listItem-picture-img' }),
12323
+ React.createElement("canvas", { ref: canvasRef }))),
12324
+ React.createElement(FormatImage$1, { loading: 'lazy', className: 'list-content-listItem-picture-img', ref: imgDom })),
12325
+ React.createElement("div", { className: 'list-content-listItem-info' },
12326
+ React.createElement("div", { className: `${'list-content-listItem-info-title'} ${priceText ? 'list-content-listItem-info-nowrap' : ''}`, style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.title }, title && title),
12327
+ React.createElement("div", { className: 'list-content-listItem-info-price', style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.price, hidden: !priceText }, priceText))));
12328
+ };
12329
+ function WaterfallList(_a) {
12330
+ var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
12331
+ var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
12332
+ const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
12333
+ const [list, setList] = useState();
12334
+ const [data, setData] = useState();
12335
+ const [isLoadingData, setIsLoadingData] = useState(false);
12336
+ const containerRef = useRef(null);
12337
+ const [isLoadMore, setIsLoadMore] = useState(false);
12338
+ useCallback(() => {
12339
+ if (isLoadMore)
12340
+ return;
12341
+ setIsLoadMore(true);
12342
+ waterFallData &&
12343
+ (getRecommendVideos === null || getRecommendVideos === void 0 ? void 0 : getRecommendVideos({
12344
+ hashTag: waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag,
12345
+ 'itemFilter.itemId': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemId,
12346
+ 'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType
12347
+ }).then((res) => {
12348
+ var _a;
12349
+ setList(list === null || list === void 0 ? void 0 : list.concat((_a = res === null || res === void 0 ? void 0 : res.recList) !== null && _a !== void 0 ? _a : []));
12350
+ setIsLoadMore(false);
12351
+ }));
12352
+ }, [waterFallData, getRecommendVideos, list, isLoadMore]);
12353
+ useEffect(() => {
12354
+ var _a, _b;
12355
+ setIsLoadingData(true);
12356
+ waterFallData &&
12357
+ (getRecommendVideos === null || getRecommendVideos === void 0 ? void 0 : getRecommendVideos({
12358
+ hashTag: waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag,
12359
+ 'itemFilter.itemId': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemId,
12360
+ 'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType,
12361
+ defaultSize: hashTagSize,
12362
+ maxSize: hashTagSize
12363
+ }).then((res) => {
12364
+ var _a, _b;
12365
+ setData(res);
12366
+ 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 : []);
12367
+ setIsLoadingData(false);
12368
+ }));
12369
+ if (isOpenHashTag) {
12370
+ const res = previewData;
12371
+ setData(res);
12372
+ 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 : []);
12373
+ setIsLoadingData(false);
12374
+ }
12375
+ }, [waterFallData, getRecommendVideos, hashTagSize, isOpenHashTag]);
12376
+ // useEffect(() => {
12377
+ // const container = containerRef?.current;
12378
+ // if (!container) return;
12379
+ // const handleScroll = () => {
12380
+ // const top = (container as any)?.scrollTop;
12381
+ // const clientHeight = (container as any)?.clientHeight;
12382
+ // const scrollHeight = (container as any)?.scrollHeight;
12383
+ // if (scrollHeight <= top + clientHeight && !isLoadingData) {
12384
+ // loadMoreData();
12385
+ // }
12386
+ // };
12387
+ // container?.addEventListener('scroll', handleScroll);
12388
+ // return () => {
12389
+ // container?.removeEventListener('scroll', handleScroll); // 在组件卸载时移除事件监听器
12390
+ // };
12391
+ // }, [isLoadingData, containerRef, loadMoreData]);
12392
+ const handleClickLink = () => {
12393
+ var _a, _b;
12394
+ if ((_a = data === null || data === void 0 ? void 0 : data.tag) === null || _a === void 0 ? void 0 : _a.link) {
12395
+ reportTagsView();
12396
+ window.location.href = (_b = data === null || data === void 0 ? void 0 : data.tag) === null || _b === void 0 ? void 0 : _b.link;
12397
+ }
12398
+ };
12399
+ return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
12400
+ React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'list' },
12401
+ React.createElement("div", { className: 'list-scroll', ref: containerRef },
12402
+ React.createElement("div", { className: 'list-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),
12403
+ React.createElement("div", { hidden: !((_d = data === null || data === void 0 ? void 0 : data.tag) === null || _d === void 0 ? void 0 : _d.link), className: 'list-collection', onClick: handleClickLink, style: Object.assign(Object.assign({}, (_e = props === null || props === void 0 ? void 0 : props.textStyles) === null || _e === void 0 ? void 0 : _e.hashTagLink), { marginBottom: props === null || props === void 0 ? void 0 : props.space }) }, ((_f = data === null || data === void 0 ? void 0 : data.tag) === null || _f === void 0 ? void 0 : _f.linkTitle) || 'Shop the collection'),
12404
+ React.createElement("div", { className: 'list-content' }, list === null || list === void 0 ? void 0 : list.map((item, ind) => {
12405
+ return (React.createElement(WaterfallFlowItem, Object.assign({ key: ind, index: ind, rec: item, list: list, reportTagsView: reportTagsView }, props)));
12406
+ })),
12407
+ React.createElement("div", { hidden: !isLoadMore, style: { textAlign: 'center' } }, "loading..."),
12408
+ React.createElement("div", { hidden: !((_g = data === null || data === void 0 ? void 0 : data.tag) === null || _g === void 0 ? void 0 : _g.link), style: {
12409
+ 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
12410
+ } })),
12411
+ 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 }),
12412
+ 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' }) },
12413
+ 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'))))));
12414
+ }
12415
+
12222
12416
  /*
12223
12417
  * @Author: binruan@chatlabs.com
12224
12418
  * @Date: 2024-01-10 10:58:24
12225
12419
  * @LastEditors: binruan@chatlabs.com
12226
- * @LastEditTime: 2024-06-06 17:19:25
12420
+ * @LastEditTime: 2024-06-07 10:35:35
12227
12421
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
12228
12422
  *
12229
12423
  */
@@ -12317,7 +12511,7 @@ const WaterFall = (props) => {
12317
12511
  display: openHashtag ? 'block' : 'none'
12318
12512
  } },
12319
12513
  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 }),
12320
- React.createElement(WaterfallList, Object.assign({ reportTagsView: reportTagsView }, props))), modalEleRef.current);
12514
+ (props === null || props === void 0 ? void 0 : props.isWaterfallFlow) ? (React.createElement(WaterfallList$1, Object.assign({ reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList, Object.assign({ reportTagsView: reportTagsView }, props)))), modalEleRef.current);
12321
12515
  };
12322
12516
  var WaterFall$1 = memo(WaterFall);
12323
12517
 
@@ -12841,7 +13035,7 @@ const FingerSwipeTip = ({ imageUrl, style }) => {
12841
13035
  *
12842
13036
  */
12843
13037
  const Picture = (props) => {
12844
- const { src, height, imgUrlsPostConfig } = props;
13038
+ const { src, height, imgUrlsPostConfig, onShowFirstImage } = props;
12845
13039
  const blur = useMemo(() => {
12846
13040
  return (imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.mode) === '2';
12847
13041
  }, [imgUrlsPostConfig]);
@@ -12866,7 +13060,7 @@ const Picture = (props) => {
12866
13060
  return isBgColor && (imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.bgColor) ? { backgroundColor: imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.bgColor } : {};
12867
13061
  }, [imgUrlsPostConfig, isBgColor]);
12868
13062
  return (React.createElement("div", { style: Object.assign({ overflow: 'hidden', height, width: '100%', position: 'relative' }, bgStyle) },
12869
- (!blur || !isBgColor) && (React.createElement(FormatImage$1, { src: src, style: Object.assign({ height: '100%', width: '100%', objectFit: 'cover' }, blurStyle) })),
13063
+ (!blur || !isBgColor) && (React.createElement(FormatImage$1, { src: src, style: Object.assign({ height: '100%', width: '100%', objectFit: 'cover' }, blurStyle), onLoad: onShowFirstImage })),
12870
13064
  blur && (React.createElement(FormatImage$1, { src: src, style: {
12871
13065
  width: '100%',
12872
13066
  height: '100%',
@@ -12883,7 +13077,7 @@ const Picture = (props) => {
12883
13077
  * @Author: lewinlu@chatlabs.com
12884
13078
  * @Date: 2024-01-03 14:39:09
12885
13079
  * @LastEditors: binruan@chatlabs.com
12886
- * @LastEditTime: 2024-04-18 19:56:22
13080
+ * @LastEditTime: 2024-06-07 14:05:08
12887
13081
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
12888
13082
  */
12889
13083
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
@@ -12903,16 +13097,20 @@ const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageE
12903
13097
  }
12904
13098
  }
12905
13099
  else {
12906
- setIsLoad(true);
12907
13100
  (ref === null || ref === void 0 ? void 0 : ref.current) && ref.current.swiper.autoplay.stop();
12908
13101
  }
12909
13102
  }, [rec, isActive, onReportViewImageEnd, openHashtag, index, onViewImageStartEvent, isLoad]);
13103
+ const showFirstImageFn = useCallback(() => {
13104
+ if (!isLoad) {
13105
+ setIsLoad(true);
13106
+ }
13107
+ }, [isLoad]);
12910
13108
  // if (!isActive) {
12911
13109
  // return <img src={sxpParameter?.placeholder_image} style={{ width, height, objectFit: 'cover' }} />;
12912
13110
  // }
12913
- 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) => {
12914
- return (React.createElement(SwiperSlide, { key: url },
12915
- React.createElement(Picture, { src: url, height: height, imgUrlsPostConfig: imgUrlsPostConfig })));
13111
+ 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) => {
13112
+ return (React.createElement(SwiperSlide, { key: index },
13113
+ React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
12916
13114
  })));
12917
13115
  };
12918
13116
  var PictureGroup$3 = memo(PictureGroup$2);
@@ -13132,7 +13330,7 @@ var Tagbar$1 = memo(Tagbar);
13132
13330
  * @Author: binruan@chatlabs.com
13133
13331
  * @Date: 2024-01-15 19:03:09
13134
13332
  * @LastEditors: binruan@chatlabs.com
13135
- * @LastEditTime: 2024-06-06 18:42:24
13333
+ * @LastEditTime: 2024-06-07 11:10:42
13136
13334
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13137
13335
  *
13138
13336
  */
@@ -13155,6 +13353,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13155
13353
  return data.length > 0 && !loading && getFeUserId();
13156
13354
  }, [data, loading]);
13157
13355
  const handleH5EnterLink = useCallback(() => {
13356
+ var _a, _b;
13158
13357
  if (data.length <= 0) {
13159
13358
  return;
13160
13359
  }
@@ -13177,7 +13376,9 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13177
13376
  utmId: getVal('utm_id'),
13178
13377
  utmContent: getVal('utm_content'),
13179
13378
  enterTime: `${Date.now()}`,
13180
- requestId: null
13379
+ requestId: null,
13380
+ 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 : '',
13381
+ clSource: getVal('cl_sourc')
13181
13382
  }
13182
13383
  });
13183
13384
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
@@ -13237,26 +13438,6 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13237
13438
  })) || 0;
13238
13439
  (_a = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _a === void 0 ? void 0 : _a.swiper.slideTo(index);
13239
13440
  }, [ctaType, swiperRef]);
13240
- // useEffect(() => {
13241
- // const handleBeforeUnload = (event: any) => {
13242
- // event.preventDefault();
13243
- // const item = data?.[activeIndex];
13244
- // bffEventReport?.({
13245
- // eventInfo: {
13246
- // sessionDuration: Math.floor(((new Date() as any) - curTime) / 1000) + '',
13247
- // eventSubject: 'sessionCompleted',
13248
- // eventDescription: 'Session completed',
13249
- // contentId: item?.video?.itemId,
13250
- // productId: item?.product?.itemId,
13251
- // position: item?.position
13252
- // }
13253
- // });
13254
- // };
13255
- // window.addEventListener('beforeunload', handleBeforeUnload);
13256
- // return () => {
13257
- // window.removeEventListener('beforeunload', handleBeforeUnload);
13258
- // };
13259
- // }, [activeIndex, data, bffEventReport, curTime]);
13260
13441
  useEffect(() => {
13261
13442
  const item = data === null || data === void 0 ? void 0 : data[activeIndex];
13262
13443
  const visibleChange = () => {