@nutui/nutui 4.0.0 → 4.0.1-2.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 (285) hide show
  1. package/CHANGELOG.md +226 -0
  2. package/README.md +34 -65
  3. package/dist/nutui.es.js +10 -17
  4. package/dist/nutui.js +16202 -0
  5. package/dist/nutui.umd.js +1 -7
  6. package/dist/packages/_es/ActionSheet.js +79 -94
  7. package/dist/packages/_es/Address.js +260 -345
  8. package/dist/packages/_es/AddressList.js +269 -354
  9. package/dist/packages/_es/Animate.js +46 -38
  10. package/dist/packages/_es/Audio.js +128 -180
  11. package/dist/packages/_es/AudioOperate.js +60 -52
  12. package/dist/packages/_es/Avatar.js +67 -75
  13. package/dist/packages/_es/AvatarGroup.js +23 -31
  14. package/dist/packages/_es/Backtop.js +59 -99
  15. package/dist/packages/_es/Badge.js +39 -46
  16. package/dist/packages/_es/Barrage.js +68 -145
  17. package/dist/packages/_es/Button.js +47 -66
  18. package/dist/packages/_es/Calendar.js +135 -152
  19. package/dist/packages/_es/CalendarItem.js +6 -6
  20. package/dist/packages/_es/Card.js +42 -56
  21. package/dist/packages/_es/Cascader.js +323 -433
  22. package/dist/packages/_es/Category.js +29 -39
  23. package/dist/packages/_es/CategoryPane.js +57 -83
  24. package/dist/packages/_es/Cell.js +56 -71
  25. package/dist/packages/_es/CellGroup.js +19 -27
  26. package/dist/packages/_es/Checkbox.js +109 -138
  27. package/dist/packages/_es/CheckboxGroup.js +38 -61
  28. package/dist/packages/_es/CircleProgress.js +67 -96
  29. package/dist/packages/_es/Col.js +23 -31
  30. package/dist/packages/_es/Collapse.js +37 -67
  31. package/dist/packages/_es/CollapseItem.js +91 -184
  32. package/dist/packages/_es/Comment.js +207 -279
  33. package/dist/packages/_es/ConfigProvider.js +38 -56
  34. package/dist/packages/_es/Countdown.js +100 -194
  35. package/dist/packages/_es/Countup.js +232 -428
  36. package/dist/packages/_es/DatePicker.js +169 -245
  37. package/dist/packages/_es/Dialog.js +163 -188
  38. package/dist/packages/_es/Divider.js +42 -40
  39. package/dist/packages/_es/Drag.js +70 -153
  40. package/dist/packages/_es/Ecard.js +64 -104
  41. package/dist/packages/_es/Elevator.js +144 -201
  42. package/dist/packages/_es/Ellipsis.js +95 -159
  43. package/dist/packages/_es/Empty.js +23 -39
  44. package/dist/packages/_es/FixedNav.js +93 -116
  45. package/dist/packages/_es/Form.js +108 -164
  46. package/dist/packages/_es/FormItem.js +48 -61
  47. package/dist/packages/_es/Grid.js +5 -6
  48. package/dist/packages/_es/GridItem.js +58 -84
  49. package/dist/packages/_es/Image.js +98 -88
  50. package/dist/packages/_es/ImagePreview.js +262 -392
  51. package/dist/packages/_es/Indicator.js +30 -34
  52. package/dist/packages/_es/InfiniteLoading.js +83 -117
  53. package/dist/packages/_es/Input.js +176 -223
  54. package/dist/packages/_es/InputNumber.js +81 -117
  55. package/dist/packages/_es/Interceptor-6e26b757.js +18 -0
  56. package/dist/packages/_es/Invoice.js +105 -113
  57. package/dist/packages/_es/Layout.js +3 -4
  58. package/dist/packages/_es/List.js +147 -89
  59. package/dist/packages/_es/Menu.js +96 -152
  60. package/dist/packages/_es/MenuItem.js +117 -153
  61. package/dist/packages/_es/Navbar.js +103 -119
  62. package/dist/packages/_es/Noticebar.js +207 -273
  63. package/dist/packages/_es/Notify.js +110 -147
  64. package/dist/packages/_es/NumberKeyboard.js +127 -202
  65. package/dist/packages/_es/Overlay.js +53 -66
  66. package/dist/packages/_es/Pagination.js +70 -100
  67. package/dist/packages/_es/Picker.js +276 -425
  68. package/dist/packages/_es/Popover.js +122 -225
  69. package/dist/packages/_es/Popup.js +4 -4
  70. package/dist/packages/_es/Price.js +47 -80
  71. package/dist/packages/_es/Progress.js +63 -79
  72. package/dist/packages/_es/PullRefresh.js +96 -157
  73. package/dist/packages/_es/Radio.js +4 -4
  74. package/dist/packages/_es/RadioGroup.js +3 -3
  75. package/dist/packages/_es/Range.js +205 -329
  76. package/dist/packages/_es/Rate.js +93 -122
  77. package/dist/packages/_es/Row.js +21 -27
  78. package/dist/packages/_es/Searchbar.js +130 -160
  79. package/dist/packages/_es/ShortPassword.js +69 -93
  80. package/dist/packages/_es/SideNavbar.js +49 -59
  81. package/dist/packages/_es/SideNavbarItem.js +22 -32
  82. package/dist/packages/_es/Signature.js +83 -128
  83. package/dist/packages/_es/Skeleton.js +110 -130
  84. package/dist/packages/_es/Sku.js +251 -326
  85. package/dist/packages/_es/Step.js +60 -69
  86. package/dist/packages/_es/Steps.js +26 -31
  87. package/dist/packages/_es/Sticky.js +4 -4
  88. package/dist/packages/_es/SubSideNavbar.js +52 -56
  89. package/dist/packages/_es/Swipe.js +84 -137
  90. package/dist/packages/_es/Swiper.js +175 -310
  91. package/dist/packages/_es/SwiperItem.js +28 -44
  92. package/dist/packages/_es/Switch.js +55 -67
  93. package/dist/packages/_es/TabPane.js +32 -20
  94. package/dist/packages/_es/Tabbar.js +41 -52
  95. package/dist/packages/_es/TabbarItem.js +61 -81
  96. package/dist/packages/_es/Table.js +110 -148
  97. package/dist/packages/_es/Tabs.js +284 -205
  98. package/dist/packages/_es/Tag.js +44 -61
  99. package/dist/packages/_es/Textarea.js +80 -124
  100. package/dist/packages/_es/TimeDetail.js +49 -57
  101. package/dist/packages/_es/TimePannel.js +35 -31
  102. package/dist/packages/_es/TimeSelect.js +47 -68
  103. package/dist/packages/_es/Toast.js +150 -203
  104. package/dist/packages/_es/Tour.js +139 -175
  105. package/dist/packages/_es/TrendArrow.js +57 -58
  106. package/dist/packages/_es/Uploader.js +235 -359
  107. package/dist/packages/_es/Video.js +191 -298
  108. package/dist/packages/_es/Watermark.js +84 -98
  109. package/dist/packages/_es/_plugin-vue_export-helper-dad06003.js +9 -0
  110. package/dist/packages/_es/common-d218746f.js +116 -0
  111. package/dist/packages/_es/component-234624bc.js +89 -0
  112. package/dist/packages/_es/index-14dfadc4.js +561 -0
  113. package/dist/packages/_es/index-192a3ef6.js +29 -0
  114. package/dist/packages/_es/index-360c5092.js +210 -0
  115. package/dist/packages/_es/index-496e6e05.js +24 -0
  116. package/dist/packages/_es/index-50eed3d9.js +7 -0
  117. package/dist/packages/_es/index-53ec2d4d.js +34 -0
  118. package/dist/packages/_es/index-fadb0974.js +8 -0
  119. package/dist/packages/_es/index.vue_vue_type_script_lang-1139b29a.js +43 -0
  120. package/dist/packages/_es/index.vue_vue_type_script_lang-43b774dd.js +77 -0
  121. package/dist/packages/_es/index.vue_vue_type_script_lang-f44c159d.js +110 -0
  122. package/dist/packages/_es/mountComponent-6d4ff200.js +23 -0
  123. package/dist/packages/_es/pxCheck-38173291.js +4 -0
  124. package/dist/packages/_es/raf-a74f1a06.js +16 -0
  125. package/dist/packages/_es/renderIcon-47498b32.js +5 -0
  126. package/dist/packages/actionsheet/index.scss +2 -0
  127. package/dist/packages/actionsheet/style.mjs +0 -2
  128. package/dist/packages/address/index.scss +5 -2
  129. package/dist/packages/address/style.mjs +0 -3
  130. package/dist/packages/addresslist/index.scss +3 -0
  131. package/dist/packages/addresslist/style.mjs +0 -2
  132. package/dist/packages/audio/index.scss +2 -0
  133. package/dist/packages/audio/style.mjs +0 -1
  134. package/dist/packages/audiooperate/index.scss +2 -0
  135. package/dist/packages/audiooperate/style.mjs +0 -1
  136. package/dist/packages/badge/index.scss +3 -0
  137. package/dist/packages/button/index.scss +1 -1
  138. package/dist/packages/calendar/index.scss +3 -0
  139. package/dist/packages/calendar/style.mjs +0 -3
  140. package/dist/packages/card/index.scss +3 -0
  141. package/dist/packages/card/style.mjs +0 -2
  142. package/dist/packages/cascader/index.scss +4 -0
  143. package/dist/packages/cascader/style.mjs +0 -5
  144. package/dist/packages/cellgroup/index.scss +1 -1
  145. package/dist/packages/checkbox/index.scss +41 -0
  146. package/dist/packages/col/index.scss +2 -2
  147. package/dist/packages/comment/index.scss +2 -0
  148. package/dist/packages/comment/style.mjs +0 -1
  149. package/dist/packages/datepicker/index.scss +1 -2
  150. package/dist/packages/datepicker/style.mjs +0 -3
  151. package/dist/packages/dialog/index.scss +11 -0
  152. package/dist/packages/dialog/style.mjs +0 -3
  153. package/dist/packages/ecard/index.scss +2 -0
  154. package/dist/packages/ecard/style.mjs +0 -1
  155. package/dist/packages/fixednav/index.scss +2 -0
  156. package/dist/packages/fixednav/style.mjs +0 -1
  157. package/dist/packages/form/index.scss +1 -2
  158. package/dist/packages/form/style.mjs +0 -1
  159. package/dist/packages/formitem/index.scss +3 -0
  160. package/dist/packages/formitem/style.mjs +0 -1
  161. package/dist/packages/imagepreview/index.scss +5 -5
  162. package/dist/packages/imagepreview/style.mjs +0 -5
  163. package/dist/packages/input/index.scss +13 -13
  164. package/dist/packages/invoice/index.scss +6 -0
  165. package/dist/packages/invoice/style.mjs +0 -7
  166. package/dist/packages/list/index.scss +8 -8
  167. package/dist/packages/menuitem/index.scss +9 -10
  168. package/dist/packages/menuitem/style.mjs +0 -2
  169. package/dist/packages/navbar/index.scss +0 -1
  170. package/dist/packages/noticebar/index.scss +12 -2
  171. package/dist/packages/notify/index.scss +2 -0
  172. package/dist/packages/notify/style.mjs +0 -2
  173. package/dist/packages/numberkeyboard/index.scss +2 -0
  174. package/dist/packages/numberkeyboard/style.mjs +0 -2
  175. package/dist/packages/picker/index.scss +4 -9
  176. package/dist/packages/picker/style.mjs +0 -2
  177. package/dist/packages/popover/index.scss +2 -0
  178. package/dist/packages/popover/style.mjs +0 -2
  179. package/dist/packages/popup/index.scss +2 -0
  180. package/dist/packages/popup/style.mjs +0 -1
  181. package/dist/packages/price/index.scss +5 -10
  182. package/dist/packages/rate/index.scss +6 -9
  183. package/dist/packages/searchbar/index.scss +4 -0
  184. package/dist/packages/shortpassword/index.scss +18 -0
  185. package/dist/packages/shortpassword/style.mjs +0 -2
  186. package/dist/packages/signature/index.scss +2 -0
  187. package/dist/packages/signature/style.mjs +0 -1
  188. package/dist/packages/skeleton/index.scss +2 -0
  189. package/dist/packages/skeleton/style.mjs +0 -1
  190. package/dist/packages/sku/index.scss +4 -0
  191. package/dist/packages/sku/style.mjs +0 -4
  192. package/dist/packages/tabbaritem/index.scss +2 -0
  193. package/dist/packages/tabbaritem/style.mjs +0 -1
  194. package/dist/packages/tabs/index.scss +36 -2
  195. package/dist/packages/tabs/style.mjs +0 -1
  196. package/dist/packages/textarea/index.scss +2 -0
  197. package/dist/packages/timeselect/index.scss +2 -0
  198. package/dist/packages/timeselect/style.mjs +0 -2
  199. package/dist/packages/tour/index.scss +2 -0
  200. package/dist/packages/tour/style.mjs +0 -3
  201. package/dist/packages/uploader/index.scss +10 -2
  202. package/dist/packages/uploader/style.mjs +0 -2
  203. package/dist/resolver/index.d.ts +6 -0
  204. package/dist/resolver/index.js +1 -0
  205. package/dist/resolver/index.mjs +24 -0
  206. package/dist/resolver/package.json +20 -0
  207. package/dist/smartips/web-types.json +114 -15
  208. package/dist/style.css +1 -1
  209. package/dist/styles/themes/default.scss +155 -52
  210. package/dist/styles/themes/jdb.scss +155 -52
  211. package/dist/styles/themes/jddkh.scss +155 -52
  212. package/dist/styles/themes/jdt.scss +155 -52
  213. package/dist/styles/variables-jdb.scss +9 -1
  214. package/dist/styles/variables-jddkh.scss +9 -1
  215. package/dist/styles/variables-jdt.scss +9 -1
  216. package/dist/styles/variables.scss +8 -0
  217. package/dist/types/__VUE/address/index.vue.d.ts +2 -1
  218. package/dist/types/__VUE/addresslist/components/GeneralShell.vue.d.ts +1 -1
  219. package/dist/types/__VUE/addresslist/components/ItemContents.vue.d.ts +1 -1
  220. package/dist/types/__VUE/addresslist/index.vue.d.ts +1 -1
  221. package/dist/types/__VUE/animate/index.vue.d.ts +6 -0
  222. package/dist/types/__VUE/audiooperate/index.vue.d.ts +4 -4
  223. package/dist/types/__VUE/badge/index.vue.d.ts +9 -0
  224. package/dist/types/__VUE/button/type.d.ts +1 -0
  225. package/dist/types/__VUE/calendaritem/type.d.ts +1 -0
  226. package/dist/types/__VUE/collapse/index.vue.d.ts +31 -5
  227. package/dist/types/__VUE/collapseitem/index.vue.d.ts +117 -11
  228. package/dist/types/__VUE/configprovider/index.vue.d.ts +2 -2
  229. package/dist/types/__VUE/datepicker/index.vue.d.ts +1 -1
  230. package/dist/types/__VUE/dialog/index.d.ts +1 -0
  231. package/dist/types/__VUE/dialog/index.vue.d.ts +1 -0
  232. package/dist/types/__VUE/grid/index.vue.d.ts +1 -1
  233. package/dist/types/__VUE/image/index.vue.d.ts +14 -3
  234. package/dist/types/__VUE/imagepreview/imagePreviewItem.vue.d.ts +9 -0
  235. package/dist/types/__VUE/imagepreview/index.vue.d.ts +1 -1
  236. package/dist/types/__VUE/input/index.vue.d.ts +27 -2
  237. package/dist/types/__VUE/list/index.vue.d.ts +42 -13
  238. package/dist/types/__VUE/list/type.d.ts +13 -0
  239. package/dist/types/__VUE/menu/index.vue.d.ts +0 -2
  240. package/dist/types/__VUE/menuitem/index.vue.d.ts +9 -17
  241. package/dist/types/__VUE/navbar/index.vue.d.ts +1 -1
  242. package/dist/types/__VUE/noticebar/index.vue.d.ts +5 -2
  243. package/dist/types/__VUE/picker/common.d.ts +2 -0
  244. package/dist/types/__VUE/picker/usePicker.d.ts +1 -1
  245. package/dist/types/__VUE/price/index.vue.d.ts +9 -0
  246. package/dist/types/__VUE/rate/index.vue.d.ts +110 -3
  247. package/dist/types/__VUE/row/index.vue.d.ts +1 -1
  248. package/dist/types/__VUE/searchbar/index.vue.d.ts +121 -5
  249. package/dist/types/__VUE/skeleton/index.vue.d.ts +2 -2
  250. package/dist/types/__VUE/swiper/index.vue.d.ts +9 -2
  251. package/dist/types/__VUE/switch/index.vue.d.ts +1 -0
  252. package/dist/types/__VUE/table/common.d.ts +55 -2
  253. package/dist/types/__VUE/tabpane/index.vue.d.ts +1 -4
  254. package/dist/types/__VUE/tabs/hooks.d.ts +12 -0
  255. package/dist/types/__VUE/tabs/index.vue.d.ts +35 -5
  256. package/dist/types/__VUE/tabs/types.d.ts +12 -0
  257. package/dist/types/__VUE/timeselect/index.vue.d.ts +1 -1
  258. package/dist/types/__VUE/toast/index.vue.d.ts +11 -4
  259. package/dist/types/__VUE/uploader/type.d.ts +2 -1
  260. package/dist/types/__VUE/watermark/index.vue.d.ts +1 -1
  261. package/dist/types/index.d.ts +1 -2
  262. package/dist/types/resolver/index.d.ts +6 -0
  263. package/dist/types/utils/date.d.ts +4 -0
  264. package/dist/types/utils/useTaroRect/index.d.ts +1 -1
  265. package/dist/types/utils/util.d.ts +1 -1
  266. package/package.json +13 -6
  267. package/dist/packages/_es/_plugin-vue_export-helper-cc2b3d55.js +0 -10
  268. package/dist/packages/_es/common-b9a5e726.js +0 -145
  269. package/dist/packages/_es/component-81a4c1d0.js +0 -145
  270. package/dist/packages/_es/index-29892cda.js +0 -33
  271. package/dist/packages/_es/index-2ae3ae87.js +0 -846
  272. package/dist/packages/_es/index-43c34ac6.js +0 -30
  273. package/dist/packages/_es/index-54d03fc1.js +0 -8
  274. package/dist/packages/_es/index-79c5dc33.js +0 -10
  275. package/dist/packages/_es/index-7a7385e4.js +0 -67
  276. package/dist/packages/_es/index-991c279f.js +0 -244
  277. package/dist/packages/_es/index.vue_vue_type_script_lang-22dfc112.js +0 -46
  278. package/dist/packages/_es/index.vue_vue_type_script_lang-442e4704.js +0 -98
  279. package/dist/packages/_es/index.vue_vue_type_script_lang-cc5c4086.js +0 -151
  280. package/dist/packages/_es/interceptor-956b24fc.js +0 -29
  281. package/dist/packages/_es/mountComponent-1ece4110.js +0 -39
  282. package/dist/packages/_es/pxCheck-c6b9f6b7.js +0 -6
  283. package/dist/packages/_es/raf-729dad54.js +0 -25
  284. package/dist/packages/_es/renderIcon-3d0fd47c.js +0 -9
  285. /package/dist/types/utils/{interceptor.d.ts → Interceptor.d.ts} +0 -0
@@ -1,26 +1,36 @@
1
- import { reactive, computed, onBeforeMount, watch, toRefs, resolveComponent, openBlock, createBlock, withCtx, renderSlot } from "vue";
2
- import Picker from "./Picker.js";
3
- import { c as createComponent, a as isDate$1, p as padZero } from "./component-81a4c1d0.js";
4
- import { _ as _export_sfc } from "./_plugin-vue_export-helper-cc2b3d55.js";
5
- import "./pxCheck-c6b9f6b7.js";
6
- import "./index-7a7385e4.js";
1
+ var P = Object.defineProperty, R = Object.defineProperties;
2
+ var U = Object.getOwnPropertyDescriptors;
3
+ var p = Object.getOwnPropertySymbols;
4
+ var Z = Object.prototype.hasOwnProperty, j = Object.prototype.propertyIsEnumerable;
5
+ var M = (t, o, a) => o in t ? P(t, o, { enumerable: !0, configurable: !0, writable: !0, value: a }) : t[o] = a, V = (t, o) => {
6
+ for (var a in o || (o = {}))
7
+ Z.call(o, a) && M(t, a, o[a]);
8
+ if (p)
9
+ for (var a of p(o))
10
+ j.call(o, a) && M(t, a, o[a]);
11
+ return t;
12
+ }, k = (t, o) => R(t, U(o));
13
+ import { reactive as q, computed as T, onBeforeMount as A, watch as b, toRefs as G, resolveComponent as K, openBlock as Q, createBlock as W, withCtx as x, renderSlot as H } from "vue";
14
+ import $ from "./Picker.js";
15
+ import { c as X, a as _, p as S } from "./component-234624bc.js";
16
+ import { _ as ee } from "./_plugin-vue_export-helper-dad06003.js";
17
+ import "./pxCheck-38173291.js";
18
+ import "./index-53ec2d4d.js";
7
19
  import "../locale/lang";
8
- const { componentName, create, translate } = createComponent("date-picker");
9
- const currentYear = new Date().getFullYear();
10
- function isDate(val) {
11
- return isDate$1(val) && !isNaN(val.getTime());
20
+ const { componentName: ge, create: te, translate: s } = X("date-picker"), C = (/* @__PURE__ */ new Date()).getFullYear();
21
+ function w(t) {
22
+ return _(t) && !isNaN(t.getTime());
12
23
  }
13
- const zhCNType = {
14
- day: translate("day"),
15
- year: translate("year"),
16
- month: translate("month"),
17
- hour: translate("hour"),
18
- minute: translate("minute"),
19
- seconds: translate("seconds")
20
- };
21
- const _sfc_main = create({
24
+ const ne = {
25
+ day: s("day"),
26
+ year: s("year"),
27
+ month: s("month"),
28
+ hour: s("hour"),
29
+ minute: s("minute"),
30
+ seconds: s("seconds")
31
+ }, ae = te({
22
32
  components: {
23
- [Picker.name]: Picker
33
+ [$.name]: $
24
34
  },
25
35
  props: {
26
36
  modelValue: null,
@@ -42,7 +52,7 @@ const _sfc_main = create({
42
52
  },
43
53
  isShowChinese: {
44
54
  type: Boolean,
45
- default: false
55
+ default: !1
46
56
  },
47
57
  minuteStep: {
48
58
  type: Number,
@@ -50,13 +60,13 @@ const _sfc_main = create({
50
60
  },
51
61
  minDate: {
52
62
  type: Date,
53
- default: () => new Date(currentYear - 10, 0, 1),
54
- validator: isDate
63
+ default: () => new Date(C - 10, 0, 1),
64
+ validator: w
55
65
  },
56
66
  maxDate: {
57
67
  type: Date,
58
- default: () => new Date(currentYear + 10, 11, 31),
59
- validator: isDate
68
+ default: () => new Date(C + 10, 11, 31),
69
+ validator: w
60
70
  },
61
71
  formatter: {
62
72
  type: Function,
@@ -65,7 +75,7 @@ const _sfc_main = create({
65
75
  // 是否开启3D效果
66
76
  threeDimensional: {
67
77
  type: Boolean,
68
- default: true
78
+ default: !0
69
79
  },
70
80
  // 惯性滚动 时长
71
81
  swipeDuration: {
@@ -75,7 +85,7 @@ const _sfc_main = create({
75
85
  filter: Function,
76
86
  showToolbar: {
77
87
  type: Boolean,
78
- default: true
88
+ default: !0
79
89
  },
80
90
  visibleOptionNum: {
81
91
  type: [Number, String],
@@ -87,271 +97,185 @@ const _sfc_main = create({
87
97
  }
88
98
  },
89
99
  emits: ["click", "cancel", "change", "confirm", "update:modelValue"],
90
- setup(props, { emit }) {
91
- const state = reactive({
92
- currentDate: new Date(),
93
- title: props.title,
100
+ setup(t, { emit: o }) {
101
+ const a = q({
102
+ currentDate: /* @__PURE__ */ new Date(),
103
+ title: t.title,
94
104
  selectedValue: []
95
- });
96
- const formatValue = (value) => {
97
- if (!isDate(value)) {
98
- value = props.minDate;
99
- }
100
- let timestmp = Math.max(value.getTime(), props.minDate.getTime());
101
- timestmp = Math.min(timestmp, props.maxDate.getTime());
102
- return new Date(timestmp);
105
+ }), f = (e) => {
106
+ w(e) || (e = t.minDate);
107
+ let n = Math.max(e.getTime(), t.minDate.getTime());
108
+ return n = Math.min(n, t.maxDate.getTime()), new Date(n);
103
109
  };
104
- function getMonthEndDay(year, month) {
105
- return 32 - new Date(year, month - 1, 32).getDate();
110
+ function g(e, n) {
111
+ return 32 - new Date(e, n - 1, 32).getDate();
106
112
  }
107
- const getBoundary = (type, value) => {
108
- const boundary = props[`${type}Date`];
109
- const year = boundary.getFullYear();
110
- let month = 1;
111
- let day = 1;
112
- let hour = 0;
113
- let minute = 0;
114
- if (type === "max") {
115
- month = 12;
116
- day = getMonthEndDay(value.getFullYear(), value.getMonth() + 1);
117
- hour = 23;
118
- minute = 59;
119
- }
120
- const seconds = minute;
121
- if (value.getFullYear() === year) {
122
- month = boundary.getMonth() + 1;
123
- if (value.getMonth() + 1 === month) {
124
- day = boundary.getDate();
125
- if (value.getDate() === day) {
126
- hour = boundary.getHours();
127
- if (value.getHours() === hour) {
128
- minute = boundary.getMinutes();
129
- }
130
- }
131
- }
132
- } else {
133
- return {
134
- [`${type}Year`]: year,
135
- [`${type}Month`]: month,
136
- [`${type}Day`]: day,
137
- [`${type}Hour`]: hour,
138
- [`${type}Minute`]: minute,
139
- [`${type}Seconds`]: seconds
140
- };
141
- }
142
- return {
143
- [`${type}Year`]: year,
144
- [`${type}Month`]: month,
145
- [`${type}Day`]: day,
146
- [`${type}Hour`]: hour,
147
- [`${type}Minute`]: minute,
148
- [`${type}Seconds`]: seconds
113
+ const h = (e, n) => {
114
+ const u = e == "min" ? t.minDate : t.maxDate, r = u.getFullYear();
115
+ let l = 1, i = 1, c = 0, m = 0;
116
+ e === "max" && (l = 12, i = g(n.getFullYear(), n.getMonth() + 1), c = 23, m = 59);
117
+ const d = m;
118
+ return n.getFullYear() === r && (l = u.getMonth() + 1, n.getMonth() + 1 === l && (i = u.getDate(), n.getDate() === i && (c = u.getHours(), n.getHours() === c && (m = u.getMinutes())))), {
119
+ [`${e}Year`]: r,
120
+ [`${e}Month`]: l,
121
+ [`${e}Date`]: i,
122
+ [`${e}Hour`]: c,
123
+ [`${e}Minute`]: m,
124
+ [`${e}Seconds`]: d
149
125
  };
150
- };
151
- const ranges = computed(() => {
152
- const { maxYear, maxDay, maxMonth, maxHour, maxMinute, maxSeconds } = getBoundary("max", state.currentDate);
153
- const { minYear, minDay, minMonth, minHour, minMinute, minSeconds } = getBoundary("min", state.currentDate);
154
- let result = [
126
+ }, D = T(() => {
127
+ const { maxYear: e, maxDate: n, maxMonth: u, maxHour: r, maxMinute: l, maxSeconds: i } = h("max", a.currentDate), { minYear: c, minDate: m, minMonth: d, minHour: z, minMinute: I, minSeconds: L } = h("min", a.currentDate);
128
+ return N([
155
129
  {
156
130
  type: "year",
157
- range: [minYear, maxYear]
131
+ range: [c, e]
158
132
  },
159
133
  {
160
134
  type: "month",
161
- range: [minMonth, maxMonth]
135
+ range: [d, u]
162
136
  },
163
137
  {
164
138
  type: "day",
165
- range: [minDay, maxDay]
139
+ range: [m, n]
166
140
  },
167
141
  {
168
142
  type: "hour",
169
- range: [minHour, maxHour]
143
+ range: [z, r]
170
144
  },
171
145
  {
172
146
  type: "minute",
173
- range: [minMinute, maxMinute]
147
+ range: [I, l]
174
148
  },
175
149
  {
176
150
  type: "seconds",
177
- range: [minSeconds, maxSeconds]
151
+ range: [L, i]
178
152
  }
179
- ];
180
- switch (props.type) {
153
+ ]);
154
+ }), y = T(() => D.value.map((n, u) => F(n.range[0], n.range[1], B(n.type), n.type, u))), Y = ({
155
+ columnIndex: e,
156
+ selectedValue: n,
157
+ selectedOptions: u
158
+ }) => {
159
+ if (["date", "datetime", "datehour", "month-day", "year-month"].includes(t.type)) {
160
+ let r = [];
161
+ n.forEach((d) => {
162
+ r.push(d);
163
+ }), t.type == "month-day" && r.length < 3 && r.unshift(new Date(a.currentDate || t.minDate || t.maxDate).getFullYear()), t.type == "year-month" && r.length < 3 && r.push(new Date(a.currentDate || t.minDate || t.maxDate).getDate());
164
+ const l = Number(r[0]), i = Number(r[1]) - 1, c = Math.min(Number(r[2]), g(Number(r[0]), Number(r[1])));
165
+ let m = null;
166
+ t.type === "date" || t.type === "month-day" || t.type === "year-month" ? m = new Date(l, i, c) : t.type === "datetime" ? m = new Date(l, i, c, Number(r[3]), Number(r[4])) : t.type === "datehour" && (m = new Date(l, i, c, Number(r[3]))), a.currentDate = f(m);
167
+ }
168
+ o("change", { columnIndex: e, selectedValue: n, selectedOptions: u });
169
+ }, O = (e, n) => {
170
+ const { formatter: u, isShowChinese: r } = t;
171
+ let l = null;
172
+ if (u)
173
+ l = u(e, { text: S(n, 2), value: S(n, 2) });
174
+ else {
175
+ const i = S(n, 2), c = r ? ne[e] : "";
176
+ l = { text: i + c, value: i };
177
+ }
178
+ return l;
179
+ }, F = (e, n, u, r, l) => {
180
+ const i = [];
181
+ let c = 0;
182
+ for (; e <= n; )
183
+ i.push(O(r, e)), r === "minute" ? e += t.minuteStep : e++, e <= u && c++;
184
+ return a.selectedValue[l] = i[c].value, t.filter ? t.filter(r, i) : i;
185
+ }, B = (e) => e === "year" ? a.currentDate.getFullYear() : e === "month" ? a.currentDate.getMonth() + 1 : e === "day" ? a.currentDate.getDate() : e === "hour" ? a.currentDate.getHours() : e === "minute" ? a.currentDate.getMinutes() : e === "seconds" ? a.currentDate.getSeconds() : 0, v = (e) => {
186
+ o("cancel", e);
187
+ }, J = (e) => {
188
+ o("confirm", e);
189
+ }, N = (e) => {
190
+ switch (t.type) {
181
191
  case "date":
182
- result = result.slice(0, 3);
192
+ e = e.slice(0, 3);
183
193
  break;
184
194
  case "datetime":
185
- result = result.slice(0, 5);
195
+ e = e.slice(0, 5);
186
196
  break;
187
197
  case "time":
188
- result = result.slice(3, 6);
198
+ e = e.slice(3, 6);
189
199
  break;
190
200
  case "year-month":
191
- result = result.slice(0, 2);
201
+ e = e.slice(0, 2);
192
202
  break;
193
203
  case "month-day":
194
- result = result.slice(1, 3);
204
+ e = e.slice(1, 3);
195
205
  break;
196
206
  case "datehour":
197
- result = result.slice(0, 4);
207
+ e = e.slice(0, 4);
208
+ break;
209
+ case "hour-minute":
210
+ e = e.slice(3, 5);
198
211
  break;
199
212
  }
200
- return result;
201
- });
202
- const columns = computed(() => {
203
- const val = ranges.value.map((res, columnIndex) => {
204
- return generateValue(res.range[0], res.range[1], getDateIndex(res.type), res.type, columnIndex);
205
- });
206
- return val;
207
- });
208
- const changeHandler = ({
209
- columnIndex,
210
- selectedValue,
211
- selectedOptions
212
- }) => {
213
- if (["date", "datetime", "datehour", "month-day", "year-month"].includes(props.type)) {
214
- let formatDate = [];
215
- selectedValue.forEach((item) => {
216
- formatDate.push(item);
217
- });
218
- if (props.type == "month-day" && formatDate.length < 3) {
219
- formatDate.unshift(new Date(state.currentDate || props.minDate || props.maxDate).getFullYear());
220
- }
221
- if (props.type == "year-month" && formatDate.length < 3) {
222
- formatDate.push(new Date(state.currentDate || props.minDate || props.maxDate).getDate());
223
- }
224
- const year = Number(formatDate[0]);
225
- const month = Number(formatDate[1]) - 1;
226
- const day = Math.min(Number(formatDate[2]), getMonthEndDay(Number(formatDate[0]), Number(formatDate[1])));
227
- let date = null;
228
- if (props.type === "date" || props.type === "month-day" || props.type === "year-month") {
229
- date = new Date(year, month, day);
230
- } else if (props.type === "datetime") {
231
- date = new Date(year, month, day, Number(formatDate[3]), Number(formatDate[4]));
232
- } else if (props.type === "datehour") {
233
- date = new Date(year, month, day, Number(formatDate[3]));
234
- }
235
- state.currentDate = formatValue(date);
236
- }
237
- emit("change", { columnIndex, selectedValue, selectedOptions });
213
+ return e;
214
+ }, E = (e) => {
215
+ const n = [
216
+ e.getFullYear(),
217
+ e.getMonth() + 1,
218
+ e.getDate(),
219
+ e.getHours(),
220
+ e.getMinutes(),
221
+ e.getSeconds()
222
+ ];
223
+ return N(n.map((u) => String(u)));
238
224
  };
239
- const formatterOption = (type, value) => {
240
- const { formatter, isShowChinese } = props;
241
- let fOption = null;
242
- if (formatter) {
243
- fOption = formatter(type, { text: padZero(value, 2), value: padZero(value, 2) });
244
- } else {
245
- const padMin = padZero(value, 2);
246
- const fatter = isShowChinese ? zhCNType[type] : "";
247
- fOption = { text: padMin + fatter, value: padMin };
225
+ return A(() => {
226
+ a.currentDate = f(t.modelValue);
227
+ }), b(
228
+ () => t.modelValue,
229
+ (e) => {
230
+ const n = f(e);
231
+ JSON.stringify(n) === JSON.stringify(a.currentDate) || (a.currentDate = n, a.selectedValue = E(n));
248
232
  }
249
- return fOption;
250
- };
251
- const generateValue = (min, max, val, type, columnIndex) => {
252
- const arr = [];
253
- let index2 = 0;
254
- while (min <= max) {
255
- arr.push(formatterOption(type, min));
256
- if (type === "minute") {
257
- min += props.minuteStep;
258
- } else {
259
- min++;
260
- }
261
- if (min <= val) {
262
- index2++;
263
- }
233
+ ), b(
234
+ () => a.currentDate,
235
+ (e) => {
236
+ JSON.stringify(e) === JSON.stringify(t.modelValue) || o("update:modelValue", e);
264
237
  }
265
- state.selectedValue[columnIndex] = arr[index2].value;
266
- return props.filter ? props.filter(type, arr) : arr;
267
- };
268
- const getDateIndex = (type) => {
269
- if (type === "year") {
270
- return state.currentDate.getFullYear();
271
- } else if (type === "month") {
272
- return state.currentDate.getMonth() + 1;
273
- } else if (type === "day") {
274
- return state.currentDate.getDate();
275
- } else if (type === "hour") {
276
- return state.currentDate.getHours();
277
- } else if (type === "minute") {
278
- return state.currentDate.getMinutes();
279
- } else if (type === "seconds") {
280
- return state.currentDate.getSeconds();
238
+ ), b(
239
+ () => t.title,
240
+ (e) => {
241
+ a.title = e;
281
242
  }
282
- return 0;
283
- };
284
- const closeHandler = (val) => {
285
- emit("cancel", val);
286
- };
287
- const confirm = (val) => {
288
- emit("confirm", val);
289
- };
290
- onBeforeMount(() => {
291
- state.currentDate = formatValue(props.modelValue);
243
+ ), k(V({}, G(a)), {
244
+ changeHandler: Y,
245
+ closeHandler: v,
246
+ confirm: J,
247
+ columns: y
292
248
  });
293
- watch(
294
- () => props.modelValue,
295
- (value) => {
296
- const newValues = formatValue(value);
297
- const isSameValue = JSON.stringify(newValues) === JSON.stringify(state.currentDate);
298
- if (!isSameValue) {
299
- state.currentDate = newValues;
300
- }
301
- }
302
- );
303
- watch(
304
- () => state.currentDate,
305
- (newValues) => {
306
- const isSameValue = JSON.stringify(newValues) === JSON.stringify(props.modelValue);
307
- if (!isSameValue) {
308
- emit("update:modelValue", newValues);
309
- }
310
- }
311
- );
312
- watch(
313
- () => props.title,
314
- (val) => {
315
- state.title = val;
316
- }
317
- );
318
- return {
319
- ...toRefs(state),
320
- changeHandler,
321
- closeHandler,
322
- confirm,
323
- columns
324
- };
325
249
  }
326
250
  });
327
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
328
- const _component_nut_picker = resolveComponent("nut-picker");
329
- return openBlock(), createBlock(_component_nut_picker, {
330
- modelValue: _ctx.selectedValue,
331
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.selectedValue = $event),
332
- okText: _ctx.okText,
333
- cancelText: _ctx.cancelText,
334
- onCancel: _ctx.closeHandler,
335
- columns: _ctx.columns,
336
- onChange: _ctx.changeHandler,
337
- title: _ctx.title,
338
- onConfirm: _ctx.confirm,
339
- threeDimensional: _ctx.threeDimensional,
340
- swipeDuration: _ctx.swipeDuration,
341
- showToolbar: _ctx.showToolbar,
342
- visibleOptionNum: _ctx.visibleOptionNum,
343
- optionHeight: _ctx.optionHeight
251
+ function re(t, o, a, f, g, h) {
252
+ const D = K("nut-picker");
253
+ return Q(), W(D, {
254
+ modelValue: t.selectedValue,
255
+ "onUpdate:modelValue": o[0] || (o[0] = (y) => t.selectedValue = y),
256
+ okText: t.okText,
257
+ cancelText: t.cancelText,
258
+ onCancel: t.closeHandler,
259
+ columns: t.columns,
260
+ onChange: t.changeHandler,
261
+ title: t.title,
262
+ onConfirm: t.confirm,
263
+ threeDimensional: t.threeDimensional,
264
+ swipeDuration: t.swipeDuration,
265
+ showToolbar: t.showToolbar,
266
+ visibleOptionNum: t.visibleOptionNum,
267
+ optionHeight: t.optionHeight
344
268
  }, {
345
- top: withCtx(() => [
346
- renderSlot(_ctx.$slots, "top")
269
+ top: x(() => [
270
+ H(t.$slots, "top")
347
271
  ]),
348
- default: withCtx(() => [
349
- renderSlot(_ctx.$slots, "default")
272
+ default: x(() => [
273
+ H(t.$slots, "default")
350
274
  ]),
351
275
  _: 3
352
276
  }, 8, ["modelValue", "okText", "cancelText", "onCancel", "columns", "onChange", "title", "onConfirm", "threeDimensional", "swipeDuration", "showToolbar", "visibleOptionNum", "optionHeight"]);
353
277
  }
354
- const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
278
+ const he = /* @__PURE__ */ ee(ae, [["render", re]]);
355
279
  export {
356
- index as default
280
+ he as default
357
281
  };