Mailspring/app/internal_packages/draft-list/lib/draft-list.jsx

68 lines
1.7 KiB
React
Raw Normal View History

import React from 'react';
import { Actions } from 'mailspring-exports';
import {
FluxContainer,
FocusContainer,
EmptyListState,
MultiselectList,
} from 'mailspring-component-kit';
import DraftListStore from './draft-list-store';
import DraftListColumns from './draft-list-columns';
class DraftList extends React.Component {
static displayName = 'DraftList';
static containerRequired = false;
render() {
return (
<FluxContainer
stores={[DraftListStore]}
getStateFromStores={() => {
return { dataSource: DraftListStore.dataSource() };
}}
>
<FocusContainer collection="draft">
<MultiselectList
className="draft-list"
columns={DraftListColumns.Wide}
onDoubleClick={this._onDoubleClick}
EmptyComponent={EmptyListState}
keymapHandlers={this._keymapHandlers()}
itemPropsProvider={this._itemPropsProvider}
itemHeight={39}
/>
</FocusContainer>
</FluxContainer>
);
}
_itemPropsProvider = draft => {
const props = {};
if (draft.uploadTaskId) {
props.className = 'sending';
}
return props;
};
_keymapHandlers = () => {
return {
'core:delete-item': this._onRemoveFromView,
'core:gmail-remove-from-view': this._onRemoveFromView,
'core:remove-from-view': this._onRemoveFromView,
};
};
_onDoubleClick = draft => {
if (!draft.uploadTaskId) {
Actions.composePopoutDraft(draft.headerMessageId);
}
};
_onRemoveFromView = () => {
for (const draft of DraftListStore.dataSource().selection.items()) {
Actions.destroyDraft(draft);
}
};
}
module.exports = DraftList;