@bifrostui/react 1.4.8-beta.0 → 2.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/dist/ActionSheet/ActionSheet.css +2 -2
  2. package/dist/ActionSheet/ActionSheetItem.js +3 -8
  3. package/dist/Avatar/Avatar.js +3 -8
  4. package/dist/Avatar/AvatarGroup.js +2 -6
  5. package/dist/Badge/Badge.js +3 -8
  6. package/dist/Button/Button.css +77 -78
  7. package/dist/Button/Button.d.ts +1 -1
  8. package/dist/Button/Button.js +4 -10
  9. package/dist/Button/Button.types.d.ts +8 -7
  10. package/dist/Calendar/Calendar.js +7 -19
  11. package/dist/Calendar/Calendar.types.d.ts +0 -5
  12. package/dist/Card/Card.css +1 -1
  13. package/dist/Card/CardContent.css +1 -2
  14. package/dist/Card/CardFooter.css +2 -4
  15. package/dist/Card/CardHeader.css +4 -5
  16. package/dist/Checkbox/Checkbox.js +2 -6
  17. package/dist/Checkbox/CheckboxGroup.js +4 -7
  18. package/dist/Collapse/Collapse.css +1 -0
  19. package/dist/Collapse/Collapse.d.ts +1 -1
  20. package/dist/Collapse/Collapse.js +8 -11
  21. package/dist/CollapsePanel/CollapsePanel.css +2 -4
  22. package/dist/CollapsePanel/CollapsePanelItem.js +45 -46
  23. package/dist/Countdown/Countdown.js +5 -12
  24. package/dist/Dialog/FunctionalDialog.js +1 -1
  25. package/dist/Divider/Divider.js +8 -5
  26. package/dist/Drawer/Drawer.js +4 -10
  27. package/dist/Fade/Fade.js +52 -56
  28. package/dist/IconButton/IconButton.js +5 -12
  29. package/dist/Image/Image.js +112 -119
  30. package/dist/Input/Input.js +4 -10
  31. package/dist/List/List.js +3 -8
  32. package/dist/List/ListItem.js +42 -44
  33. package/dist/List/ListItemContent.js +1 -4
  34. package/dist/List/ListItemExtra.js +9 -4
  35. package/dist/List/ListItemFooter.js +9 -4
  36. package/dist/List/ListItemHeader.js +9 -4
  37. package/dist/Loading/Loading.js +13 -4
  38. package/dist/Modal/Modal.js +0 -6
  39. package/dist/Modal/Modal.miniapp.js +4 -10
  40. package/dist/NavBar/NavBar.js +0 -1
  41. package/dist/Picker/Picker.css +0 -5
  42. package/dist/Picker/Picker.js +5 -27
  43. package/dist/Picker/Picker.types.d.ts +2 -15
  44. package/dist/Picker/PickerPanel.css +0 -4
  45. package/dist/Picker/PickerPanel.js +6 -7
  46. package/dist/Popover/Popover.css +5 -5
  47. package/dist/Popover/Popover.js +27 -70
  48. package/dist/Portal/Portal.miniapp.js +4 -7
  49. package/dist/Radio/Radio.css +0 -1
  50. package/dist/Radio/Radio.js +2 -6
  51. package/dist/Radio/RadioGroup.js +0 -3
  52. package/dist/Rating/Rating.js +8 -18
  53. package/dist/ScrollView/ScrollView.js +11 -24
  54. package/dist/ScrollView/ScrollView.types.d.ts +1 -0
  55. package/dist/Select/Select.css +4 -1
  56. package/dist/Select/Select.js +41 -68
  57. package/dist/Skeleton/Skeleton.js +5 -9
  58. package/dist/Slide/Slide.js +69 -74
  59. package/dist/Slider/Slider.js +11 -27
  60. package/dist/Steps/Step.js +81 -82
  61. package/dist/Steps/Steps.d.ts +1 -1
  62. package/dist/Steps/Steps.js +57 -60
  63. package/dist/Switch/Switch.js +75 -78
  64. package/dist/TabBar/TabBar.js +3 -8
  65. package/dist/Tabs/Tab.css +10 -16
  66. package/dist/Tabs/Tab.js +2 -3
  67. package/dist/Tabs/Tabs.css +13 -22
  68. package/dist/Tabs/Tabs.js +39 -70
  69. package/dist/Tabs/Tabs.types.d.ts +0 -10
  70. package/dist/Tabs/utils/bound.d.ts +1 -0
  71. package/dist/{DesktopPicker/utils/calcAfterMounted.js → Tabs/utils/bound.js} +14 -7
  72. package/dist/Tag/Tag.css +1 -1
  73. package/dist/Tag/Tag.js +2 -6
  74. package/dist/TextArea/TextArea.js +5 -12
  75. package/dist/Toast/FunctionalToast.js +1 -1
  76. package/dist/Toast/Toast.css +1 -0
  77. package/dist/Tooltip/Tooltip.css +5 -5
  78. package/dist/Tooltip/Tooltip.js +27 -70
  79. package/dist/Transition/TransitionCore.js +3 -8
  80. package/dist/index.d.ts +0 -6
  81. package/dist/index.js +1 -13
  82. package/dist/locales/base.d.ts +0 -11
  83. package/dist/locales/en-US.js +0 -24
  84. package/dist/locales/zh-CN.js +0 -24
  85. package/dist/locales/zh-TW.js +0 -24
  86. package/es/ActionSheet/ActionSheet.css +2 -2
  87. package/es/ActionSheet/ActionSheetItem.js +3 -8
  88. package/es/Avatar/Avatar.js +3 -8
  89. package/es/Avatar/AvatarGroup.js +2 -6
  90. package/es/Badge/Badge.js +3 -8
  91. package/es/Button/Button.css +77 -78
  92. package/es/Button/Button.d.ts +1 -1
  93. package/es/Button/Button.js +3 -9
  94. package/es/Button/Button.types.d.ts +8 -7
  95. package/es/Calendar/Calendar.js +7 -19
  96. package/es/Calendar/Calendar.types.d.ts +0 -5
  97. package/es/Card/Card.css +1 -1
  98. package/es/Card/CardContent.css +1 -2
  99. package/es/Card/CardFooter.css +2 -4
  100. package/es/Card/CardHeader.css +4 -5
  101. package/es/Checkbox/Checkbox.js +2 -6
  102. package/es/Checkbox/CheckboxGroup.js +4 -7
  103. package/es/Collapse/Collapse.css +1 -0
  104. package/es/Collapse/Collapse.d.ts +1 -1
  105. package/es/Collapse/Collapse.js +8 -11
  106. package/es/CollapsePanel/CollapsePanel.css +2 -4
  107. package/es/CollapsePanel/CollapsePanelItem.js +45 -46
  108. package/es/Countdown/Countdown.js +5 -12
  109. package/es/Dialog/FunctionalDialog.js +2 -2
  110. package/es/Divider/Divider.js +8 -5
  111. package/es/Drawer/Drawer.js +4 -10
  112. package/es/Fade/Fade.js +52 -56
  113. package/es/IconButton/IconButton.js +5 -12
  114. package/es/Image/Image.js +112 -119
  115. package/es/Input/Input.js +4 -10
  116. package/es/List/List.js +3 -8
  117. package/es/List/ListItem.js +42 -44
  118. package/es/List/ListItemContent.js +1 -4
  119. package/es/List/ListItemExtra.js +9 -4
  120. package/es/List/ListItemFooter.js +9 -4
  121. package/es/List/ListItemHeader.js +9 -4
  122. package/es/Loading/Loading.js +13 -4
  123. package/es/Modal/Modal.js +0 -6
  124. package/es/Modal/Modal.miniapp.d.ts +1 -1
  125. package/es/Modal/Modal.miniapp.js +4 -10
  126. package/es/NavBar/NavBar.js +0 -1
  127. package/es/Picker/Picker.css +0 -5
  128. package/es/Picker/Picker.js +5 -27
  129. package/es/Picker/Picker.types.d.ts +2 -15
  130. package/es/Picker/PickerPanel.css +0 -4
  131. package/es/Picker/PickerPanel.js +6 -7
  132. package/es/Popover/Popover.css +5 -5
  133. package/es/Popover/Popover.js +29 -73
  134. package/es/Portal/Portal.miniapp.js +5 -8
  135. package/es/Radio/Radio.css +0 -1
  136. package/es/Radio/Radio.js +2 -6
  137. package/es/Radio/RadioGroup.js +0 -3
  138. package/es/Rating/Rating.js +8 -18
  139. package/es/ScrollView/ScrollView.js +11 -24
  140. package/es/ScrollView/ScrollView.types.d.ts +1 -0
  141. package/es/Select/Select.css +4 -1
  142. package/es/Select/Select.js +42 -68
  143. package/es/Skeleton/Skeleton.js +5 -9
  144. package/es/Slide/Slide.js +69 -74
  145. package/es/Slider/Slider.js +12 -30
  146. package/es/Steps/Step.js +81 -82
  147. package/es/Steps/Steps.d.ts +1 -1
  148. package/es/Steps/Steps.js +57 -60
  149. package/es/Switch/Switch.js +75 -78
  150. package/es/TabBar/TabBar.js +3 -8
  151. package/es/Tabs/Tab.css +10 -16
  152. package/es/Tabs/Tab.js +2 -3
  153. package/es/Tabs/Tabs.css +13 -22
  154. package/es/Tabs/Tabs.js +41 -83
  155. package/es/Tabs/Tabs.types.d.ts +0 -10
  156. package/es/Tabs/utils/bound.d.ts +1 -0
  157. package/es/Tabs/utils/bound.js +13 -0
  158. package/es/Tag/Tag.css +1 -1
  159. package/es/Tag/Tag.js +2 -6
  160. package/es/TextArea/TextArea.js +5 -12
  161. package/es/Toast/FunctionalToast.js +2 -2
  162. package/es/Toast/Toast.css +1 -0
  163. package/es/Tooltip/Tooltip.css +5 -5
  164. package/es/Tooltip/Tooltip.js +29 -73
  165. package/es/Transition/TransitionCore.js +3 -8
  166. package/es/index.d.ts +0 -6
  167. package/es/index.js +0 -6
  168. package/es/locales/base.d.ts +0 -11
  169. package/es/locales/en-US.js +0 -24
  170. package/es/locales/zh-CN.js +0 -24
  171. package/es/locales/zh-TW.js +0 -24
  172. package/package.json +6 -6
  173. package/dist/Collapse/Collapse.miniapp.d.ts +0 -5
  174. package/dist/Collapse/Collapse.miniapp.js +0 -177
  175. package/dist/DatePicker/DatePicker.d.ts +0 -4
  176. package/dist/DatePicker/DatePicker.js +0 -335
  177. package/dist/DatePicker/DatePicker.types.d.ts +0 -36
  178. package/dist/DatePicker/DatePicker.types.js +0 -15
  179. package/dist/DatePicker/constants.d.ts +0 -9
  180. package/dist/DatePicker/constants.js +0 -37
  181. package/dist/DatePicker/index.d.ts +0 -3
  182. package/dist/DatePicker/index.js +0 -44
  183. package/dist/DesktopDatePicker/DesktopDatePicker.d.ts +0 -5
  184. package/dist/DesktopDatePicker/DesktopDatePicker.js +0 -280
  185. package/dist/DesktopDatePicker/DesktopDatePicker.types.d.ts +0 -163
  186. package/dist/DesktopDatePicker/DesktopDatePicker.types.js +0 -15
  187. package/dist/DesktopDatePicker/deskTopPickerContainer.css +0 -100
  188. package/dist/DesktopDatePicker/index.css +0 -61
  189. package/dist/DesktopDatePicker/index.d.ts +0 -2
  190. package/dist/DesktopDatePicker/index.js +0 -41
  191. package/dist/DesktopDatePicker/useGetDatePickerContent.d.ts +0 -6
  192. package/dist/DesktopDatePicker/useGetDatePickerContent.js +0 -343
  193. package/dist/DesktopDateTimePicker/DesktopDateTimePicker.d.ts +0 -5
  194. package/dist/DesktopDateTimePicker/DesktopDateTimePicker.js +0 -322
  195. package/dist/DesktopDateTimePicker/DesktopDateTimePicker.types.d.ts +0 -163
  196. package/dist/DesktopDateTimePicker/DesktopDateTimePicker.types.js +0 -15
  197. package/dist/DesktopDateTimePicker/index.css +0 -66
  198. package/dist/DesktopDateTimePicker/index.d.ts +0 -2
  199. package/dist/DesktopDateTimePicker/index.js +0 -41
  200. package/dist/DesktopPicker/DesktopPicker.d.ts +0 -5
  201. package/dist/DesktopPicker/DesktopPicker.js +0 -238
  202. package/dist/DesktopPicker/DesktopPicker.types.d.ts +0 -57
  203. package/dist/DesktopPicker/DesktopPicker.types.js +0 -15
  204. package/dist/DesktopPicker/index.css +0 -37
  205. package/dist/DesktopPicker/index.d.ts +0 -2
  206. package/dist/DesktopPicker/index.js +0 -41
  207. package/dist/DesktopPicker/utils/calcAfterMounted.d.ts +0 -2
  208. package/dist/DesktopPicker/utils/calcAfterMounted.miniapp.d.ts +0 -2
  209. package/dist/DesktopPicker/utils/calcAfterMounted.miniapp.js +0 -38
  210. package/dist/DesktopTimePicker/DesktopTimePicker.d.ts +0 -5
  211. package/dist/DesktopTimePicker/DesktopTimePicker.js +0 -288
  212. package/dist/DesktopTimePicker/DesktopTimePicker.types.d.ts +0 -182
  213. package/dist/DesktopTimePicker/DesktopTimePicker.types.js +0 -15
  214. package/dist/DesktopTimePicker/DesktopTimePickerList.d.ts +0 -4
  215. package/dist/DesktopTimePicker/DesktopTimePickerList.js +0 -111
  216. package/dist/DesktopTimePicker/index.css +0 -170
  217. package/dist/DesktopTimePicker/index.d.ts +0 -2
  218. package/dist/DesktopTimePicker/index.js +0 -41
  219. package/dist/DesktopTimePicker/useGetTimePickerContent.d.ts +0 -6
  220. package/dist/DesktopTimePicker/useGetTimePickerContent.js +0 -249
  221. package/dist/DesktopTimePicker/utils/scrollUtil.d.ts +0 -2
  222. package/dist/DesktopTimePicker/utils/scrollUtil.js +0 -27
  223. package/dist/DesktopTimePicker/utils/scrollUtil.miniapp.d.ts +0 -2
  224. package/dist/DesktopTimePicker/utils/scrollUtil.miniapp.js +0 -51
  225. package/dist/DesktopTimePicker/utils/utils.d.ts +0 -28
  226. package/dist/DesktopTimePicker/utils/utils.js +0 -408
  227. package/dist/SwipeAction/SwipeAction.css +0 -79
  228. package/dist/SwipeAction/SwipeAction.d.ts +0 -5
  229. package/dist/SwipeAction/SwipeAction.js +0 -349
  230. package/dist/SwipeAction/SwipeAction.types.d.ts +0 -75
  231. package/dist/SwipeAction/SwipeAction.types.js +0 -15
  232. package/dist/SwipeAction/SwipeActionContext.d.ts +0 -4
  233. package/dist/SwipeAction/SwipeActionContext.js +0 -30
  234. package/dist/SwipeAction/SwipeActionItem.css +0 -31
  235. package/dist/SwipeAction/SwipeActionItem.d.ts +0 -5
  236. package/dist/SwipeAction/SwipeActionItem.js +0 -105
  237. package/dist/SwipeAction/constants.d.ts +0 -9
  238. package/dist/SwipeAction/constants.js +0 -39
  239. package/dist/SwipeAction/index.d.ts +0 -5
  240. package/dist/SwipeAction/index.js +0 -50
  241. package/dist/Tabs/utils/scroll.d.ts +0 -2
  242. package/dist/Tabs/utils/scroll.js +0 -55
  243. package/es/Collapse/Collapse.miniapp.d.ts +0 -5
  244. package/es/Collapse/Collapse.miniapp.js +0 -157
  245. package/es/DatePicker/DatePicker.d.ts +0 -4
  246. package/es/DatePicker/DatePicker.js +0 -308
  247. package/es/DatePicker/DatePicker.types.d.ts +0 -36
  248. package/es/DatePicker/DatePicker.types.js +0 -1
  249. package/es/DatePicker/constants.d.ts +0 -9
  250. package/es/DatePicker/constants.js +0 -14
  251. package/es/DatePicker/index.d.ts +0 -3
  252. package/es/DatePicker/index.js +0 -8
  253. package/es/DesktopDatePicker/DesktopDatePicker.d.ts +0 -5
  254. package/es/DesktopDatePicker/DesktopDatePicker.js +0 -253
  255. package/es/DesktopDatePicker/DesktopDatePicker.types.d.ts +0 -163
  256. package/es/DesktopDatePicker/DesktopDatePicker.types.js +0 -1
  257. package/es/DesktopDatePicker/deskTopPickerContainer.css +0 -100
  258. package/es/DesktopDatePicker/index.css +0 -61
  259. package/es/DesktopDatePicker/index.d.ts +0 -2
  260. package/es/DesktopDatePicker/index.js +0 -6
  261. package/es/DesktopDatePicker/useGetDatePickerContent.d.ts +0 -6
  262. package/es/DesktopDatePicker/useGetDatePickerContent.js +0 -316
  263. package/es/DesktopDateTimePicker/DesktopDateTimePicker.d.ts +0 -5
  264. package/es/DesktopDateTimePicker/DesktopDateTimePicker.js +0 -295
  265. package/es/DesktopDateTimePicker/DesktopDateTimePicker.types.d.ts +0 -163
  266. package/es/DesktopDateTimePicker/DesktopDateTimePicker.types.js +0 -1
  267. package/es/DesktopDateTimePicker/index.css +0 -66
  268. package/es/DesktopDateTimePicker/index.d.ts +0 -2
  269. package/es/DesktopDateTimePicker/index.js +0 -9
  270. package/es/DesktopPicker/DesktopPicker.d.ts +0 -5
  271. package/es/DesktopPicker/DesktopPicker.js +0 -221
  272. package/es/DesktopPicker/DesktopPicker.types.d.ts +0 -57
  273. package/es/DesktopPicker/DesktopPicker.types.js +0 -1
  274. package/es/DesktopPicker/index.css +0 -37
  275. package/es/DesktopPicker/index.d.ts +0 -2
  276. package/es/DesktopPicker/index.js +0 -6
  277. package/es/DesktopPicker/utils/calcAfterMounted.d.ts +0 -2
  278. package/es/DesktopPicker/utils/calcAfterMounted.js +0 -6
  279. package/es/DesktopPicker/utils/calcAfterMounted.miniapp.d.ts +0 -2
  280. package/es/DesktopPicker/utils/calcAfterMounted.miniapp.js +0 -9
  281. package/es/DesktopTimePicker/DesktopTimePicker.d.ts +0 -5
  282. package/es/DesktopTimePicker/DesktopTimePicker.js +0 -261
  283. package/es/DesktopTimePicker/DesktopTimePicker.types.d.ts +0 -182
  284. package/es/DesktopTimePicker/DesktopTimePicker.types.js +0 -1
  285. package/es/DesktopTimePicker/DesktopTimePickerList.d.ts +0 -4
  286. package/es/DesktopTimePicker/DesktopTimePickerList.js +0 -84
  287. package/es/DesktopTimePicker/index.css +0 -170
  288. package/es/DesktopTimePicker/index.d.ts +0 -2
  289. package/es/DesktopTimePicker/index.js +0 -6
  290. package/es/DesktopTimePicker/useGetTimePickerContent.d.ts +0 -6
  291. package/es/DesktopTimePicker/useGetTimePickerContent.js +0 -226
  292. package/es/DesktopTimePicker/utils/scrollUtil.d.ts +0 -2
  293. package/es/DesktopTimePicker/utils/scrollUtil.js +0 -8
  294. package/es/DesktopTimePicker/utils/scrollUtil.miniapp.d.ts +0 -2
  295. package/es/DesktopTimePicker/utils/scrollUtil.miniapp.js +0 -22
  296. package/es/DesktopTimePicker/utils/utils.d.ts +0 -28
  297. package/es/DesktopTimePicker/utils/utils.js +0 -365
  298. package/es/SwipeAction/SwipeAction.css +0 -79
  299. package/es/SwipeAction/SwipeAction.d.ts +0 -5
  300. package/es/SwipeAction/SwipeAction.js +0 -334
  301. package/es/SwipeAction/SwipeAction.types.d.ts +0 -75
  302. package/es/SwipeAction/SwipeAction.types.js +0 -1
  303. package/es/SwipeAction/SwipeActionContext.d.ts +0 -4
  304. package/es/SwipeAction/SwipeActionContext.js +0 -11
  305. package/es/SwipeAction/SwipeActionItem.css +0 -31
  306. package/es/SwipeAction/SwipeActionItem.d.ts +0 -5
  307. package/es/SwipeAction/SwipeActionItem.js +0 -78
  308. package/es/SwipeAction/constants.d.ts +0 -9
  309. package/es/SwipeAction/constants.js +0 -15
  310. package/es/SwipeAction/index.d.ts +0 -5
  311. package/es/SwipeAction/index.js +0 -12
  312. package/es/Tabs/utils/scroll.d.ts +0 -2
  313. package/es/Tabs/utils/scroll.js +0 -36
@@ -1,253 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __objRest = (source, exclude) => {
21
- var target = {};
22
- for (var prop in source)
23
- if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
- target[prop] = source[prop];
25
- if (source != null && __getOwnPropSymbols)
26
- for (var prop of __getOwnPropSymbols(source)) {
27
- if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
- target[prop] = source[prop];
29
- }
30
- return target;
31
- };
32
- import { DateOutlinedIcon } from "@bifrostui/icons";
33
- import dayjs from "dayjs";
34
- import clsx from "clsx";
35
- import React, { useMemo, useState, useEffect } from "react";
36
- import { useValue } from "@bifrostui/utils";
37
- import DesktopPicker from "../DesktopPicker";
38
- import useGetDatePickerContent from "./useGetDatePickerContent";
39
- import "./index.css";
40
- const prefixCls = "bui-d-date-picker";
41
- const DesktopDatePicker = /* @__PURE__ */ React.forwardRef((props, ref) => {
42
- const _a = props, {
43
- className,
44
- inputRef,
45
- inputProps,
46
- value,
47
- defaultValue,
48
- disabled = false,
49
- disableOpenPicker = false,
50
- placeholder,
51
- format = "YYYY/MM/DD",
52
- open,
53
- disabledDate,
54
- picker = "day",
55
- minDate = dayjs(dayjs().format("YYYYMMDD")).subtract(10, "year").toDate(),
56
- maxDate = dayjs(dayjs().format("YYYYMMDD")).add(10, "year").toDate(),
57
- icon,
58
- headerBarLeftIcon,
59
- headerBarRightIcon,
60
- closeOnSelect = true,
61
- onChange,
62
- onClose,
63
- onOpen,
64
- monthRender,
65
- yearRender,
66
- onMonthChange,
67
- onYearChange,
68
- DesktopPickerProps,
69
- CalendarProps
70
- } = _a, others = __objRest(_a, [
71
- "className",
72
- "inputRef",
73
- "inputProps",
74
- "value",
75
- "defaultValue",
76
- "disabled",
77
- "disableOpenPicker",
78
- "placeholder",
79
- "format",
80
- "open",
81
- "disabledDate",
82
- "picker",
83
- "minDate",
84
- "maxDate",
85
- "icon",
86
- "headerBarLeftIcon",
87
- "headerBarRightIcon",
88
- "closeOnSelect",
89
- "onChange",
90
- "onClose",
91
- "onOpen",
92
- "monthRender",
93
- "yearRender",
94
- "onMonthChange",
95
- "onYearChange",
96
- "DesktopPickerProps",
97
- "CalendarProps"
98
- ]);
99
- const [isOpen, setIsOpen] = useState(false);
100
- const [selectType, setSelectType] = useState(
101
- picker
102
- );
103
- const [inputStr, setInputStr] = useState("");
104
- const [useUserStr, setUseUserStr] = useState(false);
105
- const [calendarValue, triggerChange] = useValue({
106
- value,
107
- defaultValue,
108
- onChange
109
- });
110
- const handleDatePickerIconClick = (e) => {
111
- if (disabled || disableOpenPicker || open !== void 0)
112
- return;
113
- setIsOpen(!isOpen);
114
- };
115
- const handleDatePickerInputClick = (e) => {
116
- e.stopPropagation();
117
- if (inputProps == null ? void 0 : inputProps.readOnly) {
118
- if (disabled || disableOpenPicker || open !== void 0)
119
- return;
120
- setIsOpen(!isOpen);
121
- return;
122
- }
123
- setIsOpen(false);
124
- };
125
- const { desktopDatePicker } = useGetDatePickerContent({
126
- format,
127
- minDate,
128
- maxDate,
129
- setIsOpen,
130
- triggerChange,
131
- disabledDate,
132
- calendarValue,
133
- setSelectType,
134
- picker,
135
- selectType,
136
- headerBarLeftIcon,
137
- headerBarRightIcon,
138
- CalendarProps,
139
- onClose,
140
- monthRender,
141
- yearRender,
142
- onMonthChange,
143
- onYearChange,
144
- closeOnSelect
145
- });
146
- const onInputChange = (e) => {
147
- e.stopPropagation();
148
- const newValue = e.target.value;
149
- if (newValue.length === 0) {
150
- setInputStr("");
151
- setUseUserStr(true);
152
- triggerChange(e, null);
153
- return;
154
- }
155
- if (dayjs(newValue, format, true).isValid()) {
156
- setInputStr("");
157
- setUseUserStr(false);
158
- if (disabledDate == null ? void 0 : disabledDate(dayjs(newValue).toDate())) {
159
- return;
160
- }
161
- if (dayjs(newValue).isAfter(maxDate)) {
162
- triggerChange(e, maxDate);
163
- return;
164
- }
165
- if (dayjs(newValue).isBefore(minDate)) {
166
- triggerChange(e, minDate);
167
- return;
168
- }
169
- triggerChange(e, dayjs(e.target.value).toDate());
170
- } else {
171
- setUseUserStr(true);
172
- setInputStr(e.target.value);
173
- }
174
- };
175
- const onMount = () => {
176
- onOpen == null ? void 0 : onOpen();
177
- };
178
- const unMounted = () => {
179
- onClose == null ? void 0 : onClose();
180
- setSelectType(picker);
181
- };
182
- const showPlaceholder = useMemo(() => {
183
- if (placeholder) {
184
- return placeholder;
185
- }
186
- return format;
187
- }, [placeholder, format]);
188
- const renderValue = useMemo(() => {
189
- if (useUserStr) {
190
- return inputStr;
191
- }
192
- if (calendarValue) {
193
- return dayjs(calendarValue).format(format);
194
- }
195
- return "";
196
- }, [calendarValue, inputStr, useUserStr, format]);
197
- useEffect(() => {
198
- setUseUserStr(false);
199
- }, [calendarValue]);
200
- return /* @__PURE__ */ React.createElement(
201
- "div",
202
- __spreadProps(__spreadValues({}, others), {
203
- className: clsx(prefixCls, className, {
204
- [`${prefixCls}-disabled`]: disabled,
205
- [`${prefixCls}-active`]: isOpen
206
- }),
207
- ref
208
- }),
209
- /* @__PURE__ */ React.createElement(
210
- DesktopPicker,
211
- __spreadValues({
212
- open: open != null ? open : isOpen,
213
- miniBackdropInvisible: open !== void 0,
214
- onClose: (e, data) => {
215
- setIsOpen(data == null ? void 0 : data.value);
216
- },
217
- onMount,
218
- onUnmounted: unMounted,
219
- content: desktopDatePicker()
220
- }, DesktopPickerProps),
221
- /* @__PURE__ */ React.createElement("div", { className: `${prefixCls}-container` }, /* @__PURE__ */ React.createElement(
222
- "input",
223
- __spreadProps(__spreadValues({}, inputProps), {
224
- "aria-invalid": true,
225
- autoComplete: "off",
226
- placeholder: showPlaceholder,
227
- type: "text",
228
- inputMode: "text",
229
- ref: inputRef,
230
- className: clsx(`${prefixCls}-input`, {
231
- [inputProps == null ? void 0 : inputProps.className]: inputProps == null ? void 0 : inputProps.className
232
- }),
233
- onBlur: () => setUseUserStr(false),
234
- onClick: handleDatePickerInputClick,
235
- onChange: onInputChange,
236
- value: renderValue
237
- })
238
- ), /* @__PURE__ */ React.createElement(
239
- "div",
240
- {
241
- onClick: handleDatePickerIconClick,
242
- className: `${prefixCls}-icon`
243
- },
244
- icon || /* @__PURE__ */ React.createElement(DateOutlinedIcon, { htmlColor: "var(--bui-color-neutral-3)" })
245
- ))
246
- )
247
- );
248
- });
249
- DesktopDatePicker.displayName = "BUIDatePicker";
250
- var DesktopDatePicker_default = DesktopDatePicker;
251
- export {
252
- DesktopDatePicker_default as default
253
- };
@@ -1,163 +0,0 @@
1
- import React, { Ref } from 'react';
2
- import { OverrideProps } from '@bifrostui/types';
3
- import { DesktopPickerProps } from '../DesktopPicker';
4
- import { CalendarProps } from '../Calendar';
5
- export type IDatePickerValue = Date | null;
6
- export interface IDatePickerInstance {
7
- /** 日期对象 */
8
- day: Date;
9
- /** 是否禁用 */
10
- disabled: boolean;
11
- }
12
- export interface IDatePickerCustomIconProps {
13
- /**
14
- * 是否是最小时间
15
- */
16
- isMinMonth?: boolean;
17
- /**
18
- * 是否是最大时间
19
- */
20
- isMaxMonth?: boolean;
21
- }
22
- export interface IDatePickerCalendarProps {
23
- /**
24
- * 是否隐藏当前月之外的日期,默认为false
25
- */
26
- hideDaysOutsideCurrentMonth?: boolean;
27
- /**
28
- * 高亮的日期,默认为today
29
- * today 若选中的非当天,则当天高亮显示,若选中的是当天,则当天展示选中态
30
- * weekend 可选的周末高亮显示
31
- */
32
- highlightDate?: 'today' | 'weekend';
33
- /**
34
- * 自定义日期单元格的内容
35
- */
36
- dateRender?: (currentDate: IDatePickerInstance) => React.ReactNode;
37
- /**
38
- * 自定义周单元格的内容
39
- */
40
- weekRender?: (week: string) => React.ReactNode;
41
- }
42
- export type DesktopDatePickerProps<D extends React.ElementType = 'div', P = {}> = OverrideProps<{
43
- props: P & {
44
- /**
45
- * 默认选中的值,当组件非受控时使用
46
- */
47
- defaultValue?: IDatePickerValue;
48
- /**
49
- * 选中的值,当组件受控时使用
50
- */
51
- value?: IDatePickerValue;
52
- /**
53
- * 输入框占位内容
54
- */
55
- placeholder?: string;
56
- /**
57
- * 可选择的最小日期,默认为当前日期
58
- * 渲染指定月时:value=null并指定minDate
59
- */
60
- minDate?: Date;
61
- /**
62
- * 可选择的最大日期,默认为当前日期的一年后
63
- */
64
- maxDate?: Date;
65
- /**
66
- * 弹层是否打开
67
- */
68
- open?: boolean;
69
- /**
70
- * 输入框icon
71
- */
72
- icon?: React.ReactNode;
73
- /**
74
- * inputRef
75
- */
76
- inputRef?: Ref<HTMLInputElement>;
77
- /**
78
- * inputProp
79
- */
80
- inputProps?: React.InputHTMLAttributes<HTMLInputElement>;
81
- /**
82
- * 日期选择器类型
83
- */
84
- picker?: 'year' | 'month' | 'day';
85
- /**
86
- * 头部操作栏左边图标
87
- */
88
- headerBarLeftIcon?: (options: IDatePickerCustomIconProps) => React.ReactNode;
89
- /**
90
- * 头部操作栏右边图标
91
- */
92
- headerBarRightIcon?: (options: IDatePickerCustomIconProps) => React.ReactNode;
93
- /**
94
- * 是否禁用日期选择器
95
- */
96
- disabled?: boolean;
97
- /**
98
- * 不可选择的日期
99
- */
100
- disabledDate?: (currentDate: Date) => boolean;
101
- /**
102
- * 自定义月份单元格的内容
103
- */
104
- monthRender?: ({ month, currentDate, }: {
105
- month: string | number;
106
- currentDate: IDatePickerInstance;
107
- }) => React.ReactNode;
108
- /**
109
- * 自定义年份单元格的内容
110
- */
111
- yearRender?: ({ year, currentDate, }: {
112
- year: string | number;
113
- currentDate: IDatePickerInstance;
114
- }) => React.ReactNode;
115
- /**
116
- * 日期发生变化的回调
117
- */
118
- onChange?: (e: React.SyntheticEvent, data: {
119
- value: IDatePickerValue;
120
- }) => void;
121
- /**
122
- * 选择日期后是否立刻关闭
123
- */
124
- closeOnSelect?: boolean;
125
- /**
126
- * 禁用弹层选择功能
127
- */
128
- disableOpenPicker?: boolean;
129
- /**
130
- * 日期格式化
131
- */
132
- format?: string;
133
- /**
134
- * 弹层关闭的回调
135
- */
136
- onClose?: () => void;
137
- /**
138
- * 弹层打开的回调
139
- */
140
- onOpen?: () => void;
141
- /**
142
- * 月份切换的回调
143
- */
144
- onMonthChange?: (e: React.SyntheticEvent, data: {
145
- value: Date;
146
- }) => void;
147
- /**
148
- * 年份切换的回调
149
- */
150
- onYearChange?: (e: React.SyntheticEvent, data: {
151
- value: Date;
152
- }) => void;
153
- /**
154
- * DesktopPickerProps
155
- */
156
- DesktopPickerProps?: Omit<DesktopPickerProps, 'open'>;
157
- /**
158
- * CalendarProps
159
- */
160
- CalendarProps?: CalendarProps;
161
- };
162
- defaultComponent: D;
163
- }, D>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,100 +0,0 @@
1
- :root,
2
- page,
3
- xhs-page {
4
- --bui-calendar-padding: 6px 12px 7px;
5
- --bui-d-date-picker-lay-font-family: var(--bui-font-family);
6
- --bui-d-date-picker-lay-main-radius: 3px;
7
- --bui-d-date-picker-lay-content-padding: 10px 16px;
8
- --bui-d-date-picker-lay-content-height: 30px;
9
- --bui-d-date-picker-lay-content-line-height: 30px;
10
- --bui-d-date-picker-lay-content-width: 60px;
11
- --bui-d-date-picker-lay-calendar-padding: 6px 12px 7px;
12
- --bui-d-date-picker-lay-shadow: 0 0 0 2px var(--bui-color-bg-default);
13
- --bui-d-date-picker-title-size: var(--bui-title-size-3);
14
- --bui-d-date-picker-list-padding: 6px 12px 7px;
15
- --bui-d-date-picker-col-bg: var(--bui-color-bg-view);
16
- --bui-d-date-picker-content-radius: var(--bui-shape-radius-default, 6px);
17
- --bui-d-date-picker-col-font-size: var(--bui-title-size-4);
18
- }
19
- .bui-d-date-picker-lay-main {
20
- height: 308px;
21
- font-family: var(--bui-d-date-picker-lay-font-family);
22
- border-radius: var(--bui-d-date-picker-lay-main-radius);
23
- padding: 3px 0;
24
- box-shadow: var(--bui-d-date-picker-lay-shadow);
25
- overflow: hidden;
26
- flex: 1;
27
- }
28
- .bui-d-date-picker-lay-handler {
29
- height: 28px;
30
- display: flex;
31
- align-items: center;
32
- justify-content: center;
33
- margin-bottom: 7px;
34
- margin-top: 8px;
35
- }
36
- .bui-d-date-picker-lay-handler-btn {
37
- font-size: 16px;
38
- height: 100%;
39
- width: 46px;
40
- cursor: pointer;
41
- display: flex;
42
- align-items: center;
43
- justify-content: center;
44
- }
45
- .bui-d-date-picker-lay-handler-icon {
46
- font-size: 28px;
47
- }
48
- .bui-d-date-picker-lay-title {
49
- display: flex;
50
- align-items: center;
51
- }
52
- .bui-d-date-picker-lay-title-text {
53
- white-space: nowrap;
54
- font-size: var(--bui-d-date-picker-title-size);
55
- font-weight: var(--bui-font-weight-medium);
56
- text-align: center;
57
- }
58
- .bui-d-date-picker-lay-title-text:hover {
59
- cursor: pointer;
60
- color: var(--bui-color-blue);
61
- }
62
- .bui-d-date-picker-lay-list {
63
- max-height: 262px;
64
- overflow: auto;
65
- padding: var(--bui-d-date-picker-list-padding);
66
- }
67
- .bui-d-date-picker-lay-row {
68
- display: grid;
69
- grid-template-columns: repeat(3, 1fr);
70
- }
71
- .bui-d-date-picker-lay-col {
72
- display: flex;
73
- align-items: center;
74
- justify-content: center;
75
- background-color: var(--bui-d-date-picker-col-bg);
76
- cursor: pointer;
77
- }
78
- .bui-d-date-picker-lay-col-content {
79
- margin: 12px 8px;
80
- padding: 4px 6px;
81
- border-radius: var(--bui-d-date-picker-content-radius);
82
- display: inline-block;
83
- text-align: center;
84
- font-weight: var(--bui-font-weight-medium);
85
- color: var(--bui-color-fg-default);
86
- font-family: var(--bui-d-date-picker-lay-font-family);
87
- }
88
- .bui-d-date-picker-lay-col-text {
89
- display: inline-block;
90
- width: 36px;
91
- font-size: var(--bui-d-date-picker-col-font-size);
92
- line-height: 1;
93
- }
94
- .bui-d-date-picker-lay-col-active .bui-d-date-picker-lay-col-content {
95
- color: #000;
96
- background-color: #ffc7da;
97
- }
98
- .bui-d-date-picker-lay-col-disabled .bui-d-date-picker-lay-col-content {
99
- color: #ccc;
100
- }
@@ -1,61 +0,0 @@
1
- :root,
2
- page,
3
- xhs-page {
4
- --bui-d-date-picker-height: var(--bui-input-height, 32px);
5
- --bui-d-date-picker-min-width: var(--bui-input-min-width, 100px);
6
- --bui-d-date-picker-font-size: var(--bui-title-size-3, 16px);
7
- --bui-d-date-picker-icon-size: var(--bui-title-size-3, 16px);
8
- --bui-d-date-picker-container-padding: var(--bui-spacing-md, 9px);
9
- --bui-d-date-picker-bg: var(--bui-color-bg-view);
10
- --bui-d-date-picker-font-family: var(--bui-font-family);
11
- --bui-d-date-picker-border: 1px solid var(--bui-color-border-default);
12
- --bui-d-date-picker-shadow: 0 0 0 2px var(--bui-color-bg-default);
13
- --bui-d-date-picker-disabled-color: var(--bui-color-fg-subtle);
14
- }
15
- .bui-d-date-picker {
16
- position: relative;
17
- cursor: pointer;
18
- vertical-align: middle;
19
- height: var(--bui-d-date-picker-height);
20
- min-width: var(--bui-d-date-picker-min-width);
21
- font-size: var(--bui-d-date-picker-font-size);
22
- border-radius: 5px;
23
- background-color: var(--bui-d-date-picker-bg);
24
- font-family: var(--bui-d-date-picker-font-family);
25
- border: var(--bui-d-date-picker-border);
26
- }
27
- .bui-d-date-picker:active,
28
- .bui-d-date-picker-active {
29
- box-shadow: var(--bui-d-date-picker-shadow);
30
- }
31
- .bui-d-date-picker-icon {
32
- display: flex;
33
- align-items: center;
34
- font-size: var(--bui-d-date-picker-icon-size);
35
- height: 100%;
36
- padding-left: 6px;
37
- }
38
- .bui-d-date-picker-container {
39
- display: flex;
40
- align-items: center;
41
- padding: 0 var(--bui-d-date-picker-container-padding);
42
- height: 100%;
43
- }
44
- .bui-d-date-picker-input {
45
- display: flex;
46
- justify-content: space-between;
47
- align-items: center;
48
- flex: 1;
49
- height: 100%;
50
- background-color: transparent;
51
- outline: none;
52
- border: 0;
53
- }
54
- .bui-d-date-picker.bui-d-date-picker-disabled {
55
- pointer-events: none;
56
- box-shadow: none;
57
- background-color: rgba(188, 188, 188, 0.2);
58
- }
59
- .bui-d-date-picker.bui-d-date-picker-disabled input {
60
- color: var(--bui-d-date-picker-disabled-color);
61
- }
@@ -1,2 +0,0 @@
1
- export { default, default as DesktopDatePicker } from './DesktopDatePicker';
2
- export * from './DesktopDatePicker.types';
@@ -1,6 +0,0 @@
1
- import { default as default2, default as default3 } from "./DesktopDatePicker";
2
- export * from "./DesktopDatePicker.types";
3
- export {
4
- default3 as DesktopDatePicker,
5
- default2 as default
6
- };
@@ -1,6 +0,0 @@
1
- import React from 'react';
2
- import './deskTopPickerContainer.less';
3
- declare const useGetDatePickerContent: (props: any) => {
4
- desktopDatePicker: () => React.JSX.Element;
5
- };
6
- export default useGetDatePickerContent;