Skip to content

Commit

Permalink
feat: add support base64 uri type in SvgUri component (#2444)
Browse files Browse the repository at this point in the history
# Summary
Feature #2142 

Add support for data: image/svg+XML; Base64 format.

## Test Plan
TestExample app -> src -> Test2142

## Compatibility

| OS      | Implemented |
| ------- | :---------: |
| iOS     |    ✅      |
| MacOS   |    ✅      |
| Android |    ✅      |
| Web     |    ✅      |

---------

Co-authored-by: Jakub Grzywacz <[email protected]>
  • Loading branch information
bohdanprog and jakex7 authored Sep 24, 2024
1 parent 712201a commit 14a131c
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 0 deletions.
1 change: 1 addition & 0 deletions apps/test-examples/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import Test2071 from './src/Test2071';
import Test2080 from './src/Test2080';
import Test2086 from './src/Test2086';
import Test2089 from './src/Test2089';
import Test2142 from './src/Test2142';
import Test2148 from './src/Test2148';
import Test2196 from './src/Test2196';
import Test2248 from './src/Test2248';
Expand Down
22 changes: 22 additions & 0 deletions apps/test-examples/src/Test2142.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import {SvgUri} from 'react-native-svg';

export default function App() {
return (
<>
<SvgUri
uri={``}
/>
<SvgUri
uri={``}
/>
<SvgUri
uri={``}
/>
<SvgUri
width={100}
height={100}
uri={``}
/>
</>
);
}
12 changes: 12 additions & 0 deletions src/utils/fetchData.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,28 @@
import { Platform } from 'react-native';
import { Buffer } from 'buffer';

export async function fetchText(uri?: string): Promise<string | null> {
if (!uri) {
return null;
}
if (uri.startsWith('data:image/svg+xml;utf8') && Platform.OS === 'android') {
return dataUriToXml(uri);
} else if (uri.startsWith('data:image/svg+xml;base64')) {
return decodeBase64Image(uri);
} else {
return fetchUriData(uri);
}
}

const decodeBase64Image = (uri: string) => {
const decoded = decodeURIComponent(uri);
const splitContent = decoded.split(';')[1].split(',');
const dataType = splitContent[0] as BufferEncoding;
const content = splitContent.slice(1).join(',');

return Buffer.from(content, dataType).toString('utf-8');
};

function dataUriToXml(uri: string): string | null {
try {
// decode and remove data:image/svg+xml;utf8, prefix
Expand Down

0 comments on commit 14a131c

Please sign in to comment.