@nextworks/blocks-templates 0.1.0-alpha.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 (193) hide show
  1. package/README.md +42 -0
  2. package/dist/index.d.ts +5 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +4 -0
  5. package/dist/templates/digitalagency/Page.d.ts +3 -0
  6. package/dist/templates/digitalagency/Page.d.ts.map +1 -0
  7. package/dist/templates/digitalagency/Page.js +18 -0
  8. package/dist/templates/digitalagency/Page.jsx +33 -0
  9. package/dist/templates/digitalagency/PresetThemeVars.d.ts +11 -0
  10. package/dist/templates/digitalagency/PresetThemeVars.d.ts.map +1 -0
  11. package/dist/templates/digitalagency/PresetThemeVars.js +29 -0
  12. package/dist/templates/digitalagency/PresetThemeVars.jsx +31 -0
  13. package/dist/templates/digitalagency/components/About.d.ts +3 -0
  14. package/dist/templates/digitalagency/components/About.d.ts.map +1 -0
  15. package/dist/templates/digitalagency/components/About.js +45 -0
  16. package/dist/templates/digitalagency/components/About.jsx +43 -0
  17. package/dist/templates/digitalagency/components/CTA.d.ts +3 -0
  18. package/dist/templates/digitalagency/components/CTA.d.ts.map +1 -0
  19. package/dist/templates/digitalagency/components/CTA.js +33 -0
  20. package/dist/templates/digitalagency/components/CTA.jsx +31 -0
  21. package/dist/templates/digitalagency/components/Contact.d.ts +3 -0
  22. package/dist/templates/digitalagency/components/Contact.d.ts.map +1 -0
  23. package/dist/templates/digitalagency/components/Contact.js +91 -0
  24. package/dist/templates/digitalagency/components/Contact.jsx +91 -0
  25. package/dist/templates/digitalagency/components/Footer.d.ts +8 -0
  26. package/dist/templates/digitalagency/components/Footer.d.ts.map +1 -0
  27. package/dist/templates/digitalagency/components/Footer.js +58 -0
  28. package/dist/templates/digitalagency/components/Footer.jsx +58 -0
  29. package/dist/templates/digitalagency/components/Hero.d.ts +7 -0
  30. package/dist/templates/digitalagency/components/Hero.d.ts.map +1 -0
  31. package/dist/templates/digitalagency/components/Hero.js +69 -0
  32. package/dist/templates/digitalagency/components/Hero.jsx +71 -0
  33. package/dist/templates/digitalagency/components/Navbar.d.ts +21 -0
  34. package/dist/templates/digitalagency/components/Navbar.d.ts.map +1 -0
  35. package/dist/templates/digitalagency/components/Navbar.js +86 -0
  36. package/dist/templates/digitalagency/components/Navbar.jsx +85 -0
  37. package/dist/templates/digitalagency/components/NetworkPattern.d.ts +8 -0
  38. package/dist/templates/digitalagency/components/NetworkPattern.d.ts.map +1 -0
  39. package/dist/templates/digitalagency/components/NetworkPattern.js +38 -0
  40. package/dist/templates/digitalagency/components/NetworkPattern.jsx +128 -0
  41. package/dist/templates/digitalagency/components/Portfolio.d.ts +3 -0
  42. package/dist/templates/digitalagency/components/Portfolio.d.ts.map +1 -0
  43. package/dist/templates/digitalagency/components/Portfolio.js +108 -0
  44. package/dist/templates/digitalagency/components/Portfolio.jsx +110 -0
  45. package/dist/templates/digitalagency/components/Pricing.d.ts +3 -0
  46. package/dist/templates/digitalagency/components/Pricing.d.ts.map +1 -0
  47. package/dist/templates/digitalagency/components/Pricing.js +82 -0
  48. package/dist/templates/digitalagency/components/Pricing.jsx +84 -0
  49. package/dist/templates/digitalagency/components/Process.d.ts +3 -0
  50. package/dist/templates/digitalagency/components/Process.d.ts.map +1 -0
  51. package/dist/templates/digitalagency/components/Process.js +38 -0
  52. package/dist/templates/digitalagency/components/Process.jsx +40 -0
  53. package/dist/templates/digitalagency/components/Services.d.ts +3 -0
  54. package/dist/templates/digitalagency/components/Services.d.ts.map +1 -0
  55. package/dist/templates/digitalagency/components/Services.js +34 -0
  56. package/dist/templates/digitalagency/components/Services.jsx +36 -0
  57. package/dist/templates/digitalagency/components/Team.d.ts +3 -0
  58. package/dist/templates/digitalagency/components/Team.d.ts.map +1 -0
  59. package/dist/templates/digitalagency/components/Team.js +14 -0
  60. package/dist/templates/digitalagency/components/Team.jsx +14 -0
  61. package/dist/templates/digitalagency/components/Testimonials.d.ts +3 -0
  62. package/dist/templates/digitalagency/components/Testimonials.d.ts.map +1 -0
  63. package/dist/templates/digitalagency/components/Testimonials.js +38 -0
  64. package/dist/templates/digitalagency/components/Testimonials.jsx +40 -0
  65. package/dist/templates/gallery/PresetThemeVars.d.ts +15 -0
  66. package/dist/templates/gallery/PresetThemeVars.d.ts.map +1 -0
  67. package/dist/templates/gallery/PresetThemeVars.js +31 -0
  68. package/dist/templates/gallery/PresetThemeVars.jsx +33 -0
  69. package/dist/templates/gallery/page.d.ts +2 -0
  70. package/dist/templates/gallery/page.d.ts.map +1 -0
  71. package/dist/templates/gallery/page.js +151 -0
  72. package/dist/templates/gallery/page.jsx +216 -0
  73. package/dist/templates/productlaunch/Page.d.ts +2 -0
  74. package/dist/templates/productlaunch/Page.d.ts.map +1 -0
  75. package/dist/templates/productlaunch/Page.js +20 -0
  76. package/dist/templates/productlaunch/Page.jsx +42 -0
  77. package/dist/templates/productlaunch/PresetThemeVars.d.ts +16 -0
  78. package/dist/templates/productlaunch/PresetThemeVars.d.ts.map +1 -0
  79. package/dist/templates/productlaunch/PresetThemeVars.js +28 -0
  80. package/dist/templates/productlaunch/PresetThemeVars.jsx +30 -0
  81. package/dist/templates/productlaunch/components/About.d.ts +15 -0
  82. package/dist/templates/productlaunch/components/About.d.ts.map +1 -0
  83. package/dist/templates/productlaunch/components/About.js +59 -0
  84. package/dist/templates/productlaunch/components/About.jsx +57 -0
  85. package/dist/templates/productlaunch/components/CTA.d.ts +3 -0
  86. package/dist/templates/productlaunch/components/CTA.d.ts.map +1 -0
  87. package/dist/templates/productlaunch/components/CTA.js +39 -0
  88. package/dist/templates/productlaunch/components/CTA.jsx +37 -0
  89. package/dist/templates/productlaunch/components/Contact.d.ts +3 -0
  90. package/dist/templates/productlaunch/components/Contact.d.ts.map +1 -0
  91. package/dist/templates/productlaunch/components/Contact.js +93 -0
  92. package/dist/templates/productlaunch/components/Contact.jsx +93 -0
  93. package/dist/templates/productlaunch/components/FAQ.d.ts +7 -0
  94. package/dist/templates/productlaunch/components/FAQ.d.ts.map +1 -0
  95. package/dist/templates/productlaunch/components/FAQ.js +64 -0
  96. package/dist/templates/productlaunch/components/FAQ.jsx +63 -0
  97. package/dist/templates/productlaunch/components/Features.d.ts +6 -0
  98. package/dist/templates/productlaunch/components/Features.d.ts.map +1 -0
  99. package/dist/templates/productlaunch/components/Features.js +52 -0
  100. package/dist/templates/productlaunch/components/Features.jsx +51 -0
  101. package/dist/templates/productlaunch/components/Footer.d.ts +5 -0
  102. package/dist/templates/productlaunch/components/Footer.d.ts.map +1 -0
  103. package/dist/templates/productlaunch/components/Footer.js +103 -0
  104. package/dist/templates/productlaunch/components/Footer.jsx +102 -0
  105. package/dist/templates/productlaunch/components/Hero.d.ts +6 -0
  106. package/dist/templates/productlaunch/components/Hero.d.ts.map +1 -0
  107. package/dist/templates/productlaunch/components/Hero.js +70 -0
  108. package/dist/templates/productlaunch/components/Hero.jsx +69 -0
  109. package/dist/templates/productlaunch/components/Navbar.d.ts +25 -0
  110. package/dist/templates/productlaunch/components/Navbar.d.ts.map +1 -0
  111. package/dist/templates/productlaunch/components/Navbar.js +82 -0
  112. package/dist/templates/productlaunch/components/Navbar.jsx +81 -0
  113. package/dist/templates/productlaunch/components/Pricing.d.ts +5 -0
  114. package/dist/templates/productlaunch/components/Pricing.d.ts.map +1 -0
  115. package/dist/templates/productlaunch/components/Pricing.js +77 -0
  116. package/dist/templates/productlaunch/components/Pricing.jsx +76 -0
  117. package/dist/templates/productlaunch/components/ProcessTimeline.d.ts +5 -0
  118. package/dist/templates/productlaunch/components/ProcessTimeline.d.ts.map +1 -0
  119. package/dist/templates/productlaunch/components/ProcessTimeline.js +63 -0
  120. package/dist/templates/productlaunch/components/ProcessTimeline.jsx +62 -0
  121. package/dist/templates/productlaunch/components/ServicesGrid.d.ts +5 -0
  122. package/dist/templates/productlaunch/components/ServicesGrid.d.ts.map +1 -0
  123. package/dist/templates/productlaunch/components/ServicesGrid.js +41 -0
  124. package/dist/templates/productlaunch/components/ServicesGrid.jsx +40 -0
  125. package/dist/templates/productlaunch/components/Team.d.ts +5 -0
  126. package/dist/templates/productlaunch/components/Team.d.ts.map +1 -0
  127. package/dist/templates/productlaunch/components/Team.js +72 -0
  128. package/dist/templates/productlaunch/components/Team.jsx +71 -0
  129. package/dist/templates/productlaunch/components/Testimonials.d.ts +5 -0
  130. package/dist/templates/productlaunch/components/Testimonials.d.ts.map +1 -0
  131. package/dist/templates/productlaunch/components/Testimonials.js +55 -0
  132. package/dist/templates/productlaunch/components/Testimonials.jsx +54 -0
  133. package/dist/templates/productlaunch/components/TrustBadges.d.ts +5 -0
  134. package/dist/templates/productlaunch/components/TrustBadges.d.ts.map +1 -0
  135. package/dist/templates/productlaunch/components/TrustBadges.js +50 -0
  136. package/dist/templates/productlaunch/components/TrustBadges.jsx +49 -0
  137. package/dist/templates/saasdashboard/Page.d.ts +2 -0
  138. package/dist/templates/saasdashboard/Page.d.ts.map +1 -0
  139. package/dist/templates/saasdashboard/Page.js +15 -0
  140. package/dist/templates/saasdashboard/Page.jsx +35 -0
  141. package/dist/templates/saasdashboard/PresetThemeVars.d.ts +11 -0
  142. package/dist/templates/saasdashboard/PresetThemeVars.d.ts.map +1 -0
  143. package/dist/templates/saasdashboard/PresetThemeVars.js +27 -0
  144. package/dist/templates/saasdashboard/PresetThemeVars.jsx +29 -0
  145. package/dist/templates/saasdashboard/components/Contact.d.ts +3 -0
  146. package/dist/templates/saasdashboard/components/Contact.d.ts.map +1 -0
  147. package/dist/templates/saasdashboard/components/Contact.js +83 -0
  148. package/dist/templates/saasdashboard/components/Contact.jsx +90 -0
  149. package/dist/templates/saasdashboard/components/Dashboard.d.ts +21 -0
  150. package/dist/templates/saasdashboard/components/Dashboard.d.ts.map +1 -0
  151. package/dist/templates/saasdashboard/components/Dashboard.js +120 -0
  152. package/dist/templates/saasdashboard/components/Dashboard.jsx +168 -0
  153. package/dist/templates/saasdashboard/components/FAQ.d.ts +2 -0
  154. package/dist/templates/saasdashboard/components/FAQ.d.ts.map +1 -0
  155. package/dist/templates/saasdashboard/components/FAQ.js +35 -0
  156. package/dist/templates/saasdashboard/components/FAQ.jsx +34 -0
  157. package/dist/templates/saasdashboard/components/Features.d.ts +2 -0
  158. package/dist/templates/saasdashboard/components/Features.d.ts.map +1 -0
  159. package/dist/templates/saasdashboard/components/Features.js +55 -0
  160. package/dist/templates/saasdashboard/components/Features.jsx +54 -0
  161. package/dist/templates/saasdashboard/components/Footer.d.ts +2 -0
  162. package/dist/templates/saasdashboard/components/Footer.d.ts.map +1 -0
  163. package/dist/templates/saasdashboard/components/Footer.js +52 -0
  164. package/dist/templates/saasdashboard/components/Footer.jsx +51 -0
  165. package/dist/templates/saasdashboard/components/Hero.d.ts +2 -0
  166. package/dist/templates/saasdashboard/components/Hero.d.ts.map +1 -0
  167. package/dist/templates/saasdashboard/components/Hero.js +65 -0
  168. package/dist/templates/saasdashboard/components/Hero.jsx +70 -0
  169. package/dist/templates/saasdashboard/components/Hero_mask.d.ts +3 -0
  170. package/dist/templates/saasdashboard/components/Hero_mask.d.ts.map +1 -0
  171. package/dist/templates/saasdashboard/components/Hero_mask.js +73 -0
  172. package/dist/templates/saasdashboard/components/Hero_mask.jsx +85 -0
  173. package/dist/templates/saasdashboard/components/Navbar.d.ts +25 -0
  174. package/dist/templates/saasdashboard/components/Navbar.d.ts.map +1 -0
  175. package/dist/templates/saasdashboard/components/Navbar.js +83 -0
  176. package/dist/templates/saasdashboard/components/Navbar.jsx +84 -0
  177. package/dist/templates/saasdashboard/components/Pricing.d.ts +2 -0
  178. package/dist/templates/saasdashboard/components/Pricing.d.ts.map +1 -0
  179. package/dist/templates/saasdashboard/components/Pricing.js +65 -0
  180. package/dist/templates/saasdashboard/components/Pricing.jsx +64 -0
  181. package/dist/templates/saasdashboard/components/SmoothScroll.d.ts +2 -0
  182. package/dist/templates/saasdashboard/components/SmoothScroll.d.ts.map +1 -0
  183. package/dist/templates/saasdashboard/components/SmoothScroll.js +87 -0
  184. package/dist/templates/saasdashboard/components/SmoothScroll.jsx +87 -0
  185. package/dist/templates/saasdashboard/components/Testimonials.d.ts +2 -0
  186. package/dist/templates/saasdashboard/components/Testimonials.d.ts.map +1 -0
  187. package/dist/templates/saasdashboard/components/Testimonials.js +35 -0
  188. package/dist/templates/saasdashboard/components/Testimonials.jsx +39 -0
  189. package/dist/templates/saasdashboard/components/TrustBadges.d.ts +2 -0
  190. package/dist/templates/saasdashboard/components/TrustBadges.d.ts.map +1 -0
  191. package/dist/templates/saasdashboard/components/TrustBadges.js +37 -0
  192. package/dist/templates/saasdashboard/components/TrustBadges.jsx +36 -0
  193. package/package.json +27 -0
@@ -0,0 +1,34 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { ServicesGrid } from "@nextworks/blocks-sections";
4
+ const defaultServicesData = [
5
+ {
6
+ icon: "💻",
7
+ title: "Web Design & Development",
8
+ description: "Custom websites that capture your brand and convert visitors into customers",
9
+ },
10
+ {
11
+ icon: "📈",
12
+ title: "SEO & Digital Marketing",
13
+ description: "Get found on Google and drive qualified traffic to your website",
14
+ },
15
+ {
16
+ icon: "🛒",
17
+ title: "E-commerce Solutions",
18
+ description: "Online stores that maximize sales and customer experience",
19
+ },
20
+ {
21
+ icon: "🎨",
22
+ title: "Brand Identity & Design",
23
+ description: "Logo, branding, and visual identity that makes you stand out",
24
+ },
25
+ ];
26
+ export function Services() {
27
+ return (_jsx("section", { id: "services", children: _jsx(ServicesGrid, { enableMotion: true, section: {
28
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-900",
29
+ }, container: { className: "max-w-6xl mx-auto px-6" }, heading: {
30
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold font-poppins text-gray-800 dark:text-white text-center mb-8 md:mb-12",
31
+ }, grid: { className: "grid grid-cols-1 md:grid-cols-2 gap-6 md:gap-8" }, card: {
32
+ className: "bg-white dark:bg-gray-800 p-6 md:p-8 rounded-lg border border-gray-200 dark:border-gray-700 shadow-sm hover:shadow-md hover:-translate-y-1 transition-all duration-300",
33
+ }, servicesData: defaultServicesData, sectionHeading: "Our Services", ariaLabel: "Services section" }) }));
34
+ }
@@ -0,0 +1,36 @@
1
+ "use client";
2
+ import React from "react";
3
+ import { ServicesGrid } from "@nextworks/blocks-sections";
4
+ const defaultServicesData = [
5
+ {
6
+ icon: "💻",
7
+ title: "Web Design & Development",
8
+ description: "Custom websites that capture your brand and convert visitors into customers",
9
+ },
10
+ {
11
+ icon: "📈",
12
+ title: "SEO & Digital Marketing",
13
+ description: "Get found on Google and drive qualified traffic to your website",
14
+ },
15
+ {
16
+ icon: "🛒",
17
+ title: "E-commerce Solutions",
18
+ description: "Online stores that maximize sales and customer experience",
19
+ },
20
+ {
21
+ icon: "🎨",
22
+ title: "Brand Identity & Design",
23
+ description: "Logo, branding, and visual identity that makes you stand out",
24
+ },
25
+ ];
26
+ export function Services() {
27
+ return (<section id="services">
28
+ <ServicesGrid enableMotion={true} section={{
29
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-900",
30
+ }} container={{ className: "max-w-6xl mx-auto px-6" }} heading={{
31
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold font-poppins text-gray-800 dark:text-white text-center mb-8 md:mb-12",
32
+ }} grid={{ className: "grid grid-cols-1 md:grid-cols-2 gap-6 md:gap-8" }} card={{
33
+ className: "bg-white dark:bg-gray-800 p-6 md:p-8 rounded-lg border border-gray-200 dark:border-gray-700 shadow-sm hover:shadow-md hover:-translate-y-1 transition-all duration-300",
34
+ }} servicesData={defaultServicesData} sectionHeading="Our Services" ariaLabel="Services section"/>
35
+ </section>);
36
+ }
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ export declare function Team(): React.JSX.Element;
3
+ //# sourceMappingURL=Team.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Team.d.ts","sourceRoot":"","sources":["../../../../src/templates/digitalagency/components/Team.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,wBAAgB,IAAI,sBAsBnB"}
@@ -0,0 +1,14 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Team as SharedTeam } from "@nextworks/blocks-sections";
4
+ export function Team() {
5
+ return (_jsx(SharedTeam, { section: {
6
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-900",
7
+ }, card: { className: "dark:bg-gray-800" }, heading: {
8
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold text-[var(--heading-fg)]",
9
+ }, subheading: {
10
+ className: "text-xl md:text-2xl text-[var(--subheading-fg)] max-w-2xl mx-auto leading-relaxed",
11
+ }, role: {
12
+ className: "text-md font-semibold font-poppins text-fuchsia-600 dark:text-fuchsia-400",
13
+ }, ariaLabel: "Team section" }));
14
+ }
@@ -0,0 +1,14 @@
1
+ "use client";
2
+ import React from "react";
3
+ import { Team as SharedTeam } from "@nextworks/blocks-sections";
4
+ export function Team() {
5
+ return (<SharedTeam section={{
6
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-900",
7
+ }} card={{ className: "dark:bg-gray-800" }} heading={{
8
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold text-[var(--heading-fg)]",
9
+ }} subheading={{
10
+ className: "text-xl md:text-2xl text-[var(--subheading-fg)] max-w-2xl mx-auto leading-relaxed",
11
+ }} role={{
12
+ className: "text-md font-semibold font-poppins text-fuchsia-600 dark:text-fuchsia-400",
13
+ }} ariaLabel="Team section"/>);
14
+ }
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ export declare function Testimonials(): React.JSX.Element;
3
+ //# sourceMappingURL=Testimonials.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Testimonials.d.ts","sourceRoot":"","sources":["../../../../src/templates/digitalagency/components/Testimonials.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,wBAAgB,YAAY,sBA2D3B"}
@@ -0,0 +1,38 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Testimonials as SharedTestimonials } from "@nextworks/blocks-sections";
4
+ export function Testimonials() {
5
+ return (_jsx("section", { id: "testimonials", children: _jsx(SharedTestimonials, { testimonialSectionHeader: "What Our Customers Say", section: {
6
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-800",
7
+ }, container: { className: "max-w-7xl mx-auto px-6" }, header: { className: "text-center mb-12 md:mb-16" }, heading: {
8
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold font-poppins text-gray-800 dark:text-white",
9
+ }, grid: {
10
+ className: "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8",
11
+ }, card: {
12
+ className: "bg-white dark:bg-gray-900 p-6 rounded-lg shadow-md transition-transform duration-200 hover:-translate-y-1 border border-fuchsia-200/60 dark:border-fuchsia-800/40",
13
+ }, text: {
14
+ className: "text-gray-700 dark:text-gray-300 text-base leading-relaxed italic font-inter",
15
+ }, author: {
16
+ className: "text-gray-600 dark:text-gray-400 text-sm font-medium font-poppins",
17
+ }, avatar: {
18
+ className: "w-12 h-12 bg-fuchsia-600 text-white rounded-full flex items-center justify-center text-lg font-bold",
19
+ }, avatarText: {
20
+ className: "text-white font-bold",
21
+ }, testimonials: [
22
+ {
23
+ testimonialText: "Nexus Digital transformed our online presence completely.",
24
+ testimonialAuthor: "- Sarah Chen, CEO of TechFlow",
25
+ testimonialAuthorInitials: "SC",
26
+ },
27
+ {
28
+ testimonialText: "The team delivered beyond expectations.",
29
+ testimonialAuthor: "- Marcus Rodriguez, GreenLeaf Wellness",
30
+ testimonialAuthorInitials: "MR",
31
+ },
32
+ {
33
+ testimonialText: "Professional, fast, and results-driven. They understood our vision and brought it to life perfectly.",
34
+ testimonialAuthor: "- Jennifer Walsh, UrbanFit",
35
+ testimonialAuthorInitials: "JW",
36
+ },
37
+ ], ariaLabel: "Testimonials section" }) }));
38
+ }
@@ -0,0 +1,40 @@
1
+ "use client";
2
+ import React from "react";
3
+ import { Testimonials as SharedTestimonials } from "@nextworks/blocks-sections";
4
+ export function Testimonials() {
5
+ return (<section id="testimonials">
6
+ <SharedTestimonials testimonialSectionHeader="What Our Customers Say" section={{
7
+ className: "py-16 md:py-20 lg:py-24 bg-fuchsia-50 dark:bg-gray-800",
8
+ }} container={{ className: "max-w-7xl mx-auto px-6" }} header={{ className: "text-center mb-12 md:mb-16" }} heading={{
9
+ className: "text-4xl md:text-5xl lg:text-6xl font-bold font-poppins text-gray-800 dark:text-white",
10
+ }} grid={{
11
+ className: "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8",
12
+ }} card={{
13
+ className: "bg-white dark:bg-gray-900 p-6 rounded-lg shadow-md transition-transform duration-200 hover:-translate-y-1 border border-fuchsia-200/60 dark:border-fuchsia-800/40",
14
+ }} text={{
15
+ className: "text-gray-700 dark:text-gray-300 text-base leading-relaxed italic font-inter",
16
+ }} author={{
17
+ className: "text-gray-600 dark:text-gray-400 text-sm font-medium font-poppins",
18
+ }} avatar={{
19
+ className: "w-12 h-12 bg-fuchsia-600 text-white rounded-full flex items-center justify-center text-lg font-bold",
20
+ }} avatarText={{
21
+ className: "text-white font-bold",
22
+ }} testimonials={[
23
+ {
24
+ testimonialText: "Nexus Digital transformed our online presence completely.",
25
+ testimonialAuthor: "- Sarah Chen, CEO of TechFlow",
26
+ testimonialAuthorInitials: "SC",
27
+ },
28
+ {
29
+ testimonialText: "The team delivered beyond expectations.",
30
+ testimonialAuthor: "- Marcus Rodriguez, GreenLeaf Wellness",
31
+ testimonialAuthorInitials: "MR",
32
+ },
33
+ {
34
+ testimonialText: "Professional, fast, and results-driven. They understood our vision and brought it to life perfectly.",
35
+ testimonialAuthor: "- Jennifer Walsh, UrbanFit",
36
+ testimonialAuthorInitials: "JW",
37
+ },
38
+ ]} ariaLabel="Testimonials section"/>
39
+ </section>);
40
+ }
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+ type Props = React.PropsWithChildren<{
3
+ className?: string;
4
+ }>;
5
+ /**
6
+ * Gallery template token-bridge wrapper.
7
+ *
8
+ * Maps component-level CSS variables (btn, input, card, etc.) to the
9
+ * EnhancedThemeProvider token variables applied on :root (e.g., --primary,
10
+ * --foreground, --card, --ring). This preserves the original Gallery behavior:
11
+ * colors are driven by the selected Color Theme, not a fixed preset palette.
12
+ */
13
+ export declare function PresetThemeVars({ className, children }: Props): React.JSX.Element;
14
+ export {};
15
+ //# sourceMappingURL=PresetThemeVars.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PresetThemeVars.d.ts","sourceRoot":"","sources":["../../../src/templates/gallery/PresetThemeVars.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,KAAK,KAAK,GAAG,KAAK,CAAC,iBAAiB,CAAC;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE7D;;;;;;;GAOG;AACH,wBAAgB,eAAe,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,KAAK,qBAuE7D"}
@@ -0,0 +1,31 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "@nextworks/blocks-core";
3
+ /**
4
+ * Gallery template token-bridge wrapper.
5
+ *
6
+ * Maps component-level CSS variables (btn, input, card, etc.) to the
7
+ * EnhancedThemeProvider token variables applied on :root (e.g., --primary,
8
+ * --foreground, --card, --ring). This preserves the original Gallery behavior:
9
+ * colors are driven by the selected Color Theme, not a fixed preset palette.
10
+ */
11
+ export function PresetThemeVars({ className, children }) {
12
+ return (_jsx("div", { className: cn(
13
+ // Buttons (leave bg/fg unset by default so tokenized variants can apply; set ring here)
14
+ "[--btn-ring:var(--ring)]",
15
+ // Inputs
16
+ "[--input-bg:var(--background)]", "[--input-fg:var(--foreground)]", "[--input-placeholder:var(--muted-foreground)]", "[--input-border:var(--input)]", "[--input-focus-ring:var(--ring)]", "[--input-ring-offset:var(--background)]",
17
+ // Cards
18
+ "[--card-bg:var(--card)]", "[--card-fg:var(--card-foreground)]", "[--card-title-fg:var(--foreground)]", "[--card-muted-fg:var(--muted-foreground)]", "[--card-border:var(--border)]", "[--card-shadow:0_6px_20px_rgba(0,0,0,0.06)]",
19
+ // Badges/Chips (align to accent; active uses primary)
20
+ "[--badge-bg:var(--accent)]", "[--badge-fg:var(--accent-foreground)]", "[--badge-border:var(--border)]", "[--badge-active-bg:var(--primary)]", "[--badge-active-fg:var(--primary-foreground)]", "[--badge-active-border:var(--primary)]",
21
+ // Typography helpers
22
+ "[--heading-fg:var(--foreground)]", "[--subheading-fg:var(--muted-foreground)]", "[--description-fg:var(--foreground)]",
23
+ // Process timeline
24
+ "[--process-step-bg:var(--primary)]", "[--process-step-fg:var(--primary-foreground)]", "[--process-connector:var(--border)]",
25
+ // Footer
26
+ "[--footer-bg:transparent]", "[--footer-fg:var(--foreground)]", "[--footer-heading-fg:var(--foreground)]", "[--footer-link-fg:var(--muted-foreground)]", "[--footer-link-hover-fg:var(--primary)]", "[--footer-link-hover-bg:color-mix(in oklab, var(--primary) 12%, transparent)]", "[--footer-muted-fg:var(--muted-foreground)]", "[--footer-border:var(--border)]",
27
+ // Table (optional)
28
+ "[--table-fg:inherit]", "[--table-muted-fg:var(--muted-foreground)]", "[--table-head-fg:var(--foreground)]", "[--table-border:var(--border)]", "[--table-row-hover-bg:var(--muted)]",
29
+ // Navbar
30
+ "[--navbar-toggle-bg:var(--background)]", "[--navbar-hover-bg:color-mix(in oklab, var(--primary) 12%, transparent)]", "[--navbar-ring:var(--ring)]", "[--navbar-border:var(--border)]", "[--navbar-accent:var(--foreground)]", className), children: children }));
31
+ }
@@ -0,0 +1,33 @@
1
+ import React from "react";
2
+ import { cn } from "@nextworks/blocks-core";
3
+ /**
4
+ * Gallery template token-bridge wrapper.
5
+ *
6
+ * Maps component-level CSS variables (btn, input, card, etc.) to the
7
+ * EnhancedThemeProvider token variables applied on :root (e.g., --primary,
8
+ * --foreground, --card, --ring). This preserves the original Gallery behavior:
9
+ * colors are driven by the selected Color Theme, not a fixed preset palette.
10
+ */
11
+ export function PresetThemeVars({ className, children }) {
12
+ return (<div className={cn(
13
+ // Buttons (leave bg/fg unset by default so tokenized variants can apply; set ring here)
14
+ "[--btn-ring:var(--ring)]",
15
+ // Inputs
16
+ "[--input-bg:var(--background)]", "[--input-fg:var(--foreground)]", "[--input-placeholder:var(--muted-foreground)]", "[--input-border:var(--input)]", "[--input-focus-ring:var(--ring)]", "[--input-ring-offset:var(--background)]",
17
+ // Cards
18
+ "[--card-bg:var(--card)]", "[--card-fg:var(--card-foreground)]", "[--card-title-fg:var(--foreground)]", "[--card-muted-fg:var(--muted-foreground)]", "[--card-border:var(--border)]", "[--card-shadow:0_6px_20px_rgba(0,0,0,0.06)]",
19
+ // Badges/Chips (align to accent; active uses primary)
20
+ "[--badge-bg:var(--accent)]", "[--badge-fg:var(--accent-foreground)]", "[--badge-border:var(--border)]", "[--badge-active-bg:var(--primary)]", "[--badge-active-fg:var(--primary-foreground)]", "[--badge-active-border:var(--primary)]",
21
+ // Typography helpers
22
+ "[--heading-fg:var(--foreground)]", "[--subheading-fg:var(--muted-foreground)]", "[--description-fg:var(--foreground)]",
23
+ // Process timeline
24
+ "[--process-step-bg:var(--primary)]", "[--process-step-fg:var(--primary-foreground)]", "[--process-connector:var(--border)]",
25
+ // Footer
26
+ "[--footer-bg:transparent]", "[--footer-fg:var(--foreground)]", "[--footer-heading-fg:var(--foreground)]", "[--footer-link-fg:var(--muted-foreground)]", "[--footer-link-hover-fg:var(--primary)]", "[--footer-link-hover-bg:color-mix(in oklab, var(--primary) 12%, transparent)]", "[--footer-muted-fg:var(--muted-foreground)]", "[--footer-border:var(--border)]",
27
+ // Table (optional)
28
+ "[--table-fg:inherit]", "[--table-muted-fg:var(--muted-foreground)]", "[--table-head-fg:var(--foreground)]", "[--table-border:var(--border)]", "[--table-row-hover-bg:var(--muted)]",
29
+ // Navbar
30
+ "[--navbar-toggle-bg:var(--background)]", "[--navbar-hover-bg:color-mix(in oklab, var(--primary) 12%, transparent)]", "[--navbar-ring:var(--ring)]", "[--navbar-border:var(--border)]", "[--navbar-accent:var(--foreground)]", className)}>
31
+ {children}
32
+ </div>);
33
+ }
@@ -0,0 +1,2 @@
1
+ export default function Gallery(): import("react").JSX.Element;
2
+ //# sourceMappingURL=page.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"page.d.ts","sourceRoot":"","sources":["../../../src/templates/gallery/page.tsx"],"names":[],"mappings":"AA6BA,MAAM,CAAC,OAAO,UAAU,OAAO,gCAqR9B"}
@@ -0,0 +1,151 @@
1
+ // - /app/templates/gallery/page.tsx
2
+ "use client";
3
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
4
+ import { About, Contact, CTA, FAQ, Features, Footer, HeroMotion, HeroOverlay, HeroSplit, Navbar, Newsletter, PortfolioSimple, Pricing, ProcessTimeline, ServicesGrid, Team, Testimonials, TrustBadges, } from "@nextworks/blocks-sections";
5
+ import { ThemeSelector } from "@nextworks/blocks-core";
6
+ import { PresetThemeVars } from "./PresetThemeVars";
7
+ export default function Gallery() {
8
+ const defaultFeaturesData = [
9
+ {
10
+ imageSrc: "/placeholders/gallery/pexels-googledeepmind-25626431.jpg",
11
+ imageAlt: "Advanced Analytics Dashboard",
12
+ headingText: "Advanced Analytics",
13
+ subheadingText: "Get deep insights into your business performance with our comprehensive analytics dashboard that tracks key metrics and provides actionable recommendations.",
14
+ },
15
+ {
16
+ imageSrc: "/placeholders/gallery/pexels-googledeepmind-25626432.jpg",
17
+ imageAlt: "Real-time Collaboration Tools",
18
+ headingText: "Real-time Collaboration",
19
+ subheadingText: "Work seamlessly with your team using our real-time collaboration tools that keep everyone in sync and boost productivity across all projects.",
20
+ },
21
+ {
22
+ imageSrc: "/placeholders/gallery/pexels-googledeepmind-25626434.jpg",
23
+ imageAlt: "Secure Data Management",
24
+ headingText: "Secure Data Management",
25
+ subheadingText: "Protect your sensitive information with enterprise-grade security features including encryption, access controls, and compliance monitoring.",
26
+ },
27
+ {
28
+ imageSrc: "/placeholders/gallery/pexels-googledeepmind-25626436.jpg",
29
+ imageAlt: "Mobile-First Design",
30
+ headingText: "Mobile-First Design",
31
+ subheadingText: "Access your data and manage your workflow from anywhere with our responsive, mobile-optimized interface that works perfectly on all devices.",
32
+ },
33
+ ];
34
+ const BrandNode = (_jsxs(_Fragment, { children: [_jsx(ThemeSelector, { ariaLabel: "Demo: Color theme", label: "", className: "mr-2" }), _jsx("div", { className: "flex h-7 w-7 items-center justify-center rounded-md bg-gradient-to-br from-zinc-900 via-zinc-700 to-zinc-500 text-xs font-bold text-white shadow-sm dark:from-zinc-100 dark:via-zinc-300 dark:to-zinc-500 dark:text-zinc-900", children: "NW" })] }));
35
+ return (_jsx(PresetThemeVars, { children: _jsxs("div", { className: "component-gallery", children: [_jsx(Navbar, { container: { className: "max-w-7xl mx-auto" }, mobileMenu: {
36
+ className: "border-t border-border md:block lg:hidden",
37
+ }, desktopMenu: {
38
+ className: "hidden md:hidden lg:flex items-center space-x-1 lg:space-x-0",
39
+ }, id: "site-navigation", brand: "Nextworks", brandNode: BrandNode, menuItems: [
40
+ { label: "Hero", href: "#hero-sections" },
41
+ { label: "Trust", href: "#trust" },
42
+ { label: "Features", href: "#features" },
43
+ { label: "About", href: "#about-process" },
44
+ { label: "Work", href: "#portfolio-team" },
45
+ { label: "Testimonials", href: "#testimonials" },
46
+ { label: "Pricing", href: "#pricing" },
47
+ { label: "FAQ", href: "#faq" },
48
+ { label: "CTA", href: "#cta" },
49
+ { label: "Contact", href: "#contact" },
50
+ ], links: {
51
+ className: "text-base font-normal text-foreground hover:text-gray-500 dark:hover:text-gray-400 transition-colors",
52
+ }, ctaButton: null }), _jsxs("div", { id: "hero-sections", children: [_jsx(HeroMotion, { actions: {
53
+ className: "mt-8 flex items-center justify-center gap-3 [--btn-ring:var(--ring)]",
54
+ }, primaryButtonStyle: {
55
+ size: "lg",
56
+ variant: "default",
57
+ className: "[--btn-bg:var(--primary)] [--btn-fg:var(--primary-foreground)] " +
58
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_88%,black)] " +
59
+ "hover:[--btn-hover-fg:var(--primary-foreground)]",
60
+ }, secondaryButtonStyle: {
61
+ size: "lg",
62
+ variant: "outline",
63
+ className: "border [&:where(button)]:border " +
64
+ "[--btn-bg:transparent] dark:[--btn-bg:transparent] " +
65
+ "[--btn-fg:var(--primary)] dark:[--btn-fg:var(--primary)] " +
66
+ "[--btn-border:var(--primary)] dark:[--btn-border:var(--primary)] " +
67
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_15%,transparent)] " +
68
+ "dark:hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_18%,transparent)] " +
69
+ "hover:[--btn-hover-fg:var(--primary)] dark:hover:[--btn-hover-fg:var(--primary)]",
70
+ }, primaryCta: { label: "Get Started", href: "#hero-sections" }, secondaryCta: { label: "See Demo", href: "#hero-sections" } }), _jsx(HeroOverlay, { heading: "Forecast The Next Move", subheading: "Predict demand, personalize journeys, and scale impact with AI-guided insights your team can use today.", cta1: {
71
+ label: "Try It Free",
72
+ href: "#hero-sections",
73
+ className: "[--btn-bg:var(--primary)] [--btn-fg:var(--primary-foreground)] " +
74
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_88%,black)] " +
75
+ "hover:[--btn-hover-fg:var(--primary-foreground)]",
76
+ }, cta2: {
77
+ label: "See Demo",
78
+ href: "#hero-sections",
79
+ // Outline CTA should be transparent bg, primary fg/border, with subtle hover bg
80
+ className: "border [&:where(button)]:border " +
81
+ "[--btn-bg:transparent] dark:[--btn-bg:transparent] " +
82
+ "[--btn-fg:var(--primary)] dark:[--btn-fg:var(--primary)] " +
83
+ "[--btn-border:var(--primary)] dark:[--btn-border:var(--primary)] " +
84
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_15%,transparent)] " +
85
+ "dark:hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_18%,transparent)] " +
86
+ "hover:[--btn-hover-fg:var(--primary)] dark:hover:[--btn-hover-fg:var(--primary)]",
87
+ },
88
+ // Set ring color on the CTA container so both buttons share it
89
+ ctaContainer: {
90
+ className: "flex flex-col sm:flex-row gap-4 mt-6 justify-center items-center [--btn-ring:var(--ring)]",
91
+ }, image: {
92
+ src: "/placeholders/gallery/hero-pexels-broken-9945014.avif",
93
+ } }), _jsx(HeroSplit, { heading: "Confident Decisions, On Demand", subheading: "Reliable data when you need it.", cta1: {
94
+ label: "Start Free Trial",
95
+ href: "#hero-sections",
96
+ className: "[--btn-bg:var(--primary)] [--btn-fg:var(--primary-foreground)] " +
97
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_88%,black)] " +
98
+ "hover:[--btn-hover-fg:var(--primary-foreground)]",
99
+ }, cta2: {
100
+ label: "View Sample Report",
101
+ href: "#hero-sections",
102
+ className: "border [&:where(button)]:border " +
103
+ "[--btn-bg:transparent] dark:[--btn-bg:transparent] " +
104
+ "[--btn-fg:var(--primary)] dark:[--btn-fg:var(--primary)] " +
105
+ "[--btn-border:var(--primary)] dark:[--btn-border:var(--primary)] " +
106
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_15%,transparent)] " +
107
+ "dark:hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_18%,transparent)] " +
108
+ "hover:[--btn-hover-fg:var(--primary)] dark:hover:[--btn-hover-fg:var(--primary)]",
109
+ }, buttonsContainer: {
110
+ className: "flex flex-col md:flex-row gap-4 mt-6 [--btn-ring:var(--ring)]",
111
+ }, image: {
112
+ src: "/placeholders/gallery/hero-pexels-broken-9945014.avif",
113
+ }, imageLayout: "full-bleed" })] }), _jsx("div", { id: "trust", className: "scroll-mt-16", children: _jsx(TrustBadges, {}) }), _jsxs("div", { id: "features", className: "scroll-mt-16", children: [_jsx(Features, { featuresData: defaultFeaturesData }), _jsx(ServicesGrid, {})] }), _jsxs("div", { id: "about-process", className: "scroll-mt-16", children: [_jsx(About, { animateStats: false }), _jsx(ProcessTimeline, {})] }), _jsxs("div", { id: "portfolio-team", className: "scroll-mt-16", children: [_jsx(PortfolioSimple, {}), _jsx(Team, {})] }), _jsx("div", { id: "testimonials", className: "scroll-mt-16", children: _jsx(Testimonials, {}) }), _jsx("div", { id: "pricing", className: "scroll-mt-16", children: _jsx(Pricing, {}) }), _jsx("div", { id: "faq", className: "scroll-mt-16", children: _jsx(FAQ, { questionButton: {
114
+ className:
115
+ // Distinct, theme-driven gradient tile + brand ring/border
116
+ "bg-gradient-to-r " +
117
+ "from-[var(--primary)] to-[color-mix(in_oklab,var(--primary)_88%,black)] " +
118
+ "hover:from-[color-mix(in_oklab,var(--primary)_92%,black)] " +
119
+ "hover:to-[color-mix(in_oklab,var(--primary)_95%,black)] " +
120
+ "text-[var(--primary-foreground)] p-5 cursor-pointer rounded-lg " +
121
+ "transition-all duration-200 flex items-center justify-between " +
122
+ "shadow-lg hover:shadow-xl hover:-translate-y-0.5 " +
123
+ // define ring/border vars and ensure a visible border if tokens apply
124
+ "[--btn-ring:var(--ring)] [--btn-border:var(--primary)] border [&:where(button)]:border",
125
+ }, answer: {
126
+ className: "bg-gradient-to-r " +
127
+ "from-[var(--secondary)] to-[color-mix(in_oklab,var(--secondary)_90%,white)] ",
128
+ } }) }), _jsx("div", { id: "cta", className: "scroll-mt-16", children: _jsx(CTA, { ctaButton: { label: "Sign Up Now", href: "#contact" }, actionsWrapper: {
129
+ className: "mt-6 flex flex-col items-center gap-3 sm:flex-row [--btn-ring:var(--ring)]",
130
+ }, ctaButtonStyle: {
131
+ variant: "default",
132
+ size: "default",
133
+ className: "shadow-lg hover:shadow-xl transition-all duration-200 hover:-translate-y-0.5 " +
134
+ "[--btn-bg:var(--primary)] [--btn-fg:var(--primary-foreground)] " +
135
+ "hover:[--btn-hover-bg:color-mix(in_oklab,var(--primary)_88%,black)] " +
136
+ "hover:[--btn-hover-fg:var(--primary-foreground)]",
137
+ } }) }), _jsx("div", { id: "contact", className: "scroll-mt-16", children: _jsx(Contact, { submitButtonStyle: {
138
+ variant: "default",
139
+ size: "lg",
140
+ className: "w-full shadow-lg hover:shadow-xl transition-all duration-200 hover:-translate-y-0.5 " +
141
+ // Match FAQ question button gradient + brand ring/border
142
+ "bg-gradient-to-r " +
143
+ "from-[var(--primary)] to-[color-mix(in_oklab,var(--primary)_88%,black)] " +
144
+ "hover:from-[color-mix(in_oklab,var(--primary)_92%,black)] " +
145
+ "hover:to-[color-mix(in_oklab,var(--primary)_95%,black)] " +
146
+ "text-[var(--primary-foreground)] " +
147
+ "[--btn-ring:var(--ring)] [--btn-border:var(--primary)] border [&:where(button)]:border",
148
+ } }) }), _jsx("div", { id: "newsletter", className: "scroll-mt-16", children: _jsx(Newsletter, { button: {
149
+ className: "!bg-[var(--primary)] hover:!bg-[color-mix(in_oklab,var(--primary)_90%,transparent)] !text-[var(--primary-foreground)] hover:!text-[var(--primary-background)]",
150
+ } }) }), _jsx("div", { id: "footer", children: _jsx(Footer, {}) })] }) }));
151
+ }