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/pb-ui.js CHANGED
@@ -1106,7 +1106,7 @@
1106
1106
  * @Author: binruan@chatlabs.com
1107
1107
  * @Date: 2023-07-28 18:29:57
1108
1108
  * @LastEditors: binruan@chatlabs.com
1109
- * @LastEditTime: 2024-06-27 09:50:07
1109
+ * @LastEditTime: 2024-07-02 10:01:21
1110
1110
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
1111
1111
  *
1112
1112
  */
@@ -1130,12 +1130,12 @@
1130
1130
  child: [
1131
1131
  {
1132
1132
  type: 'Select',
1133
- name: ['testStyle', 'fontFamily-cn'],
1133
+ name: ['textStyle', 'fontFamily-cn'],
1134
1134
  bottomText: '中文字体'
1135
1135
  },
1136
1136
  {
1137
1137
  type: 'Select',
1138
- name: ['testStyle', 'fontFamily-en'],
1138
+ name: ['textStyle', 'fontFamily-en'],
1139
1139
  bottomText: '英文/其他字体'
1140
1140
  }
1141
1141
  ]
@@ -1362,7 +1362,7 @@
1362
1362
  * @Author: binruan@chatlabs.com
1363
1363
  * @Date: 2024-06-27 16:22:34
1364
1364
  * @LastEditors: binruan@chatlabs.com
1365
- * @LastEditTime: 2024-06-27 18:27:11
1365
+ * @LastEditTime: 2024-07-02 10:34:34
1366
1366
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\Form.tsx
1367
1367
  *
1368
1368
  */
@@ -8921,7 +8921,7 @@
8921
8921
  * @Author: binruan@chatlabs.com
8922
8922
  * @Date: 2023-10-27 14:06:35
8923
8923
  * @LastEditors: binruan@chatlabs.com
8924
- * @LastEditTime: 2024-06-27 09:57:31
8924
+ * @LastEditTime: 2024-07-02 09:58:06
8925
8925
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\Prompt\settingRender.tsx
8926
8926
  *
8927
8927
  */
@@ -8941,9 +8941,37 @@
8941
8941
  name: ['props', 'content']
8942
8942
  },
8943
8943
  {
8944
- type: 'Text',
8945
- label: '按钮文案',
8946
- name: ['props', 'btnText']
8944
+ type: 'Group',
8945
+ label: '内容字体',
8946
+ child: [
8947
+ {
8948
+ type: 'Select',
8949
+ name: ['props', 'contentStyle', 'fontFamily-cn'],
8950
+ bottomText: '中文字体'
8951
+ },
8952
+ {
8953
+ type: 'Select',
8954
+ name: ['props', 'contentStyle', 'fontFamily-en'],
8955
+ bottomText: '英文/其他字体'
8956
+ }
8957
+ ]
8958
+ },
8959
+ {
8960
+ type: 'Group',
8961
+ label: '',
8962
+ child: [
8963
+ {
8964
+ type: 'Color',
8965
+ name: ['props', 'contentStyle', 'color'],
8966
+ initialValue: '#000'
8967
+ },
8968
+ {
8969
+ type: 'Number',
8970
+ name: ['props', 'contentStyle', 'fontSize'],
8971
+ addonAfter: 'px',
8972
+ initialValue: 14
8973
+ }
8974
+ ]
8947
8975
  },
8948
8976
  {
8949
8977
  type: 'Group',
@@ -8989,7 +9017,8 @@
8989
9017
  {
8990
9018
  label: '提交按钮颜色',
8991
9019
  type: 'Color',
8992
- name: ['props', 'submitButtonStyle', 'backgroundColor']
9020
+ name: ['props', 'submitButtonStyle', 'backgroundColor'],
9021
+ initialValue: '#000'
8993
9022
  }
8994
9023
  ]
8995
9024
  }
@@ -9030,7 +9059,7 @@
9030
9059
  };
9031
9060
 
9032
9061
  const Prompt$1 = (_a) => {
9033
- var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle"]);
9062
+ var { content, btnText, style, icon, isPopup, isExternalLink, onClose, onClick, submitButtonStyle, contentStyle } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "isPopup", "isExternalLink", "onClose", "onClick", "submitButtonStyle", "contentStyle"]);
9034
9063
  const { popupDetailData } = useSxpDataSource();
9035
9064
  const { jumpToWeb } = useEventReport();
9036
9065
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
@@ -9051,7 +9080,9 @@
9051
9080
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
9052
9081
  React.createElement("div", { className: 'pb-prompt-icon' },
9053
9082
  React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3, alt: 'success image' })),
9054
- React.createElement("div", { className: 'pb-prompt-content' }, content),
9083
+ React.createElement("div", { className: 'pb-prompt-content', style: contentStyle, dangerouslySetInnerHTML: {
9084
+ __html: setFontForText(content, contentStyle)
9085
+ } }),
9055
9086
  React.createElement("button", { "aria-label": btnText, className: 'pb-prompt-btn', style: submitButtonStyle, onClick: handleOk, dangerouslySetInnerHTML: {
9056
9087
  __html: setFontForText(btnText, submitButtonStyle)
9057
9088
  } })));
@@ -10006,11 +10037,122 @@ Made in Italy` })));
10006
10037
  sort: 6
10007
10038
  });
10008
10039
 
10009
- var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU"};
10040
+ /*
10041
+ * @Author: binruan@chatlabs.com
10042
+ * @Date: 2024-07-02 14:51:32
10043
+ * @LastEditors: binruan@chatlabs.com
10044
+ * @LastEditTime: 2024-07-02 16:44:34
10045
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\settingRender.tsx
10046
+ *
10047
+ */
10048
+ var linkSettingRender = [
10049
+ {
10050
+ title: '自定义标题',
10051
+ child: [
10052
+ {
10053
+ type: 'Switch',
10054
+ label: '自定义标题开关',
10055
+ name: ['props', 'customTitle', 'display']
10056
+ },
10057
+ {
10058
+ type: 'Text',
10059
+ label: '标题文案',
10060
+ name: ['props', 'customTitle', 'text']
10061
+ },
10062
+ {
10063
+ type: 'Group',
10064
+ label: '尺寸',
10065
+ child: [
10066
+ {
10067
+ type: 'Number',
10068
+ name: ['props', 'customTitle', 'style', 'width'],
10069
+ addonAfter: 'W'
10070
+ },
10071
+ {
10072
+ type: 'Number',
10073
+ name: ['props', 'customTitle', 'style', 'height'],
10074
+ addonAfter: 'H'
10075
+ }
10076
+ ]
10077
+ },
10078
+ {
10079
+ type: 'Group',
10080
+ label: '圆角',
10081
+ child: [
10082
+ {
10083
+ type: 'Slider',
10084
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10085
+ max: 100
10086
+ },
10087
+ {
10088
+ type: 'Number',
10089
+ name: ['props', 'customTitle', 'style', 'borderRadius'],
10090
+ addonAfter: 'px',
10091
+ max: 100
10092
+ }
10093
+ ]
10094
+ },
10095
+ {
10096
+ type: 'Color',
10097
+ label: '背景色',
10098
+ name: ['props', 'customTitle', 'style', 'backgroundColor']
10099
+ },
10100
+ {
10101
+ type: 'Group',
10102
+ label: '字体',
10103
+ child: [
10104
+ {
10105
+ type: 'Select',
10106
+ name: ['props', 'customTitle', 'style', 'fontFamily-cn'],
10107
+ bottomText: '中文字体'
10108
+ },
10109
+ {
10110
+ type: 'Select',
10111
+ name: ['props', 'customTitle', 'style', 'fontFamily-en'],
10112
+ bottomText: '英文/其他字体'
10113
+ }
10114
+ ]
10115
+ },
10116
+ {
10117
+ type: 'Group',
10118
+ label: '',
10119
+ child: [
10120
+ {
10121
+ type: 'Color',
10122
+ name: ['props', 'customTitle', 'style', 'color']
10123
+ },
10124
+ {
10125
+ type: 'Number',
10126
+ addonAfter: 'px',
10127
+ name: ['props', 'customTitle', 'style', 'fontSize']
10128
+ }
10129
+ ]
10130
+ },
10131
+ {
10132
+ label: '样式',
10133
+ type: 'TextStyle',
10134
+ name: ['props', 'customTitle', 'style']
10135
+ },
10136
+ {
10137
+ label: '对齐',
10138
+ type: 'TextAlign',
10139
+ name: ['props', 'customTitle', 'style']
10140
+ },
10141
+ {
10142
+ label: '上边距',
10143
+ type: 'Number',
10144
+ name: ['props', 'customTitle', 'style', 'marginTop'],
10145
+ addonAfter: 'px'
10146
+ }
10147
+ ]
10148
+ }
10149
+ ];
10150
+
10151
+ var styles$5 = {"tow-line-ellipsis":"index-module_tow-line-ellipsis__nkBlU","one-line-ellipsis":"index-module_one-line-ellipsis__buFw1"};
10010
10152
 
10011
10153
  const Link$1 = (_a) => {
10012
- var _b, _c, _d, _e, _f, _g, _h;
10013
- var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index"]);
10154
+ var _b, _c, _d, _e, _f, _g, _h, _j;
10155
+ var { content, style, bgImg, recData, bottom_image, ctaTempStyles, index, customTitle } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "bottom_image", "ctaTempStyles", "index", "customTitle"]);
10014
10156
  const { sxpParameter, bffEventReport } = useSxpDataSource();
10015
10157
  const { jumpToWeb } = useEventReport();
10016
10158
  const cta = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindCta;
@@ -10030,27 +10172,24 @@ Made in Italy` })));
10030
10172
  width: '100%',
10031
10173
  overflow: 'hidden'
10032
10174
  }) },
10033
- React.createElement("div", { className: styles$5['tow-line-ellipsis'], style: ctaTempStyles === null || ctaTempStyles === void 0 ? void 0 : ctaTempStyles.ctaTitle, dangerouslySetInnerHTML: {
10034
- __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)
10035
- } }))));
10175
+ React.createElement("div", null,
10176
+ 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: {
10177
+ __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)
10178
+ } }),
10179
+ (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: {
10180
+ __html: setFontForText(customTitle === null || customTitle === void 0 ? void 0 : customTitle.text, customTitle === null || customTitle === void 0 ? void 0 : customTitle.style)
10181
+ } }))))));
10036
10182
  };
10037
10183
  var LinkComponent = React.memo(Link$1);
10038
10184
 
10039
- /*
10040
- * @Author: binruan@chatlabs.com
10041
- * @Date: 2023-07-28 18:29:57
10042
- * @LastEditors: binruan@chatlabs.com
10043
- * @LastEditTime: 2024-03-29 17:04:57
10044
- * @FilePath: \pb-sxp-ui\src\materials\sxp\template\Link\material.tsx
10045
- *
10046
- */
10185
+ var _a;
10047
10186
  const Link = createMaterial(LinkComponent, {
10048
10187
  displayName: '跳转指引',
10049
10188
  icon: '',
10050
10189
  category: 'template',
10051
10190
  type: 'Link',
10052
10191
  related: {
10053
- settingRender: settingRender$2 === null || settingRender$2 === void 0 ? void 0 : settingRender$2.filter((i) => i.type !== 'commodityTitle'),
10192
+ 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),
10054
10193
  bindableProps: []
10055
10194
  },
10056
10195
  defaulSetting: {
@@ -10069,6 +10208,18 @@ Made in Italy` })));
10069
10208
  width: 130,
10070
10209
  height: 20
10071
10210
  }
10211
+ },
10212
+ customTitle: {
10213
+ style: {
10214
+ textAlign: 'left',
10215
+ textDecoration: 'underline',
10216
+ fontWeight: 'bold',
10217
+ width: 130,
10218
+ height: 20,
10219
+ fontSize: 12,
10220
+ color: '#000'
10221
+ },
10222
+ text: '探索更多'
10072
10223
  }
10073
10224
  },
10074
10225
  style: {
@@ -13076,7 +13227,29 @@ Made in Italy` })));
13076
13227
 
13077
13228
  var img$1 = "";
13078
13229
 
13079
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13230
+ const mountVideoPlayerAtNode = (() => {
13231
+ if (typeof document === 'undefined')
13232
+ return;
13233
+ const playerContainer = document.createElement('div');
13234
+ const dom = ReactDOM.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13235
+ backgroundColor: 'transparent',
13236
+ width: '100%',
13237
+ height: '100%',
13238
+ objectFit: 'cover',
13239
+ pointerEvents: 'none'
13240
+ } }), playerContainer);
13241
+ // 播放器的挂载节点
13242
+ return (domNode) => {
13243
+ if (!domNode)
13244
+ return;
13245
+ domNode.innerHTML = '';
13246
+ domNode.appendChild(dom);
13247
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13248
+ return videoPlayerWrapperNode;
13249
+ };
13250
+ })();
13251
+
13252
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13080
13253
  const [isPauseVideo, setIsPauseVideo] = React.useState(false);
13081
13254
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13082
13255
  const videoStartTime = React.useRef(0);
@@ -13086,6 +13259,7 @@ Made in Italy` })));
13086
13259
  const canvasRef = React.useRef(null);
13087
13260
  const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
13088
13261
  const [waiting, setWaiting] = React.useState(false);
13262
+ const videoRef = React.useRef();
13089
13263
  const videoId = `pb-cache-video-${index}`;
13090
13264
  const videoEleRef = React.useRef(null);
13091
13265
  const blur = React.useMemo(() => {
@@ -13116,56 +13290,57 @@ Made in Italy` })));
13116
13290
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13117
13291
  }, [videoPostConfig, isBgColor]);
13118
13292
  React.useEffect(() => {
13119
- if (!videoRef)
13293
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13120
13294
  return;
13121
- videoRef.muted = muted;
13122
- }, [muted, videoRef]);
13295
+ videoRef.current.muted = muted;
13296
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13123
13297
  const handlePlay = React.useCallback(() => {
13124
- if (!videoRef)
13298
+ var _a;
13299
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13125
13300
  return;
13126
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13127
- }, [videoRef]);
13301
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13302
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13128
13303
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13129
13304
  const handlePlaying = React.useCallback(() => {
13130
- if (!videoRef)
13305
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13131
13306
  return;
13132
13307
  setWaiting(false);
13133
13308
  setIsLoadFinish(true);
13134
13309
  }, []);
13135
13310
  const handleStartPlay = React.useCallback(() => {
13136
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13137
- if (!videoRef)
13311
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13312
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13138
13313
  return;
13139
13314
  setIsPauseVideo(false);
13140
13315
  const item = data[index];
13141
- if (item && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration)) {
13142
- videoStartTime.current = (videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) || 0;
13143
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13144
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13316
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13317
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13318
+ 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);
13319
+ 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);
13145
13320
  const playType = isFirstPlay ? '0' : '1';
13146
13321
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13147
13322
  eventInfo: {
13148
13323
  eventSubject: 'playVideo',
13149
13324
  eventDescription: 'User played the video',
13150
- 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 : '',
13151
- 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 : '',
13325
+ 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 : '',
13326
+ 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 : '',
13152
13327
  playType,
13153
13328
  startTime: videoCurrentTime,
13154
13329
  videoDuration,
13155
- 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 : []),
13330
+ 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 : []),
13156
13331
  position: index + '',
13157
13332
  contentFormat: 'video',
13158
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13333
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13159
13334
  }
13160
13335
  });
13161
13336
  setIsFirstPlay(false);
13162
13337
  }
13163
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13338
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13164
13339
  const handLoadeddata = React.useCallback(() => {
13165
13340
  var _a;
13166
- if (!videoRef || firstFrameSrc || !blur)
13341
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13167
13342
  return;
13168
- videoRef.style.objectFit = 'contain';
13343
+ videoRef.current.style.objectFit = 'contain';
13169
13344
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13170
13345
  return;
13171
13346
  const setFrameImg = () => {
@@ -13175,158 +13350,163 @@ Made in Italy` })));
13175
13350
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13176
13351
  canvas.height = targetHeight;
13177
13352
  canvas.width = targetWidth;
13178
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13353
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13179
13354
  setFirstFrameSrc(canvas.toDataURL());
13180
13355
  };
13181
13356
  setFrameImg();
13182
13357
  setTimeout(() => {
13183
13358
  setFrameImg();
13184
13359
  }, 500);
13185
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13360
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13186
13361
  const handleLoadedmetadata = React.useCallback(() => {
13187
- if (!videoRef)
13362
+ if (!videoRef.current)
13188
13363
  return;
13189
13364
  handleStartPlay();
13190
13365
  handLoadeddata();
13191
- }, [videoRef, handLoadeddata, handleStartPlay]);
13366
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13192
13367
  const handleClickVideo = React.useCallback((type) => () => {
13193
- if (!videoRef)
13368
+ var _a, _b, _c, _d, _e;
13369
+ if (!videoRef.current)
13194
13370
  return;
13195
13371
  if (!isLoadFinish)
13196
13372
  return;
13197
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13373
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13198
13374
  switch (type) {
13199
13375
  case 'start':
13200
13376
  if (!isPause)
13201
13377
  return;
13202
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13378
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13203
13379
  setIsPauseVideo(false);
13204
13380
  break;
13205
13381
  case 'pause':
13206
13382
  if (isPause)
13207
13383
  return;
13208
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13384
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13209
13385
  setIsPauseVideo(true);
13210
13386
  break;
13211
13387
  default:
13212
13388
  if (isPause) {
13213
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13389
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13214
13390
  }
13215
13391
  else {
13216
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13392
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13217
13393
  }
13218
13394
  setIsPauseVideo(!isPause);
13219
13395
  break;
13220
13396
  }
13221
- }, [isLoadFinish, videoRef]);
13397
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13222
13398
  const handlePause = React.useCallback(() => {
13223
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13224
- if (!videoRef)
13399
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13400
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13225
13401
  return;
13226
13402
  if (activeIndex !== index)
13227
13403
  return;
13228
13404
  const item = data[index];
13229
- const videoDuration = ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) !== null && _a !== void 0 ? _a : 0).toFixed(2);
13230
- const videoCurrentTime = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13231
- if (videoRef === null || videoRef === void 0 ? void 0 : videoRef.duration) {
13232
- const playDuration = ((videoRef === null || videoRef === void 0 ? void 0 : videoRef.currentTime) - videoStartTime.current).toFixed(2);
13405
+ 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);
13406
+ 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);
13407
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13408
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13233
13409
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13234
13410
  eventInfo: {
13235
13411
  eventSubject: 'playOverVideo',
13236
13412
  eventDescription: 'User finished playing the video',
13237
- 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 : '',
13238
- 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 : '',
13413
+ 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 : '',
13414
+ 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 : '',
13239
13415
  endTime: videoCurrentTime,
13240
13416
  videoDuration,
13241
13417
  playDuration,
13242
- 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 : []),
13418
+ 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 : []),
13243
13419
  position: index + '',
13244
13420
  contentFormat: 'video',
13245
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13421
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13246
13422
  }
13247
13423
  });
13248
13424
  }
13249
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13425
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13250
13426
  const handleWaiting = React.useCallback(() => {
13251
13427
  setWaiting(true);
13252
13428
  }, []);
13253
13429
  React.useEffect(() => {
13254
- if (!isActive || !videoRef)
13430
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13431
+ if (!isActive)
13255
13432
  return;
13256
13433
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13257
13434
  if (!videoSrc)
13258
13435
  return;
13436
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13437
+ if (!videoPlayerWrapperNode)
13438
+ return;
13439
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13440
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13441
+ return;
13259
13442
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13260
13443
  let hls = null;
13261
13444
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13262
13445
  hls = new Hls();
13263
13446
  hls.loadSource(videoSrc);
13264
- hls.attachMedia(videoRef);
13447
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13265
13448
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13266
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13449
+ var _a;
13450
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13267
13451
  });
13268
13452
  }
13269
13453
  else {
13270
- videoRef.src = videoSrc;
13271
- }
13272
- const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13273
- const dom = document.querySelector('#player-container-id');
13274
- const dom2 = document.querySelector('#player-container-id-copy');
13275
- if (!dom && !dom2)
13276
- return;
13277
- videoPlayerWrapperNode === null || videoPlayerWrapperNode === void 0 ? void 0 : videoPlayerWrapperNode.appendChild(dom || dom2);
13278
- videoRef.setAttribute('x5-playsinline', 'true');
13279
- videoRef.setAttribute('webkit-playsinline', 'true');
13280
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadedmetadata', handleLoadedmetadata);
13281
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('loadeddata', handLoadeddata);
13282
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('play', handleStartPlay);
13283
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('playing', handlePlaying);
13284
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('pause', handlePause);
13285
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('ended', handlePlay);
13286
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('canplay', handlePlay);
13287
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.addEventListener('waiting', handleWaiting);
13454
+ videoRef.current.src = videoSrc;
13455
+ }
13456
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13457
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13458
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13459
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13460
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13461
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13462
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13463
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13464
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13465
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13288
13466
  return () => {
13467
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13289
13468
  if (hls)
13290
13469
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13291
13470
  setIsLoadFinish(false);
13292
- dom2 === null || dom2 === void 0 ? void 0 : dom2.appendChild(dom);
13293
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadedmetadata', handleLoadedmetadata);
13294
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('loadeddata', handLoadeddata);
13295
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('play', handleStartPlay);
13296
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('playing', handlePlaying);
13297
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('pause', handlePause);
13298
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('ended', handlePlay);
13299
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('canplay', handlePlay);
13300
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.removeEventListener('waiting', handleWaiting);
13471
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13472
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13473
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13474
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13475
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13476
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13477
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13478
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13301
13479
  };
13302
- }, [isActive, videoId, rec, videoRef]);
13480
+ }, [isActive, videoId, rec]);
13303
13481
  React.useEffect(() => {
13304
- if (!videoRef || !isLoadFinish)
13482
+ var _a, _b;
13483
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13305
13484
  return;
13306
13485
  if (isActive) {
13307
13486
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13308
13487
  eventName: 'ViewContent'
13309
13488
  });
13310
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13489
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13311
13490
  }
13312
13491
  else {
13313
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13492
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13314
13493
  }
13315
- }, [isActive, isLoadFinish, videoRef]);
13494
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13316
13495
  /*
13317
13496
  打开/关闭hashtag暂停/播放视频
13318
13497
  */
13319
13498
  React.useEffect(() => {
13320
- if (!isActive || !videoRef)
13499
+ var _a, _b, _c;
13500
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13321
13501
  return;
13322
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13502
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13323
13503
  if (!isPause && openHashtag) {
13324
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13504
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13325
13505
  }
13326
13506
  else if (!openHashtag) {
13327
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13507
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13328
13508
  }
13329
- }, [openHashtag, isActive, videoRef]);
13509
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13330
13510
  React.useEffect(() => {
13331
13511
  if (!isActive)
13332
13512
  return;
@@ -13373,11 +13553,11 @@ Made in Italy` })));
13373
13553
  }, src: img$1, alt: 'placeholder image' }));
13374
13554
  }, [waiting, isLoadFinish]);
13375
13555
  React.useEffect(() => {
13376
- if (!videoRef)
13556
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13377
13557
  return;
13378
13558
  const handleBeforeUnload = () => {
13379
13559
  var _a;
13380
- if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && videoRef && !isPauseVideo) {
13560
+ 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) {
13381
13561
  handleClickVideo('pause')();
13382
13562
  }
13383
13563
  };
@@ -13385,7 +13565,7 @@ Made in Italy` })));
13385
13565
  return () => {
13386
13566
  window.removeEventListener('beforeunload', handleBeforeUnload);
13387
13567
  };
13388
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13568
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13389
13569
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13390
13570
  return null;
13391
13571
  }
@@ -13514,11 +13694,11 @@ Made in Italy` })));
13514
13694
  * @Author: lewinlu@chatlabs.com
13515
13695
  * @Date: 2024-01-03 14:39:09
13516
13696
  * @LastEditors: binruan@chatlabs.com
13517
- * @LastEditTime: 2024-06-07 14:05:08
13697
+ * @LastEditTime: 2024-07-02 18:25:17
13518
13698
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\PictureGroup\index.tsx
13519
13699
  */
13520
13700
  const PictureGroup$2 = ({ imgUrls, width, height, rec, index, onReportViewImageEnd, onViewImageStartEvent, imgUrlsPostConfig }) => {
13521
- var _a;
13701
+ var _a, _b;
13522
13702
  const ref = React.useRef();
13523
13703
  const { isActive } = useSwiperSlide();
13524
13704
  const { sxpParameter, openHashtag } = useSxpDataSource();
@@ -13545,7 +13725,14 @@ Made in Italy` })));
13545
13725
  // if (!isActive) {
13546
13726
  // return <img src={sxpParameter?.placeholder_image} style={{ width, height, objectFit: 'cover' }} />;
13547
13727
  // }
13548
- 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) => {
13728
+ return (React.createElement(Swiper, { ref: ref, defaultValue: 0, direction: 'horizontal', modules: [Pagination, Autoplay], pagination: {
13729
+ clickable: true,
13730
+ bulletActiveClass: 'swipe-item-active-bullet'
13731
+ }, className: css.css(Object.assign({}, ((imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) && {
13732
+ '.swiper-pagination': {
13733
+ bottom: (_a = imgUrlsPostConfig === null || imgUrlsPostConfig === void 0 ? void 0 : imgUrlsPostConfig.marginBottom) !== null && _a !== void 0 ? _a : 0
13734
+ }
13735
+ }))), 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) => {
13549
13736
  return (React.createElement(SwiperSlide, { key: index },
13550
13737
  React.createElement(Picture, { src: !isLoad && index > 0 ? '' : url, height: height, imgUrlsPostConfig: imgUrlsPostConfig, onShowFirstImage: showFirstImageFn })));
13551
13738
  })));
@@ -13710,12 +13897,12 @@ Made in Italy` })));
13710
13897
  * @Author: binruan@chatlabs.com
13711
13898
  * @Date: 2024-03-26 10:07:41
13712
13899
  * @LastEditors: binruan@chatlabs.com
13713
- * @LastEditTime: 2024-05-23 14:31:12
13900
+ * @LastEditTime: 2024-07-03 10:07:29
13714
13901
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13715
13902
  *
13716
13903
  */
13717
13904
  const Nudge = ({ nudge }) => {
13718
- var _a, _b, _c, _d, _e, _f, _g;
13905
+ var _a, _b, _c, _d, _e, _f;
13719
13906
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13720
13907
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13721
13908
  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,
@@ -13724,7 +13911,9 @@ Made in Italy` })));
13724
13911
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13725
13912
  } },
13726
13913
  (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,
13727
- 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 : '')))));
13914
+ 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: {
13915
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13916
+ } })))));
13728
13917
  };
13729
13918
 
13730
13919
  /*
@@ -13787,7 +13976,7 @@ Made in Italy` })));
13787
13976
  * @Author: binruan@chatlabs.com
13788
13977
  * @Date: 2024-01-15 19:03:09
13789
13978
  * @LastEditors: binruan@chatlabs.com
13790
- * @LastEditTime: 2024-06-28 14:53:42
13979
+ * @LastEditTime: 2024-07-02 17:55:40
13791
13980
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13792
13981
  *
13793
13982
  */
@@ -13796,14 +13985,12 @@ Made in Italy` })));
13796
13985
  const { schema } = useEditor();
13797
13986
  const [activeIndex, setActiveIndex] = React.useState(0);
13798
13987
  const viewImageStartTime = React.useRef(0);
13799
- React.useState(false);
13800
13988
  const [isMuted, setIsMuted] = React.useState(true);
13801
13989
  const viewTime = React.useRef();
13802
13990
  const [isLoadMore, setIsLoadMore] = React.useState(false);
13803
13991
  const [isShowMore, setIsShowMore] = React.useState(false);
13804
13992
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13805
13993
  const { backMainFeed } = useEventReport();
13806
- const videoRef = React.useRef();
13807
13994
  const { productView } = useEventReport();
13808
13995
  const isShowFingerTip = React.useMemo(() => {
13809
13996
  return data.length > 0 && !loading && getFeUserId();
@@ -13831,16 +14018,6 @@ Made in Italy` })));
13831
14018
  });
13832
14019
  }
13833
14020
  }, [data.length, bffFbReport, h5EnterLink]);
13834
- const firstRef = React.useRef();
13835
- React.useEffect(() => {
13836
- var _a, _b, _c, _d;
13837
- if (!firstRef.current && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && (data === null || data === void 0 ? void 0 : data.length) > 0) {
13838
- firstRef.current = true;
13839
- 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) {
13840
- 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;
13841
- }
13842
- }
13843
- }, [videoRef, data]);
13844
14021
  React.useEffect(() => {
13845
14022
  var _a;
13846
14023
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13961,7 +14138,7 @@ Made in Italy` })));
13961
14138
  const renderContent = React.useCallback((rec, index) => {
13962
14139
  var _a, _b, _c, _d;
13963
14140
  if ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) {
13964
- return (React.createElement(VideoWidget$3, { rec: rec, index: index, muted: isMuted, data: data, height: height, activeIndex: activeIndex, videoPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPost, videoRef: videoRef.current, videoPlayIcon: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPlayIcon }));
14141
+ return (React.createElement(VideoWidget$3, { rec: rec, index: index, muted: isMuted, data: data, height: height, activeIndex: activeIndex, videoPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPost, videoPlayIcon: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPlayIcon }));
13965
14142
  }
13966
14143
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13967
14144
  return (React.createElement(PictureGroup$3, { key: rec === null || rec === void 0 ? void 0 : rec.video.itemId, imgUrls: rec === null || rec === void 0 ? void 0 : rec.video.imgUrls, width: containerWidth, height: height, rec: rec, index: index, onReportViewImageEnd: handleReportViewImageEnd, onViewImageStartEvent: handleViewImageStartEvent, imgUrlsPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.imgUrlsPost }));
@@ -13987,8 +14164,7 @@ Made in Italy` })));
13987
14164
  viewTime,
13988
14165
  tipText,
13989
14166
  resolver,
13990
- schema,
13991
- videoRef.current
14167
+ schema
13992
14168
  ]);
13993
14169
  const onExpandableChange = React.useCallback((v) => {
13994
14170
  setIsShowMore(v);
@@ -14221,16 +14397,7 @@ Made in Italy` })));
14221
14397
  [(_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
14222
14398
  }, 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 }),
14223
14399
  renderView),
14224
- React.createElement(WaterFall$1, Object.assign({}, (_k = (_j = (_h = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _h === void 0 ? void 0 : _h[0]) === null || _j === void 0 ? void 0 : _j.item) === null || _k === void 0 ? void 0 : _k.props)),
14225
- React.createElement("div", { style: { position: 'absolute', zIndex: -100 } },
14226
- React.createElement("video", { ref: videoRef, id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
14227
- backgroundColor: 'transparent',
14228
- width: '100%',
14229
- height: '100%',
14230
- objectFit: 'cover',
14231
- pointerEvents: 'none'
14232
- } }),
14233
- React.createElement("div", { id: 'player-container-id-copy' }))));
14400
+ 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))));
14234
14401
  };
14235
14402
 
14236
14403
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {