mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-17 05:30:57 +08:00
0669468ec0
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
105 lines
2.9 KiB
CoffeeScript
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()
|