UNPKG

next-i18next

Version:

The easiest way to translate your NextJs apps.

136 lines (133 loc) 8.22 kB
"use strict"; require("core-js/modules/es.symbol.js"); require("core-js/modules/es.array.filter.js"); require("core-js/modules/es.object.to-string.js"); require("core-js/modules/es.object.get-own-property-descriptor.js"); require("core-js/modules/es.array.for-each.js"); require("core-js/modules/web.dom-collections.for-each.js"); require("core-js/modules/es.object.get-own-property-descriptors.js"); require("core-js/modules/es.object.define-properties.js"); require("core-js/modules/es.object.define-property.js"); require("core-js/modules/es.array.iterator.js"); require("core-js/modules/es.string.iterator.js"); require("core-js/modules/es.weak-map.js"); require("core-js/modules/web.dom-collections.iterator.js"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "Trans", { enumerable: true, get: function get() { return _reactI18next.Trans; } }); exports.globalI18n = exports.appWithTranslation = void 0; Object.defineProperty(exports, "useTranslation", { enumerable: true, get: function get() { return _reactI18next.useTranslation; } }); Object.defineProperty(exports, "withTranslation", { enumerable: true, get: function get() { return _reactI18next.withTranslation; } }); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); require("core-js/modules/es.object.keys.js"); var _react = _interopRequireWildcard(require("react")); var _hoistNonReactStatics = _interopRequireDefault(require("hoist-non-react-statics")); var _reactI18next = require("react-i18next"); var _createConfig = require("./config/createConfig"); var _createClient = _interopRequireDefault(require("./createClient")); var _utils = require("./utils"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } var __jsx = _react["default"].createElement; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var globalI18n = exports.globalI18n = null; var addResourcesToI18next = function addResourcesToI18next(instance, resources) { if (resources && instance.isInitialized) { for (var _i = 0, _Object$keys = Object.keys(resources); _i < _Object$keys.length; _i++) { var locale = _Object$keys[_i]; for (var _i2 = 0, _Object$keys2 = Object.keys(resources[locale]); _i2 < _Object$keys2.length; _i2++) { var _instance$store; var ns = _Object$keys2[_i2]; if (!(instance !== null && instance !== void 0 && (_instance$store = instance.store) !== null && _instance$store !== void 0 && _instance$store.data) || !instance.store.data[locale] || !instance.store.data[locale][ns]) { instance.addResourceBundle(locale, ns, resources[locale][ns], true, true); } } } } }; var appWithTranslation = exports.appWithTranslation = function appWithTranslation(WrappedComponent) { var configOverride = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; var AppWithTranslation = function AppWithTranslation(props) { var _nextI18Next$initialL, _props$router; var _ref = props.pageProps || {}, _nextI18Next = _ref._nextI18Next; // pageProps may be undefined on strange setups, i.e. https://github.com/i18next/next-i18next/issues/2109 var locale = (_nextI18Next$initialL = _nextI18Next === null || _nextI18Next === void 0 ? void 0 : _nextI18Next.initialLocale) !== null && _nextI18Next$initialL !== void 0 ? _nextI18Next$initialL : props === null || props === void 0 || (_props$router = props.router) === null || _props$router === void 0 ? void 0 : _props$router.locale; var ns = _nextI18Next === null || _nextI18Next === void 0 ? void 0 : _nextI18Next.ns; var instanceRef = (0, _react.useRef)(null); /** * Memoize i18n instance and reuse it rather than creating new instance. * When the locale or resources are changed after instance was created, * we will update the instance by calling addResourceBundle method on it. */ var i18n = (0, _react.useMemo)(function () { var _userConfig$i18n, _configOverride$resou; if (!_nextI18Next && !configOverride) return null; var userConfig = configOverride !== null && configOverride !== void 0 ? configOverride : _nextI18Next === null || _nextI18Next === void 0 ? void 0 : _nextI18Next.userConfig; if (!userConfig) { throw new Error('appWithTranslation was called without a next-i18next config'); } if (!(userConfig !== null && userConfig !== void 0 && userConfig.i18n)) { throw new Error('appWithTranslation was called without config.i18n'); } if (!(userConfig !== null && userConfig !== void 0 && (_userConfig$i18n = userConfig.i18n) !== null && _userConfig$i18n !== void 0 && _userConfig$i18n.defaultLocale)) { throw new Error('config.i18n does not include a defaultLocale property'); } var _ref2 = _nextI18Next || {}, initialI18nStore = _ref2.initialI18nStore; var resources = (_configOverride$resou = configOverride === null || configOverride === void 0 ? void 0 : configOverride.resources) !== null && _configOverride$resou !== void 0 ? _configOverride$resou : initialI18nStore; if (!locale) locale = userConfig.i18n.defaultLocale; var instance = instanceRef.current; if (instance) { addResourcesToI18next(instance, resources); } else { instance = (0, _createClient["default"])(_objectSpread(_objectSpread(_objectSpread({}, (0, _createConfig.createConfig)(_objectSpread(_objectSpread({}, userConfig), {}, { lng: locale }))), {}, { lng: locale }, ns && { ns: ns }), {}, { resources: resources })).i18n; addResourcesToI18next(instance, resources); exports.globalI18n = globalI18n = instance; instanceRef.current = instance; } return instance; }, [_nextI18Next, locale, ns]); /** * Since calling changeLanguage method on existing i18n instance cause state update in react, * we need to call the method in `useLayoutEffect` to prevent state update in render phase. */ (0, _utils.useIsomorphicLayoutEffect)(function () { if (!i18n || !locale) return; i18n.changeLanguage(locale); }, [i18n, locale]); return i18n !== null ? __jsx(_reactI18next.I18nextProvider, { i18n: i18n }, __jsx(WrappedComponent, props)) : __jsx(WrappedComponent, (0, _extends2["default"])({ key: locale }, props)); }; return (0, _hoistNonReactStatics["default"])(AppWithTranslation, WrappedComponent); };