mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-07 16:48:02 +08:00
44 lines
1.4 KiB
Text
44 lines
1.4 KiB
Text
|
React = require "react"
|
||
|
{Actions} = require 'inbox-exports'
|
||
|
crypto = require "crypto"
|
||
|
|
||
|
module.exports = React.createClass
|
||
|
render: ->
|
||
|
className = "contact-chip"
|
||
|
if @props.clickable
|
||
|
className += " clickable"
|
||
|
|
||
|
img = []
|
||
|
if @props.context is 'primary'
|
||
|
img = <img
|
||
|
className="contact-img"
|
||
|
src={"https://secure.gravatar.com/avatar/#{@md5}?s=20&d=blank"}
|
||
|
style={{"backgroundColor": @bg}}
|
||
|
/>
|
||
|
|
||
|
<span className={className} onClick={@_onClick}>
|
||
|
{img}
|
||
|
<span className="contact-name">{@_getParticipantDisplay()}</span>
|
||
|
</span>
|
||
|
|
||
|
_onClick: ->
|
||
|
return unless @props.clickable
|
||
|
clipboard = require('clipboard')
|
||
|
clipboard.writeText(@props.participant.email)
|
||
|
Actions.postNotification({message: "Copied #{@props.participant.email} to clipboard", type: 'success'})
|
||
|
|
||
|
_getParticipantDisplay: ->
|
||
|
@props.participant.displayName()
|
||
|
|
||
|
shouldComponentUpdate: (newProps, newState) ->
|
||
|
(newProps.participant?.email != @props.participant?.email) ||
|
||
|
(newProps.participant?.name != @props.participant?.name)
|
||
|
|
||
|
componentWillMount: ->
|
||
|
email = @props.participant.email.toLowerCase()
|
||
|
@md5 = crypto.createHash('md5').update(email).digest('hex')
|
||
|
|
||
|
nameMD5 = crypto.createHash('md5').update(email + @props.participant.name).digest('hex')
|
||
|
n = Math.floor(parseInt(nameMD5.slice(0, 2), 16) * 360/256)
|
||
|
@bg = "hsl(#{n}, 50%, 50%)"
|