projectPlugins.tsx 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import {Component} from 'react';
  2. import {RouteComponentProps} from 'react-router';
  3. import Access from 'sentry/components/acl/access';
  4. import Link from 'sentry/components/links/link';
  5. import LoadingIndicator from 'sentry/components/loadingIndicator';
  6. import {
  7. Panel,
  8. PanelAlert,
  9. PanelBody,
  10. PanelHeader,
  11. PanelItem,
  12. } from 'sentry/components/panels';
  13. import {t, tct} from 'sentry/locale';
  14. import {Organization, Plugin, Project} from 'sentry/types';
  15. import RouteError from 'sentry/views/routeError';
  16. import ProjectPluginRow from './projectPluginRow';
  17. type Props = {
  18. error: React.ComponentProps<typeof RouteError>['error'];
  19. loading: boolean;
  20. onChange: React.ComponentProps<typeof ProjectPluginRow>['onChange'];
  21. organization: Organization;
  22. plugins: Plugin[];
  23. project: Project;
  24. } & RouteComponentProps<{}, {}>;
  25. class ProjectPlugins extends Component<Props> {
  26. render() {
  27. const {plugins, loading, error, onChange, routes, organization, project} = this.props;
  28. const hasError = error;
  29. const isLoading = !hasError && loading;
  30. if (hasError) {
  31. return <RouteError error={error} />;
  32. }
  33. if (isLoading) {
  34. return <LoadingIndicator />;
  35. }
  36. const params = {orgId: organization.slug, projectId: project.slug};
  37. return (
  38. <Panel>
  39. <PanelHeader>
  40. <div>{t('Legacy Integration')}</div>
  41. <div>{t('Enabled')}</div>
  42. </PanelHeader>
  43. <PanelBody>
  44. <PanelAlert type="warning">
  45. <Access access={['org:integrations']}>
  46. {({hasAccess}) =>
  47. hasAccess
  48. ? tct(
  49. "Legacy Integrations must be configured per-project. It's recommended to prefer organization integrations over the legacy project integrations when available. Visit the [link:organization integrations] settings to manage them.",
  50. {
  51. link: <Link to={`/settings/${organization.slug}/integrations`} />,
  52. }
  53. )
  54. : t(
  55. "Legacy Integrations must be configured per-project. It's recommended to prefer organization integrations over the legacy project integrations when available."
  56. )
  57. }
  58. </Access>
  59. </PanelAlert>
  60. {plugins
  61. .filter(p => {
  62. return !p.isHidden;
  63. })
  64. .map(plugin => (
  65. <PanelItem key={plugin.id}>
  66. <ProjectPluginRow
  67. params={params}
  68. routes={routes}
  69. project={project}
  70. {...plugin}
  71. onChange={onChange}
  72. />
  73. </PanelItem>
  74. ))}
  75. </PanelBody>
  76. </Panel>
  77. );
  78. }
  79. }
  80. export default ProjectPlugins;