@m5kdev/web-ui 0.6.0 → 0.8.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 (377) hide show
  1. package/dist/src/animations/card.motion.d.ts +7 -2
  2. package/dist/src/animations/card.motion.js +25 -6
  3. package/dist/src/animations/card.motion.js.map +1 -0
  4. package/dist/src/components/AvatarUpload.d.ts +14 -5
  5. package/dist/src/components/AvatarUpload.js +105 -63
  6. package/dist/src/components/AvatarUpload.js.map +1 -0
  7. package/dist/src/components/Button.d.ts +14 -4
  8. package/dist/src/components/Button.js +13 -4
  9. package/dist/src/components/Button.js.map +1 -0
  10. package/dist/src/components/Calendar.d.ts +33 -31
  11. package/dist/src/components/Calendar.js +14 -6
  12. package/dist/src/components/Calendar.js.map +1 -0
  13. package/dist/src/components/{Calendar.css → Calendar2.css} +757 -684
  14. package/dist/src/components/CardsSelect.d.ts +25 -21
  15. package/dist/src/components/CardsSelect.js +75 -42
  16. package/dist/src/components/CardsSelect.js.map +1 -0
  17. package/dist/src/components/CollapsibleSidebarMenuItem.d.ts +22 -9
  18. package/dist/src/components/CollapsibleSidebarMenuItem.js +31 -8
  19. package/dist/src/components/CollapsibleSidebarMenuItem.js.map +1 -0
  20. package/dist/src/components/ColorPicker.d.ts +15 -4
  21. package/dist/src/components/ColorPicker.js +46 -16
  22. package/dist/src/components/ColorPicker.js.map +1 -0
  23. package/dist/src/components/CopyButton.d.ts +18 -6
  24. package/dist/src/components/CopyButton.js +28 -19
  25. package/dist/src/components/CopyButton.js.map +1 -0
  26. package/dist/src/components/CropDialog.d.ts +20 -8
  27. package/dist/src/components/CropDialog.js +108 -62
  28. package/dist/src/components/CropDialog.js.map +1 -0
  29. package/dist/src/components/DialogProvider.d.ts +22 -14
  30. package/dist/src/components/DialogProvider.js +67 -45
  31. package/dist/src/components/DialogProvider.js.map +1 -0
  32. package/dist/src/components/ErrorFallback.d.ts +13 -4
  33. package/dist/src/components/ErrorFallback.js +29 -4
  34. package/dist/src/components/ErrorFallback.js.map +1 -0
  35. package/dist/src/components/FileDropzone.d.ts +12 -4
  36. package/dist/src/components/FileDropzone.js +98 -60
  37. package/dist/src/components/FileDropzone.js.map +1 -0
  38. package/dist/src/components/MultiSelectDropdown.d.ts +25 -22
  39. package/dist/src/components/MultiSelectDropdown.js +99 -49
  40. package/dist/src/components/MultiSelectDropdown.js.map +1 -0
  41. package/dist/src/components/Orb.d.ts +17 -6
  42. package/dist/src/components/Orb.js +263 -255
  43. package/dist/src/components/Orb.js.map +1 -0
  44. package/dist/src/components/PageAlert.d.ts +20 -15
  45. package/dist/src/components/PageAlert.js +67 -39
  46. package/dist/src/components/PageAlert.js.map +1 -0
  47. package/dist/src/components/SelectChips.d.ts +21 -10
  48. package/dist/src/components/SelectChips.js +21 -9
  49. package/dist/src/components/SelectChips.js.map +1 -0
  50. package/dist/src/components/SidebarItem.d.ts +18 -7
  51. package/dist/src/components/SidebarItem.js +16 -4
  52. package/dist/src/components/SidebarItem.js.map +1 -0
  53. package/dist/src/components/Steps.d.ts +21 -16
  54. package/dist/src/components/Steps.js +193 -27
  55. package/dist/src/components/Steps.js.map +1 -0
  56. package/dist/src/components/TablerIconPicker.d.ts +13 -2
  57. package/dist/src/components/TablerIconPicker.js +4254 -4234
  58. package/dist/src/components/TablerIconPicker.js.map +1 -0
  59. package/dist/src/components/app-header.d.ts +14 -6
  60. package/dist/src/components/app-header.js +27 -6
  61. package/dist/src/components/app-header.js.map +1 -0
  62. package/dist/src/components/blur-card.d.ts +25 -11
  63. package/dist/src/components/blur-card.js +134 -31
  64. package/dist/src/components/blur-card.js.map +1 -0
  65. package/dist/src/components/features-section-demo-1.d.ts +22 -6
  66. package/dist/src/components/features-section-demo-1.js +119 -47
  67. package/dist/src/components/features-section-demo-1.js.map +1 -0
  68. package/dist/src/components/features-section-demo-2.d.ts +7 -1
  69. package/dist/src/components/features-section-demo-2.js +80 -49
  70. package/dist/src/components/features-section-demo-2.js.map +1 -0
  71. package/dist/src/components/features-section-demo-3.d.ts +16 -8
  72. package/dist/src/components/features-section-demo-3.js +239 -103
  73. package/dist/src/components/features-section-demo-3.js.map +1 -0
  74. package/dist/src/components/mode-toggle.d.ts +7 -1
  75. package/dist/src/components/mode-toggle.js +42 -7
  76. package/dist/src/components/mode-toggle.js.map +1 -0
  77. package/dist/src/components/nav-main.d.ts +20 -12
  78. package/dist/src/components/nav-main.js +31 -5
  79. package/dist/src/components/nav-main.js.map +1 -0
  80. package/dist/src/components/pricing-cards.d.ts +7 -1
  81. package/dist/src/components/pricing-cards.js +125 -24
  82. package/dist/src/components/pricing-cards.js.map +1 -0
  83. package/dist/src/components/shared/ButtonCopy.d.ts +17 -6
  84. package/dist/src/components/shared/ButtonCopy.js +31 -20
  85. package/dist/src/components/shared/ButtonCopy.js.map +1 -0
  86. package/dist/src/components/team-switcher.d.ts +16 -8
  87. package/dist/src/components/team-switcher.js +70 -8
  88. package/dist/src/components/team-switcher.js.map +1 -0
  89. package/dist/src/components/theme-provider.d.ts +18 -8
  90. package/dist/src/components/theme-provider.js +42 -38
  91. package/dist/src/components/theme-provider.js.map +1 -0
  92. package/dist/src/components/typewriter.d.ts +35 -14
  93. package/dist/src/components/typewriter.js +45 -36
  94. package/dist/src/components/typewriter.js.map +1 -0
  95. package/dist/src/components/ui/alert-dialog.d.ts +48 -13
  96. package/dist/src/components/ui/alert-dialog.js +58 -15
  97. package/dist/src/components/ui/alert-dialog.js.map +1 -0
  98. package/dist/src/components/ui/alert.d.ts +24 -8
  99. package/dist/src/components/ui/alert.js +28 -15
  100. package/dist/src/components/ui/alert.js.map +1 -0
  101. package/dist/src/components/ui/avatar.d.ts +9 -5
  102. package/dist/src/components/ui/avatar.js +23 -7
  103. package/dist/src/components/ui/avatar.js.map +1 -0
  104. package/dist/src/components/ui/badge.d.ts +17 -8
  105. package/dist/src/components/ui/badge.js +17 -14
  106. package/dist/src/components/ui/badge.js.map +1 -0
  107. package/dist/src/components/ui/bento-grid.d.ts +26 -11
  108. package/dist/src/components/ui/bento-grid.js +30 -6
  109. package/dist/src/components/ui/bento-grid.js.map +1 -0
  110. package/dist/src/components/ui/bento-grid2.d.ts +30 -14
  111. package/dist/src/components/ui/bento-grid2.js +45 -9
  112. package/dist/src/components/ui/bento-grid2.js.map +1 -0
  113. package/dist/src/components/ui/breadcrumb.d.ts +27 -15
  114. package/dist/src/components/ui/breadcrumb.js +54 -14
  115. package/dist/src/components/ui/breadcrumb.js.map +1 -0
  116. package/dist/src/components/ui/button.d.ts +14 -9
  117. package/dist/src/components/ui/button.js +37 -26
  118. package/dist/src/components/ui/button.js.map +1 -0
  119. package/dist/src/components/ui/card.d.ts +12 -8
  120. package/dist/src/components/ui/card.js +38 -10
  121. package/dist/src/components/ui/card.js.map +1 -0
  122. package/dist/src/components/ui/checkbox.d.ts +6 -2
  123. package/dist/src/components/ui/checkbox.js +17 -5
  124. package/dist/src/components/ui/checkbox.js.map +1 -0
  125. package/dist/src/components/ui/collapsible.d.ts +9 -4
  126. package/dist/src/components/ui/collapsible.js +5 -1
  127. package/dist/src/components/ui/collapsible.js.map +1 -0
  128. package/dist/src/components/ui/dialog.d.ts +44 -12
  129. package/dist/src/components/ui/dialog.js +64 -14
  130. package/dist/src/components/ui/dialog.js.map +1 -0
  131. package/dist/src/components/ui/dropdown-menu.d.ts +32 -24
  132. package/dist/src/components/ui/dropdown-menu.js +64 -14
  133. package/dist/src/components/ui/dropdown-menu.js.map +1 -0
  134. package/dist/src/components/ui/floating-navbar.d.ts +18 -9
  135. package/dist/src/components/ui/floating-navbar.js +49 -35
  136. package/dist/src/components/ui/floating-navbar.js.map +1 -0
  137. package/dist/src/components/ui/form.d.ts +30 -21
  138. package/dist/src/components/ui/form.js +76 -44
  139. package/dist/src/components/ui/form.js.map +1 -0
  140. package/dist/src/components/ui/image.d.ts +6 -2
  141. package/dist/src/components/ui/image.js +51 -11
  142. package/dist/src/components/ui/image.js.map +1 -0
  143. package/dist/src/components/ui/input.d.ts +6 -2
  144. package/dist/src/components/ui/input.js +14 -5
  145. package/dist/src/components/ui/input.js.map +1 -0
  146. package/dist/src/components/ui/label.d.ts +8 -3
  147. package/dist/src/components/ui/label.js +13 -5
  148. package/dist/src/components/ui/label.js.map +1 -0
  149. package/dist/src/components/ui/pagination.d.ts +39 -12
  150. package/dist/src/components/ui/pagination.js +64 -14
  151. package/dist/src/components/ui/pagination.js.map +1 -0
  152. package/dist/src/components/ui/progress.d.ts +6 -2
  153. package/dist/src/components/ui/progress.js +16 -4
  154. package/dist/src/components/ui/progress.js.map +1 -0
  155. package/dist/src/components/ui/resizable-navbar.d.ts +84 -43
  156. package/dist/src/components/ui/resizable-navbar.js +126 -74
  157. package/dist/src/components/ui/resizable-navbar.js.map +1 -0
  158. package/dist/src/components/ui/segment-control.d.ts +10 -7
  159. package/dist/src/components/ui/segment-control.js +83 -38
  160. package/dist/src/components/ui/segment-control.js.map +1 -0
  161. package/dist/src/components/ui/select.d.ts +16 -12
  162. package/dist/src/components/ui/select.js +63 -14
  163. package/dist/src/components/ui/select.js.map +1 -0
  164. package/dist/src/components/ui/separator.d.ts +6 -2
  165. package/dist/src/components/ui/separator.js +14 -4
  166. package/dist/src/components/ui/separator.js.map +1 -0
  167. package/dist/src/components/ui/sheet.d.ts +30 -19
  168. package/dist/src/components/ui/sheet.js +52 -23
  169. package/dist/src/components/ui/sheet.js.map +1 -0
  170. package/dist/src/components/ui/sidebar.d.ts +69 -62
  171. package/dist/src/components/ui/sidebar.js +326 -171
  172. package/dist/src/components/ui/sidebar.js.map +1 -0
  173. package/dist/src/components/ui/skeleton.d.ts +9 -1
  174. package/dist/src/components/ui/skeleton.js +10 -3
  175. package/dist/src/components/ui/skeleton.js.map +1 -0
  176. package/dist/src/components/ui/slider.d.ts +6 -2
  177. package/dist/src/components/ui/slider.js +16 -4
  178. package/dist/src/components/ui/slider.js.map +1 -0
  179. package/dist/src/components/ui/sonner.d.ts +10 -3
  180. package/dist/src/components/ui/sonner.js +18 -11
  181. package/dist/src/components/ui/sonner.js.map +1 -0
  182. package/dist/src/components/ui/spinner.d.ts +21 -10
  183. package/dist/src/components/ui/spinner.js +24 -24
  184. package/dist/src/components/ui/spinner.js.map +1 -0
  185. package/dist/src/components/ui/switch.d.ts +6 -2
  186. package/dist/src/components/ui/switch.js +13 -4
  187. package/dist/src/components/ui/switch.js.map +1 -0
  188. package/dist/src/components/ui/table.d.ts +39 -10
  189. package/dist/src/components/ui/table.js +51 -11
  190. package/dist/src/components/ui/table.js.map +1 -0
  191. package/dist/src/components/ui/tabs.d.ts +23 -6
  192. package/dist/src/components/ui/tabs.js +27 -7
  193. package/dist/src/components/ui/tabs.js.map +1 -0
  194. package/dist/src/components/ui/textarea.d.ts +10 -2
  195. package/dist/src/components/ui/textarea.js +11 -3
  196. package/dist/src/components/ui/textarea.js.map +1 -0
  197. package/dist/src/components/ui/timeline.d.ts +16 -9
  198. package/dist/src/components/ui/timeline.js +87 -24
  199. package/dist/src/components/ui/timeline.js.map +1 -0
  200. package/dist/src/components/ui/toast.d.ts +19 -14
  201. package/dist/src/components/ui/toast.js +48 -22
  202. package/dist/src/components/ui/toast.js.map +1 -0
  203. package/dist/src/components/ui/tooltip.d.ts +23 -6
  204. package/dist/src/components/ui/tooltip.js +27 -7
  205. package/dist/src/components/ui/tooltip.js.map +1 -0
  206. package/dist/src/components/ui/typewriter-effect.d.ts +28 -14
  207. package/dist/src/components/ui/typewriter-effect.js +102 -72
  208. package/dist/src/components/ui/typewriter-effect.js.map +1 -0
  209. package/dist/src/hooks/use-mobile.d.ts +5 -1
  210. package/dist/src/hooks/use-mobile.js +18 -13
  211. package/dist/src/hooks/use-mobile.js.map +1 -0
  212. package/dist/src/hooks/useDialog.d.ts +8 -4
  213. package/dist/src/hooks/useDialog.js +24 -20
  214. package/dist/src/hooks/useDialog.js.map +1 -0
  215. package/dist/src/icons/GoogleIcon.d.ts +9 -5
  216. package/dist/src/icons/GoogleIcon.js +32 -3
  217. package/dist/src/icons/GoogleIcon.js.map +1 -0
  218. package/dist/src/icons/LinkedInIcon.d.ts +9 -5
  219. package/dist/src/icons/LinkedInIcon.js +27 -3
  220. package/dist/src/icons/LinkedInIcon.js.map +1 -0
  221. package/dist/src/icons/MicrosoftIcon.d.ts +9 -5
  222. package/dist/src/icons/MicrosoftIcon.js +31 -3
  223. package/dist/src/icons/MicrosoftIcon.js.map +1 -0
  224. package/dist/src/lib/chatwoot.d.ts +19 -10
  225. package/dist/src/lib/chatwoot.js +25 -27
  226. package/dist/src/lib/chatwoot.js.map +1 -0
  227. package/dist/src/lib/utils.d.ts +7 -2
  228. package/dist/src/lib/utils.js +7 -2
  229. package/dist/src/lib/utils.js.map +1 -0
  230. package/dist/src/modules/app/components/AppLoader.d.ts +8 -2
  231. package/dist/src/modules/app/components/AppLoader.js +14 -3
  232. package/dist/src/modules/app/components/AppLoader.js.map +1 -0
  233. package/dist/src/modules/app/components/AppShell.d.ts +15 -6
  234. package/dist/src/modules/app/components/AppShell.js +14 -5
  235. package/dist/src/modules/app/components/AppShell.js.map +1 -0
  236. package/dist/src/modules/app/components/AppSidebar.d.ts +16 -6
  237. package/dist/src/modules/app/components/AppSidebar.js +17 -4
  238. package/dist/src/modules/app/components/AppSidebar.js.map +1 -0
  239. package/dist/src/modules/app/components/AppSidebarContent.d.ts +22 -13
  240. package/dist/src/modules/app/components/AppSidebarContent.js +34 -5
  241. package/dist/src/modules/app/components/AppSidebarContent.js.map +1 -0
  242. package/dist/src/modules/app/components/AppSidebarHeader.d.ts +18 -8
  243. package/dist/src/modules/app/components/AppSidebarHeader.js +37 -6
  244. package/dist/src/modules/app/components/AppSidebarHeader.js.map +1 -0
  245. package/dist/src/modules/app/components/AppSidebarInvites.d.ts +11 -3
  246. package/dist/src/modules/app/components/AppSidebarInvites.js +39 -8
  247. package/dist/src/modules/app/components/AppSidebarInvites.js.map +1 -0
  248. package/dist/src/modules/app/components/AppSidebarUser.d.ts +20 -10
  249. package/dist/src/modules/app/components/AppSidebarUser.js +121 -12
  250. package/dist/src/modules/app/components/AppSidebarUser.js.map +1 -0
  251. package/dist/src/modules/auth/components/AdminUserManagement.d.ts +11 -4
  252. package/dist/src/modules/auth/components/AdminUserManagement.js +970 -418
  253. package/dist/src/modules/auth/components/AdminUserManagement.js.map +1 -0
  254. package/dist/src/modules/auth/components/AdminWaitlist.d.ts +11 -4
  255. package/dist/src/modules/auth/components/AdminWaitlist.js +284 -115
  256. package/dist/src/modules/auth/components/AdminWaitlist.js.map +1 -0
  257. package/dist/src/modules/auth/components/AuthLayout.d.ts +12 -4
  258. package/dist/src/modules/auth/components/AuthLayout.js +17 -3
  259. package/dist/src/modules/auth/components/AuthLayout.js.map +1 -0
  260. package/dist/src/modules/auth/components/AuthProviders.d.ts +17 -6
  261. package/dist/src/modules/auth/components/AuthProviders.js +80 -41
  262. package/dist/src/modules/auth/components/AuthProviders.js.map +1 -0
  263. package/dist/src/modules/auth/components/AuthRouter.d.ts +16 -7
  264. package/dist/src/modules/auth/components/AuthRouter.js +46 -10
  265. package/dist/src/modules/auth/components/AuthRouter.js.map +1 -0
  266. package/dist/src/modules/auth/components/ClaimAccountRoute.d.ts +12 -4
  267. package/dist/src/modules/auth/components/ClaimAccountRoute.js +202 -139
  268. package/dist/src/modules/auth/components/ClaimAccountRoute.js.map +1 -0
  269. package/dist/src/modules/auth/components/ErrorAuthRoute.d.ts +7 -1
  270. package/dist/src/modules/auth/components/ErrorAuthRoute.js +125 -89
  271. package/dist/src/modules/auth/components/ErrorAuthRoute.js.map +1 -0
  272. package/dist/src/modules/auth/components/ForgotPasswordForm.d.ts +7 -1
  273. package/dist/src/modules/auth/components/ForgotPasswordForm.js +49 -23
  274. package/dist/src/modules/auth/components/ForgotPasswordForm.js.map +1 -0
  275. package/dist/src/modules/auth/components/ForgotPasswordRoute.d.ts +7 -1
  276. package/dist/src/modules/auth/components/ForgotPasswordRoute.js +34 -6
  277. package/dist/src/modules/auth/components/ForgotPasswordRoute.js.map +1 -0
  278. package/dist/src/modules/auth/components/InviteFriends.d.ts +12 -4
  279. package/dist/src/modules/auth/components/InviteFriends.js +275 -69
  280. package/dist/src/modules/auth/components/InviteFriends.js.map +1 -0
  281. package/dist/src/modules/auth/components/LastUsedBadge.d.ts +17 -5
  282. package/dist/src/modules/auth/components/LastUsedBadge.js +16 -6
  283. package/dist/src/modules/auth/components/LastUsedBadge.js.map +1 -0
  284. package/dist/src/modules/auth/components/LoginForm.d.ts +11 -3
  285. package/dist/src/modules/auth/components/LoginForm.js +107 -40
  286. package/dist/src/modules/auth/components/LoginForm.js.map +1 -0
  287. package/dist/src/modules/auth/components/LoginRoute.d.ts +11 -3
  288. package/dist/src/modules/auth/components/LoginRoute.js +41 -8
  289. package/dist/src/modules/auth/components/LoginRoute.js.map +1 -0
  290. package/dist/src/modules/auth/components/LogoutRoute.d.ts +7 -1
  291. package/dist/src/modules/auth/components/LogoutRoute.js +18 -12
  292. package/dist/src/modules/auth/components/LogoutRoute.js.map +1 -0
  293. package/dist/src/modules/auth/components/OrganizationAcceptInvitationRoute.d.ts +21 -8
  294. package/dist/src/modules/auth/components/OrganizationAcceptInvitationRoute.js +107 -97
  295. package/dist/src/modules/auth/components/OrganizationAcceptInvitationRoute.js.map +1 -0
  296. package/dist/src/modules/auth/components/OrganizationMembersRoute.d.ts +58 -48
  297. package/dist/src/modules/auth/components/OrganizationMembersRoute.js +448 -349
  298. package/dist/src/modules/auth/components/OrganizationMembersRoute.js.map +1 -0
  299. package/dist/src/modules/auth/components/OrganizationPreferences.d.ts +27 -16
  300. package/dist/src/modules/auth/components/OrganizationPreferences.js +129 -124
  301. package/dist/src/modules/auth/components/OrganizationPreferences.js.map +1 -0
  302. package/dist/src/modules/auth/components/OrganizationSettingsRoute.d.ts +27 -18
  303. package/dist/src/modules/auth/components/OrganizationSettingsRoute.js +184 -144
  304. package/dist/src/modules/auth/components/OrganizationSettingsRoute.js.map +1 -0
  305. package/dist/src/modules/auth/components/OrganizationSwitcher.d.ts +17 -6
  306. package/dist/src/modules/auth/components/OrganizationSwitcher.js +91 -69
  307. package/dist/src/modules/auth/components/OrganizationSwitcher.js.map +1 -0
  308. package/dist/src/modules/auth/components/PreferencesEditor.d.ts +44 -33
  309. package/dist/src/modules/auth/components/PreferencesEditor.js +82 -58
  310. package/dist/src/modules/auth/components/PreferencesEditor.js.map +1 -0
  311. package/dist/src/modules/auth/components/ProfileRoute.d.ts +7 -1
  312. package/dist/src/modules/auth/components/ProfileRoute.js +79 -36
  313. package/dist/src/modules/auth/components/ProfileRoute.js.map +1 -0
  314. package/dist/src/modules/auth/components/RangeNuqsDatePicker.d.ts +44 -30
  315. package/dist/src/modules/auth/components/RangeNuqsDatePicker.js +234 -242
  316. package/dist/src/modules/auth/components/RangeNuqsDatePicker.js.map +1 -0
  317. package/dist/src/modules/auth/components/ResetPasswordForm.d.ts +7 -1
  318. package/dist/src/modules/auth/components/ResetPasswordForm.js +97 -35
  319. package/dist/src/modules/auth/components/ResetPasswordForm.js.map +1 -0
  320. package/dist/src/modules/auth/components/ResetPasswordRoute.d.ts +7 -1
  321. package/dist/src/modules/auth/components/ResetPasswordRoute.js +34 -6
  322. package/dist/src/modules/auth/components/ResetPasswordRoute.js.map +1 -0
  323. package/dist/src/modules/auth/components/SignupFormRoute.d.ts +15 -5
  324. package/dist/src/modules/auth/components/SignupFormRoute.js +142 -99
  325. package/dist/src/modules/auth/components/SignupFormRoute.js.map +1 -0
  326. package/dist/src/modules/auth/components/SignupRoute.d.ts +13 -5
  327. package/dist/src/modules/auth/components/SignupRoute.js +59 -13
  328. package/dist/src/modules/auth/components/SignupRoute.js.map +1 -0
  329. package/dist/src/modules/auth/components/UserPreferences.d.ts +22 -11
  330. package/dist/src/modules/auth/components/UserPreferences.js +24 -12
  331. package/dist/src/modules/auth/components/UserPreferences.js.map +1 -0
  332. package/dist/src/modules/auth/components/WaitlistCard.d.ts +11 -4
  333. package/dist/src/modules/auth/components/WaitlistCard.js +63 -28
  334. package/dist/src/modules/auth/components/WaitlistCard.js.map +1 -0
  335. package/dist/src/modules/auth/components/WaitlistCodeValidation.d.ts +13 -5
  336. package/dist/src/modules/auth/components/WaitlistCodeValidation.js +42 -40
  337. package/dist/src/modules/auth/components/WaitlistCodeValidation.js.map +1 -0
  338. package/dist/src/modules/billing/components/BillingBetaPage.d.ts +15 -6
  339. package/dist/src/modules/billing/components/BillingBetaPage.js +155 -8
  340. package/dist/src/modules/billing/components/BillingBetaPage.js.map +1 -0
  341. package/dist/src/modules/billing/components/BillingInvoicePage.d.ts +13 -5
  342. package/dist/src/modules/billing/components/BillingInvoicePage.js +160 -30
  343. package/dist/src/modules/billing/components/BillingInvoicePage.js.map +1 -0
  344. package/dist/src/modules/billing/components/BillingPlanSelect.d.ts +11 -4
  345. package/dist/src/modules/billing/components/BillingPlanSelect.js +10 -7
  346. package/dist/src/modules/billing/components/BillingPlanSelect.js.map +1 -0
  347. package/dist/src/modules/billing/components/BillingRouter.d.ts +15 -7
  348. package/dist/src/modules/billing/components/BillingRouter.js +19 -6
  349. package/dist/src/modules/billing/components/BillingRouter.js.map +1 -0
  350. package/dist/src/modules/billing/components/BillingSinglePlanSelect.d.ts +17 -7
  351. package/dist/src/modules/billing/components/BillingSinglePlanSelect.js +163 -42
  352. package/dist/src/modules/billing/components/BillingSinglePlanSelect.js.map +1 -0
  353. package/dist/src/modules/table/components/ColumnOrderAndVisibility.d.ts +18 -8
  354. package/dist/src/modules/table/components/ColumnOrderAndVisibility.js +81 -38
  355. package/dist/src/modules/table/components/ColumnOrderAndVisibility.js.map +1 -0
  356. package/dist/src/modules/table/components/NuqsTable.d.ts +33 -21
  357. package/dist/src/modules/table/components/NuqsTable.js +295 -221
  358. package/dist/src/modules/table/components/NuqsTable.js.map +1 -0
  359. package/dist/src/modules/table/components/TableFiltering.d.ts +33 -21
  360. package/dist/src/modules/table/components/TableFiltering.js +408 -226
  361. package/dist/src/modules/table/components/TableFiltering.js.map +1 -0
  362. package/dist/src/modules/table/components/TableGroupBy.d.ts +18 -8
  363. package/dist/src/modules/table/components/TableGroupBy.js +56 -16
  364. package/dist/src/modules/table/components/TableGroupBy.js.map +1 -0
  365. package/dist/src/modules/table/components/TablePagination.d.ts +17 -7
  366. package/dist/src/modules/table/components/TablePagination.js +64 -32
  367. package/dist/src/modules/table/components/TablePagination.js.map +1 -0
  368. package/dist/src/modules/table/components/table.types.d.ts +15 -10
  369. package/dist/src/modules/table/components/table.types.js +0 -1
  370. package/dist/src/modules/table/filterTransformers.d.ts +35 -30
  371. package/dist/src/modules/table/filterTransformers.js +198 -261
  372. package/dist/src/modules/table/filterTransformers.js.map +1 -0
  373. package/dist/src/types.d.ts +8 -3
  374. package/dist/src/types.js +0 -1
  375. package/package.json +8 -6
  376. package/dist/translations/en/web-ui.json +0 -209
  377. package/dist/tsconfig.lib.tsbuildinfo +0 -1
@@ -1,34 +1,137 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { motion } from "motion/react";
1
+ import { cn } from "../lib/utils.js";
2
+ import { Card } from "./ui/card.js";
3
3
  import { useState } from "react";
4
- import { Card } from "./ui/card";
5
- import { cn } from "../lib/utils";
6
- function BlurCardHeader({ title, subtitle, type, date, }) {
7
- return (_jsxs("div", { className: "w-full px-4 py-4", children: [_jsxs("div", { className: "hidden lg:block", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-lg font-semibold text-white drop-shadow-md", children: title }), _jsx("span", { className: "inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md", children: type })] }), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-sm text-neutral-300 drop-shadow-md", children: subtitle }), _jsx("span", { className: "text-xs text-neutral-300 drop-shadow-md italic", children: date })] })] }), _jsxs("div", { className: "block lg:hidden", children: [_jsx("div", { className: "inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md", children: type }), _jsx("div", { className: "text-lg font-semibold text-white drop-shadow-md", children: title }), _jsx("div", { className: "text-sm text-neutral-300 drop-shadow-md", children: subtitle }), _jsx("div", { className: "text-xs text-neutral-300 drop-shadow-md italic", children: date })] })] }));
4
+ import { jsx, jsxs } from "react/jsx-runtime";
5
+ import { motion } from "motion/react";
6
+ //#region src/components/blur-card.tsx
7
+ function BlurCardHeader({ title, subtitle, type, date }) {
8
+ return /* @__PURE__ */ jsxs("div", {
9
+ className: "w-full px-4 py-4",
10
+ children: [/* @__PURE__ */ jsxs("div", {
11
+ className: "hidden lg:block",
12
+ children: [/* @__PURE__ */ jsxs("div", {
13
+ className: "flex items-center justify-between",
14
+ children: [/* @__PURE__ */ jsx("span", {
15
+ className: "text-lg font-semibold text-white drop-shadow-md",
16
+ children: title
17
+ }), /* @__PURE__ */ jsx("span", {
18
+ className: "inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md",
19
+ children: type
20
+ })]
21
+ }), /* @__PURE__ */ jsxs("div", {
22
+ className: "flex items-center justify-between",
23
+ children: [/* @__PURE__ */ jsx("span", {
24
+ className: "text-sm text-neutral-300 drop-shadow-md",
25
+ children: subtitle
26
+ }), /* @__PURE__ */ jsx("span", {
27
+ className: "text-xs text-neutral-300 drop-shadow-md italic",
28
+ children: date
29
+ })]
30
+ })]
31
+ }), /* @__PURE__ */ jsxs("div", {
32
+ className: "block lg:hidden",
33
+ children: [
34
+ /* @__PURE__ */ jsx("div", {
35
+ className: "inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md",
36
+ children: type
37
+ }),
38
+ /* @__PURE__ */ jsx("div", {
39
+ className: "text-lg font-semibold text-white drop-shadow-md",
40
+ children: title
41
+ }),
42
+ /* @__PURE__ */ jsx("div", {
43
+ className: "text-sm text-neutral-300 drop-shadow-md",
44
+ children: subtitle
45
+ }),
46
+ /* @__PURE__ */ jsx("div", {
47
+ className: "text-xs text-neutral-300 drop-shadow-md italic",
48
+ children: date
49
+ })
50
+ ]
51
+ })]
52
+ });
8
53
  }
9
- export function BlurCard({ image, title, subtitle, type, date, description, className, link, }) {
10
- // Detect touch device
11
- const isTouchDevice = typeof window !== "undefined" && ("ontouchstart" in window || navigator.maxTouchPoints > 0);
12
- const [isOpen, setIsOpen] = useState(false);
13
- // Handler for tap on mobile
14
- const handleCardClick = () => {
15
- if (isTouchDevice)
16
- setIsOpen((open) => !open);
17
- };
18
- return (_jsx(Card, { className: cn("relative overflow-hidden p-0 h-80 w-full flex flex-col justify-start", className), onClick: isTouchDevice ? handleCardClick : undefined, style: { touchAction: "manipulation" }, children: _jsxs(motion.div, { whileHover: isTouchDevice ? undefined : "hover", initial: "rest", animate: isTouchDevice && isOpen ? "hover" : "rest", className: "relative w-full h-full flex flex-col justify-end", style: {
19
- backgroundImage: `url(${image})`,
20
- backgroundSize: "cover",
21
- backgroundPosition: "center",
22
- height: "100%",
23
- }, children: [_jsx(motion.div, { variants: {
24
- rest: { opacity: 0, backdropFilter: "blur(0px)" },
25
- hover: { opacity: 1, backdropFilter: "blur(8px)" },
26
- }, transition: { duration: 0.3, ease: "easeInOut" }, className: "absolute inset-0 z-10 bg-black/70 pointer-events-none rounded-xl", style: { WebkitBackdropFilter: "blur(8px)" } }), _jsxs(motion.div, { variants: {
27
- rest: { height: "5rem" },
28
- hover: { height: "100%" },
29
- }, transition: { duration: 0.3, ease: "easeInOut" }, className: "w-full flex flex-col justify-start bg-black/70 pointer-events-none rounded-xl z-20", style: {
30
- overflow: "hidden",
31
- WebkitBackdropFilter: "blur(8px)",
32
- backdropFilter: "blur(8px)",
33
- }, children: [_jsx(BlurCardHeader, { title: title, subtitle: subtitle, type: type, date: date }), _jsxs("div", { className: "w-full h-full px-4 pb-4 flex flex-col justify-between", children: [_jsx("p", { className: "text-neutral-100", children: description }), _jsx("div", { className: "flex items-center justify-end pointer-events-auto", children: link })] })] }), _jsx("img", { src: image, alt: title, className: "invisible w-0 h-0" })] }) }));
54
+ function BlurCard({ image, title, subtitle, type, date, description, className, link }) {
55
+ const isTouchDevice = typeof window !== "undefined" && ("ontouchstart" in window || navigator.maxTouchPoints > 0);
56
+ const [isOpen, setIsOpen] = useState(false);
57
+ const handleCardClick = () => {
58
+ if (isTouchDevice) setIsOpen((open) => !open);
59
+ };
60
+ return /* @__PURE__ */ jsx(Card, {
61
+ className: cn("relative overflow-hidden p-0 h-80 w-full flex flex-col justify-start", className),
62
+ onClick: isTouchDevice ? handleCardClick : void 0,
63
+ style: { touchAction: "manipulation" },
64
+ children: /* @__PURE__ */ jsxs(motion.div, {
65
+ whileHover: isTouchDevice ? void 0 : "hover",
66
+ initial: "rest",
67
+ animate: isTouchDevice && isOpen ? "hover" : "rest",
68
+ className: "relative w-full h-full flex flex-col justify-end",
69
+ style: {
70
+ backgroundImage: `url(${image})`,
71
+ backgroundSize: "cover",
72
+ backgroundPosition: "center",
73
+ height: "100%"
74
+ },
75
+ children: [
76
+ /* @__PURE__ */ jsx(motion.div, {
77
+ variants: {
78
+ rest: {
79
+ opacity: 0,
80
+ backdropFilter: "blur(0px)"
81
+ },
82
+ hover: {
83
+ opacity: 1,
84
+ backdropFilter: "blur(8px)"
85
+ }
86
+ },
87
+ transition: {
88
+ duration: .3,
89
+ ease: "easeInOut"
90
+ },
91
+ className: "absolute inset-0 z-10 bg-black/70 pointer-events-none rounded-xl",
92
+ style: { WebkitBackdropFilter: "blur(8px)" }
93
+ }),
94
+ /* @__PURE__ */ jsxs(motion.div, {
95
+ variants: {
96
+ rest: { height: "5rem" },
97
+ hover: { height: "100%" }
98
+ },
99
+ transition: {
100
+ duration: .3,
101
+ ease: "easeInOut"
102
+ },
103
+ className: "w-full flex flex-col justify-start bg-black/70 pointer-events-none rounded-xl z-20",
104
+ style: {
105
+ overflow: "hidden",
106
+ WebkitBackdropFilter: "blur(8px)",
107
+ backdropFilter: "blur(8px)"
108
+ },
109
+ children: [/* @__PURE__ */ jsx(BlurCardHeader, {
110
+ title,
111
+ subtitle,
112
+ type,
113
+ date
114
+ }), /* @__PURE__ */ jsxs("div", {
115
+ className: "w-full h-full px-4 pb-4 flex flex-col justify-between",
116
+ children: [/* @__PURE__ */ jsx("p", {
117
+ className: "text-neutral-100",
118
+ children: description
119
+ }), /* @__PURE__ */ jsx("div", {
120
+ className: "flex items-center justify-end pointer-events-auto",
121
+ children: link
122
+ })]
123
+ })]
124
+ }),
125
+ /* @__PURE__ */ jsx("img", {
126
+ src: image,
127
+ alt: title,
128
+ className: "invisible w-0 h-0"
129
+ })
130
+ ]
131
+ })
132
+ });
34
133
  }
134
+ //#endregion
135
+ export { BlurCard };
136
+
137
+ //# sourceMappingURL=blur-card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blur-card.js","names":[],"sources":["../../../src/components/blur-card.tsx"],"sourcesContent":["import { motion } from \"motion/react\";\r\nimport type { ReactNode } from \"react\";\r\nimport { useState } from \"react\";\r\nimport { Card } from \"./ui/card\";\r\nimport { cn } from \"../lib/utils\";\r\n\r\nfunction BlurCardHeader({\r\n title,\r\n subtitle,\r\n type,\r\n date,\r\n}: {\r\n title: string;\r\n subtitle: string;\r\n type: string;\r\n date: string;\r\n}) {\r\n return (\r\n <div className=\"w-full px-4 py-4\">\r\n <div className=\"hidden lg:block\">\r\n <div className=\"flex items-center justify-between\">\r\n <span className=\"text-lg font-semibold text-white drop-shadow-md\">{title}</span>\r\n <span className=\"inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md\">\r\n {type}\r\n </span>\r\n </div>\r\n <div className=\"flex items-center justify-between\">\r\n <span className=\"text-sm text-neutral-300 drop-shadow-md\">{subtitle}</span>\r\n <span className=\"text-xs text-neutral-300 drop-shadow-md italic\">{date}</span>\r\n </div>\r\n </div>\r\n\r\n <div className=\"block lg:hidden\">\r\n <div className=\"inline-block rounded-full bg-white/20 text-xs text-white font-semibold px-2 py-0.5 drop-shadow-md\">\r\n {type}\r\n </div>\r\n <div className=\"text-lg font-semibold text-white drop-shadow-md\">{title}</div>\r\n <div className=\"text-sm text-neutral-300 drop-shadow-md\">{subtitle}</div>\r\n <div className=\"text-xs text-neutral-300 drop-shadow-md italic\">{date}</div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\ninterface BlurCardProps {\r\n image: string;\r\n title: string;\r\n subtitle: string;\r\n type: string;\r\n date: string;\r\n description: string;\r\n className?: string;\r\n link?: ReactNode;\r\n}\r\n\r\nexport function BlurCard({\r\n image,\r\n title,\r\n subtitle,\r\n type,\r\n date,\r\n description,\r\n className,\r\n link,\r\n}: BlurCardProps) {\r\n // Detect touch device\r\n const isTouchDevice =\r\n typeof window !== \"undefined\" && (\"ontouchstart\" in window || navigator.maxTouchPoints > 0);\r\n const [isOpen, setIsOpen] = useState(false);\r\n\r\n // Handler for tap on mobile\r\n const handleCardClick = () => {\r\n if (isTouchDevice) setIsOpen((open) => !open);\r\n };\r\n\r\n return (\r\n <Card\r\n className={cn(\r\n \"relative overflow-hidden p-0 h-80 w-full flex flex-col justify-start\",\r\n className\r\n )}\r\n onClick={isTouchDevice ? handleCardClick : undefined}\r\n style={{ touchAction: \"manipulation\" }}\r\n >\r\n <motion.div\r\n whileHover={isTouchDevice ? undefined : \"hover\"}\r\n initial=\"rest\"\r\n animate={isTouchDevice && isOpen ? \"hover\" : \"rest\"}\r\n className=\"relative w-full h-full flex flex-col justify-end\"\r\n style={{\r\n backgroundImage: `url(${image})`,\r\n backgroundSize: \"cover\",\r\n backgroundPosition: \"center\",\r\n height: \"100%\",\r\n }}\r\n >\r\n {/* Overlay for blur and dim */}\r\n <motion.div\r\n variants={{\r\n rest: { opacity: 0, backdropFilter: \"blur(0px)\" },\r\n hover: { opacity: 1, backdropFilter: \"blur(8px)\" },\r\n }}\r\n transition={{ duration: 0.3, ease: \"easeInOut\" }}\r\n className=\"absolute inset-0 z-10 bg-black/70 pointer-events-none rounded-xl\"\r\n style={{ WebkitBackdropFilter: \"blur(8px)\" }}\r\n />\r\n {/* Header wrapper */}\r\n <motion.div\r\n variants={{\r\n rest: { height: \"5rem\" },\r\n hover: { height: \"100%\" },\r\n }}\r\n transition={{ duration: 0.3, ease: \"easeInOut\" }}\r\n className=\"w-full flex flex-col justify-start bg-black/70 pointer-events-none rounded-xl z-20\"\r\n style={{\r\n overflow: \"hidden\",\r\n WebkitBackdropFilter: \"blur(8px)\",\r\n backdropFilter: \"blur(8px)\",\r\n }}\r\n >\r\n <BlurCardHeader title={title} subtitle={subtitle} type={type} date={date} />\r\n <div className=\"w-full h-full px-4 pb-4 flex flex-col justify-between\">\r\n <p className=\"text-neutral-100\">{description}</p>\r\n <div className=\"flex items-center justify-end pointer-events-auto\">{link}</div>\r\n </div>\r\n </motion.div>\r\n {/* For accessibility, add an invisible img tag */}\r\n <img src={image} alt={title} className=\"invisible w-0 h-0\" />\r\n </motion.div>\r\n </Card>\r\n );\r\n}\r\n"],"mappings":";;;;;;AAMA,SAAS,eAAe,EACtB,OACA,UACA,MACA,QAMC;AACD,QACE,qBAAC,OAAD;EAAK,WAAU;YAAf,CACE,qBAAC,OAAD;GAAK,WAAU;aAAf,CACE,qBAAC,OAAD;IAAK,WAAU;cAAf,CACE,oBAAC,QAAD;KAAM,WAAU;eAAmD;KAAa,CAAA,EAChF,oBAAC,QAAD;KAAM,WAAU;eACb;KACI,CAAA,CACH;OACN,qBAAC,OAAD;IAAK,WAAU;cAAf,CACE,oBAAC,QAAD;KAAM,WAAU;eAA2C;KAAgB,CAAA,EAC3E,oBAAC,QAAD;KAAM,WAAU;eAAkD;KAAY,CAAA,CAC1E;MACF;MAEN,qBAAC,OAAD;GAAK,WAAU;aAAf;IACE,oBAAC,OAAD;KAAK,WAAU;eACZ;KACG,CAAA;IACN,oBAAC,OAAD;KAAK,WAAU;eAAmD;KAAY,CAAA;IAC9E,oBAAC,OAAD;KAAK,WAAU;eAA2C;KAAe,CAAA;IACzE,oBAAC,OAAD;KAAK,WAAU;eAAkD;KAAW,CAAA;IACxE;KACF;;;AAeV,SAAgB,SAAS,EACvB,OACA,OACA,UACA,MACA,MACA,aACA,WACA,QACgB;CAEhB,MAAM,gBACJ,OAAO,WAAW,gBAAgB,kBAAkB,UAAU,UAAU,iBAAiB;CAC3F,MAAM,CAAC,QAAQ,aAAa,SAAS,MAAM;CAG3C,MAAM,wBAAwB;AAC5B,MAAI,cAAe,YAAW,SAAS,CAAC,KAAK;;AAG/C,QACE,oBAAC,MAAD;EACE,WAAW,GACT,wEACA,UACD;EACD,SAAS,gBAAgB,kBAAkB,KAAA;EAC3C,OAAO,EAAE,aAAa,gBAAgB;YAEtC,qBAAC,OAAO,KAAR;GACE,YAAY,gBAAgB,KAAA,IAAY;GACxC,SAAQ;GACR,SAAS,iBAAiB,SAAS,UAAU;GAC7C,WAAU;GACV,OAAO;IACL,iBAAiB,OAAO,MAAM;IAC9B,gBAAgB;IAChB,oBAAoB;IACpB,QAAQ;IACT;aAVH;IAaE,oBAAC,OAAO,KAAR;KACE,UAAU;MACR,MAAM;OAAE,SAAS;OAAG,gBAAgB;OAAa;MACjD,OAAO;OAAE,SAAS;OAAG,gBAAgB;OAAa;MACnD;KACD,YAAY;MAAE,UAAU;MAAK,MAAM;MAAa;KAChD,WAAU;KACV,OAAO,EAAE,sBAAsB,aAAa;KAC5C,CAAA;IAEF,qBAAC,OAAO,KAAR;KACE,UAAU;MACR,MAAM,EAAE,QAAQ,QAAQ;MACxB,OAAO,EAAE,QAAQ,QAAQ;MAC1B;KACD,YAAY;MAAE,UAAU;MAAK,MAAM;MAAa;KAChD,WAAU;KACV,OAAO;MACL,UAAU;MACV,sBAAsB;MACtB,gBAAgB;MACjB;eAXH,CAaE,oBAAC,gBAAD;MAAuB;MAAiB;MAAgB;MAAY;MAAQ,CAAA,EAC5E,qBAAC,OAAD;MAAK,WAAU;gBAAf,CACE,oBAAC,KAAD;OAAG,WAAU;iBAAoB;OAAgB,CAAA,EACjD,oBAAC,OAAD;OAAK,WAAU;iBAAqD;OAAW,CAAA,CAC3E;QACK;;IAEb,oBAAC,OAAD;KAAK,KAAK;KAAO,KAAK;KAAO,WAAU;KAAsB,CAAA;IAClD;;EACR,CAAA"}
@@ -1,6 +1,22 @@
1
- export default function FeaturesSectionDemo(): import("react/jsx-runtime").JSX.Element;
2
- export declare const Grid: ({ pattern, size }: {
3
- pattern?: number[][];
4
- size?: number;
5
- }) => import("react/jsx-runtime").JSX.Element;
6
- export declare function GridPattern({ width, height, x, y, squares, ...props }: any): import("react/jsx-runtime").JSX.Element;
1
+ import * as _$react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components/features-section-demo-1.d.ts
4
+ declare function FeaturesSectionDemo(): _$react_jsx_runtime0.JSX.Element;
5
+ declare const Grid: ({
6
+ pattern,
7
+ size
8
+ }: {
9
+ pattern?: number[][];
10
+ size?: number;
11
+ }) => _$react_jsx_runtime0.JSX.Element;
12
+ declare function GridPattern({
13
+ width,
14
+ height,
15
+ x,
16
+ y,
17
+ squares,
18
+ ...props
19
+ }: any): _$react_jsx_runtime0.JSX.Element;
20
+ //#endregion
21
+ export { Grid, GridPattern, FeaturesSectionDemo as default };
22
+ //# sourceMappingURL=features-section-demo-1.d.ts.map
@@ -1,53 +1,125 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
1
  import { useId } from "react";
3
- export default function FeaturesSectionDemo() {
4
- return (_jsx("div", { className: "py-20 lg:py-40", children: _jsx("div", { className: "grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-10 md:gap-2 max-w-7xl mx-auto", children: grid.map((feature) => (_jsxs("div", { className: "relative bg-gradient-to-b dark:from-neutral-900 from-neutral-100 dark:to-neutral-950 to-white p-6 rounded-3xl overflow-hidden", children: [_jsx(Grid, { size: 20 }), _jsx("p", { className: "text-base font-bold text-neutral-800 dark:text-white relative z-20", children: feature.title }), _jsx("p", { className: "text-neutral-600 dark:text-neutral-400 mt-4 text-base font-normal relative z-20", children: feature.description })] }, feature.title))) }) }));
2
+ import { jsx, jsxs } from "react/jsx-runtime";
3
+ //#region src/components/features-section-demo-1.tsx
4
+ function FeaturesSectionDemo() {
5
+ return /* @__PURE__ */ jsx("div", {
6
+ className: "py-20 lg:py-40",
7
+ children: /* @__PURE__ */ jsx("div", {
8
+ className: "grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-10 md:gap-2 max-w-7xl mx-auto",
9
+ children: grid.map((feature) => /* @__PURE__ */ jsxs("div", {
10
+ className: "relative bg-gradient-to-b dark:from-neutral-900 from-neutral-100 dark:to-neutral-950 to-white p-6 rounded-3xl overflow-hidden",
11
+ children: [
12
+ /* @__PURE__ */ jsx(Grid, { size: 20 }),
13
+ /* @__PURE__ */ jsx("p", {
14
+ className: "text-base font-bold text-neutral-800 dark:text-white relative z-20",
15
+ children: feature.title
16
+ }),
17
+ /* @__PURE__ */ jsx("p", {
18
+ className: "text-neutral-600 dark:text-neutral-400 mt-4 text-base font-normal relative z-20",
19
+ children: feature.description
20
+ })
21
+ ]
22
+ }, feature.title))
23
+ })
24
+ });
5
25
  }
6
26
  const grid = [
7
- {
8
- title: "HIPAA and SOC2 Compliant",
9
- description: "Our applications are HIPAA and SOC2 compliant, your data is safe with us, always.",
10
- },
11
- {
12
- title: "Automated Social Media Posting",
13
- description: "Schedule and automate your social media posts across multiple platforms to save time and maintain a consistent online presence.",
14
- },
15
- {
16
- title: "Advanced Analytics",
17
- description: "Gain insights into your social media performance with detailed analytics and reporting tools to measure engagement and ROI.",
18
- },
19
- {
20
- title: "Content Calendar",
21
- description: "Plan and organize your social media content with an intuitive calendar view, ensuring you never miss a post.",
22
- },
23
- {
24
- title: "Audience Targeting",
25
- description: "Reach the right audience with advanced targeting options, including demographics, interests, and behaviors.",
26
- },
27
- {
28
- title: "Social Listening",
29
- description: "Monitor social media conversations and trends to stay informed about what your audience is saying and respond in real-time.",
30
- },
31
- {
32
- title: "Customizable Templates",
33
- description: "Create stunning social media posts with our customizable templates, designed to fit your brand's unique style and voice.",
34
- },
35
- {
36
- title: "Collaboration Tools",
37
- description: "Work seamlessly with your team using our collaboration tools, allowing you to assign tasks, share drafts, and provide feedback in real-time.",
38
- },
27
+ {
28
+ title: "HIPAA and SOC2 Compliant",
29
+ description: "Our applications are HIPAA and SOC2 compliant, your data is safe with us, always."
30
+ },
31
+ {
32
+ title: "Automated Social Media Posting",
33
+ description: "Schedule and automate your social media posts across multiple platforms to save time and maintain a consistent online presence."
34
+ },
35
+ {
36
+ title: "Advanced Analytics",
37
+ description: "Gain insights into your social media performance with detailed analytics and reporting tools to measure engagement and ROI."
38
+ },
39
+ {
40
+ title: "Content Calendar",
41
+ description: "Plan and organize your social media content with an intuitive calendar view, ensuring you never miss a post."
42
+ },
43
+ {
44
+ title: "Audience Targeting",
45
+ description: "Reach the right audience with advanced targeting options, including demographics, interests, and behaviors."
46
+ },
47
+ {
48
+ title: "Social Listening",
49
+ description: "Monitor social media conversations and trends to stay informed about what your audience is saying and respond in real-time."
50
+ },
51
+ {
52
+ title: "Customizable Templates",
53
+ description: "Create stunning social media posts with our customizable templates, designed to fit your brand's unique style and voice."
54
+ },
55
+ {
56
+ title: "Collaboration Tools",
57
+ description: "Work seamlessly with your team using our collaboration tools, allowing you to assign tasks, share drafts, and provide feedback in real-time."
58
+ }
39
59
  ];
40
- export const Grid = ({ pattern, size }) => {
41
- const p = pattern ?? [
42
- [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
43
- [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
44
- [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
45
- [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
46
- [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
47
- ];
48
- return (_jsx("div", { className: "pointer-events-none absolute left-1/2 top-0 -ml-20 -mt-2 h-full w-full [mask-image:linear-gradient(white,transparent)]", children: _jsx("div", { className: "absolute inset-0 bg-gradient-to-r [mask-image:radial-gradient(farthest-side_at_top,white,transparent)] dark:from-zinc-900/30 from-zinc-100/30 to-zinc-300/30 dark:to-zinc-900/30 opacity-100", children: _jsx(GridPattern, { width: size ?? 20, height: size ?? 20, x: "-12", y: "4", squares: p, className: "absolute inset-0 h-full w-full mix-blend-overlay dark:fill-white/10 dark:stroke-white/10 stroke-black/10 fill-black/10" }) }) }));
60
+ const Grid = ({ pattern, size }) => {
61
+ const p = pattern ?? [
62
+ [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
63
+ [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
64
+ [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
65
+ [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],
66
+ [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1]
67
+ ];
68
+ return /* @__PURE__ */ jsx("div", {
69
+ className: "pointer-events-none absolute left-1/2 top-0 -ml-20 -mt-2 h-full w-full [mask-image:linear-gradient(white,transparent)]",
70
+ children: /* @__PURE__ */ jsx("div", {
71
+ className: "absolute inset-0 bg-gradient-to-r [mask-image:radial-gradient(farthest-side_at_top,white,transparent)] dark:from-zinc-900/30 from-zinc-100/30 to-zinc-300/30 dark:to-zinc-900/30 opacity-100",
72
+ children: /* @__PURE__ */ jsx(GridPattern, {
73
+ width: size ?? 20,
74
+ height: size ?? 20,
75
+ x: "-12",
76
+ y: "4",
77
+ squares: p,
78
+ className: "absolute inset-0 h-full w-full mix-blend-overlay dark:fill-white/10 dark:stroke-white/10 stroke-black/10 fill-black/10"
79
+ })
80
+ })
81
+ });
49
82
  };
50
- export function GridPattern({ width, height, x, y, squares, ...props }) {
51
- const patternId = useId();
52
- return (_jsxs("svg", { "aria-hidden": "true", ...props, children: [_jsx("defs", { children: _jsx("pattern", { id: patternId, width: width, height: height, patternUnits: "userSpaceOnUse", x: x, y: y, children: _jsx("path", { d: `M.5 ${height}V.5H${width}`, fill: "none" }) }) }), _jsx("rect", { width: "100%", height: "100%", strokeWidth: 0, fill: `url(#${patternId})` }), squares && (_jsx("svg", { x: x, y: y, className: "overflow-visible", children: squares.map(([x, y]) => (_jsx("rect", { strokeWidth: "0", width: width + 1, height: height + 1, x: x * width, y: y * height }, `${x}-${y}`))) }))] }));
83
+ function GridPattern({ width, height, x, y, squares, ...props }) {
84
+ const patternId = useId();
85
+ return /* @__PURE__ */ jsxs("svg", {
86
+ "aria-hidden": "true",
87
+ ...props,
88
+ children: [
89
+ /* @__PURE__ */ jsx("defs", { children: /* @__PURE__ */ jsx("pattern", {
90
+ id: patternId,
91
+ width,
92
+ height,
93
+ patternUnits: "userSpaceOnUse",
94
+ x,
95
+ y,
96
+ children: /* @__PURE__ */ jsx("path", {
97
+ d: `M.5 ${height}V.5H${width}`,
98
+ fill: "none"
99
+ })
100
+ }) }),
101
+ /* @__PURE__ */ jsx("rect", {
102
+ width: "100%",
103
+ height: "100%",
104
+ strokeWidth: 0,
105
+ fill: `url(#${patternId})`
106
+ }),
107
+ squares && /* @__PURE__ */ jsx("svg", {
108
+ x,
109
+ y,
110
+ className: "overflow-visible",
111
+ children: squares.map(([x, y]) => /* @__PURE__ */ jsx("rect", {
112
+ strokeWidth: "0",
113
+ width: width + 1,
114
+ height: height + 1,
115
+ x: x * width,
116
+ y: y * height
117
+ }, `${x}-${y}`))
118
+ })
119
+ ]
120
+ });
53
121
  }
122
+ //#endregion
123
+ export { Grid, GridPattern, FeaturesSectionDemo as default };
124
+
125
+ //# sourceMappingURL=features-section-demo-1.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"features-section-demo-1.js","names":[],"sources":["../../../src/components/features-section-demo-1.tsx"],"sourcesContent":["import { useId } from \"react\";\r\n\r\nexport default function FeaturesSectionDemo() {\r\n return (\r\n <div className=\"py-20 lg:py-40\">\r\n <div className=\"grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-10 md:gap-2 max-w-7xl mx-auto\">\r\n {grid.map((feature) => (\r\n <div\r\n key={feature.title}\r\n className=\"relative bg-gradient-to-b dark:from-neutral-900 from-neutral-100 dark:to-neutral-950 to-white p-6 rounded-3xl overflow-hidden\"\r\n >\r\n <Grid size={20} />\r\n <p className=\"text-base font-bold text-neutral-800 dark:text-white relative z-20\">\r\n {feature.title}\r\n </p>\r\n <p className=\"text-neutral-600 dark:text-neutral-400 mt-4 text-base font-normal relative z-20\">\r\n {feature.description}\r\n </p>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\nconst grid = [\r\n {\r\n title: \"HIPAA and SOC2 Compliant\",\r\n description:\r\n \"Our applications are HIPAA and SOC2 compliant, your data is safe with us, always.\",\r\n },\r\n {\r\n title: \"Automated Social Media Posting\",\r\n description:\r\n \"Schedule and automate your social media posts across multiple platforms to save time and maintain a consistent online presence.\",\r\n },\r\n {\r\n title: \"Advanced Analytics\",\r\n description:\r\n \"Gain insights into your social media performance with detailed analytics and reporting tools to measure engagement and ROI.\",\r\n },\r\n {\r\n title: \"Content Calendar\",\r\n description:\r\n \"Plan and organize your social media content with an intuitive calendar view, ensuring you never miss a post.\",\r\n },\r\n {\r\n title: \"Audience Targeting\",\r\n description:\r\n \"Reach the right audience with advanced targeting options, including demographics, interests, and behaviors.\",\r\n },\r\n {\r\n title: \"Social Listening\",\r\n description:\r\n \"Monitor social media conversations and trends to stay informed about what your audience is saying and respond in real-time.\",\r\n },\r\n {\r\n title: \"Customizable Templates\",\r\n description:\r\n \"Create stunning social media posts with our customizable templates, designed to fit your brand's unique style and voice.\",\r\n },\r\n {\r\n title: \"Collaboration Tools\",\r\n description:\r\n \"Work seamlessly with your team using our collaboration tools, allowing you to assign tasks, share drafts, and provide feedback in real-time.\",\r\n },\r\n];\r\n\r\nexport const Grid = ({ pattern, size }: { pattern?: number[][]; size?: number }) => {\r\n const p = pattern ?? [\r\n [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],\r\n [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],\r\n [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],\r\n [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],\r\n [Math.floor(Math.random() * 4) + 7, Math.floor(Math.random() * 6) + 1],\r\n ];\r\n return (\r\n <div className=\"pointer-events-none absolute left-1/2 top-0 -ml-20 -mt-2 h-full w-full [mask-image:linear-gradient(white,transparent)]\">\r\n <div className=\"absolute inset-0 bg-gradient-to-r [mask-image:radial-gradient(farthest-side_at_top,white,transparent)] dark:from-zinc-900/30 from-zinc-100/30 to-zinc-300/30 dark:to-zinc-900/30 opacity-100\">\r\n <GridPattern\r\n width={size ?? 20}\r\n height={size ?? 20}\r\n x=\"-12\"\r\n y=\"4\"\r\n squares={p}\r\n className=\"absolute inset-0 h-full w-full mix-blend-overlay dark:fill-white/10 dark:stroke-white/10 stroke-black/10 fill-black/10\"\r\n />\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nexport function GridPattern({ width, height, x, y, squares, ...props }: any) {\r\n const patternId = useId();\r\n\r\n return (\r\n <svg aria-hidden=\"true\" {...props}>\r\n <defs>\r\n <pattern\r\n id={patternId}\r\n width={width}\r\n height={height}\r\n patternUnits=\"userSpaceOnUse\"\r\n x={x}\r\n y={y}\r\n >\r\n <path d={`M.5 ${height}V.5H${width}`} fill=\"none\" />\r\n </pattern>\r\n </defs>\r\n <rect width=\"100%\" height=\"100%\" strokeWidth={0} fill={`url(#${patternId})`} />\r\n {squares && (\r\n <svg x={x} y={y} className=\"overflow-visible\">\r\n {squares.map(([x, y]: any) => (\r\n <rect\r\n strokeWidth=\"0\"\r\n key={`${x}-${y}`}\r\n width={width + 1}\r\n height={height + 1}\r\n x={x * width}\r\n y={y * height}\r\n />\r\n ))}\r\n </svg>\r\n )}\r\n </svg>\r\n );\r\n}\r\n"],"mappings":";;;AAEA,SAAwB,sBAAsB;AAC5C,QACE,oBAAC,OAAD;EAAK,WAAU;YACb,oBAAC,OAAD;GAAK,WAAU;aACZ,KAAK,KAAK,YACT,qBAAC,OAAD;IAEE,WAAU;cAFZ;KAIE,oBAAC,MAAD,EAAM,MAAM,IAAM,CAAA;KAClB,oBAAC,KAAD;MAAG,WAAU;gBACV,QAAQ;MACP,CAAA;KACJ,oBAAC,KAAD;MAAG,WAAU;gBACV,QAAQ;MACP,CAAA;KACA;MAVC,QAAQ,MAUT,CACN;GACE,CAAA;EACF,CAAA;;AAIV,MAAM,OAAO;CACX;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACD;EACE,OAAO;EACP,aACE;EACH;CACF;AAED,MAAa,QAAQ,EAAE,SAAS,WAAoD;CAClF,MAAM,IAAI,WAAW;EACnB,CAAC,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,GAAG,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,EAAE;EACtE,CAAC,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,GAAG,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,EAAE;EACtE,CAAC,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,GAAG,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,EAAE;EACtE,CAAC,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,GAAG,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,EAAE;EACtE,CAAC,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,GAAG,KAAK,MAAM,KAAK,QAAQ,GAAG,EAAE,GAAG,EAAE;EACvE;AACD,QACE,oBAAC,OAAD;EAAK,WAAU;YACb,oBAAC,OAAD;GAAK,WAAU;aACb,oBAAC,aAAD;IACE,OAAO,QAAQ;IACf,QAAQ,QAAQ;IAChB,GAAE;IACF,GAAE;IACF,SAAS;IACT,WAAU;IACV,CAAA;GACE,CAAA;EACF,CAAA;;AAIV,SAAgB,YAAY,EAAE,OAAO,QAAQ,GAAG,GAAG,SAAS,GAAG,SAAc;CAC3E,MAAM,YAAY,OAAO;AAEzB,QACE,qBAAC,OAAD;EAAK,eAAY;EAAO,GAAI;YAA5B;GACE,oBAAC,QAAD,EAAA,UACE,oBAAC,WAAD;IACE,IAAI;IACG;IACC;IACR,cAAa;IACV;IACA;cAEH,oBAAC,QAAD;KAAM,GAAG,OAAO,OAAO,MAAM;KAAS,MAAK;KAAS,CAAA;IAC5C,CAAA,EACL,CAAA;GACP,oBAAC,QAAD;IAAM,OAAM;IAAO,QAAO;IAAO,aAAa;IAAG,MAAM,QAAQ,UAAU;IAAM,CAAA;GAC9E,WACC,oBAAC,OAAD;IAAQ;IAAM;IAAG,WAAU;cACxB,QAAQ,KAAK,CAAC,GAAG,OAChB,oBAAC,QAAD;KACE,aAAY;KAEZ,OAAO,QAAQ;KACf,QAAQ,SAAS;KACjB,GAAG,IAAI;KACP,GAAG,IAAI;KACP,EALK,GAAG,EAAE,GAAG,IAKb,CACF;IACE,CAAA;GAEJ"}
@@ -1 +1,7 @@
1
- export default function FeaturesSectionDemo(): import("react/jsx-runtime").JSX.Element;
1
+ import * as _$react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components/features-section-demo-2.d.ts
4
+ declare function FeaturesSectionDemo(): _$react_jsx_runtime0.JSX.Element;
5
+ //#endregion
6
+ export { FeaturesSectionDemo as default };
7
+ //# sourceMappingURL=features-section-demo-2.d.ts.map
@@ -1,51 +1,82 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { IconBlocks, IconBooks, IconCode, IconMicroscope, IconRocket, IconSchool, IconUser, IconWriting, } from "@tabler/icons-react";
3
- import { cn } from "../lib/utils";
4
- export default function FeaturesSectionDemo() {
5
- const features = [
6
- {
7
- title: "Founder",
8
- description: "I turn zero into one. Sometimes into ten.",
9
- icon: _jsx(IconBlocks, {}),
10
- },
11
- {
12
- title: "Entrepreneur",
13
- description: "I chase opportunities, not job titles.",
14
- icon: _jsx(IconRocket, {}),
15
- },
16
- {
17
- title: "Developer",
18
- description: "I speak fluent JavaScript and problem-solving.",
19
- icon: _jsx(IconCode, {}),
20
- },
21
- {
22
- title: "Mentor",
23
- description: "Helping others skip the dumb mistakes I made.",
24
- icon: _jsx(IconSchool, {}),
25
- },
26
- {
27
- title: "Researcher",
28
- description: "Curious by default. I dig deep before I build.",
29
- icon: _jsx(IconMicroscope, {}),
30
- },
31
- {
32
- title: "Thinker",
33
- description: "Not everything I do ships — but it shapes what does.",
34
- icon: _jsx(IconBooks, {}),
35
- },
36
- {
37
- title: "Writer",
38
- description: "Sometimes code, sometimes essays, sometimes late-night rambles.",
39
- icon: _jsx(IconWriting, {}),
40
- },
41
- {
42
- title: "Human",
43
- description: "Imperfect. Learning. Figuring it out like the rest of us.",
44
- icon: _jsx(IconUser, {}),
45
- },
46
- ];
47
- return (_jsx("div", { className: "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 relative z-10 py-20 max-w-7xl mx-auto", children: features.map((feature, index) => (_jsx(Feature, { ...feature, index: index }, feature.title))) }));
1
+ import { cn } from "../lib/utils.js";
2
+ import { jsx, jsxs } from "react/jsx-runtime";
3
+ import { IconBlocks, IconBooks, IconCode, IconMicroscope, IconRocket, IconSchool, IconUser, IconWriting } from "@tabler/icons-react";
4
+ //#region src/components/features-section-demo-2.tsx
5
+ function FeaturesSectionDemo() {
6
+ return /* @__PURE__ */ jsx("div", {
7
+ className: "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 relative z-10 py-20 max-w-7xl mx-auto",
8
+ children: [
9
+ {
10
+ title: "Founder",
11
+ description: "I turn zero into one. Sometimes into ten.",
12
+ icon: /* @__PURE__ */ jsx(IconBlocks, {})
13
+ },
14
+ {
15
+ title: "Entrepreneur",
16
+ description: "I chase opportunities, not job titles.",
17
+ icon: /* @__PURE__ */ jsx(IconRocket, {})
18
+ },
19
+ {
20
+ title: "Developer",
21
+ description: "I speak fluent JavaScript and problem-solving.",
22
+ icon: /* @__PURE__ */ jsx(IconCode, {})
23
+ },
24
+ {
25
+ title: "Mentor",
26
+ description: "Helping others skip the dumb mistakes I made.",
27
+ icon: /* @__PURE__ */ jsx(IconSchool, {})
28
+ },
29
+ {
30
+ title: "Researcher",
31
+ description: "Curious by default. I dig deep before I build.",
32
+ icon: /* @__PURE__ */ jsx(IconMicroscope, {})
33
+ },
34
+ {
35
+ title: "Thinker",
36
+ description: "Not everything I do ships — but it shapes what does.",
37
+ icon: /* @__PURE__ */ jsx(IconBooks, {})
38
+ },
39
+ {
40
+ title: "Writer",
41
+ description: "Sometimes code, sometimes essays, sometimes late-night rambles.",
42
+ icon: /* @__PURE__ */ jsx(IconWriting, {})
43
+ },
44
+ {
45
+ title: "Human",
46
+ description: "Imperfect. Learning. Figuring it out like the rest of us.",
47
+ icon: /* @__PURE__ */ jsx(IconUser, {})
48
+ }
49
+ ].map((feature, index) => /* @__PURE__ */ jsx(Feature, {
50
+ ...feature,
51
+ index
52
+ }, feature.title))
53
+ });
48
54
  }
49
- const Feature = ({ title, description, icon, index, }) => {
50
- return (_jsxs("div", { className: cn("flex flex-col lg:border-r py-10 relative group/feature dark:border-neutral-800", (index === 0 || index === 4) && "lg:border-l dark:border-neutral-800", index < 4 && "lg:border-b dark:border-neutral-800"), children: [index < 4 && (_jsx("div", { className: "opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-t from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none" })), index >= 4 && (_jsx("div", { className: "opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-b from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none" })), _jsx("div", { className: "mb-4 relative z-10 px-10 text-neutral-600 dark:text-neutral-400", children: icon }), _jsxs("div", { className: "text-lg font-bold mb-2 relative z-10 px-10", children: [_jsx("div", { className: "absolute left-0 inset-y-0 h-6 group-hover/feature:h-8 w-1 rounded-tr-full rounded-br-full bg-neutral-300 dark:bg-neutral-700 group-hover/feature:bg-blue-500 transition-all duration-200 origin-center" }), _jsx("span", { className: "group-hover/feature:translate-x-2 transition duration-200 inline-block text-neutral-800 dark:text-neutral-100", children: title })] }), _jsx("p", { className: "text-sm text-neutral-600 dark:text-neutral-300 max-w-xs relative z-10 px-10", children: description })] }));
55
+ const Feature = ({ title, description, icon, index }) => {
56
+ return /* @__PURE__ */ jsxs("div", {
57
+ className: cn("flex flex-col lg:border-r py-10 relative group/feature dark:border-neutral-800", (index === 0 || index === 4) && "lg:border-l dark:border-neutral-800", index < 4 && "lg:border-b dark:border-neutral-800"),
58
+ children: [
59
+ index < 4 && /* @__PURE__ */ jsx("div", { className: "opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-t from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none" }),
60
+ index >= 4 && /* @__PURE__ */ jsx("div", { className: "opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-b from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none" }),
61
+ /* @__PURE__ */ jsx("div", {
62
+ className: "mb-4 relative z-10 px-10 text-neutral-600 dark:text-neutral-400",
63
+ children: icon
64
+ }),
65
+ /* @__PURE__ */ jsxs("div", {
66
+ className: "text-lg font-bold mb-2 relative z-10 px-10",
67
+ children: [/* @__PURE__ */ jsx("div", { className: "absolute left-0 inset-y-0 h-6 group-hover/feature:h-8 w-1 rounded-tr-full rounded-br-full bg-neutral-300 dark:bg-neutral-700 group-hover/feature:bg-blue-500 transition-all duration-200 origin-center" }), /* @__PURE__ */ jsx("span", {
68
+ className: "group-hover/feature:translate-x-2 transition duration-200 inline-block text-neutral-800 dark:text-neutral-100",
69
+ children: title
70
+ })]
71
+ }),
72
+ /* @__PURE__ */ jsx("p", {
73
+ className: "text-sm text-neutral-600 dark:text-neutral-300 max-w-xs relative z-10 px-10",
74
+ children: description
75
+ })
76
+ ]
77
+ });
51
78
  };
79
+ //#endregion
80
+ export { FeaturesSectionDemo as default };
81
+
82
+ //# sourceMappingURL=features-section-demo-2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"features-section-demo-2.js","names":[],"sources":["../../../src/components/features-section-demo-2.tsx"],"sourcesContent":["import {\r\n IconBlocks,\r\n IconBooks,\r\n IconCode,\r\n IconMicroscope,\r\n IconRocket,\r\n IconSchool,\r\n IconUser,\r\n IconWriting,\r\n} from \"@tabler/icons-react\";\r\nimport { cn } from \"../lib/utils\";\r\n\r\nexport default function FeaturesSectionDemo() {\r\n const features = [\r\n {\r\n title: \"Founder\",\r\n description: \"I turn zero into one. Sometimes into ten.\",\r\n icon: <IconBlocks />,\r\n },\r\n {\r\n title: \"Entrepreneur\",\r\n description: \"I chase opportunities, not job titles.\",\r\n icon: <IconRocket />,\r\n },\r\n {\r\n title: \"Developer\",\r\n description: \"I speak fluent JavaScript and problem-solving.\",\r\n icon: <IconCode />,\r\n },\r\n {\r\n title: \"Mentor\",\r\n description: \"Helping others skip the dumb mistakes I made.\",\r\n icon: <IconSchool />,\r\n },\r\n {\r\n title: \"Researcher\",\r\n description: \"Curious by default. I dig deep before I build.\",\r\n icon: <IconMicroscope />,\r\n },\r\n {\r\n title: \"Thinker\",\r\n description: \"Not everything I do ships — but it shapes what does.\",\r\n icon: <IconBooks />,\r\n },\r\n {\r\n title: \"Writer\",\r\n description: \"Sometimes code, sometimes essays, sometimes late-night rambles.\",\r\n icon: <IconWriting />,\r\n },\r\n {\r\n title: \"Human\",\r\n description: \"Imperfect. Learning. Figuring it out like the rest of us.\",\r\n icon: <IconUser />,\r\n },\r\n ];\r\n return (\r\n <div className=\"grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 relative z-10 py-20 max-w-7xl mx-auto\">\r\n {features.map((feature, index) => (\r\n <Feature key={feature.title} {...feature} index={index} />\r\n ))}\r\n </div>\r\n );\r\n}\r\n\r\nconst Feature = ({\r\n title,\r\n description,\r\n icon,\r\n index,\r\n}: {\r\n title: string;\r\n description: string;\r\n icon: React.ReactNode;\r\n index: number;\r\n}) => {\r\n return (\r\n <div\r\n className={cn(\r\n \"flex flex-col lg:border-r py-10 relative group/feature dark:border-neutral-800\",\r\n (index === 0 || index === 4) && \"lg:border-l dark:border-neutral-800\",\r\n index < 4 && \"lg:border-b dark:border-neutral-800\"\r\n )}\r\n >\r\n {index < 4 && (\r\n <div className=\"opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-t from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none\" />\r\n )}\r\n {index >= 4 && (\r\n <div className=\"opacity-0 group-hover/feature:opacity-100 transition duration-200 absolute inset-0 h-full w-full bg-gradient-to-b from-neutral-100 dark:from-neutral-800 to-transparent pointer-events-none\" />\r\n )}\r\n <div className=\"mb-4 relative z-10 px-10 text-neutral-600 dark:text-neutral-400\">{icon}</div>\r\n <div className=\"text-lg font-bold mb-2 relative z-10 px-10\">\r\n <div className=\"absolute left-0 inset-y-0 h-6 group-hover/feature:h-8 w-1 rounded-tr-full rounded-br-full bg-neutral-300 dark:bg-neutral-700 group-hover/feature:bg-blue-500 transition-all duration-200 origin-center\" />\r\n <span className=\"group-hover/feature:translate-x-2 transition duration-200 inline-block text-neutral-800 dark:text-neutral-100\">\r\n {title}\r\n </span>\r\n </div>\r\n <p className=\"text-sm text-neutral-600 dark:text-neutral-300 max-w-xs relative z-10 px-10\">\r\n {description}\r\n </p>\r\n </div>\r\n );\r\n};\r\n"],"mappings":";;;;AAYA,SAAwB,sBAAsB;AA2C5C,QACE,oBAAC,OAAD;EAAK,WAAU;YA3CA;GACf;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,YAAD,EAAc,CAAA;IACrB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,YAAD,EAAc,CAAA;IACrB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,UAAD,EAAY,CAAA;IACnB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,YAAD,EAAc,CAAA;IACrB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,gBAAD,EAAkB,CAAA;IACzB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,WAAD,EAAa,CAAA;IACpB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,aAAD,EAAe,CAAA;IACtB;GACD;IACE,OAAO;IACP,aAAa;IACb,MAAM,oBAAC,UAAD,EAAY,CAAA;IACnB;GACF,CAGa,KAAK,SAAS,UACtB,oBAAC,SAAD;GAA6B,GAAI;GAAgB;GAAS,EAA5C,QAAQ,MAAoC,CAC1D;EACE,CAAA;;AAIV,MAAM,WAAW,EACf,OACA,aACA,MACA,YAMI;AACJ,QACE,qBAAC,OAAD;EACE,WAAW,GACT,oFACC,UAAU,KAAK,UAAU,MAAM,uCAChC,QAAQ,KAAK,sCACd;YALH;GAOG,QAAQ,KACP,oBAAC,OAAD,EAAK,WAAU,+LAAgM,CAAA;GAEhN,SAAS,KACR,oBAAC,OAAD,EAAK,WAAU,+LAAgM,CAAA;GAEjN,oBAAC,OAAD;IAAK,WAAU;cAAmE;IAAW,CAAA;GAC7F,qBAAC,OAAD;IAAK,WAAU;cAAf,CACE,oBAAC,OAAD,EAAK,WAAU,0MAA2M,CAAA,EAC1N,oBAAC,QAAD;KAAM,WAAU;eACb;KACI,CAAA,CACH;;GACN,oBAAC,KAAD;IAAG,WAAU;cACV;IACC,CAAA;GACA"}
@@ -1,8 +1,16 @@
1
- export default function FeaturesSectionDemo(): import("react/jsx-runtime").JSX.Element;
2
- export declare const SkeletonOne: () => import("react/jsx-runtime").JSX.Element;
3
- export declare const SkeletonThree: () => import("react/jsx-runtime").JSX.Element;
4
- export declare const SkeletonTwo: () => import("react/jsx-runtime").JSX.Element;
5
- export declare const SkeletonFour: () => import("react/jsx-runtime").JSX.Element;
6
- export declare const Globe: ({ className }: {
7
- className?: string;
8
- }) => import("react/jsx-runtime").JSX.Element;
1
+ import * as _$react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components/features-section-demo-3.d.ts
4
+ declare function FeaturesSectionDemo(): _$react_jsx_runtime0.JSX.Element;
5
+ declare const SkeletonOne: () => _$react_jsx_runtime0.JSX.Element;
6
+ declare const SkeletonThree: () => _$react_jsx_runtime0.JSX.Element;
7
+ declare const SkeletonTwo: () => _$react_jsx_runtime0.JSX.Element;
8
+ declare const SkeletonFour: () => _$react_jsx_runtime0.JSX.Element;
9
+ declare const Globe: ({
10
+ className
11
+ }: {
12
+ className?: string;
13
+ }) => _$react_jsx_runtime0.JSX.Element;
14
+ //#endregion
15
+ export { Globe, SkeletonFour, SkeletonOne, SkeletonThree, SkeletonTwo, FeaturesSectionDemo as default };
16
+ //# sourceMappingURL=features-section-demo-3.d.ts.map