wssf-kage-ui 0.1.0 → 0.1.2

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 (306) hide show
  1. package/README.md +4 -4
  2. package/dist/cjs/Anchor/index.d.ts +56 -0
  3. package/dist/cjs/Anchor/index.js +307 -0
  4. package/dist/cjs/Anchor/style.less +183 -0
  5. package/dist/cjs/AutoComplete/index.d.ts +54 -0
  6. package/dist/cjs/AutoComplete/index.js +273 -0
  7. package/dist/cjs/AutoComplete/style.less +325 -0
  8. package/dist/cjs/Avatar/index.d.ts +47 -0
  9. package/dist/cjs/Avatar/index.js +147 -0
  10. package/dist/cjs/Avatar/style.less +193 -0
  11. package/dist/cjs/Badge/index.d.ts +48 -0
  12. package/dist/cjs/Badge/index.js +141 -0
  13. package/dist/cjs/Badge/style.less +237 -0
  14. package/dist/cjs/Breadcrumb/index.d.ts +51 -0
  15. package/dist/cjs/Breadcrumb/index.js +129 -0
  16. package/dist/cjs/Breadcrumb/style.less +96 -0
  17. package/dist/cjs/Calendar/index.d.ts +33 -0
  18. package/dist/cjs/Calendar/index.js +296 -0
  19. package/dist/cjs/Calendar/style.less +384 -0
  20. package/dist/cjs/Card/index.d.ts +68 -0
  21. package/dist/cjs/Card/index.js +155 -0
  22. package/dist/cjs/Card/style.less +356 -0
  23. package/dist/cjs/Carousel/index.d.ts +33 -0
  24. package/dist/cjs/Carousel/index.js +169 -0
  25. package/dist/cjs/Carousel/style.less +232 -0
  26. package/dist/cjs/Cascader/index.d.ts +53 -0
  27. package/dist/cjs/Cascader/index.js +338 -0
  28. package/dist/cjs/Cascader/style.less +457 -0
  29. package/dist/cjs/Checkbox/index.d.ts +52 -0
  30. package/dist/cjs/Checkbox/index.js +158 -0
  31. package/dist/cjs/Checkbox/style.less +211 -0
  32. package/dist/cjs/Collapse/index.d.ts +55 -0
  33. package/dist/cjs/Collapse/index.js +191 -0
  34. package/dist/cjs/Collapse/style.less +217 -0
  35. package/dist/cjs/ColorPicker/index.d.ts +28 -0
  36. package/dist/cjs/ColorPicker/index.js +381 -0
  37. package/dist/cjs/ColorPicker/style.less +276 -0
  38. package/dist/cjs/DatePicker/index.d.ts +32 -0
  39. package/dist/cjs/DatePicker/index.js +377 -0
  40. package/dist/cjs/DatePicker/style.less +498 -0
  41. package/dist/cjs/Descriptions/index.d.ts +54 -0
  42. package/dist/cjs/Descriptions/index.js +181 -0
  43. package/dist/cjs/Descriptions/style.less +259 -0
  44. package/dist/cjs/Divider/index.d.ts +24 -0
  45. package/dist/cjs/Divider/index.js +75 -0
  46. package/dist/cjs/Divider/style.less +144 -0
  47. package/dist/cjs/Dropdown/index.d.ts +88 -0
  48. package/dist/cjs/Dropdown/index.js +253 -0
  49. package/dist/cjs/Dropdown/style.less +430 -0
  50. package/dist/cjs/Empty/index.d.ts +21 -0
  51. package/dist/cjs/Empty/index.js +115 -0
  52. package/dist/cjs/Empty/style.less +103 -0
  53. package/dist/cjs/Flex/index.d.ts +37 -0
  54. package/dist/cjs/Flex/index.js +76 -0
  55. package/dist/cjs/Flex/style.less +13 -0
  56. package/dist/cjs/Form/index.d.ts +89 -0
  57. package/dist/cjs/Form/index.js +421 -0
  58. package/dist/cjs/Form/style.less +203 -0
  59. package/dist/cjs/Grid/index.d.ts +69 -0
  60. package/dist/cjs/Grid/index.js +171 -0
  61. package/dist/cjs/Grid/style.less +273 -0
  62. package/dist/cjs/Image/index.d.ts +30 -0
  63. package/dist/cjs/Image/index.js +153 -0
  64. package/dist/cjs/Image/style.less +156 -0
  65. package/dist/cjs/Input/index.d.ts +24 -0
  66. package/dist/cjs/Input/index.js +158 -0
  67. package/dist/cjs/Input/style.less +276 -0
  68. package/dist/cjs/InputNumber/index.d.ts +47 -0
  69. package/dist/cjs/InputNumber/index.js +323 -0
  70. package/dist/cjs/InputNumber/style.less +392 -0
  71. package/dist/cjs/Layout/index.d.ts +74 -0
  72. package/dist/cjs/Layout/index.js +166 -0
  73. package/dist/cjs/Layout/style.less +145 -0
  74. package/dist/cjs/Masonry/index.d.ts +18 -0
  75. package/dist/cjs/Masonry/index.js +146 -0
  76. package/dist/cjs/Masonry/style.less +15 -0
  77. package/dist/cjs/Mentions/index.d.ts +57 -0
  78. package/dist/cjs/Mentions/index.js +378 -0
  79. package/dist/cjs/Mentions/style.less +297 -0
  80. package/dist/cjs/Menu/index.d.ts +87 -0
  81. package/dist/cjs/Menu/index.js +306 -0
  82. package/dist/cjs/Menu/style.less +363 -0
  83. package/dist/cjs/Pagination/index.d.ts +38 -0
  84. package/dist/cjs/Pagination/index.js +255 -0
  85. package/dist/cjs/Pagination/style.less +353 -0
  86. package/dist/cjs/Popover/index.d.ts +30 -0
  87. package/dist/cjs/Popover/index.js +131 -0
  88. package/dist/cjs/Popover/style.less +279 -0
  89. package/dist/cjs/QRCode/index.d.ts +30 -0
  90. package/dist/cjs/QRCode/index.js +167 -0
  91. package/dist/cjs/QRCode/style.less +201 -0
  92. package/dist/cjs/Radio/index.d.ts +70 -0
  93. package/dist/cjs/Radio/index.js +199 -0
  94. package/dist/cjs/Radio/style.less +326 -0
  95. package/dist/cjs/Rate/index.d.ts +37 -0
  96. package/dist/cjs/Rate/index.js +151 -0
  97. package/dist/cjs/Rate/style.less +170 -0
  98. package/dist/cjs/Segmented/index.d.ts +31 -0
  99. package/dist/cjs/Segmented/index.js +121 -0
  100. package/dist/cjs/Segmented/style.less +167 -0
  101. package/dist/cjs/Select/index.d.ts +67 -0
  102. package/dist/cjs/Select/index.js +403 -0
  103. package/dist/cjs/Select/style.less +523 -0
  104. package/dist/cjs/Slider/index.d.ts +41 -0
  105. package/dist/cjs/Slider/index.js +325 -0
  106. package/dist/cjs/Slider/style.less +287 -0
  107. package/dist/cjs/Space/index.d.ts +41 -0
  108. package/dist/cjs/Space/index.js +137 -0
  109. package/dist/cjs/Space/style.less +116 -0
  110. package/dist/cjs/Splitter/index.d.ts +43 -0
  111. package/dist/cjs/Splitter/index.js +219 -0
  112. package/dist/cjs/Splitter/style.less +99 -0
  113. package/dist/cjs/Statistic/index.d.ts +26 -0
  114. package/dist/cjs/Statistic/index.js +71 -0
  115. package/dist/cjs/Statistic/style.less +94 -0
  116. package/dist/cjs/Steps/index.d.ts +58 -0
  117. package/dist/cjs/Steps/index.js +180 -0
  118. package/dist/cjs/Steps/style.less +507 -0
  119. package/dist/cjs/Switch/index.d.ts +28 -0
  120. package/dist/cjs/Switch/index.js +71 -0
  121. package/dist/cjs/Switch/style.less +212 -0
  122. package/dist/cjs/Table/index.d.ts +188 -0
  123. package/dist/cjs/Table/index.js +787 -0
  124. package/dist/cjs/Table/style.less +663 -0
  125. package/dist/cjs/Tabs/index.d.ts +58 -0
  126. package/dist/cjs/Tabs/index.js +196 -0
  127. package/dist/cjs/Tabs/style.less +423 -0
  128. package/dist/cjs/Tag/index.d.ts +51 -0
  129. package/dist/cjs/Tag/index.js +142 -0
  130. package/dist/cjs/Tag/style.less +356 -0
  131. package/dist/cjs/TimePicker/index.d.ts +51 -0
  132. package/dist/cjs/TimePicker/index.js +332 -0
  133. package/dist/cjs/TimePicker/style.less +384 -0
  134. package/dist/cjs/Timeline/index.d.ts +47 -0
  135. package/dist/cjs/Timeline/index.js +127 -0
  136. package/dist/cjs/Timeline/style.less +265 -0
  137. package/dist/cjs/Tooltip/index.d.ts +53 -0
  138. package/dist/cjs/Tooltip/index.js +468 -0
  139. package/dist/cjs/Tooltip/style.less +237 -0
  140. package/dist/cjs/Transfer/index.d.ts +52 -0
  141. package/dist/cjs/Transfer/index.js +344 -0
  142. package/dist/cjs/Transfer/style.less +331 -0
  143. package/dist/cjs/TreeSelect/index.d.ts +54 -0
  144. package/dist/cjs/TreeSelect/index.js +373 -0
  145. package/dist/cjs/TreeSelect/style.less +471 -0
  146. package/dist/cjs/Typography/index.d.ts +102 -0
  147. package/dist/cjs/Typography/index.js +168 -0
  148. package/dist/cjs/Typography/style.less +246 -0
  149. package/dist/cjs/Upload/index.d.ts +65 -0
  150. package/dist/cjs/Upload/index.js +517 -0
  151. package/dist/cjs/Upload/style.less +424 -0
  152. package/dist/cjs/index.d.ts +100 -0
  153. package/dist/cjs/index.js +487 -1
  154. package/dist/esm/Anchor/index.d.ts +56 -0
  155. package/dist/esm/Anchor/index.js +302 -0
  156. package/dist/esm/Anchor/style.less +183 -0
  157. package/dist/esm/AutoComplete/index.d.ts +54 -0
  158. package/dist/esm/AutoComplete/index.js +268 -0
  159. package/dist/esm/AutoComplete/style.less +325 -0
  160. package/dist/esm/Avatar/index.d.ts +47 -0
  161. package/dist/esm/Avatar/index.js +142 -0
  162. package/dist/esm/Avatar/style.less +193 -0
  163. package/dist/esm/Badge/index.d.ts +48 -0
  164. package/dist/esm/Badge/index.js +137 -0
  165. package/dist/esm/Badge/style.less +237 -0
  166. package/dist/esm/Breadcrumb/index.d.ts +51 -0
  167. package/dist/esm/Breadcrumb/index.js +124 -0
  168. package/dist/esm/Breadcrumb/style.less +96 -0
  169. package/dist/esm/Calendar/index.d.ts +33 -0
  170. package/dist/esm/Calendar/index.js +291 -0
  171. package/dist/esm/Calendar/style.less +384 -0
  172. package/dist/esm/Card/index.d.ts +68 -0
  173. package/dist/esm/Card/index.js +149 -0
  174. package/dist/esm/Card/style.less +356 -0
  175. package/dist/esm/Carousel/index.d.ts +33 -0
  176. package/dist/esm/Carousel/index.js +163 -0
  177. package/dist/esm/Carousel/style.less +232 -0
  178. package/dist/esm/Cascader/index.d.ts +53 -0
  179. package/dist/esm/Cascader/index.js +333 -0
  180. package/dist/esm/Cascader/style.less +457 -0
  181. package/dist/esm/Checkbox/index.d.ts +52 -0
  182. package/dist/esm/Checkbox/index.js +152 -0
  183. package/dist/esm/Checkbox/style.less +211 -0
  184. package/dist/esm/Collapse/index.d.ts +55 -0
  185. package/dist/esm/Collapse/index.js +187 -0
  186. package/dist/esm/Collapse/style.less +217 -0
  187. package/dist/esm/ColorPicker/index.d.ts +28 -0
  188. package/dist/esm/ColorPicker/index.js +375 -0
  189. package/dist/esm/ColorPicker/style.less +276 -0
  190. package/dist/esm/DatePicker/index.d.ts +32 -0
  191. package/dist/esm/DatePicker/index.js +371 -0
  192. package/dist/esm/DatePicker/style.less +498 -0
  193. package/dist/esm/Descriptions/index.d.ts +54 -0
  194. package/dist/esm/Descriptions/index.js +179 -0
  195. package/dist/esm/Descriptions/style.less +259 -0
  196. package/dist/esm/Divider/index.d.ts +24 -0
  197. package/dist/esm/Divider/index.js +68 -0
  198. package/dist/esm/Divider/style.less +144 -0
  199. package/dist/esm/Dropdown/index.d.ts +88 -0
  200. package/dist/esm/Dropdown/index.js +249 -0
  201. package/dist/esm/Dropdown/style.less +430 -0
  202. package/dist/esm/Empty/index.d.ts +21 -0
  203. package/dist/esm/Empty/index.js +109 -0
  204. package/dist/esm/Empty/style.less +103 -0
  205. package/dist/esm/Flex/index.d.ts +37 -0
  206. package/dist/esm/Flex/index.js +69 -0
  207. package/dist/esm/Flex/style.less +13 -0
  208. package/dist/esm/Form/index.d.ts +89 -0
  209. package/dist/esm/Form/index.js +416 -0
  210. package/dist/esm/Form/style.less +203 -0
  211. package/dist/esm/Grid/index.d.ts +69 -0
  212. package/dist/esm/Grid/index.js +165 -0
  213. package/dist/esm/Grid/style.less +273 -0
  214. package/dist/esm/Image/index.d.ts +30 -0
  215. package/dist/esm/Image/index.js +149 -0
  216. package/dist/esm/Image/style.less +156 -0
  217. package/dist/esm/Input/index.d.ts +24 -0
  218. package/dist/esm/Input/index.js +151 -0
  219. package/dist/esm/Input/style.less +276 -0
  220. package/dist/esm/InputNumber/index.d.ts +47 -0
  221. package/dist/esm/InputNumber/index.js +316 -0
  222. package/dist/esm/InputNumber/style.less +392 -0
  223. package/dist/esm/Layout/index.d.ts +74 -0
  224. package/dist/esm/Layout/index.js +161 -0
  225. package/dist/esm/Layout/style.less +145 -0
  226. package/dist/esm/Masonry/index.d.ts +18 -0
  227. package/dist/esm/Masonry/index.js +138 -0
  228. package/dist/esm/Masonry/style.less +15 -0
  229. package/dist/esm/Mentions/index.d.ts +57 -0
  230. package/dist/esm/Mentions/index.js +374 -0
  231. package/dist/esm/Mentions/style.less +297 -0
  232. package/dist/esm/Menu/index.d.ts +87 -0
  233. package/dist/esm/Menu/index.js +301 -0
  234. package/dist/esm/Menu/style.less +363 -0
  235. package/dist/esm/Pagination/index.d.ts +38 -0
  236. package/dist/esm/Pagination/index.js +247 -0
  237. package/dist/esm/Pagination/style.less +353 -0
  238. package/dist/esm/Popover/index.d.ts +30 -0
  239. package/dist/esm/Popover/index.js +126 -0
  240. package/dist/esm/Popover/style.less +279 -0
  241. package/dist/esm/QRCode/index.d.ts +30 -0
  242. package/dist/esm/QRCode/index.js +158 -0
  243. package/dist/esm/QRCode/style.less +201 -0
  244. package/dist/esm/Radio/index.d.ts +70 -0
  245. package/dist/esm/Radio/index.js +193 -0
  246. package/dist/esm/Radio/style.less +326 -0
  247. package/dist/esm/Rate/index.d.ts +37 -0
  248. package/dist/esm/Rate/index.js +143 -0
  249. package/dist/esm/Rate/style.less +170 -0
  250. package/dist/esm/Segmented/index.d.ts +31 -0
  251. package/dist/esm/Segmented/index.js +113 -0
  252. package/dist/esm/Segmented/style.less +167 -0
  253. package/dist/esm/Select/index.d.ts +67 -0
  254. package/dist/esm/Select/index.js +398 -0
  255. package/dist/esm/Select/style.less +523 -0
  256. package/dist/esm/Slider/index.d.ts +41 -0
  257. package/dist/esm/Slider/index.js +318 -0
  258. package/dist/esm/Slider/style.less +287 -0
  259. package/dist/esm/Space/index.d.ts +41 -0
  260. package/dist/esm/Space/index.js +131 -0
  261. package/dist/esm/Space/style.less +116 -0
  262. package/dist/esm/Splitter/index.d.ts +43 -0
  263. package/dist/esm/Splitter/index.js +214 -0
  264. package/dist/esm/Splitter/style.less +99 -0
  265. package/dist/esm/Statistic/index.d.ts +26 -0
  266. package/dist/esm/Statistic/index.js +65 -0
  267. package/dist/esm/Statistic/style.less +94 -0
  268. package/dist/esm/Steps/index.d.ts +58 -0
  269. package/dist/esm/Steps/index.js +174 -0
  270. package/dist/esm/Steps/style.less +507 -0
  271. package/dist/esm/Switch/index.d.ts +28 -0
  272. package/dist/esm/Switch/index.js +63 -0
  273. package/dist/esm/Switch/style.less +212 -0
  274. package/dist/esm/Table/index.d.ts +188 -0
  275. package/dist/esm/Table/index.js +797 -0
  276. package/dist/esm/Table/style.less +663 -0
  277. package/dist/esm/Tabs/index.d.ts +58 -0
  278. package/dist/esm/Tabs/index.js +193 -0
  279. package/dist/esm/Tabs/style.less +423 -0
  280. package/dist/esm/Tag/index.d.ts +51 -0
  281. package/dist/esm/Tag/index.js +144 -0
  282. package/dist/esm/Tag/style.less +356 -0
  283. package/dist/esm/TimePicker/index.d.ts +51 -0
  284. package/dist/esm/TimePicker/index.js +327 -0
  285. package/dist/esm/TimePicker/style.less +384 -0
  286. package/dist/esm/Timeline/index.d.ts +47 -0
  287. package/dist/esm/Timeline/index.js +130 -0
  288. package/dist/esm/Timeline/style.less +265 -0
  289. package/dist/esm/Tooltip/index.d.ts +53 -0
  290. package/dist/esm/Tooltip/index.js +471 -0
  291. package/dist/esm/Tooltip/style.less +237 -0
  292. package/dist/esm/Transfer/index.d.ts +52 -0
  293. package/dist/esm/Transfer/index.js +340 -0
  294. package/dist/esm/Transfer/style.less +331 -0
  295. package/dist/esm/TreeSelect/index.d.ts +54 -0
  296. package/dist/esm/TreeSelect/index.js +369 -0
  297. package/dist/esm/TreeSelect/style.less +471 -0
  298. package/dist/esm/Typography/index.d.ts +102 -0
  299. package/dist/esm/Typography/index.js +161 -0
  300. package/dist/esm/Typography/style.less +246 -0
  301. package/dist/esm/Upload/index.d.ts +65 -0
  302. package/dist/esm/Upload/index.js +513 -0
  303. package/dist/esm/Upload/style.less +424 -0
  304. package/dist/esm/index.d.ts +100 -0
  305. package/dist/esm/index.js +51 -1
  306. package/package.json +14 -8
@@ -0,0 +1,371 @@
1
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
4
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
5
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
6
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
+ import React, { useState, useRef, useEffect, useCallback } from 'react';
8
+ import "./style.less";
9
+
10
+ // ============ 日期工具函数 ============
11
+ import { jsx as _jsx } from "react/jsx-runtime";
12
+ import { jsxs as _jsxs } from "react/jsx-runtime";
13
+ var formatDate = function formatDate(date) {
14
+ var format = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'YYYY-MM-DD';
15
+ var year = date.getFullYear();
16
+ var month = String(date.getMonth() + 1).padStart(2, '0');
17
+ var day = String(date.getDate()).padStart(2, '0');
18
+ return format.replace('YYYY', String(year)).replace('MM', month).replace('DD', day);
19
+ };
20
+ var parseDate = function parseDate(dateStr) {
21
+ var date = new Date(dateStr);
22
+ return isNaN(date.getTime()) ? null : date;
23
+ };
24
+ var isSameDay = function isSameDay(date1, date2) {
25
+ return date1.getFullYear() === date2.getFullYear() && date1.getMonth() === date2.getMonth() && date1.getDate() === date2.getDate();
26
+ };
27
+ var getDaysInMonth = function getDaysInMonth(year, month) {
28
+ return new Date(year, month + 1, 0).getDate();
29
+ };
30
+ var getFirstDayOfMonth = function getFirstDayOfMonth(year, month) {
31
+ return new Date(year, month, 1).getDay();
32
+ };
33
+
34
+ // ============ DatePicker Props ============
35
+
36
+ // ============ DatePicker Component ============
37
+ export var DatePicker = function DatePicker(_ref) {
38
+ var controlledValue = _ref.value,
39
+ defaultValue = _ref.defaultValue,
40
+ _ref$placeholder = _ref.placeholder,
41
+ placeholder = _ref$placeholder === void 0 ? '请选择日期' : _ref$placeholder,
42
+ _ref$format = _ref.format,
43
+ format = _ref$format === void 0 ? 'YYYY-MM-DD' : _ref$format,
44
+ _ref$disabled = _ref.disabled,
45
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
46
+ _ref$allowClear = _ref.allowClear,
47
+ allowClear = _ref$allowClear === void 0 ? true : _ref$allowClear,
48
+ _ref$size = _ref.size,
49
+ size = _ref$size === void 0 ? 'middle' : _ref$size,
50
+ status = _ref.status,
51
+ disabledDate = _ref.disabledDate,
52
+ onChange = _ref.onChange,
53
+ onOpenChange = _ref.onOpenChange,
54
+ _ref$className = _ref.className,
55
+ className = _ref$className === void 0 ? '' : _ref$className,
56
+ style = _ref.style;
57
+ // 解析初始值
58
+ var parseInitialValue = function parseInitialValue(val) {
59
+ if (!val) return null;
60
+ if (val instanceof Date) return val;
61
+ return parseDate(val);
62
+ };
63
+ var _useState = useState(parseInitialValue(defaultValue)),
64
+ _useState2 = _slicedToArray(_useState, 2),
65
+ internalValue = _useState2[0],
66
+ setInternalValue = _useState2[1];
67
+ var _useState3 = useState(false),
68
+ _useState4 = _slicedToArray(_useState3, 2),
69
+ isOpen = _useState4[0],
70
+ setIsOpen = _useState4[1];
71
+ var _useState5 = useState(new Date()),
72
+ _useState6 = _slicedToArray(_useState5, 2),
73
+ viewDate = _useState6[0],
74
+ setViewDate = _useState6[1];
75
+ var _useState7 = useState('date'),
76
+ _useState8 = _slicedToArray(_useState7, 2),
77
+ viewMode = _useState8[0],
78
+ setViewMode = _useState8[1];
79
+ var containerRef = useRef(null);
80
+ var value = controlledValue !== undefined ? parseInitialValue(controlledValue) : internalValue;
81
+
82
+ // 同步 viewDate
83
+ useEffect(function () {
84
+ if (value) {
85
+ setViewDate(new Date(value));
86
+ }
87
+ }, [value]);
88
+
89
+ // 打开/关闭面板
90
+ var setOpen = useCallback(function (open) {
91
+ if (disabled) return;
92
+ setIsOpen(open);
93
+ onOpenChange === null || onOpenChange === void 0 || onOpenChange(open);
94
+ if (open) {
95
+ setViewMode('date');
96
+ if (value) {
97
+ setViewDate(new Date(value));
98
+ } else {
99
+ setViewDate(new Date());
100
+ }
101
+ }
102
+ }, [disabled, value, onOpenChange]);
103
+
104
+ // 点击外部关闭
105
+ useEffect(function () {
106
+ var handleClickOutside = function handleClickOutside(e) {
107
+ if (containerRef.current && !containerRef.current.contains(e.target)) {
108
+ setOpen(false);
109
+ }
110
+ };
111
+ document.addEventListener('mousedown', handleClickOutside);
112
+ return function () {
113
+ return document.removeEventListener('mousedown', handleClickOutside);
114
+ };
115
+ }, [setOpen]);
116
+
117
+ // 选择日期
118
+ var handleSelectDate = useCallback(function (date) {
119
+ if (disabledDate !== null && disabledDate !== void 0 && disabledDate(date)) return;
120
+ if (controlledValue === undefined) {
121
+ setInternalValue(date);
122
+ }
123
+ onChange === null || onChange === void 0 || onChange(date, formatDate(date, format));
124
+ setOpen(false);
125
+ }, [controlledValue, format, disabledDate, onChange, setOpen]);
126
+
127
+ // 清除
128
+ var handleClear = useCallback(function (e) {
129
+ e.stopPropagation();
130
+ if (controlledValue === undefined) {
131
+ setInternalValue(null);
132
+ }
133
+ onChange === null || onChange === void 0 || onChange(null, '');
134
+ }, [controlledValue, onChange]);
135
+
136
+ // 切换月份
137
+ var handlePrevMonth = useCallback(function () {
138
+ setViewDate(function (prev) {
139
+ return new Date(prev.getFullYear(), prev.getMonth() - 1, 1);
140
+ });
141
+ }, []);
142
+ var handleNextMonth = useCallback(function () {
143
+ setViewDate(function (prev) {
144
+ return new Date(prev.getFullYear(), prev.getMonth() + 1, 1);
145
+ });
146
+ }, []);
147
+
148
+ // 切换年份
149
+ var handlePrevYear = useCallback(function () {
150
+ if (viewMode === 'year') {
151
+ setViewDate(function (prev) {
152
+ return new Date(prev.getFullYear() - 12, prev.getMonth(), 1);
153
+ });
154
+ } else {
155
+ setViewDate(function (prev) {
156
+ return new Date(prev.getFullYear() - 1, prev.getMonth(), 1);
157
+ });
158
+ }
159
+ }, [viewMode]);
160
+ var handleNextYear = useCallback(function () {
161
+ if (viewMode === 'year') {
162
+ setViewDate(function (prev) {
163
+ return new Date(prev.getFullYear() + 12, prev.getMonth(), 1);
164
+ });
165
+ } else {
166
+ setViewDate(function (prev) {
167
+ return new Date(prev.getFullYear() + 1, prev.getMonth(), 1);
168
+ });
169
+ }
170
+ }, [viewMode]);
171
+
172
+ // 选择月份
173
+ var handleSelectMonth = useCallback(function (month) {
174
+ setViewDate(function (prev) {
175
+ return new Date(prev.getFullYear(), month, 1);
176
+ });
177
+ setViewMode('date');
178
+ }, []);
179
+
180
+ // 选择年份
181
+ var handleSelectYear = useCallback(function (year) {
182
+ setViewDate(function (prev) {
183
+ return new Date(year, prev.getMonth(), 1);
184
+ });
185
+ setViewMode('month');
186
+ }, []);
187
+
188
+ // 选择今天
189
+ var handleToday = useCallback(function () {
190
+ var today = new Date();
191
+ handleSelectDate(today);
192
+ }, [handleSelectDate]);
193
+
194
+ // 生成日期网格
195
+ var generateDateGrid = useCallback(function () {
196
+ var year = viewDate.getFullYear();
197
+ var month = viewDate.getMonth();
198
+ var daysInMonth = getDaysInMonth(year, month);
199
+ var firstDay = getFirstDayOfMonth(year, month);
200
+ var prevMonthDays = getDaysInMonth(year, month - 1);
201
+ var days = [];
202
+
203
+ // 上个月的天数
204
+ for (var i = firstDay - 1; i >= 0; i--) {
205
+ days.push({
206
+ date: new Date(year, month - 1, prevMonthDays - i),
207
+ isCurrentMonth: false
208
+ });
209
+ }
210
+
211
+ // 当前月的天数
212
+ for (var _i = 1; _i <= daysInMonth; _i++) {
213
+ days.push({
214
+ date: new Date(year, month, _i),
215
+ isCurrentMonth: true
216
+ });
217
+ }
218
+
219
+ // 下个月的天数
220
+ var remaining = 42 - days.length;
221
+ for (var _i2 = 1; _i2 <= remaining; _i2++) {
222
+ days.push({
223
+ date: new Date(year, month + 1, _i2),
224
+ isCurrentMonth: false
225
+ });
226
+ }
227
+ return days;
228
+ }, [viewDate]);
229
+
230
+ // 生成月份网格
231
+ var generateMonthGrid = useCallback(function () {
232
+ var months = ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'];
233
+ return months.map(function (name, index) {
234
+ return {
235
+ name: name,
236
+ index: index
237
+ };
238
+ });
239
+ }, []);
240
+
241
+ // 生成年份网格
242
+ var generateYearGrid = useCallback(function () {
243
+ var currentYear = viewDate.getFullYear();
244
+ var startYear = Math.floor(currentYear / 12) * 12;
245
+ var years = [];
246
+ for (var i = 0; i < 12; i++) {
247
+ years.push(startYear + i);
248
+ }
249
+ return years;
250
+ }, [viewDate]);
251
+ var classNames = ['kage-datepicker', "kage-datepicker-".concat(size), disabled && 'kage-datepicker-disabled', status && "kage-datepicker-status-".concat(status), isOpen && 'kage-datepicker-open', className].filter(Boolean).join(' ');
252
+ var weekDays = ['日', '一', '二', '三', '四', '五', '六'];
253
+ var today = new Date();
254
+ return /*#__PURE__*/_jsxs("div", {
255
+ ref: containerRef,
256
+ className: classNames,
257
+ style: style,
258
+ children: [/*#__PURE__*/_jsxs("div", {
259
+ className: "kage-datepicker-input",
260
+ onClick: function onClick() {
261
+ return setOpen(!isOpen);
262
+ },
263
+ children: [/*#__PURE__*/_jsx("span", {
264
+ className: "kage-datepicker-value ".concat(!value ? 'kage-datepicker-placeholder' : ''),
265
+ children: value ? formatDate(value, format) : placeholder
266
+ }), allowClear && value && !disabled && /*#__PURE__*/_jsx("span", {
267
+ className: "kage-datepicker-clear",
268
+ onClick: handleClear,
269
+ children: "\xD7"
270
+ }), /*#__PURE__*/_jsx("span", {
271
+ className: "kage-datepicker-icon",
272
+ children: "\uD83D\uDCC5"
273
+ })]
274
+ }), isOpen && /*#__PURE__*/_jsxs("div", {
275
+ className: "kage-datepicker-panel",
276
+ children: [/*#__PURE__*/_jsxs("div", {
277
+ className: "kage-datepicker-header",
278
+ children: [/*#__PURE__*/_jsx("button", {
279
+ className: "kage-datepicker-header-btn",
280
+ onClick: handlePrevYear,
281
+ children: "\xAB"
282
+ }), viewMode === 'date' && /*#__PURE__*/_jsx("button", {
283
+ className: "kage-datepicker-header-btn",
284
+ onClick: handlePrevMonth,
285
+ children: "\u2039"
286
+ }), /*#__PURE__*/_jsxs("div", {
287
+ className: "kage-datepicker-header-title",
288
+ children: [/*#__PURE__*/_jsxs("span", {
289
+ onClick: function onClick() {
290
+ return setViewMode('year');
291
+ },
292
+ children: [viewMode === 'year' ? "".concat(generateYearGrid()[0], " - ").concat(generateYearGrid()[11]) : viewDate.getFullYear(), "\u5E74"]
293
+ }), viewMode === 'date' && /*#__PURE__*/_jsxs("span", {
294
+ onClick: function onClick() {
295
+ return setViewMode('month');
296
+ },
297
+ children: [viewDate.getMonth() + 1, "\u6708"]
298
+ })]
299
+ }), viewMode === 'date' && /*#__PURE__*/_jsx("button", {
300
+ className: "kage-datepicker-header-btn",
301
+ onClick: handleNextMonth,
302
+ children: "\u203A"
303
+ }), /*#__PURE__*/_jsx("button", {
304
+ className: "kage-datepicker-header-btn",
305
+ onClick: handleNextYear,
306
+ children: "\xBB"
307
+ })]
308
+ }), viewMode === 'date' && /*#__PURE__*/_jsxs("div", {
309
+ className: "kage-datepicker-body",
310
+ children: [/*#__PURE__*/_jsx("div", {
311
+ className: "kage-datepicker-weekdays",
312
+ children: weekDays.map(function (day) {
313
+ return /*#__PURE__*/_jsx("span", {
314
+ className: "kage-datepicker-weekday",
315
+ children: day
316
+ }, day);
317
+ })
318
+ }), /*#__PURE__*/_jsx("div", {
319
+ className: "kage-datepicker-dates",
320
+ children: generateDateGrid().map(function (_ref2, index) {
321
+ var date = _ref2.date,
322
+ isCurrentMonth = _ref2.isCurrentMonth;
323
+ var isSelected = value && isSameDay(date, value);
324
+ var isToday = isSameDay(date, today);
325
+ var isDisabled = disabledDate === null || disabledDate === void 0 ? void 0 : disabledDate(date);
326
+ var dayClassNames = ['kage-datepicker-date', !isCurrentMonth && 'kage-datepicker-date-other', isSelected && 'kage-datepicker-date-selected', isToday && 'kage-datepicker-date-today', isDisabled && 'kage-datepicker-date-disabled'].filter(Boolean).join(' ');
327
+ return /*#__PURE__*/_jsx("span", {
328
+ className: dayClassNames,
329
+ onClick: function onClick() {
330
+ return !isDisabled && handleSelectDate(date);
331
+ },
332
+ children: date.getDate()
333
+ }, index);
334
+ })
335
+ })]
336
+ }), viewMode === 'month' && /*#__PURE__*/_jsx("div", {
337
+ className: "kage-datepicker-months",
338
+ children: generateMonthGrid().map(function (_ref3) {
339
+ var name = _ref3.name,
340
+ index = _ref3.index;
341
+ return /*#__PURE__*/_jsx("span", {
342
+ className: "kage-datepicker-month ".concat(viewDate.getMonth() === index ? 'kage-datepicker-month-selected' : ''),
343
+ onClick: function onClick() {
344
+ return handleSelectMonth(index);
345
+ },
346
+ children: name
347
+ }, index);
348
+ })
349
+ }), viewMode === 'year' && /*#__PURE__*/_jsx("div", {
350
+ className: "kage-datepicker-years",
351
+ children: generateYearGrid().map(function (year) {
352
+ return /*#__PURE__*/_jsx("span", {
353
+ className: "kage-datepicker-year ".concat(viewDate.getFullYear() === year ? 'kage-datepicker-year-selected' : ''),
354
+ onClick: function onClick() {
355
+ return handleSelectYear(year);
356
+ },
357
+ children: year
358
+ }, year);
359
+ })
360
+ }), /*#__PURE__*/_jsx("div", {
361
+ className: "kage-datepicker-footer",
362
+ children: /*#__PURE__*/_jsx("button", {
363
+ className: "kage-datepicker-today",
364
+ onClick: handleToday,
365
+ children: "\u4ECA\u5929"
366
+ })
367
+ })]
368
+ })]
369
+ });
370
+ };
371
+ export default DatePicker;