contextIcon.tsx 5.0 KB

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