next-intl 3.3.2 → 3.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/development/react-server/{getBaseTranslator.js → getTranslator.js} +6 -6
- package/dist/development/react-server/{useHook.js → useConfig.js} +7 -1
- package/dist/development/react-server/useFormatter.js +6 -7
- package/dist/development/react-server/useMessages.js +3 -6
- package/dist/development/react-server/useNow.js +3 -7
- package/dist/development/react-server/useTimeZone.js +3 -7
- package/dist/development/react-server/useTranslations.js +4 -6
- package/dist/development/server/react-server/RequestLocale.js +6 -4
- package/dist/development/server/react-server/getConfig.js +14 -6
- package/dist/development/server/react-server/getFormatter.js +4 -3
- package/dist/development/server/react-server/getMessages.js +9 -4
- package/dist/development/server/react-server/getNow.js +4 -3
- package/dist/development/server/react-server/getTimeZone.js +4 -3
- package/dist/development/server.react-server.js +2 -2
- package/dist/esm/react-server/getTranslator.js +1 -0
- package/dist/esm/react-server/useConfig.js +1 -0
- package/dist/esm/react-server/useFormatter.js +1 -1
- package/dist/esm/react-server/useMessages.js +1 -1
- package/dist/esm/react-server/useNow.js +1 -1
- package/dist/esm/react-server/useTimeZone.js +1 -1
- package/dist/esm/react-server/useTranslations.js +1 -1
- package/dist/esm/server/react-server/RequestLocale.js +1 -1
- package/dist/esm/server/react-server/getConfig.js +1 -1
- package/dist/esm/server/react-server/getFormatter.js +1 -1
- package/dist/esm/server/react-server/getMessages.js +1 -1
- package/dist/esm/server/react-server/getNow.js +1 -1
- package/dist/esm/server/react-server/getTimeZone.js +1 -1
- package/dist/esm/server.react-server.js +1 -1
- package/dist/production/react-server/getTranslator.js +1 -0
- package/dist/production/react-server/useConfig.js +1 -0
- package/dist/production/react-server/useFormatter.js +1 -1
- package/dist/production/react-server/useMessages.js +1 -1
- package/dist/production/react-server/useNow.js +1 -1
- package/dist/production/react-server/useTimeZone.js +1 -1
- package/dist/production/react-server/useTranslations.js +1 -1
- package/dist/production/server/react-server/RequestLocale.js +1 -1
- package/dist/production/server/react-server/getConfig.js +1 -1
- package/dist/production/server/react-server/getFormatter.js +1 -1
- package/dist/production/server/react-server/getMessages.js +1 -1
- package/dist/production/server/react-server/getNow.js +1 -1
- package/dist/production/server/react-server/getTimeZone.js +1 -1
- package/dist/production/server.react-server.js +1 -1
- package/dist/types/__mocks__/react.d.ts +9 -0
- package/dist/types/src/react-server/{getBaseTranslator.d.ts → getTranslator.d.ts} +3 -3
- package/dist/types/src/react-server/useConfig.d.ts +2 -0
- package/dist/types/src/react-server/useFormatter.d.ts +1 -1
- package/dist/types/src/server/react-server/getConfig.d.ts +2 -1
- package/dist/types/src/server/react-server/getMessages.d.ts +2 -0
- package/dist/types/test/react-server/index.test.d.ts +1 -0
- package/dist/types/test/react-server/useTranslations.test.d.ts +1 -0
- package/dist/types/test/react-server/utils.d.ts +2 -0
- package/package.json +6 -6
- package/dist/esm/react-server/getBaseTranslator.js +0 -1
- package/dist/esm/react-server/useHook.js +0 -1
- package/dist/production/react-server/getBaseTranslator.js +0 -1
- package/dist/production/react-server/useHook.js +0 -1
- package/dist/types/src/react-server/useHook.d.ts +0 -1
|
@@ -4,16 +4,16 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
4
4
|
|
|
5
5
|
var React = require('react');
|
|
6
6
|
var core = require('use-intl/core');
|
|
7
|
-
var getConfig = require('../server/react-server/getConfig.js');
|
|
8
7
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
function getMessageFormatCacheImpl() {
|
|
9
|
+
return new Map();
|
|
10
|
+
}
|
|
11
|
+
const getMessageFormatCache = React.cache(getMessageFormatCacheImpl);
|
|
12
|
+
function getTranslatorImpl(config, namespace) {
|
|
12
13
|
return core.createTranslator({
|
|
13
14
|
...config,
|
|
14
15
|
messageFormatCache: getMessageFormatCache(),
|
|
15
|
-
namespace
|
|
16
|
-
messages: config.messages
|
|
16
|
+
namespace
|
|
17
17
|
});
|
|
18
18
|
}
|
|
19
19
|
var getBaseTranslator = React.cache(getTranslatorImpl);
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
5
|
var React = require('react');
|
|
6
|
+
var getConfig = require('../server/react-server/getConfig.js');
|
|
7
|
+
var useLocale = require('./useLocale.js');
|
|
6
8
|
|
|
7
9
|
function useHook(hookName, promise) {
|
|
8
10
|
try {
|
|
@@ -17,5 +19,9 @@ function useHook(hookName, promise) {
|
|
|
17
19
|
}
|
|
18
20
|
}
|
|
19
21
|
}
|
|
22
|
+
function useConfig(hookName) {
|
|
23
|
+
const locale = useLocale.default();
|
|
24
|
+
return useHook(hookName, getConfig.default(locale));
|
|
25
|
+
}
|
|
20
26
|
|
|
21
|
-
exports.default =
|
|
27
|
+
exports.default = useConfig;
|
|
@@ -2,18 +2,17 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var
|
|
6
|
-
var
|
|
7
|
-
var
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var core = require('use-intl/core');
|
|
7
|
+
var useConfig = require('./useConfig.js');
|
|
8
8
|
|
|
9
|
+
const createFormatterCached = React.cache(core.createFormatter);
|
|
9
10
|
function useFormatter() {
|
|
10
11
|
for (var _len = arguments.length, _ref = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
11
12
|
_ref[_key] = arguments[_key];
|
|
12
13
|
}
|
|
13
|
-
const
|
|
14
|
-
return
|
|
15
|
-
locale
|
|
16
|
-
}));
|
|
14
|
+
const config = useConfig.default('useFormatter');
|
|
15
|
+
return createFormatterCached(config);
|
|
17
16
|
}
|
|
18
17
|
|
|
19
18
|
exports.default = useFormatter;
|
|
@@ -3,17 +3,14 @@
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
5
|
var getMessages = require('../server/react-server/getMessages.js');
|
|
6
|
-
var
|
|
7
|
-
var useLocale = require('./useLocale.js');
|
|
6
|
+
var useConfig = require('./useConfig.js');
|
|
8
7
|
|
|
9
8
|
function useMessages() {
|
|
10
9
|
for (var _len = arguments.length, _ref = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
11
10
|
_ref[_key] = arguments[_key];
|
|
12
11
|
}
|
|
13
|
-
const
|
|
14
|
-
return
|
|
15
|
-
locale
|
|
16
|
-
}));
|
|
12
|
+
const config = useConfig.default('useMessages');
|
|
13
|
+
return getMessages.getMessagesFromConfig(config);
|
|
17
14
|
}
|
|
18
15
|
|
|
19
16
|
exports.default = useMessages;
|
|
@@ -2,9 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var
|
|
6
|
-
var useHook = require('./useHook.js');
|
|
7
|
-
var useLocale = require('./useLocale.js');
|
|
5
|
+
var useConfig = require('./useConfig.js');
|
|
8
6
|
|
|
9
7
|
function useNow() {
|
|
10
8
|
for (var _len = arguments.length, _ref = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
@@ -14,10 +12,8 @@ function useNow() {
|
|
|
14
12
|
if ((options === null || options === void 0 ? void 0 : options.updateInterval) != null) {
|
|
15
13
|
console.error("`useNow` doesn't support the `updateInterval` option in Server Components, the value will be ignored. If you need the value to update, you can convert the component to a Client Component.");
|
|
16
14
|
}
|
|
17
|
-
const
|
|
18
|
-
return
|
|
19
|
-
locale
|
|
20
|
-
}));
|
|
15
|
+
const config = useConfig.default('useNow');
|
|
16
|
+
return config.now;
|
|
21
17
|
}
|
|
22
18
|
|
|
23
19
|
exports.default = useNow;
|
|
@@ -2,18 +2,14 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var
|
|
6
|
-
var useHook = require('./useHook.js');
|
|
7
|
-
var useLocale = require('./useLocale.js');
|
|
5
|
+
var useConfig = require('./useConfig.js');
|
|
8
6
|
|
|
9
7
|
function useTimeZone() {
|
|
10
8
|
for (var _len = arguments.length, _ref = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
11
9
|
_ref[_key] = arguments[_key];
|
|
12
10
|
}
|
|
13
|
-
const
|
|
14
|
-
return
|
|
15
|
-
locale
|
|
16
|
-
}));
|
|
11
|
+
const config = useConfig.default('useTimeZone');
|
|
12
|
+
return config.timeZone;
|
|
17
13
|
}
|
|
18
14
|
|
|
19
15
|
exports.default = useTimeZone;
|
|
@@ -2,18 +2,16 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var
|
|
6
|
-
var
|
|
7
|
-
var useLocale = require('./useLocale.js');
|
|
5
|
+
var getTranslator = require('./getTranslator.js');
|
|
6
|
+
var useConfig = require('./useConfig.js');
|
|
8
7
|
|
|
9
8
|
function useTranslations() {
|
|
10
9
|
for (var _len = arguments.length, _ref = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
11
10
|
_ref[_key] = arguments[_key];
|
|
12
11
|
}
|
|
13
12
|
let [namespace] = _ref;
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
return result;
|
|
13
|
+
const config = useConfig.default('useTranslations');
|
|
14
|
+
return getTranslator.default(config, namespace);
|
|
17
15
|
}
|
|
18
16
|
|
|
19
17
|
exports.default = useTranslations;
|
|
@@ -6,7 +6,7 @@ var headers = require('next/headers');
|
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var constants = require('../../shared/constants.js');
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
function getLocaleFromHeaderImpl() {
|
|
10
10
|
let locale;
|
|
11
11
|
try {
|
|
12
12
|
locale = headers.headers().get(constants.HEADER_LOCALE_NAME);
|
|
@@ -23,15 +23,17 @@ const getLocaleFromHeader = React.cache(() => {
|
|
|
23
23
|
throw new Error("Unable to find `next-intl` locale because the middleware didn't run on this request. See https://next-intl-docs.vercel.app/docs/routing/middleware#unable-to-find-locale");
|
|
24
24
|
}
|
|
25
25
|
return locale;
|
|
26
|
-
}
|
|
26
|
+
}
|
|
27
|
+
const getLocaleFromHeader = React.cache(getLocaleFromHeaderImpl);
|
|
27
28
|
|
|
28
29
|
// Workaround until `createServerContext` is available
|
|
29
|
-
|
|
30
|
+
function getCacheImpl() {
|
|
30
31
|
const value = {
|
|
31
32
|
locale: undefined
|
|
32
33
|
};
|
|
33
34
|
return value;
|
|
34
|
-
}
|
|
35
|
+
}
|
|
36
|
+
const getCache = React.cache(getCacheImpl);
|
|
35
37
|
function setRequestLocale(locale) {
|
|
36
38
|
getCache().locale = locale;
|
|
37
39
|
}
|
|
@@ -11,12 +11,18 @@ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
|
11
11
|
var getRuntimeConfig__default = /*#__PURE__*/_interopDefault(getRuntimeConfig);
|
|
12
12
|
|
|
13
13
|
// Make sure `now` is consistent across the request in case none was configured
|
|
14
|
-
|
|
14
|
+
function getDefaultNowImpl() {
|
|
15
|
+
return new Date();
|
|
16
|
+
}
|
|
17
|
+
const getDefaultNow = React.cache(getDefaultNowImpl);
|
|
15
18
|
|
|
16
19
|
// This is automatically inherited by `NextIntlClientProvider` if
|
|
17
20
|
// the component is rendered from a Server Component
|
|
18
|
-
|
|
19
|
-
|
|
21
|
+
function getDefaultTimeZoneImpl() {
|
|
22
|
+
return Intl.DateTimeFormat().resolvedOptions().timeZone;
|
|
23
|
+
}
|
|
24
|
+
const getDefaultTimeZone = React.cache(getDefaultTimeZoneImpl);
|
|
25
|
+
async function receiveRuntimeConfigImpl(locale, getConfig) {
|
|
20
26
|
var _result, _result2;
|
|
21
27
|
let result = getConfig === null || getConfig === void 0 ? void 0 : getConfig({
|
|
22
28
|
locale
|
|
@@ -29,15 +35,17 @@ const receiveRuntimeConfig = React.cache(async (locale, getConfig) => {
|
|
|
29
35
|
now: ((_result = result) === null || _result === void 0 ? void 0 : _result.now) || getDefaultNow(),
|
|
30
36
|
timeZone: ((_result2 = result) === null || _result2 === void 0 ? void 0 : _result2.timeZone) || getDefaultTimeZone()
|
|
31
37
|
};
|
|
32
|
-
}
|
|
33
|
-
const
|
|
38
|
+
}
|
|
39
|
+
const receiveRuntimeConfig = React.cache(receiveRuntimeConfigImpl);
|
|
40
|
+
async function getConfigImpl(locale) {
|
|
34
41
|
const runtimeConfig = await receiveRuntimeConfig(locale, getRuntimeConfig__default.default);
|
|
35
42
|
const opts = {
|
|
36
43
|
...runtimeConfig,
|
|
37
44
|
locale
|
|
38
45
|
};
|
|
39
46
|
return core.initializeConfig(opts);
|
|
40
|
-
}
|
|
47
|
+
}
|
|
48
|
+
const getConfig = React.cache(getConfigImpl);
|
|
41
49
|
var getConfig$1 = getConfig;
|
|
42
50
|
|
|
43
51
|
exports.default = getConfig$1;
|
|
@@ -7,10 +7,11 @@ var core = require('use-intl/core');
|
|
|
7
7
|
var getConfig = require('./getConfig.js');
|
|
8
8
|
var resolveLocaleArg = require('./resolveLocaleArg.js');
|
|
9
9
|
|
|
10
|
-
|
|
10
|
+
async function getFormatterCachedImpl(locale) {
|
|
11
11
|
const config = await getConfig.default(locale);
|
|
12
12
|
return core.createFormatter(config);
|
|
13
|
-
}
|
|
13
|
+
}
|
|
14
|
+
const getFormatterCached = React.cache(getFormatterCachedImpl);
|
|
14
15
|
|
|
15
16
|
/**
|
|
16
17
|
* Returns a formatter based on the given locale.
|
|
@@ -20,7 +21,7 @@ const getFormatterImpl = React.cache(async locale => {
|
|
|
20
21
|
*/
|
|
21
22
|
async function getFormatter(opts) {
|
|
22
23
|
const locale = await resolveLocaleArg.default(opts);
|
|
23
|
-
return
|
|
24
|
+
return getFormatterCached(locale);
|
|
24
25
|
}
|
|
25
26
|
|
|
26
27
|
exports.default = getFormatter;
|
|
@@ -6,16 +6,21 @@ var React = require('react');
|
|
|
6
6
|
var getConfig = require('./getConfig.js');
|
|
7
7
|
var resolveLocaleArg = require('./resolveLocaleArg.js');
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
const config = await getConfig.default(locale);
|
|
9
|
+
function getMessagesFromConfig(config) {
|
|
11
10
|
if (!config.messages) {
|
|
12
11
|
throw new Error('No messages found. Have you configured them correctly? See https://next-intl-docs.vercel.app/docs/configuration#messages');
|
|
13
12
|
}
|
|
14
13
|
return config.messages;
|
|
15
|
-
}
|
|
14
|
+
}
|
|
15
|
+
async function getMessagesCachedImpl(locale) {
|
|
16
|
+
const config = await getConfig.default(locale);
|
|
17
|
+
return getMessagesFromConfig(config);
|
|
18
|
+
}
|
|
19
|
+
const getMessagesCached = React.cache(getMessagesCachedImpl);
|
|
16
20
|
async function getMessages(opts) {
|
|
17
21
|
const locale = await resolveLocaleArg.default(opts);
|
|
18
|
-
return
|
|
22
|
+
return getMessagesCached(locale);
|
|
19
23
|
}
|
|
20
24
|
|
|
21
25
|
exports.default = getMessages;
|
|
26
|
+
exports.getMessagesFromConfig = getMessagesFromConfig;
|
|
@@ -6,13 +6,14 @@ var React = require('react');
|
|
|
6
6
|
var getConfig = require('./getConfig.js');
|
|
7
7
|
var resolveLocaleArg = require('./resolveLocaleArg.js');
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
async function getNowCachedImpl(locale) {
|
|
10
10
|
const config = await getConfig.default(locale);
|
|
11
11
|
return config.now;
|
|
12
|
-
}
|
|
12
|
+
}
|
|
13
|
+
const getNowCached = React.cache(getNowCachedImpl);
|
|
13
14
|
async function getNow(opts) {
|
|
14
15
|
const locale = await resolveLocaleArg.default(opts);
|
|
15
|
-
return
|
|
16
|
+
return getNowCached(locale);
|
|
16
17
|
}
|
|
17
18
|
|
|
18
19
|
exports.default = getNow;
|
|
@@ -6,13 +6,14 @@ var React = require('react');
|
|
|
6
6
|
var getConfig = require('./getConfig.js');
|
|
7
7
|
var resolveLocaleArg = require('./resolveLocaleArg.js');
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
async function getTimeZoneCachedImpl(locale) {
|
|
10
10
|
const config = await getConfig.default(locale);
|
|
11
11
|
return config.timeZone;
|
|
12
|
-
}
|
|
12
|
+
}
|
|
13
|
+
const getTimeZoneCached = React.cache(getTimeZoneCachedImpl);
|
|
13
14
|
async function getTimeZone(opts) {
|
|
14
15
|
const locale = await resolveLocaleArg.default(opts);
|
|
15
|
-
return
|
|
16
|
+
return getTimeZoneCached(locale);
|
|
16
17
|
}
|
|
17
18
|
|
|
18
19
|
exports.default = getTimeZone;
|
|
@@ -4,10 +4,10 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
4
4
|
|
|
5
5
|
var getRequestConfig = require('./server/react-server/getRequestConfig.js');
|
|
6
6
|
var getFormatter = require('./server/react-server/getFormatter.js');
|
|
7
|
+
var getMessages = require('./server/react-server/getMessages.js');
|
|
7
8
|
var getNow = require('./server/react-server/getNow.js');
|
|
8
9
|
var getTimeZone = require('./server/react-server/getTimeZone.js');
|
|
9
10
|
var getTranslations = require('./server/react-server/getTranslations.js');
|
|
10
|
-
var getMessages = require('./server/react-server/getMessages.js');
|
|
11
11
|
var getLocale = require('./server/react-server/getLocale.js');
|
|
12
12
|
var RequestLocale = require('./server/react-server/RequestLocale.js');
|
|
13
13
|
|
|
@@ -15,9 +15,9 @@ var RequestLocale = require('./server/react-server/RequestLocale.js');
|
|
|
15
15
|
|
|
16
16
|
exports.getRequestConfig = getRequestConfig.default;
|
|
17
17
|
exports.getFormatter = getFormatter.default;
|
|
18
|
+
exports.getMessages = getMessages.default;
|
|
18
19
|
exports.getNow = getNow.default;
|
|
19
20
|
exports.getTimeZone = getTimeZone.default;
|
|
20
21
|
exports.getTranslations = getTranslations.default;
|
|
21
|
-
exports.getMessages = getMessages.default;
|
|
22
22
|
exports.getLocale = getLocale.default;
|
|
23
23
|
exports.unstable_setRequestLocale = RequestLocale.setRequestLocale;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{cache as e}from"react";import{createTranslator as r}from"use-intl/core";const t=e((function(){return new Map}));var a=e((function(e,a){return r({...e,messageFormatCache:t(),namespace:a})}));export{a as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{use as e}from"react";import r from"../server/react-server/getConfig.js";import n from"./useLocale.js";function t(t){const o=n();return function(r,n){try{return e(n)}catch(e){throw e instanceof TypeError&&e.message.includes("Cannot read properties of null (reading 'use')")?new Error("`".concat(r,"` is not callable within an async component. Please refer to https://next-intl-docs.vercel.app/docs/environments/server-client-components#async-components"),{cause:e}):e}}(t,r(o))}export{t as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import r
|
|
1
|
+
import{cache as r}from"react";import{createFormatter as o}from"use-intl/core";import t from"./useConfig.js";const e=r(o);function n(){for(var r=arguments.length,o=new Array(r),n=0;n<r;n++)o[n]=arguments[n];const f=t("useFormatter");return e(f)}export{n as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import e
|
|
1
|
+
import{getMessagesFromConfig as e}from"../server/react-server/getMessages.js";import r from"./useConfig.js";function s(){for(var s=arguments.length,t=new Array(s),o=0;o<s;o++)t[o]=arguments[o];const a=r("useMessages");return e(a)}export{s as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import e from"
|
|
1
|
+
import e from"./useConfig.js";function o(){for(var o=arguments.length,n=new Array(o),t=0;t<o;t++)n[t]=arguments[t];let[r]=n;null!=(null==r?void 0:r.updateInterval)&&console.error("`useNow` doesn't support the `updateInterval` option in Server Components, the value will be ignored. If you need the value to update, you can convert the component to a Client Component.");return e("useNow").now}export{o as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import e from"
|
|
1
|
+
import e from"./useConfig.js";function r(){for(var r=arguments.length,n=new Array(r),o=0;o<r;o++)n[o]=arguments[o];return e("useTimeZone").timeZone}export{r as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import r from"./
|
|
1
|
+
import r from"./getTranslator.js";import t from"./useConfig.js";function o(){for(var o=arguments.length,n=new Array(o),e=0;e<o;e++)n[e]=arguments[e];let[s]=n;const a=t("useTranslations");return r(a,s)}export{o as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{headers as e}from"next/headers";import{cache as t}from"react";import{HEADER_LOCALE_NAME as n}from"../../shared/constants.js";const r=t((()
|
|
1
|
+
import{headers as e}from"next/headers";import{cache as t}from"react";import{HEADER_LOCALE_NAME as n}from"../../shared/constants.js";const r=t((function(){let t;try{t=e().get(n)}catch(e){throw e instanceof Error&&"DYNAMIC_SERVER_USAGE"===e.digest?new Error("Usage of next-intl APIs in Server Components currently opts into dynamic rendering. This limitation will eventually be lifted, but as a stopgap solution, you can use the `unstable_setRequestLocale` API to enable static rendering, see https://next-intl-docs.vercel.app/docs/getting-started/app-router-server-components#static-rendering",{cause:e}):e}if(!t)throw new Error("Unable to find `next-intl` locale because the middleware didn't run on this request. See https://next-intl-docs.vercel.app/docs/routing/middleware#unable-to-find-locale");return t}));const o=t((function(){return{locale:void 0}}));function i(e){o().locale=e}function s(){return o().locale||r()}export{s as getRequestLocale,i as setRequestLocale};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cache as
|
|
1
|
+
import{cache as n}from"react";import{initializeConfig as o}from"use-intl/core";import t from"next-intl/config";const e=n((function(){return new Date}));const i=n((function(){return Intl.DateTimeFormat().resolvedOptions().timeZone}));const r=n((async function(n,o){var t,r;let a=null==o?void 0:o({locale:n});return a instanceof Promise&&(a=await a),{...a,now:(null===(t=a)||void 0===t?void 0:t.now)||e(),timeZone:(null===(r=a)||void 0===r?void 0:r.timeZone)||i()}}));var a=n((async function(n){const e={...await r(n,t),locale:n};return o(e)}));export{a as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cache as o}from"react";import{createFormatter as
|
|
1
|
+
import{cache as o}from"react";import{createFormatter as t}from"use-intl/core";import r from"./getConfig.js";import n from"./resolveLocaleArg.js";const e=o((async function(o){const n=await r(o);return t(n)}));async function a(o){const t=await n(o);return e(t)}export{a as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cache as e}from"react";import o from"./getConfig.js";import
|
|
1
|
+
import{cache as e}from"react";import o from"./getConfig.js";import r from"./resolveLocaleArg.js";function t(e){if(!e.messages)throw new Error("No messages found. Have you configured them correctly? See https://next-intl-docs.vercel.app/docs/configuration#messages");return e.messages}const s=e((async function(e){return t(await o(e))}));async function n(e){const o=await r(e);return s(o)}export{n as default,t as getMessagesFromConfig};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cache as o}from"react";import t from"./getConfig.js";import r from"./resolveLocaleArg.js";const
|
|
1
|
+
import{cache as o}from"react";import t from"./getConfig.js";import r from"./resolveLocaleArg.js";const n=o((async function(o){return(await t(o)).now}));async function a(o){const t=await r(o);return n(t)}export{a as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{cache as
|
|
1
|
+
import{cache as t}from"react";import o from"./getConfig.js";import r from"./resolveLocaleArg.js";const n=t((async function(t){return(await o(t)).timeZone}));async function e(t){const o=await r(t);return n(o)}export{e as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export{default as getRequestConfig}from"./server/react-server/getRequestConfig.js";export{default as getFormatter}from"./server/react-server/getFormatter.js";export{default as
|
|
1
|
+
export{default as getRequestConfig}from"./server/react-server/getRequestConfig.js";export{default as getFormatter}from"./server/react-server/getFormatter.js";export{default as getMessages}from"./server/react-server/getMessages.js";export{default as getNow}from"./server/react-server/getNow.js";export{default as getTimeZone}from"./server/react-server/getTimeZone.js";export{default as getTranslations}from"./server/react-server/getTranslations.js";export{default as getLocale}from"./server/react-server/getLocale.js";export{setRequestLocale as unstable_setRequestLocale}from"./server/react-server/RequestLocale.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("use-intl/core");const t=e.cache((function(){return new Map}));var a=e.cache((function(e,a){return r.createTranslator({...e,messageFormatCache:t(),namespace:a})}));exports.default=a;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("../server/react-server/getConfig.js"),t=require("./useLocale.js");exports.default=function(n){const s=t.default();return function(r,t){try{return e.use(t)}catch(e){throw e instanceof TypeError&&e.message.includes("Cannot read properties of null (reading 'use')")?new Error("`".concat(r,"` is not callable within an async component. Please refer to https://next-intl-docs.vercel.app/docs/environments/server-client-components#async-components"),{cause:e}):e}}(n,r.default(s))};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("use-intl/core"),t=require("./useConfig.js");const u=e.cache(r.createFormatter);exports.default=function(){for(var e=arguments.length,r=new Array(e),o=0;o<e;o++)r[o]=arguments[o];const a=t.default("useFormatter");return u(a)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../server/react-server/getMessages.js"),r=require("./
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../server/react-server/getMessages.js"),r=require("./useConfig.js");exports.default=function(){for(var s=arguments.length,t=new Array(s),u=0;u<s;u++)t[u]=arguments[u];const a=r.default("useMessages");return e.getMessagesFromConfig(a)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./useConfig.js");exports.default=function(){for(var t=arguments.length,o=new Array(t),n=0;n<t;n++)o[n]=arguments[n];let[r]=o;return null!=(null==r?void 0:r.updateInterval)&&console.error("`useNow` doesn't support the `updateInterval` option in Server Components, the value will be ignored. If you need the value to update, you can convert the component to a Client Component."),e.default("useNow").now};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./useConfig.js");exports.default=function(){for(var r=arguments.length,t=new Array(r),u=0;u<r;u++)t[u]=arguments[u];return e.default("useTimeZone").timeZone};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./getTranslator.js"),r=require("./useConfig.js");exports.default=function(){for(var t=arguments.length,s=new Array(t),u=0;u<t;u++)s[u]=arguments[u];let[a]=s;const n=r.default("useTranslations");return e.default(n,a)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("next/headers"),t=require("react"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("next/headers"),t=require("react"),n=require("../../shared/constants.js");const r=t.cache((function(){let t;try{t=e.headers().get(n.HEADER_LOCALE_NAME)}catch(e){throw e instanceof Error&&"DYNAMIC_SERVER_USAGE"===e.digest?new Error("Usage of next-intl APIs in Server Components currently opts into dynamic rendering. This limitation will eventually be lifted, but as a stopgap solution, you can use the `unstable_setRequestLocale` API to enable static rendering, see https://next-intl-docs.vercel.app/docs/getting-started/app-router-server-components#static-rendering",{cause:e}):e}if(!t)throw new Error("Unable to find `next-intl` locale because the middleware didn't run on this request. See https://next-intl-docs.vercel.app/docs/routing/middleware#unable-to-find-locale");return t}));const o=t.cache((function(){return{locale:void 0}}));exports.getRequestLocale=function(){return o().locale||r()},exports.setRequestLocale=function(e){o().locale=e};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),n=require("use-intl/core");function t(e){return e&&e.__esModule?e:{default:e}}var o=t(require("next-intl/config"));const i=e.cache((function(){return new Date}));const r=e.cache((function(){return Intl.DateTimeFormat().resolvedOptions().timeZone}));const c=e.cache((async function(e,n){var t,o;let c=null==n?void 0:n({locale:e});return c instanceof Promise&&(c=await c),{...c,now:(null===(t=c)||void 0===t?void 0:t.now)||i(),timeZone:(null===(o=c)||void 0===o?void 0:o.timeZone)||r()}}));var a=e.cache((async function(e){const t={...await c(e,o.default),locale:e};return n.initializeConfig(t)}));exports.default=a;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("use-intl/core"),t=require("./getConfig.js"),a=require("./resolveLocaleArg.js");const c=e.cache((async e
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("use-intl/core"),t=require("./getConfig.js"),a=require("./resolveLocaleArg.js");const c=e.cache((async function(e){const a=await t.default(e);return r.createFormatter(a)}));exports.default=async function(e){const r=await a.default(e);return c(r)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./getConfig.js"),s=require("./resolveLocaleArg.js");
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./getConfig.js"),s=require("./resolveLocaleArg.js");function t(e){if(!e.messages)throw new Error("No messages found. Have you configured them correctly? See https://next-intl-docs.vercel.app/docs/configuration#messages");return e.messages}const o=e.cache((async function(e){return t(await r.default(e))}));exports.default=async function(e){const r=await s.default(e);return o(r)},exports.getMessagesFromConfig=t;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./getConfig.js"),t=require("./resolveLocaleArg.js");const a=e.cache((async e
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("./getConfig.js"),t=require("./resolveLocaleArg.js");const a=e.cache((async function(e){return(await r.default(e)).now}));exports.default=async function(e){const r=await t.default(e);return a(r)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("./getConfig.js"),r=require("./resolveLocaleArg.js");const a=e.cache((async e
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("./getConfig.js"),r=require("./resolveLocaleArg.js");const a=e.cache((async function(e){return(await t.default(e)).timeZone}));exports.default=async function(e){const t=await r.default(e);return a(t)};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./server/react-server/getRequestConfig.js"),r=require("./server/react-server/getFormatter.js"),t=require("./server/react-server/
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./server/react-server/getRequestConfig.js"),r=require("./server/react-server/getFormatter.js"),t=require("./server/react-server/getMessages.js"),s=require("./server/react-server/getNow.js"),a=require("./server/react-server/getTimeZone.js"),o=require("./server/react-server/getTranslations.js"),u=require("./server/react-server/getLocale.js"),g=require("./server/react-server/RequestLocale.js");exports.getRequestConfig=e.default,exports.getFormatter=r.default,exports.getMessages=t.default,exports.getNow=s.default,exports.getTimeZone=a.default,exports.getTranslations=o.default,exports.getLocale=u.default,exports.unstable_setRequestLocale=g.setRequestLocale;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from 'react';
|
|
2
|
+
export { default } from 'react';
|
|
3
|
+
export declare function use(promise: Promise<unknown> & {
|
|
4
|
+
value?: unknown;
|
|
5
|
+
}): {};
|
|
6
|
+
export declare function cache(fn: (...args: Array<unknown>) => unknown): (...args: Array<unknown>) => unknown;
|
|
7
|
+
export declare namespace cache {
|
|
8
|
+
var reset: () => void;
|
|
9
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ReactElement, ReactNodeArray } from 'react';
|
|
2
|
-
import { Formats, TranslationValues, RichTranslationValues, MessageKeys, NamespaceKeys, NestedKeyOf, NestedValueOf, MarkupTranslationValues } from 'use-intl/core';
|
|
3
|
-
declare function getTranslatorImpl<NestedKey extends NamespaceKeys<IntlMessages, NestedKeyOf<IntlMessages>> = never>(
|
|
2
|
+
import { Formats, TranslationValues, RichTranslationValues, MessageKeys, NamespaceKeys, NestedKeyOf, NestedValueOf, createTranslator, MarkupTranslationValues } from 'use-intl/core';
|
|
3
|
+
declare function getTranslatorImpl<NestedKey extends NamespaceKeys<IntlMessages, NestedKeyOf<IntlMessages>> = never>(config: Parameters<typeof createTranslator>[0], namespace?: NestedKey): {
|
|
4
4
|
<TargetKey extends MessageKeys<NestedValueOf<{
|
|
5
5
|
'!': IntlMessages;
|
|
6
6
|
}, [
|
|
@@ -37,6 +37,6 @@ declare function getTranslatorImpl<NestedKey extends NamespaceKeys<IntlMessages,
|
|
|
37
37
|
}, [
|
|
38
38
|
NestedKey
|
|
39
39
|
] extends [never] ? '!' : `!.${NestedKey}`>>>>(key: TargetKey): any;
|
|
40
|
-
}
|
|
40
|
+
};
|
|
41
41
|
declare const _default: typeof getTranslatorImpl;
|
|
42
42
|
export default _default;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import type
|
|
1
|
+
import { type useFormatter as useFormatterType } from 'use-intl';
|
|
2
2
|
export default function useFormatter(...[]: Parameters<typeof useFormatterType>): ReturnType<typeof useFormatterType>;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { IntlConfig } from 'use-intl/core';
|
|
2
|
-
declare
|
|
2
|
+
declare function getConfigImpl(locale: string): Promise<IntlConfig & {
|
|
3
3
|
getMessageFallback: NonNullable<IntlConfig['getMessageFallback']>;
|
|
4
4
|
now: NonNullable<IntlConfig['now']>;
|
|
5
5
|
onError: NonNullable<IntlConfig['onError']>;
|
|
6
6
|
timeZone: NonNullable<IntlConfig['timeZone']>;
|
|
7
7
|
}>;
|
|
8
|
+
declare const getConfig: typeof getConfigImpl;
|
|
8
9
|
export default getConfig;
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import type { AbstractIntlMessages } from 'use-intl';
|
|
2
|
+
import getConfig from './getConfig';
|
|
3
|
+
export declare function getMessagesFromConfig(config: Awaited<ReturnType<typeof getConfig>>): AbstractIntlMessages;
|
|
2
4
|
export default function getMessages(opts?: {
|
|
3
5
|
locale?: string;
|
|
4
6
|
}): Promise<AbstractIntlMessages>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "next-intl",
|
|
3
|
-
"version": "3.3.
|
|
3
|
+
"version": "3.3.3",
|
|
4
4
|
"sideEffects": false,
|
|
5
5
|
"author": "Jan Amann <jan@amann.work>",
|
|
6
6
|
"funding": [
|
|
@@ -80,7 +80,7 @@
|
|
|
80
80
|
"dependencies": {
|
|
81
81
|
"@formatjs/intl-localematcher": "^0.2.32",
|
|
82
82
|
"negotiator": "^0.6.3",
|
|
83
|
-
"use-intl": "^3.3.
|
|
83
|
+
"use-intl": "^3.3.3"
|
|
84
84
|
},
|
|
85
85
|
"peerDependencies": {
|
|
86
86
|
"next": "^10.0.0 || ^11.0.0 || ^12.0.0 || ^13.0.0 || ^14.0.0",
|
|
@@ -97,7 +97,7 @@
|
|
|
97
97
|
"eslint": "^8.54.0",
|
|
98
98
|
"eslint-config-molindo": "^7.0.0",
|
|
99
99
|
"eslint-plugin-deprecation": "^1.4.1",
|
|
100
|
-
"next": "^14.0.
|
|
100
|
+
"next": "^14.0.4",
|
|
101
101
|
"path-to-regexp": "^6.2.1",
|
|
102
102
|
"react": "^18.2.0",
|
|
103
103
|
"react-dom": "^18.2.0",
|
|
@@ -114,7 +114,7 @@
|
|
|
114
114
|
},
|
|
115
115
|
{
|
|
116
116
|
"path": "dist/production/index.react-server.js",
|
|
117
|
-
"limit": "
|
|
117
|
+
"limit": "14.15 KB"
|
|
118
118
|
},
|
|
119
119
|
{
|
|
120
120
|
"path": "dist/production/navigation.react-client.js",
|
|
@@ -130,12 +130,12 @@
|
|
|
130
130
|
},
|
|
131
131
|
{
|
|
132
132
|
"path": "dist/production/server.react-server.js",
|
|
133
|
-
"limit": "12.
|
|
133
|
+
"limit": "12.82 KB"
|
|
134
134
|
},
|
|
135
135
|
{
|
|
136
136
|
"path": "dist/production/middleware.js",
|
|
137
137
|
"limit": "5.8 KB"
|
|
138
138
|
}
|
|
139
139
|
],
|
|
140
|
-
"gitHead": "
|
|
140
|
+
"gitHead": "b9e17a95ecbcfc00d6a69e9bd5b622a371534d29"
|
|
141
141
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{cache as e}from"react";import{createTranslator as r}from"use-intl/core";import s from"../server/react-server/getConfig.js";const a=e((()=>new Map));var t=e((async function(e,t){const o=await s(e);return r({...o,messageFormatCache:a(),namespace:t,messages:o.messages})}));export{t as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{use as e}from"react";function n(n,t){try{return e(t)}catch(e){throw e instanceof TypeError&&e.message.includes("Cannot read properties of null (reading 'use')")?new Error("`".concat(n,"` is not callable within an async component. Please refer to https://next-intl-docs.vercel.app/docs/environments/server-client-components#async-components"),{cause:e}):e}}export{n as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=require("use-intl/core"),a=require("../server/react-server/getConfig.js");const s=e.cache((()=>new Map));var t=e.cache((async function(e,t){const c=await a.default(e);return r.createTranslator({...c,messageFormatCache:s(),namespace:t,messages:c.messages})}));exports.default=t;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react");exports.default=function(n,r){try{return e.use(r)}catch(e){throw e instanceof TypeError&&e.message.includes("Cannot read properties of null (reading 'use')")?new Error("`".concat(n,"` is not callable within an async component. Please refer to https://next-intl-docs.vercel.app/docs/environments/server-client-components#async-components"),{cause:e}):e}};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export default function useHook<Value>(hookName: string, promise: Promise<Value>): Value;
|