visibility_icon.tsx 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import { defineMessages, useIntl } from 'react-intl';
  2. import AlternateEmailIcon from '@/material-icons/400-24px/alternate_email.svg?react';
  3. import LockIcon from '@/material-icons/400-24px/lock.svg?react';
  4. import LockOpenIcon from '@/material-icons/400-24px/lock_open.svg?react';
  5. import PublicIcon from '@/material-icons/400-24px/public.svg?react';
  6. import { Icon } from './icon';
  7. type Visibility = 'public' | 'unlisted' | 'private' | 'direct';
  8. const messages = defineMessages({
  9. public_short: { id: 'privacy.public.short', defaultMessage: 'Public' },
  10. unlisted_short: { id: 'privacy.unlisted.short', defaultMessage: 'Unlisted' },
  11. private_short: {
  12. id: 'privacy.private.short',
  13. defaultMessage: 'Followers only',
  14. },
  15. direct_short: {
  16. id: 'privacy.direct.short',
  17. defaultMessage: 'Mentioned people only',
  18. },
  19. });
  20. export const VisibilityIcon: React.FC<{ visibility: Visibility }> = ({
  21. visibility,
  22. }) => {
  23. const intl = useIntl();
  24. const visibilityIconInfo = {
  25. public: {
  26. icon: 'globe',
  27. iconComponent: PublicIcon,
  28. text: intl.formatMessage(messages.public_short),
  29. },
  30. unlisted: {
  31. icon: 'unlock',
  32. iconComponent: LockOpenIcon,
  33. text: intl.formatMessage(messages.unlisted_short),
  34. },
  35. private: {
  36. icon: 'lock',
  37. iconComponent: LockIcon,
  38. text: intl.formatMessage(messages.private_short),
  39. },
  40. direct: {
  41. icon: 'at',
  42. iconComponent: AlternateEmailIcon,
  43. text: intl.formatMessage(messages.direct_short),
  44. },
  45. };
  46. const visibilityIcon = visibilityIconInfo[visibility];
  47. return (
  48. <Icon
  49. id={visibilityIcon.icon}
  50. icon={visibilityIcon.iconComponent}
  51. title={visibilityIcon.text}
  52. />
  53. );
  54. };