import {Component} from 'react'; import {getRepositories} from 'sentry/actionCreators/repositories'; import {Client} from 'sentry/api'; import RepositoryStore from 'sentry/stores/repositoryStore'; import {Organization, Repository} from 'sentry/types'; import getDisplayName from 'sentry/utils/getDisplayName'; type DependentProps = { api: Client; organization: Organization; }; type InjectedProps = { repositories?: Repository[]; repositoriesError?: Error; repositoriesLoading?: boolean; }; const INITIAL_STATE: InjectedProps = { repositories: undefined, repositoriesLoading: undefined, repositoriesError: undefined, }; function withRepositories

( WrappedComponent: React.ComponentType

) { class WithRepositories extends Component

{ static displayName = `withRepositories(${getDisplayName(WrappedComponent)})`; constructor(props: P & DependentProps, context: any) { super(props, context); const repoData = RepositoryStore.get(); this.state = repoData.orgSlug === props.organization.slug ? {...INITIAL_STATE, ...repoData} : {...INITIAL_STATE}; } componentDidMount() { const {organization} = this.props; const orgSlug = organization.slug; const repoData = RepositoryStore.get(); if (repoData.orgSlug !== orgSlug) { RepositoryStore.resetRepositories(); } // XXX(leedongwei): Do not move this function call unless you modify the // unit test named "prevents repeated calls" this.fetchRepositories(); } componentWillUnmount() { this.unsubscribe(); } unsubscribe = RepositoryStore.listen(() => this.onStoreUpdate(), undefined); fetchRepositories() { const {api, organization} = this.props; const orgSlug = organization.slug; const repoData = RepositoryStore.get(); // XXX(leedongwei): Do not check the orgSlug here. It would have been // verified at `getInitialState`. The short-circuit hack in actionCreator // does not update the orgSlug in the store. if ( (!repoData.repositories && !repoData.repositoriesLoading) || repoData.repositoriesError ) { getRepositories(api, {orgSlug}); } } onStoreUpdate() { const repoData = RepositoryStore.get(); this.setState({...repoData}); } render() { return ; } } return WithRepositories; } export default withRepositories;