import PlainBackground from "@/components/background/PlainBackground"; import GridBackround from "@/components/background/GridBackround"; import DotGridBackground from "@/components/background/DotGridBackground"; import CircleGradientBackground from "@/components/background/CircleGradientBackground"; import AuroraBackground from "@/components/background/AuroraBackground"; import FloatingGradientBackground from "@/components/background/floatingGradientBackground/FloatingGradientBackground"; import AnimatedGridBackground from "@/components/background/AnimatedGridBackground"; import AnimatedAuroraBackground from "@/components/background/AnimatedAuroraBackground"; import FluidBackground from "@/components/background/FluidBackground"; import RadialGradientBackground from "@/components/background/RadialGradientBackground"; import NoiseBackground from "@/components/background/NoiseBackground"; import NoiseGradientBackground from "@/components/background/NoiseGradientBackground"; import NoiseDiagonalGradientBackground from "@/components/background/NoiseDiagonalGradientBackground"; import type { BorderRadiusPreset, ContentWidthPreset, SizingPreset, BackgroundType, HeadingFontWeight } from "./types"; /** * Shared component layout and styling type definitions */ export type TextboxLayout = "default" | "split" | "split-actions" | "split-description" | "inline-image"; export type InvertedBackground = "noInvert" | "invertDefault" | "invertCard"; export const borderRadiusMap: Record = { sharp: "0", rounded: "var(--radius)", soft: "var(--radius-lg)", pill: "var(--radius-full)", }; export const borderRadiusCappedMap: Record = { sharp: "0", rounded: "var(--radius)", soft: "var(--radius-lg)", pill: "var(--radius-xl)", // Capped at xl instead of full }; export const headingFontWeightMap: Record = { light: "300", normal: "400", medium: "500", semibold: "600", bold: "700", extrabold: "800", }; export const contentWidthMap: Record = { small: { desktop: "clamp(40rem, 70vw, 100rem)", mobile: "80vw", }, medium: { desktop: "clamp(40rem, 80vw, 100rem)", mobile: "80vw", }, large: { desktop: "clamp(40rem, 90vw, 100rem)", mobile: "90vw", }, }; function calculateExpandedWidth(width: string): string { const clampMatch = width.match(/clamp\(([\d.]+)rem,\s*([\d.]+)vw,\s*([\d.]+)rem\)/); if (clampMatch) { const minRem = clampMatch[1]; const vwValue = parseFloat(clampMatch[2]); const maxRem = clampMatch[3]; const remainingVw = 100 - vwValue; const expandedVw = vwValue + (remainingVw / 2); const expandedMin = `calc(${minRem}rem - (${minRem}rem - 100vw) / 2)`; const expandedMax = `calc(${maxRem}rem + (100vw - ${maxRem}rem) / 2)`; return `clamp(${expandedMin}, ${expandedVw}vw, ${expandedMax})`; } const vwMatch = width.match(/([\d.]+)vw/); if (vwMatch) { const vwValue = parseFloat(vwMatch[1]); const remainingVw = 100 - vwValue; const expandedVw = vwValue + (remainingVw / 2); return `${expandedVw}vw`; } return width; } export const expandedContentWidthMap: Record = { small: { desktop: calculateExpandedWidth(contentWidthMap.small.desktop), mobile: calculateExpandedWidth(contentWidthMap.small.mobile), }, medium: { desktop: calculateExpandedWidth(contentWidthMap.medium.desktop), mobile: calculateExpandedWidth(contentWidthMap.medium.mobile), }, large: { desktop: calculateExpandedWidth(contentWidthMap.large.desktop), mobile: calculateExpandedWidth(contentWidthMap.large.mobile), }, }; export const baseVwMap: Record = { small: { desktop: "clamp(0.5rem, 0.68vw, 1rem)", mobile: "2.55vw", }, medium: { desktop: "clamp(0.5rem, 0.8vw, 1rem)", mobile: "3vw", }, large: { desktop: "clamp(0.5rem, 0.92vw, 1rem)", mobile: "3.45vw", }, mediumSizeExtraLargeTitles: { desktop: "clamp(0.5rem, 0.8vw, 1rem)", mobile: "3vw", }, smallSizeLargeTitles: { desktop: "clamp(0.5rem, 0.68vw, 1rem)", mobile: "2.55vw", }, largeSizeMediumTitles: { desktop: "clamp(0.5rem, 0.92vw, 1rem)", mobile: "3.45vw", }, mediumSizeExtraLargeSpacing: { desktop: "clamp(0.5rem, 1.1vw, 1.2rem)", mobile: "4vw", }, mediumSizeExtraSmallSpacing: { desktop: "clamp(0.5rem, 0.6vw, 1rem)", mobile: "2.2vw", }, largeSizeExtraLargeSpacing: { desktop: "clamp(0.5rem, 1.1vw, 1.2rem)", mobile: "4vw", }, }; interface TextSizingValues { text2xs: string; textXs: string; textSm: string; textBase: string; textLg: string; textXl: string; text2xl: string; text3xl: string; text4xl: string; text5xl: string; text6xl: string; text7xl: string; text8xl: string; text9xl: string; } export const textSizingMap: Record = { small: { desktop: { text2xs: "clamp(0.465rem, 0.527vw, 0.62rem)", textXs: "clamp(0.54rem, 0.612vw, 0.72rem)", textSm: "clamp(0.615rem, 0.697vw, 0.82rem)", textBase: "clamp(0.69rem, 0.782vw, 0.92rem)", textLg: "clamp(0.75rem, 0.85vw, 1rem)", textXl: "clamp(0.825rem, 0.935vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.105vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.36vw, 1.6rem)", text4xl: "clamp(1.5rem, 1.7vw, 2rem)", text5xl: "clamp(2.025rem, 2.3375vw, 2.75rem)", text6xl: "clamp(2.475rem, 2.805vw, 3.3rem)", text7xl: "clamp(3rem, 3.4vw, 4rem)", text8xl: "clamp(3.5rem, 3.825vw, 4.5rem)", text9xl: "clamp(5.25rem, 5.95vw, 7rem)", }, mobile: { text2xs: "2.125vw", textXs: "2.3375vw", textSm: "2.55vw", textBase: "2.7625vw", textLg: "2.975vw", textXl: "3.6125vw", text2xl: "4.25vw", text3xl: "5.1vw", text4xl: "5.95vw", text5xl: "6.375vw", text6xl: "7.225vw", text7xl: "8.5vw", text8xl: "10.2vw", text9xl: "11.9vw", }, }, medium: { desktop: { text2xs: "clamp(0.465rem, 0.62vw, 0.62rem)", textXs: "clamp(0.54rem, 0.72vw, 0.72rem)", textSm: "clamp(0.615rem, 0.82vw, 0.82rem)", textBase: "clamp(0.69rem, 0.92vw, 0.92rem)", textLg: "clamp(0.75rem, 1vw, 1rem)", textXl: "clamp(0.825rem, 1.1vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.3vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.6vw, 1.6rem)", text4xl: "clamp(1.5rem, 2vw, 2rem)", text5xl: "clamp(2.025rem, 2.75vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.3vw, 3.3rem)", text7xl: "clamp(3rem, 4vw, 4rem)", text8xl: "clamp(3.5rem, 4.5vw, 4.5rem)", text9xl: "clamp(5.25rem, 7vw, 7rem)", }, mobile: { text2xs: "2.5vw", textXs: "2.75vw", textSm: "3vw", textBase: "3.25vw", textLg: "3.5vw", textXl: "4.25vw", text2xl: "5vw", text3xl: "6vw", text4xl: "7vw", text5xl: "7.5vw", text6xl: "8.5vw", text7xl: "10vw", text8xl: "12vw", text9xl: "14vw", }, }, large: { desktop: { text2xs: "clamp(0.465rem, 0.713vw, 0.62rem)", textXs: "clamp(0.54rem, 0.828vw, 0.72rem)", textSm: "clamp(0.615rem, 0.943vw, 0.82rem)", textBase: "clamp(0.69rem, 1.058vw, 0.92rem)", textLg: "clamp(0.75rem, 1.15vw, 1rem)", textXl: "clamp(0.825rem, 1.265vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.495vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.84vw, 1.6rem)", text4xl: "clamp(1.5rem, 2.3vw, 2rem)", text5xl: "clamp(2.025rem, 3.1625vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.795vw, 3.3rem)", text7xl: "clamp(3rem, 4.6vw, 4rem)", text8xl: "clamp(3.5rem, 5.175vw, 4.5rem)", text9xl: "clamp(5.25rem, 8.05vw, 7rem)", }, mobile: { text2xs: "2.875vw", textXs: "3.1625vw", textSm: "3.45vw", textBase: "3.7375vw", textLg: "4.025vw", textXl: "4.8875vw", text2xl: "5.75vw", text3xl: "6.9vw", text4xl: "8.05vw", text5xl: "8.625vw", text6xl: "9.775vw", text7xl: "11.5vw", text8xl: "13.8vw", text9xl: "16.1vw", }, }, mediumSizeExtraLargeTitles: { desktop: { // Small-medium text sizes: use medium values text2xs: "clamp(0.465rem, 0.62vw, 0.62rem)", textXs: "clamp(0.54rem, 0.72vw, 0.72rem)", textSm: "clamp(0.615rem, 0.82vw, 0.82rem)", textBase: "clamp(0.69rem, 0.92vw, 0.92rem)", textLg: "clamp(0.75rem, 1vw, 1rem)", textXl: "clamp(0.825rem, 1.1vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.3vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.6vw, 1.6rem)", text4xl: "clamp(1.5rem, 2vw, 2rem)", // Large title sizes: significantly bigger than large preset text5xl: "clamp(2.5rem, 3.5vw, 3.5rem)", text6xl: "clamp(3rem, 4.5vw, 4.5rem)", text7xl: "clamp(4rem, 5.5vw, 5.5rem)", text8xl: "clamp(5rem, 6.5vw, 6.5rem)", text9xl: "clamp(7rem, 9vw, 9rem)", }, mobile: { // Small-medium text sizes: use medium values text2xs: "2.5vw", textXs: "2.75vw", textSm: "3vw", textBase: "3.25vw", textLg: "3.5vw", textXl: "4.25vw", text2xl: "5vw", text3xl: "6vw", text4xl: "7vw", // Large title sizes: significantly bigger text5xl: "10vw", text6xl: "12vw", text7xl: "14vw", text8xl: "16vw", text9xl: "20vw", }, }, smallSizeLargeTitles: { desktop: { // Small body text sizes: use small values text2xs: "clamp(0.465rem, 0.527vw, 0.62rem)", textXs: "clamp(0.54rem, 0.612vw, 0.72rem)", textSm: "clamp(0.615rem, 0.697vw, 0.82rem)", textBase: "clamp(0.69rem, 0.782vw, 0.92rem)", textLg: "clamp(0.75rem, 0.85vw, 1rem)", textXl: "clamp(0.825rem, 0.935vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.105vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.36vw, 1.6rem)", text4xl: "clamp(1.5rem, 1.7vw, 2rem)", // Large title sizes: use large preset values text5xl: "clamp(2.025rem, 3.1625vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.795vw, 3.3rem)", text7xl: "clamp(3rem, 4.6vw, 4rem)", text8xl: "clamp(3.5rem, 5.175vw, 4.5rem)", text9xl: "clamp(5.25rem, 8.05vw, 7rem)", }, mobile: { // Small body text sizes: use small values text2xs: "2.125vw", textXs: "2.3375vw", textSm: "2.55vw", textBase: "2.7625vw", textLg: "2.975vw", textXl: "3.6125vw", text2xl: "4.25vw", text3xl: "5.1vw", text4xl: "5.95vw", // Large title sizes: use large preset values text5xl: "8.625vw", text6xl: "9.775vw", text7xl: "11.5vw", text8xl: "13.8vw", text9xl: "16.1vw", }, }, largeSizeMediumTitles: { desktop: { // Large body text sizes: use large values text2xs: "clamp(0.465rem, 0.713vw, 0.62rem)", textXs: "clamp(0.54rem, 0.828vw, 0.72rem)", textSm: "clamp(0.615rem, 0.943vw, 0.82rem)", textBase: "clamp(0.69rem, 1.058vw, 0.92rem)", textLg: "clamp(0.75rem, 1.15vw, 1rem)", textXl: "clamp(0.825rem, 1.265vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.495vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.84vw, 1.6rem)", text4xl: "clamp(1.5rem, 2.3vw, 2rem)", // Medium title sizes: use medium preset values text5xl: "clamp(2.025rem, 2.75vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.3vw, 3.3rem)", text7xl: "clamp(3rem, 4vw, 4rem)", text8xl: "clamp(3.5rem, 4.5vw, 4.5rem)", text9xl: "clamp(5.25rem, 7vw, 7rem)", }, mobile: { // Large body text sizes: use large values text2xs: "2.875vw", textXs: "3.1625vw", textSm: "3.45vw", textBase: "3.7375vw", textLg: "4.025vw", textXl: "4.8875vw", text2xl: "5.75vw", text3xl: "6.9vw", text4xl: "8.05vw", // Medium title sizes: use medium preset values text5xl: "7.5vw", text6xl: "8.5vw", text7xl: "10vw", text8xl: "12vw", text9xl: "14vw", }, }, mediumSizeExtraLargeSpacing: { desktop: { // Medium text sizes for all text2xs: "clamp(0.465rem, 0.62vw, 0.62rem)", textXs: "clamp(0.54rem, 0.72vw, 0.72rem)", textSm: "clamp(0.615rem, 0.82vw, 0.82rem)", textBase: "clamp(0.69rem, 0.92vw, 0.92rem)", textLg: "clamp(0.75rem, 1vw, 1rem)", textXl: "clamp(0.825rem, 1.1vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.3vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.6vw, 1.6rem)", text4xl: "clamp(1.5rem, 2vw, 2rem)", text5xl: "clamp(2.025rem, 2.75vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.3vw, 3.3rem)", text7xl: "clamp(3rem, 4vw, 4rem)", text8xl: "clamp(3.5rem, 4.5vw, 4.5rem)", text9xl: "clamp(5.25rem, 7vw, 7rem)", }, mobile: { // Medium text sizes for all text2xs: "2.5vw", textXs: "2.75vw", textSm: "3vw", textBase: "3.25vw", textLg: "3.5vw", textXl: "4.25vw", text2xl: "5vw", text3xl: "6vw", text4xl: "7vw", text5xl: "7.5vw", text6xl: "8.5vw", text7xl: "10vw", text8xl: "12vw", text9xl: "14vw", }, }, mediumSizeExtraSmallSpacing: { desktop: { // Medium text sizes for all text2xs: "clamp(0.465rem, 0.62vw, 0.62rem)", textXs: "clamp(0.54rem, 0.72vw, 0.72rem)", textSm: "clamp(0.615rem, 0.82vw, 0.82rem)", textBase: "clamp(0.69rem, 0.92vw, 0.92rem)", textLg: "clamp(0.75rem, 1vw, 1rem)", textXl: "clamp(0.825rem, 1.1vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.3vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.6vw, 1.6rem)", text4xl: "clamp(1.5rem, 2vw, 2rem)", text5xl: "clamp(2.025rem, 2.75vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.3vw, 3.3rem)", text7xl: "clamp(3rem, 4vw, 4rem)", text8xl: "clamp(3.5rem, 4.5vw, 4.5rem)", text9xl: "clamp(5.25rem, 7vw, 7rem)", }, mobile: { // Medium text sizes for all text2xs: "2.5vw", textXs: "2.75vw", textSm: "3vw", textBase: "3.25vw", textLg: "3.5vw", textXl: "4.25vw", text2xl: "5vw", text3xl: "6vw", text4xl: "7vw", text5xl: "7.5vw", text6xl: "8.5vw", text7xl: "10vw", text8xl: "12vw", text9xl: "14vw", }, }, largeSizeExtraLargeSpacing: { desktop: { // Large text sizes for all text2xs: "clamp(0.465rem, 0.713vw, 0.62rem)", textXs: "clamp(0.54rem, 0.828vw, 0.72rem)", textSm: "clamp(0.615rem, 0.943vw, 0.82rem)", textBase: "clamp(0.69rem, 1.058vw, 0.92rem)", textLg: "clamp(0.75rem, 1.15vw, 1rem)", textXl: "clamp(0.825rem, 1.265vw, 1.1rem)", text2xl: "clamp(0.975rem, 1.495vw, 1.3rem)", text3xl: "clamp(1.2rem, 1.84vw, 1.6rem)", text4xl: "clamp(1.5rem, 2.3vw, 2rem)", text5xl: "clamp(2.025rem, 3.1625vw, 2.75rem)", text6xl: "clamp(2.475rem, 3.795vw, 3.3rem)", text7xl: "clamp(3rem, 4.6vw, 4rem)", text8xl: "clamp(3.5rem, 5.175vw, 4.5rem)", text9xl: "clamp(5.25rem, 8.05vw, 7rem)", }, mobile: { // Large text sizes for all text2xs: "2.875vw", textXs: "3.1625vw", textSm: "3.45vw", textBase: "3.7375vw", textLg: "4.025vw", textXl: "4.8875vw", text2xl: "5.75vw", text3xl: "6.9vw", text4xl: "8.05vw", text5xl: "8.625vw", text6xl: "9.775vw", text7xl: "11.5vw", text8xl: "13.8vw", text9xl: "16.1vw", }, }, }; interface BackgroundComponentProps { className?: string; invertColors?: boolean; // For AnimatedAuroraBackground } export const backgroundComponents: Record | null> = { none: null, plain: PlainBackground, grid: GridBackround, dotGrid: DotGridBackground, circleGradient: CircleGradientBackground, aurora: AuroraBackground, floatingGradient: FloatingGradientBackground, animatedGrid: AnimatedGridBackground, animatedAurora: AnimatedAuroraBackground, fluid: FluidBackground, radialGradient: RadialGradientBackground, noise: NoiseBackground, noiseGradient: NoiseGradientBackground, noiseDiagonalGradient: NoiseDiagonalGradientBackground, };