mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-18 14:07:44 +08:00
78 lines
2 KiB
JavaScript
78 lines
2 KiB
JavaScript
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:
|
|
//
|
|
// <RetinaImg
|
|
// url="mailspring://<<package.name>>/assets/checkmark_templatethis.2x.png"
|
|
// mode={RetinaImg.Mode.ContentIsMask}/>
|
|
//
|
|
return (
|
|
<div className="header">
|
|
<h1>{this.state.contact.displayName()} is the focused contact.</h1>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
_renderPlaceholder() {
|
|
return (
|
|
<div> No Data Available </div>
|
|
);
|
|
}
|
|
|
|
render() {
|
|
const content = (this.state.contact) ? this._renderContent() : this._renderPlaceholder();
|
|
return (
|
|
<div className="my-message-sidebar">
|
|
{content}
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
|
|
// 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,
|
|
};
|