@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,75 +1,57 @@
1
- import { c as createComponent } from "./component-81a4c1d0.js";
2
- import { h } from "vue";
1
+ import { c as g } from "./component-234624bc.js";
2
+ import { h as m } from "vue";
3
3
  import "../locale/lang";
4
- const { componentName, create } = createComponent("config-provider");
5
- const _sfc_main = create({
4
+ const { componentName: v, create: s } = g("config-provider"), $ = s({
6
5
  props: {
7
6
  theme: { type: String, default: "" },
8
- themeVars: { type: Object, default: () => {
9
- } },
7
+ themeVars: { type: Object, default: {} },
10
8
  tag: { type: String, default: "div" }
11
9
  },
12
- setup(props, { slots }) {
13
- const kebabCase = (str) => {
14
- str = str.replace(str.charAt(0), str.charAt(0).toLocaleLowerCase());
15
- return str.replace(/([a-z])([A-Z])/g, (_, p1, p2) => p1 + "-" + p2.toLowerCase());
16
- };
17
- const colorRgb = (str) => {
18
- if (!str)
19
- return;
20
- var sColor = str.toLowerCase();
21
- var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
22
- if (sColor && reg.test(sColor)) {
23
- if (sColor.length === 4) {
24
- var sColorNew = "#";
25
- for (var i = 1; i < 4; i += 1) {
26
- sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1));
10
+ setup(o, { slots: c }) {
11
+ const f = (t) => (t = t.replace(t.charAt(0), t.charAt(0).toLocaleLowerCase()), t.replace(/([a-z])([A-Z])/g, (e, r, n) => r + "-" + n.toLowerCase())), i = (t) => {
12
+ if (t) {
13
+ var e = t.toLowerCase(), r = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/;
14
+ if (e && r.test(e)) {
15
+ if (e.length === 4) {
16
+ for (var n = "#", a = 1; a < 4; a += 1)
17
+ n += e.slice(a, a + 1).concat(e.slice(a, a + 1));
18
+ e = n;
27
19
  }
28
- sColor = sColorNew;
29
- }
30
- var sColorChange = [];
31
- for (var i = 1; i < 7; i += 2) {
32
- sColorChange.push(parseInt("0x" + sColor.slice(i, i + 2)));
20
+ for (var l = [], a = 1; a < 7; a += 2)
21
+ l.push(parseInt("0x" + e.slice(a, a + 2)));
22
+ return l.join(",");
33
23
  }
34
- return sColorChange.join(",");
24
+ return null;
35
25
  }
36
- return null;
37
- };
38
- const mapThemeVarsToCSSVars = (themeVars) => {
39
- var _a;
40
- if (!themeVars)
26
+ }, u = (t) => {
27
+ var n;
28
+ if (!t)
41
29
  return;
42
- const cssVars = {};
43
- const primaryColor = (_a = props == null ? void 0 : props.themeVars) == null ? void 0 : _a.primaryColor;
44
- if (primaryColor) {
45
- cssVars[`--nut-address-region-tab-line`] = `linear-gradient(90deg, ${primaryColor} 0%, rgba(${colorRgb(
46
- primaryColor
47
- )},0.15) 100%) `;
48
- cssVars[`--nut-tabs-horizontal-tab-line-color`] = `linear-gradient(90deg, ${primaryColor} 0%, rgba(${colorRgb(
49
- primaryColor
50
- )},0.15)100%)`;
51
- cssVars[`--nut-tabs-vertical-tab-line-color`] = `linear-gradient(180deg, ${primaryColor} 0%, rgba(${colorRgb(
52
- primaryColor
53
- )},0.15) 100%) `;
54
- }
55
- Object.keys(themeVars).forEach((key) => {
56
- cssVars[`--nut-${kebabCase(key)}`] = themeVars[key];
57
- });
58
- return cssVars;
30
+ const e = {}, r = (n = o == null ? void 0 : o.themeVars) == null ? void 0 : n.primaryColor;
31
+ return r && (e["--nut-address-region-tab-line"] = `linear-gradient(90deg, ${r} 0%, rgba(${i(
32
+ r
33
+ )},0.15) 100%) `, e["--nut-tabs-horizontal-tab-line-color"] = `linear-gradient(90deg, ${r} 0%, rgba(${i(
34
+ r
35
+ )},0.15)100%)`, e["--nut-tabs-vertical-tab-line-color"] = `linear-gradient(180deg, ${r} 0%, rgba(${i(
36
+ r
37
+ )},0.15) 100%) `), Object.keys(t).forEach((a) => {
38
+ e[`--nut-${f(a)}`] = t[a];
39
+ }), e;
59
40
  };
60
41
  return () => {
61
- var _a;
62
- return h(
63
- props.tag,
42
+ var e;
43
+ const t = (e = c.default) == null ? void 0 : e.call(c);
44
+ return m(
45
+ o.tag,
64
46
  {
65
- class: `nut-theme-${props.theme}`,
66
- style: mapThemeVarsToCSSVars(props.themeVars)
47
+ class: `nut-theme-${o.theme}`,
48
+ style: u(o.themeVars)
67
49
  },
68
- (_a = slots.default) == null ? void 0 : _a.call(slots)
50
+ t
69
51
  );
70
52
  };
71
53
  }
72
54
  });
73
55
  export {
74
- _sfc_main as default
56
+ $ as default
75
57
  };
@@ -1,45 +1,50 @@
1
- import { reactive, computed, onBeforeMount, watch, toRefs, openBlock, createElementBlock, normalizeClass, renderSlot } from "vue";
2
- import { p as padZero, c as createComponent } from "./component-81a4c1d0.js";
3
- import { _ as _export_sfc } from "./_plugin-vue_export-helper-cc2b3d55.js";
1
+ var B = Object.defineProperty, k = Object.defineProperties;
2
+ var $ = Object.getOwnPropertyDescriptors;
3
+ var N = Object.getOwnPropertySymbols;
4
+ var L = Object.prototype.hasOwnProperty, x = Object.prototype.propertyIsEnumerable;
5
+ var v = (e, n, r) => n in e ? B(e, n, { enumerable: !0, configurable: !0, writable: !0, value: r }) : e[n] = r, g = (e, n) => {
6
+ for (var r in n || (n = {}))
7
+ L.call(n, r) && v(e, r, n[r]);
8
+ if (N)
9
+ for (var r of N(n))
10
+ x.call(n, r) && v(e, r, n[r]);
11
+ return e;
12
+ }, b = (e, n) => k(e, $(n));
13
+ import { reactive as A, computed as y, onBeforeMount as F, watch as S, toRefs as O, openBlock as M, createElementBlock as H, normalizeClass as R, renderSlot as V } from "vue";
14
+ import { p as d, c as U } from "./component-234624bc.js";
15
+ import { _ as j } from "./_plugin-vue_export-helper-dad06003.js";
4
16
  import "../locale/lang";
5
- const getTimeStamp = (timeStr) => {
6
- if (!timeStr)
17
+ const q = (e) => {
18
+ if (!e)
7
19
  return Date.now();
8
- let t = timeStr;
9
- t = t > 0 ? +t : t.toString().replace(/\-/g, "/");
10
- return new Date(t).getTime();
11
- };
12
- const { componentName, create, translate } = createComponent("countdown");
13
- const _sfc_main = create({
20
+ let n = e;
21
+ return n = n > 0 ? +n : n.toString().replace(/\-/g, "/"), new Date(n).getTime();
22
+ }, { componentName: z, create: I, translate: Y } = U("countdown"), Z = I({
14
23
  props: {
15
24
  modelValue: {
16
25
  type: Object,
17
- default: () => {
18
- return {};
19
- }
26
+ default: () => ({})
20
27
  },
21
28
  paused: {
22
- default: false,
29
+ default: !1,
23
30
  type: Boolean
24
31
  },
25
32
  startTime: {
26
33
  // 可以是服务器当前时间
27
34
  type: [Number, String],
28
- validator(v) {
29
- const dateStr = new Date(v).toString().toLowerCase();
30
- return dateStr !== "invalid date";
35
+ validator(e) {
36
+ return new Date(e).toString().toLowerCase() !== "invalid date";
31
37
  }
32
38
  },
33
39
  endTime: {
34
40
  type: [Number, String],
35
- validator(v) {
36
- const dateStr = new Date(v).toString().toLowerCase();
37
- return dateStr !== "invalid date";
41
+ validator(e) {
42
+ return new Date(e).toString().toLowerCase() !== "invalid date";
38
43
  }
39
44
  },
40
45
  // 是否开启毫秒
41
46
  millisecond: {
42
- default: false,
47
+ default: !1,
43
48
  type: Boolean
44
49
  },
45
50
  // 时间格式化
@@ -49,7 +54,7 @@ const _sfc_main = create({
49
54
  },
50
55
  autoStart: {
51
56
  type: Boolean,
52
- default: true
57
+ default: !0
53
58
  },
54
59
  // 倒计时时长,单位毫秒
55
60
  time: {
@@ -58,198 +63,99 @@ const _sfc_main = create({
58
63
  }
59
64
  },
60
65
  emits: ["input", "on-end", "on-restart", "on-paused", "update:modelValue"],
61
- setup(props, { emit, slots }) {
62
- const state = reactive({
66
+ setup(e, { emit: n, slots: r }) {
67
+ const t = A({
63
68
  restTime: 0,
64
69
  // 倒计时剩余时间时间
65
70
  timer: null,
66
- counting: !props.paused && props.autoStart,
71
+ counting: !e.paused && e.autoStart,
67
72
  // 是否处于倒计时中
68
73
  handleEndTime: Date.now(),
69
74
  // 最终截止时间
70
75
  diffTime: 0
71
76
  // 设置了 startTime 时,与 date.now() 的差异
72
- });
73
- const classes = computed(() => {
74
- const prefixCls = componentName;
75
- return {
76
- [prefixCls]: true
77
- };
78
- });
79
- const renderTime = computed(() => {
80
- return formatRemainTime(state.restTime);
81
- });
82
- const initTime = () => {
83
- state.handleEndTime = props.endTime;
84
- state.diffTime = Date.now() - getTimeStamp(props.startTime);
85
- if (!state.counting)
86
- state.counting = true;
87
- tick();
88
- };
89
- const tick = () => {
90
- if (window !== void 0) {
91
- state.timer = requestAnimationFrame(() => {
92
- if (state.counting) {
93
- const currentTime = Date.now() - state.diffTime;
94
- const remainTime = Math.max(state.handleEndTime - currentTime, 0);
95
- state.restTime = remainTime;
96
- if (!remainTime) {
97
- state.counting = false;
98
- pause();
99
- emit("on-end");
100
- }
101
- if (remainTime > 0) {
102
- tick();
103
- }
104
- }
105
- });
106
- }
107
- };
108
- const formatRemainTime = (t, type) => {
109
- const ts = t;
110
- let rest = {
77
+ }), w = y(() => ({
78
+ [z]: !0
79
+ })), h = y(() => D(t.restTime)), p = () => {
80
+ t.handleEndTime = e.endTime, t.diffTime = Date.now() - q(e.startTime), t.counting || (t.counting = !0), f();
81
+ }, f = () => {
82
+ window !== void 0 && (t.timer = requestAnimationFrame(() => {
83
+ if (t.counting) {
84
+ const o = Date.now() - t.diffTime, i = Math.max(t.handleEndTime - o, 0);
85
+ t.restTime = i, i || (t.counting = !1, T(), n("on-end")), i > 0 && f();
86
+ }
87
+ }));
88
+ }, D = (o, i) => {
89
+ const s = o;
90
+ let l = {
111
91
  d: 0,
112
92
  h: 0,
113
93
  m: 0,
114
94
  s: 0,
115
95
  ms: 0
116
96
  };
117
- const SECOND = 1e3;
118
- const MINUTE = 60 * SECOND;
119
- const HOUR = 60 * MINUTE;
120
- const DAY = 24 * HOUR;
121
- if (ts > 0) {
122
- rest.d = ts >= SECOND ? Math.floor(ts / DAY) : 0;
123
- rest.h = Math.floor(ts % DAY / HOUR);
124
- rest.m = Math.floor(ts % HOUR / MINUTE);
125
- rest.s = Math.floor(ts % MINUTE / SECOND);
126
- rest.ms = Math.floor(ts % SECOND);
127
- }
128
- return type == "custom" ? rest : parseFormat({ ...rest });
129
- };
130
- const parseFormat = (time) => {
131
- let { d, h, m, s, ms } = time;
132
- let format = props.format;
133
- if (format.includes("DD")) {
134
- format = format.replace("DD", padZero(d));
135
- } else {
136
- h += Number(d) * 24;
137
- }
138
- if (format.includes("HH")) {
139
- format = format.replace("HH", padZero(h));
140
- } else {
141
- m += Number(h) * 60;
142
- }
143
- if (format.includes("mm")) {
144
- format = format.replace("mm", padZero(m));
145
- } else {
146
- s += Number(m) * 60;
147
- }
148
- if (format.includes("ss")) {
149
- format = format.replace("ss", padZero(s));
150
- } else {
151
- ms += Number(s) * 1e3;
152
- }
153
- if (format.includes("S")) {
154
- const msC = padZero(ms, 3).toString();
155
- if (format.includes("SSS")) {
156
- format = format.replace("SSS", msC);
157
- } else if (format.includes("SS")) {
158
- format = format.replace("SS", msC.slice(0, 2));
159
- } else if (format.includes("S")) {
160
- format = format.replace("SS", msC.slice(0, 1));
161
- }
162
- }
163
- return format;
164
- };
165
- const start = () => {
166
- if (!state.counting && !props.autoStart) {
167
- state.counting = true;
168
- state.handleEndTime = Date.now() + Number(state.restTime);
169
- tick();
170
- emit("on-restart", state.restTime);
171
- }
172
- };
173
- const pause = () => {
174
- cancelAnimationFrame(state.timer);
175
- state.counting = false;
176
- emit("on-paused", state.restTime);
177
- };
178
- const reset = () => {
179
- if (!props.autoStart) {
180
- pause();
181
- state.restTime = props.time;
182
- }
97
+ const m = 1e3, u = 60 * m, a = 60 * u, c = 24 * a;
98
+ return s > 0 && (l.d = s >= m ? Math.floor(s / c) : 0, l.h = Math.floor(s % c / a), l.m = Math.floor(s % a / u), l.s = Math.floor(s % u / m), l.ms = Math.floor(s % m)), i == "custom" ? l : _(g({}, l));
99
+ }, _ = (o) => {
100
+ let { d: i, h: s, m: l, s: m, ms: u } = o, a = e.format;
101
+ if (a.includes("DD") ? a = a.replace("DD", d(i)) : s += Number(i) * 24, a.includes("HH") ? a = a.replace("HH", d(s)) : l += Number(s) * 60, a.includes("mm") ? a = a.replace("mm", d(l)) : m += Number(l) * 60, a.includes("ss") ? a = a.replace("ss", d(m)) : u += Number(m) * 1e3, a.includes("S")) {
102
+ const c = d(u, 3).toString();
103
+ a.includes("SSS") ? a = a.replace("SSS", c) : a.includes("SS") ? a = a.replace("SS", c.slice(0, 2)) : a.includes("S") && (a = a.replace("SS", c.slice(0, 1)));
104
+ }
105
+ return a;
106
+ }, C = () => {
107
+ !t.counting && !e.autoStart && (t.counting = !0, t.handleEndTime = Date.now() + Number(t.restTime), f(), n("on-restart", t.restTime));
108
+ }, T = () => {
109
+ cancelAnimationFrame(t.timer), t.counting = !1, n("on-paused", t.restTime);
110
+ }, E = () => {
111
+ e.autoStart || (T(), t.restTime = e.time);
183
112
  };
184
- onBeforeMount(() => {
185
- if (props.autoStart) {
186
- initTime();
187
- } else {
188
- state.restTime = props.time;
189
- }
113
+ return F(() => {
114
+ e.autoStart ? p() : t.restTime = e.time;
115
+ }), S(
116
+ () => t.restTime,
117
+ (o) => {
118
+ let i = D(o, "custom");
119
+ n("update:modelValue", i), n("input", i);
120
+ }
121
+ ), S(
122
+ () => e.paused,
123
+ (o, i) => {
124
+ i ? (t.counting || (t.counting = !0, t.handleEndTime = Date.now() + Number(t.restTime), f()), n("on-restart", t.restTime)) : t.counting && T();
125
+ }
126
+ ), S(
127
+ () => e.endTime,
128
+ (o) => {
129
+ p();
130
+ }
131
+ ), S(
132
+ () => e.startTime,
133
+ (o) => {
134
+ p();
135
+ }
136
+ ), b(g({}, O(e)), {
137
+ slots: r,
138
+ classes: w,
139
+ start: C,
140
+ pause: T,
141
+ renderTime: h,
142
+ translate: Y,
143
+ reset: E
190
144
  });
191
- watch(
192
- () => state.restTime,
193
- (value) => {
194
- let tranTime = formatRemainTime(value, "custom");
195
- emit("update:modelValue", tranTime);
196
- emit("input", tranTime);
197
- }
198
- );
199
- watch(
200
- () => props.paused,
201
- (v, ov) => {
202
- if (!ov) {
203
- if (state.counting) {
204
- pause();
205
- }
206
- } else {
207
- if (!state.counting) {
208
- state.counting = true;
209
- state.handleEndTime = Date.now() + Number(state.restTime);
210
- tick();
211
- }
212
- emit("on-restart", state.restTime);
213
- }
214
- }
215
- );
216
- watch(
217
- () => props.endTime,
218
- (value) => {
219
- initTime();
220
- }
221
- );
222
- watch(
223
- () => props.startTime,
224
- (value) => {
225
- initTime();
226
- }
227
- );
228
- return {
229
- ...toRefs(props),
230
- slots,
231
- classes,
232
- start,
233
- pause,
234
- renderTime,
235
- translate,
236
- reset
237
- };
238
145
  }
239
- });
240
- const _hoisted_1 = ["innerHTML"];
241
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
242
- return openBlock(), createElementBlock("view", {
243
- class: normalizeClass(_ctx.classes)
146
+ }), G = ["innerHTML"];
147
+ function J(e, n, r, t, w, h) {
148
+ return M(), H("view", {
149
+ class: R(e.classes)
244
150
  }, [
245
- _ctx.slots.default ? renderSlot(_ctx.$slots, "default", { key: 0 }) : (openBlock(), createElementBlock("view", {
151
+ e.slots.default ? V(e.$slots, "default", { key: 0 }) : (M(), H("view", {
246
152
  key: 1,
247
153
  class: "nut-countdown__content",
248
- innerHTML: _ctx.renderTime
249
- }, null, 8, _hoisted_1))
154
+ innerHTML: e.renderTime
155
+ }, null, 8, G))
250
156
  ], 2);
251
157
  }
252
- const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
158
+ const ee = /* @__PURE__ */ j(Z, [["render", J]]);
253
159
  export {
254
- index as default
160
+ ee as default
255
161
  };