0
# react-inlinesvg
1
2
react-inlinesvg is a React component library for loading and displaying SVG files inline within React applications. It supports loading SVGs from remote URLs, local files, base64-encoded strings, and raw SVG markup, with intelligent caching mechanisms to optimize performance and comprehensive customization options.
3
4
## Package Information
5
6
- **Package Name**: react-inlinesvg
7
- **Package Type**: npm
8
- **Language**: TypeScript
9
- **Installation**: `npm install react-inlinesvg`
10
11
## Core Imports
12
13
```typescript
14
import InlineSVG from "react-inlinesvg";
15
```
16
17
With types and utilities:
18
19
```typescript
20
import InlineSVG, {
21
Props,
22
ErrorCallback,
23
LoadCallback,
24
PreProcessorCallback,
25
FetchError,
26
StorageItem,
27
Status,
28
State,
29
PlainObject,
30
Simplify,
31
cacheStore,
32
canUseDOM,
33
isSupportedEnvironment,
34
randomString,
35
request,
36
sleep,
37
supportsInlineSVG,
38
omit,
39
CACHE_NAME,
40
CACHE_MAX_RETRIES,
41
STATUS
42
} from "react-inlinesvg";
43
```
44
45
For CommonJS:
46
47
```javascript
48
const InlineSVG = require("react-inlinesvg");
49
```
50
51
## Basic Usage
52
53
```typescript
54
import React from "react";
55
import InlineSVG from "react-inlinesvg";
56
57
export default function App() {
58
return (
59
<main>
60
<InlineSVG
61
src="https://cdn.svgporn.com/logos/react.svg"
62
width={128}
63
height="auto"
64
title="React Logo"
65
onLoad={(src, isCached) => console.log(`Loaded ${src}, cached: ${isCached}`)}
66
onError={(error) => console.error("SVG failed to load:", error)}
67
>
68
<img src="/fallback-logo.png" alt="React" />
69
</InlineSVG>
70
</main>
71
);
72
}
73
```
74
75
## Architecture
76
77
react-inlinesvg is built around several key components:
78
79
- **Main Component**: `InlineSVG` component handles SVG loading, processing, and rendering
80
- **Caching System**: Automatic in-memory caching with optional browser Cache API persistence
81
- **SVG Processing**: Content preprocessing, ID uniquification, and DOM conversion
82
- **Error Handling**: Comprehensive error handling with fallback content support
83
- **Loading States**: Built-in loading state management with customizable loader components
84
85
## Capabilities
86
87
### SVG Loading and Rendering
88
89
Core SVG loading functionality that fetches, processes, and renders SVG content inline as React elements. Supports multiple source types and provides comprehensive customization options.
90
91
```typescript { .api }
92
declare const InlineSVG: React.FC<Props>;
93
94
interface Props extends Omit<React.SVGProps<SVGElement>, 'onLoad' | 'onError' | 'ref'> {
95
/** SVG source - URL, base64 data URI, or raw SVG string */
96
src: string;
97
/** URL prefix for relative IDs when using uniquifyIDs */
98
baseURL?: string;
99
/** Enable SVG content caching (default: true) */
100
cacheRequests?: boolean;
101
/** Fallback content for errors/unsupported browsers */
102
children?: React.ReactNode;
103
/** SVG description text (overrides existing <desc>) */
104
description?: string;
105
/** Custom fetch options for HTTP requests */
106
fetchOptions?: RequestInit;
107
/** Ref for the rendered SVG element */
108
innerRef?: React.Ref<SVGElement | null>;
109
/** Loading component while SVG fetches */
110
loader?: React.ReactNode;
111
/** Error handler callback */
112
onError?: ErrorCallback;
113
/** Success callback with src and cache status */
114
onLoad?: LoadCallback;
115
/** SVG content preprocessing function */
116
preProcessor?: PreProcessorCallback;
117
/** SVG title text (overrides existing <title>, null removes) */
118
title?: string | null;
119
/** Hash for ID uniquification (default: random 8-char) */
120
uniqueHash?: string;
121
/** Make SVG IDs unique to prevent conflicts (default: false) */
122
uniquifyIDs?: boolean;
123
}
124
125
type ErrorCallback = (error: Error | FetchError) => void;
126
type LoadCallback = (src: string, isCached: boolean) => void;
127
type PreProcessorCallback = (code: string) => string;
128
129
interface FetchError extends Error {
130
code: string;
131
errno: string;
132
message: string;
133
type: string;
134
}
135
```
136
137
### Persistent Caching
138
139
Optional browser Cache API integration for persistent SVG storage across browser sessions. Enables faster loading and offline support for cached SVGs.
140
141
```typescript { .api }
142
import CacheProvider from "react-inlinesvg/provider";
143
144
interface CacheProviderProps {
145
/** React components to wrap with cache context */
146
children: React.ReactNode;
147
/** Custom cache name (default: 'react-inlinesvg') */
148
name?: string;
149
}
150
151
declare const CacheProvider: React.FC<CacheProviderProps>;
152
```
153
154
[Persistent Caching](./caching.md)
155
156
## Global Cache Store
157
158
```typescript { .api }
159
import { cacheStore } from "react-inlinesvg";
160
161
interface CacheStore {
162
/** Cache initialization status */
163
readonly isReady: boolean;
164
/** Register ready state callback */
165
onReady(callback: () => void): void;
166
/** Retrieve cached/fetch SVG content */
167
get(url: string, fetchOptions?: RequestInit): Promise<string>;
168
/** Store SVG content in cache */
169
set(url: string, data: StorageItem): void;
170
/** Check if URL is cached and loaded */
171
isCached(url: string): boolean;
172
/** Get all cached URLs */
173
keys(): string[];
174
/** Get all cache entries */
175
data(): Array<Record<string, StorageItem>>;
176
/** Remove specific cache entry */
177
delete(url: string): Promise<void>;
178
/** Clear all cache entries */
179
clear(): Promise<void>;
180
}
181
182
interface StorageItem {
183
content: string;
184
status: Status;
185
}
186
187
type Status = 'idle' | 'loading' | 'loaded' | 'failed' | 'ready' | 'unsupported';
188
```
189
190
### Utility Functions
191
192
Core utility functions for environment detection, string manipulation, and DOM operations.
193
194
```typescript { .api }
195
/** Check if DOM environment is available (browser vs SSR) */
196
function canUseDOM(): boolean;
197
198
/** Check if environment supports inline SVG rendering */
199
function isSupportedEnvironment(): boolean;
200
201
/** Generate random alphanumeric string of specified length */
202
function randomString(length: number): string;
203
204
/** Make HTTP request with SVG content validation */
205
function request(url: string, options?: RequestInit): Promise<string>;
206
207
/** Async sleep utility for specified seconds */
208
function sleep(seconds?: number): Promise<void>;
209
210
/** Test browser support for inline SVG elements */
211
function supportsInlineSVG(): boolean;
212
213
/** Remove specified properties from object, returning new object */
214
function omit<T extends PlainObject, K extends keyof T>(
215
input: T,
216
...filter: K[]
217
): Omit<T, K>;
218
```
219
220
## Constants and Configuration
221
222
```typescript { .api }
223
/** Default cache name for browser Cache API storage */
224
const CACHE_NAME = 'react-inlinesvg';
225
226
/** Maximum retry attempts for cache loading operations */
227
const CACHE_MAX_RETRIES = 10;
228
229
/** SVG loading and processing status constants */
230
const STATUS = {
231
IDLE: 'idle',
232
LOADING: 'loading',
233
LOADED: 'loaded',
234
FAILED: 'failed',
235
READY: 'ready',
236
UNSUPPORTED: 'unsupported',
237
} as const;
238
```
239
240
## Additional Types
241
242
```typescript { .api }
243
/** Utility type for flattening complex type definitions */
244
type Simplify<T> = { [KeyType in keyof T]: T[KeyType] } & {};
245
246
/** Generic object type with string keys */
247
type PlainObject<T = unknown> = Record<string, T>;
248
249
/** Internal component state interface */
250
interface State {
251
content: string;
252
element: React.ReactNode;
253
isCached: boolean;
254
status: Status;
255
}
256
```
257
258
## Supported SVG Sources
259
260
- **Remote URLs**: `https://example.com/icon.svg` (requires CORS support)
261
- **Base64 Data URIs**: ``
262
- **URL-encoded Data URIs**: `data:image/svg+xml,%3Csvg...%3E`
263
- **Raw SVG Strings**: Any string containing `<svg` tag
264
- **Local Files**: Relative or absolute paths (in compatible environments)
265
266
## Error Handling
267
268
The component handles various error scenarios:
269
270
- **Network Failures**: HTTP errors, CORS issues, timeout
271
- **Invalid Content**: Non-SVG content, malformed SVG
272
- **Browser Support**: Unsupported SVG features
273
- **Missing Source**: Empty or undefined `src` prop
274
- **Conversion Errors**: DOM parsing or React conversion failures
275
276
All errors are passed to the `onError` callback and trigger fallback to `children` content.