{Utils, React, FocusedContactsStore} = require 'nylas-exports' {RetinaImg} = require 'nylas-component-kit' class MyMessageSidebar extends React.Component @displayName: 'MyMessageSidebar' # 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. @containerStyles: order: 1 flexShrink: 0 # 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) -> @state = @_getStateFromStores() componentDidMount: => @unsubscribe = FocusedContactsStore.listen(@_onChange) componentWillUnmount: => @unsubscribe() render: => if @state.contact content = @_renderContent() else content = @_renderPlaceholder()