_ = require 'underscore' React = require 'react' {ListTabular, MultiselectList, InjectedComponent} = require 'nylas-component-kit' {timestamp, subject} = require './formatting-utils' {Actions, DatabaseStore} = require 'nylas-exports' DraftListStore = require './draft-list-store' class DraftList extends React.Component @displayName: 'DraftList' @containerRequired: false componentWillMount: => snippet = (html) => @draftSanitizer ?= document.createElement('div') @draftSanitizer.innerHTML = html text = @draftSanitizer.innerText text[0..140] c1 = new ListTabular.Column name: "Name" width: 200 resolver: (draft) =>
c2 = new ListTabular.Column name: "Message" flex: 4 resolver: (draft) => attachments = [] if draft.files?.length > 0 attachments =
{subject(draft.subject)} {snippet(draft.body)} {attachments} c3 = new ListTabular.Column name: "Date" flex: 1 resolver: (draft) => {timestamp(draft.date)} @columns = [c1, c2, c3] @commands = 'core:remove-item': @_onDelete render: => {} } className="draft-list" collection="draft" /> _onDoubleClick: (item) => DatabaseStore.localIdForModel(item).then (localId) -> Actions.composePopoutDraft(localId) # Additional Commands _onDelete: ({focusedId}) => item = DraftListStore.view().getById(focusedId) return unless item DatabaseStore.localIdForModel(item).then (localId) -> Actions.destroyDraft(localId) module.exports = DraftList