pluginIcon.tsx 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. import styled from '@emotion/styled';
  2. import amixr from 'sentry-logos/logo-amixr.svg';
  3. import asana from 'sentry-logos/logo-asana.svg';
  4. import asayer from 'sentry-logos/logo-asayer.svg';
  5. import aws from 'sentry-logos/logo-aws.svg';
  6. import vsts from 'sentry-logos/logo-azure.svg';
  7. import bitbucket from 'sentry-logos/logo-bitbucket.svg';
  8. import bitbucketserver from 'sentry-logos/logo-bitbucket-server.svg';
  9. import campfire from 'sentry-logos/logo-campfire.svg';
  10. import clickup from 'sentry-logos/logo-clickup.svg';
  11. import clubhouse from 'sentry-logos/logo-clubhouse.svg';
  12. import datadog from 'sentry-logos/logo-datadog.svg';
  13. import placeholder from 'sentry-logos/logo-default.svg';
  14. import flowdock from 'sentry-logos/logo-flowdock.svg';
  15. import fullstory from 'sentry-logos/logo-fullstory.svg';
  16. import github from 'sentry-logos/logo-github.svg';
  17. import githubActions from 'sentry-logos/logo-github-actions.svg';
  18. import githubEnterprise from 'sentry-logos/logo-github-enterprise.svg';
  19. import gitlab from 'sentry-logos/logo-gitlab.svg';
  20. import heroku from 'sentry-logos/logo-heroku.svg';
  21. import jira from 'sentry-logos/logo-jira.svg';
  22. import jiraserver from 'sentry-logos/logo-jira-server.svg';
  23. import komodor from 'sentry-logos/logo-komodor.svg';
  24. import lighthouse from 'sentry-logos/logo-lighthouse.svg';
  25. import linear from 'sentry-logos/logo-linear.svg';
  26. import msteams from 'sentry-logos/logo-msteams.svg';
  27. import netlify from 'sentry-logos/logo-netlify.svg';
  28. import octohook from 'sentry-logos/logo-octohook.svg';
  29. import opsgenie from 'sentry-logos/logo-opsgenie.svg';
  30. import pagerduty from 'sentry-logos/logo-pagerduty.svg';
  31. import phabricator from 'sentry-logos/logo-phabricator.svg';
  32. import pivotal from 'sentry-logos/logo-pivotaltracker.svg';
  33. import pushover from 'sentry-logos/logo-pushover.svg';
  34. import quill from 'sentry-logos/logo-quill.svg';
  35. import redmine from 'sentry-logos/logo-redmine.svg';
  36. import rocketchat from 'sentry-logos/logo-rocketchat.svg';
  37. import rookout from 'sentry-logos/logo-rookout.svg';
  38. import segment from 'sentry-logos/logo-segment.svg';
  39. import sentry from 'sentry-logos/logo-sentry.svg';
  40. import slack from 'sentry-logos/logo-slack.svg';
  41. import spikesh from 'sentry-logos/logo-spikesh.svg';
  42. import split from 'sentry-logos/logo-split.svg';
  43. import taiga from 'sentry-logos/logo-taiga.svg';
  44. import teamwork from 'sentry-logos/logo-teamwork.svg';
  45. import trello from 'sentry-logos/logo-trello.svg';
  46. import twilio from 'sentry-logos/logo-twilio.svg';
  47. import vercel from 'sentry-logos/logo-vercel.svg';
  48. import victorops from 'sentry-logos/logo-victorops.svg';
  49. import visualstudio from 'sentry-logos/logo-visualstudio.svg';
  50. import youtrack from 'sentry-logos/logo-youtrack.svg';
  51. import zepel from 'sentry-logos/logo-zepel.svg';
  52. import zulip from 'sentry-logos/logo-zulip.svg';
  53. // Map of plugin id -> logo filename
  54. export const DEFAULT_ICON = placeholder;
  55. export const ICON_PATHS = {
  56. _default: DEFAULT_ICON,
  57. sentry,
  58. browsers: sentry,
  59. device: sentry,
  60. interface_types: sentry,
  61. os: sentry,
  62. urls: sentry,
  63. webhooks: sentry,
  64. 'amazon-sqs': aws,
  65. aws_lambda: aws,
  66. amixr,
  67. asana,
  68. asayer,
  69. bitbucket,
  70. bitbucket_pipelines: bitbucket,
  71. bitbucket_server: bitbucketserver,
  72. campfire,
  73. clickup,
  74. clubhouse,
  75. datadog,
  76. flowdock,
  77. fullstory,
  78. github,
  79. github_actions: githubActions,
  80. github_enterprise: githubEnterprise,
  81. gitlab,
  82. heroku,
  83. jira,
  84. 'jira-atlassian-connect': jira,
  85. 'jira-ac': jira,
  86. jira_server: jiraserver,
  87. komodor,
  88. lighthouse,
  89. linear,
  90. msteams,
  91. netlify,
  92. octohook,
  93. opsgenie,
  94. pagerduty,
  95. phabricator,
  96. pivotal,
  97. pushover,
  98. quill,
  99. redmine,
  100. rocketchat,
  101. rookout,
  102. segment,
  103. slack,
  104. spikesh,
  105. split,
  106. taiga,
  107. teamwork,
  108. trello,
  109. twilio,
  110. visualstudio,
  111. vsts,
  112. youtrack,
  113. vercel,
  114. victorops,
  115. zepel,
  116. zulip,
  117. };
  118. type Props = {
  119. pluginId?: string;
  120. size?: number;
  121. };
  122. const PluginIcon = styled('div')<Props>`
  123. position: relative;
  124. height: ${p => p.size}px;
  125. width: ${p => p.size}px;
  126. border-radius: 2px;
  127. border: 0;
  128. display: inline-block;
  129. background-size: contain;
  130. background-position: center center;
  131. background-repeat: no-repeat;
  132. background-image: url(${({pluginId}) =>
  133. (pluginId !== undefined && ICON_PATHS[pluginId]) || DEFAULT_ICON});
  134. `;
  135. PluginIcon.defaultProps = {
  136. pluginId: '_default',
  137. size: 20,
  138. };
  139. export default PluginIcon;