React = require 'react' _ = require 'underscore' EmailFrame = require './email-frame' {Utils, MessageUtils, MessageBodyProcessor, QuotedHTMLTransformer, FileDownloadStore} = require 'nylas-exports' {InjectedComponentSet} = require 'nylas-component-kit' TransparentPixel = "" class MessageItemBody extends React.Component @displayName: 'MessageItemBody' @propTypes: message: React.PropTypes.object.isRequired downloads: React.PropTypes.object.isRequired constructor: (@props) -> @state = showQuotedText: Utils.isForwardedMessage(@props.message) processedBody: undefined componentWillMount: => @_prepareBody(@props) shouldComponentUpdate: (nextProps, nextState) -> not Utils.isEqualReact(nextProps, @props) or not Utils.isEqualReact(nextState, @state) componentWillUpdate: (nextProps, nextState) => if not Utils.isEqualReact(nextProps.message, @props.message) @_prepareBody(nextProps) _prepareBody: (props) -> MessageBodyProcessor.resetCache(props.message) @_unsub?() @_unsub = MessageBodyProcessor.processAndSubscribe(props.message, @_onBodyChanged) componentWillUnmount: => @_unsub?() render: => {@_renderBody()} {@_renderQuotedTextControl()} _renderBody: => return null unless @state.processedBody? _renderQuotedTextControl: => return null unless QuotedHTMLTransformer.hasQuotedHTML(@props.message.body) text = if @state.showQuotedText then "Hide" else "Show" •••{text} previous _toggleQuotedText: => @setState showQuotedText: !@state.showQuotedText _onBodyChanged: (body) => downloadingSpinnerPath = Utils.imageNamed('inline-loading-spinner.gif') # Replace cid:// references with the paths to downloaded files for file in @props.message.files download = @props.downloads[file.id] cidRegexp = new RegExp("cid:#{file.contentId}(['\"]+)", 'gi') if download and download.state isnt 'finished' # Render a spinner and inject a `style` tag that injects object-position / object-fit body = body.replace cidRegexp, (text, quoteCharacter) -> "#{downloadingSpinnerPath}#{quoteCharacter} style=#{quoteCharacter} object-position: 50% 50%; object-fit: none; " else # Render the completed download body = body.replace cidRegexp, (text, quoteCharacter) -> "#{FileDownloadStore.pathForFile(file)}#{quoteCharacter}" # Replace remaining cid:// references - we will not display them since they'll # throw "unknown ERR_UNKNOWN_URL_SCHEME". Show a transparent pixel so that there's # no "missing image" region shown, just a space. body = body.replace(MessageUtils.cidRegex, "src=\"#{TransparentPixel}\"") @setState processedBody: body module.exports = MessageItemBody