Mailspring/internal_packages/worker-ui/lib/developer-bar-long-poll-item.cjsx

44 lines
1.2 KiB
Text
Raw Normal View History

React = require 'react/addons'
moment = require 'moment'
2015-05-16 01:53:00 +08:00
{Utils} = require 'nylas-exports'
class DeveloperBarLongPollItem extends React.Component
@displayName: 'DeveloperBarLongPollItem'
constructor: (@props) ->
@state = expanded: false
shouldComponentUpdate: (nextProps, nextState) =>
return not Utils.isEqualReact(nextProps, @props) or not Utils.isEqualReact(nextState, @state)
render: =>
if @state.expanded
payload = JSON.stringify(@props.item)
else
payload = []
itemId = @props.item.id
itemVersion = @props.item.version || @props.item.attributes?.version
itemId += " (version #{itemVersion})" if itemVersion
timestamp = moment(@props.item.timestamp).format("h:mm:ss")
classname = "item"
right = @props.item.cursor
if @props.ignoredBecause
classname += " ignored"
right = @props.ignoredBecause + " - " + right
<div className={classname} onClick={ => @setState expanded: not @state?.expanded}>
<div className="cursor">{right}</div>
{" #{timestamp}: #{@props.item.event} #{@props.item.object} #{itemId}"}
<div className="payload" onClick={ (e) -> e.stopPropagation() }>
{payload}
</div>
</div>
module.exports = DeveloperBarLongPollItem