@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,87 +1,57 @@
1
- import { ref, computed, watch, onMounted, getCurrentInstance, provide, openBlock, createElementBlock, normalizeClass, renderSlot } from "vue";
2
- import { c as createComponent } from "./component-81a4c1d0.js";
3
- import { _ as _export_sfc } from "./_plugin-vue_export-helper-cc2b3d55.js";
1
+ import { ref as u, computed as i, watch as d, provide as f, openBlock as p, createElementBlock as m, normalizeClass as v, renderSlot as V } from "vue";
2
+ import { c as y } from "./component-234624bc.js";
3
+ import { _ } from "./_plugin-vue_export-helper-dad06003.js";
4
4
  import "../locale/lang";
5
- const { create, componentName } = createComponent("collapse");
6
- const _sfc_main = create({
5
+ const { create: x, componentName: h } = y("collapse"), w = x({
7
6
  props: {
8
7
  modelValue: {
9
8
  type: [String, Number, Array],
10
- default: () => []
9
+ default: ""
11
10
  },
12
11
  accordion: {
13
12
  type: Boolean,
14
- default: false
13
+ default: !1
15
14
  }
16
15
  },
17
16
  emits: ["update:modelValue", "change"],
18
- setup(props, { emit }) {
19
- const collapseDom = ref(null);
20
- const collapseChldren = ref([]);
21
- const classes = computed(() => {
22
- const prefixCls = componentName;
23
- return {
24
- [prefixCls]: true
25
- };
17
+ setup(a, { emit: t }) {
18
+ const c = u(null), l = u(a.modelValue || (a.accordion ? "" : [])), n = i(() => ({
19
+ [h]: !0
20
+ }));
21
+ d(() => a.modelValue, (e) => {
22
+ l.value = e;
26
23
  });
27
- watch(
28
- () => props.modelValue,
29
- (newval) => {
30
- let doms = collapseChldren.value;
31
- Array.from(doms).forEach((item) => {
32
- if (typeof newval == "number" || typeof newval == "string") {
33
- item.changeOpen(newval == item.name ? true : false);
34
- } else if (Object.values(newval) instanceof Array) {
35
- const isOpen = newval.indexOf(Number(item.name)) > -1 || newval.indexOf(String(item.name)) > -1;
36
- item.changeOpen(isOpen);
37
- }
38
- item.animation();
39
- });
40
- }
41
- );
42
- onMounted(() => {
43
- collapseChldren.value = getCurrentInstance().provides.collapseParent.children || [];
44
- });
45
- const changeVal = (val) => {
46
- emit("update:modelValue", val);
47
- emit("change", val);
48
- };
49
- const changeValAry = (name) => {
50
- const activeItem = props.modelValue instanceof Object ? Object.values(props.modelValue) : props.modelValue;
51
- let index2 = -1;
52
- activeItem.forEach((item, idx) => {
53
- if (String(item) == String(name)) {
54
- index2 = idx;
55
- }
56
- });
57
- index2 > -1 ? activeItem.splice(index2, 1) : activeItem.push(name);
58
- changeVal(activeItem);
24
+ const o = (e, r, s = !0) => {
25
+ l.value = e, t("update:modelValue", e), t("change", e, r, s);
59
26
  };
60
- const isExpanded = (name) => {
61
- const { accordion, modelValue } = props;
62
- if (accordion) {
63
- return typeof modelValue === "number" || typeof modelValue === "string" ? modelValue == name : false;
64
- }
65
- };
66
- provide("collapseParent", {
67
- children: [],
68
- props,
69
- changeValAry,
70
- changeVal,
71
- isExpanded
72
- });
73
- return { collapseDom, classes };
27
+ return f("collapseParent", {
28
+ updateVal: (e) => {
29
+ if (a.accordion)
30
+ l.value === e ? o("", e, !1) : o(e, e, !0);
31
+ else if (Array.isArray(l.value))
32
+ if (l.value.includes(e)) {
33
+ const r = l.value.filter((s) => s !== e);
34
+ o(r, e, !1);
35
+ } else {
36
+ const r = l.value.concat([e]);
37
+ o(r, e, !0);
38
+ }
39
+ else
40
+ console.warn("[NutUI] <Collapse> 未开启手风琴模式时 v-model 应为数组");
41
+ },
42
+ isExpanded: (e) => a.accordion ? l.value === e : Array.isArray(l.value) ? l.value.includes(e) : !1
43
+ }), { collapseDom: c, classes: n };
74
44
  }
75
45
  });
76
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
77
- return openBlock(), createElementBlock("view", {
78
- class: normalizeClass(_ctx.classes),
46
+ function A(a, t, c, l, n, o) {
47
+ return p(), m("view", {
48
+ class: v(a.classes),
79
49
  ref: "collapseDom"
80
50
  }, [
81
- renderSlot(_ctx.$slots, "default")
51
+ V(a.$slots, "default")
82
52
  ], 2);
83
53
  }
84
- const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
54
+ const k = /* @__PURE__ */ _(w, [["render", A]]);
85
55
  export {
86
- index as default
56
+ k as default
87
57
  };
@@ -1,11 +1,10 @@
1
- import { inject, reactive, computed, getCurrentInstance, ref, watch, onMounted, toRefs, nextTick, openBlock, createElementBlock, normalizeClass, createElementVNode, renderSlot, toDisplayString, createCommentVNode, normalizeStyle, createBlock, resolveDynamicComponent } from "vue";
2
- import { DownArrow } from "@nutui/icons-vue";
3
- import { c as createComponent } from "./component-81a4c1d0.js";
4
- import { r as renderIcon } from "./renderIcon-3d0fd47c.js";
5
- import { _ as _export_sfc } from "./_plugin-vue_export-helper-cc2b3d55.js";
1
+ import { ref as d, inject as k, reactive as H, computed as g, watch as S, openBlock as n, createElementBlock as i, normalizeClass as m, createElementVNode as o, renderSlot as c, toDisplayString as T, createCommentVNode as w, normalizeStyle as h, createBlock as C, resolveDynamicComponent as E } from "vue";
2
+ import { DownArrow as R } from "@nutui/icons-vue";
3
+ import { c as q } from "./component-234624bc.js";
4
+ import { r as A } from "./renderIcon-47498b32.js";
5
+ import { _ as B } from "./_plugin-vue_export-helper-dad06003.js";
6
6
  import "../locale/lang";
7
- const { create, componentName } = createComponent("collapse-item");
8
- const _sfc_main = create({
7
+ const { create: N, componentName: F } = q("collapse-item"), L = N({
9
8
  props: {
10
9
  collapseRef: {
11
10
  type: Object
@@ -24,226 +23,134 @@ const _sfc_main = create({
24
23
  },
25
24
  disabled: {
26
25
  type: Boolean,
27
- default: false
26
+ default: !1
28
27
  },
29
28
  name: {
30
29
  type: [Number, String],
31
30
  default: -1,
32
- required: true
31
+ required: !0
33
32
  },
34
33
  border: {
35
34
  type: Boolean,
36
- default: true
35
+ default: !0
37
36
  },
38
37
  icon: {
39
38
  type: Object,
40
- default: () => DownArrow
39
+ default: () => R
41
40
  },
42
41
  rotate: {
43
42
  type: [String, Number],
44
43
  default: 180
45
44
  }
46
45
  },
47
- // components: { DownArrow },
48
- setup(props, ctx) {
49
- const collapse = inject("collapseParent");
50
- const parent = reactive(collapse);
51
- const classes = computed(() => {
52
- const prefixCls = componentName;
46
+ setup(e) {
47
+ const s = d(null), p = d(null), f = k("collapseParent"), u = H(f), _ = g(() => {
48
+ const t = F;
53
49
  return {
54
- [prefixCls]: true,
55
- [prefixCls + "__border"]: props.border
50
+ [t]: !0,
51
+ [t + "__border"]: e.border
56
52
  };
57
- });
58
- const relation = (child) => {
59
- if (child.proxy) {
60
- parent.children.push(child.proxy);
61
- }
62
- };
63
- relation(getCurrentInstance());
64
- const proxyData = reactive({
65
- openExpanded: false
66
- });
67
- const wrapperRef = ref(null);
68
- const contentRef = ref(null);
69
- const onTransitionEnd = () => {
70
- const wrapperRefEle = document.getElementsByClassName("nut-collapse__item-wrapper")[0];
71
- if (wrapperRefEle) {
72
- wrapperRefEle.style.willChange = "auto";
73
- }
74
- };
75
- const animation = () => {
76
- const wrapperRefEle = wrapperRef.value;
77
- const contentRefEle = contentRef.value;
78
- if (!wrapperRefEle || !contentRefEle) {
79
- return;
80
- }
81
- const offsetHeight = contentRefEle.offsetHeight || "auto";
82
- if (offsetHeight) {
83
- const contentHeight = `${offsetHeight}px`;
84
- wrapperRefEle.style.willChange = "height";
85
- wrapperRefEle.style.height = !proxyData.openExpanded ? 0 : contentHeight;
86
- }
87
- if (!proxyData.openExpanded) {
88
- onTransitionEnd();
89
- }
90
- };
91
- const open = () => {
92
- proxyData.openExpanded = !proxyData.openExpanded;
93
- animation();
94
- };
95
- const defaultOpen = () => {
96
- open();
97
- };
98
- const currentName = computed(() => props.name);
99
- const toggleOpen = () => {
100
- if (parent.props.accordion) {
101
- nextTick(() => {
102
- if (currentName.value == parent.props.modelValue) {
103
- open();
104
- } else {
105
- parent.changeVal(currentName.value);
106
- }
53
+ }), l = g(() => u ? u.isExpanded(e.name) : !1), a = d(l.value ? "auto" : "0px"), y = () => {
54
+ u.updateVal(e.name);
55
+ }, b = () => {
56
+ l.value && (a.value = "auto");
57
+ }, v = () => {
58
+ a.value = "0px", requestAnimationFrame(() => {
59
+ requestAnimationFrame(() => {
60
+ var r;
61
+ const t = (r = p.value) == null ? void 0 : r.offsetHeight;
62
+ a.value = t ? `${t}px` : "auto";
107
63
  });
108
- } else {
109
- parent.changeValAry(String(props.name));
110
- open();
111
- }
112
- };
113
- const changeOpen = (bol) => {
114
- proxyData.openExpanded = bol;
115
- };
116
- const expanded = computed(() => {
117
- if (parent) {
118
- return parent.isExpanded(props.name);
119
- }
120
- return null;
121
- });
122
- watch(expanded, (value, oldValue) => {
123
- if (value) {
124
- proxyData.openExpanded = true;
125
- }
126
- });
127
- const init = () => {
128
- const { name } = props;
129
- const active = parent && parent.props.modelValue;
130
- nextTick(() => {
131
- if (typeof active == "number" || typeof active == "string") {
132
- if (name == active) {
133
- defaultOpen();
134
- }
135
- } else if (Object.values(active) instanceof Array) {
136
- const f = Object.values(active).filter((item) => item == name);
137
- if (f.length > 0) {
138
- defaultOpen();
139
- }
140
- }
141
- });
142
- };
143
- onMounted(() => {
144
- var observer = new MutationObserver(() => {
145
- animation();
146
64
  });
147
- const ele = document.getElementsByClassName("nut-collapse__item-wrapper")[0];
148
- if (ele) {
149
- observer.observe(ele, {
150
- childList: true,
151
- subtree: true
65
+ }, $ = () => {
66
+ var r;
67
+ const t = (r = p.value) == null ? void 0 : r.offsetHeight;
68
+ a.value = t ? `${t}px` : "auto", requestAnimationFrame(() => {
69
+ requestAnimationFrame(() => {
70
+ a.value = "0px";
152
71
  });
153
- }
154
- init();
155
- });
156
- const emptyContent = computed(() => {
157
- let ele = contentRef.value;
158
- let _class = "";
159
- if (!(ele == null ? void 0 : ele.innerText)) {
160
- _class = "nut-collapse__item-wrapper__content--empty";
161
- }
162
- return _class;
163
- });
164
- return {
165
- classes,
166
- emptyContent,
167
- ...toRefs(proxyData),
168
- renderIcon,
169
- wrapperRef,
170
- contentRef,
171
- open,
172
- toggleOpen,
173
- changeOpen,
174
- animation
72
+ });
73
+ };
74
+ return S(l, (t) => {
75
+ t ? v() : $();
76
+ }), {
77
+ classes: _,
78
+ renderIcon: A,
79
+ wrapperRef: s,
80
+ contentRef: p,
81
+ open: v,
82
+ toggle: y,
83
+ wrapperHeight: a,
84
+ expanded: l,
85
+ onTransitionEnd: b
175
86
  };
176
87
  }
177
- });
178
- const _hoisted_1 = { class: "nut-collapse-item__title-main" };
179
- const _hoisted_2 = { class: "nut-collapse-item__title-main-value" };
180
- const _hoisted_3 = ["innerHTML"];
181
- const _hoisted_4 = {
88
+ }), M = { class: "nut-collapse-item__title-main" }, j = { class: "nut-collapse-item__title-main-value" }, D = ["innerHTML"], V = {
182
89
  key: 2,
183
90
  class: "nut-collapse-item__title-label"
184
- };
185
- const _hoisted_5 = {
91
+ }, z = {
186
92
  key: 0,
187
93
  class: "nut-collapse-item__title-sub"
188
- };
189
- const _hoisted_6 = ["innerHTML"];
190
- const _hoisted_7 = {
94
+ }, I = ["innerHTML"], O = {
191
95
  key: 0,
192
96
  class: "nut-collapse__item-extraWrapper"
97
+ }, W = { class: "nut-collapse__item-extraWrapper__extraRender" }, P = {
98
+ class: "nut-collapse__item-wrapper__content",
99
+ ref: "contentRef"
193
100
  };
194
- const _hoisted_8 = { class: "nut-collapse__item-extraWrapper__extraRender" };
195
- const _hoisted_9 = {
196
- class: "nut-collapse__item-wrapper",
197
- ref: "wrapperRef"
198
- };
199
- function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
200
- return openBlock(), createElementBlock("view", {
201
- class: normalizeClass(_ctx.classes)
101
+ function G(e, s, p, f, u, _) {
102
+ return n(), i("view", {
103
+ class: m(e.classes)
202
104
  }, [
203
- createElementVNode("view", {
204
- class: normalizeClass(["nut-collapse-item__title", { "nut-collapse-item__title--disabled": _ctx.disabled }]),
205
- onClick: _cache[0] || (_cache[0] = (...args) => _ctx.toggleOpen && _ctx.toggleOpen(...args))
105
+ o("view", {
106
+ class: m(["nut-collapse-item__title", { "nut-collapse-item__title--disabled": e.disabled }]),
107
+ onClick: s[0] || (s[0] = (...l) => e.toggle && e.toggle(...l))
206
108
  }, [
207
- createElementVNode("view", _hoisted_1, [
208
- createElementVNode("view", _hoisted_2, [
209
- _ctx.$slots.title ? renderSlot(_ctx.$slots, "title", { key: 0 }) : (openBlock(), createElementBlock("view", {
109
+ o("view", M, [
110
+ o("view", j, [
111
+ e.$slots.title ? c(e.$slots, "title", { key: 0 }) : (n(), i("view", {
210
112
  key: 1,
211
- innerHTML: _ctx.title,
113
+ innerHTML: e.title,
212
114
  class: "nut-collapse-item__title-mtitle"
213
- }, null, 8, _hoisted_3)),
214
- _ctx.label ? (openBlock(), createElementBlock("view", _hoisted_4, toDisplayString(_ctx.label), 1)) : createCommentVNode("", true)
115
+ }, null, 8, D)),
116
+ e.label ? (n(), i("view", V, T(e.label), 1)) : w("", !0)
215
117
  ])
216
118
  ]),
217
- _ctx.$slots.value ? (openBlock(), createElementBlock("view", _hoisted_5, [
218
- renderSlot(_ctx.$slots, "value")
219
- ])) : (openBlock(), createElementBlock("view", {
119
+ e.$slots.value ? (n(), i("view", z, [
120
+ c(e.$slots, "value")
121
+ ])) : (n(), i("view", {
220
122
  key: 1,
221
- innerHTML: _ctx.value,
123
+ innerHTML: e.value,
222
124
  class: "nut-collapse-item__title-sub"
223
- }, null, 8, _hoisted_6)),
224
- createElementVNode("view", {
225
- class: normalizeClass(["nut-collapse-item__title-icon", { "nut-collapse-item__title-icon--expanded": _ctx.openExpanded }]),
226
- style: normalizeStyle({ transform: "rotate(" + (_ctx.openExpanded ? _ctx.rotate : 0) + "deg)" })
125
+ }, null, 8, I)),
126
+ o("view", {
127
+ class: m(["nut-collapse-item__title-icon", { "nut-collapse-item__title-icon--expanded": e.expanded }]),
128
+ style: h({ transform: "rotate(" + (e.expanded ? e.rotate : 0) + "deg)" })
227
129
  }, [
228
- (openBlock(), createBlock(resolveDynamicComponent(_ctx.renderIcon(_ctx.icon))))
130
+ (n(), C(E(e.renderIcon(e.icon))))
229
131
  ], 6)
230
132
  ], 2),
231
- _ctx.$slots.extra ? (openBlock(), createElementBlock("view", _hoisted_7, [
232
- createElementVNode("div", _hoisted_8, [
233
- renderSlot(_ctx.$slots, "extra")
133
+ e.$slots.extra ? (n(), i("view", O, [
134
+ o("div", W, [
135
+ c(e.$slots, "extra")
234
136
  ])
235
- ])) : createCommentVNode("", true),
236
- createElementVNode("view", _hoisted_9, [
237
- createElementVNode("view", {
238
- class: normalizeClass(["nut-collapse__item-wrapper__content", _ctx.emptyContent]),
239
- ref: "contentRef"
240
- }, [
241
- renderSlot(_ctx.$slots, "default")
242
- ], 2)
243
- ], 512)
137
+ ])) : w("", !0),
138
+ o("view", {
139
+ class: "nut-collapse__item-wrapper",
140
+ ref: "wrapperRef",
141
+ style: h({
142
+ willChange: "height",
143
+ height: e.wrapperHeight
144
+ }),
145
+ onTransitionend: s[1] || (s[1] = (...l) => e.onTransitionEnd && e.onTransitionEnd(...l))
146
+ }, [
147
+ o("view", P, [
148
+ c(e.$slots, "default")
149
+ ], 512)
150
+ ], 36)
244
151
  ], 2);
245
152
  }
246
- const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
153
+ const Z = /* @__PURE__ */ B(L, [["render", G]]);
247
154
  export {
248
- index as default
155
+ Z as default
249
156
  };