navigationConfiguration.tsx 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. import {t} from 'sentry/locale';
  2. import {Organization, Project} from 'sentry/types';
  3. import {NavigationSection} from 'sentry/views/settings/types';
  4. type ConfigParams = {
  5. debugFilesNeedsReview?: boolean;
  6. organization?: Organization;
  7. project?: Project;
  8. };
  9. const pathPrefix = '/settings/:orgId/projects/:projectId';
  10. export default function getConfiguration({
  11. project,
  12. organization,
  13. debugFilesNeedsReview,
  14. }: ConfigParams): NavigationSection[] {
  15. const plugins = ((project && project.plugins) || []).filter(plugin => plugin.enabled);
  16. return [
  17. {
  18. name: t('Project'),
  19. items: [
  20. {
  21. path: `${pathPrefix}/`,
  22. index: true,
  23. title: t('General Settings'),
  24. description: t('Configure general settings for a project'),
  25. },
  26. {
  27. path: `${pathPrefix}/teams/`,
  28. title: t('Project Teams'),
  29. description: t('Manage team access for a project'),
  30. },
  31. {
  32. path: `${pathPrefix}/alerts/`,
  33. title: t('Alert Settings'),
  34. description: t('Project alert settings'),
  35. },
  36. {
  37. path: `${pathPrefix}/tags/`,
  38. title: t('Tags'),
  39. description: t("View and manage a project's tags"),
  40. },
  41. {
  42. path: `${pathPrefix}/environments/`,
  43. title: t('Environments'),
  44. description: t('Manage environments in a project'),
  45. },
  46. {
  47. path: `${pathPrefix}/ownership/`,
  48. title: organization?.features?.includes('streamline-targeting-context')
  49. ? t('Ownership Rules')
  50. : t('Issue Owners'),
  51. description: t('Manage ownership rules for a project'),
  52. },
  53. {
  54. path: `${pathPrefix}/data-forwarding/`,
  55. title: t('Data Forwarding'),
  56. },
  57. ],
  58. },
  59. {
  60. name: t('Processing'),
  61. items: [
  62. {
  63. path: `${pathPrefix}/filters/`,
  64. title: t('Inbound Filters'),
  65. description: t(
  66. "Configure a project's inbound filters (e.g. browsers, messages)"
  67. ),
  68. },
  69. {
  70. path: `${pathPrefix}/security-and-privacy/`,
  71. title: t('Security & Privacy'),
  72. description: t(
  73. 'Configuration related to dealing with sensitive data and other security settings. (Data Scrubbing, Data Privacy, Data Scrubbing) for a project'
  74. ),
  75. },
  76. {
  77. path: `${pathPrefix}/issue-grouping/`,
  78. title: t('Issue Grouping'),
  79. },
  80. {
  81. path: `${pathPrefix}/processing-issues/`,
  82. title: t('Processing Issues'),
  83. // eslint-disable-next-line @typescript-eslint/no-shadow
  84. badge: ({project}) => {
  85. if (!project) {
  86. return null;
  87. }
  88. if (project.processingIssues <= 0) {
  89. return null;
  90. }
  91. return project.processingIssues > 99 ? '99+' : project.processingIssues;
  92. },
  93. },
  94. {
  95. path: `${pathPrefix}/debug-symbols/`,
  96. title: t('Debug Files'),
  97. badge: debugFilesNeedsReview ? () => 'warning' : undefined,
  98. },
  99. {
  100. path: `${pathPrefix}/proguard/`,
  101. title: t('ProGuard'),
  102. },
  103. {
  104. path: `${pathPrefix}/source-maps/`,
  105. title: t('Source Maps'),
  106. },
  107. {
  108. path: `${pathPrefix}/performance/`,
  109. title: t('Performance'),
  110. show: () => !!organization?.features?.includes('performance-view'),
  111. },
  112. ],
  113. },
  114. {
  115. name: t('SDK Setup'),
  116. items: [
  117. {
  118. path: `${pathPrefix}/keys/`,
  119. title: t('Client Keys (DSN)'),
  120. description: t("View and manage the project's client keys (DSN)"),
  121. },
  122. {
  123. path: `${pathPrefix}/release-tracking/`,
  124. title: t('Releases'),
  125. },
  126. {
  127. path: `${pathPrefix}/security-headers/`,
  128. title: t('Security Headers'),
  129. },
  130. {
  131. path: `${pathPrefix}/user-feedback/`,
  132. title: t('User Feedback'),
  133. description: t('Configure user feedback reporting feature'),
  134. },
  135. ],
  136. },
  137. {
  138. name: t('Legacy Integrations'),
  139. items: [
  140. {
  141. path: `${pathPrefix}/plugins/`,
  142. title: t('Legacy Integrations'),
  143. description: t('View, enable, and disable all integrations for a project'),
  144. id: 'legacy_integrations',
  145. recordAnalytics: true,
  146. },
  147. ...plugins.map(plugin => ({
  148. path: `${pathPrefix}/plugins/${plugin.id}/`,
  149. title: plugin.name,
  150. show: opts => opts?.access?.has('project:write') && !plugin.isDeprecated,
  151. id: 'plugin_details',
  152. recordAnalytics: true,
  153. })),
  154. ],
  155. },
  156. ];
  157. }