import { React, FocusedContactsStore, } from 'mailspring-exports'; export default class MyMessageSidebar extends React.Component { static displayName = 'MyMessageSidebar'; // This sidebar component listens to the FocusedContactStore, // which gives us access to the Contact object of the currently // selected person in the conversation. If you wanted to take // the contact and fetch your own data, you'd want to create // your own store, so the flow of data would be: // FocusedContactStore => Your Store => Your Component constructor(props) { super(props); this.state = this._getStateFromStores(); } componentDidMount() { this.unsubscribe = FocusedContactsStore.listen(this._onChange); } componentWillUnmount() { this.unsubscribe(); } _onChange = () => { this.setState(this._getStateFromStores()); } _getStateFromStores = () => { return { contact: FocusedContactsStore.focusedContact(), }; } _renderContent() { // Want to include images or other static assets in your components? // Reference them using the mailspring:// URL scheme: // // // return (

{this.state.contact.displayName()} is the focused contact.

); } _renderPlaceholder() { return (
No Data Available
); } render() { const content = (this.state.contact) ? this._renderContent() : this._renderPlaceholder(); return (
{content}
); } } // Providing container styles tells the app how to constrain // the column your component is being rendered in. The min and // max size of the column are chosen automatically based on // these values. MyMessageSidebar.containerStyles = { order: 1, flexShrink: 0, };