@coog/gatsby-plugin-react-i18next
Version:
Easily translate your Gatsby website into multiple languages
54 lines (40 loc) • 1.6 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.__esModule = true;
exports.Link = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
var _react = _interopRequireWildcard(require("react"));
var _i18nextContext = require("./i18nextContext");
var _gatsby = require("gatsby");
var _types = require("./types");
var Link = function Link(_ref) {
var language = _ref.language,
to = _ref.to,
_onClick = _ref.onClick,
rest = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["language", "to", "onClick"]);
var context = (0, _react.useContext)(_i18nextContext.I18nextContext);
var urlLanguage = language || context.language;
var getLanguagePath = function getLanguagePath(language) {
return context.generateDefaultLanguagePage || language !== context.defaultLanguage ? "/" + language : '';
};
var link = "" + getLanguagePath(urlLanguage) + to;
return (
/*#__PURE__*/
// @ts-ignore
_react.default.createElement(_gatsby.Link, (0, _extends2.default)({}, rest, {
to: link,
hrefLang: urlLanguage,
onClick: function onClick(e) {
if (language) {
localStorage.setItem(_types.LANGUAGE_KEY, language);
}
if (_onClick) {
_onClick(e);
}
}
}))
);
};
exports.Link = Link;