Created
January 11, 2017 12:58
-
-
Save homerjam/67c1320ad76f056ac9ef667bcb3b1dcd to your computer and use it in GitHub Desktop.
Custom MJML component useful for MailChimp templates
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import { MJMLElement } from 'mjml-core' | |
import merge from 'lodash/merge' | |
import min from 'lodash/min' | |
import React, { Component } from 'react' | |
const tagName = 'mc-image' | |
const parentTag = ['mj-column', 'mj-hero-content'] | |
const defaultMJMLDefinition = { | |
attributes: { | |
'mc:edit': null, | |
'align': 'center', | |
'alt': '', | |
'border': 'none', | |
'border-radius': null, | |
'container-background-color': null, | |
'height': 'auto', | |
'href': '', | |
'padding-bottom': null, | |
'padding-left': null, | |
'padding-right': null, | |
'padding-top': null, | |
'padding': '10px 25px', | |
'src': '', | |
'target': '_blank', | |
'title': '', | |
'vertical-align': null, | |
'width': null, | |
} | |
} | |
const endingTag = true | |
const baseStyles = { | |
table: { | |
borderCollapse: 'collapse', | |
borderSpacing: '0' | |
}, | |
img: { | |
border: 'none', | |
borderRadius: '', | |
display: 'block', | |
outline: 'none', | |
textDecoration: 'none', | |
width: '100%' | |
} | |
} | |
const postRender = $ => { | |
$('[data-mc-edit]').each(function () { | |
$(this) | |
.attr('mc:edit', $(this).attr('data-mc-edit')) | |
.removeAttr('data-mc-edit') | |
}) | |
return $ | |
} | |
@MJMLElement | |
class Image extends Component { | |
styles = this.getStyles() | |
getContentWidth () { | |
const { mjAttribute, getPadding } = this.props | |
const parentWidth = mjAttribute('parentWidth') | |
const width = min([parseInt(mjAttribute('width')), parseInt(parentWidth)]) | |
const paddingRight = getPadding('right') | |
const paddingLeft = getPadding('left') | |
const widthOverflow = paddingLeft + paddingRight + width - parseInt(parentWidth) | |
return widthOverflow > 0 ? width - widthOverflow : width | |
} | |
getStyles () { | |
const { mjAttribute, defaultUnit } = this.props | |
return merge({}, baseStyles, { | |
td: { | |
width: this.getContentWidth() | |
}, | |
img: { | |
border: mjAttribute('border'), | |
height: mjAttribute('height'), | |
borderRadius: defaultUnit(mjAttribute('border-radius'), "px") | |
} | |
}) | |
} | |
renderImage () { | |
const { mjAttribute } = this.props | |
const img = ( | |
<img | |
data-mc-edit={mjAttribute('mc:edit')} | |
alt={mjAttribute('alt')} | |
title={mjAttribute('title')} | |
height={mjAttribute('height')} | |
src={mjAttribute('src')} | |
style={this.styles.img} | |
width={this.getContentWidth()} /> | |
) | |
if (mjAttribute('href') != '') { | |
return ( | |
<a | |
href={mjAttribute('href')} | |
target={mjAttribute('target')}> | |
{img} | |
</a> | |
) | |
} | |
return img | |
} | |
render () { | |
const { mjAttribute } = this.props | |
return ( | |
<table | |
className="mc-image" | |
cellPadding="0" | |
cellSpacing="0" | |
data-legacy-align={mjAttribute('align')} | |
data-legacy-border="0" | |
style={this.styles.table}> | |
<tbody> | |
<tr> | |
<td style={this.styles.td}> | |
{this.renderImage()} | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
) | |
} | |
} | |
Image.tagName = tagName | |
Image.parentTag = parentTag | |
Image.defaultMJMLDefinition = defaultMJMLDefinition | |
Image.endingTag = endingTag | |
Image.baseStyles = baseStyles | |
Image.postRender = postRender | |
export default Image |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment