pb-sxp-ui 1.0.2-alpha.1 → 1.0.3-alpha.1

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 (40) hide show
  1. package/dist/index.cjs +476 -411
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.css +4 -115
  4. package/dist/index.js +476 -411
  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 +476 -411
  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/ExpandableText.js +2 -2
  15. package/es/core/components/SxpPageRender/index.js +1 -1
  16. package/es/materials/sxp/popup/CommodityDetail/index.d.ts +20 -1
  17. package/es/materials/sxp/popup/CommodityDetail/index.js +44 -21
  18. package/es/materials/sxp/popup/CommodityDetail/material.js +36 -1
  19. package/es/materials/sxp/popup/CommodityDetail/settingRender.d.ts +134 -0
  20. package/es/materials/sxp/popup/CommodityDetail/settingRender.js +167 -0
  21. package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +3 -3
  22. package/es/materials/sxp/popup/CommodityDetailDiroNew/material.js +11 -0
  23. package/es/materials/sxp/popup/CommodityDetailDiroNew/settingRender.d.ts +6 -6
  24. package/es/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +4 -8
  25. package/es/materials/sxp/popup/index.d.ts +0 -1
  26. package/es/materials/sxp/popup/index.js +0 -1
  27. package/lib/core/components/SxpPageRender/ExpandableText.js +2 -2
  28. package/lib/core/components/SxpPageRender/index.js +1 -1
  29. package/lib/materials/sxp/popup/CommodityDetail/index.d.ts +20 -1
  30. package/lib/materials/sxp/popup/CommodityDetail/index.js +43 -20
  31. package/lib/materials/sxp/popup/CommodityDetail/material.js +36 -1
  32. package/lib/materials/sxp/popup/CommodityDetail/settingRender.d.ts +134 -0
  33. package/lib/materials/sxp/popup/CommodityDetail/settingRender.js +169 -0
  34. package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +3 -3
  35. package/lib/materials/sxp/popup/CommodityDetailDiroNew/material.js +11 -0
  36. package/lib/materials/sxp/popup/CommodityDetailDiroNew/settingRender.d.ts +6 -6
  37. package/lib/materials/sxp/popup/CommodityDetailDiroNew/settingRender.js +4 -8
  38. package/lib/materials/sxp/popup/index.d.ts +0 -1
  39. package/lib/materials/sxp/popup/index.js +0 -1
  40. package/package.json +1 -1
package/dist/pb-ui.js CHANGED
@@ -882,7 +882,7 @@
882
882
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\AppointForm\settingRender.tsx
883
883
  *
884
884
  */
885
- var settingRender$3 = [
885
+ var settingRender$4 = [
886
886
  {
887
887
  type: 'Text',
888
888
  label: '组件名称',
@@ -1071,7 +1071,7 @@
1071
1071
  category: 'popup',
1072
1072
  type: 'AppointForm',
1073
1073
  related: {
1074
- settingRender: settingRender$3,
1074
+ settingRender: settingRender$4,
1075
1075
  bindableProps: [],
1076
1076
  interactionRender: interactionRender$8
1077
1077
  },
@@ -1097,6 +1097,190 @@
1097
1097
  sort: 2
1098
1098
  });
1099
1099
 
1100
+ /*
1101
+ * @Author: binruan@chatlabs.com
1102
+ * @Date: 2024-04-02 18:01:34
1103
+ * @LastEditors: binruan@chatlabs.com
1104
+ * @LastEditTime: 2024-04-02 18:01:41
1105
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiro\settingRender.tsx
1106
+ *
1107
+ */
1108
+ /*
1109
+ * @Author: binruan@chatlabs.com
1110
+ * @Date: 2024-03-26 16:50:25
1111
+ * @LastEditors: binruan@chatlabs.com
1112
+ * @LastEditTime: 2024-03-28 18:42:26
1113
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\settingRender.tsx
1114
+ *
1115
+ */
1116
+ var settingRender$3 = [
1117
+ {
1118
+ title: '商品图片',
1119
+ child: [
1120
+ {
1121
+ type: 'Radius',
1122
+ label: '轮播指示器',
1123
+ options: [
1124
+ {
1125
+ label: '居左',
1126
+ value: 'left'
1127
+ },
1128
+ {
1129
+ label: '居中',
1130
+ value: 'center'
1131
+ }
1132
+ ],
1133
+ name: ['props', 'swiper', 'dotsAlign']
1134
+ },
1135
+ {
1136
+ type: 'Number',
1137
+ name: ['props', 'swiper', 'delay'],
1138
+ addonAfter: 's'
1139
+ }
1140
+ ]
1141
+ },
1142
+ {
1143
+ title: '商品文本',
1144
+ child: [
1145
+ {
1146
+ name: ['props', 'commodityStyles'],
1147
+ type: 'SelectLinkage',
1148
+ child: [
1149
+ {
1150
+ label: '字段',
1151
+ type: 'Select',
1152
+ options: [
1153
+ {
1154
+ label: '商品名称',
1155
+ value: 'title'
1156
+ },
1157
+ {
1158
+ label: '系列名称',
1159
+ value: 'collection'
1160
+ },
1161
+ {
1162
+ label: '价格',
1163
+ value: 'price'
1164
+ },
1165
+ {
1166
+ label: '商品描述',
1167
+ value: 'info'
1168
+ }
1169
+ ],
1170
+ name: ['props', 'commodityStyles', 'field'],
1171
+ initialValue: 'title'
1172
+ },
1173
+ {
1174
+ type: 'Group',
1175
+ label: '标题字体',
1176
+ child: [
1177
+ {
1178
+ type: 'Color',
1179
+ name: ['color']
1180
+ },
1181
+ {
1182
+ type: 'Select',
1183
+ options: [{ label: '黑体', value: '黑体' }],
1184
+ name: ['fontFamily']
1185
+ },
1186
+ {
1187
+ type: 'Number',
1188
+ addonAfter: 'px',
1189
+ name: ['fontSize']
1190
+ }
1191
+ ]
1192
+ },
1193
+ {
1194
+ label: '标题样式',
1195
+ type: 'TextStyle'
1196
+ },
1197
+ {
1198
+ label: '标题对齐',
1199
+ type: 'TextAlign'
1200
+ },
1201
+ {
1202
+ label: '默认行数',
1203
+ type: 'Number',
1204
+ name: ['lineClamp']
1205
+ }
1206
+ ]
1207
+ }
1208
+ ]
1209
+ },
1210
+ {
1211
+ title: '购买按钮样式',
1212
+ child: [
1213
+ {
1214
+ type: 'Color',
1215
+ label: '背景色',
1216
+ name: ['props', 'buttonStyle', 'backgroundColor'],
1217
+ initialValue: '#000'
1218
+ },
1219
+ {
1220
+ type: 'Group',
1221
+ label: '尺寸',
1222
+ child: [
1223
+ {
1224
+ type: 'Number',
1225
+ name: ['props', 'buttonStyle', 'height'],
1226
+ addonAfter: 'H'
1227
+ }
1228
+ ]
1229
+ },
1230
+ {
1231
+ type: 'Group',
1232
+ label: '圆角',
1233
+ child: [
1234
+ {
1235
+ type: 'Slider',
1236
+ name: ['props', 'buttonStyle', 'borderRadius'],
1237
+ max: 100
1238
+ },
1239
+ {
1240
+ type: 'Number',
1241
+ name: ['props', 'buttonStyle', 'borderRadius'],
1242
+ addonAfter: 'px',
1243
+ max: 100
1244
+ }
1245
+ ]
1246
+ },
1247
+ {
1248
+ type: 'TextMargin',
1249
+ name: ['props', 'buttonStyle']
1250
+ },
1251
+ {
1252
+ type: 'Group',
1253
+ label: '字体',
1254
+ child: [
1255
+ {
1256
+ type: 'Color',
1257
+ name: ['props', 'buttonStyle', 'color'],
1258
+ initialValue: '#fff'
1259
+ },
1260
+ {
1261
+ type: 'Select',
1262
+ name: ['props', 'buttonStyle', 'fontFamily'],
1263
+ options: [{ label: '黑体', value: '黑体' }]
1264
+ },
1265
+ {
1266
+ type: 'Number',
1267
+ name: ['props', 'buttonStyle', 'fontSize'],
1268
+ addonAfter: 'px'
1269
+ }
1270
+ ]
1271
+ },
1272
+ {
1273
+ type: 'TextStyle',
1274
+ name: ['props', 'buttonStyle']
1275
+ },
1276
+ {
1277
+ type: 'TextAlign',
1278
+ name: ['props', 'buttonStyle']
1279
+ }
1280
+ ]
1281
+ }
1282
+ ];
1283
+
1100
1284
  /**
1101
1285
  * SSR Window 4.0.2
1102
1286
  * Better handling for window object in SSR environment
@@ -7980,100 +8164,278 @@
7980
8164
  };
7981
8165
  }
7982
8166
 
7983
- const CommodityDetail$1 = (_a) => {
7984
- var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
7985
- var { content, style, bgImg, onClick, schema, isDefault, bottom_image } = _a, props = __rest(_a, ["content", "style", "bgImg", "onClick", "schema", "isDefault", "bottom_image"]);
7986
- const { sxpParameter } = useSxpDataSource();
7987
- const { popupDetailData, bffEventReport, isPreview, waterFallData } = useSxpDataSource();
7988
- const { jumpToWeb, productView } = useEventReport();
7989
- const curTimeRef = React.useRef(null);
7990
- const product = (_b = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.video) === null || _b === void 0 ? void 0 : _b.bindProduct;
7991
- const cta = (_d = (_c = popupDetailData === null || popupDetailData === void 0 ? void 0 : popupDetailData.video) === null || _c === void 0 ? void 0 : _c.bindProduct) === null || _d === void 0 ? void 0 : _d.bindCta;
7992
- const handleLink = () => {
7993
- if (product === null || product === void 0 ? void 0 : product.link) {
7994
- jumpToWeb(popupDetailData, product, cta);
7995
- productView(popupDetailData, product, cta, curTimeRef.current);
7996
- window.location.href = window.getJointUtmLink(product.link);
7997
- }
7998
- };
7999
- React.useEffect(() => {
8000
- const initTime = () => {
8001
- curTimeRef.current = new Date();
8002
- };
8003
- initTime();
8004
- window.addEventListener('pageshow', initTime);
8005
- return () => {
8006
- window.removeEventListener('pageshow', initTime);
8007
- };
8008
- }, []);
8009
- const priceText = React.useMemo(() => {
8010
- var _a, _b, _c, _d, _e;
8011
- if ((product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price)) {
8012
- return `${(_c = (_b = (_a = product === null || product === void 0 ? void 0 : product.currency) === null || _a === void 0 ? void 0 : _a.split('-')[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase()) !== null && _c !== void 0 ? _c : ''}${(_e = (_d = product === null || product === void 0 ? void 0 : product.price) === null || _d === void 0 ? void 0 : _d.toLocaleString('zh', {
8013
- minimumFractionDigits: 0
8014
- })) !== null && _e !== void 0 ? _e : ''}`;
8015
- }
8016
- else {
8017
- return '$7,000';
8018
- }
8019
- }, [product === null || product === void 0 ? void 0 : product.price, product === null || product === void 0 ? void 0 : product.currency]);
8020
- const width = isPreview ? 375 : window.innerWidth;
8021
- return (React.createElement("div", { className: 'pb-commondity' },
8022
- React.createElement("div", Object.assign({ className: css.css(Object.assign({}, style)) }, props),
8023
- product && ((_e = product === null || product === void 0 ? void 0 : product.homePage) === null || _e === void 0 ? void 0 : _e.length) > 0 && (React.createElement(Swiper, { height: width, modules: [Pagination, Autoplay], pagination: { clickable: true, bulletActiveClass: 'swipe-item-active-bullet' }, loop: true, autoplay: {
8024
- delay: 3000
8025
- } }, (_f = product === null || product === void 0 ? void 0 : product.homePage) === null || _f === void 0 ? void 0 : _f.map((src) => {
8026
- return (React.createElement(SwiperSlide, { key: src },
8027
- React.createElement("div", { style: {
8028
- overflow: 'hidden',
8029
- width,
8030
- height: width
8031
- } },
8032
- React.createElement("img", { src: src, style: { height: '100%', width: '100%', objectFit: 'cover' } }))));
8033
- }))),
8034
- !((_g = product === null || product === void 0 ? void 0 : product.homePage) === null || _g === void 0 ? void 0 : _g.length) && (React.createElement("div", { className: css.css({
8035
- position: 'relative',
8036
- height: 0,
8037
- width: '100%',
8038
- paddingBottom: '100%',
8039
- overflow: 'hidden'
8040
- }) },
8041
- React.createElement("img", { className: css.css({
8042
- position: 'absolute',
8043
- left: 0,
8044
- top: 0,
8045
- objectFit: 'cover',
8046
- width: '100%'
8047
- }), src: (_h = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _h !== void 0 ? _h : bottom_image, alt: '' }))),
8048
- React.createElement("div", { className: 'pb-commondity-content' },
8049
- React.createElement("div", { className: 'pb-commondity-content-collection' }, (_j = product === null || product === void 0 ? void 0 : product.collection) !== null && _j !== void 0 ? _j : 'Tiffany Lock'),
8050
- React.createElement("div", { className: 'pb-commondity-content-title' }, (_k = product === null || product === void 0 ? void 0 : product.title) !== null && _k !== void 0 ? _k : 'Pendant in Yellow Gold with Diamonds, Medium'),
8051
- React.createElement("div", { className: 'pb-commondity-content-price' }, priceText),
8052
- React.createElement("div", { className: 'pb-commondity-content-info' }, (_l = product === null || product === void 0 ? void 0 : product.info) !== null && _l !== void 0 ? _l : `The design inspiration of Tiffany Lock series comes from the power of connection and inclusiveness, and the
8053
- bold and avant-garde visual design interprets the emotional bond connecting my heart. The Tiffany Lock
8054
- collection is unisex and is inspired by the padlock pattern found in the Tiffany Antique Collection. This
8055
- necklace features a stylish and eye-catching oval clasp chain decorated with a lock pattern. Crafted from
8056
- 18-karat gold, this necklace is embellished with hand-set diamonds.`))),
8057
- (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { onClick: handleLink, className: 'pb-commondity-btn' }, (_m = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _m !== void 0 ? _m : 'Purchase on Website'))));
8058
- };
8059
- var CommodityDetailComponent = React.memo(CommodityDetail$1);
8060
-
8061
8167
  /*
8062
8168
  * @Author: binruan@chatlabs.com
8063
- * @Date: 2023-07-28 18:29:57
8169
+ * @Date: 2023-11-02 18:34:34
8064
8170
  * @LastEditors: binruan@chatlabs.com
8065
- * @LastEditTime: 2024-03-20 15:52:25
8066
- * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetail\material.tsx
8171
+ * @LastEditTime: 2024-04-02 10:33:15
8172
+ * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8067
8173
  *
8068
8174
  */
8069
- const CommodityDetail = createMaterial(CommodityDetailComponent, {
8070
- displayName: '商品详情',
8071
- icon: '',
8072
- category: 'popup',
8073
- type: 'CommodityDetail',
8074
- defaulSetting: {
8075
- props: {},
8076
- style: {}
8175
+ const closeIcon = '';
8176
+ const Modal = ({ visible, onClose, children, modalStyle, padding, popupAniData }) => {
8177
+ const { popupAni } = useEditor();
8178
+ const cssAni = popupAniData !== null && popupAniData !== void 0 ? popupAniData : popupAni;
8179
+ const [isShow, setIsShow] = React.useState(false);
8180
+ const modalEleRef = React.useRef(null);
8181
+ React.useEffect(() => {
8182
+ const parentNode = document.getElementById('sxp-render');
8183
+ const node = document.getElementById('pb-modal');
8184
+ if (node) {
8185
+ modalEleRef.current = node;
8186
+ }
8187
+ else {
8188
+ modalEleRef.current = document.createElement('div');
8189
+ modalEleRef.current.setAttribute('id', 'pb-modal');
8190
+ parentNode === null || parentNode === void 0 ? void 0 : parentNode.appendChild(modalEleRef.current);
8191
+ }
8192
+ }, []);
8193
+ React.useEffect(() => {
8194
+ if (visible) {
8195
+ setIsShow(true);
8196
+ }
8197
+ else {
8198
+ setTimeout(() => {
8199
+ setIsShow(false);
8200
+ }, cssAni === null || cssAni === void 0 ? void 0 : cssAni.duration);
8201
+ }
8202
+ }, [visible, cssAni]);
8203
+ if (!modalEleRef.current)
8204
+ return null;
8205
+ const handleClose = lodash.debounce(() => {
8206
+ onClose === null || onClose === void 0 ? void 0 : onClose();
8207
+ }, 300);
8208
+ 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 },
8209
+ 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) => {
8210
+ e.stopPropagation();
8211
+ e.preventDefault();
8212
+ } },
8213
+ React.createElement("div", { onClick: onClose, className: 'modal-icon-wrapper' },
8214
+ React.createElement("img", { src: closeIcon, alt: 'close', className: 'modal-icon' })),
8215
+ children)), modalEleRef.current);
8216
+ };
8217
+ var Modal$1 = React.memo(Modal);
8218
+
8219
+ /*
8220
+ * @Author: binruan@chatlabs.com
8221
+ * @Date: 2023-12-26 16:11:34
8222
+ * @LastEditors: binruan@chatlabs.com
8223
+ * @LastEditTime: 2024-04-02 18:52:59
8224
+ * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ExpandableText.tsx
8225
+ *
8226
+ */
8227
+ const limitTextLastWholeWord = (originalText = '', limit) => {
8228
+ // 匹配到中文
8229
+ const chineseRegex = /[\u4e00-\u9fa5]+/;
8230
+ if (chineseRegex.test(originalText)) {
8231
+ return originalText.slice(0, 54);
8232
+ }
8233
+ const words = originalText.split(' ');
8234
+ const newWords = [];
8235
+ for (let i = 0; i < words.length; i++) {
8236
+ newWords.push(words[i]);
8237
+ const tempText = newWords.join(' ');
8238
+ if (tempText.length >= limit)
8239
+ break;
8240
+ }
8241
+ // const _words = newWords.length === words.length ? newWords : newWords.slice(0, newWords.length - 1);
8242
+ const _words = newWords.length > 1 && newWords.length < words.length ? newWords.slice(0, newWords.length - 1) : newWords;
8243
+ return _words.join(' ') + ' ';
8244
+ };
8245
+ const ExpandableText = ({ text, maxStr = 108, style, className, onClick, foldText, unfoldText, isPost }) => {
8246
+ const [isShowMore, setIsShowMore] = React.useState(true);
8247
+ const [isShow, setIsShow] = React.useState(false);
8248
+ const lineClamp = Number((style === null || style === void 0 ? void 0 : style.lineClamp) || 2);
8249
+ const multiRow = React.useRef(null);
8250
+ const handleClick = React.useCallback(() => {
8251
+ setIsShowMore(!isShowMore);
8252
+ }, [isShowMore]);
8253
+ React.useMemo(() => {
8254
+ return !isShowMore && text.length > maxStr ? limitTextLastWholeWord(text, maxStr) + '...' : text;
8255
+ }, [text, maxStr, isShowMore]);
8256
+ React.useEffect(() => {
8257
+ if (multiRow.current && isPost) {
8258
+ setIsShowMore(true);
8259
+ setTimeout(() => {
8260
+ var _a;
8261
+ setIsShow(false);
8262
+ try {
8263
+ const cs = (_a = window === null || window === void 0 ? void 0 : window.getComputedStyle) === null || _a === void 0 ? void 0 : _a.call(window, multiRow.current);
8264
+ const height = parseFloat(cs === null || cs === void 0 ? void 0 : cs.height);
8265
+ const lh = parseFloat(cs === null || cs === void 0 ? void 0 : cs.lineHeight);
8266
+ const fs = parseFloat(cs === null || cs === void 0 ? void 0 : cs.fontSize) + 4;
8267
+ const lineHeight = isNaN(lh) ? fs : lh;
8268
+ if (text && height > lineHeight * lineClamp) {
8269
+ setIsShowMore(false);
8270
+ setIsShow(true);
8271
+ }
8272
+ }
8273
+ catch (_b) { }
8274
+ }, 100);
8275
+ }
8276
+ }, [multiRow, text, lineClamp, style, isPost]);
8277
+ return (React.createElement("div", { className: className, style: Object.assign({}, style), hidden: !text || text === '' },
8278
+ React.createElement("div", { ref: multiRow, style: {
8279
+ overflow: 'hidden',
8280
+ WebkitLineClamp: !isShowMore ? lineClamp : '',
8281
+ textOverflow: 'ellipsis',
8282
+ display: '-webkit-box',
8283
+ WebkitBoxOrient: 'vertical',
8284
+ wordBreak: 'break-word'
8285
+ }, dangerouslySetInnerHTML: { __html: text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>') } }),
8286
+ isShow && text && (React.createElement("span", { style: { textDecoration: 'underline', cursor: 'pointer' }, onClick: onClick !== null && onClick !== void 0 ? onClick : handleClick }, isShowMore ? unfoldText || 'show less' : foldText || 'show more'))));
8287
+ };
8288
+ var ExpandableText$1 = React.memo(ExpandableText);
8289
+
8290
+ const CommodityDetail$1 = (_a) => {
8291
+ var _b, _c, _d, _e, _f, _g, _h, _j;
8292
+ var { content, style, bgImg, onClick, schema, isDefault, bottom_image, tipText, isPost, viewTime, rec, swiper, commodityStyles, buttonStyle } = _a, props = __rest(_a, ["content", "style", "bgImg", "onClick", "schema", "isDefault", "bottom_image", "tipText", "isPost", "viewTime", "rec", "swiper", "commodityStyles", "buttonStyle"]);
8293
+ const { sxpParameter } = useSxpDataSource();
8294
+ const { popupDetailData, bffEventReport, isPreview, waterFallData } = useSxpDataSource();
8295
+ const { jumpToWeb, productView } = useEventReport();
8296
+ const curTimeRef = React.useRef(null);
8297
+ const [showModal, setShowModal] = React.useState(false);
8298
+ const data = isPost ? rec : popupDetailData;
8299
+ const product = isPost ? data === null || data === void 0 ? void 0 : data.product : (_b = data === null || data === void 0 ? void 0 : data.video) === null || _b === void 0 ? void 0 : _b.bindProduct;
8300
+ const cta = isPost ? (_c = data === null || data === void 0 ? void 0 : data.product) === null || _c === void 0 ? void 0 : _c.bindCta : (_e = (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.bindProduct) === null || _e === void 0 ? void 0 : _e.bindCta;
8301
+ const handleLink = () => {
8302
+ if (product === null || product === void 0 ? void 0 : product.link) {
8303
+ jumpToWeb(popupDetailData, product, cta);
8304
+ if (!isPost) {
8305
+ productView(data, product, cta, viewTime || curTimeRef.current);
8306
+ }
8307
+ window.location.href = window.getJointUtmLink(product.link);
8308
+ }
8309
+ };
8310
+ React.useEffect(() => {
8311
+ const initTime = () => {
8312
+ curTimeRef.current = new Date();
8313
+ };
8314
+ initTime();
8315
+ window.addEventListener('pageshow', initTime);
8316
+ return () => {
8317
+ window.removeEventListener('pageshow', initTime);
8318
+ };
8319
+ }, []);
8320
+ const priceText = React.useMemo(() => {
8321
+ var _a, _b, _c, _d, _e;
8322
+ if ((product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price)) {
8323
+ return `${(_c = (_b = (_a = product === null || product === void 0 ? void 0 : product.currency) === null || _a === void 0 ? void 0 : _a.split('-')[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase()) !== null && _c !== void 0 ? _c : ''}${(_e = (_d = product === null || product === void 0 ? void 0 : product.price) === null || _d === void 0 ? void 0 : _d.toLocaleString('zh', {
8324
+ minimumFractionDigits: 0
8325
+ })) !== null && _e !== void 0 ? _e : ''}`;
8326
+ }
8327
+ else {
8328
+ return '$7,000';
8329
+ }
8330
+ }, [product === null || product === void 0 ? void 0 : product.price, product === null || product === void 0 ? void 0 : product.currency]);
8331
+ const width = isPreview ? 375 : window.innerWidth;
8332
+ const renderContent = ({ isPost }) => {
8333
+ var _a, _b, _c;
8334
+ return (React.createElement("div", { className: 'pb-commondity-content' },
8335
+ React.createElement("div", { className: 'pb-commondity-content-collection', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.collection }, (_a = product === null || product === void 0 ? void 0 : product.collection) !== null && _a !== void 0 ? _a : 'Tiffany Lock'),
8336
+ React.createElement("div", { className: 'pb-commondity-content-title', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.title }, (_b = product === null || product === void 0 ? void 0 : product.title) !== null && _b !== void 0 ? _b : 'Pendant in Yellow Gold with Diamonds, Medium'),
8337
+ React.createElement("div", { className: 'pb-commondity-content-price', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.price }, priceText),
8338
+ React.createElement(ExpandableText$1, { foldText: tipText === null || tipText === void 0 ? void 0 : tipText.foldText, unfoldText: tipText === null || tipText === void 0 ? void 0 : tipText.unfoldText, onClick: () => setShowModal(true), isPost: isPost, text: (_c = product === null || product === void 0 ? void 0 : product.info) !== null && _c !== void 0 ? _c : `The design inspiration of Tiffany Lock series comes from the power of connection and inclusiveness, and the
8339
+ bold and avant-garde visual design interprets the emotional bond connecting my heart. The Tiffany Lock
8340
+ collection is unisex and is inspired by the padlock pattern found in the Tiffany Antique Collection. This
8341
+ necklace features a stylish and eye-catching oval clasp chain decorated with a lock pattern. Crafted from
8342
+ 18-karat gold, this necklace is embellished with hand-set diamonds.`, maxStr: 79, className: 'pb-commondity-content-info', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.info })));
8343
+ };
8344
+ const renderBtn = () => {
8345
+ var _a;
8346
+ return (React.createElement(React.Fragment, null, (isDefault || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { onClick: handleLink, className: 'pb-commondity-btn', style: buttonStyle }, (_a = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _a !== void 0 ? _a : 'Purchase on Website'))));
8347
+ };
8348
+ return (React.createElement("div", { className: 'pb-commondity' },
8349
+ React.createElement("div", Object.assign({ className: css.css(Object.assign({}, style)) }, props),
8350
+ product && ((_f = product === null || product === void 0 ? void 0 : product.homePage) === null || _f === void 0 ? void 0 : _f.length) > 0 && (React.createElement(Swiper, { height: width, modules: [Pagination, Autoplay], pagination: {
8351
+ clickable: true,
8352
+ bulletActiveClass: 'swipe-item-active-bullet',
8353
+ clickableClass: (swiper === null || swiper === void 0 ? void 0 : swiper.dotsAlign) === 'left'
8354
+ ? 'commondityDetail-swiper-clickable-left'
8355
+ : 'commondityDetail-swiper-clickable-center'
8356
+ }, loop: true, autoplay: {
8357
+ delay: (swiper === null || swiper === void 0 ? void 0 : swiper.delay) * 1000
8358
+ } }, (_g = product === null || product === void 0 ? void 0 : product.homePage) === null || _g === void 0 ? void 0 : _g.map((src) => {
8359
+ return (React.createElement(SwiperSlide, { key: src },
8360
+ React.createElement("div", { style: {
8361
+ overflow: 'hidden',
8362
+ width,
8363
+ height: width
8364
+ } },
8365
+ React.createElement("img", { src: src, style: { height: '100%', width: '100%', objectFit: 'cover' } }))));
8366
+ }))),
8367
+ !((_h = product === null || product === void 0 ? void 0 : product.homePage) === null || _h === void 0 ? void 0 : _h.length) && (React.createElement("div", { className: css.css({
8368
+ position: 'relative',
8369
+ height: 0,
8370
+ width: '100%',
8371
+ paddingBottom: '100%',
8372
+ overflow: 'hidden'
8373
+ }) },
8374
+ React.createElement("img", { className: css.css({
8375
+ position: 'absolute',
8376
+ left: 0,
8377
+ top: 0,
8378
+ objectFit: 'cover',
8379
+ width: '100%'
8380
+ }), src: (_j = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _j !== void 0 ? _j : bottom_image, alt: '' }))),
8381
+ renderContent({ isPost })),
8382
+ renderBtn(),
8383
+ React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) },
8384
+ renderContent({ isPost: false }),
8385
+ renderBtn())));
8386
+ };
8387
+ var CommodityDetailComponent = React.memo(CommodityDetail$1);
8388
+
8389
+ /*
8390
+ * @Author: binruan@chatlabs.com
8391
+ * @Date: 2023-07-28 18:29:57
8392
+ * @LastEditors: binruan@chatlabs.com
8393
+ * @LastEditTime: 2024-04-02 18:13:10
8394
+ * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetail\material.tsx
8395
+ *
8396
+ */
8397
+ const CommodityDetail = createMaterial(CommodityDetailComponent, {
8398
+ displayName: '商品详情',
8399
+ icon: '',
8400
+ category: 'popup',
8401
+ type: 'CommodityDetail',
8402
+ related: {
8403
+ settingRender: settingRender$3
8404
+ },
8405
+ defaulSetting: {
8406
+ props: {
8407
+ swiper: {
8408
+ dotsAlign: 'center',
8409
+ delay: 3
8410
+ },
8411
+ commodityStyles: {
8412
+ price: {
8413
+ color: '#000',
8414
+ fontSize: 18
8415
+ },
8416
+ title: {
8417
+ color: '#000',
8418
+ fontSize: 23
8419
+ },
8420
+ collection: {
8421
+ fontSize: 12,
8422
+ color: '#000'
8423
+ },
8424
+ info: {
8425
+ color: 'gray',
8426
+ fontSize: 12
8427
+ }
8428
+ },
8429
+ buttonStyle: {
8430
+ backgroundColor: '#000',
8431
+ fontSize: 12,
8432
+ height: 45,
8433
+ fontWeight: 'bold',
8434
+ textAlign: 'center',
8435
+ color: 'rgba(255, 255, 255, 0.9)'
8436
+ }
8437
+ },
8438
+ style: {}
8077
8439
  },
8078
8440
  w: 100,
8079
8441
  h: 40,
@@ -8119,7 +8481,7 @@
8119
8481
  }
8120
8482
  ];
8121
8483
 
8122
- var img$3 = "";
8484
+ var img$2 = "";
8123
8485
 
8124
8486
  /*
8125
8487
  * @Author: binruan@chatlabs.com
@@ -8163,7 +8525,7 @@
8163
8525
  };
8164
8526
  return (React.createElement("div", Object.assign({ className: `pb-prompt ${css.css(Object.assign({}, style))}` }, props),
8165
8527
  React.createElement("div", { className: 'pb-prompt-icon' },
8166
- React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$3 })),
8528
+ React.createElement("img", { width: '100%', src: iconSrc !== null && iconSrc !== void 0 ? iconSrc : img$2 })),
8167
8529
  React.createElement("div", { className: 'pb-prompt-content' }, content),
8168
8530
  React.createElement("button", { className: 'pb-prompt-btn', onClick: handleOk }, btnText)));
8169
8531
  };
@@ -8181,7 +8543,7 @@
8181
8543
  },
8182
8544
  defaulSetting: {
8183
8545
  props: {
8184
- icon: img$3,
8546
+ icon: img$2,
8185
8547
  content: 'You have successfully completed the appointment!',
8186
8548
  btnText: 'OK'
8187
8549
  },
@@ -8192,184 +8554,6 @@
8192
8554
  sort: 3
8193
8555
  });
8194
8556
 
8195
- var img$2 = "";
8196
-
8197
- const CommodityDetailDiro$1 = (_a) => {
8198
- var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
8199
- var { style, isDefault, rec, viewTime, isPost, bottom_image } = _a, props = __rest(_a, ["style", "isDefault", "rec", "viewTime", "isPost", "bottom_image"]);
8200
- const [spread, setSpread] = React.useState(true);
8201
- const { sxpParameter } = useSxpDataSource();
8202
- const { popupDetailData, bffEventReport, isPreview, swiperRef, waterFallData } = useSxpDataSource();
8203
- const { jumpToWeb, productView } = useEventReport();
8204
- const scrollRef = React.useRef(null);
8205
- const touchRef = React.useRef(null);
8206
- const touchMoveRef = React.useRef(null);
8207
- const [stopSlide, setStopSlide] = React.useState(false);
8208
- const [isBottom, setIsBottom] = React.useState(false);
8209
- const [isTop, setIsTop] = React.useState(true);
8210
- const curTimeRef = React.useRef(null);
8211
- const data = isPost ? rec : popupDetailData;
8212
- const product = isPost ? data === null || data === void 0 ? void 0 : data.product : (_b = data === null || data === void 0 ? void 0 : data.video) === null || _b === void 0 ? void 0 : _b.bindProduct;
8213
- const cta = isPost ? (_c = data === null || data === void 0 ? void 0 : data.product) === null || _c === void 0 ? void 0 : _c.bindCta : (_e = (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.bindProduct) === null || _e === void 0 ? void 0 : _e.bindCta;
8214
- const handleLink = () => {
8215
- if (product === null || product === void 0 ? void 0 : product.link) {
8216
- jumpToWeb(data, product, cta);
8217
- if (!isPost) {
8218
- productView(data, product, cta, viewTime || curTimeRef.current);
8219
- }
8220
- window.location.href = window.getJointUtmLink(product.link);
8221
- }
8222
- };
8223
- React.useEffect(() => {
8224
- const initTime = () => {
8225
- curTimeRef.current = new Date();
8226
- };
8227
- initTime();
8228
- window.addEventListener('pageshow', initTime);
8229
- return () => {
8230
- window.removeEventListener('pageshow', initTime);
8231
- };
8232
- }, []);
8233
- const priceText = React.useMemo(() => {
8234
- var _a, _b, _c, _d, _e;
8235
- if ((product === null || product === void 0 ? void 0 : product.currency) && (product === null || product === void 0 ? void 0 : product.price)) {
8236
- return `${(_c = (_b = (_a = product === null || product === void 0 ? void 0 : product.currency) === null || _a === void 0 ? void 0 : _a.split('-')[1]) === null || _b === void 0 ? void 0 : _b.toUpperCase()) !== null && _c !== void 0 ? _c : ''}${(_e = (_d = product === null || product === void 0 ? void 0 : product.price) === null || _d === void 0 ? void 0 : _d.toLocaleString('zh', {
8237
- minimumFractionDigits: 0
8238
- })) !== null && _e !== void 0 ? _e : ''}`;
8239
- }
8240
- else {
8241
- return '$7,000';
8242
- }
8243
- }, [product === null || product === void 0 ? void 0 : product.price, product === null || product === void 0 ? void 0 : product.currency]);
8244
- const width = isPreview ? 375 : window.innerWidth;
8245
- const handleClickCollapse = () => {
8246
- setSpread(!spread);
8247
- };
8248
- React.useEffect(() => {
8249
- var _a, _b;
8250
- console.log((_a = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) === null || _a === void 0 ? void 0 : _a.scrollHeight, window.innerHeight);
8251
- if ((scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) && ((_b = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) === null || _b === void 0 ? void 0 : _b.scrollHeight) > window.innerHeight) {
8252
- setStopSlide(true);
8253
- }
8254
- }, [scrollRef]);
8255
- React.useEffect(() => {
8256
- const handleScroll = () => {
8257
- if (scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) {
8258
- const { scrollTop, scrollHeight, clientHeight } = scrollRef.current;
8259
- const isBottom = scrollTop + clientHeight === scrollHeight;
8260
- if (isBottom) {
8261
- setIsBottom(true);
8262
- }
8263
- else {
8264
- setIsBottom(false);
8265
- }
8266
- if (scrollTop === 0) {
8267
- setIsTop(true);
8268
- }
8269
- else {
8270
- setIsTop(false);
8271
- }
8272
- }
8273
- };
8274
- if (scrollRef.current) {
8275
- scrollRef.current.addEventListener('scroll', handleScroll);
8276
- }
8277
- return () => {
8278
- if (scrollRef.current) {
8279
- scrollRef.current.removeEventListener('scroll', handleScroll);
8280
- }
8281
- };
8282
- }, [scrollRef]);
8283
- const handleTouchStart = (event) => {
8284
- event.stopPropagation();
8285
- touchRef.current = event.touches[0].clientY;
8286
- touchMoveRef.current = true;
8287
- };
8288
- const handleTouchMove = (event) => {
8289
- var _a, _b, _c, _d;
8290
- if (touchMoveRef.current) {
8291
- touchMoveRef.current = false;
8292
- const currentY = event.touches[0].clientY;
8293
- const diff = touchRef.current - currentY;
8294
- if (diff > 0 && (isBottom || !stopSlide)) {
8295
- (_b = (_a = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _a === void 0 ? void 0 : _a.swiper) === null || _b === void 0 ? void 0 : _b.slideNext();
8296
- }
8297
- else if (diff < 0 && (isTop || !stopSlide)) {
8298
- (_d = (_c = swiperRef === null || swiperRef === void 0 ? void 0 : swiperRef.current) === null || _c === void 0 ? void 0 : _c.swiper) === null || _d === void 0 ? void 0 : _d.slidePrev();
8299
- }
8300
- }
8301
- };
8302
- return (React.createElement("div", { className: 'pb-commondityDiro' },
8303
- React.createElement("div", Object.assign({ ref: scrollRef, className: css.css(Object.assign({}, style)) }, props, { onTouchStart: handleTouchStart, onTouchMove: (e) => {
8304
- e.stopPropagation();
8305
- handleTouchMove(e);
8306
- } }),
8307
- product && ((_f = product === null || product === void 0 ? void 0 : product.homePage) === null || _f === void 0 ? void 0 : _f.length) > 0 && (React.createElement(Swiper, { height: width, modules: [Pagination, Autoplay], pagination: { clickable: true, bulletActiveClass: 'swipe-item-active-bullet' }, loop: true, autoplay: {
8308
- delay: 3000
8309
- } }, (_g = product === null || product === void 0 ? void 0 : product.homePage) === null || _g === void 0 ? void 0 : _g.map((src) => {
8310
- return (React.createElement(SwiperSlide, { key: src },
8311
- React.createElement("div", { style: {
8312
- overflow: 'hidden',
8313
- width,
8314
- height: width
8315
- } },
8316
- React.createElement("img", { src: src, style: { height: '100%', width: '100%', objectFit: 'cover' } }))));
8317
- }))),
8318
- !((_h = product === null || product === void 0 ? void 0 : product.homePage) === null || _h === void 0 ? void 0 : _h.length) && (React.createElement("div", { className: css.css({
8319
- position: 'relative',
8320
- height: 0,
8321
- width: '100%',
8322
- paddingBottom: '100%',
8323
- overflow: 'hidden'
8324
- }) },
8325
- React.createElement("img", { className: css.css({
8326
- position: 'absolute',
8327
- left: 0,
8328
- top: 0,
8329
- objectFit: 'cover',
8330
- width: '100%'
8331
- }), src: (_j = sxpParameter === null || sxpParameter === void 0 ? void 0 : sxpParameter.bottom_image) !== null && _j !== void 0 ? _j : bottom_image, alt: '' }))),
8332
- React.createElement("div", { className: 'pb-commondityDiro-content' },
8333
- React.createElement("div", { className: 'pb-commondityDiro-content-title' }, (_k = product === null || product === void 0 ? void 0 : product.title) !== null && _k !== void 0 ? _k : 'MEDIUM LADY D-LITE BAG'),
8334
- React.createElement("div", { className: 'pb-commondityDiro-content-collection', hidden: !!product && (!(product === null || product === void 0 ? void 0 : product.collection) || (product === null || product === void 0 ? void 0 : product.collection) === '') }, (product === null || product === void 0 ? void 0 : product.collection) || 'Gold-Tone and White Butterfly Zodiac Embroidery'),
8335
- React.createElement("div", { className: 'pb-commondityDiro-content-scrollRef', hidden: !!product && !(product === null || product === void 0 ? void 0 : product.itemId) }, (product === null || product === void 0 ? void 0 : product.itemId) ? `Reference: ${product === null || product === void 0 ? void 0 : product.itemId}` : 'Reference: M0565OESU_M01E'),
8336
- React.createElement("div", { className: 'pb-commondityDiro-content-line' }),
8337
- React.createElement("div", { className: 'pb-commondityDiro-content-price' }, priceText)),
8338
- React.createElement("div", { className: 'pb-commondityDiro-desc', hidden: !!product && (!(product === null || product === void 0 ? void 0 : product.info) || (product === null || product === void 0 ? void 0 : product.info) === '') },
8339
- React.createElement("div", { className: 'pb-commondityDiro-desc-collapse', onClick: handleClickCollapse },
8340
- React.createElement("div", { className: 'pb-commondityDiro-desc-collapse-title' }, "DESCRIPTION"),
8341
- React.createElement("img", { className: `pb-commondityDiro-desc-collapse-icon ${spread ? 'pb-commondityDiro-desc-collapse-iconActive' : ''}`, src: img$2, alt: '' })),
8342
- React.createElement("div", { className: 'pb-commondityDiro-desc-info', hidden: !spread }, (product === null || product === void 0 ? void 0 : product.info) ||
8343
- 'The Lady D-Lite bag combines classic elegance with House modernity. The style is fully embroidered with a gold-tone and white Butterfly Zodiac motif by Pietro Ruffo, showcasing a constellation enhanced by astrological signs and adorned with butterflies. A Christian Dior Paris signature adorns the front, while D.I.O.R. charms in pale gold-finish metal further enhance and highlight the silhouette. Featuring a wide, removable embroidered shoulder strap, the medium Lady D-Lite bag can be carried by hand or worn crossbody.')),
8344
- (!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement(React.Fragment, null,
8345
- React.createElement("div", { className: 'pb-commondityDiro-h90' }),
8346
- React.createElement("div", { className: 'pb-commondityDiro-bottom' },
8347
- React.createElement("button", { onClick: handleLink, className: 'pb-commondityDiro-bottom-btn' }, (_l = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _l !== void 0 ? _l : 'SHOP NOW')))))));
8348
- };
8349
- var CommodityDetailDiroComponent = React.memo(CommodityDetailDiro$1);
8350
-
8351
- /*
8352
- * @Author: binruan@chatlabs.com
8353
- * @Date: 2023-07-28 18:29:57
8354
- * @LastEditors: binruan@chatlabs.com
8355
- * @LastEditTime: 2024-01-05 11:37:37
8356
- * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiro\material.tsx
8357
- *
8358
- */
8359
- const CommodityDetailDiro = createMaterial(CommodityDetailDiroComponent, {
8360
- displayName: '商品详情',
8361
- icon: '',
8362
- category: 'popup',
8363
- type: 'CommodityDetailDiro',
8364
- defaulSetting: {
8365
- props: {},
8366
- style: {}
8367
- },
8368
- w: 100,
8369
- h: 40,
8370
- sort: 1
8371
- });
8372
-
8373
8557
  /*
8374
8558
  * @Author: binruan@chatlabs.com
8375
8559
  * @Date: 2024-03-26 16:50:25
@@ -8513,6 +8697,10 @@
8513
8697
  }
8514
8698
  ]
8515
8699
  },
8700
+ {
8701
+ type: 'TextMargin',
8702
+ name: ['props', 'buttonStyle']
8703
+ },
8516
8704
  {
8517
8705
  type: 'Group',
8518
8706
  label: '字体',
@@ -8541,142 +8729,11 @@
8541
8729
  {
8542
8730
  type: 'TextAlign',
8543
8731
  name: ['props', 'buttonStyle']
8544
- },
8545
- {
8546
- type: 'TextSpace',
8547
- name: ['props', 'buttonStyle']
8548
- },
8549
- {
8550
- type: 'TextMargin',
8551
- name: ['props', 'buttonStyle']
8552
8732
  }
8553
8733
  ]
8554
8734
  }
8555
8735
  ];
8556
8736
 
8557
- /*
8558
- * @Author: binruan@chatlabs.com
8559
- * @Date: 2023-11-02 18:34:34
8560
- * @LastEditors: binruan@chatlabs.com
8561
- * @LastEditTime: 2024-04-02 10:33:15
8562
- * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\Modal\index.tsx
8563
- *
8564
- */
8565
- const closeIcon = '';
8566
- const Modal = ({ visible, onClose, children, modalStyle, padding, popupAniData }) => {
8567
- const { popupAni } = useEditor();
8568
- const cssAni = popupAniData !== null && popupAniData !== void 0 ? popupAniData : popupAni;
8569
- const [isShow, setIsShow] = React.useState(false);
8570
- const modalEleRef = React.useRef(null);
8571
- React.useEffect(() => {
8572
- const parentNode = document.getElementById('sxp-render');
8573
- const node = document.getElementById('pb-modal');
8574
- if (node) {
8575
- modalEleRef.current = node;
8576
- }
8577
- else {
8578
- modalEleRef.current = document.createElement('div');
8579
- modalEleRef.current.setAttribute('id', 'pb-modal');
8580
- parentNode === null || parentNode === void 0 ? void 0 : parentNode.appendChild(modalEleRef.current);
8581
- }
8582
- }, []);
8583
- React.useEffect(() => {
8584
- if (visible) {
8585
- setIsShow(true);
8586
- }
8587
- else {
8588
- setTimeout(() => {
8589
- setIsShow(false);
8590
- }, cssAni === null || cssAni === void 0 ? void 0 : cssAni.duration);
8591
- }
8592
- }, [visible, cssAni]);
8593
- if (!modalEleRef.current)
8594
- return null;
8595
- const handleClose = lodash.debounce(() => {
8596
- onClose === null || onClose === void 0 ? void 0 : onClose();
8597
- }, 300);
8598
- 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 },
8599
- 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) => {
8600
- e.stopPropagation();
8601
- e.preventDefault();
8602
- } },
8603
- React.createElement("div", { onClick: onClose, className: 'modal-icon-wrapper' },
8604
- React.createElement("img", { src: closeIcon, alt: 'close', className: 'modal-icon' })),
8605
- children)), modalEleRef.current);
8606
- };
8607
- var Modal$1 = React.memo(Modal);
8608
-
8609
- /*
8610
- * @Author: binruan@chatlabs.com
8611
- * @Date: 2023-12-26 16:11:34
8612
- * @LastEditors: binruan@chatlabs.com
8613
- * @LastEditTime: 2024-04-02 10:57:30
8614
- * @FilePath: \pb-sxp-ui\src\core\components\SxpPageRender\ExpandableText.tsx
8615
- *
8616
- */
8617
- const limitTextLastWholeWord = (originalText = '', limit) => {
8618
- // 匹配到中文
8619
- const chineseRegex = /[\u4e00-\u9fa5]+/;
8620
- if (chineseRegex.test(originalText)) {
8621
- return originalText.slice(0, 54);
8622
- }
8623
- const words = originalText.split(' ');
8624
- const newWords = [];
8625
- for (let i = 0; i < words.length; i++) {
8626
- newWords.push(words[i]);
8627
- const tempText = newWords.join(' ');
8628
- if (tempText.length >= limit)
8629
- break;
8630
- }
8631
- // const _words = newWords.length === words.length ? newWords : newWords.slice(0, newWords.length - 1);
8632
- const _words = newWords.length > 1 && newWords.length < words.length ? newWords.slice(0, newWords.length - 1) : newWords;
8633
- return _words.join(' ') + ' ';
8634
- };
8635
- const ExpandableText = ({ text, maxStr = 108, style, className, onClick, foldText, unfoldText, isPost }) => {
8636
- const [isShowMore, setIsShowMore] = React.useState(true);
8637
- const [isShow, setIsShow] = React.useState(false);
8638
- const lineClamp = Number((style === null || style === void 0 ? void 0 : style.lineClamp) || 2);
8639
- const multiRow = React.useRef(null);
8640
- const handleClick = React.useCallback(() => {
8641
- setIsShowMore(!isShowMore);
8642
- }, [isShowMore]);
8643
- React.useMemo(() => {
8644
- return !isShowMore && text.length > maxStr ? limitTextLastWholeWord(text, maxStr) + '...' : text;
8645
- }, [text, maxStr, isShowMore]);
8646
- React.useEffect(() => {
8647
- if (multiRow.current && isPost) {
8648
- setIsShowMore(true);
8649
- setTimeout(() => {
8650
- var _a;
8651
- setIsShow(false);
8652
- try {
8653
- const cs = (_a = window === null || window === void 0 ? void 0 : window.getComputedStyle) === null || _a === void 0 ? void 0 : _a.call(window, multiRow.current);
8654
- const height = parseFloat(cs === null || cs === void 0 ? void 0 : cs.height);
8655
- const lh = parseFloat(cs === null || cs === void 0 ? void 0 : cs.lineHeight);
8656
- const fs = parseFloat(cs === null || cs === void 0 ? void 0 : cs.fontSize) + 4;
8657
- const lineHeight = isNaN(lh) ? fs : lh;
8658
- if (text && height > lineHeight * lineClamp) {
8659
- setIsShowMore(false);
8660
- setIsShow(true);
8661
- }
8662
- }
8663
- catch (_b) { }
8664
- }, 100);
8665
- }
8666
- }, [multiRow, text, lineClamp, style, isPost]);
8667
- return (React.createElement("div", { className: className, style: Object.assign({}, style) },
8668
- React.createElement("div", { ref: multiRow, style: {
8669
- overflow: 'hidden',
8670
- WebkitLineClamp: !isShowMore ? lineClamp : '',
8671
- textOverflow: 'ellipsis',
8672
- display: '-webkit-box',
8673
- WebkitBoxOrient: 'vertical',
8674
- wordBreak: 'break-word'
8675
- }, dangerouslySetInnerHTML: { __html: text ? text === null || text === void 0 ? void 0 : text.replace(/\n/g, '</br>') : React.createElement(React.Fragment, null) } }),
8676
- isShow && text && (React.createElement("span", { style: { textDecoration: 'underline', cursor: 'pointer' }, onClick: onClick !== null && onClick !== void 0 ? onClick : handleClick }, isShowMore ? unfoldText || 'show less' : foldText || 'show more'))));
8677
- };
8678
- var ExpandableText$1 = React.memo(ExpandableText);
8679
-
8680
8737
  const CommodityDetailDiroNew$1 = (_a) => {
8681
8738
  var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
8682
8739
  var { style, isDefault, rec, viewTime, isPost, bottom_image, tipText, swiper, commodityStyles, buttonStyle } = _a, props = __rest(_a, ["style", "isDefault", "rec", "viewTime", "isPost", "bottom_image", "tipText", "swiper", "commodityStyles", "buttonStyle"]);
@@ -8726,7 +8783,7 @@
8726
8783
  }
8727
8784
  }, [product === null || product === void 0 ? void 0 : product.price, product === null || product === void 0 ? void 0 : product.currency]);
8728
8785
  const width = isPreview ? 375 : window.innerWidth;
8729
- const productInfoText = () => {
8786
+ const productInfoText = ({ isPost }) => {
8730
8787
  return (React.createElement("div", { hidden: !!product && (!(product === null || product === void 0 ? void 0 : product.info) || (product === null || product === void 0 ? void 0 : product.info) === '') },
8731
8788
  React.createElement(ExpandableText$1, { isPost: isPost, onClick: () => setShowModal(true), className: 'pb-commondityDiroNew-info', style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.info, foldText: tipText === null || tipText === void 0 ? void 0 : tipText.foldText, unfoldText: tipText === null || tipText === void 0 ? void 0 : tipText.unfoldText, text: (product === null || product === void 0 ? void 0 : product.info) ||
8732
8789
  `Unveiled at the Spring-Summer 2023 fashion show, the Dior Toujours bag is distinguished by a casual and practical design. Crafted in black calfskin with Macrocannage topstitching, it showcases a spacious interior compartment with a matching pouch to organize essentials. Its leather strap closure keeps items secure while the D of the CD Lock closure twists to adjust the sides and enhance the bag's silhouette. The leather handles can be adjusted using the small notches in order to be able to carry the large bag by hand or wear it over the shoulder. CD Lock and strap closures D.I.O.R. charms Removable interior pouch Adjustable leather handles Dust bag included
@@ -8773,8 +8830,8 @@ Made in Italy` })));
8773
8830
  React.createElement("div", { className: 'pb-commondityDiroNew-content-top-price', hidden: !!product && !(product === null || product === void 0 ? void 0 : product.taxInfo), style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.taxInfo }, (_l = product === null || product === void 0 ? void 0 : product.taxInfo) !== null && _l !== void 0 ? _l : '税费'))),
8774
8831
  React.createElement("div", { className: 'pb-commondityDiroNew-content-collection', hidden: !!product && (!(product === null || product === void 0 ? void 0 : product.collection) || (product === null || product === void 0 ? void 0 : product.collection) === ''), style: commodityStyles === null || commodityStyles === void 0 ? void 0 : commodityStyles.collection }, (product === null || product === void 0 ? void 0 : product.collection) || 'Black Macrocannage Calfskin'),
8775
8832
  (!product || (product === null || product === void 0 ? void 0 : product.link)) && (React.createElement("button", { onClick: handleLink, className: 'pb-commondityDiroNew-btn', style: buttonStyle }, (_m = cta === null || cta === void 0 ? void 0 : cta.enTitle) !== null && _m !== void 0 ? _m : 'Shop now')),
8776
- productInfoText())),
8777
- React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText())));
8833
+ productInfoText({ isPost }))),
8834
+ React.createElement(Modal$1, { visible: showModal, onClose: () => setShowModal(false) }, productInfoText({ isPost: false }))));
8778
8835
  };
8779
8836
  var CommodityDetailDiroNewComponent = React.memo(CommodityDetailDiroNew$1);
8780
8837
 
@@ -8782,7 +8839,7 @@ Made in Italy` })));
8782
8839
  * @Author: binruan@chatlabs.com
8783
8840
  * @Date: 2024-03-20 10:27:31
8784
8841
  * @LastEditors: binruan@chatlabs.com
8785
- * @LastEditTime: 2024-03-28 16:05:12
8842
+ * @LastEditTime: 2024-04-02 15:12:53
8786
8843
  * @FilePath: \pb-sxp-ui\src\materials\sxp\popup\CommodityDetailDiroNew\material.tsx
8787
8844
  *
8788
8845
  */
@@ -8824,6 +8881,17 @@ Made in Italy` })));
8824
8881
  fontSize: 13,
8825
8882
  textAlign: 'right'
8826
8883
  }
8884
+ },
8885
+ buttonStyle: {
8886
+ backgroundColor: '#000',
8887
+ fontSize: 12,
8888
+ height: 52,
8889
+ fontWeight: 'bold',
8890
+ textAlign: 'center',
8891
+ color: '#fff',
8892
+ borderRadius: 25,
8893
+ marginTop: 16,
8894
+ marginBottom: 16
8827
8895
  }
8828
8896
  },
8829
8897
  style: {}
@@ -9873,7 +9941,6 @@ Made in Italy` })));
9873
9941
  AppointForm: AppointForm,
9874
9942
  Commodity: Commodity,
9875
9943
  CommodityDetail: CommodityDetail,
9876
- CommodityDetailDiro: CommodityDetailDiro,
9877
9944
  CommodityDetailDiroNew: CommodityDetailDiroNew,
9878
9945
  CommodityDiro: CommodityDiro,
9879
9946
  CommodityDiroNew: CommodityDiroNew,
@@ -10939,9 +11006,7 @@ Made in Italy` })));
10939
11006
  return (_d = globalConfig === null || globalConfig === void 0 ? void 0 : globalConfig.productPost) === null || _d === void 0 ? void 0 : _d.map((value, index) => {
10940
11007
  var _a, _b, _c, _d, _e, _f;
10941
11008
  const Component = withBindDataSource(resolver[(_a = value === null || value === void 0 ? void 0 : value.item) === null || _a === void 0 ? void 0 : _a.type]);
10942
- return (React.createElement(Component, Object.assign({ key: index, textStyle: (_b = value === null || value === void 0 ? void 0 : value.item) === null || _b === void 0 ? void 0 : _b.textStyle, bindDatas: (_d = (_c = value === null || value === void 0 ? void 0 : value.item) === null || _c === void 0 ? void 0 : _c.bindDatas) !== null && _d !== void 0 ? _d : [] }, (_e = value === null || value === void 0 ? void 0 : value.item) === null || _e === void 0 ? void 0 : _e.props, { event: ((_f = value === null || value === void 0 ? void 0 : value.item) === null || _f === void 0 ? void 0 : _f.event) || {}, schema: schema, id: value === null || value === void 0 ? void 0 : value.id, viewTime: viewTime.current, rec: rec, isPost: true, tipText: tipText, style: { height: '100%', overflow: 'auto' },
10943
- // ProductInfo
10944
- data: rec, height: height, width: containerWidth })));
11009
+ return (React.createElement(Component, Object.assign({ key: index, textStyle: (_b = value === null || value === void 0 ? void 0 : value.item) === null || _b === void 0 ? void 0 : _b.textStyle, bindDatas: (_d = (_c = value === null || value === void 0 ? void 0 : value.item) === null || _c === void 0 ? void 0 : _c.bindDatas) !== null && _d !== void 0 ? _d : [] }, (_e = value === null || value === void 0 ? void 0 : value.item) === null || _e === void 0 ? void 0 : _e.props, { event: ((_f = value === null || value === void 0 ? void 0 : value.item) === null || _f === void 0 ? void 0 : _f.event) || {}, schema: schema, id: value === null || value === void 0 ? void 0 : value.id, viewTime: viewTime.current, rec: rec, isPost: true, tipText: tipText, style: { height: '100%', overflow: 'auto' } })));
10945
11010
  });
10946
11011
  }
10947
11012
  return null;