about summary refs log tree commit diff
diff options
context:
space:
mode:
authorEugen Rochko <eugen@zeonfederated.com>2017-03-25 19:22:24 +0100
committerEugen Rochko <eugen@zeonfederated.com>2017-03-25 19:22:24 +0100
commitbd1ceb1daa954a97b2bc6cea0c1c0fe6da309f32 (patch)
treec057fc4d2bf13ae63101bfc879db412ec586f91c
parent99ca63a543113a551a03d8ce061740837566d167 (diff)
Privacy dropdown i18n
-rw-r--r--app/assets/javascripts/components/features/compose/components/privacy_dropdown.jsx28
1 files 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 f582267f0..300c5a26f 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);