mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-21 15:42:19 +08:00
92 lines
2.7 KiB
CoffeeScript
92 lines
2.7 KiB
CoffeeScript
_ = 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?
|
|
<div className="event-wrapper">
|
|
<div className="event-header">
|
|
<RetinaImg name="icon-RSVP-calendar-mini@2x.png"
|
|
mode={RetinaImg.Mode.ContentPreserve}/>
|
|
<span className="event-title-text">Event: </span><span className="event-title">{@state.event.title}</span>
|
|
</div>
|
|
<div className="event-body">
|
|
<div className="event-date">
|
|
<div className="event-day">
|
|
{moment(@state.event.start*1000).tz(DateUtils.timeZone).format("dddd, MMMM Do")}
|
|
</div>
|
|
<div>
|
|
<div className="event-time">
|
|
{moment(@state.event.start*1000).tz(DateUtils.timeZone).format(timeFormat)}
|
|
</div>
|
|
{@_renderEventActions()}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
else
|
|
<div></div>
|
|
|
|
_renderEventActions: =>
|
|
me = @state.event.participantForMe()
|
|
return false unless me
|
|
|
|
actions = [["yes", "Accept"], ["maybe", "Maybe"], ["no", "Decline"]]
|
|
|
|
<div className="event-actions">
|
|
{actions.map ([status, label]) =>
|
|
classes = "btn-rsvp "
|
|
classes += status if me.status is status
|
|
<div key={status} className={classes} onClick={=> @_rsvp(status)}>
|
|
{label}
|
|
</div>
|
|
}
|
|
</div>
|
|
|
|
_rsvp: (status) =>
|
|
me = @state.event.participantForMe()
|
|
Actions.queueTask(new EventRSVPTask(@state.event, me.email, status))
|
|
|
|
module.exports = EventHeader
|