react-intlayer
Version:
Easily internationalize i18n your React applications with type-safe multilingual content management.
72 lines • 2.92 kB
JavaScript
"use client";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var useLocale_exports = {};
__export(useLocale_exports, {
useLocale: () => useLocale
});
module.exports = __toCommonJS(useLocale_exports);
var import_built = __toESM(require("@intlayer/config/built"));
var import_react = require("react");
var import_IntlayerProvider = require('./IntlayerProvider.cjs');
var import_useLocaleCookie = require('./useLocaleCookie.cjs');
const useLocale = ({ onLocaleChange } = {}) => {
const { defaultLocale, locales: availableLocales } = import_built.default?.internationalization ?? {};
const { locale, setLocale: setLocaleState } = (0, import_react.useContext)(
import_IntlayerProvider.IntlayerClientContext
);
const { setLocaleCookie } = (0, import_useLocaleCookie.useLocaleCookie)();
const setLocale = (0, import_react.useCallback)(
(locale2) => {
if (!availableLocales?.map(String).includes(locale2)) {
console.error(`Locale ${locale2} is not available`);
return;
}
setLocaleState(locale2);
setLocaleCookie(locale2);
onLocaleChange?.(locale2);
},
[availableLocales, onLocaleChange, setLocaleCookie, setLocaleState]
);
return {
locale,
// Current locale
defaultLocale,
// Principal locale defined in config
availableLocales,
// List of the available locales defined in config
setLocale
// Function to set the locale
};
};
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
useLocale
});
//# sourceMappingURL=useLocale.cjs.map
;