feat: recolor BrandLogo to cyan gradient, split BrandWordmark for gradient Flow text
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -5,42 +5,37 @@ interface BrandLogoProps {
|
|||||||
className?: string
|
className?: string
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* ResolutionFlow brand logo icon — white monochrome.
|
|
||||||
* sm (32x32) for header/navbar, lg (80x80) for login/register pages.
|
|
||||||
*/
|
|
||||||
export function BrandLogo({ size = 'sm', className }: BrandLogoProps) {
|
export function BrandLogo({ size = 'sm', className }: BrandLogoProps) {
|
||||||
const sizeClasses = size === 'sm' ? 'h-8 w-8' : 'h-20 w-20'
|
const sizeClasses = size === 'sm' ? 'h-8 w-8' : 'h-20 w-20'
|
||||||
|
|
||||||
const strokeBase = size === 'sm' ? 1 : 2
|
const strokeBase = size === 'sm' ? 1 : 2
|
||||||
const strokeThick = size === 'sm' ? 1.25 : 2.5
|
const strokeThick = size === 'sm' ? 1.25 : 2.5
|
||||||
const dashArray = size === 'sm' ? '1 1.5' : '2 3'
|
const dashArray = size === 'sm' ? '1 1.5' : '2 3'
|
||||||
const nodeR = size === 'sm' ? { outer: 2.5, inner: 2.75 } : { outer: 5, inner: 5.5 }
|
const nodeR = size === 'sm' ? { outer: 2.5, inner: 2.75 } : { outer: 5, inner: 5.5 }
|
||||||
const hubR = size === 'sm' ? { glow: 5, solid: 3.5 } : { glow: 10, solid: 7 }
|
const hubR = size === 'sm' ? { glow: 5, solid: 3.5 } : { glow: 10, solid: 7 }
|
||||||
|
|
||||||
const vb = size === 'sm' ? '0 0 40 40' : '0 0 80 80'
|
const vb = size === 'sm' ? '0 0 40 40' : '0 0 80 80'
|
||||||
const s = size === 'sm' ? 1 : 2
|
const s = size === 'sm' ? 1 : 2
|
||||||
|
const gradId = size === 'sm' ? 'logoGradSm' : 'logoGradLg'
|
||||||
|
const gradEnd = String(40 * (size === 'sm' ? 1 : 2))
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<svg viewBox={vb} fill="none" className={cn(sizeClasses, className)}>
|
<svg viewBox={vb} fill="none" className={cn(sizeClasses, className)}>
|
||||||
{/* Input nodes */}
|
<defs>
|
||||||
<circle cx={5 * s} cy={7 * s} r={nodeR.outer} fill="white" opacity="0.35" />
|
<linearGradient id={gradId} x1="0" y1="0" x2={gradEnd} y2={gradEnd} gradientUnits="userSpaceOnUse">
|
||||||
<circle cx={5 * s} cy={15 * s} r={nodeR.inner} fill="white" opacity="0.5" />
|
<stop offset="0%" stopColor="#06b6d4" />
|
||||||
<circle cx={5 * s} cy={25 * s} r={nodeR.inner} fill="white" opacity="0.5" />
|
<stop offset="100%" stopColor="#22d3ee" />
|
||||||
<circle cx={5 * s} cy={33 * s} r={nodeR.outer} fill="white" opacity="0.35" />
|
</linearGradient>
|
||||||
|
</defs>
|
||||||
{/* Connecting lines */}
|
<circle cx={5 * s} cy={7 * s} r={nodeR.outer} fill={`url(#${gradId})`} opacity="0.5" />
|
||||||
<path d={`M${7.5 * s} ${7 * s}L${14 * s} ${17 * s}`} stroke="white" strokeWidth={strokeBase} strokeLinecap="round" strokeDasharray={dashArray} opacity="0.45" />
|
<circle cx={5 * s} cy={15 * s} r={nodeR.inner} fill={`url(#${gradId})`} opacity="0.7" />
|
||||||
<path d={`M${7.75 * s} ${15 * s}L${14 * s} ${19 * s}`} stroke="white" strokeWidth={strokeBase} strokeLinecap="round" opacity="0.6" />
|
<circle cx={5 * s} cy={25 * s} r={nodeR.inner} fill={`url(#${gradId})`} opacity="0.7" />
|
||||||
<path d={`M${7.75 * s} ${25 * s}L${14 * s} ${21 * s}`} stroke="white" strokeWidth={strokeBase} strokeLinecap="round" opacity="0.6" />
|
<circle cx={5 * s} cy={33 * s} r={nodeR.outer} fill={`url(#${gradId})`} opacity="0.5" />
|
||||||
<path d={`M${7.5 * s} ${33 * s}L${14 * s} ${23 * s}`} stroke="white" strokeWidth={strokeBase} strokeLinecap="round" strokeDasharray={dashArray} opacity="0.45" />
|
<path d={`M${7.5 * s} ${7 * s}L${14 * s} ${17 * s}`} stroke={`url(#${gradId})`} strokeWidth={strokeBase} strokeLinecap="round" strokeDasharray={dashArray} opacity="0.4" />
|
||||||
|
<path d={`M${7.75 * s} ${15 * s}L${14 * s} ${19 * s}`} stroke={`url(#${gradId})`} strokeWidth={strokeBase} strokeLinecap="round" opacity="0.5" />
|
||||||
{/* Central hub */}
|
<path d={`M${7.75 * s} ${25 * s}L${14 * s} ${21 * s}`} stroke={`url(#${gradId})`} strokeWidth={strokeBase} strokeLinecap="round" opacity="0.5" />
|
||||||
<circle cx={18 * s} cy={20 * s} r={hubR.glow} fill="white" opacity="0.15" />
|
<path d={`M${7.5 * s} ${33 * s}L${14 * s} ${23 * s}`} stroke={`url(#${gradId})`} strokeWidth={strokeBase} strokeLinecap="round" strokeDasharray={dashArray} opacity="0.4" />
|
||||||
<circle cx={18 * s} cy={20 * s} r={hubR.solid} fill="white" />
|
<circle cx={18 * s} cy={20 * s} r={hubR.glow} fill={`url(#${gradId})`} opacity="0.15" />
|
||||||
|
<circle cx={18 * s} cy={20 * s} r={hubR.solid} fill={`url(#${gradId})`} opacity="0.9" />
|
||||||
{/* Output arrow */}
|
<path d={`M${21.5 * s} ${20 * s}H${35 * s}M${35 * s} ${20 * s}L${30 * s} ${15 * s}M${35 * s} ${20 * s}L${30 * s} ${25 * s}`} stroke={`url(#${gradId})`} strokeWidth={strokeThick} strokeLinecap="round" strokeLinejoin="round" />
|
||||||
<path d={`M${21.5 * s} ${20 * s}H${35 * s}M${35 * s} ${20 * s}L${30 * s} ${15 * s}M${35 * s} ${20 * s}L${30 * s} ${25 * s}`} stroke="white" strokeWidth={strokeThick} strokeLinecap="round" strokeLinejoin="round" />
|
|
||||||
</svg>
|
</svg>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,20 +5,17 @@ interface BrandWordmarkProps {
|
|||||||
className?: string
|
className?: string
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* ResolutionFlow wordmark — clean white text.
|
|
||||||
* sm for header/navbar, lg for login/register pages.
|
|
||||||
*/
|
|
||||||
export function BrandWordmark({ size = 'sm', className }: BrandWordmarkProps) {
|
export function BrandWordmark({ size = 'sm', className }: BrandWordmarkProps) {
|
||||||
return (
|
return (
|
||||||
<span
|
<span
|
||||||
className={cn(
|
className={cn(
|
||||||
'font-semibold tracking-tight text-white',
|
'font-heading font-bold tracking-tight',
|
||||||
size === 'sm' ? 'text-xl' : 'text-3xl',
|
size === 'sm' ? 'text-xl' : 'text-3xl',
|
||||||
className
|
className
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
ResolutionFlow
|
<span className="text-foreground">Resolution</span>
|
||||||
|
<span className="text-gradient-brand">Flow</span>
|
||||||
</span>
|
</span>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user