_ = require 'underscore' path = require 'path' {RetinaImg} = require 'mailspring-component-kit' {Actions, React, PropTypes, DateUtils, Message, Event, ComponentRegistry, EventRSVPTask, DatabaseStore, AccountStore} = require 'mailspring-exports' moment = require 'moment-timezone' class EventHeader extends React.Component @displayName: 'EventHeader' @propTypes: message: PropTypes.instanceOf(Message).isRequired constructor: (@props) -> @state = event: @props.message.events[0] _onChange: => return unless @state.event DatabaseStore.find(Event, @state.event.id).then (event) => return unless event @setState({event}) componentDidMount: => # TODO: This should use observables! @_unlisten = DatabaseStore.listen (change) => if @state.event and change.objectClass is Event.name updated = _.find change.objects, (o) => o.id is @state.event.id @setState({event: updated}) if updated @_onChange() componentWillReceiveProps: (nextProps) => @setState({event:nextProps.message.events[0]}) @_onChange() componentWillUnmount: => @_unlisten?() render: => timeFormat = DateUtils.getTimeFormat({timeZone: true}) if @state.event?