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/index.cjs CHANGED
@@ -724,6 +724,11 @@ const item = {
724
724
  pathArr: [0],
725
725
  positionY: 0
726
726
  };
727
+ const popupInit = {
728
+ id: '',
729
+ duration: 0,
730
+ name: 'none'
731
+ };
727
732
  const EditorContext = React.createContext({
728
733
  resolver: {},
729
734
  currentNode: null,
@@ -743,12 +748,8 @@ const EditorContext = React.createContext({
743
748
  prePiontData: [],
744
749
  undoStack: [item],
745
750
  redoStack: [],
746
- popup: '',
747
- setPopup: () => { },
748
- popupAni: {
749
- name: 'none',
750
- duration: 0
751
- }
751
+ popup: popupInit,
752
+ setPopup: () => { }
752
753
  });
753
754
  const EditorCore = React.forwardRef(({ children, resolver, isSsr, schema, enableDataSource = true, utmVal }, ref) => {
754
755
  const [currentNode, setCurrentNode] = React.useState(null);
@@ -771,25 +772,10 @@ const EditorCore = React.forwardRef(({ children, resolver, isSsr, schema, enable
771
772
  */
772
773
  const [undoStack, setUndoStack] = React.useState([[item]]);
773
774
  const [redoStack, setRedoStack] = React.useState([]);
774
- const [popup, setPopup] = React.useState('');
775
- const [popupAni, setPopupAni] = React.useState({
776
- name: 'none',
777
- duration: 0
778
- });
775
+ const [popup, setPopup] = React.useState(popupInit);
779
776
  typeof window !== 'undefined' &&
780
777
  (window.sxpPopup = (type, aniType) => {
781
- if (aniType && (aniType === null || aniType === void 0 ? void 0 : aniType.name) !== 'none') {
782
- setPopupAni(Object.assign(Object.assign({}, popupAni), aniType));
783
- }
784
- else {
785
- setPopupAni({
786
- name: 'none',
787
- duration: 0
788
- });
789
- }
790
- setTimeout(() => {
791
- setPopup(type);
792
- });
778
+ setPopup(Object.assign(Object.assign(Object.assign({}, popupInit), { id: type }), aniType));
793
779
  });
794
780
  typeof window !== 'undefined' &&
795
781
  (window.getJointUtmLink = (url) => {
@@ -865,8 +851,7 @@ const EditorCore = React.forwardRef(({ children, resolver, isSsr, schema, enable
865
851
  setUndoStack,
866
852
  getCurPageConf,
867
853
  popup,
868
- setPopup,
869
- popupAni
854
+ setPopup
870
855
  } },
871
856
  React.createElement(DataSourceProvider$1, { isSsr: isSsr, enable: enableDataSource }, children)));
872
857
  });
@@ -1005,7 +990,6 @@ var settingRender$5 = [
1005
990
 
1006
991
  const AppointForm$1 = (_a) => {
1007
992
  var { columns, style, title, textStyle, submitBgColor, submitColor, submitText, layoutType, onClick } = _a, props = __rest(_a, ["columns", "style", "title", "textStyle", "submitBgColor", "submitColor", "submitText", "layoutType", "onClick"]);
1008
- useEditor();
1009
993
  const { submitForm } = useSxpDataSource();
1010
994
  const formRef = React.useRef();
1011
995
  const [loading, setLoading] = React.useState(false);
@@ -8102,7 +8086,7 @@ SwiperSlide.displayName = 'SwiperSlide';
8102
8086
  * @Author: binruan@chatlabs.com
8103
8087
  * @Date: 2024-03-12 10:59:06
8104
8088
  * @LastEditors: binruan@chatlabs.com
8105
- * @LastEditTime: 2024-03-18 17:38:46
8089
+ * @LastEditTime: 2024-04-11 22:30:45
8106
8090
  * @FilePath: \pb-sxp-ui\src\core\hooks\useEventReport.ts
8107
8091
  *
8108
8092
  */
@@ -8126,23 +8110,25 @@ function useEventReport() {
8126
8110
  else if (data === null || data === void 0 ? void 0 : data.product) {
8127
8111
  fromKName = 'productPage';
8128
8112
  }
8129
- bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8130
- eventInfo: {
8131
- eventSubject: 'jumpToWeb',
8132
- eventDescription: 'User jumped to website',
8133
- productId: (_h = product === null || product === void 0 ? void 0 : product.itemId) !== null && _h !== void 0 ? _h : '',
8134
- productName: (_j = product === null || product === void 0 ? void 0 : product.title) !== null && _j !== void 0 ? _j : '',
8135
- price: (product === null || product === void 0 ? void 0 : product.price) ? (product === null || product === void 0 ? void 0 : product.price) + '' : '0',
8136
- productCollection: (_k = product === null || product === void 0 ? void 0 : product.collection) !== null && _k !== void 0 ? _k : '',
8137
- fromKName,
8138
- fromKPage: location === null || location === void 0 ? void 0 : location.href,
8139
- contentTags: (product === null || product === void 0 ? void 0 : product.tags) ? JSON.stringify(product === null || product === void 0 ? void 0 : product.tags) : '',
8140
- position: (data === null || data === void 0 ? void 0 : data.position) + '',
8141
- 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 : '',
8142
- relatedCtatId: (_o = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _o !== void 0 ? _o : '',
8143
- traceInfo: (_p = product === null || product === void 0 ? void 0 : product.traceInfo) !== null && _p !== void 0 ? _p : ''
8144
- }
8145
- });
8113
+ if (product === null || product === void 0 ? void 0 : product.price) {
8114
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8115
+ eventInfo: {
8116
+ eventSubject: 'jumpToWeb',
8117
+ eventDescription: 'User jumped to website',
8118
+ productId: (_h = product === null || product === void 0 ? void 0 : product.itemId) !== null && _h !== void 0 ? _h : '',
8119
+ productName: (_j = product === null || product === void 0 ? void 0 : product.title) !== null && _j !== void 0 ? _j : '',
8120
+ price: (product === null || product === void 0 ? void 0 : product.price) ? (product === null || product === void 0 ? void 0 : product.price) + '' : '0',
8121
+ productCollection: (_k = product === null || product === void 0 ? void 0 : product.collection) !== null && _k !== void 0 ? _k : '',
8122
+ fromKName,
8123
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
8124
+ contentTags: (product === null || product === void 0 ? void 0 : product.tags) ? JSON.stringify(product === null || product === void 0 ? void 0 : product.tags) : '',
8125
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
8126
+ 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 : '',
8127
+ relatedCtatId: (_o = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _o !== void 0 ? _o : '',
8128
+ traceInfo: (_p = product === null || product === void 0 ? void 0 : product.traceInfo) !== null && _p !== void 0 ? _p : ''
8129
+ }
8130
+ });
8131
+ }
8146
8132
  }, [bffEventReport, popupDetailData, isFromHashtag]);
8147
8133
  const productView = React.useCallback((data, product, cta, viewTime) => {
8148
8134
  var _a, _b, _c, _d;
@@ -8153,24 +8139,26 @@ function useEventReport() {
8153
8139
  else if (data === null || data === void 0 ? void 0 : data.product) {
8154
8140
  fromKName = 'productPage';
8155
8141
  }
8156
- bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8157
- eventInfo: {
8158
- productId: product === null || product === void 0 ? void 0 : product.itemId,
8159
- productName: product === null || product === void 0 ? void 0 : product.title,
8160
- price: (product === null || product === void 0 ? void 0 : product.price) + '',
8161
- productCollection: product === null || product === void 0 ? void 0 : product.collection,
8162
- fromKName,
8163
- fromKPage: location === null || location === void 0 ? void 0 : location.href,
8164
- contentTags: JSON.stringify(product === null || product === void 0 ? void 0 : product.tags),
8165
- position: (data === null || data === void 0 ? void 0 : data.position) + '',
8166
- relatedContentId: (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.itemId,
8167
- relatedCtatId: cta === null || cta === void 0 ? void 0 : cta.itemId,
8168
- traceInfo: product === null || product === void 0 ? void 0 : product.traceInfo,
8169
- timeOnSite: Math.floor((new Date() - viewTime) / 1000) + '',
8170
- eventSubject: 'productView',
8171
- eventDescription: 'User browsed the product'
8172
- }
8173
- });
8142
+ if (product === null || product === void 0 ? void 0 : product.price) {
8143
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
8144
+ eventInfo: {
8145
+ productId: product === null || product === void 0 ? void 0 : product.itemId,
8146
+ productName: product === null || product === void 0 ? void 0 : product.title,
8147
+ price: (product === null || product === void 0 ? void 0 : product.price) + '',
8148
+ productCollection: product === null || product === void 0 ? void 0 : product.collection,
8149
+ fromKName,
8150
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
8151
+ contentTags: JSON.stringify(product === null || product === void 0 ? void 0 : product.tags),
8152
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
8153
+ relatedContentId: (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.itemId,
8154
+ relatedCtatId: cta === null || cta === void 0 ? void 0 : cta.itemId,
8155
+ traceInfo: product === null || product === void 0 ? void 0 : product.traceInfo,
8156
+ timeOnSite: Math.floor((new Date() - viewTime) / 1000) + '',
8157
+ eventSubject: 'productView',
8158
+ eventDescription: 'User browsed the product'
8159
+ }
8160
+ });
8161
+ }
8174
8162
  }, [bffEventReport, popupDetailData]);
8175
8163
  return {
8176
8164
  jumpToWeb,
@@ -8182,14 +8170,13 @@ function useEventReport() {
8182
8170
  * @Author: binruan@chatlabs.com
8183
8171
  * @Date: 2023-11-02 18:34:34
8184
8172
  * @LastEditors: binruan@chatlabs.com
8185
- * @LastEditTime: 2024-04-10 11:11:50
8173
+ * @LastEditTime: 2024-04-12 11:23:00
8186
8174
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8187
8175
  *
8188
8176
  */
8189
8177
  const closeIcon = '';
8190
- const Modal = ({ visible, onClose, children, modalStyle, padding, popupAniData }) => {
8191
- const { popupAni } = useEditor();
8192
- const cssAni = popupAniData !== null && popupAniData !== void 0 ? popupAniData : popupAni;
8178
+ const Modal = ({ visible, onClose, children, modalStyle, padding, popup }) => {
8179
+ var _a;
8193
8180
  const [isShow, setIsShow] = React.useState(false);
8194
8181
  const modalEleRef = React.useRef(null);
8195
8182
  React.useEffect(() => {
@@ -8204,29 +8191,32 @@ const Modal = ({ visible, onClose, children, modalStyle, padding, popupAniData }
8204
8191
  parentNode === null || parentNode === void 0 ? void 0 : parentNode.appendChild(modalEleRef.current);
8205
8192
  }
8206
8193
  }, []);
8194
+ const isOpen = React.useMemo(() => {
8195
+ return ((popup === null || popup === void 0 ? void 0 : popup.id) && (popup === null || popup === void 0 ? void 0 : popup.id) !== '') || visible;
8196
+ }, [visible, popup]);
8207
8197
  React.useEffect(() => {
8208
- if (visible) {
8198
+ if (isOpen) {
8209
8199
  setIsShow(true);
8210
8200
  }
8211
8201
  else {
8212
8202
  setTimeout(() => {
8213
8203
  setIsShow(false);
8214
- }, cssAni === null || cssAni === void 0 ? void 0 : cssAni.duration);
8204
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
8215
8205
  }
8216
- }, [visible, cssAni]);
8206
+ }, [isOpen, popup]);
8217
8207
  if (!modalEleRef.current)
8218
8208
  return null;
8219
8209
  const handleClose = lodash.debounce(() => {
8220
8210
  onClose === null || onClose === void 0 ? void 0 : onClose();
8221
8211
  }, 300);
8222
- 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 },
8223
- 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) => {
8212
+ 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 },
8213
+ 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) => {
8224
8214
  e.stopPropagation();
8225
8215
  e.preventDefault();
8226
8216
  } },
8227
8217
  React.createElement("div", { onClick: onClose, className: 'modal-icon-wrapper' },
8228
8218
  React.createElement("img", { src: closeIcon, alt: 'close', className: 'modal-icon' })),
8229
- children)), modalEleRef.current);
8219
+ children)))), modalEleRef.current);
8230
8220
  };
8231
8221
  var Modal$1 = React.memo(Modal);
8232
8222
 
@@ -8532,7 +8522,6 @@ const getMediaValueByMode = (obj) => {
8532
8522
 
8533
8523
  const Prompt$1 = (_a) => {
8534
8524
  var { content, btnText, style, icon, onClick } = _a, props = __rest(_a, ["content", "btnText", "style", "icon", "onClick"]);
8535
- useEditor();
8536
8525
  const iconSrc = typeof icon === 'string' ? icon : getMediaValueByMode(icon);
8537
8526
  const handleOk = () => {
8538
8527
  window === null || window === void 0 ? void 0 : window.sxpPopup('');
@@ -9184,7 +9173,7 @@ const EventProvider = (_a) => {
9184
9173
  var { rec, children, className, onClick, style, isExternalLink = false } = _a; __rest(_a, ["rec", "children", "className", "onClick", "style", "isExternalLink"]);
9185
9174
  const ref = React.useRef(null);
9186
9175
  const isOnScreen = useOnScreen(ref);
9187
- const { popupAni } = useEditor();
9176
+ const { popup } = useEditor();
9188
9177
  const { setPopupDetailData, ctaEvent } = useSxpDataSource();
9189
9178
  const { jumpToWeb } = useEventReport();
9190
9179
  React.useEffect(() => {
@@ -9206,17 +9195,17 @@ const EventProvider = (_a) => {
9206
9195
  }, rec, item);
9207
9196
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(rec);
9208
9197
  if (isExternalLink) {
9209
- 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) {
9198
+ 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) {
9210
9199
  const cta = (_e = rec === null || rec === void 0 ? void 0 : rec.video) === null || _e === void 0 ? void 0 : _e.bindCta;
9211
9200
  const product = (_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.bindProduct;
9212
9201
  jumpToWeb(rec, product, cta);
9213
- 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;
9202
+ 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;
9214
9203
  }
9215
9204
  }
9216
9205
  else {
9217
9206
  onClick === null || onClick === void 0 ? void 0 : onClick();
9218
9207
  }
9219
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9208
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9220
9209
  return (React.createElement("div", { ref: ref, className: className, style: style, onClick: handleClick }, children));
9221
9210
  };
9222
9211
  var EventProvider$1 = React.memo(EventProvider);
@@ -9684,26 +9673,25 @@ const MultiCommodityDiro$1 = (_a) => {
9684
9673
  var _b, _c;
9685
9674
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9686
9675
  const { ctaEvent, setPopupDetailData, sxpParameter } = useSxpDataSource();
9687
- const { popupAni } = useEditor();
9676
+ const { popup } = useEditor();
9688
9677
  const { jumpToWeb } = useEventReport();
9689
9678
  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]);
9690
9679
  const handleClick = lodash.throttle((item) => {
9691
- var _a;
9692
9680
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9693
9681
  eventSubject: 'clickCta',
9694
9682
  eventDescription: 'User clicked the CTA'
9695
9683
  }, recData, item);
9696
9684
  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 }) }));
9697
9685
  if (isExternalLink) {
9698
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9686
+ if (item === null || item === void 0 ? void 0 : item.link) {
9699
9687
  jumpToWeb(recData, item, item.bindCta);
9700
- window.location.href = item.bindCta.link;
9688
+ window.location.href = item.link;
9701
9689
  }
9702
9690
  }
9703
9691
  else {
9704
9692
  onClick === null || onClick === void 0 ? void 0 : onClick();
9705
9693
  }
9706
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9694
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9707
9695
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9708
9696
  var _a, _b, _c, _d, _e, _f;
9709
9697
  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) }),
@@ -9798,26 +9786,25 @@ const MultiCommodity$1 = (_a) => {
9798
9786
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9799
9787
  const { sxpParameter } = useSxpDataSource();
9800
9788
  const { ctaEvent, setPopupDetailData } = useSxpDataSource();
9801
- const { popupAni } = useEditor();
9789
+ const { popup } = useEditor();
9802
9790
  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]);
9803
9791
  const { jumpToWeb } = useEventReport();
9804
9792
  const handleClick = lodash.throttle((item) => {
9805
- var _a;
9806
9793
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9807
9794
  eventSubject: 'clickCta',
9808
9795
  eventDescription: 'User clicked the CTA'
9809
9796
  }, recData, item);
9810
9797
  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 }) }));
9811
9798
  if (isExternalLink) {
9812
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9799
+ if (item === null || item === void 0 ? void 0 : item.link) {
9813
9800
  jumpToWeb(recData, item, item.bindCta);
9814
- window.location.href = item.bindCta.link;
9801
+ window.location.href = item.link;
9815
9802
  }
9816
9803
  }
9817
9804
  else {
9818
9805
  onClick === null || onClick === void 0 ? void 0 : onClick();
9819
9806
  }
9820
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9807
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9821
9808
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9822
9809
  var _a, _b, _c, _d, _e, _f;
9823
9810
  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) }),
@@ -9911,26 +9898,25 @@ const MultiCommodityDiroNew$1 = (_a) => {
9911
9898
  var _b, _c;
9912
9899
  var { content, style, bgImg, recData, onClick, bottom_image, ctaTempStyles, isExternalLink } = _a, props = __rest(_a, ["content", "style", "bgImg", "recData", "onClick", "bottom_image", "ctaTempStyles", "isExternalLink"]);
9913
9900
  const { ctaEvent, setPopupDetailData, sxpParameter } = useSxpDataSource();
9914
- const { popupAni } = useEditor();
9901
+ const { popup } = useEditor();
9915
9902
  const { jumpToWeb } = useEventReport();
9916
9903
  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]);
9917
9904
  const handleClick = lodash.throttle((item) => {
9918
- var _a;
9919
9905
  ctaEvent === null || ctaEvent === void 0 ? void 0 : ctaEvent({
9920
9906
  eventSubject: 'clickCta',
9921
9907
  eventDescription: 'User clicked the CTA'
9922
9908
  }, recData, item);
9923
9909
  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 }) }));
9924
9910
  if (isExternalLink) {
9925
- if ((_a = item === null || item === void 0 ? void 0 : item.bindCta) === null || _a === void 0 ? void 0 : _a.link) {
9911
+ if (item === null || item === void 0 ? void 0 : item.link) {
9926
9912
  jumpToWeb(recData, item, item.bindCta);
9927
- window.location.href = item.bindCta.link;
9913
+ window.location.href = item.link;
9928
9914
  }
9929
9915
  }
9930
9916
  else {
9931
9917
  onClick === null || onClick === void 0 ? void 0 : onClick();
9932
9918
  }
9933
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
9919
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
9934
9920
  return (React.createElement(Scroll$1, { isPadding: !!recData }, products === null || products === void 0 ? void 0 : products.map((item) => {
9935
9921
  var _a, _b, _c, _d, _e, _f;
9936
9922
  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) }),
@@ -11686,7 +11672,7 @@ var img$1 = "
11686
11672
  * @Author: binruan@chatlabs.com
11687
11673
  * @Date: 2024-01-10 10:58:24
11688
11674
  * @LastEditors: binruan@chatlabs.com
11689
- * @LastEditTime: 2024-04-07 15:18:35
11675
+ * @LastEditTime: 2024-04-12 11:29:01
11690
11676
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\WaterFall\index.tsx
11691
11677
  *
11692
11678
  */
@@ -11750,7 +11736,7 @@ const WaterFall = (props) => {
11750
11736
  relatedContentId: (_d = rec === null || rec === void 0 ? void 0 : rec.video) === null || _d === void 0 ? void 0 : _d.itemId,
11751
11737
  position: rec === null || rec === void 0 ? void 0 : rec.position,
11752
11738
  contentTags: JSON.stringify((_e = rec === null || rec === void 0 ? void 0 : rec.video) === null || _e === void 0 ? void 0 : _e.tags),
11753
- traceInfo: JSON.stringify((_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.traceInfo),
11739
+ traceInfo: (_f = rec === null || rec === void 0 ? void 0 : rec.video) === null || _f === void 0 ? void 0 : _f.traceInfo,
11754
11740
  hashTags: JSON.stringify([recData === null || recData === void 0 ? void 0 : recData.hashTag]),
11755
11741
  fromKName,
11756
11742
  fromKPage: location === null || location === void 0 ? void 0 : location.href,
@@ -12854,15 +12840,15 @@ const SxpPageRender = ({ globalConfig, descStyle, containerHeight = window.inner
12854
12840
  * @Author: binruan@chatlabs.com
12855
12841
  * @Date: 2023-10-31 10:56:01
12856
12842
  * @LastEditors: binruan@chatlabs.com
12857
- * @LastEditTime: 2024-04-10 09:57:19
12843
+ * @LastEditTime: 2024-04-12 09:50:58
12858
12844
  * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Popup\index.tsx
12859
12845
  *
12860
12846
  */
12861
12847
  const Popup = () => {
12862
- const { schema, resolver, popup, popupAni } = useEditor();
12848
+ const { schema, resolver, popup } = useEditor();
12863
12849
  const { setPopupDetailData, popupDetailData, bffEventReport } = useSxpDataSource();
12864
12850
  const { productView } = useEventReport();
12865
- const [visible, setVisible] = React.useState(false);
12851
+ const [visible, setVisible] = React.useState();
12866
12852
  const curTimeRef = React.useRef(null);
12867
12853
  React.useEffect(() => {
12868
12854
  const initTime = () => {
@@ -12875,33 +12861,33 @@ const Popup = () => {
12875
12861
  };
12876
12862
  }, []);
12877
12863
  React.useEffect(() => {
12878
- if (popup && popup !== '') {
12864
+ if (popup && (popup === null || popup === void 0 ? void 0 : popup.id) && (popup === null || popup === void 0 ? void 0 : popup.id) !== '') {
12879
12865
  curTimeRef.current = new Date();
12880
- setVisible(true);
12866
+ setVisible(popup);
12881
12867
  }
12882
12868
  }, [popup]);
12883
12869
  const handleClose = () => {
12884
- var _a, _b, _c;
12885
- if (!popup || popup === '' || !visible || new Date() - curTimeRef.current < (popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration)) {
12870
+ var _a, _b, _c, _d;
12871
+ 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)) {
12886
12872
  return;
12887
12873
  }
12888
- setVisible(false);
12874
+ setVisible(Object.assign(Object.assign({}, popup), { id: '' }));
12889
12875
  const data = popupDetailData;
12890
- const product = (_a = data === null || data === void 0 ? void 0 : data.video) === null || _a === void 0 ? void 0 : _a.bindProduct;
12891
- 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;
12876
+ const product = (_b = data === null || data === void 0 ? void 0 : data.video) === null || _b === void 0 ? void 0 : _b.bindProduct;
12877
+ 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;
12892
12878
  if (product && cta) {
12893
12879
  productView(data, product, cta, curTimeRef.current);
12894
12880
  }
12895
12881
  setTimeout(() => {
12896
12882
  window === null || window === void 0 ? void 0 : window.sxpPopup('');
12897
12883
  setPopupDetailData === null || setPopupDetailData === void 0 ? void 0 : setPopupDetailData(null);
12898
- }, popupAni === null || popupAni === void 0 ? void 0 : popupAni.duration);
12884
+ }, popup === null || popup === void 0 ? void 0 : popup.duration);
12899
12885
  };
12900
12886
  const renderPopupDetail = React.useMemo(() => {
12901
12887
  var _a, _b, _c;
12902
12888
  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) => {
12903
12889
  var _a, _b, _c, _d, _e, _f, _g, _h;
12904
- if ((value === null || value === void 0 ? void 0 : value.id) === popup) {
12890
+ if ((value === null || value === void 0 ? void 0 : value.id) === (popup === null || popup === void 0 ? void 0 : popup.id)) {
12905
12891
  const t = resolver[(_a = value === null || value === void 0 ? void 0 : value.item) === null || _a === void 0 ? void 0 : _a.type];
12906
12892
  const Component = withBindDataSource(t);
12907
12893
  const defaulSetting = (_b = t === null || t === void 0 ? void 0 : t.extend) === null || _b === void 0 ? void 0 : _b.defaulSetting;
@@ -12912,7 +12898,7 @@ const Popup = () => {
12912
12898
  }
12913
12899
  });
12914
12900
  }, [schema, popup, resolver]);
12915
- return (React.createElement(Modal$1, { visible: !!visible, onClose: handleClose, padding: 0, modalStyle: { position: 'fixed' } }, renderPopupDetail));
12901
+ return (React.createElement(Modal$1, { popup: visible, onClose: handleClose, padding: 0, modalStyle: { position: 'fixed' } }, renderPopupDetail));
12916
12902
  };
12917
12903
 
12918
12904
  /*