@dpocean/chatui 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 (612) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +119 -0
  3. package/README.zh-CN.md +123 -0
  4. package/dist/index.css +1 -0
  5. package/dist/index.js +1 -0
  6. package/es/components/Avatar/index.js +21 -0
  7. package/es/components/Avatar/style.less +26 -0
  8. package/es/components/BackBottom/index.js +28 -0
  9. package/es/components/BackBottom/style.less +15 -0
  10. package/es/components/Backdrop/index.js +17 -0
  11. package/es/components/Backdrop/style.less +17 -0
  12. package/es/components/Bubble/index.js +17 -0
  13. package/es/components/Bubble/style.less +59 -0
  14. package/es/components/Button/index.js +45 -0
  15. package/es/components/Button/style.less +114 -0
  16. package/es/components/Card/Card.js +20 -0
  17. package/es/components/Card/CardActions.js +14 -0
  18. package/es/components/Card/CardContent.js +13 -0
  19. package/es/components/Card/CardHeader.js +52 -0
  20. package/es/components/Card/CardMedia.js +30 -0
  21. package/es/components/Card/CardText.js +13 -0
  22. package/es/components/Card/CardTitle.js +24 -0
  23. package/es/components/Card/index.js +7 -0
  24. package/es/components/Card/style.less +239 -0
  25. package/es/components/Carousel/Item.js +11 -0
  26. package/es/components/Carousel/index.js +369 -0
  27. package/es/components/Carousel/style.less +55 -0
  28. package/es/components/Chat/index.js +157 -0
  29. package/es/components/Chat/style.less +68 -0
  30. package/es/components/Checkbox/Checkbox.js +27 -0
  31. package/es/components/Checkbox/CheckboxGroup.js +43 -0
  32. package/es/components/Checkbox/index.js +2 -0
  33. package/es/components/ClickOutside/index.js +31 -0
  34. package/es/components/ComponentsProvider/ComponentsContext.js +10 -0
  35. package/es/components/ComponentsProvider/index.js +90 -0
  36. package/es/components/ComponentsProvider/interface.js +1 -0
  37. package/es/components/ComponentsProvider/useComponents.js +5 -0
  38. package/es/components/Composer/AccessoryWrap.js +9 -0
  39. package/es/components/Composer/Action.js +11 -0
  40. package/es/components/Composer/ComposerInput.js +58 -0
  41. package/es/components/Composer/SendButton.js +29 -0
  42. package/es/components/Composer/ToolbarItem.js +14 -0
  43. package/es/components/Composer/index.js +344 -0
  44. package/es/components/Composer/riseInput.js +49 -0
  45. package/es/components/Composer/style.less +103 -0
  46. package/es/components/Composer/viewportTop.js +22 -0
  47. package/es/components/ConfigProvider/index.js +44 -0
  48. package/es/components/ConfigProvider/locales/en_US.js +37 -0
  49. package/es/components/ConfigProvider/locales/es.js +37 -0
  50. package/es/components/ConfigProvider/locales/hi.js +37 -0
  51. package/es/components/ConfigProvider/locales/id.js +37 -0
  52. package/es/components/ConfigProvider/locales/index.js +20 -0
  53. package/es/components/ConfigProvider/locales/pt.js +37 -0
  54. package/es/components/ConfigProvider/locales/ur.js +37 -0
  55. package/es/components/ConfigProvider/locales/vi.js +37 -0
  56. package/es/components/ConfigProvider/locales/zh_CN.js +40 -0
  57. package/es/components/Countdown/index.js +22 -0
  58. package/es/components/Countdown/style.less +14 -0
  59. package/es/components/Coupon/index.js +84 -0
  60. package/es/components/Coupon/style.less +145 -0
  61. package/es/components/Divider/index.js +16 -0
  62. package/es/components/Divider/style.less +44 -0
  63. package/es/components/Empty/index.js +45 -0
  64. package/es/components/Empty/style.less +26 -0
  65. package/es/components/ErrorBoundary/index.js +58 -0
  66. package/es/components/FileCard/index.js +38 -0
  67. package/es/components/FileCard/style.less +63 -0
  68. package/es/components/Filter/index.js +200 -0
  69. package/es/components/Filter/style.less +96 -0
  70. package/es/components/Flex/Flex.js +52 -0
  71. package/es/components/Flex/FlexItem.js +25 -0
  72. package/es/components/Flex/index.js +2 -0
  73. package/es/components/Flex/style.less +78 -0
  74. package/es/components/Form/Form.js +20 -0
  75. package/es/components/Form/FormActions.js +12 -0
  76. package/es/components/Form/FormItem.js +19 -0
  77. package/es/components/Form/index.js +3 -0
  78. package/es/components/Form/style.less +64 -0
  79. package/es/components/Goods/index.js +126 -0
  80. package/es/components/Goods/style.less +119 -0
  81. package/es/components/HelpText/index.js +11 -0
  82. package/es/components/HelpText/style.less +4 -0
  83. package/es/components/Icon/index.js +24 -0
  84. package/es/components/Icon/style.less +21 -0
  85. package/es/components/IconButton/index.js +22 -0
  86. package/es/components/IconButton/style.less +25 -0
  87. package/es/components/Image/index.js +54 -0
  88. package/es/components/Image/style.less +11 -0
  89. package/es/components/ImageList/index.js +29 -0
  90. package/es/components/ImageList/style.less +20 -0
  91. package/es/components/InfiniteScroll/index.js +35 -0
  92. package/es/components/InfiniteScroll/style.less +4 -0
  93. package/es/components/Input/index.js +118 -0
  94. package/es/components/Input/style.less +74 -0
  95. package/es/components/KvList/KvItem.js +44 -0
  96. package/es/components/KvList/KvList.js +13 -0
  97. package/es/components/KvList/index.js +2 -0
  98. package/es/components/KvList/style.less +73 -0
  99. package/es/components/Label/index.js +12 -0
  100. package/es/components/Label/style.less +5 -0
  101. package/es/components/LazyComponent/SuspenseWrap.js +15 -0
  102. package/es/components/LazyComponent/index.js +50 -0
  103. package/es/components/LazyComponent/interface.js +1 -0
  104. package/es/components/List/List.js +17 -0
  105. package/es/components/List/ListItem.js +30 -0
  106. package/es/components/List/index.js +2 -0
  107. package/es/components/List/style.less +75 -0
  108. package/es/components/Loading/index.js +16 -0
  109. package/es/components/Loading/style.less +13 -0
  110. package/es/components/MediaObject/index.js +24 -0
  111. package/es/components/MediaObject/style.less +28 -0
  112. package/es/components/Message/Message.js +62 -0
  113. package/es/components/Message/SystemMessage.js +33 -0
  114. package/es/components/Message/index.js +2 -0
  115. package/es/components/Message/style.less +132 -0
  116. package/es/components/MessageContainer/index.js +187 -0
  117. package/es/components/MessageContainer/style.less +19 -0
  118. package/es/components/MessageStatus/index.js +84 -0
  119. package/es/components/MessageStatus/style.less +32 -0
  120. package/es/components/Modal/Base.js +131 -0
  121. package/es/components/Modal/Confirm.js +42 -0
  122. package/es/components/Modal/Modal.js +9 -0
  123. package/es/components/Modal/Popup.js +9 -0
  124. package/es/components/Modal/index.js +3 -0
  125. package/es/components/Modal/style.less +267 -0
  126. package/es/components/MultiRedPacket/index.js +29 -0
  127. package/es/components/MultiRedPacket/style.less +53 -0
  128. package/es/components/Navbar/index.js +49 -0
  129. package/es/components/Navbar/style.less +84 -0
  130. package/es/components/Notice/index.js +33 -0
  131. package/es/components/Notice/style.less +29 -0
  132. package/es/components/OrderObject/index.js +38 -0
  133. package/es/components/OrderObject/style.less +18 -0
  134. package/es/components/Popover/index.js +56 -0
  135. package/es/components/Popover/style.less +22 -0
  136. package/es/components/Portal/index.js +29 -0
  137. package/es/components/Price/index.js +92 -0
  138. package/es/components/Price/style.less +45 -0
  139. package/es/components/Progress/index.js +25 -0
  140. package/es/components/Progress/style.less +23 -0
  141. package/es/components/PullToRefresh/index.js +224 -0
  142. package/es/components/PullToRefresh/style.less +37 -0
  143. package/es/components/QuickReplies/QuickReplies.js +50 -0
  144. package/es/components/QuickReplies/QuickReply.js +29 -0
  145. package/es/components/QuickReplies/index.js +2 -0
  146. package/es/components/QuickReplies/style.less +94 -0
  147. package/es/components/Quote/index.js +16 -0
  148. package/es/components/Quote/style.less +46 -0
  149. package/es/components/Radio/Radio.js +27 -0
  150. package/es/components/Radio/RadioGroup.js +37 -0
  151. package/es/components/Radio/index.js +2 -0
  152. package/es/components/Radio/style.less +87 -0
  153. package/es/components/RateActions/index.js +54 -0
  154. package/es/components/RateActions/style.less +34 -0
  155. package/es/components/Recorder/index.js +128 -0
  156. package/es/components/Recorder/style.less +89 -0
  157. package/es/components/RedPacket/index.js +93 -0
  158. package/es/components/RedPacket/style.less +135 -0
  159. package/es/components/Ribbon/index.js +37 -0
  160. package/es/components/Ribbon/style.less +71 -0
  161. package/es/components/RichText/configDOMPurify.js +26 -0
  162. package/es/components/RichText/index.js +25 -0
  163. package/es/components/RichText/style.less +4 -0
  164. package/es/components/ScrollGrid/index.js +74 -0
  165. package/es/components/ScrollGrid/style.less +54 -0
  166. package/es/components/ScrollView/Item.js +39 -0
  167. package/es/components/ScrollView/ScrollView.js +89 -0
  168. package/es/components/ScrollView/index.js +1 -0
  169. package/es/components/ScrollView/style.less +60 -0
  170. package/es/components/Search/index.js +78 -0
  171. package/es/components/Search/style.less +47 -0
  172. package/es/components/Select/index.js +20 -0
  173. package/es/components/Select/style.less +11 -0
  174. package/es/components/SendConfirm/SendConfirm.js +45 -0
  175. package/es/components/SendConfirm/index.js +1 -0
  176. package/es/components/SendConfirm/style.less +16 -0
  177. package/es/components/Skeleton/index.js +21 -0
  178. package/es/components/Skeleton/style.less +26 -0
  179. package/es/components/StatusBadge/index.js +22 -0
  180. package/es/components/StatusBadge/style.less +27 -0
  181. package/es/components/Stepper/Step.js +56 -0
  182. package/es/components/Stepper/Stepper.js +40 -0
  183. package/es/components/Stepper/index.js +2 -0
  184. package/es/components/Stepper/style.less +105 -0
  185. package/es/components/Tabs/Tab.js +5 -0
  186. package/es/components/Tabs/Tabs.js +142 -0
  187. package/es/components/Tabs/index.js +2 -0
  188. package/es/components/Tabs/style.less +98 -0
  189. package/es/components/Tag/index.js +17 -0
  190. package/es/components/Tag/style.less +45 -0
  191. package/es/components/Text/index.js +28 -0
  192. package/es/components/Text/style.less +19 -0
  193. package/es/components/Think/index.js +37 -0
  194. package/es/components/Think/style.less +68 -0
  195. package/es/components/Time/Time.js +13 -0
  196. package/es/components/Time/index.js +1 -0
  197. package/es/components/Time/parser.js +50 -0
  198. package/es/components/Time/style.less +4 -0
  199. package/es/components/Tips/index.js +21 -0
  200. package/es/components/Tips/style.less +23 -0
  201. package/es/components/Toast/Toast.js +61 -0
  202. package/es/components/Toast/index.js +23 -0
  203. package/es/components/Toast/style.less +48 -0
  204. package/es/components/Toolbar/Toolbar.js +15 -0
  205. package/es/components/Toolbar/ToolbarButton.js +30 -0
  206. package/es/components/Toolbar/index.js +1 -0
  207. package/es/components/Toolbar/style.less +97 -0
  208. package/es/components/Tooltip/style.less +40 -0
  209. package/es/components/Tree/Tree.js +10 -0
  210. package/es/components/Tree/TreeNode.js +66 -0
  211. package/es/components/Tree/index.js +2 -0
  212. package/es/components/Tree/style.less +41 -0
  213. package/es/components/Typing/Typing.js +22 -0
  214. package/es/components/Typing/index.js +1 -0
  215. package/es/components/Typing/style.less +41 -0
  216. package/es/components/TypingBubble/index.js +48 -0
  217. package/es/components/Video/index.js +82 -0
  218. package/es/components/Video/style.less +47 -0
  219. package/es/components/VisuallyHidden/index.js +18 -0
  220. package/es/components/VisuallyHidden/style.less +0 -0
  221. package/es/global.d.js +7 -0
  222. package/es/hooks/useClickOutside.js +21 -0
  223. package/es/hooks/useCountdown.js +54 -0
  224. package/es/hooks/useForwardRef.js +14 -0
  225. package/es/hooks/useLatest.js +6 -0
  226. package/es/hooks/useMessages.js +72 -0
  227. package/es/hooks/useMount.js +47 -0
  228. package/es/hooks/useNextId.js +11 -0
  229. package/es/hooks/useQuickReplies.js +44 -0
  230. package/es/hooks/useTitleTyping.js +53 -0
  231. package/es/hooks/useTypewriter.js +35 -0
  232. package/es/hooks/useWindowResize.js +24 -0
  233. package/es/index.js +85 -0
  234. package/es/styles/animation.less +48 -0
  235. package/es/styles/dark.less +40 -0
  236. package/es/styles/font-face.less +22 -0
  237. package/es/styles/index.less +81 -0
  238. package/es/styles/root.less +122 -0
  239. package/es/styles/scale.less +19 -0
  240. package/es/styles/utils.less +9 -0
  241. package/es/styles/var.less +369 -0
  242. package/es/utils/canUse.js +32 -0
  243. package/es/utils/countLines.js +6 -0
  244. package/es/utils/date.js +28 -0
  245. package/es/utils/formatTime.js +16 -0
  246. package/es/utils/getExtName.js +4 -0
  247. package/es/utils/getFps.js +25 -0
  248. package/es/utils/getRandomInt.js +3 -0
  249. package/es/utils/getToBottom.js +3 -0
  250. package/es/utils/importScript.js +124 -0
  251. package/es/utils/index.js +23 -0
  252. package/es/utils/lazyComponent.js +26 -0
  253. package/es/utils/mountComponent.js +19 -0
  254. package/es/utils/parseDataTransfer.js +18 -0
  255. package/es/utils/prettyBytes.js +10 -0
  256. package/es/utils/smoothScroll.js +34 -0
  257. package/es/utils/style.js +13 -0
  258. package/es/utils/throttle.js +14 -0
  259. package/es/utils/toggleClass.js +5 -0
  260. package/es/utils/ua.js +11 -0
  261. package/lib/components/Avatar/index.d.ts +13 -0
  262. package/lib/components/Avatar/index.js +28 -0
  263. package/lib/components/BackBottom/index.d.ts +8 -0
  264. package/lib/components/BackBottom/index.js +36 -0
  265. package/lib/components/Backdrop/index.d.ts +7 -0
  266. package/lib/components/Backdrop/index.js +24 -0
  267. package/lib/components/Bubble/index.d.ts +6 -0
  268. package/lib/components/Bubble/index.js +24 -0
  269. package/lib/components/Button/index.d.ts +14 -0
  270. package/lib/components/Button/index.js +52 -0
  271. package/lib/components/Card/Card.d.ts +9 -0
  272. package/lib/components/Card/Card.js +27 -0
  273. package/lib/components/Card/CardActions.d.ts +7 -0
  274. package/lib/components/Card/CardActions.js +21 -0
  275. package/lib/components/Card/CardContent.d.ts +6 -0
  276. package/lib/components/Card/CardContent.js +20 -0
  277. package/lib/components/Card/CardHeader.d.ts +13 -0
  278. package/lib/components/Card/CardHeader.js +59 -0
  279. package/lib/components/Card/CardMedia.d.ts +9 -0
  280. package/lib/components/Card/CardMedia.js +37 -0
  281. package/lib/components/Card/CardText.d.ts +6 -0
  282. package/lib/components/Card/CardText.js +20 -0
  283. package/lib/components/Card/CardTitle.d.ts +9 -0
  284. package/lib/components/Card/CardTitle.js +31 -0
  285. package/lib/components/Card/index.d.ts +14 -0
  286. package/lib/components/Card/index.js +54 -0
  287. package/lib/components/Carousel/Item.d.ts +7 -0
  288. package/lib/components/Carousel/Item.js +18 -0
  289. package/lib/components/Carousel/index.d.ts +26 -0
  290. package/lib/components/Carousel/index.js +378 -0
  291. package/lib/components/Chat/index.d.ts +216 -0
  292. package/lib/components/Chat/index.js +166 -0
  293. package/lib/components/Checkbox/Checkbox.d.ts +7 -0
  294. package/lib/components/Checkbox/Checkbox.js +34 -0
  295. package/lib/components/Checkbox/CheckboxGroup.d.ts +15 -0
  296. package/lib/components/Checkbox/CheckboxGroup.js +50 -0
  297. package/lib/components/Checkbox/index.d.ts +4 -0
  298. package/lib/components/Checkbox/index.js +19 -0
  299. package/lib/components/ClickOutside/index.d.ts +7 -0
  300. package/lib/components/ClickOutside/index.js +40 -0
  301. package/lib/components/ComponentsProvider/ComponentsContext.d.ts +3 -0
  302. package/lib/components/ComponentsProvider/ComponentsContext.js +17 -0
  303. package/lib/components/ComponentsProvider/index.d.ts +5 -0
  304. package/lib/components/ComponentsProvider/index.js +105 -0
  305. package/lib/components/ComponentsProvider/interface.d.ts +40 -0
  306. package/lib/components/ComponentsProvider/interface.js +5 -0
  307. package/lib/components/ComponentsProvider/useComponents.d.ts +1 -0
  308. package/lib/components/ComponentsProvider/useComponents.js +12 -0
  309. package/lib/components/Composer/AccessoryWrap.d.ts +7 -0
  310. package/lib/components/Composer/AccessoryWrap.js +16 -0
  311. package/lib/components/Composer/Action.d.ts +3 -0
  312. package/lib/components/Composer/Action.js +18 -0
  313. package/lib/components/Composer/ComposerInput.d.ts +9 -0
  314. package/lib/components/Composer/ComposerInput.js +67 -0
  315. package/lib/components/Composer/SendButton.d.ts +7 -0
  316. package/lib/components/Composer/SendButton.js +37 -0
  317. package/lib/components/Composer/ToolbarItem.d.ts +8 -0
  318. package/lib/components/Composer/ToolbarItem.js +21 -0
  319. package/lib/components/Composer/index.d.ts +32 -0
  320. package/lib/components/Composer/index.js +353 -0
  321. package/lib/components/Composer/riseInput.d.ts +1 -0
  322. package/lib/components/Composer/riseInput.js +55 -0
  323. package/lib/components/Composer/viewportTop.d.ts +2 -0
  324. package/lib/components/Composer/viewportTop.js +29 -0
  325. package/lib/components/ConfigProvider/index.d.ts +33 -0
  326. package/lib/components/ConfigProvider/index.js +53 -0
  327. package/lib/components/ConfigProvider/locales/en_US.d.ts +38 -0
  328. package/lib/components/ConfigProvider/locales/en_US.js +43 -0
  329. package/lib/components/ConfigProvider/locales/es.d.ts +38 -0
  330. package/lib/components/ConfigProvider/locales/es.js +43 -0
  331. package/lib/components/ConfigProvider/locales/hi.d.ts +38 -0
  332. package/lib/components/ConfigProvider/locales/hi.js +43 -0
  333. package/lib/components/ConfigProvider/locales/id.d.ts +38 -0
  334. package/lib/components/ConfigProvider/locales/id.js +43 -0
  335. package/lib/components/ConfigProvider/locales/index.d.ts +2 -0
  336. package/lib/components/ConfigProvider/locales/index.js +27 -0
  337. package/lib/components/ConfigProvider/locales/pt.d.ts +38 -0
  338. package/lib/components/ConfigProvider/locales/pt.js +43 -0
  339. package/lib/components/ConfigProvider/locales/ur.d.ts +38 -0
  340. package/lib/components/ConfigProvider/locales/ur.js +43 -0
  341. package/lib/components/ConfigProvider/locales/vi.d.ts +38 -0
  342. package/lib/components/ConfigProvider/locales/vi.js +43 -0
  343. package/lib/components/ConfigProvider/locales/zh_CN.d.ts +38 -0
  344. package/lib/components/ConfigProvider/locales/zh_CN.js +46 -0
  345. package/lib/components/Countdown/index.d.ts +6 -0
  346. package/lib/components/Countdown/index.js +29 -0
  347. package/lib/components/Coupon/index.d.ts +18 -0
  348. package/lib/components/Coupon/index.js +91 -0
  349. package/lib/components/Divider/index.d.ts +7 -0
  350. package/lib/components/Divider/index.js +23 -0
  351. package/lib/components/Empty/index.d.ts +10 -0
  352. package/lib/components/Empty/index.js +52 -0
  353. package/lib/components/ErrorBoundary/index.d.ts +20 -0
  354. package/lib/components/ErrorBoundary/index.js +65 -0
  355. package/lib/components/FileCard/index.d.ts +8 -0
  356. package/lib/components/FileCard/index.js +45 -0
  357. package/lib/components/Filter/index.d.ts +17 -0
  358. package/lib/components/Filter/index.js +208 -0
  359. package/lib/components/Flex/Flex.d.ts +16 -0
  360. package/lib/components/Flex/Flex.js +59 -0
  361. package/lib/components/Flex/FlexItem.d.ts +8 -0
  362. package/lib/components/Flex/FlexItem.js +32 -0
  363. package/lib/components/Flex/index.d.ts +4 -0
  364. package/lib/components/Flex/index.js +19 -0
  365. package/lib/components/Form/Form.d.ts +9 -0
  366. package/lib/components/Form/Form.js +27 -0
  367. package/lib/components/Form/FormActions.d.ts +2 -0
  368. package/lib/components/Form/FormActions.js +19 -0
  369. package/lib/components/Form/FormItem.d.ts +10 -0
  370. package/lib/components/Form/FormItem.js +26 -0
  371. package/lib/components/Form/index.d.ts +5 -0
  372. package/lib/components/Form/index.js +32 -0
  373. package/lib/components/Goods/index.d.ts +32 -0
  374. package/lib/components/Goods/index.js +133 -0
  375. package/lib/components/HelpText/index.d.ts +2 -0
  376. package/lib/components/HelpText/index.js +18 -0
  377. package/lib/components/Icon/index.d.ts +8 -0
  378. package/lib/components/Icon/index.js +31 -0
  379. package/lib/components/IconButton/index.d.ts +6 -0
  380. package/lib/components/IconButton/index.js +29 -0
  381. package/lib/components/Image/index.d.ts +8 -0
  382. package/lib/components/Image/index.js +63 -0
  383. package/lib/components/ImageList/index.d.ts +13 -0
  384. package/lib/components/ImageList/index.js +36 -0
  385. package/lib/components/InfiniteScroll/index.d.ts +8 -0
  386. package/lib/components/InfiniteScroll/index.js +42 -0
  387. package/lib/components/Input/index.d.ts +15 -0
  388. package/lib/components/Input/index.js +127 -0
  389. package/lib/components/KvList/KvItem.d.ts +14 -0
  390. package/lib/components/KvList/KvItem.js +51 -0
  391. package/lib/components/KvList/KvList.d.ts +7 -0
  392. package/lib/components/KvList/KvList.js +20 -0
  393. package/lib/components/KvList/index.d.ts +4 -0
  394. package/lib/components/KvList/index.js +19 -0
  395. package/lib/components/Label/index.d.ts +2 -0
  396. package/lib/components/Label/index.js +19 -0
  397. package/lib/components/LazyComponent/SuspenseWrap.d.ts +3 -0
  398. package/lib/components/LazyComponent/SuspenseWrap.js +24 -0
  399. package/lib/components/LazyComponent/index.d.ts +6 -0
  400. package/lib/components/LazyComponent/index.js +57 -0
  401. package/lib/components/LazyComponent/interface.d.ts +18 -0
  402. package/lib/components/LazyComponent/interface.js +5 -0
  403. package/lib/components/List/List.d.ts +8 -0
  404. package/lib/components/List/List.js +24 -0
  405. package/lib/components/List/ListItem.d.ts +17 -0
  406. package/lib/components/List/ListItem.js +37 -0
  407. package/lib/components/List/index.d.ts +4 -0
  408. package/lib/components/List/index.js +19 -0
  409. package/lib/components/Loading/index.d.ts +6 -0
  410. package/lib/components/Loading/index.js +23 -0
  411. package/lib/components/MediaObject/index.d.ts +10 -0
  412. package/lib/components/MediaObject/index.js +31 -0
  413. package/lib/components/Message/Message.d.ts +54 -0
  414. package/lib/components/Message/Message.js +69 -0
  415. package/lib/components/Message/SystemMessage.d.ts +12 -0
  416. package/lib/components/Message/SystemMessage.js +42 -0
  417. package/lib/components/Message/index.d.ts +4 -0
  418. package/lib/components/Message/index.js +20 -0
  419. package/lib/components/MessageContainer/index.d.ts +19 -0
  420. package/lib/components/MessageContainer/index.js +197 -0
  421. package/lib/components/MessageStatus/index.d.ts +13 -0
  422. package/lib/components/MessageStatus/index.js +93 -0
  423. package/lib/components/Modal/Base.d.ts +24 -0
  424. package/lib/components/Modal/Base.js +140 -0
  425. package/lib/components/Modal/Confirm.d.ts +3 -0
  426. package/lib/components/Modal/Confirm.js +49 -0
  427. package/lib/components/Modal/Modal.d.ts +3 -0
  428. package/lib/components/Modal/Modal.js +16 -0
  429. package/lib/components/Modal/Popup.d.ts +3 -0
  430. package/lib/components/Modal/Popup.js +16 -0
  431. package/lib/components/Modal/index.d.ts +4 -0
  432. package/lib/components/Modal/index.js +26 -0
  433. package/lib/components/MultiRedPacket/index.d.ts +11 -0
  434. package/lib/components/MultiRedPacket/index.js +36 -0
  435. package/lib/components/Navbar/index.d.ts +13 -0
  436. package/lib/components/Navbar/index.js +56 -0
  437. package/lib/components/Notice/index.d.ts +9 -0
  438. package/lib/components/Notice/index.js +40 -0
  439. package/lib/components/OrderObject/index.d.ts +10 -0
  440. package/lib/components/OrderObject/index.js +45 -0
  441. package/lib/components/Popover/index.d.ts +9 -0
  442. package/lib/components/Popover/index.js +65 -0
  443. package/lib/components/Portal/index.d.ts +8 -0
  444. package/lib/components/Portal/index.js +36 -0
  445. package/lib/components/Price/index.d.ts +10 -0
  446. package/lib/components/Price/index.js +99 -0
  447. package/lib/components/Progress/index.d.ts +7 -0
  448. package/lib/components/Progress/index.js +32 -0
  449. package/lib/components/PullToRefresh/index.d.ts +27 -0
  450. package/lib/components/PullToRefresh/index.js +233 -0
  451. package/lib/components/QuickReplies/QuickReplies.d.ts +10 -0
  452. package/lib/components/QuickReplies/QuickReplies.js +59 -0
  453. package/lib/components/QuickReplies/QuickReply.d.ts +15 -0
  454. package/lib/components/QuickReplies/QuickReply.js +36 -0
  455. package/lib/components/QuickReplies/index.d.ts +4 -0
  456. package/lib/components/QuickReplies/index.js +20 -0
  457. package/lib/components/Quote/index.d.ts +8 -0
  458. package/lib/components/Quote/index.js +23 -0
  459. package/lib/components/Radio/Radio.d.ts +7 -0
  460. package/lib/components/Radio/Radio.js +34 -0
  461. package/lib/components/Radio/RadioGroup.d.ts +15 -0
  462. package/lib/components/Radio/RadioGroup.js +44 -0
  463. package/lib/components/Radio/index.d.ts +4 -0
  464. package/lib/components/Radio/index.js +19 -0
  465. package/lib/components/RateActions/index.d.ts +7 -0
  466. package/lib/components/RateActions/index.js +63 -0
  467. package/lib/components/Recorder/index.d.ts +15 -0
  468. package/lib/components/Recorder/index.js +137 -0
  469. package/lib/components/RedPacket/index.d.ts +20 -0
  470. package/lib/components/RedPacket/index.js +100 -0
  471. package/lib/components/Ribbon/index.d.ts +9 -0
  472. package/lib/components/Ribbon/index.js +44 -0
  473. package/lib/components/RichText/configDOMPurify.d.ts +1 -0
  474. package/lib/components/RichText/configDOMPurify.js +29 -0
  475. package/lib/components/RichText/index.d.ts +9 -0
  476. package/lib/components/RichText/index.js +32 -0
  477. package/lib/components/ScrollGrid/index.d.ts +7 -0
  478. package/lib/components/ScrollGrid/index.js +83 -0
  479. package/lib/components/ScrollView/Item.d.ts +9 -0
  480. package/lib/components/ScrollView/Item.js +48 -0
  481. package/lib/components/ScrollView/ScrollView.d.ts +28 -0
  482. package/lib/components/ScrollView/ScrollView.js +98 -0
  483. package/lib/components/ScrollView/index.d.ts +2 -0
  484. package/lib/components/ScrollView/index.js +12 -0
  485. package/lib/components/Search/index.d.ts +14 -0
  486. package/lib/components/Search/index.js +87 -0
  487. package/lib/components/Select/index.d.ts +7 -0
  488. package/lib/components/Select/index.js +27 -0
  489. package/lib/components/SendConfirm/SendConfirm.d.ts +7 -0
  490. package/lib/components/SendConfirm/SendConfirm.js +54 -0
  491. package/lib/components/SendConfirm/index.d.ts +1 -0
  492. package/lib/components/SendConfirm/index.js +12 -0
  493. package/lib/components/Skeleton/index.d.ts +10 -0
  494. package/lib/components/Skeleton/index.js +28 -0
  495. package/lib/components/StatusBadge/index.d.ts +6 -0
  496. package/lib/components/StatusBadge/index.js +29 -0
  497. package/lib/components/Stepper/Step.d.ts +15 -0
  498. package/lib/components/Stepper/Step.js +63 -0
  499. package/lib/components/Stepper/Stepper.d.ts +10 -0
  500. package/lib/components/Stepper/Stepper.js +47 -0
  501. package/lib/components/Stepper/index.d.ts +4 -0
  502. package/lib/components/Stepper/index.js +19 -0
  503. package/lib/components/Tabs/Tab.d.ts +6 -0
  504. package/lib/components/Tabs/Tab.js +12 -0
  505. package/lib/components/Tabs/Tabs.d.ts +12 -0
  506. package/lib/components/Tabs/Tabs.js +151 -0
  507. package/lib/components/Tabs/index.d.ts +4 -0
  508. package/lib/components/Tabs/index.js +19 -0
  509. package/lib/components/Tag/index.d.ts +10 -0
  510. package/lib/components/Tag/index.js +24 -0
  511. package/lib/components/Text/index.d.ts +10 -0
  512. package/lib/components/Text/index.js +35 -0
  513. package/lib/components/Think/index.d.ts +8 -0
  514. package/lib/components/Think/index.js +46 -0
  515. package/lib/components/Time/Time.d.ts +7 -0
  516. package/lib/components/Time/Time.js +20 -0
  517. package/lib/components/Time/index.d.ts +2 -0
  518. package/lib/components/Time/index.js +12 -0
  519. package/lib/components/Time/parser.d.ts +10 -0
  520. package/lib/components/Time/parser.js +56 -0
  521. package/lib/components/Tips/index.d.ts +9 -0
  522. package/lib/components/Tips/index.js +28 -0
  523. package/lib/components/Toast/Toast.d.ts +8 -0
  524. package/lib/components/Toast/Toast.js +70 -0
  525. package/lib/components/Toast/index.d.ts +10 -0
  526. package/lib/components/Toast/index.js +35 -0
  527. package/lib/components/Toolbar/Toolbar.d.ts +7 -0
  528. package/lib/components/Toolbar/Toolbar.js +22 -0
  529. package/lib/components/Toolbar/ToolbarButton.d.ts +13 -0
  530. package/lib/components/Toolbar/ToolbarButton.js +37 -0
  531. package/lib/components/Toolbar/index.d.ts +3 -0
  532. package/lib/components/Toolbar/index.js +12 -0
  533. package/lib/components/Tree/Tree.d.ts +6 -0
  534. package/lib/components/Tree/Tree.js +17 -0
  535. package/lib/components/Tree/TreeNode.d.ts +10 -0
  536. package/lib/components/Tree/TreeNode.js +75 -0
  537. package/lib/components/Tree/index.d.ts +4 -0
  538. package/lib/components/Tree/index.js +19 -0
  539. package/lib/components/Typing/Typing.d.ts +6 -0
  540. package/lib/components/Typing/Typing.js +29 -0
  541. package/lib/components/Typing/index.d.ts +1 -0
  542. package/lib/components/Typing/index.js +12 -0
  543. package/lib/components/TypingBubble/index.d.ts +12 -0
  544. package/lib/components/TypingBubble/index.js +57 -0
  545. package/lib/components/Video/index.d.ts +12 -0
  546. package/lib/components/Video/index.js +91 -0
  547. package/lib/components/VisuallyHidden/index.d.ts +2 -0
  548. package/lib/components/VisuallyHidden/index.js +25 -0
  549. package/lib/global.d.js +5 -0
  550. package/lib/hooks/useClickOutside.d.ts +1 -0
  551. package/lib/hooks/useClickOutside.js +27 -0
  552. package/lib/hooks/useCountdown.d.ts +11 -0
  553. package/lib/hooks/useCountdown.js +61 -0
  554. package/lib/hooks/useForwardRef.d.ts +2 -0
  555. package/lib/hooks/useForwardRef.js +20 -0
  556. package/lib/hooks/useLatest.d.ts +1 -0
  557. package/lib/hooks/useLatest.js +12 -0
  558. package/lib/hooks/useMessages.d.ts +14 -0
  559. package/lib/hooks/useMessages.js +79 -0
  560. package/lib/hooks/useMount.d.ts +11 -0
  561. package/lib/hooks/useMount.js +54 -0
  562. package/lib/hooks/useNextId.d.ts +1 -0
  563. package/lib/hooks/useNextId.js +17 -0
  564. package/lib/hooks/useQuickReplies.d.ts +12 -0
  565. package/lib/hooks/useQuickReplies.js +51 -0
  566. package/lib/hooks/useTitleTyping.d.ts +10 -0
  567. package/lib/hooks/useTitleTyping.js +60 -0
  568. package/lib/hooks/useTypewriter.d.ts +9 -0
  569. package/lib/hooks/useTypewriter.js +42 -0
  570. package/lib/hooks/useWindowResize.d.ts +1 -0
  571. package/lib/hooks/useWindowResize.js +30 -0
  572. package/lib/index.d.ts +153 -0
  573. package/lib/index.js +751 -0
  574. package/lib/utils/canUse.d.ts +2 -0
  575. package/lib/utils/canUse.js +39 -0
  576. package/lib/utils/countLines.d.ts +1 -0
  577. package/lib/utils/countLines.js +12 -0
  578. package/lib/utils/date.d.ts +17 -0
  579. package/lib/utils/date.js +37 -0
  580. package/lib/utils/formatTime.d.ts +1 -0
  581. package/lib/utils/formatTime.js +22 -0
  582. package/lib/utils/getExtName.d.ts +2 -0
  583. package/lib/utils/getExtName.js +10 -0
  584. package/lib/utils/getFps.d.ts +2 -0
  585. package/lib/utils/getFps.js +31 -0
  586. package/lib/utils/getRandomInt.d.ts +1 -0
  587. package/lib/utils/getRandomInt.js +9 -0
  588. package/lib/utils/getToBottom.d.ts +1 -0
  589. package/lib/utils/getToBottom.js +9 -0
  590. package/lib/utils/importScript.d.ts +19 -0
  591. package/lib/utils/importScript.js +130 -0
  592. package/lib/utils/index.d.ts +14 -0
  593. package/lib/utils/index.js +30 -0
  594. package/lib/utils/lazyComponent.d.ts +5 -0
  595. package/lib/utils/lazyComponent.js +33 -0
  596. package/lib/utils/mountComponent.d.ts +2 -0
  597. package/lib/utils/mountComponent.js +26 -0
  598. package/lib/utils/parseDataTransfer.d.ts +1 -0
  599. package/lib/utils/parseDataTransfer.js +24 -0
  600. package/lib/utils/prettyBytes.d.ts +2 -0
  601. package/lib/utils/prettyBytes.js +16 -0
  602. package/lib/utils/smoothScroll.d.ts +8 -0
  603. package/lib/utils/smoothScroll.js +41 -0
  604. package/lib/utils/style.d.ts +2 -0
  605. package/lib/utils/style.js +19 -0
  606. package/lib/utils/throttle.d.ts +1 -0
  607. package/lib/utils/throttle.js +20 -0
  608. package/lib/utils/toggleClass.d.ts +2 -0
  609. package/lib/utils/toggleClass.js +11 -0
  610. package/lib/utils/ua.d.ts +7 -0
  611. package/lib/utils/ua.js +18 -0
  612. package/package.json +114 -0
@@ -0,0 +1,122 @@
1
+ :root {
2
+ // 已弃用,用下面的文字色、填充色、线条色、功能色替换
3
+ --black: #000; // 不再使用
4
+ --white: #fff;
5
+ --gray-1: #11192d;
6
+ --gray-2: #50607a;
7
+ --gray-3: #7c889c;
8
+ --gray-4: #cacfd7;
9
+ --gray-5: rgba(80, 96, 122, 0.15);
10
+ --gray-6: #e5e5e5; // 不再使用
11
+ --gray-7: #f5f5f5; // 不再使用
12
+ --gray-8: #f3f6f8;
13
+ --light-1: @gray-6; // 不再使用
14
+ --light-2: @gray-7; // 不再使用
15
+ --link-color: var(--blue);
16
+ --blue: #0080ff;
17
+ --gray-dark: @gray-dark;
18
+ --green: #1dbf1d;
19
+ --orange: @orange;
20
+ --red: #ff0300;
21
+ --yellow: @yellow;
22
+ --yellow-light: @yellow-light;
23
+ }
24
+
25
+ :root {
26
+ // Brand 品牌色
27
+ --brand-1: #ff6200;
28
+ --brand-2: #ffb300;
29
+ --brand-3: #ffe0cc;
30
+ --brand-4: #ffefe5;
31
+
32
+ // Text 文字色
33
+ --color-text-1: var(--gray-1);
34
+ --color-text-2: var(--gray-2);
35
+ --color-text-3: var(--gray-3);
36
+
37
+ // Fill 填充色
38
+ --color-fill-1: var(--white);
39
+ --color-fill-2: var(--gray-8);
40
+ --color-mask: rgba(14, 17, 25, 0.5);
41
+ --color-toast: rgba(17, 25, 45, 0.9);
42
+
43
+ // Line 线条色
44
+ --color-line-1: var(--gray-5);
45
+ --color-line-2: var(--gray-4);
46
+
47
+ // Functional 功能色
48
+ --highlight-1: var(--brand-1);
49
+ --highlight-2: var(--brand-2);
50
+ --color-warning: var(--red);
51
+ --color-success: var(--green);
52
+ --color-link: var(--link-color);
53
+
54
+ --font-size-xs: @font-size-xs; // 12px
55
+ --font-size-sm: @font-size-sm; // 14px
56
+ --font-size-body: 15px;
57
+ --font-size-md: @font-size-md; // 16px
58
+ --font-size-lg: @font-size-lg; // 18px
59
+
60
+ --radius-sm: 4Px;
61
+ --radius-md: 6Px;
62
+ // --radius-lg: @border-radius-lg;
63
+
64
+ --shadow-1: @shadow-1;
65
+ --shadow-2: @shadow-2;
66
+ --shadow-3: @shadow-3;
67
+
68
+ --safe-top: 0px;
69
+ --safe-bottom: 0px;
70
+ --viewport-top: 0px;
71
+ }
72
+
73
+ @supports (top: constant(safe-area-inset-top)) {
74
+ :root {
75
+ --safe-top: constant(safe-area-inset-top);
76
+ --safe-bottom: constant(safe-area-inset-bottom);
77
+ }
78
+ }
79
+
80
+ @supports (top: env(safe-area-inset-top)) {
81
+ :root {
82
+ --safe-top: env(safe-area-inset-top);
83
+ --safe-bottom: env(safe-area-inset-bottom);
84
+ }
85
+ }
86
+
87
+ :root {
88
+ --app-bg: var(--color-fill-2);
89
+ --navbar-bg: var(--color-fill-2);
90
+ --footer-bg: var(--color-fill-2);
91
+
92
+ --gutter: @gutter;
93
+ --rate-width: 32Px;
94
+
95
+ // 头像和消息内容的间隙
96
+ --msg-avatar-gap: 6Px;
97
+ // 消息旁边的空白空间:间隙 + 头像的宽度(点赞踩的宽度一致)
98
+ --msg-gutter: calc(var(--msg-avatar-gap) + var(--rate-width));
99
+
100
+ --btn-padding: 8px 12px;
101
+ --btn-border-color: var(--color-line-2);
102
+ --btn-border-radius: var(--radius-md);
103
+ --btn-bg: var(--color-fill-1);
104
+ --btn-color: var(--color-text-2);
105
+ --btn-font-weight: 500;
106
+ --btn-font-size: @btn-font-size;
107
+ --btn-line-height: 1.125rem; // 18px
108
+ --btn-padding-sm: 4px 12px;
109
+ --btn-font-size-sm: @btn-font-size-sm;
110
+ --btn-padding-lg: 10px 12px;
111
+ --btn-font-size-lg: 15px;
112
+ --btn-active-bg: rgba(0, 0, 0, 0.08);
113
+ --btn-hover-bg: rgba(0, 0, 0, 0.04);
114
+ --btn-primary-border-color: transparent;
115
+ --btn-primary-bg: var(--brand-1);
116
+ --btn-primary-color: var(--white);
117
+
118
+ --goods-img-size: 65px;
119
+
120
+ --skeleton-bg-1: #f6f6f6;
121
+ --skeleton-bg-2: #f0f0f0;
122
+ }
@@ -0,0 +1,19 @@
1
+ & when (@global-style = true) {
2
+ :root {
3
+ --scale-ratio: 1;
4
+ // vw = 16 * 100 / 375
5
+ font-size: calc(4.2666666667vw * var(--scale-ratio));
6
+ }
7
+
8
+ @media (max-width: 374px) {
9
+ :root {
10
+ font-size: calc(16px * var(--scale-ratio));
11
+ }
12
+ }
13
+
14
+ @media (min-width: 768px) {
15
+ :root {
16
+ font-size: 16px;
17
+ }
18
+ }
19
+ }
@@ -0,0 +1,9 @@
1
+ // state
2
+ .S--invisible {
3
+ position: absolute;
4
+ clip: rect(0, 0, 0, 0);
5
+ }
6
+
7
+ .pb-safe {
8
+ padding-bottom: var(--safe-bottom);
9
+ }
@@ -0,0 +1,369 @@
1
+ @global-style: true;
2
+
3
+ // Color Palette
4
+ @brand-1: #ff6200;
5
+ @brand-2: #ffb300;
6
+ @brand-3: #ffe0cc;
7
+ @black: #000;
8
+ @white: #fff;
9
+ @gray-1: #11192d;
10
+ @gray-2: #50607a;
11
+ @gray-3: #7c889c;
12
+ @gray-4: #cacfd7;
13
+ @gray-5: #50607a;
14
+ @gray-6: #e5e5e5;
15
+ @gray-7: #f5f5f5;
16
+ @gray-8: #f3f6f8;
17
+
18
+ @blue: #0080ff;
19
+ @gray-dark: #11192d;
20
+ @green: #1dbf1d;
21
+ @orange: #ff6200;
22
+ @red: #ff0300;
23
+ @yellow: #ffb300;
24
+ @yellow-light: #fff9db;
25
+
26
+ // Box Shadow
27
+ @shadow-1: 0 3px 4px 0 rgba(0, 0, 0, 0.04);
28
+ @shadow-2: 0 4px 8px 0 rgba(0, 0, 0, 0.08);
29
+ @shadow-3: 0 6px 10px 0 rgba(0, 0, 0, 0.08);
30
+
31
+ // Gutter
32
+ @gutter: 12px;
33
+
34
+ // Body
35
+ @body-bg: @white;
36
+ @body-color: var(--color-text-1);
37
+
38
+ // Links
39
+ @link-color: var(--blue);
40
+ @link-decoration: none;
41
+ // @link-hover-color: darken(@link-color, 15%);
42
+ @link-hover-decoration: underline;
43
+
44
+ // Typography
45
+ @font-family-sans-serif: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue',
46
+ Arial, 'Noto Sans', sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',
47
+ 'Noto Color Emoji';
48
+ @font-family-base: @font-family-sans-serif;
49
+
50
+ @font-size-root: 16px;
51
+ @font-size-base: 1rem;
52
+
53
+ @font-size-xxs: 1rem * (10px / @font-size-root);
54
+ @font-size-xs: 1rem * (12px / @font-size-root);
55
+ @font-size-sm: 1rem * (14px / @font-size-root);
56
+ @font-size-md: 1rem * (16px / @font-size-root);
57
+ @font-size-lg: 1rem * (18px / @font-size-root);
58
+
59
+ // @font-weight-lighter: lighter;
60
+ // @font-weight-light: 300;
61
+ @font-weight-normal: 400;
62
+ @font-weight-bold: 500;
63
+ // @font-weight-bolder: bolder;
64
+
65
+ @font-weight-base: @font-weight-normal;
66
+
67
+ @line-height-base: 1.5;
68
+ @line-height-lg: 1.75;
69
+ @line-height-sm: 1.25;
70
+
71
+ // Border
72
+ @border-width: 1px;
73
+ // @border-color: @gray-4;
74
+ // @border-radius-sm: 0.25rem; // 4px
75
+ // @border-radius-md: 0.75rem; // 12px
76
+ // @border-radius-lg: 1.25rem; // 20px
77
+
78
+ // Button
79
+ @btn-padding: 5px 12px;
80
+ @btn-border-radius: 999px;
81
+ @btn-bg: var(--color-fill-1);
82
+ @btn-font-family: inherit;
83
+ @btn-font-size: @font-size-sm;
84
+ @btn-font-weight: @font-weight-normal;
85
+ @btn-line-height: @line-height-base;
86
+
87
+ @btn-hover-bg: rgba(0, 0, 0, 0.04);
88
+ @btn-active-bg: rgba(0, 0, 0, 0.08);
89
+
90
+ @btn-padding-sm: 4px 12px;
91
+ // @btn-border-radius-sm: 15px;
92
+ @btn-font-size-sm: @font-size-sm;
93
+
94
+ @btn-padding-lg: 7px 12px;
95
+ // @btn-border-radius-lg: 50px;
96
+ @btn-font-size-lg: @font-size-md;
97
+
98
+ @btn-block-spacing-y: 9px;
99
+
100
+ @btn-border-width: @border-width;
101
+
102
+ @btn-transition: 0.15s ease-in-out;
103
+
104
+ // Composer
105
+ @composer-padding: 9px var(--gutter);
106
+
107
+ @composer-input-max-height: 132px;
108
+ @composer-input-min-height: 36Px;
109
+ @composer-input-padding: 8px 12px;
110
+ @composer-input-bg: var(--color-fill-1);
111
+ @composer-input-caret-color: var(--brand-2);
112
+ @composer-input-transition: border-color 0.15s ease-in-out;
113
+
114
+ // Input
115
+ @input-width: 100%;
116
+ @input-min-height: 24px;
117
+ @input-margin: 0;
118
+ @input-padding: 5px @gutter;
119
+ @input-border: 1px solid var(--color-line-1);
120
+ @input-border-radius: 12px;
121
+ @input-bg: var(--color-fill-1);
122
+ @input-font-family: inherit;
123
+ @input-font-size: @font-size-sm;
124
+ @input-line-height: 1.5;
125
+ @input-color: var(--color-text-1);
126
+ @input-resize: none;
127
+
128
+ // List
129
+ @list-bg: var(--color-fill-1);
130
+ @list-border-width: @border-width;
131
+ @list-border-color: var(--color-line-1);
132
+ @list-border-radius: 2px;
133
+
134
+ @list-item-padding: 10px var(--gutter);
135
+ @list-item-color: var(--color-text-1);
136
+ @list-item-font-size: 15px;
137
+ @list-item-line-height: 1.6;
138
+ @list-item-icon-color: var(--color-text-3);
139
+
140
+ @list-item-hover-bg: @btn-hover-bg;
141
+
142
+ @list-item-active-bg: var(--color-fill-2);
143
+
144
+ // Navbar
145
+ @navbar-height: 44Px;
146
+ @navbar-padding: 0 var(--gutter);
147
+
148
+ @navbar-color: var(--color-text-1);
149
+ @navbar-font-size: 17Px;
150
+ @navbar-logo-height: @navbar-height - 6Px;
151
+
152
+ // Notice
153
+ @notice-padding: @gutter;
154
+ @notice-border-radius: 12px;
155
+ @notice-bg: var(--color-fill-1);
156
+ @notice-icon-color: var(--brand-1);
157
+
158
+ @notice-content-color: var(--color-text-1);
159
+ @notice-content-font-size: 13px;
160
+
161
+ // Popover
162
+ @popover-border-radius: 6px;
163
+ @popover-bg: var(--color-fill-1);
164
+ @popover-box-shadow: @modal-box-shadow;
165
+
166
+ // RateActions
167
+ @rate-btn-bg: var(--color-fill-1);
168
+
169
+ // Card
170
+ @card-padding: 12px;
171
+ @card-title-padding: @card-padding @card-padding 6px;
172
+ @card-title-font-size: @font-size-md;
173
+ @card-title-font-weight: @font-weight-bold;
174
+ @card-subtitle-font-size: @font-size-xxs;
175
+ @card-subtitle-color: var(--color-text-3);
176
+ @card-border-width: @border-width;
177
+ @card-border-radius: 12px;
178
+ // @card-border-color: ;
179
+ @card-bg: var(--color-fill-1);
180
+
181
+ @card-text-color: var(--color-text-1);
182
+
183
+ @card-size-xl: 300Px;
184
+ @card-size-lg: 160px;
185
+ @card-size-md: 120px;
186
+ @card-size-sm: 104px;
187
+ @card-size-xs: 80px;
188
+
189
+ // 卡片自适应宽度 = 100%宽度 - 赞踩宽度 - 赞踩左右边距
190
+ @card-fluid-width: calc(100% - var(--rate-width) - 16Px);
191
+ @card-max-width: 432Px;
192
+ @card-min-width: 256Px;
193
+
194
+ @card-btn-padding: 10px;
195
+ @card-btn-line-height: 1.5;
196
+ @card-btn-spacing-x: @gutter;
197
+ @card-btn-spacing-y: 0;
198
+ @card-btn-border-color: var(--color-line-1);
199
+
200
+ @card-column-btn-bg: var(--color-fill-1);
201
+ @card-column-btn-color: var(--color-text-2);
202
+
203
+ @card-column-btn-primary-color: var(--brand-1);
204
+
205
+ @card-column-btn-hover-bg: var(--color-fill-2);
206
+ @card-column-btn-active-bg: var(--color-fill-2);
207
+
208
+ // Carousel
209
+ @carousel-dots-bottom: 8px;
210
+
211
+ @carousel-dot-width: 8px;
212
+ @carousel-dot-height: @carousel-dot-width;
213
+ @carousel-dot-margin: 0 4px;
214
+ @carousel-dot-padding: 0;
215
+ @carousel-dot-border: 0;
216
+ @carousel-dot-border-radius: 50%;
217
+ @carousel-dot-transition: 0.3s;
218
+
219
+ // Icon
220
+ @icon-size-lg: 30px;
221
+
222
+ // IconButton
223
+ @icon-button-border: 0;
224
+ @icon-button-border-radius: 3px;
225
+ @icon-button-bg: transparent;
226
+ @icon-button-color: var(--color-text-2);
227
+ @icon-button-size: 18px;
228
+
229
+ @icon-button-primary-color: var(--brand-2);
230
+
231
+ @icon-button-lg-border-radius: 6px;
232
+ @icon-button-lg-size: 24px;
233
+
234
+ // Modals
235
+ @modal-width: 320px;
236
+ @modal-border-radius: 12px;
237
+
238
+ @modal-bg: var(--color-fill-1);
239
+ @modal-box-shadow: var(--shadow-3);
240
+
241
+ @modal-header-padding: @gutter;
242
+
243
+ @modal-title-margin: 0;
244
+ @modal-title-color: var(--color-text-1);
245
+ @modal-title-font-size: @font-size-lg;
246
+ @modal-title-font-weight: @font-weight-bold;
247
+
248
+ @modal-close-padding: 0;
249
+ @modal-close-color: var(--color-text-1);
250
+
251
+ @modal-footer-x-padding: @gutter;
252
+ @modal-btn-x-spacing: @gutter;
253
+
254
+ @modal-btn-y-padding: 12px;
255
+ @modal-btn-y-border-width: 1px;
256
+ @modal-btn-y-bg: var(--color-fill-1);
257
+ @modal-btn-y-color: var(--color-text-2);
258
+ @modal-btn-y-primary-color: var(--brand-1);
259
+
260
+ @modal-fade-transform: translate(0, -50px);
261
+ @modal-show-transform: none;
262
+ @modal-opacity: 0;
263
+ @modal-show-opacity: 1;
264
+ @modal-transition: transform 0.3s ease-out, opacity 0.15s linear;
265
+
266
+ // Popup
267
+ @popup-bg: var(--color-fill-1);
268
+
269
+ @popup-max-height: 70vh;
270
+ @popup-wide-width: 480px;
271
+
272
+ @popup-header-padding: 18px 40px 12px;
273
+
274
+ @popup-title-margin: @modal-title-margin;
275
+ @popup-title-color: @modal-title-color;
276
+ @popup-title-font-size: @modal-title-font-size;
277
+
278
+ @popup-subtitle-margin: 0;
279
+ @popup-subtitle-color: var(--color-text-3);
280
+ @popup-subtitle-font-size: @font-size-xs;
281
+
282
+ @popup-close-color: @modal-close-color;
283
+
284
+ @popup-footer-padding: 9px @gutter;
285
+ @popup-btn-x-spacing: @gutter;
286
+ @popup-btn-y-spacing: 9px;
287
+
288
+ // SendConfirm
289
+ @send-confirm-dialog-width: 480px;
290
+ @send-confirm-dialog-margin: 20px;
291
+ @send-confirm-inner-height: 320px;
292
+
293
+ // Progress bars
294
+ @progress-height: 2px;
295
+ @progress-bg: var(--color-line-1);
296
+ @progress-border-radius: 100px;
297
+ @progress-bar-bg: var(--blue);
298
+ @progress-bar-transition: width 0.6s ease;
299
+
300
+ @progress-bar-bg-success: var(--green);
301
+ @progress-bar-bg-error: var(--red);
302
+
303
+ // QuickReplies
304
+ @quick-replies-padding: 9Px var(--gutter);
305
+
306
+ @quick-reply-color: var(--color-text-1);
307
+ @quick-reply-font-size: 14Px;
308
+
309
+ @quick-reply-dot-top: 0;
310
+ @quick-reply-dot-right: 0;
311
+ @quick-reply-dot-size: 8px;
312
+ @quick-reply-dot-bg: var(--red);
313
+
314
+ // ScrollView
315
+ @scroll-view-spacing-x: 6px;
316
+
317
+ // Tag
318
+ @tag-margin: 0 4px 0 0;
319
+ @tag-padding: 0 6px;
320
+ @tag-border-radius: 4px;
321
+ @tag-color: var(--brand-1);
322
+ @tag-font-size: 12px;
323
+
324
+ // Price
325
+ @price-font-size: @font-size-sm;
326
+
327
+ // Goods
328
+ @goods-img-width: 72px;
329
+ @goods-img-height: @goods-img-width;
330
+ @goods-img-border-radius: 12px;
331
+
332
+ @goods-padding: @gutter;
333
+ @goods-gap: 9Px;
334
+ @goods-desc-color: var(--color-text-3);
335
+ @goods-meta-color: var(--color-text-3);
336
+ @goods-meta-font-size: @font-size-xxs;
337
+ @goods-border-width: 1px;
338
+ @goods-border-color: var(--color-line-1);
339
+ @goods-count-color: var(--color-text-3);
340
+ @goods-count-font-size: @font-size-sm;
341
+ @goods-unit-font-size: @font-size-xs;
342
+ @goods-buy-btn-bg: var(--brand-1);
343
+ @goods-buy-btn-color: #fff;
344
+ @goods-buy-btn-padding: 2px;
345
+
346
+ // Toast
347
+ @toast-content-padding: 18px 24px;
348
+ @toast-content-border-radius: 12px;
349
+ @toast-content-bg: rgba(0, 0, 0, 0.7);
350
+
351
+ @toast-message-margin: 0;
352
+ @toast-message-color: var(--color-fill-1);
353
+ @toast-message-font-size: 16px;
354
+
355
+ // Z-index
356
+ @zindex-backdrop: 100;
357
+ @zindex-modal: 100;
358
+ @zindex-popup: @zindex-modal;
359
+ @zindex-popover: 1030;
360
+ @zindex-toast: 200;
361
+ @zindex-tooltip: 200;
362
+ @zindex-recorder-toast: 100;
363
+
364
+ @zindex-navbar: 10;
365
+ @zindex-footer: 10;
366
+ @zindex-quick-replies: 110;
367
+ @zindex-rate-actions: 10;
368
+
369
+ @zindex-step-dot: 2;
@@ -0,0 +1,32 @@
1
+ var testCache = {
2
+ passiveListener: function passiveListener() {
3
+ var supportsPassive = false;
4
+ try {
5
+ var opts = Object.defineProperty({}, 'passive', {
6
+ // eslint-disable-next-line
7
+ get: function get() {
8
+ supportsPassive = true;
9
+ }
10
+ });
11
+ // @ts-ignore
12
+ window.addEventListener('test', null, opts);
13
+ } catch (e) {
14
+ // No support
15
+ }
16
+ return supportsPassive;
17
+ },
18
+ smoothScroll: function smoothScroll() {
19
+ return 'scrollBehavior' in document.documentElement.style;
20
+ },
21
+ touch: function touch() {
22
+ return 'ontouchstart' in window;
23
+ }
24
+ };
25
+ export function addTest(name, test) {
26
+ // @ts-ignore
27
+ testCache[name] = test();
28
+ }
29
+ export default function canUse(name) {
30
+ // @ts-ignore
31
+ return testCache[name]();
32
+ }
@@ -0,0 +1,6 @@
1
+ export default function countLines(el) {
2
+ var styles = window.getComputedStyle(el, null);
3
+ var lh = parseInt(styles.lineHeight, 10);
4
+ var h = parseInt(styles.height, 10);
5
+ return Math.round(h / lh);
6
+ }
@@ -0,0 +1,28 @@
1
+ export var oneDayInMs = 24 * 60 * 60 * 1000;
2
+ export var padZero = function padZero(t) {
3
+ return "".concat(t < 10 ? '0' : '').concat(t);
4
+ };
5
+ export function parseDateTime(timestamp) {
6
+ var date = new Date(timestamp);
7
+ return {
8
+ year: date.getFullYear(),
9
+ month: padZero(date.getMonth() + 1),
10
+ day: padZero(date.getDate()),
11
+ hours: padZero(date.getHours()),
12
+ minutes: padZero(date.getMinutes()),
13
+ seconds: padZero(date.getSeconds())
14
+ };
15
+ }
16
+
17
+ /**
18
+ * 判断是否在24小时内
19
+ */
20
+ export function isWithin24Hours(timestamp) {
21
+ var now = Date.now();
22
+ var timeDiff = Math.abs(timestamp - now);
23
+ return timeDiff < oneDayInMs;
24
+ }
25
+ export function formatExpireTime(timestamp) {
26
+ var d = parseDateTime(timestamp);
27
+ return "".concat(d.year, ".").concat(d.month, ".").concat(d.day, " ").concat(d.hours, ":").concat(d.minutes, " \u5230\u671F");
28
+ }
@@ -0,0 +1,16 @@
1
+ export function formatTime(duration) {
2
+ if (!duration) return '';
3
+ var hours = Math.floor(duration / 3600);
4
+ var minutes = Math.floor((duration - hours * 3600) / 60);
5
+ var seconds = Math.floor(duration - hours * 3600 - minutes * 60);
6
+ var ret = '';
7
+ if (hours > 0) {
8
+ ret += "".concat(hours, ":");
9
+ }
10
+ ret += "".concat(minutes, ":");
11
+ if (seconds < 10) {
12
+ ret += '0';
13
+ }
14
+ ret += seconds;
15
+ return ret;
16
+ }
@@ -0,0 +1,4 @@
1
+ // eslint-disable-next-line no-bitwise
2
+ export default (function (str) {
3
+ return str.slice((str.lastIndexOf('.') - 1 >>> 0) + 2);
4
+ });
@@ -0,0 +1,25 @@
1
+ export default (function (callback, maxCount) {
2
+ var fps = 0;
3
+ var last = Date.now();
4
+ var count = 0; // 回调触发次数
5
+
6
+ // 兼容性处理
7
+ if (!requestAnimationFrame) {
8
+ callback(0);
9
+ return;
10
+ }
11
+ var _loop = function loop() {
12
+ var offset = Date.now() - last;
13
+ fps += 1;
14
+ if (offset >= 1000) {
15
+ last += offset;
16
+ callback(fps);
17
+ if (maxCount) count += 1;
18
+ fps = 0;
19
+ }
20
+ if (!maxCount || count <= maxCount) {
21
+ requestAnimationFrame(_loop);
22
+ }
23
+ };
24
+ _loop();
25
+ });
@@ -0,0 +1,3 @@
1
+ export default function getRandomInt(min, max) {
2
+ return Math.floor(Math.random() * (max - min + 1)) + min;
3
+ }
@@ -0,0 +1,3 @@
1
+ export default function getToBottom(el) {
2
+ return el.scrollHeight - el.scrollTop - el.offsetHeight;
3
+ }