63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { defineMessages, useIntl } from 'react-intl';
 | 
						|
 | 
						|
import AlternateEmailIcon from 'mastodon/../material-icons/400-24px/alternate_email.svg?react';
 | 
						|
import LockIcon from 'mastodon/../material-icons/400-24px/lock.svg?react';
 | 
						|
import LockOpenIcon from 'mastodon/../material-icons/400-24px/lock_open.svg?react';
 | 
						|
import PublicIcon from 'mastodon/../material-icons/400-24px/public.svg?react';
 | 
						|
 | 
						|
import { Icon } from './icon';
 | 
						|
 | 
						|
type Visibility = 'public' | 'unlisted' | 'private' | 'direct';
 | 
						|
 | 
						|
const messages = defineMessages({
 | 
						|
  public_short: { id: 'privacy.public.short', defaultMessage: 'Public' },
 | 
						|
  unlisted_short: { id: 'privacy.unlisted.short', defaultMessage: 'Unlisted' },
 | 
						|
  private_short: {
 | 
						|
    id: 'privacy.private.short',
 | 
						|
    defaultMessage: 'Followers only',
 | 
						|
  },
 | 
						|
  direct_short: {
 | 
						|
    id: 'privacy.direct.short',
 | 
						|
    defaultMessage: 'Mentioned people only',
 | 
						|
  },
 | 
						|
});
 | 
						|
 | 
						|
export const VisibilityIcon: React.FC<{ visibility: Visibility }> = ({
 | 
						|
  visibility,
 | 
						|
}) => {
 | 
						|
  const intl = useIntl();
 | 
						|
 | 
						|
  const visibilityIconInfo = {
 | 
						|
    public: {
 | 
						|
      icon: 'globe',
 | 
						|
      iconComponent: PublicIcon,
 | 
						|
      text: intl.formatMessage(messages.public_short),
 | 
						|
    },
 | 
						|
    unlisted: {
 | 
						|
      icon: 'unlock',
 | 
						|
      iconComponent: LockOpenIcon,
 | 
						|
      text: intl.formatMessage(messages.unlisted_short),
 | 
						|
    },
 | 
						|
    private: {
 | 
						|
      icon: 'lock',
 | 
						|
      iconComponent: LockIcon,
 | 
						|
      text: intl.formatMessage(messages.private_short),
 | 
						|
    },
 | 
						|
    direct: {
 | 
						|
      icon: 'at',
 | 
						|
      iconComponent: AlternateEmailIcon,
 | 
						|
      text: intl.formatMessage(messages.direct_short),
 | 
						|
    },
 | 
						|
  };
 | 
						|
 | 
						|
  const visibilityIcon = visibilityIconInfo[visibility];
 | 
						|
 | 
						|
  return (
 | 
						|
    <Icon
 | 
						|
      id={visibilityIcon.icon}
 | 
						|
      icon={visibilityIcon.iconComponent}
 | 
						|
      title={visibilityIcon.text}
 | 
						|
    />
 | 
						|
  );
 | 
						|
};
 |