React TypeScript Icons — Export Typed Components

Export icons as typed React components with a single click in IconVectors, then drop them into your app with forwardRef, accessible labels, and currentColor theming. This guide shows export steps and production patterns.

When to choose React TypeScript

Draw, Import or Trace your icon

Draw your icon illustration

Export a React TypeScript component from IconVectors

  1. Design on a consistent grid (e.g., 24×24). Keep strokes aligned to whole pixels.
  2. Set theming strategy: for single‑color icons, prefer currentColor on fill or stroke so CSS can control color.
  3. Open the Live Code Viewer (F3) and switch to the React (TS) tab.
  4. Copy the generated component (or use Export) and save it to your project, e.g., icons/HeartIcon.tsx.

Component template (typed & forwardRef)

import * as React from "react";

export type IconProps = React.SVGProps<SVGSVGElement> & {
  /** Optional accessible label; if omitted, icon is decorative */
  title?: string;
  /** Optional size in px (applies to width/height) */
  size?: number | string;
};

export const HeartIcon = React.forwardRef<SVGSVGElement, IconProps>(
  function HeartIcon({ title, size = 24, ...props }, ref) {
    const aria = title
      ? { role: "img", "aria-label": title }
      : { "aria-hidden": "true" as const };

    return (
      <svg
        ref={ref}
        viewBox="0 0 24 24"
        width={size}
        height={size}
        {...aria}
        {...props}
      >
        <path
          fill="none"
          stroke="currentColor"
          strokeWidth="1"
          strokeLinecap="round"
          strokeLinejoin="round"
          d="M2.5 9C2.5 2.5 10 3 12 7.5C14 3 21.5 2.5 21.5 9C21.5 15.4 12 21.5 12 21.5C12 21.5 2.5 15.6 2.5 9z"
        />
      </svg>
    );
  }
);

Usage examples

import { HeartIcon } from "./icons/HeartIcon";

// 1) Decorative icon (screen readers ignore)
<HeartIcon className="h-5 w-5 text-rose-600" aria-hidden="true" />

// 2) Informative icon with label
<HeartIcon className="h-5 w-5" title="Favorite" />

// 3) Set size via prop or CSS
<HeartIcon size={20} style={{ color: "#16a34a" }} />

Using an SVG sprite in React (alternative)

If you maintain a global sprite, reference symbols with <use href="…"/> (modern React supports href):

// sprite definition lives once in your app (e.g., in _app.tsx or index.html)
/*
<svg style="display:none">
  <symbol id="icon-heart-24" viewBox="0 0 24 24">
    <path fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round"
          d="M2.5 9C2.5 2.5 10 3 12 7.5C14 3 21.5 2.5 21.5 9C21.5 15.4 12 21.5 12 21.5C12 21.5 2.5 15.6 2.5 9z"/>
  </symbol>
</svg>
*/

export function HeartIconSprite(props: React.SVGProps<SVGSVGElement>) {
  return (
    <svg width={24} height={24} aria-hidden="true" {...props}>
      <use href="#icon-heart-24" fill="currentColor" />
    </svg>
  );
}

Accessibility checklist

Theming with currentColor

Keep fills or strokes on the main shape set to currentColor so icons inherit text color from CSS (utility classes or variables). For fixed accents, use hard‑coded colors on secondary paths.

.btn-icon { color: #2563eb; }
[data-theme="dark"] .btn-icon { color: #93c5fd; }
<button className="btn-icon inline-flex items-center gap-2">
  <HeartIcon size={20} aria-hidden="true" /> Save
</button>

Performance & packaging tips

Next steps: Minified SVG, Native SVG, XAML.

Start Making SVG Icons Today with IconVectors

Download the fully-functional 30‑Day Free Trial and unlock your icon design workflow.

Version 1.10 - September 17, 2025