dn-react-router-toolkit 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 (284) hide show
  1. package/dist/auth-kit/apple_auth.d.mts +24 -0
  2. package/dist/{esm/auth-kit → auth-kit}/apple_auth.d.ts +11 -2
  3. package/dist/auth-kit/apple_auth.js +75 -0
  4. package/dist/auth-kit/apple_auth.mjs +50 -0
  5. package/dist/auth-kit/auth_service.d.mts +73 -0
  6. package/dist/{esm/auth-kit → auth-kit}/auth_service.d.ts +17 -11
  7. package/dist/auth-kit/auth_service.js +257 -0
  8. package/dist/auth-kit/auth_service.mjs +218 -0
  9. package/dist/auth-kit/client/google_login_button.d.mts +9 -0
  10. package/dist/auth-kit/client/google_login_button.d.ts +9 -0
  11. package/dist/auth-kit/client/google_login_button.js +67 -0
  12. package/dist/auth-kit/client/google_login_button.mjs +32 -0
  13. package/dist/auth-kit/client/redirect_page.d.mts +5 -0
  14. package/dist/auth-kit/client/redirect_page.d.ts +5 -0
  15. package/dist/auth-kit/client/redirect_page.js +53 -0
  16. package/dist/auth-kit/client/redirect_page.mjs +18 -0
  17. package/dist/auth-kit/google_auth.d.mts +27 -0
  18. package/dist/{esm/auth-kit → auth-kit}/google_auth.d.ts +11 -2
  19. package/dist/auth-kit/google_auth.js +144 -0
  20. package/dist/auth-kit/google_auth.mjs +117 -0
  21. package/dist/auth-kit/jwt.d.mts +18 -0
  22. package/dist/{esm/auth-kit → auth-kit}/jwt.d.ts +5 -2
  23. package/dist/auth-kit/jwt.js +76 -0
  24. package/dist/auth-kit/jwt.mjs +51 -0
  25. package/dist/auth-kit/kakao_auth.d.mts +24 -0
  26. package/dist/{esm/auth-kit → auth-kit}/kakao_auth.d.ts +11 -2
  27. package/dist/auth-kit/kakao_auth.js +115 -0
  28. package/dist/auth-kit/kakao_auth.mjs +88 -0
  29. package/dist/auth-kit/repository.d.mts +42 -0
  30. package/dist/{esm/auth-kit → auth-kit}/repository.d.ts +3 -1
  31. package/dist/auth-kit/repository.js +18 -0
  32. package/dist/auth-kit/repository.mjs +0 -0
  33. package/dist/auth-kit/with_auth.d.mts +17 -0
  34. package/dist/auth-kit/with_auth.d.ts +17 -0
  35. package/dist/auth-kit/with_auth.js +106 -0
  36. package/dist/auth-kit/with_auth.mjs +69 -0
  37. package/dist/cn.d.mts +3 -0
  38. package/dist/cn.d.ts +3 -0
  39. package/dist/cn.js +32 -0
  40. package/dist/cn.mjs +7 -0
  41. package/dist/components/index.d.mts +5 -0
  42. package/dist/components/index.d.ts +5 -0
  43. package/dist/components/index.js +261 -0
  44. package/dist/components/index.mjs +219 -0
  45. package/dist/components/modal/fullscreen_container.d.mts +7 -0
  46. package/dist/components/modal/fullscreen_container.d.ts +7 -0
  47. package/dist/components/modal/fullscreen_container.js +102 -0
  48. package/dist/components/modal/fullscreen_container.mjs +68 -0
  49. package/dist/components/modal/hooks.d.mts +18 -0
  50. package/dist/components/modal/hooks.d.ts +18 -0
  51. package/dist/components/modal/hooks.js +236 -0
  52. package/dist/components/modal/hooks.mjs +204 -0
  53. package/dist/components/modal/index.d.mts +4 -0
  54. package/dist/components/modal/index.d.ts +4 -0
  55. package/dist/components/modal/index.js +238 -0
  56. package/dist/components/modal/index.mjs +203 -0
  57. package/dist/components/modal/modal.d.mts +13 -0
  58. package/dist/components/modal/modal.d.ts +13 -0
  59. package/dist/components/modal/modal.js +155 -0
  60. package/dist/components/modal/modal.mjs +130 -0
  61. package/dist/components/styles.d.mts +9 -0
  62. package/dist/components/styles.d.ts +9 -0
  63. package/dist/components/styles.js +48 -0
  64. package/dist/components/styles.mjs +17 -0
  65. package/dist/date.d.mts +3 -0
  66. package/dist/date.d.ts +3 -0
  67. package/dist/date.js +63 -0
  68. package/dist/date.mjs +28 -0
  69. package/dist/file-kit/cdn.d.mts +5 -0
  70. package/dist/file-kit/cdn.d.ts +5 -0
  71. package/dist/file-kit/cdn.js +34 -0
  72. package/dist/file-kit/cdn.mjs +9 -0
  73. package/dist/file-kit/client/drop_file_input.d.mts +33 -0
  74. package/dist/{esm/file-kit → file-kit}/client/drop_file_input.d.ts +10 -8
  75. package/dist/file-kit/client/drop_file_input.js +235 -0
  76. package/dist/file-kit/client/drop_file_input.mjs +205 -0
  77. package/dist/file-kit/client/file_uploader.d.mts +13 -0
  78. package/dist/{esm/file-kit → file-kit}/client/file_uploader.d.ts +4 -2
  79. package/dist/file-kit/client/file_uploader.js +115 -0
  80. package/dist/file-kit/client/file_uploader.mjs +90 -0
  81. package/dist/file-kit/file_service.d.mts +26 -0
  82. package/dist/{esm/file-kit → file-kit}/file_service.d.ts +7 -4
  83. package/dist/file-kit/file_service.js +60 -0
  84. package/dist/file-kit/file_service.mjs +35 -0
  85. package/dist/file-kit/object_storage.d.mts +17 -0
  86. package/dist/{esm/file-kit → file-kit}/object_storage.d.ts +6 -2
  87. package/dist/file-kit/object_storage.js +78 -0
  88. package/dist/file-kit/object_storage.mjs +57 -0
  89. package/dist/file-kit/repository.d.mts +16 -0
  90. package/dist/{esm/file-kit → file-kit}/repository.d.ts +3 -1
  91. package/dist/file-kit/repository.js +18 -0
  92. package/dist/file-kit/repository.mjs +0 -0
  93. package/dist/file-kit/responsive_image.d.mts +20 -0
  94. package/dist/file-kit/responsive_image.d.ts +20 -0
  95. package/dist/file-kit/responsive_image.js +123 -0
  96. package/dist/file-kit/responsive_image.mjs +87 -0
  97. package/dist/http-kit/index.d.mts +1 -0
  98. package/dist/http-kit/index.d.ts +1 -0
  99. package/dist/http-kit/index.js +111 -0
  100. package/dist/http-kit/index.mjs +68 -0
  101. package/dist/http-kit/response.d.mts +19 -0
  102. package/dist/http-kit/response.d.ts +19 -0
  103. package/dist/http-kit/response.js +109 -0
  104. package/dist/http-kit/response.mjs +68 -0
  105. package/dist/index.d.mts +4 -0
  106. package/dist/index.d.ts +4 -0
  107. package/dist/index.js +91 -0
  108. package/dist/index.mjs +51 -0
  109. package/dist/route/api/auth/login/[provider]/route.js +113 -0
  110. package/dist/route/api/auth/login/[provider]/route.mjs +86 -0
  111. package/dist/route/api/auth/login/_provider_/route.d.mts +20 -0
  112. package/dist/route/api/auth/login/_provider_/route.d.ts +20 -0
  113. package/dist/route/api/auth/login/route.d.mts +14 -0
  114. package/dist/route/api/auth/login/route.d.ts +14 -0
  115. package/dist/route/api/auth/login/route.js +107 -0
  116. package/dist/route/api/auth/login/route.mjs +80 -0
  117. package/dist/route/api/auth/logout/route.d.mts +14 -0
  118. package/dist/route/api/auth/logout/route.d.ts +14 -0
  119. package/dist/route/api/auth/logout/route.js +98 -0
  120. package/dist/route/api/auth/logout/route.mjs +71 -0
  121. package/dist/route/api/auth/refresh/route.d.mts +13 -0
  122. package/dist/route/api/auth/refresh/route.d.ts +13 -0
  123. package/dist/route/api/auth/refresh/route.js +92 -0
  124. package/dist/route/api/auth/refresh/route.mjs +65 -0
  125. package/dist/route/api/auth/route.d.mts +13 -0
  126. package/dist/route/api/auth/route.d.ts +13 -0
  127. package/dist/route/api/auth/route.js +82 -0
  128. package/dist/route/api/auth/route.mjs +55 -0
  129. package/dist/route/api/files/[fileId]/route.js +99 -0
  130. package/dist/route/api/files/[fileId]/route.mjs +72 -0
  131. package/dist/route/api/files/_fileId_/route.d.mts +17 -0
  132. package/dist/route/api/files/_fileId_/route.d.ts +17 -0
  133. package/dist/route/api/files/route.d.mts +16 -0
  134. package/dist/route/api/files/route.d.ts +16 -0
  135. package/dist/route/api/files/route.js +106 -0
  136. package/dist/route/api/files/route.mjs +79 -0
  137. package/dist/route/api.d.mts +29 -0
  138. package/dist/route/api.d.ts +29 -0
  139. package/dist/route/api.js +395 -0
  140. package/dist/route/api.mjs +368 -0
  141. package/dist/route/auth/callback/[provider]/route.js +120 -0
  142. package/dist/route/auth/callback/[provider]/route.mjs +93 -0
  143. package/dist/route/auth/callback/_provider_/route.d.mts +20 -0
  144. package/dist/route/auth/callback/_provider_/route.d.ts +20 -0
  145. package/dist/seo-kit/index.d.mts +6 -0
  146. package/dist/seo-kit/index.d.ts +6 -0
  147. package/dist/seo-kit/index.js +321 -0
  148. package/dist/seo-kit/index.mjs +282 -0
  149. package/dist/seo-kit/loader.d.mts +7 -0
  150. package/dist/seo-kit/loader.d.ts +7 -0
  151. package/dist/seo-kit/loader.js +43 -0
  152. package/dist/seo-kit/loader.mjs +18 -0
  153. package/dist/seo-kit/seo.d.mts +103 -0
  154. package/dist/{esm/seo-kit → seo-kit}/seo.d.ts +10 -6
  155. package/dist/seo-kit/seo.js +286 -0
  156. package/dist/seo-kit/seo.mjs +251 -0
  157. package/dist/seo-kit/seo_loader.d.mts +16 -0
  158. package/dist/seo-kit/seo_loader.d.ts +16 -0
  159. package/dist/seo-kit/seo_loader.js +68 -0
  160. package/dist/seo-kit/seo_loader.mjs +31 -0
  161. package/dist/singleton.d.mts +3 -0
  162. package/dist/singleton.d.ts +3 -0
  163. package/dist/singleton.js +37 -0
  164. package/dist/singleton.mjs +12 -0
  165. package/dist/slug.d.mts +3 -0
  166. package/dist/slug.d.ts +3 -0
  167. package/dist/slug.js +32 -0
  168. package/dist/slug.mjs +7 -0
  169. package/package.json +36 -34
  170. package/tsup.config.ts +9 -0
  171. package/dist/cjs/auth-kit/apple_auth.js +0 -61
  172. package/dist/cjs/auth-kit/auth_service.js +0 -204
  173. package/dist/cjs/auth-kit/client/google_login_button.js +0 -19
  174. package/dist/cjs/auth-kit/client/redirect_page.js +0 -18
  175. package/dist/cjs/auth-kit/google_auth.js +0 -69
  176. package/dist/cjs/auth-kit/jwt.js +0 -54
  177. package/dist/cjs/auth-kit/kakao_auth.js +0 -43
  178. package/dist/cjs/auth-kit/repository.js +0 -2
  179. package/dist/cjs/auth-kit/with_auth.js +0 -46
  180. package/dist/cjs/cn.js +0 -6
  181. package/dist/cjs/components/index.js +0 -18
  182. package/dist/cjs/components/modal/fullscreen_container.js +0 -49
  183. package/dist/cjs/components/modal/hooks.js +0 -76
  184. package/dist/cjs/components/modal/index.js +0 -19
  185. package/dist/cjs/components/modal/modal.js +0 -79
  186. package/dist/cjs/components/styles.js +0 -10
  187. package/dist/cjs/date.js +0 -31
  188. package/dist/cjs/file-kit/cdn.js +0 -9
  189. package/dist/cjs/file-kit/client/drop_file_input.js +0 -148
  190. package/dist/cjs/file-kit/client/file_uploader.js +0 -88
  191. package/dist/cjs/file-kit/file_service.js +0 -32
  192. package/dist/cjs/file-kit/object_storage.js +0 -51
  193. package/dist/cjs/file-kit/repository.js +0 -2
  194. package/dist/cjs/file-kit/responsive_image.js +0 -63
  195. package/dist/cjs/http-kit/index.js +0 -17
  196. package/dist/cjs/http-kit/response.js +0 -37
  197. package/dist/cjs/index.js +0 -20
  198. package/dist/cjs/route/api/auth/login/[provider]/route.js +0 -36
  199. package/dist/cjs/route/api/auth/login/route.js +0 -35
  200. package/dist/cjs/route/api/auth/logout/route.js +0 -22
  201. package/dist/cjs/route/api/auth/refresh/route.js +0 -22
  202. package/dist/cjs/route/api/auth/route.js +0 -12
  203. package/dist/cjs/route/api/files/[fileId]/route.js +0 -20
  204. package/dist/cjs/route/api/files/route.js +0 -34
  205. package/dist/cjs/route/auth/callback/[provider]/route.js +0 -38
  206. package/dist/cjs/route/index.js +0 -80
  207. package/dist/cjs/seo-kit/index.js +0 -19
  208. package/dist/cjs/seo-kit/loader.js +0 -17
  209. package/dist/cjs/seo-kit/seo.js +0 -278
  210. package/dist/cjs/seo-kit/seo_loader.js +0 -15
  211. package/dist/cjs/singleton.js +0 -12
  212. package/dist/cjs/slug.js +0 -10
  213. package/dist/esm/auth-kit/apple_auth.js +0 -57
  214. package/dist/esm/auth-kit/auth_service.js +0 -197
  215. package/dist/esm/auth-kit/client/google_login_button.d.ts +0 -5
  216. package/dist/esm/auth-kit/client/google_login_button.js +0 -16
  217. package/dist/esm/auth-kit/client/redirect_page.d.ts +0 -1
  218. package/dist/esm/auth-kit/client/redirect_page.js +0 -15
  219. package/dist/esm/auth-kit/google_auth.js +0 -65
  220. package/dist/esm/auth-kit/jwt.js +0 -50
  221. package/dist/esm/auth-kit/kakao_auth.js +0 -39
  222. package/dist/esm/auth-kit/repository.js +0 -1
  223. package/dist/esm/auth-kit/with_auth.d.ts +0 -12
  224. package/dist/esm/auth-kit/with_auth.js +0 -43
  225. package/dist/esm/cn.d.ts +0 -1
  226. package/dist/esm/cn.js +0 -3
  227. package/dist/esm/components/index.d.ts +0 -2
  228. package/dist/esm/components/index.js +0 -2
  229. package/dist/esm/components/modal/fullscreen_container.d.ts +0 -5
  230. package/dist/esm/components/modal/fullscreen_container.js +0 -45
  231. package/dist/esm/components/modal/hooks.d.ts +0 -15
  232. package/dist/esm/components/modal/hooks.js +0 -67
  233. package/dist/esm/components/modal/index.d.ts +0 -3
  234. package/dist/esm/components/modal/index.js +0 -3
  235. package/dist/esm/components/modal/modal.d.ts +0 -10
  236. package/dist/esm/components/modal/modal.js +0 -43
  237. package/dist/esm/components/styles.d.ts +0 -7
  238. package/dist/esm/components/styles.js +0 -7
  239. package/dist/esm/date.d.ts +0 -1
  240. package/dist/esm/date.js +0 -24
  241. package/dist/esm/file-kit/cdn.d.ts +0 -3
  242. package/dist/esm/file-kit/cdn.js +0 -5
  243. package/dist/esm/file-kit/client/drop_file_input.js +0 -144
  244. package/dist/esm/file-kit/client/file_uploader.js +0 -84
  245. package/dist/esm/file-kit/file_service.js +0 -28
  246. package/dist/esm/file-kit/object_storage.js +0 -47
  247. package/dist/esm/file-kit/repository.js +0 -1
  248. package/dist/esm/file-kit/responsive_image.d.ts +0 -17
  249. package/dist/esm/file-kit/responsive_image.js +0 -58
  250. package/dist/esm/http-kit/index.d.ts +0 -1
  251. package/dist/esm/http-kit/index.js +0 -1
  252. package/dist/esm/http-kit/response.d.ts +0 -17
  253. package/dist/esm/http-kit/response.js +0 -31
  254. package/dist/esm/index.d.ts +0 -4
  255. package/dist/esm/index.js +0 -4
  256. package/dist/esm/route/api/auth/login/[provider]/route.d.ts +0 -10
  257. package/dist/esm/route/api/auth/login/[provider]/route.js +0 -32
  258. package/dist/esm/route/api/auth/login/route.d.ts +0 -6
  259. package/dist/esm/route/api/auth/login/route.js +0 -31
  260. package/dist/esm/route/api/auth/logout/route.d.ts +0 -6
  261. package/dist/esm/route/api/auth/logout/route.js +0 -18
  262. package/dist/esm/route/api/auth/refresh/route.d.ts +0 -4
  263. package/dist/esm/route/api/auth/refresh/route.js +0 -18
  264. package/dist/esm/route/api/auth/route.d.ts +0 -4
  265. package/dist/esm/route/api/auth/route.js +0 -8
  266. package/dist/esm/route/api/files/[fileId]/route.d.ts +0 -8
  267. package/dist/esm/route/api/files/[fileId]/route.js +0 -16
  268. package/dist/esm/route/api/files/route.d.ts +0 -6
  269. package/dist/esm/route/api/files/route.js +0 -30
  270. package/dist/esm/route/auth/callback/[provider]/route.d.ts +0 -11
  271. package/dist/esm/route/auth/callback/[provider]/route.js +0 -34
  272. package/dist/esm/route/index.d.ts +0 -22
  273. package/dist/esm/route/index.js +0 -76
  274. package/dist/esm/seo-kit/index.d.ts +0 -3
  275. package/dist/esm/seo-kit/index.js +0 -3
  276. package/dist/esm/seo-kit/loader.d.ts +0 -5
  277. package/dist/esm/seo-kit/loader.js +0 -14
  278. package/dist/esm/seo-kit/seo.js +0 -275
  279. package/dist/esm/seo-kit/seo_loader.d.ts +0 -12
  280. package/dist/esm/seo-kit/seo_loader.js +0 -12
  281. package/dist/esm/singleton.d.ts +0 -1
  282. package/dist/esm/singleton.js +0 -9
  283. package/dist/esm/slug.d.ts +0 -1
  284. package/dist/esm/slug.js +0 -6
@@ -0,0 +1,155 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/components/modal/modal.tsx
31
+ var modal_exports = {};
32
+ __export(modal_exports, {
33
+ default: () => Modal
34
+ });
35
+ module.exports = __toCommonJS(modal_exports);
36
+ var import_react3 = __toESM(require("react"));
37
+
38
+ // src/cn.ts
39
+ function cn(...classes) {
40
+ return classes.filter(Boolean).join(" ").trim();
41
+ }
42
+
43
+ // src/components/modal/fullscreen_container.tsx
44
+ var import_react = __toESM(require("react"));
45
+ var import_react2 = require("react");
46
+ function useFullscreen(ref) {
47
+ (0, import_react2.useEffect)(() => {
48
+ const container = ref.current;
49
+ if (!container) {
50
+ return;
51
+ }
52
+ const scroll = () => {
53
+ if (scrollY > 0) {
54
+ window.scrollTo({
55
+ top: 0,
56
+ behavior: "instant"
57
+ });
58
+ }
59
+ };
60
+ const resize = () => {
61
+ if (!visualViewport) {
62
+ return;
63
+ }
64
+ container.classList.remove("bottom-0");
65
+ container.style.height = `${visualViewport?.height}px`;
66
+ if (visualViewport.height < window.innerHeight) {
67
+ window.addEventListener("scroll", scroll);
68
+ } else {
69
+ window.removeEventListener("scroll", scroll);
70
+ }
71
+ };
72
+ resize();
73
+ visualViewport?.addEventListener("resize", resize);
74
+ scroll();
75
+ return () => {
76
+ window.removeEventListener("scroll", scroll);
77
+ visualViewport?.removeEventListener("resize", resize);
78
+ };
79
+ }, [ref]);
80
+ return "fixed inset-0";
81
+ }
82
+
83
+ // src/components/modal/modal.tsx
84
+ function Modal({
85
+ open,
86
+ className,
87
+ background = "bg-gray-500/25",
88
+ onBackgroundClick,
89
+ children,
90
+ ...props
91
+ }) {
92
+ const containerRef = (0, import_react3.useRef)(null);
93
+ const fullscreen = useFullscreen(containerRef);
94
+ const [mounted, setMounted] = import_react3.default.useState(false);
95
+ (0, import_react3.useEffect)(() => {
96
+ if (open) {
97
+ setMounted(true);
98
+ } else {
99
+ setTimeout(() => {
100
+ setMounted(false);
101
+ }, 200);
102
+ }
103
+ return () => {
104
+ };
105
+ }, [open]);
106
+ const onBackgroundMouseDown = (event) => {
107
+ event.preventDefault();
108
+ onBackgroundClick?.();
109
+ };
110
+ const onModalMouseDown = (event) => {
111
+ event.stopPropagation();
112
+ };
113
+ const onBackgroundTouchStart = (event) => {
114
+ event.preventDefault();
115
+ onBackgroundClick?.();
116
+ };
117
+ const onModalTouchStart = (event) => {
118
+ event.stopPropagation();
119
+ };
120
+ return /* @__PURE__ */ import_react3.default.createElement(
121
+ "div",
122
+ {
123
+ ref: containerRef,
124
+ className: cn(
125
+ fullscreen,
126
+ "z-[999] flex flex-col justify-center transition-bg duration-200 md:px-6 overflow-hidden print:px-0 print:block print:overflow-auto",
127
+ open && mounted ? cn(background, "ease-out") : "bg-transparent ease-in pointer-events-none"
128
+ ),
129
+ onMouseDown: onBackgroundMouseDown,
130
+ onTouchStart: onBackgroundTouchStart
131
+ },
132
+ /* @__PURE__ */ import_react3.default.createElement(
133
+ "div",
134
+ {
135
+ className: cn(
136
+ "relative flex-1 flex flex-col justify-end md:justify-center items-center transition-[opacity transform] duration-200 print:block",
137
+ open && mounted ? "translate-y-[0px] opacity-100 ease-out" : "translate-y-[100%] md:translate-y-[50px] opacity-0 ease-in"
138
+ )
139
+ },
140
+ (open || mounted) && /* @__PURE__ */ import_react3.default.createElement(
141
+ "div",
142
+ {
143
+ ...props,
144
+ className: cn(
145
+ className,
146
+ "w-full max-h-[92vh] print:w-[unset] print:max-h-[unset] rounded-tl-lg rounded-tr-lg md:rounded-lg overflow-auto print:rounded-none"
147
+ ),
148
+ onMouseDown: onModalMouseDown,
149
+ onTouchStart: onModalTouchStart
150
+ },
151
+ children
152
+ )
153
+ )
154
+ );
155
+ }
@@ -0,0 +1,130 @@
1
+ // src/components/modal/modal.tsx
2
+ import React2, {
3
+ useEffect as useEffect2,
4
+ useRef as useRef2
5
+ } from "react";
6
+
7
+ // src/cn.ts
8
+ function cn(...classes) {
9
+ return classes.filter(Boolean).join(" ").trim();
10
+ }
11
+
12
+ // src/components/modal/fullscreen_container.tsx
13
+ import React from "react";
14
+ import {
15
+ useEffect,
16
+ useRef
17
+ } from "react";
18
+ function useFullscreen(ref) {
19
+ useEffect(() => {
20
+ const container = ref.current;
21
+ if (!container) {
22
+ return;
23
+ }
24
+ const scroll = () => {
25
+ if (scrollY > 0) {
26
+ window.scrollTo({
27
+ top: 0,
28
+ behavior: "instant"
29
+ });
30
+ }
31
+ };
32
+ const resize = () => {
33
+ if (!visualViewport) {
34
+ return;
35
+ }
36
+ container.classList.remove("bottom-0");
37
+ container.style.height = `${visualViewport?.height}px`;
38
+ if (visualViewport.height < window.innerHeight) {
39
+ window.addEventListener("scroll", scroll);
40
+ } else {
41
+ window.removeEventListener("scroll", scroll);
42
+ }
43
+ };
44
+ resize();
45
+ visualViewport?.addEventListener("resize", resize);
46
+ scroll();
47
+ return () => {
48
+ window.removeEventListener("scroll", scroll);
49
+ visualViewport?.removeEventListener("resize", resize);
50
+ };
51
+ }, [ref]);
52
+ return "fixed inset-0";
53
+ }
54
+
55
+ // src/components/modal/modal.tsx
56
+ function Modal({
57
+ open,
58
+ className,
59
+ background = "bg-gray-500/25",
60
+ onBackgroundClick,
61
+ children,
62
+ ...props
63
+ }) {
64
+ const containerRef = useRef2(null);
65
+ const fullscreen = useFullscreen(containerRef);
66
+ const [mounted, setMounted] = React2.useState(false);
67
+ useEffect2(() => {
68
+ if (open) {
69
+ setMounted(true);
70
+ } else {
71
+ setTimeout(() => {
72
+ setMounted(false);
73
+ }, 200);
74
+ }
75
+ return () => {
76
+ };
77
+ }, [open]);
78
+ const onBackgroundMouseDown = (event) => {
79
+ event.preventDefault();
80
+ onBackgroundClick?.();
81
+ };
82
+ const onModalMouseDown = (event) => {
83
+ event.stopPropagation();
84
+ };
85
+ const onBackgroundTouchStart = (event) => {
86
+ event.preventDefault();
87
+ onBackgroundClick?.();
88
+ };
89
+ const onModalTouchStart = (event) => {
90
+ event.stopPropagation();
91
+ };
92
+ return /* @__PURE__ */ React2.createElement(
93
+ "div",
94
+ {
95
+ ref: containerRef,
96
+ className: cn(
97
+ fullscreen,
98
+ "z-[999] flex flex-col justify-center transition-bg duration-200 md:px-6 overflow-hidden print:px-0 print:block print:overflow-auto",
99
+ open && mounted ? cn(background, "ease-out") : "bg-transparent ease-in pointer-events-none"
100
+ ),
101
+ onMouseDown: onBackgroundMouseDown,
102
+ onTouchStart: onBackgroundTouchStart
103
+ },
104
+ /* @__PURE__ */ React2.createElement(
105
+ "div",
106
+ {
107
+ className: cn(
108
+ "relative flex-1 flex flex-col justify-end md:justify-center items-center transition-[opacity transform] duration-200 print:block",
109
+ open && mounted ? "translate-y-[0px] opacity-100 ease-out" : "translate-y-[100%] md:translate-y-[50px] opacity-0 ease-in"
110
+ )
111
+ },
112
+ (open || mounted) && /* @__PURE__ */ React2.createElement(
113
+ "div",
114
+ {
115
+ ...props,
116
+ className: cn(
117
+ className,
118
+ "w-full max-h-[92vh] print:w-[unset] print:max-h-[unset] rounded-tl-lg rounded-tr-lg md:rounded-lg overflow-auto print:rounded-none"
119
+ ),
120
+ onMouseDown: onModalMouseDown,
121
+ onTouchStart: onModalTouchStart
122
+ },
123
+ children
124
+ )
125
+ )
126
+ );
127
+ }
128
+ export {
129
+ Modal as default
130
+ };
@@ -0,0 +1,9 @@
1
+ declare const inputBackgroundStyle = "text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400";
2
+ declare const formInputStyle = "w-full px-3 text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400 h-[40px]";
3
+ declare const baseButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden";
4
+ declare const primaryButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden px-4 h-[40px] bg-gradient-to-br from-primary-400 to-primary-500 text-white transition-colors";
5
+ declare const disabledButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-neutral-200 text-neutral-400";
6
+ declare const outlineButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-white border border-neutral-300 hover:bg-neutral-50";
7
+ declare const dangerousButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-white border hover:bg-red-50 text-red-600";
8
+
9
+ export { baseButtonStyle, dangerousButtonStyle, disabledButtonStyle, formInputStyle, inputBackgroundStyle, outlineButtonStyle, primaryButtonStyle };
@@ -0,0 +1,9 @@
1
+ declare const inputBackgroundStyle = "text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400";
2
+ declare const formInputStyle = "w-full px-3 text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400 h-[40px]";
3
+ declare const baseButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden";
4
+ declare const primaryButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden px-4 h-[40px] bg-gradient-to-br from-primary-400 to-primary-500 text-white transition-colors";
5
+ declare const disabledButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-neutral-200 text-neutral-400";
6
+ declare const outlineButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-white border border-neutral-300 hover:bg-neutral-50";
7
+ declare const dangerousButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden h-[40px] px-4 bg-white border hover:bg-red-50 text-red-600";
8
+
9
+ export { baseButtonStyle, dangerousButtonStyle, disabledButtonStyle, formInputStyle, inputBackgroundStyle, outlineButtonStyle, primaryButtonStyle };
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/components/styles.ts
21
+ var styles_exports = {};
22
+ __export(styles_exports, {
23
+ baseButtonStyle: () => baseButtonStyle,
24
+ dangerousButtonStyle: () => dangerousButtonStyle,
25
+ disabledButtonStyle: () => disabledButtonStyle,
26
+ formInputStyle: () => formInputStyle,
27
+ inputBackgroundStyle: () => inputBackgroundStyle,
28
+ outlineButtonStyle: () => outlineButtonStyle,
29
+ primaryButtonStyle: () => primaryButtonStyle
30
+ });
31
+ module.exports = __toCommonJS(styles_exports);
32
+ var inputBackgroundStyle = "text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400";
33
+ var formInputStyle = `w-full px-3 ${inputBackgroundStyle} h-[40px]`;
34
+ var baseButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden";
35
+ var primaryButtonStyle = `${baseButtonStyle} px-4 h-[40px] bg-gradient-to-br from-primary-400 to-primary-500 text-white transition-colors`;
36
+ var disabledButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-neutral-200 text-neutral-400`;
37
+ var outlineButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-white border border-neutral-300 hover:bg-neutral-50`;
38
+ var dangerousButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-white border hover:bg-red-50 text-red-600`;
39
+ // Annotate the CommonJS export names for ESM import in node:
40
+ 0 && (module.exports = {
41
+ baseButtonStyle,
42
+ dangerousButtonStyle,
43
+ disabledButtonStyle,
44
+ formInputStyle,
45
+ inputBackgroundStyle,
46
+ outlineButtonStyle,
47
+ primaryButtonStyle
48
+ });
@@ -0,0 +1,17 @@
1
+ // src/components/styles.ts
2
+ var inputBackgroundStyle = "text-[16px] border border-neutral-200 outline-none appearance-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-neutral-400";
3
+ var formInputStyle = `w-full px-3 ${inputBackgroundStyle} h-[40px]`;
4
+ var baseButtonStyle = "transition-colors text-sm font-semibold cursor-pointer flex items-center justify-center rounded-lg whitespace-nowrap text-ellipsis overflow-hidden";
5
+ var primaryButtonStyle = `${baseButtonStyle} px-4 h-[40px] bg-gradient-to-br from-primary-400 to-primary-500 text-white transition-colors`;
6
+ var disabledButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-neutral-200 text-neutral-400`;
7
+ var outlineButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-white border border-neutral-300 hover:bg-neutral-50`;
8
+ var dangerousButtonStyle = `${baseButtonStyle} h-[40px] px-4 bg-white border hover:bg-red-50 text-red-600`;
9
+ export {
10
+ baseButtonStyle,
11
+ dangerousButtonStyle,
12
+ disabledButtonStyle,
13
+ formInputStyle,
14
+ inputBackgroundStyle,
15
+ outlineButtonStyle,
16
+ primaryButtonStyle
17
+ };
@@ -0,0 +1,3 @@
1
+ declare const formatHumanDateTime: (value: string | Date) => string;
2
+
3
+ export { formatHumanDateTime };
package/dist/date.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ declare const formatHumanDateTime: (value: string | Date) => string;
2
+
3
+ export { formatHumanDateTime };
package/dist/date.js ADDED
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/date.ts
31
+ var date_exports = {};
32
+ __export(date_exports, {
33
+ formatHumanDateTime: () => formatHumanDateTime
34
+ });
35
+ module.exports = __toCommonJS(date_exports);
36
+ var import_moment_timezone = __toESM(require("moment-timezone"));
37
+ var formatHumanDateTime = (value) => {
38
+ const date = (0, import_moment_timezone.default)(value).tz("Asia/Seoul");
39
+ const now = (0, import_moment_timezone.default)().tz("Asia/Seoul");
40
+ if (date.isAfter(now.clone().subtract(1, "minute"))) {
41
+ return "\uBC29\uAE08 \uC804";
42
+ }
43
+ if (date.isAfter(now.clone().subtract(1, "hour"))) {
44
+ const diff = now.diff(date, "minute");
45
+ return `${diff}\uBD84 \uC804`;
46
+ }
47
+ if (date.isAfter(now.clone().subtract(6, "hours"))) {
48
+ const diff = now.diff(date, "hour");
49
+ return `${diff}\uC2DC\uAC04 \uC804`;
50
+ }
51
+ if (date.isAfter(now.clone().subtract(1, "week"))) {
52
+ const diff = now.diff(date, "day");
53
+ return `${diff}\uC77C \uC804`;
54
+ }
55
+ if (date.isSame(now, "year")) {
56
+ return date.format("M\uC6D4 D\uC77C");
57
+ }
58
+ return date.format("YYYY\uB144 M\uC6D4 D\uC77C");
59
+ };
60
+ // Annotate the CommonJS export names for ESM import in node:
61
+ 0 && (module.exports = {
62
+ formatHumanDateTime
63
+ });
package/dist/date.mjs ADDED
@@ -0,0 +1,28 @@
1
+ // src/date.ts
2
+ import moment from "moment-timezone";
3
+ var formatHumanDateTime = (value) => {
4
+ const date = moment(value).tz("Asia/Seoul");
5
+ const now = moment().tz("Asia/Seoul");
6
+ if (date.isAfter(now.clone().subtract(1, "minute"))) {
7
+ return "\uBC29\uAE08 \uC804";
8
+ }
9
+ if (date.isAfter(now.clone().subtract(1, "hour"))) {
10
+ const diff = now.diff(date, "minute");
11
+ return `${diff}\uBD84 \uC804`;
12
+ }
13
+ if (date.isAfter(now.clone().subtract(6, "hours"))) {
14
+ const diff = now.diff(date, "hour");
15
+ return `${diff}\uC2DC\uAC04 \uC804`;
16
+ }
17
+ if (date.isAfter(now.clone().subtract(1, "week"))) {
18
+ const diff = now.diff(date, "day");
19
+ return `${diff}\uC77C \uC804`;
20
+ }
21
+ if (date.isSame(now, "year")) {
22
+ return date.format("M\uC6D4 D\uC77C");
23
+ }
24
+ return date.format("YYYY\uB144 M\uC6D4 D\uC77C");
25
+ };
26
+ export {
27
+ formatHumanDateTime
28
+ };
@@ -0,0 +1,5 @@
1
+ declare const createCDN: (origin: string) => <T extends string | undefined>(key: T, { width }?: {
2
+ width?: number;
3
+ }) => T extends undefined ? T : string;
4
+
5
+ export { createCDN };
@@ -0,0 +1,5 @@
1
+ declare const createCDN: (origin: string) => <T extends string | undefined>(key: T, { width }?: {
2
+ width?: number;
3
+ }) => T extends undefined ? T : string;
4
+
5
+ export { createCDN };
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/file-kit/cdn.ts
21
+ var cdn_exports = {};
22
+ __export(cdn_exports, {
23
+ createCDN: () => createCDN
24
+ });
25
+ module.exports = __toCommonJS(cdn_exports);
26
+ var createCDN = (origin) => {
27
+ return (key, { width } = {}) => {
28
+ return key ? `${origin}/${key}${width ? `?w=${width}` : ""}` : void 0;
29
+ };
30
+ };
31
+ // Annotate the CommonJS export names for ESM import in node:
32
+ 0 && (module.exports = {
33
+ createCDN
34
+ });
@@ -0,0 +1,9 @@
1
+ // src/file-kit/cdn.ts
2
+ var createCDN = (origin) => {
3
+ return (key, { width } = {}) => {
4
+ return key ? `${origin}/${key}${width ? `?w=${width}` : ""}` : void 0;
5
+ };
6
+ };
7
+ export {
8
+ createCDN
9
+ };
@@ -0,0 +1,33 @@
1
+ import React from 'react';
2
+ import { FileUploaderOptions } from './file_uploader.mjs';
3
+
4
+ type FileInputProps = Omit<React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "defaultValue" | "onChange"> & {
5
+ container?: string;
6
+ accept?: string;
7
+ multiple?: boolean;
8
+ name?: string;
9
+ hideMessage?: boolean;
10
+ draggingClassName?: (value: boolean) => string;
11
+ };
12
+ type FileItem<T> = {
13
+ key: string;
14
+ item?: T;
15
+ };
16
+ type Props<T> = {
17
+ defaultValue?: T | T[];
18
+ options?: FileUploaderOptions;
19
+ uploadFile?: (file: File, options?: FileUploaderOptions) => Promise<T>;
20
+ onFileInput?: (files: File[]) => void;
21
+ onFileUploaded?: (file: T) => Promise<void>;
22
+ onChange?: (files: FileItem<T>[]) => void;
23
+ limit?: number;
24
+ };
25
+ declare function useDropFileInput<T>({ defaultValue, options, uploadFile, onFileInput, onFileUploaded, limit, }?: Props<T>): {
26
+ fileIds: string[];
27
+ files: FileItem<T>[];
28
+ setFiles: React.Dispatch<React.SetStateAction<FileItem<T>[]>>;
29
+ Component: ({ className, container, draggingClassName, name, hideMessage, children, ...props }: FileInputProps) => React.JSX.Element;
30
+ };
31
+ declare function DropFileMessageBox(): React.JSX.Element;
32
+
33
+ export { DropFileMessageBox, type FileInputProps, type FileItem, useDropFileInput as default, useDropFileInput };
@@ -1,6 +1,7 @@
1
- import React from "react";
2
- import { type FileUploaderOptions } from "./file_uploader";
3
- export type FileInputProps = Omit<React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "defaultValue" | "onChange"> & {
1
+ import React from 'react';
2
+ import { FileUploaderOptions } from './file_uploader.js';
3
+
4
+ type FileInputProps = Omit<React.DetailedHTMLProps<React.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "defaultValue" | "onChange"> & {
4
5
  container?: string;
5
6
  accept?: string;
6
7
  multiple?: boolean;
@@ -8,7 +9,7 @@ export type FileInputProps = Omit<React.DetailedHTMLProps<React.InputHTMLAttribu
8
9
  hideMessage?: boolean;
9
10
  draggingClassName?: (value: boolean) => string;
10
11
  };
11
- export type FileItem<T> = {
12
+ type FileItem<T> = {
12
13
  key: string;
13
14
  item?: T;
14
15
  };
@@ -21,11 +22,12 @@ type Props<T> = {
21
22
  onChange?: (files: FileItem<T>[]) => void;
22
23
  limit?: number;
23
24
  };
24
- export declare function useDropFileInput<T>({ defaultValue, options, uploadFile, onFileInput, onFileUploaded, limit, }?: Props<T>): {
25
+ declare function useDropFileInput<T>({ defaultValue, options, uploadFile, onFileInput, onFileUploaded, limit, }?: Props<T>): {
25
26
  fileIds: string[];
26
27
  files: FileItem<T>[];
27
28
  setFiles: React.Dispatch<React.SetStateAction<FileItem<T>[]>>;
28
- Component: ({ className, container, draggingClassName, name, hideMessage, children, ...props }: FileInputProps) => import("react/jsx-runtime").JSX.Element;
29
+ Component: ({ className, container, draggingClassName, name, hideMessage, children, ...props }: FileInputProps) => React.JSX.Element;
29
30
  };
30
- export declare function DropFileMessageBox(): import("react/jsx-runtime").JSX.Element;
31
- export default useDropFileInput;
31
+ declare function DropFileMessageBox(): React.JSX.Element;
32
+
33
+ export { DropFileMessageBox, type FileInputProps, type FileItem, useDropFileInput as default, useDropFileInput };