pb-sxp-ui 1.0.100 → 1.0.102

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.
Files changed (48) hide show
  1. package/dist/index.cjs +188 -139
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +10 -3
  4. package/dist/index.js +189 -139
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.cjs +3 -3
  7. package/dist/index.min.cjs.map +1 -1
  8. package/dist/index.min.js +3 -3
  9. package/dist/index.min.js.map +1 -1
  10. package/dist/pb-ui.js +188 -139
  11. package/dist/pb-ui.js.map +1 -1
  12. package/dist/pb-ui.min.js +3 -3
  13. package/dist/pb-ui.min.js.map +1 -1
  14. package/es/core/components/SxpPageRender/ExpandableText.js +3 -1
  15. package/es/core/components/SxpPageRender/Nudge/index.d.ts +2 -0
  16. package/es/core/components/SxpPageRender/Nudge/index.js +5 -2
  17. package/es/core/components/SxpPageRender/Tagbar.d.ts +1 -0
  18. package/es/core/components/SxpPageRender/Tagbar.js +2 -2
  19. package/es/core/components/SxpPageRender/VideoWidget/VideoPlayer.d.ts +1 -0
  20. package/es/core/components/SxpPageRender/VideoWidget/VideoPlayer.js +22 -0
  21. package/es/core/components/SxpPageRender/VideoWidget/index.d.ts +0 -1
  22. package/es/core/components/SxpPageRender/VideoWidget/index.js +93 -85
  23. package/es/core/components/SxpPageRender/index.js +10 -27
  24. package/es/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  25. package/es/materials/sxp/popup/CommodityDetail/index.js +4 -3
  26. package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -3
  27. package/es/materials/sxp/popup/Prompt/index.d.ts +1 -0
  28. package/es/materials/sxp/popup/Prompt/index.js +4 -2
  29. package/es/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  30. package/es/materials/sxp/popup/Prompt/settingRender.js +33 -4
  31. package/lib/core/components/SxpPageRender/ExpandableText.js +3 -1
  32. package/lib/core/components/SxpPageRender/Nudge/index.d.ts +2 -0
  33. package/lib/core/components/SxpPageRender/Nudge/index.js +5 -2
  34. package/lib/core/components/SxpPageRender/Tagbar.d.ts +1 -0
  35. package/lib/core/components/SxpPageRender/Tagbar.js +2 -2
  36. package/lib/core/components/SxpPageRender/VideoWidget/VideoPlayer.d.ts +1 -0
  37. package/lib/core/components/SxpPageRender/VideoWidget/VideoPlayer.js +26 -0
  38. package/lib/core/components/SxpPageRender/VideoWidget/index.d.ts +0 -1
  39. package/lib/core/components/SxpPageRender/VideoWidget/index.js +93 -85
  40. package/lib/core/components/SxpPageRender/index.js +10 -27
  41. package/lib/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  42. package/lib/materials/sxp/popup/CommodityDetail/index.js +4 -3
  43. package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +4 -3
  44. package/lib/materials/sxp/popup/Prompt/index.d.ts +1 -0
  45. package/lib/materials/sxp/popup/Prompt/index.js +4 -2
  46. package/lib/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  47. package/lib/materials/sxp/popup/Prompt/settingRender.js +33 -4
  48. package/package.json +1 -1
package/dist/pb-ui.js CHANGED
@@ -1106,7 +1106,7 @@
1106
1106
  * @Author: binruan@chatlabs.com
1107
1107
  * @Date: 2023-07-28 18:29:57
1108
1108
  * @LastEditors: binruan@chatlabs.com
1109
- * @LastEditTime: 2024-06-27 09:50:07
1109
+ * @LastEditTime: 2024-07-02 10:01:21
1110
1110
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1111
1111
  *
1112
1112
  */
@@ -1130,12 +1130,12 @@
1130
1130
  child: [
1131
1131
  {
1132
1132
  type: 'Select',
1133
- name: ['testStyle', 'fontFamily-cn'],
1133
+ name: ['textStyle', 'fontFamily-cn'],
1134
1134
  bottomText: '中文字体'
1135
1135
  },
1136
1136
  {
1137
1137
  type: 'Select',
1138
- name: ['testStyle', 'fontFamily-en'],
1138
+ name: ['textStyle', 'fontFamily-en'],
1139
1139
  bottomText: '英文/其他字体'
1140
1140
  }
1141
1141
  ]
@@ -1362,7 +1362,7 @@
1362
1362
  * @Author: binruan@chatlabs.com
1363
1363
  * @Date: 2024-06-27 16:22:34
1364
1364
  * @LastEditors: binruan@chatlabs.com
1365
- * @LastEditTime: 2024-06-27 18:27:11
1365
+ * @LastEditTime: 2024-07-02 10:34:34
1366
1366
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\Form.tsx
1367
1367
  *
1368
1368
  */
@@ -8601,7 +8601,7 @@
8601
8601
  * @Author: binruan@chatlabs.com
8602
8602
  * @Date: 2023-12-26 16:11:34
8603
8603
  * @LastEditors: binruan@chatlabs.com
8604
- * @LastEditTime: 2024-06-26 18:22:30
8604
+ * @LastEditTime: 2024-06-28 15:17:10
8605
8605
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ExpandableText.tsx
8606
8606
  *
8607
8607
  */
@@ -8656,7 +8656,9 @@
8656
8656
  wordBreak: 'break-word'
8657
8657
  }, dangerouslySetInnerHTML: { __html: setFontForText(text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>'), style) } }),
8658
8658
  React.createElement("div", { ref: multiRowCopy, dangerouslySetInnerHTML: { __html: setFontForText(text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>'), style) } }),
8659
- text && isPost && isShow && (React.createElement("span", { style: { textDecoration: 'underline', cursor: 'pointer' }, onClick: onClick !== null && onClick !== void 0 ? onClick : handleClick }, isShowMore ? unfoldText || 'show less' : foldText || 'show more'))));
8659
+ text && isPost && isShow && (React.createElement("span", { style: { textDecoration: 'underline', cursor: 'pointer' }, onClick: onClick !== null && onClick !== void 0 ? onClick : handleClick, dangerouslySetInnerHTML: {
8660
+ __html: setFontForText(isShowMore ? unfoldText || 'show less' : foldText || 'show more', style)
8661
+ } }))));
8660
8662
  };
8661
8663
  var ExpandableText$1 = React.memo(ExpandableText);
8662
8664
 
@@ -8786,9 +8788,10 @@
8786
8788
  };
8787
8789
  const renderBtn = () => {
8788
8790
  var _a, _b;
8789
- return (React.createElement(React.Fragment, null, (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_a = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _a !== void 0 ? _a : 'Purchase on Website', onClick: handleLink, className: 'pb-commondity-btn', style: buttonStyle, dangerouslySetInnerHTML: {
8790
- __html: setFontForText((_b = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _b !== void 0 ? _b : 'Purchase on Website', buttonStyle)
8791
- } }))));
8791
+ return (React.createElement(React.Fragment, null, (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_a = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _a !== void 0 ? _a : 'Purchase on Website', onClick: handleLink, className: 'pb-commondity-btn', style: buttonStyle },
8792
+ React.createElement("span", { dangerouslySetInnerHTML: {
8793
+ __html: setFontForText((_b = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _b !== void 0 ? _b : 'Purchase on Website', buttonStyle)
8794
+ } })))));
8792
8795
  };
8793
8796
  const getStyle = React.useCallback((style) => {
8794
8797
  if (style === null || style === void 0 ? void 0 : style.lineClamp) {
@@ -8918,7 +8921,7 @@
8918
8921
  * @Author: binruan@chatlabs.com
8919
8922
  * @Date: 2023-10-27 14:06:35
8920
8923
  * @LastEditors: binruan@chatlabs.com
8921
- * @LastEditTime: 2024-06-27 09:57:31
8924
+ * @LastEditTime: 2024-07-02 09:58:06
8922
8925
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
8923
8926
  *
8924
8927
  */
@@ -8938,9 +8941,37 @@
8938
8941
  name: ['props', 'content']
8939
8942
  },
8940
8943
  {
8941
- type: 'Text',
8942
- label: '按钮文案',
8943
- name: ['props', 'btnText']
8944
+ type: 'Group',
8945
+ label: '内容字体',
8946
+ child: [
8947
+ {
8948
+ type: 'Select',
8949
+ name: ['props', 'contentStyle', 'fontFamily-cn'],
8950
+ bottomText: '中文字体'
8951
+ },
8952
+ {
8953
+ type: 'Select',
8954
+ name: ['props', 'contentStyle', 'fontFamily-en'],
8955
+ bottomText: '英文/其他字体'
8956
+ }
8957
+ ]
8958
+ },
8959
+ {
8960
+ type: 'Group',
8961
+ label: '',
8962
+ child: [
8963
+ {
8964
+ type: 'Color',
8965
+ name: ['props', 'contentStyle', 'color'],
8966
+ initialValue: '#000'
8967
+ },
8968
+ {
8969
+ type: 'Number',
8970
+ name: ['props', 'contentStyle', 'fontSize'],
8971
+ addonAfter: 'px',
8972
+ initialValue: 14
8973
+ }
8974
+ ]
8944
8975
  },
8945
8976
  {
8946
8977
  type: 'Group',
@@ -8986,7 +9017,8 @@
8986
9017
  {
8987
9018
  label: '提交按钮颜色',
8988
9019
  type: 'Color',
8989
- name: ['props', 'submitButtonStyle', 'backgroundColor']
9020
+ name: ['props', 'submitButtonStyle', 'backgroundColor'],
9021
+ initialValue: '#000'
8990
9022
  }
8991
9023
  ]
8992
9024
  }
@@ -9027,7 +9059,7 @@
9027
9059
  };
9028
9060
 
9029
9061
  const Prompt$1 = (_a) => {
9030
- var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle"]);
9062
+ var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle, contentStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle", "contentStyle"]);
9031
9063
  const { popupDetailData } = useSxpDataSource();
9032
9064
  const { jumpToWeb } = useEventReport();
9033
9065
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
@@ -9048,7 +9080,9 @@
9048
9080
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
9049
9081
  React.createElement("div", { className: 'pb-prompt-icon' },
9050
9082
  React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3, alt: 'success image' })),
9051
- React.createElement("div", { className: 'pb-prompt-content' }, content),
9083
+ React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
9084
+ __html: setFontForText(content, contentStyle)
9085
+ } }),
9052
9086
  React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk, dangerouslySetInnerHTML: {
9053
9087
  __html: setFontForText(btnText, submitButtonStyle)
9054
9088
  } })));
@@ -9417,9 +9451,10 @@ Made in Italy` })));
9417
9451
  React.createElement("div", { className: 'pb-commondityDiroNew-content-top-right-price', hidden: !!product && !(product === null || product === void 0 ? void 0 : product.taxInfo), style: getStyle(commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.taxInfo), dangerouslySetInnerHTML: {
9418
9452
  __html: setFontForText((_m = product === null || product === void 0 ? void 0 : product.taxInfo) !== null && _m !== void 0 ? _m : '税费', commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.taxInfo)
9419
9453
  } }))),
9420
- (!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_o = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _o !== void 0 ? _o : 'Shop now', onClick: handleLink, className: 'pb-commondityDiroNew-btn', style: buttonStyle, dangerouslySetInnerHTML: {
9421
- __html: setFontForText((_p = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _p !== void 0 ? _p : 'Shop now', buttonStyle)
9422
- } })),
9454
+ (!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { "aria-label": (_o = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _o !== void 0 ? _o : 'Shop now', onClick: handleLink, className: 'pb-commondityDiroNew-btn', style: buttonStyle },
9455
+ React.createElement("span", { dangerouslySetInnerHTML: {
9456
+ __html: setFontForText((_p = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _p !== void 0 ? _p : 'Shop now', buttonStyle)
9457
+ } }))),
9423
9458
  productInfoText({ isPost }))),
9424
9459
  React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText({ isPost: false }))));
9425
9460
  };
@@ -13072,7 +13107,29 @@ Made in Italy` })));
13072
13107
 
13073
13108
  var img$1 = "";
13074
13109
 
13075
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13110
+ const mountVideoPlayerAtNode = (() => {
13111
+ if (typeof document === 'undefined')
13112
+ return;
13113
+ const playerContainer = document.createElement('div');
13114
+ const dom = ReactDOM.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13115
+ backgroundColor: 'transparent',
13116
+ width: '100%',
13117
+ height: '100%',
13118
+ objectFit: 'cover',
13119
+ pointerEvents: 'none'
13120
+ } }), playerContainer);
13121
+ // 播放器的挂载节点
13122
+ return (domNode) => {
13123
+ if (!domNode)
13124
+ return;
13125
+ domNode.innerHTML = '';
13126
+ domNode.appendChild(dom);
13127
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13128
+ return videoPlayerWrapperNode;
13129
+ };
13130
+ })();
13131
+
13132
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13076
13133
  const [isPauseVideo, setIsPauseVideo] = React.useState(false);
13077
13134
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13078
13135
  const videoStartTime = React.useRef(0);
@@ -13082,6 +13139,7 @@ Made in Italy` })));
13082
13139
  const canvasRef = React.useRef(null);
13083
13140
  const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
13084
13141
  const [waiting, setWaiting] = React.useState(false);
13142
+ const videoRef = React.useRef();
13085
13143
  const videoId = `pb-cache-video-${index}`;
13086
13144
  const videoEleRef = React.useRef(null);
13087
13145
  const blur = React.useMemo(() => {
@@ -13112,56 +13170,57 @@ Made in Italy` })));
13112
13170
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13113
13171
  }, [videoPostConfig, isBgColor]);
13114
13172
  React.useEffect(() => {
13115
- if (!videoRef)
13173
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13116
13174
  return;
13117
- videoRef.muted = muted;
13118
- }, [muted, videoRef]);
13175
+ videoRef.current.muted = muted;
13176
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13119
13177
  const handlePlay = React.useCallback(() => {
13120
- if (!videoRef)
13178
+ var _a;
13179
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13121
13180
  return;
13122
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13123
- }, [videoRef]);
13181
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13182
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13124
13183
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13125
13184
  const handlePlaying = React.useCallback(() => {
13126
- if (!videoRef)
13185
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13127
13186
  return;
13128
13187
  setWaiting(false);
13129
13188
  setIsLoadFinish(true);
13130
13189
  }, []);
13131
13190
  const handleStartPlay = React.useCallback(() => {
13132
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13133
- if (!videoRef)
13191
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13192
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13134
13193
  return;
13135
13194
  setIsPauseVideo(false);
13136
13195
  const item = data[index];
13137
- if (item && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration)) {
13138
- videoStartTime.current = (videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) || 0;
13139
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13140
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13196
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13197
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13198
+ const videoDuration = ((_d = (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.duration) !== null && _d !== void 0 ? _d : 0).toFixed(2);
13199
+ const videoCurrentTime = ((_f = (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.currentTime) !== null && _f !== void 0 ? _f : 0).toFixed(2);
13141
13200
  const playType = isFirstPlay ? '0' : '1';
13142
13201
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13143
13202
  eventInfo: {
13144
13203
  eventSubject: 'playVideo',
13145
13204
  eventDescription: 'User played the video',
13146
- contentId: (_d = (_c = item === null || item === void 0 ? void 0 : item.video) === null || _c === void 0 ? void 0 : _c.itemId) !== null && _d !== void 0 ? _d : '',
13147
- contentName: (_f = (_e = item === null || item === void 0 ? void 0 : item.video) === null || _e === void 0 ? void 0 : _e.title) !== null && _f !== void 0 ? _f : '',
13205
+ contentId: (_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.itemId) !== null && _h !== void 0 ? _h : '',
13206
+ contentName: (_k = (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.title) !== null && _k !== void 0 ? _k : '',
13148
13207
  playType,
13149
13208
  startTime: videoCurrentTime,
13150
13209
  videoDuration,
13151
- contentTags: JSON.stringify((_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.tags) !== null && _h !== void 0 ? _h : []),
13210
+ contentTags: JSON.stringify((_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.tags) !== null && _m !== void 0 ? _m : []),
13152
13211
  position: index + '',
13153
13212
  contentFormat: 'video',
13154
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13213
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13155
13214
  }
13156
13215
  });
13157
13216
  setIsFirstPlay(false);
13158
13217
  }
13159
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13218
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13160
13219
  const handLoadeddata = React.useCallback(() => {
13161
13220
  var _a;
13162
- if (!videoRef || firstFrameSrc || !blur)
13221
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13163
13222
  return;
13164
- videoRef.style.objectFit = 'contain';
13223
+ videoRef.current.style.objectFit = 'contain';
13165
13224
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13166
13225
  return;
13167
13226
  const setFrameImg = () => {
@@ -13171,158 +13230,163 @@ Made in Italy` })));
13171
13230
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13172
13231
  canvas.height = targetHeight;
13173
13232
  canvas.width = targetWidth;
13174
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13233
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13175
13234
  setFirstFrameSrc(canvas.toDataURL());
13176
13235
  };
13177
13236
  setFrameImg();
13178
13237
  setTimeout(() => {
13179
13238
  setFrameImg();
13180
13239
  }, 500);
13181
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13240
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13182
13241
  const handleLoadedmetadata = React.useCallback(() => {
13183
- if (!videoRef)
13242
+ if (!videoRef.current)
13184
13243
  return;
13185
13244
  handleStartPlay();
13186
13245
  handLoadeddata();
13187
- }, [videoRef, handLoadeddata, handleStartPlay]);
13246
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13188
13247
  const handleClickVideo = React.useCallback((type) => () => {
13189
- if (!videoRef)
13248
+ var _a, _b, _c, _d, _e;
13249
+ if (!videoRef.current)
13190
13250
  return;
13191
13251
  if (!isLoadFinish)
13192
13252
  return;
13193
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13253
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13194
13254
  switch (type) {
13195
13255
  case 'start':
13196
13256
  if (!isPause)
13197
13257
  return;
13198
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13258
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13199
13259
  setIsPauseVideo(false);
13200
13260
  break;
13201
13261
  case 'pause':
13202
13262
  if (isPause)
13203
13263
  return;
13204
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13264
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13205
13265
  setIsPauseVideo(true);
13206
13266
  break;
13207
13267
  default:
13208
13268
  if (isPause) {
13209
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13269
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13210
13270
  }
13211
13271
  else {
13212
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13272
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13213
13273
  }
13214
13274
  setIsPauseVideo(!isPause);
13215
13275
  break;
13216
13276
  }
13217
- }, [isLoadFinish, videoRef]);
13277
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13218
13278
  const handlePause = React.useCallback(() => {
13219
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13220
- if (!videoRef)
13279
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13280
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13221
13281
  return;
13222
13282
  if (activeIndex !== index)
13223
13283
  return;
13224
13284
  const item = data[index];
13225
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13226
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13227
- if (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) {
13228
- const playDuration = ((videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) - videoStartTime.current).toFixed(2);
13285
+ const videoDuration = ((_b = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13286
+ const videoCurrentTime = ((_d = (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.currentTime) !== null && _d !== void 0 ? _d : 0).toFixed(2);
13287
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13288
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13229
13289
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13230
13290
  eventInfo: {
13231
13291
  eventSubject: 'playOverVideo',
13232
13292
  eventDescription: 'User finished playing the video',
13233
- contentId: (_d = (_c = item === null || item === void 0 ? void 0 : item.video) === null || _c === void 0 ? void 0 : _c.itemId) !== null && _d !== void 0 ? _d : '',
13234
- contentName: (_f = (_e = item === null || item === void 0 ? void 0 : item.video) === null || _e === void 0 ? void 0 : _e.title) !== null && _f !== void 0 ? _f : '',
13293
+ contentId: (_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.itemId) !== null && _h !== void 0 ? _h : '',
13294
+ contentName: (_k = (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.title) !== null && _k !== void 0 ? _k : '',
13235
13295
  endTime: videoCurrentTime,
13236
13296
  videoDuration,
13237
13297
  playDuration,
13238
- contentTags: JSON.stringify((_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.tags) !== null && _h !== void 0 ? _h : []),
13298
+ contentTags: JSON.stringify((_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.tags) !== null && _m !== void 0 ? _m : []),
13239
13299
  position: index + '',
13240
13300
  contentFormat: 'video',
13241
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13301
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13242
13302
  }
13243
13303
  });
13244
13304
  }
13245
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13305
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13246
13306
  const handleWaiting = React.useCallback(() => {
13247
13307
  setWaiting(true);
13248
13308
  }, []);
13249
13309
  React.useEffect(() => {
13250
- if (!isActive || !videoRef)
13310
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13311
+ if (!isActive)
13251
13312
  return;
13252
13313
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13253
13314
  if (!videoSrc)
13254
13315
  return;
13316
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13317
+ if (!videoPlayerWrapperNode)
13318
+ return;
13319
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13320
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13321
+ return;
13255
13322
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13256
13323
  let hls = null;
13257
13324
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13258
13325
  hls = new Hls();
13259
13326
  hls.loadSource(videoSrc);
13260
- hls.attachMedia(videoRef);
13327
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13261
13328
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13262
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13329
+ var _a;
13330
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13263
13331
  });
13264
13332
  }
13265
13333
  else {
13266
- videoRef.src = videoSrc;
13267
- }
13268
- const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13269
- const dom = document.querySelector('#player-container-id');
13270
- const dom2 = document.querySelector('#player-container-id-copy');
13271
- if (!dom && !dom2)
13272
- return;
13273
- videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
13274
- videoRef.setAttribute('x5-playsinline', 'true');
13275
- videoRef.setAttribute('webkit-playsinline', 'true');
13276
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadedmetadata', handleLoadedmetadata);
13277
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadeddata', handLoadeddata);
13278
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('play', handleStartPlay);
13279
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('playing', handlePlaying);
13280
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('pause', handlePause);
13281
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('ended', handlePlay);
13282
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('canplay', handlePlay);
13283
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('waiting', handleWaiting);
13334
+ videoRef.current.src = videoSrc;
13335
+ }
13336
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13337
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13338
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13339
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13340
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13341
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13342
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13343
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13344
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13345
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13284
13346
  return () => {
13347
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13285
13348
  if (hls)
13286
13349
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13287
13350
  setIsLoadFinish(false);
13288
- dom2 === null || dom2 === void 0 ? void 0 : dom2.appendChild(dom);
13289
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadedmetadata', handleLoadedmetadata);
13290
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadeddata', handLoadeddata);
13291
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('play', handleStartPlay);
13292
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('playing', handlePlaying);
13293
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('pause', handlePause);
13294
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('ended', handlePlay);
13295
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('canplay', handlePlay);
13296
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('waiting', handleWaiting);
13351
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13352
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13353
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13354
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13355
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13356
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13357
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13358
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13297
13359
  };
13298
- }, [isActive, videoId, rec, videoRef]);
13360
+ }, [isActive, videoId, rec]);
13299
13361
  React.useEffect(() => {
13300
- if (!videoRef || !isLoadFinish)
13362
+ var _a, _b;
13363
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13301
13364
  return;
13302
13365
  if (isActive) {
13303
13366
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13304
13367
  eventName: 'ViewContent'
13305
13368
  });
13306
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13369
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13307
13370
  }
13308
13371
  else {
13309
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13372
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13310
13373
  }
13311
- }, [isActive, isLoadFinish, videoRef]);
13374
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13312
13375
  /*
13313
13376
  打开/关闭hashtag暂停/播放视频
13314
13377
  */
13315
13378
  React.useEffect(() => {
13316
- if (!isActive || !videoRef)
13379
+ var _a, _b, _c;
13380
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13317
13381
  return;
13318
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13382
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13319
13383
  if (!isPause && openHashtag) {
13320
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13384
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13321
13385
  }
13322
13386
  else if (!openHashtag) {
13323
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13387
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13324
13388
  }
13325
- }, [openHashtag, isActive, videoRef]);
13389
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13326
13390
  React.useEffect(() => {
13327
13391
  if (!isActive)
13328
13392
  return;
@@ -13369,11 +13433,11 @@ Made in Italy` })));
13369
13433
  }, src: img$1, alt: 'placeholder image' }));
13370
13434
  }, [waiting, isLoadFinish]);
13371
13435
  React.useEffect(() => {
13372
- if (!videoRef)
13436
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13373
13437
  return;
13374
13438
  const handleBeforeUnload = () => {
13375
13439
  var _a;
13376
- if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && videoRef && !isPauseVideo) {
13440
+ if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && !isPauseVideo) {
13377
13441
  handleClickVideo('pause')();
13378
13442
  }
13379
13443
  };
@@ -13381,7 +13445,7 @@ Made in Italy` })));
13381
13445
  return () => {
13382
13446
  window.removeEventListener('beforeunload', handleBeforeUnload);
13383
13447
  };
13384
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13448
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13385
13449
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13386
13450
  return null;
13387
13451
  }
@@ -13706,12 +13770,12 @@ Made in Italy` })));
13706
13770
  * @Author: binruan@chatlabs.com
13707
13771
  * @Date: 2024-03-26 10:07:41
13708
13772
  * @LastEditors: binruan@chatlabs.com
13709
- * @LastEditTime: 2024-05-23 14:31:12
13773
+ * @LastEditTime: 2024-07-01 17:47:33
13710
13774
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13711
13775
  *
13712
13776
  */
13713
13777
  const Nudge = ({ nudge }) => {
13714
- var _a, _b, _c, _d, _e, _f, _g;
13778
+ var _a, _b, _c, _d, _e, _f;
13715
13779
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13716
13780
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13717
13781
  width: (_c = (_b = nudge === null || nudge === void 0 ? void 0 : nudge.size) === null || _b === void 0 ? void 0 : _b.width) !== null && _c !== void 0 ? _c : 212,
@@ -13720,18 +13784,20 @@ Made in Italy` })));
13720
13784
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13721
13785
  } },
13722
13786
  (nudge === null || nudge === void 0 ? void 0 : nudge.icon) ? (React.createElement("img", { src: nudge.icon, alt: 'nudge icon', style: { height: '100%', objectFit: 'cover', flexShrink: 0 } })) : null,
13723
- 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 : '')))));
13787
+ 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 }), dangerouslySetInnerHTML: {
13788
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13789
+ } })))));
13724
13790
  };
13725
13791
 
13726
13792
  /*
13727
13793
  * @Author: binruan@chatlabs.com
13728
13794
  * @Date: 2024-04-29 16:32:21
13729
13795
  * @LastEditors: binruan@chatlabs.com
13730
- * @LastEditTime: 2024-06-20 10:53:08
13796
+ * @LastEditTime: 2024-06-28 18:03:50
13731
13797
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Tagbar.tsx
13732
13798
  *
13733
13799
  */
13734
- const Tagbar = ({ tagList = [], setActiveIndex }) => {
13800
+ const Tagbar = ({ tagList = [], setActiveIndex, style }) => {
13735
13801
  const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport, selectTag, setSelectTag } = useSxpDataSource();
13736
13802
  const { backMainFeed } = useEventReport();
13737
13803
  const realTagList = React.useMemo(() => {
@@ -13772,7 +13838,7 @@ Made in Italy` })));
13772
13838
  };
13773
13839
  if (waterFallData || tagList.length <= 0)
13774
13840
  return null;
13775
- return (React.createElement("div", { className: 'clc-sxp-tagbar' },
13841
+ return (React.createElement("div", { className: 'clc-sxp-tagbar', style: style },
13776
13842
  React.createElement("ul", { className: 'clc-sxp-tagbar-list', style: { margin: 'auto', gap: 24 } }, realTagList.map((tag) => {
13777
13843
  return (React.createElement("li", { className: `clc-sxp-tagbar-list-item ${tag === selectTag ? 'clc-sxp-tagbar-list-item-active' : ''}`, key: tag, onClick: handleSelectTag(tag) }, tag));
13778
13844
  }))));
@@ -13783,7 +13849,7 @@ Made in Italy` })));
13783
13849
  * @Author: binruan@chatlabs.com
13784
13850
  * @Date: 2024-01-15 19:03:09
13785
13851
  * @LastEditors: binruan@chatlabs.com
13786
- * @LastEditTime: 2024-06-27 15:47:52
13852
+ * @LastEditTime: 2024-07-01 11:49:58
13787
13853
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13788
13854
  *
13789
13855
  */
@@ -13792,14 +13858,12 @@ Made in Italy` })));
13792
13858
  const { schema } = useEditor();
13793
13859
  const [activeIndex, setActiveIndex] = React.useState(0);
13794
13860
  const viewImageStartTime = React.useRef(0);
13795
- React.useState(false);
13796
13861
  const [isMuted, setIsMuted] = React.useState(true);
13797
13862
  const viewTime = React.useRef();
13798
13863
  const [isLoadMore, setIsLoadMore] = React.useState(false);
13799
13864
  const [isShowMore, setIsShowMore] = React.useState(false);
13800
13865
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13801
13866
  const { backMainFeed } = useEventReport();
13802
- const videoRef = React.useRef();
13803
13867
  const { productView } = useEventReport();
13804
13868
  const isShowFingerTip = React.useMemo(() => {
13805
13869
  return data.length > 0 && !loading && getFeUserId();
@@ -13827,16 +13891,6 @@ Made in Italy` })));
13827
13891
  });
13828
13892
  }
13829
13893
  }, [data.length, bffFbReport, h5EnterLink]);
13830
- const firstRef = React.useRef();
13831
- React.useEffect(() => {
13832
- var _a, _b, _c, _d;
13833
- if (!firstRef.current && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && (data === null || data === void 0 ? void 0 : data.length) > 0) {
13834
- firstRef.current = true;
13835
- if ((_b = (_a = data === null || data === void 0 ? void 0 : data[0]) === null || _a === void 0 ? void 0 : _a.video) === null || _b === void 0 ? void 0 : _b.url) {
13836
- videoRef.current.src = (_d = (_c = data === null || data === void 0 ? void 0 : data[0]) === null || _c === void 0 ? void 0 : _c.video) === null || _d === void 0 ? void 0 : _d.url;
13837
- }
13838
- }
13839
- }, [videoRef, data]);
13840
13894
  React.useEffect(() => {
13841
13895
  var _a;
13842
13896
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13937,11 +13991,14 @@ Made in Italy` })));
13937
13991
  }
13938
13992
  return h;
13939
13993
  }, [tagList, waterFallData]);
13940
- const height = React.useMemo(() => {
13994
+ const minusHeight = React.useMemo(() => {
13941
13995
  let minusHeight = 0;
13942
13996
  if ((globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.logoUrl) && (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.isShowLogo)) {
13943
13997
  minusHeight += 45;
13944
13998
  }
13999
+ return minusHeight;
14000
+ }, []);
14001
+ const height = React.useMemo(() => {
13945
14002
  return containerHeight - minusHeight - tagHeight;
13946
14003
  }, [globalConfig, containerHeight, tagHeight]);
13947
14004
  const renderLogo = React.useMemo(() => {
@@ -13954,7 +14011,7 @@ Made in Italy` })));
13954
14011
  const renderContent = React.useCallback((rec, index) => {
13955
14012
  var _a, _b, _c, _d;
13956
14013
  if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) {
13957
- return (React.createElement(VideoWidget$3, { rec: rec, index: index, muted: isMuted, data: data, height: height, activeIndex: activeIndex, videoPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPost, videoRef: videoRef.current, videoPlayIcon: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPlayIcon }));
14014
+ return (React.createElement(VideoWidget$3, { rec: rec, index: index, muted: isMuted, data: data, height: height, activeIndex: activeIndex, videoPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPost, videoPlayIcon: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPlayIcon }));
13958
14015
  }
13959
14016
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13960
14017
  return (React.createElement(PictureGroup$3, { key: rec === null || rec === void 0 ? void 0 : rec.video.itemId, imgUrls: rec === null || rec === void 0 ? void 0 : rec.video.imgUrls, width: containerWidth, height: height, rec: rec, index: index, onReportViewImageEnd: handleReportViewImageEnd, onViewImageStartEvent: handleViewImageStartEvent, imgUrlsPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.imgUrlsPost }));
@@ -13980,8 +14037,7 @@ Made in Italy` })));
13980
14037
  viewTime,
13981
14038
  tipText,
13982
14039
  resolver,
13983
- schema,
13984
- videoRef.current
14040
+ schema
13985
14041
  ]);
13986
14042
  const onExpandableChange = React.useCallback((v) => {
13987
14043
  setIsShowMore(v);
@@ -14178,7 +14234,9 @@ Made in Italy` })));
14178
14234
  setOpenHashtag === null || setOpenHashtag === void 0 ? void 0 : setOpenHashtag(true);
14179
14235
  } })),
14180
14236
  renderLogo,
14181
- React.createElement(Tagbar$1, { tagList: tagList, setActiveIndex: setActiveIndex }),
14237
+ React.createElement(Tagbar$1, { tagList: tagList, setActiveIndex: setActiveIndex, style: {
14238
+ top: minusHeight
14239
+ } }),
14182
14240
  isShowFingerTip ? (React.createElement(FingerSwipeTip, { imageUrl: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipIcon, style: { top: `${50 + ((_a = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.swipeTipOffset) !== null && _a !== void 0 ? _a : 0)}%` } })) : null,
14183
14241
  React.createElement(Swiper, { style: {
14184
14242
  marginTop: tagHeight
@@ -14212,16 +14270,7 @@ Made in Italy` })));
14212
14270
  [(_f = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconYPosit) !== null && _f !== void 0 ? _f : 'bottom']: (_g = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconY) !== null && _g !== void 0 ? _g : 23
14213
14271
  }, defaultValue: isMuted, activeIcon: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.unMuteIcon) ? globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.unMuteIcon : mutedIcon, unactiveIcon: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIcon) ? globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIcon : unmutedIcon, onChange: setIsMuted }),
14214
14272
  renderView),
14215
- React.createElement(WaterFall$1, Object.assign({}, (_k = (_j = (_h = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _h === void 0 ? void 0 : _h[0]) === null || _j === void 0 ? void 0 : _j.item) === null || _k === void 0 ? void 0 : _k.props)),
14216
- React.createElement("div", { style: { position: 'absolute', zIndex: -100 } },
14217
- React.createElement("video", { ref: videoRef, id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
14218
- backgroundColor: 'transparent',
14219
- width: '100%',
14220
- height: '100%',
14221
- objectFit: 'cover',
14222
- pointerEvents: 'none'
14223
- } }),
14224
- React.createElement("div", { id: 'player-container-id-copy' }))));
14273
+ React.createElement(WaterFall$1, Object.assign({}, (_k = (_j = (_h = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _h === void 0 ? void 0 : _h[0]) === null || _j === void 0 ? void 0 : _j.item) === null || _k === void 0 ? void 0 : _k.props))));
14225
14274
  };
14226
14275
 
14227
14276
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {