pb-sxp-ui 1.0.80 → 1.0.81
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 +321 -85
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +93 -0
- package/dist/index.js +322 -86
- 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 +321 -85
- 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/Pagebuilder/type.d.ts +7 -0
- package/es/core/components/Consent/index.d.ts +13 -0
- package/es/core/components/Consent/index.js +60 -0
- package/es/core/components/SxpPageCore/index.js +2 -2
- package/es/core/components/SxpPageRender/Tagbar.js +15 -1
- package/es/core/components/SxpPageRender/WaterFall/List.d.ts +1 -1
- package/es/core/components/SxpPageRender/WaterFall/List.js +15 -9
- package/es/core/components/SxpPageRender/WaterFall/WaterfallList.d.ts +1 -1
- package/es/core/components/SxpPageRender/WaterFall/WaterfallList.js +18 -12
- package/es/core/components/SxpPageRender/WaterFall/index.js +7 -2
- package/es/core/components/SxpPageRender/index.d.ts +2 -1
- package/es/core/components/SxpPageRender/index.js +30 -10
- package/es/core/components/SxpPageRender/typing.d.ts +1 -0
- package/es/core/context/EditorDataProvider.d.ts +9 -0
- package/es/core/context/EditorDataProvider.js +13 -3
- package/es/core/context/SxpDataSourceProvider.d.ts +10 -0
- package/es/core/context/SxpDataSourceProvider.js +37 -21
- package/es/core/hooks/useEventReport.d.ts +1 -0
- package/es/core/hooks/useEventReport.js +13 -1
- package/es/core/utils/localStore.d.ts +1 -0
- package/es/core/utils/localStore.js +1 -0
- package/es/materials/sxp/Consent/index.d.ts +12 -0
- package/es/materials/sxp/Consent/index.js +5 -0
- package/es/materials/sxp/Consent/material.d.ts +2 -0
- package/es/materials/sxp/Consent/material.js +20 -0
- package/es/materials/sxp/Consent/settingRender.d.ts +31 -0
- package/es/materials/sxp/Consent/settingRender.js +39 -0
- package/es/materials/sxp/HashTag/index.d.ts +1 -1
- package/es/materials/sxp/HashTag/settingRender.js +1 -1
- package/es/materials/sxp/index.d.ts +1 -0
- package/es/materials/sxp/index.js +1 -0
- package/lib/core/Pagebuilder/type.d.ts +7 -0
- package/lib/core/components/Consent/index.d.ts +13 -0
- package/lib/core/components/Consent/index.js +63 -0
- package/lib/core/components/SxpPageCore/index.js +2 -2
- package/lib/core/components/SxpPageRender/Tagbar.js +15 -1
- package/lib/core/components/SxpPageRender/WaterFall/List.d.ts +1 -1
- package/lib/core/components/SxpPageRender/WaterFall/List.js +15 -9
- package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.d.ts +1 -1
- package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.js +18 -12
- package/lib/core/components/SxpPageRender/WaterFall/index.js +7 -2
- package/lib/core/components/SxpPageRender/index.d.ts +2 -1
- package/lib/core/components/SxpPageRender/index.js +30 -10
- package/lib/core/components/SxpPageRender/typing.d.ts +1 -0
- package/lib/core/context/EditorDataProvider.d.ts +9 -0
- package/lib/core/context/EditorDataProvider.js +13 -3
- package/lib/core/context/SxpDataSourceProvider.d.ts +10 -0
- package/lib/core/context/SxpDataSourceProvider.js +36 -20
- package/lib/core/hooks/useEventReport.d.ts +1 -0
- package/lib/core/hooks/useEventReport.js +13 -1
- package/lib/core/utils/localStore.d.ts +1 -0
- package/lib/core/utils/localStore.js +2 -1
- package/lib/materials/sxp/Consent/index.d.ts +12 -0
- package/lib/materials/sxp/Consent/index.js +8 -0
- package/lib/materials/sxp/Consent/material.d.ts +2 -0
- package/lib/materials/sxp/Consent/material.js +24 -0
- package/lib/materials/sxp/Consent/settingRender.d.ts +31 -0
- package/lib/materials/sxp/Consent/settingRender.js +41 -0
- package/lib/materials/sxp/HashTag/index.d.ts +1 -1
- package/lib/materials/sxp/HashTag/settingRender.js +1 -1
- package/lib/materials/sxp/index.d.ts +1 -0
- package/lib/materials/sxp/index.js +1 -0
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
@@ -393,6 +393,7 @@ const getFeSessionId = () => {
|
|
393
393
|
|
394
394
|
const FAKE_USER_KEY = 'SXP_FAKE_USER_ID';
|
395
395
|
const FAKE_USER_STATE = 'FAKE_USER_STATE';
|
396
|
+
const AGREE_POLICY = 'AGREE_POLICY';
|
396
397
|
const storeAndLoadFeUserId = () => {
|
397
398
|
let fakeUserId = window.localStorage.getItem(FAKE_USER_KEY);
|
398
399
|
if (lodash.isEmpty(fakeUserId)) {
|
@@ -437,6 +438,70 @@ var SXP_EVENT_TYPE;
|
|
437
438
|
SXP_EVENT_TYPE["CHANGE_THEME_TAG"] = "changeThemeTag";
|
438
439
|
})(SXP_EVENT_TYPE || (SXP_EVENT_TYPE = {}));
|
439
440
|
|
441
|
+
/*
|
442
|
+
* @Author: binruan@chatlabs.com
|
443
|
+
* @Date: 2024-06-13 15:16:53
|
444
|
+
* @LastEditors: binruan@chatlabs.com
|
445
|
+
* @LastEditTime: 2024-06-13 18:22:53
|
446
|
+
* @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
|
447
|
+
*
|
448
|
+
*/
|
449
|
+
const Consent$2 = ({ width = window.innerWidth, height = window.innerHeight, privacy_title, privacy_context, privacy_policy_url, privacy_policy_title }) => {
|
450
|
+
const { setIsAgreePolicy, bffEventReport } = useSxpDataSource();
|
451
|
+
const channelObj = React.useMemo(() => {
|
452
|
+
const queryString = location.search.slice(1);
|
453
|
+
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
454
|
+
for (const key in params) {
|
455
|
+
params[key] = params[key].replace(/%2B/g, '+');
|
456
|
+
}
|
457
|
+
return params;
|
458
|
+
}, []);
|
459
|
+
const getUtmValue = (key) => { var _a; return (_a = channelObj[key]) !== null && _a !== void 0 ? _a : null; };
|
460
|
+
React.useEffect(() => {
|
461
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
462
|
+
eventInfo: {
|
463
|
+
eventSubject: 'privacyEnter',
|
464
|
+
eventDescription: 'User enter privacy page',
|
465
|
+
utmSource: getUtmValue('utm_source'),
|
466
|
+
utmMedium: getUtmValue('utm_medium'),
|
467
|
+
utmCampaign: getUtmValue('utm_campaign'),
|
468
|
+
utmId: getUtmValue('utm_id'),
|
469
|
+
utmContent: getUtmValue('utm_content'),
|
470
|
+
clSource: getUtmValue('cl_source'),
|
471
|
+
enterTime: `${Date.now()}`,
|
472
|
+
enterUrl: window.location.href,
|
473
|
+
rtc: null,
|
474
|
+
requestId: null,
|
475
|
+
sessionID: null
|
476
|
+
}
|
477
|
+
});
|
478
|
+
}, []);
|
479
|
+
const handleAgree = () => {
|
480
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
481
|
+
eventInfo: {
|
482
|
+
eventSubject: 'userConsent',
|
483
|
+
eventDescription: '用户授权【操作结果】',
|
484
|
+
consentResult: '0',
|
485
|
+
consentTags: '[]',
|
486
|
+
rtc: null,
|
487
|
+
requestId: null,
|
488
|
+
sessionID: null
|
489
|
+
}
|
490
|
+
});
|
491
|
+
setIsAgreePolicy === null || setIsAgreePolicy === void 0 ? void 0 : setIsAgreePolicy(true);
|
492
|
+
window.localStorage.setItem(AGREE_POLICY, 'yes');
|
493
|
+
};
|
494
|
+
return (React.createElement("div", { className: 'consent-bg' },
|
495
|
+
React.createElement("div", { className: 'consent' },
|
496
|
+
React.createElement("div", { className: 'consent-col' },
|
497
|
+
React.createElement("div", { className: 'consent-title' }, privacy_title !== null && privacy_title !== void 0 ? privacy_title : 'Privacy Policy'),
|
498
|
+
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.')),
|
499
|
+
React.createElement("div", { className: 'consent-col' },
|
500
|
+
React.createElement("button", { className: 'consent-btn', onClick: handleAgree }, "Agree"),
|
501
|
+
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')))));
|
502
|
+
};
|
503
|
+
var Consent$3 = React.memo(Consent$2);
|
504
|
+
|
440
505
|
const SxpDataSourceContext = React.createContext({
|
441
506
|
rtcList: [],
|
442
507
|
tagList: []
|
@@ -446,13 +511,15 @@ var DataSourceType;
|
|
446
511
|
DataSourceType[DataSourceType["BFF"] = 5] = "BFF";
|
447
512
|
})(DataSourceType || (DataSourceType = {}));
|
448
513
|
const UTM_KEYS = ['utm_source', 'utm_medium', 'utm_campaign', 'utm_id', 'utm_content', 'cl_source'];
|
449
|
-
const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent = true, maxSize, defaultSize, isPreview = false, sxpParameter, appDomain, hashTagSize, loadingImage, isOpenHashTag = false, enabledMetaConversionApi = false, isShowTag = true }) => {
|
514
|
+
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 }) => {
|
515
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
450
516
|
const [rtcList, setRtcList] = React.useState([]);
|
451
517
|
const [tagList, setTagList] = React.useState([]);
|
452
518
|
const [loading, setLoading] = React.useState(false);
|
453
519
|
const [curReqInfo, setCurReqInfo] = React.useState({ rtc: '', requestId: '' });
|
454
520
|
const swiperRef = React.useRef(null);
|
455
521
|
const isInit = React.useRef(false);
|
522
|
+
const [isAgreePolicy, setIsAgreePolicy] = React.useState(() => !!window.localStorage.getItem(AGREE_POLICY));
|
456
523
|
// 弹窗数据
|
457
524
|
const [popupDetailData, setPopupDetailData] = React.useState();
|
458
525
|
const [waterFallData, setWaterFallData] = React.useState();
|
@@ -462,6 +529,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
462
529
|
const [isFromHashtag, setIsFromHashtag] = React.useState(false);
|
463
530
|
const [videoRef, setVideoRef] = React.useState(null);
|
464
531
|
const themeTag = React.useRef();
|
532
|
+
const curTime = React.useRef();
|
465
533
|
React.useEffect(() => {
|
466
534
|
const handleChangeThemeTag = (tag) => {
|
467
535
|
themeTag.current = tag;
|
@@ -506,10 +574,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
506
574
|
}, [bffDataSource]);
|
507
575
|
// 获取推荐视频数据
|
508
576
|
const getRecommendVideos = React.useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
|
509
|
-
var
|
577
|
+
var _h, _j, _k, _l, _m;
|
510
578
|
query = {
|
511
|
-
maxSize: (
|
512
|
-
defaultSize: (
|
579
|
+
maxSize: (_h = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _h !== void 0 ? _h : maxSize,
|
580
|
+
defaultSize: (_j = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _j !== void 0 ? _j : defaultSize,
|
513
581
|
'itemFilter.itemId': query === null || query === void 0 ? void 0 : query['itemFilter.itemId'],
|
514
582
|
'itemFilter.itemType': query === null || query === void 0 ? void 0 : query['itemFilter.itemType'],
|
515
583
|
hashTag: query === null || query === void 0 ? void 0 : query.hashTag,
|
@@ -517,10 +585,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
517
585
|
themeTag: query === null || query === void 0 ? void 0 : query.themeTag
|
518
586
|
};
|
519
587
|
if (utmVal) {
|
520
|
-
const val = (
|
588
|
+
const val = (_m = (_l = (_k = utmVal === null || utmVal === void 0 ? void 0 : utmVal.split('&')) === null || _k === void 0 ? void 0 : _k.filter((val) => {
|
521
589
|
const key = val.split('=')[0];
|
522
590
|
return UTM_KEYS.includes(key);
|
523
|
-
})) === null ||
|
591
|
+
})) === null || _l === void 0 ? void 0 : _l.join('&')) !== null && _m !== void 0 ? _m : '';
|
524
592
|
query = Object.assign(Object.assign({}, query), { channel: decodeURIComponent(val) });
|
525
593
|
}
|
526
594
|
const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'GET', query }));
|
@@ -532,7 +600,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
532
600
|
return result === null || result === void 0 ? void 0 : result.data;
|
533
601
|
}), [bffFetch, utmVal, maxSize, defaultSize]);
|
534
602
|
const loadVideos = React.useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
|
535
|
-
var
|
603
|
+
var _o, _p;
|
536
604
|
if (rtcList.length <= 0) {
|
537
605
|
return;
|
538
606
|
}
|
@@ -542,8 +610,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
542
610
|
'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType,
|
543
611
|
themeTag: themeTag.current
|
544
612
|
});
|
545
|
-
setRtcList(rtcList.concat((
|
546
|
-
setCacheRtcList(cacheRtcList.concat((
|
613
|
+
setRtcList(rtcList.concat((_o = data === null || data === void 0 ? void 0 : data.recList) !== null && _o !== void 0 ? _o : []));
|
614
|
+
setCacheRtcList(cacheRtcList.concat((_p = data === null || data === void 0 ? void 0 : data.recList) !== null && _p !== void 0 ? _p : []));
|
547
615
|
}), [getRecommendVideos, rtcList, waterFallData, cacheRtcList]);
|
548
616
|
const bffEventReport = React.useCallback(({ userInfo, eventInfo }) => {
|
549
617
|
// 关闭 BFF 事件上报
|
@@ -607,16 +675,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
607
675
|
}), [bffFetch]);
|
608
676
|
// 获取 Tag
|
609
677
|
const bffGetTagList = React.useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
|
610
|
-
var
|
678
|
+
var _q, _r, _s, _t, _u;
|
611
679
|
if (!utmVal || !isShowTag)
|
612
680
|
return;
|
613
681
|
try {
|
614
|
-
const val = (
|
682
|
+
const val = (_s = (_r = (_q = utmVal === null || utmVal === void 0 ? void 0 : utmVal.split('&')) === null || _q === void 0 ? void 0 : _q.filter((val) => {
|
615
683
|
const key = val.split('=')[0];
|
616
684
|
return UTM_KEYS.includes(key);
|
617
|
-
})) === null ||
|
685
|
+
})) === null || _r === void 0 ? void 0 : _r.join('&')) !== null && _s !== void 0 ? _s : '';
|
618
686
|
const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
|
619
|
-
setTagList((
|
687
|
+
setTagList((_u = (_t = result === null || result === void 0 ? void 0 : result.data) === null || _t === void 0 ? void 0 : _t.tags) !== null && _u !== void 0 ? _u : []);
|
620
688
|
}
|
621
689
|
catch (e) {
|
622
690
|
console.log('e', e);
|
@@ -640,7 +708,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
640
708
|
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 })
|
641
709
|
});
|
642
710
|
}, [bffEventReport, isFromHashtag]);
|
643
|
-
React.
|
711
|
+
const h5EnterLink = React.useCallback(() => {
|
644
712
|
var _a, _b;
|
645
713
|
const queryString = location.search.slice(1);
|
646
714
|
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
@@ -648,6 +716,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
648
716
|
params[key] = params[key].replace(/%2B/g, '+');
|
649
717
|
}
|
650
718
|
const getVal = (key) => { var _a; return (_a = params[key]) !== null && _a !== void 0 ? _a : ''; };
|
719
|
+
const time = new Date();
|
720
|
+
curTime.current = time;
|
651
721
|
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
652
722
|
eventInfo: {
|
653
723
|
eventSubject: 'h5LinkEnterFeed',
|
@@ -657,14 +727,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
657
727
|
utmCampaign: getVal('utm_campaign'),
|
658
728
|
utmId: getVal('utm_id'),
|
659
729
|
utmContent: getVal('utm_content'),
|
660
|
-
enterTime:
|
730
|
+
enterTime: Math.floor(time / 1000) + '',
|
661
731
|
requestId: null,
|
662
732
|
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 : '',
|
663
|
-
clSource: getVal('
|
733
|
+
clSource: getVal('cl_source')
|
664
734
|
}
|
665
735
|
});
|
736
|
+
}, [bffEventReport]);
|
737
|
+
React.useEffect(() => {
|
738
|
+
h5EnterLink();
|
666
739
|
}, []);
|
667
740
|
React.useEffect(() => {
|
741
|
+
if (!isAgreePolicy)
|
742
|
+
return;
|
668
743
|
setLoading(true);
|
669
744
|
bffGetTagList();
|
670
745
|
getRecommendVideos()
|
@@ -683,7 +758,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
683
758
|
setLoading(false);
|
684
759
|
isInit.current = true;
|
685
760
|
});
|
686
|
-
}, []);
|
761
|
+
}, [isAgreePolicy]);
|
687
762
|
React.useEffect(() => {
|
688
763
|
if (!isInit.current)
|
689
764
|
return;
|
@@ -735,14 +810,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
735
810
|
setLoading,
|
736
811
|
videoRef,
|
737
812
|
setVideoRef,
|
738
|
-
bffFbReport
|
739
|
-
|
813
|
+
bffFbReport,
|
814
|
+
isAgreePolicy,
|
815
|
+
setIsAgreePolicy,
|
816
|
+
curTime,
|
817
|
+
h5EnterLink,
|
818
|
+
themeTag
|
819
|
+
} }, (((_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) || isOpenConsent ? (React.createElement(Consent$3, Object.assign({}, (_g = (_f = (_e = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.consent) === null || _e === void 0 ? void 0 : _e[0]) === null || _f === void 0 ? void 0 : _f.item) === null || _g === void 0 ? void 0 : _g.props))) : (render({
|
740
820
|
rtcList,
|
741
821
|
mutateLike: bffMutateLike,
|
742
822
|
mutateUnlike: bffMutateUnlike,
|
743
823
|
submitForm: bffSubmitForm,
|
744
824
|
tagList
|
745
|
-
})));
|
825
|
+
}))));
|
746
826
|
};
|
747
827
|
var SxpDataSourceProvider$1 = React.memo(SxpDataSourceProvider);
|
748
828
|
|
@@ -1008,7 +1088,7 @@ var defaultSetting = {
|
|
1008
1088
|
*
|
1009
1089
|
*/
|
1010
1090
|
var _a$5, _b$5, _c;
|
1011
|
-
var settingRender$
|
1091
|
+
var settingRender$6 = [
|
1012
1092
|
{
|
1013
1093
|
type: 'Text',
|
1014
1094
|
label: '组件名称',
|
@@ -1146,7 +1226,7 @@ var settingRender$5 = [
|
|
1146
1226
|
* @Author: binruan@chatlabs.com
|
1147
1227
|
* @Date: 2024-03-12 10:59:06
|
1148
1228
|
* @LastEditors: binruan@chatlabs.com
|
1149
|
-
* @LastEditTime: 2024-
|
1229
|
+
* @LastEditTime: 2024-06-12 10:53:57
|
1150
1230
|
* @FilePath: \pb-sxp-ui\src\core\hooks\useEventReport.ts
|
1151
1231
|
*
|
1152
1232
|
*/
|
@@ -1216,9 +1296,21 @@ function useEventReport() {
|
|
1216
1296
|
}
|
1217
1297
|
});
|
1218
1298
|
}, [bffEventReport, popupDetailData]);
|
1299
|
+
const backMainFeed = React.useCallback((lastFeed, themeTag, hashTag) => {
|
1300
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
1301
|
+
eventInfo: {
|
1302
|
+
lastFeed,
|
1303
|
+
themeTags: themeTag ? `[${themeTag}]` : '',
|
1304
|
+
hashTags: hashTag ? `[${hashTag}]` : '',
|
1305
|
+
eventSubject: 'backMainFeed',
|
1306
|
+
eventDescription: 'back Main Feed'
|
1307
|
+
}
|
1308
|
+
});
|
1309
|
+
}, [bffEventReport]);
|
1219
1310
|
return {
|
1220
1311
|
jumpToWeb,
|
1221
|
-
productView
|
1312
|
+
productView,
|
1313
|
+
backMainFeed
|
1222
1314
|
};
|
1223
1315
|
}
|
1224
1316
|
|
@@ -1323,7 +1415,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
|
|
1323
1415
|
category: 'popup',
|
1324
1416
|
type: 'AppointForm',
|
1325
1417
|
related: {
|
1326
|
-
settingRender: settingRender$
|
1418
|
+
settingRender: settingRender$6,
|
1327
1419
|
bindableProps: [],
|
1328
1420
|
interactionRender: interactionRender$8
|
1329
1421
|
},
|
@@ -1349,7 +1441,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
|
|
1349
1441
|
});
|
1350
1442
|
|
1351
1443
|
var _a$4, _b$4;
|
1352
|
-
var settingRender$
|
1444
|
+
var settingRender$5 = [
|
1353
1445
|
{
|
1354
1446
|
title: '商品图片',
|
1355
1447
|
child: [
|
@@ -8663,7 +8755,7 @@ const CommodityDetail = createMaterial(CommodityDetailComponent, {
|
|
8663
8755
|
category: 'popup',
|
8664
8756
|
type: 'CommodityDetail',
|
8665
8757
|
related: {
|
8666
|
-
settingRender: settingRender$
|
8758
|
+
settingRender: settingRender$5
|
8667
8759
|
},
|
8668
8760
|
defaulSetting: {
|
8669
8761
|
props: {
|
@@ -8729,7 +8821,7 @@ var interactionRender$7 = [
|
|
8729
8821
|
*
|
8730
8822
|
*/
|
8731
8823
|
var _a$3, _b$3;
|
8732
|
-
var settingRender$
|
8824
|
+
var settingRender$4 = [
|
8733
8825
|
{
|
8734
8826
|
title: '',
|
8735
8827
|
child: [
|
@@ -8856,7 +8948,7 @@ const Prompt = createMaterial(PromptComponent, {
|
|
8856
8948
|
category: 'popup',
|
8857
8949
|
type: 'Prompt',
|
8858
8950
|
related: {
|
8859
|
-
settingRender: settingRender$
|
8951
|
+
settingRender: settingRender$4,
|
8860
8952
|
bindableProps: [],
|
8861
8953
|
interactionRender: interactionRender$7
|
8862
8954
|
},
|
@@ -8882,7 +8974,7 @@ var _a$2, _b$2;
|
|
8882
8974
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
|
8883
8975
|
*
|
8884
8976
|
*/
|
8885
|
-
var settingRender$
|
8977
|
+
var settingRender$3 = [
|
8886
8978
|
{
|
8887
8979
|
title: '商品图片',
|
8888
8980
|
child: [
|
@@ -9205,7 +9297,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
|
|
9205
9297
|
category: 'popup',
|
9206
9298
|
type: 'CommodityDetailDiroNew',
|
9207
9299
|
related: {
|
9208
|
-
settingRender: settingRender$
|
9300
|
+
settingRender: settingRender$3
|
9209
9301
|
},
|
9210
9302
|
defaulSetting: {
|
9211
9303
|
props: {
|
@@ -9266,7 +9358,7 @@ var _a$1, _b$1;
|
|
9266
9358
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
|
9267
9359
|
*
|
9268
9360
|
*/
|
9269
|
-
var settingRender$
|
9361
|
+
var settingRender$2 = [
|
9270
9362
|
{
|
9271
9363
|
title: '主题样式',
|
9272
9364
|
child: [
|
@@ -9618,7 +9710,7 @@ const Commodity = createMaterial(CommodityComponent, {
|
|
9618
9710
|
related: {
|
9619
9711
|
interactionRender: interactionRender$6,
|
9620
9712
|
bindableProps: [],
|
9621
|
-
settingRender: settingRender$
|
9713
|
+
settingRender: settingRender$2
|
9622
9714
|
},
|
9623
9715
|
defaulSetting: {
|
9624
9716
|
props: {
|
@@ -9697,7 +9789,7 @@ const Appoint = createMaterial(AppointComponent, {
|
|
9697
9789
|
type: 'Appoint',
|
9698
9790
|
related: {
|
9699
9791
|
interactionRender: interactionRender$5,
|
9700
|
-
settingRender: settingRender$
|
9792
|
+
settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
|
9701
9793
|
bindableProps: []
|
9702
9794
|
},
|
9703
9795
|
defaulSetting: {
|
@@ -9774,7 +9866,7 @@ const Link = createMaterial(LinkComponent, {
|
|
9774
9866
|
category: 'template',
|
9775
9867
|
type: 'Link',
|
9776
9868
|
related: {
|
9777
|
-
settingRender: settingRender$
|
9869
|
+
settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
|
9778
9870
|
bindableProps: []
|
9779
9871
|
},
|
9780
9872
|
defaulSetting: {
|
@@ -9866,7 +9958,7 @@ const CommodityDiro = createMaterial(CommodityDiroComponent, {
|
|
9866
9958
|
type: 'CommodityDiro',
|
9867
9959
|
related: {
|
9868
9960
|
interactionRender: interactionRender$4,
|
9869
|
-
settingRender: settingRender$
|
9961
|
+
settingRender: settingRender$2,
|
9870
9962
|
bindableProps: []
|
9871
9963
|
},
|
9872
9964
|
defaulSetting: {
|
@@ -9965,7 +10057,7 @@ const CommodityDiroNew = createMaterial(CommodityDiroNewComponent, {
|
|
9965
10057
|
related: {
|
9966
10058
|
interactionRender: interactionRender$3,
|
9967
10059
|
bindableProps: [],
|
9968
|
-
settingRender: settingRender$
|
10060
|
+
settingRender: settingRender$2
|
9969
10061
|
},
|
9970
10062
|
defaulSetting: {
|
9971
10063
|
props: {
|
@@ -10110,7 +10202,7 @@ const MultiCommodityDiro = createMaterial(MultiCommodityDiroComponent, {
|
|
10110
10202
|
related: {
|
10111
10203
|
interactionRender: interactionRender$2,
|
10112
10204
|
bindableProps: [],
|
10113
|
-
settingRender: settingRender$
|
10205
|
+
settingRender: settingRender$2
|
10114
10206
|
},
|
10115
10207
|
defaulSetting: {
|
10116
10208
|
props: {
|
@@ -10224,7 +10316,7 @@ const MultiCommodity = createMaterial(MultiCommodityComponent, {
|
|
10224
10316
|
type: 'MultiCommodity',
|
10225
10317
|
related: {
|
10226
10318
|
interactionRender: interactionRender$1,
|
10227
|
-
settingRender: settingRender$
|
10319
|
+
settingRender: settingRender$2,
|
10228
10320
|
bindableProps: []
|
10229
10321
|
},
|
10230
10322
|
defaulSetting: {
|
@@ -10340,7 +10432,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
|
|
10340
10432
|
related: {
|
10341
10433
|
interactionRender,
|
10342
10434
|
bindableProps: [],
|
10343
|
-
settingRender: settingRender$
|
10435
|
+
settingRender: settingRender$2
|
10344
10436
|
},
|
10345
10437
|
defaulSetting: {
|
10346
10438
|
props: {
|
@@ -10386,11 +10478,11 @@ var _a, _b;
|
|
10386
10478
|
* @Author: binruan@chatlabs.com
|
10387
10479
|
* @Date: 2024-04-07 14:07:12
|
10388
10480
|
* @LastEditors: binruan@chatlabs.com
|
10389
|
-
* @LastEditTime: 2024-06-
|
10481
|
+
* @LastEditTime: 2024-06-11 11:04:55
|
10390
10482
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
|
10391
10483
|
*
|
10392
10484
|
*/
|
10393
|
-
var settingRender = [
|
10485
|
+
var settingRender$1 = [
|
10394
10486
|
{
|
10395
10487
|
title: 'Banner',
|
10396
10488
|
child: [
|
@@ -10413,7 +10505,7 @@ var settingRender = [
|
|
10413
10505
|
{
|
10414
10506
|
type: 'Switch',
|
10415
10507
|
label: '固定宽高',
|
10416
|
-
name: ['props', '
|
10508
|
+
name: ['props', 'openFixedSize'],
|
10417
10509
|
initialValue: true
|
10418
10510
|
}
|
10419
10511
|
]
|
@@ -12023,8 +12115,8 @@ const WaterfallFlowItem$1 = (props) => {
|
|
12023
12115
|
React.createElement("div", { className: 'waterFallList-content-listItem-info-price', hidden: !priceText, style: textStyles.price }, priceText))));
|
12024
12116
|
};
|
12025
12117
|
function WaterfallList$1(_a) {
|
12026
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
|
12027
|
-
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
12118
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
|
12119
|
+
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12028
12120
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12029
12121
|
/** 滚动的父元素 */
|
12030
12122
|
const scrollParent = React.useRef(null);
|
@@ -12228,25 +12320,30 @@ function WaterfallList$1(_a) {
|
|
12228
12320
|
return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
|
12229
12321
|
React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'waterFallList', ref: waterfallFlowDom },
|
12230
12322
|
React.createElement("div", { className: 'waterFallList-scroll', ref: scrollParent },
|
12231
|
-
|
12232
|
-
|
12323
|
+
showBanner && ((_b = data === null || data === void 0 ? void 0 : data.tag) === null || _b === void 0 ? void 0 : _b.picture) && (React.createElement(FormatImage$1, { className: css.css({
|
12324
|
+
width: '100%',
|
12325
|
+
objectFit: 'cover',
|
12326
|
+
marginBottom: '20px'
|
12327
|
+
}), src: (_c = data === null || data === void 0 ? void 0 : data.tag) === null || _c === void 0 ? void 0 : _c.picture })),
|
12328
|
+
React.createElement("div", { className: 'waterFallList-info', style: (_d = props === null || props === void 0 ? void 0 : props.textStyles) === null || _d === void 0 ? void 0 : _d.hashTagDesc }, (_e = data === null || data === void 0 ? void 0 : data.tag) === null || _e === void 0 ? void 0 : _e.info),
|
12329
|
+
React.createElement("div", { hidden: !((_f = data === null || data === void 0 ? void 0 : data.tag) === null || _f === void 0 ? void 0 : _f.link), className: 'waterFallList-collection', style: Object.assign({}, (_g = props === null || props === void 0 ? void 0 : props.textStyles) === null || _g === void 0 ? void 0 : _g.hashTagLink), onClick: handleClickLink }, ((_h = data === null || data === void 0 ? void 0 : data.tag) === null || _h === void 0 ? void 0 : _h.linkTitle) || 'Shop the collection'),
|
12233
12330
|
React.createElement("div", { className: 'waterFallList-content' }, list === null || list === void 0 ? void 0 :
|
12234
12331
|
list.map((item, ind) => {
|
12235
12332
|
var _a;
|
12236
12333
|
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)));
|
12237
12334
|
}),
|
12238
|
-
React.createElement("div", { hidden: !((
|
12335
|
+
React.createElement("div", { hidden: !((_j = data === null || data === void 0 ? void 0 : data.tag) === null || _j === void 0 ? void 0 : _j.link), style: {
|
12239
12336
|
position: 'absolute',
|
12240
12337
|
width: '100%',
|
12241
|
-
transform: `translate(0px,${(
|
12242
|
-
((
|
12243
|
-
height: ((
|
12244
|
-
? ((
|
12338
|
+
transform: `translate(0px,${(_p = ((_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.top) +
|
12339
|
+
((_o = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current[((_m = waterfallFlowListInfo === null || waterfallFlowListInfo === void 0 ? void 0 : waterfallFlowListInfo.current) === null || _m === void 0 ? void 0 : _m.length) - 1]) === null || _o === void 0 ? void 0 : _o.height)) !== null && _p !== void 0 ? _p : 0}px)`,
|
12340
|
+
height: ((_q = data === null || data === void 0 ? void 0 : data.tag) === null || _q === void 0 ? void 0 : _q.link)
|
12341
|
+
? ((_r = buttonRef === null || buttonRef === void 0 ? void 0 : buttonRef.current) === null || _r === void 0 ? void 0 : _r.offsetHeight) || ((_s = props === null || props === void 0 ? void 0 : props.buttonBgStyle) === null || _s === void 0 ? void 0 : _s.height) || '100px'
|
12245
12342
|
: 0
|
12246
12343
|
} }))),
|
12247
|
-
React.createElement("div", { className: 'waterFallList-bottom', hidden: !((
|
12248
|
-
React.createElement("div", { ref: buttonRef, hidden: !((
|
12249
|
-
React.createElement("button", { className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12344
|
+
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 }),
|
12345
|
+
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' }) },
|
12346
|
+
React.createElement("button", { className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_v = data === null || data === void 0 ? void 0 : data.tag) === null || _v === void 0 ? void 0 : _v.linkTitle) || 'Shop the collection'))))));
|
12250
12347
|
}
|
12251
12348
|
|
12252
12349
|
var img$1 = "";
|
@@ -12375,8 +12472,8 @@ const WaterfallFlowItem = (props) => {
|
|
12375
12472
|
React.createElement("div", { className: 'list-content-listItem-info-price', style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.price, hidden: !priceText }, priceText))));
|
12376
12473
|
};
|
12377
12474
|
function WaterfallList(_a) {
|
12378
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
12379
|
-
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
12475
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
12476
|
+
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12380
12477
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12381
12478
|
const [list, setList] = React.useState();
|
12382
12479
|
const [data, setData] = React.useState();
|
@@ -12447,31 +12544,37 @@ function WaterfallList(_a) {
|
|
12447
12544
|
return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
|
12448
12545
|
React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'list' },
|
12449
12546
|
React.createElement("div", { className: 'list-scroll', ref: containerRef },
|
12450
|
-
|
12451
|
-
|
12547
|
+
showBanner && ((_b = data === null || data === void 0 ? void 0 : data.tag) === null || _b === void 0 ? void 0 : _b.picture) && (React.createElement(FormatImage$1, { className: css.css({
|
12548
|
+
width: '100%',
|
12549
|
+
objectFit: 'cover',
|
12550
|
+
marginBottom: '20px'
|
12551
|
+
}), src: (_c = data === null || data === void 0 ? void 0 : data.tag) === null || _c === void 0 ? void 0 : _c.picture })),
|
12552
|
+
React.createElement("div", { className: 'list-info', style: (_d = props === null || props === void 0 ? void 0 : props.textStyles) === null || _d === void 0 ? void 0 : _d.hashTagDesc }, (_e = data === null || data === void 0 ? void 0 : data.tag) === null || _e === void 0 ? void 0 : _e.info),
|
12553
|
+
React.createElement("div", { hidden: !((_f = data === null || data === void 0 ? void 0 : data.tag) === null || _f === void 0 ? void 0 : _f.link), className: 'list-collection', onClick: handleClickLink, style: Object.assign(Object.assign({}, (_g = props === null || props === void 0 ? void 0 : props.textStyles) === null || _g === void 0 ? void 0 : _g.hashTagLink), { marginBottom: props === null || props === void 0 ? void 0 : props.space }) }, ((_h = data === null || data === void 0 ? void 0 : data.tag) === null || _h === void 0 ? void 0 : _h.linkTitle) || 'Shop the collection'),
|
12452
12554
|
React.createElement("div", { className: 'list-content' }, list === null || list === void 0 ? void 0 : list.map((item, ind) => {
|
12453
12555
|
return (React.createElement(WaterfallFlowItem, Object.assign({ key: ind, index: ind, rec: item, list: list, reportTagsView: reportTagsView }, props)));
|
12454
12556
|
})),
|
12455
12557
|
React.createElement("div", { hidden: !isLoadMore, style: { textAlign: 'center' } }, "loading..."),
|
12456
|
-
React.createElement("div", { hidden: !((
|
12457
|
-
height: ((
|
12558
|
+
React.createElement("div", { hidden: !((_j = data === null || data === void 0 ? void 0 : data.tag) === null || _j === void 0 ? void 0 : _j.link), style: {
|
12559
|
+
height: ((_k = data === null || data === void 0 ? void 0 : data.tag) === null || _k === void 0 ? void 0 : _k.link) ? ((_l = props === null || props === void 0 ? void 0 : props.buttonBgStyle) === null || _l === void 0 ? void 0 : _l.height) || ((_m = props === null || props === void 0 ? void 0 : props.buttonStyle) === null || _m === void 0 ? void 0 : _m.height) || '100px' : 0
|
12458
12560
|
} })),
|
12459
|
-
React.createElement("div", { className: 'list-bottom', hidden: !((
|
12460
|
-
React.createElement("div", { hidden: !((
|
12461
|
-
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12561
|
+
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 }),
|
12562
|
+
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' }) },
|
12563
|
+
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((_q = data === null || data === void 0 ? void 0 : data.tag) === null || _q === void 0 ? void 0 : _q.linkTitle) || 'Shop the collection'))))));
|
12462
12564
|
}
|
12463
12565
|
|
12464
12566
|
/*
|
12465
12567
|
* @Author: binruan@chatlabs.com
|
12466
12568
|
* @Date: 2024-01-10 10:58:24
|
12467
12569
|
* @LastEditors: binruan@chatlabs.com
|
12468
|
-
* @LastEditTime: 2024-06-
|
12570
|
+
* @LastEditTime: 2024-06-12 14:18:56
|
12469
12571
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
|
12470
12572
|
*
|
12471
12573
|
*/
|
12472
12574
|
const WaterFall = (props) => {
|
12473
12575
|
var _a;
|
12474
|
-
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport } = useSxpDataSource();
|
12576
|
+
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport, themeTag } = useSxpDataSource();
|
12577
|
+
const { backMainFeed } = useEventReport();
|
12475
12578
|
React.useRef(null);
|
12476
12579
|
const modalEleRef = React.useRef(null);
|
12477
12580
|
const [viewTime, setViewTime] = React.useState();
|
@@ -12492,6 +12595,9 @@ const WaterFall = (props) => {
|
|
12492
12595
|
if (!isEq && cacheRtcList && (cacheRtcList === null || cacheRtcList === void 0 ? void 0 : cacheRtcList.length)) {
|
12493
12596
|
setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(cacheRtcList);
|
12494
12597
|
}
|
12598
|
+
if (!(themeTag === null || themeTag === void 0 ? void 0 : themeTag.current)) {
|
12599
|
+
backMainFeed('branch', themeTag === null || themeTag === void 0 ? void 0 : themeTag.current, waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag);
|
12600
|
+
}
|
12495
12601
|
reportTagsView();
|
12496
12602
|
setWaterFallData === null || setWaterFallData === void 0 ? void 0 : setWaterFallData(undefined);
|
12497
12603
|
setIsFromHashtag === null || setIsFromHashtag === void 0 ? void 0 : setIsFromHashtag(false);
|
@@ -12559,7 +12665,7 @@ const WaterFall = (props) => {
|
|
12559
12665
|
display: openHashtag ? 'block' : 'none'
|
12560
12666
|
} },
|
12561
12667
|
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 }),
|
12562
|
-
(props === null || props === void 0 ? void 0 : props.
|
12668
|
+
(props === null || props === void 0 ? void 0 : props.openFixedSize) === true || (props === null || props === void 0 ? void 0 : props.openFixedSize) === undefined ? (React.createElement(WaterfallList, Object.assign({ reportTagsView: reportTagsView }, props))) : (React.createElement(WaterfallList$1, Object.assign({ reportTagsView: reportTagsView }, props)))), modalEleRef.current);
|
12563
12669
|
};
|
12564
12670
|
var WaterFall$1 = React.memo(WaterFall);
|
12565
12671
|
|
@@ -12590,7 +12696,7 @@ const HashTag = createMaterial(HashTagComponent, {
|
|
12590
12696
|
category: 'base',
|
12591
12697
|
type: 'HashTag',
|
12592
12698
|
related: {
|
12593
|
-
settingRender,
|
12699
|
+
settingRender: settingRender$1,
|
12594
12700
|
bindableProps: []
|
12595
12701
|
},
|
12596
12702
|
defaulSetting: {
|
@@ -12647,6 +12753,84 @@ const HashTag = createMaterial(HashTagComponent, {
|
|
12647
12753
|
sort: 2
|
12648
12754
|
});
|
12649
12755
|
|
12756
|
+
/*
|
12757
|
+
* @Author: binruan@chatlabs.com
|
12758
|
+
* @Date: 2024-06-13 10:08:32
|
12759
|
+
* @LastEditors: binruan@chatlabs.com
|
12760
|
+
* @LastEditTime: 2024-06-13 17:42:50
|
12761
|
+
* @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
|
12762
|
+
*
|
12763
|
+
*/
|
12764
|
+
var settingRender = [
|
12765
|
+
{
|
12766
|
+
title: '协议详情',
|
12767
|
+
child: [
|
12768
|
+
{
|
12769
|
+
type: 'Switch',
|
12770
|
+
label: '必须同意用户协议',
|
12771
|
+
name: ['props', 'privacy_necessity'],
|
12772
|
+
extra: '当新用户进入页面时,会出现用户协议弹窗,用户需要先同意协议后才能访问内容。'
|
12773
|
+
},
|
12774
|
+
{
|
12775
|
+
type: 'Text',
|
12776
|
+
label: '弹窗标题',
|
12777
|
+
name: ['props', 'privacy_title']
|
12778
|
+
},
|
12779
|
+
{
|
12780
|
+
type: 'TextArea',
|
12781
|
+
label: '用户协议弹窗内容',
|
12782
|
+
name: ['props', 'privacy_context']
|
12783
|
+
},
|
12784
|
+
{
|
12785
|
+
type: 'Group',
|
12786
|
+
label: '隐私政策',
|
12787
|
+
child: [
|
12788
|
+
{
|
12789
|
+
type: 'Text',
|
12790
|
+
name: ['props', 'privacy_policy_title']
|
12791
|
+
},
|
12792
|
+
{
|
12793
|
+
type: 'Text',
|
12794
|
+
name: ['props', 'privacy_policy_url'],
|
12795
|
+
addonBefore: 'https://'
|
12796
|
+
}
|
12797
|
+
],
|
12798
|
+
extra: '当用户点击更多信息按钮时,将会跳转至设置的链接查看政策内容'
|
12799
|
+
}
|
12800
|
+
]
|
12801
|
+
}
|
12802
|
+
];
|
12803
|
+
|
12804
|
+
const Consent$1 = (props) => {
|
12805
|
+
return React.createElement(Consent$1, Object.assign({}, props));
|
12806
|
+
};
|
12807
|
+
var ConsentComponent = React.memo(Consent$1);
|
12808
|
+
|
12809
|
+
/*
|
12810
|
+
* @Author: binruan@chatlabs.com
|
12811
|
+
* @Date: 2023-07-28 18:29:57
|
12812
|
+
* @LastEditors: binruan@chatlabs.com
|
12813
|
+
* @LastEditTime: 2024-06-13 17:32:17
|
12814
|
+
* @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\material.tsx
|
12815
|
+
*
|
12816
|
+
*/
|
12817
|
+
const Consent = createMaterial(ConsentComponent, {
|
12818
|
+
displayName: 'Consent',
|
12819
|
+
icon: '',
|
12820
|
+
category: 'base',
|
12821
|
+
type: 'Consent',
|
12822
|
+
related: {
|
12823
|
+
settingRender
|
12824
|
+
},
|
12825
|
+
defaulSetting: {
|
12826
|
+
props: {},
|
12827
|
+
style: {}
|
12828
|
+
},
|
12829
|
+
w: 100,
|
12830
|
+
h: 40,
|
12831
|
+
sort: 1
|
12832
|
+
});
|
12833
|
+
|
12650
12834
|
/*
|
12651
12835
|
* @Author: binruan@chatlabs.com
|
12652
12836
|
* @Date: 2023-07-25 14:56:49
|
@@ -12665,6 +12849,7 @@ var _materials_ = /*#__PURE__*/Object.freeze({
|
|
12665
12849
|
CommodityDetailDiroNew: CommodityDetailDiroNew,
|
12666
12850
|
CommodityDiro: CommodityDiro,
|
12667
12851
|
CommodityDiroNew: CommodityDiroNew,
|
12852
|
+
Consent: Consent,
|
12668
12853
|
HashTag: HashTag,
|
12669
12854
|
Link: Link,
|
12670
12855
|
MultiCommodity: MultiCommodity,
|
@@ -13337,16 +13522,37 @@ const Nudge = ({ nudge }) => {
|
|
13337
13522
|
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 : '')))));
|
13338
13523
|
};
|
13339
13524
|
|
13525
|
+
/*
|
13526
|
+
* @Author: binruan@chatlabs.com
|
13527
|
+
* @Date: 2024-04-29 16:32:21
|
13528
|
+
* @LastEditors: binruan@chatlabs.com
|
13529
|
+
* @LastEditTime: 2024-06-12 11:01:48
|
13530
|
+
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Tagbar.tsx
|
13531
|
+
*
|
13532
|
+
*/
|
13340
13533
|
const DEFAULT_TAG = 'FOR U';
|
13341
13534
|
const Tagbar = ({ tagList = [], setActiveIndex }) => {
|
13342
13535
|
const [selectTag, setSelectTag] = React.useState(DEFAULT_TAG);
|
13343
|
-
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData } = useSxpDataSource();
|
13536
|
+
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport } = useSxpDataSource();
|
13537
|
+
const { backMainFeed } = useEventReport();
|
13344
13538
|
const realTagList = React.useMemo(() => {
|
13345
13539
|
return [DEFAULT_TAG, ...tagList];
|
13346
13540
|
}, [tagList]);
|
13347
13541
|
const handleSelectTag = (tag) => () => {
|
13348
13542
|
if (tag === selectTag)
|
13349
13543
|
return;
|
13544
|
+
if (tag !== 'FOR U') {
|
13545
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
13546
|
+
eventInfo: {
|
13547
|
+
eventSubject: 'clickThemeTagsViewContents',
|
13548
|
+
eventDescription: 'click Theme Tags View Contents',
|
13549
|
+
themeTags: `[${tag}]`
|
13550
|
+
}
|
13551
|
+
});
|
13552
|
+
}
|
13553
|
+
else {
|
13554
|
+
backMainFeed('theme', selectTag);
|
13555
|
+
}
|
13350
13556
|
let themeTag;
|
13351
13557
|
if (tag !== DEFAULT_TAG) {
|
13352
13558
|
themeTag = tag;
|
@@ -13378,7 +13584,7 @@ var Tagbar$1 = React.memo(Tagbar);
|
|
13378
13584
|
* @Author: binruan@chatlabs.com
|
13379
13585
|
* @Date: 2024-01-15 19:03:09
|
13380
13586
|
* @LastEditors: binruan@chatlabs.com
|
13381
|
-
* @LastEditTime: 2024-06-
|
13587
|
+
* @LastEditTime: 2024-06-13 18:09:16
|
13382
13588
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
|
13383
13589
|
*
|
13384
13590
|
*/
|
@@ -13389,11 +13595,11 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13389
13595
|
const viewImageStartTime = React.useRef(0);
|
13390
13596
|
const [isInit, setIsInit] = React.useState(false);
|
13391
13597
|
const [isMuted, setIsMuted] = React.useState(true);
|
13392
|
-
const curTime = React.useRef();
|
13393
13598
|
const viewTime = React.useRef();
|
13394
13599
|
const [isLoadMore, setIsLoadMore] = React.useState(false);
|
13395
13600
|
const [isShowMore, setIsShowMore] = React.useState(false);
|
13396
|
-
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport } = useSxpDataSource();
|
13601
|
+
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink } = useSxpDataSource();
|
13602
|
+
const { backMainFeed } = useEventReport();
|
13397
13603
|
const [videoRef, setVideoRef] = React.useState(null);
|
13398
13604
|
const playerRef = React.useRef();
|
13399
13605
|
const { productView } = useEventReport();
|
@@ -13404,17 +13610,17 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13404
13610
|
if (data.length <= 0) {
|
13405
13611
|
return;
|
13406
13612
|
}
|
13407
|
-
|
13613
|
+
refreshFeSessionId();
|
13614
|
+
const now = new Date();
|
13615
|
+
viewTime.current = now;
|
13616
|
+
if (isInit) {
|
13617
|
+
h5EnterLink === null || h5EnterLink === void 0 ? void 0 : h5EnterLink();
|
13618
|
+
}
|
13408
13619
|
bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
|
13409
13620
|
eventName: 'PageView'
|
13410
13621
|
});
|
13411
13622
|
setIsInit(true);
|
13412
|
-
}, [data.length, bffFbReport]);
|
13413
|
-
const initTime = () => {
|
13414
|
-
curTime.current = new Date();
|
13415
|
-
viewTime.current = new Date();
|
13416
|
-
refreshFeSessionId();
|
13417
|
-
};
|
13623
|
+
}, [data.length, bffFbReport, h5EnterLink, isInit]);
|
13418
13624
|
const firstRef = React.useRef();
|
13419
13625
|
React.useEffect(() => {
|
13420
13626
|
var _a, _b, _c, _d;
|
@@ -13510,13 +13716,33 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13510
13716
|
handleH5EnterLink();
|
13511
13717
|
handleViewImageStartEvent(activeIndex);
|
13512
13718
|
SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
|
13719
|
+
backMainFeed('external');
|
13513
13720
|
}
|
13514
13721
|
};
|
13515
13722
|
document.addEventListener('visibilitychange', visibleChange);
|
13516
13723
|
return () => {
|
13517
13724
|
document.removeEventListener('visibilitychange', visibleChange);
|
13518
13725
|
};
|
13519
|
-
}, [
|
13726
|
+
}, [
|
13727
|
+
activeIndex,
|
13728
|
+
bffEventReport,
|
13729
|
+
data,
|
13730
|
+
handleH5EnterLink,
|
13731
|
+
popupDetailData,
|
13732
|
+
isFromHashtag,
|
13733
|
+
tempMap,
|
13734
|
+
curTime,
|
13735
|
+
backMainFeed
|
13736
|
+
]);
|
13737
|
+
React.useEffect(() => {
|
13738
|
+
const initTime = () => {
|
13739
|
+
backMainFeed('external');
|
13740
|
+
};
|
13741
|
+
window.addEventListener('pageshow', initTime);
|
13742
|
+
return () => {
|
13743
|
+
window.removeEventListener('pageshow', initTime);
|
13744
|
+
};
|
13745
|
+
}, []);
|
13520
13746
|
const tagHeight = React.useMemo(() => {
|
13521
13747
|
let h = 0;
|
13522
13748
|
if (tagList.length > 0) {
|
@@ -14258,7 +14484,7 @@ const Popup = () => {
|
|
14258
14484
|
* @Author: binruan@chatlabs.com
|
14259
14485
|
* @Date: 2024-01-15 19:03:09
|
14260
14486
|
* @LastEditors: binruan@chatlabs.com
|
14261
|
-
* @LastEditTime: 2024-
|
14487
|
+
* @LastEditTime: 2024-06-13 14:54:12
|
14262
14488
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageCore\index.tsx
|
14263
14489
|
*
|
14264
14490
|
*/
|
@@ -14275,14 +14501,14 @@ Object.values(_materials_).forEach((v) => {
|
|
14275
14501
|
RESOLVER[v.extend.type] = v;
|
14276
14502
|
});
|
14277
14503
|
const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, loadingImage, appDomain, licenseUrl, enabledMetaConversionApi }) => {
|
14278
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
14504
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
14279
14505
|
const utmVal = React.useMemo(() => {
|
14280
14506
|
var _a;
|
14281
14507
|
const searchParams = (location === null || location === void 0 ? void 0 : location.search) ? (_a = location === null || location === void 0 ? void 0 : location.search) === null || _a === void 0 ? void 0 : _a.replace('?', '') : '';
|
14282
14508
|
return searchParams;
|
14283
14509
|
}, []);
|
14284
14510
|
return (React.createElement(EditorCore, { resolver: RESOLVER, enableDataSource: false, schema: data === null || data === void 0 ? void 0 : data.data, utmVal: utmVal },
|
14285
|
-
React.createElement(SxpDataSourceProvider$1, { utmVal: utmVal, dataSources: data === null || data === void 0 ? void 0 : data.data_sources, sxpParameter: data === null || data === void 0 ? void 0 : data.sxp_parameter, maxSize: (_b = (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.personalized_recommend) !== null && _b !== void 0 ? _b : maxSize, defaultSize: (_d = (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.default_recommend) !== null && _d !== void 0 ? _d : defaultSize, hashTagSize: (_f = (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size) !== null && _f !== void 0 ? _f : hashTagSize, loadingImage: loadingImage, appDomain: appDomain, enabledMetaConversionApi: enabledMetaConversionApi, isShowTag: (_j = (_h = (_g = data === null || data === void 0 ? void 0 : data.data) === null || _g === void 0 ? void 0 : _g.sxpPageConf) === null || _h === void 0 ? void 0 : _h.globalConfig) === null || _j === void 0 ? void 0 : _j.isShowTag, render: ({ rtcList, tagList }) => {
|
14511
|
+
React.createElement(SxpDataSourceProvider$1, { utmVal: utmVal, dataSources: data === null || data === void 0 ? void 0 : data.data_sources, sxpParameter: data === null || data === void 0 ? void 0 : data.sxp_parameter, maxSize: (_b = (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.personalized_recommend) !== null && _b !== void 0 ? _b : maxSize, defaultSize: (_d = (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.default_recommend) !== null && _d !== void 0 ? _d : defaultSize, hashTagSize: (_f = (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size) !== null && _f !== void 0 ? _f : hashTagSize, loadingImage: loadingImage, appDomain: appDomain, enabledMetaConversionApi: enabledMetaConversionApi, isShowTag: (_j = (_h = (_g = data === null || data === void 0 ? void 0 : data.data) === null || _g === void 0 ? void 0 : _g.sxpPageConf) === null || _h === void 0 ? void 0 : _h.globalConfig) === null || _j === void 0 ? void 0 : _j.isShowTag, globalConfig: (_l = (_k = data === null || data === void 0 ? void 0 : data.data) === null || _k === void 0 ? void 0 : _k.sxpPageConf) === null || _l === void 0 ? void 0 : _l.globalConfig, render: ({ rtcList, tagList }) => {
|
14286
14512
|
var _a;
|
14287
14513
|
return (React.createElement(React.Fragment, null,
|
14288
14514
|
React.createElement(SxpPageRender, Object.assign({}, (_a = data === null || data === void 0 ? void 0 : data.data) === null || _a === void 0 ? void 0 : _a.sxpPageConf, { tagList: tagList, data: rtcList, resolver: RESOLVER, licenseUrl: licenseUrl })),
|
@@ -14301,8 +14527,9 @@ var index = React.memo(SxpPageCore);
|
|
14301
14527
|
*/
|
14302
14528
|
const EditorDataContext = React.createContext({});
|
14303
14529
|
const EditorDataProvider = ({ children, data }) => {
|
14304
|
-
var _a, _b, _c, _d, _e, _f;
|
14530
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
14305
14531
|
const [openHashtag, setOpenHashtag] = React.useState(false);
|
14532
|
+
const [openConsent, setOpenConsent] = React.useState(false);
|
14306
14533
|
return (React.createElement(EditorDataContext.Provider, { value: {
|
14307
14534
|
sxpPrameter: {
|
14308
14535
|
bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
|
@@ -14310,11 +14537,20 @@ const EditorDataProvider = ({ children, data }) => {
|
|
14310
14537
|
personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
|
14311
14538
|
placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
|
14312
14539
|
hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
|
14313
|
-
loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image
|
14540
|
+
loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
|
14541
|
+
privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
|
14542
|
+
privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
|
14543
|
+
privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
|
14544
|
+
privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
|
14545
|
+
privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
|
14546
|
+
template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
|
14547
|
+
industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
|
14314
14548
|
},
|
14315
14549
|
appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
|
14316
14550
|
openHashtag,
|
14317
|
-
setOpenHashtag
|
14551
|
+
setOpenHashtag,
|
14552
|
+
openConsent,
|
14553
|
+
setOpenConsent
|
14318
14554
|
} }, children));
|
14319
14555
|
};
|
14320
14556
|
function useEditorDataProvider() {
|