pb-sxp-ui 1.0.101 → 1.0.103

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 (52) hide show
  1. package/dist/index.cjs +311 -144
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +20 -3
  4. package/dist/index.js +312 -144
  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 +311 -144
  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/Nudge/index.d.ts +2 -0
  15. package/es/core/components/SxpPageRender/Nudge/index.js +5 -2
  16. package/es/core/components/SxpPageRender/PictureGroup/index.js +10 -2
  17. package/es/core/components/SxpPageRender/VideoWidget/VideoPlayer.d.ts +1 -0
  18. package/es/core/components/SxpPageRender/VideoWidget/VideoPlayer.js +22 -0
  19. package/es/core/components/SxpPageRender/VideoWidget/index.d.ts +0 -1
  20. package/es/core/components/SxpPageRender/VideoWidget/index.js +93 -85
  21. package/es/core/components/SxpPageRender/index.d.ts +1 -0
  22. package/es/core/components/SxpPageRender/index.js +3 -25
  23. package/es/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  24. package/es/materials/sxp/popup/Prompt/index.d.ts +1 -0
  25. package/es/materials/sxp/popup/Prompt/index.js +4 -2
  26. package/es/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  27. package/es/materials/sxp/popup/Prompt/settingRender.js +33 -4
  28. package/es/materials/sxp/template/Link/index.d.ts +6 -1
  29. package/es/materials/sxp/template/Link/index.js +9 -5
  30. package/es/materials/sxp/template/Link/material.js +15 -1
  31. package/es/materials/sxp/template/Link/settingRender.d.ts +57 -0
  32. package/es/materials/sxp/template/Link/settingRender.js +102 -0
  33. package/lib/core/components/SxpPageRender/Nudge/index.d.ts +2 -0
  34. package/lib/core/components/SxpPageRender/Nudge/index.js +5 -2
  35. package/lib/core/components/SxpPageRender/PictureGroup/index.js +10 -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.d.ts +1 -0
  41. package/lib/core/components/SxpPageRender/index.js +3 -25
  42. package/lib/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  43. package/lib/materials/sxp/popup/Prompt/index.d.ts +1 -0
  44. package/lib/materials/sxp/popup/Prompt/index.js +4 -2
  45. package/lib/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  46. package/lib/materials/sxp/popup/Prompt/settingRender.js +33 -4
  47. package/lib/materials/sxp/template/Link/index.d.ts +6 -1
  48. package/lib/materials/sxp/template/Link/index.js +9 -5
  49. package/lib/materials/sxp/template/Link/material.js +15 -1
  50. package/lib/materials/sxp/template/Link/settingRender.d.ts +57 -0
  51. package/lib/materials/sxp/template/Link/settingRender.js +104 -0
  52. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -6,6 +6,7 @@ import qs from 'qs';
6
6
  import EventEmitter from 'eventemitter3';
7
7
  import { css } from '@emotion/css';
8
8
  import * as ReactDOM from 'react-dom';
9
+ import ReactDOM__default from 'react-dom';
9
10
 
10
11
  /******************************************************************************
11
12
  Copyright (c) Microsoft Corporation.
@@ -1090,7 +1091,7 @@ var interactionRender$8 = [
1090
1091
  * @Author: binruan@chatlabs.com
1091
1092
  * @Date: 2023-07-28 18:29:57
1092
1093
  * @LastEditors: binruan@chatlabs.com
1093
- * @LastEditTime: 2024-06-27 09:50:07
1094
+ * @LastEditTime: 2024-07-02 10:01:21
1094
1095
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1095
1096
  *
1096
1097
  */
@@ -1114,12 +1115,12 @@ var settingRender$6 = [
1114
1115
  child: [
1115
1116
  {
1116
1117
  type: 'Select',
1117
- name: ['testStyle', 'fontFamily-cn'],
1118
+ name: ['textStyle', 'fontFamily-cn'],
1118
1119
  bottomText: '中文字体'
1119
1120
  },
1120
1121
  {
1121
1122
  type: 'Select',
1122
- name: ['testStyle', 'fontFamily-en'],
1123
+ name: ['textStyle', 'fontFamily-en'],
1123
1124
  bottomText: '英文/其他字体'
1124
1125
  }
1125
1126
  ]
@@ -1346,7 +1347,7 @@ function useEventReport() {
1346
1347
  * @Author: binruan@chatlabs.com
1347
1348
  * @Date: 2024-06-27 16:22:34
1348
1349
  * @LastEditors: binruan@chatlabs.com
1349
- * @LastEditTime: 2024-06-27 18:27:11
1350
+ * @LastEditTime: 2024-07-02 10:34:34
1350
1351
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\Form.tsx
1351
1352
  *
1352
1353
  */
@@ -8905,7 +8906,7 @@ var interactionRender$7 = [
8905
8906
  * @Author: binruan@chatlabs.com
8906
8907
  * @Date: 2023-10-27 14:06:35
8907
8908
  * @LastEditors: binruan@chatlabs.com
8908
- * @LastEditTime: 2024-06-27 09:57:31
8909
+ * @LastEditTime: 2024-07-02 09:58:06
8909
8910
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
8910
8911
  *
8911
8912
  */
@@ -8925,9 +8926,37 @@ var settingRender$4 = [
8925
8926
  name: ['props', 'content']
8926
8927
  },
8927
8928
  {
8928
- type: 'Text',
8929
- label: '按钮文案',
8930
- name: ['props', 'btnText']
8929
+ type: 'Group',
8930
+ label: '内容字体',
8931
+ child: [
8932
+ {
8933
+ type: 'Select',
8934
+ name: ['props', 'contentStyle', 'fontFamily-cn'],
8935
+ bottomText: '中文字体'
8936
+ },
8937
+ {
8938
+ type: 'Select',
8939
+ name: ['props', 'contentStyle', 'fontFamily-en'],
8940
+ bottomText: '英文/其他字体'
8941
+ }
8942
+ ]
8943
+ },
8944
+ {
8945
+ type: 'Group',
8946
+ label: '',
8947
+ child: [
8948
+ {
8949
+ type: 'Color',
8950
+ name: ['props', 'contentStyle', 'color'],
8951
+ initialValue: '#000'
8952
+ },
8953
+ {
8954
+ type: 'Number',
8955
+ name: ['props', 'contentStyle', 'fontSize'],
8956
+ addonAfter: 'px',
8957
+ initialValue: 14
8958
+ }
8959
+ ]
8931
8960
  },
8932
8961
  {
8933
8962
  type: 'Group',
@@ -8973,7 +9002,8 @@ var settingRender$4 = [
8973
9002
  {
8974
9003
  label: '提交按钮颜色',
8975
9004
  type: 'Color',
8976
- name: ['props', 'submitButtonStyle', 'backgroundColor']
9005
+ name: ['props', 'submitButtonStyle', 'backgroundColor'],
9006
+ initialValue: '#000'
8977
9007
  }
8978
9008
  ]
8979
9009
  }
@@ -9014,7 +9044,7 @@ const getMediaValueByMode = (obj) => {
9014
9044
  };
9015
9045
 
9016
9046
  const Prompt$1 = (_a) => {
9017
- var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle"]);
9047
+ 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"]);
9018
9048
  const { popupDetailData } = useSxpDataSource();
9019
9049
  const { jumpToWeb } = useEventReport();
9020
9050
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
@@ -9035,7 +9065,9 @@ const Prompt$1 = (_a) => {
9035
9065
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css(Object.assign({}, style))}` }, props),
9036
9066
  React.createElement("div", { className: 'pb-prompt-icon' },
9037
9067
  React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3, alt: 'success image' })),
9038
- React.createElement("div", { className: 'pb-prompt-content' }, content),
9068
+ React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
9069
+ __html: setFontForText(content, contentStyle)
9070
+ } }),
9039
9071
  React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk, dangerouslySetInnerHTML: {
9040
9072
  __html: setFontForText(btnText, submitButtonStyle)
9041
9073
  } })));
@@ -9990,11 +10022,122 @@ const Appoint = createMaterial(AppointComponent, {
9990
10022
  sort: 6
9991
10023
  });
9992
10024
 
9993
- var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU"};
10025
+ /*
10026
+ * @Author: binruan@chatlabs.com
10027
+ * @Date: 2024-07-02 14:51:32
10028
+ * @LastEditors: binruan@chatlabs.com
10029
+ * @LastEditTime: 2024-07-02 16:44:34
10030
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\settingRender.tsx
10031
+ *
10032
+ */
10033
+ var linkSettingRender = [
10034
+ {
10035
+ title: '自定义标题',
10036
+ child: [
10037
+ {
10038
+ type: 'Switch',
10039
+ label: '自定义标题开关',
10040
+ name: ['props', 'customTitle', 'display']
10041
+ },
10042
+ {
10043
+ type: 'Text',
10044
+ label: '标题文案',
10045
+ name: ['props', 'customTitle', 'text']
10046
+ },
10047
+ {
10048
+ type: 'Group',
10049
+ label: '尺寸',
10050
+ child: [
10051
+ {
10052
+ type: 'Number',
10053
+ name: ['props', 'customTitle', 'style', 'width'],
10054
+ addonAfter: 'W'
10055
+ },
10056
+ {
10057
+ type: 'Number',
10058
+ name: ['props', 'customTitle', 'style', 'height'],
10059
+ addonAfter: 'H'
10060
+ }
10061
+ ]
10062
+ },
10063
+ {
10064
+ type: 'Group',
10065
+ label: '圆角',
10066
+ child: [
10067
+ {
10068
+ type: 'Slider',
10069
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10070
+ max: 100
10071
+ },
10072
+ {
10073
+ type: 'Number',
10074
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10075
+ addonAfter: 'px',
10076
+ max: 100
10077
+ }
10078
+ ]
10079
+ },
10080
+ {
10081
+ type: 'Color',
10082
+ label: '背景色',
10083
+ name: ['props', 'customTitle', 'style', 'backgroundColor']
10084
+ },
10085
+ {
10086
+ type: 'Group',
10087
+ label: '字体',
10088
+ child: [
10089
+ {
10090
+ type: 'Select',
10091
+ name: ['props', 'customTitle', 'style', 'fontFamily-cn'],
10092
+ bottomText: '中文字体'
10093
+ },
10094
+ {
10095
+ type: 'Select',
10096
+ name: ['props', 'customTitle', 'style', 'fontFamily-en'],
10097
+ bottomText: '英文/其他字体'
10098
+ }
10099
+ ]
10100
+ },
10101
+ {
10102
+ type: 'Group',
10103
+ label: '',
10104
+ child: [
10105
+ {
10106
+ type: 'Color',
10107
+ name: ['props', 'customTitle', 'style', 'color']
10108
+ },
10109
+ {
10110
+ type: 'Number',
10111
+ addonAfter: 'px',
10112
+ name: ['props', 'customTitle', 'style', 'fontSize']
10113
+ }
10114
+ ]
10115
+ },
10116
+ {
10117
+ label: '样式',
10118
+ type: 'TextStyle',
10119
+ name: ['props', 'customTitle', 'style']
10120
+ },
10121
+ {
10122
+ label: '对齐',
10123
+ type: 'TextAlign',
10124
+ name: ['props', 'customTitle', 'style']
10125
+ },
10126
+ {
10127
+ label: '上边距',
10128
+ type: 'Number',
10129
+ name: ['props', 'customTitle', 'style', 'marginTop'],
10130
+ addonAfter: 'px'
10131
+ }
10132
+ ]
10133
+ }
10134
+ ];
10135
+
10136
+ var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU","one-line-ellipsis":"index-module_one-line-ellipsis__buFw1"};
9994
10137
 
9995
10138
  const Link$1 = (_a) => {
9996
- var _b, _c, _d, _e, _f, _g, _h;
9997
- var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index"]);
10139
+ var _b, _c, _d, _e, _f, _g, _h, _j;
10140
+ var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index, customTitle } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index", "customTitle"]);
9998
10141
  const { sxpParameter, bffEventReport } = useSxpDataSource();
9999
10142
  const { jumpToWeb } = useEventReport();
10000
10143
  const cta = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindCta;
@@ -10014,27 +10157,24 @@ const Link$1 = (_a) => {
10014
10157
  width: '100%',
10015
10158
  overflow: 'hidden'
10016
10159
  }) },
10017
- React.createElement("div", { className: styles$5['tow-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle, dangerouslySetInnerHTML: {
10018
- __html: setFontForText((_h = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _h !== void 0 ? _h : 'Product Name', ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle)
10019
- } }))));
10160
+ React.createElement("div", null,
10161
+ React.createElement("div", { className: (customTitle === null || customTitle === void 0 ? void 0 : customTitle.display) ? styles$5['one-line-ellipsis'] : styles$5['tow-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle, dangerouslySetInnerHTML: {
10162
+ __html: setFontForText((_h = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _h !== void 0 ? _h : 'Product Name', ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle)
10163
+ } }),
10164
+ (customTitle === null || customTitle === void 0 ? void 0 : customTitle.display) && (React.createElement("div", { style: Object.assign(Object.assign({}, customTitle === null || customTitle === void 0 ? void 0 : customTitle.style), { lineHeight: ((_j = customTitle === null || customTitle === void 0 ? void 0 : customTitle.style) === null || _j === void 0 ? void 0 : _j.height) + 'px' }), className: styles$5['one-line-ellipsis'], dangerouslySetInnerHTML: {
10165
+ __html: setFontForText(customTitle === null || customTitle === void 0 ? void 0 : customTitle.text, customTitle === null || customTitle === void 0 ? void 0 : customTitle.style)
10166
+ } }))))));
10020
10167
  };
10021
10168
  var LinkComponent = memo(Link$1);
10022
10169
 
10023
- /*
10024
- * @Author: binruan@chatlabs.com
10025
- * @Date: 2023-07-28 18:29:57
10026
- * @LastEditors: binruan@chatlabs.com
10027
- * @LastEditTime: 2024-03-29 17:04:57
10028
- * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\material.tsx
10029
- *
10030
- */
10170
+ var _a;
10031
10171
  const Link = createMaterial(LinkComponent, {
10032
10172
  displayName: '跳转指引',
10033
10173
  icon: '',
10034
10174
  category: 'template',
10035
10175
  type: 'Link',
10036
10176
  related: {
10037
- settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
10177
+ settingRender: (_a = settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle')) === null || _a === void 0 ? void 0 : _a.concat(linkSettingRender),
10038
10178
  bindableProps: []
10039
10179
  },
10040
10180
  defaulSetting: {
@@ -10053,6 +10193,18 @@ const Link = createMaterial(LinkComponent, {
10053
10193
  width: 130,
10054
10194
  height: 20
10055
10195
  }
10196
+ },
10197
+ customTitle: {
10198
+ style: {
10199
+ textAlign: 'left',
10200
+ textDecoration: 'underline',
10201
+ fontWeight: 'bold',
10202
+ width: 130,
10203
+ height: 20,
10204
+ fontSize: 12,
10205
+ color: '#000'
10206
+ },
10207
+ text: '探索更多'
10056
10208
  }
10057
10209
  },
10058
10210
  style: {
@@ -13060,7 +13212,29 @@ var LikeButton$1 = memo(LikeButton);
13060
13212
 
13061
13213
  var img$1 = "";
13062
13214
 
13063
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13215
+ const mountVideoPlayerAtNode = (() => {
13216
+ if (typeof document === 'undefined')
13217
+ return;
13218
+ const playerContainer = document.createElement('div');
13219
+ const dom = ReactDOM__default.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13220
+ backgroundColor: 'transparent',
13221
+ width: '100%',
13222
+ height: '100%',
13223
+ objectFit: 'cover',
13224
+ pointerEvents: 'none'
13225
+ } }), playerContainer);
13226
+ // 播放器的挂载节点
13227
+ return (domNode) => {
13228
+ if (!domNode)
13229
+ return;
13230
+ domNode.innerHTML = '';
13231
+ domNode.appendChild(dom);
13232
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13233
+ return videoPlayerWrapperNode;
13234
+ };
13235
+ })();
13236
+
13237
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13064
13238
  const [isPauseVideo, setIsPauseVideo] = useState(false);
13065
13239
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13066
13240
  const videoStartTime = useRef(0);
@@ -13070,6 +13244,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13070
13244
  const canvasRef = useRef(null);
13071
13245
  const [firstFrameSrc, setFirstFrameSrc] = useState('');
13072
13246
  const [waiting, setWaiting] = useState(false);
13247
+ const videoRef = useRef();
13073
13248
  const videoId = `pb-cache-video-${index}`;
13074
13249
  const videoEleRef = useRef(null);
13075
13250
  const blur = useMemo(() => {
@@ -13100,56 +13275,57 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13100
13275
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13101
13276
  }, [videoPostConfig, isBgColor]);
13102
13277
  useEffect(() => {
13103
- if (!videoRef)
13278
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13104
13279
  return;
13105
- videoRef.muted = muted;
13106
- }, [muted, videoRef]);
13280
+ videoRef.current.muted = muted;
13281
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13107
13282
  const handlePlay = useCallback(() => {
13108
- if (!videoRef)
13283
+ var _a;
13284
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13109
13285
  return;
13110
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13111
- }, [videoRef]);
13286
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13287
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13112
13288
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13113
13289
  const handlePlaying = useCallback(() => {
13114
- if (!videoRef)
13290
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13115
13291
  return;
13116
13292
  setWaiting(false);
13117
13293
  setIsLoadFinish(true);
13118
13294
  }, []);
13119
13295
  const handleStartPlay = useCallback(() => {
13120
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13121
- if (!videoRef)
13296
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13297
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13122
13298
  return;
13123
13299
  setIsPauseVideo(false);
13124
13300
  const item = data[index];
13125
- if (item && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration)) {
13126
- videoStartTime.current = (videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) || 0;
13127
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13128
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13301
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13302
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13303
+ 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);
13304
+ 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);
13129
13305
  const playType = isFirstPlay ? '0' : '1';
13130
13306
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13131
13307
  eventInfo: {
13132
13308
  eventSubject: 'playVideo',
13133
13309
  eventDescription: 'User played the video',
13134
- 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 : '',
13135
- 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 : '',
13310
+ 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 : '',
13311
+ 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 : '',
13136
13312
  playType,
13137
13313
  startTime: videoCurrentTime,
13138
13314
  videoDuration,
13139
- 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 : []),
13315
+ 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 : []),
13140
13316
  position: index + '',
13141
13317
  contentFormat: 'video',
13142
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13318
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13143
13319
  }
13144
13320
  });
13145
13321
  setIsFirstPlay(false);
13146
13322
  }
13147
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13323
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13148
13324
  const handLoadeddata = useCallback(() => {
13149
13325
  var _a;
13150
- if (!videoRef || firstFrameSrc || !blur)
13326
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13151
13327
  return;
13152
- videoRef.style.objectFit = 'contain';
13328
+ videoRef.current.style.objectFit = 'contain';
13153
13329
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13154
13330
  return;
13155
13331
  const setFrameImg = () => {
@@ -13159,158 +13335,163 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13159
13335
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13160
13336
  canvas.height = targetHeight;
13161
13337
  canvas.width = targetWidth;
13162
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13338
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13163
13339
  setFirstFrameSrc(canvas.toDataURL());
13164
13340
  };
13165
13341
  setFrameImg();
13166
13342
  setTimeout(() => {
13167
13343
  setFrameImg();
13168
13344
  }, 500);
13169
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13345
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13170
13346
  const handleLoadedmetadata = useCallback(() => {
13171
- if (!videoRef)
13347
+ if (!videoRef.current)
13172
13348
  return;
13173
13349
  handleStartPlay();
13174
13350
  handLoadeddata();
13175
- }, [videoRef, handLoadeddata, handleStartPlay]);
13351
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13176
13352
  const handleClickVideo = useCallback((type) => () => {
13177
- if (!videoRef)
13353
+ var _a, _b, _c, _d, _e;
13354
+ if (!videoRef.current)
13178
13355
  return;
13179
13356
  if (!isLoadFinish)
13180
13357
  return;
13181
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13358
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13182
13359
  switch (type) {
13183
13360
  case 'start':
13184
13361
  if (!isPause)
13185
13362
  return;
13186
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13363
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13187
13364
  setIsPauseVideo(false);
13188
13365
  break;
13189
13366
  case 'pause':
13190
13367
  if (isPause)
13191
13368
  return;
13192
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13369
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13193
13370
  setIsPauseVideo(true);
13194
13371
  break;
13195
13372
  default:
13196
13373
  if (isPause) {
13197
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13374
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13198
13375
  }
13199
13376
  else {
13200
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13377
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13201
13378
  }
13202
13379
  setIsPauseVideo(!isPause);
13203
13380
  break;
13204
13381
  }
13205
- }, [isLoadFinish, videoRef]);
13382
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13206
13383
  const handlePause = useCallback(() => {
13207
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13208
- if (!videoRef)
13384
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13385
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13209
13386
  return;
13210
13387
  if (activeIndex !== index)
13211
13388
  return;
13212
13389
  const item = data[index];
13213
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13214
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13215
- if (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) {
13216
- const playDuration = ((videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) - videoStartTime.current).toFixed(2);
13390
+ 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);
13391
+ 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);
13392
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13393
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13217
13394
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13218
13395
  eventInfo: {
13219
13396
  eventSubject: 'playOverVideo',
13220
13397
  eventDescription: 'User finished playing the video',
13221
- 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 : '',
13222
- 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 : '',
13398
+ 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 : '',
13399
+ 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 : '',
13223
13400
  endTime: videoCurrentTime,
13224
13401
  videoDuration,
13225
13402
  playDuration,
13226
- 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 : []),
13403
+ 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 : []),
13227
13404
  position: index + '',
13228
13405
  contentFormat: 'video',
13229
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13406
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13230
13407
  }
13231
13408
  });
13232
13409
  }
13233
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13410
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13234
13411
  const handleWaiting = useCallback(() => {
13235
13412
  setWaiting(true);
13236
13413
  }, []);
13237
13414
  useEffect(() => {
13238
- if (!isActive || !videoRef)
13415
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13416
+ if (!isActive)
13239
13417
  return;
13240
13418
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13241
13419
  if (!videoSrc)
13242
13420
  return;
13421
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13422
+ if (!videoPlayerWrapperNode)
13423
+ return;
13424
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13425
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13426
+ return;
13243
13427
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13244
13428
  let hls = null;
13245
13429
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13246
13430
  hls = new Hls();
13247
13431
  hls.loadSource(videoSrc);
13248
- hls.attachMedia(videoRef);
13432
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13249
13433
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13250
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13434
+ var _a;
13435
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13251
13436
  });
13252
13437
  }
13253
13438
  else {
13254
- videoRef.src = videoSrc;
13255
- }
13256
- const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13257
- const dom = document.querySelector('#player-container-id');
13258
- const dom2 = document.querySelector('#player-container-id-copy');
13259
- if (!dom && !dom2)
13260
- return;
13261
- videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
13262
- videoRef.setAttribute('x5-playsinline', 'true');
13263
- videoRef.setAttribute('webkit-playsinline', 'true');
13264
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadedmetadata', handleLoadedmetadata);
13265
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadeddata', handLoadeddata);
13266
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('play', handleStartPlay);
13267
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('playing', handlePlaying);
13268
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('pause', handlePause);
13269
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('ended', handlePlay);
13270
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('canplay', handlePlay);
13271
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('waiting', handleWaiting);
13439
+ videoRef.current.src = videoSrc;
13440
+ }
13441
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13442
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13443
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13444
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13445
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13446
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13447
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13448
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13449
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13450
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13272
13451
  return () => {
13452
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13273
13453
  if (hls)
13274
13454
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13275
13455
  setIsLoadFinish(false);
13276
- dom2 === null || dom2 === void 0 ? void 0 : dom2.appendChild(dom);
13277
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadedmetadata', handleLoadedmetadata);
13278
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadeddata', handLoadeddata);
13279
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('play', handleStartPlay);
13280
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('playing', handlePlaying);
13281
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('pause', handlePause);
13282
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('ended', handlePlay);
13283
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('canplay', handlePlay);
13284
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('waiting', handleWaiting);
13456
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13457
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13458
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13459
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13460
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13461
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13462
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13463
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13285
13464
  };
13286
- }, [isActive, videoId, rec, videoRef]);
13465
+ }, [isActive, videoId, rec]);
13287
13466
  useEffect(() => {
13288
- if (!videoRef || !isLoadFinish)
13467
+ var _a, _b;
13468
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13289
13469
  return;
13290
13470
  if (isActive) {
13291
13471
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13292
13472
  eventName: 'ViewContent'
13293
13473
  });
13294
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13474
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13295
13475
  }
13296
13476
  else {
13297
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13477
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13298
13478
  }
13299
- }, [isActive, isLoadFinish, videoRef]);
13479
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13300
13480
  /*
13301
13481
  打开/关闭hashtag暂停/播放视频
13302
13482
  */
13303
13483
  useEffect(() => {
13304
- if (!isActive || !videoRef)
13484
+ var _a, _b, _c;
13485
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13305
13486
  return;
13306
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13487
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13307
13488
  if (!isPause && openHashtag) {
13308
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13489
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13309
13490
  }
13310
13491
  else if (!openHashtag) {
13311
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13492
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13312
13493
  }
13313
- }, [openHashtag, isActive, videoRef]);
13494
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13314
13495
  useEffect(() => {
13315
13496
  if (!isActive)
13316
13497
  return;
@@ -13357,11 +13538,11 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13357
13538
  }, src: img$1, alt: 'placeholder image' }));
13358
13539
  }, [waiting, isLoadFinish]);
13359
13540
  useEffect(() => {
13360
- if (!videoRef)
13541
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13361
13542
  return;
13362
13543
  const handleBeforeUnload = () => {
13363
13544
  var _a;
13364
- if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && videoRef && !isPauseVideo) {
13545
+ 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) {
13365
13546
  handleClickVideo('pause')();
13366
13547
  }
13367
13548
  };
@@ -13369,7 +13550,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13369
13550
  return () => {
13370
13551
  window.removeEventListener('beforeunload', handleBeforeUnload);
13371
13552
  };
13372
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13553
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13373
13554
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13374
13555
  return null;
13375
13556
  }
@@ -13498,11 +13679,11 @@ const Picture = (props) => {
13498
13679
  * @Author: lewinlu@chatlabs.com
13499
13680
  * @Date: 2024-01-03 14:39:09
13500
13681
  * @LastEditors: binruan@chatlabs.com
13501
- * @LastEditTime: 2024-06-07 14:05:08
13682
+ * @LastEditTime: 2024-07-02 18:25:17
13502
13683
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
13503
13684
  */
13504
13685
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
13505
- var _a;
13686
+ var _a, _b;
13506
13687
  const ref = useRef();
13507
13688
  const { isActive } = useSwiperSlide();
13508
13689
  const { sxpParameter, openHashtag } = useSxpDataSource();
@@ -13529,7 +13710,14 @@ const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageE
13529
13710
  // if (!isActive) {
13530
13711
  // return <img src={sxpParameter?.placeholder_image} style={{ width, height, objectFit: 'cover' }} />;
13531
13712
  // }
13532
- return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: { clickable: true, bulletActiveClass: 'swipe-item-active-bullet' }, height: height, loop: true, autoplay: { delay: ((_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _a !== void 0 ? _a : 3) * 1000 } }, imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, index) => {
13713
+ return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: {
13714
+ clickable: true,
13715
+ bulletActiveClass: 'swipe-item-active-bullet'
13716
+ }, className: css(Object.assign({}, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) && {
13717
+ '.swiper-pagination': {
13718
+ bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0
13719
+ }
13720
+ }))), height: height, loop: true, autoplay: { delay: ((_b = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.delay) !== null && _b !== void 0 ? _b : 3) * 1000 } }, imgUrls === null || imgUrls === void 0 ? void 0 : imgUrls.map((url, index) => {
13533
13721
  return (React.createElement(SwiperSlide, { key: index },
13534
13722
  React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
13535
13723
  })));
@@ -13694,12 +13882,12 @@ var RenderCard$1 = memo(RenderCard);
13694
13882
  * @Author: binruan@chatlabs.com
13695
13883
  * @Date: 2024-03-26 10:07:41
13696
13884
  * @LastEditors: binruan@chatlabs.com
13697
- * @LastEditTime: 2024-05-23 14:31:12
13885
+ * @LastEditTime: 2024-07-03 10:07:29
13698
13886
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13699
13887
  *
13700
13888
  */
13701
13889
  const Nudge = ({ nudge }) => {
13702
- var _a, _b, _c, _d, _e, _f, _g;
13890
+ var _a, _b, _c, _d, _e, _f;
13703
13891
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13704
13892
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13705
13893
  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,
@@ -13708,7 +13896,9 @@ const Nudge = ({ nudge }) => {
13708
13896
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13709
13897
  } },
13710
13898
  (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,
13711
- 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 : '')))));
13899
+ 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, marginTop: 0 }), dangerouslySetInnerHTML: {
13900
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13901
+ } })))));
13712
13902
  };
13713
13903
 
13714
13904
  /*
@@ -13771,7 +13961,7 @@ var Tagbar$1 = memo(Tagbar);
13771
13961
  * @Author: binruan@chatlabs.com
13772
13962
  * @Date: 2024-01-15 19:03:09
13773
13963
  * @LastEditors: binruan@chatlabs.com
13774
- * @LastEditTime: 2024-06-28 14:53:42
13964
+ * @LastEditTime: 2024-07-02 17:55:40
13775
13965
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13776
13966
  *
13777
13967
  */
@@ -13780,14 +13970,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13780
13970
  const { schema } = useEditor();
13781
13971
  const [activeIndex, setActiveIndex] = useState(0);
13782
13972
  const viewImageStartTime = useRef(0);
13783
- useState(false);
13784
13973
  const [isMuted, setIsMuted] = useState(true);
13785
13974
  const viewTime = useRef();
13786
13975
  const [isLoadMore, setIsLoadMore] = useState(false);
13787
13976
  const [isShowMore, setIsShowMore] = useState(false);
13788
13977
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13789
13978
  const { backMainFeed } = useEventReport();
13790
- const videoRef = useRef();
13791
13979
  const { productView } = useEventReport();
13792
13980
  const isShowFingerTip = useMemo(() => {
13793
13981
  return data.length > 0 && !loading && getFeUserId();
@@ -13815,16 +14003,6 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13815
14003
  });
13816
14004
  }
13817
14005
  }, [data.length, bffFbReport, h5EnterLink]);
13818
- const firstRef = useRef();
13819
- useEffect(() => {
13820
- var _a, _b, _c, _d;
13821
- if (!firstRef.current && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && (data === null || data === void 0 ? void 0 : data.length) > 0) {
13822
- firstRef.current = true;
13823
- 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) {
13824
- 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;
13825
- }
13826
- }
13827
- }, [videoRef, data]);
13828
14006
  useEffect(() => {
13829
14007
  var _a;
13830
14008
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13945,7 +14123,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13945
14123
  const renderContent = useCallback((rec, index) => {
13946
14124
  var _a, _b, _c, _d;
13947
14125
  if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) {
13948
- 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 }));
14126
+ 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 }));
13949
14127
  }
13950
14128
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13951
14129
  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 }));
@@ -13971,8 +14149,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13971
14149
  viewTime,
13972
14150
  tipText,
13973
14151
  resolver,
13974
- schema,
13975
- videoRef.current
14152
+ schema
13976
14153
  ]);
13977
14154
  const onExpandableChange = useCallback((v) => {
13978
14155
  setIsShowMore(v);
@@ -14205,16 +14382,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
14205
14382
  [(_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
14206
14383
  }, 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 }),
14207
14384
  renderView),
14208
- 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)),
14209
- React.createElement("div", { style: { position: 'absolute', zIndex: -100 } },
14210
- React.createElement("video", { ref: videoRef, id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
14211
- backgroundColor: 'transparent',
14212
- width: '100%',
14213
- height: '100%',
14214
- objectFit: 'cover',
14215
- pointerEvents: 'none'
14216
- } }),
14217
- React.createElement("div", { id: 'player-container-id-copy' }))));
14385
+ 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))));
14218
14386
  };
14219
14387
 
14220
14388
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {