actionTargetSelector.tsx 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. import SelectControl from 'sentry/components/forms/controls/selectControl';
  2. import Input from 'sentry/components/input';
  3. import SelectMembers from 'sentry/components/selectMembers';
  4. import TeamSelector from 'sentry/components/teamSelector';
  5. import {Organization, Project, SelectValue} from 'sentry/types';
  6. import {
  7. Action,
  8. ActionType,
  9. MetricActionTemplate,
  10. TargetType,
  11. } from 'sentry/views/alerts/rules/metric/types';
  12. const getPlaceholderForType = (type: ActionType) => {
  13. switch (type) {
  14. case ActionType.SLACK:
  15. return '@username or #channel';
  16. case ActionType.MSTEAMS:
  17. // no prefixes for msteams
  18. return 'username or channel';
  19. case ActionType.PAGERDUTY:
  20. return 'service';
  21. case ActionType.OPSGENIE:
  22. return 'team';
  23. default:
  24. throw Error('Not implemented');
  25. }
  26. };
  27. type Props = {
  28. action: Action;
  29. disabled: boolean;
  30. loading: boolean;
  31. onChange: (value: string) => void;
  32. organization: Organization;
  33. availableAction?: MetricActionTemplate;
  34. project?: Project;
  35. };
  36. export default function ActionTargetSelector(props: Props) {
  37. const {action, availableAction, disabled, loading, onChange, organization, project} =
  38. props;
  39. const handleChangeTargetIdentifier = (value: SelectValue<string>) => {
  40. onChange(value.value);
  41. };
  42. const handleChangeSpecificTargetIdentifier = (
  43. e: React.ChangeEvent<HTMLInputElement>
  44. ) => {
  45. onChange(e.target.value);
  46. };
  47. switch (action.targetType) {
  48. case TargetType.TEAM:
  49. case TargetType.USER:
  50. const isTeam = action.targetType === TargetType.TEAM;
  51. return isTeam ? (
  52. <TeamSelector
  53. disabled={disabled}
  54. key="team"
  55. project={project}
  56. value={action.targetIdentifier}
  57. onChange={handleChangeTargetIdentifier}
  58. useId
  59. />
  60. ) : (
  61. <SelectMembers
  62. disabled={disabled}
  63. key="member"
  64. project={project}
  65. organization={organization}
  66. value={action.targetIdentifier}
  67. onChange={handleChangeTargetIdentifier}
  68. />
  69. );
  70. case TargetType.SPECIFIC:
  71. return availableAction?.options ? (
  72. <SelectControl
  73. isDisabled={disabled || loading}
  74. value={action.targetIdentifier}
  75. options={availableAction.options}
  76. onChange={handleChangeTargetIdentifier}
  77. />
  78. ) : (
  79. <Input
  80. type="text"
  81. autoComplete="off"
  82. disabled={disabled}
  83. key={action.type}
  84. value={action.targetIdentifier || ''}
  85. onChange={handleChangeSpecificTargetIdentifier}
  86. placeholder={getPlaceholderForType(action.type)}
  87. />
  88. );
  89. default:
  90. return null;
  91. }
  92. }