path = require 'path' React = require 'react' {Actions, FileUploadStore} = require 'inbox-exports' FileUpload = React.createClass render: ->
  {@_basename()}
_uploadProgressStyle: -> if @props.uploadData.fileSize <= 0 percent = 0 else percent = (@props.uploadData.bytesUploaded / @props.uploadData.fileSize) * 100 width: "#{percent}%" _onClickRemove: -> Actions.abortUpload @props.uploadData _basename: -> path.basename(@props.uploadData.filePath) module.exports = FileUploads = React.createClass getInitialState: -> uploads: FileUploadStore.uploadsForMessage(@props.localId) ? [] componentDidMount: -> @storeUnlisten = FileUploadStore.listen(@_onFileUploadStoreChange) componentWillUnmount: -> @storeUnlisten() if @storeUnlisten render: -> {@_fileUploads()} _fileUploads: -> @state.uploads.map (uploadData) => _key: (uploadData) -> "#{uploadData.messageLocalId} #{uploadData.filePath}" # fileUploads: # "some_local_msg_id /some/full/path/name": # messageLocalId - The localId of the message (draft) we're uploading to # filePath - The full absolute local system file path # fileSize - The size in bytes # fileName - The basename of the file # bytesUploaded - Current number of bytes uploaded # state - one of "started" "progress" "completed" "aborted" "failed" _onFileUploadStoreChange: -> @setState uploads: FileUploadStore.uploadsForMessage(@props.localId)