pb-sxp-ui 1.0.80 → 1.0.82
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 +400 -145
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +97 -4
- package/dist/index.js +401 -146
- 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 +400 -145
- 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.js
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
import { isEmpty, isEqual, cloneDeep, debounce, throttle, get } from 'lodash';
|
2
2
|
import { v4 } from 'uuid';
|
3
3
|
import pako from 'pako';
|
4
|
-
import React, { useContext, useMemo,
|
4
|
+
import React, { useContext, useMemo, memo, useEffect, createContext, useState, useRef, useCallback, forwardRef, useImperativeHandle, useLayoutEffect } from 'react';
|
5
5
|
import qs from 'qs';
|
6
6
|
import EventEmitter from 'eventemitter3';
|
7
7
|
import { css } from '@emotion/css';
|
@@ -370,6 +370,7 @@ const getFeSessionId = () => {
|
|
370
370
|
|
371
371
|
const FAKE_USER_KEY = 'SXP_FAKE_USER_ID';
|
372
372
|
const FAKE_USER_STATE = 'FAKE_USER_STATE';
|
373
|
+
const AGREE_POLICY = 'AGREE_POLICY';
|
373
374
|
const storeAndLoadFeUserId = () => {
|
374
375
|
let fakeUserId = window.localStorage.getItem(FAKE_USER_KEY);
|
375
376
|
if (isEmpty(fakeUserId)) {
|
@@ -414,6 +415,70 @@ var SXP_EVENT_TYPE;
|
|
414
415
|
SXP_EVENT_TYPE["CHANGE_THEME_TAG"] = "changeThemeTag";
|
415
416
|
})(SXP_EVENT_TYPE || (SXP_EVENT_TYPE = {}));
|
416
417
|
|
418
|
+
/*
|
419
|
+
* @Author: binruan@chatlabs.com
|
420
|
+
* @Date: 2024-06-13 15:16:53
|
421
|
+
* @LastEditors: binruan@chatlabs.com
|
422
|
+
* @LastEditTime: 2024-06-13 18:22:53
|
423
|
+
* @FilePath: \pb-sxp-ui\src\core\components\Consent\index.tsx
|
424
|
+
*
|
425
|
+
*/
|
426
|
+
const Consent$2 = ({ width = window.innerWidth, height = window.innerHeight, privacy_title, privacy_context, privacy_policy_url, privacy_policy_title }) => {
|
427
|
+
const { setIsAgreePolicy, bffEventReport } = useSxpDataSource();
|
428
|
+
const channelObj = useMemo(() => {
|
429
|
+
const queryString = location.search.slice(1);
|
430
|
+
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
431
|
+
for (const key in params) {
|
432
|
+
params[key] = params[key].replace(/%2B/g, '+');
|
433
|
+
}
|
434
|
+
return params;
|
435
|
+
}, []);
|
436
|
+
const getUtmValue = (key) => { var _a; return (_a = channelObj[key]) !== null && _a !== void 0 ? _a : null; };
|
437
|
+
useEffect(() => {
|
438
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
439
|
+
eventInfo: {
|
440
|
+
eventSubject: 'privacyEnter',
|
441
|
+
eventDescription: 'User enter privacy page',
|
442
|
+
utmSource: getUtmValue('utm_source'),
|
443
|
+
utmMedium: getUtmValue('utm_medium'),
|
444
|
+
utmCampaign: getUtmValue('utm_campaign'),
|
445
|
+
utmId: getUtmValue('utm_id'),
|
446
|
+
utmContent: getUtmValue('utm_content'),
|
447
|
+
clSource: getUtmValue('cl_source'),
|
448
|
+
enterTime: `${Date.now()}`,
|
449
|
+
enterUrl: window.location.href,
|
450
|
+
rtc: null,
|
451
|
+
requestId: null,
|
452
|
+
sessionID: null
|
453
|
+
}
|
454
|
+
});
|
455
|
+
}, []);
|
456
|
+
const handleAgree = () => {
|
457
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
458
|
+
eventInfo: {
|
459
|
+
eventSubject: 'userConsent',
|
460
|
+
eventDescription: '用户授权【操作结果】',
|
461
|
+
consentResult: '0',
|
462
|
+
consentTags: '[]',
|
463
|
+
rtc: null,
|
464
|
+
requestId: null,
|
465
|
+
sessionID: null
|
466
|
+
}
|
467
|
+
});
|
468
|
+
setIsAgreePolicy === null || setIsAgreePolicy === void 0 ? void 0 : setIsAgreePolicy(true);
|
469
|
+
window.localStorage.setItem(AGREE_POLICY, 'yes');
|
470
|
+
};
|
471
|
+
return (React.createElement("div", { className: 'consent-bg' },
|
472
|
+
React.createElement("div", { className: 'consent' },
|
473
|
+
React.createElement("div", { className: 'consent-col' },
|
474
|
+
React.createElement("div", { className: 'consent-title' }, privacy_title !== null && privacy_title !== void 0 ? privacy_title : 'Privacy Policy'),
|
475
|
+
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.')),
|
476
|
+
React.createElement("div", { className: 'consent-col' },
|
477
|
+
React.createElement("button", { className: 'consent-btn', onClick: handleAgree }, "Agree"),
|
478
|
+
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')))));
|
479
|
+
};
|
480
|
+
var Consent$3 = memo(Consent$2);
|
481
|
+
|
417
482
|
const SxpDataSourceContext = createContext({
|
418
483
|
rtcList: [],
|
419
484
|
tagList: []
|
@@ -423,13 +488,15 @@ var DataSourceType;
|
|
423
488
|
DataSourceType[DataSourceType["BFF"] = 5] = "BFF";
|
424
489
|
})(DataSourceType || (DataSourceType = {}));
|
425
490
|
const UTM_KEYS = ['utm_source', 'utm_medium', 'utm_campaign', 'utm_id', 'utm_content', 'cl_source'];
|
426
|
-
const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent = true, maxSize, defaultSize, isPreview = false, sxpParameter, appDomain, hashTagSize, loadingImage, isOpenHashTag = false, enabledMetaConversionApi = false, isShowTag = true }) => {
|
491
|
+
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 }) => {
|
492
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
427
493
|
const [rtcList, setRtcList] = useState([]);
|
428
494
|
const [tagList, setTagList] = useState([]);
|
429
495
|
const [loading, setLoading] = useState(false);
|
430
496
|
const [curReqInfo, setCurReqInfo] = useState({ rtc: '', requestId: '' });
|
431
497
|
const swiperRef = useRef(null);
|
432
498
|
const isInit = useRef(false);
|
499
|
+
const [isAgreePolicy, setIsAgreePolicy] = useState(() => !!window.localStorage.getItem(AGREE_POLICY));
|
433
500
|
// 弹窗数据
|
434
501
|
const [popupDetailData, setPopupDetailData] = useState();
|
435
502
|
const [waterFallData, setWaterFallData] = useState();
|
@@ -439,6 +506,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
439
506
|
const [isFromHashtag, setIsFromHashtag] = useState(false);
|
440
507
|
const [videoRef, setVideoRef] = useState(null);
|
441
508
|
const themeTag = useRef();
|
509
|
+
const curTime = useRef();
|
442
510
|
useEffect(() => {
|
443
511
|
const handleChangeThemeTag = (tag) => {
|
444
512
|
themeTag.current = tag;
|
@@ -483,10 +551,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
483
551
|
}, [bffDataSource]);
|
484
552
|
// 获取推荐视频数据
|
485
553
|
const getRecommendVideos = useCallback((query) => __awaiter(void 0, void 0, void 0, function* () {
|
486
|
-
var
|
554
|
+
var _h, _j, _k, _l, _m;
|
487
555
|
query = {
|
488
|
-
maxSize: (
|
489
|
-
defaultSize: (
|
556
|
+
maxSize: (_h = query === null || query === void 0 ? void 0 : query.maxSize) !== null && _h !== void 0 ? _h : maxSize,
|
557
|
+
defaultSize: (_j = query === null || query === void 0 ? void 0 : query.defaultSize) !== null && _j !== void 0 ? _j : defaultSize,
|
490
558
|
'itemFilter.itemId': query === null || query === void 0 ? void 0 : query['itemFilter.itemId'],
|
491
559
|
'itemFilter.itemType': query === null || query === void 0 ? void 0 : query['itemFilter.itemType'],
|
492
560
|
hashTag: query === null || query === void 0 ? void 0 : query.hashTag,
|
@@ -494,10 +562,10 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
494
562
|
themeTag: query === null || query === void 0 ? void 0 : query.themeTag
|
495
563
|
};
|
496
564
|
if (utmVal) {
|
497
|
-
const val = (
|
565
|
+
const val = (_m = (_l = (_k = utmVal === null || utmVal === void 0 ? void 0 : utmVal.split('&')) === null || _k === void 0 ? void 0 : _k.filter((val) => {
|
498
566
|
const key = val.split('=')[0];
|
499
567
|
return UTM_KEYS.includes(key);
|
500
|
-
})) === null ||
|
568
|
+
})) === null || _l === void 0 ? void 0 : _l.join('&')) !== null && _m !== void 0 ? _m : '';
|
501
569
|
query = Object.assign(Object.assign({}, query), { channel: decodeURIComponent(val) });
|
502
570
|
}
|
503
571
|
const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/recommend/list', { method: 'GET', query }));
|
@@ -509,7 +577,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
509
577
|
return result === null || result === void 0 ? void 0 : result.data;
|
510
578
|
}), [bffFetch, utmVal, maxSize, defaultSize]);
|
511
579
|
const loadVideos = useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
|
512
|
-
var
|
580
|
+
var _o, _p;
|
513
581
|
if (rtcList.length <= 0) {
|
514
582
|
return;
|
515
583
|
}
|
@@ -519,8 +587,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
519
587
|
'itemFilter.itemType': waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.itemType,
|
520
588
|
themeTag: themeTag.current
|
521
589
|
});
|
522
|
-
setRtcList(rtcList.concat((
|
523
|
-
setCacheRtcList(cacheRtcList.concat((
|
590
|
+
setRtcList(rtcList.concat((_o = data === null || data === void 0 ? void 0 : data.recList) !== null && _o !== void 0 ? _o : []));
|
591
|
+
setCacheRtcList(cacheRtcList.concat((_p = data === null || data === void 0 ? void 0 : data.recList) !== null && _p !== void 0 ? _p : []));
|
524
592
|
}), [getRecommendVideos, rtcList, waterFallData, cacheRtcList]);
|
525
593
|
const bffEventReport = useCallback(({ userInfo, eventInfo }) => {
|
526
594
|
// 关闭 BFF 事件上报
|
@@ -584,16 +652,16 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
584
652
|
}), [bffFetch]);
|
585
653
|
// 获取 Tag
|
586
654
|
const bffGetTagList = useCallback(() => __awaiter(void 0, void 0, void 0, function* () {
|
587
|
-
var
|
655
|
+
var _q, _r, _s, _t, _u;
|
588
656
|
if (!utmVal || !isShowTag)
|
589
657
|
return;
|
590
658
|
try {
|
591
|
-
const val = (
|
659
|
+
const val = (_s = (_r = (_q = utmVal === null || utmVal === void 0 ? void 0 : utmVal.split('&')) === null || _q === void 0 ? void 0 : _q.filter((val) => {
|
592
660
|
const key = val.split('=')[0];
|
593
661
|
return UTM_KEYS.includes(key);
|
594
|
-
})) === null ||
|
662
|
+
})) === null || _r === void 0 ? void 0 : _r.join('&')) !== null && _s !== void 0 ? _s : '';
|
595
663
|
const result = yield (bffFetch === null || bffFetch === void 0 ? void 0 : bffFetch('/tag/list', { method: 'GET', query: { channel: decodeURIComponent(val) } }));
|
596
|
-
setTagList((
|
664
|
+
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 : []);
|
597
665
|
}
|
598
666
|
catch (e) {
|
599
667
|
console.log('e', e);
|
@@ -617,7 +685,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
617
685
|
eventInfo: Object.assign(Object.assign({}, eventInfo), { ctaId: (_h = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _h !== void 0 ? _h : '', ctaName: (_j = cta === null || cta === void 0 ? void 0 : cta.title) !== null && _j !== void 0 ? _j : '', contentTags: JSON.stringify(cta === null || cta === void 0 ? void 0 : cta.tags), position: position + '', contentId: (_l = (_k = rec === null || rec === void 0 ? void 0 : rec.video) === null || _k === void 0 ? void 0 : _k.itemId) !== null && _l !== void 0 ? _l : '', productId: isProd ? product === null || product === void 0 ? void 0 : product.itemId : '', traceInfo: (_m = cta === null || cta === void 0 ? void 0 : cta.traceInfo) !== null && _m !== void 0 ? _m : '', fromKName })
|
618
686
|
});
|
619
687
|
}, [bffEventReport, isFromHashtag]);
|
620
|
-
|
688
|
+
const h5EnterLink = useCallback(() => {
|
621
689
|
var _a, _b;
|
622
690
|
const queryString = location.search.slice(1);
|
623
691
|
const params = qs.parse(queryString.replace(/\+/g, '%2B'));
|
@@ -625,6 +693,8 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
625
693
|
params[key] = params[key].replace(/%2B/g, '+');
|
626
694
|
}
|
627
695
|
const getVal = (key) => { var _a; return (_a = params[key]) !== null && _a !== void 0 ? _a : ''; };
|
696
|
+
const time = new Date();
|
697
|
+
curTime.current = time;
|
628
698
|
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
629
699
|
eventInfo: {
|
630
700
|
eventSubject: 'h5LinkEnterFeed',
|
@@ -634,14 +704,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
634
704
|
utmCampaign: getVal('utm_campaign'),
|
635
705
|
utmId: getVal('utm_id'),
|
636
706
|
utmContent: getVal('utm_content'),
|
637
|
-
enterTime:
|
707
|
+
enterTime: Math.floor(time / 1000) + '',
|
638
708
|
requestId: null,
|
639
709
|
enterUrl: (_b = (_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.href) !== null && _b !== void 0 ? _b : '',
|
640
|
-
clSource: getVal('
|
710
|
+
clSource: getVal('cl_source')
|
641
711
|
}
|
642
712
|
});
|
713
|
+
}, [bffEventReport]);
|
714
|
+
useEffect(() => {
|
715
|
+
h5EnterLink();
|
643
716
|
}, []);
|
644
717
|
useEffect(() => {
|
718
|
+
if (!isAgreePolicy)
|
719
|
+
return;
|
645
720
|
setLoading(true);
|
646
721
|
bffGetTagList();
|
647
722
|
getRecommendVideos()
|
@@ -660,7 +735,7 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
660
735
|
setLoading(false);
|
661
736
|
isInit.current = true;
|
662
737
|
});
|
663
|
-
}, []);
|
738
|
+
}, [isAgreePolicy]);
|
664
739
|
useEffect(() => {
|
665
740
|
if (!isInit.current)
|
666
741
|
return;
|
@@ -712,14 +787,19 @@ const SxpDataSourceProvider = ({ render, dataSources, utmVal, enableReportEvent
|
|
712
787
|
setLoading,
|
713
788
|
videoRef,
|
714
789
|
setVideoRef,
|
715
|
-
bffFbReport
|
716
|
-
|
790
|
+
bffFbReport,
|
791
|
+
isAgreePolicy,
|
792
|
+
setIsAgreePolicy,
|
793
|
+
curTime,
|
794
|
+
h5EnterLink,
|
795
|
+
themeTag
|
796
|
+
} }, (((_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({
|
717
797
|
rtcList,
|
718
798
|
mutateLike: bffMutateLike,
|
719
799
|
mutateUnlike: bffMutateUnlike,
|
720
800
|
submitForm: bffSubmitForm,
|
721
801
|
tagList
|
722
|
-
})));
|
802
|
+
}))));
|
723
803
|
};
|
724
804
|
var SxpDataSourceProvider$1 = memo(SxpDataSourceProvider);
|
725
805
|
|
@@ -985,7 +1065,7 @@ var defaultSetting = {
|
|
985
1065
|
*
|
986
1066
|
*/
|
987
1067
|
var _a$5, _b$5, _c;
|
988
|
-
var settingRender$
|
1068
|
+
var settingRender$6 = [
|
989
1069
|
{
|
990
1070
|
type: 'Text',
|
991
1071
|
label: '组件名称',
|
@@ -1123,7 +1203,7 @@ var settingRender$5 = [
|
|
1123
1203
|
* @Author: binruan@chatlabs.com
|
1124
1204
|
* @Date: 2024-03-12 10:59:06
|
1125
1205
|
* @LastEditors: binruan@chatlabs.com
|
1126
|
-
* @LastEditTime: 2024-
|
1206
|
+
* @LastEditTime: 2024-06-12 10:53:57
|
1127
1207
|
* @FilePath: \pb-sxp-ui\src\core\hooks\useEventReport.ts
|
1128
1208
|
*
|
1129
1209
|
*/
|
@@ -1193,9 +1273,21 @@ function useEventReport() {
|
|
1193
1273
|
}
|
1194
1274
|
});
|
1195
1275
|
}, [bffEventReport, popupDetailData]);
|
1276
|
+
const backMainFeed = useCallback((lastFeed, themeTag, hashTag) => {
|
1277
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
1278
|
+
eventInfo: {
|
1279
|
+
lastFeed,
|
1280
|
+
themeTags: themeTag ? `[${themeTag}]` : '',
|
1281
|
+
hashTags: hashTag ? `[${hashTag}]` : '',
|
1282
|
+
eventSubject: 'backMainFeed',
|
1283
|
+
eventDescription: 'back Main Feed'
|
1284
|
+
}
|
1285
|
+
});
|
1286
|
+
}, [bffEventReport]);
|
1196
1287
|
return {
|
1197
1288
|
jumpToWeb,
|
1198
|
-
productView
|
1289
|
+
productView,
|
1290
|
+
backMainFeed
|
1199
1291
|
};
|
1200
1292
|
}
|
1201
1293
|
|
@@ -1300,7 +1392,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
|
|
1300
1392
|
category: 'popup',
|
1301
1393
|
type: 'AppointForm',
|
1302
1394
|
related: {
|
1303
|
-
settingRender: settingRender$
|
1395
|
+
settingRender: settingRender$6,
|
1304
1396
|
bindableProps: [],
|
1305
1397
|
interactionRender: interactionRender$8
|
1306
1398
|
},
|
@@ -1326,7 +1418,7 @@ const AppointForm = createMaterial(AppointFormComponent, {
|
|
1326
1418
|
});
|
1327
1419
|
|
1328
1420
|
var _a$4, _b$4;
|
1329
|
-
var settingRender$
|
1421
|
+
var settingRender$5 = [
|
1330
1422
|
{
|
1331
1423
|
title: '商品图片',
|
1332
1424
|
child: [
|
@@ -2985,7 +3077,7 @@ function Scrollbar(_ref) {
|
|
2985
3077
|
dragEl
|
2986
3078
|
} = scrollbar;
|
2987
3079
|
if (!isTouched) return;
|
2988
|
-
if (e.preventDefault) e.preventDefault();else e.returnValue = false;
|
3080
|
+
if (e.preventDefault && e.cancelable) e.preventDefault();else e.returnValue = false;
|
2989
3081
|
setDragPosition(e);
|
2990
3082
|
wrapperEl.style.transitionDuration = '0ms';
|
2991
3083
|
el.style.transitionDuration = '0ms';
|
@@ -3212,7 +3304,7 @@ function Autoplay(_ref) {
|
|
3212
3304
|
if (!swiper || swiper.destroyed || !swiper.wrapperEl) return;
|
3213
3305
|
if (e.target !== swiper.wrapperEl) return;
|
3214
3306
|
swiper.wrapperEl.removeEventListener('transitionend', onTransitionEnd);
|
3215
|
-
if (pausedByPointerEnter) {
|
3307
|
+
if (pausedByPointerEnter || e.detail && e.detail.bySwiperTouchMove) {
|
3216
3308
|
return;
|
3217
3309
|
}
|
3218
3310
|
resume();
|
@@ -3383,8 +3475,10 @@ function Autoplay(_ref) {
|
|
3383
3475
|
}
|
3384
3476
|
};
|
3385
3477
|
const detachMouseEvents = () => {
|
3386
|
-
swiper.el.
|
3387
|
-
|
3478
|
+
if (swiper.el && typeof swiper.el !== 'string') {
|
3479
|
+
swiper.el.removeEventListener('pointerenter', onPointerEnter);
|
3480
|
+
swiper.el.removeEventListener('pointerleave', onPointerLeave);
|
3481
|
+
}
|
3388
3482
|
};
|
3389
3483
|
const attachDocumentEvents = () => {
|
3390
3484
|
const document = getDocument();
|
@@ -4306,8 +4400,9 @@ function updateSlides() {
|
|
4306
4400
|
allSlidesSize += slideSizeValue + (spaceBetween || 0);
|
4307
4401
|
});
|
4308
4402
|
allSlidesSize -= spaceBetween;
|
4309
|
-
|
4310
|
-
|
4403
|
+
const offsetSize = (params.slidesOffsetBefore || 0) + (params.slidesOffsetAfter || 0);
|
4404
|
+
if (allSlidesSize + offsetSize < swiperSize) {
|
4405
|
+
const allSlidesOffset = (swiperSize - allSlidesSize - offsetSize) / 2;
|
4311
4406
|
snapGrid.forEach((snap, snapIndex) => {
|
4312
4407
|
snapGrid[snapIndex] = snap - allSlidesOffset;
|
4313
4408
|
});
|
@@ -4411,6 +4506,13 @@ function updateSlidesOffset() {
|
|
4411
4506
|
}
|
4412
4507
|
}
|
4413
4508
|
|
4509
|
+
const toggleSlideClasses$1 = (slideEl, condition, className) => {
|
4510
|
+
if (condition && !slideEl.classList.contains(className)) {
|
4511
|
+
slideEl.classList.add(className);
|
4512
|
+
} else if (!condition && slideEl.classList.contains(className)) {
|
4513
|
+
slideEl.classList.remove(className);
|
4514
|
+
}
|
4515
|
+
};
|
4414
4516
|
function updateSlidesProgress(translate) {
|
4415
4517
|
if (translate === void 0) {
|
4416
4518
|
translate = this && this.translate || 0;
|
@@ -4426,11 +4528,6 @@ function updateSlidesProgress(translate) {
|
|
4426
4528
|
if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();
|
4427
4529
|
let offsetCenter = -translate;
|
4428
4530
|
if (rtl) offsetCenter = translate;
|
4429
|
-
|
4430
|
-
// Visible Slides
|
4431
|
-
slides.forEach(slideEl => {
|
4432
|
-
slideEl.classList.remove(params.slideVisibleClass, params.slideFullyVisibleClass);
|
4433
|
-
});
|
4434
4531
|
swiper.visibleSlidesIndexes = [];
|
4435
4532
|
swiper.visibleSlides = [];
|
4436
4533
|
let spaceBetween = params.spaceBetween;
|
@@ -4454,11 +4551,9 @@ function updateSlidesProgress(translate) {
|
|
4454
4551
|
if (isVisible) {
|
4455
4552
|
swiper.visibleSlides.push(slide);
|
4456
4553
|
swiper.visibleSlidesIndexes.push(i);
|
4457
|
-
slides[i].classList.add(params.slideVisibleClass);
|
4458
|
-
}
|
4459
|
-
if (isFullyVisible) {
|
4460
|
-
slides[i].classList.add(params.slideFullyVisibleClass);
|
4461
4554
|
}
|
4555
|
+
toggleSlideClasses$1(slide, isVisible, params.slideVisibleClass);
|
4556
|
+
toggleSlideClasses$1(slide, isFullyVisible, params.slideFullyVisibleClass);
|
4462
4557
|
slide.progress = rtl ? -slideProgress : slideProgress;
|
4463
4558
|
slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;
|
4464
4559
|
}
|
@@ -4527,6 +4622,13 @@ function updateProgress(translate) {
|
|
4527
4622
|
swiper.emit('progress', progress);
|
4528
4623
|
}
|
4529
4624
|
|
4625
|
+
const toggleSlideClasses = (slideEl, condition, className) => {
|
4626
|
+
if (condition && !slideEl.classList.contains(className)) {
|
4627
|
+
slideEl.classList.add(className);
|
4628
|
+
} else if (!condition && slideEl.classList.contains(className)) {
|
4629
|
+
slideEl.classList.remove(className);
|
4630
|
+
}
|
4631
|
+
};
|
4530
4632
|
function updateSlidesClasses() {
|
4531
4633
|
const swiper = this;
|
4532
4634
|
const {
|
@@ -4540,9 +4642,6 @@ function updateSlidesClasses() {
|
|
4540
4642
|
const getFilteredSlide = selector => {
|
4541
4643
|
return elementChildren(slidesEl, `.${params.slideClass}${selector}, swiper-slide${selector}`)[0];
|
4542
4644
|
};
|
4543
|
-
slides.forEach(slideEl => {
|
4544
|
-
slideEl.classList.remove(params.slideActiveClass, params.slideNextClass, params.slidePrevClass);
|
4545
|
-
});
|
4546
4645
|
let activeSlide;
|
4547
4646
|
let prevSlide;
|
4548
4647
|
let nextSlide;
|
@@ -4565,35 +4664,25 @@ function updateSlidesClasses() {
|
|
4565
4664
|
}
|
4566
4665
|
}
|
4567
4666
|
if (activeSlide) {
|
4568
|
-
|
4569
|
-
activeSlide.classList.add(params.slideActiveClass);
|
4570
|
-
if (gridEnabled) {
|
4571
|
-
if (nextSlide) {
|
4572
|
-
nextSlide.classList.add(params.slideNextClass);
|
4573
|
-
}
|
4574
|
-
if (prevSlide) {
|
4575
|
-
prevSlide.classList.add(params.slidePrevClass);
|
4576
|
-
}
|
4577
|
-
} else {
|
4667
|
+
if (!gridEnabled) {
|
4578
4668
|
// Next Slide
|
4579
4669
|
nextSlide = elementNextAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];
|
4580
4670
|
if (params.loop && !nextSlide) {
|
4581
4671
|
nextSlide = slides[0];
|
4582
4672
|
}
|
4583
|
-
if (nextSlide) {
|
4584
|
-
nextSlide.classList.add(params.slideNextClass);
|
4585
|
-
}
|
4586
4673
|
|
4587
4674
|
// Prev Slide
|
4588
4675
|
prevSlide = elementPrevAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];
|
4589
4676
|
if (params.loop && !prevSlide === 0) {
|
4590
4677
|
prevSlide = slides[slides.length - 1];
|
4591
4678
|
}
|
4592
|
-
if (prevSlide) {
|
4593
|
-
prevSlide.classList.add(params.slidePrevClass);
|
4594
|
-
}
|
4595
4679
|
}
|
4596
4680
|
}
|
4681
|
+
slides.forEach(slideEl => {
|
4682
|
+
toggleSlideClasses(slideEl, slideEl === activeSlide, params.slideActiveClass);
|
4683
|
+
toggleSlideClasses(slideEl, slideEl === nextSlide, params.slideNextClass);
|
4684
|
+
toggleSlideClasses(slideEl, slideEl === prevSlide, params.slidePrevClass);
|
4685
|
+
});
|
4597
4686
|
swiper.emitSlidesClasses();
|
4598
4687
|
}
|
4599
4688
|
|
@@ -4971,6 +5060,7 @@ function translateTo(translate, speed, runCallbacks, translateBounds, internal)
|
|
4971
5060
|
swiper.wrapperEl.removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);
|
4972
5061
|
swiper.onTranslateToWrapperTransitionEnd = null;
|
4973
5062
|
delete swiper.onTranslateToWrapperTransitionEnd;
|
5063
|
+
swiper.animating = false;
|
4974
5064
|
if (runCallbacks) {
|
4975
5065
|
swiper.emit('transitionEnd');
|
4976
5066
|
}
|
@@ -5078,9 +5168,6 @@ function slideTo(index, speed, runCallbacks, internal, initial) {
|
|
5078
5168
|
if (index === void 0) {
|
5079
5169
|
index = 0;
|
5080
5170
|
}
|
5081
|
-
if (speed === void 0) {
|
5082
|
-
speed = this.params.speed;
|
5083
|
-
}
|
5084
5171
|
if (runCallbacks === void 0) {
|
5085
5172
|
runCallbacks = true;
|
5086
5173
|
}
|
@@ -5100,9 +5187,12 @@ function slideTo(index, speed, runCallbacks, internal, initial) {
|
|
5100
5187
|
wrapperEl,
|
5101
5188
|
enabled
|
5102
5189
|
} = swiper;
|
5103
|
-
if (
|
5190
|
+
if (!enabled && !internal && !initial || swiper.destroyed || swiper.animating && params.preventInteractionOnTransition) {
|
5104
5191
|
return false;
|
5105
5192
|
}
|
5193
|
+
if (typeof speed === 'undefined') {
|
5194
|
+
speed = swiper.params.speed;
|
5195
|
+
}
|
5106
5196
|
const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);
|
5107
5197
|
let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);
|
5108
5198
|
if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;
|
@@ -5229,9 +5319,6 @@ function slideToLoop(index, speed, runCallbacks, internal) {
|
|
5229
5319
|
if (index === void 0) {
|
5230
5320
|
index = 0;
|
5231
5321
|
}
|
5232
|
-
if (speed === void 0) {
|
5233
|
-
speed = this.params.speed;
|
5234
|
-
}
|
5235
5322
|
if (runCallbacks === void 0) {
|
5236
5323
|
runCallbacks = true;
|
5237
5324
|
}
|
@@ -5241,6 +5328,9 @@ function slideToLoop(index, speed, runCallbacks, internal) {
|
|
5241
5328
|
}
|
5242
5329
|
const swiper = this;
|
5243
5330
|
if (swiper.destroyed) return;
|
5331
|
+
if (typeof speed === 'undefined') {
|
5332
|
+
speed = swiper.params.speed;
|
5333
|
+
}
|
5244
5334
|
const gridEnabled = swiper.grid && swiper.params.grid && swiper.params.grid.rows > 1;
|
5245
5335
|
let newIndex = index;
|
5246
5336
|
if (swiper.params.loop) {
|
@@ -5272,6 +5362,9 @@ function slideToLoop(index, speed, runCallbacks, internal) {
|
|
5272
5362
|
if (centeredSlides) {
|
5273
5363
|
needLoopFix = needLoopFix || targetSlideIndex < Math.ceil(slidesPerView / 2);
|
5274
5364
|
}
|
5365
|
+
if (internal && centeredSlides && swiper.params.slidesPerView !== 'auto' && !gridEnabled) {
|
5366
|
+
needLoopFix = false;
|
5367
|
+
}
|
5275
5368
|
if (needLoopFix) {
|
5276
5369
|
const direction = centeredSlides ? targetSlideIndex < swiper.activeIndex ? 'prev' : 'next' : targetSlideIndex - swiper.activeIndex - 1 < swiper.params.slidesPerView ? 'next' : 'prev';
|
5277
5370
|
swiper.loopFix({
|
@@ -5297,9 +5390,6 @@ function slideToLoop(index, speed, runCallbacks, internal) {
|
|
5297
5390
|
|
5298
5391
|
/* eslint no-unused-vars: "off" */
|
5299
5392
|
function slideNext(speed, runCallbacks, internal) {
|
5300
|
-
if (speed === void 0) {
|
5301
|
-
speed = this.params.speed;
|
5302
|
-
}
|
5303
5393
|
if (runCallbacks === void 0) {
|
5304
5394
|
runCallbacks = true;
|
5305
5395
|
}
|
@@ -5310,6 +5400,9 @@ function slideNext(speed, runCallbacks, internal) {
|
|
5310
5400
|
animating
|
5311
5401
|
} = swiper;
|
5312
5402
|
if (!enabled || swiper.destroyed) return swiper;
|
5403
|
+
if (typeof speed === 'undefined') {
|
5404
|
+
speed = swiper.params.speed;
|
5405
|
+
}
|
5313
5406
|
let perGroup = params.slidesPerGroup;
|
5314
5407
|
if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {
|
5315
5408
|
perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);
|
@@ -5338,9 +5431,6 @@ function slideNext(speed, runCallbacks, internal) {
|
|
5338
5431
|
|
5339
5432
|
/* eslint no-unused-vars: "off" */
|
5340
5433
|
function slidePrev(speed, runCallbacks, internal) {
|
5341
|
-
if (speed === void 0) {
|
5342
|
-
speed = this.params.speed;
|
5343
|
-
}
|
5344
5434
|
if (runCallbacks === void 0) {
|
5345
5435
|
runCallbacks = true;
|
5346
5436
|
}
|
@@ -5354,6 +5444,9 @@ function slidePrev(speed, runCallbacks, internal) {
|
|
5354
5444
|
animating
|
5355
5445
|
} = swiper;
|
5356
5446
|
if (!enabled || swiper.destroyed) return swiper;
|
5447
|
+
if (typeof speed === 'undefined') {
|
5448
|
+
speed = swiper.params.speed;
|
5449
|
+
}
|
5357
5450
|
const isVirtual = swiper.virtual && params.virtual.enabled;
|
5358
5451
|
if (params.loop) {
|
5359
5452
|
if (animating && !isVirtual && params.loopPreventsSliding) return false;
|
@@ -5406,22 +5499,19 @@ function slidePrev(speed, runCallbacks, internal) {
|
|
5406
5499
|
|
5407
5500
|
/* eslint no-unused-vars: "off" */
|
5408
5501
|
function slideReset(speed, runCallbacks, internal) {
|
5409
|
-
if (speed === void 0) {
|
5410
|
-
speed = this.params.speed;
|
5411
|
-
}
|
5412
5502
|
if (runCallbacks === void 0) {
|
5413
5503
|
runCallbacks = true;
|
5414
5504
|
}
|
5415
5505
|
const swiper = this;
|
5416
5506
|
if (swiper.destroyed) return;
|
5507
|
+
if (typeof speed === 'undefined') {
|
5508
|
+
speed = swiper.params.speed;
|
5509
|
+
}
|
5417
5510
|
return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);
|
5418
5511
|
}
|
5419
5512
|
|
5420
5513
|
/* eslint no-unused-vars: "off" */
|
5421
5514
|
function slideToClosest(speed, runCallbacks, internal, threshold) {
|
5422
|
-
if (speed === void 0) {
|
5423
|
-
speed = this.params.speed;
|
5424
|
-
}
|
5425
5515
|
if (runCallbacks === void 0) {
|
5426
5516
|
runCallbacks = true;
|
5427
5517
|
}
|
@@ -5430,6 +5520,9 @@ function slideToClosest(speed, runCallbacks, internal, threshold) {
|
|
5430
5520
|
}
|
5431
5521
|
const swiper = this;
|
5432
5522
|
if (swiper.destroyed) return;
|
5523
|
+
if (typeof speed === 'undefined') {
|
5524
|
+
speed = swiper.params.speed;
|
5525
|
+
}
|
5433
5526
|
let index = swiper.activeIndex;
|
5434
5527
|
const skip = Math.min(swiper.params.slidesPerGroupSkip, index);
|
5435
5528
|
const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);
|
@@ -6064,7 +6157,7 @@ function onTouchMove(event) {
|
|
6064
6157
|
data.startMoving = true;
|
6065
6158
|
}
|
6066
6159
|
}
|
6067
|
-
if (data.isScrolling) {
|
6160
|
+
if (data.isScrolling || e.type === 'touchmove' && data.preventTouchMoveFromPointerMove) {
|
6068
6161
|
data.isTouched = false;
|
6069
6162
|
return;
|
6070
6163
|
}
|
@@ -6106,7 +6199,10 @@ function onTouchMove(event) {
|
|
6106
6199
|
if (swiper.animating) {
|
6107
6200
|
const evt = new window.CustomEvent('transitionend', {
|
6108
6201
|
bubbles: true,
|
6109
|
-
cancelable: true
|
6202
|
+
cancelable: true,
|
6203
|
+
detail: {
|
6204
|
+
bySwiperTouchMove: true
|
6205
|
+
}
|
6110
6206
|
});
|
6111
6207
|
swiper.wrapperEl.dispatchEvent(evt);
|
6112
6208
|
}
|
@@ -6500,6 +6596,7 @@ const events = (swiper, method) => {
|
|
6500
6596
|
const capture = !!params.nested;
|
6501
6597
|
const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';
|
6502
6598
|
const swiperMethod = method;
|
6599
|
+
if (!el || typeof el === 'string') return;
|
6503
6600
|
|
6504
6601
|
// Touch Events
|
6505
6602
|
document[domMethod]('touchstart', swiper.onDocumentTouchStart, {
|
@@ -6608,6 +6705,8 @@ function setBreakpoint() {
|
|
6608
6705
|
const breakpointParams = breakpointOnlyParams || swiper.originalParams;
|
6609
6706
|
const wasMultiRow = isGridEnabled(swiper, params);
|
6610
6707
|
const isMultiRow = isGridEnabled(swiper, breakpointParams);
|
6708
|
+
const wasGrabCursor = swiper.params.grabCursor;
|
6709
|
+
const isGrabCursor = breakpointParams.grabCursor;
|
6611
6710
|
const wasEnabled = params.enabled;
|
6612
6711
|
if (wasMultiRow && !isMultiRow) {
|
6613
6712
|
el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);
|
@@ -6619,6 +6718,11 @@ function setBreakpoint() {
|
|
6619
6718
|
}
|
6620
6719
|
swiper.emitContainerClasses();
|
6621
6720
|
}
|
6721
|
+
if (wasGrabCursor && !isGrabCursor) {
|
6722
|
+
swiper.unsetGrabCursor();
|
6723
|
+
} else if (!wasGrabCursor && isGrabCursor) {
|
6724
|
+
swiper.setGrabCursor();
|
6725
|
+
}
|
6622
6726
|
|
6623
6727
|
// Toggle navigation, pagination, scrollbar
|
6624
6728
|
['navigation', 'pagination', 'scrollbar'].forEach(prop => {
|
@@ -6769,6 +6873,7 @@ function removeClasses() {
|
|
6769
6873
|
el,
|
6770
6874
|
classNames
|
6771
6875
|
} = swiper;
|
6876
|
+
if (!el || typeof el === 'string') return;
|
6772
6877
|
el.classList.remove(...classNames);
|
6773
6878
|
swiper.emitContainerClasses();
|
6774
6879
|
}
|
@@ -7533,8 +7638,12 @@ let Swiper$1 = class Swiper {
|
|
7533
7638
|
// Cleanup styles
|
7534
7639
|
if (cleanStyles) {
|
7535
7640
|
swiper.removeClasses();
|
7536
|
-
el
|
7537
|
-
|
7641
|
+
if (el && typeof el !== 'string') {
|
7642
|
+
el.removeAttribute('style');
|
7643
|
+
}
|
7644
|
+
if (wrapperEl) {
|
7645
|
+
wrapperEl.removeAttribute('style');
|
7646
|
+
}
|
7538
7647
|
if (slides && slides.length) {
|
7539
7648
|
slides.forEach(slideEl => {
|
7540
7649
|
slideEl.classList.remove(params.slideVisibleClass, params.slideFullyVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass);
|
@@ -7550,7 +7659,9 @@ let Swiper$1 = class Swiper {
|
|
7550
7659
|
swiper.off(eventName);
|
7551
7660
|
});
|
7552
7661
|
if (deleteInstance !== false) {
|
7553
|
-
swiper.el.
|
7662
|
+
if (swiper.el && typeof swiper.el !== 'string') {
|
7663
|
+
swiper.el.swiper = null;
|
7664
|
+
}
|
7554
7665
|
deleteProps(swiper);
|
7555
7666
|
}
|
7556
7667
|
swiper.destroyed = true;
|
@@ -7944,7 +8055,7 @@ const updateOnVirtualData = swiper => {
|
|
7944
8055
|
};
|
7945
8056
|
|
7946
8057
|
/**
|
7947
|
-
* Swiper React 11.
|
8058
|
+
* Swiper React 11.1.4
|
7948
8059
|
* Most modern mobile touch slider and framework with hardware accelerated transitions
|
7949
8060
|
* https://swiperjs.com
|
7950
8061
|
*
|
@@ -7952,7 +8063,7 @@ const updateOnVirtualData = swiper => {
|
|
7952
8063
|
*
|
7953
8064
|
* Released under the MIT License
|
7954
8065
|
*
|
7955
|
-
* Released on:
|
8066
|
+
* Released on: May 30, 2024
|
7956
8067
|
*/
|
7957
8068
|
|
7958
8069
|
|
@@ -8640,7 +8751,7 @@ const CommodityDetail = createMaterial(CommodityDetailComponent, {
|
|
8640
8751
|
category: 'popup',
|
8641
8752
|
type: 'CommodityDetail',
|
8642
8753
|
related: {
|
8643
|
-
settingRender: settingRender$
|
8754
|
+
settingRender: settingRender$5
|
8644
8755
|
},
|
8645
8756
|
defaulSetting: {
|
8646
8757
|
props: {
|
@@ -8706,7 +8817,7 @@ var interactionRender$7 = [
|
|
8706
8817
|
*
|
8707
8818
|
*/
|
8708
8819
|
var _a$3, _b$3;
|
8709
|
-
var settingRender$
|
8820
|
+
var settingRender$4 = [
|
8710
8821
|
{
|
8711
8822
|
title: '',
|
8712
8823
|
child: [
|
@@ -8833,7 +8944,7 @@ const Prompt = createMaterial(PromptComponent, {
|
|
8833
8944
|
category: 'popup',
|
8834
8945
|
type: 'Prompt',
|
8835
8946
|
related: {
|
8836
|
-
settingRender: settingRender$
|
8947
|
+
settingRender: settingRender$4,
|
8837
8948
|
bindableProps: [],
|
8838
8949
|
interactionRender: interactionRender$7
|
8839
8950
|
},
|
@@ -8859,7 +8970,7 @@ var _a$2, _b$2;
|
|
8859
8970
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
|
8860
8971
|
*
|
8861
8972
|
*/
|
8862
|
-
var settingRender$
|
8973
|
+
var settingRender$3 = [
|
8863
8974
|
{
|
8864
8975
|
title: '商品图片',
|
8865
8976
|
child: [
|
@@ -9182,7 +9293,7 @@ const CommodityDetailDiroNew = createMaterial(CommodityDetailDiroNewComponent, {
|
|
9182
9293
|
category: 'popup',
|
9183
9294
|
type: 'CommodityDetailDiroNew',
|
9184
9295
|
related: {
|
9185
|
-
settingRender: settingRender$
|
9296
|
+
settingRender: settingRender$3
|
9186
9297
|
},
|
9187
9298
|
defaulSetting: {
|
9188
9299
|
props: {
|
@@ -9243,7 +9354,7 @@ var _a$1, _b$1;
|
|
9243
9354
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\template\components\settingRender.tsx
|
9244
9355
|
*
|
9245
9356
|
*/
|
9246
|
-
var settingRender$
|
9357
|
+
var settingRender$2 = [
|
9247
9358
|
{
|
9248
9359
|
title: '主题样式',
|
9249
9360
|
child: [
|
@@ -9595,7 +9706,7 @@ const Commodity = createMaterial(CommodityComponent, {
|
|
9595
9706
|
related: {
|
9596
9707
|
interactionRender: interactionRender$6,
|
9597
9708
|
bindableProps: [],
|
9598
|
-
settingRender: settingRender$
|
9709
|
+
settingRender: settingRender$2
|
9599
9710
|
},
|
9600
9711
|
defaulSetting: {
|
9601
9712
|
props: {
|
@@ -9674,7 +9785,7 @@ const Appoint = createMaterial(AppointComponent, {
|
|
9674
9785
|
type: 'Appoint',
|
9675
9786
|
related: {
|
9676
9787
|
interactionRender: interactionRender$5,
|
9677
|
-
settingRender: settingRender$
|
9788
|
+
settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
|
9678
9789
|
bindableProps: []
|
9679
9790
|
},
|
9680
9791
|
defaulSetting: {
|
@@ -9751,7 +9862,7 @@ const Link = createMaterial(LinkComponent, {
|
|
9751
9862
|
category: 'template',
|
9752
9863
|
type: 'Link',
|
9753
9864
|
related: {
|
9754
|
-
settingRender: settingRender$
|
9865
|
+
settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
|
9755
9866
|
bindableProps: []
|
9756
9867
|
},
|
9757
9868
|
defaulSetting: {
|
@@ -9843,7 +9954,7 @@ const CommodityDiro = createMaterial(CommodityDiroComponent, {
|
|
9843
9954
|
type: 'CommodityDiro',
|
9844
9955
|
related: {
|
9845
9956
|
interactionRender: interactionRender$4,
|
9846
|
-
settingRender: settingRender$
|
9957
|
+
settingRender: settingRender$2,
|
9847
9958
|
bindableProps: []
|
9848
9959
|
},
|
9849
9960
|
defaulSetting: {
|
@@ -9942,7 +10053,7 @@ const CommodityDiroNew = createMaterial(CommodityDiroNewComponent, {
|
|
9942
10053
|
related: {
|
9943
10054
|
interactionRender: interactionRender$3,
|
9944
10055
|
bindableProps: [],
|
9945
|
-
settingRender: settingRender$
|
10056
|
+
settingRender: settingRender$2
|
9946
10057
|
},
|
9947
10058
|
defaulSetting: {
|
9948
10059
|
props: {
|
@@ -10087,7 +10198,7 @@ const MultiCommodityDiro = createMaterial(MultiCommodityDiroComponent, {
|
|
10087
10198
|
related: {
|
10088
10199
|
interactionRender: interactionRender$2,
|
10089
10200
|
bindableProps: [],
|
10090
|
-
settingRender: settingRender$
|
10201
|
+
settingRender: settingRender$2
|
10091
10202
|
},
|
10092
10203
|
defaulSetting: {
|
10093
10204
|
props: {
|
@@ -10201,7 +10312,7 @@ const MultiCommodity = createMaterial(MultiCommodityComponent, {
|
|
10201
10312
|
type: 'MultiCommodity',
|
10202
10313
|
related: {
|
10203
10314
|
interactionRender: interactionRender$1,
|
10204
|
-
settingRender: settingRender$
|
10315
|
+
settingRender: settingRender$2,
|
10205
10316
|
bindableProps: []
|
10206
10317
|
},
|
10207
10318
|
defaulSetting: {
|
@@ -10317,7 +10428,7 @@ const MultiCommodityDiroNew = createMaterial(MultiCommodityDiroNewComponent, {
|
|
10317
10428
|
related: {
|
10318
10429
|
interactionRender,
|
10319
10430
|
bindableProps: [],
|
10320
|
-
settingRender: settingRender$
|
10431
|
+
settingRender: settingRender$2
|
10321
10432
|
},
|
10322
10433
|
defaulSetting: {
|
10323
10434
|
props: {
|
@@ -10363,11 +10474,11 @@ var _a, _b;
|
|
10363
10474
|
* @Author: binruan@chatlabs.com
|
10364
10475
|
* @Date: 2024-04-07 14:07:12
|
10365
10476
|
* @LastEditors: binruan@chatlabs.com
|
10366
|
-
* @LastEditTime: 2024-06-
|
10477
|
+
* @LastEditTime: 2024-06-11 11:04:55
|
10367
10478
|
* @FilePath: \pb-sxp-ui\src\materials\sxp\HashTag\settingRender.tsx
|
10368
10479
|
*
|
10369
10480
|
*/
|
10370
|
-
var settingRender = [
|
10481
|
+
var settingRender$1 = [
|
10371
10482
|
{
|
10372
10483
|
title: 'Banner',
|
10373
10484
|
child: [
|
@@ -10390,7 +10501,7 @@ var settingRender = [
|
|
10390
10501
|
{
|
10391
10502
|
type: 'Switch',
|
10392
10503
|
label: '固定宽高',
|
10393
|
-
name: ['props', '
|
10504
|
+
name: ['props', 'openFixedSize'],
|
10394
10505
|
initialValue: true
|
10395
10506
|
}
|
10396
10507
|
]
|
@@ -12000,8 +12111,8 @@ const WaterfallFlowItem$1 = (props) => {
|
|
12000
12111
|
React.createElement("div", { className: 'waterFallList-content-listItem-info-price', hidden: !priceText, style: textStyles.price }, priceText))));
|
12001
12112
|
};
|
12002
12113
|
function WaterfallList$1(_a) {
|
12003
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
|
12004
|
-
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
12114
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v;
|
12115
|
+
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12005
12116
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12006
12117
|
/** 滚动的父元素 */
|
12007
12118
|
const scrollParent = useRef(null);
|
@@ -12205,25 +12316,30 @@ function WaterfallList$1(_a) {
|
|
12205
12316
|
return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
|
12206
12317
|
React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'waterFallList', ref: waterfallFlowDom },
|
12207
12318
|
React.createElement("div", { className: 'waterFallList-scroll', ref: scrollParent },
|
12208
|
-
|
12209
|
-
|
12319
|
+
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({
|
12320
|
+
width: '100%',
|
12321
|
+
objectFit: 'cover',
|
12322
|
+
marginBottom: '20px'
|
12323
|
+
}), src: (_c = data === null || data === void 0 ? void 0 : data.tag) === null || _c === void 0 ? void 0 : _c.picture })),
|
12324
|
+
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),
|
12325
|
+
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'),
|
12210
12326
|
React.createElement("div", { className: 'waterFallList-content' }, list === null || list === void 0 ? void 0 :
|
12211
12327
|
list.map((item, ind) => {
|
12212
12328
|
var _a;
|
12213
12329
|
return (React.createElement(WaterfallFlowItem$1, Object.assign({ key: ind, index: ind, rec: item, list: list, showBorder: scrollTop + ((_a = scrollParent === null || scrollParent === void 0 ? void 0 : scrollParent.current) === null || _a === void 0 ? void 0 : _a.clientHeight), style: styleList[ind], sizeChange: onSizeChange, unitWidth: unitWidth, reportTagsView: reportTagsView }, props)));
|
12214
12330
|
}),
|
12215
|
-
React.createElement("div", { hidden: !((
|
12331
|
+
React.createElement("div", { hidden: !((_j = data === null || data === void 0 ? void 0 : data.tag) === null || _j === void 0 ? void 0 : _j.link), style: {
|
12216
12332
|
position: 'absolute',
|
12217
12333
|
width: '100%',
|
12218
|
-
transform: `translate(0px,${(
|
12219
|
-
((
|
12220
|
-
height: ((
|
12221
|
-
? ((
|
12334
|
+
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) +
|
12335
|
+
((_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)`,
|
12336
|
+
height: ((_q = data === null || data === void 0 ? void 0 : data.tag) === null || _q === void 0 ? void 0 : _q.link)
|
12337
|
+
? ((_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'
|
12222
12338
|
: 0
|
12223
12339
|
} }))),
|
12224
|
-
React.createElement("div", { className: 'waterFallList-bottom', hidden: !((
|
12225
|
-
React.createElement("div", { ref: buttonRef, hidden: !((
|
12226
|
-
React.createElement("button", { className: 'waterFallList-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12340
|
+
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 }),
|
12341
|
+
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' }) },
|
12342
|
+
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'))))));
|
12227
12343
|
}
|
12228
12344
|
|
12229
12345
|
var img$1 = "";
|
@@ -12352,8 +12468,8 @@ const WaterfallFlowItem = (props) => {
|
|
12352
12468
|
React.createElement("div", { className: 'list-content-listItem-info-price', style: textStyles === null || textStyles === void 0 ? void 0 : textStyles.price, hidden: !priceText }, priceText))));
|
12353
12469
|
};
|
12354
12470
|
function WaterfallList(_a) {
|
12355
|
-
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
12356
|
-
var { reportTagsView } = _a, props = __rest(_a, ["reportTagsView"]);
|
12471
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
12472
|
+
var { reportTagsView, showBanner } = _a, props = __rest(_a, ["reportTagsView", "showBanner"]);
|
12357
12473
|
const { waterFallData, getRecommendVideos, hashTagSize, loadingImage, isOpenHashTag } = useSxpDataSource();
|
12358
12474
|
const [list, setList] = useState();
|
12359
12475
|
const [data, setData] = useState();
|
@@ -12424,31 +12540,37 @@ function WaterfallList(_a) {
|
|
12424
12540
|
return (React.createElement(React.Fragment, null, isLoadingData ? (React.createElement("div", { style: { height: '100%', width: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' } },
|
12425
12541
|
React.createElement("img", { width: 64, height: 64, src: loadingImage, alt: 'loading...', style: { objectFit: 'contain' } }))) : (React.createElement("div", { className: 'list' },
|
12426
12542
|
React.createElement("div", { className: 'list-scroll', ref: containerRef },
|
12427
|
-
|
12428
|
-
|
12543
|
+
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({
|
12544
|
+
width: '100%',
|
12545
|
+
objectFit: 'cover',
|
12546
|
+
marginBottom: '20px'
|
12547
|
+
}), src: (_c = data === null || data === void 0 ? void 0 : data.tag) === null || _c === void 0 ? void 0 : _c.picture })),
|
12548
|
+
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),
|
12549
|
+
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'),
|
12429
12550
|
React.createElement("div", { className: 'list-content' }, list === null || list === void 0 ? void 0 : list.map((item, ind) => {
|
12430
12551
|
return (React.createElement(WaterfallFlowItem, Object.assign({ key: ind, index: ind, rec: item, list: list, reportTagsView: reportTagsView }, props)));
|
12431
12552
|
})),
|
12432
12553
|
React.createElement("div", { hidden: !isLoadMore, style: { textAlign: 'center' } }, "loading..."),
|
12433
|
-
React.createElement("div", { hidden: !((
|
12434
|
-
height: ((
|
12554
|
+
React.createElement("div", { hidden: !((_j = data === null || data === void 0 ? void 0 : data.tag) === null || _j === void 0 ? void 0 : _j.link), style: {
|
12555
|
+
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
|
12435
12556
|
} })),
|
12436
|
-
React.createElement("div", { className: 'list-bottom', hidden: !((
|
12437
|
-
React.createElement("div", { hidden: !((
|
12438
|
-
React.createElement("button", { className: 'list-btn', style: props === null || props === void 0 ? void 0 : props.buttonStyle, onClick: handleClickLink }, ((
|
12557
|
+
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 }),
|
12558
|
+
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' }) },
|
12559
|
+
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'))))));
|
12439
12560
|
}
|
12440
12561
|
|
12441
12562
|
/*
|
12442
12563
|
* @Author: binruan@chatlabs.com
|
12443
12564
|
* @Date: 2024-01-10 10:58:24
|
12444
12565
|
* @LastEditors: binruan@chatlabs.com
|
12445
|
-
* @LastEditTime: 2024-06-
|
12566
|
+
* @LastEditTime: 2024-06-12 14:18:56
|
12446
12567
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
|
12447
12568
|
*
|
12448
12569
|
*/
|
12449
12570
|
const WaterFall = (props) => {
|
12450
12571
|
var _a;
|
12451
|
-
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport } = useSxpDataSource();
|
12572
|
+
const { waterFallData, setOpenHashtag, openHashtag, swiperRef, setWaterFallData, cacheRtcList, setRtcList, cacheActiveIndex, rtcList, setCacheRtcList, setIsFromHashtag, isFromHashtag, bffEventReport, themeTag } = useSxpDataSource();
|
12573
|
+
const { backMainFeed } = useEventReport();
|
12452
12574
|
useRef(null);
|
12453
12575
|
const modalEleRef = useRef(null);
|
12454
12576
|
const [viewTime, setViewTime] = useState();
|
@@ -12469,6 +12591,9 @@ const WaterFall = (props) => {
|
|
12469
12591
|
if (!isEq && cacheRtcList && (cacheRtcList === null || cacheRtcList === void 0 ? void 0 : cacheRtcList.length)) {
|
12470
12592
|
setRtcList === null || setRtcList === void 0 ? void 0 : setRtcList(cacheRtcList);
|
12471
12593
|
}
|
12594
|
+
if (!(themeTag === null || themeTag === void 0 ? void 0 : themeTag.current)) {
|
12595
|
+
backMainFeed('branch', themeTag === null || themeTag === void 0 ? void 0 : themeTag.current, waterFallData === null || waterFallData === void 0 ? void 0 : waterFallData.hashTag);
|
12596
|
+
}
|
12472
12597
|
reportTagsView();
|
12473
12598
|
setWaterFallData === null || setWaterFallData === void 0 ? void 0 : setWaterFallData(undefined);
|
12474
12599
|
setIsFromHashtag === null || setIsFromHashtag === void 0 ? void 0 : setIsFromHashtag(false);
|
@@ -12536,7 +12661,7 @@ const WaterFall = (props) => {
|
|
12536
12661
|
display: openHashtag ? 'block' : 'none'
|
12537
12662
|
} },
|
12538
12663
|
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 }),
|
12539
|
-
(props === null || props === void 0 ? void 0 : props.
|
12664
|
+
(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);
|
12540
12665
|
};
|
12541
12666
|
var WaterFall$1 = memo(WaterFall);
|
12542
12667
|
|
@@ -12567,7 +12692,7 @@ const HashTag = createMaterial(HashTagComponent, {
|
|
12567
12692
|
category: 'base',
|
12568
12693
|
type: 'HashTag',
|
12569
12694
|
related: {
|
12570
|
-
settingRender,
|
12695
|
+
settingRender: settingRender$1,
|
12571
12696
|
bindableProps: []
|
12572
12697
|
},
|
12573
12698
|
defaulSetting: {
|
@@ -12624,6 +12749,84 @@ const HashTag = createMaterial(HashTagComponent, {
|
|
12624
12749
|
sort: 2
|
12625
12750
|
});
|
12626
12751
|
|
12752
|
+
/*
|
12753
|
+
* @Author: binruan@chatlabs.com
|
12754
|
+
* @Date: 2024-06-13 10:08:32
|
12755
|
+
* @LastEditors: binruan@chatlabs.com
|
12756
|
+
* @LastEditTime: 2024-06-13 17:42:50
|
12757
|
+
* @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\settingRender.tsx
|
12758
|
+
*
|
12759
|
+
*/
|
12760
|
+
var settingRender = [
|
12761
|
+
{
|
12762
|
+
title: '协议详情',
|
12763
|
+
child: [
|
12764
|
+
{
|
12765
|
+
type: 'Switch',
|
12766
|
+
label: '必须同意用户协议',
|
12767
|
+
name: ['props', 'privacy_necessity'],
|
12768
|
+
extra: '当新用户进入页面时,会出现用户协议弹窗,用户需要先同意协议后才能访问内容。'
|
12769
|
+
},
|
12770
|
+
{
|
12771
|
+
type: 'Text',
|
12772
|
+
label: '弹窗标题',
|
12773
|
+
name: ['props', 'privacy_title']
|
12774
|
+
},
|
12775
|
+
{
|
12776
|
+
type: 'TextArea',
|
12777
|
+
label: '用户协议弹窗内容',
|
12778
|
+
name: ['props', 'privacy_context']
|
12779
|
+
},
|
12780
|
+
{
|
12781
|
+
type: 'Group',
|
12782
|
+
label: '隐私政策',
|
12783
|
+
child: [
|
12784
|
+
{
|
12785
|
+
type: 'Text',
|
12786
|
+
name: ['props', 'privacy_policy_title']
|
12787
|
+
},
|
12788
|
+
{
|
12789
|
+
type: 'Text',
|
12790
|
+
name: ['props', 'privacy_policy_url'],
|
12791
|
+
addonBefore: 'https://'
|
12792
|
+
}
|
12793
|
+
],
|
12794
|
+
extra: '当用户点击更多信息按钮时,将会跳转至设置的链接查看政策内容'
|
12795
|
+
}
|
12796
|
+
]
|
12797
|
+
}
|
12798
|
+
];
|
12799
|
+
|
12800
|
+
const Consent$1 = (props) => {
|
12801
|
+
return React.createElement(Consent$1, Object.assign({}, props));
|
12802
|
+
};
|
12803
|
+
var ConsentComponent = memo(Consent$1);
|
12804
|
+
|
12805
|
+
/*
|
12806
|
+
* @Author: binruan@chatlabs.com
|
12807
|
+
* @Date: 2023-07-28 18:29:57
|
12808
|
+
* @LastEditors: binruan@chatlabs.com
|
12809
|
+
* @LastEditTime: 2024-06-13 17:32:17
|
12810
|
+
* @FilePath: \pb-sxp-ui\src\materials\sxp\Consent\material.tsx
|
12811
|
+
*
|
12812
|
+
*/
|
12813
|
+
const Consent = createMaterial(ConsentComponent, {
|
12814
|
+
displayName: 'Consent',
|
12815
|
+
icon: '',
|
12816
|
+
category: 'base',
|
12817
|
+
type: 'Consent',
|
12818
|
+
related: {
|
12819
|
+
settingRender
|
12820
|
+
},
|
12821
|
+
defaulSetting: {
|
12822
|
+
props: {},
|
12823
|
+
style: {}
|
12824
|
+
},
|
12825
|
+
w: 100,
|
12826
|
+
h: 40,
|
12827
|
+
sort: 1
|
12828
|
+
});
|
12829
|
+
|
12627
12830
|
/*
|
12628
12831
|
* @Author: binruan@chatlabs.com
|
12629
12832
|
* @Date: 2023-07-25 14:56:49
|
@@ -12642,6 +12845,7 @@ var _materials_ = /*#__PURE__*/Object.freeze({
|
|
12642
12845
|
CommodityDetailDiroNew: CommodityDetailDiroNew,
|
12643
12846
|
CommodityDiro: CommodityDiro,
|
12644
12847
|
CommodityDiroNew: CommodityDiroNew,
|
12848
|
+
Consent: Consent,
|
12645
12849
|
HashTag: HashTag,
|
12646
12850
|
Link: Link,
|
12647
12851
|
MultiCommodity: MultiCommodity,
|
@@ -13314,16 +13518,37 @@ const Nudge = ({ nudge }) => {
|
|
13314
13518
|
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 : '')))));
|
13315
13519
|
};
|
13316
13520
|
|
13521
|
+
/*
|
13522
|
+
* @Author: binruan@chatlabs.com
|
13523
|
+
* @Date: 2024-04-29 16:32:21
|
13524
|
+
* @LastEditors: binruan@chatlabs.com
|
13525
|
+
* @LastEditTime: 2024-06-12 11:01:48
|
13526
|
+
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Tagbar.tsx
|
13527
|
+
*
|
13528
|
+
*/
|
13317
13529
|
const DEFAULT_TAG = 'FOR U';
|
13318
13530
|
const Tagbar = ({ tagList = [], setActiveIndex }) => {
|
13319
13531
|
const [selectTag, setSelectTag] = useState(DEFAULT_TAG);
|
13320
|
-
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData } = useSxpDataSource();
|
13532
|
+
const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport } = useSxpDataSource();
|
13533
|
+
const { backMainFeed } = useEventReport();
|
13321
13534
|
const realTagList = useMemo(() => {
|
13322
13535
|
return [DEFAULT_TAG, ...tagList];
|
13323
13536
|
}, [tagList]);
|
13324
13537
|
const handleSelectTag = (tag) => () => {
|
13325
13538
|
if (tag === selectTag)
|
13326
13539
|
return;
|
13540
|
+
if (tag !== 'FOR U') {
|
13541
|
+
bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
|
13542
|
+
eventInfo: {
|
13543
|
+
eventSubject: 'clickThemeTagsViewContents',
|
13544
|
+
eventDescription: 'click Theme Tags View Contents',
|
13545
|
+
themeTags: `[${tag}]`
|
13546
|
+
}
|
13547
|
+
});
|
13548
|
+
}
|
13549
|
+
else {
|
13550
|
+
backMainFeed('theme', selectTag);
|
13551
|
+
}
|
13327
13552
|
let themeTag;
|
13328
13553
|
if (tag !== DEFAULT_TAG) {
|
13329
13554
|
themeTag = tag;
|
@@ -13355,7 +13580,7 @@ var Tagbar$1 = memo(Tagbar);
|
|
13355
13580
|
* @Author: binruan@chatlabs.com
|
13356
13581
|
* @Date: 2024-01-15 19:03:09
|
13357
13582
|
* @LastEditors: binruan@chatlabs.com
|
13358
|
-
* @LastEditTime: 2024-06-
|
13583
|
+
* @LastEditTime: 2024-06-13 18:09:16
|
13359
13584
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
|
13360
13585
|
*
|
13361
13586
|
*/
|
@@ -13366,11 +13591,11 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13366
13591
|
const viewImageStartTime = useRef(0);
|
13367
13592
|
const [isInit, setIsInit] = useState(false);
|
13368
13593
|
const [isMuted, setIsMuted] = useState(true);
|
13369
|
-
const curTime = useRef();
|
13370
13594
|
const viewTime = useRef();
|
13371
13595
|
const [isLoadMore, setIsLoadMore] = useState(false);
|
13372
13596
|
const [isShowMore, setIsShowMore] = useState(false);
|
13373
|
-
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport } = useSxpDataSource();
|
13597
|
+
const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink } = useSxpDataSource();
|
13598
|
+
const { backMainFeed } = useEventReport();
|
13374
13599
|
const [videoRef, setVideoRef] = useState(null);
|
13375
13600
|
const playerRef = useRef();
|
13376
13601
|
const { productView } = useEventReport();
|
@@ -13381,17 +13606,17 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13381
13606
|
if (data.length <= 0) {
|
13382
13607
|
return;
|
13383
13608
|
}
|
13384
|
-
|
13609
|
+
refreshFeSessionId();
|
13610
|
+
const now = new Date();
|
13611
|
+
viewTime.current = now;
|
13612
|
+
if (isInit) {
|
13613
|
+
h5EnterLink === null || h5EnterLink === void 0 ? void 0 : h5EnterLink();
|
13614
|
+
}
|
13385
13615
|
bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
|
13386
13616
|
eventName: 'PageView'
|
13387
13617
|
});
|
13388
13618
|
setIsInit(true);
|
13389
|
-
}, [data.length, bffFbReport]);
|
13390
|
-
const initTime = () => {
|
13391
|
-
curTime.current = new Date();
|
13392
|
-
viewTime.current = new Date();
|
13393
|
-
refreshFeSessionId();
|
13394
|
-
};
|
13619
|
+
}, [data.length, bffFbReport, h5EnterLink, isInit]);
|
13395
13620
|
const firstRef = useRef();
|
13396
13621
|
useEffect(() => {
|
13397
13622
|
var _a, _b, _c, _d;
|
@@ -13487,13 +13712,33 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
|
|
13487
13712
|
handleH5EnterLink();
|
13488
13713
|
handleViewImageStartEvent(activeIndex);
|
13489
13714
|
SXP_EVENT_BUS.emit(SXP_EVENT_TYPE.PAGE_DID_SHOW, item);
|
13715
|
+
backMainFeed('external');
|
13490
13716
|
}
|
13491
13717
|
};
|
13492
13718
|
document.addEventListener('visibilitychange', visibleChange);
|
13493
13719
|
return () => {
|
13494
13720
|
document.removeEventListener('visibilitychange', visibleChange);
|
13495
13721
|
};
|
13496
|
-
}, [
|
13722
|
+
}, [
|
13723
|
+
activeIndex,
|
13724
|
+
bffEventReport,
|
13725
|
+
data,
|
13726
|
+
handleH5EnterLink,
|
13727
|
+
popupDetailData,
|
13728
|
+
isFromHashtag,
|
13729
|
+
tempMap,
|
13730
|
+
curTime,
|
13731
|
+
backMainFeed
|
13732
|
+
]);
|
13733
|
+
useEffect(() => {
|
13734
|
+
const initTime = () => {
|
13735
|
+
backMainFeed('external');
|
13736
|
+
};
|
13737
|
+
window.addEventListener('pageshow', initTime);
|
13738
|
+
return () => {
|
13739
|
+
window.removeEventListener('pageshow', initTime);
|
13740
|
+
};
|
13741
|
+
}, []);
|
13497
13742
|
const tagHeight = useMemo(() => {
|
13498
13743
|
let h = 0;
|
13499
13744
|
if (tagList.length > 0) {
|
@@ -14235,7 +14480,7 @@ const Popup = () => {
|
|
14235
14480
|
* @Author: binruan@chatlabs.com
|
14236
14481
|
* @Date: 2024-01-15 19:03:09
|
14237
14482
|
* @LastEditors: binruan@chatlabs.com
|
14238
|
-
* @LastEditTime: 2024-
|
14483
|
+
* @LastEditTime: 2024-06-13 14:54:12
|
14239
14484
|
* @FilePath: \pb-sxp-ui\src\core\components\SxpPageCore\index.tsx
|
14240
14485
|
*
|
14241
14486
|
*/
|
@@ -14252,14 +14497,14 @@ Object.values(_materials_).forEach((v) => {
|
|
14252
14497
|
RESOLVER[v.extend.type] = v;
|
14253
14498
|
});
|
14254
14499
|
const SxpPageCore = ({ data, maxSize = 10, defaultSize = 10, hashTagSize = 20, loadingImage, appDomain, licenseUrl, enabledMetaConversionApi }) => {
|
14255
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
14500
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
14256
14501
|
const utmVal = useMemo(() => {
|
14257
14502
|
var _a;
|
14258
14503
|
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('?', '') : '';
|
14259
14504
|
return searchParams;
|
14260
14505
|
}, []);
|
14261
14506
|
return (React.createElement(EditorCore, { resolver: RESOLVER, enableDataSource: false, schema: data === null || data === void 0 ? void 0 : data.data, utmVal: utmVal },
|
14262
|
-
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 }) => {
|
14507
|
+
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 }) => {
|
14263
14508
|
var _a;
|
14264
14509
|
return (React.createElement(React.Fragment, null,
|
14265
14510
|
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 })),
|
@@ -14278,8 +14523,9 @@ var index = memo(SxpPageCore);
|
|
14278
14523
|
*/
|
14279
14524
|
const EditorDataContext = createContext({});
|
14280
14525
|
const EditorDataProvider = ({ children, data }) => {
|
14281
|
-
var _a, _b, _c, _d, _e, _f;
|
14526
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
14282
14527
|
const [openHashtag, setOpenHashtag] = useState(false);
|
14528
|
+
const [openConsent, setOpenConsent] = useState(false);
|
14283
14529
|
return (React.createElement(EditorDataContext.Provider, { value: {
|
14284
14530
|
sxpPrameter: {
|
14285
14531
|
bottomImage: (_a = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _a === void 0 ? void 0 : _a.bottom_image,
|
@@ -14287,11 +14533,20 @@ const EditorDataProvider = ({ children, data }) => {
|
|
14287
14533
|
personalizedRecommend: (_c = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _c === void 0 ? void 0 : _c.personalized_recommend,
|
14288
14534
|
placeholderImage: (_d = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _d === void 0 ? void 0 : _d.placeholder_image,
|
14289
14535
|
hashTagSize: (_e = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _e === void 0 ? void 0 : _e.hash_tag_size,
|
14290
|
-
loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image
|
14536
|
+
loadingImage: (_f = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _f === void 0 ? void 0 : _f.loading_image,
|
14537
|
+
privacyContent: (_g = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _g === void 0 ? void 0 : _g.privacy_context,
|
14538
|
+
privacyNecessity: (_h = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _h === void 0 ? void 0 : _h.privacy_necessity,
|
14539
|
+
privacyPolicyTitle: (_j = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _j === void 0 ? void 0 : _j.privacy_policy_title,
|
14540
|
+
privacyPolicyUrl: (_k = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _k === void 0 ? void 0 : _k.privacy_policy_url,
|
14541
|
+
privacyTitle: (_l = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _l === void 0 ? void 0 : _l.privacy_title,
|
14542
|
+
template: (_m = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _m === void 0 ? void 0 : _m.template,
|
14543
|
+
industry: (_o = data === null || data === void 0 ? void 0 : data.sxp_parameter) === null || _o === void 0 ? void 0 : _o.industry
|
14291
14544
|
},
|
14292
14545
|
appDomain: data === null || data === void 0 ? void 0 : data.appDomain,
|
14293
14546
|
openHashtag,
|
14294
|
-
setOpenHashtag
|
14547
|
+
setOpenHashtag,
|
14548
|
+
openConsent,
|
14549
|
+
setOpenConsent
|
14295
14550
|
} }, children));
|
14296
14551
|
};
|
14297
14552
|
function useEditorDataProvider() {
|