import PropTypes from 'prop-types'; import { defineMessages, injectIntl } from 'react-intl'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { Icon } from 'flavours/glitch/components/icon'; import ForumIcon from 'mastodon/../material-icons/400-24px/forum.svg?react'; import HomeIcon from 'mastodon/../material-icons/400-24px/home-fill.svg?react'; const messages = defineMessages({ localOnly: { defaultMessage: 'This post is local-only', id: 'advanced_options.local-only.tooltip', }, threadedMode: { defaultMessage: 'Threaded mode enabled', id: 'advanced_options.threaded_mode.tooltip', }, }); // We use an array of tuples here instead of an object because it // preserves order. const iconMap = [ ['do_not_federate', 'home', HomeIcon, messages.localOnly], ['threaded_mode', 'comments', ForumIcon, messages.threadedMode], ]; class TextareaIcons extends ImmutablePureComponent { static propTypes = { advancedOptions: ImmutablePropTypes.map, intl: PropTypes.object.isRequired, }; render () { const { advancedOptions, intl } = this.props; return (