organizationGeneralSettings.tsx 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. import type {JsonFormObject} from 'sentry/components/forms/types';
  2. import ExternalLink from 'sentry/components/links/externalLink';
  3. import {t, tct} from 'sentry/locale';
  4. import ConfigStore from 'sentry/stores/configStore';
  5. import type {BaseRole} from 'sentry/types/organization';
  6. import slugify from 'sentry/utils/slugify';
  7. // Export route to make these forms searchable by label/help
  8. export const route = '/settings/:orgId/';
  9. const formGroups: JsonFormObject[] = [
  10. {
  11. // Form "section"/"panel"
  12. title: t('General'),
  13. fields: [
  14. {
  15. name: 'slug',
  16. type: 'string',
  17. required: true,
  18. label: t('Organization Slug'),
  19. help: t('A unique ID used to identify this organization'),
  20. transformInput: slugify,
  21. saveOnBlur: false,
  22. saveMessageAlertType: 'info',
  23. saveMessage: t(
  24. 'You will be redirected to the new organization slug after saving'
  25. ),
  26. },
  27. {
  28. name: 'name',
  29. type: 'string',
  30. required: true,
  31. label: t('Display Name'),
  32. help: t('A human-friendly name for the organization'),
  33. },
  34. {
  35. name: 'isEarlyAdopter',
  36. type: 'boolean',
  37. label: t('Early Adopter'),
  38. help: tct("Opt-in to [link:new features] before they're released to the public", {
  39. link: (
  40. <ExternalLink href="https://docs.sentry.io/product/accounts/early-adopter/" />
  41. ),
  42. }),
  43. visible: () => !ConfigStore.get('isSelfHostedErrorsOnly'),
  44. },
  45. {
  46. name: 'aiSuggestedSolution',
  47. type: 'boolean',
  48. label: t('AI Suggested Solution'),
  49. help: tct(
  50. 'Opt-in to [link:ai suggested solution] to get AI help on how to solve an issue.',
  51. {
  52. link: (
  53. <ExternalLink href="https://docs.sentry.io/product/issues/issue-details/ai-suggested-solution/" />
  54. ),
  55. }
  56. ),
  57. visible: () => !ConfigStore.get('isSelfHostedErrorsOnly'),
  58. },
  59. {
  60. name: 'uptimeAutodetection',
  61. type: 'boolean',
  62. label: t('Automatically Configure Uptime Alerts'),
  63. help: t('Detect most-used URLs for uptime monitoring.'),
  64. // TOOD(epurkhiser): Currently there's no need for users to change this
  65. // setting as it will just be confusing. In the future when
  66. // autodetection is used for suggested URLs it will make more sense to
  67. // for users to have the option to disable this.
  68. visible: false,
  69. },
  70. ],
  71. },
  72. {
  73. title: 'Membership',
  74. fields: [
  75. {
  76. name: 'defaultRole',
  77. type: 'select',
  78. label: t('Default Role'),
  79. // seems weird to have choices in initial form data
  80. choices: ({initialData} = {}) =>
  81. initialData?.orgRoleList?.map((r: BaseRole) => [r.id, r.name]) ?? [],
  82. help: t('The default role new members will receive'),
  83. disabled: ({access}) => !access.has('org:admin'),
  84. },
  85. {
  86. name: 'openMembership',
  87. type: 'boolean',
  88. label: t('Open Team Membership'),
  89. help: t('Allow organization members to freely join any team'),
  90. },
  91. {
  92. name: 'allowMemberInvite',
  93. type: 'boolean',
  94. label: t('Let Members Invite Others'),
  95. help: t(
  96. 'Allow organization members to invite other members via email without needing org owner or manager approval.'
  97. ),
  98. visible: ({features}) => features.has('members-invite-teammates'),
  99. },
  100. {
  101. name: 'allowMemberProjectCreation',
  102. type: 'boolean',
  103. label: t('Let Members Create Projects'),
  104. help: t('Allow organization members to create and configure new projects.'),
  105. disabled: ({features, access}) =>
  106. !access.has('org:write') || !features.has('team-roles'),
  107. disabledReason: ({features}) =>
  108. !features.has('team-roles')
  109. ? t('You must be on a business plan to toggle this feature.')
  110. : undefined,
  111. },
  112. {
  113. name: 'eventsMemberAdmin',
  114. type: 'boolean',
  115. label: t('Let Members Delete Events'),
  116. help: t(
  117. 'Allow members to delete events (including the delete & discard action) by granting them the `event:admin` scope.'
  118. ),
  119. },
  120. {
  121. name: 'alertsMemberWrite',
  122. type: 'boolean',
  123. label: t('Let Members Create and Edit Alerts'),
  124. help: t(
  125. 'Allow members to create, edit, and delete alert rules by granting them the `alerts:write` scope.'
  126. ),
  127. },
  128. {
  129. name: 'attachmentsRole',
  130. type: 'select',
  131. choices: ({initialData = {}}) =>
  132. initialData?.orgRoleList?.map((r: BaseRole) => [r.id, r.name]) ?? [],
  133. label: t('Attachments Access'),
  134. help: t(
  135. 'Role required to download event attachments, such as native crash reports or log files.'
  136. ),
  137. visible: ({features}) => features.has('event-attachments'),
  138. },
  139. {
  140. name: 'debugFilesRole',
  141. type: 'select',
  142. choices: ({initialData = {}}) =>
  143. initialData?.orgRoleList?.map((r: BaseRole) => [r.id, r.name]) ?? [],
  144. label: t('Debug Files Access'),
  145. help: t(
  146. 'Role required to download debug information files, proguard mappings and source maps.'
  147. ),
  148. },
  149. ],
  150. },
  151. ];
  152. export default formGroups;