"use strict"; import classNames from "classnames"; import PropTypes from "prop-types"; import createReactClass from "create-react-class"; import LinkedStateMixin from "react-addons-linked-state-mixin"; var PT = PropTypes; var LanguageSelector = createReactClass({ propTypes: { anyLanguage: PT.array.isRequired, languageMap: PT.object.isRequired, selectedLanguage: PT.array.isRequired, languageFilter: PT.string.isRequired, languageChangeHandler: PT.func.isRequired, }, mixins: [LinkedStateMixin], //fixme! - react-addons-linked-state-mixin - Explicitly set the value and onChange handler instead. selectLang: function(language) { this.props.languageChangeHandler(language, this.props.languageFilter); }, setFilter: function(filter) { this.props.languageChangeHandler(this.props.selectedLanguage, filter); }, renderLanguageObject: function(lang) { var desc = lang[1] + " [" + lang[0] + "]"; var style = { whiteSpace: "nowrap", fontWeight: lang[0] === this.props.selectedLanguage[0] ? "bold":"normal", }; return (
{desc}
); }, renderRadio: function(option) { return this.props.languageFilter === option ? : ; }, render: function() { var languages = _.pairs(this.props.languageMap) .sort(function(l1, l2){return l1[1].localeCompare(l2[1]); }); languages.unshift(this.props.anyLanguage); languages = languages.map(this.renderLanguageObject); var third = Math.round(languages.length/3); var l1 = languages.slice(0, third); var l2 = languages.slice(third, 2*third); var l3 = languages.slice(2*third, languages.length); return (
{l1}
{l2}
{l3}
); } }); module.exports = LanguageSelector;