pb-sxp-ui 1.0.86 → 1.0.88
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 +113 -166
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +113 -166
- package/dist/index.js.map +1 -1
- package/dist/index.min.cjs +3 -4
- package/dist/index.min.cjs.map +1 -1
- package/dist/index.min.js +3 -4
- package/dist/index.min.js.map +1 -1
- package/dist/pb-ui.js +113 -166
- package/dist/pb-ui.js.map +1 -1
- package/dist/pb-ui.min.js +3 -4
- package/dist/pb-ui.min.js.map +1 -1
- package/es/core/components/Consent/index.js +2 -2
- package/es/core/components/DiyPortalPreview/VideoWidget.js +3 -3
- package/es/core/components/SxpPageRender/FingerSwipeTip/index.js +1 -1
- package/es/core/components/SxpPageRender/FormatImage.js +2 -2
- package/es/core/components/SxpPageRender/LikeButton/index.js +1 -1
- package/es/core/components/SxpPageRender/Navbar.js +1 -1
- package/es/core/components/SxpPageRender/Nudge/index.js +1 -1
- package/es/core/components/SxpPageRender/Tagbar.js +6 -7
- package/es/core/components/SxpPageRender/ToggleButton/index.js +2 -2
- package/es/core/components/SxpPageRender/VideoWidget/index.js +3 -3
- package/es/core/components/SxpPageRender/WaterFall/List.js +2 -2
- package/es/core/components/SxpPageRender/WaterFall/WaterfallList.js +17 -52
- package/es/core/components/SxpPageRender/WaterFall/index.js +2 -4
- package/es/core/components/SxpPageRender/index.js +28 -30
- package/es/core/context/SxpDataSourceProvider.d.ts +4 -0
- package/es/core/context/SxpDataSourceProvider.js +9 -3
- package/es/core/hooks/useEventReport.d.ts +1 -1
- package/es/core/hooks/useEventReport.js +13 -10
- package/es/materials/sxp/popup/AppointForm/index.js +1 -1
- package/es/materials/sxp/popup/CommodityDetail/index.js +3 -3
- package/es/materials/sxp/popup/CommodityDetailDiro/index.js +4 -4
- package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +3 -3
- package/es/materials/sxp/popup/Prompt/index.js +2 -2
- package/es/materials/sxp/template/Appoint/index.js +1 -1
- package/lib/core/components/Consent/index.js +2 -2
- package/lib/core/components/DiyPortalPreview/VideoWidget.js +3 -3
- package/lib/core/components/SxpPageRender/FingerSwipeTip/index.js +1 -1
- package/lib/core/components/SxpPageRender/FormatImage.js +2 -2
- package/lib/core/components/SxpPageRender/LikeButton/index.js +1 -1
- package/lib/core/components/SxpPageRender/Navbar.js +1 -1
- package/lib/core/components/SxpPageRender/Nudge/index.js +1 -1
- package/lib/core/components/SxpPageRender/Tagbar.js +7 -8
- package/lib/core/components/SxpPageRender/ToggleButton/index.js +2 -2
- package/lib/core/components/SxpPageRender/VideoWidget/index.js +3 -3
- package/lib/core/components/SxpPageRender/WaterFall/List.js +2 -2
- package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.js +17 -52
- package/lib/core/components/SxpPageRender/WaterFall/index.js +2 -4
- package/lib/core/components/SxpPageRender/index.js +28 -30
- package/lib/core/context/SxpDataSourceProvider.d.ts +4 -0
- package/lib/core/context/SxpDataSourceProvider.js +10 -4
- package/lib/core/hooks/useEventReport.d.ts +1 -1
- package/lib/core/hooks/useEventReport.js +13 -10
- package/lib/materials/sxp/popup/AppointForm/index.js +1 -1
- package/lib/materials/sxp/popup/CommodityDetail/index.js +3 -3
- package/lib/materials/sxp/popup/CommodityDetailDiro/index.js +4 -4
- package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +3 -3
- package/lib/materials/sxp/popup/Prompt/index.js +2 -2
- package/lib/materials/sxp/template/Appoint/index.js +1 -1
- package/package.json +1 -1
package/dist/pb-ui.js
CHANGED
@@ -434,7 +434,7 @@
|
|
434
434
|
* @Author: binruan@chatlabs.com
|
435
435
|
* @Date: 2024-06-13 15:16:53
|
436
436
|
* @LastEditors: binruan@chatlabs.com
|
437
|
-
* @LastEditTime: 2024-06-
|
437
|
+
* @LastEditTime: 2024-06-19 14:13:50
|
438
438
|
* @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
|
439
439
|
*
|
440
440
|
*/
|
@@ -489,8 +489,8 @@
|
|
489
489
|
React.createElement("div", { className: 'consent-title' }, privacy_title !== null && privacy_title !== void 0 ? privacy_title : 'Privacy Policy'),
|
490
490
|
React.createElement("div", { className: 'consent-content' }, privacy_context !== null && privacy_context !== void 0 ? privacy_context : 'This site uses cookies to improve your online experience. By continuing to use the site please agree the policy first.')),
|
491
491
|
React.createElement("div", { className: 'consent-col' },
|
492
|
-
React.createElement("button", { className: 'consent-btn', onClick: handleAgree }, "Agree"),
|
493
|
-
React.createElement("a", { className: 'consent-policy', target: '_blank', href: privacy_policy_url }, privacy_policy_title !== null && privacy_policy_title !== void 0 ? privacy_policy_title : 'More information')))));
|
492
|
+
React.createElement("button", { "aria-label": 'agree', className: 'consent-btn', onClick: handleAgree }, "Agree"),
|
493
|
+
React.createElement("a", { className: 'consent-policy', target: '_blank', href: privacy_policy_url ? `https://${privacy_policy_url}` : undefined }, privacy_policy_title !== null && privacy_policy_title !== void 0 ? privacy_policy_title : 'More information')))));
|
494
494
|
};
|
495
495
|
var Consent$3 = React.memo(Consent$2);
|
496
496
|
|
@@ -503,6 +503,7 @@
|
|
503
503
|
DataSourceType[DataSourceType["BFF"] = 5] = "BFF";
|
504
504
|
})(DataSourceType || (DataSourceType = {}));
|
505
505
|
const UTM_KEYS = ['utm_source', 'utm_medium', 'utm_campaign', 'utm_id', 'utm_content', 'cl_source'];
|
506
|
+
const DEFAULT_TAG = 'FOR U';
|
506
507
|
const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent = true, maxSize, defaultSize, isPreview = false, sxpParameter, appDomain, hashTagSize, loadingImage, isOpenHashTag = false, enabledMetaConversionApi = false, consentHeight, consentWidth, isShowTag = true, isOpenConsent = false, globalConfig, isEditor = false }) => {
|
507
508
|
var _a, _b, _c;
|
508
509
|
const [rtcList, setRtcList] = React.useState([]);
|
@@ -522,6 +523,7 @@
|
|
522
523
|
const [videoRef, setVideoRef] = React.useState(null);
|
523
524
|
const themeTag = React.useRef();
|
524
525
|
const curTime = React.useRef();
|
526
|
+
const [selectTag, setSelectTag] = React.useState(DEFAULT_TAG);
|
525
527
|
const isShowConsent = React.useMemo(() => {
|
526
528
|
var _a, _b, _c, _d;
|
527
529
|
return (((_d = (_c = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consent) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item) === null || _c === void 0 ? void 0 : _c.props) === null || _d === void 0 ? void 0 : _d.privacy_necessity) && !isAgreePolicy && !isEditor) || isOpenConsent;
|
@@ -731,8 +733,9 @@
|
|
731
733
|
});
|
732
734
|
}, [bffEventReport]);
|
733
735
|
React.useEffect(() => {
|
734
|
-
|
735
|
-
|
736
|
+
if (!isShowConsent)
|
737
|
+
h5EnterLink();
|
738
|
+
}, [isShowConsent]);
|
736
739
|
React.useEffect(() => {
|
737
740
|
if (isShowConsent)
|
738
741
|
return;
|
@@ -811,7 +814,10 @@
|
|
811
814
|
setIsAgreePolicy,
|
812
815
|
curTime,
|
813
816
|
h5EnterLink,
|
814
|
-
themeTag
|
817
|
+
themeTag,
|
818
|
+
isShowConsent,
|
819
|
+
selectTag,
|
820
|
+
setSelectTag
|
815
821
|
} }, isShowConsent ? (React.createElement(Consent$3, Object.assign({}, (_c = (_b = (_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consent) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.item) === null || _c === void 0 ? void 0 : _c.props))) : (render({
|
816
822
|
rtcList,
|
817
823
|
mutateLike: bffMutateLike,
|
@@ -1222,7 +1228,7 @@
|
|
1222
1228
|
* @Author: binruan@chatlabs.com
|
1223
1229
|
* @Date: 2024-03-12 10:59:06
|
1224
1230
|
* @LastEditors: binruan@chatlabs.com
|
1225
|
-
* @LastEditTime: 2024-06-
|
1231
|
+
* @LastEditTime: 2024-06-20 13:39:07
|
1226
1232
|
* @FilePath: \pb-sxp-ui\src\core\hooks\useEventReport.ts
|
1227
1233
|
*
|
1228
1234
|
*/
|
@@ -1292,16 +1298,18 @@
|
|
1292
1298
|
}
|
1293
1299
|
});
|
1294
1300
|
}, [bffEventReport, popupDetailData]);
|
1295
|
-
const backMainFeed = React.useCallback((lastFeed, themeTag, hashTag) => {
|
1296
|
-
|
1297
|
-
|
1298
|
-
|
1299
|
-
|
1300
|
-
|
1301
|
-
|
1302
|
-
|
1303
|
-
|
1304
|
-
|
1301
|
+
const backMainFeed = React.useCallback((lastFeed, selectTag, themeTag, hashTag) => {
|
1302
|
+
if (selectTag && selectTag === DEFAULT_TAG) {
|
1303
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
1304
|
+
eventInfo: {
|
1305
|
+
lastFeed,
|
1306
|
+
themeTags: themeTag ? `['${themeTag}']` : '',
|
1307
|
+
hashTags: hashTag ? `['${hashTag}']` : '',
|
1308
|
+
eventSubject: 'backMainFeed',
|
1309
|
+
eventDescription: 'back Main Feed'
|
1310
|
+
}
|
1311
|
+
});
|
1312
|
+
}
|
1305
1313
|
}, [bffEventReport]);
|
1306
1314
|
return {
|
1307
1315
|
jumpToWeb,
|
@@ -1388,7 +1396,7 @@
|
|
1388
1396
|
React.createElement("div", { className: 'pb-appoint-form-container' },
|
1389
1397
|
React.createElement(proComponents.BetaSchemaForm, { columns: columnsData, submitter: false, layout: layoutType, autoFocusFirstInput: false, size: 'large', formRef: formRef, className: 'panel-reset' }))),
|
1390
1398
|
React.createElement("div", { className: 'pb-appoint-form-btn-wrapper' },
|
1391
|
-
React.createElement("button", { onClick: handleSubmit, className: 'pb-appoint-form-btn', style: Object.assign({ color: submitColor, background: submitBgColor }, submitButtonStyle) }, loading ? React.createElement(React.Fragment, null, "loading...") : submitText))));
|
1399
|
+
React.createElement("button", { "aria-label": submitText, onClick: handleSubmit, className: 'pb-appoint-form-btn', style: Object.assign({ color: submitColor, background: submitBgColor }, submitButtonStyle) }, loading ? React.createElement(React.Fragment, null, "loading...") : submitText))));
|
1392
1400
|
};
|
1393
1401
|
var AppointFormComponent = React.memo(AppointForm$1);
|
1394
1402
|
|
@@ -8580,7 +8588,7 @@
|
|
8580
8588
|
* @Author: binruan@chatlabs.com
|
8581
8589
|
* @Date: 2024-03-20 10:27:31
|
8582
8590
|
* @LastEditors: binruan@chatlabs.com
|
8583
|
-
* @LastEditTime: 2024-
|
8591
|
+
* @LastEditTime: 2024-06-19 16:25:46
|
8584
8592
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\FormatImage.tsx
|
8585
8593
|
*
|
8586
8594
|
*/
|
@@ -8630,9 +8638,9 @@
|
|
8630
8638
|
React.createElement("source", { type: 'image/jpeg', srcSet: `${imgSrc}?imageMogr2/format/jpg` }),
|
8631
8639
|
React.createElement("img", { className: className, src: imgSrc, style: style, loading: loading, onLoad: (e) => {
|
8632
8640
|
onLoad === null || onLoad === void 0 ? void 0 : onLoad(e.target);
|
8633
|
-
} }))) : (React.createElement("img", { className: className, src: imgSrc, style: style, loading: loading, onLoad: (e) => {
|
8641
|
+
}, alt: 'image' }))) : (React.createElement("img", { className: className, src: imgSrc, style: style, loading: loading, onLoad: (e) => {
|
8634
8642
|
onLoad === null || onLoad === void 0 ? void 0 : onLoad(e.target);
|
8635
|
-
} }))));
|
8643
|
+
}, alt: 'image' }))));
|
8636
8644
|
});
|
8637
8645
|
var FormatImage$1 = React.memo(FormatImage);
|
8638
8646
|
|
@@ -8700,8 +8708,8 @@
|
|
8700
8708
|
18-karat gold, this necklace is embellished with hand-set diamonds.`, maxStr: 79, className: 'pb-commondity-content-info', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.info }))));
|
8701
8709
|
};
|
8702
8710
|
const renderBtn = () => {
|
8703
|
-
var _a;
|
8704
|
-
return (React.createElement(React.Fragment, null, (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { onClick: handleLink, className: 'pb-commondity-btn', style: buttonStyle }, (
|
8711
|
+
var _a, _b;
|
8712
|
+
return (React.createElement(React.Fragment, null, (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_a = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _a !== void 0 ? _a : 'Purchase on Website', onClick: handleLink, className: 'pb-commondity-btn', style: buttonStyle }, (_b = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _b !== void 0 ? _b : 'Purchase on Website'))));
|
8705
8713
|
};
|
8706
8714
|
const getStyle = React.useCallback((style) => {
|
8707
8715
|
if (style === null || style === void 0 ? void 0 : style.lineClamp) {
|
@@ -8747,7 +8755,7 @@
|
|
8747
8755
|
top: 0,
|
8748
8756
|
objectFit: 'cover',
|
8749
8757
|
width: '100%'
|
8750
|
-
}), src: (_k = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _k !== void 0 ? _k : bottom_image, alt: '' }))),
|
8758
|
+
}), src: (_k = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _k !== void 0 ? _k : bottom_image, alt: 'pdp image' }))),
|
8751
8759
|
React.createElement("div", { className: 'pb-commondity-content' }, renderContent({ isPost }))),
|
8752
8760
|
renderBtn(),
|
8753
8761
|
React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) },
|
@@ -8951,9 +8959,9 @@
|
|
8951
8959
|
};
|
8952
8960
|
return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
|
8953
8961
|
React.createElement("div", { className: 'pb-prompt-icon' },
|
8954
|
-
React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$2 })),
|
8962
|
+
React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$2, alt: 'success image' })),
|
8955
8963
|
React.createElement("div", { className: 'pb-prompt-content' }, content),
|
8956
|
-
React.createElement("button", { className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk }, btnText)));
|
8964
|
+
React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk }, btnText)));
|
8957
8965
|
};
|
8958
8966
|
var PromptComponent = React.memo(Prompt$1);
|
8959
8967
|
|
@@ -9177,7 +9185,7 @@
|
|
9177
9185
|
];
|
9178
9186
|
|
9179
9187
|
const CommodityDetailDiroNew$1 = (_a) => {
|
9180
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
9188
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
|
9181
9189
|
var { style, isDefault, rec, viewTime, isPost, bottom_image, tipText, swiper, commodityStyles, buttonStyle, index } = _a, props = __rest(_a, ["style", "isDefault", "rec", "viewTime", "isPost", "bottom_image", "tipText", "swiper", "commodityStyles", "buttonStyle", "index"]);
|
9182
9190
|
React.useState(true);
|
9183
9191
|
const { sxpParameter } = useSxpDataSource();
|
@@ -9283,7 +9291,7 @@ Made in Italy` })));
|
|
9283
9291
|
top: 0,
|
9284
9292
|
objectFit: 'cover',
|
9285
9293
|
width: '100%'
|
9286
|
-
}), src: (_k = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _k !== void 0 ? _k : bottom_image, alt: '' }))),
|
9294
|
+
}), src: (_k = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _k !== void 0 ? _k : bottom_image, alt: 'pdp image' }))),
|
9287
9295
|
React.createElement("div", { className: 'pb-commondityDiroNew-content' },
|
9288
9296
|
React.createElement("div", { className: 'pb-commondityDiroNew-content-top' },
|
9289
9297
|
React.createElement("div", { className: 'pb-commondityDiroNew-content-top-left' },
|
@@ -9292,7 +9300,7 @@ Made in Italy` })));
|
|
9292
9300
|
React.createElement("div", { className: 'pb-commondityDiroNew-content-top-right' },
|
9293
9301
|
React.createElement("div", { className: 'pb-commondityDiroNew-content-top-right-price', hidden: !!product && !(product === null || product === void 0 ? void 0 : product.price), style: getStyle(commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.price) }, priceText),
|
9294
9302
|
React.createElement("div", { className: 'pb-commondityDiroNew-content-top-right-price', hidden: !!product && !(product === null || product === void 0 ? void 0 : product.taxInfo), style: getStyle(commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.taxInfo) }, (_m = product === null || product === void 0 ? void 0 : product.taxInfo) !== null && _m !== void 0 ? _m : '税费'))),
|
9295
|
-
(!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { onClick: handleLink, className: 'pb-commondityDiroNew-btn', style: buttonStyle }, (
|
9303
|
+
(!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_o = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _o !== void 0 ? _o : 'Shop now', onClick: handleLink, className: 'pb-commondityDiroNew-btn', style: buttonStyle }, (_p = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _p !== void 0 ? _p : 'Shop now')),
|
9296
9304
|
productInfoText({ isPost }))),
|
9297
9305
|
React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText({ isPost: false }))));
|
9298
9306
|
};
|
@@ -9784,7 +9792,7 @@ Made in Italy` })));
|
|
9784
9792
|
const cta = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindCta;
|
9785
9793
|
return (React.createElement(EventProvider$1, Object.assign({ isExternalLink: isExternalLink, rec: recData, className: css.css(Object.assign({ alignItems: 'center' }, style)), style: { display: 'flex' } }, props),
|
9786
9794
|
React.createElement("div", { className: css.css(Object.assign({ overflow: 'hidden', flexShrink: 0, backgroundColor: '#f2f2f2' }, ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.img)) },
|
9787
|
-
React.createElement("img", { className: css.css({ width: '100%', objectFit: 'cover', height: '100%', display: 'block' }), src: (_d = (_c = cta === null || cta === void 0 ? void 0 : cta.icon) !== null && _c !== void 0 ? _c : sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _d !== void 0 ? _d : bottom_image, alt: '' })),
|
9795
|
+
React.createElement("img", { className: css.css({ width: '100%', objectFit: 'cover', height: '100%', display: 'block' }), src: (_d = (_c = cta === null || cta === void 0 ? void 0 : cta.icon) !== null && _c !== void 0 ? _c : sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _d !== void 0 ? _d : bottom_image, alt: 'cta image' })),
|
9788
9796
|
React.createElement("div", { className: css.css(Object.assign({ overflow: 'hidden', textOverflow: 'ellipsis' }, ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle)) }, (_e = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _e !== void 0 ? _e : 'Product Name')));
|
9789
9797
|
};
|
9790
9798
|
var AppointComponent = React.memo(Appoint$1);
|
@@ -10702,7 +10710,7 @@ Made in Italy` })));
|
|
10702
10710
|
var _a;
|
10703
10711
|
const { waterFallData, setOpenHashtag } = useSxpDataSource();
|
10704
10712
|
return (React.createElement("div", { className: 'clc-sxp-nav', style: styles },
|
10705
|
-
React.createElement("img", { className: 'clc-sxp-nav-left', src: icon, alt: '', onClick: onClose }),
|
10713
|
+
React.createElement("img", { className: 'clc-sxp-nav-left', src: icon, alt: 'back button', onClick: onClose }),
|
10706
10714
|
React.createElement("div", { className: 'clc-sxp-nav-title', style: textStyle }, `#${(_a = waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag) !== null && _a !== void 0 ? _a : '标题'}`)));
|
10707
10715
|
};
|
10708
10716
|
var Navbar$1 = React.memo(Navbar);
|
@@ -11994,15 +12002,15 @@ Made in Italy` })));
|
|
11994
12002
|
const { rec, style = {}, sizeChange = () => { }, unitWidth, index, showBorder, list, reportTagsView, textStyles, space } = props;
|
11995
12003
|
const { swiperRef, setRtcList, setOpenHashtag, sxpParameter } = useSxpDataSource();
|
11996
12004
|
const [showVideo, setShowVideo] = React.useState(false);
|
11997
|
-
|
11998
|
-
|
12005
|
+
React.useState(false);
|
12006
|
+
React.useState({
|
11999
12007
|
height: 1,
|
12000
12008
|
width: 1
|
12001
12009
|
});
|
12002
12010
|
const imgDom = React.useRef(null);
|
12003
12011
|
const ref = React.useRef(null);
|
12004
|
-
|
12005
|
-
|
12012
|
+
React.useRef(null);
|
12013
|
+
React.useRef(null);
|
12006
12014
|
const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
|
12007
12015
|
const src = React.useMemo(() => {
|
12008
12016
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
@@ -12032,7 +12040,7 @@ Made in Italy` })));
|
|
12032
12040
|
return y;
|
12033
12041
|
}, [style]);
|
12034
12042
|
/** 是否加载图片 */
|
12035
|
-
|
12043
|
+
React.useMemo(() => {
|
12036
12044
|
if (top === undefined) {
|
12037
12045
|
return false;
|
12038
12046
|
}
|
@@ -12058,58 +12066,25 @@ Made in Italy` })));
|
|
12058
12066
|
if (imgDom.current === null || src === '') {
|
12059
12067
|
return;
|
12060
12068
|
}
|
12061
|
-
|
12069
|
+
let imgSrc = null;
|
12062
12070
|
if (showVideo && firstFrameSrc) {
|
12063
|
-
|
12071
|
+
imgSrc = firstFrameSrc;
|
12064
12072
|
}
|
12065
12073
|
else {
|
12066
|
-
|
12074
|
+
imgSrc = src;
|
12067
12075
|
}
|
12068
|
-
|
12069
|
-
|
12070
|
-
|
12071
|
-
|
12072
|
-
|
12073
|
-
|
12074
|
-
|
12075
|
-
|
12076
|
-
}, [src, showVideo, firstFrameSrc, isImgShow]);
|
12077
|
-
React.useEffect(() => {
|
12078
|
-
// 通过宽度比例获取图片高度
|
12079
|
-
const height = imgInfo.height * (unitWidth / imgInfo.width);
|
12080
|
-
if (isLoading) {
|
12076
|
+
if (imgSrc)
|
12077
|
+
imgDom.current.setSrc(imgSrc);
|
12078
|
+
}, [src, showVideo, firstFrameSrc]);
|
12079
|
+
const pictRef = React.useRef();
|
12080
|
+
const imgLoad = React.useCallback((img) => {
|
12081
|
+
setTimeout(() => {
|
12082
|
+
var _a;
|
12083
|
+
const height = (_a = pictRef === null || pictRef === void 0 ? void 0 : pictRef.current) === null || _a === void 0 ? void 0 : _a.offsetHeight;
|
12081
12084
|
// 加56是因为下方文字部分高度为56,可以自己设置
|
12082
12085
|
sizeChange(height + 56 + space, index);
|
12083
|
-
}
|
12084
|
-
}, [
|
12085
|
-
const calculateHeightForWidth = (videoWidth, videoHeight, targetWidth) => {
|
12086
|
-
const aspectRatio = videoWidth / videoHeight;
|
12087
|
-
const targetHeight = targetWidth / aspectRatio;
|
12088
|
-
return targetHeight;
|
12089
|
-
};
|
12090
|
-
React.useEffect(() => {
|
12091
|
-
const video = videoDom === null || videoDom === void 0 ? void 0 : videoDom.current;
|
12092
|
-
if (video === null || src === '' || !showVideo) {
|
12093
|
-
return;
|
12094
|
-
}
|
12095
|
-
video.src = src;
|
12096
|
-
video.currentTime = 1;
|
12097
|
-
video.crossOrigin = 'anonymous';
|
12098
|
-
video.onloadeddata = () => {
|
12099
|
-
const canvas = canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.current;
|
12100
|
-
if (!canvas)
|
12101
|
-
return;
|
12102
|
-
const ctx = canvas.getContext('2d');
|
12103
|
-
const targetWidth = (window === null || window === void 0 ? void 0 : window.innerWidth) / 2;
|
12104
|
-
const targetHeight = calculateHeightForWidth(video.videoWidth, video.videoHeight, targetWidth);
|
12105
|
-
canvas.height = targetHeight;
|
12106
|
-
canvas.width = targetWidth;
|
12107
|
-
ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
|
12108
|
-
setFirstFrameSrc(canvas.toDataURL());
|
12109
|
-
video.remove();
|
12110
|
-
canvas.remove();
|
12111
|
-
};
|
12112
|
-
}, [src, showVideo]);
|
12086
|
+
}, 0);
|
12087
|
+
}, [space, sizeChange, index, unitWidth, pictRef]);
|
12113
12088
|
const handleClickToDetail = () => {
|
12114
12089
|
reportTagsView();
|
12115
12090
|
setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(list);
|
@@ -12120,17 +12095,14 @@ Made in Italy` })));
|
|
12120
12095
|
}, 0);
|
12121
12096
|
};
|
12122
12097
|
return (React.createElement("div", { ref: ref, style: Object.assign({}, style), className: 'waterFallList-content-listItem', key: index, onClick: handleClickToDetail },
|
12123
|
-
React.createElement("div", { className: 'waterFallList-content-listItem-picture' },
|
12124
|
-
|
12125
|
-
React.createElement("video", { ref: videoDom, src: src, crossOrigin: 'anonymous', className: 'waterFallList-content-listItem-picture-img' }),
|
12126
|
-
React.createElement("canvas", { ref: canvasRef }))),
|
12127
|
-
React.createElement(FormatImage$1, { loading: 'lazy', className: 'waterFallList-content-listItem-picture-img', ref: imgDom })),
|
12098
|
+
React.createElement("div", { className: 'waterFallList-content-listItem-picture', ref: pictRef },
|
12099
|
+
React.createElement(FormatImage$1, { loading: 'lazy', className: 'waterFallList-content-listItem-picture-img', onLoad: imgLoad, ref: imgDom })),
|
12128
12100
|
React.createElement("div", { className: 'waterFallList-content-listItem-info' },
|
12129
12101
|
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),
|
12130
12102
|
React.createElement("div", { className: 'waterFallList-content-listItem-info-price', hidden: !priceText, style: textStyles.price }, priceText))));
|
12131
12103
|
};
|
12132
12104
|
function WaterfallList$1(_a) {
|
12133
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
|
12105
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w;
|
12134
12106
|
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12135
12107
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12136
12108
|
/** 滚动的父元素 */
|
@@ -12182,7 +12154,6 @@ Made in Italy` })));
|
|
12182
12154
|
for (let i = 0; i < (list === null || list === void 0 ? void 0 : list.length); i++) {
|
12183
12155
|
// 原本应对应的行数
|
12184
12156
|
const currentRow = Math.floor(i / rowsNum);
|
12185
|
-
//
|
12186
12157
|
const remainder = (i % rowsNum) + 1;
|
12187
12158
|
// 最低item下标
|
12188
12159
|
let minHeightInd = 0;
|
@@ -12359,7 +12330,7 @@ Made in Italy` })));
|
|
12359
12330
|
} }))),
|
12360
12331
|
React.createElement("div", { className: 'waterFallList-bottom', hidden: !((_t = data === null || data === void 0 ? void 0 : data.tag) === null || _t === void 0 ? void 0 : _t.link), style: props === null || props === void 0 ? void 0 : props.buttonBgStyle }),
|
12361
12332
|
React.createElement("div", { ref: buttonRef, hidden: !((_u = data === null || data === void 0 ? void 0 : data.tag) === null || _u === void 0 ? void 0 : _u.link), className: 'waterFallList-btn-wrap', style: Object.assign(Object.assign({}, props === null || props === void 0 ? void 0 : props.buttonBgStyle), { height: 'auto', backgroundColor: 'transparent' }) },
|
12362
|
-
React.createElement("button", { className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12333
|
+
React.createElement("button", { "aria-label": ((_v = data === null || data === void 0 ? void 0 : data.tag) === null || _v === void 0 ? void 0 : _v.linkTitle) || 'Shop the collection', className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_w = data === null || data === void 0 ? void 0 : data.tag) === null || _w === void 0 ? void 0 : _w.linkTitle) || 'Shop the collection'))))));
|
12363
12334
|
}
|
12364
12335
|
|
12365
12336
|
var img$1 = "";
|
@@ -12488,7 +12459,7 @@ Made in Italy` })));
|
|
12488
12459
|
React.createElement("div", { className: 'list-content-listItem-info-price', style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.price, hidden: !priceText }, priceText))));
|
12489
12460
|
};
|
12490
12461
|
function WaterfallList(_a) {
|
12491
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
12462
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
|
12492
12463
|
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12493
12464
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12494
12465
|
const [list, setList] = React.useState();
|
@@ -12577,20 +12548,20 @@ Made in Italy` })));
|
|
12577
12548
|
} })),
|
12578
12549
|
React.createElement("div", { className: 'list-bottom', hidden: !((_o = data === null || data === void 0 ? void 0 : data.tag) === null || _o === void 0 ? void 0 : _o.link), style: props === null || props === void 0 ? void 0 : props.buttonBgStyle }),
|
12579
12550
|
React.createElement("div", { hidden: !((_p = data === null || data === void 0 ? void 0 : data.tag) === null || _p === void 0 ? void 0 : _p.link), className: 'list-btn-wrap', style: Object.assign(Object.assign({}, props === null || props === void 0 ? void 0 : props.buttonBgStyle), { height: 'auto', backgroundColor: 'transparent' }) },
|
12580
|
-
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12551
|
+
React.createElement("button", { "aria-label": ((_q = data === null || data === void 0 ? void 0 : data.tag) === null || _q === void 0 ? void 0 : _q.linkTitle) || 'Shop the collection', className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_r = data === null || data === void 0 ? void 0 : data.tag) === null || _r === void 0 ? void 0 : _r.linkTitle) || 'Shop the collection'))))));
|
12581
12552
|
}
|
12582
12553
|
|
12583
12554
|
/*
|
12584
12555
|
* @Author: binruan@chatlabs.com
|
12585
12556
|
* @Date: 2024-01-10 10:58:24
|
12586
12557
|
* @LastEditors: binruan@chatlabs.com
|
12587
|
-
* @LastEditTime: 2024-06-12
|
12558
|
+
* @LastEditTime: 2024-06-20 12:45:26
|
12588
12559
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
|
12589
12560
|
*
|
12590
12561
|
*/
|
12591
12562
|
const WaterFall = (props) => {
|
12592
12563
|
var _a;
|
12593
|
-
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport, themeTag } = useSxpDataSource();
|
12564
|
+
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport, themeTag, selectTag } = useSxpDataSource();
|
12594
12565
|
const { backMainFeed } = useEventReport();
|
12595
12566
|
React.useRef(null);
|
12596
12567
|
const modalEleRef = React.useRef(null);
|
@@ -12612,9 +12583,7 @@ Made in Italy` })));
|
|
12612
12583
|
if (!isEq && cacheRtcList && (cacheRtcList === null || cacheRtcList === void 0 ? void 0 : cacheRtcList.length)) {
|
12613
12584
|
setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(cacheRtcList);
|
12614
12585
|
}
|
12615
|
-
|
12616
|
-
backMainFeed('branch', themeTag === null || themeTag === void 0 ? void 0 : themeTag.current, waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag);
|
12617
|
-
}
|
12586
|
+
backMainFeed('branch', selectTag, undefined, waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag);
|
12618
12587
|
reportTagsView();
|
12619
12588
|
setWaterFallData === null || setWaterFallData === void 0 ? void 0 : setWaterFallData(undefined);
|
12620
12589
|
setIsFromHashtag === null || setIsFromHashtag === void 0 ? void 0 : setIsFromHashtag(false);
|
@@ -12926,7 +12895,7 @@ Made in Italy` })));
|
|
12926
12895
|
}
|
12927
12896
|
}
|
12928
12897
|
}), 200);
|
12929
|
-
return (React.createElement("button", Object.assign({}, props, { onClick: handleClick }),
|
12898
|
+
return (React.createElement("button", Object.assign({}, props, { "aria-label": 'like', onClick: handleClick }),
|
12930
12899
|
React.createElement("img", { style: { width: '100%', height: '100%', objectFit: 'contain' }, src: state ? activeIcon || likeIcon : unActicveIcon || unlikeIcon, alt: 'icon' })));
|
12931
12900
|
};
|
12932
12901
|
var LikeButton$1 = React.memo(LikeButton);
|
@@ -13185,7 +13154,7 @@ Made in Italy` })));
|
|
13185
13154
|
if (!(sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image) || isLoadFinish) {
|
13186
13155
|
return null;
|
13187
13156
|
}
|
13188
|
-
return (React.createElement("img", { style: { position: 'absolute', left: 0, top: 0, width: '100%', height: '100%', objectFit: 'cover' }, src: sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image }));
|
13157
|
+
return (React.createElement("img", { style: { position: 'absolute', left: 0, top: 0, width: '100%', height: '100%', objectFit: 'cover' }, src: sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image, alt: 'placeholder image' }));
|
13189
13158
|
}, [isLoadFinish, sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image]);
|
13190
13159
|
React.useEffect(() => {
|
13191
13160
|
if (!videoRef)
|
@@ -13218,7 +13187,7 @@ Made in Italy` })));
|
|
13218
13187
|
} },
|
13219
13188
|
React.createElement("div", { style: { position: 'relative', width: '100%', height: '100%' } },
|
13220
13189
|
React.createElement("div", { className: 'n-full-screen', ref: videoEleRef, id: videoId, style: { width: '100%', height: '100%' } }),
|
13221
|
-
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON }))),
|
13190
|
+
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', alt: 'pause', src: PAUSE_ICON }))),
|
13222
13191
|
renderPoster)) : (React.createElement("div", { className: 'video-container', key: rec === null || rec === void 0 ? void 0 : rec.video.itemId, style: {
|
13223
13192
|
position: 'relative',
|
13224
13193
|
width: '100%',
|
@@ -13227,7 +13196,7 @@ Made in Italy` })));
|
|
13227
13196
|
}, onClick: handleClickVideo() },
|
13228
13197
|
React.createElement("div", { className: 'n-full-screen', ref: videoEleRef, id: videoId, style: { width: '100%', height: '100%' } }),
|
13229
13198
|
renderPoster,
|
13230
|
-
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON })))));
|
13199
|
+
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON, alt: 'pause' })))));
|
13231
13200
|
};
|
13232
13201
|
var VideoWidget$3 = React.memo(VideoWidget$2);
|
13233
13202
|
|
@@ -13247,8 +13216,8 @@ Made in Italy` })));
|
|
13247
13216
|
setIsTure(result);
|
13248
13217
|
onChange === null || onChange === void 0 ? void 0 : onChange(result);
|
13249
13218
|
};
|
13250
|
-
return (React.createElement("button", { style: style, className: 'pb-toggle-button', onClick: handleClick },
|
13251
|
-
React.createElement("img", { className: 'pb-toggle-button-icon', src: isTrue ? activeIcon : unactiveIcon })));
|
13219
|
+
return (React.createElement("button", { style: style, "aria-label": 'toggle button', className: 'pb-toggle-button', onClick: handleClick },
|
13220
|
+
React.createElement("img", { className: 'pb-toggle-button-icon', alt: 'toggle image', src: isTrue ? activeIcon : unactiveIcon })));
|
13252
13221
|
};
|
13253
13222
|
var ToggleButton$1 = React.memo(ToggleButton);
|
13254
13223
|
|
@@ -13273,7 +13242,7 @@ Made in Italy` })));
|
|
13273
13242
|
return show ? 'pb-fadeIn' : 'pb-fadeOut';
|
13274
13243
|
}, [show]);
|
13275
13244
|
return (React.createElement("div", { hidden: !show, className: `pb-finger-wrap ${animationCls}`, style: style },
|
13276
|
-
React.createElement("img", { src: imageUrl || FINGER_SWIPE_ICON })));
|
13245
|
+
React.createElement("img", { src: imageUrl || FINGER_SWIPE_ICON, alt: 'finger swiper' })));
|
13277
13246
|
};
|
13278
13247
|
|
13279
13248
|
/*
|
@@ -13535,7 +13504,7 @@ Made in Italy` })));
|
|
13535
13504
|
backgroundColor: nudge === null || nudge === void 0 ? void 0 : nudge.backgroundColor,
|
13536
13505
|
borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
|
13537
13506
|
} },
|
13538
|
-
(nudge === null || nudge === void 0 ? void 0 : nudge.icon) ? React.createElement("img", { src: nudge.icon, style: { height: '100%', objectFit: 'cover', flexShrink: 0 } }) : null,
|
13507
|
+
(nudge === null || nudge === void 0 ? void 0 : nudge.icon) ? (React.createElement("img", { src: nudge.icon, alt: 'nudge icon', style: { height: '100%', objectFit: 'cover', flexShrink: 0 } })) : null,
|
13539
13508
|
React.createElement("p", { style: Object.assign(Object.assign({}, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle), { textWrap: 'nowrap', textOverflow: 'ellipsis', overflow: 'hidden', whiteSpace: 'nowrap', flex: 1, marginBottom: 0 }) }, (_g = nudge === null || nudge === void 0 ? void 0 : nudge.content) !== null && _g !== void 0 ? _g : '')))));
|
13540
13509
|
};
|
13541
13510
|
|
@@ -13543,14 +13512,12 @@ Made in Italy` })));
|
|
13543
13512
|
* @Author: binruan@chatlabs.com
|
13544
13513
|
* @Date: 2024-04-29 16:32:21
|
13545
13514
|
* @LastEditors: binruan@chatlabs.com
|
13546
|
-
* @LastEditTime: 2024-06-
|
13515
|
+
* @LastEditTime: 2024-06-20 10:53:08
|
13547
13516
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Tagbar.tsx
|
13548
13517
|
*
|
13549
13518
|
*/
|
13550
|
-
const DEFAULT_TAG = 'FOR U';
|
13551
13519
|
const Tagbar = ({ tagList = [], setActiveIndex }) => {
|
13552
|
-
const
|
13553
|
-
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport } = useSxpDataSource();
|
13520
|
+
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport, selectTag, setSelectTag } = useSxpDataSource();
|
13554
13521
|
const { backMainFeed } = useEventReport();
|
13555
13522
|
const realTagList = React.useMemo(() => {
|
13556
13523
|
return [DEFAULT_TAG, ...tagList];
|
@@ -13563,12 +13530,12 @@ Made in Italy` })));
|
|
13563
13530
|
eventInfo: {
|
13564
13531
|
eventSubject: 'clickThemeTagsViewContents',
|
13565
13532
|
eventDescription: 'click Theme Tags View Contents',
|
13566
|
-
themeTags: `[${tag}]`
|
13533
|
+
themeTags: `['${tag}']`
|
13567
13534
|
}
|
13568
13535
|
});
|
13569
13536
|
}
|
13570
13537
|
else {
|
13571
|
-
backMainFeed('theme', selectTag);
|
13538
|
+
backMainFeed('theme', tag, selectTag);
|
13572
13539
|
}
|
13573
13540
|
let themeTag;
|
13574
13541
|
if (tag !== DEFAULT_TAG) {
|
@@ -13586,7 +13553,7 @@ Made in Italy` })));
|
|
13586
13553
|
}).finally(() => {
|
13587
13554
|
setLoading === null || setLoading === void 0 ? void 0 : setLoading(false);
|
13588
13555
|
});
|
13589
|
-
setSelectTag(tag);
|
13556
|
+
setSelectTag === null || setSelectTag === void 0 ? void 0 : setSelectTag(tag);
|
13590
13557
|
};
|
13591
13558
|
if (waterFallData || tagList.length <= 0)
|
13592
13559
|
return null;
|
@@ -13601,7 +13568,7 @@ Made in Italy` })));
|
|
13601
13568
|
* @Author: binruan@chatlabs.com
|
13602
13569
|
* @Date: 2024-01-15 19:03:09
|
13603
13570
|
* @LastEditors: binruan@chatlabs.com
|
13604
|
-
* @LastEditTime: 2024-06-
|
13571
|
+
* @LastEditTime: 2024-06-20 15:54:53
|
13605
13572
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
|
13606
13573
|
*
|
13607
13574
|
*/
|
@@ -13610,12 +13577,12 @@ Made in Italy` })));
|
|
13610
13577
|
const { schema } = useEditor();
|
13611
13578
|
const [activeIndex, setActiveIndex] = React.useState(0);
|
13612
13579
|
const viewImageStartTime = React.useRef(0);
|
13613
|
-
|
13580
|
+
React.useState(false);
|
13614
13581
|
const [isMuted, setIsMuted] = React.useState(true);
|
13615
13582
|
const viewTime = React.useRef();
|
13616
13583
|
const [isLoadMore, setIsLoadMore] = React.useState(false);
|
13617
13584
|
const [isShowMore, setIsShowMore] = React.useState(false);
|
13618
|
-
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink } = useSxpDataSource();
|
13585
|
+
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
|
13619
13586
|
const { backMainFeed } = useEventReport();
|
13620
13587
|
const [videoRef, setVideoRef] = React.useState(null);
|
13621
13588
|
const playerRef = React.useRef();
|
@@ -13623,21 +13590,29 @@ Made in Italy` })));
|
|
13623
13590
|
const isShowFingerTip = React.useMemo(() => {
|
13624
13591
|
return data.length > 0 && !loading && getFeUserId();
|
13625
13592
|
}, [data, loading]);
|
13626
|
-
|
13627
|
-
|
13628
|
-
|
13593
|
+
React.useEffect(() => {
|
13594
|
+
refreshFeSessionId();
|
13595
|
+
}, []);
|
13596
|
+
React.useEffect(() => {
|
13597
|
+
if ((data === null || data === void 0 ? void 0 : data.length) > 0) {
|
13598
|
+
const now = new Date();
|
13599
|
+
viewTime.current = now;
|
13600
|
+
bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
|
13601
|
+
eventName: 'PageView'
|
13602
|
+
});
|
13629
13603
|
}
|
13604
|
+
}, [data === null || data === void 0 ? void 0 : data.length]);
|
13605
|
+
const handleH5EnterLink = React.useCallback(() => {
|
13630
13606
|
refreshFeSessionId();
|
13631
|
-
|
13632
|
-
|
13633
|
-
|
13634
|
-
|
13607
|
+
h5EnterLink === null || h5EnterLink === void 0 ? void 0 : h5EnterLink();
|
13608
|
+
if (data.length > 0) {
|
13609
|
+
const now = new Date();
|
13610
|
+
viewTime.current = now;
|
13611
|
+
bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
|
13612
|
+
eventName: 'PageView'
|
13613
|
+
});
|
13635
13614
|
}
|
13636
|
-
|
13637
|
-
eventName: 'PageView'
|
13638
|
-
});
|
13639
|
-
setIsInit(true);
|
13640
|
-
}, [data.length, bffFbReport, h5EnterLink, isInit]);
|
13615
|
+
}, [data.length, bffFbReport, h5EnterLink]);
|
13641
13616
|
const firstRef = React.useRef();
|
13642
13617
|
React.useEffect(() => {
|
13643
13618
|
var _a, _b, _c, _d;
|
@@ -13665,10 +13640,6 @@ Made in Italy` })));
|
|
13665
13640
|
});
|
13666
13641
|
}
|
13667
13642
|
}, [videoRef, licenseUrl, data]);
|
13668
|
-
React.useEffect(() => {
|
13669
|
-
if (!isInit)
|
13670
|
-
handleH5EnterLink();
|
13671
|
-
}, [handleH5EnterLink, isInit]);
|
13672
13643
|
React.useEffect(() => {
|
13673
13644
|
var _a;
|
13674
13645
|
const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
|
@@ -13689,10 +13660,11 @@ Made in Italy` })));
|
|
13689
13660
|
const item = data === null || data === void 0 ? void 0 : data[activeIndex];
|
13690
13661
|
const visibleChange = () => {
|
13691
13662
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
|
13663
|
+
const repCond = !openHashtag && !isShowConsent;
|
13692
13664
|
if (document.visibilityState === 'hidden') {
|
13693
13665
|
// 当用户导航到新页面、切换标签页、关闭标签页、最小化或关闭浏览器、刷新原页面(即离开原页面时),或者在移动设备上从浏览器切换到不同的应用程序时
|
13694
13666
|
// 移动端h5直接杀掉浏览器或宿主app时不会触发,pc端直接杀掉标签页时能触发
|
13695
|
-
if (
|
13667
|
+
if (repCond) {
|
13696
13668
|
SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_HIDE, item);
|
13697
13669
|
handleReportViewImageEnd(item);
|
13698
13670
|
handleReportProductView(item);
|
@@ -13733,11 +13705,11 @@ Made in Italy` })));
|
|
13733
13705
|
else if (document.visibilityState === 'visible') {
|
13734
13706
|
// 页面可见时触发,注意页面初始化时不会触发
|
13735
13707
|
handleH5EnterLink();
|
13736
|
-
if (
|
13708
|
+
if (repCond) {
|
13737
13709
|
handleViewImageStartEvent(activeIndex);
|
13738
13710
|
SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
|
13711
|
+
backMainFeed('external', selectTag);
|
13739
13712
|
}
|
13740
|
-
backMainFeed('external');
|
13741
13713
|
}
|
13742
13714
|
};
|
13743
13715
|
document.addEventListener('visibilitychange', visibleChange);
|
@@ -13754,17 +13726,10 @@ Made in Italy` })));
|
|
13754
13726
|
tempMap,
|
13755
13727
|
curTime,
|
13756
13728
|
backMainFeed,
|
13757
|
-
openHashtag
|
13729
|
+
openHashtag,
|
13730
|
+
isShowConsent,
|
13731
|
+
selectTag
|
13758
13732
|
]);
|
13759
|
-
React.useEffect(() => {
|
13760
|
-
const initTime = () => {
|
13761
|
-
backMainFeed('external');
|
13762
|
-
};
|
13763
|
-
window.addEventListener('pageshow', initTime);
|
13764
|
-
return () => {
|
13765
|
-
window.removeEventListener('pageshow', initTime);
|
13766
|
-
};
|
13767
|
-
}, []);
|
13768
13733
|
const tagHeight = React.useMemo(() => {
|
13769
13734
|
let h = 0;
|
13770
13735
|
if (tagList.length > 0) {
|
@@ -14037,24 +14002,7 @@ Made in Italy` })));
|
|
14037
14002
|
});
|
14038
14003
|
}
|
14039
14004
|
}
|
14040
|
-
},
|
14041
|
-
// style={{
|
14042
|
-
// pointerEvents: canSwiper ? 'auto' : 'none'
|
14043
|
-
// }}
|
14044
|
-
// onReachEnd={() => {
|
14045
|
-
// // 由hashtaglist跳转过来时不执行下面的方法
|
14046
|
-
// if (waterFallData) return;
|
14047
|
-
// if (!isLoadMore) {
|
14048
|
-
// console.log('trigger load 2');
|
14049
|
-
// setIsLoadMore(true);
|
14050
|
-
// loadVideos?.(Math.ceil(activeIndex / 10) + 1).then(() => {
|
14051
|
-
// setIsLoadMore(false);
|
14052
|
-
// });
|
14053
|
-
// }
|
14054
|
-
// }}
|
14055
|
-
// modules={[Virtual]}
|
14056
|
-
// virtual={{ enabled: true, cache: true }}
|
14057
|
-
direction: 'vertical', height: height },
|
14005
|
+
}, direction: 'vertical', height: height },
|
14058
14006
|
React.createElement(ToggleButton$1, { style: {
|
14059
14007
|
position: 'fixed',
|
14060
14008
|
visibility: ((_c = (_b = data === null || data === void 0 ? void 0 : data[activeIndex]) === null || _b === void 0 ? void 0 : _b.video) === null || _c === void 0 ? void 0 : _c.url) ? 'visible' : 'hidden',
|
@@ -14253,7 +14201,7 @@ Made in Italy` })));
|
|
14253
14201
|
if (!(sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image) || isLoadFinish) {
|
14254
14202
|
return null;
|
14255
14203
|
}
|
14256
|
-
return (React.createElement("img", { style: { position: 'absolute', left: 0, top: 0, width: '100%', height: '100%', objectFit: 'cover' }, src: sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image }));
|
14204
|
+
return (React.createElement("img", { style: { position: 'absolute', left: 0, top: 0, width: '100%', height: '100%', objectFit: 'cover' }, src: sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image, alt: 'video poster' }));
|
14257
14205
|
}, [isLoadFinish, sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.placeholder_image]);
|
14258
14206
|
React.useEffect(() => {
|
14259
14207
|
const handleBeforeUnload = () => {
|
@@ -14302,7 +14250,7 @@ Made in Italy` })));
|
|
14302
14250
|
height,
|
14303
14251
|
objectFit: 'contain'
|
14304
14252
|
} }),
|
14305
|
-
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON }))),
|
14253
|
+
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON, alt: 'video pause image' }))),
|
14306
14254
|
renderPoster)) : (React.createElement("div", { className: 'video-container', key: rec === null || rec === void 0 ? void 0 : rec.video.itemId, onClick: handleClickVideo(), style: {
|
14307
14255
|
position: 'relative',
|
14308
14256
|
width,
|
@@ -14311,7 +14259,7 @@ Made in Italy` })));
|
|
14311
14259
|
} },
|
14312
14260
|
React.createElement("video", { id: `pb-video-${index}`, className: 'clc-pb-video', style: { width: '100%' }, ref: videoRef, crossOrigin: 'anonymous', muted: true, autoPlay: true, controls: false, playsInline: true, preload: 'auto', onPause: onPause, onEnded: handleVideoStart }),
|
14313
14261
|
renderPoster,
|
14314
|
-
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON })))));
|
14262
|
+
React.createElement("img", { hidden: !isPauseVideo, className: 'clc-pb-video-pause', src: PAUSE_ICON, alt: 'video pause image' })))));
|
14315
14263
|
};
|
14316
14264
|
var VideoWidget$1 = React.memo(VideoWidget);
|
14317
14265
|
|
@@ -14602,4 +14550,3 @@ Made in Italy` })));
|
|
14602
14550
|
Object.defineProperty(exports, '__esModule', { value: true });
|
14603
14551
|
|
14604
14552
|
}));
|
14605
|
-
//# sourceMappingURL=pb-ui.js.map
|