visibility_icon.tsx 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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 PublicIcon from '@/material-icons/400-24px/public.svg?react';
  5. import QuietTimeIcon from '@/material-icons/400-24px/quiet_time.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: {
  11. id: 'privacy.unlisted.short',
  12. defaultMessage: 'Quiet public',
  13. },
  14. private_short: {
  15. id: 'privacy.private.short',
  16. defaultMessage: 'Followers',
  17. },
  18. direct_short: {
  19. id: 'privacy.direct.short',
  20. defaultMessage: 'Specific people',
  21. },
  22. });
  23. export const VisibilityIcon: React.FC<{ visibility: Visibility }> = ({
  24. visibility,
  25. }) => {
  26. const intl = useIntl();
  27. const visibilityIconInfo = {
  28. public: {
  29. icon: 'globe',
  30. iconComponent: PublicIcon,
  31. text: intl.formatMessage(messages.public_short),
  32. },
  33. unlisted: {
  34. icon: 'unlock',
  35. iconComponent: QuietTimeIcon,
  36. text: intl.formatMessage(messages.unlisted_short),
  37. },
  38. private: {
  39. icon: 'lock',
  40. iconComponent: LockIcon,
  41. text: intl.formatMessage(messages.private_short),
  42. },
  43. direct: {
  44. icon: 'at',
  45. iconComponent: AlternateEmailIcon,
  46. text: intl.formatMessage(messages.direct_short),
  47. },
  48. };
  49. const visibilityIcon = visibilityIconInfo[visibility];
  50. return (
  51. <Icon
  52. id={visibilityIcon.icon}
  53. icon={visibilityIcon.iconComponent}
  54. title={visibilityIcon.text}
  55. />
  56. );
  57. };