Skip to content

Commit

Permalink
Add base64 image support (#60)
Browse files Browse the repository at this point in the history
  • Loading branch information
gidztech authored and adamgruber committed Oct 23, 2017
1 parent 207a1bb commit 4278e4c
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 10 deletions.
8 changes: 8 additions & 0 deletions src/components/test/context.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ const cx = classNames.bind(styles);
const imgRegEx = /(?:png|jpe?g|gif)$/i;
const protocolRegEx = /^(?:(?:https?|ftp):\/\/)/i;
const urlRegEx = /^(?:(?:https?|ftp):\/\/)?(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,}))\.?)(?::\d{2,5})?(?:[/?#]\S*)?$/ // eslint-disable-line
const base64ImgRegEx = /^data:image\/([a-zA-Z0-9-_.])+;base64,([^"]*)$/i;

class TestContext extends Component {
static displayName = 'TestContext';
Expand Down Expand Up @@ -38,6 +39,8 @@ class TestContext extends Component {
);
}

renderBase64Image = (ctx, title) => <img src={ ctx } className={ cx('image') } alt={ title } />;

renderLink = (url, title) => {
const linkUrl = `${protocolRegEx.test(url) ? '' : 'http://'}${url}`;
return (
Expand All @@ -58,6 +61,11 @@ class TestContext extends Component {
return this.renderImage(content, title);
}

// Base64 Images
if (base64ImgRegEx.test(content)) {
return this.renderBase64Image(content, title);
}

// URLs
if (urlRegEx.test(content)) {
return this.renderLink(content, title);
Expand Down
65 changes: 55 additions & 10 deletions test/spec/components/test/context.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ describe('<TestContext />', () => {
wrapper,
ctx: wrapper.find(TestContext),
ctxItems: wrapper.find('.test-context-item'),
img: wrapper.find('.test-image-link'),
img: wrapper.find('.test-image'),
imgLink: wrapper.find('.test-image-link'),
link: wrapper.find('.test-text-link'),
snippet: wrapper.find(CodeSnippet)
};
Expand Down Expand Up @@ -57,29 +58,73 @@ describe('<TestContext />', () => {

it('renders image url with protocol', () => {
const context = 'http://test.url.com/testimage.png';
const { wrapper, snippet, img } = getInstance({
const { wrapper, snippet, imgLink } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
img.simulate('click', { stopPropagation: noop });
expect(imgLink).to.have.lengthOf(1);
imgLink.simulate('click', { stopPropagation: noop });
});

it('renders image url without protocol', () => {
const context = 'test.url.com/testimage.png';
const { wrapper, snippet, img } = getInstance({
const { wrapper, snippet, imgLink } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
expect(imgLink).to.have.lengthOf(1);
});

it('renders local image', () => {
const context = '/testimage.png';
const { wrapper, snippet, imgLink } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(imgLink).to.have.lengthOf(1);
});

it('renders base64 jpeg image', () => {
const context = '';
const { wrapper, snippet, img } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
});

it('renders base64 png image', () => {
const context = '';
const { wrapper, snippet, img } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
});

it('renders base64 animated gif image', () => {
const context = '';
const { wrapper, snippet, img } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
});

it('renders base64 x-icon image', () => {
const context = '';
const { wrapper, snippet, img } = getInstance({
context: JSON.stringify(context),
className: 'test'
Expand Down Expand Up @@ -124,13 +169,13 @@ describe('<TestContext />', () => {
title: 'sample context',
value: 'http://test.url.com/testimage.png'
};
const { wrapper, snippet, img } = getInstance({
const { wrapper, snippet, imgLink } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(0);
expect(img).to.have.lengthOf(1);
expect(imgLink).to.have.lengthOf(1);
});

it('renders object value', () => {
Expand Down Expand Up @@ -160,13 +205,13 @@ describe('<TestContext />', () => {
value: { testing: true }
}
];
const { wrapper, snippet, img } = getInstance({
const { wrapper, snippet, imgLink } = getInstance({
context: JSON.stringify(context),
className: 'test'
});
expect(wrapper).to.have.className('test');
expect(snippet).to.have.lengthOf(1);
expect(img).to.have.lengthOf(1);
expect(imgLink).to.have.lengthOf(1);
});
});
});

0 comments on commit 4278e4c

Please sign in to comment.