Skip to content

Commit

Permalink
Update dataURI regex pattern
Browse files Browse the repository at this point in the history
Closes #203
  • Loading branch information
gilbarbara committed Aug 6, 2023
1 parent df3803a commit 80eb114
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ export default class InlineSVG extends React.PureComponent<Props, State> {
return;
}

const dataURI = src.match(/data:image\/svg[^,]*?(;base64)?,(.*)/);
const dataURI = src.match(/^data:image\/svg[^,]*?(;base64)?,(.*)/u);
let inlineSrc;

if (dataURI) {
Expand Down
29 changes: 29 additions & 0 deletions test/__snapshots__/index.spec.tsx.snap
Original file line number Diff line number Diff line change
Expand Up @@ -2290,6 +2290,35 @@ exports[`react-inlinesvg basic functionality should render an urlEncoded src 1`]
</svg>
`;
exports[`react-inlinesvg basic functionality should render an urlEncodedWithBase64 src 1`] = `
<svg
height="768px"
version="1.1"
viewBox="-0.5 -0.5 1098 768"
width="1098px"
xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
>
<title>
URL Encoded With Base 64
</title>
<defs />
<g>
<a
xlink:href="/dashboard/dash-l1MVuUCUAQ67LmpaHyH6"
>
<image
height="80"
width="86.25"
x="428.5"
xlink:href=""
y="617.5"
/>
</a>
</g>
</svg>
`;
exports[`react-inlinesvg basic functionality should transform the SVG text with the preProcessor prop 1`] = `
<svg
data-isvg="test"
Expand Down
15 changes: 15 additions & 0 deletions test/index.spec.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ const fixtures = {
'',
urlEncoded:
'" /%3E%3C/a%3E%3C/g%3E%3C/svg%3E%0A',
html: 'data:image/svg+xml,%3Chtml%20lang%3D%22en%22%3E%3Cbody%3EText%3C%2Fbody%3E%3C%2Fhtml%3E',
string:
'<svg width="24px" height="24px" viewBox="0 0 24 24" version="1.1" xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="xMidYMid"><g> <polygon fill="#000000" points="7 5 7 19 18 12"></polygon></g></svg>',
Expand Down Expand Up @@ -79,6 +81,19 @@ describe('react-inlinesvg', () => {
expect(container.querySelector('svg')).toMatchSnapshot();
});

it('should render an urlEncodedWithBase64 src', async () => {
const { container } = setup({
src: fixtures.urlEncodedWithBase64,
title: 'URL Encoded With Base 64',
});

await waitFor(() => {
expect(mockOnLoad).toHaveBeenCalledTimes(1);
});

expect(container.querySelector('svg')).toMatchSnapshot();
});

it('should render a svg string src', async () => {
const { container } = setup({
src: fixtures.string,
Expand Down

0 comments on commit 80eb114

Please sign in to comment.