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.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
  */
@@ -8928,7 +8928,7 @@ var interactionRender$7 = [
8928
8928
  * @Author: binruan@chatlabs.com
8929
8929
  * @Date: 2023-10-27 14:06:35
8930
8930
  * @LastEditors: binruan@chatlabs.com
8931
- * @LastEditTime: 2024-06-27 09:57:31
8931
+ * @LastEditTime: 2024-07-02 09:58:06
8932
8932
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
8933
8933
  *
8934
8934
  */
@@ -8948,9 +8948,37 @@ var settingRender$4 = [
8948
8948
  name: ['props', 'content']
8949
8949
  },
8950
8950
  {
8951
- type: 'Text',
8952
- label: '按钮文案',
8953
- 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
+ ]
8954
8982
  },
8955
8983
  {
8956
8984
  type: 'Group',
@@ -8996,7 +9024,8 @@ var settingRender$4 = [
8996
9024
  {
8997
9025
  label: '提交按钮颜色',
8998
9026
  type: 'Color',
8999
- name: ['props', 'submitButtonStyle', 'backgroundColor']
9027
+ name: ['props', 'submitButtonStyle', 'backgroundColor'],
9028
+ initialValue: '#000'
9000
9029
  }
9001
9030
  ]
9002
9031
  }
@@ -9037,7 +9066,7 @@ const getMediaValueByMode = (obj) => {
9037
9066
  };
9038
9067
 
9039
9068
  const Prompt$1 = (_a) => {
9040
- 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"]);
9041
9070
  const { popupDetailData } = useSxpDataSource();
9042
9071
  const { jumpToWeb } = useEventReport();
9043
9072
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
@@ -9058,7 +9087,9 @@ const Prompt$1 = (_a) => {
9058
9087
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
9059
9088
  React.createElement("div", { className: 'pb-prompt-icon' },
9060
9089
  React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3, alt: 'success image' })),
9061
- 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
+ } }),
9062
9093
  React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk, dangerouslySetInnerHTML: {
9063
9094
  __html: setFontForText(btnText, submitButtonStyle)
9064
9095
  } })));
@@ -10013,11 +10044,122 @@ const Appoint = createMaterial(AppointComponent, {
10013
10044
  sort: 6
10014
10045
  });
10015
10046
 
10016
- var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU"};
10047
+ /*
10048
+ * @Author: binruan@chatlabs.com
10049
+ * @Date: 2024-07-02 14:51:32
10050
+ * @LastEditors: binruan@chatlabs.com
10051
+ * @LastEditTime: 2024-07-02 16:44:34
10052
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\settingRender.tsx
10053
+ *
10054
+ */
10055
+ var linkSettingRender = [
10056
+ {
10057
+ title: '自定义标题',
10058
+ child: [
10059
+ {
10060
+ type: 'Switch',
10061
+ label: '自定义标题开关',
10062
+ name: ['props', 'customTitle', 'display']
10063
+ },
10064
+ {
10065
+ type: 'Text',
10066
+ label: '标题文案',
10067
+ name: ['props', 'customTitle', 'text']
10068
+ },
10069
+ {
10070
+ type: 'Group',
10071
+ label: '尺寸',
10072
+ child: [
10073
+ {
10074
+ type: 'Number',
10075
+ name: ['props', 'customTitle', 'style', 'width'],
10076
+ addonAfter: 'W'
10077
+ },
10078
+ {
10079
+ type: 'Number',
10080
+ name: ['props', 'customTitle', 'style', 'height'],
10081
+ addonAfter: 'H'
10082
+ }
10083
+ ]
10084
+ },
10085
+ {
10086
+ type: 'Group',
10087
+ label: '圆角',
10088
+ child: [
10089
+ {
10090
+ type: 'Slider',
10091
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10092
+ max: 100
10093
+ },
10094
+ {
10095
+ type: 'Number',
10096
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10097
+ addonAfter: 'px',
10098
+ max: 100
10099
+ }
10100
+ ]
10101
+ },
10102
+ {
10103
+ type: 'Color',
10104
+ label: '背景色',
10105
+ name: ['props', 'customTitle', 'style', 'backgroundColor']
10106
+ },
10107
+ {
10108
+ type: 'Group',
10109
+ label: '字体',
10110
+ child: [
10111
+ {
10112
+ type: 'Select',
10113
+ name: ['props', 'customTitle', 'style', 'fontFamily-cn'],
10114
+ bottomText: '中文字体'
10115
+ },
10116
+ {
10117
+ type: 'Select',
10118
+ name: ['props', 'customTitle', 'style', 'fontFamily-en'],
10119
+ bottomText: '英文/其他字体'
10120
+ }
10121
+ ]
10122
+ },
10123
+ {
10124
+ type: 'Group',
10125
+ label: '',
10126
+ child: [
10127
+ {
10128
+ type: 'Color',
10129
+ name: ['props', 'customTitle', 'style', 'color']
10130
+ },
10131
+ {
10132
+ type: 'Number',
10133
+ addonAfter: 'px',
10134
+ name: ['props', 'customTitle', 'style', 'fontSize']
10135
+ }
10136
+ ]
10137
+ },
10138
+ {
10139
+ label: '样式',
10140
+ type: 'TextStyle',
10141
+ name: ['props', 'customTitle', 'style']
10142
+ },
10143
+ {
10144
+ label: '对齐',
10145
+ type: 'TextAlign',
10146
+ name: ['props', 'customTitle', 'style']
10147
+ },
10148
+ {
10149
+ label: '上边距',
10150
+ type: 'Number',
10151
+ name: ['props', 'customTitle', 'style', 'marginTop'],
10152
+ addonAfter: 'px'
10153
+ }
10154
+ ]
10155
+ }
10156
+ ];
10157
+
10158
+ var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU","one-line-ellipsis":"index-module_one-line-ellipsis__buFw1"};
10017
10159
 
10018
10160
  const Link$1 = (_a) => {
10019
- var _b, _c, _d, _e, _f, _g, _h;
10020
- var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index"]);
10161
+ var _b, _c, _d, _e, _f, _g, _h, _j;
10162
+ var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index, customTitle } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index", "customTitle"]);
10021
10163
  const { sxpParameter, bffEventReport } = useSxpDataSource();
10022
10164
  const { jumpToWeb } = useEventReport();
10023
10165
  const cta = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindCta;
@@ -10037,27 +10179,24 @@ const Link$1 = (_a) => {
10037
10179
  width: '100%',
10038
10180
  overflow: 'hidden'
10039
10181
  }) },
10040
- React.createElement("div", { className: styles$5['tow-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle, dangerouslySetInnerHTML: {
10041
- __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)
10042
- } }))));
10182
+ React.createElement("div", null,
10183
+ 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: {
10184
+ __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)
10185
+ } }),
10186
+ (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: {
10187
+ __html: setFontForText(customTitle === null || customTitle === void 0 ? void 0 : customTitle.text, customTitle === null || customTitle === void 0 ? void 0 : customTitle.style)
10188
+ } }))))));
10043
10189
  };
10044
10190
  var LinkComponent = React.memo(Link$1);
10045
10191
 
10046
- /*
10047
- * @Author: binruan@chatlabs.com
10048
- * @Date: 2023-07-28 18:29:57
10049
- * @LastEditors: binruan@chatlabs.com
10050
- * @LastEditTime: 2024-03-29 17:04:57
10051
- * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\material.tsx
10052
- *
10053
- */
10192
+ var _a;
10054
10193
  const Link = createMaterial(LinkComponent, {
10055
10194
  displayName: '跳转指引',
10056
10195
  icon: '',
10057
10196
  category: 'template',
10058
10197
  type: 'Link',
10059
10198
  related: {
10060
- settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
10199
+ 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),
10061
10200
  bindableProps: []
10062
10201
  },
10063
10202
  defaulSetting: {
@@ -10076,6 +10215,18 @@ const Link = createMaterial(LinkComponent, {
10076
10215
  width: 130,
10077
10216
  height: 20
10078
10217
  }
10218
+ },
10219
+ customTitle: {
10220
+ style: {
10221
+ textAlign: 'left',
10222
+ textDecoration: 'underline',
10223
+ fontWeight: 'bold',
10224
+ width: 130,
10225
+ height: 20,
10226
+ fontSize: 12,
10227
+ color: '#000'
10228
+ },
10229
+ text: '探索更多'
10079
10230
  }
10080
10231
  },
10081
10232
  style: {
@@ -13083,7 +13234,29 @@ var LikeButton$1 = React.memo(LikeButton);
13083
13234
 
13084
13235
  var img$1 = "";
13085
13236
 
13086
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13237
+ const mountVideoPlayerAtNode = (() => {
13238
+ if (typeof document === 'undefined')
13239
+ return;
13240
+ const playerContainer = document.createElement('div');
13241
+ const dom = ReactDOM.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13242
+ backgroundColor: 'transparent',
13243
+ width: '100%',
13244
+ height: '100%',
13245
+ objectFit: 'cover',
13246
+ pointerEvents: 'none'
13247
+ } }), playerContainer);
13248
+ // 播放器的挂载节点
13249
+ return (domNode) => {
13250
+ if (!domNode)
13251
+ return;
13252
+ domNode.innerHTML = '';
13253
+ domNode.appendChild(dom);
13254
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13255
+ return videoPlayerWrapperNode;
13256
+ };
13257
+ })();
13258
+
13259
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13087
13260
  const [isPauseVideo, setIsPauseVideo] = React.useState(false);
13088
13261
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13089
13262
  const videoStartTime = React.useRef(0);
@@ -13093,6 +13266,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13093
13266
  const canvasRef = React.useRef(null);
13094
13267
  const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
13095
13268
  const [waiting, setWaiting] = React.useState(false);
13269
+ const videoRef = React.useRef();
13096
13270
  const videoId = `pb-cache-video-${index}`;
13097
13271
  const videoEleRef = React.useRef(null);
13098
13272
  const blur = React.useMemo(() => {
@@ -13123,56 +13297,57 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13123
13297
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13124
13298
  }, [videoPostConfig, isBgColor]);
13125
13299
  React.useEffect(() => {
13126
- if (!videoRef)
13300
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13127
13301
  return;
13128
- videoRef.muted = muted;
13129
- }, [muted, videoRef]);
13302
+ videoRef.current.muted = muted;
13303
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13130
13304
  const handlePlay = React.useCallback(() => {
13131
- if (!videoRef)
13305
+ var _a;
13306
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13132
13307
  return;
13133
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13134
- }, [videoRef]);
13308
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13309
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13135
13310
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13136
13311
  const handlePlaying = React.useCallback(() => {
13137
- if (!videoRef)
13312
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13138
13313
  return;
13139
13314
  setWaiting(false);
13140
13315
  setIsLoadFinish(true);
13141
13316
  }, []);
13142
13317
  const handleStartPlay = React.useCallback(() => {
13143
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13144
- if (!videoRef)
13318
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13319
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13145
13320
  return;
13146
13321
  setIsPauseVideo(false);
13147
13322
  const item = data[index];
13148
- if (item && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration)) {
13149
- videoStartTime.current = (videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) || 0;
13150
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13151
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13323
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13324
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13325
+ 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);
13326
+ 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);
13152
13327
  const playType = isFirstPlay ? '0' : '1';
13153
13328
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13154
13329
  eventInfo: {
13155
13330
  eventSubject: 'playVideo',
13156
13331
  eventDescription: 'User played the video',
13157
- 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 : '',
13158
- 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 : '',
13332
+ 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 : '',
13333
+ 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 : '',
13159
13334
  playType,
13160
13335
  startTime: videoCurrentTime,
13161
13336
  videoDuration,
13162
- 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 : []),
13337
+ 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 : []),
13163
13338
  position: index + '',
13164
13339
  contentFormat: 'video',
13165
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13340
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13166
13341
  }
13167
13342
  });
13168
13343
  setIsFirstPlay(false);
13169
13344
  }
13170
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13345
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13171
13346
  const handLoadeddata = React.useCallback(() => {
13172
13347
  var _a;
13173
- if (!videoRef || firstFrameSrc || !blur)
13348
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13174
13349
  return;
13175
- videoRef.style.objectFit = 'contain';
13350
+ videoRef.current.style.objectFit = 'contain';
13176
13351
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13177
13352
  return;
13178
13353
  const setFrameImg = () => {
@@ -13182,158 +13357,163 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13182
13357
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13183
13358
  canvas.height = targetHeight;
13184
13359
  canvas.width = targetWidth;
13185
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13360
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13186
13361
  setFirstFrameSrc(canvas.toDataURL());
13187
13362
  };
13188
13363
  setFrameImg();
13189
13364
  setTimeout(() => {
13190
13365
  setFrameImg();
13191
13366
  }, 500);
13192
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13367
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13193
13368
  const handleLoadedmetadata = React.useCallback(() => {
13194
- if (!videoRef)
13369
+ if (!videoRef.current)
13195
13370
  return;
13196
13371
  handleStartPlay();
13197
13372
  handLoadeddata();
13198
- }, [videoRef, handLoadeddata, handleStartPlay]);
13373
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13199
13374
  const handleClickVideo = React.useCallback((type) => () => {
13200
- if (!videoRef)
13375
+ var _a, _b, _c, _d, _e;
13376
+ if (!videoRef.current)
13201
13377
  return;
13202
13378
  if (!isLoadFinish)
13203
13379
  return;
13204
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13380
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13205
13381
  switch (type) {
13206
13382
  case 'start':
13207
13383
  if (!isPause)
13208
13384
  return;
13209
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13385
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13210
13386
  setIsPauseVideo(false);
13211
13387
  break;
13212
13388
  case 'pause':
13213
13389
  if (isPause)
13214
13390
  return;
13215
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13391
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13216
13392
  setIsPauseVideo(true);
13217
13393
  break;
13218
13394
  default:
13219
13395
  if (isPause) {
13220
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13396
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13221
13397
  }
13222
13398
  else {
13223
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13399
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13224
13400
  }
13225
13401
  setIsPauseVideo(!isPause);
13226
13402
  break;
13227
13403
  }
13228
- }, [isLoadFinish, videoRef]);
13404
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13229
13405
  const handlePause = React.useCallback(() => {
13230
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13231
- if (!videoRef)
13406
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13407
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13232
13408
  return;
13233
13409
  if (activeIndex !== index)
13234
13410
  return;
13235
13411
  const item = data[index];
13236
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13237
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13238
- if (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) {
13239
- const playDuration = ((videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) - videoStartTime.current).toFixed(2);
13412
+ 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);
13413
+ 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);
13414
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13415
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13240
13416
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13241
13417
  eventInfo: {
13242
13418
  eventSubject: 'playOverVideo',
13243
13419
  eventDescription: 'User finished playing the video',
13244
- 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 : '',
13245
- 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 : '',
13420
+ 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 : '',
13421
+ 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 : '',
13246
13422
  endTime: videoCurrentTime,
13247
13423
  videoDuration,
13248
13424
  playDuration,
13249
- 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 : []),
13425
+ 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 : []),
13250
13426
  position: index + '',
13251
13427
  contentFormat: 'video',
13252
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13428
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13253
13429
  }
13254
13430
  });
13255
13431
  }
13256
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13432
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13257
13433
  const handleWaiting = React.useCallback(() => {
13258
13434
  setWaiting(true);
13259
13435
  }, []);
13260
13436
  React.useEffect(() => {
13261
- if (!isActive || !videoRef)
13437
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13438
+ if (!isActive)
13262
13439
  return;
13263
13440
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13264
13441
  if (!videoSrc)
13265
13442
  return;
13443
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13444
+ if (!videoPlayerWrapperNode)
13445
+ return;
13446
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13447
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13448
+ return;
13266
13449
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13267
13450
  let hls = null;
13268
13451
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13269
13452
  hls = new Hls();
13270
13453
  hls.loadSource(videoSrc);
13271
- hls.attachMedia(videoRef);
13454
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13272
13455
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13273
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13456
+ var _a;
13457
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13274
13458
  });
13275
13459
  }
13276
13460
  else {
13277
- videoRef.src = videoSrc;
13278
- }
13279
- const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13280
- const dom = document.querySelector('#player-container-id');
13281
- const dom2 = document.querySelector('#player-container-id-copy');
13282
- if (!dom && !dom2)
13283
- return;
13284
- videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
13285
- videoRef.setAttribute('x5-playsinline', 'true');
13286
- videoRef.setAttribute('webkit-playsinline', 'true');
13287
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadedmetadata', handleLoadedmetadata);
13288
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadeddata', handLoadeddata);
13289
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('play', handleStartPlay);
13290
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('playing', handlePlaying);
13291
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('pause', handlePause);
13292
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('ended', handlePlay);
13293
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('canplay', handlePlay);
13294
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('waiting', handleWaiting);
13461
+ videoRef.current.src = videoSrc;
13462
+ }
13463
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13464
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13465
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13466
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13467
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13468
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13469
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13470
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13471
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13472
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13295
13473
  return () => {
13474
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13296
13475
  if (hls)
13297
13476
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13298
13477
  setIsLoadFinish(false);
13299
- dom2 === null || dom2 === void 0 ? void 0 : dom2.appendChild(dom);
13300
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadedmetadata', handleLoadedmetadata);
13301
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadeddata', handLoadeddata);
13302
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('play', handleStartPlay);
13303
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('playing', handlePlaying);
13304
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('pause', handlePause);
13305
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('ended', handlePlay);
13306
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('canplay', handlePlay);
13307
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('waiting', handleWaiting);
13478
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13479
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13480
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13481
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13482
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13483
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13484
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13485
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13308
13486
  };
13309
- }, [isActive, videoId, rec, videoRef]);
13487
+ }, [isActive, videoId, rec]);
13310
13488
  React.useEffect(() => {
13311
- if (!videoRef || !isLoadFinish)
13489
+ var _a, _b;
13490
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13312
13491
  return;
13313
13492
  if (isActive) {
13314
13493
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13315
13494
  eventName: 'ViewContent'
13316
13495
  });
13317
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13496
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13318
13497
  }
13319
13498
  else {
13320
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13499
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13321
13500
  }
13322
- }, [isActive, isLoadFinish, videoRef]);
13501
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13323
13502
  /*
13324
13503
  打开/关闭hashtag暂停/播放视频
13325
13504
  */
13326
13505
  React.useEffect(() => {
13327
- if (!isActive || !videoRef)
13506
+ var _a, _b, _c;
13507
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13328
13508
  return;
13329
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13509
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13330
13510
  if (!isPause && openHashtag) {
13331
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13511
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13332
13512
  }
13333
13513
  else if (!openHashtag) {
13334
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13514
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13335
13515
  }
13336
- }, [openHashtag, isActive, videoRef]);
13516
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13337
13517
  React.useEffect(() => {
13338
13518
  if (!isActive)
13339
13519
  return;
@@ -13380,11 +13560,11 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13380
13560
  }, src: img$1, alt: 'placeholder image' }));
13381
13561
  }, [waiting, isLoadFinish]);
13382
13562
  React.useEffect(() => {
13383
- if (!videoRef)
13563
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13384
13564
  return;
13385
13565
  const handleBeforeUnload = () => {
13386
13566
  var _a;
13387
- if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && videoRef && !isPauseVideo) {
13567
+ 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) {
13388
13568
  handleClickVideo('pause')();
13389
13569
  }
13390
13570
  };
@@ -13392,7 +13572,7 @@ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPost
13392
13572
  return () => {
13393
13573
  window.removeEventListener('beforeunload', handleBeforeUnload);
13394
13574
  };
13395
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13575
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13396
13576
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13397
13577
  return null;
13398
13578
  }
@@ -13521,11 +13701,11 @@ const Picture = (props) => {
13521
13701
  * @Author: lewinlu@chatlabs.com
13522
13702
  * @Date: 2024-01-03 14:39:09
13523
13703
  * @LastEditors: binruan@chatlabs.com
13524
- * @LastEditTime: 2024-06-07 14:05:08
13704
+ * @LastEditTime: 2024-07-02 18:25:17
13525
13705
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
13526
13706
  */
13527
13707
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
13528
- var _a;
13708
+ var _a, _b;
13529
13709
  const ref = React.useRef();
13530
13710
  const { isActive } = useSwiperSlide();
13531
13711
  const { sxpParameter, openHashtag } = useSxpDataSource();
@@ -13552,7 +13732,14 @@ const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageE
13552
13732
  // if (!isActive) {
13553
13733
  // return <img src={sxpParameter?.placeholder_image} style={{ width, height, objectFit: 'cover' }} />;
13554
13734
  // }
13555
- 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) => {
13735
+ return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: {
13736
+ clickable: true,
13737
+ bulletActiveClass: 'swipe-item-active-bullet'
13738
+ }, className: css.css(Object.assign({}, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) && {
13739
+ '.swiper-pagination': {
13740
+ bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0
13741
+ }
13742
+ }))), 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) => {
13556
13743
  return (React.createElement(SwiperSlide, { key: index },
13557
13744
  React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
13558
13745
  })));
@@ -13717,12 +13904,12 @@ var RenderCard$1 = React.memo(RenderCard);
13717
13904
  * @Author: binruan@chatlabs.com
13718
13905
  * @Date: 2024-03-26 10:07:41
13719
13906
  * @LastEditors: binruan@chatlabs.com
13720
- * @LastEditTime: 2024-05-23 14:31:12
13907
+ * @LastEditTime: 2024-07-03 10:07:29
13721
13908
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13722
13909
  *
13723
13910
  */
13724
13911
  const Nudge = ({ nudge }) => {
13725
- var _a, _b, _c, _d, _e, _f, _g;
13912
+ var _a, _b, _c, _d, _e, _f;
13726
13913
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13727
13914
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13728
13915
  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,
@@ -13731,7 +13918,9 @@ const Nudge = ({ nudge }) => {
13731
13918
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13732
13919
  } },
13733
13920
  (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,
13734
- 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 : '')))));
13921
+ 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: {
13922
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13923
+ } })))));
13735
13924
  };
13736
13925
 
13737
13926
  /*
@@ -13794,7 +13983,7 @@ var Tagbar$1 = React.memo(Tagbar);
13794
13983
  * @Author: binruan@chatlabs.com
13795
13984
  * @Date: 2024-01-15 19:03:09
13796
13985
  * @LastEditors: binruan@chatlabs.com
13797
- * @LastEditTime: 2024-06-28 14:53:42
13986
+ * @LastEditTime: 2024-07-02 17:55:40
13798
13987
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13799
13988
  *
13800
13989
  */
@@ -13803,14 +13992,12 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13803
13992
  const { schema } = useEditor();
13804
13993
  const [activeIndex, setActiveIndex] = React.useState(0);
13805
13994
  const viewImageStartTime = React.useRef(0);
13806
- React.useState(false);
13807
13995
  const [isMuted, setIsMuted] = React.useState(true);
13808
13996
  const viewTime = React.useRef();
13809
13997
  const [isLoadMore, setIsLoadMore] = React.useState(false);
13810
13998
  const [isShowMore, setIsShowMore] = React.useState(false);
13811
13999
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13812
14000
  const { backMainFeed } = useEventReport();
13813
- const videoRef = React.useRef();
13814
14001
  const { productView } = useEventReport();
13815
14002
  const isShowFingerTip = React.useMemo(() => {
13816
14003
  return data.length > 0 && !loading && getFeUserId();
@@ -13838,16 +14025,6 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13838
14025
  });
13839
14026
  }
13840
14027
  }, [data.length, bffFbReport, h5EnterLink]);
13841
- const firstRef = React.useRef();
13842
- React.useEffect(() => {
13843
- var _a, _b, _c, _d;
13844
- if (!firstRef.current && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && (data === null || data === void 0 ? void 0 : data.length) > 0) {
13845
- firstRef.current = true;
13846
- 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) {
13847
- 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;
13848
- }
13849
- }
13850
- }, [videoRef, data]);
13851
14028
  React.useEffect(() => {
13852
14029
  var _a;
13853
14030
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13968,7 +14145,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13968
14145
  const renderContent = React.useCallback((rec, index) => {
13969
14146
  var _a, _b, _c, _d;
13970
14147
  if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) {
13971
- 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 }));
14148
+ 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 }));
13972
14149
  }
13973
14150
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13974
14151
  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 }));
@@ -13994,8 +14171,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
13994
14171
  viewTime,
13995
14172
  tipText,
13996
14173
  resolver,
13997
- schema,
13998
- videoRef.current
14174
+ schema
13999
14175
  ]);
14000
14176
  const onExpandableChange = React.useCallback((v) => {
14001
14177
  setIsShowMore(v);
@@ -14228,16 +14404,7 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
14228
14404
  [(_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
14229
14405
  }, 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 }),
14230
14406
  renderView),
14231
- 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
- React.createElement("div", { style: { position: 'absolute', zIndex: -100 } },
14233
- React.createElement("video", { ref: videoRef, id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
14234
- backgroundColor: 'transparent',
14235
- width: '100%',
14236
- height: '100%',
14237
- objectFit: 'cover',
14238
- pointerEvents: 'none'
14239
- } }),
14240
- React.createElement("div", { id: 'player-container-id-copy' }))));
14407
+ 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))));
14241
14408
  };
14242
14409
 
14243
14410
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {