nextworks 0.0.1 → 0.1.0-alpha.1

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 (277) hide show
  1. package/README.md +209 -30
  2. package/dist/.gitkeep +0 -0
  3. package/dist/cli_manifests/auth_manifest.json +86 -0
  4. package/dist/cli_manifests/blocks_manifest.json +185 -0
  5. package/dist/cli_manifests/data_manifest.json +51 -0
  6. package/dist/cli_manifests/forms_manifest.json +61 -0
  7. package/dist/commands/admin-posts.d.ts +2 -0
  8. package/dist/commands/admin-posts.d.ts.map +1 -0
  9. package/dist/commands/admin-posts.js +15 -0
  10. package/dist/commands/admin-posts.js.map +1 -0
  11. package/dist/commands/admin-users.d.ts +2 -0
  12. package/dist/commands/admin-users.d.ts.map +1 -0
  13. package/dist/commands/admin-users.js +15 -0
  14. package/dist/commands/admin-users.js.map +1 -0
  15. package/dist/commands/auth-core.d.ts +2 -0
  16. package/dist/commands/auth-core.d.ts.map +1 -0
  17. package/dist/commands/auth-core.js +83 -0
  18. package/dist/commands/auth-core.js.map +1 -0
  19. package/dist/commands/auth-forms.d.ts +2 -0
  20. package/dist/commands/auth-forms.d.ts.map +1 -0
  21. package/dist/commands/auth-forms.js +15 -0
  22. package/dist/commands/auth-forms.js.map +1 -0
  23. package/dist/commands/blocks-options.d.ts +7 -0
  24. package/dist/commands/blocks-options.d.ts.map +1 -0
  25. package/dist/commands/blocks-options.js +19 -0
  26. package/dist/commands/blocks-options.js.map +1 -0
  27. package/dist/commands/blocks.d.ts +7 -0
  28. package/dist/commands/blocks.d.ts.map +1 -0
  29. package/dist/commands/blocks.js +145 -0
  30. package/dist/commands/blocks.js.map +1 -0
  31. package/dist/commands/data.d.ts +3 -0
  32. package/dist/commands/data.d.ts.map +1 -0
  33. package/dist/commands/data.js +88 -0
  34. package/dist/commands/data.js.map +1 -0
  35. package/dist/commands/forms.d.ts +6 -0
  36. package/dist/commands/forms.d.ts.map +1 -0
  37. package/dist/commands/forms.js +107 -0
  38. package/dist/commands/forms.js.map +1 -0
  39. package/dist/commands/remove-auth-core.d.ts +2 -0
  40. package/dist/commands/remove-auth-core.d.ts.map +1 -0
  41. package/dist/commands/remove-auth-core.js +69 -0
  42. package/dist/commands/remove-auth-core.js.map +1 -0
  43. package/dist/commands/remove-blocks.d.ts +2 -0
  44. package/dist/commands/remove-blocks.d.ts.map +1 -0
  45. package/dist/commands/remove-blocks.js +36 -0
  46. package/dist/commands/remove-blocks.js.map +1 -0
  47. package/dist/index.d.ts +3 -0
  48. package/dist/index.d.ts.map +1 -0
  49. package/dist/index.js +109 -0
  50. package/dist/index.js.map +1 -0
  51. package/dist/kits/auth-core/README.md +106 -0
  52. package/dist/kits/auth-core/app/(protected)/dashboard/page.tsx +8 -0
  53. package/dist/kits/auth-core/app/(protected)/layout.tsx +18 -0
  54. package/dist/kits/auth-core/app/(protected)/settings/profile/page.tsx +15 -0
  55. package/dist/kits/auth-core/app/(protected)/settings/profile/profile-form.tsx +114 -0
  56. package/dist/kits/auth-core/app/api/auth/[...nextauth]/route.ts +1 -0
  57. package/dist/kits/auth-core/app/api/auth/forgot-password/route.ts +114 -0
  58. package/dist/kits/auth-core/app/api/auth/providers/route.ts +6 -0
  59. package/dist/kits/auth-core/app/api/auth/reset-password/route.ts +63 -0
  60. package/dist/kits/auth-core/app/api/auth/send-verify-email/route.ts +6 -0
  61. package/dist/kits/auth-core/app/api/signup/route.ts +41 -0
  62. package/dist/kits/auth-core/app/auth/forgot-password/page.tsx +21 -0
  63. package/dist/kits/auth-core/app/auth/login/page.tsx +5 -0
  64. package/dist/kits/auth-core/app/auth/reset-password/page.tsx +187 -0
  65. package/dist/kits/auth-core/app/auth/signup/page.tsx +5 -0
  66. package/dist/kits/auth-core/app/auth/verify-email/page.tsx +11 -0
  67. package/dist/kits/auth-core/components/admin/admin-header.tsx +57 -0
  68. package/dist/kits/auth-core/components/auth/dashboard.tsx +237 -0
  69. package/dist/kits/auth-core/components/auth/forgot-password-form.tsx +90 -0
  70. package/dist/kits/auth-core/components/auth/login-form.tsx +467 -0
  71. package/dist/kits/auth-core/components/auth/logout-button.tsx +50 -0
  72. package/dist/kits/auth-core/components/auth/minimal-logout-button.tsx +40 -0
  73. package/dist/kits/auth-core/components/auth/signup-form.tsx +468 -0
  74. package/dist/kits/auth-core/components/require-auth.tsx +59 -0
  75. package/dist/kits/auth-core/components/session-provider.tsx +11 -0
  76. package/dist/kits/auth-core/components/ui/README.txt +1 -0
  77. package/dist/kits/auth-core/components/ui/button.tsx +55 -0
  78. package/dist/kits/auth-core/components/ui/input.tsx +25 -0
  79. package/dist/kits/auth-core/components/ui/label.tsx +23 -0
  80. package/dist/kits/auth-core/lib/api/errors.ts +14 -0
  81. package/dist/kits/auth-core/lib/auth-helpers.ts +29 -0
  82. package/dist/kits/auth-core/lib/auth.ts +142 -0
  83. package/dist/kits/auth-core/lib/email/dev-transport.ts +42 -0
  84. package/dist/kits/auth-core/lib/email/index.ts +28 -0
  85. package/dist/kits/auth-core/lib/email/provider-smtp.ts +36 -0
  86. package/dist/kits/auth-core/lib/forms/map-errors.ts +11 -0
  87. package/dist/kits/auth-core/lib/hash.ts +6 -0
  88. package/dist/kits/auth-core/lib/prisma.ts +15 -0
  89. package/dist/kits/auth-core/lib/server/result.ts +45 -0
  90. package/dist/kits/auth-core/lib/utils.ts +6 -0
  91. package/dist/kits/auth-core/lib/validation/forms.ts +88 -0
  92. package/dist/kits/auth-core/package-deps.json +19 -0
  93. package/dist/kits/auth-core/prisma/auth-models.prisma +81 -0
  94. package/dist/kits/auth-core/prisma/schema.prisma +81 -0
  95. package/dist/kits/auth-core/scripts/populate-tokenhash.mjs +26 -0
  96. package/dist/kits/auth-core/scripts/promote-admin.mjs +33 -0
  97. package/dist/kits/auth-core/scripts/seed-demo.mjs +40 -0
  98. package/dist/kits/auth-core/types/next-auth.d.ts +25 -0
  99. package/dist/kits/blocks/README.md +53 -0
  100. package/dist/kits/blocks/app/globals.css +175 -0
  101. package/dist/kits/blocks/app/templates/digitalagency/PresetThemeVars.tsx +80 -0
  102. package/dist/kits/blocks/app/templates/digitalagency/README.md +36 -0
  103. package/dist/kits/blocks/app/templates/digitalagency/components/About.tsx +99 -0
  104. package/dist/kits/blocks/app/templates/digitalagency/components/CTA.tsx +74 -0
  105. package/dist/kits/blocks/app/templates/digitalagency/components/Contact.tsx +227 -0
  106. package/dist/kits/blocks/app/templates/digitalagency/components/Footer.tsx +89 -0
  107. package/dist/kits/blocks/app/templates/digitalagency/components/Hero.tsx +90 -0
  108. package/dist/kits/blocks/app/templates/digitalagency/components/Navbar.tsx +168 -0
  109. package/dist/kits/blocks/app/templates/digitalagency/components/NetworkPattern.tsx +297 -0
  110. package/dist/kits/blocks/app/templates/digitalagency/components/Portfolio.tsx +157 -0
  111. package/dist/kits/blocks/app/templates/digitalagency/components/Pricing.tsx +114 -0
  112. package/dist/kits/blocks/app/templates/digitalagency/components/Process.tsx +59 -0
  113. package/dist/kits/blocks/app/templates/digitalagency/components/Services.tsx +55 -0
  114. package/dist/kits/blocks/app/templates/digitalagency/components/Team.tsx +28 -0
  115. package/dist/kits/blocks/app/templates/digitalagency/components/Testimonials.tsx +65 -0
  116. package/dist/kits/blocks/app/templates/digitalagency/page.tsx +38 -0
  117. package/dist/kits/blocks/app/templates/gallery/PresetThemeVars.tsx +85 -0
  118. package/dist/kits/blocks/app/templates/gallery/page.tsx +303 -0
  119. package/dist/kits/blocks/app/templates/productlaunch/PresetThemeVars.tsx +74 -0
  120. package/dist/kits/blocks/app/templates/productlaunch/README.md +55 -0
  121. package/dist/kits/blocks/app/templates/productlaunch/components/About.tsx +178 -0
  122. package/dist/kits/blocks/app/templates/productlaunch/components/CTA.tsx +93 -0
  123. package/dist/kits/blocks/app/templates/productlaunch/components/Contact.tsx +231 -0
  124. package/dist/kits/blocks/app/templates/productlaunch/components/FAQ.tsx +93 -0
  125. package/dist/kits/blocks/app/templates/productlaunch/components/Features.tsx +84 -0
  126. package/dist/kits/blocks/app/templates/productlaunch/components/Footer.tsx +132 -0
  127. package/dist/kits/blocks/app/templates/productlaunch/components/Hero.tsx +89 -0
  128. package/dist/kits/blocks/app/templates/productlaunch/components/Navbar.tsx +162 -0
  129. package/dist/kits/blocks/app/templates/productlaunch/components/Pricing.tsx +106 -0
  130. package/dist/kits/blocks/app/templates/productlaunch/components/ProcessTimeline.tsx +110 -0
  131. package/dist/kits/blocks/app/templates/productlaunch/components/ServicesGrid.tsx +68 -0
  132. package/dist/kits/blocks/app/templates/productlaunch/components/Team.tsx +104 -0
  133. package/dist/kits/blocks/app/templates/productlaunch/components/Testimonials.tsx +89 -0
  134. package/dist/kits/blocks/app/templates/productlaunch/components/TrustBadges.tsx +76 -0
  135. package/dist/kits/blocks/app/templates/productlaunch/page.tsx +45 -0
  136. package/dist/kits/blocks/app/templates/saasdashboard/PresetThemeVars.tsx +80 -0
  137. package/dist/kits/blocks/app/templates/saasdashboard/README.md +38 -0
  138. package/dist/kits/blocks/app/templates/saasdashboard/components/Contact.tsx +176 -0
  139. package/dist/kits/blocks/app/templates/saasdashboard/components/Dashboard.tsx +293 -0
  140. package/dist/kits/blocks/app/templates/saasdashboard/components/FAQ.tsx +55 -0
  141. package/dist/kits/blocks/app/templates/saasdashboard/components/Features.tsx +91 -0
  142. package/dist/kits/blocks/app/templates/saasdashboard/components/Footer.tsx +77 -0
  143. package/dist/kits/blocks/app/templates/saasdashboard/components/Hero.tsx +105 -0
  144. package/dist/kits/blocks/app/templates/saasdashboard/components/Hero_mask.tsx +127 -0
  145. package/dist/kits/blocks/app/templates/saasdashboard/components/Navbar.tsx +159 -0
  146. package/dist/kits/blocks/app/templates/saasdashboard/components/Pricing.tsx +90 -0
  147. package/dist/kits/blocks/app/templates/saasdashboard/components/SmoothScroll.tsx +97 -0
  148. package/dist/kits/blocks/app/templates/saasdashboard/components/Testimonials.tsx +72 -0
  149. package/dist/kits/blocks/app/templates/saasdashboard/components/TrustBadges.tsx +53 -0
  150. package/dist/kits/blocks/app/templates/saasdashboard/page.tsx +39 -0
  151. package/dist/kits/blocks/components/app-providers.tsx +1 -0
  152. package/dist/kits/blocks/components/enhanced-theme-provider.tsx +195 -0
  153. package/dist/kits/blocks/components/sections/About.tsx +291 -0
  154. package/dist/kits/blocks/components/sections/CTA.tsx +258 -0
  155. package/dist/kits/blocks/components/sections/Contact.tsx +267 -0
  156. package/dist/kits/blocks/components/sections/FAQ.tsx +226 -0
  157. package/dist/kits/blocks/components/sections/Features.tsx +269 -0
  158. package/dist/kits/blocks/components/sections/Footer.tsx +302 -0
  159. package/dist/kits/blocks/components/sections/HeroMotion.tsx +307 -0
  160. package/dist/kits/blocks/components/sections/HeroOverlay.tsx +358 -0
  161. package/dist/kits/blocks/components/sections/HeroSplit.tsx +352 -0
  162. package/dist/kits/blocks/components/sections/Navbar.tsx +353 -0
  163. package/dist/kits/blocks/components/sections/Newsletter.tsx +156 -0
  164. package/dist/kits/blocks/components/sections/PortfolioSimple.tsx +550 -0
  165. package/dist/kits/blocks/components/sections/Pricing.tsx +264 -0
  166. package/dist/kits/blocks/components/sections/ProcessTimeline.tsx +325 -0
  167. package/dist/kits/blocks/components/sections/ServicesGrid.tsx +210 -0
  168. package/dist/kits/blocks/components/sections/Team.tsx +309 -0
  169. package/dist/kits/blocks/components/sections/Testimonials.tsx +158 -0
  170. package/dist/kits/blocks/components/sections/TrustBadges.tsx +162 -0
  171. package/dist/kits/blocks/components/theme-provider.tsx +34 -0
  172. package/dist/kits/blocks/components/ui/alert-dialog.tsx +134 -0
  173. package/dist/kits/blocks/components/ui/brand-node.tsx +121 -0
  174. package/dist/kits/blocks/components/ui/button.tsx +122 -0
  175. package/dist/kits/blocks/components/ui/button_bck.tsx +93 -0
  176. package/dist/kits/blocks/components/ui/card.tsx +95 -0
  177. package/dist/kits/blocks/components/ui/checkbox.tsx +30 -0
  178. package/dist/kits/blocks/components/ui/cta-button.tsx +125 -0
  179. package/dist/kits/blocks/components/ui/dropdown-menu.tsx +201 -0
  180. package/dist/kits/blocks/components/ui/feature-card.tsx +91 -0
  181. package/dist/kits/blocks/components/ui/input.tsx +27 -0
  182. package/dist/kits/blocks/components/ui/label.tsx +29 -0
  183. package/dist/kits/blocks/components/ui/pricing-card.tsx +120 -0
  184. package/dist/kits/blocks/components/ui/select.tsx +25 -0
  185. package/dist/kits/blocks/components/ui/skeleton.tsx +13 -0
  186. package/dist/kits/blocks/components/ui/switch.tsx +78 -0
  187. package/dist/kits/blocks/components/ui/table.tsx +98 -0
  188. package/dist/kits/blocks/components/ui/testimonial-card.tsx +108 -0
  189. package/dist/kits/blocks/components/ui/textarea.tsx +26 -0
  190. package/dist/kits/blocks/components/ui/theme-selector.tsx +247 -0
  191. package/dist/kits/blocks/components/ui/theme-toggle.tsx +74 -0
  192. package/dist/kits/blocks/components/ui/toaster.tsx +7 -0
  193. package/dist/kits/blocks/lib/themes.ts +399 -0
  194. package/dist/kits/blocks/lib/themes_old.ts +37 -0
  195. package/dist/kits/blocks/lib/utils.ts +9 -0
  196. package/dist/kits/blocks/next.config.ts +11 -0
  197. package/dist/kits/blocks/notes/THEME_GUIDE.md +29 -0
  198. package/dist/kits/blocks/notes/THEMING_CONVERSION_SUMMARY.md +14 -0
  199. package/dist/kits/blocks/package-deps.json +22 -0
  200. package/dist/kits/blocks/public/placeholders/gallery/hero-pexels-broken-9945014.avif +0 -0
  201. package/dist/kits/blocks/public/placeholders/gallery/pexels-googledeepmind-25626431.jpg +0 -0
  202. package/dist/kits/blocks/public/placeholders/gallery/pexels-googledeepmind-25626432.jpg +0 -0
  203. package/dist/kits/blocks/public/placeholders/gallery/pexels-googledeepmind-25626434.jpg +0 -0
  204. package/dist/kits/blocks/public/placeholders/gallery/pexels-googledeepmind-25626436.jpg +0 -0
  205. package/dist/kits/blocks/public/placeholders/product_launch/feature_1.png +0 -0
  206. package/dist/kits/blocks/public/placeholders/product_launch/feature_2.png +0 -0
  207. package/dist/kits/blocks/public/placeholders/product_launch/feature_3.png +0 -0
  208. package/dist/kits/blocks/public/placeholders/product_launch/feature_4.png +0 -0
  209. package/dist/kits/blocks/public/placeholders/product_launch/hero.png +0 -0
  210. package/dist/kits/blocks/public/placeholders/saas_dashboard/analytics.png +0 -0
  211. package/dist/kits/blocks/public/placeholders/saas_dashboard/chat.png +0 -0
  212. package/dist/kits/blocks/public/placeholders/saas_dashboard/projectBoard.png +0 -0
  213. package/dist/kits/data/.gitkeep +0 -0
  214. package/dist/kits/data/README.md +104 -0
  215. package/dist/kits/data/app/(protected)/admin/posts/page.tsx +5 -0
  216. package/dist/kits/data/app/(protected)/admin/users/page.tsx +5 -0
  217. package/dist/kits/data/app/api/posts/[id]/route.ts +83 -0
  218. package/dist/kits/data/app/api/posts/route.ts +138 -0
  219. package/dist/kits/data/app/api/seed-demo/route.ts +45 -0
  220. package/dist/kits/data/app/api/users/[id]/route.ts +127 -0
  221. package/dist/kits/data/app/api/users/check-email/route.ts +18 -0
  222. package/dist/kits/data/app/api/users/check-unique/route.ts +27 -0
  223. package/dist/kits/data/app/api/users/route.ts +79 -0
  224. package/dist/kits/data/app/examples/demo/README.md +4 -0
  225. package/dist/kits/data/app/examples/demo/create-post-form.tsx +106 -0
  226. package/dist/kits/data/app/examples/demo/page.tsx +118 -0
  227. package/dist/kits/data/app/examples/demo/seed-demo-button.tsx +37 -0
  228. package/dist/kits/data/components/admin/posts-manager.tsx +719 -0
  229. package/dist/kits/data/components/admin/users-manager.tsx +432 -0
  230. package/dist/kits/data/lib/prisma.ts +15 -0
  231. package/dist/kits/data/lib/server/result.ts +90 -0
  232. package/dist/kits/data/package-deps.json +11 -0
  233. package/dist/kits/data/scripts/seed-demo.mjs +41 -0
  234. package/dist/kits/forms/.gitkeep +0 -0
  235. package/dist/kits/forms/README.md +49 -0
  236. package/dist/kits/forms/app/.gitkeep +0 -0
  237. package/dist/kits/forms/app/api/wizard/route.ts +71 -0
  238. package/dist/kits/forms/app/examples/forms/basic/page.tsx +124 -0
  239. package/dist/kits/forms/app/examples/forms/server-action/form-client.tsx +28 -0
  240. package/dist/kits/forms/app/examples/forms/server-action/page.tsx +71 -0
  241. package/dist/kits/forms/app/examples/forms/wizard/page.tsx +15 -0
  242. package/dist/kits/forms/app/examples/forms/wizard/wizard-client.tsx +2 -0
  243. package/dist/kits/forms/components/.gitkeep +0 -0
  244. package/dist/kits/forms/components/examples/wizard-client.tsx +231 -0
  245. package/dist/kits/forms/components/hooks/useCheckUnique.ts +79 -0
  246. package/dist/kits/forms/components/ui/button.tsx +122 -0
  247. package/dist/kits/forms/components/ui/checkbox.tsx +30 -0
  248. package/dist/kits/forms/components/ui/form/context.ts +33 -0
  249. package/dist/kits/forms/components/ui/form/form-control.tsx +28 -0
  250. package/dist/kits/forms/components/ui/form/form-description.tsx +22 -0
  251. package/dist/kits/forms/components/ui/form/form-field.tsx +36 -0
  252. package/dist/kits/forms/components/ui/form/form-item.tsx +21 -0
  253. package/dist/kits/forms/components/ui/form/form-label.tsx +24 -0
  254. package/dist/kits/forms/components/ui/form/form-message.tsx +29 -0
  255. package/dist/kits/forms/components/ui/form/form.tsx +26 -0
  256. package/dist/kits/forms/components/ui/input.tsx +27 -0
  257. package/dist/kits/forms/components/ui/label.tsx +29 -0
  258. package/dist/kits/forms/components/ui/select.tsx +25 -0
  259. package/dist/kits/forms/components/ui/switch.tsx +78 -0
  260. package/dist/kits/forms/components/ui/textarea.tsx +26 -0
  261. package/dist/kits/forms/lib/.gitkeep +0 -0
  262. package/dist/kits/forms/lib/forms/map-errors.ts +29 -0
  263. package/dist/kits/forms/lib/prisma.ts +16 -0
  264. package/dist/kits/forms/lib/utils.ts +9 -0
  265. package/dist/kits/forms/lib/validation/forms.ts +88 -0
  266. package/dist/kits/forms/lib/validation/wizard.ts +32 -0
  267. package/dist/kits/forms/package-deps.json +17 -0
  268. package/dist/utils/file-operations.d.ts +18 -0
  269. package/dist/utils/file-operations.d.ts.map +1 -0
  270. package/dist/utils/file-operations.js +327 -0
  271. package/dist/utils/file-operations.js.map +1 -0
  272. package/dist/utils/installation-tracker.d.ts +26 -0
  273. package/dist/utils/installation-tracker.d.ts.map +1 -0
  274. package/dist/utils/installation-tracker.js +98 -0
  275. package/dist/utils/installation-tracker.js.map +1 -0
  276. package/package.json +51 -21
  277. package/index.js +0 -1
@@ -0,0 +1,293 @@
1
+ "use client";
2
+
3
+ import React, { useEffect, useRef, useState } from "react";
4
+
5
+ type FloatingCard = {
6
+ position: string;
7
+ icon: string;
8
+ text: string;
9
+ };
10
+
11
+ type Stat = {
12
+ value: string;
13
+ label: string;
14
+ };
15
+
16
+ interface DashboardProps {
17
+ stats: Stat[];
18
+ projects: string[];
19
+ floatingCards: FloatingCard[];
20
+ activeTab?: string;
21
+ navItems?: string[];
22
+ }
23
+
24
+ export function Dashboard({
25
+ stats,
26
+ projects,
27
+ floatingCards,
28
+ activeTab = "Analytics",
29
+ navItems = ["Analytics", "Projects", "Team"],
30
+ }: DashboardProps) {
31
+ return (
32
+ <div className="relative isolate">
33
+ <DashboardMockup
34
+ stats={stats}
35
+ projects={projects}
36
+ activeTab={activeTab}
37
+ navItems={navItems}
38
+ />
39
+
40
+ {floatingCards.map(({ position, icon, text }) => (
41
+ <FloatingCard
42
+ key={position}
43
+ position={position}
44
+ icon={icon}
45
+ text={text}
46
+ />
47
+ ))}
48
+
49
+ <style jsx>{`
50
+ .dashboard-mockup {
51
+ transform: perspective(1000px) rotateY(-5deg) rotateX(5deg);
52
+ transition: transform 0.3s ease;
53
+ box-shadow: 0 25px 50px rgba(0, 0, 0, 0.3);
54
+ }
55
+ .dashboard-mockup:hover {
56
+ transform: perspective(1000px) rotateY(-2deg) rotateX(2deg);
57
+ }
58
+ .trend-line {
59
+ clip-path: polygon(
60
+ 0 100%,
61
+ 20% 80%,
62
+ 40% 85%,
63
+ 60% 60%,
64
+ 80% 50%,
65
+ 100% 20%
66
+ );
67
+ }
68
+ @keyframes growUp {
69
+ 0% {
70
+ height: 0;
71
+ opacity: 0;
72
+ }
73
+ 100% {
74
+ opacity: 1;
75
+ }
76
+ }
77
+ @keyframes floatAnim {
78
+ 0%,
79
+ 100% {
80
+ transform: translateY(0px);
81
+ }
82
+ 50% {
83
+ transform: translateY(-20px);
84
+ }
85
+ }
86
+ `}</style>
87
+ </div>
88
+ );
89
+ }
90
+
91
+ function DashboardMockup({
92
+ stats,
93
+ projects,
94
+ activeTab,
95
+ navItems,
96
+ }: {
97
+ stats: Stat[];
98
+ projects: string[];
99
+ activeTab?: string;
100
+ navItems?: string[];
101
+ }) {
102
+ const [tilt, setTilt] = useState({ rx: 0, ry: 0 });
103
+ const targetTilt = useRef({ rx: 0, ry: 0 });
104
+ const rafId = useRef<number | null>(null);
105
+
106
+ const animate = () => {
107
+ setTilt((prev) => {
108
+ const smoothing = 0.15;
109
+ const nextRx = prev.rx + (targetTilt.current.rx - prev.rx) * smoothing;
110
+ const nextRy = prev.ry + (targetTilt.current.ry - prev.ry) * smoothing;
111
+ return { rx: nextRx, ry: nextRy };
112
+ });
113
+ rafId.current = requestAnimationFrame(animate);
114
+ };
115
+
116
+ const handleMove: React.MouseEventHandler<HTMLDivElement> = (e) => {
117
+ const rect = e.currentTarget.getBoundingClientRect();
118
+ const x = e.clientX - rect.left;
119
+ const y = e.clientY - rect.top;
120
+ const rx = (y / rect.height - 0.5) * -6; // rotateX up to ~±3deg
121
+ const ry = (x / rect.width - 0.5) * 6; // rotateY up to ~±3deg
122
+ targetTilt.current = { rx, ry };
123
+ if (rafId.current == null) rafId.current = requestAnimationFrame(animate);
124
+ };
125
+
126
+ const handleLeave = () => {
127
+ targetTilt.current = { rx: 0, ry: 0 };
128
+ };
129
+
130
+ useEffect(() => {
131
+ return () => {
132
+ if (rafId.current != null) cancelAnimationFrame(rafId.current);
133
+ };
134
+ }, []);
135
+ return (
136
+ <div
137
+ className={
138
+ "dashboard-mockup transform-gpu rounded-2xl border border-blue-500/20 p-6 shadow-2xl ring-1 ring-blue-500/10 backdrop-blur transition-transform duration-150 ease-out motion-reduce:transition-none " +
139
+ "bg-slate-900/80 dark:bg-slate-900/80"
140
+ }
141
+ style={{
142
+ willChange: "transform",
143
+ transform: `perspective(1000px) rotateX(${tilt.rx}deg) rotateY(${tilt.ry}deg)`,
144
+ }}
145
+ onMouseMove={handleMove}
146
+ onMouseLeave={handleLeave}
147
+ >
148
+ <DashboardHeader activeTab={activeTab} navItems={navItems} />
149
+ <DashboardGrid stats={stats} projects={projects} />
150
+ </div>
151
+ );
152
+ }
153
+
154
+ function DashboardHeader({
155
+ activeTab = "Analytics",
156
+ navItems = ["Analytics", "Projects", "Team"],
157
+ }: {
158
+ activeTab?: string;
159
+ navItems?: string[];
160
+ }) {
161
+ return (
162
+ <div className="mb-6 flex items-center justify-between border-b border-blue-500/10 pb-4">
163
+ <div className="text-[1.1rem] font-semibold text-slate-200">
164
+ Business Overview
165
+ </div>
166
+ <div className="hidden gap-3 md:flex">
167
+ {navItems.map((item) => (
168
+ <div
169
+ key={item}
170
+ className={
171
+ "rounded-md px-3 py-2 text-sm " +
172
+ (item === activeTab
173
+ ? "bg-gradient-to-br from-blue-500 to-purple-500 text-white"
174
+ : "bg-blue-500/10 text-blue-400")
175
+ }
176
+ >
177
+ {item}
178
+ </div>
179
+ ))}
180
+ </div>
181
+ </div>
182
+ );
183
+ }
184
+
185
+ function DashboardGrid({
186
+ stats,
187
+ projects,
188
+ }: {
189
+ stats: Stat[];
190
+ projects: string[];
191
+ }) {
192
+ return (
193
+ <div className="mb-4 grid grid-cols-[2fr_1fr] gap-4">
194
+ <ChartArea />
195
+ <StatsPanel stats={stats} />
196
+ <ProjectList projects={projects} />
197
+ </div>
198
+ );
199
+ }
200
+
201
+ function ChartArea() {
202
+ const barHeights = [30, 45, 35, 60, 55, 75, 70, 85, 90, 100];
203
+ return (
204
+ <div className="relative overflow-hidden rounded-lg border border-blue-500/10 bg-slate-900/50 p-4">
205
+ <div className="mb-2 text-sm text-slate-300">Revenue Growth</div>
206
+ <div
207
+ className="relative h-32 overflow-hidden rounded-md"
208
+ style={{
209
+ background:
210
+ "linear-gradient(45deg, transparent 20%, rgba(59,130,246,0.1) 20%, rgba(59,130,246,0.1) 40%, transparent 40%, transparent 60%, rgba(139,92,246,0.1) 60%, rgba(139,92,246,0.1) 80%, transparent 80%)",
211
+ }}
212
+ >
213
+ <div className="absolute inset-[10px] flex items-end gap-[3px]">
214
+ {barHeights.map((h, i) => (
215
+ <div
216
+ key={i}
217
+ className="flex-1 rounded-t bg-gradient-to-b from-blue-500 to-purple-500"
218
+ style={{
219
+ minHeight: "20px",
220
+ height: `${h}%`,
221
+ animation: "growUp 2s ease-out both",
222
+ animationDelay: `${(i + 1) * 0.1}s`,
223
+ }}
224
+ />
225
+ ))}
226
+ </div>
227
+ <div className="trend-line absolute top-5 right-[5%] left-[5%] h-[2px] rounded bg-gradient-to-r from-emerald-500 to-blue-500 opacity-80" />
228
+ </div>
229
+ </div>
230
+ );
231
+ }
232
+
233
+ function StatsPanel({ stats }: { stats: Stat[] }) {
234
+ return (
235
+ <div className="flex flex-col gap-2">
236
+ {stats.map((s, i) => (
237
+ <div
238
+ key={i}
239
+ className="rounded-lg border border-blue-500/10 bg-slate-900/50 p-3"
240
+ >
241
+ <div className="text-lg font-bold text-blue-500">{s.value}</div>
242
+ <div className="text-[0.7rem] text-slate-400 uppercase">
243
+ {s.label}
244
+ </div>
245
+ </div>
246
+ ))}
247
+ </div>
248
+ );
249
+ }
250
+
251
+ function ProjectList({ projects }: { projects: string[] }) {
252
+ return (
253
+ <div className="col-span-2 rounded-lg border border-blue-500/10 bg-slate-900/50 p-4">
254
+ <div className="mb-2 text-sm text-slate-300">Active Projects</div>
255
+ <div className="flex flex-wrap gap-2">
256
+ {projects.map((p, i) => (
257
+ <div
258
+ key={i}
259
+ className="rounded border border-blue-500/30 bg-gradient-to-br from-blue-500/20 to-purple-500/10 px-2 py-2 text-[0.8rem] text-slate-200"
260
+ >
261
+ {p}
262
+ </div>
263
+ ))}
264
+ </div>
265
+ </div>
266
+ );
267
+ }
268
+
269
+ function FloatingCard({ position, icon, text }: FloatingCard) {
270
+ const positionClasses =
271
+ position === "card-1"
272
+ ? "top-[10%] right-[6%]"
273
+ : position === "card-2"
274
+ ? "bottom-[20%] left-[2%]"
275
+ : "top-0 left-0";
276
+
277
+ return (
278
+ <div
279
+ className={[
280
+ "absolute z-10 transform-gpu rounded-lg border border-blue-500/20 p-4 shadow-lg",
281
+ "animate-[floatAnim_6s_ease-in-out_infinite]",
282
+ "bg-slate-800 dark:bg-slate-900",
283
+ positionClasses,
284
+ ].join(" ")}
285
+ style={{ willChange: "transform" }}
286
+ >
287
+ <div className="mb-2 flex h-[30px] w-[30px] items-center justify-center rounded-md bg-gradient-to-br from-blue-500 to-purple-500 text-sm text-white">
288
+ {icon}
289
+ </div>
290
+ <div className="text-sm text-slate-300">{text}</div>
291
+ </div>
292
+ );
293
+ }
@@ -0,0 +1,55 @@
1
+ "use client";
2
+
3
+ import { FAQ as SharedFAQ } from "@/components/sections/FAQ";
4
+
5
+ const defaultFAQArray = [
6
+ {
7
+ question: "Can I migrate from other tools?",
8
+ answer: "Yes, we help with data import.",
9
+ },
10
+ {
11
+ question: "What integrations are available?",
12
+ answer: "50+ apps including Slack, Google, Zapier.",
13
+ },
14
+ { question: "How long does setup take?", answer: "Less than 15 minutes." },
15
+ {
16
+ question: "Is there a free trial?",
17
+ answer: "Yes — start a 14-day free trial with no credit card required.",
18
+ },
19
+ {
20
+ question: "What support do you offer?",
21
+ answer: "Email, chat, and dedicated onboarding for paid plans.",
22
+ },
23
+ {
24
+ question: "Are there discounts for teams or annual billing?",
25
+ answer:
26
+ "Yes — we offer team pricing and discounts for annual subscriptions.",
27
+ },
28
+ ];
29
+
30
+ export function FAQ() {
31
+ return (
32
+ <SharedFAQ
33
+ faqData={defaultFAQArray}
34
+ faqSectionHeaderText="Frequently Asked Questions"
35
+ section={{ className: "py-10 px-5 bg-background text-[var(--card-fg)]" }}
36
+ heading={{
37
+ className:
38
+ "text-3xl font-bold font-inter text-center mb-6 text-[var(--heading-fg)]",
39
+ }}
40
+ grid={{ className: "grid grid-cols-2 gap-4" }}
41
+ item={{ className: "mb-0" }}
42
+ questionButton={{
43
+ className:
44
+ "p-5 rounded-lg transition-all duration-200 flex items-center justify-between cursor-pointer shadow-lg hover:shadow-xl hover:-translate-y-0.5 font-inter bg-gradient-to-r from-sky-600 to-sky-700 hover:from-sky-700 hover:to-sky-800 text-white [--btn-ring:theme(colors.sky.500)] dark:[--btn-ring:theme(colors.sky.400)] [--btn-border:theme(colors.sky.500)] dark:[--btn-border:theme(colors.sky.400)]",
45
+ }}
46
+ questionText={{ className: "font-inter font-semibold text-base" }}
47
+ answer={{
48
+ className:
49
+ "mt-1 rounded-lg bg-[var(--card-bg)] text-[var(--card-fg)] border-[var(--card-border)]",
50
+ }}
51
+ answerText={{ className: "font-inter text-base text-[var(--card-fg)]" }}
52
+ allowMultipleOpen={true}
53
+ />
54
+ );
55
+ }
@@ -0,0 +1,91 @@
1
+ "use client";
2
+
3
+ import { Features as SharedFeatures } from "@/components/sections/Features";
4
+ import { cn } from "@/lib/utils";
5
+
6
+ const defaultFeaturesData = [
7
+ {
8
+ imageSrc: "/placeholders/saas_dashboard/projectBoard.png",
9
+ imageAlt: "Project Management Dashboard",
10
+ headingText: "Track Every Project",
11
+ subheadingText:
12
+ "Kanban boards, Gantt charts, and timeline views keep your team aligned and deadlines met",
13
+ },
14
+ {
15
+ imageSrc: "/placeholders/saas_dashboard/analytics.png",
16
+ imageAlt: "Analytics Dashboard",
17
+ headingText: "Data-Driven Insights",
18
+ subheadingText:
19
+ "Real-time metrics, custom reports, and forecasting tools to make smarter business decisions",
20
+ },
21
+ {
22
+ imageSrc: "/placeholders/saas_dashboard/chat.png",
23
+ imageAlt: "Team Collaboration Tools",
24
+ headingText: "Seamless Teamwork",
25
+ subheadingText:
26
+ "Built-in chat, file sharing, and @mentions keep everyone connected and productive",
27
+ },
28
+ ];
29
+
30
+ export function Features() {
31
+ return (
32
+ <SharedFeatures
33
+ sectionHeading="Everything You Need to Run Your Business"
34
+ sectionSubheading="Powerful tools and insights to streamline your workflow and boost productivity"
35
+ featuresData={defaultFeaturesData}
36
+ className={cn("relative")}
37
+ section={{ className: "py-16 md:py-20 lg:py-24 bg-background" }}
38
+ container={{ className: "max-w-7xl mx-auto px-4 md:px-6 lg:px-8" }}
39
+ header={{ className: "text-center mb-12 md:mb-16" }}
40
+ heading={{
41
+ className: cn(
42
+ "font-inter mb-4 text-3xl font-bold text-[var(--heading-fg)] md:text-4xl lg:text-5xl",
43
+ ),
44
+ }}
45
+ subheading={{
46
+ className: cn(
47
+ "font-inter mx-auto max-w-3xl text-lg leading-relaxed text-[var(--subheading-fg)] md:text-xl",
48
+ ),
49
+ }}
50
+ grid={{
51
+ className:
52
+ "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6 md:gap-8",
53
+ }}
54
+ cardWrapper={{
55
+ className:
56
+ "group motion-reduce:transform-none motion-reduce:transition-none",
57
+ }}
58
+ card={{
59
+ className:
60
+ "h-full transition-all duration-300 hover:-translate-y-2 hover:shadow-xl bg-[var(--card-bg)] text-[var(--card-fg)] border-[var(--card-border)] rounded-lg shadow-md overflow-hidden",
61
+ }}
62
+ image={{
63
+ className:
64
+ "w-full h-48 md:h-56 object-cover transition-transform duration-300 group-hover:scale-[1.03]",
65
+ }}
66
+ cardHeading={{
67
+ className: cn(
68
+ "font-inter mb-3 text-xl leading-tight font-semibold text-[var(--card-title-fg)] md:text-2xl",
69
+ ),
70
+ }}
71
+ cardSubheading={{
72
+ className: cn(
73
+ "font-inter text-sm leading-relaxed text-[var(--card-muted-fg)] md:text-base",
74
+ ),
75
+ }}
76
+ // Motion config showcasing upgraded API
77
+ motionConfig={{
78
+ initial: { opacity: 0, y: 12 },
79
+ whileInView: { opacity: 1, y: 0 },
80
+ viewport: { once: true, amount: 0.2 },
81
+ transition: {
82
+ type: "spring",
83
+ stiffness: 125,
84
+ damping: 50,
85
+ delay: 0.12,
86
+ },
87
+ }}
88
+ ariaLabel="Features section"
89
+ />
90
+ );
91
+ }
@@ -0,0 +1,77 @@
1
+ "use client";
2
+
3
+ import { Footer as SharedFooter } from "@/components/sections/Footer";
4
+ import { cn } from "@/lib/utils";
5
+
6
+ const defaultNavLinks = [
7
+ {
8
+ heading: "Product",
9
+ links: [
10
+ { name: "Features", href: "#features" },
11
+ { name: "Pricing", href: "#pricing" },
12
+ { name: "Documentation", href: "#documentation" },
13
+ { name: "FAQ", href: "#faq" },
14
+ ],
15
+ },
16
+ {
17
+ heading: "Company",
18
+ links: [
19
+ { name: "About", href: "#about" },
20
+ { name: "Careers", href: "#careers" },
21
+ { name: "Blog", href: "#blog" },
22
+ { name: "Contact", href: "#contact" },
23
+ ],
24
+ },
25
+ {
26
+ heading: "Resources",
27
+ links: [
28
+ { name: "Help Center", href: "#help" },
29
+ { name: "Terms of Service", href: "#terms" },
30
+ { name: "Privacy Policy", href: "#privacy" },
31
+ { name: "Status", href: "#status" },
32
+ ],
33
+ },
34
+ ];
35
+
36
+ export function Footer() {
37
+ return (
38
+ <SharedFooter
39
+ footerBrandName="Dash Flow"
40
+ footerNavLinks={defaultNavLinks}
41
+ className={cn("w-full")}
42
+ section={{
43
+ className:
44
+ "w-full bg-blue-50 dark:bg-gray-900 text-gray-800 dark:text-white",
45
+ }}
46
+ container={{ className: "max-w-7xl mx-auto px-6" }}
47
+ brand={{
48
+ className:
49
+ "text-xl font-bold text-blue-600 dark:text-blue-400 font-outfit",
50
+ }}
51
+ brandWrapper={{
52
+ className: "flex flex-col items-start text-left lg:pr-8",
53
+ }}
54
+ navSection={{
55
+ className:
56
+ "flex flex-col lg:flex-row items-start lg:items-start justify-center gap-8 lg:gap-12 pt-6.5 pb-8",
57
+ }}
58
+ navGroup={{ className: "flex flex-col items-start text-left pt-1.5" }}
59
+ navHeading={{
60
+ className:
61
+ "font-semibold text-gray-800 dark:text-white mb-3 text-xs uppercase tracking-wider font-inter",
62
+ }}
63
+ navLink={{
64
+ className:
65
+ "text-gray-600 dark:text-gray-300 hover:text-blue-500 dark:hover:text-blue-400 transition-colors duration-200 text-xs mb-2 block font-inter",
66
+ }}
67
+ socialSection={{
68
+ className: "flex items-center justify-center gap-4 py-4",
69
+ }}
70
+ copyright={{
71
+ className:
72
+ "text-center text-xs text-gray-500 dark:text-gray-400 py-4 border-t border-gray-200 dark:border-gray-700 font-inter",
73
+ }}
74
+ ariaLabel="Footer section"
75
+ />
76
+ );
77
+ }
@@ -0,0 +1,105 @@
1
+ "use client";
2
+
3
+ import { HeroSplit as SharedHeroSplit } from "@/components/sections/HeroSplit";
4
+ import { Dashboard } from "./Dashboard";
5
+ import { cn } from "@/lib/utils";
6
+
7
+ const stats = [
8
+ { value: "$124K", label: "Monthly Revenue" },
9
+ { value: "+23%", label: "Growth Rate" },
10
+ { value: "847", label: "Active Users" },
11
+ ];
12
+
13
+ const projects = ["Website Redesign", "Mobile App v2.0", "Marketing Campaign"];
14
+
15
+ const floatingCards = [
16
+ { position: "card-1", icon: "📊", text: "Real-time Analytics" },
17
+ { position: "card-2", icon: "👥", text: "Team Collaboration" },
18
+ ];
19
+
20
+ const activeTab = "Analytics";
21
+ const navItems = ["Analytics", "Projects", "Team"];
22
+
23
+ export function Hero() {
24
+ return (
25
+ <div className="relative">
26
+ <SharedHeroSplit
27
+ className={cn("relative")}
28
+ heading={{
29
+ text: "Manage Your Entire Business From One Powerful Dashboard",
30
+ className:
31
+ "text-3xl md:text-4xl lg:text-5xl font-bold leading-tight font-inter text-[var(--heading-fg)]",
32
+ }}
33
+ subheading={{
34
+ text: "Stop switching between 12 different apps. DashFlow combines project management, analytics, team chat, and customer insights in one beautiful interface.",
35
+ className:
36
+ "text-base md:text-lg mt-6 mb-8 max-w-2xl font-inter font-normal text-[var(--subheading-fg)]",
37
+ }}
38
+ section={{
39
+ className:
40
+ "relative pt-1 px-8 pb-8 bg-[var(--hero-bg)] dark:bg-[var(--hero-bg)]",
41
+ }}
42
+ cta1={{
43
+ label: "Start Free Trial",
44
+ href: "#contact",
45
+ variant: "default",
46
+ size: "lg",
47
+ className: [
48
+ "text-base font-semibold font-inter shadow-lg hover:shadow-xl hover:-translate-y-0.5 transition-all duration-200 px-8 py-3",
49
+ "[--btn-bg:theme(colors.sky.600)]",
50
+ "hover:[--btn-hover-bg:theme(colors.sky.700)]",
51
+ "[--btn-fg:theme(colors.white)]",
52
+ "hover:[--btn-hover-fg:theme(colors.white)]",
53
+ ].join(" "),
54
+ }}
55
+ cta2={{
56
+ label: "Watch demo",
57
+ href: "#demo",
58
+ variant: "outline",
59
+ size: "lg",
60
+ className: [
61
+ "text-base font-semibold font-inter shadow-lg hover:shadow-xl hover:-translate-y-0.5 transition-all duration-200 px-8 py-3",
62
+ "[--btn-fg:theme(colors.sky.600)]",
63
+ "[--btn-border:theme(colors.sky.600)]",
64
+ "hover:[--btn-hover-bg:theme(colors.sky.50)]",
65
+ "hover:[--btn-hover-fg:theme(colors.sky.600)]",
66
+ "dark:[--btn-fg:theme(colors.sky.500)]",
67
+ "dark:[--btn-border:theme(colors.sky.500)]",
68
+ "dark:hover:[--btn-hover-bg:theme(colors.sky.950)]",
69
+ "dark:hover:[--btn-hover-fg:theme(colors.sky.500)]",
70
+ ].join(" "),
71
+ }}
72
+ image={{ src: undefined, alt: "Dashboard preview" }}
73
+ imageLayout="padded"
74
+ fallback={
75
+ <div className="flex h-full w-full items-center justify-center">
76
+ <div className="relative w-[min(100%,720px)] overflow-hidden rounded-xl bg-white p-0 p-1 opacity-100 md:pt-8 lg:pt-1 dark:bg-blue-950">
77
+ <Dashboard
78
+ stats={stats}
79
+ projects={projects}
80
+ floatingCards={floatingCards}
81
+ navItems={navItems}
82
+ activeTab={activeTab}
83
+ />
84
+ </div>
85
+ </div>
86
+ }
87
+ imageContainer={{
88
+ className:
89
+ "pl-0 relative self-start md:self-start md:flex-none md:shrink-0 w-full h-[24rem] sm:h-[32rem] md:h-[34rem] lg:h-[33rem] md:w-1/2 mb-0 md:mb-0 lg:mb-0 opacity-100",
90
+ // "relative self-start md:self-start md:flex-none md:shrink-0 w-full h-[24rem] sm:h-[26rem] md:h-[28rem] md:w-1/2 mb-6 md:mb-0",
91
+ }}
92
+ textContainer={{ className: "flex-1 p-5 lg:p-8" }}
93
+ buttonsContainer={{
94
+ className: [
95
+ "flex flex-col sm:flex-row gap-4 mt-8 justify-center lg:justify-start",
96
+ "[--btn-ring:theme(colors.sky.500)]",
97
+ "dark:[--btn-ring:theme(colors.sky.400)]",
98
+ ].join(" "),
99
+ }}
100
+ textAlign="center"
101
+ ariaLabel="DashFlow hero section"
102
+ />
103
+ </div>
104
+ );
105
+ }