fumadocs-core 14.7.2 → 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.
- package/dist/breadcrumb.d.ts +2 -2
- package/dist/breadcrumb.js +1 -0
- package/dist/i18n/index.js +14 -9
- package/dist/mdx-plugins/index.js +1 -1
- package/dist/source/index.d.ts +1 -0
- package/dist/source/index.js +6 -0
- package/package.json +10 -10
package/dist/breadcrumb.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ReactNode } from 'react';
|
|
2
|
-
import { R as Root, N as Node
|
|
2
|
+
import { R as Root, N as Node } from './page-tree-r8qjoUla.js';
|
|
3
3
|
|
|
4
4
|
interface BreadcrumbItem {
|
|
5
5
|
name: ReactNode;
|
|
@@ -39,6 +39,6 @@ declare function getBreadcrumbItemsFromPath(tree: Root, path: Node[], options: B
|
|
|
39
39
|
* @returns The path to the target node from root
|
|
40
40
|
* @internal
|
|
41
41
|
*/
|
|
42
|
-
declare function searchPath(nodes: Node[], url: string):
|
|
42
|
+
declare function searchPath(nodes: Node[], url: string): Node[] | null;
|
|
43
43
|
|
|
44
44
|
export { type BreadcrumbItem, type BreadcrumbOptions, getBreadcrumbItems, getBreadcrumbItemsFromPath, searchPath, useBreadcrumb };
|
package/dist/breadcrumb.js
CHANGED
|
@@ -52,6 +52,7 @@ function getBreadcrumbItemsFromPath(tree, path, options) {
|
|
|
52
52
|
return items;
|
|
53
53
|
}
|
|
54
54
|
function searchPath(nodes, url) {
|
|
55
|
+
if (url.endsWith("/")) url = url.slice(0, -1);
|
|
55
56
|
let separator;
|
|
56
57
|
for (const node of nodes) {
|
|
57
58
|
if (node.type === "separator") separator = node;
|
package/dist/i18n/index.js
CHANGED
|
@@ -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) =>
|
|
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
|
|
40
|
+
const inputPath = `${request.nextUrl.pathname}${request.nextUrl.search}`;
|
|
39
41
|
const pathLocale = languages.find(
|
|
40
|
-
(locale) =>
|
|
42
|
+
(locale) => inputPath.startsWith(`/${locale}/`) || inputPath === `/${locale}`
|
|
41
43
|
);
|
|
42
44
|
if (!pathLocale) {
|
|
43
45
|
if (hideLocale === "default-locale") {
|
|
44
|
-
return NextResponse.rewrite(
|
|
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,
|
|
53
|
+
return NextResponse.rewrite(getUrl(request, inputPath, locale));
|
|
50
54
|
}
|
|
51
|
-
return NextResponse.redirect(getUrl(request,
|
|
55
|
+
return NextResponse.redirect(getUrl(request, inputPath, preferred));
|
|
52
56
|
}
|
|
53
57
|
if (hideLocale === "always") {
|
|
54
|
-
const path =
|
|
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
|
-
|
|
61
|
-
|
|
64
|
+
return NextResponse.redirect(
|
|
65
|
+
getUrl(request, inputPath.slice(`/${pathLocale}`.length))
|
|
66
|
+
);
|
|
62
67
|
}
|
|
63
68
|
return NextResponse.next();
|
|
64
69
|
};
|
|
@@ -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.
|
|
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],
|
package/dist/source/index.d.ts
CHANGED
|
@@ -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
|
package/dist/source/index.js
CHANGED
|
@@ -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
|
+
"version": "14.7.4",
|
|
4
4
|
"description": "The library for building a documentation website in Next.js",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"NextJs",
|
|
@@ -79,9 +79,9 @@
|
|
|
79
79
|
"dependencies": {
|
|
80
80
|
"@formatjs/intl-localematcher": "^0.5.10",
|
|
81
81
|
"@orama/orama": "^2.1.1",
|
|
82
|
-
"@shikijs/rehype": "^1.26.
|
|
82
|
+
"@shikijs/rehype": "^1.26.2",
|
|
83
83
|
"github-slugger": "^2.0.0",
|
|
84
|
-
"hast-util-to-estree": "^3.1.
|
|
84
|
+
"hast-util-to-estree": "^3.1.1",
|
|
85
85
|
"hast-util-to-jsx-runtime": "^2.3.2",
|
|
86
86
|
"image-size": "^1.2.0",
|
|
87
87
|
"negotiator": "^1.0.0",
|
|
@@ -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.
|
|
92
|
+
"shiki": "^1.27.0",
|
|
93
93
|
"unist-util-visit": "^5.0.0"
|
|
94
94
|
},
|
|
95
95
|
"devDependencies": {
|
|
@@ -101,17 +101,17 @@
|
|
|
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.
|
|
105
|
-
"@types/react": "^19.0.
|
|
106
|
-
"@types/react-dom": "^19.0.
|
|
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.
|
|
108
|
+
"mdast-util-mdx-jsx": "^3.2.0",
|
|
109
109
|
"mdast-util-mdxjs-esm": "^2.0.1",
|
|
110
|
-
"next": "^15.1.
|
|
110
|
+
"next": "^15.1.4",
|
|
111
111
|
"remark-mdx": "^3.1.0",
|
|
112
112
|
"remark-rehype": "^11.1.1",
|
|
113
113
|
"shiki-transformers": "^1.0.1",
|
|
114
|
-
"typescript": "^5.7.
|
|
114
|
+
"typescript": "^5.7.3",
|
|
115
115
|
"unified": "^11.0.5",
|
|
116
116
|
"vfile": "^6.0.3",
|
|
117
117
|
"eslint-config-custom": "0.0.0",
|