nextworks 0.2.0-alpha.11 → 0.2.0-alpha.13

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 (111) hide show
  1. package/README.md +283 -282
  2. package/dist/cli_manifests/blocks_manifest.json +198 -175
  3. package/dist/kits/blocks/.nextworks/docs/BLOCKS_QUICKSTART.md +101 -100
  4. package/dist/kits/blocks/.nextworks/docs/BLOCKS_README.md +105 -104
  5. package/dist/kits/blocks/.nextworks/docs/THEME_GUIDE.md +1 -1
  6. package/dist/kits/blocks/app/templates/aiworkflow/PresetThemeVars.tsx +58 -0
  7. package/dist/kits/blocks/app/templates/aiworkflow/README.md +46 -0
  8. package/dist/kits/blocks/app/templates/aiworkflow/components/CTA.tsx +44 -0
  9. package/dist/kits/blocks/app/templates/aiworkflow/components/Contact.tsx +105 -0
  10. package/dist/kits/blocks/app/templates/aiworkflow/components/FAQ.tsx +63 -0
  11. package/dist/kits/blocks/app/templates/aiworkflow/components/Features.tsx +65 -0
  12. package/dist/kits/blocks/app/templates/aiworkflow/components/Footer.tsx +109 -0
  13. package/dist/kits/blocks/app/templates/aiworkflow/components/Hero.tsx +636 -0
  14. package/dist/kits/blocks/app/templates/aiworkflow/components/Navbar.tsx +90 -0
  15. package/dist/kits/blocks/app/templates/aiworkflow/components/Pricing.tsx +86 -0
  16. package/dist/kits/blocks/app/templates/aiworkflow/components/ProcessTimeline.tsx +103 -0
  17. package/dist/kits/blocks/app/templates/aiworkflow/components/Testimonials.tsx +56 -0
  18. package/dist/kits/blocks/app/templates/aiworkflow/components/TrustBadges.tsx +59 -0
  19. package/dist/kits/blocks/app/templates/aiworkflow/page.tsx +43 -0
  20. package/dist/kits/blocks/app/templates/digitalagency/PresetThemeVars.tsx +80 -80
  21. package/dist/kits/blocks/app/templates/digitalagency/README.md +42 -42
  22. package/dist/kits/blocks/app/templates/digitalagency/components/Pricing.tsx +114 -114
  23. package/dist/kits/blocks/app/templates/digitalagency/components/Process.tsx +59 -59
  24. package/dist/kits/blocks/app/templates/digitalagency/components/Services.tsx +55 -55
  25. package/dist/kits/blocks/app/templates/digitalagency/components/Team.tsx +28 -28
  26. package/dist/kits/blocks/app/templates/digitalagency/components/Testimonials.tsx +65 -65
  27. package/dist/kits/blocks/app/templates/digitalagency/page.tsx +38 -38
  28. package/dist/kits/blocks/app/templates/gallery/PresetThemeVars.tsx +84 -84
  29. package/dist/kits/blocks/app/templates/productlaunch/PresetThemeVars.tsx +75 -75
  30. package/dist/kits/blocks/app/templates/productlaunch/README.md +62 -62
  31. package/dist/kits/blocks/app/templates/productlaunch/components/About.tsx +84 -84
  32. package/dist/kits/blocks/app/templates/productlaunch/components/CTA.tsx +50 -50
  33. package/dist/kits/blocks/app/templates/productlaunch/components/Contact.tsx +231 -231
  34. package/dist/kits/blocks/app/templates/productlaunch/components/FAQ.tsx +86 -86
  35. package/dist/kits/blocks/app/templates/productlaunch/components/Features.tsx +83 -83
  36. package/dist/kits/blocks/app/templates/productlaunch/components/Footer.tsx +132 -132
  37. package/dist/kits/blocks/app/templates/productlaunch/components/Hero.tsx +88 -88
  38. package/dist/kits/blocks/app/templates/productlaunch/components/Navbar.tsx +116 -116
  39. package/dist/kits/blocks/app/templates/productlaunch/components/Pricing.tsx +106 -106
  40. package/dist/kits/blocks/app/templates/productlaunch/components/ProcessTimeline.tsx +110 -110
  41. package/dist/kits/blocks/app/templates/productlaunch/components/ServicesGrid.tsx +68 -68
  42. package/dist/kits/blocks/app/templates/productlaunch/components/Team.tsx +104 -104
  43. package/dist/kits/blocks/app/templates/productlaunch/components/Testimonials.tsx +90 -90
  44. package/dist/kits/blocks/app/templates/productlaunch/components/TrustBadges.tsx +76 -76
  45. package/dist/kits/blocks/app/templates/productlaunch/page.tsx +43 -43
  46. package/dist/kits/blocks/app/templates/saasdashboard/PresetThemeVars.tsx +80 -80
  47. package/dist/kits/blocks/app/templates/saasdashboard/README.md +44 -44
  48. package/dist/kits/blocks/app/templates/saasdashboard/components/Contact.tsx +129 -129
  49. package/dist/kits/blocks/app/templates/saasdashboard/components/Dashboard.tsx +293 -293
  50. package/dist/kits/blocks/app/templates/saasdashboard/components/FAQ.tsx +55 -55
  51. package/dist/kits/blocks/app/templates/saasdashboard/components/Features.tsx +90 -90
  52. package/dist/kits/blocks/app/templates/saasdashboard/components/Footer.tsx +77 -77
  53. package/dist/kits/blocks/app/templates/saasdashboard/components/Hero.tsx +104 -104
  54. package/dist/kits/blocks/app/templates/saasdashboard/components/Hero_mask.tsx +126 -126
  55. package/dist/kits/blocks/app/templates/saasdashboard/components/Navbar.tsx +117 -117
  56. package/dist/kits/blocks/app/templates/saasdashboard/components/Pricing.tsx +90 -90
  57. package/dist/kits/blocks/app/templates/saasdashboard/components/SmoothScroll.tsx +96 -96
  58. package/dist/kits/blocks/app/templates/saasdashboard/components/Testimonials.tsx +72 -72
  59. package/dist/kits/blocks/app/templates/saasdashboard/components/TrustBadges.tsx +53 -53
  60. package/dist/kits/blocks/app/templates/saasdashboard/page.tsx +39 -39
  61. package/dist/kits/blocks/components/enhanced-theme-provider.tsx +195 -195
  62. package/dist/kits/blocks/components/providers/BlocksAppProviders.tsx +27 -27
  63. package/dist/kits/blocks/components/sections/About.tsx +291 -291
  64. package/dist/kits/blocks/components/sections/CTA.tsx +257 -257
  65. package/dist/kits/blocks/components/sections/Contact.tsx +267 -267
  66. package/dist/kits/blocks/components/sections/FAQ.tsx +214 -214
  67. package/dist/kits/blocks/components/sections/Features.tsx +268 -268
  68. package/dist/kits/blocks/components/sections/Footer.tsx +302 -302
  69. package/dist/kits/blocks/components/sections/HeroMotion.tsx +308 -308
  70. package/dist/kits/blocks/components/sections/HeroOverlay.tsx +358 -358
  71. package/dist/kits/blocks/components/sections/HeroProductDemo.tsx +236 -0
  72. package/dist/kits/blocks/components/sections/HeroSplit.tsx +352 -352
  73. package/dist/kits/blocks/components/sections/Navbar.tsx +350 -350
  74. package/dist/kits/blocks/components/sections/PortfolioSimple.tsx +549 -549
  75. package/dist/kits/blocks/components/sections/Pricing.tsx +264 -264
  76. package/dist/kits/blocks/components/sections/ProcessTimeline.tsx +325 -325
  77. package/dist/kits/blocks/components/sections/ServicesGrid.tsx +210 -210
  78. package/dist/kits/blocks/components/sections/Team.tsx +309 -309
  79. package/dist/kits/blocks/components/sections/Testimonials.tsx +158 -158
  80. package/dist/kits/blocks/components/sections/TrustBadges.tsx +162 -162
  81. package/dist/kits/blocks/components/sections/product-demo/ApprovalInboxPanel.tsx +125 -0
  82. package/dist/kits/blocks/components/sections/product-demo/DemoStage.tsx +397 -0
  83. package/dist/kits/blocks/components/sections/product-demo/DemoWindow.tsx +128 -0
  84. package/dist/kits/blocks/components/sections/product-demo/KnowledgePanel.tsx +127 -0
  85. package/dist/kits/blocks/components/sections/product-demo/RunConsolePanel.tsx +150 -0
  86. package/dist/kits/blocks/components/sections/product-demo/WorkflowStudioPanel.tsx +191 -0
  87. package/dist/kits/blocks/components/sections/product-demo/types.ts +193 -0
  88. package/dist/kits/blocks/components/theme-provider.tsx +1 -1
  89. package/dist/kits/blocks/components/ui/alert-dialog.tsx +134 -134
  90. package/dist/kits/blocks/components/ui/brand-node.tsx +121 -121
  91. package/dist/kits/blocks/components/ui/button.tsx +122 -122
  92. package/dist/kits/blocks/components/ui/card.tsx +95 -95
  93. package/dist/kits/blocks/components/ui/checkbox.tsx +30 -30
  94. package/dist/kits/blocks/components/ui/cta-button.tsx +125 -125
  95. package/dist/kits/blocks/components/ui/dropdown-menu.tsx +201 -201
  96. package/dist/kits/blocks/components/ui/feature-card.tsx +91 -91
  97. package/dist/kits/blocks/components/ui/input.tsx +27 -27
  98. package/dist/kits/blocks/components/ui/label.tsx +29 -29
  99. package/dist/kits/blocks/components/ui/pricing-card.tsx +120 -120
  100. package/dist/kits/blocks/components/ui/select.tsx +25 -25
  101. package/dist/kits/blocks/components/ui/skeleton.tsx +13 -13
  102. package/dist/kits/blocks/components/ui/table.tsx +98 -98
  103. package/dist/kits/blocks/components/ui/testimonial-card.tsx +108 -108
  104. package/dist/kits/blocks/components/ui/textarea.tsx +26 -26
  105. package/dist/kits/blocks/components/ui/theme-selector.tsx +243 -243
  106. package/dist/kits/blocks/components/ui/theme-toggle.tsx +74 -74
  107. package/dist/kits/blocks/components/ui/toaster.tsx +7 -7
  108. package/dist/kits/blocks/lib/themes.ts +400 -400
  109. package/dist/kits/blocks/lib/utils.ts +6 -6
  110. package/dist/kits/blocks/package-deps.json +3 -3
  111. package/package.json +1 -1
@@ -1,309 +1,309 @@
1
- "use client";
2
-
3
- import React from "react";
4
- import Link from "next/link";
5
- import { cn } from "@/lib/utils";
6
-
7
- /**
8
- * A social link shown on a team member card.
9
- * @public
10
- */
11
- export interface SocialLink {
12
- /** Platform name (e.g., "LinkedIn") */
13
- platform: string;
14
- /** Destination URL */
15
- url: string;
16
- /** Icon identifier or emoji; replace with SVGs in real usage */
17
- icon: string;
18
- }
19
-
20
- /**
21
- * Team member data rendered by Team.
22
- * @public
23
- */
24
- export interface TeamMemberData {
25
- /** Member name */
26
- name?: string;
27
- /** Job role or title */
28
- role?: string;
29
- /** Short bio or description */
30
- bio?: string;
31
- /** Avatar content (emoji or image URL if swapped out) */
32
- avatar?: string;
33
- /** Optional social links */
34
- socialLinks?: SocialLink[];
35
- }
36
-
37
- /**
38
- * Props for the Team section component.
39
- *
40
- * @remarks
41
- * - Styling: slot-style className overrides are merged after defaults via cn().
42
- * - Motion: enableMotion controls hover lift on cards.
43
- * - Accessibility: semantic <section> with aria-label.
44
- */
45
- export interface TeamProps {
46
- /** Optional id on root. @defaultValue "team" */
47
- id?: string;
48
- /** Top-level className override */
49
- className?: string;
50
- /** Section heading text or object. @defaultValue "Meet Our Team" */
51
- teamHeadingText?: string | { text?: string; className?: string };
52
- /** Optional subheading text or object. @defaultValue "The talented people behind your success" */
53
- teamSubheadingText?: string | { text?: string; className?: string };
54
- /** Members to render. @defaultValue DefaultTeamData */
55
- teamMembers?: TeamMemberData[];
56
-
57
- /** Slot-style overrides */
58
- section?: { className?: string };
59
- container?: { className?: string };
60
- header?: { className?: string };
61
- heading?: { className?: string };
62
- subheading?: { className?: string };
63
- grid?: { className?: string };
64
- card?: { className?: string };
65
- cardContent?: { className?: string };
66
- avatar?: { className?: string };
67
- name?: { className?: string };
68
- role?: { className?: string };
69
- bio?: { className?: string };
70
- socialLinks?: { className?: string };
71
- socialLink?: { className?: string };
72
-
73
- /** When false, removes hover lift on cards */
74
- enableMotion?: boolean;
75
-
76
- /** ARIA label for the section. @defaultValue "Team section" */
77
- ariaLabel?: string;
78
- }
79
-
80
- const DefaultTeamData: TeamMemberData[] = [
81
- {
82
- name: "Alex Chen",
83
- role: "CEO & Founder",
84
- bio: "Full-stack developer with 8+ years.",
85
- avatar: "👨‍💼",
86
- socialLinks: [{ platform: "LinkedIn", url: "#", icon: "💼" }],
87
- },
88
- {
89
- name: "Sarah Martinez",
90
- role: "Lead Designer",
91
- bio: "UI/UX expert.",
92
- avatar: "👩‍🎨",
93
- socialLinks: [{ platform: "Dribbble", url: "#", icon: "🎨" }],
94
- },
95
- {
96
- name: "Jordan Patel",
97
- role: "DevOps Engineer",
98
- bio: "Automates cloud infra and CI/CD pipelines.",
99
- avatar: "🛠️",
100
- socialLinks: [{ platform: "GitHub", url: "#", icon: "🐙" }],
101
- },
102
- {
103
- name: "Maya Thompson",
104
- role: "Product Manager",
105
- bio: "Drives roadmap and aligns cross‑functional teams.",
106
- avatar: "🧭",
107
- socialLinks: [{ platform: "Twitter", url: "#", icon: "🐦" }],
108
- },
109
- ];
110
-
111
- /**
112
- * Internal presentational card for a single team member.
113
- * Receives already-merged className strings from the parent.
114
- */
115
- function TeamCard({
116
- member,
117
- card = { className: "" },
118
- cardContent = { className: "" },
119
- avatar = { className: "" },
120
- name = { className: "" },
121
- role = { className: "" },
122
- bio = { className: "" },
123
- socialLinks = { className: "" },
124
- socialLink = { className: "" },
125
- }: {
126
- member: TeamMemberData;
127
- card?: { className?: string };
128
- cardContent?: { className?: string };
129
- avatar?: { className?: string };
130
- name?: { className?: string };
131
- role?: { className?: string };
132
- bio?: { className?: string };
133
- socialLinks?: { className?: string };
134
- socialLink?: { className?: string };
135
- }) {
136
- return (
137
- <div className={card.className}>
138
- <div className={cardContent.className}>
139
- <div className={avatar.className}>{member.avatar}</div>
140
- <h3 className={name.className}>{member.name}</h3>
141
- <p className={role.className}>{member.role}</p>
142
- <p className={bio.className}>{member.bio}</p>
143
- {member.socialLinks && member.socialLinks.length > 0 && (
144
- <div className={socialLinks.className}>
145
- {member.socialLinks.map((social, index) => (
146
- <Link
147
- key={index}
148
- href={social.url}
149
- className={socialLink.className}
150
- title={social.platform}
151
- aria-label={`${member.name}'s ${social.platform} profile`}
152
- >
153
- {social.icon}
154
- </Link>
155
- ))}
156
- </div>
157
- )}
158
- </div>
159
- </div>
160
- );
161
- }
162
-
163
- /**
164
- * Team section with heading, subheading, and a responsive member grid.
165
- *
166
- * @remarks
167
- * - Uses a slot-style API for className overrides merged via cn().
168
- * - Motion: enableMotion toggles hover lift on cards.
169
- * - Accessibility: semantic <section> with aria-label.
170
- *
171
- * @example
172
- * <Team teamMembers={[{ name: 'Alex', role: 'Engineer' }]} />
173
- */
174
- export function Team({
175
- id,
176
- className,
177
- teamMembers = DefaultTeamData,
178
- teamHeadingText = "Meet Our Team",
179
- teamSubheadingText = "The talented people behind your success",
180
- section,
181
- container,
182
- header,
183
- heading,
184
- subheading,
185
- grid,
186
- card,
187
- cardContent,
188
- avatar,
189
- name,
190
- role,
191
- bio,
192
- socialLinks,
193
- socialLink,
194
- enableMotion = true,
195
- ariaLabel = "Team section",
196
- }: TeamProps) {
197
- // Defaults for slots
198
- const defaultSection = "py-16 px-6 bg-muted";
199
- const defaultContainer = "max-w-7xl mx-auto";
200
- const defaultHeader = "space-y-12 items-center";
201
- const defaultHeadingClass =
202
- "text-3xl font-bold font-poppins text-foreground text-center text-[var(--heading-fg)]";
203
- const defaultSubheadingClass =
204
- "text-lg font-inter text-muted-foreground opacity-80 leading-relaxed text-center max-w-2xl text-[var(--subheading-fg)]";
205
- const defaultGrid =
206
- "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-8 w-full";
207
- const defaultCardBase =
208
- "bg-card p-6 rounded-lg shadow-md text-center border border-border bg-[var(--card-bg)] text-[var(--card-fg)] border-[var(--card-border)] shadow-[var(--card-shadow)]";
209
- const defaultCardContent = "flex flex-col items-center space-y-4";
210
- const defaultAvatar = "text-4xl mb-2";
211
- const defaultName =
212
- "text-xl font-bold font-poppins text-card-foreground text-[var(--card-fg)]";
213
- const defaultRole = "text-md font-semibold font-poppins text-primary";
214
- const defaultBio =
215
- "text-sm font-inter text-muted-foreground opacity-80 leading-relaxed text-[var(--card-muted-fg)]";
216
- const defaultSocialLinks = "flex gap-3 mt-2";
217
- const defaultSocialLink =
218
- "text-lg text-primary hover:text-accent-foreground transition-colors duration-200";
219
-
220
- // Motion control for card
221
- const motionCard = enableMotion
222
- ? "transition-transform duration-200 hover:-translate-y-1"
223
- : "transition-none hover:!translate-y-0";
224
-
225
- // Merge slot classes using cn (defaults first, then overrides)
226
- const finalSectionClass = cn(defaultSection, section?.className, className);
227
- const finalContainerClass = cn(defaultContainer, container?.className);
228
- const finalHeaderClass = cn(defaultHeader, header?.className);
229
- const finalGridClass = cn(defaultGrid, grid?.className);
230
-
231
- const finalCardClass = cn(defaultCardBase, motionCard, card?.className);
232
- const finalCardContentClass = cn(defaultCardContent, cardContent?.className);
233
- const finalAvatarClass = cn(defaultAvatar, avatar?.className);
234
- const finalNameClass = cn(defaultName, name?.className);
235
- const finalRoleClass = cn(defaultRole, role?.className);
236
- const finalBioClass = cn(defaultBio, bio?.className);
237
- const finalSocialLinksClass = cn(defaultSocialLinks, socialLinks?.className);
238
- const finalSocialLinkClass = cn(defaultSocialLink, socialLink?.className);
239
-
240
- // Normalize heading/subheading allowing string or object, plus slot class merges
241
- const normalizedHeading =
242
- typeof teamHeadingText === "string"
243
- ? {
244
- text: teamHeadingText,
245
- className: cn(defaultHeadingClass, heading?.className),
246
- }
247
- : {
248
- text: teamHeadingText?.text ?? "Meet Our Team",
249
- className: cn(
250
- defaultHeadingClass,
251
- teamHeadingText?.className,
252
- heading?.className,
253
- ),
254
- };
255
-
256
- const normalizedSubheading =
257
- typeof teamSubheadingText === "string"
258
- ? {
259
- text: teamSubheadingText,
260
- className: cn(defaultSubheadingClass, subheading?.className),
261
- }
262
- : {
263
- text:
264
- teamSubheadingText?.text ??
265
- "The talented people behind your success",
266
- className: cn(
267
- defaultSubheadingClass,
268
- teamSubheadingText?.className,
269
- subheading?.className,
270
- ),
271
- };
272
-
273
- return (
274
- <section
275
- id={id || "team"}
276
- className={finalSectionClass}
277
- aria-label={ariaLabel}
278
- >
279
- <div className={finalContainerClass}>
280
- <div className={finalHeaderClass}>
281
- <div className="mx-auto flex max-w-2xl flex-col items-center space-y-4 text-center">
282
- <h2 className={normalizedHeading.className}>
283
- {normalizedHeading.text}
284
- </h2>
285
- <p className={normalizedSubheading.className}>
286
- {normalizedSubheading.text}
287
- </p>
288
- </div>
289
- <div className={finalGridClass}>
290
- {teamMembers.map((member, index) => (
291
- <TeamCard
292
- key={index}
293
- member={member}
294
- card={{ className: finalCardClass }}
295
- cardContent={{ className: finalCardContentClass }}
296
- avatar={{ className: finalAvatarClass }}
297
- name={{ className: finalNameClass }}
298
- role={{ className: finalRoleClass }}
299
- bio={{ className: finalBioClass }}
300
- socialLinks={{ className: finalSocialLinksClass }}
301
- socialLink={{ className: finalSocialLinkClass }}
302
- />
303
- ))}
304
- </div>
305
- </div>
306
- </div>
307
- </section>
308
- );
309
- }
1
+ "use client";
2
+
3
+ import React from "react";
4
+ import Link from "next/link";
5
+ import { cn } from "@/lib/utils";
6
+
7
+ /**
8
+ * A social link shown on a team member card.
9
+ * @public
10
+ */
11
+ export interface SocialLink {
12
+ /** Platform name (e.g., "LinkedIn") */
13
+ platform: string;
14
+ /** Destination URL */
15
+ url: string;
16
+ /** Icon identifier or emoji; replace with SVGs in real usage */
17
+ icon: string;
18
+ }
19
+
20
+ /**
21
+ * Team member data rendered by Team.
22
+ * @public
23
+ */
24
+ export interface TeamMemberData {
25
+ /** Member name */
26
+ name?: string;
27
+ /** Job role or title */
28
+ role?: string;
29
+ /** Short bio or description */
30
+ bio?: string;
31
+ /** Avatar content (emoji or image URL if swapped out) */
32
+ avatar?: string;
33
+ /** Optional social links */
34
+ socialLinks?: SocialLink[];
35
+ }
36
+
37
+ /**
38
+ * Props for the Team section component.
39
+ *
40
+ * @remarks
41
+ * - Styling: slot-style className overrides are merged after defaults via cn().
42
+ * - Motion: enableMotion controls hover lift on cards.
43
+ * - Accessibility: semantic <section> with aria-label.
44
+ */
45
+ export interface TeamProps {
46
+ /** Optional id on root. @defaultValue "team" */
47
+ id?: string;
48
+ /** Top-level className override */
49
+ className?: string;
50
+ /** Section heading text or object. @defaultValue "Meet Our Team" */
51
+ teamHeadingText?: string | { text?: string; className?: string };
52
+ /** Optional subheading text or object. @defaultValue "The talented people behind your success" */
53
+ teamSubheadingText?: string | { text?: string; className?: string };
54
+ /** Members to render. @defaultValue DefaultTeamData */
55
+ teamMembers?: TeamMemberData[];
56
+
57
+ /** Slot-style overrides */
58
+ section?: { className?: string };
59
+ container?: { className?: string };
60
+ header?: { className?: string };
61
+ heading?: { className?: string };
62
+ subheading?: { className?: string };
63
+ grid?: { className?: string };
64
+ card?: { className?: string };
65
+ cardContent?: { className?: string };
66
+ avatar?: { className?: string };
67
+ name?: { className?: string };
68
+ role?: { className?: string };
69
+ bio?: { className?: string };
70
+ socialLinks?: { className?: string };
71
+ socialLink?: { className?: string };
72
+
73
+ /** When false, removes hover lift on cards */
74
+ enableMotion?: boolean;
75
+
76
+ /** ARIA label for the section. @defaultValue "Team section" */
77
+ ariaLabel?: string;
78
+ }
79
+
80
+ const DefaultTeamData: TeamMemberData[] = [
81
+ {
82
+ name: "Alex Chen",
83
+ role: "CEO & Founder",
84
+ bio: "Full-stack developer with 8+ years.",
85
+ avatar: "👨‍💼",
86
+ socialLinks: [{ platform: "LinkedIn", url: "#", icon: "💼" }],
87
+ },
88
+ {
89
+ name: "Sarah Martinez",
90
+ role: "Lead Designer",
91
+ bio: "UI/UX expert.",
92
+ avatar: "👩‍🎨",
93
+ socialLinks: [{ platform: "Dribbble", url: "#", icon: "🎨" }],
94
+ },
95
+ {
96
+ name: "Jordan Patel",
97
+ role: "DevOps Engineer",
98
+ bio: "Automates cloud infra and CI/CD pipelines.",
99
+ avatar: "🛠️",
100
+ socialLinks: [{ platform: "GitHub", url: "#", icon: "🐙" }],
101
+ },
102
+ {
103
+ name: "Maya Thompson",
104
+ role: "Product Manager",
105
+ bio: "Drives roadmap and aligns cross‑functional teams.",
106
+ avatar: "🧭",
107
+ socialLinks: [{ platform: "Twitter", url: "#", icon: "🐦" }],
108
+ },
109
+ ];
110
+
111
+ /**
112
+ * Internal presentational card for a single team member.
113
+ * Receives already-merged className strings from the parent.
114
+ */
115
+ function TeamCard({
116
+ member,
117
+ card = { className: "" },
118
+ cardContent = { className: "" },
119
+ avatar = { className: "" },
120
+ name = { className: "" },
121
+ role = { className: "" },
122
+ bio = { className: "" },
123
+ socialLinks = { className: "" },
124
+ socialLink = { className: "" },
125
+ }: {
126
+ member: TeamMemberData;
127
+ card?: { className?: string };
128
+ cardContent?: { className?: string };
129
+ avatar?: { className?: string };
130
+ name?: { className?: string };
131
+ role?: { className?: string };
132
+ bio?: { className?: string };
133
+ socialLinks?: { className?: string };
134
+ socialLink?: { className?: string };
135
+ }) {
136
+ return (
137
+ <div className={card.className}>
138
+ <div className={cardContent.className}>
139
+ <div className={avatar.className}>{member.avatar}</div>
140
+ <h3 className={name.className}>{member.name}</h3>
141
+ <p className={role.className}>{member.role}</p>
142
+ <p className={bio.className}>{member.bio}</p>
143
+ {member.socialLinks && member.socialLinks.length > 0 && (
144
+ <div className={socialLinks.className}>
145
+ {member.socialLinks.map((social, index) => (
146
+ <Link
147
+ key={index}
148
+ href={social.url}
149
+ className={socialLink.className}
150
+ title={social.platform}
151
+ aria-label={`${member.name}'s ${social.platform} profile`}
152
+ >
153
+ {social.icon}
154
+ </Link>
155
+ ))}
156
+ </div>
157
+ )}
158
+ </div>
159
+ </div>
160
+ );
161
+ }
162
+
163
+ /**
164
+ * Team section with heading, subheading, and a responsive member grid.
165
+ *
166
+ * @remarks
167
+ * - Uses a slot-style API for className overrides merged via cn().
168
+ * - Motion: enableMotion toggles hover lift on cards.
169
+ * - Accessibility: semantic <section> with aria-label.
170
+ *
171
+ * @example
172
+ * <Team teamMembers={[{ name: 'Alex', role: 'Engineer' }]} />
173
+ */
174
+ export function Team({
175
+ id,
176
+ className,
177
+ teamMembers = DefaultTeamData,
178
+ teamHeadingText = "Meet Our Team",
179
+ teamSubheadingText = "The talented people behind your success",
180
+ section,
181
+ container,
182
+ header,
183
+ heading,
184
+ subheading,
185
+ grid,
186
+ card,
187
+ cardContent,
188
+ avatar,
189
+ name,
190
+ role,
191
+ bio,
192
+ socialLinks,
193
+ socialLink,
194
+ enableMotion = true,
195
+ ariaLabel = "Team section",
196
+ }: TeamProps) {
197
+ // Defaults for slots
198
+ const defaultSection = "py-16 px-6 bg-muted";
199
+ const defaultContainer = "max-w-7xl mx-auto";
200
+ const defaultHeader = "space-y-12 items-center";
201
+ const defaultHeadingClass =
202
+ "text-3xl font-bold font-poppins text-foreground text-center text-[var(--heading-fg)]";
203
+ const defaultSubheadingClass =
204
+ "text-lg font-inter text-muted-foreground opacity-80 leading-relaxed text-center max-w-2xl text-[var(--subheading-fg)]";
205
+ const defaultGrid =
206
+ "grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-8 w-full";
207
+ const defaultCardBase =
208
+ "bg-card p-6 rounded-lg shadow-md text-center border border-border bg-[var(--card-bg)] text-[var(--card-fg)] border-[var(--card-border)] shadow-[var(--card-shadow)]";
209
+ const defaultCardContent = "flex flex-col items-center space-y-4";
210
+ const defaultAvatar = "text-4xl mb-2";
211
+ const defaultName =
212
+ "text-xl font-bold font-poppins text-card-foreground text-[var(--card-fg)]";
213
+ const defaultRole = "text-md font-semibold font-poppins text-primary";
214
+ const defaultBio =
215
+ "text-sm font-inter text-muted-foreground opacity-80 leading-relaxed text-[var(--card-muted-fg)]";
216
+ const defaultSocialLinks = "flex gap-3 mt-2";
217
+ const defaultSocialLink =
218
+ "text-lg text-primary hover:text-accent-foreground transition-colors duration-200";
219
+
220
+ // Motion control for card
221
+ const motionCard = enableMotion
222
+ ? "transition-transform duration-200 hover:-translate-y-1"
223
+ : "transition-none hover:!translate-y-0";
224
+
225
+ // Merge slot classes using cn (defaults first, then overrides)
226
+ const finalSectionClass = cn(defaultSection, section?.className, className);
227
+ const finalContainerClass = cn(defaultContainer, container?.className);
228
+ const finalHeaderClass = cn(defaultHeader, header?.className);
229
+ const finalGridClass = cn(defaultGrid, grid?.className);
230
+
231
+ const finalCardClass = cn(defaultCardBase, motionCard, card?.className);
232
+ const finalCardContentClass = cn(defaultCardContent, cardContent?.className);
233
+ const finalAvatarClass = cn(defaultAvatar, avatar?.className);
234
+ const finalNameClass = cn(defaultName, name?.className);
235
+ const finalRoleClass = cn(defaultRole, role?.className);
236
+ const finalBioClass = cn(defaultBio, bio?.className);
237
+ const finalSocialLinksClass = cn(defaultSocialLinks, socialLinks?.className);
238
+ const finalSocialLinkClass = cn(defaultSocialLink, socialLink?.className);
239
+
240
+ // Normalize heading/subheading allowing string or object, plus slot class merges
241
+ const normalizedHeading =
242
+ typeof teamHeadingText === "string"
243
+ ? {
244
+ text: teamHeadingText,
245
+ className: cn(defaultHeadingClass, heading?.className),
246
+ }
247
+ : {
248
+ text: teamHeadingText?.text ?? "Meet Our Team",
249
+ className: cn(
250
+ defaultHeadingClass,
251
+ teamHeadingText?.className,
252
+ heading?.className,
253
+ ),
254
+ };
255
+
256
+ const normalizedSubheading =
257
+ typeof teamSubheadingText === "string"
258
+ ? {
259
+ text: teamSubheadingText,
260
+ className: cn(defaultSubheadingClass, subheading?.className),
261
+ }
262
+ : {
263
+ text:
264
+ teamSubheadingText?.text ??
265
+ "The talented people behind your success",
266
+ className: cn(
267
+ defaultSubheadingClass,
268
+ teamSubheadingText?.className,
269
+ subheading?.className,
270
+ ),
271
+ };
272
+
273
+ return (
274
+ <section
275
+ id={id || "team"}
276
+ className={finalSectionClass}
277
+ aria-label={ariaLabel}
278
+ >
279
+ <div className={finalContainerClass}>
280
+ <div className={finalHeaderClass}>
281
+ <div className="mx-auto flex max-w-2xl flex-col items-center space-y-4 text-center">
282
+ <h2 className={normalizedHeading.className}>
283
+ {normalizedHeading.text}
284
+ </h2>
285
+ <p className={normalizedSubheading.className}>
286
+ {normalizedSubheading.text}
287
+ </p>
288
+ </div>
289
+ <div className={finalGridClass}>
290
+ {teamMembers.map((member, index) => (
291
+ <TeamCard
292
+ key={index}
293
+ member={member}
294
+ card={{ className: finalCardClass }}
295
+ cardContent={{ className: finalCardContentClass }}
296
+ avatar={{ className: finalAvatarClass }}
297
+ name={{ className: finalNameClass }}
298
+ role={{ className: finalRoleClass }}
299
+ bio={{ className: finalBioClass }}
300
+ socialLinks={{ className: finalSocialLinksClass }}
301
+ socialLink={{ className: finalSocialLinkClass }}
302
+ />
303
+ ))}
304
+ </div>
305
+ </div>
306
+ </div>
307
+ </section>
308
+ );
309
+ }