fumadocs-core 14.7.3 → 14.7.4

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.
@@ -7,7 +7,9 @@ import { NextResponse } from "next/server";
7
7
  var COOKIE = "FD_LOCALE";
8
8
  function getLocale(request, locales, defaultLanguage) {
9
9
  const negotiatorHeaders = {};
10
- request.headers.forEach((value, key) => negotiatorHeaders[key] = value);
10
+ request.headers.forEach((value, key) => {
11
+ negotiatorHeaders[key] = value;
12
+ });
11
13
  const languages = new Negotiator({ headers: negotiatorHeaders }).languages(
12
14
  locales
13
15
  );
@@ -35,30 +37,33 @@ function createI18nMiddleware({
35
37
  );
36
38
  }
37
39
  return (request) => {
38
- const { pathname } = request.nextUrl;
40
+ const inputPath = `${request.nextUrl.pathname}${request.nextUrl.search}`;
39
41
  const pathLocale = languages.find(
40
- (locale) => pathname.startsWith(`/${locale}/`) || pathname === `/${locale}`
42
+ (locale) => inputPath.startsWith(`/${locale}/`) || inputPath === `/${locale}`
41
43
  );
42
44
  if (!pathLocale) {
43
45
  if (hideLocale === "default-locale") {
44
- return NextResponse.rewrite(getUrl(request, pathname, defaultLanguage));
46
+ return NextResponse.rewrite(
47
+ getUrl(request, inputPath, defaultLanguage)
48
+ );
45
49
  }
46
50
  const preferred = getLocale(request, languages, defaultLanguage);
47
51
  if (hideLocale === "always") {
48
52
  const locale = request.cookies.get(COOKIE)?.value ?? preferred;
49
- return NextResponse.rewrite(getUrl(request, pathname, locale));
53
+ return NextResponse.rewrite(getUrl(request, inputPath, locale));
50
54
  }
51
- return NextResponse.redirect(getUrl(request, pathname, preferred));
55
+ return NextResponse.redirect(getUrl(request, inputPath, preferred));
52
56
  }
53
57
  if (hideLocale === "always") {
54
- const path = pathname.slice(`/${pathLocale}`.length);
58
+ const path = inputPath.slice(`/${pathLocale}`.length);
55
59
  const res = NextResponse.redirect(getUrl(request, path));
56
60
  res.cookies.set(COOKIE, pathLocale);
57
61
  return res;
58
62
  }
59
63
  if (hideLocale === "default-locale" && pathLocale === defaultLanguage) {
60
- const path = pathname.slice(`/${pathLocale}`.length);
61
- return NextResponse.redirect(getUrl(request, path));
64
+ return NextResponse.redirect(
65
+ getUrl(request, inputPath.slice(`/${pathLocale}`.length))
66
+ );
62
67
  }
63
68
  return NextResponse.next();
64
69
  };
@@ -1,11 +1,11 @@
1
- import {
2
- resolvePath,
3
- slash
4
- } from "../chunk-SHGL6VBO.js";
5
1
  import {
6
2
  flattenNode,
7
3
  remarkHeading
8
4
  } from "../chunk-4MNUWZIW.js";
5
+ import {
6
+ resolvePath,
7
+ slash
8
+ } from "../chunk-SHGL6VBO.js";
9
9
  import {
10
10
  createStyleTransformer,
11
11
  defaultThemes
@@ -20,7 +20,7 @@ import {
20
20
  // src/mdx-plugins/rehype-code.ts
21
21
  import rehypeShikiFromHighlighter from "@shikijs/rehype/core";
22
22
 
23
- // ../../node_modules/.pnpm/shiki-transformers@1.0.1_shiki@1.26.1/node_modules/shiki-transformers/dist/index.js
23
+ // ../../node_modules/.pnpm/shiki-transformers@1.0.1_shiki@1.27.0/node_modules/shiki-transformers/dist/index.js
24
24
  var matchers = [
25
25
  [/^(<!--)(.+)(-->)$/, false],
26
26
  [/^(\/\*)(.+)(\*\/)$/, false],
@@ -102,6 +102,7 @@ interface LanguageEntry<Data = PageData> {
102
102
  }
103
103
  interface LoaderOutput<Config extends LoaderConfig> {
104
104
  pageTree: Config['i18n'] extends true ? Record<string, Root> : Root;
105
+ getPageTree(locale?: string): Root;
105
106
  _i18n?: I18nConfig;
106
107
  /**
107
108
  * Get list of pages from language, empty if language hasn't specified
@@ -426,6 +426,12 @@ function createOutput(options) {
426
426
  if (!node.$ref?.metaFile) return;
427
427
  return walker.pathToMeta.get(node.$ref.metaFile);
428
428
  },
429
+ getPageTree(locale) {
430
+ if (options.i18n) {
431
+ return pageTree[locale ?? options.i18n.defaultLanguage];
432
+ }
433
+ return pageTree;
434
+ },
429
435
  getNodePage(node) {
430
436
  if (!node.$ref?.file) return;
431
437
  return walker.pathToPage.get(node.$ref.file);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fumadocs-core",
3
- "version": "14.7.3",
3
+ "version": "14.7.4",
4
4
  "description": "The library for building a documentation website in Next.js",
5
5
  "keywords": [
6
6
  "NextJs",
@@ -79,7 +79,7 @@
79
79
  "dependencies": {
80
80
  "@formatjs/intl-localematcher": "^0.5.10",
81
81
  "@orama/orama": "^2.1.1",
82
- "@shikijs/rehype": "^1.26.1",
82
+ "@shikijs/rehype": "^1.26.2",
83
83
  "github-slugger": "^2.0.0",
84
84
  "hast-util-to-estree": "^3.1.1",
85
85
  "hast-util-to-jsx-runtime": "^2.3.2",
@@ -89,7 +89,7 @@
89
89
  "remark": "^15.0.0",
90
90
  "remark-gfm": "^4.0.0",
91
91
  "scroll-into-view-if-needed": "^3.1.0",
92
- "shiki": "^1.26.1",
92
+ "shiki": "^1.27.0",
93
93
  "unist-util-visit": "^5.0.0"
94
94
  },
95
95
  "devDependencies": {
@@ -101,11 +101,11 @@
101
101
  "@types/hast": "^3.0.4",
102
102
  "@types/mdast": "^4.0.3",
103
103
  "@types/negotiator": "^0.6.3",
104
- "@types/node": "22.10.5",
105
- "@types/react": "^19.0.4",
106
- "@types/react-dom": "^19.0.2",
104
+ "@types/node": "22.10.6",
105
+ "@types/react": "^19.0.7",
106
+ "@types/react-dom": "^19.0.3",
107
107
  "algoliasearch": "4.24.0",
108
- "mdast-util-mdx-jsx": "^3.1.3",
108
+ "mdast-util-mdx-jsx": "^3.2.0",
109
109
  "mdast-util-mdxjs-esm": "^2.0.1",
110
110
  "next": "^15.1.4",
111
111
  "remark-mdx": "^3.1.0",