contextIcon.tsx 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. 'internet-explorer': logoIe,
  50. 'legacy-edge': logoEdgeOld,
  51. 'mac-os-x': logoApple,
  52. 'mobile-safari': logoSafari,
  53. 'net-core': logoNetcore,
  54. 'net-framework': logoNetframework,
  55. 'qq-browser': logoQq,
  56. amazon: logoAmazon,
  57. amd: logoAmd,
  58. android: logoAndroid,
  59. apple: logoApple,
  60. appletv: logoAppleTv,
  61. arm: logoArm,
  62. chrome: logoChrome,
  63. chromium: logoChromium,
  64. cpython: logoPython,
  65. crystal: logoCrystal,
  66. darwin: logoApple,
  67. edge: logoEdgeNew,
  68. electron: logoElectron,
  69. firefox: logoFirefox,
  70. google: logoGoogle,
  71. il: logoUnity,
  72. ios: logoApple,
  73. ipad: logoAppleTablet,
  74. iphone: logoApplePhone,
  75. ipod: logoApplePhone,
  76. linux: logoLinux,
  77. mac: logoApple,
  78. macos: logoApple,
  79. mono: logoMonogorilla,
  80. motorola: logoMotorola,
  81. net: logoDotnet,
  82. nvidia: logoNvidia,
  83. opera: logoOpera,
  84. php: logoPhp,
  85. playstation: logoPlaystation,
  86. python: logoPython,
  87. ruby: logoRuby,
  88. safari: logoSafari,
  89. samsung: logoSamsung,
  90. tvos: logoApple,
  91. ubuntu: logoUbuntu,
  92. watch: logoAppleWatch,
  93. watchos: logoApple,
  94. windows: logoWindows,
  95. };
  96. // The icons in this list will be inverted when the theme is set to dark mode
  97. const INVERT_IN_DARKMODE = [
  98. 'darwin',
  99. 'ios',
  100. 'macos',
  101. 'tvos',
  102. 'mac-os-x',
  103. 'mac',
  104. 'apple',
  105. 'watchos',
  106. ];
  107. const darkCss = css`
  108. filter: invert(100%);
  109. opacity: 0.8;
  110. `;
  111. function getLogoImage(name: string) {
  112. if (name.startsWith('amd-')) {
  113. return logoAmd;
  114. }
  115. if (name.startsWith('nvidia-')) {
  116. return logoNvidia;
  117. }
  118. return LOGO_MAPPING[name] ?? logoUnknown;
  119. }
  120. type Props = {
  121. name: string;
  122. size?: IconSize;
  123. };
  124. function ContextIcon({name, size: providedSize = 'xl'}: Props) {
  125. const theme = useTheme();
  126. const size = theme.iconSizes[providedSize];
  127. // Apply darkmode CSS to icon when in darkmode
  128. const isDarkmode = useLegacyStore(ConfigStore).theme === 'dark';
  129. const extraCass = isDarkmode && INVERT_IN_DARKMODE.includes(name) ? darkCss : null;
  130. return <img height={size} width={size} css={extraCass} src={getLogoImage(name)} />;
  131. }
  132. export default ContextIcon;