glitch-soc/mastodon

View on GitHub
app/javascript/flavours/glitch/features/notifications/components/moderation_warning.tsx

Summary

Maintainability
D
1 day
Test Coverage
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';

import GavelIcon from '@/material-icons/400-24px/gavel.svg?react';
import { Icon } from 'flavours/glitch/components/icon';

// This needs to be kept in sync with app/models/account_warning.rb
const messages = defineMessages({
  none: {
    id: 'notification.moderation_warning.action_none',
    defaultMessage: 'Your account has received a moderation warning.',
  },
  disable: {
    id: 'notification.moderation_warning.action_disable',
    defaultMessage: 'Your account has been disabled.',
  },
  mark_statuses_as_sensitive: {
    id: 'notification.moderation_warning.action_mark_statuses_as_sensitive',
    defaultMessage: 'Some of your posts have been marked as sensitive.',
  },
  delete_statuses: {
    id: 'notification.moderation_warning.action_delete_statuses',
    defaultMessage: 'Some of your posts have been removed.',
  },
  sensitive: {
    id: 'notification.moderation_warning.action_sensitive',
    defaultMessage: 'Your posts will be marked as sensitive from now on.',
  },
  silence: {
    id: 'notification.moderation_warning.action_silence',
    defaultMessage: 'Your account has been limited.',
  },
  suspend: {
    id: 'notification.moderation_warning.action_suspend',
    defaultMessage: 'Your account has been suspended.',
  },
});

interface Props {
  action:
    | 'none'
    | 'disable'
    | 'mark_statuses_as_sensitive'
    | 'delete_statuses'
    | 'sensitive'
    | 'silence'
    | 'suspend';
  id: string;
  hidden: boolean;
}

export const ModerationWarning: React.FC<Props> = ({ action, id, hidden }) => {
  const intl = useIntl();

  if (hidden) {
    return null;
  }

  return (
    <a
      href={`/disputes/strikes/${id}`}
      target='_blank'
      rel='noopener noreferrer'
      className='notification__moderation-warning'
    >
      <Icon id='warning' icon={GavelIcon} />

      <div className='notification__moderation-warning__content'>
        <p>{intl.formatMessage(messages[action])}</p>
        <span className='link-button'>
          <FormattedMessage
            id='notification.moderation-warning.learn_more'
            defaultMessage='Learn more'
          />
        </span>
      </div>
    </a>
  );
};