fuma-content 1.0.1 → 1.0.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.
Files changed (147) hide show
  1. package/dist/async-cache-BM9Yf4Nw.js +29 -0
  2. package/dist/async-cache-BM9Yf4Nw.js.map +1 -0
  3. package/dist/bin.d.ts +1 -1
  4. package/dist/bin.js +21 -14
  5. package/dist/bin.js.map +1 -0
  6. package/dist/build-D8A5ByFk.js +42 -0
  7. package/dist/build-D8A5ByFk.js.map +1 -0
  8. package/dist/build-mdx-C1PZsGp2.js +395 -0
  9. package/dist/build-mdx-C1PZsGp2.js.map +1 -0
  10. package/dist/build-mdx-DFndaVbS.js +4 -0
  11. package/dist/bun/index.d.ts +6 -13
  12. package/dist/bun/index.d.ts.map +1 -0
  13. package/dist/bun/index.js +23 -34
  14. package/dist/bun/index.js.map +1 -0
  15. package/dist/bun-QKQnqgIi.js +35 -0
  16. package/dist/bun-QKQnqgIi.js.map +1 -0
  17. package/dist/code-generator-gPtrfZ6Q.js +133 -0
  18. package/dist/code-generator-gPtrfZ6Q.js.map +1 -0
  19. package/dist/collections/handlers/fs.d.ts +2 -10
  20. package/dist/collections/handlers/fs.js +28 -6
  21. package/dist/collections/handlers/fs.js.map +1 -0
  22. package/dist/collections/index.d.ts +2 -10
  23. package/dist/collections/index.js +16 -6
  24. package/dist/collections/index.js.map +1 -0
  25. package/dist/collections/mdx/loader-webpack.d.ts +6 -14
  26. package/dist/collections/mdx/loader-webpack.d.ts.map +1 -0
  27. package/dist/collections/mdx/loader-webpack.js +23 -36
  28. package/dist/collections/mdx/loader-webpack.js.map +1 -0
  29. package/dist/collections/mdx/runtime-browser.d.ts +27 -37
  30. package/dist/collections/mdx/runtime-browser.d.ts.map +1 -0
  31. package/dist/collections/mdx/runtime-browser.js +57 -70
  32. package/dist/collections/mdx/runtime-browser.js.map +1 -0
  33. package/dist/collections/mdx/runtime-dynamic.d.ts +22 -30
  34. package/dist/collections/mdx/runtime-dynamic.d.ts.map +1 -0
  35. package/dist/collections/mdx/runtime-dynamic.js +63 -85
  36. package/dist/collections/mdx/runtime-dynamic.js.map +1 -0
  37. package/dist/collections/mdx/runtime.d.ts +31 -52
  38. package/dist/collections/mdx/runtime.d.ts.map +1 -0
  39. package/dist/collections/mdx/runtime.js +24 -34
  40. package/dist/collections/mdx/runtime.js.map +1 -0
  41. package/dist/collections/mdx.d.ts +2 -10
  42. package/dist/collections/mdx.js +240 -284
  43. package/dist/collections/mdx.js.map +1 -0
  44. package/dist/collections/meta/loader-webpack.d.ts +6 -14
  45. package/dist/collections/meta/loader-webpack.d.ts.map +1 -0
  46. package/dist/collections/meta/loader-webpack.js +25 -39
  47. package/dist/collections/meta/loader-webpack.js.map +1 -0
  48. package/dist/collections/meta/runtime.d.ts +7 -15
  49. package/dist/collections/meta/runtime.d.ts.map +1 -0
  50. package/dist/collections/meta/runtime.js +9 -15
  51. package/dist/collections/meta/runtime.js.map +1 -0
  52. package/dist/collections/meta.d.ts +2 -10
  53. package/dist/collections/meta.js +128 -164
  54. package/dist/collections/meta.js.map +1 -0
  55. package/dist/collections/runtime/file-store.d.ts +17 -14
  56. package/dist/collections/runtime/file-store.d.ts.map +1 -0
  57. package/dist/collections/runtime/file-store.js +30 -6
  58. package/dist/collections/runtime/file-store.js.map +1 -0
  59. package/dist/collections/runtime/store.d.ts +3 -28
  60. package/dist/collections/runtime/store.js +3 -6
  61. package/dist/config/index.d.ts +2 -10
  62. package/dist/config/index.js +6 -5
  63. package/dist/config/index.js.map +1 -0
  64. package/dist/core-Bkh-SI_3.d.ts +561 -0
  65. package/dist/core-Bkh-SI_3.d.ts.map +1 -0
  66. package/dist/core-ZuoVBkeg.js +170 -0
  67. package/dist/core-ZuoVBkeg.js.map +1 -0
  68. package/dist/dynamic-B40uAtdo.js +28 -0
  69. package/dist/dynamic-B40uAtdo.js.map +1 -0
  70. package/dist/fuma-matter-O4fA6nSx.js +27 -0
  71. package/dist/fuma-matter-O4fA6nSx.js.map +1 -0
  72. package/dist/index.d.ts +13 -16
  73. package/dist/index.d.ts.map +1 -0
  74. package/dist/index.js +6 -8
  75. package/dist/load-from-file-1f4WaHsf.js +38 -0
  76. package/dist/load-from-file-1f4WaHsf.js.map +1 -0
  77. package/dist/load-from-file-BTNnBu6f.js +3 -0
  78. package/dist/loader-80abXEHx.js +4 -0
  79. package/dist/loader-BFhPyg3z.js +4 -0
  80. package/dist/loader-CXnMFuyE.js +80 -0
  81. package/dist/loader-CXnMFuyE.js.map +1 -0
  82. package/dist/loader-gk94iHf5.js +66 -0
  83. package/dist/loader-gk94iHf5.js.map +1 -0
  84. package/dist/next/index.cjs +459 -551
  85. package/dist/next/index.d.ts +16 -22
  86. package/dist/next/index.d.ts.map +1 -0
  87. package/dist/next/index.js +71 -89
  88. package/dist/next/index.js.map +1 -0
  89. package/dist/node/loader.d.ts +4 -2
  90. package/dist/node/loader.d.ts.map +1 -0
  91. package/dist/node/loader.js +32 -44
  92. package/dist/node/loader.js.map +1 -0
  93. package/dist/node-CGIIJIcs.js +31 -0
  94. package/dist/node-CGIIJIcs.js.map +1 -0
  95. package/dist/pipe-5cnvE6KY.js +31 -0
  96. package/dist/pipe-5cnvE6KY.js.map +1 -0
  97. package/dist/plugins/git.d.ts +2 -10
  98. package/dist/plugins/git.js +57 -65
  99. package/dist/plugins/git.js.map +1 -0
  100. package/dist/plugins/json-schema.d.ts +2 -10
  101. package/dist/plugins/json-schema.js +60 -58
  102. package/dist/plugins/json-schema.js.map +1 -0
  103. package/dist/plugins/with-loader/index.d.ts +2 -61
  104. package/dist/plugins/with-loader/index.js +28 -6
  105. package/dist/plugins/with-loader/index.js.map +1 -0
  106. package/dist/plugins/with-loader/webpack.d.ts +10 -18
  107. package/dist/plugins/with-loader/webpack.d.ts.map +1 -0
  108. package/dist/plugins/with-loader/webpack.js +43 -12
  109. package/dist/plugins/with-loader/webpack.js.map +1 -0
  110. package/dist/store-0LQ2PlH6.js +37 -0
  111. package/dist/store-0LQ2PlH6.js.map +1 -0
  112. package/dist/store-DEjYYF6a.d.ts +31 -0
  113. package/dist/store-DEjYYF6a.d.ts.map +1 -0
  114. package/dist/validation-BOJKRAp5.js +28 -0
  115. package/dist/validation-BOJKRAp5.js.map +1 -0
  116. package/dist/vite/index.d.ts +22 -28
  117. package/dist/vite/index.d.ts.map +1 -0
  118. package/dist/vite/index.js +37 -52
  119. package/dist/vite/index.js.map +1 -0
  120. package/dist/vite-X-2Al8fq.js +32 -0
  121. package/dist/vite-X-2Al8fq.js.map +1 -0
  122. package/package.json +7 -6
  123. package/dist/build-mdx-I4NROXCF.js +0 -8
  124. package/dist/bun-DMNX4PBC.js +0 -40
  125. package/dist/chunk-3VQS3KSP.js +0 -39
  126. package/dist/chunk-BTRE6MOX.js +0 -16
  127. package/dist/chunk-E4HRKSP4.js +0 -24
  128. package/dist/chunk-ERBMAQYP.js +0 -33
  129. package/dist/chunk-GGL4EF6H.js +0 -38
  130. package/dist/chunk-JBZTQ55D.js +0 -30
  131. package/dist/chunk-KH5GT2Y5.js +0 -104
  132. package/dist/chunk-LUM7SIZN.js +0 -40
  133. package/dist/chunk-MT7RY65Y.js +0 -167
  134. package/dist/chunk-NRZ4GE5O.js +0 -207
  135. package/dist/chunk-OQQNA7L7.js +0 -412
  136. package/dist/chunk-OUJENWQ4.js +0 -45
  137. package/dist/chunk-RMSV4HP6.js +0 -85
  138. package/dist/chunk-RXR7OL76.js +0 -37
  139. package/dist/chunk-VWJKRQZR.js +0 -19
  140. package/dist/chunk-W6HENTK7.js +0 -44
  141. package/dist/chunk-XR5N6ZXJ.js +0 -50
  142. package/dist/core-Bo8KaWQz.d.ts +0 -411
  143. package/dist/load-from-file-HL2VEY3M.js +0 -7
  144. package/dist/loader-NFSL6P5I.js +0 -7
  145. package/dist/loader-T756NSCS.js +0 -7
  146. package/dist/node-DCMYL4DL.js +0 -34
  147. package/dist/vite-QCUPZHHB.js +0 -32
@@ -1,594 +1,502 @@
1
- "use strict";
1
+ //#region rolldown:runtime
2
2
  var __create = Object.create;
3
3
  var __defProp = Object.defineProperty;
4
4
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
8
  var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
9
+ if (from && typeof from === "object" || typeof from === "function") {
10
+ for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
11
+ key = keys[i];
12
+ if (!__hasOwnProp.call(to, key) && key !== except) {
13
+ __defProp(to, key, {
14
+ get: ((k) => from[k]).bind(null, key),
15
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
16
+ });
17
+ }
18
+ }
19
+ }
20
+ return to;
19
21
  };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
-
30
- // src/next/index.ts
31
- var next_exports = {};
32
- __export(next_exports, {
33
- createContent: () => createContent,
34
- createStandaloneCore: () => createStandaloneCore
35
- });
36
- module.exports = __toCommonJS(next_exports);
37
- var path3 = __toESM(require("path"), 1);
22
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
23
+ value: mod,
24
+ enumerable: true
25
+ }) : target, mod));
38
26
 
39
- // src/config/load-from-file.ts
40
- var import_node_url = require("url");
27
+ //#endregion
28
+ let node_path = require("node:path");
29
+ node_path = __toESM(node_path);
30
+ let node_url = require("node:url");
31
+ let node_fs_promises = require("node:fs/promises");
32
+ node_fs_promises = __toESM(node_fs_promises);
33
+ let tinyglobby = require("tinyglobby");
41
34
 
42
- // src/config/build.ts
35
+ //#region src/config/build.ts
36
+ /**
37
+ * @param config - either the default export or all exports of config file.
38
+ * @param workspace
39
+ */
43
40
  function buildConfig(config, workspace) {
44
- const collections = /* @__PURE__ */ new Map();
45
- const loaded = {};
46
- let globalConfig;
47
- if ("default" in config) {
48
- globalConfig = config.default;
49
- for (const [k, v] of Object.entries(config)) {
50
- if (k === "default") continue;
51
- globalConfig.collections ??= {};
52
- globalConfig.collections[k] = v;
53
- }
54
- } else {
55
- globalConfig = config;
56
- }
57
- if (globalConfig.collections) {
58
- for (const [name, collection] of Object.entries(globalConfig.collections)) {
59
- collection.init?.({ name, workspace });
60
- collections.set(name, collection);
61
- }
62
- }
63
- return {
64
- ...globalConfig,
65
- collections,
66
- workspaces: Object.fromEntries(
67
- Object.entries(loaded.workspaces ?? {}).map(([key, value]) => {
68
- return [
69
- key,
70
- {
71
- dir: value.dir,
72
- config: buildConfig(value.config, {
73
- ...value,
74
- name: key
75
- })
76
- }
77
- ];
78
- })
79
- )
80
- };
41
+ const collections = /* @__PURE__ */ new Map();
42
+ const loaded = {};
43
+ let globalConfig;
44
+ if ("default" in config) {
45
+ globalConfig = config.default;
46
+ for (const [k, v] of Object.entries(config)) {
47
+ if (k === "default") continue;
48
+ globalConfig.collections ??= {};
49
+ globalConfig.collections[k] = v;
50
+ }
51
+ } else globalConfig = config;
52
+ if (globalConfig.collections) for (const [name, collection] of Object.entries(globalConfig.collections)) {
53
+ collection.init?.({
54
+ name,
55
+ workspace
56
+ });
57
+ collections.set(name, collection);
58
+ }
59
+ return {
60
+ ...globalConfig,
61
+ collections,
62
+ workspaces: Object.fromEntries(Object.entries(loaded.workspaces ?? {}).map(([key, value]) => {
63
+ return [key, {
64
+ dir: value.dir,
65
+ config: buildConfig(value.config, {
66
+ ...value,
67
+ name: key
68
+ })
69
+ }];
70
+ }))
71
+ };
81
72
  }
82
73
 
83
- // src/config/load-from-file.ts
74
+ //#endregion
75
+ //#region src/config/load-from-file.ts
84
76
  async function compileConfig(core) {
85
- const { build } = await import("esbuild");
86
- const { configPath, outDir } = core.getOptions();
87
- const transformed = await build({
88
- entryPoints: [{ in: configPath, out: "content.config" }],
89
- bundle: true,
90
- outdir: outDir,
91
- target: "node20",
92
- write: true,
93
- platform: "node",
94
- format: "esm",
95
- packages: "external",
96
- outExtension: {
97
- ".js": ".mjs"
98
- },
99
- allowOverwrite: true
100
- });
101
- if (transformed.errors.length > 0) {
102
- throw new Error("failed to compile configuration file");
103
- }
77
+ const { build } = await import("esbuild");
78
+ const { configPath, outDir } = core.getOptions();
79
+ if ((await build({
80
+ entryPoints: [{
81
+ in: configPath,
82
+ out: "content.config"
83
+ }],
84
+ bundle: true,
85
+ outdir: outDir,
86
+ target: "node20",
87
+ write: true,
88
+ platform: "node",
89
+ format: "esm",
90
+ packages: "external",
91
+ outExtension: { ".js": ".mjs" },
92
+ allowOverwrite: true
93
+ })).errors.length > 0) throw new Error("failed to compile configuration file");
104
94
  }
95
+ /**
96
+ * Load config
97
+ *
98
+ * @param build - By default, it assumes the config file has been compiled. Set this `true` to compile the config first.
99
+ */
105
100
  async function loadConfig(core, build = false) {
106
- if (build) await compileConfig(core);
107
- const url = (0, import_node_url.pathToFileURL)(core.getCompiledConfigPath());
108
- url.searchParams.set("hash", Date.now().toString());
109
- const config = import(url.href).then(
110
- (loaded) => buildConfig(loaded)
111
- );
112
- return await config;
101
+ if (build) await compileConfig(core);
102
+ const url = (0, node_url.pathToFileURL)(core.getCompiledConfigPath());
103
+ url.searchParams.set("hash", Date.now().toString());
104
+ return await import(url.href).then((loaded) => buildConfig(loaded));
113
105
  }
114
106
 
115
- // src/core.ts
116
- var import_node_path2 = __toESM(require("path"), 1);
117
- var import_promises = __toESM(require("fs/promises"), 1);
118
-
119
- // src/utils/code-generator.ts
120
- var import_node_path = __toESM(require("path"), 1);
121
- var import_tinyglobby = require("tinyglobby");
122
-
123
- // src/utils/async-cache.ts
107
+ //#endregion
108
+ //#region src/utils/async-cache.ts
109
+ /**
110
+ * cache for async resources, finished promises will be resolved into original value, otherwise wrapped with a promise.
111
+ */
124
112
  function createCache(store = /* @__PURE__ */ new Map()) {
125
- return {
126
- cached(key, fn) {
127
- let cached = store.get(key);
128
- if (cached) return cached;
129
- cached = fn();
130
- if (cached instanceof Promise) {
131
- cached = cached.then((out) => {
132
- if (store.has(key)) {
133
- store.set(key, out);
134
- }
135
- return out;
136
- });
137
- }
138
- store.set(key, cached);
139
- return cached;
140
- },
141
- invalidate(key) {
142
- store.delete(key);
143
- },
144
- $value() {
145
- return this;
146
- }
147
- };
113
+ return {
114
+ cached(key, fn) {
115
+ let cached = store.get(key);
116
+ if (cached) return cached;
117
+ cached = fn();
118
+ if (cached instanceof Promise) cached = cached.then((out) => {
119
+ if (store.has(key)) store.set(key, out);
120
+ return out;
121
+ });
122
+ store.set(key, cached);
123
+ return cached;
124
+ },
125
+ invalidate(key) {
126
+ store.delete(key);
127
+ },
128
+ $value() {
129
+ return this;
130
+ }
131
+ };
148
132
  }
149
133
 
150
- // src/utils/code-generator.ts
134
+ //#endregion
135
+ //#region src/utils/code-generator.ts
151
136
  function importInfo() {
152
- return {
153
- named: /* @__PURE__ */ new Map(),
154
- namespaces: /* @__PURE__ */ new Set(),
155
- isUsed: /* @__PURE__ */ new Set()
156
- };
137
+ return {
138
+ named: /* @__PURE__ */ new Map(),
139
+ namespaces: /* @__PURE__ */ new Set(),
140
+ isUsed: /* @__PURE__ */ new Set()
141
+ };
157
142
  }
143
+ /**
144
+ * Code generator (one instance per file)
145
+ */
158
146
  var CodeGenerator = class {
159
- lines = [];
160
- globCache;
161
- // specifier -> imported members/info
162
- importInfos = /* @__PURE__ */ new Map();
163
- eagerImportId = 0;
164
- options;
165
- constructor({
166
- target = "default",
167
- jsExtension = false,
168
- globCache = /* @__PURE__ */ new Map(),
169
- outDir = ""
170
- }) {
171
- this.options = {
172
- target,
173
- jsExtension,
174
- globCache,
175
- outDir
176
- };
177
- this.globCache = createCache(globCache);
178
- }
179
- addNamespaceImport(namespace, specifier, types = false) {
180
- const info = this.importInfos.get(specifier) ?? importInfo();
181
- this.importInfos.set(specifier, info);
182
- if (!types) info.isUsed.add(namespace);
183
- info.namespaces.add(namespace);
184
- }
185
- addNamedImport(names, specifier, types = false) {
186
- const info = this.importInfos.get(specifier) ?? importInfo();
187
- this.importInfos.set(specifier, info);
188
- for (const name of names) {
189
- const [memberName, importName = memberName] = name.split(/\s+as\s+/, 2);
190
- info.named.set(importName, memberName);
191
- if (!types) info.isUsed.add(importName);
192
- }
193
- }
194
- push(...insert) {
195
- this.lines.push(...insert);
196
- }
197
- async pushAsync(insert) {
198
- for (const line of await Promise.all(insert)) {
199
- if (line === void 0) continue;
200
- this.lines.push(line);
201
- }
202
- }
203
- async generateGlobImport(patterns, options) {
204
- if (this.options.target === "vite") {
205
- return this.generateViteGlobImport(patterns, options);
206
- }
207
- return this.generateNodeGlobImport(patterns, options);
208
- }
209
- generateViteGlobImport(patterns, { base, ...rest }) {
210
- patterns = (typeof patterns === "string" ? [patterns] : patterns).map(
211
- normalizeViteGlobPath
212
- );
213
- return `import.meta.glob(${JSON.stringify(patterns)}, ${JSON.stringify(
214
- {
215
- base: normalizeViteGlobPath(import_node_path.default.relative(this.options.outDir, base)),
216
- ...rest
217
- },
218
- null,
219
- 2
220
- )})`;
221
- }
222
- async generateNodeGlobImport(patterns, { base, eager = false, query = {}, import: importName }) {
223
- const files = await this.globCache.cached(
224
- JSON.stringify({ patterns, base }),
225
- () => (0, import_tinyglobby.glob)(patterns, {
226
- cwd: base
227
- })
228
- );
229
- let code = "{";
230
- for (const item of files) {
231
- const fullPath = import_node_path.default.join(base, item);
232
- const searchParams = new URLSearchParams();
233
- for (const [k, v] of Object.entries(query)) {
234
- if (v !== void 0) searchParams.set(k, v);
235
- }
236
- const importPath = `${this.formatImportPath(fullPath)}?${searchParams.toString()}`;
237
- if (eager) {
238
- const name = `__fd_glob_${this.eagerImportId++}`;
239
- this.lines.unshift(
240
- importName ? `import { ${importName} as ${name} } from ${JSON.stringify(importPath)}` : `import * as ${name} from ${JSON.stringify(importPath)}`
241
- );
242
- code += `${JSON.stringify(item)}: ${name}, `;
243
- } else {
244
- let line = `${JSON.stringify(item)}: () => import(${JSON.stringify(importPath)})`;
245
- if (importName) {
246
- line += `.then(mod => mod.${importName})`;
247
- }
248
- code += `${line}, `;
249
- }
250
- }
251
- code += "}";
252
- return code;
253
- }
254
- formatImportPath(file) {
255
- const ext = import_node_path.default.extname(file);
256
- let filename;
257
- if (ext === ".ts") {
258
- filename = file.substring(0, file.length - ext.length);
259
- if (this.options.jsExtension) filename += ".js";
260
- } else {
261
- filename = file;
262
- }
263
- const importPath = slash(import_node_path.default.relative(this.options.outDir, filename));
264
- return importPath.startsWith(".") ? importPath : `./${importPath}`;
265
- }
266
- toString() {
267
- const final = ["// @ts-nocheck"];
268
- if (this.options.target === "vite") {
269
- final.push('/// <reference types="vite/client" />');
270
- }
271
- for (const [specifier, info] of this.importInfos) {
272
- const { namespaces, named, isUsed } = info;
273
- for (const namespace of namespaces) {
274
- final.push(
275
- isUsed.has(namespace) ? `import * as ${namespace} from "${specifier}";` : `import type * as ${namespace} from "${specifier}";`
276
- );
277
- }
278
- const namedImports = [];
279
- for (const [importName, memberName] of named) {
280
- const item = importName === memberName ? importName : `${memberName} as ${importName}`;
281
- namedImports.push(isUsed.has(importName) ? item : `type ${item}`);
282
- }
283
- if (namedImports.length > 0) {
284
- final.push(
285
- `import { ${namedImports.join(", ")} } from "${specifier}";`
286
- );
287
- }
288
- }
289
- final.push(...this.lines);
290
- return final.join("\n");
291
- }
147
+ lines = [];
148
+ globCache;
149
+ importInfos = /* @__PURE__ */ new Map();
150
+ eagerImportId = 0;
151
+ options;
152
+ constructor({ target = "default", jsExtension = false, globCache = /* @__PURE__ */ new Map(), outDir = "" }) {
153
+ this.options = {
154
+ target,
155
+ jsExtension,
156
+ globCache,
157
+ outDir
158
+ };
159
+ this.globCache = createCache(globCache);
160
+ }
161
+ addNamespaceImport(namespace, specifier, types = false) {
162
+ const info = this.importInfos.get(specifier) ?? importInfo();
163
+ this.importInfos.set(specifier, info);
164
+ if (!types) info.isUsed.add(namespace);
165
+ info.namespaces.add(namespace);
166
+ }
167
+ addNamedImport(names, specifier, types = false) {
168
+ const info = this.importInfos.get(specifier) ?? importInfo();
169
+ this.importInfos.set(specifier, info);
170
+ for (const name of names) {
171
+ const [memberName, importName = memberName] = name.split(/\s+as\s+/, 2);
172
+ info.named.set(importName, memberName);
173
+ if (!types) info.isUsed.add(importName);
174
+ }
175
+ }
176
+ push(...insert) {
177
+ this.lines.push(...insert);
178
+ }
179
+ async pushAsync(insert) {
180
+ for (const line of await Promise.all(insert)) {
181
+ if (line === void 0) continue;
182
+ this.lines.push(line);
183
+ }
184
+ }
185
+ async generateGlobImport(patterns, options) {
186
+ if (this.options.target === "vite") return this.generateViteGlobImport(patterns, options);
187
+ return this.generateNodeGlobImport(patterns, options);
188
+ }
189
+ generateViteGlobImport(patterns, { base, ...rest }) {
190
+ patterns = (typeof patterns === "string" ? [patterns] : patterns).map(normalizeViteGlobPath);
191
+ return `import.meta.glob(${JSON.stringify(patterns)}, ${JSON.stringify({
192
+ base: normalizeViteGlobPath(node_path.default.relative(this.options.outDir, base)),
193
+ ...rest
194
+ }, null, 2)})`;
195
+ }
196
+ async generateNodeGlobImport(patterns, { base, eager = false, query = {}, import: importName }) {
197
+ const files = await this.globCache.cached(JSON.stringify({
198
+ patterns,
199
+ base
200
+ }), () => (0, tinyglobby.glob)(patterns, { cwd: base }));
201
+ let code = "{";
202
+ for (const item of files) {
203
+ const fullPath = node_path.default.join(base, item);
204
+ const searchParams = new URLSearchParams();
205
+ for (const [k, v] of Object.entries(query)) if (v !== void 0) searchParams.set(k, v);
206
+ const importPath = `${this.formatImportPath(fullPath)}?${searchParams.toString()}`;
207
+ if (eager) {
208
+ const name = `__fd_glob_${this.eagerImportId++}`;
209
+ this.lines.unshift(importName ? `import { ${importName} as ${name} } from ${JSON.stringify(importPath)}` : `import * as ${name} from ${JSON.stringify(importPath)}`);
210
+ code += `${JSON.stringify(item)}: ${name}, `;
211
+ } else {
212
+ let line = `${JSON.stringify(item)}: () => import(${JSON.stringify(importPath)})`;
213
+ if (importName) line += `.then(mod => mod.${importName})`;
214
+ code += `${line}, `;
215
+ }
216
+ }
217
+ code += "}";
218
+ return code;
219
+ }
220
+ formatImportPath(file) {
221
+ const ext = node_path.default.extname(file);
222
+ let filename;
223
+ if (ext === ".ts") {
224
+ filename = file.substring(0, file.length - ext.length);
225
+ if (this.options.jsExtension) filename += ".js";
226
+ } else filename = file;
227
+ const importPath = slash(node_path.default.relative(this.options.outDir, filename));
228
+ return importPath.startsWith(".") ? importPath : `./${importPath}`;
229
+ }
230
+ toString() {
231
+ const final = ["// @ts-nocheck"];
232
+ if (this.options.target === "vite") final.push("/// <reference types=\"vite/client\" />");
233
+ for (const [specifier, info] of this.importInfos) {
234
+ const { namespaces, named, isUsed } = info;
235
+ for (const namespace of namespaces) final.push(isUsed.has(namespace) ? `import * as ${namespace} from "${specifier}";` : `import type * as ${namespace} from "${specifier}";`);
236
+ const namedImports = [];
237
+ for (const [importName, memberName] of named) {
238
+ const item = importName === memberName ? importName : `${memberName} as ${importName}`;
239
+ namedImports.push(isUsed.has(importName) ? item : `type ${item}`);
240
+ }
241
+ if (namedImports.length > 0) final.push(`import { ${namedImports.join(", ")} } from "${specifier}";`);
242
+ }
243
+ final.push(...this.lines);
244
+ return final.join("\n");
245
+ }
292
246
  };
247
+ /**
248
+ * convert into POSIX & relative file paths, such that Vite can accept it.
249
+ */
293
250
  function normalizeViteGlobPath(file) {
294
- file = slash(file);
295
- if (file.startsWith("./")) return file;
296
- if (file.startsWith("/")) return `.${file}`;
297
- return `./${file}`;
251
+ file = slash(file);
252
+ if (file.startsWith("./")) return file;
253
+ if (file.startsWith("/")) return `.${file}`;
254
+ return `./${file}`;
298
255
  }
299
- function slash(path4) {
300
- const isExtendedLengthPath = path4.startsWith("\\\\?\\");
301
- if (isExtendedLengthPath) {
302
- return path4;
303
- }
304
- return path4.replaceAll("\\", "/");
256
+ function slash(path$2) {
257
+ if (path$2.startsWith("\\\\?\\")) return path$2;
258
+ return path$2.replaceAll("\\", "/");
305
259
  }
306
260
 
307
- // src/core.ts
261
+ //#endregion
262
+ //#region src/core.ts
308
263
  async function getPlugins(pluginOptions) {
309
- const plugins = [];
310
- for (const option of await Promise.all(pluginOptions)) {
311
- if (!option) continue;
312
- if (Array.isArray(option)) plugins.push(...await getPlugins(option));
313
- else plugins.push(option);
314
- }
315
- return plugins;
264
+ const plugins = [];
265
+ for (const option of await Promise.all(pluginOptions)) {
266
+ if (!option) continue;
267
+ if (Array.isArray(option)) plugins.push(...await getPlugins(option));
268
+ else plugins.push(option);
269
+ }
270
+ return plugins;
316
271
  }
317
- var Core = class _Core {
318
- workspaces = /* @__PURE__ */ new Map();
319
- options;
320
- plugins = [];
321
- config;
322
- static defaultOptions = {
323
- configPath: "content.config.ts",
324
- outDir: ".content"
325
- };
326
- /**
327
- * Convenient cache store, reset when config changes.
328
- *
329
- * You can group namespaces in cache key with ":", like `my-plugin:data`
330
- */
331
- cache = /* @__PURE__ */ new Map();
332
- constructor(options) {
333
- this.options = options;
334
- }
335
- async init({ config: newConfig }) {
336
- this.config = await newConfig;
337
- this.cache.clear();
338
- this.workspaces.clear();
339
- const loadedCollectionTypeIds = /* @__PURE__ */ new Set();
340
- this.plugins = await getPlugins([
341
- this.options.plugins,
342
- this.config.plugins,
343
- ...this.config.collections.values().map(({ typeInfo }) => {
344
- if (loadedCollectionTypeIds.has(typeInfo.id)) return false;
345
- loadedCollectionTypeIds.add(typeInfo.id);
346
- return typeInfo.plugins;
347
- })
348
- ]);
349
- const ctx = this.getPluginContext();
350
- for (const plugin of this.plugins) {
351
- const out = await plugin.config?.call(ctx, this.config);
352
- if (out) this.config = out;
353
- }
354
- const { workspace, outDir } = this.options;
355
- if (!workspace) {
356
- await Promise.all(
357
- Object.entries(this.config.workspaces).map(
358
- async ([name, workspace2]) => {
359
- const child = new _Core({
360
- ...this.options,
361
- outDir: import_node_path2.default.join(outDir, name),
362
- workspace: {
363
- name,
364
- parent: this,
365
- dir: workspace2.dir
366
- }
367
- });
368
- await child.init({ config: workspace2.config });
369
- this.workspaces.set(name, child);
370
- }
371
- )
372
- );
373
- }
374
- await Promise.all(
375
- this.config.collections.values().map(async (collection) => {
376
- for (const plugin of this.plugins) {
377
- await plugin.collection?.call(ctx, collection);
378
- }
379
- })
380
- );
381
- }
382
- getWorkspaces() {
383
- return this.workspaces;
384
- }
385
- getOptions() {
386
- return this.options;
387
- }
388
- getConfig() {
389
- return this.config;
390
- }
391
- /**
392
- * The file path of compiled config file, the file may not exist (e.g. on Vite, or still compiling)
393
- */
394
- getCompiledConfigPath() {
395
- return import_node_path2.default.join(this.options.outDir, "content.config.mjs");
396
- }
397
- getPlugins(workspace = false) {
398
- if (workspace) {
399
- const plugins = [...this.plugins];
400
- for (const workspace2 of this.workspaces.values()) {
401
- plugins.push(...workspace2.plugins);
402
- }
403
- return plugins;
404
- }
405
- return this.plugins;
406
- }
407
- getCollections(workspace = false) {
408
- const list = Array.from(this.config.collections.values());
409
- if (workspace) {
410
- for (const workspace2 of this.workspaces.values()) {
411
- list.push(...workspace2.getCollections());
412
- }
413
- }
414
- return list;
415
- }
416
- getCollection(name) {
417
- return this.config.collections.get(name);
418
- }
419
- getPluginContext() {
420
- return {
421
- core: this
422
- };
423
- }
424
- async initServer(server) {
425
- const ctx = this.getPluginContext();
426
- const promises = [];
427
- for (const plugin of this.plugins) {
428
- promises.push(plugin.configureServer?.call(ctx, server));
429
- }
430
- for (const workspace of this.workspaces.values()) {
431
- promises.push(workspace.initServer(server));
432
- }
433
- await Promise.all(promises);
434
- }
435
- async emit(emitOptions = {}) {
436
- const {
437
- workspace,
438
- outDir,
439
- emit: { target, jsExtension } = {}
440
- } = this.options;
441
- const { filterPlugin, filterWorkspace, write = false } = emitOptions;
442
- const start = performance.now();
443
- const globCache = /* @__PURE__ */ new Map();
444
- const ctx = {
445
- ...this.getPluginContext(),
446
- createCodeGenerator: async (path4, content) => {
447
- const codegen = new CodeGenerator({
448
- target,
449
- outDir,
450
- jsExtension,
451
- globCache
452
- });
453
- await content({
454
- core: this,
455
- codegen,
456
- workspace: workspace?.name
457
- });
458
- return {
459
- path: path4,
460
- content: codegen.toString()
461
- };
462
- }
463
- };
464
- const added = /* @__PURE__ */ new Set();
465
- const out = {
466
- entries: [],
467
- workspaces: {}
468
- };
469
- for (const li of await Promise.all(
470
- this.plugins.map((plugin) => {
471
- if (filterPlugin && !filterPlugin(plugin) || !plugin.emit)
472
- return null;
473
- return plugin.emit.call(ctx);
474
- })
475
- )) {
476
- if (!li) continue;
477
- for (const item of li) {
478
- if (added.has(item.path)) continue;
479
- out.entries.push(item);
480
- added.add(item.path);
481
- }
482
- }
483
- if (write) {
484
- await Promise.all(
485
- out.entries.map(async (entry) => {
486
- const file = import_node_path2.default.join(outDir, entry.path);
487
- await import_promises.default.mkdir(import_node_path2.default.dirname(file), { recursive: true });
488
- await import_promises.default.writeFile(file, entry.content);
489
- })
490
- );
491
- console.log(
492
- workspace ? `[MDX: ${workspace.name}] generated files in ${performance.now() - start}ms` : `[MDX] generated files in ${performance.now() - start}ms`
493
- );
494
- }
495
- await Promise.all(
496
- this.workspaces.entries().map(async ([name, workspace2]) => {
497
- if (filterWorkspace && !filterWorkspace(name)) return;
498
- out.workspaces[name] = (await workspace2.emit(emitOptions)).entries;
499
- })
500
- );
501
- return out;
502
- }
272
+ var Core = class Core {
273
+ workspaces = /* @__PURE__ */ new Map();
274
+ options;
275
+ plugins = [];
276
+ config;
277
+ static defaultOptions = {
278
+ configPath: "content.config.ts",
279
+ outDir: ".content"
280
+ };
281
+ /**
282
+ * Convenient cache store, reset when config changes.
283
+ *
284
+ * You can group namespaces in cache key with ":", like `my-plugin:data`
285
+ */
286
+ cache = /* @__PURE__ */ new Map();
287
+ constructor(options) {
288
+ this.options = options;
289
+ }
290
+ async init({ config: newConfig }) {
291
+ this.config = await newConfig;
292
+ this.cache.clear();
293
+ this.workspaces.clear();
294
+ const loadedCollectionTypeIds = /* @__PURE__ */ new Set();
295
+ this.plugins = await getPlugins([
296
+ this.options.plugins,
297
+ this.config.plugins,
298
+ ...this.config.collections.values().map(({ typeInfo }) => {
299
+ if (loadedCollectionTypeIds.has(typeInfo.id)) return false;
300
+ loadedCollectionTypeIds.add(typeInfo.id);
301
+ return typeInfo.plugins;
302
+ })
303
+ ]);
304
+ const ctx = this.getPluginContext();
305
+ for (const plugin of this.plugins) {
306
+ const out = await plugin.config?.call(ctx, this.config);
307
+ if (out) this.config = out;
308
+ }
309
+ const { workspace, outDir } = this.options;
310
+ if (!workspace) await Promise.all(Object.entries(this.config.workspaces).map(async ([name, workspace$1]) => {
311
+ const child = new Core({
312
+ ...this.options,
313
+ outDir: node_path.default.join(outDir, name),
314
+ workspace: {
315
+ name,
316
+ parent: this,
317
+ dir: workspace$1.dir
318
+ }
319
+ });
320
+ await child.init({ config: workspace$1.config });
321
+ this.workspaces.set(name, child);
322
+ }));
323
+ await Promise.all(this.config.collections.values().map(async (collection) => {
324
+ for (const plugin of this.plugins) await plugin.collection?.call(ctx, collection);
325
+ }));
326
+ }
327
+ getWorkspaces() {
328
+ return this.workspaces;
329
+ }
330
+ getOptions() {
331
+ return this.options;
332
+ }
333
+ getConfig() {
334
+ return this.config;
335
+ }
336
+ /**
337
+ * The file path of compiled config file, the file may not exist (e.g. on Vite, or still compiling)
338
+ */
339
+ getCompiledConfigPath() {
340
+ return node_path.default.join(this.options.outDir, "content.config.mjs");
341
+ }
342
+ getPlugins(workspace = false) {
343
+ if (workspace) {
344
+ const plugins = [...this.plugins];
345
+ for (const workspace$1 of this.workspaces.values()) plugins.push(...workspace$1.plugins);
346
+ return plugins;
347
+ }
348
+ return this.plugins;
349
+ }
350
+ getCollections(workspace = false) {
351
+ const list = Array.from(this.config.collections.values());
352
+ if (workspace) for (const workspace$1 of this.workspaces.values()) list.push(...workspace$1.getCollections());
353
+ return list;
354
+ }
355
+ getCollection(name) {
356
+ return this.config.collections.get(name);
357
+ }
358
+ getPluginContext() {
359
+ return { core: this };
360
+ }
361
+ async initServer(server) {
362
+ const ctx = this.getPluginContext();
363
+ const promises = [];
364
+ for (const plugin of this.plugins) promises.push(plugin.configureServer?.call(ctx, server));
365
+ for (const workspace of this.workspaces.values()) promises.push(workspace.initServer(server));
366
+ await Promise.all(promises);
367
+ }
368
+ async emit(emitOptions = {}) {
369
+ const { workspace, outDir, emit: { target, jsExtension } = {} } = this.options;
370
+ const { filterPlugin, filterWorkspace, write = false } = emitOptions;
371
+ const start = performance.now();
372
+ const globCache = /* @__PURE__ */ new Map();
373
+ const ctx = {
374
+ ...this.getPluginContext(),
375
+ createCodeGenerator: async (path$2, content) => {
376
+ const codegen = new CodeGenerator({
377
+ target,
378
+ outDir,
379
+ jsExtension,
380
+ globCache
381
+ });
382
+ await content({
383
+ core: this,
384
+ codegen,
385
+ workspace: workspace?.name
386
+ });
387
+ return {
388
+ path: path$2,
389
+ content: codegen.toString()
390
+ };
391
+ }
392
+ };
393
+ const added = /* @__PURE__ */ new Set();
394
+ const out = {
395
+ entries: [],
396
+ workspaces: {}
397
+ };
398
+ for (const li of await Promise.all(this.plugins.map((plugin) => {
399
+ if (filterPlugin && !filterPlugin(plugin) || !plugin.emit) return null;
400
+ return plugin.emit.call(ctx);
401
+ }))) {
402
+ if (!li) continue;
403
+ for (const item of li) {
404
+ if (added.has(item.path)) continue;
405
+ out.entries.push(item);
406
+ added.add(item.path);
407
+ }
408
+ }
409
+ if (write) {
410
+ await Promise.all(out.entries.map(async (entry) => {
411
+ const file = node_path.default.join(outDir, entry.path);
412
+ await node_fs_promises.default.mkdir(node_path.default.dirname(file), { recursive: true });
413
+ await node_fs_promises.default.writeFile(file, entry.content);
414
+ }));
415
+ console.log(workspace ? `[MDX: ${workspace.name}] generated files in ${performance.now() - start}ms` : `[MDX] generated files in ${performance.now() - start}ms`);
416
+ }
417
+ await Promise.all(this.workspaces.entries().map(async ([name, workspace$1]) => {
418
+ if (filterWorkspace && !filterWorkspace(name)) return;
419
+ out.workspaces[name] = (await workspace$1.emit(emitOptions)).entries;
420
+ }));
421
+ return out;
422
+ }
503
423
  };
504
424
 
505
- // src/next/index.ts
425
+ //#endregion
426
+ //#region src/next/index.ts
506
427
  async function createContent(nextOptions = {}) {
507
- const core = createNextCore(applyDefaults(nextOptions));
508
- await core.init({
509
- config: loadConfig(core, true)
510
- });
511
- if (process.env._FUMADOCS_MDX !== "1") {
512
- process.env._FUMADOCS_MDX = "1";
513
- await core.emit({ write: true });
514
- await init(process.env.NODE_ENV === "development", core);
515
- }
516
- return (nextConfig = {}) => {
517
- const ctx = core.getPluginContext();
518
- for (const plugin of core.getPlugins(true)) {
519
- nextConfig = plugin.next?.config?.call(ctx, nextConfig) ?? nextConfig;
520
- }
521
- return nextConfig;
522
- };
428
+ const core = createNextCore(applyDefaults(nextOptions));
429
+ await core.init({ config: loadConfig(core, true) });
430
+ if (process.env._FUMADOCS_MDX !== "1") {
431
+ process.env._FUMADOCS_MDX = "1";
432
+ await core.emit({ write: true });
433
+ await init(process.env.NODE_ENV === "development", core);
434
+ }
435
+ return (nextConfig = {}) => {
436
+ const ctx = core.getPluginContext();
437
+ for (const plugin of core.getPlugins(true)) nextConfig = plugin.next?.config?.call(ctx, nextConfig) ?? nextConfig;
438
+ return nextConfig;
439
+ };
523
440
  }
524
441
  async function init(dev, core) {
525
- if (!dev) return;
526
- const { FSWatcher } = await import("chokidar");
527
- const { configPath, outDir } = core.getOptions();
528
- const absoluteConfigPath = path3.resolve(configPath);
529
- let watcher;
530
- async function devServer() {
531
- if (watcher && !watcher.closed) {
532
- await watcher.close();
533
- }
534
- watcher = new FSWatcher({
535
- ignoreInitial: true,
536
- persistent: true,
537
- ignored: [outDir]
538
- });
539
- watcher.add(configPath);
540
- for (const collection of core.getCollections(true)) {
541
- const handler = collection.handlers.fs;
542
- if (handler) {
543
- watcher.add(handler.dir);
544
- }
545
- }
546
- watcher.once("ready", () => {
547
- console.log("[MDX] started dev server");
548
- });
549
- watcher.on("all", (_event, file) => {
550
- if (path3.resolve(file) === absoluteConfigPath) {
551
- console.log("[MDX] restarting dev server");
552
- watcher?.removeAllListeners();
553
- void (async () => {
554
- await core.init({
555
- config: loadConfig(core, true)
556
- });
557
- await devServer();
558
- await core.emit({ write: true });
559
- })();
560
- }
561
- });
562
- await core.initServer({ watcher });
563
- }
564
- process.on("exit", () => {
565
- if (!watcher || watcher.closed) return;
566
- console.log("[MDX] closing dev server");
567
- void watcher.close();
568
- });
569
- await devServer();
442
+ if (!dev) return;
443
+ const { FSWatcher } = await import("chokidar");
444
+ const { configPath, outDir } = core.getOptions();
445
+ const absoluteConfigPath = node_path.resolve(configPath);
446
+ let watcher;
447
+ async function devServer() {
448
+ if (watcher && !watcher.closed) await watcher.close();
449
+ watcher = new FSWatcher({
450
+ ignoreInitial: true,
451
+ persistent: true,
452
+ ignored: [outDir]
453
+ });
454
+ watcher.add(configPath);
455
+ for (const collection of core.getCollections(true)) {
456
+ const handler = collection.handlers.fs;
457
+ if (handler) watcher.add(handler.dir);
458
+ }
459
+ watcher.once("ready", () => {
460
+ console.log("[MDX] started dev server");
461
+ });
462
+ watcher.on("all", (_event, file) => {
463
+ if (node_path.resolve(file) === absoluteConfigPath) {
464
+ console.log("[MDX] restarting dev server");
465
+ watcher?.removeAllListeners();
466
+ (async () => {
467
+ await core.init({ config: loadConfig(core, true) });
468
+ await devServer();
469
+ await core.emit({ write: true });
470
+ })();
471
+ }
472
+ });
473
+ await core.initServer({ watcher });
474
+ }
475
+ process.on("exit", () => {
476
+ if (!watcher || watcher.closed) return;
477
+ console.log("[MDX] closing dev server");
478
+ watcher.close();
479
+ });
480
+ await devServer();
570
481
  }
571
482
  async function createStandaloneCore(options) {
572
- const core = createNextCore(applyDefaults(options));
573
- await core.init({
574
- config: loadConfig(core, true)
575
- });
576
- return core;
483
+ const core = createNextCore(applyDefaults(options));
484
+ await core.init({ config: loadConfig(core, true) });
485
+ return core;
577
486
  }
578
487
  function applyDefaults(options) {
579
- return {
580
- outDir: options.outDir ?? Core.defaultOptions.outDir,
581
- configPath: options.configPath ?? Core.defaultOptions.configPath
582
- };
488
+ return {
489
+ outDir: options.outDir ?? Core.defaultOptions.outDir,
490
+ configPath: options.configPath ?? Core.defaultOptions.configPath
491
+ };
583
492
  }
584
493
  function createNextCore(options) {
585
- return new Core({
586
- outDir: options.outDir,
587
- configPath: options.configPath
588
- });
494
+ return new Core({
495
+ outDir: options.outDir,
496
+ configPath: options.configPath
497
+ });
589
498
  }
590
- // Annotate the CommonJS export names for ESM import in node:
591
- 0 && (module.exports = {
592
- createContent,
593
- createStandaloneCore
594
- });
499
+
500
+ //#endregion
501
+ exports.createContent = createContent;
502
+ exports.createStandaloneCore = createStandaloneCore;