next-intl 2.14.1 → 2.15.0-beta.2
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/config.js +3 -0
- package/dist/client/index.d.ts +6 -0
- package/dist/client/next-intl.esm.js +45 -0
- package/dist/client/next-intl.esm.js.map +1 -0
- package/dist/client/next-intl.esm2.js +18 -0
- package/dist/client/next-intl.esm2.js.map +1 -0
- package/dist/link/next-intl.esm.js +37 -0
- package/dist/link/next-intl.esm.js.map +1 -0
- package/dist/link/react-server/Link.d.ts +7 -0
- package/dist/link/react-server/index.d.ts +1 -0
- package/dist/middleware/NextIntlMiddlewareConfig.d.ts +18 -0
- package/dist/next-intl.cjs.development.js +216 -1
- package/dist/next-intl.cjs.development.js.map +1 -1
- package/dist/next-intl.cjs.production.min.js +1 -1
- package/dist/next-intl.cjs.production.min.js.map +1 -1
- package/dist/next-intl.esm.js +4 -1
- package/dist/next-intl.esm.js.map +1 -1
- package/dist/react-client/Link.d.ts +4 -0
- package/dist/react-client/index.d.ts +5 -0
- package/dist/react-client/next-intl.esm.js +21 -0
- package/dist/react-client/next-intl.esm.js.map +1 -0
- package/dist/react-client/next-intl.esm2.js +15 -0
- package/dist/react-client/next-intl.esm2.js.map +1 -0
- package/dist/react-client/next-intl.esm3.js +18 -0
- package/dist/react-client/next-intl.esm3.js.map +1 -0
- package/dist/react-client/useLocalizedRouter.d.ts +8 -0
- package/dist/react-server/Link.d.ts +4 -0
- package/dist/react-server/index.d.ts +11 -9
- package/dist/react-server/useFormatter.d.ts +2 -0
- package/dist/react-server/useHook.d.ts +1 -0
- package/dist/react-server/useIntl.d.ts +5 -0
- package/dist/react-server/useLocale.d.ts +2 -0
- package/dist/react-server/useNow.d.ts +2 -0
- package/dist/react-server/useTimeZone.d.ts +2 -0
- package/dist/react-server/useTranslations.d.ts +2 -0
- package/dist/server/createRequestConfig.d.ts +4 -0
- package/dist/server/getConfig.d.ts +23 -0
- package/dist/server/getFormatter.d.ts +6 -0
- package/dist/server/getIntl.d.ts +7 -0
- package/dist/server/getLocale.d.ts +2 -0
- package/dist/server/getNow.d.ts +2 -0
- package/dist/server/getRequestConfig.d.ts +10 -0
- package/dist/server/getTimeZone.d.ts +2 -0
- package/dist/server/getTranslations.d.ts +38 -0
- package/dist/server/index.d.ts +8 -0
- package/dist/server/redirect.d.ts +1 -0
- package/dist/shared/constants.d.ts +1 -0
- package/dist/shared/next-intl.esm2.js +55 -0
- package/dist/shared/next-intl.esm2.js.map +1 -0
- package/dist/shared/next-intl.esm3.js +49 -0
- package/dist/shared/next-intl.esm3.js.map +1 -0
- package/dist/shared/next-intl.esm4.js +6 -0
- package/dist/shared/next-intl.esm4.js.map +1 -0
- package/dist/src/client/index.d.ts +6 -0
- package/dist/src/client/index.js +6 -0
- package/dist/src/client/index.js.map +1 -1
- package/dist/src/link/react-server/Link.d.ts +7 -0
- package/dist/src/link/react-server/Link.js +8 -0
- package/dist/src/link/react-server/Link.js.map +1 -0
- package/dist/src/link/react-server/index.d.ts +1 -0
- package/dist/src/link/react-server/index.js +2 -0
- package/dist/src/link/react-server/index.js.map +1 -0
- package/dist/src/middleware/NextIntlMiddlewareConfig.d.ts +18 -0
- package/dist/src/middleware/middleware.js +50 -3
- package/dist/src/middleware/middleware.js.map +1 -1
- package/dist/src/react-client/Link.d.ts +4 -0
- package/dist/src/react-client/Link.js +19 -0
- package/dist/src/react-client/Link.js.map +1 -0
- package/dist/src/react-client/index.d.ts +5 -0
- package/dist/src/react-client/index.js +5 -0
- package/dist/src/react-client/index.js.map +1 -1
- package/dist/src/react-client/useLocalizedRouter.d.ts +8 -0
- package/dist/src/react-client/useLocalizedRouter.js +12 -0
- package/dist/src/react-client/useLocalizedRouter.js.map +1 -0
- package/dist/src/react-server/Link.d.ts +4 -0
- package/dist/src/react-server/Link.js +19 -0
- package/dist/src/react-server/Link.js.map +1 -0
- package/dist/src/react-server/index.d.ts +11 -9
- package/dist/src/react-server/index.js +14 -16
- package/dist/src/react-server/index.js.map +1 -1
- package/dist/src/react-server/useFormatter.d.ts +2 -0
- package/dist/src/react-server/useFormatter.js +8 -0
- package/dist/src/react-server/useFormatter.js.map +1 -0
- package/dist/src/react-server/useHook.d.ts +1 -0
- package/dist/src/react-server/useHook.js +24 -0
- package/dist/src/react-server/useHook.js.map +1 -0
- package/dist/src/react-server/useIntl.d.ts +5 -0
- package/dist/src/react-server/useIntl.js +11 -0
- package/dist/src/react-server/useIntl.js.map +1 -0
- package/dist/src/react-server/useLocale.d.ts +2 -0
- package/dist/src/react-server/useLocale.js +7 -0
- package/dist/src/react-server/useLocale.js.map +1 -0
- package/dist/src/react-server/useNow.d.ts +2 -0
- package/dist/src/react-server/useNow.js +9 -0
- package/dist/src/react-server/useNow.js.map +1 -0
- package/dist/src/react-server/useTimeZone.d.ts +2 -0
- package/dist/src/react-server/useTimeZone.js +8 -0
- package/dist/src/react-server/useTimeZone.js.map +1 -0
- package/dist/src/react-server/useTranslations.d.ts +2 -0
- package/dist/src/react-server/useTranslations.js +9 -0
- package/dist/src/react-server/useTranslations.js.map +1 -0
- package/dist/src/server/createRequestConfig.d.ts +4 -0
- package/dist/src/server/createRequestConfig.js +5 -0
- package/dist/src/server/createRequestConfig.js.map +1 -0
- package/dist/src/server/getConfig.d.ts +23 -0
- package/dist/src/server/getConfig.js +23 -0
- package/dist/src/server/getConfig.js.map +1 -0
- package/dist/src/server/getFormatter.d.ts +6 -0
- package/dist/src/server/getFormatter.js +9 -0
- package/dist/src/server/getFormatter.js.map +1 -0
- package/dist/src/server/getIntl.d.ts +7 -0
- package/dist/src/server/getIntl.js +15 -0
- package/dist/src/server/getIntl.js.map +1 -0
- package/dist/src/server/getLocale.d.ts +2 -0
- package/dist/src/server/getLocale.js +33 -0
- package/dist/src/server/getLocale.js.map +1 -0
- package/dist/src/server/getNow.d.ts +2 -0
- package/dist/src/server/getNow.js +8 -0
- package/dist/src/server/getNow.js.map +1 -0
- package/dist/src/server/getRequestConfig.d.ts +10 -0
- package/dist/src/server/getRequestConfig.js +7 -0
- package/dist/src/server/getRequestConfig.js.map +1 -0
- package/dist/src/server/getTimeZone.d.ts +2 -0
- package/dist/src/server/getTimeZone.js +8 -0
- package/dist/src/server/getTimeZone.js.map +1 -0
- package/dist/src/server/getTranslations.d.ts +38 -0
- package/dist/src/server/getTranslations.js +23 -0
- package/dist/src/server/getTranslations.js.map +1 -0
- package/dist/src/server/index.d.ts +8 -0
- package/dist/src/server/index.js +11 -3
- package/dist/src/server/index.js.map +1 -1
- package/dist/src/server/redirect.d.ts +1 -0
- package/dist/src/server/redirect.js +9 -0
- package/dist/src/server/redirect.js.map +1 -0
- package/dist/src/shared/constants.d.ts +1 -0
- package/dist/src/shared/constants.js +2 -0
- package/dist/src/shared/constants.js.map +1 -1
- package/package.json +16 -4
- package/plugin.d.ts +3 -0
- package/plugin.js +65 -0
- package/src/client/index.tsx +9 -0
- package/src/link/react-server/Link.tsx +12 -0
- package/src/link/react-server/index.tsx +1 -0
- package/src/middleware/NextIntlMiddlewareConfig.tsx +21 -0
- package/src/middleware/middleware.tsx +61 -3
- package/src/react-client/Link.tsx +24 -0
- package/src/react-client/index.tsx +8 -0
- package/src/react-client/useLocalizedRouter.tsx +17 -0
- package/src/react-server/Link.tsx +24 -0
- package/src/react-server/index.tsx +16 -17
- package/src/react-server/useFormatter.tsx +10 -0
- package/src/react-server/useHook.tsx +30 -0
- package/src/react-server/useIntl.tsx +15 -0
- package/src/react-server/useLocale.tsx +9 -0
- package/src/react-server/useNow.tsx +15 -0
- package/src/react-server/useTimeZone.tsx +10 -0
- package/src/react-server/useTranslations.tsx +13 -0
- package/src/server/createRequestConfig.tsx +9 -0
- package/src/server/getConfig.tsx +27 -0
- package/src/server/getFormatter.tsx +10 -0
- package/src/server/getIntl.tsx +20 -0
- package/src/server/getLocale.tsx +40 -0
- package/src/server/getNow.tsx +9 -0
- package/src/server/getRequestConfig.tsx +18 -0
- package/src/server/getTimeZone.tsx +9 -0
- package/src/server/getTranslations.tsx +102 -0
- package/src/server/index.tsx +13 -3
- package/src/server/redirect.tsx +10 -0
- package/src/shared/constants.tsx +3 -0
- package/withNextIntl.d.ts +5 -0
- package/withNextIntl.js +13 -0
package/config.js
ADDED
package/dist/client/index.d.ts
CHANGED
|
@@ -1,6 +1,12 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Client-only APIs available via `next-intl/client`.
|
|
3
3
|
*/
|
|
4
|
+
import usePathname from './usePathname';
|
|
5
|
+
import useRouter from './useRouter';
|
|
4
6
|
export { default as useRouter } from './useRouter';
|
|
5
7
|
export { default as usePathname } from './usePathname';
|
|
8
|
+
/** @deprecated Is called `usePathname` now. */
|
|
9
|
+
export declare const useUnlocalizedPathname: typeof usePathname;
|
|
10
|
+
/** @deprecated Is called `useRouter` now. */
|
|
11
|
+
export declare const useLocalizedRouter: typeof useRouter;
|
|
6
12
|
export { default as NextIntlClientProvider } from './NextIntlClientProvider';
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { extends as _extends } from '../_virtual/next-intl.esm.js';
|
|
2
|
+
import { useRouter as useRouter$1 } from 'next/navigation';
|
|
3
|
+
import { useMemo } from 'react';
|
|
4
|
+
import { localizeHref } from '../shared/next-intl.esm2.js';
|
|
5
|
+
import useClientLocale from './next-intl.esm2.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Returns a wrapped instance of `useRouter` from `next/navigation` that
|
|
9
|
+
* will automatically localize the `href` parameters it receives.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* 'use client';
|
|
14
|
+
*
|
|
15
|
+
* import {useRouter} from 'next-intl/client';
|
|
16
|
+
*
|
|
17
|
+
* const router = useRouter();
|
|
18
|
+
*
|
|
19
|
+
* // When the user is on `/en`, the router will navigate to `/en/about`
|
|
20
|
+
* router.push('/about');
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
function useRouter() {
|
|
24
|
+
var router = useRouter$1();
|
|
25
|
+
var locale = useClientLocale();
|
|
26
|
+
return useMemo(function () {
|
|
27
|
+
function localize(href) {
|
|
28
|
+
return localizeHref(href, locale, locale, window.location.pathname);
|
|
29
|
+
}
|
|
30
|
+
return _extends({}, router, {
|
|
31
|
+
push: function push(href) {
|
|
32
|
+
return router.push(localize(href));
|
|
33
|
+
},
|
|
34
|
+
replace: function replace(href) {
|
|
35
|
+
return router.replace(localize(href));
|
|
36
|
+
},
|
|
37
|
+
prefetch: function prefetch(href) {
|
|
38
|
+
return router.prefetch(localize(href));
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}, [locale, router]);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export { useRouter as default };
|
|
45
|
+
//# sourceMappingURL=next-intl.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"next-intl.esm.js","sources":["../../src/client/useRouter.tsx"],"sourcesContent":["import {useRouter as useNextRouter} from 'next/navigation';\nimport {useMemo} from 'react';\nimport {localizeHref} from '../shared/utils';\nimport useClientLocale from './useClientLocale';\n\n/**\n * Returns a wrapped instance of `useRouter` from `next/navigation` that\n * will automatically localize the `href` parameters it receives.\n *\n * @example\n * ```tsx\n * 'use client';\n *\n * import {useRouter} from 'next-intl/client';\n *\n * const router = useRouter();\n *\n * // When the user is on `/en`, the router will navigate to `/en/about`\n * router.push('/about');\n * ```\n */\nexport default function useRouter() {\n const router = useNextRouter();\n const locale = useClientLocale();\n\n return useMemo(() => {\n function localize(href: string) {\n return localizeHref(href, locale, locale, window.location.pathname);\n }\n\n return {\n ...router,\n push(href: string) {\n return router.push(localize(href));\n },\n replace(href: string) {\n return router.replace(localize(href));\n },\n prefetch(href: string) {\n return router.prefetch(localize(href));\n }\n };\n }, [locale, router]);\n}\n"],"names":["useRouter","router","useNextRouter","locale","useClientLocale","useMemo","localize","href","localizeHref","window","location","pathname","_extends","push","replace","prefetch"],"mappings":";;;;;;AAKA;;;;;;;;;;;;;;;AAeG;AACW,SAAUA,SAASA,GAAA;AAC/B,EAAA,IAAMC,MAAM,GAAGC,WAAa,EAAE,CAAA;AAC9B,EAAA,IAAMC,MAAM,GAAGC,eAAe,EAAE,CAAA;EAEhC,OAAOC,OAAO,CAAC,YAAK;IAClB,SAASC,QAAQA,CAACC,IAAY,EAAA;AAC5B,MAAA,OAAOC,YAAY,CAACD,IAAI,EAAEJ,MAAM,EAAEA,MAAM,EAAEM,MAAM,CAACC,QAAQ,CAACC,QAAQ,CAAC,CAAA;AACrE,KAAA;IAEA,OAAAC,QAAA,KACKX,MAAM,EAAA;MACTY,IAAI,EAAA,SAAAA,IAACN,CAAAA,IAAY,EAAA;QACf,OAAON,MAAM,CAACY,IAAI,CAACP,QAAQ,CAACC,IAAI,CAAC,CAAC,CAAA;OACnC;MACDO,OAAO,EAAA,SAAAA,OAACP,CAAAA,IAAY,EAAA;QAClB,OAAON,MAAM,CAACa,OAAO,CAACR,QAAQ,CAACC,IAAI,CAAC,CAAC,CAAA;OACtC;MACDQ,QAAQ,EAAA,SAAAA,QAACR,CAAAA,IAAY,EAAA;QACnB,OAAON,MAAM,CAACc,QAAQ,CAACT,QAAQ,CAACC,IAAI,CAAC,CAAC,CAAA;AACxC,OAAA;AAAC,KAAA,CAAA,CAAA;AAEL,GAAC,EAAE,CAACJ,MAAM,EAAEF,MAAM,CAAC,CAAC,CAAA;AACtB;;;;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useParams } from 'next/navigation';
|
|
2
|
+
import { useLocale } from 'use-intl';
|
|
3
|
+
import { LOCALE_SEGMENT_NAME } from '../shared/next-intl.esm4.js';
|
|
4
|
+
|
|
5
|
+
function useClientLocale() {
|
|
6
|
+
var locale;
|
|
7
|
+
var params = useParams();
|
|
8
|
+
if (params[LOCALE_SEGMENT_NAME]) {
|
|
9
|
+
locale = params[LOCALE_SEGMENT_NAME];
|
|
10
|
+
} else {
|
|
11
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks -- Reading from context conditionally is fine
|
|
12
|
+
locale = useLocale();
|
|
13
|
+
}
|
|
14
|
+
return locale;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export { useClientLocale as default };
|
|
18
|
+
//# sourceMappingURL=next-intl.esm2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"next-intl.esm2.js","sources":["../../src/client/useClientLocale.tsx"],"sourcesContent":["import {useParams} from 'next/navigation';\nimport {useLocale} from 'use-intl';\nimport {LOCALE_SEGMENT_NAME} from '../shared/constants';\n\nexport default function useClientLocale(): string {\n let locale;\n\n const params = useParams();\n if (params[LOCALE_SEGMENT_NAME]) {\n locale = params[LOCALE_SEGMENT_NAME];\n } else {\n // eslint-disable-next-line react-hooks/rules-of-hooks -- Reading from context conditionally is fine\n locale = useLocale();\n }\n\n return locale;\n}\n"],"names":["useClientLocale","locale","params","useParams","LOCALE_SEGMENT_NAME","useLocale"],"mappings":";;;;AAIc,SAAUA,eAAeA,GAAA;AACrC,EAAA,IAAIC,MAAM,CAAA;AAEV,EAAA,IAAMC,MAAM,GAAGC,SAAS,EAAE,CAAA;AAC1B,EAAA,IAAID,MAAM,CAACE,mBAAmB,CAAC,EAAE;AAC/BH,IAAAA,MAAM,GAAGC,MAAM,CAACE,mBAAmB,CAAC,CAAA;AACrC,GAAA,MAAM;AACL;IACAH,MAAM,GAAGI,SAAS,EAAE,CAAA;AACrB,GAAA;AAED,EAAA,OAAOJ,MAAM,CAAA;AACf;;;;"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose, extends as _extends } from '../_virtual/next-intl.esm.js';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import useClientLocale from '../client/next-intl.esm2.js';
|
|
4
|
+
import BaseLink from '../shared/next-intl.esm3.js';
|
|
5
|
+
|
|
6
|
+
var _excluded = ["locale"];
|
|
7
|
+
/**
|
|
8
|
+
* Wraps `next/link` and prefixes the `href` with the current locale if
|
|
9
|
+
* necessary.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```tsx
|
|
13
|
+
* import {Link} from 'next-intl';
|
|
14
|
+
*
|
|
15
|
+
* // When the user is on `/en`, the link will point to `/en/about`
|
|
16
|
+
* <Link href="/about">About</Link>
|
|
17
|
+
*
|
|
18
|
+
* // You can override the `locale` to switch to another language
|
|
19
|
+
* <Link href="/" locale="de">Switch to German</Link>
|
|
20
|
+
* ```
|
|
21
|
+
*
|
|
22
|
+
* Note that when a `locale` prop is passed to switch the locale, the `prefetch`
|
|
23
|
+
* prop is not supported. This is because Next.js would prefetch the page and
|
|
24
|
+
* the `set-cookie` response header would cause the locale cookie on the current
|
|
25
|
+
* page to be overwritten before the user even decides to change the locale.
|
|
26
|
+
*/
|
|
27
|
+
function Link(_ref) {
|
|
28
|
+
var locale = _ref.locale,
|
|
29
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded);
|
|
30
|
+
var defaultLocale = useClientLocale();
|
|
31
|
+
return React.createElement(BaseLink, _extends({
|
|
32
|
+
locale: locale || defaultLocale
|
|
33
|
+
}, rest));
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export { Link as default };
|
|
37
|
+
//# sourceMappingURL=next-intl.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"next-intl.esm.js","sources":["../../src/link/Link.tsx"],"sourcesContent":["import React, {ComponentProps} from 'react';\nimport useClientLocale from '../client/useClientLocale';\nimport BaseLink from '../shared/BaseLink';\n\ntype Props = Omit<ComponentProps<typeof BaseLink>, 'locale'> & {\n locale?: string;\n};\n\n/**\n * Wraps `next/link` and prefixes the `href` with the current locale if\n * necessary.\n *\n * @example\n * ```tsx\n * import {Link} from 'next-intl';\n *\n * // When the user is on `/en`, the link will point to `/en/about`\n * <Link href=\"/about\">About</Link>\n *\n * // You can override the `locale` to switch to another language\n * <Link href=\"/\" locale=\"de\">Switch to German</Link>\n * ```\n *\n * Note that when a `locale` prop is passed to switch the locale, the `prefetch`\n * prop is not supported. This is because Next.js would prefetch the page and\n * the `set-cookie` response header would cause the locale cookie on the current\n * page to be overwritten before the user even decides to change the locale.\n */\nexport default function Link({locale, ...rest}: Props) {\n const defaultLocale = useClientLocale();\n return <BaseLink locale={locale || defaultLocale} {...rest} />;\n}\n"],"names":["Link","_ref","locale","rest","_objectWithoutPropertiesLoose","_excluded","defaultLocale","useClientLocale","React","createElement","BaseLink","_extends"],"mappings":";;;;;;AAQA;;;;;;;;;;;;;;;;;;;AAmBG;AACW,SAAUA,IAAIA,CAAAC,IAAA,EAAyB;AAAA,EAAA,IAAvBC,MAAM,GAAAD,IAAA,CAANC,MAAM;AAAKC,IAAAA,IAAI,GAAAC,6BAAA,CAAAH,IAAA,EAAAI,SAAA,CAAA,CAAA;AAC3C,EAAA,IAAMC,aAAa,GAAGC,eAAe,EAAE,CAAA;AACvC,EAAA,OAAOC,KAAA,CAAAC,aAAA,CAACC,QAAQ,EAAAC,QAAA,CAAA;IAACT,MAAM,EAAEA,MAAM,IAAII,aAAAA;GAAmBH,EAAAA,IAAI,CAAA,CAAI,CAAA;AAChE;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './Link';
|
|
@@ -1,3 +1,17 @@
|
|
|
1
|
+
type RoutingConfigPrefix = {
|
|
2
|
+
type: 'prefix';
|
|
3
|
+
/** The default locale can be used without a prefix (e.g. `/about`). If you prefer to have a prefix for the default locale as well (e.g. `/en/about`), you can switch this option to `always`.
|
|
4
|
+
*/
|
|
5
|
+
prefix?: 'as-needed' | 'always';
|
|
6
|
+
};
|
|
7
|
+
type RoutingConfigDomain = {
|
|
8
|
+
type: 'domain';
|
|
9
|
+
/** Provide a list of mappings between domains and locales. Note that the `x-forwarded-host` or alternatively the `host` header will be used to determine the requested domain. */
|
|
10
|
+
domains: Array<{
|
|
11
|
+
domain: string;
|
|
12
|
+
locale: string;
|
|
13
|
+
}>;
|
|
14
|
+
};
|
|
1
15
|
type LocalePrefix = 'as-needed' | 'always';
|
|
2
16
|
type RoutingBaseConfig = {
|
|
3
17
|
/** A list of all locales that are supported. */
|
|
@@ -11,6 +25,8 @@ export type DomainConfig = Omit<RoutingBaseConfig, 'locales' | 'localePrefix'> &
|
|
|
11
25
|
/** The domain name (e.g. "example.com", "www.example.com" or "fr.example.com"). Note that the `x-forwarded-host` or alternatively the `host` header will be used to determine the requested domain. */
|
|
12
26
|
domain: string;
|
|
13
27
|
locales?: RoutingBaseConfig['locales'];
|
|
28
|
+
/** @deprecated Use `defaultLocale` instead. */
|
|
29
|
+
locale?: string;
|
|
14
30
|
};
|
|
15
31
|
type MiddlewareConfig = RoutingBaseConfig & {
|
|
16
32
|
/** Can be used to change the locale handling per domain. */
|
|
@@ -19,6 +35,8 @@ type MiddlewareConfig = RoutingBaseConfig & {
|
|
|
19
35
|
localeDetection?: boolean;
|
|
20
36
|
/** Sets the `Link` response header to notify search engines about content in other languages (defaults to `true`). See https://developers.google.com/search/docs/specialty/international/localized-versions#http */
|
|
21
37
|
alternateLinks?: boolean;
|
|
38
|
+
/** @deprecated Deprecated in favor of `localePrefix` and `domains`. */
|
|
39
|
+
routing?: RoutingConfigPrefix | RoutingConfigDomain;
|
|
22
40
|
};
|
|
23
41
|
export type MiddlewareConfigWithDefaults = MiddlewareConfig & {
|
|
24
42
|
alternateLinks: boolean;
|
|
@@ -2,13 +2,16 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var navigation = require('next/navigation');
|
|
5
7
|
var useIntl = require('use-intl');
|
|
8
|
+
var NextLink = require('next/link');
|
|
6
9
|
var router = require('next/router');
|
|
7
|
-
var React = require('react');
|
|
8
10
|
|
|
9
11
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
12
|
|
|
11
13
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
14
|
+
var NextLink__default = /*#__PURE__*/_interopDefaultLegacy(NextLink);
|
|
12
15
|
|
|
13
16
|
function _extends() {
|
|
14
17
|
_extends = Object.assign ? Object.assign.bind() : function (target) {
|
|
@@ -37,6 +40,155 @@ function _objectWithoutPropertiesLoose(source, excluded) {
|
|
|
37
40
|
return target;
|
|
38
41
|
}
|
|
39
42
|
|
|
43
|
+
// Reuse the legacy cookie name
|
|
44
|
+
// In a URL like "/en-US/about", the locale segment is "en-US"
|
|
45
|
+
var LOCALE_SEGMENT_NAME = 'locale';
|
|
46
|
+
|
|
47
|
+
function useClientLocale() {
|
|
48
|
+
var locale;
|
|
49
|
+
var params = navigation.useParams();
|
|
50
|
+
if (params[LOCALE_SEGMENT_NAME]) {
|
|
51
|
+
locale = params[LOCALE_SEGMENT_NAME];
|
|
52
|
+
} else {
|
|
53
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks -- Reading from context conditionally is fine
|
|
54
|
+
locale = useIntl.useLocale();
|
|
55
|
+
}
|
|
56
|
+
return locale;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
function isRelativeHref(href) {
|
|
60
|
+
var pathname = typeof href === 'object' ? href.pathname : href;
|
|
61
|
+
return pathname != null && !pathname.startsWith('/');
|
|
62
|
+
}
|
|
63
|
+
function isLocalHref(href) {
|
|
64
|
+
if (typeof href === 'object') {
|
|
65
|
+
return href.host == null && href.hostname == null;
|
|
66
|
+
} else {
|
|
67
|
+
var hasProtocol = /^[a-z]+:/i.test(href);
|
|
68
|
+
return !hasProtocol;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
function localizeHref(href, locale, defaultLocale, pathname) {
|
|
72
|
+
if (defaultLocale === void 0) {
|
|
73
|
+
defaultLocale = locale;
|
|
74
|
+
}
|
|
75
|
+
if (!isLocalHref(href) || isRelativeHref(href)) {
|
|
76
|
+
return href;
|
|
77
|
+
}
|
|
78
|
+
var isSwitchingLocale = locale !== defaultLocale;
|
|
79
|
+
var isPathnamePrefixed = locale == null || hasPathnamePrefixed(locale, pathname);
|
|
80
|
+
var shouldPrefix = isPathnamePrefixed || isSwitchingLocale;
|
|
81
|
+
if (shouldPrefix && locale != null) {
|
|
82
|
+
return prefixHref(href, locale);
|
|
83
|
+
}
|
|
84
|
+
return href;
|
|
85
|
+
}
|
|
86
|
+
function prefixHref(href, locale) {
|
|
87
|
+
var prefixedHref;
|
|
88
|
+
if (typeof href === 'string') {
|
|
89
|
+
prefixedHref = localizePathname(locale, href);
|
|
90
|
+
} else {
|
|
91
|
+
prefixedHref = _extends({}, href);
|
|
92
|
+
if (href.pathname) {
|
|
93
|
+
prefixedHref.pathname = localizePathname(locale, href.pathname);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return prefixedHref;
|
|
97
|
+
}
|
|
98
|
+
function localizePathname(locale, pathname) {
|
|
99
|
+
var localizedHref = '/' + locale;
|
|
100
|
+
if (pathname !== '/') {
|
|
101
|
+
localizedHref += pathname;
|
|
102
|
+
}
|
|
103
|
+
return localizedHref;
|
|
104
|
+
}
|
|
105
|
+
function hasPathnamePrefixed(locale, pathname) {
|
|
106
|
+
var prefix = "/" + locale;
|
|
107
|
+
return pathname === prefix || pathname.startsWith(prefix + "/");
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
var _excluded$2 = ["href", "locale", "prefetch"];
|
|
111
|
+
function BaseLink(_ref, ref) {
|
|
112
|
+
var href = _ref.href,
|
|
113
|
+
locale = _ref.locale,
|
|
114
|
+
prefetch = _ref.prefetch,
|
|
115
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$2);
|
|
116
|
+
var pathname = navigation.usePathname();
|
|
117
|
+
var defaultLocale = useClientLocale();
|
|
118
|
+
var isChangingLocale = locale !== defaultLocale;
|
|
119
|
+
var _useState = React.useState(function () {
|
|
120
|
+
return isLocalHref(href) && locale ?
|
|
121
|
+
// Potentially the href shouldn't be prefixed, but to determine this we
|
|
122
|
+
// need a) the default locale and b) the information if we use prefixed
|
|
123
|
+
// routing. During the server side render (both in RSC as well as SSR),
|
|
124
|
+
// we don't have this information. Therefore we always prefix the href
|
|
125
|
+
// since this will always result in a valid URL, even if it might cause
|
|
126
|
+
// a redirect. This is better than pointing to a non-localized href
|
|
127
|
+
// during the server render, which would potentially be wrong. The final
|
|
128
|
+
// href is determined in the effect below.
|
|
129
|
+
prefixHref(href, locale) : href;
|
|
130
|
+
}),
|
|
131
|
+
localizedHref = _useState[0],
|
|
132
|
+
setLocalizedHref = _useState[1];
|
|
133
|
+
React.useEffect(function () {
|
|
134
|
+
setLocalizedHref(localizeHref(href, locale, defaultLocale, pathname != null ? pathname : undefined));
|
|
135
|
+
}, [defaultLocale, href, locale, pathname]);
|
|
136
|
+
if (isChangingLocale) {
|
|
137
|
+
if (prefetch && "development" !== 'production') {
|
|
138
|
+
console.error('The `prefetch` prop is currently not supported when using the `locale` prop on `Link` to switch the locale.`');
|
|
139
|
+
}
|
|
140
|
+
prefetch = false;
|
|
141
|
+
}
|
|
142
|
+
return React__default["default"].createElement(NextLink__default["default"], _extends({
|
|
143
|
+
ref: ref,
|
|
144
|
+
href: localizedHref,
|
|
145
|
+
prefetch: prefetch
|
|
146
|
+
}, rest));
|
|
147
|
+
}
|
|
148
|
+
var BaseLink$1 = /*#__PURE__*/React.forwardRef(BaseLink);
|
|
149
|
+
|
|
150
|
+
var _excluded$1 = ["locale"];
|
|
151
|
+
/**
|
|
152
|
+
* Wraps `next/link` and prefixes the `href` with the current locale if
|
|
153
|
+
* necessary.
|
|
154
|
+
*
|
|
155
|
+
* @example
|
|
156
|
+
* ```tsx
|
|
157
|
+
* import {Link} from 'next-intl';
|
|
158
|
+
*
|
|
159
|
+
* // When the user is on `/en`, the link will point to `/en/about`
|
|
160
|
+
* <Link href="/about">About</Link>
|
|
161
|
+
*
|
|
162
|
+
* // You can override the `locale` to switch to another language
|
|
163
|
+
* <Link href="/" locale="de">Switch to German</Link>
|
|
164
|
+
* ```
|
|
165
|
+
*
|
|
166
|
+
* Note that when a `locale` prop is passed to switch the locale, the `prefetch`
|
|
167
|
+
* prop is not supported. This is because Next.js would prefetch the page and
|
|
168
|
+
* the `set-cookie` response header would cause the locale cookie on the current
|
|
169
|
+
* page to be overwritten before the user even decides to change the locale.
|
|
170
|
+
*/
|
|
171
|
+
function Link(_ref) {
|
|
172
|
+
var locale = _ref.locale,
|
|
173
|
+
rest = _objectWithoutPropertiesLoose(_ref, _excluded$1);
|
|
174
|
+
var defaultLocale = useClientLocale();
|
|
175
|
+
return React__default["default"].createElement(BaseLink$1, _extends({
|
|
176
|
+
locale: locale || defaultLocale
|
|
177
|
+
}, rest));
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
// TODO: Only available for backwards compatibility
|
|
181
|
+
// during the beta, remove for stable release
|
|
182
|
+
var hasWarned$1 = false;
|
|
183
|
+
/** @deprecated Is available as `import Link from 'next-intl/link'` now. */
|
|
184
|
+
function LinkDeprecated(props) {
|
|
185
|
+
if (!hasWarned$1) {
|
|
186
|
+
console.warn("\n\nDEPRECATION WARNING: The import for `Link` from next-intl has changed.\n\nPreviously: import {Link} from 'next-intl';\nNow: import Link from 'next-intl/link';\n\nPlease upgrade your import accordingly. See also https://next-intl-docs.vercel.app/docs/next-13/navigation#link\n\n");
|
|
187
|
+
hasWarned$1 = true;
|
|
188
|
+
}
|
|
189
|
+
return React__default["default"].createElement(Link, _extends({}, props));
|
|
190
|
+
}
|
|
191
|
+
|
|
40
192
|
var _excluded = ["children", "locale", "now"];
|
|
41
193
|
function NextIntlClientProvider(_ref) {
|
|
42
194
|
var children = _ref.children,
|
|
@@ -71,8 +223,71 @@ function NextIntlClientProvider(_ref) {
|
|
|
71
223
|
}, rest), children);
|
|
72
224
|
}
|
|
73
225
|
|
|
226
|
+
/**
|
|
227
|
+
* Returns a wrapped instance of `useRouter` from `next/navigation` that
|
|
228
|
+
* will automatically localize the `href` parameters it receives.
|
|
229
|
+
*
|
|
230
|
+
* @example
|
|
231
|
+
* ```tsx
|
|
232
|
+
* 'use client';
|
|
233
|
+
*
|
|
234
|
+
* import {useRouter} from 'next-intl/client';
|
|
235
|
+
*
|
|
236
|
+
* const router = useRouter();
|
|
237
|
+
*
|
|
238
|
+
* // When the user is on `/en`, the router will navigate to `/en/about`
|
|
239
|
+
* router.push('/about');
|
|
240
|
+
* ```
|
|
241
|
+
*/
|
|
242
|
+
function useRouter() {
|
|
243
|
+
var router = navigation.useRouter();
|
|
244
|
+
var locale = useClientLocale();
|
|
245
|
+
return React.useMemo(function () {
|
|
246
|
+
function localize(href) {
|
|
247
|
+
return localizeHref(href, locale, locale, window.location.pathname);
|
|
248
|
+
}
|
|
249
|
+
return _extends({}, router, {
|
|
250
|
+
push: function push(href) {
|
|
251
|
+
return router.push(localize(href));
|
|
252
|
+
},
|
|
253
|
+
replace: function replace(href) {
|
|
254
|
+
return router.replace(localize(href));
|
|
255
|
+
},
|
|
256
|
+
prefetch: function prefetch(href) {
|
|
257
|
+
return router.prefetch(localize(href));
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
}, [locale, router]);
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
// TODO: Only available for backwards compatibility
|
|
264
|
+
// during the beta, remove for stable release
|
|
265
|
+
var hasWarned = false;
|
|
266
|
+
function useLocalizedRouterDeprecated() {
|
|
267
|
+
if (!hasWarned) {
|
|
268
|
+
console.warn("\n\nDEPRECATION WARNING: The `useLocalizedRouter` import from `next-intl` is deprecated and will be removed in the stable release of next-intl. Please import `useLocalizedRouter` from `next-intl/client` instead. See https://next-intl-docs.vercel.app/docs/next-13/server-components\n\n");
|
|
269
|
+
hasWarned = true;
|
|
270
|
+
}
|
|
271
|
+
return useRouter();
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
/**
|
|
275
|
+
* This is the main entry file when non-'react-server'
|
|
276
|
+
* environments import from 'next-intl'.
|
|
277
|
+
*
|
|
278
|
+
* Maintainer notes:
|
|
279
|
+
* - Make sure this mirrors the API from 'react-server'.
|
|
280
|
+
* - Make sure everything exported from this module is
|
|
281
|
+
* supported in all Next.js versions that are supported.
|
|
282
|
+
*/
|
|
283
|
+
/** @deprecated Is available as `import Link from 'next-intl/link'` now. */
|
|
284
|
+
var LocalizedLink = LinkDeprecated;
|
|
285
|
+
|
|
286
|
+
exports.Link = LinkDeprecated;
|
|
287
|
+
exports.LocalizedLink = LocalizedLink;
|
|
74
288
|
exports.NextIntlClientProvider = NextIntlClientProvider;
|
|
75
289
|
exports.NextIntlProvider = NextIntlClientProvider;
|
|
290
|
+
exports.useLocalizedRouter = useLocalizedRouterDeprecated;
|
|
76
291
|
Object.keys(useIntl).forEach(function (k) {
|
|
77
292
|
if (k !== 'default' && !exports.hasOwnProperty(k)) Object.defineProperty(exports, k, {
|
|
78
293
|
enumerable: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"next-intl.cjs.development.js","sources":["../src/shared/NextIntlClientProvider.tsx"],"sourcesContent":["'use client';\n\nimport {useRouter} from 'next/router';\nimport React, {ComponentProps} from 'react';\nimport {IntlProvider} from 'use-intl';\n\ntype Props = Omit<ComponentProps<typeof IntlProvider>, 'locale' | 'now'> & {\n locale?: string;\n /** If a string is supplied, make sure this conforms to the ISO 8601 format (YYYY-MM-DDTHH:mm:ss.sssZ */\n now?: Date | string;\n};\n\nexport default function NextIntlClientProvider({\n children,\n locale,\n now,\n ...rest\n}: Props) {\n let router;\n try {\n // Reading from context is practically ok to do conditionally\n // eslint-disable-next-line react-hooks/rules-of-hooks\n router = useRouter();\n } catch (error) {\n // Calling `useRouter` is not supported in the app folder\n }\n\n // The router can be undefined if used in a context outside\n // of Next.js (e.g. unit tests, Storybook, ...)\n if (!locale && router) {\n locale = router.locale;\n }\n\n // Currently RSC serialize dates to strings, therefore make sure we have\n // a date object. We might be able to remove this once more types have\n // first-class serialization support (https://github.com/facebook/react/issues/25687)\n if (typeof now === 'string') {\n now = new Date(now);\n }\n\n if (!locale) {\n throw new Error(\n process.env.NODE_ENV !== 'production'\n ? \"Couldn't determine locale. Please pass an explicit `locale` prop the provider, or if you're using the `pages` folder, use internationalized routing (https://nextjs.org/docs/advanced-features/i18n-routing).\"\n : undefined\n );\n }\n\n return (\n <IntlProvider locale={locale} now={now} {...rest}>\n {children}\n </IntlProvider>\n );\n}\n"],"names":["_excluded","NextIntlClientProvider","_ref","children","locale","now","rest","_objectWithoutPropertiesLoose","router","useRouter","error","Date","Error","React","createElement","IntlProvider","_extends"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAa,IAAAA,SAAA,GAAA,CAAA,UAAA,EAAA,QAAA,EAAA,KAAA,CAAA,CAAA;AAYW,SAAAC,sBAAsBA,CAAAC,IAAA,EAKtC;AAAA,EAAA,IAJNC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;IACRC,MAAM,GAAAF,IAAA,CAANE,MAAM;IACNC,GAAG,GAAAH,IAAA,CAAHG,GAAG;AACAC,IAAAA,IAAI,GAAAC,6BAAA,CAAAL,IAAA,EAAAF,SAAA,CAAA,CAAA;AAEP,EAAA,IAAIQ,QAAM,CAAA;EACV,IAAI;AACF;AACA;IACAA,QAAM,GAAGC,gBAAS,EAAE,CAAA;GACrB,CAAC,OAAOC,KAAK,EAAE;AACd;AAAA,GAAA;AAGF;AACA;AACA,EAAA,IAAI,CAACN,MAAM,IAAII,QAAM,EAAE;IACrBJ,MAAM,GAAGI,QAAM,CAACJ,MAAM,CAAA;AACvB,GAAA;AAED;AACA;AACA;AACA,EAAA,IAAI,OAAOC,GAAG,KAAK,QAAQ,EAAE;AAC3BA,IAAAA,GAAG,GAAG,IAAIM,IAAI,CAACN,GAAG,CAAC,CAAA;AACpB,GAAA;EAED,IAAI,CAACD,MAAM,EAAE;AACX,IAAA,MAAM,IAAIQ,KAAK,CAET,+MAA+M,CACtM,CACd,CAAA;AACF,GAAA;AAED,EAAA,OACEC,yBAAC,CAAAC,aAAA,CAAAC,oBAAY,EAAAC,QAAA,CAAA;AAACZ,IAAAA,MAAM,EAAEA,MAAM;AAAEC,IAAAA,GAAG,EAAEA,GAAAA;GAASC,EAAAA,IAAI,CAC7CH,EAAAA,QAAQ,CACI,CAAA;AAEnB;;;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"next-intl.cjs.development.js","sources":["../src/shared/constants.tsx","../src/client/useClientLocale.tsx","../src/shared/utils.tsx","../src/shared/BaseLink.tsx","../src/link/Link.tsx","../src/react-client/Link.tsx","../src/shared/NextIntlClientProvider.tsx","../src/client/useRouter.tsx","../src/react-client/useLocalizedRouter.tsx","../src/react-client/index.tsx"],"sourcesContent":["// Reuse the legacy cookie name\n// https://nextjs.org/docs/advanced-features/i18n-routing#leveraging-the-next_locale-cookie\nexport const COOKIE_LOCALE_NAME = 'NEXT_LOCALE';\n\n// Should take precedence over the cookie\nexport const HEADER_LOCALE_NAME = 'X-NEXT-INTL-LOCALE';\n\n// In a URL like \"/en-US/about\", the locale segment is \"en-US\"\nexport const LOCALE_SEGMENT_NAME = 'locale';\n","import {useParams} from 'next/navigation';\nimport {useLocale} from 'use-intl';\nimport {LOCALE_SEGMENT_NAME} from '../shared/constants';\n\nexport default function useClientLocale(): string {\n let locale;\n\n const params = useParams();\n if (params[LOCALE_SEGMENT_NAME]) {\n locale = params[LOCALE_SEGMENT_NAME];\n } else {\n // eslint-disable-next-line react-hooks/rules-of-hooks -- Reading from context conditionally is fine\n locale = useLocale();\n }\n\n return locale;\n}\n","import {UrlObject} from 'url';\nimport NextLink from 'next/link';\nimport {ComponentProps} from 'react';\n\ntype Href = ComponentProps<typeof NextLink>['href'];\n\nexport function isRelativeHref(href: Href) {\n const pathname = typeof href === 'object' ? href.pathname : href;\n return pathname != null && !pathname.startsWith('/');\n}\n\nexport function isLocalHref(href: Href) {\n if (typeof href === 'object') {\n return href.host == null && href.hostname == null;\n } else {\n const hasProtocol = /^[a-z]+:/i.test(href);\n return !hasProtocol;\n }\n}\n\nexport function localizeHref(\n href: string,\n locale: string,\n defaultLocale: string,\n pathname: string\n): string;\nexport function localizeHref(\n href: UrlObject | string,\n locale: string,\n defaultLocale: string,\n pathname: string\n): UrlObject | string;\nexport function localizeHref(\n href: UrlObject | string,\n locale: string,\n defaultLocale: string = locale,\n pathname: string\n) {\n if (!isLocalHref(href) || isRelativeHref(href)) {\n return href;\n }\n\n const isSwitchingLocale = locale !== defaultLocale;\n const isPathnamePrefixed =\n locale == null || hasPathnamePrefixed(locale, pathname);\n const shouldPrefix = isPathnamePrefixed || isSwitchingLocale;\n\n if (shouldPrefix && locale != null) {\n return prefixHref(href, locale);\n }\n\n return href;\n}\n\nexport function prefixHref(href: string, locale: string): string;\nexport function prefixHref(\n href: UrlObject | string,\n locale: string\n): UrlObject | string;\nexport function prefixHref(href: UrlObject | string, locale: string) {\n let prefixedHref;\n if (typeof href === 'string') {\n prefixedHref = localizePathname(locale, href);\n } else {\n prefixedHref = {...href};\n if (href.pathname) {\n prefixedHref.pathname = localizePathname(locale, href.pathname);\n }\n }\n\n return prefixedHref;\n}\n\nexport function unlocalizePathname(pathname: string, locale: string) {\n return pathname.replace(new RegExp(`^/${locale}`), '') || '/';\n}\n\nexport function localizePathname(locale: string, pathname: string) {\n let localizedHref = '/' + locale;\n\n if (pathname !== '/') {\n localizedHref += pathname;\n }\n\n return localizedHref;\n}\n\nexport function hasPathnamePrefixed(locale: string, pathname: string) {\n const prefix = `/${locale}`;\n return pathname === prefix || pathname.startsWith(`${prefix}/`);\n}\n","'use client';\n\nimport NextLink from 'next/link';\nimport {usePathname} from 'next/navigation';\nimport React, {ComponentProps, forwardRef, useEffect, useState} from 'react';\nimport useClientLocale from '../client/useClientLocale';\nimport {isLocalHref, localizeHref, prefixHref} from './utils';\n\ntype Props = Omit<ComponentProps<typeof NextLink>, 'locale'> & {\n locale: string;\n};\n\nfunction BaseLink({href, locale, prefetch, ...rest}: Props, ref: Props['ref']) {\n const pathname = usePathname();\n const defaultLocale = useClientLocale();\n const isChangingLocale = locale !== defaultLocale;\n\n const [localizedHref, setLocalizedHref] = useState<typeof href>(() =>\n isLocalHref(href) && locale\n ? // Potentially the href shouldn't be prefixed, but to determine this we\n // need a) the default locale and b) the information if we use prefixed\n // routing. During the server side render (both in RSC as well as SSR),\n // we don't have this information. Therefore we always prefix the href\n // since this will always result in a valid URL, even if it might cause\n // a redirect. This is better than pointing to a non-localized href\n // during the server render, which would potentially be wrong. The final\n // href is determined in the effect below.\n prefixHref(href, locale)\n : href\n );\n\n useEffect(() => {\n setLocalizedHref(\n localizeHref(href, locale, defaultLocale, pathname ?? undefined)\n );\n }, [defaultLocale, href, locale, pathname]);\n\n if (isChangingLocale) {\n if (prefetch && process.env.NODE_ENV !== 'production') {\n console.error(\n 'The `prefetch` prop is currently not supported when using the `locale` prop on `Link` to switch the locale.`'\n );\n }\n prefetch = false;\n }\n\n return (\n <NextLink ref={ref} href={localizedHref} prefetch={prefetch} {...rest} />\n );\n}\n\nexport default forwardRef(BaseLink);\n","import React, {ComponentProps} from 'react';\nimport useClientLocale from '../client/useClientLocale';\nimport BaseLink from '../shared/BaseLink';\n\ntype Props = Omit<ComponentProps<typeof BaseLink>, 'locale'> & {\n locale?: string;\n};\n\n/**\n * Wraps `next/link` and prefixes the `href` with the current locale if\n * necessary.\n *\n * @example\n * ```tsx\n * import {Link} from 'next-intl';\n *\n * // When the user is on `/en`, the link will point to `/en/about`\n * <Link href=\"/about\">About</Link>\n *\n * // You can override the `locale` to switch to another language\n * <Link href=\"/\" locale=\"de\">Switch to German</Link>\n * ```\n *\n * Note that when a `locale` prop is passed to switch the locale, the `prefetch`\n * prop is not supported. This is because Next.js would prefetch the page and\n * the `set-cookie` response header would cause the locale cookie on the current\n * page to be overwritten before the user even decides to change the locale.\n */\nexport default function Link({locale, ...rest}: Props) {\n const defaultLocale = useClientLocale();\n return <BaseLink locale={locale || defaultLocale} {...rest} />;\n}\n","import React, {ComponentProps} from 'react';\nimport Link from '../link';\n\n// TODO: Only available for backwards compatibility\n// during the beta, remove for stable release\n\nlet hasWarned = false;\n\n/** @deprecated Is available as `import Link from 'next-intl/link'` now. */\nexport default function LinkDeprecated(props: ComponentProps<typeof Link>) {\n if (!hasWarned) {\n console.warn(\n `\\n\\nDEPRECATION WARNING: The import for \\`Link\\` from next-intl has changed.\n\nPreviously: import {Link} from 'next-intl';\nNow: import Link from 'next-intl/link';\n\nPlease upgrade your import accordingly. See also https://next-intl-docs.vercel.app/docs/next-13/navigation#link\\n\\n`\n );\n hasWarned = true;\n }\n\n return <Link {...props} />;\n}\n","'use client';\n\nimport {useRouter} from 'next/router';\nimport React, {ComponentProps} from 'react';\nimport {IntlProvider} from 'use-intl';\n\ntype Props = Omit<ComponentProps<typeof IntlProvider>, 'locale' | 'now'> & {\n locale?: string;\n /** If a string is supplied, make sure this conforms to the ISO 8601 format (YYYY-MM-DDTHH:mm:ss.sssZ */\n now?: Date | string;\n};\n\nexport default function NextIntlClientProvider({\n children,\n locale,\n now,\n ...rest\n}: Props) {\n let router;\n try {\n // Reading from context is practically ok to do conditionally\n // eslint-disable-next-line react-hooks/rules-of-hooks\n router = useRouter();\n } catch (error) {\n // Calling `useRouter` is not supported in the app folder\n }\n\n // The router can be undefined if used in a context outside\n // of Next.js (e.g. unit tests, Storybook, ...)\n if (!locale && router) {\n locale = router.locale;\n }\n\n // Currently RSC serialize dates to strings, therefore make sure we have\n // a date object. We might be able to remove this once more types have\n // first-class serialization support (https://github.com/facebook/react/issues/25687)\n if (typeof now === 'string') {\n now = new Date(now);\n }\n\n if (!locale) {\n throw new Error(\n process.env.NODE_ENV !== 'production'\n ? \"Couldn't determine locale. Please pass an explicit `locale` prop the provider, or if you're using the `pages` folder, use internationalized routing (https://nextjs.org/docs/advanced-features/i18n-routing).\"\n : undefined\n );\n }\n\n return (\n <IntlProvider locale={locale} now={now} {...rest}>\n {children}\n </IntlProvider>\n );\n}\n","import {useRouter as useNextRouter} from 'next/navigation';\nimport {useMemo} from 'react';\nimport {localizeHref} from '../shared/utils';\nimport useClientLocale from './useClientLocale';\n\n/**\n * Returns a wrapped instance of `useRouter` from `next/navigation` that\n * will automatically localize the `href` parameters it receives.\n *\n * @example\n * ```tsx\n * 'use client';\n *\n * import {useRouter} from 'next-intl/client';\n *\n * const router = useRouter();\n *\n * // When the user is on `/en`, the router will navigate to `/en/about`\n * router.push('/about');\n * ```\n */\nexport default function useRouter() {\n const router = useNextRouter();\n const locale = useClientLocale();\n\n return useMemo(() => {\n function localize(href: string) {\n return localizeHref(href, locale, locale, window.location.pathname);\n }\n\n return {\n ...router,\n push(href: string) {\n return router.push(localize(href));\n },\n replace(href: string) {\n return router.replace(localize(href));\n },\n prefetch(href: string) {\n return router.prefetch(localize(href));\n }\n };\n }, [locale, router]);\n}\n","import useRouter from '../client/useRouter';\n\n// TODO: Only available for backwards compatibility\n// during the beta, remove for stable release\n\nlet hasWarned = false;\n\nexport default function useLocalizedRouterDeprecated() {\n if (!hasWarned) {\n console.warn(\n `\\n\\nDEPRECATION WARNING: The \\`useLocalizedRouter\\` import from \\`next-intl\\` is deprecated and will be removed in the stable release of next-intl. Please import \\`useLocalizedRouter\\` from \\`next-intl/client\\` instead. See https://next-intl-docs.vercel.app/docs/next-13/server-components\\n\\n`\n );\n hasWarned = true;\n }\n\n return useRouter();\n}\n","/**\n * This is the main entry file when non-'react-server'\n * environments import from 'next-intl'.\n *\n * Maintainer notes:\n * - Make sure this mirrors the API from 'react-server'.\n * - Make sure everything exported from this module is\n * supported in all Next.js versions that are supported.\n */\n\nimport Link from './Link';\n\nexport * from 'use-intl';\nexport {default as NextIntlClientProvider} from '../shared/NextIntlClientProvider';\n\n// Legacy export (TBD if we'll deprecate this in favour of `NextIntlClientProvider`)\nexport {default as NextIntlProvider} from '../shared/NextIntlClientProvider';\n\n/** @deprecated Is available as `import Link from 'next-intl/link'` now. */\nexport const LocalizedLink = Link;\nexport {default as Link} from './Link';\n\nexport {default as useLocalizedRouter} from './useLocalizedRouter';\n"],"names":["LOCALE_SEGMENT_NAME","useClientLocale","locale","params","useParams","useLocale","isRelativeHref","href","pathname","startsWith","isLocalHref","host","hostname","hasProtocol","test","localizeHref","defaultLocale","isSwitchingLocale","isPathnamePrefixed","hasPathnamePrefixed","shouldPrefix","prefixHref","prefixedHref","localizePathname","_extends","localizedHref","prefix","_excluded","BaseLink","_ref","ref","prefetch","rest","_objectWithoutPropertiesLoose","usePathname","isChangingLocale","_useState","useState","setLocalizedHref","useEffect","undefined","process","console","error","React","createElement","NextLink","forwardRef","Link","hasWarned","LinkDeprecated","props","warn","NextIntlClientProvider","children","now","router","useRouter","Date","Error","IntlProvider","useNextRouter","useMemo","localize","window","location","push","replace","useLocalizedRouterDeprecated","LocalizedLink"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("use-intl"),r=require("next/router");function
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("next/navigation"),n=require("use-intl"),r=require("next/link"),o=require("next/router");function a(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=a(e),i=a(r);function l(){return l=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},l.apply(this,arguments)}function c(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r<a.length;r++)t.indexOf(n=a[r])>=0||(o[n]=e[n]);return o}var f="locale";function s(){var e=t.useParams();return e[f]?e[f]:n.useLocale()}function p(e){return"object"==typeof e?null==e.host&&null==e.hostname:!/^[a-z]+:/i.test(e)}function d(e,t,n,r){if(void 0===n&&(n=t),!p(e)||function(e){var t="object"==typeof e?e.pathname:e;return null!=t&&!t.startsWith("/")}(e))return e;var o=t!==n,a=null==t||function(e,t){var n="/"+e;return t===n||t.startsWith(n+"/")}(t,r);return(a||o)&&null!=t?h(e,t):e}function h(e,t){var n;return"string"==typeof e?n=v(t,e):(n=l({},e),e.pathname&&(n.pathname=v(t,e.pathname))),n}function v(e,t){var n="/"+e;return"/"!==t&&(n+=t),n}var m=["href","locale","prefetch"];function x(n,r){var o=n.href,a=n.locale,f=n.prefetch,v=c(n,m),x=t.usePathname(),y=s(),w=a!==y,b=e.useState((function(){return p(o)&&a?h(o,a):o})),P=b[0],g=b[1];return e.useEffect((function(){g(d(o,a,y,null!=x?x:void 0))}),[y,o,a,x]),w&&(f=!1),u.default.createElement(i.default,l({ref:r,href:P,prefetch:f},v))}var y=e.forwardRef(x),w=["locale"];function b(e){var t=e.locale,n=c(e,w),r=s();return u.default.createElement(y,l({locale:t||r},n))}var P=!1;function g(e){return P||(console.warn("\n\nDEPRECATION WARNING: The import for `Link` from next-intl has changed.\n\nPreviously: import {Link} from 'next-intl';\nNow: import Link from 'next-intl/link';\n\nPlease upgrade your import accordingly. See also https://next-intl-docs.vercel.app/docs/next-13/navigation#link\n\n"),P=!0),u.default.createElement(b,l({},e))}var O=["children","locale","now"];function E(e){var t,r=e.children,a=e.locale,i=e.now,f=c(e,O);try{t=o.useRouter()}catch(e){}if(!a&&t&&(a=t.locale),"string"==typeof i&&(i=new Date(i)),!a)throw new Error(void 0);return u.default.createElement(n.IntlProvider,l({locale:a,now:i},f),r)}var j=!1,k=g;exports.Link=g,exports.LocalizedLink=k,exports.NextIntlClientProvider=E,exports.NextIntlProvider=E,exports.useLocalizedRouter=function(){return j||(console.warn("\n\nDEPRECATION WARNING: The `useLocalizedRouter` import from `next-intl` is deprecated and will be removed in the stable release of next-intl. Please import `useLocalizedRouter` from `next-intl/client` instead. See https://next-intl-docs.vercel.app/docs/next-13/server-components\n\n"),j=!0),function(){var n=t.useRouter(),r=s();return e.useMemo((function(){function e(e){return d(e,r,r,window.location.pathname)}return l({},n,{push:function(t){return n.push(e(t))},replace:function(t){return n.replace(e(t))},prefetch:function(t){return n.prefetch(e(t))}})}),[r,n])}()},Object.keys(n).forEach((function(e){"default"===e||exports.hasOwnProperty(e)||Object.defineProperty(exports,e,{enumerable:!0,get:function(){return n[e]}})}));
|
|
2
2
|
//# sourceMappingURL=next-intl.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"next-intl.cjs.production.min.js","sources":["../src/shared/NextIntlClientProvider.tsx"],"sourcesContent":["'use client';\n\nimport {useRouter} from 'next/router';\nimport React, {ComponentProps} from 'react';\nimport {IntlProvider} from 'use-intl';\n\ntype Props = Omit<ComponentProps<typeof IntlProvider>, 'locale' | 'now'> & {\n locale?: string;\n /** If a string is supplied, make sure this conforms to the ISO 8601 format (YYYY-MM-DDTHH:mm:ss.sssZ */\n now?: Date | string;\n};\n\nexport default function NextIntlClientProvider({\n children,\n locale,\n now,\n ...rest\n}: Props) {\n let router;\n try {\n // Reading from context is practically ok to do conditionally\n // eslint-disable-next-line react-hooks/rules-of-hooks\n router = useRouter();\n } catch (error) {\n // Calling `useRouter` is not supported in the app folder\n }\n\n // The router can be undefined if used in a context outside\n // of Next.js (e.g. unit tests, Storybook, ...)\n if (!locale && router) {\n locale = router.locale;\n }\n\n // Currently RSC serialize dates to strings, therefore make sure we have\n // a date object. We might be able to remove this once more types have\n // first-class serialization support (https://github.com/facebook/react/issues/25687)\n if (typeof now === 'string') {\n now = new Date(now);\n }\n\n if (!locale) {\n throw new Error(\n process.env.NODE_ENV !== 'production'\n ? \"Couldn't determine locale. Please pass an explicit `locale` prop the provider, or if you're using the `pages` folder, use internationalized routing (https://nextjs.org/docs/advanced-features/i18n-routing).\"\n : undefined\n );\n }\n\n return (\n <IntlProvider locale={locale} now={now} {...rest}>\n {children}\n </IntlProvider>\n );\n}\n"],"names":["_excluded","NextIntlClientProvider","_ref","router","children","locale","now","rest","_objectWithoutPropertiesLoose","useRouter","error","Date","Error","undefined","React","createElement","IntlProvider","_extends"],"mappings":"6bAAa,IAAAA,EAAA,CAAA,WAAA,SAAA,OAYW,SAAAC,EAAsBC,GAKtC,IACFC,EALJC,EAAQF,EAARE,SACAC,EAAMH,EAANG,OACAC,EAAGJ,EAAHI,IACGC,oIAAIC,CAAAN,EAAAF,GAGP,IAGEG,EAASM,EAASA,WACnB,CAAC,MAAOC,GACP,CAgBF,IAXKL,GAAUF,IACbE,EAASF,EAAOE,QAMC,iBAARC,IACTA,EAAM,IAAIK,KAAKL,KAGZD,EACH,MAAM,IAAIO,WAGJC,GAIR,OACEC,UAACC,cAAAC,EAAYA,aAAAC,EAAA,CAACZ,OAAQA,EAAQC,IAAKA,GAASC,GACzCH,EAGP"}
|
|
1
|
+
{"version":3,"file":"next-intl.cjs.production.min.js","sources":["../src/shared/constants.tsx","../src/client/useClientLocale.tsx","../src/shared/utils.tsx","../src/shared/BaseLink.tsx","../src/link/Link.tsx","../src/react-client/Link.tsx","../src/shared/NextIntlClientProvider.tsx","../src/react-client/useLocalizedRouter.tsx","../src/react-client/index.tsx","../src/client/useRouter.tsx"],"sourcesContent":["// Reuse the legacy cookie name\n// https://nextjs.org/docs/advanced-features/i18n-routing#leveraging-the-next_locale-cookie\nexport const COOKIE_LOCALE_NAME = 'NEXT_LOCALE';\n\n// Should take precedence over the cookie\nexport const HEADER_LOCALE_NAME = 'X-NEXT-INTL-LOCALE';\n\n// In a URL like \"/en-US/about\", the locale segment is \"en-US\"\nexport const LOCALE_SEGMENT_NAME = 'locale';\n","import {useParams} from 'next/navigation';\nimport {useLocale} from 'use-intl';\nimport {LOCALE_SEGMENT_NAME} from '../shared/constants';\n\nexport default function useClientLocale(): string {\n let locale;\n\n const params = useParams();\n if (params[LOCALE_SEGMENT_NAME]) {\n locale = params[LOCALE_SEGMENT_NAME];\n } else {\n // eslint-disable-next-line react-hooks/rules-of-hooks -- Reading from context conditionally is fine\n locale = useLocale();\n }\n\n return locale;\n}\n","import {UrlObject} from 'url';\nimport NextLink from 'next/link';\nimport {ComponentProps} from 'react';\n\ntype Href = ComponentProps<typeof NextLink>['href'];\n\nexport function isRelativeHref(href: Href) {\n const pathname = typeof href === 'object' ? href.pathname : href;\n return pathname != null && !pathname.startsWith('/');\n}\n\nexport function isLocalHref(href: Href) {\n if (typeof href === 'object') {\n return href.host == null && href.hostname == null;\n } else {\n const hasProtocol = /^[a-z]+:/i.test(href);\n return !hasProtocol;\n }\n}\n\nexport function localizeHref(\n href: string,\n locale: string,\n defaultLocale: string,\n pathname: string\n): string;\nexport function localizeHref(\n href: UrlObject | string,\n locale: string,\n defaultLocale: string,\n pathname: string\n): UrlObject | string;\nexport function localizeHref(\n href: UrlObject | string,\n locale: string,\n defaultLocale: string = locale,\n pathname: string\n) {\n if (!isLocalHref(href) || isRelativeHref(href)) {\n return href;\n }\n\n const isSwitchingLocale = locale !== defaultLocale;\n const isPathnamePrefixed =\n locale == null || hasPathnamePrefixed(locale, pathname);\n const shouldPrefix = isPathnamePrefixed || isSwitchingLocale;\n\n if (shouldPrefix && locale != null) {\n return prefixHref(href, locale);\n }\n\n return href;\n}\n\nexport function prefixHref(href: string, locale: string): string;\nexport function prefixHref(\n href: UrlObject | string,\n locale: string\n): UrlObject | string;\nexport function prefixHref(href: UrlObject | string, locale: string) {\n let prefixedHref;\n if (typeof href === 'string') {\n prefixedHref = localizePathname(locale, href);\n } else {\n prefixedHref = {...href};\n if (href.pathname) {\n prefixedHref.pathname = localizePathname(locale, href.pathname);\n }\n }\n\n return prefixedHref;\n}\n\nexport function unlocalizePathname(pathname: string, locale: string) {\n return pathname.replace(new RegExp(`^/${locale}`), '') || '/';\n}\n\nexport function localizePathname(locale: string, pathname: string) {\n let localizedHref = '/' + locale;\n\n if (pathname !== '/') {\n localizedHref += pathname;\n }\n\n return localizedHref;\n}\n\nexport function hasPathnamePrefixed(locale: string, pathname: string) {\n const prefix = `/${locale}`;\n return pathname === prefix || pathname.startsWith(`${prefix}/`);\n}\n","'use client';\n\nimport NextLink from 'next/link';\nimport {usePathname} from 'next/navigation';\nimport React, {ComponentProps, forwardRef, useEffect, useState} from 'react';\nimport useClientLocale from '../client/useClientLocale';\nimport {isLocalHref, localizeHref, prefixHref} from './utils';\n\ntype Props = Omit<ComponentProps<typeof NextLink>, 'locale'> & {\n locale: string;\n};\n\nfunction BaseLink({href, locale, prefetch, ...rest}: Props, ref: Props['ref']) {\n const pathname = usePathname();\n const defaultLocale = useClientLocale();\n const isChangingLocale = locale !== defaultLocale;\n\n const [localizedHref, setLocalizedHref] = useState<typeof href>(() =>\n isLocalHref(href) && locale\n ? // Potentially the href shouldn't be prefixed, but to determine this we\n // need a) the default locale and b) the information if we use prefixed\n // routing. During the server side render (both in RSC as well as SSR),\n // we don't have this information. Therefore we always prefix the href\n // since this will always result in a valid URL, even if it might cause\n // a redirect. This is better than pointing to a non-localized href\n // during the server render, which would potentially be wrong. The final\n // href is determined in the effect below.\n prefixHref(href, locale)\n : href\n );\n\n useEffect(() => {\n setLocalizedHref(\n localizeHref(href, locale, defaultLocale, pathname ?? undefined)\n );\n }, [defaultLocale, href, locale, pathname]);\n\n if (isChangingLocale) {\n if (prefetch && process.env.NODE_ENV !== 'production') {\n console.error(\n 'The `prefetch` prop is currently not supported when using the `locale` prop on `Link` to switch the locale.`'\n );\n }\n prefetch = false;\n }\n\n return (\n <NextLink ref={ref} href={localizedHref} prefetch={prefetch} {...rest} />\n );\n}\n\nexport default forwardRef(BaseLink);\n","import React, {ComponentProps} from 'react';\nimport useClientLocale from '../client/useClientLocale';\nimport BaseLink from '../shared/BaseLink';\n\ntype Props = Omit<ComponentProps<typeof BaseLink>, 'locale'> & {\n locale?: string;\n};\n\n/**\n * Wraps `next/link` and prefixes the `href` with the current locale if\n * necessary.\n *\n * @example\n * ```tsx\n * import {Link} from 'next-intl';\n *\n * // When the user is on `/en`, the link will point to `/en/about`\n * <Link href=\"/about\">About</Link>\n *\n * // You can override the `locale` to switch to another language\n * <Link href=\"/\" locale=\"de\">Switch to German</Link>\n * ```\n *\n * Note that when a `locale` prop is passed to switch the locale, the `prefetch`\n * prop is not supported. This is because Next.js would prefetch the page and\n * the `set-cookie` response header would cause the locale cookie on the current\n * page to be overwritten before the user even decides to change the locale.\n */\nexport default function Link({locale, ...rest}: Props) {\n const defaultLocale = useClientLocale();\n return <BaseLink locale={locale || defaultLocale} {...rest} />;\n}\n","import React, {ComponentProps} from 'react';\nimport Link from '../link';\n\n// TODO: Only available for backwards compatibility\n// during the beta, remove for stable release\n\nlet hasWarned = false;\n\n/** @deprecated Is available as `import Link from 'next-intl/link'` now. */\nexport default function LinkDeprecated(props: ComponentProps<typeof Link>) {\n if (!hasWarned) {\n console.warn(\n `\\n\\nDEPRECATION WARNING: The import for \\`Link\\` from next-intl has changed.\n\nPreviously: import {Link} from 'next-intl';\nNow: import Link from 'next-intl/link';\n\nPlease upgrade your import accordingly. See also https://next-intl-docs.vercel.app/docs/next-13/navigation#link\\n\\n`\n );\n hasWarned = true;\n }\n\n return <Link {...props} />;\n}\n","'use client';\n\nimport {useRouter} from 'next/router';\nimport React, {ComponentProps} from 'react';\nimport {IntlProvider} from 'use-intl';\n\ntype Props = Omit<ComponentProps<typeof IntlProvider>, 'locale' | 'now'> & {\n locale?: string;\n /** If a string is supplied, make sure this conforms to the ISO 8601 format (YYYY-MM-DDTHH:mm:ss.sssZ */\n now?: Date | string;\n};\n\nexport default function NextIntlClientProvider({\n children,\n locale,\n now,\n ...rest\n}: Props) {\n let router;\n try {\n // Reading from context is practically ok to do conditionally\n // eslint-disable-next-line react-hooks/rules-of-hooks\n router = useRouter();\n } catch (error) {\n // Calling `useRouter` is not supported in the app folder\n }\n\n // The router can be undefined if used in a context outside\n // of Next.js (e.g. unit tests, Storybook, ...)\n if (!locale && router) {\n locale = router.locale;\n }\n\n // Currently RSC serialize dates to strings, therefore make sure we have\n // a date object. We might be able to remove this once more types have\n // first-class serialization support (https://github.com/facebook/react/issues/25687)\n if (typeof now === 'string') {\n now = new Date(now);\n }\n\n if (!locale) {\n throw new Error(\n process.env.NODE_ENV !== 'production'\n ? \"Couldn't determine locale. Please pass an explicit `locale` prop the provider, or if you're using the `pages` folder, use internationalized routing (https://nextjs.org/docs/advanced-features/i18n-routing).\"\n : undefined\n );\n }\n\n return (\n <IntlProvider locale={locale} now={now} {...rest}>\n {children}\n </IntlProvider>\n );\n}\n","import useRouter from '../client/useRouter';\n\n// TODO: Only available for backwards compatibility\n// during the beta, remove for stable release\n\nlet hasWarned = false;\n\nexport default function useLocalizedRouterDeprecated() {\n if (!hasWarned) {\n console.warn(\n `\\n\\nDEPRECATION WARNING: The \\`useLocalizedRouter\\` import from \\`next-intl\\` is deprecated and will be removed in the stable release of next-intl. Please import \\`useLocalizedRouter\\` from \\`next-intl/client\\` instead. See https://next-intl-docs.vercel.app/docs/next-13/server-components\\n\\n`\n );\n hasWarned = true;\n }\n\n return useRouter();\n}\n","/**\n * This is the main entry file when non-'react-server'\n * environments import from 'next-intl'.\n *\n * Maintainer notes:\n * - Make sure this mirrors the API from 'react-server'.\n * - Make sure everything exported from this module is\n * supported in all Next.js versions that are supported.\n */\n\nimport Link from './Link';\n\nexport * from 'use-intl';\nexport {default as NextIntlClientProvider} from '../shared/NextIntlClientProvider';\n\n// Legacy export (TBD if we'll deprecate this in favour of `NextIntlClientProvider`)\nexport {default as NextIntlProvider} from '../shared/NextIntlClientProvider';\n\n/** @deprecated Is available as `import Link from 'next-intl/link'` now. */\nexport const LocalizedLink = Link;\nexport {default as Link} from './Link';\n\nexport {default as useLocalizedRouter} from './useLocalizedRouter';\n","import {useRouter as useNextRouter} from 'next/navigation';\nimport {useMemo} from 'react';\nimport {localizeHref} from '../shared/utils';\nimport useClientLocale from './useClientLocale';\n\n/**\n * Returns a wrapped instance of `useRouter` from `next/navigation` that\n * will automatically localize the `href` parameters it receives.\n *\n * @example\n * ```tsx\n * 'use client';\n *\n * import {useRouter} from 'next-intl/client';\n *\n * const router = useRouter();\n *\n * // When the user is on `/en`, the router will navigate to `/en/about`\n * router.push('/about');\n * ```\n */\nexport default function useRouter() {\n const router = useNextRouter();\n const locale = useClientLocale();\n\n return useMemo(() => {\n function localize(href: string) {\n return localizeHref(href, locale, locale, window.location.pathname);\n }\n\n return {\n ...router,\n push(href: string) {\n return router.push(localize(href));\n },\n replace(href: string) {\n return router.replace(localize(href));\n },\n prefetch(href: string) {\n return router.prefetch(localize(href));\n }\n };\n }, [locale, router]);\n}\n"],"names":["LOCALE_SEGMENT_NAME","useClientLocale","params","useParams","useLocale","isLocalHref","href","host","hostname","test","localizeHref","locale","defaultLocale","pathname","startsWith","isRelativeHref","isSwitchingLocale","isPathnamePrefixed","prefix","hasPathnamePrefixed","prefixHref","prefixedHref","localizePathname","_extends","localizedHref","_excluded","BaseLink","_ref","ref","prefetch","rest","_objectWithoutPropertiesLoose","usePathname","isChangingLocale","_useState","useState","setLocalizedHref","useEffect","undefined","React","createElement","NextLink","BaseLink$1","forwardRef","Link","hasWarned","LinkDeprecated","props","console","warn","NextIntlClientProvider","router","children","now","useRouter","error","Date","Error","IntlProvider","LocalizedLink","useNextRouter","useMemo","localize","window","location","push","replace"],"mappings":"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"}
|
package/dist/next-intl.esm.js
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { LocalizedLink } from './react-client/next-intl.esm.js';
|
|
2
2
|
export { default as NextIntlClientProvider, default as NextIntlProvider } from './shared/next-intl.esm.js';
|
|
3
|
+
export { default as Link } from './react-client/next-intl.esm3.js';
|
|
4
|
+
export { default as useLocalizedRouter } from './react-client/next-intl.esm2.js';
|
|
5
|
+
export * from 'use-intl';
|
|
3
6
|
//# sourceMappingURL=next-intl.esm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"next-intl.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"next-intl.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -7,6 +7,11 @@
|
|
|
7
7
|
* - Make sure everything exported from this module is
|
|
8
8
|
* supported in all Next.js versions that are supported.
|
|
9
9
|
*/
|
|
10
|
+
import Link from './Link';
|
|
10
11
|
export * from 'use-intl';
|
|
11
12
|
export { default as NextIntlClientProvider } from '../shared/NextIntlClientProvider';
|
|
12
13
|
export { default as NextIntlProvider } from '../shared/NextIntlClientProvider';
|
|
14
|
+
/** @deprecated Is available as `import Link from 'next-intl/link'` now. */
|
|
15
|
+
export declare const LocalizedLink: typeof Link;
|
|
16
|
+
export { default as Link } from './Link';
|
|
17
|
+
export { default as useLocalizedRouter } from './useLocalizedRouter';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import LinkDeprecated from './next-intl.esm3.js';
|
|
2
|
+
export { default as Link } from './next-intl.esm3.js';
|
|
3
|
+
export * from 'use-intl';
|
|
4
|
+
import 'next/router';
|
|
5
|
+
import 'react';
|
|
6
|
+
import 'next/navigation';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* This is the main entry file when non-'react-server'
|
|
10
|
+
* environments import from 'next-intl'.
|
|
11
|
+
*
|
|
12
|
+
* Maintainer notes:
|
|
13
|
+
* - Make sure this mirrors the API from 'react-server'.
|
|
14
|
+
* - Make sure everything exported from this module is
|
|
15
|
+
* supported in all Next.js versions that are supported.
|
|
16
|
+
*/
|
|
17
|
+
/** @deprecated Is available as `import Link from 'next-intl/link'` now. */
|
|
18
|
+
var LocalizedLink = LinkDeprecated;
|
|
19
|
+
|
|
20
|
+
export { LocalizedLink };
|
|
21
|
+
//# sourceMappingURL=next-intl.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"next-intl.esm.js","sources":["../../src/react-client/index.tsx"],"sourcesContent":["/**\n * This is the main entry file when non-'react-server'\n * environments import from 'next-intl'.\n *\n * Maintainer notes:\n * - Make sure this mirrors the API from 'react-server'.\n * - Make sure everything exported from this module is\n * supported in all Next.js versions that are supported.\n */\n\nimport Link from './Link';\n\nexport * from 'use-intl';\nexport {default as NextIntlClientProvider} from '../shared/NextIntlClientProvider';\n\n// Legacy export (TBD if we'll deprecate this in favour of `NextIntlClientProvider`)\nexport {default as NextIntlProvider} from '../shared/NextIntlClientProvider';\n\n/** @deprecated Is available as `import Link from 'next-intl/link'` now. */\nexport const LocalizedLink = Link;\nexport {default as Link} from './Link';\n\nexport {default as useLocalizedRouter} from './useLocalizedRouter';\n"],"names":["LocalizedLink","Link"],"mappings":";;;;;;;AAAA;;;;;;;;AAQG;AAUH;AACO,IAAMA,aAAa,GAAGC;;;;"}
|