wssf-kage-ui 0.1.1 → 0.1.3

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 (257) hide show
  1. package/dist/cjs/Alert/index.d.ts +37 -0
  2. package/dist/cjs/Alert/index.js +124 -0
  3. package/dist/cjs/Alert/style.less +248 -0
  4. package/dist/cjs/Avatar/index.d.ts +47 -0
  5. package/dist/cjs/Avatar/index.js +147 -0
  6. package/dist/cjs/Avatar/style.less +193 -0
  7. package/dist/cjs/Badge/index.d.ts +48 -0
  8. package/dist/cjs/Badge/index.js +141 -0
  9. package/dist/cjs/Badge/style.less +237 -0
  10. package/dist/cjs/Calendar/index.d.ts +33 -0
  11. package/dist/cjs/Calendar/index.js +296 -0
  12. package/dist/cjs/Calendar/style.less +384 -0
  13. package/dist/cjs/Card/index.d.ts +68 -0
  14. package/dist/cjs/Card/index.js +155 -0
  15. package/dist/cjs/Card/style.less +356 -0
  16. package/dist/cjs/Carousel/index.d.ts +33 -0
  17. package/dist/cjs/Carousel/index.js +169 -0
  18. package/dist/cjs/Carousel/style.less +232 -0
  19. package/dist/cjs/Collapse/index.d.ts +55 -0
  20. package/dist/cjs/Collapse/index.js +191 -0
  21. package/dist/cjs/Collapse/style.less +217 -0
  22. package/dist/cjs/Descriptions/index.d.ts +54 -0
  23. package/dist/cjs/Descriptions/index.js +181 -0
  24. package/dist/cjs/Descriptions/style.less +259 -0
  25. package/dist/cjs/Drawer/index.d.ts +57 -0
  26. package/dist/cjs/Drawer/index.js +203 -0
  27. package/dist/cjs/Drawer/style.less +215 -0
  28. package/dist/cjs/Empty/index.d.ts +21 -0
  29. package/dist/cjs/Empty/index.js +115 -0
  30. package/dist/cjs/Empty/style.less +103 -0
  31. package/dist/cjs/FloatButton/index.d.ts +54 -0
  32. package/dist/cjs/FloatButton/index.js +119 -0
  33. package/dist/cjs/FloatButton/style.less +266 -0
  34. package/dist/cjs/Image/index.d.ts +30 -0
  35. package/dist/cjs/Image/index.js +153 -0
  36. package/dist/cjs/Image/style.less +156 -0
  37. package/dist/cjs/Input/index.d.ts +24 -0
  38. package/dist/cjs/Input/index.js +158 -0
  39. package/dist/cjs/Input/style.less +276 -0
  40. package/dist/cjs/InputNumber/index.d.ts +47 -0
  41. package/dist/cjs/InputNumber/index.js +323 -0
  42. package/dist/cjs/InputNumber/style.less +392 -0
  43. package/dist/cjs/Mentions/index.d.ts +57 -0
  44. package/dist/cjs/Mentions/index.js +378 -0
  45. package/dist/cjs/Mentions/style.less +297 -0
  46. package/dist/cjs/Message/index.d.ts +38 -0
  47. package/dist/cjs/Message/index.js +292 -0
  48. package/dist/cjs/Message/style.less +183 -0
  49. package/dist/cjs/Modal/index.d.ts +63 -0
  50. package/dist/cjs/Modal/index.js +254 -0
  51. package/dist/cjs/Modal/style.less +298 -0
  52. package/dist/cjs/Notification/index.d.ts +48 -0
  53. package/dist/cjs/Notification/index.js +340 -0
  54. package/dist/cjs/Notification/style.less +260 -0
  55. package/dist/cjs/Popconfirm/index.d.ts +58 -0
  56. package/dist/cjs/Popconfirm/index.js +393 -0
  57. package/dist/cjs/Popconfirm/style.less +417 -0
  58. package/dist/cjs/Popover/index.d.ts +30 -0
  59. package/dist/cjs/Popover/index.js +131 -0
  60. package/dist/cjs/Popover/style.less +279 -0
  61. package/dist/cjs/Progress/index.d.ts +43 -0
  62. package/dist/cjs/Progress/index.js +213 -0
  63. package/dist/cjs/Progress/style.less +206 -0
  64. package/dist/cjs/QRCode/index.d.ts +30 -0
  65. package/dist/cjs/QRCode/index.js +167 -0
  66. package/dist/cjs/QRCode/style.less +201 -0
  67. package/dist/cjs/Radio/index.d.ts +70 -0
  68. package/dist/cjs/Radio/index.js +199 -0
  69. package/dist/cjs/Radio/style.less +326 -0
  70. package/dist/cjs/Rate/index.d.ts +37 -0
  71. package/dist/cjs/Rate/index.js +151 -0
  72. package/dist/cjs/Rate/style.less +170 -0
  73. package/dist/cjs/Result/index.d.ts +25 -0
  74. package/dist/cjs/Result/index.js +63 -0
  75. package/dist/cjs/Result/style.less +111 -0
  76. package/dist/cjs/Segmented/index.d.ts +31 -0
  77. package/dist/cjs/Segmented/index.js +121 -0
  78. package/dist/cjs/Segmented/style.less +167 -0
  79. package/dist/cjs/Select/index.d.ts +67 -0
  80. package/dist/cjs/Select/index.js +403 -0
  81. package/dist/cjs/Select/style.less +523 -0
  82. package/dist/cjs/Skeleton/index.d.ts +88 -0
  83. package/dist/cjs/Skeleton/index.js +207 -0
  84. package/dist/cjs/Skeleton/style.less +487 -0
  85. package/dist/cjs/Slider/index.d.ts +41 -0
  86. package/dist/cjs/Slider/index.js +325 -0
  87. package/dist/cjs/Slider/style.less +287 -0
  88. package/dist/cjs/Spin/index.d.ts +25 -0
  89. package/dist/cjs/Spin/index.js +98 -0
  90. package/dist/cjs/Spin/style.less +169 -0
  91. package/dist/cjs/Statistic/index.d.ts +26 -0
  92. package/dist/cjs/Statistic/index.js +71 -0
  93. package/dist/cjs/Statistic/style.less +94 -0
  94. package/dist/cjs/Switch/index.d.ts +28 -0
  95. package/dist/cjs/Switch/index.js +71 -0
  96. package/dist/cjs/Switch/style.less +212 -0
  97. package/dist/cjs/Table/index.d.ts +188 -0
  98. package/dist/cjs/Table/index.js +787 -0
  99. package/dist/cjs/Table/style.less +663 -0
  100. package/dist/cjs/Tag/index.d.ts +51 -0
  101. package/dist/cjs/Tag/index.js +142 -0
  102. package/dist/cjs/Tag/style.less +356 -0
  103. package/dist/cjs/TimePicker/index.d.ts +51 -0
  104. package/dist/cjs/TimePicker/index.js +332 -0
  105. package/dist/cjs/TimePicker/style.less +384 -0
  106. package/dist/cjs/Timeline/index.d.ts +47 -0
  107. package/dist/cjs/Timeline/index.js +127 -0
  108. package/dist/cjs/Timeline/style.less +265 -0
  109. package/dist/cjs/Tooltip/index.d.ts +53 -0
  110. package/dist/cjs/Tooltip/index.js +468 -0
  111. package/dist/cjs/Tooltip/style.less +237 -0
  112. package/dist/cjs/Transfer/index.d.ts +52 -0
  113. package/dist/cjs/Transfer/index.js +344 -0
  114. package/dist/cjs/Transfer/style.less +331 -0
  115. package/dist/cjs/Tree/index.d.ts +82 -0
  116. package/dist/cjs/Tree/index.js +226 -0
  117. package/dist/cjs/Tree/style.less +313 -0
  118. package/dist/cjs/TreeSelect/index.d.ts +54 -0
  119. package/dist/cjs/TreeSelect/index.js +373 -0
  120. package/dist/cjs/TreeSelect/style.less +471 -0
  121. package/dist/cjs/Upload/index.d.ts +65 -0
  122. package/dist/cjs/Upload/index.js +517 -0
  123. package/dist/cjs/Upload/style.less +424 -0
  124. package/dist/cjs/Watermark/index.d.ts +41 -0
  125. package/dist/cjs/Watermark/index.js +353 -0
  126. package/dist/cjs/Watermark/style.less +31 -0
  127. package/dist/cjs/index.d.ts +84 -0
  128. package/dist/cjs/index.js +318 -0
  129. package/dist/esm/Alert/index.d.ts +37 -0
  130. package/dist/esm/Alert/index.js +121 -0
  131. package/dist/esm/Alert/style.less +248 -0
  132. package/dist/esm/Avatar/index.d.ts +47 -0
  133. package/dist/esm/Avatar/index.js +142 -0
  134. package/dist/esm/Avatar/style.less +193 -0
  135. package/dist/esm/Badge/index.d.ts +48 -0
  136. package/dist/esm/Badge/index.js +137 -0
  137. package/dist/esm/Badge/style.less +237 -0
  138. package/dist/esm/Calendar/index.d.ts +33 -0
  139. package/dist/esm/Calendar/index.js +291 -0
  140. package/dist/esm/Calendar/style.less +384 -0
  141. package/dist/esm/Card/index.d.ts +68 -0
  142. package/dist/esm/Card/index.js +149 -0
  143. package/dist/esm/Card/style.less +356 -0
  144. package/dist/esm/Carousel/index.d.ts +33 -0
  145. package/dist/esm/Carousel/index.js +163 -0
  146. package/dist/esm/Carousel/style.less +232 -0
  147. package/dist/esm/Collapse/index.d.ts +55 -0
  148. package/dist/esm/Collapse/index.js +187 -0
  149. package/dist/esm/Collapse/style.less +217 -0
  150. package/dist/esm/Descriptions/index.d.ts +54 -0
  151. package/dist/esm/Descriptions/index.js +179 -0
  152. package/dist/esm/Descriptions/style.less +259 -0
  153. package/dist/esm/Drawer/index.d.ts +57 -0
  154. package/dist/esm/Drawer/index.js +202 -0
  155. package/dist/esm/Drawer/style.less +215 -0
  156. package/dist/esm/Empty/index.d.ts +21 -0
  157. package/dist/esm/Empty/index.js +109 -0
  158. package/dist/esm/Empty/style.less +103 -0
  159. package/dist/esm/FloatButton/index.d.ts +54 -0
  160. package/dist/esm/FloatButton/index.js +123 -0
  161. package/dist/esm/FloatButton/style.less +266 -0
  162. package/dist/esm/Image/index.d.ts +30 -0
  163. package/dist/esm/Image/index.js +149 -0
  164. package/dist/esm/Image/style.less +156 -0
  165. package/dist/esm/Input/index.d.ts +24 -0
  166. package/dist/esm/Input/index.js +151 -0
  167. package/dist/esm/Input/style.less +276 -0
  168. package/dist/esm/InputNumber/index.d.ts +47 -0
  169. package/dist/esm/InputNumber/index.js +316 -0
  170. package/dist/esm/InputNumber/style.less +392 -0
  171. package/dist/esm/Mentions/index.d.ts +57 -0
  172. package/dist/esm/Mentions/index.js +374 -0
  173. package/dist/esm/Mentions/style.less +297 -0
  174. package/dist/esm/Message/index.d.ts +38 -0
  175. package/dist/esm/Message/index.js +294 -0
  176. package/dist/esm/Message/style.less +183 -0
  177. package/dist/esm/Modal/index.d.ts +63 -0
  178. package/dist/esm/Modal/index.js +251 -0
  179. package/dist/esm/Modal/style.less +298 -0
  180. package/dist/esm/Notification/index.d.ts +48 -0
  181. package/dist/esm/Notification/index.js +345 -0
  182. package/dist/esm/Notification/style.less +260 -0
  183. package/dist/esm/Popconfirm/index.d.ts +58 -0
  184. package/dist/esm/Popconfirm/index.js +389 -0
  185. package/dist/esm/Popconfirm/style.less +417 -0
  186. package/dist/esm/Popover/index.d.ts +30 -0
  187. package/dist/esm/Popover/index.js +126 -0
  188. package/dist/esm/Popover/style.less +279 -0
  189. package/dist/esm/Progress/index.d.ts +43 -0
  190. package/dist/esm/Progress/index.js +208 -0
  191. package/dist/esm/Progress/style.less +206 -0
  192. package/dist/esm/QRCode/index.d.ts +30 -0
  193. package/dist/esm/QRCode/index.js +158 -0
  194. package/dist/esm/QRCode/style.less +201 -0
  195. package/dist/esm/Radio/index.d.ts +70 -0
  196. package/dist/esm/Radio/index.js +193 -0
  197. package/dist/esm/Radio/style.less +326 -0
  198. package/dist/esm/Rate/index.d.ts +37 -0
  199. package/dist/esm/Rate/index.js +143 -0
  200. package/dist/esm/Rate/style.less +170 -0
  201. package/dist/esm/Result/index.d.ts +25 -0
  202. package/dist/esm/Result/index.js +57 -0
  203. package/dist/esm/Result/style.less +111 -0
  204. package/dist/esm/Segmented/index.d.ts +31 -0
  205. package/dist/esm/Segmented/index.js +113 -0
  206. package/dist/esm/Segmented/style.less +167 -0
  207. package/dist/esm/Select/index.d.ts +67 -0
  208. package/dist/esm/Select/index.js +398 -0
  209. package/dist/esm/Select/style.less +523 -0
  210. package/dist/esm/Skeleton/index.d.ts +88 -0
  211. package/dist/esm/Skeleton/index.js +213 -0
  212. package/dist/esm/Skeleton/style.less +487 -0
  213. package/dist/esm/Slider/index.d.ts +41 -0
  214. package/dist/esm/Slider/index.js +318 -0
  215. package/dist/esm/Slider/style.less +287 -0
  216. package/dist/esm/Spin/index.d.ts +25 -0
  217. package/dist/esm/Spin/index.js +95 -0
  218. package/dist/esm/Spin/style.less +169 -0
  219. package/dist/esm/Statistic/index.d.ts +26 -0
  220. package/dist/esm/Statistic/index.js +65 -0
  221. package/dist/esm/Statistic/style.less +94 -0
  222. package/dist/esm/Switch/index.d.ts +28 -0
  223. package/dist/esm/Switch/index.js +63 -0
  224. package/dist/esm/Switch/style.less +212 -0
  225. package/dist/esm/Table/index.d.ts +188 -0
  226. package/dist/esm/Table/index.js +797 -0
  227. package/dist/esm/Table/style.less +663 -0
  228. package/dist/esm/Tag/index.d.ts +51 -0
  229. package/dist/esm/Tag/index.js +144 -0
  230. package/dist/esm/Tag/style.less +356 -0
  231. package/dist/esm/TimePicker/index.d.ts +51 -0
  232. package/dist/esm/TimePicker/index.js +327 -0
  233. package/dist/esm/TimePicker/style.less +384 -0
  234. package/dist/esm/Timeline/index.d.ts +47 -0
  235. package/dist/esm/Timeline/index.js +130 -0
  236. package/dist/esm/Timeline/style.less +265 -0
  237. package/dist/esm/Tooltip/index.d.ts +53 -0
  238. package/dist/esm/Tooltip/index.js +471 -0
  239. package/dist/esm/Tooltip/style.less +237 -0
  240. package/dist/esm/Transfer/index.d.ts +52 -0
  241. package/dist/esm/Transfer/index.js +340 -0
  242. package/dist/esm/Transfer/style.less +331 -0
  243. package/dist/esm/Tree/index.d.ts +82 -0
  244. package/dist/esm/Tree/index.js +225 -0
  245. package/dist/esm/Tree/style.less +313 -0
  246. package/dist/esm/TreeSelect/index.d.ts +54 -0
  247. package/dist/esm/TreeSelect/index.js +369 -0
  248. package/dist/esm/TreeSelect/style.less +471 -0
  249. package/dist/esm/Upload/index.d.ts +65 -0
  250. package/dist/esm/Upload/index.js +513 -0
  251. package/dist/esm/Upload/style.less +424 -0
  252. package/dist/esm/Watermark/index.d.ts +41 -0
  253. package/dist/esm/Watermark/index.js +349 -0
  254. package/dist/esm/Watermark/style.less +31 -0
  255. package/dist/esm/index.d.ts +84 -0
  256. package/dist/esm/index.js +43 -1
  257. package/package.json +6 -3
@@ -0,0 +1,327 @@
1
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
3
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
5
+ 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."); }
6
+ 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); }
7
+ 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; }
8
+ 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; } }
9
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
10
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
11
+ import React, { useState, useRef, useEffect, useCallback, useMemo } from 'react';
12
+ import "./style.less";
13
+
14
+ // ============ 时间工具函数 ============
15
+ import { jsx as _jsx } from "react/jsx-runtime";
16
+ import { jsxs as _jsxs } from "react/jsx-runtime";
17
+ var formatTime = function formatTime(hour, minute, second, format) {
18
+ var h12 = hour % 12 || 12;
19
+ var period = hour < 12 ? 'AM' : 'PM';
20
+ return format.replace('HH', String(hour).padStart(2, '0')).replace('H', String(hour)).replace('hh', String(h12).padStart(2, '0')).replace('h', String(h12)).replace('mm', String(minute).padStart(2, '0')).replace('m', String(minute)).replace('ss', String(second).padStart(2, '0')).replace('s', String(second)).replace('A', period).replace('a', period.toLowerCase());
21
+ };
22
+ var parseTime = function parseTime(timeStr, format) {
23
+ if (!timeStr) return null;
24
+ var is12Hour = format.includes('h');
25
+ var hasSecond = format.includes('s');
26
+ var parts = timeStr.split(':');
27
+ if (parts.length < 2) return null;
28
+ var hour = parseInt(parts[0], 10);
29
+ var minute = parseInt(parts[1], 10);
30
+ var second = hasSecond && parts.length > 2 ? parseInt(parts[2], 10) : 0;
31
+
32
+ // 处理 12 小时制
33
+ if (is12Hour) {
34
+ var isPM = timeStr.toLowerCase().includes('pm');
35
+ if (isPM && hour < 12) hour += 12;
36
+ if (!isPM && hour === 12) hour = 0;
37
+ }
38
+ if (isNaN(hour) || isNaN(minute) || isNaN(second)) return null;
39
+ if (hour < 0 || hour > 23 || minute < 0 || minute > 59 || second < 0 || second > 59) return null;
40
+ return {
41
+ hour: hour,
42
+ minute: minute,
43
+ second: second
44
+ };
45
+ };
46
+
47
+ // ============ TimePicker Props ============
48
+
49
+ // ============ TimePicker Component ============
50
+ export var TimePicker = function TimePicker(_ref) {
51
+ var controlledValue = _ref.value,
52
+ defaultValue = _ref.defaultValue,
53
+ _ref$placeholder = _ref.placeholder,
54
+ placeholder = _ref$placeholder === void 0 ? '请选择时间' : _ref$placeholder,
55
+ _ref$format = _ref.format,
56
+ format = _ref$format === void 0 ? 'HH:mm:ss' : _ref$format,
57
+ _ref$disabled = _ref.disabled,
58
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
59
+ _ref$allowClear = _ref.allowClear,
60
+ allowClear = _ref$allowClear === void 0 ? true : _ref$allowClear,
61
+ _ref$size = _ref.size,
62
+ size = _ref$size === void 0 ? 'middle' : _ref$size,
63
+ status = _ref.status,
64
+ _ref$hourStep = _ref.hourStep,
65
+ hourStep = _ref$hourStep === void 0 ? 1 : _ref$hourStep,
66
+ _ref$minuteStep = _ref.minuteStep,
67
+ minuteStep = _ref$minuteStep === void 0 ? 1 : _ref$minuteStep,
68
+ _ref$secondStep = _ref.secondStep,
69
+ secondStep = _ref$secondStep === void 0 ? 1 : _ref$secondStep,
70
+ disabledHours = _ref.disabledHours,
71
+ disabledMinutes = _ref.disabledMinutes,
72
+ disabledSeconds = _ref.disabledSeconds,
73
+ _ref$hideDisabledOpti = _ref.hideDisabledOptions,
74
+ hideDisabledOptions = _ref$hideDisabledOpti === void 0 ? false : _ref$hideDisabledOpti,
75
+ _ref$use12Hours = _ref.use12Hours,
76
+ use12Hours = _ref$use12Hours === void 0 ? false : _ref$use12Hours,
77
+ onChange = _ref.onChange,
78
+ onOpenChange = _ref.onOpenChange,
79
+ _ref$className = _ref.className,
80
+ className = _ref$className === void 0 ? '' : _ref$className,
81
+ style = _ref.style;
82
+ var showSecond = format.includes('s');
83
+ var actualFormat = use12Hours && !format.includes('h') ? format.replace('HH', 'hh') + ' A' : format;
84
+
85
+ // 解析初始值
86
+ var parseInitialValue = function parseInitialValue(val) {
87
+ if (!val) return null;
88
+ if (_typeof(val) === 'object') return val;
89
+ return parseTime(val, actualFormat);
90
+ };
91
+ var _useState = useState(parseInitialValue(defaultValue)),
92
+ _useState2 = _slicedToArray(_useState, 2),
93
+ internalValue = _useState2[0],
94
+ setInternalValue = _useState2[1];
95
+ var _useState3 = useState(false),
96
+ _useState4 = _slicedToArray(_useState3, 2),
97
+ isOpen = _useState4[0],
98
+ setIsOpen = _useState4[1];
99
+ var containerRef = useRef(null);
100
+ var hourRef = useRef(null);
101
+ var minuteRef = useRef(null);
102
+ var secondRef = useRef(null);
103
+ var value = controlledValue !== undefined ? parseInitialValue(controlledValue) : internalValue;
104
+
105
+ // 打开/关闭面板
106
+ var setOpen = useCallback(function (open) {
107
+ if (disabled) return;
108
+ setIsOpen(open);
109
+ onOpenChange === null || onOpenChange === void 0 || onOpenChange(open);
110
+ }, [disabled, onOpenChange]);
111
+
112
+ // 点击外部关闭
113
+ useEffect(function () {
114
+ var handleClickOutside = function handleClickOutside(e) {
115
+ if (containerRef.current && !containerRef.current.contains(e.target)) {
116
+ setOpen(false);
117
+ }
118
+ };
119
+ document.addEventListener('mousedown', handleClickOutside);
120
+ return function () {
121
+ return document.removeEventListener('mousedown', handleClickOutside);
122
+ };
123
+ }, [setOpen]);
124
+
125
+ // 滚动到选中项
126
+ useEffect(function () {
127
+ if (isOpen && value) {
128
+ setTimeout(function () {
129
+ var scrollToValue = function scrollToValue(ref, targetValue) {
130
+ if (ref.current) {
131
+ var item = ref.current.querySelector("[data-value=\"".concat(targetValue, "\"]"));
132
+ if (item) {
133
+ ref.current.scrollTop = item.offsetTop - ref.current.offsetHeight / 2 + item.offsetHeight / 2;
134
+ }
135
+ }
136
+ };
137
+ scrollToValue(hourRef, value.hour);
138
+ scrollToValue(minuteRef, value.minute);
139
+ if (showSecond) {
140
+ scrollToValue(secondRef, value.second);
141
+ }
142
+ }, 0);
143
+ }
144
+ }, [isOpen, value, showSecond]);
145
+
146
+ // 生成选项列表
147
+ var generateOptions = useCallback(function (max, step, disabledFn, currentHour, currentMinute) {
148
+ var options = [];
149
+ for (var i = 0; i < max; i += step) {
150
+ var isDisabled = false;
151
+ if (disabledFn) {
152
+ if (typeof disabledFn === 'function') {
153
+ var _disabled = [];
154
+ if (disabledFn.length === 0) {
155
+ _disabled = disabledFn();
156
+ } else if (disabledFn.length === 1) {
157
+ _disabled = disabledFn(currentHour);
158
+ } else {
159
+ _disabled = disabledFn(currentHour, currentMinute);
160
+ }
161
+ isDisabled = Array.isArray(_disabled) && _disabled.includes(i);
162
+ }
163
+ }
164
+ if (!hideDisabledOptions || !isDisabled) {
165
+ options.push(i);
166
+ }
167
+ }
168
+ return options;
169
+ }, [hideDisabledOptions]);
170
+
171
+ // 小时选项
172
+ var hourOptions = useMemo(function () {
173
+ var max = use12Hours ? 12 : 24;
174
+ var options = generateOptions(max, hourStep);
175
+ if (use12Hours && !options.includes(12)) {
176
+ options.push(12);
177
+ }
178
+ if (disabledHours) {
179
+ var _disabled2 = disabledHours();
180
+ return options.filter(function (h) {
181
+ return !_disabled2.includes(h);
182
+ });
183
+ }
184
+ return options;
185
+ }, [use12Hours, hourStep, disabledHours, generateOptions]);
186
+
187
+ // 分钟选项
188
+ var minuteOptions = useMemo(function () {
189
+ var options = generateOptions(60, minuteStep);
190
+ if (disabledMinutes && value) {
191
+ var _disabled3 = disabledMinutes(value.hour);
192
+ return options.filter(function (m) {
193
+ return !_disabled3.includes(m);
194
+ });
195
+ }
196
+ return options;
197
+ }, [minuteStep, disabledMinutes, value, generateOptions]);
198
+
199
+ // 秒选项
200
+ var secondOptions = useMemo(function () {
201
+ var options = generateOptions(60, secondStep);
202
+ if (disabledSeconds && value) {
203
+ var _disabled4 = disabledSeconds(value.hour, value.minute);
204
+ return options.filter(function (s) {
205
+ return !_disabled4.includes(s);
206
+ });
207
+ }
208
+ return options;
209
+ }, [secondStep, disabledSeconds, value, generateOptions]);
210
+
211
+ // 选择时间
212
+ var handleSelectTime = useCallback(function (type, val) {
213
+ var _value$hour, _value$minute, _value$second;
214
+ var newValue = _defineProperty({
215
+ hour: (_value$hour = value === null || value === void 0 ? void 0 : value.hour) !== null && _value$hour !== void 0 ? _value$hour : 0,
216
+ minute: (_value$minute = value === null || value === void 0 ? void 0 : value.minute) !== null && _value$minute !== void 0 ? _value$minute : 0,
217
+ second: (_value$second = value === null || value === void 0 ? void 0 : value.second) !== null && _value$second !== void 0 ? _value$second : 0
218
+ }, type, val);
219
+ if (controlledValue === undefined) {
220
+ setInternalValue(newValue);
221
+ }
222
+ var timeString = formatTime(newValue.hour, newValue.minute, newValue.second, actualFormat);
223
+ onChange === null || onChange === void 0 || onChange(newValue, timeString);
224
+ }, [value, controlledValue, actualFormat, onChange]);
225
+
226
+ // 清除
227
+ var handleClear = useCallback(function (e) {
228
+ e.stopPropagation();
229
+ if (controlledValue === undefined) {
230
+ setInternalValue(null);
231
+ }
232
+ onChange === null || onChange === void 0 || onChange(null, '');
233
+ }, [controlledValue, onChange]);
234
+
235
+ // 当前时间
236
+ var handleNow = useCallback(function () {
237
+ var now = new Date();
238
+ var newValue = {
239
+ hour: now.getHours(),
240
+ minute: now.getMinutes(),
241
+ second: now.getSeconds()
242
+ };
243
+ if (controlledValue === undefined) {
244
+ setInternalValue(newValue);
245
+ }
246
+ var timeString = formatTime(newValue.hour, newValue.minute, newValue.second, actualFormat);
247
+ onChange === null || onChange === void 0 || onChange(newValue, timeString);
248
+ setOpen(false);
249
+ }, [controlledValue, actualFormat, onChange, setOpen]);
250
+ var classNames = ['kage-timepicker', "kage-timepicker-".concat(size), disabled && 'kage-timepicker-disabled', status && "kage-timepicker-status-".concat(status), isOpen && 'kage-timepicker-open', className].filter(Boolean).join(' ');
251
+ var displayValue = value ? formatTime(value.hour, value.minute, value.second, actualFormat) : '';
252
+ return /*#__PURE__*/_jsxs("div", {
253
+ ref: containerRef,
254
+ className: classNames,
255
+ style: style,
256
+ children: [/*#__PURE__*/_jsxs("div", {
257
+ className: "kage-timepicker-input",
258
+ onClick: function onClick() {
259
+ return setOpen(!isOpen);
260
+ },
261
+ children: [/*#__PURE__*/_jsx("span", {
262
+ className: "kage-timepicker-value ".concat(!value ? 'kage-timepicker-placeholder' : ''),
263
+ children: value ? displayValue : placeholder
264
+ }), allowClear && value && !disabled && /*#__PURE__*/_jsx("span", {
265
+ className: "kage-timepicker-clear",
266
+ onClick: handleClear,
267
+ children: "\xD7"
268
+ }), /*#__PURE__*/_jsx("span", {
269
+ className: "kage-timepicker-icon",
270
+ children: "\uD83D\uDD50"
271
+ })]
272
+ }), isOpen && /*#__PURE__*/_jsxs("div", {
273
+ className: "kage-timepicker-panel",
274
+ children: [/*#__PURE__*/_jsxs("div", {
275
+ className: "kage-timepicker-panel-inner",
276
+ children: [/*#__PURE__*/_jsx("div", {
277
+ className: "kage-timepicker-column",
278
+ ref: hourRef,
279
+ children: hourOptions.map(function (hour) {
280
+ return /*#__PURE__*/_jsx("div", {
281
+ "data-value": hour,
282
+ className: "kage-timepicker-cell ".concat((value === null || value === void 0 ? void 0 : value.hour) === hour ? 'kage-timepicker-cell-selected' : ''),
283
+ onClick: function onClick() {
284
+ return handleSelectTime('hour', hour);
285
+ },
286
+ children: String(hour).padStart(2, '0')
287
+ }, hour);
288
+ })
289
+ }), /*#__PURE__*/_jsx("div", {
290
+ className: "kage-timepicker-column",
291
+ ref: minuteRef,
292
+ children: minuteOptions.map(function (minute) {
293
+ return /*#__PURE__*/_jsx("div", {
294
+ "data-value": minute,
295
+ className: "kage-timepicker-cell ".concat((value === null || value === void 0 ? void 0 : value.minute) === minute ? 'kage-timepicker-cell-selected' : ''),
296
+ onClick: function onClick() {
297
+ return handleSelectTime('minute', minute);
298
+ },
299
+ children: String(minute).padStart(2, '0')
300
+ }, minute);
301
+ })
302
+ }), showSecond && /*#__PURE__*/_jsx("div", {
303
+ className: "kage-timepicker-column",
304
+ ref: secondRef,
305
+ children: secondOptions.map(function (second) {
306
+ return /*#__PURE__*/_jsx("div", {
307
+ "data-value": second,
308
+ className: "kage-timepicker-cell ".concat((value === null || value === void 0 ? void 0 : value.second) === second ? 'kage-timepicker-cell-selected' : ''),
309
+ onClick: function onClick() {
310
+ return handleSelectTime('second', second);
311
+ },
312
+ children: String(second).padStart(2, '0')
313
+ }, second);
314
+ })
315
+ })]
316
+ }), /*#__PURE__*/_jsx("div", {
317
+ className: "kage-timepicker-footer",
318
+ children: /*#__PURE__*/_jsx("button", {
319
+ className: "kage-timepicker-now",
320
+ onClick: handleNow,
321
+ children: "\u6B64\u523B"
322
+ })
323
+ })]
324
+ })]
325
+ });
326
+ };
327
+ export default TimePicker;
@@ -0,0 +1,384 @@
1
+ // TimePicker 时间选择器样式
2
+
3
+ @prefix: kage-timepicker;
4
+
5
+ // 颜色变量
6
+ @timepicker-bg: #fff;
7
+ @timepicker-border: #d9d9d9;
8
+ @timepicker-hover-border: #6366f1;
9
+ @timepicker-focus-border: #6366f1;
10
+ @timepicker-focus-shadow: 0 0 0 2px rgba(99, 102, 241, 0.1);
11
+ @timepicker-disabled-bg: #f5f5f5;
12
+ @timepicker-disabled-color: rgba(0, 0, 0, 0.25);
13
+ @timepicker-placeholder-color: rgba(0, 0, 0, 0.35);
14
+ @timepicker-panel-bg: #fff;
15
+ @timepicker-panel-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
16
+ @timepicker-cell-hover-bg: rgba(0, 0, 0, 0.04);
17
+ @timepicker-cell-selected-bg: #e0e7ff;
18
+ @timepicker-cell-selected-color: #4f46e5;
19
+
20
+ // ============ 容器 ============
21
+ .@{prefix} {
22
+ position: relative;
23
+ display: inline-block;
24
+ width: 100%;
25
+
26
+ * {
27
+ box-sizing: border-box;
28
+ }
29
+ }
30
+
31
+ // ============ 输入框 ============
32
+ .@{prefix}-input {
33
+ position: relative;
34
+ display: flex;
35
+ align-items: center;
36
+ width: 100%;
37
+ padding: 8px 12px;
38
+ background: @timepicker-bg;
39
+ border: 1px solid @timepicker-border;
40
+ border-radius: 6px;
41
+ cursor: pointer;
42
+ transition: all 0.2s ease;
43
+
44
+ &:hover {
45
+ border-color: @timepicker-hover-border;
46
+ }
47
+ }
48
+
49
+ .@{prefix}-open .@{prefix}-input {
50
+ border-color: @timepicker-focus-border;
51
+ box-shadow: @timepicker-focus-shadow;
52
+ }
53
+
54
+ .@{prefix}-value {
55
+ flex: 1;
56
+ font-size: 14px;
57
+ color: rgba(0, 0, 0, 0.88);
58
+ line-height: 1.5;
59
+ }
60
+
61
+ .@{prefix}-placeholder {
62
+ color: @timepicker-placeholder-color;
63
+ }
64
+
65
+ .@{prefix}-clear {
66
+ display: flex;
67
+ align-items: center;
68
+ justify-content: center;
69
+ width: 16px;
70
+ height: 16px;
71
+ margin-right: 4px;
72
+ font-size: 12px;
73
+ color: rgba(0, 0, 0, 0.35);
74
+ background: rgba(0, 0, 0, 0.06);
75
+ border-radius: 50%;
76
+ cursor: pointer;
77
+ transition: all 0.2s ease;
78
+ line-height: 1;
79
+
80
+ &:hover {
81
+ color: rgba(0, 0, 0, 0.65);
82
+ background: rgba(0, 0, 0, 0.12);
83
+ }
84
+ }
85
+
86
+ .@{prefix}-icon {
87
+ display: flex;
88
+ align-items: center;
89
+ font-size: 14px;
90
+ color: rgba(0, 0, 0, 0.35);
91
+ pointer-events: none;
92
+ }
93
+
94
+ // ============ 尺寸变体 ============
95
+ .@{prefix}-large .@{prefix}-input {
96
+ padding: 10px 14px;
97
+ font-size: 16px;
98
+ }
99
+
100
+ .@{prefix}-small .@{prefix}-input {
101
+ padding: 4px 8px;
102
+ font-size: 12px;
103
+ }
104
+
105
+ // ============ 状态变体 ============
106
+ .@{prefix}-status-error .@{prefix}-input {
107
+ border-color: #ff4d4f;
108
+
109
+ &:hover {
110
+ border-color: #ff7875;
111
+ }
112
+ }
113
+
114
+ .@{prefix}-status-warning .@{prefix}-input {
115
+ border-color: #faad14;
116
+
117
+ &:hover {
118
+ border-color: #ffc53d;
119
+ }
120
+ }
121
+
122
+ .@{prefix}-disabled {
123
+ .@{prefix}-input {
124
+ background: @timepicker-disabled-bg;
125
+ border-color: @timepicker-border;
126
+ cursor: not-allowed;
127
+
128
+ &:hover {
129
+ border-color: @timepicker-border;
130
+ }
131
+ }
132
+
133
+ .@{prefix}-value {
134
+ color: @timepicker-disabled-color;
135
+ }
136
+
137
+ .@{prefix}-icon {
138
+ color: @timepicker-disabled-color;
139
+ }
140
+ }
141
+
142
+ // ============ 面板 ============
143
+ .@{prefix}-panel {
144
+ position: absolute;
145
+ top: calc(100% + 4px);
146
+ left: 0;
147
+ z-index: 1050;
148
+ width: auto;
149
+ background: @timepicker-panel-bg;
150
+ border-radius: 8px;
151
+ box-shadow: @timepicker-panel-shadow;
152
+ overflow: hidden;
153
+ animation: timepickerSlideDown 0.2s ease;
154
+ }
155
+
156
+ @keyframes timepickerSlideDown {
157
+ from {
158
+ opacity: 0;
159
+ transform: translateY(-8px);
160
+ }
161
+ to {
162
+ opacity: 1;
163
+ transform: translateY(0);
164
+ }
165
+ }
166
+
167
+ .@{prefix}-panel-inner {
168
+ display: flex;
169
+ gap: 0;
170
+ }
171
+
172
+ // ============ 时间列 ============
173
+ .@{prefix}-column {
174
+ flex: 1;
175
+ width: 64px;
176
+ max-height: 224px;
177
+ overflow-y: auto;
178
+ border-right: 1px solid #f0f0f0;
179
+
180
+ &:last-child {
181
+ border-right: none;
182
+ }
183
+
184
+ &::-webkit-scrollbar {
185
+ width: 6px;
186
+ }
187
+
188
+ &::-webkit-scrollbar-thumb {
189
+ background: rgba(0, 0, 0, 0.1);
190
+ border-radius: 3px;
191
+
192
+ &:hover {
193
+ background: rgba(0, 0, 0, 0.2);
194
+ }
195
+ }
196
+ }
197
+
198
+ .@{prefix}-cell {
199
+ display: flex;
200
+ align-items: center;
201
+ justify-content: center;
202
+ height: 32px;
203
+ padding: 0 8px;
204
+ font-size: 14px;
205
+ color: rgba(0, 0, 0, 0.88);
206
+ cursor: pointer;
207
+ transition: all 0.2s ease;
208
+
209
+ &:hover {
210
+ background: @timepicker-cell-hover-bg;
211
+ }
212
+ }
213
+
214
+ .@{prefix}-cell-selected {
215
+ background: @timepicker-cell-selected-bg;
216
+ color: @timepicker-cell-selected-color;
217
+ font-weight: 600;
218
+
219
+ &:hover {
220
+ background: @timepicker-cell-selected-bg;
221
+ }
222
+ }
223
+
224
+ .@{prefix}-cell-disabled {
225
+ color: @timepicker-disabled-color;
226
+ cursor: not-allowed;
227
+
228
+ &:hover {
229
+ background: transparent;
230
+ }
231
+ }
232
+
233
+ // ============ 底部 ============
234
+ .@{prefix}-footer {
235
+ display: flex;
236
+ align-items: center;
237
+ justify-content: flex-end;
238
+ padding: 8px 12px;
239
+ border-top: 1px solid #f0f0f0;
240
+ }
241
+
242
+ .@{prefix}-now {
243
+ padding: 4px 12px;
244
+ font-size: 13px;
245
+ color: #6366f1;
246
+ background: transparent;
247
+ border: none;
248
+ border-radius: 4px;
249
+ cursor: pointer;
250
+ transition: all 0.2s ease;
251
+
252
+ &:hover {
253
+ background: rgba(99, 102, 241, 0.08);
254
+ }
255
+
256
+ &:active {
257
+ background: rgba(99, 102, 241, 0.15);
258
+ }
259
+ }
260
+
261
+ // ============ 暗色模式适配 ============
262
+ [data-theme='dark'],
263
+ [data-prefers-color-scheme='dark'],
264
+ [data-prefers-color='dark'] {
265
+ .@{prefix}-input {
266
+ background: #1f1f1f;
267
+ border-color: #434343;
268
+ color: rgba(255, 255, 255, 0.88);
269
+
270
+ &:hover {
271
+ border-color: #6366f1;
272
+ }
273
+ }
274
+
275
+ .@{prefix}-open .@{prefix}-input {
276
+ border-color: #6366f1;
277
+ box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.2);
278
+ }
279
+
280
+ .@{prefix}-value {
281
+ color: rgba(255, 255, 255, 0.88);
282
+ }
283
+
284
+ .@{prefix}-placeholder {
285
+ color: rgba(255, 255, 255, 0.35);
286
+ }
287
+
288
+ .@{prefix}-clear {
289
+ color: rgba(255, 255, 255, 0.35);
290
+ background: rgba(255, 255, 255, 0.08);
291
+
292
+ &:hover {
293
+ color: rgba(255, 255, 255, 0.65);
294
+ background: rgba(255, 255, 255, 0.15);
295
+ }
296
+ }
297
+
298
+ .@{prefix}-icon {
299
+ color: rgba(255, 255, 255, 0.35);
300
+ }
301
+
302
+ .@{prefix}-disabled {
303
+ .@{prefix}-input {
304
+ background: rgba(255, 255, 255, 0.04);
305
+ border-color: #434343;
306
+ }
307
+
308
+ .@{prefix}-value,
309
+ .@{prefix}-icon {
310
+ color: rgba(255, 255, 255, 0.25);
311
+ }
312
+ }
313
+
314
+ .@{prefix}-panel {
315
+ background: #1f1f1f;
316
+ box-shadow: 0 6px 16px rgba(0, 0, 0, 0.4);
317
+ }
318
+
319
+ .@{prefix}-column {
320
+ border-right-color: #434343;
321
+
322
+ &::-webkit-scrollbar-thumb {
323
+ background: rgba(255, 255, 255, 0.2);
324
+
325
+ &:hover {
326
+ background: rgba(255, 255, 255, 0.3);
327
+ }
328
+ }
329
+ }
330
+
331
+ .@{prefix}-cell {
332
+ color: rgba(255, 255, 255, 0.88);
333
+
334
+ &:hover {
335
+ background: rgba(255, 255, 255, 0.08);
336
+ }
337
+ }
338
+
339
+ .@{prefix}-cell-selected {
340
+ background: rgba(99, 102, 241, 0.3);
341
+ color: #a5b4fc;
342
+
343
+ &:hover {
344
+ background: rgba(99, 102, 241, 0.3);
345
+ }
346
+ }
347
+
348
+ .@{prefix}-cell-disabled {
349
+ color: rgba(255, 255, 255, 0.25);
350
+ }
351
+
352
+ .@{prefix}-footer {
353
+ border-top-color: #434343;
354
+ }
355
+
356
+ .@{prefix}-now {
357
+ color: #a5b4fc;
358
+
359
+ &:hover {
360
+ background: rgba(99, 102, 241, 0.2);
361
+ }
362
+
363
+ &:active {
364
+ background: rgba(99, 102, 241, 0.3);
365
+ }
366
+ }
367
+
368
+ .@{prefix}-status-error .@{prefix}-input {
369
+ border-color: #a61d24;
370
+
371
+ &:hover {
372
+ border-color: #cf1322;
373
+ }
374
+ }
375
+
376
+ .@{prefix}-status-warning .@{prefix}-input {
377
+ border-color: #ad6800;
378
+
379
+ &:hover {
380
+ border-color: #d48806;
381
+ }
382
+ }
383
+ }
384
+