pb-sxp-ui 1.0.4 → 1.0.6

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 (45) hide show
  1. package/dist/index.cjs +93 -107
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.js +93 -107
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.min.cjs +3 -3
  6. package/dist/index.min.cjs.map +1 -1
  7. package/dist/index.min.js +3 -3
  8. package/dist/index.min.js.map +1 -1
  9. package/dist/pb-ui.js +93 -107
  10. package/dist/pb-ui.js.map +1 -1
  11. package/dist/pb-ui.min.js +3 -3
  12. package/dist/pb-ui.min.js.map +1 -1
  13. package/es/core/components/SxpPageRender/Modal/index.d.ts +2 -2
  14. package/es/core/components/SxpPageRender/Modal/index.js +12 -11
  15. package/es/core/components/SxpPageRender/Popup/index.js +12 -12
  16. package/es/core/components/SxpPageRender/WaterFall/WaterfallList.js +3 -4
  17. package/es/core/components/SxpPageRender/WaterFall/index.js +1 -1
  18. package/es/core/context/EditorContext.d.ts +7 -5
  19. package/es/core/context/EditorContext.js +10 -25
  20. package/es/core/hooks/useEventReport.js +39 -35
  21. package/es/materials/sxp/popup/AppointForm/index.js +1 -2
  22. package/es/materials/sxp/popup/Prompt/index.js +0 -2
  23. package/es/materials/sxp/template/MultiCommodity/index.js +4 -5
  24. package/es/materials/sxp/template/MultiCommodityDiro/index.js +4 -5
  25. package/es/materials/sxp/template/MultiCommodityDiroNew/index.js +4 -5
  26. package/es/materials/sxp/template/components/EventProvider.js +4 -4
  27. package/lib/core/components/SxpPageRender/Modal/index.d.ts +2 -2
  28. package/lib/core/components/SxpPageRender/Modal/index.js +11 -10
  29. package/lib/core/components/SxpPageRender/Popup/index.js +12 -12
  30. package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.js +2 -3
  31. package/lib/core/components/SxpPageRender/WaterFall/index.js +1 -1
  32. package/lib/core/context/EditorContext.d.ts +7 -5
  33. package/lib/core/context/EditorContext.js +10 -25
  34. package/lib/core/hooks/useEventReport.js +39 -35
  35. package/lib/materials/sxp/popup/AppointForm/index.js +0 -1
  36. package/lib/materials/sxp/popup/Prompt/index.js +0 -2
  37. package/lib/materials/sxp/template/MultiCommodity/index.js +4 -5
  38. package/lib/materials/sxp/template/MultiCommodityDiro/index.js +4 -5
  39. package/lib/materials/sxp/template/MultiCommodityDiroNew/index.js +4 -5
  40. package/lib/materials/sxp/template/components/EventProvider.js +4 -4
  41. package/package.json +1 -1
  42. package/es/core/components/SxpPageRender/ProductInfo/index.d.ts +0 -14
  43. package/es/core/components/SxpPageRender/ProductInfo/index.js +0 -55
  44. package/lib/core/components/SxpPageRender/ProductInfo/index.d.ts +0 -14
  45. package/lib/core/components/SxpPageRender/ProductInfo/index.js +0 -58
package/dist/pb-ui.js CHANGED
@@ -716,6 +716,11 @@
716
716
  pathArr: [0],
717
717
  positionY: 0
718
718
  };
719
+ const popupInit = {
720
+ id: '',
721
+ duration: 0,
722
+ name: 'none'
723
+ };
719
724
  const EditorContext = React.createContext({
720
725
  resolver: {},
721
726
  currentNode: null,
@@ -735,12 +740,8 @@
735
740
  prePiontData: [],
736
741
  undoStack: [item],
737
742
  redoStack: [],
738
- popup: '',
739
- setPopup: () => { },
740
- popupAni: {
741
- name: 'none',
742
- duration: 0
743
- }
743
+ popup: popupInit,
744
+ setPopup: () => { }
744
745
  });
745
746
  const EditorCore = React.forwardRef(({ children, resolver, isSsr, schema, enableDataSource = true, utmVal }, ref) => {
746
747
  const [currentNode, setCurrentNode] = React.useState(null);
@@ -763,25 +764,10 @@
763
764
  */
764
765
  const [undoStack, setUndoStack] = React.useState([[item]]);
765
766
  const [redoStack, setRedoStack] = React.useState([]);
766
- const [popup, setPopup] = React.useState('');
767
- const [popupAni, setPopupAni] = React.useState({
768
- name: 'none',
769
- duration: 0
770
- });
767
+ const [popup, setPopup] = React.useState(popupInit);
771
768
  typeof window !== 'undefined' &&
772
769
  (window.sxpPopup = (type, aniType) => {
773
- if (aniType && (aniType === null || aniType === void 0 ? void 0 : aniType.name) !== 'none') {
774
- setPopupAni(Object.assign(Object.assign({}, popupAni), aniType));
775
- }
776
- else {
777
- setPopupAni({
778
- name: 'none',
779
- duration: 0
780
- });
781
- }
782
- setTimeout(() => {
783
- setPopup(type);
784
- });
770
+ setPopup(Object.assign(Object.assign(Object.assign({}, popupInit), { id: type }), aniType));
785
771
  });
786
772
  typeof window !== 'undefined' &&
787
773
  (window.getJointUtmLink = (url) => {
@@ -857,8 +843,7 @@
857
843
  setUndoStack,
858
844
  getCurPageConf,
859
845
  popup,
860
- setPopup,
861
- popupAni
846
+ setPopup
862
847
  } },
863
848
  React.createElement(DataSourceProvider$1, { isSsr: isSsr, enable: enableDataSource }, children)));
864
849
  });
@@ -997,7 +982,6 @@
997
982
 
998
983
  const AppointForm$1 = (_a) => {
999
984
  var { columns, style, title, textStyle, submitBgColor, submitColor, submitText, layoutType, onClick } = _a, props = __rest(_a, ["columns", "style", "title", "textStyle", "submitBgColor", "submitColor", "submitText", "layoutType", "onClick"]);
1000
- useEditor();
1001
985
  const { submitForm } = useSxpDataSource();
1002
986
  const formRef = React.useRef();
1003
987
  const [loading, setLoading] = React.useState(false);
@@ -8094,7 +8078,7 @@
8094
8078
  * @Author: binruan@chatlabs.com
8095
8079
  * @Date: 2024-03-12 10:59:06
8096
8080
  * @LastEditors: binruan@chatlabs.com
8097
- * @LastEditTime: 2024-03-18 17:38:46
8081
+ * @LastEditTime: 2024-04-11 22:30:45
8098
8082
  * @FilePath: \pb-sxp-ui\src\core\hooks\useEventReport.ts
8099
8083
  *
8100
8084
  */
@@ -8118,23 +8102,25 @@
8118
8102
  else if (data === null || data === void 0 ? void 0 : data.product) {
8119
8103
  fromKName = 'productPage';
8120
8104
  }
8121
- bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8122
- eventInfo: {
8123
- eventSubject: 'jumpToWeb',
8124
- eventDescription: 'User jumped to website',
8125
- productId: (_h = product === null || product === void 0 ? void 0 : product.itemId) !== null && _h !== void 0 ? _h : '',
8126
- productName: (_j = product === null || product === void 0 ? void 0 : product.title) !== null && _j !== void 0 ? _j : '',
8127
- price: (product === null || product === void 0 ? void 0 : product.price) ? (product === null || product === void 0 ? void 0 : product.price) + '' : '0',
8128
- productCollection: (_k = product === null || product === void 0 ? void 0 : product.collection) !== null && _k !== void 0 ? _k : '',
8129
- fromKName,
8130
- fromKPage: location === null || location === void 0 ? void 0 : location.href,
8131
- contentTags: (product === null || product === void 0 ? void 0 : product.tags) ? JSON.stringify(product === null || product === void 0 ? void 0 : product.tags) : '',
8132
- position: (data === null || data === void 0 ? void 0 : data.position) + '',
8133
- relatedContentId: (_m = (_l = data === null || data === void 0 ? void 0 : data.video) === null || _l === void 0 ? void 0 : _l.itemId) !== null && _m !== void 0 ? _m : '',
8134
- relatedCtatId: (_o = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _o !== void 0 ? _o : '',
8135
- traceInfo: (_p = product === null || product === void 0 ? void 0 : product.traceInfo) !== null && _p !== void 0 ? _p : ''
8136
- }
8137
- });
8105
+ if (product === null || product === void 0 ? void 0 : product.price) {
8106
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8107
+ eventInfo: {
8108
+ eventSubject: 'jumpToWeb',
8109
+ eventDescription: 'User jumped to website',
8110
+ productId: (_h = product === null || product === void 0 ? void 0 : product.itemId) !== null && _h !== void 0 ? _h : '',
8111
+ productName: (_j = product === null || product === void 0 ? void 0 : product.title) !== null && _j !== void 0 ? _j : '',
8112
+ price: (product === null || product === void 0 ? void 0 : product.price) ? (product === null || product === void 0 ? void 0 : product.price) + '' : '0',
8113
+ productCollection: (_k = product === null || product === void 0 ? void 0 : product.collection) !== null && _k !== void 0 ? _k : '',
8114
+ fromKName,
8115
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
8116
+ contentTags: (product === null || product === void 0 ? void 0 : product.tags) ? JSON.stringify(product === null || product === void 0 ? void 0 : product.tags) : '',
8117
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
8118
+ relatedContentId: (_m = (_l = data === null || data === void 0 ? void 0 : data.video) === null || _l === void 0 ? void 0 : _l.itemId) !== null && _m !== void 0 ? _m : '',
8119
+ relatedCtatId: (_o = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _o !== void 0 ? _o : '',
8120
+ traceInfo: (_p = product === null || product === void 0 ? void 0 : product.traceInfo) !== null && _p !== void 0 ? _p : ''
8121
+ }
8122
+ });
8123
+ }
8138
8124
  }, [bffEventReport, popupDetailData, isFromHashtag]);
8139
8125
  const productView = React.useCallback((data, product, cta, viewTime) => {
8140
8126
  var _a, _b, _c, _d;
@@ -8145,24 +8131,26 @@
8145
8131
  else if (data === null || data === void 0 ? void 0 : data.product) {
8146
8132
  fromKName = 'productPage';
8147
8133
  }
8148
- bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8149
- eventInfo: {
8150
- productId: product === null || product === void 0 ? void 0 : product.itemId,
8151
- productName: product === null || product === void 0 ? void 0 : product.title,
8152
- price: (product === null || product === void 0 ? void 0 : product.price) + '',
8153
- productCollection: product === null || product === void 0 ? void 0 : product.collection,
8154
- fromKName,
8155
- fromKPage: location === null || location === void 0 ? void 0 : location.href,
8156
- contentTags: JSON.stringify(product === null || product === void 0 ? void 0 : product.tags),
8157
- position: (data === null || data === void 0 ? void 0 : data.position) + '',
8158
- relatedContentId: (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.itemId,
8159
- relatedCtatId: cta === null || cta === void 0 ? void 0 : cta.itemId,
8160
- traceInfo: product === null || product === void 0 ? void 0 : product.traceInfo,
8161
- timeOnSite: Math.floor((new Date() - viewTime) / 1000) + '',
8162
- eventSubject: 'productView',
8163
- eventDescription: 'User browsed the product'
8164
- }
8165
- });
8134
+ if (product === null || product === void 0 ? void 0 : product.price) {
8135
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8136
+ eventInfo: {
8137
+ productId: product === null || product === void 0 ? void 0 : product.itemId,
8138
+ productName: product === null || product === void 0 ? void 0 : product.title,
8139
+ price: (product === null || product === void 0 ? void 0 : product.price) + '',
8140
+ productCollection: product === null || product === void 0 ? void 0 : product.collection,
8141
+ fromKName,
8142
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
8143
+ contentTags: JSON.stringify(product === null || product === void 0 ? void 0 : product.tags),
8144
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
8145
+ relatedContentId: (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.itemId,
8146
+ relatedCtatId: cta === null || cta === void 0 ? void 0 : cta.itemId,
8147
+ traceInfo: product === null || product === void 0 ? void 0 : product.traceInfo,
8148
+ timeOnSite: Math.floor((new Date() - viewTime) / 1000) + '',
8149
+ eventSubject: 'productView',
8150
+ eventDescription: 'User browsed the product'
8151
+ }
8152
+ });
8153
+ }
8166
8154
  }, [bffEventReport, popupDetailData]);
8167
8155
  return {
8168
8156
  jumpToWeb,
@@ -8174,14 +8162,13 @@
8174
8162
  * @Author: binruan@chatlabs.com
8175
8163
  * @Date: 2023-11-02 18:34:34
8176
8164
  * @LastEditors: binruan@chatlabs.com
8177
- * @LastEditTime: 2024-04-10 11:11:50
8165
+ * @LastEditTime: 2024-04-12 11:23:00
8178
8166
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8179
8167
  *
8180
8168
  */
8181
8169
  const closeIcon = '';
8182
- const Modal = ({ visible, onClose, children, modalStyle, padding, popupAniData }) => {
8183
- const { popupAni } = useEditor();
8184
- const cssAni = popupAniData !== null && popupAniData !== void 0 ? popupAniData : popupAni;
8170
+ const Modal = ({ visible, onClose, children, modalStyle, padding, popup }) => {
8171
+ var _a;
8185
8172
  const [isShow, setIsShow] = React.useState(false);
8186
8173
  const modalEleRef = React.useRef(null);
8187
8174
  React.useEffect(() => {
@@ -8196,29 +8183,32 @@
8196
8183
  parentNode === null || parentNode === void 0 ? void 0 : parentNode.appendChild(modalEleRef.current);
8197
8184
  }
8198
8185
  }, []);
8186
+ const isOpen = React.useMemo(() => {
8187
+ return ((popup === null || popup === void 0 ? void 0 : popup.id) && (popup === null || popup === void 0 ? void 0 : popup.id) !== '') || visible;
8188
+ }, [visible, popup]);
8199
8189
  React.useEffect(() => {
8200
- if (visible) {
8190
+ if (isOpen) {
8201
8191
  setIsShow(true);
8202
8192
  }
8203
8193
  else {
8204
8194
  setTimeout(() => {
8205
8195
  setIsShow(false);
8206
- }, cssAni === null || cssAni === void 0 ? void 0 : cssAni.duration);
8196
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
8207
8197
  }
8208
- }, [visible, cssAni]);
8198
+ }, [isOpen, popup]);
8209
8199
  if (!modalEleRef.current)
8210
8200
  return null;
8211
8201
  const handleClose = lodash.debounce(() => {
8212
8202
  onClose === null || onClose === void 0 ? void 0 : onClose();
8213
8203
  }, 300);
8214
- return ReactDOM__namespace.createPortal(React.createElement("div", { className: 'modal-bg', style: Object.assign({ display: isShow ? 'flex' : 'none', backgroundColor: visible ? 'rgba(0, 0, 0, 0.7)' : 'rgba(0, 0, 0, 0)' }, modalStyle), onClick: handleClose },
8215
- React.createElement("div", { className: `modal-container ${visible ? 'modal-popIn' : 'modal-popOut'}`, style: { padding, animationDuration: (cssAni === null || cssAni === void 0 ? void 0 : cssAni.duration) / 1000 + 's' }, onClick: (e) => {
8204
+ return ReactDOM__namespace.createPortal(React.createElement(React.Fragment, null, isShow && (React.createElement("div", { className: 'modal-bg', style: Object.assign({ display: 'flex', backgroundColor: isOpen ? 'rgba(0, 0, 0, 0.7)' : 'rgba(0, 0, 0, 0)' }, modalStyle), onClick: handleClose },
8205
+ React.createElement("div", { className: `modal-container ${isOpen ? 'modal-popIn' : 'modal-popOut'}`, style: { padding, animationDuration: ((_a = popup === null || popup === void 0 ? void 0 : popup.duration) !== null && _a !== void 0 ? _a : 0) / 1000 + 's' }, onClick: (e) => {
8216
8206
  e.stopPropagation();
8217
8207
  e.preventDefault();
8218
8208
  } },
8219
8209
  React.createElement("div", { onClick: onClose, className: 'modal-icon-wrapper' },
8220
8210
  React.createElement("img", { src: closeIcon, alt: 'close', className: 'modal-icon' })),
8221
- children)), modalEleRef.current);
8211
+ children)))), modalEleRef.current);
8222
8212
  };
8223
8213
  var Modal$1 = React.memo(Modal);
8224
8214
 
@@ -8524,7 +8514,6 @@
8524
8514
 
8525
8515
  const Prompt$1 = (_a) => {
8526
8516
  var { content, btnText, style, icon, onClick } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "onClick"]);
8527
- useEditor();
8528
8517
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
8529
8518
  const handleOk = () => {
8530
8519
  window === null || window === void 0 ? void 0 : window.sxpPopup('');
@@ -9176,7 +9165,7 @@ Made in Italy` })));
9176
9165
  var { rec, children, className, onClick, style, isExternalLink = false } = _a; __rest(_a, ["rec", "children", "className", "onClick", "style", "isExternalLink"]);
9177
9166
  const ref = React.useRef(null);
9178
9167
  const isOnScreen = useOnScreen(ref);
9179
- const { popupAni } = useEditor();
9168
+ const { popup } = useEditor();
9180
9169
  const { setPopupDetailData, ctaEvent } = useSxpDataSource();
9181
9170
  const { jumpToWeb } = useEventReport();
9182
9171
  React.useEffect(() => {
@@ -9198,17 +9187,17 @@ Made in Italy` })));
9198
9187
  }, rec, item);
9199
9188
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(rec);
9200
9189
  if (isExternalLink) {
9201
- if ((_d = (_c = rec === null || rec === void 0 ? void 0 : rec.video) === null || _c === void 0 ? void 0 : _c.bindCta) === null || _d === void 0 ? void 0 : _d.link) {
9190
+ if ((_d = (_c = rec === null || rec === void 0 ? void 0 : rec.video) === null || _c === void 0 ? void 0 : _c.bindProduct) === null || _d === void 0 ? void 0 : _d.link) {
9202
9191
  const cta = (_e = rec === null || rec === void 0 ? void 0 : rec.video) === null || _e === void 0 ? void 0 : _e.bindCta;
9203
9192
  const product = (_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.bindProduct;
9204
9193
  jumpToWeb(rec, product, cta);
9205
- window.location.href = (_h = (_g = rec === null || rec === void 0 ? void 0 : rec.video) === null || _g === void 0 ? void 0 : _g.bindCta) === null || _h === void 0 ? void 0 : _h.link;
9194
+ window.location.href = (_h = (_g = rec === null || rec === void 0 ? void 0 : rec.video) === null || _g === void 0 ? void 0 : _g.bindProduct) === null || _h === void 0 ? void 0 : _h.link;
9206
9195
  }
9207
9196
  }
9208
9197
  else {
9209
9198
  onClick === null || onClick === void 0 ? void 0 : onClick();
9210
9199
  }
9211
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9200
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9212
9201
  return (React.createElement("div", { ref: ref, className: className, style: style, onClick: handleClick }, children));
9213
9202
  };
9214
9203
  var EventProvider$1 = React.memo(EventProvider);
@@ -9676,26 +9665,25 @@ Made in Italy` })));
9676
9665
  var _b, _c;
9677
9666
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9678
9667
  const { ctaEvent, setPopupDetailData, sxpParameter } = useSxpDataSource();
9679
- const { popupAni } = useEditor();
9668
+ const { popup } = useEditor();
9680
9669
  const { jumpToWeb } = useEventReport();
9681
9670
  const [products, setProducts] = React.useState((_c = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindProducts) !== null && _c !== void 0 ? _c : [1, 2]);
9682
9671
  const handleClick = lodash.throttle((item) => {
9683
- var _a;
9684
9672
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9685
9673
  eventSubject: 'clickCta',
9686
9674
  eventDescription: 'User clicked the CTA'
9687
9675
  }, recData, item);
9688
9676
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(Object.assign(Object.assign({}, recData), { video: Object.assign(Object.assign({}, recData === null || recData === void 0 ? void 0 : recData.video), { bindProduct: item }) }));
9689
9677
  if (isExternalLink) {
9690
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9678
+ if (item === null || item === void 0 ? void 0 : item.link) {
9691
9679
  jumpToWeb(recData, item, item.bindCta);
9692
- window.location.href = item.bindCta.link;
9680
+ window.location.href = item.link;
9693
9681
  }
9694
9682
  }
9695
9683
  else {
9696
9684
  onClick === null || onClick === void 0 ? void 0 : onClick();
9697
9685
  }
9698
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9686
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9699
9687
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9700
9688
  var _a, _b, _c, _d, _e, _f;
9701
9689
  return (React.createElement(SwiperSlide, Object.assign({ hidden: recData && !(item === null || item === void 0 ? void 0 : item.bindCta), key: item === null || item === void 0 ? void 0 : item.itemId, className: css.css(Object.assign(Object.assign({}, style), { display: 'flex', flexShrink: 0, marginLeft: 0, marginRight: '8px' })) }, props, { onClick: () => handleClick(item) }),
@@ -9790,26 +9778,25 @@ Made in Italy` })));
9790
9778
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9791
9779
  const { sxpParameter } = useSxpDataSource();
9792
9780
  const { ctaEvent, setPopupDetailData } = useSxpDataSource();
9793
- const { popupAni } = useEditor();
9781
+ const { popup } = useEditor();
9794
9782
  const [products, setProducts] = React.useState((_c = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindProducts) !== null && _c !== void 0 ? _c : [1, 2]);
9795
9783
  const { jumpToWeb } = useEventReport();
9796
9784
  const handleClick = lodash.throttle((item) => {
9797
- var _a;
9798
9785
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9799
9786
  eventSubject: 'clickCta',
9800
9787
  eventDescription: 'User clicked the CTA'
9801
9788
  }, recData, item);
9802
9789
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(Object.assign(Object.assign({}, recData), { video: Object.assign(Object.assign({}, recData === null || recData === void 0 ? void 0 : recData.video), { bindProduct: item }) }));
9803
9790
  if (isExternalLink) {
9804
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9791
+ if (item === null || item === void 0 ? void 0 : item.link) {
9805
9792
  jumpToWeb(recData, item, item.bindCta);
9806
- window.location.href = item.bindCta.link;
9793
+ window.location.href = item.link;
9807
9794
  }
9808
9795
  }
9809
9796
  else {
9810
9797
  onClick === null || onClick === void 0 ? void 0 : onClick();
9811
9798
  }
9812
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9799
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9813
9800
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9814
9801
  var _a, _b, _c, _d, _e, _f;
9815
9802
  return (React.createElement(SwiperSlide, Object.assign({ hidden: recData && !(item === null || item === void 0 ? void 0 : item.bindCta), key: item.itemId, className: css.css(Object.assign(Object.assign({}, style), { display: 'flex', flexShrink: 0, marginLeft: 0, marginRight: '8px' })) }, props, { onClick: () => handleClick(item) }),
@@ -9903,26 +9890,25 @@ Made in Italy` })));
9903
9890
  var _b, _c;
9904
9891
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9905
9892
  const { ctaEvent, setPopupDetailData, sxpParameter } = useSxpDataSource();
9906
- const { popupAni } = useEditor();
9893
+ const { popup } = useEditor();
9907
9894
  const { jumpToWeb } = useEventReport();
9908
9895
  const [products, setProducts] = React.useState((_c = (_b = recData === null || recData === void 0 ? void 0 : recData.video) === null || _b === void 0 ? void 0 : _b.bindProducts) !== null && _c !== void 0 ? _c : [1, 2]);
9909
9896
  const handleClick = lodash.throttle((item) => {
9910
- var _a;
9911
9897
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9912
9898
  eventSubject: 'clickCta',
9913
9899
  eventDescription: 'User clicked the CTA'
9914
9900
  }, recData, item);
9915
9901
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(Object.assign(Object.assign({}, recData), { video: Object.assign(Object.assign({}, recData === null || recData === void 0 ? void 0 : recData.video), { bindProduct: item }) }));
9916
9902
  if (isExternalLink) {
9917
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9903
+ if (item === null || item === void 0 ? void 0 : item.link) {
9918
9904
  jumpToWeb(recData, item, item.bindCta);
9919
- window.location.href = item.bindCta.link;
9905
+ window.location.href = item.link;
9920
9906
  }
9921
9907
  }
9922
9908
  else {
9923
9909
  onClick === null || onClick === void 0 ? void 0 : onClick();
9924
9910
  }
9925
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9911
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9926
9912
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9927
9913
  var _a, _b, _c, _d, _e, _f;
9928
9914
  return (React.createElement(SwiperSlide, Object.assign({ hidden: recData && !(item === null || item === void 0 ? void 0 : item.bindCta), key: item === null || item === void 0 ? void 0 : item.itemId, className: css.css(Object.assign(Object.assign({}, style), { display: 'flex', flexShrink: 0, marginLeft: 0, marginRight: '8px' })) }, props, { onClick: () => handleClick(item) }),
@@ -11678,7 +11664,7 @@ Made in Italy` })));
11678
11664
  * @Author: binruan@chatlabs.com
11679
11665
  * @Date: 2024-01-10 10:58:24
11680
11666
  * @LastEditors: binruan@chatlabs.com
11681
- * @LastEditTime: 2024-04-07 15:18:35
11667
+ * @LastEditTime: 2024-04-12 11:29:01
11682
11668
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
11683
11669
  *
11684
11670
  */
@@ -11742,7 +11728,7 @@ Made in Italy` })));
11742
11728
  relatedContentId: (_d = rec === null || rec === void 0 ? void 0 : rec.video) === null || _d === void 0 ? void 0 : _d.itemId,
11743
11729
  position: rec === null || rec === void 0 ? void 0 : rec.position,
11744
11730
  contentTags: JSON.stringify((_e = rec === null || rec === void 0 ? void 0 : rec.video) === null || _e === void 0 ? void 0 : _e.tags),
11745
- traceInfo: JSON.stringify((_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.traceInfo),
11731
+ traceInfo: (_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.traceInfo,
11746
11732
  hashTags: JSON.stringify([recData === null || recData === void 0 ? void 0 : recData.hashTag]),
11747
11733
  fromKName,
11748
11734
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
@@ -12846,15 +12832,15 @@ Made in Italy` })));
12846
12832
  * @Author: binruan@chatlabs.com
12847
12833
  * @Date: 2023-10-31 10:56:01
12848
12834
  * @LastEditors: binruan@chatlabs.com
12849
- * @LastEditTime: 2024-04-10 09:57:19
12835
+ * @LastEditTime: 2024-04-12 09:50:58
12850
12836
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Popup\index.tsx
12851
12837
  *
12852
12838
  */
12853
12839
  const Popup = () => {
12854
- const { schema, resolver, popup, popupAni } = useEditor();
12840
+ const { schema, resolver, popup } = useEditor();
12855
12841
  const { setPopupDetailData, popupDetailData, bffEventReport } = useSxpDataSource();
12856
12842
  const { productView } = useEventReport();
12857
- const [visible, setVisible] = React.useState(false);
12843
+ const [visible, setVisible] = React.useState();
12858
12844
  const curTimeRef = React.useRef(null);
12859
12845
  React.useEffect(() => {
12860
12846
  const initTime = () => {
@@ -12867,33 +12853,33 @@ Made in Italy` })));
12867
12853
  };
12868
12854
  }, []);
12869
12855
  React.useEffect(() => {
12870
- if (popup && popup !== '') {
12856
+ if (popup && (popup === null || popup === void 0 ? void 0 : popup.id) && (popup === null || popup === void 0 ? void 0 : popup.id) !== '') {
12871
12857
  curTimeRef.current = new Date();
12872
- setVisible(true);
12858
+ setVisible(popup);
12873
12859
  }
12874
12860
  }, [popup]);
12875
12861
  const handleClose = () => {
12876
- var _a, _b, _c;
12877
- if (!popup || popup === '' || !visible || new Date() - curTimeRef.current < (popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration)) {
12862
+ var _a, _b, _c, _d;
12863
+ if (!popup || (popup === null || popup === void 0 ? void 0 : popup.id) === '' || !visible || new Date() - curTimeRef.current < ((_a = popup === null || popup === void 0 ? void 0 : popup.duration) !== null && _a !== void 0 ? _a : 0)) {
12878
12864
  return;
12879
12865
  }
12880
- setVisible(false);
12866
+ setVisible(Object.assign(Object.assign({}, popup), { id: '' }));
12881
12867
  const data = popupDetailData;
12882
- const product = (_a = data === null || data === void 0 ? void 0 : data.video) === null || _a === void 0 ? void 0 : _a.bindProduct;
12883
- const cta = (_c = (_b = data === null || data === void 0 ? void 0 : data.video) === null || _b === void 0 ? void 0 : _b.bindProduct) === null || _c === void 0 ? void 0 : _c.bindCta;
12868
+ const product = (_b = data === null || data === void 0 ? void 0 : data.video) === null || _b === void 0 ? void 0 : _b.bindProduct;
12869
+ const cta = (_d = (_c = data === null || data === void 0 ? void 0 : data.video) === null || _c === void 0 ? void 0 : _c.bindProduct) === null || _d === void 0 ? void 0 : _d.bindCta;
12884
12870
  if (product && cta) {
12885
12871
  productView(data, product, cta, curTimeRef.current);
12886
12872
  }
12887
12873
  setTimeout(() => {
12888
12874
  window === null || window === void 0 ? void 0 : window.sxpPopup('');
12889
12875
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(null);
12890
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
12876
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
12891
12877
  };
12892
12878
  const renderPopupDetail = React.useMemo(() => {
12893
12879
  var _a, _b, _c;
12894
12880
  return (_c = (_b = (_a = schema === null || schema === void 0 ? void 0 : schema.sxpPageConf) === null || _a === void 0 ? void 0 : _a.globalConfig) === null || _b === void 0 ? void 0 : _b.popupList) === null || _c === void 0 ? void 0 : _c.map((value, index) => {
12895
12881
  var _a, _b, _c, _d, _e, _f, _g, _h;
12896
- if ((value === null || value === void 0 ? void 0 : value.id) === popup) {
12882
+ if ((value === null || value === void 0 ? void 0 : value.id) === (popup === null || popup === void 0 ? void 0 : popup.id)) {
12897
12883
  const t = resolver[(_a = value === null || value === void 0 ? void 0 : value.item) === null || _a === void 0 ? void 0 : _a.type];
12898
12884
  const Component = withBindDataSource(t);
12899
12885
  const defaulSetting = (_b = t === null || t === void 0 ? void 0 : t.extend) === null || _b === void 0 ? void 0 : _b.defaulSetting;
@@ -12904,7 +12890,7 @@ Made in Italy` })));
12904
12890
  }
12905
12891
  });
12906
12892
  }, [schema, popup, resolver]);
12907
- return (React.createElement(Modal$1, { visible: !!visible, onClose: handleClose, padding: 0, modalStyle: { position: 'fixed' } }, renderPopupDetail));
12893
+ return (React.createElement(Modal$1, { popup: visible, onClose: handleClose, padding: 0, modalStyle: { position: 'fixed' } }, renderPopupDetail));
12908
12894
  };
12909
12895
 
12910
12896
  /*