Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
@doodle/i18n / dist / containers / LocaleSwitcher / LocaleSwitcher.js
Size: Mime:
"use strict";

var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");

var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.default = void 0;

var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));

var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));

var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));

var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));

var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));

var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));

var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));

var _react = _interopRequireWildcard(require("react"));

var _propTypes = _interopRequireDefault(require("prop-types"));

var _reactRedux = require("react-redux");

var _LanguageMenu = _interopRequireDefault(require("@doodle/components/controls/LanguageMenu"));

var _localeFlagsHelper = _interopRequireDefault(require("./localeFlagsHelper"));

var _actions = require("../../state/actions");

var _locales = _interopRequireDefault(require("../../locales"));

function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }

function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }

var LocaleSwitcher = /*#__PURE__*/function (_Component) {
  (0, _inherits2.default)(LocaleSwitcher, _Component);

  var _super = _createSuper(LocaleSwitcher);

  function LocaleSwitcher() {
    (0, _classCallCheck2.default)(this, LocaleSwitcher);
    return _super.apply(this, arguments);
  }

  (0, _createClass2.default)(LocaleSwitcher, [{
    key: "render",
    value: function render() {
      var _this$props = this.props,
          currentLocale = _this$props.currentLocale,
          locales = _this$props.locales,
          onChangeLocale = _this$props.onChangeLocale;
      var items = Object.entries(locales).map(function (_ref) {
        var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
            locale = _ref2[0],
            label = _ref2[1];

        return {
          label: label,
          icon: _localeFlagsHelper.default[locale],
          action: function action() {
            return onChangeLocale(locale);
          }
        };
      });
      return /*#__PURE__*/_react.default.createElement(_LanguageMenu.default, {
        className: "LocaleSwitcher",
        items: items
      }, locales[currentLocale]);
    }
  }]);
  return LocaleSwitcher;
}(_react.Component);

(0, _defineProperty2.default)(LocaleSwitcher, "propTypes", {
  currentLocale: _propTypes.default.string.isRequired,
  locales: _propTypes.default.object,
  onChangeLocale: _propTypes.default.func.isRequired
});
(0, _defineProperty2.default)(LocaleSwitcher, "defaultProps", {
  locales: _locales.default
});

var mapStateToProps = function mapStateToProps(state) {
  return {
    currentLocale: state.i18n.locale
  };
};

var mapDispatchToProps = function mapDispatchToProps(dispatch) {
  return {
    onChangeLocale: function onChangeLocale(locale) {
      dispatch((0, _actions.changeLocale)(locale));
    }
  };
};

var _default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)(LocaleSwitcher);

exports.default = _default;
//# sourceMappingURL=LocaleSwitcher.js.map