_ = require 'underscore' moment = require 'moment-timezone' React = require 'react' {DateUtils, Utils} = require 'nylas-exports' class MessageTimestamp extends React.Component @displayName: 'MessageTimestamp' @propTypes: date: React.PropTypes.object.isRequired, className: React.PropTypes.string, isDetailed: React.PropTypes.bool onClick: React.PropTypes.func shouldComponentUpdate: (nextProps, nextState) => +nextProps.date isnt +@props.date or nextProps.isDetailed isnt @props.isDetailed render: => msgDate = moment.tz(@props.date, Utils.timeZone) nowDate = @_today() formattedDate = @_formattedDate(msgDate, nowDate, @props.isDetailed)
{formattedDate}
_formattedDate: (msgDate, now, isDetailed) => timeFormat = DateUtils.getTimeFormat upperCase: true if isDetailed return msgDate.format "MMMM D, YYYY [at] #{timeFormat}" else diff = now.diff(msgDate, 'days', true) isSameDay = now.isSame(msgDate, 'days') if diff < 1 and isSameDay return msgDate.format timeFormat if diff < 1.5 and not isSameDay timeAgo = msgDate.from now monthAndDay = msgDate.format timeFormat return monthAndDay + " (" + timeAgo + ")" if diff >= 1.5 and diff < 365 return msgDate.format "MMM D" if diff >= 365 return msgDate.format "MMM D, YYYY" # Stubbable for testing. Returns a `moment` _today: -> moment.tz(Utils.timeZone) module.exports = MessageTimestamp