@ya-accelerators/nextjs-framework 0.0.0

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 (318) hide show
  1. package/@types/general.d.ts +1 -0
  2. package/@types/image.d.ts +8 -0
  3. package/@types/next-auth.d.ts +18 -0
  4. package/dist/env.client.d.ts +3 -0
  5. package/dist/env.client.js +9 -0
  6. package/dist/env.client.js.map +1 -0
  7. package/dist/env.d.ts +6 -0
  8. package/dist/env.js +18 -0
  9. package/dist/env.js.map +1 -0
  10. package/dist/hooks/date/index.d.ts +11 -0
  11. package/dist/hooks/date/index.js +14 -0
  12. package/dist/hooks/date/index.js.map +1 -0
  13. package/dist/hooks/dispatch/index.d.ts +9 -0
  14. package/dist/hooks/dispatch/index.jsx +25 -0
  15. package/dist/hooks/dispatch/index.jsx.map +1 -0
  16. package/dist/hooks/index.d.ts +6 -0
  17. package/dist/hooks/index.js +7 -0
  18. package/dist/hooks/index.js.map +1 -0
  19. package/dist/hooks/loading/index.d.ts +10 -0
  20. package/dist/hooks/loading/index.jsx +22 -0
  21. package/dist/hooks/loading/index.jsx.map +1 -0
  22. package/dist/hooks/localStorage/index.d.ts +1 -0
  23. package/dist/hooks/localStorage/index.js +53 -0
  24. package/dist/hooks/localStorage/index.js.map +1 -0
  25. package/dist/hooks/modal/index.d.ts +26 -0
  26. package/dist/hooks/modal/index.jsx +63 -0
  27. package/dist/hooks/modal/index.jsx.map +1 -0
  28. package/dist/hooks/toast/index.d.ts +15 -0
  29. package/dist/hooks/toast/index.jsx +39 -0
  30. package/dist/hooks/toast/index.jsx.map +1 -0
  31. package/dist/i18n/index.d.ts +3 -0
  32. package/dist/i18n/index.js +40 -0
  33. package/dist/i18n/index.js.map +1 -0
  34. package/dist/i18n/strings/en-US.json +18 -0
  35. package/dist/i18n/strings/ja-JP.json +37 -0
  36. package/dist/index.d.ts +7 -0
  37. package/dist/index.js +8 -0
  38. package/dist/index.js.map +1 -0
  39. package/dist/lib/cookie/index.d.ts +9 -0
  40. package/dist/lib/cookie/index.js +66 -0
  41. package/dist/lib/cookie/index.js.map +1 -0
  42. package/dist/lib/index.d.ts +10 -0
  43. package/dist/lib/index.js +11 -0
  44. package/dist/lib/index.js.map +1 -0
  45. package/dist/lib/next-auth/index.d.ts +2 -0
  46. package/dist/lib/next-auth/index.js +62 -0
  47. package/dist/lib/next-auth/index.js.map +1 -0
  48. package/dist/lib/s3/index.d.ts +2 -0
  49. package/dist/lib/s3/index.js +17 -0
  50. package/dist/lib/s3/index.js.map +1 -0
  51. package/dist/lib/trpc/index.d.ts +8 -0
  52. package/dist/lib/trpc/index.js +32 -0
  53. package/dist/lib/trpc/index.js.map +1 -0
  54. package/dist/styles/globals.css +26 -0
  55. package/dist/styles/tailwind.config.d.ts +577 -0
  56. package/dist/styles/tailwind.config.js +671 -0
  57. package/dist/styles/tailwind.config.js.map +1 -0
  58. package/dist/styles/tailwind.config.ts +672 -0
  59. package/dist/tsconfig.tsbuildinfo +1 -0
  60. package/dist/ui/component/button/base.d.ts +27 -0
  61. package/dist/ui/component/button/base.jsx +54 -0
  62. package/dist/ui/component/button/base.jsx.map +1 -0
  63. package/dist/ui/component/button/colored/index.d.ts +11 -0
  64. package/dist/ui/component/button/colored/index.jsx +7 -0
  65. package/dist/ui/component/button/colored/index.jsx.map +1 -0
  66. package/dist/ui/component/button/image/index.d.ts +4 -0
  67. package/dist/ui/component/button/image/index.jsx +5 -0
  68. package/dist/ui/component/button/image/index.jsx.map +1 -0
  69. package/dist/ui/component/button/index.d.ts +18 -0
  70. package/dist/ui/component/button/index.jsx +25 -0
  71. package/dist/ui/component/button/index.jsx.map +1 -0
  72. package/dist/ui/component/button/text/index.d.ts +11 -0
  73. package/dist/ui/component/button/text/index.jsx +8 -0
  74. package/dist/ui/component/button/text/index.jsx.map +1 -0
  75. package/dist/ui/component/card/index.d.ts +12 -0
  76. package/dist/ui/component/card/index.jsx +20 -0
  77. package/dist/ui/component/card/index.jsx.map +1 -0
  78. package/dist/ui/component/icon/index.d.ts +7 -0
  79. package/dist/ui/component/icon/index.jsx +3 -0
  80. package/dist/ui/component/icon/index.jsx.map +1 -0
  81. package/dist/ui/component/index.d.ts +95 -0
  82. package/dist/ui/component/index.js +15 -0
  83. package/dist/ui/component/index.js.map +1 -0
  84. package/dist/ui/component/loading/index.d.ts +5 -0
  85. package/dist/ui/component/loading/index.jsx +27 -0
  86. package/dist/ui/component/loading/index.jsx.map +1 -0
  87. package/dist/ui/component/ssr/index.d.ts +5 -0
  88. package/dist/ui/component/ssr/index.jsx +11 -0
  89. package/dist/ui/component/ssr/index.jsx.map +1 -0
  90. package/dist/ui/component/typography/H1/index.d.ts +7 -0
  91. package/dist/ui/component/typography/H1/index.jsx +13 -0
  92. package/dist/ui/component/typography/H1/index.jsx.map +1 -0
  93. package/dist/ui/component/typography/H2/index.d.ts +7 -0
  94. package/dist/ui/component/typography/H2/index.jsx +13 -0
  95. package/dist/ui/component/typography/H2/index.jsx.map +1 -0
  96. package/dist/ui/component/typography/H3/index.d.ts +7 -0
  97. package/dist/ui/component/typography/H3/index.jsx +13 -0
  98. package/dist/ui/component/typography/H3/index.jsx.map +1 -0
  99. package/dist/ui/component/typography/H4/index.d.ts +7 -0
  100. package/dist/ui/component/typography/H4/index.jsx +13 -0
  101. package/dist/ui/component/typography/H4/index.jsx.map +1 -0
  102. package/dist/ui/component/typography/H5/index.d.ts +7 -0
  103. package/dist/ui/component/typography/H5/index.jsx +13 -0
  104. package/dist/ui/component/typography/H5/index.jsx.map +1 -0
  105. package/dist/ui/component/typography/H6/index.d.ts +7 -0
  106. package/dist/ui/component/typography/H6/index.jsx +13 -0
  107. package/dist/ui/component/typography/H6/index.jsx.map +1 -0
  108. package/dist/ui/component/typography/Label/index.d.ts +7 -0
  109. package/dist/ui/component/typography/Label/index.jsx +13 -0
  110. package/dist/ui/component/typography/Label/index.jsx.map +1 -0
  111. package/dist/ui/component/typography/LinkText/index.d.ts +8 -0
  112. package/dist/ui/component/typography/LinkText/index.jsx +14 -0
  113. package/dist/ui/component/typography/LinkText/index.jsx.map +1 -0
  114. package/dist/ui/component/typography/P/index.d.ts +7 -0
  115. package/dist/ui/component/typography/P/index.jsx +13 -0
  116. package/dist/ui/component/typography/P/index.jsx.map +1 -0
  117. package/dist/ui/component/typography/Pre/index.d.ts +7 -0
  118. package/dist/ui/component/typography/Pre/index.jsx +13 -0
  119. package/dist/ui/component/typography/Pre/index.jsx.map +1 -0
  120. package/dist/ui/component/typography/index.d.ts +54 -0
  121. package/dist/ui/component/typography/index.jsx +23 -0
  122. package/dist/ui/component/typography/index.jsx.map +1 -0
  123. package/dist/ui/composite/button/index.d.ts +8 -0
  124. package/dist/ui/composite/button/index.jsx +45 -0
  125. package/dist/ui/composite/button/index.jsx.map +1 -0
  126. package/dist/ui/composite/dropdown/index.d.ts +12 -0
  127. package/dist/ui/composite/dropdown/index.jsx +102 -0
  128. package/dist/ui/composite/dropdown/index.jsx.map +1 -0
  129. package/dist/ui/composite/index.d.ts +342 -0
  130. package/dist/ui/composite/index.js +13 -0
  131. package/dist/ui/composite/index.js.map +1 -0
  132. package/dist/ui/composite/input/address/index.d.ts +33 -0
  133. package/dist/ui/composite/input/address/index.jsx +132 -0
  134. package/dist/ui/composite/input/address/index.jsx.map +1 -0
  135. package/dist/ui/composite/input/address/map.d.ts +64 -0
  136. package/dist/ui/composite/input/address/map.jsx +111 -0
  137. package/dist/ui/composite/input/address/map.jsx.map +1 -0
  138. package/dist/ui/composite/input/address/utils.d.ts +23 -0
  139. package/dist/ui/composite/input/address/utils.js +63 -0
  140. package/dist/ui/composite/input/address/utils.js.map +1 -0
  141. package/dist/ui/composite/input/checkbox/index.d.ts +22 -0
  142. package/dist/ui/composite/input/checkbox/index.jsx +38 -0
  143. package/dist/ui/composite/input/checkbox/index.jsx.map +1 -0
  144. package/dist/ui/composite/input/datePicker/index.d.ts +19 -0
  145. package/dist/ui/composite/input/datePicker/index.jsx +100 -0
  146. package/dist/ui/composite/input/datePicker/index.jsx.map +1 -0
  147. package/dist/ui/composite/input/dateRange/index.d.ts +14 -0
  148. package/dist/ui/composite/input/dateRange/index.jsx +46 -0
  149. package/dist/ui/composite/input/dateRange/index.jsx.map +1 -0
  150. package/dist/ui/composite/input/dateTimePicker/index.d.ts +15 -0
  151. package/dist/ui/composite/input/dateTimePicker/index.jsx +74 -0
  152. package/dist/ui/composite/input/dateTimePicker/index.jsx.map +1 -0
  153. package/dist/ui/composite/input/dateTimeRange/index.d.ts +14 -0
  154. package/dist/ui/composite/input/dateTimeRange/index.jsx +88 -0
  155. package/dist/ui/composite/input/dateTimeRange/index.jsx.map +1 -0
  156. package/dist/ui/composite/input/index.d.ts +216 -0
  157. package/dist/ui/composite/input/index.js +35 -0
  158. package/dist/ui/composite/input/index.js.map +1 -0
  159. package/dist/ui/composite/input/list/index.d.ts +20 -0
  160. package/dist/ui/composite/input/list/index.jsx +30 -0
  161. package/dist/ui/composite/input/list/index.jsx.map +1 -0
  162. package/dist/ui/composite/input/radio/index.d.ts +14 -0
  163. package/dist/ui/composite/input/radio/index.jsx +34 -0
  164. package/dist/ui/composite/input/radio/index.jsx.map +1 -0
  165. package/dist/ui/composite/input/search/index.d.ts +5 -0
  166. package/dist/ui/composite/input/search/index.jsx +38 -0
  167. package/dist/ui/composite/input/search/index.jsx.map +1 -0
  168. package/dist/ui/composite/input/select/ClearIndicator/index.d.ts +4 -0
  169. package/dist/ui/composite/input/select/ClearIndicator/index.jsx +8 -0
  170. package/dist/ui/composite/input/select/ClearIndicator/index.jsx.map +1 -0
  171. package/dist/ui/composite/input/select/Control/index.d.ts +4 -0
  172. package/dist/ui/composite/input/select/Control/index.jsx +23 -0
  173. package/dist/ui/composite/input/select/Control/index.jsx.map +1 -0
  174. package/dist/ui/composite/input/select/DropdownIndicator/index.d.ts +4 -0
  175. package/dist/ui/composite/input/select/DropdownIndicator/index.jsx +8 -0
  176. package/dist/ui/composite/input/select/DropdownIndicator/index.jsx.map +1 -0
  177. package/dist/ui/composite/input/select/GroupHeading/index.d.ts +4 -0
  178. package/dist/ui/composite/input/select/GroupHeading/index.jsx +9 -0
  179. package/dist/ui/composite/input/select/GroupHeading/index.jsx.map +1 -0
  180. package/dist/ui/composite/input/select/Input/index.d.ts +4 -0
  181. package/dist/ui/composite/input/select/Input/index.jsx +7 -0
  182. package/dist/ui/composite/input/select/Input/index.jsx.map +1 -0
  183. package/dist/ui/composite/input/select/Menu/index.d.ts +4 -0
  184. package/dist/ui/composite/input/select/Menu/index.jsx +19 -0
  185. package/dist/ui/composite/input/select/Menu/index.jsx.map +1 -0
  186. package/dist/ui/composite/input/select/MultiValue/index.d.ts +4 -0
  187. package/dist/ui/composite/input/select/MultiValue/index.jsx +15 -0
  188. package/dist/ui/composite/input/select/MultiValue/index.jsx.map +1 -0
  189. package/dist/ui/composite/input/select/Option/index.d.ts +4 -0
  190. package/dist/ui/composite/input/select/Option/index.jsx +79 -0
  191. package/dist/ui/composite/input/select/Option/index.jsx.map +1 -0
  192. package/dist/ui/composite/input/select/Placeholder/index.d.ts +4 -0
  193. package/dist/ui/composite/input/select/Placeholder/index.jsx +7 -0
  194. package/dist/ui/composite/input/select/Placeholder/index.jsx.map +1 -0
  195. package/dist/ui/composite/input/select/SelectContainer/index.d.ts +4 -0
  196. package/dist/ui/composite/input/select/SelectContainer/index.jsx +40 -0
  197. package/dist/ui/composite/input/select/SelectContainer/index.jsx.map +1 -0
  198. package/dist/ui/composite/input/select/SingleValue/index.d.ts +4 -0
  199. package/dist/ui/composite/input/select/SingleValue/index.jsx +17 -0
  200. package/dist/ui/composite/input/select/SingleValue/index.jsx.map +1 -0
  201. package/dist/ui/composite/input/select/index.d.ts +37 -0
  202. package/dist/ui/composite/input/select/index.jsx +242 -0
  203. package/dist/ui/composite/input/select/index.jsx.map +1 -0
  204. package/dist/ui/composite/input/select/types.d.ts +16 -0
  205. package/dist/ui/composite/input/select/types.js +6 -0
  206. package/dist/ui/composite/input/select/types.js.map +1 -0
  207. package/dist/ui/composite/input/text/index.d.ts +15 -0
  208. package/dist/ui/composite/input/text/index.jsx +40 -0
  209. package/dist/ui/composite/input/text/index.jsx.map +1 -0
  210. package/dist/ui/composite/input/textarea/index.d.ts +11 -0
  211. package/dist/ui/composite/input/textarea/index.jsx +62 -0
  212. package/dist/ui/composite/input/textarea/index.jsx.map +1 -0
  213. package/dist/ui/composite/input/timePicker/index.d.ts +13 -0
  214. package/dist/ui/composite/input/timePicker/index.jsx +36 -0
  215. package/dist/ui/composite/input/timePicker/index.jsx.map +1 -0
  216. package/dist/ui/composite/input/timeRange/index.d.ts +16 -0
  217. package/dist/ui/composite/input/timeRange/index.jsx +54 -0
  218. package/dist/ui/composite/input/timeRange/index.jsx.map +1 -0
  219. package/dist/ui/composite/input/weekDaysSelector/index.d.ts +11 -0
  220. package/dist/ui/composite/input/weekDaysSelector/index.jsx +39 -0
  221. package/dist/ui/composite/input/weekDaysSelector/index.jsx.map +1 -0
  222. package/dist/ui/composite/input/weekdayPicker/index.d.ts +13 -0
  223. package/dist/ui/composite/input/weekdayPicker/index.jsx +49 -0
  224. package/dist/ui/composite/input/weekdayPicker/index.jsx.map +1 -0
  225. package/dist/ui/composite/label/index.d.ts +11 -0
  226. package/dist/ui/composite/label/index.jsx +18 -0
  227. package/dist/ui/composite/label/index.jsx.map +1 -0
  228. package/dist/ui/composite/pageTitle/index.d.ts +18 -0
  229. package/dist/ui/composite/pageTitle/index.jsx +62 -0
  230. package/dist/ui/composite/pageTitle/index.jsx.map +1 -0
  231. package/dist/ui/functional/index.d.ts +10 -0
  232. package/dist/ui/functional/index.js +9 -0
  233. package/dist/ui/functional/index.js.map +1 -0
  234. package/dist/ui/functional/notFound/index.d.ts +1 -0
  235. package/dist/ui/functional/notFound/index.jsx +13 -0
  236. package/dist/ui/functional/notFound/index.jsx.map +1 -0
  237. package/dist/ui/functional/signInForm/index.d.ts +4 -0
  238. package/dist/ui/functional/signInForm/index.jsx +45 -0
  239. package/dist/ui/functional/signInForm/index.jsx.map +1 -0
  240. package/dist/ui/functional/signOutForm/index.d.ts +3 -0
  241. package/dist/ui/functional/signOutForm/index.jsx +29 -0
  242. package/dist/ui/functional/signOutForm/index.jsx.map +1 -0
  243. package/dist/ui/index.d.ts +6 -0
  244. package/dist/ui/index.js +7 -0
  245. package/dist/ui/index.js.map +1 -0
  246. package/dist/ui/layout/app/component.d.ts +59 -0
  247. package/dist/ui/layout/app/component.jsx +224 -0
  248. package/dist/ui/layout/app/component.jsx.map +1 -0
  249. package/dist/ui/layout/app/content/index.d.ts +9 -0
  250. package/dist/ui/layout/app/content/index.jsx +18 -0
  251. package/dist/ui/layout/app/content/index.jsx.map +1 -0
  252. package/dist/ui/layout/app/index.d.ts +18 -0
  253. package/dist/ui/layout/app/index.jsx +40 -0
  254. package/dist/ui/layout/app/index.jsx.map +1 -0
  255. package/dist/ui/layout/form/index.d.ts +68 -0
  256. package/dist/ui/layout/form/index.jsx +558 -0
  257. package/dist/ui/layout/form/index.jsx.map +1 -0
  258. package/dist/ui/layout/index.d.ts +356 -0
  259. package/dist/ui/layout/index.js +19 -0
  260. package/dist/ui/layout/index.js.map +1 -0
  261. package/dist/ui/layout/modal/index.d.ts +7 -0
  262. package/dist/ui/layout/modal/index.jsx +11 -0
  263. package/dist/ui/layout/modal/index.jsx.map +1 -0
  264. package/dist/ui/layout/object/index.d.ts +30 -0
  265. package/dist/ui/layout/object/index.jsx +145 -0
  266. package/dist/ui/layout/object/index.jsx.map +1 -0
  267. package/dist/ui/layout/root/index.d.ts +10 -0
  268. package/dist/ui/layout/root/index.jsx +31 -0
  269. package/dist/ui/layout/root/index.jsx.map +1 -0
  270. package/dist/ui/layout/root/provider/index.d.ts +7 -0
  271. package/dist/ui/layout/root/provider/index.jsx +26 -0
  272. package/dist/ui/layout/root/provider/index.jsx.map +1 -0
  273. package/dist/ui/layout/tab/component.d.ts +4 -0
  274. package/dist/ui/layout/tab/component.jsx +16 -0
  275. package/dist/ui/layout/tab/component.jsx.map +1 -0
  276. package/dist/ui/layout/tab/content/index.d.ts +8 -0
  277. package/dist/ui/layout/tab/content/index.jsx +8 -0
  278. package/dist/ui/layout/tab/content/index.jsx.map +1 -0
  279. package/dist/ui/layout/tab/index.d.ts +11 -0
  280. package/dist/ui/layout/tab/index.jsx +25 -0
  281. package/dist/ui/layout/tab/index.jsx.map +1 -0
  282. package/dist/ui/layout/table/index.d.ts +33 -0
  283. package/dist/ui/layout/table/index.jsx +283 -0
  284. package/dist/ui/layout/table/index.jsx.map +1 -0
  285. package/dist/ui/layout/toast/index.d.ts +7 -0
  286. package/dist/ui/layout/toast/index.jsx +18 -0
  287. package/dist/ui/layout/toast/index.jsx.map +1 -0
  288. package/dist/ui/theme/border/index.d.ts +28 -0
  289. package/dist/ui/theme/border/index.js +67 -0
  290. package/dist/ui/theme/border/index.js.map +1 -0
  291. package/dist/ui/theme/color/index.d.ts +32 -0
  292. package/dist/ui/theme/color/index.js +106 -0
  293. package/dist/ui/theme/color/index.js.map +1 -0
  294. package/dist/ui/theme/index.d.ts +4 -0
  295. package/dist/ui/theme/index.js +5 -0
  296. package/dist/ui/theme/index.js.map +1 -0
  297. package/dist/ui/theme/rounded/index.d.ts +9 -0
  298. package/dist/ui/theme/rounded/index.js +14 -0
  299. package/dist/ui/theme/rounded/index.js.map +1 -0
  300. package/dist/ui/theme/size/index.d.ts +15 -0
  301. package/dist/ui/theme/size/index.js +55 -0
  302. package/dist/ui/theme/size/index.js.map +1 -0
  303. package/dist/ui/types/index.d.ts +113 -0
  304. package/dist/ui/types/index.js +33 -0
  305. package/dist/ui/types/index.js.map +1 -0
  306. package/dist/util/client.d.ts +2 -0
  307. package/dist/util/client.js +4 -0
  308. package/dist/util/client.js.map +1 -0
  309. package/dist/util/date/impl.d.ts +7 -0
  310. package/dist/util/date/impl.js +22 -0
  311. package/dist/util/date/impl.js.map +1 -0
  312. package/dist/util/date/index.d.ts +17 -0
  313. package/dist/util/date/index.js +16 -0
  314. package/dist/util/date/index.js.map +1 -0
  315. package/dist/util/index.d.ts +17 -0
  316. package/dist/util/index.js +143 -0
  317. package/dist/util/index.js.map +1 -0
  318. package/package.json +62 -0
@@ -0,0 +1,88 @@
1
+ 'use client';
2
+ import { useCallback, useEffect, useRef, useState } from 'react';
3
+ import { Component } from '../../../component';
4
+ import { DateTimePicker } from '../dateTimePicker';
5
+ const normalizeDateTime = (value, stepMinutes) => {
6
+ if (!value) {
7
+ return undefined;
8
+ }
9
+ const ret = new Date(value);
10
+ ret.setSeconds(0);
11
+ ret.setMilliseconds(0);
12
+ if (stepMinutes > 0) {
13
+ const rounded = Math.round(ret.getMinutes() / stepMinutes) * stepMinutes;
14
+ ret.setMinutes(rounded);
15
+ }
16
+ return ret;
17
+ };
18
+ export const DateTimeRange = ({ defaultValue, name, disabled, error, stepMinutes = 30, // Default to 30 minutes (in seconds)
19
+ onChange, ...props }) => {
20
+ const [startDateTime, setStartDateTime] = useState(() => normalizeDateTime(defaultValue?.start, stepMinutes));
21
+ const [endDateTime, setEndDateTime] = useState(() => normalizeDateTime(defaultValue?.end, stepMinutes));
22
+ useEffect(() => {
23
+ const normalizedStart = normalizeDateTime(defaultValue?.start, stepMinutes);
24
+ const normalizedEnd = normalizeDateTime(defaultValue?.end, stepMinutes);
25
+ if (normalizedStart) {
26
+ // eslint-disable-next-line react-hooks/set-state-in-effect
27
+ setStartDateTime(normalizedStart);
28
+ const minEndTime = new Date(normalizedStart.getTime() + stepMinutes * 60 * 1000);
29
+ setEndDateTime((prevEndDateTime) => {
30
+ const endToUse = normalizedEnd ?? prevEndDateTime;
31
+ if (!endToUse || endToUse.getTime() < minEndTime.getTime()) {
32
+ return minEndTime;
33
+ }
34
+ return endToUse;
35
+ });
36
+ }
37
+ else if (normalizedEnd) {
38
+ setEndDateTime((prevEndDateTime) => {
39
+ return normalizedEnd ?? prevEndDateTime;
40
+ });
41
+ }
42
+ }, [defaultValue?.start, defaultValue?.end, stepMinutes]);
43
+ const startTimeRef = useRef(null);
44
+ const endTimeRef = useRef(null);
45
+ const handleStartDateTimeChange = useCallback((newStartDateTime) => {
46
+ const normalizedStart = normalizeDateTime(newStartDateTime, stepMinutes);
47
+ setStartDateTime(normalizedStart);
48
+ if (!normalizedStart) {
49
+ return;
50
+ }
51
+ const minEndTime = new Date(normalizedStart.getTime() + stepMinutes * 60 * 1000);
52
+ setEndDateTime((prevEndDateTime) => {
53
+ if (!prevEndDateTime || prevEndDateTime.getTime() < minEndTime.getTime()) {
54
+ return minEndTime;
55
+ }
56
+ return prevEndDateTime;
57
+ });
58
+ }, [stepMinutes]);
59
+ const handleEndDateTimeChange = useCallback((newEndDateTime) => {
60
+ const normalizedEnd = normalizeDateTime(newEndDateTime, stepMinutes);
61
+ if (startDateTime) {
62
+ const minEndTime = new Date(startDateTime.getTime() + stepMinutes * 60 * 1000);
63
+ if (!normalizedEnd || normalizedEnd.getTime() <= minEndTime.getTime()) {
64
+ setEndDateTime(minEndTime);
65
+ }
66
+ else {
67
+ setEndDateTime(normalizedEnd);
68
+ }
69
+ }
70
+ else {
71
+ setEndDateTime(normalizedEnd);
72
+ }
73
+ }, [startDateTime, stepMinutes]);
74
+ return (<div className='gap-control-padding-base flex w-full items-center'>
75
+ <DateTimePicker key={`${name}StartAt-${startDateTime?.toISOString() ?? 'start'}`} {...props} name={`${name}StartAt`} value={startDateTime} onChange={(e) => {
76
+ handleStartDateTimeChange(e);
77
+ onChange?.({ start: e });
78
+ }} disabled={disabled} error={error} stepMinutes={stepMinutes} timeSelectRef={startTimeRef}/>
79
+ <Component.Typography.P container={true} disabled={disabled} className='text-sm'>
80
+
81
+ </Component.Typography.P>
82
+ <DateTimePicker key={`${name}EndAt-${endDateTime?.toISOString() ?? 'end'}`} {...props} name={`${name}EndAt`} value={endDateTime} min={startDateTime ? new Date(startDateTime.getTime() + stepMinutes * 60 * 1000) : undefined} onChange={(e) => {
83
+ handleEndDateTimeChange(e);
84
+ onChange?.({ end: e });
85
+ }} disabled={disabled} error={error} stepMinutes={stepMinutes} timeSelectRef={endTimeRef}/>
86
+ </div>);
87
+ };
88
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/dateTimeRange/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,216 @@
1
+ import * as address from './address';
2
+ import * as datePicker from './datePicker';
3
+ import * as dateTimePicker from './dateTimePicker';
4
+ import * as select from './select';
5
+ import * as timePicker from './timePicker';
6
+ export declare const Input: {
7
+ WeekDaysSelector: ({ name, short, defaultValue, onChange, disabled, className, error, }: {
8
+ name: string;
9
+ short?: boolean;
10
+ defaultValue?: import("../../..").Weekday | import("../../..").Weekday[] | null;
11
+ onChange?: (value: import("../../..").Weekday | import("../../..").Weekday[]) => void;
12
+ disabled?: boolean;
13
+ className?: string;
14
+ error?: boolean;
15
+ }) => import("react").JSX.Element;
16
+ WeekdayPicker: ({ name, short, defaultValue, onChange, disabled, className, required, multiSelect, error, ...props }: {
17
+ name: string;
18
+ short?: boolean;
19
+ defaultValue?: import("../../..").Weekday | import("../../..").Weekday[] | null;
20
+ onChange?: (value: import("../../..").Weekday | import("../../..").Weekday[]) => void;
21
+ disabled?: boolean;
22
+ className?: string;
23
+ required?: boolean;
24
+ multiSelect?: boolean;
25
+ error?: boolean;
26
+ }) => import("react").JSX.Element;
27
+ TimeRange: ({ defaultValue, name, disabled, error, required, stepMinutes, onChange, ...props }: Omit<import("react").ComponentProps<typeof timePicker.TimePicker>, "defaultValue" | "onChange"> & {
28
+ defaultValue?: {
29
+ start?: string | null;
30
+ end?: string | null;
31
+ };
32
+ error?: boolean;
33
+ required?: boolean;
34
+ disabled?: boolean;
35
+ stepMinutes?: number;
36
+ onChange?: (value: {
37
+ start?: string | null;
38
+ end?: string | null;
39
+ }) => void;
40
+ }) => import("react").JSX.Element;
41
+ TimePicker: ({ min, max, stepMinutes, defaultValue, value, selectRef, ...props }: {
42
+ min?: string | null;
43
+ max?: string | null;
44
+ stepMinutes?: number;
45
+ defaultValue?: string | null;
46
+ value?: string | null;
47
+ selectRef?: React.RefObject<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean> | null>;
48
+ } & Omit<import("react").ComponentProps<typeof select.Select>, "options" | "defaultValue">) => import("react").JSX.Element;
49
+ TextArea: ({ name, color, rounded, disabled, className, required, defaultValue, error, rows, ...props }: {
50
+ name: string;
51
+ color?: import("../..").TextColorTypes;
52
+ rounded?: import("../..").Rounded;
53
+ required?: boolean;
54
+ defaultValue?: string | number | readonly string[] | undefined | null;
55
+ error?: boolean;
56
+ } & Omit<import("react").ComponentProps<"textarea">, "name" | "color" | "defaultValue">) => import("react").JSX.Element;
57
+ Text: ({ name, rounded, focused, color, icon, className, defaultValue, error, inputClassName, isClearable, ...props }: {
58
+ name: string;
59
+ rounded?: import("../..").Rounded;
60
+ focused?: boolean;
61
+ color?: import("../..").TextColorTypes;
62
+ icon?: import("../..").IconType;
63
+ defaultValue?: string | number | readonly string[] | undefined | null;
64
+ error?: boolean;
65
+ inputClassName?: string;
66
+ isClearable?: boolean;
67
+ } & Omit<import("react").ComponentProps<"input">, "name" | "color" | "defaultValue">) => import("react").JSX.Element;
68
+ useScrollToSelectedOnOpen: (args: {
69
+ menuOpen: boolean;
70
+ portalEl?: HTMLElement;
71
+ instanceId: string;
72
+ }) => void;
73
+ Select: import("react").ForwardRefExoticComponent<{
74
+ name: string;
75
+ className?: string;
76
+ options: import("react-select").OptionsOrGroups<import("./select/types").SelectOption, import("react-select").GroupBase<import("./select/types").SelectOption>>;
77
+ defaultValue?: string | number | readonly string[] | undefined | null;
78
+ value?: string;
79
+ onChange?: (value: string) => void;
80
+ disabled?: boolean;
81
+ required?: boolean;
82
+ isMulti?: boolean;
83
+ isSearchable?: boolean;
84
+ isClearable?: boolean;
85
+ placeholder?: string;
86
+ noOptionsMessage?: string;
87
+ showDividerBetweenOptions?: boolean;
88
+ indentPadding?: number;
89
+ autoFocus?: boolean;
90
+ rounded?: import("../..").Rounded;
91
+ error?: boolean;
92
+ } & import("react").RefAttributes<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean>>>;
93
+ Search: ({ value, onUpdate, className, }: {
94
+ value?: string;
95
+ onUpdate: (value: string) => void;
96
+ className?: string;
97
+ }) => import("react").JSX.Element;
98
+ Radio: ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }: {
99
+ orientation: "horizontal" | "vertical";
100
+ name: string;
101
+ options: {
102
+ value: string;
103
+ label: string;
104
+ disabled?: boolean;
105
+ }[];
106
+ value?: string;
107
+ defaultValue?: string | null;
108
+ onChange?: (value: string) => void;
109
+ disabled?: boolean;
110
+ required?: boolean;
111
+ }) => import("react").JSX.Element;
112
+ List: ({ name, rounded, defaultList, minListLength, maxListLength, valueLength, isFirstItem, input, }: {
113
+ name: string;
114
+ rounded?: import("../..").Rounded;
115
+ defaultList: string[][];
116
+ minListLength?: number;
117
+ maxListLength?: number;
118
+ valueLength: number;
119
+ isFirstItem: boolean;
120
+ input: (props: {
121
+ name: string;
122
+ autoFocus: boolean;
123
+ values: string[];
124
+ onChange: (index: number, value: string) => void;
125
+ }) => {
126
+ node: import("react").ReactNode;
127
+ disabled?: boolean;
128
+ };
129
+ }) => import("react").JSX.Element;
130
+ DateTimeRange: ({ defaultValue, name, disabled, error, stepMinutes, onChange, ...props }: Omit<import("react").ComponentProps<typeof dateTimePicker.DateTimePicker>, "defaultValue" | "onChange"> & {
131
+ defaultValue?: {
132
+ start?: Date;
133
+ end?: Date;
134
+ };
135
+ error?: boolean;
136
+ stepMinutes?: number;
137
+ onChange?: (value: {
138
+ start?: Date;
139
+ end?: Date;
140
+ }) => void;
141
+ }) => import("react").JSX.Element;
142
+ DateTimePicker: ({ name, defaultValue, value, min, max, onChange, disabled, required, error, stepMinutes, timeSelectRef, }: {
143
+ name: string;
144
+ defaultValue?: Date;
145
+ value?: Date;
146
+ min?: Date;
147
+ max?: Date;
148
+ onChange?: (value: Date) => void;
149
+ disabled?: boolean;
150
+ required?: boolean;
151
+ error?: boolean;
152
+ stepMinutes?: number;
153
+ timeSelectRef?: React.RefObject<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean> | null>;
154
+ }) => import("react").JSX.Element;
155
+ DateRange: ({ defaultValue, name, disabled, error, stepDays, onChange, ...props }: Omit<import("react").ComponentProps<typeof datePicker.DatePicker>, "defaultValue" | "onChange"> & {
156
+ defaultValue?: {
157
+ start?: Date;
158
+ end?: Date;
159
+ };
160
+ error?: boolean;
161
+ stepDays?: number;
162
+ onChange?: (value: {
163
+ start?: Date;
164
+ end?: Date;
165
+ }) => void;
166
+ }) => import("react").JSX.Element;
167
+ DatePicker: (props: Parameters<({ name, rounded, placement, defaultValue, value, min, max, onChange, disabled, className, required, error, autoFocus, }: {
168
+ name: string;
169
+ rounded?: import("../..").Rounded;
170
+ placement?: "top" | "right" | "bottom" | "left" | "top-start" | "top-end" | "right-start" | "right-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end";
171
+ defaultValue?: Date;
172
+ value?: Date;
173
+ min?: Date;
174
+ max?: Date;
175
+ onChange?: (value?: Date) => void;
176
+ disabled?: boolean;
177
+ className?: string;
178
+ required?: boolean;
179
+ error?: boolean;
180
+ autoFocus?: boolean;
181
+ }) => import("react").JSX.Element>[0]) => import("react").JSX.Element;
182
+ Checkbox: ({ orientation, name, options, defaultValue, onChange, disabled, error, }: {
183
+ orientation: "horizontal" | "vertical";
184
+ name: string;
185
+ options: {
186
+ value: string;
187
+ label: string;
188
+ disabled?: boolean;
189
+ }[];
190
+ defaultValue?: string[] | null;
191
+ onChange?: (values: string[]) => void;
192
+ disabled?: boolean;
193
+ error?: boolean;
194
+ }) => import("react").JSX.Element;
195
+ CheckboxItem: ({ name, checked, onClick, value, label, disabled, error, }: {
196
+ name: string;
197
+ checked: boolean;
198
+ onClick: () => void;
199
+ value: string;
200
+ label: string;
201
+ disabled?: boolean;
202
+ error?: boolean;
203
+ }) => import("react").JSX.Element;
204
+ Address: ({ name, rounded, defaultValue, countryCode, onSearch, onChange, disabled, required, className, googleMapsApiKey, }: {
205
+ name: string;
206
+ rounded?: import("../..").Rounded;
207
+ defaultValue?: address.AddressValue | null;
208
+ countryCode?: string;
209
+ onSearch?: (result: address.AddressValue | null) => void;
210
+ onChange?: (value: address.AddressValue) => void;
211
+ disabled?: boolean;
212
+ required?: boolean;
213
+ className?: string;
214
+ googleMapsApiKey?: string;
215
+ }) => import("react").JSX.Element;
216
+ };
@@ -0,0 +1,35 @@
1
+ import * as address from './address';
2
+ import * as checkbox from './checkbox';
3
+ import * as datePicker from './datePicker';
4
+ import * as dateRange from './dateRange';
5
+ import * as dateTimePicker from './dateTimePicker';
6
+ import * as dateTimeRange from './dateTimeRange';
7
+ import * as list from './list';
8
+ import * as radio from './radio';
9
+ import * as search from './search';
10
+ import * as select from './select';
11
+ import * as text from './text';
12
+ import * as textarea from './textarea';
13
+ import * as timePicker from './timePicker';
14
+ import * as timeRange from './timeRange';
15
+ import * as weekdayPicker from './weekdayPicker';
16
+ import * as weekDaysSelector from './weekDaysSelector';
17
+ export const Input = {
18
+ ...address,
19
+ ...checkbox,
20
+ ...datePicker,
21
+ ...dateRange,
22
+ ...dateTimePicker,
23
+ ...dateTimeRange,
24
+ ...list,
25
+ ...radio,
26
+ ...search,
27
+ ...select,
28
+ ...text,
29
+ ...textarea,
30
+ ...timePicker,
31
+ ...timeRange,
32
+ ...weekdayPicker,
33
+ ...weekDaysSelector,
34
+ };
35
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/composite/input/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAA;AACpC,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAA;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAA;AAC1C,OAAO,KAAK,SAAS,MAAM,aAAa,CAAA;AACxC,OAAO,KAAK,cAAc,MAAM,kBAAkB,CAAA;AAClD,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAA;AAChD,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAA;AAC9B,OAAO,KAAK,KAAK,MAAM,SAAS,CAAA;AAChC,OAAO,KAAK,MAAM,MAAM,UAAU,CAAA;AAClC,OAAO,KAAK,MAAM,MAAM,UAAU,CAAA;AAClC,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAA;AAC9B,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAA;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAA;AAC1C,OAAO,KAAK,SAAS,MAAM,aAAa,CAAA;AACxC,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAA;AAChD,OAAO,KAAK,gBAAgB,MAAM,oBAAoB,CAAA;AAEtD,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,GAAG,OAAO;IACV,GAAG,QAAQ;IACX,GAAG,UAAU;IACb,GAAG,SAAS;IACZ,GAAG,cAAc;IACjB,GAAG,aAAa;IAChB,GAAG,IAAI;IACP,GAAG,KAAK;IACR,GAAG,MAAM;IACT,GAAG,MAAM;IACT,GAAG,IAAI;IACP,GAAG,QAAQ;IACX,GAAG,UAAU;IACb,GAAG,SAAS;IACZ,GAAG,aAAa;IAChB,GAAG,gBAAgB;CACpB,CAAA"}
@@ -0,0 +1,20 @@
1
+ import type { ReactNode } from 'react';
2
+ import { Rounded } from '../../../theme';
3
+ export declare const List: ({ name, rounded, defaultList, minListLength, maxListLength, valueLength, isFirstItem, input, }: {
4
+ name: string;
5
+ rounded?: Rounded;
6
+ defaultList: string[][];
7
+ minListLength?: number;
8
+ maxListLength?: number;
9
+ valueLength: number;
10
+ isFirstItem: boolean;
11
+ input: (props: {
12
+ name: string;
13
+ autoFocus: boolean;
14
+ values: string[];
15
+ onChange: (index: number, value: string) => void;
16
+ }) => {
17
+ node: ReactNode;
18
+ disabled?: boolean;
19
+ };
20
+ }) => import("react").JSX.Element;
@@ -0,0 +1,30 @@
1
+ 'use client';
2
+ import AddIcon from '@mui/icons-material/Add';
3
+ import DeleteIcon from '@mui/icons-material/Delete';
4
+ import { useState } from 'react';
5
+ import { Component } from '../../../component';
6
+ import { ColorTypes, ControlSize, Rounded } from '../../../theme';
7
+ export const List = ({ name, rounded = Rounded.m, defaultList, minListLength = 1, maxListLength, valueLength, isFirstItem, input, }) => {
8
+ const [list, setList] = useState(defaultList.length === 0 ? [[...Array(valueLength)].map(() => '')] : defaultList);
9
+ return (<div className='gap-control-padding-base flex w-full flex-col'>
10
+ {list.map((values, i) => {
11
+ const ret = input({
12
+ name: `${name}[${i}]`,
13
+ autoFocus: isFirstItem && i === 0,
14
+ values,
15
+ onChange: (valueIndex, value) => setList((item) => item.map((y, j) => (j === i ? y.map((z, k) => (k === valueIndex ? value : z)) : y))),
16
+ });
17
+ return (<div key={i} className='gap-control-padding-base flex w-full'>
18
+ <div className='gap-control-padding-base flex w-full items-center'>{ret.node}</div>
19
+ <Component.Button variant='colored' size={ControlSize.md} rounded={rounded} color={ColorTypes.secondary} container={true} icon={DeleteIcon} onClick={() => setList((x) => x.filter((_, j) => j !== i))} disabled={list.length === minListLength || ret.disabled === true}/>
20
+ </div>);
21
+ })}
22
+ <Component.Button variant='colored' size={ControlSize.md} rounded={rounded} color={ColorTypes.primary} container={true} icon={AddIcon} onClick={() => {
23
+ if (list.length === maxListLength) {
24
+ return;
25
+ }
26
+ setList([...list, [...Array(valueLength)].map(() => '')]);
27
+ }}/>
28
+ </div>);
29
+ };
30
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/list/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ export declare const Radio: ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }: {
2
+ orientation: "horizontal" | "vertical";
3
+ name: string;
4
+ options: {
5
+ value: string;
6
+ label: string;
7
+ disabled?: boolean;
8
+ }[];
9
+ value?: string;
10
+ defaultValue?: string | null;
11
+ onChange?: (value: string) => void;
12
+ disabled?: boolean;
13
+ required?: boolean;
14
+ }) => import("react").JSX.Element;
@@ -0,0 +1,34 @@
1
+ 'use client';
2
+ import RadioButtonCheckedIcon from '@mui/icons-material/RadioButtonChecked';
3
+ import RadioButtonUncheckedIcon from '@mui/icons-material/RadioButtonUnchecked';
4
+ import classNames from 'classnames';
5
+ import { useTranslations } from 'next-intl';
6
+ import { useState } from 'react';
7
+ import { Component } from '../../../component';
8
+ import { getTextColorTypeClassName, TextColorTypes } from '../../../theme';
9
+ export const Radio = ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }) => {
10
+ const isControlled = value !== undefined;
11
+ const [internalValue, setInternalValue] = useState(() => defaultValue ?? (options.length === 0 ? undefined : options[0].value));
12
+ const currentValue = isControlled ? value : internalValue;
13
+ return (<div className={classNames('flex flex-wrap', orientation === 'vertical'
14
+ ? 'gap-control-padding-md flex-col'
15
+ : 'gap-control-padding-xl gap-y-control-padding-sm')}>
16
+ {options.map((x, i) => (<RadioItem key={i} name={name} checked={currentValue === x.value} onClick={() => {
17
+ if (!isControlled) {
18
+ setInternalValue(x.value);
19
+ }
20
+ onChange?.(x.value);
21
+ }} disabled={disabled === true || x.disabled === true} required={required} {...x}/>))}
22
+ </div>);
23
+ };
24
+ const RadioItem = ({ name, checked, onClick, value, label, disabled, required, }) => {
25
+ const t = useTranslations();
26
+ return (<fieldset data-disabled={disabled} className={classNames('gap-control-padding-md flex w-fit items-center justify-center whitespace-nowrap', disabled ? 'clickable-disabled' : 'clickable-enabled')} onClick={checked || disabled ? undefined : onClick}>
27
+ <input type='radio' checked={checked} onChange={() => { }} name={name} value={value} className='hidden' required={required && !checked}/>
28
+ {checked ? (<RadioButtonCheckedIcon className={classNames('size-control-base!', getTextColorTypeClassName(TextColorTypes.primary, true))}/>) : (<RadioButtonUncheckedIcon className={classNames('size-control-base!', getTextColorTypeClassName(TextColorTypes.disabled, true))}/>)}
29
+ <Component.Typography.Label container={true} className={classNames('text-xs', disabled ? 'cursor-default' : 'cursor-pointer')}>
30
+ {t(label)}
31
+ </Component.Typography.Label>
32
+ </fieldset>);
33
+ };
34
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/radio/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export declare const Search: ({ value, onUpdate, className, }: {
2
+ value?: string;
3
+ onUpdate: (value: string) => void;
4
+ className?: string;
5
+ }) => import("react").JSX.Element;
@@ -0,0 +1,38 @@
1
+ 'use client';
2
+ import SearchIcon from '@mui/icons-material/Search';
3
+ import classNames from 'classnames';
4
+ import { useEffect, useRef, useState } from 'react';
5
+ import { Text } from '../text';
6
+ export const Search = ({ value, onUpdate, className, }) => {
7
+ const [localQuery, setLocalQuery] = useState(value ?? '');
8
+ const debounceTimerRef = useRef(null);
9
+ useEffect(() => () => {
10
+ if (debounceTimerRef.current) {
11
+ clearTimeout(debounceTimerRef.current);
12
+ }
13
+ }, []);
14
+ const isComposingRef = useRef(false);
15
+ return (<Text name='search' placeholder='Search' icon={SearchIcon} className={classNames('w-full', className)} value={localQuery} onChange={(e) => {
16
+ setLocalQuery(e.target.value);
17
+ if (isComposingRef.current) {
18
+ return;
19
+ }
20
+ if (debounceTimerRef.current) {
21
+ clearTimeout(debounceTimerRef.current);
22
+ }
23
+ debounceTimerRef.current = setTimeout(() => onUpdate(e.target.value), 400);
24
+ }} onCompositionStart={() => {
25
+ isComposingRef.current = true;
26
+ if (debounceTimerRef.current) {
27
+ clearTimeout(debounceTimerRef.current);
28
+ }
29
+ }} onCompositionEnd={(e) => {
30
+ isComposingRef.current = false;
31
+ const newValue = e.currentTarget.value;
32
+ if (debounceTimerRef.current) {
33
+ clearTimeout(debounceTimerRef.current);
34
+ }
35
+ debounceTimerRef.current = setTimeout(() => onUpdate(newValue), 400);
36
+ }}/>);
37
+ };
38
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/search/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,4BAA4B,CAAA;AACnD,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEnD,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAE9B,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EACrB,KAAK,EACL,QAAQ,EACR,SAAS,GAKV,EAAE,EAAE;IACH,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,CAAA;IAEzD,MAAM,gBAAgB,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAA;IAC5D,SAAS,CACP,GAAG,EAAE,CAAC,GAAG,EAAE;QACT,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;QACxC,CAAC;IACH,CAAC,EACD,EAAE,CACH,CAAA;IAED,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;IACpC,OAAO,CACL,CAAC,IAAI,CACH,IAAI,CAAC,QAAQ,CACb,WAAW,CAAC,QAAQ,CACpB,IAAI,CAAC,CAAC,UAAU,CAAC,CACjB,SAAS,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAC3C,KAAK,CAAC,CAAC,UAAU,CAAC,CAClB,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YAC7B,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC3B,OAAM;YACR,CAAC;YACD,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;YACD,gBAAgB,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,CAAA;QAC5E,CAAC,CAAC,CACF,kBAAkB,CAAC,CAAC,GAAG,EAAE;YACvB,cAAc,CAAC,OAAO,GAAG,IAAI,CAAA;YAC7B,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;QACH,CAAC,CAAC,CACF,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;YACtB,cAAc,CAAC,OAAO,GAAG,KAAK,CAAA;YAC9B,MAAM,QAAQ,GAAG,CAAC,CAAC,aAAa,CAAC,KAAK,CAAA;YAEtC,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;YACD,gBAAgB,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAA;QACtE,CAAC,CAAC,EACF,CACH,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { type ClearIndicatorProps, type GroupBase } from 'react-select';
3
+ import type { SelectOption } from '../types';
4
+ export declare const ClearIndicator: React.FC<ClearIndicatorProps<SelectOption, boolean, GroupBase<SelectOption>>>;
@@ -0,0 +1,8 @@
1
+ 'use client';
2
+ import ClearIcon from '@mui/icons-material/Clear';
3
+ import React from 'react';
4
+ import { components } from 'react-select';
5
+ export const ClearIndicator = (props) => props.selectProps.required === null ? null : (<components.ClearIndicator {...props}>
6
+ <ClearIcon className='size-control-sm!'/>
7
+ </components.ClearIndicator>);
8
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/ClearIndicator/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,SAAS,MAAM,2BAA2B,CAAA;AACjD,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAA4B,UAAU,EAAkB,MAAM,cAAc,CAAA;AAInF,MAAM,CAAC,MAAM,cAAc,GAAkF,CAC3G,KAA0E,EAC1E,EAAE,CACF,KAAK,CAAC,WAAW,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAC3C,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,KAAK,CAAC,CACnC;MAAA,CAAC,SAAS,CAAC,SAAS,CAAC,kBAAkB,EACzC;IAAA,EAAE,UAAU,CAAC,cAAc,CAAC,CAC7B,CAAA"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { type ControlProps, type GroupBase } from 'react-select';
3
+ import type { SelectOption } from '../types';
4
+ export declare const Control: React.FC<ControlProps<SelectOption, boolean, GroupBase<SelectOption>>>;
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ import classNames from 'classnames';
3
+ import React from 'react';
4
+ import { components } from 'react-select';
5
+ import { BackgroundColorTypes, BorderColorTypes, BorderWidth, getBackgroundColorTypeClassName, getBorderColorTypeClassName, getRoundedClassName, Rounded, } from '../../../../theme';
6
+ export const Control = (props) => {
7
+ const { children, ...rest } = props;
8
+ return (<components.Control {...rest}>
9
+ <div className={classNames('flex items-center w-full pl-control-padding-base pr-control-padding-md', getBackgroundColorTypeClassName(BackgroundColorTypes.default), getRoundedClassName(props.selectProps.rounded || Rounded.m), getBorderColorTypeClassName({
10
+ color: props.selectProps.error
11
+ ? BorderColorTypes.error
12
+ : props.isFocused
13
+ ? BorderColorTypes.primary
14
+ : BorderColorTypes.default,
15
+ container: true,
16
+ width: BorderWidth.base,
17
+ type: 'outline',
18
+ }))}>
19
+ {children}
20
+ </div>
21
+ </components.Control>);
22
+ };
23
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/Control/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAAqC,MAAM,cAAc,CAAA;AAE5E,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,WAAW,EACX,+BAA+B,EAC/B,2BAA2B,EAC3B,mBAAmB,EACnB,OAAO,GACR,MAAM,mBAAmB,CAAA;AAG1B,MAAM,CAAC,MAAM,OAAO,GAA2E,CAC7F,KAAmE,EACnE,EAAE;IACF,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAA;IACnC,OAAO,CACL,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,CAC3B;MAAA,CAAC,GAAG,CACF,SAAS,CAAC,CAAC,UAAU,CACnB,wEAAwE,EACxE,+BAA+B,CAAC,oBAAoB,CAAC,OAAO,CAAC,EAC7D,mBAAmB,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAC3D,2BAA2B,CAAC;YAC1B,KAAK,EAAE,KAAK,CAAC,WAAW,CAAC,KAAK;gBAC5B,CAAC,CAAC,gBAAgB,CAAC,KAAK;gBACxB,CAAC,CAAC,KAAK,CAAC,SAAS;oBACf,CAAC,CAAC,gBAAgB,CAAC,OAAO;oBAC1B,CAAC,CAAC,gBAAgB,CAAC,OAAO;YAC9B,SAAS,EAAE,IAAI;YACf,KAAK,EAAE,WAAW,CAAC,IAAI;YACvB,IAAI,EAAE,SAAS;SAChB,CAAC,CACH,CAAC,CAEF;QAAA,CAAC,QAAQ,CACX;MAAA,EAAE,GAAG,CACP;IAAA,EAAE,UAAU,CAAC,OAAO,CAAC,CACtB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { type DropdownIndicatorProps, type GroupBase } from 'react-select';
3
+ import type { SelectOption } from '../types';
4
+ export declare const DropdownIndicator: React.FC<DropdownIndicatorProps<SelectOption, boolean, GroupBase<SelectOption>>>;
@@ -0,0 +1,8 @@
1
+ 'use client';
2
+ import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
3
+ import React from 'react';
4
+ import { components } from 'react-select';
5
+ export const DropdownIndicator = (props) => (<components.DropdownIndicator {...props}>
6
+ <ArrowDropDownIcon className='size-control-md!'/>
7
+ </components.DropdownIndicator>);
8
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/DropdownIndicator/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,iBAAiB,MAAM,mCAAmC,CAAA;AACjE,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAA+C,MAAM,cAAc,CAAA;AAItF,MAAM,CAAC,MAAM,iBAAiB,GAAqF,CACjH,KAA6E,EAC7E,EAAE,CAAC,CACH,CAAC,UAAU,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,CACtC;IAAA,CAAC,iBAAiB,CAAC,SAAS,CAAC,kBAAkB,EACjD;EAAA,EAAE,UAAU,CAAC,iBAAiB,CAAC,CAChC,CAAA"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { type GroupBase, type GroupHeadingProps } from 'react-select';
3
+ import type { SelectOption } from '../types';
4
+ export declare const GroupHeading: React.FC<GroupHeadingProps<SelectOption, boolean, GroupBase<SelectOption>>>;
@@ -0,0 +1,9 @@
1
+ 'use client';
2
+ import classNames from 'classnames';
3
+ import React from 'react';
4
+ import { components } from 'react-select';
5
+ import { getTextColorTypeClassName, TextColorTypes } from '../../../../theme';
6
+ export const GroupHeading = (props) => (<div className={classNames('font-semibold text-sm', getTextColorTypeClassName(TextColorTypes.main, false))}>
7
+ <components.GroupHeading {...props} className='cursor-default px-control-padding-base py-control-padding-md'/>
8
+ </div>);
9
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/GroupHeading/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAA0C,MAAM,cAAc,CAAA;AAEjF,OAAO,EAAE,yBAAyB,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAG7E,MAAM,CAAC,MAAM,YAAY,GAAgF,CACvG,KAAwE,EACxE,EAAE,CAAC,CACH,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,uBAAuB,EAAE,yBAAyB,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CACzG;IAAA,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,KAAK,CAAC,CAAC,SAAS,CAAC,8DAA8D,EAC9G;EAAA,EAAE,GAAG,CAAC,CACP,CAAA"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { type GroupBase, type InputProps } from 'react-select';
3
+ import type { SelectOption } from '../types';
4
+ export declare const Input: React.FC<InputProps<SelectOption, boolean, GroupBase<SelectOption>>>;