pb-sxp-ui 1.0.101 → 1.0.102

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/dist/index.cjs +166 -126
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +10 -3
  4. package/dist/index.js +167 -126
  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 +166 -126
  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/VideoWidget/VideoPlayer.d.ts +1 -0
  17. package/es/core/components/SxpPageRender/VideoWidget/VideoPlayer.js +22 -0
  18. package/es/core/components/SxpPageRender/VideoWidget/index.d.ts +0 -1
  19. package/es/core/components/SxpPageRender/VideoWidget/index.js +93 -85
  20. package/es/core/components/SxpPageRender/index.js +3 -25
  21. package/es/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  22. package/es/materials/sxp/popup/Prompt/index.d.ts +1 -0
  23. package/es/materials/sxp/popup/Prompt/index.js +4 -2
  24. package/es/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  25. package/es/materials/sxp/popup/Prompt/settingRender.js +33 -4
  26. package/lib/core/components/SxpPageRender/Nudge/index.d.ts +2 -0
  27. package/lib/core/components/SxpPageRender/Nudge/index.js +5 -2
  28. package/lib/core/components/SxpPageRender/VideoWidget/VideoPlayer.d.ts +1 -0
  29. package/lib/core/components/SxpPageRender/VideoWidget/VideoPlayer.js +26 -0
  30. package/lib/core/components/SxpPageRender/VideoWidget/index.d.ts +0 -1
  31. package/lib/core/components/SxpPageRender/VideoWidget/index.js +93 -85
  32. package/lib/core/components/SxpPageRender/index.js +3 -25
  33. package/lib/materials/sxp/popup/AppointForm/settingRender.js +2 -2
  34. package/lib/materials/sxp/popup/Prompt/index.d.ts +1 -0
  35. package/lib/materials/sxp/popup/Prompt/index.js +4 -2
  36. package/lib/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  37. package/lib/materials/sxp/popup/Prompt/settingRender.js +33 -4
  38. 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
  } })));
@@ -13076,7 +13107,29 @@ Made in Italy` })));
13076
13107
 
13077
13108
  var img$1 = "";
13078
13109
 
13079
- const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoRef, videoPlayIcon }) => {
13110
+ const mountVideoPlayerAtNode = (() => {
13111
+ if (typeof document === 'undefined')
13112
+ return;
13113
+ const playerContainer = document.createElement('div');
13114
+ const dom = ReactDOM.render(React.createElement("video", { id: 'player-container-id', playsInline: true, crossOrigin: 'anonymous', preload: 'auto', controls: false, muted: true, style: {
13115
+ backgroundColor: 'transparent',
13116
+ width: '100%',
13117
+ height: '100%',
13118
+ objectFit: 'cover',
13119
+ pointerEvents: 'none'
13120
+ } }), playerContainer);
13121
+ // 播放器的挂载节点
13122
+ return (domNode) => {
13123
+ if (!domNode)
13124
+ return;
13125
+ domNode.innerHTML = '';
13126
+ domNode.appendChild(dom);
13127
+ const videoPlayerWrapperNode = document.querySelector(`#player-container-id`);
13128
+ return videoPlayerWrapperNode;
13129
+ };
13130
+ })();
13131
+
13132
+ const VideoWidget$2 = ({ rec, index, height, data, muted, activeIndex, videoPostConfig, videoPlayIcon }) => {
13080
13133
  const [isPauseVideo, setIsPauseVideo] = React.useState(false);
13081
13134
  const { bffEventReport, sxpParameter, waterFallData, openHashtag, bffFbReport } = useSxpDataSource();
13082
13135
  const videoStartTime = React.useRef(0);
@@ -13086,6 +13139,7 @@ Made in Italy` })));
13086
13139
  const canvasRef = React.useRef(null);
13087
13140
  const [firstFrameSrc, setFirstFrameSrc] = React.useState('');
13088
13141
  const [waiting, setWaiting] = React.useState(false);
13142
+ const videoRef = React.useRef();
13089
13143
  const videoId = `pb-cache-video-${index}`;
13090
13144
  const videoEleRef = React.useRef(null);
13091
13145
  const blur = React.useMemo(() => {
@@ -13116,56 +13170,57 @@ Made in Italy` })));
13116
13170
  return isBgColor && (videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor) ? { backgroundColor: videoPostConfig === null || videoPostConfig === void 0 ? void 0 : videoPostConfig.bgColor } : {};
13117
13171
  }, [videoPostConfig, isBgColor]);
13118
13172
  React.useEffect(() => {
13119
- if (!videoRef)
13173
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13120
13174
  return;
13121
- videoRef.muted = muted;
13122
- }, [muted, videoRef]);
13175
+ videoRef.current.muted = muted;
13176
+ }, [muted, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13123
13177
  const handlePlay = React.useCallback(() => {
13124
- if (!videoRef)
13178
+ var _a;
13179
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13125
13180
  return;
13126
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13127
- }, [videoRef]);
13181
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13182
+ }, [videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13128
13183
  const PAUSE_ICON = useIconLink('/pb_static/06f28a2025c74c1cb49be6767316d827.png');
13129
13184
  const handlePlaying = React.useCallback(() => {
13130
- if (!videoRef)
13185
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13131
13186
  return;
13132
13187
  setWaiting(false);
13133
13188
  setIsLoadFinish(true);
13134
13189
  }, []);
13135
13190
  const handleStartPlay = React.useCallback(() => {
13136
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13137
- if (!videoRef)
13191
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13192
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13138
13193
  return;
13139
13194
  setIsPauseVideo(false);
13140
13195
  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);
13196
+ if (item && ((_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration)) {
13197
+ videoStartTime.current = ((_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0;
13198
+ const videoDuration = ((_d = (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.duration) !== null && _d !== void 0 ? _d : 0).toFixed(2);
13199
+ const videoCurrentTime = ((_f = (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.currentTime) !== null && _f !== void 0 ? _f : 0).toFixed(2);
13145
13200
  const playType = isFirstPlay ? '0' : '1';
13146
13201
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13147
13202
  eventInfo: {
13148
13203
  eventSubject: 'playVideo',
13149
13204
  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 : '',
13205
+ contentId: (_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.itemId) !== null && _h !== void 0 ? _h : '',
13206
+ contentName: (_k = (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.title) !== null && _k !== void 0 ? _k : '',
13152
13207
  playType,
13153
13208
  startTime: videoCurrentTime,
13154
13209
  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 : []),
13210
+ contentTags: JSON.stringify((_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.tags) !== null && _m !== void 0 ? _m : []),
13156
13211
  position: index + '',
13157
13212
  contentFormat: 'video',
13158
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13213
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13159
13214
  }
13160
13215
  });
13161
13216
  setIsFirstPlay(false);
13162
13217
  }
13163
- }, [bffEventReport, data, index, isFirstPlay, videoRef]);
13218
+ }, [bffEventReport, data, index, isFirstPlay, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13164
13219
  const handLoadeddata = React.useCallback(() => {
13165
13220
  var _a;
13166
- if (!videoRef || firstFrameSrc || !blur)
13221
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || firstFrameSrc || !blur)
13167
13222
  return;
13168
- videoRef.style.objectFit = 'contain';
13223
+ videoRef.current.style.objectFit = 'contain';
13169
13224
  if (((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.cover) || !canvasRef || !canvasRef.current || isBgColor)
13170
13225
  return;
13171
13226
  const setFrameImg = () => {
@@ -13175,158 +13230,163 @@ Made in Italy` })));
13175
13230
  const targetHeight = window === null || window === void 0 ? void 0 : window.innerHeight;
13176
13231
  canvas.height = targetHeight;
13177
13232
  canvas.width = targetWidth;
13178
- ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef, 0, 0, canvas.width, canvas.height);
13233
+ ctx === null || ctx === void 0 ? void 0 : ctx.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
13179
13234
  setFirstFrameSrc(canvas.toDataURL());
13180
13235
  };
13181
13236
  setFrameImg();
13182
13237
  setTimeout(() => {
13183
13238
  setFrameImg();
13184
13239
  }, 500);
13185
- }, [videoRef, isBgColor, rec, firstFrameSrc, blur]);
13240
+ }, [videoRef.current, isBgColor, rec, firstFrameSrc, blur]);
13186
13241
  const handleLoadedmetadata = React.useCallback(() => {
13187
- if (!videoRef)
13242
+ if (!videoRef.current)
13188
13243
  return;
13189
13244
  handleStartPlay();
13190
13245
  handLoadeddata();
13191
- }, [videoRef, handLoadeddata, handleStartPlay]);
13246
+ }, [videoRef.current, handLoadeddata, handleStartPlay]);
13192
13247
  const handleClickVideo = React.useCallback((type) => () => {
13193
- if (!videoRef)
13248
+ var _a, _b, _c, _d, _e;
13249
+ if (!videoRef.current)
13194
13250
  return;
13195
13251
  if (!isLoadFinish)
13196
13252
  return;
13197
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13253
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13198
13254
  switch (type) {
13199
13255
  case 'start':
13200
13256
  if (!isPause)
13201
13257
  return;
13202
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13258
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.play();
13203
13259
  setIsPauseVideo(false);
13204
13260
  break;
13205
13261
  case 'pause':
13206
13262
  if (isPause)
13207
13263
  return;
13208
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13264
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.pause();
13209
13265
  setIsPauseVideo(true);
13210
13266
  break;
13211
13267
  default:
13212
13268
  if (isPause) {
13213
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13269
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.play();
13214
13270
  }
13215
13271
  else {
13216
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13272
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.pause();
13217
13273
  }
13218
13274
  setIsPauseVideo(!isPause);
13219
13275
  break;
13220
13276
  }
13221
- }, [isLoadFinish, videoRef]);
13277
+ }, [isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13222
13278
  const handlePause = React.useCallback(() => {
13223
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13224
- if (!videoRef)
13279
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
13280
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13225
13281
  return;
13226
13282
  if (activeIndex !== index)
13227
13283
  return;
13228
13284
  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);
13285
+ const videoDuration = ((_b = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.duration) !== null && _b !== void 0 ? _b : 0).toFixed(2);
13286
+ const videoCurrentTime = ((_d = (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.currentTime) !== null && _d !== void 0 ? _d : 0).toFixed(2);
13287
+ if ((_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.duration) {
13288
+ const playDuration = (((_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.currentTime) - videoStartTime.current).toFixed(2);
13233
13289
  bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
13234
13290
  eventInfo: {
13235
13291
  eventSubject: 'playOverVideo',
13236
13292
  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 : '',
13293
+ contentId: (_h = (_g = item === null || item === void 0 ? void 0 : item.video) === null || _g === void 0 ? void 0 : _g.itemId) !== null && _h !== void 0 ? _h : '',
13294
+ contentName: (_k = (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.title) !== null && _k !== void 0 ? _k : '',
13239
13295
  endTime: videoCurrentTime,
13240
13296
  videoDuration,
13241
13297
  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 : []),
13298
+ contentTags: JSON.stringify((_m = (_l = item === null || item === void 0 ? void 0 : item.video) === null || _l === void 0 ? void 0 : _l.tags) !== null && _m !== void 0 ? _m : []),
13243
13299
  position: index + '',
13244
13300
  contentFormat: 'video',
13245
- traceInfo: (_j = item === null || item === void 0 ? void 0 : item.video) === null || _j === void 0 ? void 0 : _j.traceInfo
13301
+ traceInfo: (_o = item === null || item === void 0 ? void 0 : item.video) === null || _o === void 0 ? void 0 : _o.traceInfo
13246
13302
  }
13247
13303
  });
13248
13304
  }
13249
- }, [data, index, bffEventReport, videoRef, activeIndex]);
13305
+ }, [data, index, bffEventReport, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, activeIndex]);
13250
13306
  const handleWaiting = React.useCallback(() => {
13251
13307
  setWaiting(true);
13252
13308
  }, []);
13253
13309
  React.useEffect(() => {
13254
- if (!isActive || !videoRef)
13310
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
13311
+ if (!isActive)
13255
13312
  return;
13256
13313
  const videoSrc = rec === null || rec === void 0 ? void 0 : rec.video.url;
13257
13314
  if (!videoSrc)
13258
13315
  return;
13316
+ const videoPlayerWrapperNode = document.querySelector(`#${videoId}`);
13317
+ if (!videoPlayerWrapperNode)
13318
+ return;
13319
+ videoRef.current = mountVideoPlayerAtNode === null || mountVideoPlayerAtNode === void 0 ? void 0 : mountVideoPlayerAtNode(videoPlayerWrapperNode);
13320
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13321
+ return;
13259
13322
  const Hls = window === null || window === void 0 ? void 0 : window.Hls;
13260
13323
  let hls = null;
13261
13324
  if (videoSrc.includes('.m3u8') && Hls && Hls.isSupported()) {
13262
13325
  hls = new Hls();
13263
13326
  hls.loadSource(videoSrc);
13264
- hls.attachMedia(videoRef);
13327
+ hls.attachMedia(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current);
13265
13328
  hls.on(Hls.Events.MANIFEST_PARSED, function () {
13266
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13329
+ var _a;
13330
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13267
13331
  });
13268
13332
  }
13269
13333
  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);
13334
+ videoRef.current.src = videoSrc;
13335
+ }
13336
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.setAttribute('x5-playsinline', 'true');
13337
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.setAttribute('webkit-playsinline', 'true');
13338
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('loadedmetadata', handleLoadedmetadata);
13339
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('loadeddata', handLoadeddata);
13340
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.addEventListener('play', handleStartPlay);
13341
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.addEventListener('playing', handlePlaying);
13342
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.addEventListener('pause', handlePause);
13343
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.addEventListener('ended', handlePlay);
13344
+ (_j = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _j === void 0 ? void 0 : _j.addEventListener('canplay', handlePlay);
13345
+ (_k = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _k === void 0 ? void 0 : _k.addEventListener('waiting', handleWaiting);
13288
13346
  return () => {
13347
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13289
13348
  if (hls)
13290
13349
  hls === null || hls === void 0 ? void 0 : hls.destroy();
13291
13350
  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);
13351
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('loadedmetadata', handleLoadedmetadata);
13352
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('loadeddata', handLoadeddata);
13353
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('play', handleStartPlay);
13354
+ (_d = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('playing', handlePlaying);
13355
+ (_e = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _e === void 0 ? void 0 : _e.removeEventListener('pause', handlePause);
13356
+ (_f = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _f === void 0 ? void 0 : _f.removeEventListener('ended', handlePlay);
13357
+ (_g = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _g === void 0 ? void 0 : _g.removeEventListener('canplay', handlePlay);
13358
+ (_h = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _h === void 0 ? void 0 : _h.removeEventListener('waiting', handleWaiting);
13301
13359
  };
13302
- }, [isActive, videoId, rec, videoRef]);
13360
+ }, [isActive, videoId, rec]);
13303
13361
  React.useEffect(() => {
13304
- if (!videoRef || !isLoadFinish)
13362
+ var _a, _b;
13363
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) || !isLoadFinish)
13305
13364
  return;
13306
13365
  if (isActive) {
13307
13366
  bffFbReport === null || bffFbReport === void 0 ? void 0 : bffFbReport({
13308
13367
  eventName: 'ViewContent'
13309
13368
  });
13310
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13369
+ (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.play();
13311
13370
  }
13312
13371
  else {
13313
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13372
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13314
13373
  }
13315
- }, [isActive, isLoadFinish, videoRef]);
13374
+ }, [isActive, isLoadFinish, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13316
13375
  /*
13317
13376
  打开/关闭hashtag暂停/播放视频
13318
13377
  */
13319
13378
  React.useEffect(() => {
13320
- if (!isActive || !videoRef)
13379
+ var _a, _b, _c;
13380
+ if (!isActive || !(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13321
13381
  return;
13322
- const isPause = videoRef === null || videoRef === void 0 ? void 0 : videoRef.paused;
13382
+ const isPause = (_a = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _a === void 0 ? void 0 : _a.paused;
13323
13383
  if (!isPause && openHashtag) {
13324
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.pause();
13384
+ (_b = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _b === void 0 ? void 0 : _b.pause();
13325
13385
  }
13326
13386
  else if (!openHashtag) {
13327
- videoRef === null || videoRef === void 0 ? void 0 : videoRef.play();
13387
+ (_c = videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) === null || _c === void 0 ? void 0 : _c.play();
13328
13388
  }
13329
- }, [openHashtag, isActive, videoRef]);
13389
+ }, [openHashtag, isActive, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current]);
13330
13390
  React.useEffect(() => {
13331
13391
  if (!isActive)
13332
13392
  return;
@@ -13373,11 +13433,11 @@ Made in Italy` })));
13373
13433
  }, src: img$1, alt: 'placeholder image' }));
13374
13434
  }, [waiting, isLoadFinish]);
13375
13435
  React.useEffect(() => {
13376
- if (!videoRef)
13436
+ if (!(videoRef === null || videoRef === void 0 ? void 0 : videoRef.current))
13377
13437
  return;
13378
13438
  const handleBeforeUnload = () => {
13379
13439
  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) {
13440
+ if (activeIndex === index && ((_a = rec === null || rec === void 0 ? void 0 : rec.video) === null || _a === void 0 ? void 0 : _a.url) && (videoRef === null || videoRef === void 0 ? void 0 : videoRef.current) && !isPauseVideo) {
13381
13441
  handleClickVideo('pause')();
13382
13442
  }
13383
13443
  };
@@ -13385,7 +13445,7 @@ Made in Italy` })));
13385
13445
  return () => {
13386
13446
  window.removeEventListener('beforeunload', handleBeforeUnload);
13387
13447
  };
13388
- }, [activeIndex, index, rec, videoRef, handleClickVideo, isPauseVideo]);
13448
+ }, [activeIndex, index, rec, videoRef === null || videoRef === void 0 ? void 0 : videoRef.current, handleClickVideo, isPauseVideo]);
13389
13449
  if (!(rec === null || rec === void 0 ? void 0 : rec.video)) {
13390
13450
  return null;
13391
13451
  }
@@ -13710,12 +13770,12 @@ Made in Italy` })));
13710
13770
  * @Author: binruan@chatlabs.com
13711
13771
  * @Date: 2024-03-26 10:07:41
13712
13772
  * @LastEditors: binruan@chatlabs.com
13713
- * @LastEditTime: 2024-05-23 14:31:12
13773
+ * @LastEditTime: 2024-07-01 17:47:33
13714
13774
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Nudge\index.tsx
13715
13775
  *
13716
13776
  */
13717
13777
  const Nudge = ({ nudge }) => {
13718
- var _a, _b, _c, _d, _e, _f, _g;
13778
+ var _a, _b, _c, _d, _e, _f;
13719
13779
  return (React.createElement(React.Fragment, null, (nudge === null || nudge === void 0 ? void 0 : nudge.isOpen) && (React.createElement("div", { className: 'clc-sxp-bottom-nudge', style: {
13720
13780
  marginBottom: (_a = nudge === null || nudge === void 0 ? void 0 : nudge.marginBottom) !== null && _a !== void 0 ? _a : 5,
13721
13781
  width: (_c = (_b = nudge === null || nudge === void 0 ? void 0 : nudge.size) === null || _b === void 0 ? void 0 : _b.width) !== null && _c !== void 0 ? _c : 212,
@@ -13724,7 +13784,9 @@ Made in Italy` })));
13724
13784
  borderRadius: (_f = nudge === null || nudge === void 0 ? void 0 : nudge.borderRadius) !== null && _f !== void 0 ? _f : 4
13725
13785
  } },
13726
13786
  (nudge === null || nudge === void 0 ? void 0 : nudge.icon) ? (React.createElement("img", { src: nudge.icon, alt: 'nudge icon', style: { height: '100%', objectFit: 'cover', flexShrink: 0 } })) : null,
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 : '')))));
13787
+ React.createElement("p", { style: Object.assign(Object.assign({}, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle), { textWrap: 'nowrap', textOverflow: 'ellipsis', overflow: 'hidden', whiteSpace: 'nowrap', flex: 1, marginBottom: 0 }), dangerouslySetInnerHTML: {
13788
+ __html: setFontForText(nudge === null || nudge === void 0 ? void 0 : nudge.content, nudge === null || nudge === void 0 ? void 0 : nudge.textStyle)
13789
+ } })))));
13728
13790
  };
13729
13791
 
13730
13792
  /*
@@ -13787,7 +13849,7 @@ Made in Italy` })));
13787
13849
  * @Author: binruan@chatlabs.com
13788
13850
  * @Date: 2024-01-15 19:03:09
13789
13851
  * @LastEditors: binruan@chatlabs.com
13790
- * @LastEditTime: 2024-06-28 14:53:42
13852
+ * @LastEditTime: 2024-07-01 11:49:58
13791
13853
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\index.tsx
13792
13854
  *
13793
13855
  */
@@ -13796,14 +13858,12 @@ Made in Italy` })));
13796
13858
  const { schema } = useEditor();
13797
13859
  const [activeIndex, setActiveIndex] = React.useState(0);
13798
13860
  const viewImageStartTime = React.useRef(0);
13799
- React.useState(false);
13800
13861
  const [isMuted, setIsMuted] = React.useState(true);
13801
13862
  const viewTime = React.useRef();
13802
13863
  const [isLoadMore, setIsLoadMore] = React.useState(false);
13803
13864
  const [isShowMore, setIsShowMore] = React.useState(false);
13804
13865
  const { loadVideos, bffEventReport, loading, setPopupDetailData, ctaEvent, swiperRef, waterFallData, setOpenHashtag, appDomain, openHashtag, loadingImage, isFromHashtag, popupDetailData, bffFbReport, curTime, h5EnterLink, isShowConsent, selectTag } = useSxpDataSource();
13805
13866
  const { backMainFeed } = useEventReport();
13806
- const videoRef = React.useRef();
13807
13867
  const { productView } = useEventReport();
13808
13868
  const isShowFingerTip = React.useMemo(() => {
13809
13869
  return data.length > 0 && !loading && getFeUserId();
@@ -13831,16 +13891,6 @@ Made in Italy` })));
13831
13891
  });
13832
13892
  }
13833
13893
  }, [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
13894
  React.useEffect(() => {
13845
13895
  var _a;
13846
13896
  const index = (data === null || data === void 0 ? void 0 : data.findIndex((item) => {
@@ -13961,7 +14011,7 @@ Made in Italy` })));
13961
14011
  const renderContent = React.useCallback((rec, index) => {
13962
14012
  var _a, _b, _c, _d;
13963
14013
  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 }));
14014
+ return (React.createElement(VideoWidget$3, { rec: rec, index: index, muted: isMuted, data: data, height: height, activeIndex: activeIndex, videoPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPost, videoPlayIcon: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.videoPlayIcon }));
13965
14015
  }
13966
14016
  if ((_b = rec === null || rec === void 0 ? void 0 : rec.video) === null || _b === void 0 ? void 0 : _b.imgUrls) {
13967
14017
  return (React.createElement(PictureGroup$3, { key: rec === null || rec === void 0 ? void 0 : rec.video.itemId, imgUrls: rec === null || rec === void 0 ? void 0 : rec.video.imgUrls, width: containerWidth, height: height, rec: rec, index: index, onReportViewImageEnd: handleReportViewImageEnd, onViewImageStartEvent: handleViewImageStartEvent, imgUrlsPostConfig: globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.imgUrlsPost }));
@@ -13987,8 +14037,7 @@ Made in Italy` })));
13987
14037
  viewTime,
13988
14038
  tipText,
13989
14039
  resolver,
13990
- schema,
13991
- videoRef.current
14040
+ schema
13992
14041
  ]);
13993
14042
  const onExpandableChange = React.useCallback((v) => {
13994
14043
  setIsShowMore(v);
@@ -14221,16 +14270,7 @@ Made in Italy` })));
14221
14270
  [(_f = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconYPosit) !== null && _f !== void 0 ? _f : 'bottom']: (_g = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIconY) !== null && _g !== void 0 ? _g : 23
14222
14271
  }, defaultValue: isMuted, activeIcon: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.unMuteIcon) ? globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.unMuteIcon : mutedIcon, unactiveIcon: (globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIcon) ? globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.muteIcon : unmutedIcon, onChange: setIsMuted }),
14223
14272
  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' }))));
14273
+ React.createElement(WaterFall$1, Object.assign({}, (_k = (_j = (_h = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.hashTag) === null || _h === void 0 ? void 0 : _h[0]) === null || _j === void 0 ? void 0 : _j.item) === null || _k === void 0 ? void 0 : _k.props))));
14234
14274
  };
14235
14275
 
14236
14276
  const PictureGroup = ({ imgUrls, width, height, imgUrlsPostConfig, rec, index }) => {