fluent-styles 1.53.0 → 1.55.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 (872) hide show
  1. package/README.md +4065 -77
  2. package/lib/commonjs/actionSheet/actionSheet.js +372 -0
  3. package/lib/commonjs/actionSheet/actionSheet.js.map +1 -0
  4. package/lib/commonjs/actionSheet/index.js +20 -0
  5. package/lib/commonjs/actionSheet/index.js.map +1 -0
  6. package/lib/commonjs/actionSheet/useActionSheet.js +89 -0
  7. package/lib/commonjs/actionSheet/useActionSheet.js.map +1 -0
  8. package/lib/commonjs/badge/index.js +148 -0
  9. package/lib/commonjs/badge/index.js.map +1 -0
  10. package/lib/commonjs/barChart/index.js +298 -0
  11. package/lib/commonjs/barChart/index.js.map +1 -0
  12. package/lib/commonjs/button/index.js +228 -0
  13. package/lib/commonjs/button/index.js.map +1 -0
  14. package/lib/commonjs/card/index.js +202 -0
  15. package/lib/commonjs/card/index.js.map +1 -0
  16. package/lib/commonjs/checkBox/index.js +90 -0
  17. package/lib/commonjs/checkBox/index.js.map +1 -0
  18. package/lib/commonjs/chips/index.js +239 -0
  19. package/lib/commonjs/chips/index.js.map +1 -0
  20. package/lib/commonjs/circularProgress/index.js +265 -0
  21. package/lib/commonjs/circularProgress/index.js.map +1 -0
  22. package/lib/commonjs/collapsible/Collapse.js +293 -0
  23. package/lib/commonjs/collapsible/Collapse.js.map +1 -0
  24. package/lib/commonjs/collapsible/CollapseGroup.js +137 -0
  25. package/lib/commonjs/collapsible/CollapseGroup.js.map +1 -0
  26. package/lib/commonjs/collapsible/index.js +64 -0
  27. package/lib/commonjs/collapsible/index.js.map +1 -0
  28. package/lib/commonjs/collapsible/interface.js +39 -0
  29. package/lib/commonjs/collapsible/interface.js.map +1 -0
  30. package/lib/commonjs/collapsible/style.js +161 -0
  31. package/lib/commonjs/collapsible/style.js.map +1 -0
  32. package/lib/commonjs/datePicker/index.js +915 -0
  33. package/lib/commonjs/datePicker/index.js.map +1 -0
  34. package/lib/commonjs/dialog/dialogue.js +205 -0
  35. package/lib/commonjs/dialog/dialogue.js.map +1 -0
  36. package/lib/commonjs/dialog/index.js +393 -0
  37. package/lib/commonjs/dialog/index.js.map +1 -0
  38. package/lib/commonjs/dialog/useDialogue.js +117 -0
  39. package/lib/commonjs/dialog/useDialogue.js.map +1 -0
  40. package/lib/commonjs/divider/index.js +37 -0
  41. package/lib/commonjs/divider/index.js.map +1 -0
  42. package/lib/commonjs/drawer/Drawer.js +587 -0
  43. package/lib/commonjs/drawer/Drawer.js.map +1 -0
  44. package/lib/commonjs/drawer/index.js +51 -0
  45. package/lib/commonjs/drawer/index.js.map +1 -0
  46. package/lib/commonjs/drawer/interface.js +84 -0
  47. package/lib/commonjs/drawer/interface.js.map +1 -0
  48. package/lib/commonjs/dropdown/index.js +859 -0
  49. package/lib/commonjs/dropdown/index.js.map +1 -0
  50. package/lib/commonjs/emptyState/index.js +231 -0
  51. package/lib/commonjs/emptyState/index.js.map +1 -0
  52. package/lib/commonjs/form/index.js +2 -0
  53. package/lib/commonjs/form/index.js.map +1 -0
  54. package/lib/commonjs/header/index.js +147 -0
  55. package/lib/commonjs/header/index.js.map +1 -0
  56. package/lib/commonjs/header/statusBar/index.js +20 -0
  57. package/lib/commonjs/header/statusBar/index.js.map +1 -0
  58. package/lib/commonjs/icons/backArrow.js +42 -0
  59. package/lib/commonjs/icons/backArrow.js.map +1 -0
  60. package/lib/commonjs/icons/bellFill.js +43 -0
  61. package/lib/commonjs/icons/bellFill.js.map +1 -0
  62. package/lib/commonjs/icons/bellOutline.js +43 -0
  63. package/lib/commonjs/icons/bellOutline.js.map +1 -0
  64. package/lib/commonjs/icons/checkmark.js +36 -0
  65. package/lib/commonjs/icons/checkmark.js.map +1 -0
  66. package/lib/commonjs/icons/delete.js +53 -0
  67. package/lib/commonjs/icons/delete.js.map +1 -0
  68. package/lib/commonjs/icons/downChevron.js +36 -0
  69. package/lib/commonjs/icons/downChevron.js.map +1 -0
  70. package/lib/commonjs/icons/error.js +41 -0
  71. package/lib/commonjs/icons/error.js.map +1 -0
  72. package/lib/commonjs/icons/forwardArrow.js +42 -0
  73. package/lib/commonjs/icons/forwardArrow.js.map +1 -0
  74. package/lib/commonjs/icons/index.js +111 -0
  75. package/lib/commonjs/icons/index.js.map +1 -0
  76. package/lib/commonjs/icons/info.js +48 -0
  77. package/lib/commonjs/icons/info.js.map +1 -0
  78. package/lib/commonjs/icons/leftChevron.js +36 -0
  79. package/lib/commonjs/icons/leftChevron.js.map +1 -0
  80. package/lib/commonjs/icons/rightChevron.js +36 -0
  81. package/lib/commonjs/icons/rightChevron.js.map +1 -0
  82. package/lib/commonjs/icons/save.js +50 -0
  83. package/lib/commonjs/icons/save.js.map +1 -0
  84. package/lib/commonjs/icons/success.js +43 -0
  85. package/lib/commonjs/icons/success.js.map +1 -0
  86. package/lib/commonjs/icons/upChevron.js +36 -0
  87. package/lib/commonjs/icons/upChevron.js.map +1 -0
  88. package/lib/commonjs/icons/warning.js +48 -0
  89. package/lib/commonjs/icons/warning.js.map +1 -0
  90. package/lib/commonjs/image/index.js +47 -0
  91. package/lib/commonjs/image/index.js.map +1 -0
  92. package/lib/commonjs/index.js +519 -138
  93. package/lib/commonjs/index.js.map +1 -1
  94. package/lib/commonjs/input/index.js +488 -0
  95. package/lib/commonjs/input/index.js.map +1 -0
  96. package/lib/commonjs/loading/circular.js +116 -0
  97. package/lib/commonjs/loading/circular.js.map +1 -0
  98. package/lib/commonjs/loading/index.js +34 -0
  99. package/lib/commonjs/loading/index.js.map +1 -0
  100. package/lib/commonjs/loading/loader.js +247 -0
  101. package/lib/commonjs/loading/loader.js.map +1 -0
  102. package/lib/commonjs/loading/spinner.js +90 -0
  103. package/lib/commonjs/loading/spinner.js.map +1 -0
  104. package/lib/commonjs/loading/useLoader.js +62 -0
  105. package/lib/commonjs/loading/useLoader.js.map +1 -0
  106. package/lib/commonjs/loading/useLoaderBinding.js +34 -0
  107. package/lib/commonjs/loading/useLoaderBinding.js.map +1 -0
  108. package/lib/commonjs/notification/index.js +269 -0
  109. package/lib/commonjs/notification/index.js.map +1 -0
  110. package/lib/commonjs/notification/useNotification.js +62 -0
  111. package/lib/commonjs/notification/useNotification.js.map +1 -0
  112. package/lib/commonjs/page/index.js +22 -0
  113. package/lib/commonjs/page/index.js.map +1 -0
  114. package/lib/commonjs/popup/Popup.js +332 -0
  115. package/lib/commonjs/popup/Popup.js.map +1 -0
  116. package/lib/commonjs/popup/helpers.js +168 -0
  117. package/lib/commonjs/popup/helpers.js.map +1 -0
  118. package/lib/commonjs/popup/index.js +51 -0
  119. package/lib/commonjs/popup/index.js.map +1 -0
  120. package/lib/commonjs/popup/interface.js +45 -0
  121. package/lib/commonjs/popup/interface.js.map +1 -0
  122. package/lib/commonjs/portal/GlobalPortalProvider.js +68 -0
  123. package/lib/commonjs/portal/GlobalPortalProvider.js.map +1 -0
  124. package/lib/commonjs/portal/PortalContext.js +38 -0
  125. package/lib/commonjs/portal/PortalContext.js.map +1 -0
  126. package/lib/commonjs/portal/PortalInstance.js +123 -0
  127. package/lib/commonjs/portal/PortalInstance.js.map +1 -0
  128. package/lib/commonjs/portal/PortalManager.js +87 -0
  129. package/lib/commonjs/portal/PortalManager.js.map +1 -0
  130. package/lib/commonjs/portal/PortalRenderer.js +57 -0
  131. package/lib/commonjs/portal/PortalRenderer.js.map +1 -0
  132. package/lib/commonjs/portal/index.js +54 -0
  133. package/lib/commonjs/portal/index.js.map +1 -0
  134. package/lib/commonjs/portal/portal.test.js +154 -0
  135. package/lib/commonjs/portal/portal.test.js.map +1 -0
  136. package/lib/commonjs/portal/types.js +6 -0
  137. package/lib/commonjs/portal/types.js.map +1 -0
  138. package/lib/commonjs/pressable/index.js +18 -0
  139. package/lib/commonjs/pressable/index.js.map +1 -0
  140. package/lib/commonjs/progressBar/index.js +512 -0
  141. package/lib/commonjs/progressBar/index.js.map +1 -0
  142. package/lib/commonjs/radio/index.js +368 -0
  143. package/lib/commonjs/radio/index.js.map +1 -0
  144. package/lib/commonjs/safeAreaProvider/index.js +12 -0
  145. package/lib/commonjs/safeAreaProvider/index.js.map +1 -0
  146. package/lib/commonjs/safeAreaView/index.js +14 -0
  147. package/lib/commonjs/safeAreaView/index.js.map +1 -0
  148. package/lib/commonjs/scrollView/index.js +14 -0
  149. package/lib/commonjs/scrollView/index.js.map +1 -0
  150. package/lib/commonjs/searchBar/index.js +356 -0
  151. package/lib/commonjs/searchBar/index.js.map +1 -0
  152. package/lib/commonjs/seperator/index.js +44 -0
  153. package/lib/commonjs/seperator/index.js.map +1 -0
  154. package/lib/commonjs/services/index.js +185 -0
  155. package/lib/commonjs/services/index.js.map +1 -0
  156. package/lib/commonjs/shape/index.js +36 -0
  157. package/lib/commonjs/shape/index.js.map +1 -0
  158. package/lib/commonjs/skeleton/index.js +430 -0
  159. package/lib/commonjs/skeleton/index.js.map +1 -0
  160. package/lib/commonjs/slider/index.js +499 -0
  161. package/lib/commonjs/slider/index.js.map +1 -0
  162. package/lib/commonjs/spacer/index.js +14 -0
  163. package/lib/commonjs/spacer/index.js.map +1 -0
  164. package/lib/commonjs/stack/index.js +52 -0
  165. package/lib/commonjs/stack/index.js.map +1 -0
  166. package/lib/commonjs/switch/Switch.js +289 -0
  167. package/lib/commonjs/switch/Switch.js.map +1 -0
  168. package/lib/commonjs/switch/_index.js +118 -0
  169. package/lib/commonjs/switch/_index.js.map +1 -0
  170. package/lib/commonjs/switch/index.js +26 -0
  171. package/lib/commonjs/switch/index.js.map +1 -0
  172. package/lib/commonjs/switch/interface.js +47 -0
  173. package/lib/commonjs/switch/interface.js.map +1 -0
  174. package/lib/commonjs/tabBar/TabBar.js +409 -0
  175. package/lib/commonjs/tabBar/TabBar.js.map +1 -0
  176. package/lib/commonjs/tabBar/TabBarUsage.js +441 -0
  177. package/lib/commonjs/tabBar/TabBarUsage.js.map +1 -0
  178. package/lib/commonjs/tabBar/index.js +26 -0
  179. package/lib/commonjs/tabBar/index.js.map +1 -0
  180. package/lib/commonjs/tabBar/interface.js +43 -0
  181. package/lib/commonjs/tabBar/interface.js.map +1 -0
  182. package/lib/commonjs/text/index.js +65 -0
  183. package/lib/commonjs/text/index.js.map +1 -0
  184. package/lib/commonjs/timeline/index.js +264 -0
  185. package/lib/commonjs/timeline/index.js.map +1 -0
  186. package/lib/commonjs/toast/index.js +203 -0
  187. package/lib/commonjs/toast/index.js.map +1 -0
  188. package/lib/commonjs/toast/useToast.js +82 -0
  189. package/lib/commonjs/toast/useToast.js.map +1 -0
  190. package/lib/commonjs/utiles/createIcon.js +49 -0
  191. package/lib/commonjs/utiles/createIcon.js.map +1 -0
  192. package/lib/commonjs/utiles/fontStyles.js +36 -0
  193. package/lib/commonjs/utiles/fontStyles.js.map +1 -0
  194. package/lib/commonjs/utiles/position.js +98 -0
  195. package/lib/commonjs/utiles/position.js.map +1 -0
  196. package/lib/commonjs/utiles/statusBar.js +425 -0
  197. package/lib/commonjs/utiles/statusBar.js.map +1 -0
  198. package/lib/commonjs/utiles/styled.js +42 -0
  199. package/lib/commonjs/utiles/styled.js.map +1 -0
  200. package/lib/commonjs/utiles/styles.js +30 -0
  201. package/lib/commonjs/utiles/styles.js.map +1 -0
  202. package/lib/commonjs/utiles/theme.js +680 -0
  203. package/lib/commonjs/utiles/theme.js.map +1 -0
  204. package/lib/commonjs/utiles/validators.js +31 -0
  205. package/lib/commonjs/utiles/validators.js.map +1 -0
  206. package/lib/commonjs/utiles/viewStyleProps.js +6 -0
  207. package/lib/commonjs/utiles/viewStyleProps.js.map +1 -0
  208. package/lib/commonjs/utiles/viewStyleVariants.js +546 -0
  209. package/lib/commonjs/utiles/viewStyleVariants.js.map +1 -0
  210. package/lib/module/actionSheet/actionSheet.js +368 -0
  211. package/lib/module/actionSheet/actionSheet.js.map +1 -0
  212. package/lib/module/actionSheet/index.js +5 -0
  213. package/lib/module/actionSheet/index.js.map +1 -0
  214. package/lib/module/actionSheet/useActionSheet.js +85 -0
  215. package/lib/module/actionSheet/useActionSheet.js.map +1 -0
  216. package/lib/module/badge/index.js +147 -0
  217. package/lib/module/badge/index.js.map +1 -0
  218. package/lib/module/barChart/index.js +292 -0
  219. package/lib/module/barChart/index.js.map +1 -0
  220. package/lib/module/button/index.js +224 -0
  221. package/lib/module/button/index.js.map +1 -0
  222. package/lib/module/card/index.js +198 -0
  223. package/lib/module/card/index.js.map +1 -0
  224. package/lib/module/checkBox/index.js +86 -0
  225. package/lib/module/checkBox/index.js.map +1 -0
  226. package/lib/module/chips/index.js +232 -0
  227. package/lib/module/chips/index.js.map +1 -0
  228. package/lib/module/circularProgress/index.js +259 -0
  229. package/lib/module/circularProgress/index.js.map +1 -0
  230. package/lib/module/collapsible/Collapse.js +288 -0
  231. package/lib/module/collapsible/Collapse.js.map +1 -0
  232. package/lib/module/collapsible/CollapseGroup.js +133 -0
  233. package/lib/module/collapsible/CollapseGroup.js.map +1 -0
  234. package/lib/module/collapsible/index.js +40 -0
  235. package/lib/module/collapsible/index.js.map +1 -0
  236. package/lib/module/collapsible/interface.js +35 -0
  237. package/lib/module/collapsible/interface.js.map +1 -0
  238. package/lib/module/collapsible/style.js +153 -0
  239. package/lib/module/collapsible/style.js.map +1 -0
  240. package/lib/module/datePicker/index.js +908 -0
  241. package/lib/module/datePicker/index.js.map +1 -0
  242. package/lib/module/dialog/dialogue.js +189 -0
  243. package/lib/module/dialog/dialogue.js.map +1 -0
  244. package/lib/module/dialog/index.js +386 -0
  245. package/lib/module/dialog/index.js.map +1 -0
  246. package/lib/module/dialog/useDialogue.js +113 -0
  247. package/lib/module/dialog/useDialogue.js.map +1 -0
  248. package/lib/module/divider/index.js +34 -0
  249. package/lib/module/divider/index.js.map +1 -0
  250. package/lib/module/drawer/Drawer.js +583 -0
  251. package/lib/module/drawer/Drawer.js.map +1 -0
  252. package/lib/module/drawer/index.js +60 -0
  253. package/lib/module/drawer/index.js.map +1 -0
  254. package/lib/module/drawer/interface.js +80 -0
  255. package/lib/module/drawer/interface.js.map +1 -0
  256. package/lib/module/dropdown/index.js +854 -0
  257. package/lib/module/dropdown/index.js.map +1 -0
  258. package/lib/module/emptyState/index.js +225 -0
  259. package/lib/module/emptyState/index.js.map +1 -0
  260. package/lib/module/form/index.js +2 -0
  261. package/lib/module/form/index.js.map +1 -0
  262. package/lib/module/header/index.js +143 -0
  263. package/lib/module/header/index.js.map +1 -0
  264. package/lib/module/header/statusBar/index.js +15 -0
  265. package/lib/module/header/statusBar/index.js.map +1 -0
  266. package/lib/module/icons/backArrow.js +37 -0
  267. package/lib/module/icons/backArrow.js.map +1 -0
  268. package/lib/module/icons/bellFill.js +38 -0
  269. package/lib/module/icons/bellFill.js.map +1 -0
  270. package/lib/module/icons/bellOutline.js +38 -0
  271. package/lib/module/icons/bellOutline.js.map +1 -0
  272. package/lib/module/icons/checkmark.js +31 -0
  273. package/lib/module/icons/checkmark.js.map +1 -0
  274. package/lib/module/icons/delete.js +48 -0
  275. package/lib/module/icons/delete.js.map +1 -0
  276. package/lib/module/icons/downChevron.js +31 -0
  277. package/lib/module/icons/downChevron.js.map +1 -0
  278. package/lib/module/icons/error.js +36 -0
  279. package/lib/module/icons/error.js.map +1 -0
  280. package/lib/module/icons/forwardArrow.js +37 -0
  281. package/lib/module/icons/forwardArrow.js.map +1 -0
  282. package/lib/module/icons/index.js +18 -0
  283. package/lib/module/icons/index.js.map +1 -0
  284. package/lib/module/icons/info.js +43 -0
  285. package/lib/module/icons/info.js.map +1 -0
  286. package/lib/module/icons/leftChevron.js +31 -0
  287. package/lib/module/icons/leftChevron.js.map +1 -0
  288. package/lib/module/icons/rightChevron.js +31 -0
  289. package/lib/module/icons/rightChevron.js.map +1 -0
  290. package/lib/module/icons/save.js +45 -0
  291. package/lib/module/icons/save.js.map +1 -0
  292. package/lib/module/icons/success.js +38 -0
  293. package/lib/module/icons/success.js.map +1 -0
  294. package/lib/module/icons/upChevron.js +31 -0
  295. package/lib/module/icons/upChevron.js.map +1 -0
  296. package/lib/module/icons/warning.js +43 -0
  297. package/lib/module/icons/warning.js.map +1 -0
  298. package/lib/module/image/index.js +43 -0
  299. package/lib/module/image/index.js.map +1 -0
  300. package/lib/module/index.js +56 -24
  301. package/lib/module/index.js.map +1 -1
  302. package/lib/module/input/index.js +483 -0
  303. package/lib/module/input/index.js.map +1 -0
  304. package/lib/module/loading/circular.js +111 -0
  305. package/lib/module/loading/circular.js.map +1 -0
  306. package/lib/module/loading/index.js +7 -0
  307. package/lib/module/loading/index.js.map +1 -0
  308. package/lib/module/loading/loader.js +242 -0
  309. package/lib/module/loading/loader.js.map +1 -0
  310. package/lib/module/loading/spinner.js +85 -0
  311. package/lib/module/loading/spinner.js.map +1 -0
  312. package/lib/module/loading/useLoader.js +58 -0
  313. package/lib/module/loading/useLoader.js.map +1 -0
  314. package/lib/module/loading/useLoaderBinding.js +28 -0
  315. package/lib/module/loading/useLoaderBinding.js.map +1 -0
  316. package/lib/module/notification/index.js +253 -0
  317. package/lib/module/notification/index.js.map +1 -0
  318. package/lib/module/notification/useNotification.js +58 -0
  319. package/lib/module/notification/useNotification.js.map +1 -0
  320. package/lib/module/page/index.js +17 -0
  321. package/lib/module/page/index.js.map +1 -0
  322. package/lib/module/popup/Popup.js +328 -0
  323. package/lib/module/popup/Popup.js.map +1 -0
  324. package/lib/module/popup/helpers.js +159 -0
  325. package/lib/module/popup/helpers.js.map +1 -0
  326. package/lib/module/popup/index.js +45 -0
  327. package/lib/module/popup/index.js.map +1 -0
  328. package/lib/module/popup/interface.js +41 -0
  329. package/lib/module/popup/interface.js.map +1 -0
  330. package/lib/module/portal/GlobalPortalProvider.js +62 -0
  331. package/lib/module/portal/GlobalPortalProvider.js.map +1 -0
  332. package/lib/module/portal/PortalContext.js +33 -0
  333. package/lib/module/portal/PortalContext.js.map +1 -0
  334. package/lib/module/portal/PortalInstance.js +118 -0
  335. package/lib/module/portal/PortalInstance.js.map +1 -0
  336. package/lib/module/portal/PortalManager.js +81 -0
  337. package/lib/module/portal/PortalManager.js.map +1 -0
  338. package/lib/module/portal/PortalRenderer.js +51 -0
  339. package/lib/module/portal/PortalRenderer.js.map +1 -0
  340. package/lib/module/portal/index.js +56 -0
  341. package/lib/module/portal/index.js.map +1 -0
  342. package/lib/module/portal/portal.test.js +155 -0
  343. package/lib/module/portal/portal.test.js.map +1 -0
  344. package/lib/module/portal/types.js +4 -0
  345. package/lib/module/portal/types.js.map +1 -0
  346. package/lib/module/pressable/index.js +15 -0
  347. package/lib/module/pressable/index.js.map +1 -0
  348. package/lib/module/progressBar/index.js +506 -0
  349. package/lib/module/progressBar/index.js.map +1 -0
  350. package/lib/module/radio/index.js +361 -0
  351. package/lib/module/radio/index.js.map +1 -0
  352. package/lib/module/safeAreaProvider/index.js +9 -0
  353. package/lib/module/safeAreaProvider/index.js.map +1 -0
  354. package/lib/module/safeAreaView/index.js +11 -0
  355. package/lib/module/safeAreaView/index.js.map +1 -0
  356. package/lib/module/scrollView/index.js +11 -0
  357. package/lib/module/scrollView/index.js.map +1 -0
  358. package/lib/module/searchBar/index.js +350 -0
  359. package/lib/module/searchBar/index.js.map +1 -0
  360. package/lib/module/seperator/index.js +40 -0
  361. package/lib/module/seperator/index.js.map +1 -0
  362. package/lib/module/services/index.js +181 -0
  363. package/lib/module/services/index.js.map +1 -0
  364. package/lib/module/shape/index.js +33 -0
  365. package/lib/module/shape/index.js.map +1 -0
  366. package/lib/module/skeleton/index.js +425 -0
  367. package/lib/module/skeleton/index.js.map +1 -0
  368. package/lib/module/slider/index.js +493 -0
  369. package/lib/module/slider/index.js.map +1 -0
  370. package/lib/module/spacer/index.js +11 -0
  371. package/lib/module/spacer/index.js.map +1 -0
  372. package/lib/module/stack/index.js +50 -0
  373. package/lib/module/stack/index.js.map +1 -0
  374. package/lib/module/switch/Switch.js +285 -0
  375. package/lib/module/switch/Switch.js.map +1 -0
  376. package/lib/module/switch/_index.js +114 -0
  377. package/lib/module/switch/_index.js.map +1 -0
  378. package/lib/module/switch/index.js +64 -0
  379. package/lib/module/switch/index.js.map +1 -0
  380. package/lib/module/switch/interface.js +43 -0
  381. package/lib/module/switch/interface.js.map +1 -0
  382. package/lib/module/tabBar/TabBar.js +405 -0
  383. package/lib/module/tabBar/TabBar.js.map +1 -0
  384. package/lib/module/tabBar/TabBarUsage.js +437 -0
  385. package/lib/module/tabBar/TabBarUsage.js.map +1 -0
  386. package/lib/module/tabBar/index.js +54 -0
  387. package/lib/module/tabBar/index.js.map +1 -0
  388. package/lib/module/tabBar/interface.js +39 -0
  389. package/lib/module/tabBar/interface.js.map +1 -0
  390. package/lib/module/text/index.js +62 -0
  391. package/lib/module/text/index.js.map +1 -0
  392. package/lib/module/timeline/index.js +258 -0
  393. package/lib/module/timeline/index.js.map +1 -0
  394. package/lib/module/toast/index.js +187 -0
  395. package/lib/module/toast/index.js.map +1 -0
  396. package/lib/module/toast/useToast.js +78 -0
  397. package/lib/module/toast/useToast.js.map +1 -0
  398. package/lib/module/utiles/createIcon.js +45 -0
  399. package/lib/module/utiles/createIcon.js.map +1 -0
  400. package/lib/module/utiles/fontStyles.js +31 -0
  401. package/lib/module/utiles/fontStyles.js.map +1 -0
  402. package/lib/module/utiles/position.js +94 -0
  403. package/lib/module/utiles/position.js.map +1 -0
  404. package/lib/module/utiles/statusBar.js +401 -0
  405. package/lib/module/utiles/statusBar.js.map +1 -0
  406. package/lib/module/utiles/styled.js +37 -0
  407. package/lib/module/utiles/styled.js.map +1 -0
  408. package/lib/module/utiles/styles.js +27 -0
  409. package/lib/module/utiles/styles.js.map +1 -0
  410. package/lib/module/{package → utiles}/theme.js +305 -17
  411. package/lib/module/utiles/theme.js.map +1 -0
  412. package/lib/module/utiles/validators.js +24 -0
  413. package/lib/module/utiles/validators.js.map +1 -0
  414. package/lib/module/utiles/viewStyleProps.js +4 -0
  415. package/lib/module/utiles/viewStyleProps.js.map +1 -0
  416. package/lib/module/utiles/viewStyleVariants.js +542 -0
  417. package/lib/module/utiles/viewStyleVariants.js.map +1 -0
  418. package/lib/typescript/actionSheet/actionSheet.d.ts +82 -0
  419. package/lib/typescript/actionSheet/actionSheet.d.ts.map +1 -0
  420. package/lib/typescript/actionSheet/index.d.ts +4 -0
  421. package/lib/typescript/actionSheet/index.d.ts.map +1 -0
  422. package/lib/typescript/actionSheet/useActionSheet.d.ts +82 -0
  423. package/lib/typescript/actionSheet/useActionSheet.d.ts.map +1 -0
  424. package/lib/typescript/badge/index.d.ts +37 -0
  425. package/lib/typescript/badge/index.d.ts.map +1 -0
  426. package/lib/typescript/barChart/index.d.ts +125 -0
  427. package/lib/typescript/barChart/index.d.ts.map +1 -0
  428. package/lib/typescript/button/index.d.ts +86 -0
  429. package/lib/typescript/button/index.d.ts.map +1 -0
  430. package/lib/typescript/card/index.d.ts +53 -0
  431. package/lib/typescript/card/index.d.ts.map +1 -0
  432. package/lib/typescript/checkBox/index.d.ts +28 -0
  433. package/lib/typescript/checkBox/index.d.ts.map +1 -0
  434. package/lib/typescript/chips/index.d.ts +104 -0
  435. package/lib/typescript/chips/index.d.ts.map +1 -0
  436. package/lib/typescript/circularProgress/index.d.ts +36 -0
  437. package/lib/typescript/circularProgress/index.d.ts.map +1 -0
  438. package/lib/typescript/collapsible/Collapse.d.ts +5 -0
  439. package/lib/typescript/collapsible/Collapse.d.ts.map +1 -0
  440. package/lib/typescript/collapsible/CollapseGroup.d.ts +49 -0
  441. package/lib/typescript/collapsible/CollapseGroup.d.ts.map +1 -0
  442. package/lib/typescript/collapsible/index.d.ts +38 -0
  443. package/lib/typescript/collapsible/index.d.ts.map +1 -0
  444. package/lib/typescript/collapsible/interface.d.ts +116 -0
  445. package/lib/typescript/collapsible/interface.d.ts.map +1 -0
  446. package/lib/typescript/collapsible/style.d.ts +92 -0
  447. package/lib/typescript/collapsible/style.d.ts.map +1 -0
  448. package/lib/typescript/datePicker/index.d.ts +91 -0
  449. package/lib/typescript/datePicker/index.d.ts.map +1 -0
  450. package/lib/typescript/dialog/dialogue.d.ts +20 -0
  451. package/lib/typescript/dialog/dialogue.d.ts.map +1 -0
  452. package/lib/typescript/dialog/index.d.ts +175 -0
  453. package/lib/typescript/dialog/index.d.ts.map +1 -0
  454. package/lib/typescript/dialog/useDialogue.d.ts +21 -0
  455. package/lib/typescript/dialog/useDialogue.d.ts.map +1 -0
  456. package/lib/typescript/divider/index.d.ts +12 -0
  457. package/lib/typescript/divider/index.d.ts.map +1 -0
  458. package/lib/typescript/drawer/Drawer.d.ts +4 -0
  459. package/lib/typescript/drawer/Drawer.d.ts.map +1 -0
  460. package/lib/typescript/drawer/index.d.ts +48 -0
  461. package/lib/typescript/drawer/index.d.ts.map +1 -0
  462. package/lib/typescript/drawer/interface.d.ts +232 -0
  463. package/lib/typescript/drawer/interface.d.ts.map +1 -0
  464. package/lib/typescript/dropdown/index.d.ts +54 -0
  465. package/lib/typescript/dropdown/index.d.ts.map +1 -0
  466. package/lib/typescript/emptyState/index.d.ts +57 -0
  467. package/lib/typescript/emptyState/index.d.ts.map +1 -0
  468. package/lib/typescript/form/index.d.ts +1 -0
  469. package/lib/typescript/form/index.d.ts.map +1 -0
  470. package/lib/typescript/header/index.d.ts +44 -0
  471. package/lib/typescript/header/index.d.ts.map +1 -0
  472. package/lib/typescript/header/statusBar/index.d.ts +6 -0
  473. package/lib/typescript/header/statusBar/index.d.ts.map +1 -0
  474. package/lib/typescript/icons/backArrow.d.ts +12 -0
  475. package/lib/typescript/icons/backArrow.d.ts.map +1 -0
  476. package/lib/typescript/icons/bellFill.d.ts +12 -0
  477. package/lib/typescript/icons/bellFill.d.ts.map +1 -0
  478. package/lib/typescript/icons/bellOutline.d.ts +12 -0
  479. package/lib/typescript/icons/bellOutline.d.ts.map +1 -0
  480. package/lib/typescript/icons/checkmark.d.ts +12 -0
  481. package/lib/typescript/icons/checkmark.d.ts.map +1 -0
  482. package/lib/typescript/icons/delete.d.ts +12 -0
  483. package/lib/typescript/icons/delete.d.ts.map +1 -0
  484. package/lib/typescript/icons/downChevron.d.ts +12 -0
  485. package/lib/typescript/icons/downChevron.d.ts.map +1 -0
  486. package/lib/typescript/icons/error.d.ts +12 -0
  487. package/lib/typescript/icons/error.d.ts.map +1 -0
  488. package/lib/typescript/icons/forwardArrow.d.ts +12 -0
  489. package/lib/typescript/icons/forwardArrow.d.ts.map +1 -0
  490. package/lib/typescript/icons/index.d.ts +16 -0
  491. package/lib/typescript/icons/index.d.ts.map +1 -0
  492. package/lib/typescript/icons/info.d.ts +12 -0
  493. package/lib/typescript/icons/info.d.ts.map +1 -0
  494. package/lib/typescript/icons/leftChevron.d.ts +12 -0
  495. package/lib/typescript/icons/leftChevron.d.ts.map +1 -0
  496. package/lib/typescript/icons/rightChevron.d.ts +12 -0
  497. package/lib/typescript/icons/rightChevron.d.ts.map +1 -0
  498. package/lib/typescript/icons/save.d.ts +12 -0
  499. package/lib/typescript/icons/save.d.ts.map +1 -0
  500. package/lib/typescript/icons/success.d.ts +12 -0
  501. package/lib/typescript/icons/success.d.ts.map +1 -0
  502. package/lib/typescript/icons/upChevron.d.ts +12 -0
  503. package/lib/typescript/icons/upChevron.d.ts.map +1 -0
  504. package/lib/typescript/icons/warning.d.ts +12 -0
  505. package/lib/typescript/icons/warning.d.ts.map +1 -0
  506. package/lib/typescript/image/index.d.ts +15 -0
  507. package/lib/typescript/image/index.d.ts.map +1 -0
  508. package/lib/typescript/index.d.ts +56 -0
  509. package/lib/typescript/index.d.ts.map +1 -0
  510. package/lib/typescript/input/index.d.ts +89 -0
  511. package/lib/typescript/input/index.d.ts.map +1 -0
  512. package/lib/typescript/loading/circular.d.ts +10 -0
  513. package/lib/typescript/loading/circular.d.ts.map +1 -0
  514. package/lib/typescript/loading/index.d.ts +7 -0
  515. package/lib/typescript/loading/index.d.ts.map +1 -0
  516. package/lib/typescript/loading/loader.d.ts +23 -0
  517. package/lib/typescript/loading/loader.d.ts.map +1 -0
  518. package/lib/typescript/loading/spinner.d.ts +22 -0
  519. package/lib/typescript/loading/spinner.d.ts.map +1 -0
  520. package/lib/typescript/loading/useLoader.d.ts +27 -0
  521. package/lib/typescript/loading/useLoader.d.ts.map +1 -0
  522. package/lib/typescript/loading/useLoaderBinding.d.ts +9 -0
  523. package/lib/typescript/loading/useLoaderBinding.d.ts.map +1 -0
  524. package/lib/typescript/notification/index.d.ts +21 -0
  525. package/lib/typescript/notification/index.d.ts.map +1 -0
  526. package/lib/typescript/notification/useNotification.d.ts +30 -0
  527. package/lib/typescript/notification/useNotification.d.ts.map +1 -0
  528. package/lib/typescript/page/index.d.ts +12 -0
  529. package/lib/typescript/page/index.d.ts.map +1 -0
  530. package/lib/typescript/popup/Popup.d.ts +4 -0
  531. package/lib/typescript/popup/Popup.d.ts.map +1 -0
  532. package/lib/typescript/popup/helpers.d.ts +9 -0
  533. package/lib/typescript/popup/helpers.d.ts.map +1 -0
  534. package/lib/typescript/popup/index.d.ts +43 -0
  535. package/lib/typescript/popup/index.d.ts.map +1 -0
  536. package/lib/typescript/popup/interface.d.ts +103 -0
  537. package/lib/typescript/popup/interface.d.ts.map +1 -0
  538. package/lib/typescript/portal/GlobalPortalProvider.d.ts +44 -0
  539. package/lib/typescript/portal/GlobalPortalProvider.d.ts.map +1 -0
  540. package/lib/typescript/portal/PortalContext.d.ts +25 -0
  541. package/lib/typescript/portal/PortalContext.d.ts.map +1 -0
  542. package/lib/typescript/portal/PortalInstance.d.ts +72 -0
  543. package/lib/typescript/portal/PortalInstance.d.ts.map +1 -0
  544. package/lib/typescript/portal/PortalManager.d.ts +7 -0
  545. package/lib/typescript/portal/PortalManager.d.ts.map +1 -0
  546. package/lib/typescript/portal/PortalRenderer.d.ts +27 -0
  547. package/lib/typescript/portal/PortalRenderer.d.ts.map +1 -0
  548. package/lib/typescript/portal/index.d.ts +43 -0
  549. package/lib/typescript/portal/index.d.ts.map +1 -0
  550. package/lib/typescript/portal/portal.test.d.ts +11 -0
  551. package/lib/typescript/portal/portal.test.d.ts.map +1 -0
  552. package/lib/typescript/portal/types.d.ts +30 -0
  553. package/lib/typescript/portal/types.d.ts.map +1 -0
  554. package/lib/typescript/pressable/index.d.ts +8 -0
  555. package/lib/typescript/pressable/index.d.ts.map +1 -0
  556. package/lib/typescript/progressBar/index.d.ts +155 -0
  557. package/lib/typescript/progressBar/index.d.ts.map +1 -0
  558. package/lib/typescript/radio/index.d.ts +144 -0
  559. package/lib/typescript/radio/index.d.ts.map +1 -0
  560. package/lib/typescript/safeAreaProvider/index.d.ts +7 -0
  561. package/lib/typescript/safeAreaProvider/index.d.ts.map +1 -0
  562. package/lib/typescript/safeAreaView/index.d.ts +8 -0
  563. package/lib/typescript/safeAreaView/index.d.ts.map +1 -0
  564. package/lib/typescript/scrollView/index.d.ts +8 -0
  565. package/lib/typescript/scrollView/index.d.ts.map +1 -0
  566. package/lib/typescript/searchBar/index.d.ts +70 -0
  567. package/lib/typescript/searchBar/index.d.ts.map +1 -0
  568. package/lib/typescript/seperator/index.d.ts +13 -0
  569. package/lib/typescript/seperator/index.d.ts.map +1 -0
  570. package/lib/typescript/services/index.d.ts +56 -0
  571. package/lib/typescript/services/index.d.ts.map +1 -0
  572. package/lib/typescript/shape/index.d.ts +11 -0
  573. package/lib/typescript/shape/index.d.ts.map +1 -0
  574. package/lib/typescript/skeleton/index.d.ts +63 -0
  575. package/lib/typescript/skeleton/index.d.ts.map +1 -0
  576. package/lib/typescript/slider/index.d.ts +60 -0
  577. package/lib/typescript/slider/index.d.ts.map +1 -0
  578. package/lib/typescript/spacer/index.d.ts +8 -0
  579. package/lib/typescript/spacer/index.d.ts.map +1 -0
  580. package/lib/typescript/stack/index.d.ts +24 -0
  581. package/lib/typescript/stack/index.d.ts.map +1 -0
  582. package/lib/typescript/switch/Switch.d.ts +6 -0
  583. package/lib/typescript/switch/Switch.d.ts.map +1 -0
  584. package/lib/typescript/switch/_index.d.ts +11 -0
  585. package/lib/typescript/switch/_index.d.ts.map +1 -0
  586. package/lib/typescript/switch/index.d.ts +62 -0
  587. package/lib/typescript/switch/index.d.ts.map +1 -0
  588. package/lib/typescript/switch/interface.d.ts +74 -0
  589. package/lib/typescript/switch/interface.d.ts.map +1 -0
  590. package/lib/typescript/tabBar/TabBar.d.ts +5 -0
  591. package/lib/typescript/tabBar/TabBar.d.ts.map +1 -0
  592. package/lib/typescript/tabBar/TabBarUsage.d.ts +6 -0
  593. package/lib/typescript/tabBar/TabBarUsage.d.ts.map +1 -0
  594. package/lib/typescript/tabBar/index.d.ts +52 -0
  595. package/lib/typescript/tabBar/index.d.ts.map +1 -0
  596. package/lib/typescript/tabBar/interface.d.ts +119 -0
  597. package/lib/typescript/tabBar/interface.d.ts.map +1 -0
  598. package/lib/typescript/text/index.d.ts +16 -0
  599. package/lib/typescript/text/index.d.ts.map +1 -0
  600. package/lib/typescript/timeline/index.d.ts +125 -0
  601. package/lib/typescript/timeline/index.d.ts.map +1 -0
  602. package/lib/typescript/toast/index.d.ts +28 -0
  603. package/lib/typescript/toast/index.d.ts.map +1 -0
  604. package/lib/typescript/toast/useToast.d.ts +31 -0
  605. package/lib/typescript/toast/useToast.d.ts.map +1 -0
  606. package/lib/typescript/utiles/createIcon.d.ts +39 -0
  607. package/lib/typescript/utiles/createIcon.d.ts.map +1 -0
  608. package/lib/typescript/utiles/fontStyles.d.ts +9 -0
  609. package/lib/typescript/utiles/fontStyles.d.ts.map +1 -0
  610. package/lib/typescript/utiles/position.d.ts +13 -0
  611. package/lib/typescript/utiles/position.d.ts.map +1 -0
  612. package/lib/typescript/utiles/statusBar.d.ts +128 -0
  613. package/lib/typescript/utiles/statusBar.d.ts.map +1 -0
  614. package/lib/typescript/utiles/styled.d.ts +14 -0
  615. package/lib/typescript/utiles/styled.d.ts.map +1 -0
  616. package/lib/typescript/utiles/styles.d.ts +31 -0
  617. package/lib/typescript/utiles/styles.d.ts.map +1 -0
  618. package/lib/typescript/utiles/theme.d.ts +918 -0
  619. package/lib/typescript/utiles/theme.d.ts.map +1 -0
  620. package/lib/typescript/utiles/validators.d.ts +14 -0
  621. package/lib/typescript/utiles/validators.d.ts.map +1 -0
  622. package/lib/typescript/utiles/viewStyleProps.d.ts +4 -0
  623. package/lib/typescript/utiles/viewStyleProps.d.ts.map +1 -0
  624. package/lib/typescript/utiles/viewStyleVariants.d.ts +121 -0
  625. package/lib/typescript/utiles/viewStyleVariants.d.ts.map +1 -0
  626. package/package.json +146 -52
  627. package/src/actionSheet/actionSheet.tsx +471 -0
  628. package/src/actionSheet/index.tsx +3 -0
  629. package/src/actionSheet/useActionSheet.tsx +140 -0
  630. package/src/badge/index.tsx +185 -0
  631. package/src/barChart/index.tsx +386 -0
  632. package/src/button/index.tsx +335 -0
  633. package/src/card/index.tsx +220 -0
  634. package/src/checkBox/index.tsx +137 -0
  635. package/src/chips/index.tsx +293 -0
  636. package/src/circularProgress/index.tsx +349 -0
  637. package/src/collapsible/Collapse.tsx +366 -0
  638. package/src/collapsible/CollapseGroup.tsx +161 -0
  639. package/src/collapsible/index.ts +48 -0
  640. package/src/collapsible/interface.ts +187 -0
  641. package/src/collapsible/style.ts +130 -0
  642. package/src/datePicker/index.tsx +961 -0
  643. package/src/dialog/dialogue.tsx +155 -0
  644. package/src/dialog/index.tsx +604 -0
  645. package/src/dialog/useDialogue.tsx +158 -0
  646. package/src/divider/index.tsx +45 -0
  647. package/src/drawer/Drawer.tsx +655 -0
  648. package/src/drawer/index.ts +60 -0
  649. package/src/drawer/interface.ts +391 -0
  650. package/src/dropdown/index.tsx +1081 -0
  651. package/src/emptyState/index.tsx +287 -0
  652. package/src/form/index.tsx +0 -0
  653. package/src/header/index.tsx +217 -0
  654. package/src/header/statusBar/index.tsx +11 -0
  655. package/src/icons/backArrow.tsx +17 -0
  656. package/src/icons/bellFill.tsx +19 -0
  657. package/src/icons/bellOutline.tsx +18 -0
  658. package/src/icons/checkmark.tsx +18 -0
  659. package/src/icons/delete.tsx +19 -0
  660. package/src/icons/downChevron.tsx +18 -0
  661. package/src/icons/error.tsx +17 -0
  662. package/src/icons/forwardArrow.tsx +19 -0
  663. package/src/icons/index.ts +15 -0
  664. package/src/icons/info.tsx +19 -0
  665. package/src/icons/leftChevron.tsx +18 -0
  666. package/src/icons/rightChevron.tsx +18 -0
  667. package/src/icons/save.tsx +18 -0
  668. package/src/icons/success.tsx +17 -0
  669. package/src/icons/upChevron.tsx +18 -0
  670. package/src/icons/warning.tsx +19 -0
  671. package/src/image/index.tsx +45 -0
  672. package/src/index.ts +72 -0
  673. package/src/input/index.tsx +668 -0
  674. package/src/loading/circular.tsx +141 -0
  675. package/src/loading/index.tsx +6 -0
  676. package/src/loading/loader.tsx +191 -0
  677. package/src/loading/spinner.tsx +126 -0
  678. package/src/loading/useLoader.tsx +78 -0
  679. package/src/loading/useLoaderBinding.tsx +38 -0
  680. package/src/notification/index.tsx +189 -0
  681. package/src/notification/useNotification.tsx +64 -0
  682. package/src/page/index.tsx +19 -0
  683. package/src/popup/Popup.tsx +398 -0
  684. package/src/popup/helpers.ts +123 -0
  685. package/src/popup/index.ts +45 -0
  686. package/src/popup/interface.ts +178 -0
  687. package/src/portal/GlobalPortalProvider.tsx +63 -0
  688. package/src/portal/PortalContext.ts +37 -0
  689. package/src/portal/PortalInstance.ts +118 -0
  690. package/src/portal/PortalManager.tsx +84 -0
  691. package/src/portal/PortalRenderer.tsx +72 -0
  692. package/src/portal/index.ts +60 -0
  693. package/src/portal/portal.test.ts +157 -0
  694. package/src/portal/types.ts +49 -0
  695. package/src/pressable/index.tsx +19 -0
  696. package/src/progressBar/index.tsx +564 -0
  697. package/src/radio/index.tsx +469 -0
  698. package/src/safeAreaProvider/index.ts +16 -0
  699. package/src/safeAreaView/index.tsx +17 -0
  700. package/src/scrollView/index.ts +15 -0
  701. package/src/searchBar/index.tsx +383 -0
  702. package/src/seperator/index.tsx +59 -0
  703. package/src/services/index.ts +149 -0
  704. package/src/shape/index.tsx +38 -0
  705. package/src/skeleton/index.tsx +350 -0
  706. package/src/slider/index.tsx +637 -0
  707. package/src/spacer/index.ts +29 -0
  708. package/src/stack/index.ts +58 -0
  709. package/src/switch/Switch.tsx +343 -0
  710. package/src/switch/_index.tsx +135 -0
  711. package/src/switch/index.ts +62 -0
  712. package/src/switch/interface.ts +120 -0
  713. package/src/tabBar/TabBar.tsx +503 -0
  714. package/src/tabBar/TabBarUsage.tsx +366 -0
  715. package/src/tabBar/index.ts +59 -0
  716. package/src/tabBar/interface.ts +196 -0
  717. package/src/text/index.ts +73 -0
  718. package/src/timeline/index.tsx +374 -0
  719. package/src/toast/index.tsx +172 -0
  720. package/src/toast/useToast.tsx +93 -0
  721. package/src/utiles/createIcon.ts +44 -0
  722. package/src/utiles/fontStyles.js +31 -0
  723. package/src/utiles/position.ts +100 -0
  724. package/src/utiles/statusBar.ts +410 -0
  725. package/src/utiles/styled.tsx +48 -0
  726. package/src/utiles/styles.ts +25 -0
  727. package/src/utiles/theme.ts +727 -0
  728. package/src/utiles/validators.ts +21 -0
  729. package/src/utiles/viewStyleProps.ts +41 -0
  730. package/src/utiles/viewStyleVariants.ts +411 -0
  731. package/lib/commonjs/assets/img/blank_1.png +0 -0
  732. package/lib/commonjs/assets/img/blank_2.png +0 -0
  733. package/lib/commonjs/assets/img/doctor.png +0 -0
  734. package/lib/commonjs/package/badge/index.js +0 -161
  735. package/lib/commonjs/package/badge/index.js.map +0 -1
  736. package/lib/commonjs/package/button/index.js +0 -99
  737. package/lib/commonjs/package/button/index.js.map +0 -1
  738. package/lib/commonjs/package/card/index.js +0 -46
  739. package/lib/commonjs/package/card/index.js.map +0 -1
  740. package/lib/commonjs/package/checkBox/index.js +0 -92
  741. package/lib/commonjs/package/checkBox/index.js.map +0 -1
  742. package/lib/commonjs/package/cycle/index.js +0 -43
  743. package/lib/commonjs/package/cycle/index.js.map +0 -1
  744. package/lib/commonjs/package/dialog/index.js +0 -216
  745. package/lib/commonjs/package/dialog/index.js.map +0 -1
  746. package/lib/commonjs/package/dropdown/index.js +0 -112
  747. package/lib/commonjs/package/dropdown/index.js.map +0 -1
  748. package/lib/commonjs/package/form/index.js +0 -190
  749. package/lib/commonjs/package/form/index.js.map +0 -1
  750. package/lib/commonjs/package/header/index.js +0 -99
  751. package/lib/commonjs/package/header/index.js.map +0 -1
  752. package/lib/commonjs/package/image/index.js +0 -326
  753. package/lib/commonjs/package/image/index.js.map +0 -1
  754. package/lib/commonjs/package/radioButton/index.js +0 -75
  755. package/lib/commonjs/package/radioButton/index.js.map +0 -1
  756. package/lib/commonjs/package/safeAreaView/index.js +0 -26
  757. package/lib/commonjs/package/safeAreaView/index.js.map +0 -1
  758. package/lib/commonjs/package/scrollView/index.js +0 -23
  759. package/lib/commonjs/package/scrollView/index.js.map +0 -1
  760. package/lib/commonjs/package/separator/index.js +0 -33
  761. package/lib/commonjs/package/separator/index.js.map +0 -1
  762. package/lib/commonjs/package/spacer/index.js +0 -18
  763. package/lib/commonjs/package/spacer/index.js.map +0 -1
  764. package/lib/commonjs/package/spinner/index.js +0 -43
  765. package/lib/commonjs/package/spinner/index.js.map +0 -1
  766. package/lib/commonjs/package/stack/__test__/index.test.js +0 -91
  767. package/lib/commonjs/package/stack/__test__/index.test.js.map +0 -1
  768. package/lib/commonjs/package/stack/index.js +0 -54
  769. package/lib/commonjs/package/stack/index.js.map +0 -1
  770. package/lib/commonjs/package/styled/__test__/index.test.js +0 -161
  771. package/lib/commonjs/package/styled/__test__/index.test.js.map +0 -1
  772. package/lib/commonjs/package/styled/index.js +0 -42
  773. package/lib/commonjs/package/styled/index.js.map +0 -1
  774. package/lib/commonjs/package/switch/index.js +0 -43
  775. package/lib/commonjs/package/switch/index.js.map +0 -1
  776. package/lib/commonjs/package/text/index.js +0 -81
  777. package/lib/commonjs/package/text/index.js.map +0 -1
  778. package/lib/commonjs/package/theme.js +0 -385
  779. package/lib/commonjs/package/theme.js.map +0 -1
  780. package/lib/commonjs/package/utils/index.js +0 -130
  781. package/lib/commonjs/package/utils/index.js.map +0 -1
  782. package/lib/commonjs/package/utils/statusBar.js +0 -70
  783. package/lib/commonjs/package/utils/statusBar.js.map +0 -1
  784. package/lib/commonjs/package/utils/validator.js +0 -40
  785. package/lib/commonjs/package/utils/validator.js.map +0 -1
  786. package/lib/commonjs/styled.code-workspace +0 -9
  787. package/lib/module/assets/img/blank_1.png +0 -0
  788. package/lib/module/assets/img/blank_2.png +0 -0
  789. package/lib/module/assets/img/doctor.png +0 -0
  790. package/lib/module/package/badge/index.js +0 -153
  791. package/lib/module/package/badge/index.js.map +0 -1
  792. package/lib/module/package/button/index.js +0 -92
  793. package/lib/module/package/button/index.js.map +0 -1
  794. package/lib/module/package/card/index.js +0 -39
  795. package/lib/module/package/card/index.js.map +0 -1
  796. package/lib/module/package/checkBox/index.js +0 -83
  797. package/lib/module/package/checkBox/index.js.map +0 -1
  798. package/lib/module/package/cycle/index.js +0 -36
  799. package/lib/module/package/cycle/index.js.map +0 -1
  800. package/lib/module/package/dialog/index.js +0 -206
  801. package/lib/module/package/dialog/index.js.map +0 -1
  802. package/lib/module/package/dropdown/index.js +0 -102
  803. package/lib/module/package/dropdown/index.js.map +0 -1
  804. package/lib/module/package/form/index.js +0 -182
  805. package/lib/module/package/form/index.js.map +0 -1
  806. package/lib/module/package/header/index.js +0 -93
  807. package/lib/module/package/header/index.js.map +0 -1
  808. package/lib/module/package/image/index.js +0 -315
  809. package/lib/module/package/image/index.js.map +0 -1
  810. package/lib/module/package/radioButton/index.js +0 -66
  811. package/lib/module/package/radioButton/index.js.map +0 -1
  812. package/lib/module/package/safeAreaView/index.js +0 -21
  813. package/lib/module/package/safeAreaView/index.js.map +0 -1
  814. package/lib/module/package/scrollView/index.js +0 -18
  815. package/lib/module/package/scrollView/index.js.map +0 -1
  816. package/lib/module/package/separator/index.js +0 -26
  817. package/lib/module/package/separator/index.js.map +0 -1
  818. package/lib/module/package/spacer/index.js +0 -11
  819. package/lib/module/package/spacer/index.js.map +0 -1
  820. package/lib/module/package/spinner/index.js +0 -36
  821. package/lib/module/package/spinner/index.js.map +0 -1
  822. package/lib/module/package/stack/__test__/index.test.js +0 -89
  823. package/lib/module/package/stack/__test__/index.test.js.map +0 -1
  824. package/lib/module/package/stack/index.js +0 -49
  825. package/lib/module/package/stack/index.js.map +0 -1
  826. package/lib/module/package/styled/__test__/index.test.js +0 -158
  827. package/lib/module/package/styled/__test__/index.test.js.map +0 -1
  828. package/lib/module/package/styled/index.js +0 -35
  829. package/lib/module/package/styled/index.js.map +0 -1
  830. package/lib/module/package/switch/index.js +0 -36
  831. package/lib/module/package/switch/index.js.map +0 -1
  832. package/lib/module/package/text/index.js +0 -76
  833. package/lib/module/package/text/index.js.map +0 -1
  834. package/lib/module/package/theme.js.map +0 -1
  835. package/lib/module/package/utils/index.js +0 -120
  836. package/lib/module/package/utils/index.js.map +0 -1
  837. package/lib/module/package/utils/statusBar.js +0 -57
  838. package/lib/module/package/utils/statusBar.js.map +0 -1
  839. package/lib/module/package/utils/validator.js +0 -34
  840. package/lib/module/package/utils/validator.js.map +0 -1
  841. package/lib/module/styled.code-workspace +0 -9
  842. package/src/assets/img/blank_1.png +0 -0
  843. package/src/assets/img/blank_2.png +0 -0
  844. package/src/assets/img/doctor.png +0 -0
  845. package/src/index.js +0 -24
  846. package/src/package/badge/index.jsx +0 -135
  847. package/src/package/button/index.jsx +0 -83
  848. package/src/package/card/index.jsx +0 -52
  849. package/src/package/checkBox/index.jsx +0 -97
  850. package/src/package/cycle/index.jsx +0 -49
  851. package/src/package/dialog/index.jsx +0 -263
  852. package/src/package/dropdown/index.jsx +0 -101
  853. package/src/package/form/index.jsx +0 -144
  854. package/src/package/header/index.jsx +0 -96
  855. package/src/package/image/index.jsx +0 -300
  856. package/src/package/radioButton/index.jsx +0 -74
  857. package/src/package/safeAreaView/index.jsx +0 -20
  858. package/src/package/scrollView/index.jsx +0 -17
  859. package/src/package/separator/index.jsx +0 -27
  860. package/src/package/spacer/index.jsx +0 -13
  861. package/src/package/spinner/index.jsx +0 -33
  862. package/src/package/stack/__test__/index.test.js +0 -68
  863. package/src/package/stack/index.jsx +0 -50
  864. package/src/package/styled/__test__/index.test.js +0 -132
  865. package/src/package/styled/index.js +0 -32
  866. package/src/package/switch/index.jsx +0 -33
  867. package/src/package/text/index.jsx +0 -67
  868. package/src/package/theme.js +0 -377
  869. package/src/package/utils/index.js +0 -109
  870. package/src/package/utils/statusBar.js +0 -65
  871. package/src/package/utils/validator.js +0 -38
  872. package/src/styled.code-workspace +0 -9
@@ -0,0 +1,961 @@
1
+ /**
2
+ * StyledDatePicker.tsx
3
+ * ─────────────────────
4
+ * Production-ready date picker for fluent-styles apps.
5
+ * Pure JS — no native deps. Built exclusively on fluent-styles primitives.
6
+ *
7
+ * Modes: date | time | datetime | range | month
8
+ * Variants: inline | sheet | input
9
+ */
10
+
11
+ import React, { useState, useCallback, useRef, useEffect } from 'react';
12
+ import {
13
+ Animated,
14
+ Dimensions,
15
+ Modal,
16
+ Platform,
17
+ ScrollView,
18
+ NativeSyntheticEvent,
19
+ NativeScrollEvent,
20
+ } from 'react-native';
21
+ import Icon from 'react-native-vector-icons/Feather';
22
+ import {
23
+ Stack,
24
+ StyledText,
25
+ StyledPressable,
26
+ StyledDivider,
27
+ StyledSpacer,
28
+ theme,
29
+ palettes,
30
+ } from 'fluent-styles';
31
+
32
+ // ─── Types ────────────────────────────────────────────────────────────────────
33
+
34
+ export type DatePickerMode = 'date' | 'time' | 'datetime' | 'range' | 'month';
35
+ export type DatePickerVariant = 'inline' | 'sheet' | 'input';
36
+ export type DatePickerSize = 'sm' | 'md' | 'lg';
37
+
38
+ export interface StyledDatePickerColors {
39
+ selected?: string;
40
+ selectedText?: string;
41
+ today?: string;
42
+ rangeFill?: string;
43
+ dayText?: string;
44
+ disabledText?: string;
45
+ headerText?: string;
46
+ background?: string;
47
+ inputBorder?: string;
48
+ confirmBg?: string;
49
+ confirmText?: string;
50
+ }
51
+
52
+ export interface StyledDatePickerProps {
53
+ mode?: DatePickerMode;
54
+ variant?: DatePickerVariant;
55
+ size?: DatePickerSize;
56
+ value?: Date | null;
57
+ valueStart?: Date | null;
58
+ valueEnd?: Date | null;
59
+ minDate?: Date;
60
+ maxDate?: Date;
61
+ showTodayButton?: boolean;
62
+ showConfirm?: boolean;
63
+ confirmLabel?: string;
64
+ placeholder?: string;
65
+ label?: string;
66
+ formatDisplay?: (date: Date) => string;
67
+ colors?: StyledDatePickerColors;
68
+ onChange?: (date: Date) => void;
69
+ onRangeChange?: (start: Date | null, end: Date | null) => void;
70
+ onConfirm?: (date: Date | null) => void;
71
+ disabled?: boolean;
72
+ }
73
+
74
+ // ─── Date helpers (local-time safe) ──────────────────────────────────────────
75
+
76
+ function sameDay(a: Date, b: Date): boolean {
77
+ return (
78
+ a.getFullYear() === b.getFullYear() &&
79
+ a.getMonth() === b.getMonth() &&
80
+ a.getDate() === b.getDate()
81
+ );
82
+ }
83
+
84
+ function daysInMonth(year: number, month: number): number {
85
+ return new Date(year, month + 1, 0).getDate();
86
+ }
87
+
88
+ function addMonths(d: Date, n: number): Date {
89
+ return new Date(d.getFullYear(), d.getMonth() + n, 1);
90
+ }
91
+
92
+ const FMT_DATE = (d: Date) =>
93
+ d.toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' });
94
+ const FMT_TIME = (d: Date) =>
95
+ d.toLocaleTimeString('en-US', { hour: '2-digit', minute: '2-digit' });
96
+ const FMT_DATETIME = (d: Date) => `${FMT_DATE(d)}, ${FMT_TIME(d)}`;
97
+ const FMT_MONTH = (d: Date) =>
98
+ d.toLocaleDateString('en-US', { month: 'long', year: 'numeric' });
99
+
100
+ const DAY_INITIALS = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];
101
+ const MONTH_SHORT = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
102
+ const MONTH_FULL = ['January','February','March','April','May','June',
103
+ 'July','August','September','October','November','December'];
104
+
105
+ // ─── Colours ──────────────────────────────────────────────────────────────────
106
+
107
+ function buildColors(o?: StyledDatePickerColors): Required<StyledDatePickerColors> {
108
+ const sel = o?.selected ?? theme.colors.gray[900];
109
+ return {
110
+ selected: sel,
111
+ selectedText: o?.selectedText ?? '#ffffff',
112
+ today: o?.today ?? '#3b82f6',
113
+ rangeFill: o?.rangeFill ?? `${sel}18`,
114
+ dayText: o?.dayText ?? theme.colors.gray[800],
115
+ disabledText: o?.disabledText ?? theme.colors.gray[300],
116
+ headerText: o?.headerText ?? theme.colors.gray[900],
117
+ background: o?.background ?? palettes.white,
118
+ inputBorder: o?.inputBorder ?? theme.colors.gray[200],
119
+ confirmBg: o?.confirmBg ?? theme.colors.gray[900],
120
+ confirmText: o?.confirmText ?? '#ffffff',
121
+ };
122
+ }
123
+
124
+ const CELL: Record<DatePickerSize, number> = { sm: 34, md: 40, lg: 48 };
125
+ const FONT: Record<DatePickerSize, number> = { sm: 13, md: 15, lg: 17 };
126
+
127
+ // ─── MonthYearHeader ─────────────────────────────────────────────────────────
128
+
129
+ const MonthYearHeader: React.FC<{
130
+ date: Date;
131
+ onPrev: () => void;
132
+ onNext: () => void;
133
+ onTapTitle?: () => void;
134
+ C: Required<StyledDatePickerColors>;
135
+ }> = ({ date, onPrev, onNext, onTapTitle, C }) => (
136
+ <Stack horizontal alignItems="center" justifyContent="space-between"
137
+ paddingHorizontal={4} paddingBottom={12}>
138
+
139
+ <StyledPressable onPress={onPrev}
140
+ width={32} height={32} borderRadius={16}
141
+ backgroundColor={theme.colors.gray[100]}
142
+ alignItems="center" justifyContent="center">
143
+ <Icon name="chevron-left" size={16} color={C.headerText} />
144
+ </StyledPressable>
145
+
146
+ <StyledPressable onPress={onTapTitle} paddingHorizontal={8} paddingVertical={4}>
147
+ <StyledText fontSize={16} fontWeight={theme.fontWeight.bold} color={C.headerText}>
148
+ {MONTH_FULL[date.getMonth()]} {date.getFullYear()}
149
+ </StyledText>
150
+ </StyledPressable>
151
+
152
+ <StyledPressable onPress={onNext}
153
+ width={32} height={32} borderRadius={16}
154
+ backgroundColor={theme.colors.gray[100]}
155
+ alignItems="center" justifyContent="center">
156
+ <Icon name="chevron-right" size={16} color={C.headerText} />
157
+ </StyledPressable>
158
+ </Stack>
159
+ );
160
+
161
+ // ─── CalendarGrid ─────────────────────────────────────────────────────────────
162
+
163
+ const CalendarGrid: React.FC<{
164
+ viewMonth: Date;
165
+ selected: Date | null;
166
+ rangeStart: Date | null;
167
+ rangeEnd: Date | null;
168
+ isRange: boolean;
169
+ minDate?: Date;
170
+ maxDate?: Date;
171
+ size: DatePickerSize;
172
+ C: Required<StyledDatePickerColors>;
173
+ onSelect: (date: Date) => void;
174
+ }> = ({ viewMonth, selected, rangeStart, rangeEnd, isRange, minDate, maxDate, size, C, onSelect }) => {
175
+ const cellSize = CELL[size];
176
+ const fontSize = FONT[size];
177
+ const today = new Date();
178
+ const year = viewMonth.getFullYear();
179
+ const month = viewMonth.getMonth();
180
+ const firstDow = new Date(year, month, 1).getDay();
181
+ const total = daysInMonth(year, month);
182
+ const totalCells = Math.ceil((firstDow + total) / 7) * 7;
183
+
184
+ const cells: (Date | null)[] = Array.from({ length: totalCells }, (_, i) => {
185
+ const d = i - firstDow + 1;
186
+ return d < 1 || d > total ? null : new Date(year, month, d);
187
+ });
188
+
189
+ const isDisabled = (d: Date) => {
190
+ if (minDate && d < new Date(minDate.getFullYear(), minDate.getMonth(), minDate.getDate())) return true;
191
+ if (maxDate && d > new Date(maxDate.getFullYear(), maxDate.getMonth(), maxDate.getDate())) return true;
192
+ return false;
193
+ };
194
+
195
+ const isSel = (d: Date) => isRange
196
+ ? (!!rangeStart && sameDay(d, rangeStart)) || (!!rangeEnd && sameDay(d, rangeEnd))
197
+ : !!selected && sameDay(d, selected);
198
+
199
+ const inRange = (d: Date) =>
200
+ isRange && !!rangeStart && !!rangeEnd && d > rangeStart && d < rangeEnd;
201
+
202
+ const rows: (Date | null)[][] = [];
203
+ for (let i = 0; i < cells.length; i += 7) rows.push(cells.slice(i, i + 7));
204
+
205
+ return (
206
+ <Stack>
207
+ {/* Day-of-week header */}
208
+ <Stack horizontal marginBottom={4}>
209
+ {DAY_INITIALS.map((n, i) => (
210
+ <Stack key={i} flex={1} alignItems="center" paddingVertical={4}>
211
+ <StyledText fontSize={12} fontWeight={theme.fontWeight.semiBold}
212
+ color={theme.colors.gray[400]}>
213
+ {n}
214
+ </StyledText>
215
+ </Stack>
216
+ ))}
217
+ </Stack>
218
+
219
+ {/* Day rows */}
220
+ {rows.map((row, ri) => (
221
+ <Stack key={ri} horizontal marginBottom={2}>
222
+ {row.map((date, ci) => {
223
+ if (!date) return <Stack key={ci} flex={1} height={cellSize} />;
224
+
225
+ const sel = isSel(date);
226
+ const rng = inRange(date);
227
+ const dis = isDisabled(date);
228
+ const tod = sameDay(date, today);
229
+ const isStart = isRange && !!rangeStart && sameDay(date, rangeStart);
230
+ const isEnd = isRange && !!rangeEnd && sameDay(date, rangeEnd);
231
+ const hasRange = !!rangeStart && !!rangeEnd;
232
+
233
+ return (
234
+ <StyledPressable
235
+ key={ci}
236
+ flex={1}
237
+ alignItems="center"
238
+ justifyContent="center"
239
+ onPress={() => !dis && onSelect(date)}
240
+ disabled={dis}
241
+ >
242
+ {/* Range fill layers */}
243
+ {rng && (
244
+ <Stack position="absolute" left={0} right={0} top={4} bottom={4}
245
+ backgroundColor={C.rangeFill} />
246
+ )}
247
+ {isStart && hasRange && (
248
+ <Stack position="absolute" left="50%" right={0} top={4} bottom={4}
249
+ backgroundColor={C.rangeFill} />
250
+ )}
251
+ {isEnd && hasRange && !sameDay(rangeStart!, date) && (
252
+ <Stack position="absolute" left={0} right="50%" top={4} bottom={4}
253
+ backgroundColor={C.rangeFill} />
254
+ )}
255
+
256
+ {/* Day circle */}
257
+ <Stack
258
+ width={cellSize} height={cellSize} borderRadius={cellSize / 2}
259
+ alignItems="center" justifyContent="center"
260
+ backgroundColor={sel ? C.selected : 'transparent'}
261
+ borderWidth={tod && !sel ? 1.5 : 0}
262
+ borderColor={C.today}
263
+ >
264
+ <StyledText
265
+ fontSize={fontSize}
266
+ fontWeight={sel ? theme.fontWeight.bold : theme.fontWeight.normal}
267
+ color={
268
+ dis ? C.disabledText
269
+ : sel ? C.selectedText
270
+ : tod ? C.today
271
+ : C.dayText
272
+ }
273
+ >
274
+ {date.getDate()}
275
+ </StyledText>
276
+ </Stack>
277
+ </StyledPressable>
278
+ );
279
+ })}
280
+ </Stack>
281
+ ))}
282
+ </Stack>
283
+ );
284
+ };
285
+
286
+ // ─── MonthPicker ──────────────────────────────────────────────────────────────
287
+
288
+ // Year range for the drum: 100 years back → 50 years forward
289
+ const THIS_YEAR = new Date().getFullYear();
290
+ const YEAR_START = THIS_YEAR - 100;
291
+ const YEAR_END = THIS_YEAR + 50;
292
+ const YEARS = Array.from(
293
+ { length: YEAR_END - YEAR_START + 1 },
294
+ (_, i) => String(YEAR_START + i),
295
+ );
296
+
297
+ /**
298
+ * MonthPicker — month grid (left) + year scroll drum (right).
299
+ * Lets the user jump to any year instantly without tapping arrows.
300
+ *
301
+ * Layout:
302
+ * ┌──────────────────┬──────────┐
303
+ * │ Jan Feb Mar │ 2023 │
304
+ * │ Apr May Jun │ 2024 │
305
+ * │ Jul Aug Sep ← │ ► 2025 ◄ │ ← selected
306
+ * │ Oct Nov Dec │ 2026 │
307
+ * │ │ 2027 │
308
+ * └──────────────────┴──────────┘
309
+ */
310
+ const MonthPicker: React.FC<{
311
+ viewYear: number;
312
+ selected: Date | null;
313
+ onSelect: (month: number, year: number) => void;
314
+ onYearChange: (year: number) => void;
315
+ C: Required<StyledDatePickerColors>;
316
+ }> = ({ viewYear, selected, onSelect, onYearChange, C }) => {
317
+ const yearScrollRef = useRef<ScrollView>(null);
318
+ const yearIdx = viewYear - YEAR_START;
319
+ const padding = 2; // visible rows above/below selected
320
+
321
+ // Scroll year drum to selected year on mount and when viewYear changes
322
+ useEffect(() => {
323
+ yearScrollRef.current?.scrollTo({
324
+ y: yearIdx * DRUM_ITEM_H,
325
+ animated: false,
326
+ });
327
+ }, [viewYear]);
328
+
329
+ const onYearMomentumEnd = (e: NativeSyntheticEvent<NativeScrollEvent>) => {
330
+ const idx = Math.round(e.nativeEvent.contentOffset.y / DRUM_ITEM_H);
331
+ const clamped = Math.max(0, Math.min(YEARS.length - 1, idx));
332
+ const year = YEAR_START + clamped;
333
+ onYearChange(year);
334
+ yearScrollRef.current?.scrollTo({ y: clamped * DRUM_ITEM_H, animated: true });
335
+ };
336
+
337
+ return (
338
+ <Stack horizontal gap={8}>
339
+ {/* ── Month grid (left) ── */}
340
+ <Stack flex={1}>
341
+ <Stack horizontal flexWrap="wrap">
342
+ {MONTH_SHORT.map((name, i) => {
343
+ const sel = !!selected &&
344
+ selected.getMonth() === i &&
345
+ selected.getFullYear() === viewYear;
346
+ return (
347
+ <StyledPressable
348
+ key={i}
349
+ width="33.33%"
350
+ alignItems="center"
351
+ paddingVertical={10}
352
+ onPress={() => onSelect(i, viewYear)}
353
+ >
354
+ <Stack
355
+ paddingHorizontal={10} paddingVertical={7}
356
+ borderRadius={18}
357
+ backgroundColor={sel ? C.selected : 'transparent'}
358
+ >
359
+ <StyledText
360
+ fontSize={14}
361
+ fontWeight={sel ? theme.fontWeight.semiBold : theme.fontWeight.normal}
362
+ color={sel ? C.selectedText : C.dayText}
363
+ >
364
+ {name}
365
+ </StyledText>
366
+ </Stack>
367
+ </StyledPressable>
368
+ );
369
+ })}
370
+ </Stack>
371
+ </Stack>
372
+
373
+ {/* ── Year drum (right) ── */}
374
+ <Stack width={80} alignItems="center">
375
+ <StyledText fontSize={11} fontWeight={theme.fontWeight.semiBold}
376
+ color={theme.colors.gray[400]} marginBottom={4}>
377
+ Year
378
+ </StyledText>
379
+
380
+ <Stack width={80} height={DRUM_ITEM_H * 5} overflow="hidden">
381
+ {/* Selection highlight */}
382
+ <Stack
383
+ position="absolute"
384
+ top={padding * DRUM_ITEM_H}
385
+ left={4} right={4}
386
+ height={DRUM_ITEM_H}
387
+ borderRadius={10}
388
+ backgroundColor={theme.colors.gray[100]}
389
+ />
390
+
391
+ <ScrollView
392
+ ref={yearScrollRef}
393
+ showsVerticalScrollIndicator={false}
394
+ snapToInterval={DRUM_ITEM_H}
395
+ decelerationRate="fast"
396
+ onMomentumScrollEnd={onYearMomentumEnd}
397
+ contentContainerStyle={{
398
+ paddingTop: padding * DRUM_ITEM_H,
399
+ paddingBottom: padding * DRUM_ITEM_H,
400
+ }}
401
+ >
402
+ {YEARS.map((yr, i) => {
403
+ const isActive = YEAR_START + i === viewYear;
404
+ return (
405
+ <StyledPressable
406
+ key={yr}
407
+ height={DRUM_ITEM_H}
408
+ alignItems="center"
409
+ justifyContent="center"
410
+ onPress={() => {
411
+ onYearChange(YEAR_START + i);
412
+ yearScrollRef.current?.scrollTo({ y: i * DRUM_ITEM_H, animated: true });
413
+ }}
414
+ >
415
+ <StyledText
416
+ fontSize={16}
417
+ fontWeight={isActive ? theme.fontWeight.bold : theme.fontWeight.normal}
418
+ color={isActive ? C.headerText : theme.colors.gray[400]}
419
+ >
420
+ {yr}
421
+ </StyledText>
422
+ </StyledPressable>
423
+ );
424
+ })}
425
+ </ScrollView>
426
+ </Stack>
427
+ </Stack>
428
+ </Stack>
429
+ );
430
+ };
431
+
432
+ // ─── TimePicker (scroll drum) ─────────────────────────────────────────────────
433
+ // ScrollView is kept here — there is no fluent-styles snap-scroll equivalent
434
+
435
+ const DRUM_ITEM_H = 44;
436
+ const DRUM_VISIBLE = 5;
437
+ const DRUM_H = DRUM_ITEM_H * DRUM_VISIBLE;
438
+
439
+ const DrumColumn: React.FC<{
440
+ items: string[];
441
+ selected: number;
442
+ onSelect: (idx: number) => void;
443
+ C: Required<StyledDatePickerColors>;
444
+ }> = ({ items, selected, onSelect, C }) => {
445
+ const scrollRef = useRef<ScrollView>(null);
446
+ const padding = Math.floor(DRUM_VISIBLE / 2);
447
+
448
+ useEffect(() => {
449
+ scrollRef.current?.scrollTo({ y: selected * DRUM_ITEM_H, animated: false });
450
+ }, []);
451
+
452
+ const onMomentumEnd = (e: NativeSyntheticEvent<NativeScrollEvent>) => {
453
+ const idx = Math.round(e.nativeEvent.contentOffset.y / DRUM_ITEM_H);
454
+ const clamped = Math.max(0, Math.min(items.length - 1, idx));
455
+ onSelect(clamped);
456
+ scrollRef.current?.scrollTo({ y: clamped * DRUM_ITEM_H, animated: true });
457
+ };
458
+
459
+ return (
460
+ <Stack width={72} height={DRUM_H} overflow="hidden">
461
+ {/* Selection highlight */}
462
+ <Stack
463
+ position="absolute"
464
+ top={padding * DRUM_ITEM_H}
465
+ left={4} right={4}
466
+ height={DRUM_ITEM_H}
467
+ borderRadius={10}
468
+ backgroundColor={theme.colors.gray[100]}
469
+ />
470
+
471
+ <ScrollView
472
+ ref={scrollRef}
473
+ showsVerticalScrollIndicator={false}
474
+ snapToInterval={DRUM_ITEM_H}
475
+ decelerationRate="fast"
476
+ onMomentumScrollEnd={onMomentumEnd}
477
+ contentContainerStyle={{
478
+ paddingTop: padding * DRUM_ITEM_H,
479
+ paddingBottom: padding * DRUM_ITEM_H,
480
+ }}
481
+ >
482
+ {items.map((item, i) => (
483
+ <StyledPressable
484
+ key={i}
485
+ height={DRUM_ITEM_H}
486
+ alignItems="center"
487
+ justifyContent="center"
488
+ onPress={() => {
489
+ onSelect(i);
490
+ scrollRef.current?.scrollTo({ y: i * DRUM_ITEM_H, animated: true });
491
+ }}
492
+ >
493
+ <StyledText
494
+ fontSize={20}
495
+ fontWeight={i === selected ? theme.fontWeight.bold : theme.fontWeight.normal}
496
+ color={i === selected ? C.headerText : theme.colors.gray[400]}
497
+ >
498
+ {item}
499
+ </StyledText>
500
+ </StyledPressable>
501
+ ))}
502
+ </ScrollView>
503
+ </Stack>
504
+ );
505
+ };
506
+
507
+ const HOURS = Array.from({ length: 12 }, (_, i) => String(i + 1).padStart(2, '0'));
508
+ const MINUTES = Array.from({ length: 60 }, (_, i) => String(i).padStart(2, '0'));
509
+ const AMPM = ['AM', 'PM'];
510
+
511
+ const TimePicker: React.FC<{
512
+ value: Date | null;
513
+ onChange: (h: number, m: number, ampm: 'AM' | 'PM') => void;
514
+ C: Required<StyledDatePickerColors>;
515
+ }> = ({ value, onChange, C }) => {
516
+ const now = value ?? new Date();
517
+ const h24 = now.getHours();
518
+ const h12 = h24 % 12 === 0 ? 12 : h24 % 12;
519
+
520
+ const [selHour, setSelHour] = useState(h12 - 1);
521
+ const [selMin, setSelMin] = useState(now.getMinutes());
522
+ const [selAmpm, setSelAmpm] = useState(h24 >= 12 ? 1 : 0);
523
+
524
+ const emit = (h: number, m: number, ap: number) =>
525
+ onChange(h + 1, m, ap === 0 ? 'AM' : 'PM');
526
+
527
+ return (
528
+ <Stack alignItems="center">
529
+ <Stack horizontal alignItems="center" gap={4}>
530
+ <DrumColumn items={HOURS} selected={selHour} C={C}
531
+ onSelect={(i) => { setSelHour(i); emit(i, selMin, selAmpm); }} />
532
+
533
+ <StyledText fontSize={24} fontWeight={theme.fontWeight.bold} color={C.headerText}>
534
+ :
535
+ </StyledText>
536
+
537
+ <DrumColumn items={MINUTES} selected={selMin} C={C}
538
+ onSelect={(i) => { setSelMin(i); emit(selHour, i, selAmpm); }} />
539
+
540
+ <DrumColumn items={AMPM} selected={selAmpm} C={C}
541
+ onSelect={(i) => { setSelAmpm(i); emit(selHour, selMin, i); }} />
542
+ </Stack>
543
+ </Stack>
544
+ );
545
+ };
546
+
547
+ // ─── PickerBody ───────────────────────────────────────────────────────────────
548
+
549
+ const PickerBody: React.FC<{
550
+ mode: DatePickerMode;
551
+ size: DatePickerSize;
552
+ value: Date | null;
553
+ rangeStart: Date | null;
554
+ rangeEnd: Date | null;
555
+ minDate?: Date;
556
+ maxDate?: Date;
557
+ showTodayBtn: boolean;
558
+ showConfirm: boolean;
559
+ confirmLabel: string;
560
+ C: Required<StyledDatePickerColors>;
561
+ onChange: (date: Date) => void;
562
+ onRangeChange: (s: Date | null, e: Date | null) => void;
563
+ onConfirm?: () => void;
564
+ }> = ({
565
+ mode, size, value, rangeStart, rangeEnd,
566
+ minDate, maxDate, showTodayBtn, showConfirm, confirmLabel,
567
+ C, onChange, onRangeChange, onConfirm,
568
+ }) => {
569
+ const [viewMonth, setViewMonth] = useState(value ?? rangeStart ?? new Date());
570
+ const [showMonthPicker, setShowMonthPicker] = useState(false);
571
+ const [viewYear, setViewYear] = useState(viewMonth.getFullYear());
572
+ const isRange = mode === 'range';
573
+ const showCalendar = mode === 'date' || mode === 'range' || mode === 'datetime';
574
+
575
+ const handleDaySelect = useCallback((date: Date) => {
576
+ if (!isRange) { onChange(date); return; }
577
+ if (!rangeStart || (rangeStart && rangeEnd)) {
578
+ onRangeChange(date, null);
579
+ } else if (date < rangeStart) {
580
+ onRangeChange(date, rangeStart);
581
+ } else {
582
+ onRangeChange(rangeStart, date);
583
+ }
584
+ }, [isRange, rangeStart, rangeEnd, onChange, onRangeChange]);
585
+
586
+ const handleTimeChange = useCallback((h: number, m: number, ap: 'AM' | 'PM') => {
587
+ const base = value ?? new Date();
588
+ const h24 = ap === 'AM' ? (h === 12 ? 0 : h) : (h === 12 ? 12 : h + 12);
589
+ onChange(new Date(base.getFullYear(), base.getMonth(), base.getDate(), h24, m));
590
+ }, [value, onChange]);
591
+
592
+ return (
593
+ <Stack backgroundColor={C.background} borderRadius={16} padding={16}>
594
+
595
+ {/* Header — calendar modes */}
596
+ {showCalendar && !showMonthPicker && (
597
+ <MonthYearHeader
598
+ date={viewMonth}
599
+ onPrev={() => setViewMonth(addMonths(viewMonth, -1))}
600
+ onNext={() => setViewMonth(addMonths(viewMonth, 1))}
601
+ onTapTitle={() => {
602
+ setViewYear(viewMonth.getFullYear());
603
+ setShowMonthPicker(true);
604
+ }}
605
+ C={C}
606
+ />
607
+ )}
608
+
609
+ {showMonthPicker ? (
610
+ <MonthPicker
611
+ viewYear={viewYear}
612
+ selected={value}
613
+ onSelect={(m, y) => {
614
+ // Preserve current selected day; clamp if new month has fewer days
615
+ const currentDay = value ? value.getDate() : 1;
616
+ const maxDay = new Date(y, m + 1, 0).getDate(); // last day of target month
617
+ const safeDay = Math.min(currentDay, maxDay);
618
+ const newDate = value
619
+ ? new Date(y, m, safeDay, value.getHours(), value.getMinutes())
620
+ : new Date(y, m, safeDay);
621
+ onChange(newDate);
622
+ setViewMonth(new Date(y, m, 1));
623
+ setShowMonthPicker(false);
624
+ }}
625
+ onYearChange={setViewYear}
626
+ C={C}
627
+ />
628
+ ) : (
629
+ <Stack>
630
+ {/* Calendar grid */}
631
+ {showCalendar && (
632
+ <CalendarGrid
633
+ viewMonth={viewMonth}
634
+ selected={isRange ? null : value}
635
+ rangeStart={rangeStart}
636
+ rangeEnd={rangeEnd}
637
+ isRange={isRange}
638
+ minDate={minDate}
639
+ maxDate={maxDate}
640
+ size={size}
641
+ C={C}
642
+ onSelect={handleDaySelect}
643
+ />
644
+ )}
645
+
646
+ {/* Month mode */}
647
+ {mode === 'month' && (
648
+ <MonthPicker
649
+ viewYear={viewYear}
650
+ selected={value}
651
+ onSelect={(m, y) => {
652
+ const currentDay = value ? value.getDate() : 1;
653
+ const maxDay = new Date(y, m + 1, 0).getDate();
654
+ const safeDay = Math.min(currentDay, maxDay);
655
+ onChange(new Date(y, m, safeDay));
656
+ setViewMonth(new Date(y, m, 1));
657
+ setViewYear(y);
658
+ }}
659
+ onYearChange={setViewYear}
660
+ C={C}
661
+ />
662
+ )}
663
+
664
+ {/* Time drum */}
665
+ {(mode === 'time' || mode === 'datetime') && (
666
+ <Stack>
667
+ {mode === 'datetime' && (
668
+ <StyledDivider borderBottomColor={theme.colors.gray[100]} marginVertical={16} />
669
+ )}
670
+ <TimePicker value={value} onChange={handleTimeChange} C={C} />
671
+ </Stack>
672
+ )}
673
+ </Stack>
674
+ )}
675
+
676
+ {/* Today shortcut */}
677
+ {showTodayBtn && showCalendar && (
678
+ <StyledPressable
679
+ alignItems="center"
680
+ paddingVertical={10}
681
+ onPress={() => {
682
+ const t = new Date();
683
+ setViewMonth(t);
684
+ if (!isRange) onChange(t);
685
+ }}
686
+ >
687
+ <StyledText
688
+ fontSize={14}
689
+ fontWeight={theme.fontWeight.semiBold}
690
+ color={C.today}
691
+ style={{ textDecorationLine: 'underline' }}
692
+ >
693
+ Today
694
+ </StyledText>
695
+ </StyledPressable>
696
+ )}
697
+
698
+ {/* Confirm button */}
699
+ {showConfirm && onConfirm && (
700
+ <Stack>
701
+ <StyledSpacer height={8} />
702
+ <StyledPressable
703
+ onPress={onConfirm}
704
+ backgroundColor={C.confirmBg}
705
+ borderRadius={12}
706
+ paddingVertical={14}
707
+ alignItems="center"
708
+ >
709
+ <StyledText fontSize={15} fontWeight={theme.fontWeight.bold} color={C.confirmText}>
710
+ {confirmLabel}
711
+ </StyledText>
712
+ </StyledPressable>
713
+ </Stack>
714
+ )}
715
+ </Stack>
716
+ );
717
+ };
718
+
719
+ // ─── Sheet (bottom modal) ─────────────────────────────────────────────────────
720
+ // Modal is kept — no fluent-styles equivalent for a full-screen overlay
721
+
722
+ const Sheet: React.FC<{
723
+ visible: boolean;
724
+ onClose: () => void;
725
+ children: React.ReactNode;
726
+ }> = ({ visible, onClose, children }) => {
727
+ const slideAnim = useRef(new Animated.Value(0)).current;
728
+ const { height: SH } = Dimensions.get('window');
729
+
730
+ useEffect(() => {
731
+ Animated.timing(slideAnim, {
732
+ toValue: visible ? 1 : 0,
733
+ duration: 280,
734
+ useNativeDriver: true,
735
+ }).start();
736
+ }, [visible]);
737
+
738
+ if (!visible) return null;
739
+
740
+ return (
741
+ <Modal transparent animationType="none" visible={visible} onRequestClose={onClose}>
742
+ {/* Backdrop */}
743
+ <StyledPressable flex={1} backgroundColor="rgba(0,0,0,0.4)" onPress={onClose} />
744
+
745
+ {/* Slide-up panel */}
746
+ <Animated.View
747
+ style={{
748
+ position: 'absolute',
749
+ bottom: 0, left: 0, right: 0,
750
+ backgroundColor: palettes.white,
751
+ borderTopLeftRadius: 20,
752
+ borderTopRightRadius: 20,
753
+ paddingBottom: Platform.OS === 'ios' ? 34 : 16,
754
+ transform: [{
755
+ translateY: slideAnim.interpolate({
756
+ inputRange: [0, 1],
757
+ outputRange: [SH * 0.6, 0],
758
+ }),
759
+ }],
760
+ }}
761
+ >
762
+ {/* Drag handle */}
763
+ <Stack
764
+ width={40} height={4} borderRadius={2}
765
+ backgroundColor={theme.colors.gray[200]}
766
+ alignSelf="center"
767
+ marginTop={12} marginBottom={4}
768
+ />
769
+ {children}
770
+ </Animated.View>
771
+ </Modal>
772
+ );
773
+ };
774
+
775
+ // ─── InputTrigger ─────────────────────────────────────────────────────────────
776
+
777
+ const InputTrigger: React.FC<{
778
+ label?: string;
779
+ displayText: string;
780
+ placeholder: string;
781
+ isOpen: boolean;
782
+ disabled: boolean;
783
+ onPress: () => void;
784
+ C: Required<StyledDatePickerColors>;
785
+ }> = ({ label, displayText, placeholder, isOpen, disabled, onPress, C }) => (
786
+ <Stack opacity={disabled ? 0.5 : 1}>
787
+ {!!label && (
788
+ <StyledText fontSize={13} fontWeight={theme.fontWeight.semiBold}
789
+ color={theme.colors.gray[600]} marginBottom={6}>
790
+ {label}
791
+ </StyledText>
792
+ )}
793
+ <StyledPressable
794
+ flexDirection='row'
795
+ alignItems="center"
796
+ justifyContent="space-between"
797
+ borderWidth={1.5}
798
+ borderColor={isOpen ? C.selected : C.inputBorder}
799
+ borderRadius={12}
800
+ paddingHorizontal={14}
801
+ paddingVertical={12}
802
+ backgroundColor={palettes.white}
803
+ onPress={onPress}
804
+ disabled={disabled}
805
+ >
806
+ <StyledText flex={1} fontSize={15}
807
+ color={displayText ? C.dayText : theme.colors.gray[400]}>
808
+ {displayText || placeholder}
809
+ </StyledText>
810
+ <Icon name="calendar" size={18}
811
+ color={isOpen ? C.selected : theme.colors.gray[400]} />
812
+ </StyledPressable>
813
+ </Stack>
814
+ );
815
+
816
+ // ─── StyledDatePicker ─────────────────────────────────────────────────────────
817
+
818
+ /**
819
+ * StyledDatePicker — pure-JS date/time picker built on fluent-styles.
820
+ *
821
+ * @example Inline date
822
+ * ```tsx
823
+ * <StyledDatePicker value={date} onChange={setDate} />
824
+ * ```
825
+ *
826
+ * @example Input → bottom sheet
827
+ * ```tsx
828
+ * <StyledDatePicker
829
+ * variant="input"
830
+ * label="Check-in date"
831
+ * placeholder="Select date"
832
+ * value={date}
833
+ * onChange={setDate}
834
+ * onConfirm={setDate}
835
+ * />
836
+ * ```
837
+ *
838
+ * @example Date range
839
+ * ```tsx
840
+ * <StyledDatePicker
841
+ * mode="range"
842
+ * valueStart={start}
843
+ * valueEnd={end}
844
+ * onRangeChange={(s, e) => { setStart(s); setEnd(e); }}
845
+ * colors={{ selected: '#6366f1', rangeFill: '#eef2ff' }}
846
+ * />
847
+ * ```
848
+ *
849
+ * @example Time picker
850
+ * ```tsx
851
+ * <StyledDatePicker mode="time" value={time} onChange={setTime} />
852
+ * ```
853
+ *
854
+ * @example Month picker
855
+ * ```tsx
856
+ * <StyledDatePicker mode="month" value={month} onChange={setMonth} />
857
+ * ```
858
+ */
859
+ export const StyledDatePicker: React.FC<StyledDatePickerProps> = ({
860
+ mode = 'date',
861
+ variant = 'inline',
862
+ size = 'md',
863
+ value = null,
864
+ valueStart = null,
865
+ valueEnd = null,
866
+ minDate,
867
+ maxDate,
868
+ showTodayButton = true,
869
+ showConfirm = true,
870
+ confirmLabel = 'Done',
871
+ placeholder = 'Select date',
872
+ label,
873
+ formatDisplay,
874
+ colors: colorsProp,
875
+ onChange,
876
+ onRangeChange,
877
+ onConfirm,
878
+ disabled = false,
879
+ }) => {
880
+ const C = buildColors(colorsProp);
881
+
882
+ const [isOpen, setIsOpen] = useState(false);
883
+ const [localValue, setLocalValue] = useState<Date | null>(value);
884
+ const [localStart, setLocalStart] = useState<Date | null>(valueStart);
885
+ const [localEnd, setLocalEnd] = useState<Date | null>(valueEnd);
886
+
887
+ useEffect(() => { setLocalValue(value); }, [value]);
888
+ useEffect(() => { setLocalStart(valueStart); }, [valueStart]);
889
+ useEffect(() => { setLocalEnd(valueEnd); }, [valueEnd]);
890
+
891
+ const handleChange = useCallback((date: Date) => {
892
+ setLocalValue(date);
893
+ onChange?.(date);
894
+ }, [onChange]);
895
+
896
+ const handleRangeChange = useCallback((s: Date | null, e: Date | null) => {
897
+ setLocalStart(s);
898
+ setLocalEnd(e);
899
+ onRangeChange?.(s, e);
900
+ }, [onRangeChange]);
901
+
902
+ const handleConfirm = useCallback(() => {
903
+ setIsOpen(false);
904
+ onConfirm?.(localValue);
905
+ }, [localValue, onConfirm]);
906
+
907
+ const getFormat = () => {
908
+ if (formatDisplay) return formatDisplay;
909
+ if (mode === 'time') return FMT_TIME;
910
+ if (mode === 'datetime') return FMT_DATETIME;
911
+ if (mode === 'month') return FMT_MONTH;
912
+ return FMT_DATE;
913
+ };
914
+
915
+ const displayText = mode === 'range'
916
+ ? [localStart, localEnd].filter(Boolean).map(d => FMT_DATE(d!)).join(' – ')
917
+ : localValue ? getFormat()(localValue) : '';
918
+
919
+ const bodyProps = {
920
+ mode, size,
921
+ value: localValue,
922
+ rangeStart: localStart,
923
+ rangeEnd: localEnd,
924
+ minDate,
925
+ maxDate,
926
+ showTodayBtn: showTodayButton,
927
+ confirmLabel,
928
+ C,
929
+ onChange: handleChange,
930
+ onRangeChange: handleRangeChange,
931
+ };
932
+
933
+ if (variant === 'inline') {
934
+ return (
935
+ <Stack opacity={disabled ? 0.5 : 1}>
936
+ <PickerBody {...bodyProps} showConfirm={false} />
937
+ </Stack>
938
+ );
939
+ }
940
+
941
+ return (
942
+ <Stack opacity={disabled ? 0.5 : 1}>
943
+ <InputTrigger
944
+ label={label}
945
+ displayText={displayText}
946
+ placeholder={placeholder}
947
+ isOpen={isOpen}
948
+ disabled={disabled}
949
+ onPress={() => setIsOpen(true)}
950
+ C={C}
951
+ />
952
+ <Sheet visible={isOpen} onClose={() => setIsOpen(false)}>
953
+ <Stack paddingHorizontal={16} paddingBottom={8}>
954
+ <PickerBody {...bodyProps} showConfirm={showConfirm} onConfirm={handleConfirm} />
955
+ </Stack>
956
+ </Sheet>
957
+ </Stack>
958
+ );
959
+ };
960
+
961
+ export default StyledDatePicker;