pb-sxp-ui 1.0.0

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 (384) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +111 -0
  3. package/dist/index.cjs +10752 -0
  4. package/dist/index.cjs.map +1 -0
  5. package/dist/index.css +1782 -0
  6. package/dist/index.js +10721 -0
  7. package/dist/index.js.map +1 -0
  8. package/dist/index.min.cjs +9 -0
  9. package/dist/index.min.cjs.map +1 -0
  10. package/dist/index.min.js +9 -0
  11. package/dist/index.min.js.map +1 -0
  12. package/dist/pb-ui.js +10748 -0
  13. package/dist/pb-ui.js.map +1 -0
  14. package/dist/pb-ui.min.js +9 -0
  15. package/dist/pb-ui.min.js.map +1 -0
  16. package/es/core/Pagebuilder/PagebuilderClass.d.ts +15 -0
  17. package/es/core/Pagebuilder/PagebuilderClass.js +42 -0
  18. package/es/core/Pagebuilder/index.d.ts +3 -0
  19. package/es/core/Pagebuilder/index.js +96 -0
  20. package/es/core/Pagebuilder/type.d.ts +55 -0
  21. package/es/core/Pagebuilder/type.js +1 -0
  22. package/es/core/components/SxpPageCore/index.d.ts +11 -0
  23. package/es/core/components/SxpPageCore/index.js +26 -0
  24. package/es/core/components/SxpPageRender/ExpandableText.d.ts +12 -0
  25. package/es/core/components/SxpPageRender/ExpandableText.js +54 -0
  26. package/es/core/components/SxpPageRender/FingerSwipeTip/index.d.ts +6 -0
  27. package/es/core/components/SxpPageRender/FingerSwipeTip/index.js +19 -0
  28. package/es/core/components/SxpPageRender/Hashtag/index.d.ts +11 -0
  29. package/es/core/components/SxpPageRender/Hashtag/index.js +40 -0
  30. package/es/core/components/SxpPageRender/LikeButton/index.d.ts +10 -0
  31. package/es/core/components/SxpPageRender/LikeButton/index.js +58 -0
  32. package/es/core/components/SxpPageRender/Modal/index.d.ts +9 -0
  33. package/es/core/components/SxpPageRender/Modal/index.js +44 -0
  34. package/es/core/components/SxpPageRender/Navbar.d.ts +8 -0
  35. package/es/core/components/SxpPageRender/Navbar.js +9 -0
  36. package/es/core/components/SxpPageRender/PictureGroup/Picture.d.ts +8 -0
  37. package/es/core/components/SxpPageRender/PictureGroup/Picture.js +19 -0
  38. package/es/core/components/SxpPageRender/PictureGroup/index.d.ts +13 -0
  39. package/es/core/components/SxpPageRender/PictureGroup/index.js +27 -0
  40. package/es/core/components/SxpPageRender/Popup/index.d.ts +3 -0
  41. package/es/core/components/SxpPageRender/Popup/index.js +60 -0
  42. package/es/core/components/SxpPageRender/ProductInfo/index.d.ts +14 -0
  43. package/es/core/components/SxpPageRender/ProductInfo/index.js +55 -0
  44. package/es/core/components/SxpPageRender/RenderCard.d.ts +11 -0
  45. package/es/core/components/SxpPageRender/RenderCard.js +40 -0
  46. package/es/core/components/SxpPageRender/ToggleButton/index.d.ts +10 -0
  47. package/es/core/components/SxpPageRender/ToggleButton/index.js +13 -0
  48. package/es/core/components/SxpPageRender/VideoWidget/index.d.ts +12 -0
  49. package/es/core/components/SxpPageRender/VideoWidget/index.js +219 -0
  50. package/es/core/components/SxpPageRender/WaterFall/List.d.ts +3 -0
  51. package/es/core/components/SxpPageRender/WaterFall/List.js +173 -0
  52. package/es/core/components/SxpPageRender/WaterFall/WaterfallList.d.ts +3 -0
  53. package/es/core/components/SxpPageRender/WaterFall/WaterfallList.js +317 -0
  54. package/es/core/components/SxpPageRender/WaterFall/index.d.ts +6 -0
  55. package/es/core/components/SxpPageRender/WaterFall/index.js +100 -0
  56. package/es/core/components/SxpPageRender/fakeData.d.ts +130 -0
  57. package/es/core/components/SxpPageRender/fakeData.js +899 -0
  58. package/es/core/components/SxpPageRender/index.d.ts +35 -0
  59. package/es/core/components/SxpPageRender/index.js +345 -0
  60. package/es/core/components/SxpPageRender/typing.d.ts +65 -0
  61. package/es/core/components/SxpPageRender/typing.js +1 -0
  62. package/es/core/components/SxpPageRender/useIconLink.d.ts +1 -0
  63. package/es/core/components/SxpPageRender/useIconLink.js +8 -0
  64. package/es/core/context/DataSourceProvider.d.ts +17 -0
  65. package/es/core/context/DataSourceProvider.js +45 -0
  66. package/es/core/context/EditorContext.d.ts +76 -0
  67. package/es/core/context/EditorContext.js +142 -0
  68. package/es/core/context/EditorDataProvider.d.ts +18 -0
  69. package/es/core/context/EditorDataProvider.js +20 -0
  70. package/es/core/context/SxpDataSourceProvider.d.ts +90 -0
  71. package/es/core/context/SxpDataSourceProvider.js +204 -0
  72. package/es/core/create.d.ts +37 -0
  73. package/es/core/create.js +4 -0
  74. package/es/core/hoc/withBindDataSource.d.ts +6 -0
  75. package/es/core/hoc/withBindDataSource.js +61 -0
  76. package/es/core/hooks/index.d.ts +4 -0
  77. package/es/core/hooks/index.js +4 -0
  78. package/es/core/hooks/useCurrentNode.d.ts +10 -0
  79. package/es/core/hooks/useCurrentNode.js +11 -0
  80. package/es/core/hooks/useDataSource.d.ts +2 -0
  81. package/es/core/hooks/useDataSource.js +6 -0
  82. package/es/core/hooks/useEditor.d.ts +1 -0
  83. package/es/core/hooks/useEditor.js +5 -0
  84. package/es/core/hooks/useEventReport.d.ts +5 -0
  85. package/es/core/hooks/useEventReport.js +73 -0
  86. package/es/core/hooks/useOnScreen.d.ts +2 -0
  87. package/es/core/hooks/useOnScreen.js +19 -0
  88. package/es/core/hooks/useSxpDataSource.d.ts +1 -0
  89. package/es/core/hooks/useSxpDataSource.js +5 -0
  90. package/es/core/index.d.ts +3 -0
  91. package/es/core/index.js +1 -0
  92. package/es/core/schema.d.ts +58 -0
  93. package/es/core/schema.js +1 -0
  94. package/es/core/utils/event.d.ts +7 -0
  95. package/es/core/utils/event.js +8 -0
  96. package/es/core/utils/getDataByDS.d.ts +6 -0
  97. package/es/core/utils/getDataByDS.js +39 -0
  98. package/es/core/utils/getSxpTokenInfo.d.ts +2 -0
  99. package/es/core/utils/getSxpTokenInfo.js +26 -0
  100. package/es/core/utils/localStore.d.ts +3 -0
  101. package/es/core/utils/localStore.js +14 -0
  102. package/es/core/utils/materials.d.ts +11 -0
  103. package/es/core/utils/materials.js +31 -0
  104. package/es/core/utils/sessionStore.d.ts +3 -0
  105. package/es/core/utils/sessionStore.js +26 -0
  106. package/es/core/utils/tool.d.ts +5 -0
  107. package/es/core/utils/tool.js +48 -0
  108. package/es/core/utils/unzip.d.ts +1 -0
  109. package/es/core/utils/unzip.js +10 -0
  110. package/es/index.d.ts +10 -0
  111. package/es/index.js +12 -0
  112. package/es/materials/index.d.ts +1 -0
  113. package/es/materials/index.js +1 -0
  114. package/es/materials/sxp/index.d.ts +2 -0
  115. package/es/materials/sxp/index.js +2 -0
  116. package/es/materials/sxp/popup/AppointForm/index.d.ts +18 -0
  117. package/es/materials/sxp/popup/AppointForm/index.js +77 -0
  118. package/es/materials/sxp/popup/AppointForm/interactionRender.d.ts +8 -0
  119. package/es/materials/sxp/popup/AppointForm/interactionRender.js +11 -0
  120. package/es/materials/sxp/popup/AppointForm/material.d.ts +2 -0
  121. package/es/materials/sxp/popup/AppointForm/material.js +36 -0
  122. package/es/materials/sxp/popup/AppointForm/settingRender.d.ts +65 -0
  123. package/es/materials/sxp/popup/AppointForm/settingRender.js +90 -0
  124. package/es/materials/sxp/popup/CommodityDetail/index.d.ts +14 -0
  125. package/es/materials/sxp/popup/CommodityDetail/index.js +85 -0
  126. package/es/materials/sxp/popup/CommodityDetail/material.d.ts +2 -0
  127. package/es/materials/sxp/popup/CommodityDetail/material.js +16 -0
  128. package/es/materials/sxp/popup/CommodityDetailDiro/index.d.ts +18 -0
  129. package/es/materials/sxp/popup/CommodityDetailDiro/index.js +162 -0
  130. package/es/materials/sxp/popup/CommodityDetailDiro/material.d.ts +2 -0
  131. package/es/materials/sxp/popup/CommodityDetailDiro/material.js +16 -0
  132. package/es/materials/sxp/popup/CommodityDetailDiroNew/index.d.ts +22 -0
  133. package/es/materials/sxp/popup/CommodityDetailDiroNew/index.js +129 -0
  134. package/es/materials/sxp/popup/CommodityDetailDiroNew/material.d.ts +2 -0
  135. package/es/materials/sxp/popup/CommodityDetailDiroNew/material.js +16 -0
  136. package/es/materials/sxp/popup/Prompt/index.d.ts +11 -0
  137. package/es/materials/sxp/popup/Prompt/index.js +22 -0
  138. package/es/materials/sxp/popup/Prompt/interactionRender.d.ts +8 -0
  139. package/es/materials/sxp/popup/Prompt/interactionRender.js +11 -0
  140. package/es/materials/sxp/popup/Prompt/material.d.ts +2 -0
  141. package/es/materials/sxp/popup/Prompt/material.js +28 -0
  142. package/es/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  143. package/es/materials/sxp/popup/Prompt/settingRender.js +18 -0
  144. package/es/materials/sxp/popup/index.d.ts +5 -0
  145. package/es/materials/sxp/popup/index.js +5 -0
  146. package/es/materials/sxp/template/Appoint/index.d.ts +11 -0
  147. package/es/materials/sxp/template/Appoint/index.js +30 -0
  148. package/es/materials/sxp/template/Appoint/interactionRender.d.ts +8 -0
  149. package/es/materials/sxp/template/Appoint/interactionRender.js +11 -0
  150. package/es/materials/sxp/template/Appoint/material.d.ts +2 -0
  151. package/es/materials/sxp/template/Appoint/material.js +29 -0
  152. package/es/materials/sxp/template/Commodity/index.d.ts +11 -0
  153. package/es/materials/sxp/template/Commodity/index.js +44 -0
  154. package/es/materials/sxp/template/Commodity/interactionRender.d.ts +8 -0
  155. package/es/materials/sxp/template/Commodity/interactionRender.js +11 -0
  156. package/es/materials/sxp/template/Commodity/material.d.ts +2 -0
  157. package/es/materials/sxp/template/Commodity/material.js +26 -0
  158. package/es/materials/sxp/template/CommodityDiro/index.d.ts +11 -0
  159. package/es/materials/sxp/template/CommodityDiro/index.js +46 -0
  160. package/es/materials/sxp/template/CommodityDiro/interactionRender.d.ts +8 -0
  161. package/es/materials/sxp/template/CommodityDiro/interactionRender.js +11 -0
  162. package/es/materials/sxp/template/CommodityDiro/material.d.ts +2 -0
  163. package/es/materials/sxp/template/CommodityDiro/material.js +26 -0
  164. package/es/materials/sxp/template/CommodityDiroNew/index.d.ts +11 -0
  165. package/es/materials/sxp/template/CommodityDiroNew/index.js +46 -0
  166. package/es/materials/sxp/template/CommodityDiroNew/interactionRender.d.ts +8 -0
  167. package/es/materials/sxp/template/CommodityDiroNew/interactionRender.js +11 -0
  168. package/es/materials/sxp/template/CommodityDiroNew/material.d.ts +2 -0
  169. package/es/materials/sxp/template/CommodityDiroNew/material.js +26 -0
  170. package/es/materials/sxp/template/Link/index.d.ts +11 -0
  171. package/es/materials/sxp/template/Link/index.js +41 -0
  172. package/es/materials/sxp/template/Link/material.d.ts +2 -0
  173. package/es/materials/sxp/template/Link/material.js +26 -0
  174. package/es/materials/sxp/template/MultiCommodity/index.d.ts +12 -0
  175. package/es/materials/sxp/template/MultiCommodity/index.js +58 -0
  176. package/es/materials/sxp/template/MultiCommodity/interactionRender.d.ts +8 -0
  177. package/es/materials/sxp/template/MultiCommodity/interactionRender.js +11 -0
  178. package/es/materials/sxp/template/MultiCommodity/material.d.ts +2 -0
  179. package/es/materials/sxp/template/MultiCommodity/material.js +26 -0
  180. package/es/materials/sxp/template/MultiCommodityDiro/index.d.ts +12 -0
  181. package/es/materials/sxp/template/MultiCommodityDiro/index.js +60 -0
  182. package/es/materials/sxp/template/MultiCommodityDiro/interactionRender.d.ts +8 -0
  183. package/es/materials/sxp/template/MultiCommodityDiro/interactionRender.js +11 -0
  184. package/es/materials/sxp/template/MultiCommodityDiro/material.d.ts +2 -0
  185. package/es/materials/sxp/template/MultiCommodityDiro/material.js +26 -0
  186. package/es/materials/sxp/template/MultiCommodityDiroNew/index.d.ts +12 -0
  187. package/es/materials/sxp/template/MultiCommodityDiroNew/index.js +59 -0
  188. package/es/materials/sxp/template/MultiCommodityDiroNew/interactionRender.d.ts +8 -0
  189. package/es/materials/sxp/template/MultiCommodityDiroNew/interactionRender.js +11 -0
  190. package/es/materials/sxp/template/MultiCommodityDiroNew/material.d.ts +2 -0
  191. package/es/materials/sxp/template/MultiCommodityDiroNew/material.js +26 -0
  192. package/es/materials/sxp/template/components/EventProvider.d.ts +10 -0
  193. package/es/materials/sxp/template/components/EventProvider.js +33 -0
  194. package/es/materials/sxp/template/components/Img.d.ts +9 -0
  195. package/es/materials/sxp/template/components/Img.js +19 -0
  196. package/es/materials/sxp/template/components/Scroll.d.ts +9 -0
  197. package/es/materials/sxp/template/components/Scroll.js +10 -0
  198. package/es/materials/sxp/template/index.d.ts +8 -0
  199. package/es/materials/sxp/template/index.js +8 -0
  200. package/lib/core/Pagebuilder/PagebuilderClass.d.ts +15 -0
  201. package/lib/core/Pagebuilder/PagebuilderClass.js +45 -0
  202. package/lib/core/Pagebuilder/index.d.ts +3 -0
  203. package/lib/core/Pagebuilder/index.js +99 -0
  204. package/lib/core/Pagebuilder/type.d.ts +55 -0
  205. package/lib/core/Pagebuilder/type.js +2 -0
  206. package/lib/core/components/SxpPageCore/index.d.ts +11 -0
  207. package/lib/core/components/SxpPageCore/index.js +29 -0
  208. package/lib/core/components/SxpPageRender/ExpandableText.d.ts +12 -0
  209. package/lib/core/components/SxpPageRender/ExpandableText.js +57 -0
  210. package/lib/core/components/SxpPageRender/FingerSwipeTip/index.d.ts +6 -0
  211. package/lib/core/components/SxpPageRender/FingerSwipeTip/index.js +22 -0
  212. package/lib/core/components/SxpPageRender/Hashtag/index.d.ts +11 -0
  213. package/lib/core/components/SxpPageRender/Hashtag/index.js +43 -0
  214. package/lib/core/components/SxpPageRender/LikeButton/index.d.ts +10 -0
  215. package/lib/core/components/SxpPageRender/LikeButton/index.js +60 -0
  216. package/lib/core/components/SxpPageRender/Modal/index.d.ts +9 -0
  217. package/lib/core/components/SxpPageRender/Modal/index.js +47 -0
  218. package/lib/core/components/SxpPageRender/Navbar.d.ts +8 -0
  219. package/lib/core/components/SxpPageRender/Navbar.js +12 -0
  220. package/lib/core/components/SxpPageRender/PictureGroup/Picture.d.ts +8 -0
  221. package/lib/core/components/SxpPageRender/PictureGroup/Picture.js +22 -0
  222. package/lib/core/components/SxpPageRender/PictureGroup/index.d.ts +13 -0
  223. package/lib/core/components/SxpPageRender/PictureGroup/index.js +30 -0
  224. package/lib/core/components/SxpPageRender/Popup/index.d.ts +3 -0
  225. package/lib/core/components/SxpPageRender/Popup/index.js +63 -0
  226. package/lib/core/components/SxpPageRender/ProductInfo/index.d.ts +14 -0
  227. package/lib/core/components/SxpPageRender/ProductInfo/index.js +58 -0
  228. package/lib/core/components/SxpPageRender/RenderCard.d.ts +11 -0
  229. package/lib/core/components/SxpPageRender/RenderCard.js +43 -0
  230. package/lib/core/components/SxpPageRender/ToggleButton/index.d.ts +10 -0
  231. package/lib/core/components/SxpPageRender/ToggleButton/index.js +16 -0
  232. package/lib/core/components/SxpPageRender/VideoWidget/index.d.ts +12 -0
  233. package/lib/core/components/SxpPageRender/VideoWidget/index.js +222 -0
  234. package/lib/core/components/SxpPageRender/WaterFall/List.d.ts +3 -0
  235. package/lib/core/components/SxpPageRender/WaterFall/List.js +177 -0
  236. package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.d.ts +3 -0
  237. package/lib/core/components/SxpPageRender/WaterFall/WaterfallList.js +321 -0
  238. package/lib/core/components/SxpPageRender/WaterFall/index.d.ts +6 -0
  239. package/lib/core/components/SxpPageRender/WaterFall/index.js +103 -0
  240. package/lib/core/components/SxpPageRender/fakeData.d.ts +130 -0
  241. package/lib/core/components/SxpPageRender/fakeData.js +902 -0
  242. package/lib/core/components/SxpPageRender/index.d.ts +35 -0
  243. package/lib/core/components/SxpPageRender/index.js +348 -0
  244. package/lib/core/components/SxpPageRender/typing.d.ts +65 -0
  245. package/lib/core/components/SxpPageRender/typing.js +2 -0
  246. package/lib/core/components/SxpPageRender/useIconLink.d.ts +1 -0
  247. package/lib/core/components/SxpPageRender/useIconLink.js +12 -0
  248. package/lib/core/context/DataSourceProvider.d.ts +17 -0
  249. package/lib/core/context/DataSourceProvider.js +48 -0
  250. package/lib/core/context/EditorContext.d.ts +76 -0
  251. package/lib/core/context/EditorContext.js +146 -0
  252. package/lib/core/context/EditorDataProvider.d.ts +18 -0
  253. package/lib/core/context/EditorDataProvider.js +25 -0
  254. package/lib/core/context/SxpDataSourceProvider.d.ts +90 -0
  255. package/lib/core/context/SxpDataSourceProvider.js +207 -0
  256. package/lib/core/create.d.ts +37 -0
  257. package/lib/core/create.js +8 -0
  258. package/lib/core/hoc/withBindDataSource.d.ts +6 -0
  259. package/lib/core/hoc/withBindDataSource.js +63 -0
  260. package/lib/core/hooks/index.d.ts +4 -0
  261. package/lib/core/hooks/index.js +7 -0
  262. package/lib/core/hooks/useCurrentNode.d.ts +10 -0
  263. package/lib/core/hooks/useCurrentNode.js +14 -0
  264. package/lib/core/hooks/useDataSource.d.ts +2 -0
  265. package/lib/core/hooks/useDataSource.js +9 -0
  266. package/lib/core/hooks/useEditor.d.ts +1 -0
  267. package/lib/core/hooks/useEditor.js +9 -0
  268. package/lib/core/hooks/useEventReport.d.ts +5 -0
  269. package/lib/core/hooks/useEventReport.js +77 -0
  270. package/lib/core/hooks/useOnScreen.d.ts +2 -0
  271. package/lib/core/hooks/useOnScreen.js +22 -0
  272. package/lib/core/hooks/useSxpDataSource.d.ts +1 -0
  273. package/lib/core/hooks/useSxpDataSource.js +9 -0
  274. package/lib/core/index.d.ts +3 -0
  275. package/lib/core/index.js +5 -0
  276. package/lib/core/schema.d.ts +58 -0
  277. package/lib/core/schema.js +2 -0
  278. package/lib/core/utils/event.d.ts +7 -0
  279. package/lib/core/utils/event.js +12 -0
  280. package/lib/core/utils/getDataByDS.d.ts +6 -0
  281. package/lib/core/utils/getDataByDS.js +41 -0
  282. package/lib/core/utils/getSxpTokenInfo.d.ts +2 -0
  283. package/lib/core/utils/getSxpTokenInfo.js +30 -0
  284. package/lib/core/utils/localStore.d.ts +3 -0
  285. package/lib/core/utils/localStore.js +19 -0
  286. package/lib/core/utils/materials.d.ts +11 -0
  287. package/lib/core/utils/materials.js +37 -0
  288. package/lib/core/utils/sessionStore.d.ts +3 -0
  289. package/lib/core/utils/sessionStore.js +32 -0
  290. package/lib/core/utils/tool.d.ts +5 -0
  291. package/lib/core/utils/tool.js +54 -0
  292. package/lib/core/utils/unzip.d.ts +1 -0
  293. package/lib/core/utils/unzip.js +15 -0
  294. package/lib/index.d.ts +10 -0
  295. package/lib/index.js +20 -0
  296. package/lib/materials/index.d.ts +1 -0
  297. package/lib/materials/index.js +4 -0
  298. package/lib/materials/sxp/index.d.ts +2 -0
  299. package/lib/materials/sxp/index.js +5 -0
  300. package/lib/materials/sxp/popup/AppointForm/index.d.ts +18 -0
  301. package/lib/materials/sxp/popup/AppointForm/index.js +79 -0
  302. package/lib/materials/sxp/popup/AppointForm/interactionRender.d.ts +8 -0
  303. package/lib/materials/sxp/popup/AppointForm/interactionRender.js +13 -0
  304. package/lib/materials/sxp/popup/AppointForm/material.d.ts +2 -0
  305. package/lib/materials/sxp/popup/AppointForm/material.js +40 -0
  306. package/lib/materials/sxp/popup/AppointForm/settingRender.d.ts +65 -0
  307. package/lib/materials/sxp/popup/AppointForm/settingRender.js +92 -0
  308. package/lib/materials/sxp/popup/CommodityDetail/index.d.ts +14 -0
  309. package/lib/materials/sxp/popup/CommodityDetail/index.js +87 -0
  310. package/lib/materials/sxp/popup/CommodityDetail/material.d.ts +2 -0
  311. package/lib/materials/sxp/popup/CommodityDetail/material.js +20 -0
  312. package/lib/materials/sxp/popup/CommodityDetailDiro/index.d.ts +18 -0
  313. package/lib/materials/sxp/popup/CommodityDetailDiro/index.js +164 -0
  314. package/lib/materials/sxp/popup/CommodityDetailDiro/material.d.ts +2 -0
  315. package/lib/materials/sxp/popup/CommodityDetailDiro/material.js +20 -0
  316. package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.d.ts +22 -0
  317. package/lib/materials/sxp/popup/CommodityDetailDiroNew/index.js +131 -0
  318. package/lib/materials/sxp/popup/CommodityDetailDiroNew/material.d.ts +2 -0
  319. package/lib/materials/sxp/popup/CommodityDetailDiroNew/material.js +20 -0
  320. package/lib/materials/sxp/popup/Prompt/index.d.ts +11 -0
  321. package/lib/materials/sxp/popup/Prompt/index.js +24 -0
  322. package/lib/materials/sxp/popup/Prompt/interactionRender.d.ts +8 -0
  323. package/lib/materials/sxp/popup/Prompt/interactionRender.js +13 -0
  324. package/lib/materials/sxp/popup/Prompt/material.d.ts +2 -0
  325. package/lib/materials/sxp/popup/Prompt/material.js +32 -0
  326. package/lib/materials/sxp/popup/Prompt/settingRender.d.ts +12 -0
  327. package/lib/materials/sxp/popup/Prompt/settingRender.js +20 -0
  328. package/lib/materials/sxp/popup/index.d.ts +5 -0
  329. package/lib/materials/sxp/popup/index.js +8 -0
  330. package/lib/materials/sxp/template/Appoint/index.d.ts +11 -0
  331. package/lib/materials/sxp/template/Appoint/index.js +32 -0
  332. package/lib/materials/sxp/template/Appoint/interactionRender.d.ts +8 -0
  333. package/lib/materials/sxp/template/Appoint/interactionRender.js +13 -0
  334. package/lib/materials/sxp/template/Appoint/material.d.ts +2 -0
  335. package/lib/materials/sxp/template/Appoint/material.js +33 -0
  336. package/lib/materials/sxp/template/Commodity/index.d.ts +11 -0
  337. package/lib/materials/sxp/template/Commodity/index.js +46 -0
  338. package/lib/materials/sxp/template/Commodity/interactionRender.d.ts +8 -0
  339. package/lib/materials/sxp/template/Commodity/interactionRender.js +13 -0
  340. package/lib/materials/sxp/template/Commodity/material.d.ts +2 -0
  341. package/lib/materials/sxp/template/Commodity/material.js +30 -0
  342. package/lib/materials/sxp/template/CommodityDiro/index.d.ts +11 -0
  343. package/lib/materials/sxp/template/CommodityDiro/index.js +48 -0
  344. package/lib/materials/sxp/template/CommodityDiro/interactionRender.d.ts +8 -0
  345. package/lib/materials/sxp/template/CommodityDiro/interactionRender.js +13 -0
  346. package/lib/materials/sxp/template/CommodityDiro/material.d.ts +2 -0
  347. package/lib/materials/sxp/template/CommodityDiro/material.js +30 -0
  348. package/lib/materials/sxp/template/CommodityDiroNew/index.d.ts +11 -0
  349. package/lib/materials/sxp/template/CommodityDiroNew/index.js +48 -0
  350. package/lib/materials/sxp/template/CommodityDiroNew/interactionRender.d.ts +8 -0
  351. package/lib/materials/sxp/template/CommodityDiroNew/interactionRender.js +13 -0
  352. package/lib/materials/sxp/template/CommodityDiroNew/material.d.ts +2 -0
  353. package/lib/materials/sxp/template/CommodityDiroNew/material.js +30 -0
  354. package/lib/materials/sxp/template/Link/index.d.ts +11 -0
  355. package/lib/materials/sxp/template/Link/index.js +43 -0
  356. package/lib/materials/sxp/template/Link/material.d.ts +2 -0
  357. package/lib/materials/sxp/template/Link/material.js +30 -0
  358. package/lib/materials/sxp/template/MultiCommodity/index.d.ts +12 -0
  359. package/lib/materials/sxp/template/MultiCommodity/index.js +60 -0
  360. package/lib/materials/sxp/template/MultiCommodity/interactionRender.d.ts +8 -0
  361. package/lib/materials/sxp/template/MultiCommodity/interactionRender.js +13 -0
  362. package/lib/materials/sxp/template/MultiCommodity/material.d.ts +2 -0
  363. package/lib/materials/sxp/template/MultiCommodity/material.js +30 -0
  364. package/lib/materials/sxp/template/MultiCommodityDiro/index.d.ts +12 -0
  365. package/lib/materials/sxp/template/MultiCommodityDiro/index.js +62 -0
  366. package/lib/materials/sxp/template/MultiCommodityDiro/interactionRender.d.ts +8 -0
  367. package/lib/materials/sxp/template/MultiCommodityDiro/interactionRender.js +13 -0
  368. package/lib/materials/sxp/template/MultiCommodityDiro/material.d.ts +2 -0
  369. package/lib/materials/sxp/template/MultiCommodityDiro/material.js +30 -0
  370. package/lib/materials/sxp/template/MultiCommodityDiroNew/index.d.ts +12 -0
  371. package/lib/materials/sxp/template/MultiCommodityDiroNew/index.js +61 -0
  372. package/lib/materials/sxp/template/MultiCommodityDiroNew/interactionRender.d.ts +8 -0
  373. package/lib/materials/sxp/template/MultiCommodityDiroNew/interactionRender.js +13 -0
  374. package/lib/materials/sxp/template/MultiCommodityDiroNew/material.d.ts +2 -0
  375. package/lib/materials/sxp/template/MultiCommodityDiroNew/material.js +30 -0
  376. package/lib/materials/sxp/template/components/EventProvider.d.ts +10 -0
  377. package/lib/materials/sxp/template/components/EventProvider.js +35 -0
  378. package/lib/materials/sxp/template/components/Img.d.ts +9 -0
  379. package/lib/materials/sxp/template/components/Img.js +22 -0
  380. package/lib/materials/sxp/template/components/Scroll.d.ts +9 -0
  381. package/lib/materials/sxp/template/components/Scroll.js +13 -0
  382. package/lib/materials/sxp/template/index.d.ts +8 -0
  383. package/lib/materials/sxp/template/index.js +11 -0
  384. package/package.json +113 -0
@@ -0,0 +1,73 @@
1
+ import { useCallback } from 'react';
2
+ import { useSxpDataSource } from './useSxpDataSource';
3
+ export function useEventReport() {
4
+ const { bffEventReport, popupDetailData, waterFallData, isFromHashtag } = useSxpDataSource();
5
+ const jumpToWeb = useCallback((data, product, cta) => {
6
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
7
+ let fromKName = '';
8
+ if (popupDetailData && (((_b = (_a = data === null || data === void 0 ? void 0 : data.video) === null || _a === void 0 ? void 0 : _a.bindProducts) === null || _b === void 0 ? void 0 : _b.length) || ((_c = data === null || data === void 0 ? void 0 : data.video) === null || _c === void 0 ? void 0 : _c.bindProduct))) {
9
+ fromKName = 'pdpPage';
10
+ }
11
+ else if (isFromHashtag) {
12
+ fromKName = 'hashTagPage';
13
+ }
14
+ else if ((_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.url) {
15
+ fromKName = 'videoPage';
16
+ }
17
+ else if (((_e = data === null || data === void 0 ? void 0 : data.video) === null || _e === void 0 ? void 0 : _e.imgUrls) && ((_g = (_f = data === null || data === void 0 ? void 0 : data.video) === null || _f === void 0 ? void 0 : _f.imgUrls) === null || _g === void 0 ? void 0 : _g.length)) {
18
+ fromKName = 'imagePage';
19
+ }
20
+ else if (data === null || data === void 0 ? void 0 : data.product) {
21
+ fromKName = 'productPage';
22
+ }
23
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
24
+ eventInfo: {
25
+ eventSubject: 'jumpToWeb',
26
+ eventDescription: 'User jumped to website',
27
+ productId: (_h = product === null || product === void 0 ? void 0 : product.itemId) !== null && _h !== void 0 ? _h : '',
28
+ productName: (_j = product === null || product === void 0 ? void 0 : product.title) !== null && _j !== void 0 ? _j : '',
29
+ price: (product === null || product === void 0 ? void 0 : product.price) ? (product === null || product === void 0 ? void 0 : product.price) + '' : '0',
30
+ productCollection: (_k = product === null || product === void 0 ? void 0 : product.collection) !== null && _k !== void 0 ? _k : '',
31
+ fromKName,
32
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
33
+ contentTags: (product === null || product === void 0 ? void 0 : product.tags) ? JSON.stringify(product === null || product === void 0 ? void 0 : product.tags) : '',
34
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
35
+ 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 : '',
36
+ relatedCtatId: (_o = cta === null || cta === void 0 ? void 0 : cta.itemId) !== null && _o !== void 0 ? _o : '',
37
+ traceInfo: (_p = product === null || product === void 0 ? void 0 : product.traceInfo) !== null && _p !== void 0 ? _p : ''
38
+ }
39
+ });
40
+ }, [bffEventReport, popupDetailData, isFromHashtag]);
41
+ const productView = useCallback((data, product, cta, viewTime) => {
42
+ var _a, _b, _c, _d;
43
+ let fromKName = '';
44
+ if (popupDetailData && (((_b = (_a = data === null || data === void 0 ? void 0 : data.video) === null || _a === void 0 ? void 0 : _a.bindProducts) === null || _b === void 0 ? void 0 : _b.length) || ((_c = data === null || data === void 0 ? void 0 : data.video) === null || _c === void 0 ? void 0 : _c.bindProduct))) {
45
+ fromKName = 'pdpPage';
46
+ }
47
+ else if (data === null || data === void 0 ? void 0 : data.product) {
48
+ fromKName = 'productPage';
49
+ }
50
+ bffEventReport === null || bffEventReport === void 0 ? void 0 : bffEventReport({
51
+ eventInfo: {
52
+ productId: product === null || product === void 0 ? void 0 : product.itemId,
53
+ productName: product === null || product === void 0 ? void 0 : product.title,
54
+ price: (product === null || product === void 0 ? void 0 : product.price) + '',
55
+ productCollection: product === null || product === void 0 ? void 0 : product.collection,
56
+ fromKName,
57
+ fromKPage: location === null || location === void 0 ? void 0 : location.href,
58
+ contentTags: JSON.stringify(product === null || product === void 0 ? void 0 : product.tags),
59
+ position: (data === null || data === void 0 ? void 0 : data.position) + '',
60
+ relatedContentId: (_d = data === null || data === void 0 ? void 0 : data.video) === null || _d === void 0 ? void 0 : _d.itemId,
61
+ relatedCtatId: cta === null || cta === void 0 ? void 0 : cta.itemId,
62
+ traceInfo: product === null || product === void 0 ? void 0 : product.traceInfo,
63
+ timeOnSite: Math.floor((new Date() - viewTime) / 1000) + '',
64
+ eventSubject: 'productView',
65
+ eventDescription: 'User browsed the product'
66
+ }
67
+ });
68
+ }, [bffEventReport, popupDetailData]);
69
+ return {
70
+ jumpToWeb,
71
+ productView
72
+ };
73
+ }
@@ -0,0 +1,2 @@
1
+ import { RefObject } from 'react';
2
+ export default function useOnScreen(ref: RefObject<HTMLElement>): boolean;
@@ -0,0 +1,19 @@
1
+ import { useEffect, useState, useRef } from 'react';
2
+ export default function useOnScreen(ref) {
3
+ const observerRef = useRef(null);
4
+ const [isOnScreen, setIsOnScreen] = useState(false);
5
+ useEffect(() => {
6
+ observerRef.current = new IntersectionObserver(([entry]) => {
7
+ setIsOnScreen(entry.isIntersecting);
8
+ });
9
+ }, []);
10
+ useEffect(() => {
11
+ var _a;
12
+ (ref === null || ref === void 0 ? void 0 : ref.current) && ((_a = observerRef === null || observerRef === void 0 ? void 0 : observerRef.current) === null || _a === void 0 ? void 0 : _a.observe(ref === null || ref === void 0 ? void 0 : ref.current));
13
+ return () => {
14
+ var _a;
15
+ (_a = observerRef === null || observerRef === void 0 ? void 0 : observerRef.current) === null || _a === void 0 ? void 0 : _a.disconnect();
16
+ };
17
+ }, [ref]);
18
+ return isOnScreen;
19
+ }
@@ -0,0 +1 @@
1
+ export declare function useSxpDataSource(): import("../context/SxpDataSourceProvider").ISxpDataSourceContext;
@@ -0,0 +1,5 @@
1
+ import { useContext } from 'react';
2
+ import { SxpDataSourceContext } from '../context/SxpDataSourceProvider';
3
+ export function useSxpDataSource() {
4
+ return useContext(SxpDataSourceContext);
5
+ }
@@ -0,0 +1,3 @@
1
+ export { EditorCore } from './context/EditorContext';
2
+ export type { IEditorCoreRef } from './context/EditorContext';
3
+ export type { MaterialComponet } from './create';
@@ -0,0 +1 @@
1
+ export { EditorCore } from './context/EditorContext';
@@ -0,0 +1,58 @@
1
+ export interface ISchema {
2
+ id: string;
3
+ pageInfo: {
4
+ baseInfo?: {
5
+ name: string;
6
+ type: string;
7
+ remark?: string;
8
+ };
9
+ };
10
+ dataSource: Array<{
11
+ id: string;
12
+ apiId: string;
13
+ dataId: string;
14
+ method: string;
15
+ url: string;
16
+ urlParams?: Record<string, string>;
17
+ name: string;
18
+ queryString?: string;
19
+ headers?: Record<string, any>;
20
+ requestType: string;
21
+ response_parameter: any[];
22
+ body?: any;
23
+ }>;
24
+ schema: Array<{
25
+ id: string;
26
+ componentType: string;
27
+ backgroud: {
28
+ color?: string;
29
+ image?: string;
30
+ video?: string;
31
+ };
32
+ style: {
33
+ width: string | number;
34
+ height: string | number;
35
+ };
36
+ children: Array<{
37
+ id: string;
38
+ componentType: string;
39
+ name: string;
40
+ style: {
41
+ offsetX: number;
42
+ offsetY: number;
43
+ borderRaduis: number;
44
+ bgColor: string;
45
+ bgImage?: string;
46
+ borderWidth: number;
47
+ borderStyle: string;
48
+ borderColor: string;
49
+ zIndex: number;
50
+ };
51
+ bindDatas: Array<{
52
+ propKey: string;
53
+ accessPath: string;
54
+ }>;
55
+ props: Record<string, any>;
56
+ }>;
57
+ }>;
58
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,7 @@
1
+ import EventEmitter from 'eventemitter3';
2
+ declare const SXP_EVENT_BUS: EventEmitter<string | symbol, any>;
3
+ export declare enum SXP_EVENT_TYPE {
4
+ PAGE_DID_SHOW = "pageDidShow",
5
+ PAGE_DID_HIDE = "pageDidHide"
6
+ }
7
+ export default SXP_EVENT_BUS;
@@ -0,0 +1,8 @@
1
+ import EventEmitter from 'eventemitter3';
2
+ const SXP_EVENT_BUS = new EventEmitter();
3
+ export var SXP_EVENT_TYPE;
4
+ (function (SXP_EVENT_TYPE) {
5
+ SXP_EVENT_TYPE["PAGE_DID_SHOW"] = "pageDidShow";
6
+ SXP_EVENT_TYPE["PAGE_DID_HIDE"] = "pageDidHide";
7
+ })(SXP_EVENT_TYPE || (SXP_EVENT_TYPE = {}));
8
+ export default SXP_EVENT_BUS;
@@ -0,0 +1,6 @@
1
+ import { ISchema } from '../schema';
2
+ declare const _default: (apiAddr: string, configs: ISchema['dataSource']) => Promise<{
3
+ $store: Record<string, any>;
4
+ idMapName: Record<string, string>;
5
+ }>;
6
+ export default _default;
@@ -0,0 +1,39 @@
1
+ import { __awaiter } from "tslib";
2
+ const pathParamsReg = /:\w+/g;
3
+ export default (apiAddr, configs) => __awaiter(void 0, void 0, void 0, function* () {
4
+ const $store = {};
5
+ const idMapName = {};
6
+ for (let i = 0; i < (configs === null || configs === void 0 ? void 0 : configs.length); i++) {
7
+ const { id, method, url, urlParams, name, queryString, headers, body } = configs[i];
8
+ let apiUrl = url;
9
+ if (urlParams) {
10
+ Object.entries(urlParams).forEach(([k, v]) => {
11
+ apiUrl = apiUrl.replace(pathParamsReg, (p) => {
12
+ if (p === k) {
13
+ return v;
14
+ }
15
+ else {
16
+ return p;
17
+ }
18
+ });
19
+ });
20
+ }
21
+ if (queryString) {
22
+ apiUrl += queryString;
23
+ }
24
+ idMapName[id] = name;
25
+ try {
26
+ const result = yield fetch(apiUrl, {
27
+ method,
28
+ headers: Object.assign({ 'Content-Type': 'application/json' }, headers),
29
+ body: JSON.stringify(body)
30
+ }).then((res) => res.json());
31
+ $store[id] = result;
32
+ }
33
+ catch (error) {
34
+ console.error('DataSource request error: ', error);
35
+ $store[id] = {};
36
+ }
37
+ }
38
+ return { $store, idMapName };
39
+ });
@@ -0,0 +1,2 @@
1
+ import PagebuilderClass from '../Pagebuilder/PagebuilderClass';
2
+ export declare const getSxpTokenInfo: (builder: PagebuilderClass, dataId: string) => Promise<any>;
@@ -0,0 +1,26 @@
1
+ import { __awaiter } from "tslib";
2
+ const SXP_TOKEN_INFO_KEY = 'SXP_TOKEN_INFO';
3
+ export const getSxpTokenInfo = (builder, dataId) => __awaiter(void 0, void 0, void 0, function* () {
4
+ var _a;
5
+ const tenantId = builder.getTenantId();
6
+ const appId = builder.getAppId();
7
+ const apiUrl = builder.getApiUrl();
8
+ const tokenJson = window.localStorage.getItem(SXP_TOKEN_INFO_KEY);
9
+ let tokenData = JSON.parse(tokenJson || '{}');
10
+ const currentTime = Date.now();
11
+ if (currentTime > ((_a = tokenData === null || tokenData === void 0 ? void 0 : tokenData.expireTime) !== null && _a !== void 0 ? _a : 0)) {
12
+ const tokenRes = yield fetch(`${apiUrl}/storefront/v1/proxy/token/${dataId}`, {
13
+ method: 'POST',
14
+ headers: {
15
+ 'x-tenant-id': tenantId || '',
16
+ 'x-app-id': appId || ''
17
+ }
18
+ }).then((res) => res.json());
19
+ if (tokenRes.success) {
20
+ const data = tokenRes.data;
21
+ tokenData = Object.assign(Object.assign({}, data), { expireTime: Date.now() + data.expire * 1000 });
22
+ window.localStorage.setItem(SXP_TOKEN_INFO_KEY, JSON.stringify(tokenData));
23
+ }
24
+ }
25
+ return tokenData;
26
+ });
@@ -0,0 +1,3 @@
1
+ export declare const FAKE_USER_KEY = "SXP_FAKE_USER_ID";
2
+ export declare const storeAndLoadFeUserId: () => string;
3
+ export declare const removeFeUserId: () => void;
@@ -0,0 +1,14 @@
1
+ import { isEmpty } from 'lodash';
2
+ import { uuid } from './tool';
3
+ export const FAKE_USER_KEY = 'SXP_FAKE_USER_ID';
4
+ export const storeAndLoadFeUserId = () => {
5
+ let fakeUserId = window.localStorage.getItem(FAKE_USER_KEY);
6
+ if (isEmpty(fakeUserId)) {
7
+ fakeUserId = uuid(36, 62);
8
+ window.localStorage.setItem(FAKE_USER_KEY, fakeUserId);
9
+ }
10
+ return fakeUserId;
11
+ };
12
+ export const removeFeUserId = () => {
13
+ window.localStorage.removeItem(FAKE_USER_KEY);
14
+ };
@@ -0,0 +1,11 @@
1
+ export declare const getMediaValueByMode: (obj?: Record<string, any>) => any;
2
+ export declare const getBgStyle: (imgSrc: string) => "" | {
3
+ backgroundImage: string;
4
+ backgroundRepeat: string;
5
+ backgroundSize: string;
6
+ };
7
+ export declare const getBgStyleByImg: (data: any) => "" | {
8
+ backgroundImage: string;
9
+ backgroundRepeat: string;
10
+ backgroundSize: string;
11
+ };
@@ -0,0 +1,31 @@
1
+ export const getMediaValueByMode = (obj) => {
2
+ var _a;
3
+ if (!obj || typeof obj !== 'object') {
4
+ return null;
5
+ }
6
+ const { mode, link, file, src } = obj;
7
+ switch (mode) {
8
+ case 2:
9
+ return link || null;
10
+ case 3:
11
+ return src || null;
12
+ default:
13
+ return file && file.length > 0 ? (_a = file[0]) === null || _a === void 0 ? void 0 : _a.url : null;
14
+ }
15
+ };
16
+ export const getBgStyle = (imgSrc) => {
17
+ return imgSrc
18
+ ? {
19
+ backgroundImage: `url(${imgSrc})`,
20
+ backgroundRepeat: 'no-repeat',
21
+ backgroundSize: 'cover'
22
+ }
23
+ : '';
24
+ };
25
+ export const getBgStyleByImg = (data) => {
26
+ var _a;
27
+ const curPageProps = (_a = data === null || data === void 0 ? void 0 : data.props) !== null && _a !== void 0 ? _a : null;
28
+ const bgImg = curPageProps === null || curPageProps === void 0 ? void 0 : curPageProps.bgImg;
29
+ const imgSrc = typeof bgImg === 'string' ? bgImg : getMediaValueByMode(bgImg);
30
+ return getBgStyle(imgSrc);
31
+ };
@@ -0,0 +1,3 @@
1
+ export declare const storeAndLoadFeSessionId: () => string;
2
+ export declare const refreshFeSessionId: () => void;
3
+ export declare const removeFeSessionId: () => void;
@@ -0,0 +1,26 @@
1
+ import { getUid } from './tool';
2
+ const feRealSessionIdKey = 'feRealSessionIdKey';
3
+ const generateFeSessionId = () => {
4
+ const uid = getUid();
5
+ const timestamp = Date.now();
6
+ const result = `${timestamp}${uid}`;
7
+ return result;
8
+ };
9
+ export const storeAndLoadFeSessionId = () => {
10
+ let result = getFeSessionId();
11
+ if (!result) {
12
+ result = generateFeSessionId();
13
+ window.sessionStorage.setItem(feRealSessionIdKey, result);
14
+ }
15
+ return result;
16
+ };
17
+ export const refreshFeSessionId = () => {
18
+ const result = generateFeSessionId();
19
+ window.sessionStorage.setItem(feRealSessionIdKey, result);
20
+ };
21
+ const getFeSessionId = () => {
22
+ return window.sessionStorage.getItem(feRealSessionIdKey);
23
+ };
24
+ export const removeFeSessionId = () => {
25
+ window.sessionStorage.removeItem(feRealSessionIdKey);
26
+ };
@@ -0,0 +1,5 @@
1
+ declare function uuid(len: number, radix: number): string;
2
+ declare const getIndexByblockType: (type: string, index: number) => number | "initial";
3
+ export declare const generateRandomString: (length: number) => string;
4
+ export declare const getUid: () => string;
5
+ export { uuid, getIndexByblockType };
@@ -0,0 +1,48 @@
1
+ import { v4 as uuidv4 } from 'uuid';
2
+ function uuid(len, radix) {
3
+ const chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('');
4
+ const uuid = [];
5
+ let i;
6
+ radix = radix || chars.length;
7
+ if (len) {
8
+ for (i = 0; i < len; i++)
9
+ uuid[i] = chars[0 | (Math.random() * radix)];
10
+ }
11
+ else {
12
+ let r;
13
+ uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';
14
+ uuid[14] = '4';
15
+ for (i = 0; i < 36; i++) {
16
+ if (!uuid[i]) {
17
+ r = 0 | (Math.random() * 16);
18
+ uuid[i] = chars[i === 19 ? (r & 0x3) | 0x8 : r];
19
+ }
20
+ }
21
+ }
22
+ return uuid.join('');
23
+ }
24
+ const getIndexByblockType = (type, index) => {
25
+ if (type === 'CommodityCarouselBlock' || type === 'CopyBlock') {
26
+ return 'initial';
27
+ }
28
+ else {
29
+ return index;
30
+ }
31
+ };
32
+ export const generateRandomString = (length) => {
33
+ let result = '';
34
+ const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
35
+ const charactersLength = characters.length;
36
+ let counter = 0;
37
+ while (counter < length) {
38
+ result += characters.charAt(Math.floor(Math.random() * charactersLength));
39
+ counter += 1;
40
+ }
41
+ return result;
42
+ };
43
+ export const getUid = () => {
44
+ const originalUid = uuidv4();
45
+ const uid = (originalUid === null || originalUid === void 0 ? void 0 : originalUid.replaceAll) ? originalUid.replaceAll('-', '') : generateRandomString(32);
46
+ return uid;
47
+ };
48
+ export { uuid, getIndexByblockType };
@@ -0,0 +1 @@
1
+ export declare function unzip(b64Data: string): any;
@@ -0,0 +1,10 @@
1
+ import pako from 'pako';
2
+ export function unzip(b64Data) {
3
+ const strData = atob(b64Data);
4
+ const charData = strData.split('').map(function (x) {
5
+ return x.charCodeAt(0);
6
+ });
7
+ const binData = new Uint8Array(charData);
8
+ const data = pako.inflate(binData, { to: 'string' });
9
+ return JSON.parse(data);
10
+ }
package/es/index.d.ts ADDED
@@ -0,0 +1,10 @@
1
+ import { Pagebuilder } from './core/Pagebuilder';
2
+ export * as core from './core';
3
+ export * as materials from './materials';
4
+ export { default as SxpPageRender } from './core/components/SxpPageRender';
5
+ export { default as Modal } from './core/components/SxpPageRender/Modal';
6
+ export { default as SxpDataSourceProvider } from './core/context/SxpDataSourceProvider';
7
+ export { default as SxpPageCore } from './core/components/SxpPageCore';
8
+ export { default as EditorDataProvider } from './core/context/EditorDataProvider';
9
+ export { useEditorDataProvider } from './core/context/EditorDataProvider';
10
+ export default Pagebuilder;
package/es/index.js ADDED
@@ -0,0 +1,12 @@
1
+ import { Pagebuilder } from './core/Pagebuilder';
2
+ import * as core_1 from './core';
3
+ export { core_1 as core };
4
+ import * as materials_1 from './materials';
5
+ export { materials_1 as materials };
6
+ export { default as SxpPageRender } from './core/components/SxpPageRender';
7
+ export { default as Modal } from './core/components/SxpPageRender/Modal';
8
+ export { default as SxpDataSourceProvider } from './core/context/SxpDataSourceProvider';
9
+ export { default as SxpPageCore } from './core/components/SxpPageCore';
10
+ export { default as EditorDataProvider } from './core/context/EditorDataProvider';
11
+ export { useEditorDataProvider } from './core/context/EditorDataProvider';
12
+ export default Pagebuilder;
@@ -0,0 +1 @@
1
+ export * from './sxp';
@@ -0,0 +1 @@
1
+ export * from './sxp';
@@ -0,0 +1,2 @@
1
+ export * from './popup';
2
+ export * from './template';
@@ -0,0 +1,2 @@
1
+ export * from './popup';
2
+ export * from './template';
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import './index.less';
3
+ export interface IAppointFormProps {
4
+ columns?: any[];
5
+ title: string;
6
+ style?: Record<string, any>;
7
+ textStyle?: Record<string, any>;
8
+ bgImg?: Record<string, any> | string;
9
+ submitBgColor?: string;
10
+ submitColor?: string;
11
+ submitText?: string;
12
+ submitApiUrl?: string;
13
+ submitEmail?: string;
14
+ layoutType?: 'horizontal' | 'vertical' | 'inline';
15
+ onClick?: () => void;
16
+ }
17
+ declare const _default: React.NamedExoticComponent<IAppointFormProps>;
18
+ export default _default;
@@ -0,0 +1,77 @@
1
+ import { __awaiter, __rest } from "tslib";
2
+ import { css } from '@emotion/css';
3
+ import React, { memo, useMemo, useRef, useState } from 'react';
4
+ import { BetaSchemaForm } from '@ant-design/pro-components';
5
+ import { cloneDeep, debounce } from 'lodash';
6
+ import { useEditor, useSxpDataSource } from '../../../../core/hooks';
7
+ import './index.less';
8
+ const AppointForm = (_a) => {
9
+ var { columns, style, title, textStyle, submitBgColor, submitColor, submitText, layoutType, onClick } = _a, props = __rest(_a, ["columns", "style", "title", "textStyle", "submitBgColor", "submitColor", "submitText", "layoutType", "onClick"]);
10
+ const { setPopup } = useEditor();
11
+ const { submitForm } = useSxpDataSource();
12
+ const formRef = useRef();
13
+ const [loading, setLoading] = useState(false);
14
+ const defaultColumns = useMemo(() => [
15
+ {
16
+ title: '',
17
+ dataIndex: 'field',
18
+ valueType: 'text',
19
+ key: '1'
20
+ },
21
+ {
22
+ title: '',
23
+ dataIndex: 'field',
24
+ valueType: 'text',
25
+ key: '2'
26
+ },
27
+ {
28
+ title: '',
29
+ dataIndex: 'field',
30
+ valueType: 'text',
31
+ key: '3'
32
+ },
33
+ {
34
+ title: '',
35
+ dataIndex: 'field',
36
+ valueType: 'text',
37
+ key: '4'
38
+ }
39
+ ], []);
40
+ const columnsData = useMemo(() => {
41
+ if (layoutType === undefined) {
42
+ const list = cloneDeep(columns) || defaultColumns;
43
+ return list === null || list === void 0 ? void 0 : list.map((obj) => (Object.assign(Object.assign({}, obj), { title: undefined, fieldProps: { placeholder: obj === null || obj === void 0 ? void 0 : obj.title } })));
44
+ }
45
+ else {
46
+ return cloneDeep(columns) || defaultColumns;
47
+ }
48
+ }, [layoutType, columns, defaultColumns]);
49
+ const handleSubmit = debounce(() => __awaiter(void 0, void 0, void 0, function* () {
50
+ var _b, _c, _d;
51
+ setLoading(true);
52
+ const vals = yield ((_b = formRef === null || formRef === void 0 ? void 0 : formRef.current) === null || _b === void 0 ? void 0 : _b.getFieldsValue());
53
+ const arr = (_d = (_c = Object.keys(vals)) === null || _c === void 0 ? void 0 : _c.map((key) => ({
54
+ name: key,
55
+ value: vals[key]
56
+ }))) === null || _d === void 0 ? void 0 : _d.filter((item) => item === null || item === void 0 ? void 0 : item.value);
57
+ if (!arr || !(arr === null || arr === void 0 ? void 0 : arr.length))
58
+ return;
59
+ const res = yield (submitForm === null || submitForm === void 0 ? void 0 : submitForm({ attributes: arr }));
60
+ setLoading(false);
61
+ if (res) {
62
+ window === null || window === void 0 ? void 0 : window.sxpPopup('');
63
+ res && (onClick === null || onClick === void 0 ? void 0 : onClick());
64
+ }
65
+ }), 1000);
66
+ return (React.createElement("div", { className: 'pb-appoint-form' },
67
+ React.createElement("div", { className: `pb-appoint-form-title ${css(Object.assign({}, textStyle))}` }, title),
68
+ React.createElement("div", Object.assign({ className: css(Object.assign({}, style)) }, props),
69
+ React.createElement("div", { className: 'pb-appoint-form-container' },
70
+ React.createElement(BetaSchemaForm, { columns: columnsData, submitter: false, layout: layoutType, autoFocusFirstInput: false, size: 'large', formRef: formRef, className: 'panel-reset' }))),
71
+ React.createElement("div", { className: 'pb-appoint-form-btn-wrapper' },
72
+ React.createElement("button", { onClick: handleSubmit, className: 'pb-appoint-form-btn', style: {
73
+ color: submitColor,
74
+ background: submitBgColor
75
+ } }, loading ? React.createElement(React.Fragment, null, "loading...") : submitText))));
76
+ };
77
+ export default memo(AppointForm);
@@ -0,0 +1,8 @@
1
+ declare const _default: {
2
+ title: string;
3
+ child: {
4
+ type: string;
5
+ name: string;
6
+ }[];
7
+ }[];
8
+ export default _default;
@@ -0,0 +1,11 @@
1
+ export default [
2
+ {
3
+ title: '点击事件',
4
+ child: [
5
+ {
6
+ type: 'link',
7
+ name: 'onClick'
8
+ }
9
+ ]
10
+ }
11
+ ];
@@ -0,0 +1,2 @@
1
+ declare const AppointForm: import("../../../../core/create").MaterialComponet<import(".").IAppointFormProps>;
2
+ export { AppointForm };
@@ -0,0 +1,36 @@
1
+ import interactionRender from './interactionRender';
2
+ import settingRender from './settingRender';
3
+ import AppointFormComponent from '.';
4
+ import { createMaterial } from '../../../../core/create';
5
+ const AppointForm = createMaterial(AppointFormComponent, {
6
+ displayName: '预约表单',
7
+ icon: '',
8
+ category: 'popup',
9
+ type: 'AppointForm',
10
+ related: {
11
+ settingRender,
12
+ bindableProps: [],
13
+ interactionRender
14
+ },
15
+ defaulSetting: {
16
+ name: '表单',
17
+ props: {
18
+ title: 'Appointment Booking',
19
+ submitColor: '#fff',
20
+ submitBgColor: '#000',
21
+ submitText: 'Submit',
22
+ layoutType: undefined
23
+ },
24
+ style: {},
25
+ textStyle: {
26
+ fontSize: 14,
27
+ color: '#000',
28
+ fontFamily: '黑体',
29
+ textAlign: 'center'
30
+ }
31
+ },
32
+ w: 100,
33
+ h: 40,
34
+ sort: 2
35
+ });
36
+ export { AppointForm };