From bd1ceb1daa954a97b2bc6cea0c1c0fe6da309f32 Mon Sep 17 00:00:00 2001 From: Eugen Rochko Date: Sat, 25 Mar 2017 19:22:24 +0100 Subject: [PATCH] Privacy dropdown i18n --- .../compose/components/privacy_dropdown.jsx | 28 +++++++++++++------ 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/app/assets/javascripts/components/features/compose/components/privacy_dropdown.jsx b/app/assets/javascripts/components/features/compose/components/privacy_dropdown.jsx index f582267f0be..300c5a26f43 100644 --- a/app/assets/javascripts/components/features/compose/components/privacy_dropdown.jsx +++ b/app/assets/javascripts/components/features/compose/components/privacy_dropdown.jsx @@ -1,12 +1,24 @@ import PureRenderMixin from 'react-addons-pure-render-mixin'; -import { FormattedMessage } from 'react-intl'; +import { injectIntl, defineMessages } from 'react-intl'; import IconButton from '../../../components/icon_button'; +const messages = defineMessages({ + public_short: { id: 'privacy.public.short', defaultMessage: 'Public' }, + public_long: { id: 'privacy.public.long', defaultMessage: 'Anyone can see' }, + unlisted_short: { id: 'privacy.unlisted.short', defaultMessage: 'Unlisted' }, + unlisted_long: { id: 'privacy.unlisted.long', defaultMessage: 'Anyone can see' }, + private_short: { id: 'privacy.private.short', defaultMessage: 'Private' }, + private_long: { id: 'privacy.private.long', defaultMessage: 'Followers can see' }, + direct_short: { id: 'privacy.direct.short', defaultMessage: 'Direct' }, + direct_long: { id: 'privacy.direct.long', defaultMessage: 'Mentions can see' } +}); + const PrivacyDropdown = React.createClass({ propTypes: { value: React.PropTypes.string.isRequired, - onChange: React.PropTypes.func.isRequired + onChange: React.PropTypes.func.isRequired, + intl: React.PropTypes.object.isRequired }, getInitialState () { @@ -48,14 +60,14 @@ const PrivacyDropdown = React.createClass({ }, render () { - const { value, onChange } = this.props; + const { value, onChange, intl } = this.props; const { open } = this.state; const options = [ - { icon: 'globe', value: 'public', shortText: 'Public', longText: 'Anyone can see' }, - { icon: 'globe', value: 'unlisted', shortText: 'Unlisted', longText: 'Anyone can see' }, - { icon: 'lock', value: 'private', shortText: 'Private', longText: 'Followers can see' }, - { icon: 'send', value: 'direct', shortText: 'Direct', longText: 'Mentions can see' } + { icon: 'globe', value: 'public', shortText: intl.formatMessage(messages.public_short), longText: intl.formatMessage(messages.public_long) }, + { icon: 'globe', value: 'unlisted', shortText: intl.formatMessage(messages.unlisted_short), longText: intl.formatMessage(messages.unlisted_long) }, + { icon: 'lock', value: 'private', shortText: intl.formatMessage(messages.private_short), longText: intl.formatMessage(messages.private_long) }, + { icon: 'send', value: 'direct', shortText: intl.formatMessage(messages.direct_short), longText: intl.formatMessage(messages.direct_long) } ]; const valueOption = options.find(item => item.value === value); @@ -80,4 +92,4 @@ const PrivacyDropdown = React.createClass({ }); -export default PrivacyDropdown; +export default injectIntl(PrivacyDropdown);