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/index.cjs CHANGED
@@ -1113,7 +1113,7 @@ var interactionRender$8 = [
1113
1113
  * @Author: binruan@chatlabs.com
1114
1114
  * @Date: 2023-07-28 18:29:57
1115
1115
  * @LastEditors: binruan@chatlabs.com
1116
- * @LastEditTime: 2024-06-27 09:50:07
1116
+ * @LastEditTime: 2024-07-02 10:01:21
1117
1117
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1118
1118
  *
1119
1119
  */
@@ -1137,12 +1137,12 @@ var settingRender$6 = [
1137
1137
  child: [
1138
1138
  {
1139
1139
  type: 'Select',
1140
- name: ['testStyle', 'fontFamily-cn'],
1140
+ name: ['textStyle', 'fontFamily-cn'],
1141
1141
  bottomText: '中文字体'
1142
1142
  },
1143
1143
  {
1144
1144
  type: 'Select',
1145
- name: ['testStyle', 'fontFamily-en'],
1145
+ name: ['textStyle', 'fontFamily-en'],
1146
1146
  bottomText: '英文/其他字体'
1147
1147
  }
1148
1148
  ]
@@ -1369,7 +1369,7 @@ function useEventReport() {
1369
1369
  * @Author: binruan@chatlabs.com
1370
1370
  * @Date: 2024-06-27 16:22:34
1371
1371
  * @LastEditors: binruan@chatlabs.com
1372
- * @LastEditTime: 2024-06-27 18:27:11
1372
+ * @LastEditTime: 2024-07-02 10:34:34
1373
1373
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\Form.tsx
1374
1374
  *
1375
1375
  */
@@ -8608,7 +8608,7 @@ var Modal$1 = React.memo(Modal);
8608
8608
  * @Author: binruan@chatlabs.com
8609
8609
  * @Date: 2023-12-26 16:11:34
8610
8610
  * @LastEditors: binruan@chatlabs.com
8611
- * @LastEditTime: 2024-06-26 18:22:30
8611
+ * @LastEditTime: 2024-06-28 15:17:10
8612
8612
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ExpandableText.tsx
8613
8613
  *
8614
8614
  */
@@ -8663,7 +8663,9 @@ const ExpandableText = ({ text, maxStr = 108, style, className, onClick, foldTex
8663
8663
  wordBreak: 'break-word'
8664
8664
  }, dangerouslySetInnerHTML: { __html: setFontForText(text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>'), style) } }),
8665
8665
  React.createElement("div", { ref: multiRowCopy, dangerouslySetInnerHTML: { __html: setFontForText(text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>'), style) } }),
8666
- 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'))));
8666
+ text && isPost && isShow && (React.createElement("span", { style: { textDecoration: 'underline', cursor: 'pointer' }, onClick: onClick !== null && onClick !== void 0 ? onClick : handleClick, dangerouslySetInnerHTML: {
8667
+ __html: setFontForText(isShowMore ? unfoldText || 'show less' : foldText || 'show more', style)
8668
+ } }))));
8667
8669
  };
8668
8670
  var ExpandableText$1 = React.memo(ExpandableText);
8669
8671
 
@@ -8793,9 +8795,10 @@ const CommodityDetail$1 = (_a) => {
8793
8795
  };
8794
8796
  const renderBtn = () => {
8795
8797
  var _a, _b;
8796
- 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: {
8797
- __html: setFontForText((_b = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _b !== void 0 ? _b : 'Purchase on Website', buttonStyle)
8798
- } }))));
8798
+ 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 },
8799
+ React.createElement("span", { dangerouslySetInnerHTML: {
8800
+ __html: setFontForText((_b = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _b !== void 0 ? _b : 'Purchase on Website', buttonStyle)
8801
+ } })))));
8799
8802
  };
8800
8803
  const getStyle = React.useCallback((style) => {
8801
8804
  if (style === null || style === void 0 ? void 0 : style.lineClamp) {
@@ -8925,7 +8928,7 @@ var interactionRender$7 = [
8925
8928
  * @Author: binruan@chatlabs.com
8926
8929
  * @Date: 2023-10-27 14:06:35
8927
8930
  * @LastEditors: binruan@chatlabs.com
8928
- * @LastEditTime: 2024-06-27 09:57:31
8931
+ * @LastEditTime: 2024-07-02 09:58:06
8929
8932
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
8930
8933
  *
8931
8934
  */
@@ -8945,9 +8948,37 @@ var settingRender$4 = [
8945
8948
  name: ['props', 'content']
8946
8949
  },
8947
8950
  {
8948
- type: 'Text',
8949
- label: '按钮文案',
8950
- name: ['props', 'btnText']
8951
+ type: 'Group',
8952
+ label: '内容字体',
8953
+ child: [
8954
+ {
8955
+ type: 'Select',
8956
+ name: ['props', 'contentStyle', 'fontFamily-cn'],
8957
+ bottomText: '中文字体'
8958
+ },
8959
+ {
8960
+ type: 'Select',
8961
+ name: ['props', 'contentStyle', 'fontFamily-en'],
8962
+ bottomText: '英文/其他字体'
8963
+ }
8964
+ ]
8965
+ },
8966
+ {
8967
+ type: 'Group',
8968
+ label: '',
8969
+ child: [
8970
+ {
8971
+ type: 'Color',
8972
+ name: ['props', 'contentStyle', 'color'],
8973
+ initialValue: '#000'
8974
+ },
8975
+ {
8976
+ type: 'Number',
8977
+ name: ['props', 'contentStyle', 'fontSize'],
8978
+ addonAfter: 'px',
8979
+ initialValue: 14
8980
+ }
8981
+ ]
8951
8982
  },
8952
8983
  {
8953
8984
  type: 'Group',
@@ -8993,7 +9024,8 @@ var settingRender$4 = [
8993
9024
  {
8994
9025
  label: '提交按钮颜色',
8995
9026
  type: 'Color',
8996
- name: ['props', 'submitButtonStyle', 'backgroundColor']
9027
+ name: ['props', 'submitButtonStyle', 'backgroundColor'],
9028
+ initialValue: '#000'
8997
9029
  }
8998
9030
  ]
8999
9031
  }
@@ -9034,7 +9066,7 @@ const getMediaValueByMode = (obj) => {
9034
9066
  };
9035
9067
 
9036
9068
  const Prompt$1 = (_a) => {
9037
- var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle"]);
9069
+ 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"]);
9038
9070
  const { popupDetailData } = useSxpDataSource();
9039
9071
  const { jumpToWeb } = useEventReport();
9040
9072
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
@@ -9055,7 +9087,9 @@ const Prompt$1 = (_a) => {
9055
9087
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
9056
9088
  React.createElement("div", { className: 'pb-prompt-icon' },
9057
9089
  React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3, alt: 'success image' })),
9058
- React.createElement("div", { className: 'pb-prompt-content' }, content),
9090
+ React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
9091
+ __html: setFontForText(content, contentStyle)
9092
+ } }),
9059
9093
  React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk, dangerouslySetInnerHTML: {
9060
9094
  __html: setFontForText(btnText, submitButtonStyle)
9061
9095
  } })));
@@ -9424,9 +9458,10 @@ Made in Italy` })));
9424
9458
  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: {
9425
9459
  __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)
9426
9460
  } }))),
9427
- (!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: {
9428
- __html: setFontForText((_p = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _p !== void 0 ? _p : 'Shop now', buttonStyle)
9429
- } })),
9461
+ (!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 },
9462
+ React.createElement("span", { dangerouslySetInnerHTML: {
9463
+ __html: setFontForText((_p = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _p !== void 0 ? _p : 'Shop now', buttonStyle)
9464
+ } }))),
9430
9465
  productInfoText({ isPost }))),
9431
9466
  React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText({ isPost: false }))));
9432
9467
  };
@@ -13079,7 +13114,29 @@ var LikeButton$1 = React.memo(LikeButton);
13079
13114
 
13080
13115
  var img$1 = "";
13081
13116
 
13082
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13117
+ const mountVideoPlayerAtNode = (() => {
13118
+ if (typeof document === 'undefined')
13119
+ return;
13120
+ const playerContainer = document.createElement('div');
13121
+ const dom = ReactDOM.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13122
+ backgroundColor: 'transparent',
13123
+ width: '100%',
13124
+ height: '100%',
13125
+ objectFit: 'cover',
13126
+ pointerEvents: 'none'
13127
+ } }), playerContainer);
13128
+ // 播放器的挂载节点
13129
+ return (domNode) => {
13130
+ if (!domNode)
13131
+ return;
13132
+ domNode.innerHTML = '';
13133
+ domNode.appendChild(dom);
13134
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13135
+ return videoPlayerWrapperNode;
13136
+ };
13137
+ })();
13138
+
13139
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13083
13140
  const [isPauseVideo, setIsPauseVideo] = React.useState(false);
13084
13141
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13085
13142
  const videoStartTime = React.useRef(0);
@@ -13089,6 +13146,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13089
13146
  const canvasRef = React.useRef(null);
13090
13147
  const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
13091
13148
  const [waiting, setWaiting] = React.useState(false);
13149
+ const videoRef = React.useRef();
13092
13150
  const videoId = `pb-cache-video-${index}`;
13093
13151
  const videoEleRef = React.useRef(null);
13094
13152
  const blur = React.useMemo(() => {
@@ -13119,56 +13177,57 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13119
13177
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13120
13178
  }, [videoPostConfig, isBgColor]);
13121
13179
  React.useEffect(() => {
13122
- if (!videoRef)
13180
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13123
13181
  return;
13124
- videoRef.muted = muted;
13125
- }, [muted, videoRef]);
13182
+ videoRef.current.muted = muted;
13183
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13126
13184
  const handlePlay = React.useCallback(() => {
13127
- if (!videoRef)
13185
+ var _a;
13186
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13128
13187
  return;
13129
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13130
- }, [videoRef]);
13188
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13189
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13131
13190
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13132
13191
  const handlePlaying = React.useCallback(() => {
13133
- if (!videoRef)
13192
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13134
13193
  return;
13135
13194
  setWaiting(false);
13136
13195
  setIsLoadFinish(true);
13137
13196
  }, []);
13138
13197
  const handleStartPlay = React.useCallback(() => {
13139
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13140
- if (!videoRef)
13198
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13199
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13141
13200
  return;
13142
13201
  setIsPauseVideo(false);
13143
13202
  const item = data[index];
13144
- if (item && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration)) {
13145
- videoStartTime.current = (videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) || 0;
13146
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13147
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13203
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13204
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13205
+ 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);
13206
+ 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);
13148
13207
  const playType = isFirstPlay ? '0' : '1';
13149
13208
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13150
13209
  eventInfo: {
13151
13210
  eventSubject: 'playVideo',
13152
13211
  eventDescription: 'User played the video',
13153
- 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 : '',
13154
- 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 : '',
13212
+ 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 : '',
13213
+ 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 : '',
13155
13214
  playType,
13156
13215
  startTime: videoCurrentTime,
13157
13216
  videoDuration,
13158
- 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 : []),
13217
+ 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 : []),
13159
13218
  position: index + '',
13160
13219
  contentFormat: 'video',
13161
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13220
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13162
13221
  }
13163
13222
  });
13164
13223
  setIsFirstPlay(false);
13165
13224
  }
13166
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13225
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13167
13226
  const handLoadeddata = React.useCallback(() => {
13168
13227
  var _a;
13169
- if (!videoRef || firstFrameSrc || !blur)
13228
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13170
13229
  return;
13171
- videoRef.style.objectFit = 'contain';
13230
+ videoRef.current.style.objectFit = 'contain';
13172
13231
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13173
13232
  return;
13174
13233
  const setFrameImg = () => {
@@ -13178,158 +13237,163 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13178
13237
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13179
13238
  canvas.height = targetHeight;
13180
13239
  canvas.width = targetWidth;
13181
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13240
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13182
13241
  setFirstFrameSrc(canvas.toDataURL());
13183
13242
  };
13184
13243
  setFrameImg();
13185
13244
  setTimeout(() => {
13186
13245
  setFrameImg();
13187
13246
  }, 500);
13188
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13247
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13189
13248
  const handleLoadedmetadata = React.useCallback(() => {
13190
- if (!videoRef)
13249
+ if (!videoRef.current)
13191
13250
  return;
13192
13251
  handleStartPlay();
13193
13252
  handLoadeddata();
13194
- }, [videoRef, handLoadeddata, handleStartPlay]);
13253
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13195
13254
  const handleClickVideo = React.useCallback((type) => () => {
13196
- if (!videoRef)
13255
+ var _a, _b, _c, _d, _e;
13256
+ if (!videoRef.current)
13197
13257
  return;
13198
13258
  if (!isLoadFinish)
13199
13259
  return;
13200
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13260
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13201
13261
  switch (type) {
13202
13262
  case 'start':
13203
13263
  if (!isPause)
13204
13264
  return;
13205
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13265
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13206
13266
  setIsPauseVideo(false);
13207
13267
  break;
13208
13268
  case 'pause':
13209
13269
  if (isPause)
13210
13270
  return;
13211
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13271
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13212
13272
  setIsPauseVideo(true);
13213
13273
  break;
13214
13274
  default:
13215
13275
  if (isPause) {
13216
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13276
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13217
13277
  }
13218
13278
  else {
13219
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13279
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13220
13280
  }
13221
13281
  setIsPauseVideo(!isPause);
13222
13282
  break;
13223
13283
  }
13224
- }, [isLoadFinish, videoRef]);
13284
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13225
13285
  const handlePause = React.useCallback(() => {
13226
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13227
- if (!videoRef)
13286
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13287
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13228
13288
  return;
13229
13289
  if (activeIndex !== index)
13230
13290
  return;
13231
13291
  const item = data[index];
13232
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13233
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13234
- if (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) {
13235
- const playDuration = ((videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) - videoStartTime.current).toFixed(2);
13292
+ 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);
13293
+ 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);
13294
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13295
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13236
13296
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13237
13297
  eventInfo: {
13238
13298
  eventSubject: 'playOverVideo',
13239
13299
  eventDescription: 'User finished playing the video',
13240
- 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 : '',
13241
- 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 : '',
13300
+ 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 : '',
13301
+ 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 : '',
13242
13302
  endTime: videoCurrentTime,
13243
13303
  videoDuration,
13244
13304
  playDuration,
13245
- 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 : []),
13305
+ 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 : []),
13246
13306
  position: index + '',
13247
13307
  contentFormat: 'video',
13248
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13308
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13249
13309
  }
13250
13310
  });
13251
13311
  }
13252
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13312
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13253
13313
  const handleWaiting = React.useCallback(() => {
13254
13314
  setWaiting(true);
13255
13315
  }, []);
13256
13316
  React.useEffect(() => {
13257
- if (!isActive || !videoRef)
13317
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13318
+ if (!isActive)
13258
13319
  return;
13259
13320
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13260
13321
  if (!videoSrc)
13261
13322
  return;
13323
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13324
+ if (!videoPlayerWrapperNode)
13325
+ return;
13326
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13327
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13328
+ return;
13262
13329
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13263
13330
  let hls = null;
13264
13331
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13265
13332
  hls = new Hls();
13266
13333
  hls.loadSource(videoSrc);
13267
- hls.attachMedia(videoRef);
13334
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13268
13335
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13269
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13336
+ var _a;
13337
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13270
13338
  });
13271
13339
  }
13272
13340
  else {
13273
- videoRef.src = videoSrc;
13274
- }
13275
- const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13276
- const dom = document.querySelector('#player-container-id');
13277
- const dom2 = document.querySelector('#player-container-id-copy');
13278
- if (!dom && !dom2)
13279
- return;
13280
- videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
13281
- videoRef.setAttribute('x5-playsinline', 'true');
13282
- videoRef.setAttribute('webkit-playsinline', 'true');
13283
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadedmetadata', handleLoadedmetadata);
13284
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadeddata', handLoadeddata);
13285
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('play', handleStartPlay);
13286
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('playing', handlePlaying);
13287
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('pause', handlePause);
13288
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('ended', handlePlay);
13289
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('canplay', handlePlay);
13290
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('waiting', handleWaiting);
13341
+ videoRef.current.src = videoSrc;
13342
+ }
13343
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13344
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13345
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13346
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13347
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13348
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13349
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13350
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13351
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13352
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13291
13353
  return () => {
13354
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13292
13355
  if (hls)
13293
13356
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13294
13357
  setIsLoadFinish(false);
13295
- dom2 === null || dom2 === void 0 ? void 0 : dom2.appendChild(dom);
13296
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadedmetadata', handleLoadedmetadata);
13297
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadeddata', handLoadeddata);
13298
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('play', handleStartPlay);
13299
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('playing', handlePlaying);
13300
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('pause', handlePause);
13301
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('ended', handlePlay);
13302
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('canplay', handlePlay);
13303
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('waiting', handleWaiting);
13358
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13359
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13360
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13361
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13362
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13363
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13364
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13365
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13304
13366
  };
13305
- }, [isActive, videoId, rec, videoRef]);
13367
+ }, [isActive, videoId, rec]);
13306
13368
  React.useEffect(() => {
13307
- if (!videoRef || !isLoadFinish)
13369
+ var _a, _b;
13370
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13308
13371
  return;
13309
13372
  if (isActive) {
13310
13373
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13311
13374
  eventName: 'ViewContent'
13312
13375
  });
13313
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13376
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13314
13377
  }
13315
13378
  else {
13316
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13379
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13317
13380
  }
13318
- }, [isActive, isLoadFinish, videoRef]);
13381
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13319
13382
  /*
13320
13383
  打开/关闭hashtag暂停/播放视频
13321
13384
  */
13322
13385
  React.useEffect(() => {
13323
- if (!isActive || !videoRef)
13386
+ var _a, _b, _c;
13387
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13324
13388
  return;
13325
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13389
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13326
13390
  if (!isPause && openHashtag) {
13327
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13391
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13328
13392
  }
13329
13393
  else if (!openHashtag) {
13330
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13394
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13331
13395
  }
13332
- }, [openHashtag, isActive, videoRef]);
13396
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13333
13397
  React.useEffect(() => {
13334
13398
  if (!isActive)
13335
13399
  return;
@@ -13376,11 +13440,11 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13376
13440
  }, src: img$1, alt: 'placeholder image' }));
13377
13441
  }, [waiting, isLoadFinish]);
13378
13442
  React.useEffect(() => {
13379
- if (!videoRef)
13443
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13380
13444
  return;
13381
13445
  const handleBeforeUnload = () => {
13382
13446
  var _a;
13383
- if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && videoRef && !isPauseVideo) {
13447
+ 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) {
13384
13448
  handleClickVideo('pause')();
13385
13449
  }
13386
13450
  };
@@ -13388,7 +13452,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13388
13452
  return () => {
13389
13453
  window.removeEventListener('beforeunload', handleBeforeUnload);
13390
13454
  };
13391
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13455
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13392
13456
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13393
13457
  return null;
13394
13458
  }
@@ -13713,12 +13777,12 @@ var RenderCard$1 = React.memo(RenderCard);
13713
13777
  * @Author: binruan@chatlabs.com
13714
13778
  * @Date: 2024-03-26 10:07:41
13715
13779
  * @LastEditors: binruan@chatlabs.com
13716
- * @LastEditTime: 2024-05-23 14:31:12
13780
+ * @LastEditTime: 2024-07-01 17:47:33
13717
13781
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13718
13782
  *
13719
13783
  */
13720
13784
  const Nudge = ({ nudge }) => {
13721
- var _a, _b, _c, _d, _e, _f, _g;
13785
+ var _a, _b, _c, _d, _e, _f;
13722
13786
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13723
13787
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13724
13788
  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,
@@ -13727,18 +13791,20 @@ const Nudge = ({ nudge }) => {
13727
13791
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13728
13792
  } },
13729
13793
  (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,
13730
- 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 : '')))));
13794
+ 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: {
13795
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13796
+ } })))));
13731
13797
  };
13732
13798
 
13733
13799
  /*
13734
13800
  * @Author: binruan@chatlabs.com
13735
13801
  * @Date: 2024-04-29 16:32:21
13736
13802
  * @LastEditors: binruan@chatlabs.com
13737
- * @LastEditTime: 2024-06-20 10:53:08
13803
+ * @LastEditTime: 2024-06-28 18:03:50
13738
13804
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Tagbar.tsx
13739
13805
  *
13740
13806
  */
13741
- const Tagbar = ({ tagList = [], setActiveIndex }) => {
13807
+ const Tagbar = ({ tagList = [], setActiveIndex, style }) => {
13742
13808
  const { getRecommendVideos, setRtcList, setCacheRtcList, setCacheActiveIndex, setLoading, swiperRef, waterFallData, bffEventReport, selectTag, setSelectTag } = useSxpDataSource();
13743
13809
  const { backMainFeed } = useEventReport();
13744
13810
  const realTagList = React.useMemo(() => {
@@ -13779,7 +13845,7 @@ const Tagbar = ({ tagList = [], setActiveIndex }) => {
13779
13845
  };
13780
13846
  if (waterFallData || tagList.length <= 0)
13781
13847
  return null;
13782
- return (React.createElement("div", { className: 'clc-sxp-tagbar' },
13848
+ return (React.createElement("div", { className: 'clc-sxp-tagbar', style: style },
13783
13849
  React.createElement("ul", { className: 'clc-sxp-tagbar-list', style: { margin: 'auto', gap: 24 } }, realTagList.map((tag) => {
13784
13850
  return (React.createElement("li", { className: `clc-sxp-tagbar-list-item ${tag === selectTag ? 'clc-sxp-tagbar-list-item-active' : ''}`, key: tag, onClick: handleSelectTag(tag) }, tag));
13785
13851
  }))));
@@ -13790,7 +13856,7 @@ var Tagbar$1 = React.memo(Tagbar);
13790
13856
  * @Author: binruan@chatlabs.com
13791
13857
  * @Date: 2024-01-15 19:03:09
13792
13858
  * @LastEditors: binruan@chatlabs.com
13793
- * @LastEditTime: 2024-06-27 15:47:52
13859
+ * @LastEditTime: 2024-07-01 11:49:58
13794
13860
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13795
13861
  *
13796
13862
  */
@@ -13799,14 +13865,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13799
13865
  const { schema } = useEditor();
13800
13866
  const [activeIndex, setActiveIndex] = React.useState(0);
13801
13867
  const viewImageStartTime = React.useRef(0);
13802
- React.useState(false);
13803
13868
  const [isMuted, setIsMuted] = React.useState(true);
13804
13869
  const viewTime = React.useRef();
13805
13870
  const [isLoadMore, setIsLoadMore] = React.useState(false);
13806
13871
  const [isShowMore, setIsShowMore] = React.useState(false);
13807
13872
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13808
13873
  const { backMainFeed } = useEventReport();
13809
- const videoRef = React.useRef();
13810
13874
  const { productView } = useEventReport();
13811
13875
  const isShowFingerTip = React.useMemo(() => {
13812
13876
  return data.length > 0 && !loading && getFeUserId();
@@ -13834,16 +13898,6 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13834
13898
  });
13835
13899
  }
13836
13900
  }, [data.length, bffFbReport, h5EnterLink]);
13837
- const firstRef = React.useRef();
13838
- React.useEffect(() => {
13839
- var _a, _b, _c, _d;
13840
- if (!firstRef.current && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && (data === null || data === void 0 ? void 0 : data.length) > 0) {
13841
- firstRef.current = true;
13842
- 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) {
13843
- 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;
13844
- }
13845
- }
13846
- }, [videoRef, data]);
13847
13901
  React.useEffect(() => {
13848
13902
  var _a;
13849
13903
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13944,11 +13998,14 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13944
13998
  }
13945
13999
  return h;
13946
14000
  }, [tagList, waterFallData]);
13947
- const height = React.useMemo(() => {
14001
+ const minusHeight = React.useMemo(() => {
13948
14002
  let minusHeight = 0;
13949
14003
  if ((globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.logoUrl) && (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.isShowLogo)) {
13950
14004
  minusHeight += 45;
13951
14005
  }
14006
+ return minusHeight;
14007
+ }, []);
14008
+ const height = React.useMemo(() => {
13952
14009
  return containerHeight - minusHeight - tagHeight;
13953
14010
  }, [globalConfig, containerHeight, tagHeight]);
13954
14011
  const renderLogo = React.useMemo(() => {
@@ -13961,7 +14018,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13961
14018
  const renderContent = React.useCallback((rec, index) => {
13962
14019
  var _a, _b, _c, _d;
13963
14020
  if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) {
13964
- 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 }));
14021
+ 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 }));
13965
14022
  }
13966
14023
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13967
14024
  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 }));
@@ -13987,8 +14044,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13987
14044
  viewTime,
13988
14045
  tipText,
13989
14046
  resolver,
13990
- schema,
13991
- videoRef.current
14047
+ schema
13992
14048
  ]);
13993
14049
  const onExpandableChange = React.useCallback((v) => {
13994
14050
  setIsShowMore(v);
@@ -14185,7 +14241,9 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
14185
14241
  setOpenHashtag === null || setOpenHashtag === void 0 ? void 0 : setOpenHashtag(true);
14186
14242
  } })),
14187
14243
  renderLogo,
14188
- React.createElement(Tagbar$1, { tagList: tagList, setActiveIndex: setActiveIndex }),
14244
+ React.createElement(Tagbar$1, { tagList: tagList, setActiveIndex: setActiveIndex, style: {
14245
+ top: minusHeight
14246
+ } }),
14189
14247
  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,
14190
14248
  React.createElement(Swiper, { style: {
14191
14249
  marginTop: tagHeight
@@ -14219,16 +14277,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
14219
14277
  [(_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
14220
14278
  }, 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 }),
14221
14279
  renderView),
14222
- 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)),
14223
- React.createElement("div", { style: { position: 'absolute', zIndex: -100 } },
14224
- React.createElement("video", { ref: videoRef, id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
14225
- backgroundColor: 'transparent',
14226
- width: '100%',
14227
- height: '100%',
14228
- objectFit: 'cover',
14229
- pointerEvents: 'none'
14230
- } }),
14231
- React.createElement("div", { id: 'player-container-id-copy' }))));
14280
+ 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))));
14232
14281
  };
14233
14282
 
14234
14283
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {