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 / containers / I18NProvider / I18NProvider.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 _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 _reactIntl = require("react-intl");

var _hash = _interopRequireDefault(require("./hash"));

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 { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }

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

  var _super = _createSuper(I18NProvider);

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

  (0, _createClass2.default)(I18NProvider, [{
    key: "shouldComponentUpdate",
    value: // eslint-disable-next-line class-methods-use-this
    function shouldComponentUpdate(props) {
      var locale = props.locale,
          messages = props.messages;
      return typeof messages[locale] !== 'undefined';
    }
  }, {
    key: "render",
    value: function render() {
      var _this$props = this.props,
          locale = _this$props.locale,
          messages = _this$props.messages,
          children = _this$props.children; // Create a hash depending of the current locale and messages object.
      // This will enforce the re-render of the provider children when or the locale or only the messages change.

      var key = I18NProvider.generateProviderKey(locale, messages);
      return /*#__PURE__*/_react.default.createElement(_reactIntl.IntlProvider, {
        key: key,
        locale: locale,
        messages: messages[locale]
      }, _react.default.Children.only(children));
    }
  }], [{
    key: "generateProviderKey",
    value: function generateProviderKey(locale, messages) {
      var key = "".concat(locale).concat(JSON.stringify(messages[locale]));
      return (0, _hash.default)(key);
    }
  }]);
  return I18NProvider;
}(_react.Component);

(0, _defineProperty2.default)(I18NProvider, "propTypes", {
  locale: _propTypes.default.string.isRequired,
  messages: _propTypes.default.object.isRequired,
  children: _propTypes.default.element.isRequired
});

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

var mapDispatchToProps = function mapDispatchToProps() {
  return {};
};

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

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