Join our Discord Community

React True Focus Effect

Spotlight-style text effect with blur transitions and targeting brackets that focus attention on one word at a time. Perfect for emphasis and presentations.

Want to create focus spotlight effects?

Join our Discord community for help from other developers.


Most text emphasis effects use simple highlighting or color changes that don't create true focus. This component simulates a targeting system that blurs surrounding text while highlighting the active word with animated corner brackets, creating a spotlight effect that guides attention naturally.

Animated focus targeting system

Text that cycles through focus states with blur effects and targeting brackets:

Loading component...

Built with TypeScript for React applications, using Framer Motion for smooth bracket animations and CSS blur filters for focus effects with automatic cycling and manual hover modes.

Installation

npx shadcn@latest add https://www.shadcn.io/registry/true-focus.json
npx shadcn@latest add https://www.shadcn.io/registry/true-focus.json
pnpm dlx shadcn@latest add https://www.shadcn.io/registry/true-focus.json
bunx shadcn@latest add https://www.shadcn.io/registry/true-focus.json

Usage

import TrueFocus from "@/components/text/true-focus";

<div className="flex items-center justify-center min-h-screen w-full p-4 sm:p-8">
  <div className="text-center space-y-8">
    <TrueFocus 
      sentence="shadcn ui components"
      manualMode={false}
      blurAmount={4}
      borderColor="#22c55e"
      glowColor="rgba(34, 197, 94, 0.6)"
      animationDuration={1.2}
      pauseBetweenAnimations={1.5}
    />
  </div>
</div>

Why simple highlighting isn't effective

Traditional text emphasis uses static underlines, bold weights, or color changes—approaches that compete with other page elements and don't create true focus. Simple highlighting lacks the dynamic, attention-directing quality that makes content truly engaging.

This React component creates a targeting system that blurs unfocused words while highlighting the active word with animated corner brackets. The blur effect creates visual hierarchy by reducing cognitive load from surrounding text, while the targeting brackets provide clear visual indication of the current focus.

The key insight: blur creates focus better than highlighting. When surrounding elements are blurred while the target remains sharp, the eye naturally focuses on the clear content without competing visual elements.

Features

  • Dynamic blur transitions with customizable intensity for creating visual hierarchy and focus control
  • Animated targeting brackets with smooth position tracking and customizable colors and glow effects
  • Flexible interaction modes including automatic cycling and manual hover-based control systems
  • Performance optimized blur effects using CSS filters with smooth transition animations
  • Responsive bracket positioning with automatic word boundary detection and smooth tracking
  • Customizable timing controls for animation duration and pause intervals between focus changes
  • Free open source component compatible with Next.js and shadcn/ui design systems

API Reference

TrueFocus

Focus spotlight component with blur effects and targeting brackets.

PropTypeDefaultDescription
sentencestring'True Focus'Text content to focus through
manualModebooleanfalseEnable hover-based manual control
blurAmountnumber5Blur intensity for unfocused text
borderColorstring'green'Color of targeting brackets
glowColorstring'rgba(0, 255, 0, 0.6)'Glow effect color for brackets
animationDurationnumber0.5Transition duration in seconds
pauseBetweenAnimationsnumber1Pause between auto-focus cycles

Interaction Modes

Focus control behavior options:

ModeBehaviorBest For
Auto (manualMode: false)Cycles through words automaticallyPresentations, demos, storytelling
Manual (manualMode: true)Hover to focus specific wordsInteractive exploration, user control

Visual Customization

Appearance and timing configuration:

PropertyRangeEffectRecommended
blurAmount0-10pxBackground blur intensity3-6px for subtlety, 8-10px for drama
animationDuration0.3-2sTransition speed0.5-1s for smooth, 0.3s for snappy
pauseBetweenAnimations0.5-3sAuto-cycle timing1-2s for reading, 0.5s for quick demos

Common gotchas

Performance with long sentences: Blur effects can be GPU-intensive with many words. For sentences longer than 10-15 words, consider breaking into multiple components or reducing blur amount for better performance.

Bracket positioning accuracy: The targeting brackets calculate position based on word bounding rectangles. Custom fonts with unusual metrics might cause slight positioning issues. Test with your chosen typography.

Manual mode hover behavior: In manual mode, the component remembers the last active index when hovering ends. This prevents flickering but might feel unexpected. Consider the user experience for your specific use case.

Mobile blur performance: CSS blur filters can impact performance on lower-end mobile devices. Consider reducing blurAmount or disabling the effect on mobile using media queries.

Text wrapping issues: The component works best with single-line text. Multi-line sentences might cause bracket positioning problems as word positions change with screen size.

Questions developers actually ask