diff --git a/cypress/e2e/4.image-rendering/image-rendering.cy.js b/cypress/e2e/4.image-rendering/image-rendering.cy.js
new file mode 100644
index 00000000..e25e6b54
--- /dev/null
+++ b/cypress/e2e/4.image-rendering/image-rendering.cy.js
@@ -0,0 +1,43 @@
+///
+
+describe('Image rendering', () => {
+
+ const imageUrl = 'https://picsum.photos/id/237/150';
+
+ beforeEach(() => {
+ cy.visit(__dirname + '/index.html');
+ cy.intercept('GET', imageUrl).as('image');
+ });
+
+ it('must render an image inside the editor', () => {
+ cy.get('.EasyMDEContainer').should('be.visible');
+ cy.get('#textarea').should('not.be.visible');
+
+ cy.get('.EasyMDEContainer .CodeMirror').type(imageUrl);
+ cy.get('.EasyMDEContainer .CodeMirror').type('{home}data:image/s3,"s3://crabby-images/80b5e/80b5e9c8c88f3e263d5e3a9c63cbbab154de7fd9" alt="Dog!"');
+
+ cy.wait('@image');
+
+ cy.get(`.EasyMDEContainer [data-img-src="${imageUrl}"]`).should('be.visible');
+
+ cy.previewOn();
+
+ cy.get('.EasyMDEContainer .editor-preview').should('contain.html', `
data:image/s3,"s3://crabby-images/265b2/265b2778507b70b941256843fd83a250817f2f01" alt="Dog!"
`);
+ });
+
+ it('must be able to handle parentheses inside image alt text', () => {
+ cy.get('.EasyMDEContainer').should('be.visible');
+ cy.get('#textarea').should('not.be.visible');
+
+ cy.get('.EasyMDEContainer .CodeMirror').type(imageUrl);
+ cy.get('.EasyMDEContainer .CodeMirror').type('{home}data:image/s3,"s3://crabby-images/80b5e/80b5e9c8c88f3e263d5e3a9c63cbbab154de7fd9" alt="Dog! (He\'s a good boy!)"');
+
+ cy.wait('@image');
+
+ cy.get(`.EasyMDEContainer [data-img-src="${imageUrl}"]`).should('be.visible');
+
+ cy.previewOn();
+
+ cy.get('.EasyMDEContainer .editor-preview').should('contain.html', `data:image/s3,"s3://crabby-images/265b2/265b2778507b70b941256843fd83a250817f2f01" alt="Dog! (He's a good boy!)"
`);
+ });
+});
diff --git a/cypress/e2e/4.image-rendering/index.html b/cypress/e2e/4.image-rendering/index.html
new file mode 100644
index 00000000..045bc339
--- /dev/null
+++ b/cypress/e2e/4.image-rendering/index.html
@@ -0,0 +1,20 @@
+
+
+
+
+
+ Default
+
+
+
+
+
+
+
+
+
+
diff --git a/src/js/easymde.js b/src/js/easymde.js
index c038d1c7..449c76fd 100644
--- a/src/js/easymde.js
+++ b/src/js/easymde.js
@@ -2251,7 +2251,7 @@ EasyMDE.prototype.render = function (el) {
return;
}
if (!parentEl.hasAttribute('data-img-src')) {
- var srcAttr = parentEl.innerText.match('\\((.*)\\)'); // might require better parsing according to markdown spec
+ var srcAttr = parentEl.innerText.match(/!\[.*?\]\((.*?)\)/); // might require better parsing according to markdown spec
if (!window.EMDEimagesCache) {
window.EMDEimagesCache = {};
}