Mailspring/internal_packages/thread-list/lib/draft-list.cjsx
Ben Gotow 0669468ec0 fix(*): Small fixes for drafts, interface tweaks
Summary:
Message list can be narrower

Account sidebar is narrower

Never open new windows on single click

Blue send button

Clean up cruft from draft deletion

Render composer empty, setProps when draft populated

Use new `pristine` attribute to discard un-changed new drafts

_addToProxy needs deep equals to prevent "save to = [], cc = []"

Mark as read on click, not afterwards

Allow toolbar / sheet items to style based on the workspace mode

specs covering draft unloading / behavior of cleanup

Always, always reset mode to spec after each test

New tests for destroy draft functionality

Test Plan: Run a handful of new tests

Reviewers: evan

Reviewed By: evan

Differential Revision: https://review.inboxapp.com/D1335
2015-03-23 16:33:28 -07:00

105 lines
2.9 KiB
CoffeeScript

_ = require 'underscore-plus'
moment = require "moment"
React = require 'react'
{ListTabular} = require 'ui-components'
{timestamp, subject} = require './formatting-utils'
{Actions,
DraftStore,
ComponentRegistry,
DatabaseStore} = require 'inbox-exports'
module.exports =
DraftList = React.createClass
displayName: 'DraftList'
mixins: [ComponentRegistry.Mixin]
components: ['Participants']
getInitialState: ->
items: DraftStore.items()
columns: @_computeColumns()
selectedId: null
componentDidMount: ->
@draftStoreUnsubscribe = DraftStore.listen @_onChange
@bodyUnsubscriber = atom.commands.add 'body',
'application:previous-item': => @_onShiftSelectedIndex(-1)
'application:next-item': => @_onShiftSelectedIndex(1)
'application:remove-item': @_onDeleteSelected
componentWillUnmount: ->
@draftStoreUnsubscribe()
@bodyUnsubscriber.dispose()
render: ->
<div className="thread-list">
<ListTabular
columns={@state.columns}
items={@state.items}
selectedId={@state.selectedId}
onDoubleClick={@_onDoubleClick}
onSelect={@_onSelect} />
</div>
_onSelect: (item) ->
@setState
selectedId: item.id
_onDoubleClick: (item) ->
DatabaseStore.localIdForModel(item).then (localId) ->
Actions.composePopoutDraft(localId)
_computeColumns: ->
snippet = (html) =>
@draftSanitizer ?= document.createElement('div')
@draftSanitizer.innerHTML = html
text = @draftSanitizer.innerText
text[0..140]
c1 = new ListTabular.Column
name: "Name"
flex: 2
resolver: (draft) =>
Participants = @state.Participants
<div className="participants">
<Participants participants={[].concat(draft.to,draft.cc,draft.bcc)}
context={'list'} clickable={false} />
</div>
c2 = new ListTabular.Column
name: "Subject"
flex: 3
resolver: (draft) ->
<span className="subject">{subject(draft.subject)}</span>
c3 = new ListTabular.Column
name: "Snippet"
flex: 4
resolver: (draft) ->
<span className="snippet">{snippet(draft.body)}</span>
c4 = new ListTabular.Column
name: "Date"
flex: 1
resolver: (draft) ->
<span className="timestamp">{timestamp(draft.date)}</span>
[c1, c2, c3, c4]
_onShiftSelectedIndex: (delta) ->
item = _.find @state.items, (draft) => draft.id is @state.selectedId
index = if item then @state.items.indexOf(item) else -1
index = Math.max(0, Math.min(index + delta, @state.items.length-1))
@setState
selectedId: @state.items[index].id
_onDeleteSelected: ->
item = _.find @state.items, (draft) => draft.id is @state.selectedId
DatabaseStore.localIdForModel(item).then (localId) ->
Actions.destroyDraft(localId)
@_onShiftSelectedIndex(-1)
_onChange: ->
@setState
items: DraftStore.items()