contextIcon.tsx 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. import {css, useTheme} from '@emotion/react';
  2. import logoAmazon from 'sentry-logos/logo-amazon.svg';
  3. import logoAmd from 'sentry-logos/logo-amd.svg';
  4. import logoAndroid from 'sentry-logos/logo-android.svg';
  5. import logoAndroidPhone from 'sentry-logos/logo-android-phone.svg';
  6. import logoAndroidTablet from 'sentry-logos/logo-android-tablet.svg';
  7. import logoApple from 'sentry-logos/logo-apple.svg';
  8. import logoApplePhone from 'sentry-logos/logo-apple-phone.svg';
  9. import logoAppleTablet from 'sentry-logos/logo-apple-tablet.svg';
  10. import logoAppleTv from 'sentry-logos/logo-apple-tv.svg';
  11. import logoAppleWatch from 'sentry-logos/logo-apple-watch.svg';
  12. import logoArm from 'sentry-logos/logo-arm.svg';
  13. import logoChrome from 'sentry-logos/logo-chrome.svg';
  14. import logoChromium from 'sentry-logos/logo-chromium.svg';
  15. import logoCrystal from 'sentry-logos/logo-crystal.svg';
  16. import logoDotnet from 'sentry-logos/logo-dotnet.svg';
  17. import logoEdgeNew from 'sentry-logos/logo-edge-new.svg';
  18. import logoEdgeOld from 'sentry-logos/logo-edge-old.svg';
  19. import logoElectron from 'sentry-logos/logo-electron.svg';
  20. import logoFirefox from 'sentry-logos/logo-firefox.svg';
  21. import logoGoogle from 'sentry-logos/logo-google.svg';
  22. import logoIe from 'sentry-logos/logo-ie.svg';
  23. import logoLinux from 'sentry-logos/logo-linux.svg';
  24. import logoMonogorilla from 'sentry-logos/logo-monogorilla.svg';
  25. import logoMotorola from 'sentry-logos/logo-motorola.svg';
  26. import logoNetcore from 'sentry-logos/logo-netcore.svg';
  27. import logoNetframework from 'sentry-logos/logo-netframework.svg';
  28. import logoNvidia from 'sentry-logos/logo-nvidia.svg';
  29. import logoOpera from 'sentry-logos/logo-opera.svg';
  30. import logoPhp from 'sentry-logos/logo-php.svg';
  31. import logoPlaystation from 'sentry-logos/logo-playstation.svg';
  32. import logoPython from 'sentry-logos/logo-python.svg';
  33. import logoQq from 'sentry-logos/logo-qq.svg';
  34. import logoRuby from 'sentry-logos/logo-ruby.svg';
  35. import logoSafari from 'sentry-logos/logo-safari.svg';
  36. import logoSamsung from 'sentry-logos/logo-samsung.svg';
  37. import logoUbuntu from 'sentry-logos/logo-ubuntu.svg';
  38. import logoUnity from 'sentry-logos/logo-unity.svg';
  39. import logoUnknown from 'sentry-logos/logo-unknown.svg';
  40. import logoWindows from 'sentry-logos/logo-windows.svg';
  41. import ConfigStore from 'sentry/stores/configStore';
  42. import {useLegacyStore} from 'sentry/stores/useLegacyStore';
  43. import {IconSize} from 'sentry/utils/theme';
  44. const LOGO_MAPPING = {
  45. 'android-phone': logoAndroidPhone,
  46. 'android-tablet': logoAndroidTablet,
  47. 'chrome-mobile': logoChrome,
  48. 'chrome-mobile-ios': logoChrome,
  49. 'google-chrome': logoChrome,
  50. 'internet-explorer': logoIe,
  51. 'legacy-edge': logoEdgeOld,
  52. 'mac-os-x': logoApple,
  53. 'mobile-safari': logoSafari,
  54. 'net-core': logoNetcore,
  55. 'net-framework': logoNetframework,
  56. 'qq-browser': logoQq,
  57. amazon: logoAmazon,
  58. amd: logoAmd,
  59. android: logoAndroid,
  60. apple: logoApple,
  61. appletv: logoAppleTv,
  62. arm: logoArm,
  63. chrome: logoChrome,
  64. chromium: logoChromium,
  65. cpython: logoPython,
  66. crystal: logoCrystal,
  67. darwin: logoApple,
  68. edge: logoEdgeNew,
  69. electron: logoElectron,
  70. firefox: logoFirefox,
  71. google: logoGoogle,
  72. il: logoUnity,
  73. ios: logoApple,
  74. ipad: logoAppleTablet,
  75. iphone: logoApplePhone,
  76. ipod: logoApplePhone,
  77. linux: logoLinux,
  78. mac: logoApple,
  79. macos: logoApple,
  80. mono: logoMonogorilla,
  81. motorola: logoMotorola,
  82. net: logoDotnet,
  83. nvidia: logoNvidia,
  84. opera: logoOpera,
  85. php: logoPhp,
  86. playstation: logoPlaystation,
  87. python: logoPython,
  88. ruby: logoRuby,
  89. safari: logoSafari,
  90. samsung: logoSamsung,
  91. tvos: logoApple,
  92. ubuntu: logoUbuntu,
  93. watch: logoAppleWatch,
  94. watchos: logoApple,
  95. windows: logoWindows,
  96. };
  97. // The icons in this list will be inverted when the theme is set to dark mode
  98. const INVERT_IN_DARKMODE = [
  99. 'darwin',
  100. 'ios',
  101. 'macos',
  102. 'tvos',
  103. 'mac-os-x',
  104. 'mac',
  105. 'apple',
  106. 'watchos',
  107. ];
  108. const darkCss = css`
  109. filter: invert(100%);
  110. opacity: 0.8;
  111. `;
  112. function getLogoImage(name: string) {
  113. if (name.startsWith('amd-')) {
  114. return logoAmd;
  115. }
  116. if (name.startsWith('nvidia-')) {
  117. return logoNvidia;
  118. }
  119. return LOGO_MAPPING[name] ?? logoUnknown;
  120. }
  121. type Props = {
  122. name: string;
  123. size?: IconSize;
  124. };
  125. function ContextIcon({name, size: providedSize = 'xl'}: Props) {
  126. const theme = useTheme();
  127. const size = theme.iconSizes[providedSize];
  128. // Apply darkmode CSS to icon when in darkmode
  129. const isDarkmode = useLegacyStore(ConfigStore).theme === 'dark';
  130. const extraCass = isDarkmode && INVERT_IN_DARKMODE.includes(name) ? darkCss : null;
  131. return <img height={size} width={size} css={extraCass} src={getLogoImage(name)} />;
  132. }
  133. export default ContextIcon;