obsidian-dev-utils 1.7.7 → 2.0.0
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/CHANGELOG.md +10 -0
- package/dist/lib/@types/compare-versions.d.ts +37 -0
- package/dist/lib/JSON.cjs +2 -5
- package/dist/lib/Npm.cjs +1 -1
- package/dist/lib/Npm.d.ts +1 -0
- package/dist/lib/Root.cjs +4 -13
- package/dist/lib/Root.d.ts +0 -9
- package/dist/lib/_dependencies.cjs +49643 -0
- package/dist/lib/_dependencies.d.ts +6 -0
- package/dist/lib/bin/ESLint/@types/@stylistic__eslint-plugin.d.ts +16 -0
- package/dist/lib/bin/ESLint/@types/@typescript-eslint__eslint-plugin.d.ts +27 -0
- package/dist/lib/bin/ESLint/@types/@typescript-eslint__parser.d.ts +16 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-deprecation.d.ts +17 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-import.d.ts +15 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-modules-newlines.d.ts +15 -0
- package/dist/lib/bin/ESLint/@types/globals.d.ts +22 -0
- package/dist/lib/bin/ESLint/ESLint.cjs +5 -6
- package/dist/lib/bin/ESLint/eslint.config.cjs +4 -2
- package/dist/lib/bin/ObsidianDevUtilsRepoPaths.cjs +2 -1
- package/dist/lib/bin/ObsidianDevUtilsRepoPaths.d.ts +2 -0
- package/dist/lib/bin/cli.cjs +2 -2
- package/dist/lib/bin/esbuild/Dependency.cjs +125 -0
- package/dist/lib/bin/esbuild/Dependency.d.ts +18 -0
- package/dist/lib/bin/esbuild/ObsidianPluginBuilder.cjs +1 -1
- package/dist/lib/bin/esbuild/index.cjs +4 -1
- package/dist/lib/bin/esbuild/index.d.ts +1 -0
- package/dist/lib/bin/esbuild/renameToCjsPlugin.cjs +15 -3
- package/dist/lib/bin/esbuild/renameToCjsPlugin.d.ts +2 -1
- package/dist/lib/bin/spellcheck.cjs +3 -4
- package/dist/lib/bin/version.cjs +13 -1
- package/dist/lib/obsidian/@types/Dataview/api/data-array.d.ts +134 -0
- package/dist/lib/obsidian/@types/Dataview/api/extensions.d.ts +15 -0
- package/dist/lib/obsidian/@types/Dataview/api/inline-api.d.ts +165 -0
- package/dist/lib/obsidian/@types/Dataview/api/plugin-api.d.ts +192 -0
- package/dist/lib/obsidian/@types/Dataview/api/result.d.ts +38 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/common.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/csv.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/inline-field.d.ts +42 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/markdown-file.d.ts +36 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/persister.d.ts +32 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-entry.d.ts +1 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-impl.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-manager.d.ts +32 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/index.d.ts +179 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/resolver.d.ts +20 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/source.d.ts +71 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/markdown.d.ts +109 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/serialized/markdown.d.ts +103 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/transferable.d.ts +7 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/value.d.ts +148 -0
- package/dist/lib/obsidian/@types/Dataview/expression/binaryop.d.ts +29 -0
- package/dist/lib/obsidian/@types/Dataview/expression/context.d.ts +43 -0
- package/dist/lib/obsidian/@types/Dataview/expression/field.d.ts +82 -0
- package/dist/lib/obsidian/@types/Dataview/expression/functions.d.ts +137 -0
- package/dist/lib/obsidian/@types/Dataview/expression/parse.d.ts +143 -0
- package/dist/lib/obsidian/@types/Dataview/index.d.ts +21 -0
- package/dist/lib/obsidian/@types/Dataview/main.d.ts +44 -0
- package/dist/lib/obsidian/@types/Dataview/query/engine.d.ts +87 -0
- package/dist/lib/obsidian/@types/Dataview/query/parse.d.ts +31 -0
- package/dist/lib/obsidian/@types/Dataview/query/query.d.ts +95 -0
- package/dist/lib/obsidian/@types/Dataview/settings.d.ts +60 -0
- package/dist/lib/obsidian/@types/Dataview/typings/obsidian-ex.d.ts +28 -0
- package/dist/lib/obsidian/@types/Dataview/typings/workers.d.ts +4 -0
- package/dist/lib/obsidian/@types/Dataview/ui/export/markdown.d.ts +9 -0
- package/dist/lib/obsidian/@types/Dataview/ui/lp-render.d.ts +24 -0
- package/dist/lib/obsidian/@types/Dataview/ui/markdown.d.ts +73 -0
- package/dist/lib/obsidian/@types/Dataview/ui/refreshable-view.d.ts +15 -0
- package/dist/lib/obsidian/@types/Dataview/ui/render.d.ts +12 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/calendar-view.d.ts +17 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/inline-field-live-preview.d.ts +29 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/inline-view.d.ts +19 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/js-view.d.ts +23 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/list-view.d.ts +25 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/table-view.d.ts +28 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/task-view.d.ts +39 -0
- package/dist/lib/obsidian/@types/Dataview/util/hash.d.ts +1 -0
- package/dist/lib/obsidian/@types/Dataview/util/locale.d.ts +2 -0
- package/dist/lib/obsidian/@types/Dataview/util/media.d.ts +6 -0
- package/dist/lib/obsidian/@types/Dataview/util/normalize.d.ts +41 -0
- package/dist/lib/obsidian/Dataview.cjs +1 -1
- package/dist/lib/obsidian/Dataview.d.ts +2 -2
- package/package.json +156 -14
|
@@ -27,13 +27,18 @@ __export(renameToCjsPlugin_exports, {
|
|
|
27
27
|
});
|
|
28
28
|
module.exports = __toCommonJS(renameToCjsPlugin_exports);
|
|
29
29
|
var import_promises = require("node:fs/promises");
|
|
30
|
+
var import_String = require("../../String.cjs");
|
|
31
|
+
var import_Path = require("../../Path.cjs");
|
|
32
|
+
var import_Root = require("../../Root.cjs");
|
|
33
|
+
var import_ObsidianDevUtilsRepoPaths = require("../ObsidianDevUtilsRepoPaths.cjs");
|
|
30
34
|
var __import_meta_url = globalThis["import.meta.url"] ?? (() => require("node:url").pathToFileURL(__filename))();
|
|
31
35
|
var __process = globalThis["process"] ?? {
|
|
32
36
|
"cwd": () => "/",
|
|
33
37
|
"env": {},
|
|
34
38
|
"platform": "android"
|
|
35
39
|
};
|
|
36
|
-
function renameToCjsPlugin() {
|
|
40
|
+
function renameToCjsPlugin(dependenciesToSkip) {
|
|
41
|
+
const dependenciesPath = (0, import_Root.resolvePathFromRoot)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.DistLibDependenciesCjs);
|
|
37
42
|
return {
|
|
38
43
|
name: "rename-to-cjs",
|
|
39
44
|
setup(build) {
|
|
@@ -44,8 +49,15 @@ function renameToCjsPlugin() {
|
|
|
44
49
|
}
|
|
45
50
|
const newPath = file.path.replaceAll(/\.js$/g, ".cjs");
|
|
46
51
|
const newText = file.text.replaceAll(/require\("(.+?)"\)/g, (_, importPath) => {
|
|
52
|
+
const importPath1 = (0, import_String.trimStart)(importPath, "node:");
|
|
53
|
+
const importPath2 = importPath1.split("/")[0];
|
|
54
|
+
if (importPath[0] !== "." && !dependenciesToSkip.has(importPath1) && !dependenciesToSkip.has(importPath2)) {
|
|
55
|
+
const relativeDependenciesPath = (0, import_Path.normalizeIfRelative)((0, import_Path.relative)((0, import_Path.dirname)((0, import_Path.toPosixPath)(file.path)), dependenciesPath));
|
|
56
|
+
const importPathVariable = (0, import_String.makeValidVariableName)(importPath);
|
|
57
|
+
return `require("./../../_dependencies.cjs").__relativeDependenciesPath_.default ?? require("./../../_dependencies.cjs").__relativeDependenciesPath_.${importPathVariable}.default ?? require("./../../_dependencies.cjs").__relativeDependenciesPath_.default ?? require("./../../_dependencies.cjs").__relativeDependenciesPath_.${importPathVariable}`;
|
|
58
|
+
}
|
|
47
59
|
const cjsImportPath = importPath.replaceAll(/\.ts$/g, ".cjs");
|
|
48
|
-
return `require("
|
|
60
|
+
return `require("./../../_dependencies.cjs").__cjsImportPath_.default ?? require("./../../_dependencies.cjs").__cjsImportPath_`;
|
|
49
61
|
});
|
|
50
62
|
await (0, import_promises.writeFile)(newPath, newText);
|
|
51
63
|
}
|
|
@@ -57,4 +69,4 @@ function renameToCjsPlugin() {
|
|
|
57
69
|
0 && (module.exports = {
|
|
58
70
|
renameToCjsPlugin
|
|
59
71
|
});
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL2Jpbi9lc2J1aWxkL3JlbmFtZVRvQ2pzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19pbXBvcnRfbWV0YV91cmwgPSBnbG9iYWxUaGlzW1wiaW1wb3J0Lm1ldGEudXJsXCJdID8/ICgoKT0+cmVxdWlyZShcIm5vZGU6dXJsXCIpLnBhdGhUb0ZpbGVVUkwoX19maWxlbmFtZSkpKCk7XG52YXIgX19wcm9jZXNzID0gZ2xvYmFsVGhpc1tcInByb2Nlc3NcIl0gPz8ge1xuICBcImN3ZFwiOiAoKT0+
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL2Jpbi9lc2J1aWxkL3JlbmFtZVRvQ2pzUGx1Z2luLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19pbXBvcnRfbWV0YV91cmwgPSBnbG9iYWxUaGlzW1wiaW1wb3J0Lm1ldGEudXJsXCJdID8/ICgoKT0+cmVxdWlyZShcIm5vZGU6dXJsXCIpLnBhdGhUb0ZpbGVVUkwoX19maWxlbmFtZSkpKCk7XG52YXIgX19wcm9jZXNzID0gZ2xvYmFsVGhpc1tcInByb2Nlc3NcIl0gPz8ge1xuICBcImN3ZFwiOiAoKT0+XCIvXCIsXG4gIFwiZW52XCI6IHt9LFxuICBcInBsYXRmb3JtXCI6IFwiYW5kcm9pZFwiXG59O1xuLyoqXG4gKiBAZmlsZVxuICogVGhpcyBtb2R1bGUgZGVmaW5lcyBhbiBlc2J1aWxkIHBsdWdpbiB0aGF0IHJlbmFtZXMgSmF2YVNjcmlwdCBmaWxlcyB0byBDb21tb25KUyAoYC5janNgKSBmaWxlcyBhZnRlciB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqIEl0IGFsc28gYWRqdXN0cyB0aGUgYHJlcXVpcmVgIHN0YXRlbWVudHMgdG8gZW5zdXJlIGNvbXBhdGliaWxpdHkgd2l0aCB0aGUgQ29tbW9uSlMgZm9ybWF0LCBwYXJ0aWN1bGFybHkgd2hlbiBkZWFsaW5nXG4gKiB3aXRoIGRlcGVuZGVuY2llcyB0aGF0IGFyZSBub3QgdG8gYmUgc2tpcHBlZC5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gXCJlc2J1aWxkXCI7XG5pbXBvcnQgeyB3cml0ZUZpbGUgfSBmcm9tIFwibm9kZTpmcy9wcm9taXNlc1wiO1xuaW1wb3J0IHtcbiAgbWFrZVZhbGlkVmFyaWFibGVOYW1lLFxuICB0cmltU3RhcnRcbn0gZnJvbSBcIi4uLy4uL1N0cmluZy50c1wiO1xuaW1wb3J0IHtcbiAgZGlybmFtZSxcbiAgbm9ybWFsaXplSWZSZWxhdGl2ZSxcbiAgcmVsYXRpdmUsXG4gIHRvUG9zaXhQYXRoXG59IGZyb20gXCIuLi8uLi9QYXRoLnRzXCI7XG5pbXBvcnQgeyByZXNvbHZlUGF0aEZyb21Sb290IH0gZnJvbSBcIi4uLy4uL1Jvb3QudHNcIjtcbmltcG9ydCB7IE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMgfSBmcm9tIFwiLi4vT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50c1wiO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gZXNidWlsZCBwbHVnaW4gdGhhdCByZW5hbWVzIEphdmFTY3JpcHQgZmlsZXMgdG8gQ29tbW9uSlMgKGAuY2pzYCkgZmlsZXNcbiAqIGFuZCBtb2RpZmllcyBgcmVxdWlyZWAgc3RhdGVtZW50cyB0byBlbnN1cmUgcHJvcGVyIG1vZHVsZSByZXNvbHV0aW9uLlxuICpcbiAqIEBwYXJhbSBkZXBlbmRlbmNpZXNUb1NraXAgLSBBIHNldCBvZiBkZXBlbmRlbmNpZXMgdGhhdCBzaG91bGQgbm90IGJlIGJ1bmRsZWQuXG4gKiBAcmV0dXJucyBBbiBlc2J1aWxkIGBQbHVnaW5gIG9iamVjdCB0aGF0IGhhbmRsZXMgdGhlIHJlbmFtaW5nIGFuZCBtb2RpZmljYXRpb24gb2Ygb3V0cHV0IGZpbGVzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuYW1lVG9DanNQbHVnaW4oZGVwZW5kZW5jaWVzVG9Ta2lwOiBTZXQ8c3RyaW5nPik6IFBsdWdpbiB7XG4gIGNvbnN0IGRlcGVuZGVuY2llc1BhdGggPSByZXNvbHZlUGF0aEZyb21Sb290KE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuRGlzdExpYkRlcGVuZGVuY2llc0Nqcyk7XG4gIHJldHVybiB7XG4gICAgbmFtZTogXCJyZW5hbWUtdG8tY2pzXCIsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jIChyZXN1bHQpID0+IHtcbiAgICAgICAgZm9yIChjb25zdCBmaWxlIG9mIHJlc3VsdC5vdXRwdXRGaWxlcyA/PyBbXSkge1xuICAgICAgICAgIGlmICghZmlsZS5wYXRoLmVuZHNXaXRoKFwiLmpzXCIpIHx8IGZpbGUucGF0aC5lbmRzV2l0aChcIi5kLmpzXCIpKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCBuZXdQYXRoID0gZmlsZS5wYXRoLnJlcGxhY2VBbGwoL1xcLmpzJC9nLCBcIi5janNcIik7XG5cbiAgICAgICAgICBjb25zdCBuZXdUZXh0ID0gZmlsZS50ZXh0LnJlcGxhY2VBbGwoL3JlcXVpcmVcXChcIiguKz8pXCJcXCkvZywgKF8sIGltcG9ydFBhdGg6IHN0cmluZykgPT4ge1xuICAgICAgICAgICAgY29uc3QgaW1wb3J0UGF0aDEgPSB0cmltU3RhcnQoaW1wb3J0UGF0aCwgXCJub2RlOlwiKTtcbiAgICAgICAgICAgIGNvbnN0IGltcG9ydFBhdGgyID0gaW1wb3J0UGF0aDEuc3BsaXQoXCIvXCIpWzBdITtcblxuICAgICAgICAgICAgaWYgKGltcG9ydFBhdGhbMF0gIT09IFwiLlwiICYmICFkZXBlbmRlbmNpZXNUb1NraXAuaGFzKGltcG9ydFBhdGgxKSAmJiAhZGVwZW5kZW5jaWVzVG9Ta2lwLmhhcyhpbXBvcnRQYXRoMikpIHtcbiAgICAgICAgICAgICAgY29uc3QgcmVsYXRpdmVEZXBlbmRlbmNpZXNQYXRoID0gbm9ybWFsaXplSWZSZWxhdGl2ZShyZWxhdGl2ZShkaXJuYW1lKHRvUG9zaXhQYXRoKGZpbGUucGF0aCkpLCBkZXBlbmRlbmNpZXNQYXRoKSk7XG4gICAgICAgICAgICAgIGNvbnN0IGltcG9ydFBhdGhWYXJpYWJsZSA9IG1ha2VWYWxpZFZhcmlhYmxlTmFtZShpbXBvcnRQYXRoKTtcbiAgICAgICAgICAgICAgcmV0dXJuIGByZXF1aXJlKFwiJHtyZWxhdGl2ZURlcGVuZGVuY2llc1BhdGh9XCIpLiR7aW1wb3J0UGF0aFZhcmlhYmxlfS5kZWZhdWx0ID8/IHJlcXVpcmUoXCIke3JlbGF0aXZlRGVwZW5kZW5jaWVzUGF0aH1cIikuJHtpbXBvcnRQYXRoVmFyaWFibGV9YDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgY2pzSW1wb3J0UGF0aCA9IGltcG9ydFBhdGgucmVwbGFjZUFsbCgvXFwudHMkL2csIFwiLmNqc1wiKTtcbiAgICAgICAgICAgIHJldHVybiBgcmVxdWlyZShcIiR7Y2pzSW1wb3J0UGF0aH1cIilgO1xuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKG5ld1BhdGgsIG5ld1RleHQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFjQSxzQkFBMEI7QUFDMUIsb0JBR087QUFDUCxrQkFLTztBQUNQLGtCQUFvQztBQUNwQyx1Q0FBMEM7QUExQjFDLElBQUksb0JBQW9CLFdBQVcsaUJBQWlCLE1BQU0sTUFBSSxRQUFRLFVBQVUsRUFBRSxjQUFjLFVBQVUsR0FBRztBQUM3RyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBOEJPLFNBQVMsa0JBQWtCLG9CQUF5QztBQUN6RSxRQUFNLHVCQUFtQixpQ0FBb0IsMkRBQTBCLHNCQUFzQjtBQUM3RixTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLE9BQU8sV0FBVztBQUM1QixtQkFBVyxRQUFRLE9BQU8sZUFBZSxDQUFDLEdBQUc7QUFDM0MsY0FBSSxDQUFDLEtBQUssS0FBSyxTQUFTLEtBQUssS0FBSyxLQUFLLEtBQUssU0FBUyxPQUFPLEdBQUc7QUFDN0Q7QUFBQSxVQUNGO0FBRUEsZ0JBQU0sVUFBVSxLQUFLLEtBQUssV0FBVyxVQUFVLE1BQU07QUFFckQsZ0JBQU0sVUFBVSxLQUFLLEtBQUssV0FBVyx1QkFBdUIsQ0FBQyxHQUFHLGVBQXVCO0FBQ3JGLGtCQUFNLGtCQUFjLHlCQUFVLFlBQVksT0FBTztBQUNqRCxrQkFBTSxjQUFjLFlBQVksTUFBTSxHQUFHLEVBQUUsQ0FBQztBQUU1QyxnQkFBSSxXQUFXLENBQUMsTUFBTSxPQUFPLENBQUMsbUJBQW1CLElBQUksV0FBVyxLQUFLLENBQUMsbUJBQW1CLElBQUksV0FBVyxHQUFHO0FBQ3pHLG9CQUFNLCtCQUEyQixxQ0FBb0IsMEJBQVMseUJBQVEseUJBQVksS0FBSyxJQUFJLENBQUMsR0FBRyxnQkFBZ0IsQ0FBQztBQUNoSCxvQkFBTSx5QkFBcUIscUNBQXNCLFVBQVU7QUFDM0QscUJBQU8sWUFBWSx3QkFBd0IsTUFBTSxrQkFBa0Isd0JBQXdCLHdCQUF3QixNQUFNLGtCQUFrQjtBQUFBLFlBQzdJO0FBRUEsa0JBQU0sZ0JBQWdCLFdBQVcsV0FBVyxVQUFVLE1BQU07QUFDNUQsbUJBQU8sWUFBWSxhQUFhO0FBQUEsVUFDbEMsQ0FBQztBQUVELG9CQUFNLDJCQUFVLFNBQVMsT0FBTztBQUFBLFFBQ2xDO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -9,6 +9,7 @@ import type { Plugin } from "esbuild";
|
|
|
9
9
|
* Creates an esbuild plugin that renames JavaScript files to CommonJS (`.cjs`) files
|
|
10
10
|
* and modifies `require` statements to ensure proper module resolution.
|
|
11
11
|
*
|
|
12
|
+
* @param dependenciesToSkip - A set of dependencies that should not be bundled.
|
|
12
13
|
* @returns An esbuild `Plugin` object that handles the renaming and modification of output files.
|
|
13
14
|
*/
|
|
14
|
-
export declare function renameToCjsPlugin(): Plugin;
|
|
15
|
+
export declare function renameToCjsPlugin(dependenciesToSkip: Set<string>): Plugin;
|
|
@@ -26,11 +26,10 @@ __export(spellcheck_exports, {
|
|
|
26
26
|
spellcheck: () => spellcheck
|
|
27
27
|
});
|
|
28
28
|
module.exports = __toCommonJS(spellcheck_exports);
|
|
29
|
-
var import_cspell = require("cspell");
|
|
29
|
+
var import_cspell = require("./../_dependencies.cjs").cspell.default ?? require("./../_dependencies.cjs").cspell;
|
|
30
30
|
var import_Root = require("../Root.cjs");
|
|
31
31
|
var import_node_url = require("node:url");
|
|
32
32
|
var import_TaskResult = require("../TaskResult.cjs");
|
|
33
|
-
var import_Error = require("../Error.cjs");
|
|
34
33
|
var __import_meta_url = globalThis["import.meta.url"] ?? (() => require("node:url").pathToFileURL(__filename))();
|
|
35
34
|
var __process = globalThis["process"] ?? {
|
|
36
35
|
"cwd": () => "/",
|
|
@@ -46,7 +45,7 @@ async function spellcheck() {
|
|
|
46
45
|
}
|
|
47
46
|
const path = (0, import_node_url.fileURLToPath)(issue.uri);
|
|
48
47
|
const relativePath = (0, import_Root.toRelativeFromRoot)(path);
|
|
49
|
-
|
|
48
|
+
console.log(`${relativePath}:${issue.row}:${issue.col} - ${issue.text}`);
|
|
50
49
|
isSuccess = false;
|
|
51
50
|
}
|
|
52
51
|
});
|
|
@@ -56,4 +55,4 @@ async function spellcheck() {
|
|
|
56
55
|
0 && (module.exports = {
|
|
57
56
|
spellcheck
|
|
58
57
|
});
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2Jpbi9zcGVsbGNoZWNrLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19pbXBvcnRfbWV0YV91cmwgPSBnbG9iYWxUaGlzW1wiaW1wb3J0Lm1ldGEudXJsXCJdID8/ICgoKT0+cmVxdWlyZShcIm5vZGU6dXJsXCIpLnBhdGhUb0ZpbGVVUkwoX19maWxlbmFtZSkpKCk7XG52YXIgX19wcm9jZXNzID0gZ2xvYmFsVGhpc1tcInByb2Nlc3NcIl0gPz8ge1xuICBcImN3ZFwiOiAoKT0+
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2Jpbi9zcGVsbGNoZWNrLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ2YXIgX19pbXBvcnRfbWV0YV91cmwgPSBnbG9iYWxUaGlzW1wiaW1wb3J0Lm1ldGEudXJsXCJdID8/ICgoKT0+cmVxdWlyZShcIm5vZGU6dXJsXCIpLnBhdGhUb0ZpbGVVUkwoX19maWxlbmFtZSkpKCk7XG52YXIgX19wcm9jZXNzID0gZ2xvYmFsVGhpc1tcInByb2Nlc3NcIl0gPz8ge1xuICBcImN3ZFwiOiAoKT0+XCIvXCIsXG4gIFwiZW52XCI6IHt9LFxuICBcInBsYXRmb3JtXCI6IFwiYW5kcm9pZFwiXG59O1xuLyoqXG4gKiBAZmlsZVxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgYSBmdW5jdGlvbiBmb3IgcnVubmluZyBhIHNwZWxsY2hlY2sgb24gdGhlIGNvZGViYXNlIHVzaW5nIHRoZSBgY3NwZWxsYCBsaWJyYXJ5LlxuICogSXQgcmVwb3J0cyBhbnkgc3BlbGxpbmcgaXNzdWVzIGZvdW5kIGluIHRoZSBjb2RlIGFuZCByZXR1cm5zIGEgYFRhc2tSZXN1bHRgIGluZGljYXRpbmcgd2hldGhlciB0aGUgc3BlbGxjaGVjayB3YXMgc3VjY2Vzc2Z1bC5cbiAqL1xuXG5pbXBvcnQgeyBsaW50IH0gZnJvbSBcImNzcGVsbFwiO1xuaW1wb3J0IHsgdG9SZWxhdGl2ZUZyb21Sb290IH0gZnJvbSBcIi4uL1Jvb3QudHNcIjtcbmltcG9ydCB7IGZpbGVVUkxUb1BhdGggfSBmcm9tIFwibm9kZTp1cmxcIjtcbmltcG9ydCB7IFRhc2tSZXN1bHQgfSBmcm9tIFwiLi4vVGFza1Jlc3VsdC50c1wiO1xuXG4vKipcbiAqIFJ1bnMgYSBzcGVsbGNoZWNrIG9uIHRoZSBlbnRpcmUgY29kZWJhc2UgdXNpbmcgYGNzcGVsbGAuXG4gKlxuICogVGhlIGZ1bmN0aW9uIGNoZWNrcyBhbGwgZmlsZXMgaW4gdGhlIGN1cnJlbnQgZGlyZWN0b3J5IGFuZCBpdHMgc3ViZGlyZWN0b3JpZXMgZm9yIHNwZWxsaW5nIGlzc3Vlcy5cbiAqIElmIGlzc3VlcyBhcmUgZm91bmQsIHRoZXkgYXJlIGxvZ2dlZCB0byB0aGUgY29uc29sZSB3aXRoIHRoZWlyIGZpbGUgcGF0aCwgbGluZSwgYW5kIGNvbHVtbiBudW1iZXIuXG4gKlxuICogQHJldHVybnMgQSBgUHJvbWlzZWAgdGhhdCByZXNvbHZlcyB0byBhIGBUYXNrUmVzdWx0YCwgaW5kaWNhdGluZyB0aGUgc3VjY2VzcyBvciBmYWlsdXJlIG9mIHRoZSBzcGVsbGNoZWNrLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc3BlbGxjaGVjaygpOiBQcm9taXNlPFRhc2tSZXN1bHQ+IHtcbiAgbGV0IGlzU3VjY2VzcyA9IHRydWU7XG5cbiAgYXdhaXQgbGludChbXCIuXCJdLCB7fSwge1xuICAgIGlzc3VlOiAoaXNzdWUpID0+IHtcbiAgICAgIGlmICghaXNzdWUudXJpKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgY29uc3QgcGF0aCA9IGZpbGVVUkxUb1BhdGgoaXNzdWUudXJpKTtcbiAgICAgIGNvbnN0IHJlbGF0aXZlUGF0aCA9IHRvUmVsYXRpdmVGcm9tUm9vdChwYXRoKTtcbiAgICAgIGNvbnNvbGUubG9nKGAke3JlbGF0aXZlUGF0aH06JHtpc3N1ZS5yb3d9OiR7aXNzdWUuY29sfSAtICR7aXNzdWUudGV4dH1gKTtcbiAgICAgIGlzU3VjY2VzcyA9IGZhbHNlO1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIFRhc2tSZXN1bHQuQ3JlYXRlU3VjY2Vzc1Jlc3VsdChpc1N1Y2Nlc3MpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBWUEsb0JBQXFCO0FBQ3JCLGtCQUFtQztBQUNuQyxzQkFBOEI7QUFDOUIsd0JBQTJCO0FBZjNCLElBQUksb0JBQW9CLFdBQVcsaUJBQWlCLE1BQU0sTUFBSSxRQUFRLFVBQVUsRUFBRSxjQUFjLFVBQVUsR0FBRztBQUM3RyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBb0JBLGVBQXNCLGFBQWtDO0FBQ3RELE1BQUksWUFBWTtBQUVoQixZQUFNLG9CQUFLLENBQUMsR0FBRyxHQUFHLENBQUMsR0FBRztBQUFBLElBQ3BCLE9BQU8sQ0FBQyxVQUFVO0FBQ2hCLFVBQUksQ0FBQyxNQUFNLEtBQUs7QUFDZDtBQUFBLE1BQ0Y7QUFFQSxZQUFNLFdBQU8sK0JBQWMsTUFBTSxHQUFHO0FBQ3BDLFlBQU0sbUJBQWUsZ0NBQW1CLElBQUk7QUFDNUMsY0FBUSxJQUFJLEdBQUcsWUFBWSxJQUFJLE1BQU0sR0FBRyxJQUFJLE1BQU0sR0FBRyxNQUFNLE1BQU0sSUFBSSxFQUFFO0FBQ3ZFLGtCQUFZO0FBQUEsSUFDZDtBQUFBLEVBQ0YsQ0FBQztBQUVELFNBQU8sNkJBQVcsb0JBQW9CLFNBQVM7QUFDakQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
package/dist/lib/bin/version.cjs
CHANGED
|
@@ -71,6 +71,14 @@ var __process = globalThis["process"] ?? {
|
|
|
71
71
|
"platform": "android"
|
|
72
72
|
};
|
|
73
73
|
async function updateVersion(versionUpdateType) {
|
|
74
|
+
if (!versionUpdateType) {
|
|
75
|
+
const npmOldVersion = __process.env["npm_old_version"];
|
|
76
|
+
const npmNewVersion = __process.env["npm_new_version"];
|
|
77
|
+
if (npmOldVersion && npmNewVersion) {
|
|
78
|
+
await updateVersionInFiles(npmOldVersion, false);
|
|
79
|
+
return updateVersion(npmNewVersion);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
74
82
|
const isObsidianPlugin = (0, import_node_fs.existsSync)((0, import_Root.resolvePathFromRoot)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson));
|
|
75
83
|
return await import_TaskResult.TaskResult.chain([
|
|
76
84
|
async () => {
|
|
@@ -148,6 +156,10 @@ async function updateVersionInFiles(newVersion, isObsidianPlugin) {
|
|
|
148
156
|
});
|
|
149
157
|
await (0, import_Npm.editNpmPackageLock)((npmPackageLock) => {
|
|
150
158
|
npmPackageLock.version = newVersion;
|
|
159
|
+
const defaultPackage = npmPackageLock.packages?.[""];
|
|
160
|
+
if (defaultPackage) {
|
|
161
|
+
defaultPackage.version = newVersion;
|
|
162
|
+
}
|
|
151
163
|
}, { skipIfMissing: true });
|
|
152
164
|
if (isObsidianPlugin) {
|
|
153
165
|
const latestObsidianVersion = await getLatestObsidianVersion();
|
|
@@ -326,4 +338,4 @@ async function publishGitHubRelease(newVersion, isObsidianPlugin) {
|
|
|
326
338
|
updateVersionInFiles,
|
|
327
339
|
validate
|
|
328
340
|
});
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bin/version.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @file\n * This module provides functions for managing version updates in a project.\n * It includes tasks such as validating version update types, checking the state\n * of Git and GitHub CLI, updating version numbers in files, and performing\n * Git operations such as tagging and pushing.\n *\n * The main function, `updateVersion`, coordinates these tasks to ensure that\n * version updates are handled consistently and correctly. It also integrates\n * with Obsidian plugins, if applicable, by updating relevant files and releasing\n * new versions on GitHub.\n */\n\nimport { TaskResult } from \"../TaskResult.ts\";\nimport {\n  execFromRoot,\n  resolvePathFromRoot\n} from \"../Root.ts\";\nimport { spellcheck } from \"./spellcheck.ts\";\nimport { lint } from \"./ESLint/ESLint.ts\";\nimport {\n  editNpmPackage,\n  editNpmPackageLock,\n  readNpmPackage\n} from \"../Npm.ts\";\nimport { editJson } from \"../JSON.ts\";\nimport { existsSync } from \"node:fs\";\nimport {\n  cp,\n  readFile,\n  writeFile\n} from \"node:fs/promises\";\nimport { createInterface } from \"node:readline/promises\";\nimport { readdirPosix } from \"../Fs.ts\";\nimport { join } from \"../Path.ts\";\nimport { ObsidianPluginRepoPaths } from \"../obsidian/Plugin/ObsidianPluginRepoPaths.ts\";\nimport { ObsidianDevUtilsRepoPaths } from \"./ObsidianDevUtilsRepoPaths.ts\";\nimport AdmZip from \"adm-zip\";\n\n/**\n * Enum representing different types of version updates.\n */\nenum VersionUpdateType {\n  Major = \"major\",\n  Minor = \"minor\",\n  Patch = \"patch\",\n  Beta = \"beta\",\n  Manual = \"manual\",\n  Invalid = \"invalid\"\n}\n\n/**\n * Type representing the manifest file format for Obsidian plugins.\n */\ntype Manifest = {\n  minAppVersion: string;\n  version: string;\n};\n\n/**\n * Type representing the structure of Obsidian releases JSON.\n */\ntype ObsidianReleasesJson = {\n  name: string;\n};\n\n/**\n * Updates the version of the project based on the specified update type.\n *\n * This function performs a series of tasks to handle version updates:\n * 1. Validates the version update type.\n * 2. Checks if Git and GitHub CLI are installed.\n * 3. Verifies that the Git repository is clean.\n * 4. Runs spellcheck and linting.\n * 5. Builds the project.\n * 6. Updates version in files and changelog.\n * 7. Adds updated files to Git, tags the commit, and pushes to the repository.\n * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.\n *\n * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to a `TaskResult` indicating the success or failure of the version update.\n */\nexport async function updateVersion(versionUpdateType: string): Promise<TaskResult | void> {\n  const isObsidianPlugin = existsSync(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson));\n  return await TaskResult.chain([\n    async (): Promise<void> => {\n      validate(versionUpdateType);\n      await checkGitInstalled();\n      await checkGitRepoClean();\n      await checkGitHubCliInstalled();\n    },\n    (): Promise<TaskResult> => spellcheck(),\n    async (): Promise<void> => {\n      await execFromRoot(\"npm run build\");\n    },\n    (): Promise<TaskResult> => lint(),\n    async (): Promise<void> => {\n      const newVersion = await getNewVersion(versionUpdateType);\n      await updateVersionInFiles(newVersion, isObsidianPlugin);\n      await updateChangelog(newVersion);\n      await addUpdatedFilesToGit(newVersion);\n      await addGitTag(newVersion);\n      await gitPush();\n      if (isObsidianPlugin) {\n        await copyUpdatedManifest();\n      }\n      await publishGitHubRelease(newVersion, isObsidianPlugin);\n    }\n  ]);\n}\n\n/**\n * Validates the version update type to ensure it is either a recognized type\n * or a valid manual version string.\n *\n * @param versionUpdateType - The version update type to validate.\n * @throws Error if the version update type is invalid.\n */\nexport function validate(versionUpdateType: string): void {\n  if (getVersionUpdateType(versionUpdateType) === VersionUpdateType.Invalid) {\n    throw new Error(\"Invalid version update type. Please use 'major', 'minor', 'patch', or 'x.y.z[-suffix]' format.\");\n  }\n}\n\n/**\n * Checks if Git is installed on the system.\n *\n * Throws an error if Git is not installed.\n *\n * @throws Error if Git is not installed.\n */\nexport async function checkGitInstalled(): Promise<void> {\n  try {\n    await execFromRoot(\"git --version\", { quiet: true });\n  } catch {\n    throw new Error(\"Git is not installed. Please install it from https://git-scm.com/\");\n  }\n}\n\n/**\n * Checks if the GitHub CLI is installed on the system.\n *\n * Throws an error if the GitHub CLI is not installed.\n *\n * @throws Error if the GitHub CLI is not installed.\n */\nexport async function checkGitHubCliInstalled(): Promise<void> {\n  try {\n    await execFromRoot(\"gh --version\", { quiet: true });\n  } catch {\n    throw new Error(\"GitHub CLI is not installed. Please install it from https://cli.github.com/\");\n  }\n}\n\n/**\n * Checks if the Git repository is clean, meaning there are no uncommitted changes.\n *\n * Throws an error if the Git repository is not clean.\n *\n * @throws Error if the Git repository is not clean.\n */\nexport async function checkGitRepoClean(): Promise<void> {\n  try {\n    const stdout = await execFromRoot(\"git status --porcelain --untracked-files=all\", { quiet: true });\n    if (stdout) {\n      throw new Error();\n    }\n  } catch {\n    throw new Error(\"Git repository is not clean. Please commit or stash your changes before releasing a new version.\");\n  }\n}\n\n/**\n * Determines the type of version update based on the input string.\n *\n * @param versionUpdateType - The input string representing the version update type.\n * @returns The corresponding `VersionUpdateType`.\n */\nexport function getVersionUpdateType(versionUpdateType: string): VersionUpdateType {\n  const versionUpdateTypeEnum = versionUpdateType as VersionUpdateType;\n  switch (versionUpdateTypeEnum) {\n    case VersionUpdateType.Major:\n    case VersionUpdateType.Minor:\n    case VersionUpdateType.Patch:\n    case VersionUpdateType.Beta:\n      return versionUpdateTypeEnum;\n\n    default:\n      if (/^\\d+\\.\\d+\\.\\d+(-[\\w\\d.-]+)?$/.test(versionUpdateType)) {\n        return VersionUpdateType.Manual;\n      }\n\n      return VersionUpdateType.Invalid;\n  }\n}\n\n/**\n * Updates the version in various files, including `package.json`, `package-lock.json`,\n * and Obsidian plugin manifests if applicable.\n *\n * @param newVersion - The new version string to update in the files.\n * @param isObsidianPlugin - Whether the project is an Obsidian plugin.\n * @returns A `Promise` that resolves when the update is complete.\n */\nexport async function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  await editNpmPackage((npmPackage) => {\n    npmPackage.version = newVersion;\n  });\n\n  await editNpmPackageLock((npmPackageLock) => {\n    npmPackageLock.version = newVersion;\n  }, { skipIfMissing: true });\n\n  if (isObsidianPlugin) {\n    const latestObsidianVersion = await getLatestObsidianVersion();\n\n    await editJson<Manifest>(ObsidianPluginRepoPaths.ManifestJson, (manifest) => {\n      manifest.minAppVersion = latestObsidianVersion;\n      manifest.version = newVersion;\n    });\n\n    await editJson<Record<string, string>>(ObsidianPluginRepoPaths.VersionsJson, (versions) => {\n      versions[newVersion] = latestObsidianVersion;\n    });\n  }\n}\n\n/**\n * Generates a new version string based on the current version and the specified update type.\n *\n * @param versionUpdateType - The type of version update (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to the new version string.\n * @throws Error if the current version format is invalid.\n */\nexport async function getNewVersion(versionUpdateType: string): Promise<string> {\n  const versionType = getVersionUpdateType(versionUpdateType);\n  if (versionType === VersionUpdateType.Manual) {\n    return versionUpdateType;\n  }\n\n  const npmPackage = await readNpmPackage();\n  const currentVersion = npmPackage.version;\n\n  const match = currentVersion.match(/^(\\d+)\\.(\\d+)\\.(\\d+)(-beta.(\\d+))?/);\n  if (!match) {\n    throw new Error(`Invalid current version format: ${currentVersion}`);\n  }\n\n  let major = Number(match[1]);\n  let minor = Number(match[2]);\n  let patch = Number(match[3]);\n  let beta = match[5] ? Number(match[5]) : 0;\n\n  switch (versionType) {\n    case VersionUpdateType.Major:\n      major++;\n      minor = 0;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Minor:\n      minor++;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Patch:\n      patch++;\n      beta = 0;\n      break;\n    case VersionUpdateType.Beta:\n      beta++;\n      break;\n  }\n\n  return `${major}.${minor}.${patch}${beta > 0 ? `-beta.${beta}` : \"\"}`;\n}\n\n/**\n * Fetches the latest version of Obsidian from the GitHub releases API.\n *\n * @returns A promise that resolves to the latest version of Obsidian.\n */\nasync function getLatestObsidianVersion(): Promise<string> {\n  const response = await fetch(\"https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest\");\n  const obsidianReleasesJson = await response.json() as ObsidianReleasesJson;\n  return obsidianReleasesJson.name;\n}\n\n/**\n * Updates the changelog file with new version information and commit messages.\n *\n * This function reads the current changelog, appends new entries for the latest version,\n * and prompts the user to review the changes.\n *\n * @param newVersion - The new version number to be added to the changelog.\n * @returns A promise that resolves when the changelog update is complete.\n */\nexport async function updateChangelog(newVersion: string): Promise<void> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  let previousChangelogLines: string[];\n  if (!existsSync(changelogPath)) {\n    previousChangelogLines = [];\n  } else {\n    const content = await readFile(changelogPath, \"utf-8\");\n    previousChangelogLines = content.split(\"\\n\").slice(2);\n    if (previousChangelogLines.at(-1) === \"\") {\n      previousChangelogLines.pop();\n    }\n  }\n\n  const lastTag = previousChangelogLines[0]?.replace(\"## \", \"\");\n  const commitRange = lastTag ? `${lastTag}..HEAD` : \"HEAD\";\n  const commitMessages = (await execFromRoot(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\\r?\\n/);\n\n  let newChangeLog = `# CHANGELOG\\n\\n## ${newVersion}\\n\\n`;\n\n  for (const message of commitMessages) {\n    newChangeLog += `- ${message}\\n`;\n  }\n\n  if (previousChangelogLines.length > 0) {\n    newChangeLog += \"\\n\";\n    for (const line of previousChangelogLines) {\n      newChangeLog += `${line}\\n`;\n    }\n  }\n\n  await writeFile(changelogPath, newChangeLog, \"utf-8\");\n\n  await createInterface(process.stdin, process.stdout).question(`Please update the ${ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);\n}\n\n/**\n * Adds updated files to the Git staging area and commits them with the new version message.\n *\n * @param newVersion - The new version number used as the commit message.\n * @returns A promise that resolves when the files have been added and committed.\n */\nexport async function addUpdatedFilesToGit(newVersion: string): Promise<void> {\n  const files = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.PackageJson,\n    ObsidianPluginRepoPaths.PackageLockJson,\n    ObsidianPluginRepoPaths.VersionsJson,\n    ObsidianPluginRepoPaths.ChangelogMd\n  ].filter(file => existsSync(resolvePathFromRoot(file)));\n  await execFromRoot([\"git\", \"add\", ...files], { quiet: true });\n  await execFromRoot(`git commit -m ${newVersion}`, { quiet: true });\n}\n\n/**\n * Creates a Git tag for the new version.\n *\n * @param newVersion - The new version number to use for the tag.\n * @returns A promise that resolves when the tag has been created.\n */\nexport async function addGitTag(newVersion: string): Promise<void> {\n  await execFromRoot(`git tag -a ${newVersion} -m ${newVersion}`, { quiet: true });\n}\n\n/**\n * Pushes commits and tags to the remote Git repository.\n *\n * @returns A promise that resolves when the push operation is complete.\n */\nexport async function gitPush(): Promise<void> {\n  await execFromRoot(\"git push --follow-tags\", { quiet: true });\n}\n\n/**\n * Copies the updated manifest file to the distribution build directory.\n *\n * @returns A promise that resolves when the copy operation is complete.\n */\nexport async function copyUpdatedManifest(): Promise<void> {\n  await cp(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson), resolvePathFromRoot(join(ObsidianPluginRepoPaths.DistBuild, ObsidianPluginRepoPaths.ManifestJson)), { force: true });\n}\n\n/**\n * Retrieves the release notes for a specific version from the changelog.\n *\n * @param newVersion - The new version number for which to get the release notes.\n * @returns A promise that resolves to the release notes for the specified version.\n */\nexport async function getReleaseNotes(newVersion: string): Promise<string> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  const content = await readFile(changelogPath, \"utf-8\");\n  const newVersionEscaped = newVersion.replaceAll(\".\", \"\\\\.\");\n  const match = content.match(new RegExp(`\\n## ${newVersionEscaped}\\n\\n((.|\\n)+?)\\n\\n##`));\n  let releaseNotes = match ? match[1] + \"\\n\\n\" : \"\";\n\n  const tags = (await execFromRoot(\"git tag --sort=-creatordate\", { quiet: true })).split(/\\r?\\n/);\n  const previousVersion = tags[1];\n  let changesUrl = \"\";\n\n  const repoUrl = await execFromRoot(\"gh repo view --json url -q .url\", { quiet: true });\n\n  if (previousVersion) {\n    changesUrl = `${repoUrl}/compare/${previousVersion}...${newVersion}`;\n  } else {\n    changesUrl = `${repoUrl}/commits/${newVersion}`;\n  }\n\n  releaseNotes += `**Full Changelog**: ${changesUrl}`;\n  return releaseNotes;\n}\n\n/**\n * Publishes a GitHub release for the new version.\n *\n * Handles the creation of a release and uploading files for either an Obsidian plugin or another project.\n *\n * @param newVersion - The new version number for the release.\n * @param isObsidianPlugin - A boolean indicating if the project is an Obsidian plugin.\n * @returns A promise that resolves when the release has been published.\n */\nexport async function publishGitHubRelease(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  let filePaths: string[];\n\n  if (isObsidianPlugin) {\n    const buildDir = resolvePathFromRoot(ObsidianPluginRepoPaths.DistBuild);\n    const fileNames = await readdirPosix(buildDir);\n    filePaths = fileNames.map(fileName => join(buildDir, fileName));\n  } else {\n\n    const zip = new AdmZip();\n    zip.addLocalFolder(resolvePathFromRoot(ObsidianDevUtilsRepoPaths.Dist), ObsidianDevUtilsRepoPaths.Dist, (filename) => !filename.endsWith(\".zip\"));\n\n    const files = [\n      ObsidianDevUtilsRepoPaths.ChangelogMd,\n      ObsidianDevUtilsRepoPaths.License,\n      ObsidianDevUtilsRepoPaths.ReadmeMd,\n      ObsidianDevUtilsRepoPaths.PackageJson\n    ];\n\n    for (const file of files) {\n      zip.addLocalFile(resolvePathFromRoot(file));\n    }\n\n    const npmPackage = await readNpmPackage();\n    const distZipPath = resolvePathFromRoot(join(ObsidianDevUtilsRepoPaths.Dist, `${npmPackage.name}-${newVersion}.zip`));\n    zip.writeZip(distZipPath);\n    filePaths = [distZipPath];\n  }\n\n  await execFromRoot([\"gh\", \"release\", \"create\", newVersion, ...filePaths, \"--title\", `v${newVersion}`, \"--notes-file\", \"-\"], {\n    quiet: true,\n    stdin: await getReleaseNotes(newVersion)\n  });\n}\n"],
  "mappings": "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",
  "names": ["import_promises", "AdmZip"]
}

|
|
341
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/bin/version.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @file\n * This module provides functions for managing version updates in a project.\n * It includes tasks such as validating version update types, checking the state\n * of Git and GitHub CLI, updating version numbers in files, and performing\n * Git operations such as tagging and pushing.\n *\n * The main function, `updateVersion`, coordinates these tasks to ensure that\n * version updates are handled consistently and correctly. It also integrates\n * with Obsidian plugins, if applicable, by updating relevant files and releasing\n * new versions on GitHub.\n */\n\nimport { TaskResult } from \"../TaskResult.ts\";\nimport {\n  execFromRoot,\n  resolvePathFromRoot\n} from \"../Root.ts\";\nimport { spellcheck } from \"./spellcheck.ts\";\nimport { lint } from \"./ESLint/ESLint.ts\";\nimport {\n  editNpmPackage,\n  editNpmPackageLock,\n  readNpmPackage\n} from \"../Npm.ts\";\nimport { editJson } from \"../JSON.ts\";\nimport { existsSync } from \"node:fs\";\nimport {\n  cp,\n  readFile,\n  writeFile\n} from \"node:fs/promises\";\nimport { createInterface } from \"node:readline/promises\";\nimport { readdirPosix } from \"../Fs.ts\";\nimport { join } from \"../Path.ts\";\nimport { ObsidianPluginRepoPaths } from \"../obsidian/Plugin/ObsidianPluginRepoPaths.ts\";\nimport { ObsidianDevUtilsRepoPaths } from \"./ObsidianDevUtilsRepoPaths.ts\";\nimport AdmZip from \"adm-zip\";\n\n/**\n * Enum representing different types of version updates.\n */\nenum VersionUpdateType {\n  Major = \"major\",\n  Minor = \"minor\",\n  Patch = \"patch\",\n  Beta = \"beta\",\n  Manual = \"manual\",\n  Invalid = \"invalid\"\n}\n\n/**\n * Type representing the manifest file format for Obsidian plugins.\n */\ntype Manifest = {\n  minAppVersion: string;\n  version: string;\n};\n\n/**\n * Type representing the structure of Obsidian releases JSON.\n */\ntype ObsidianReleasesJson = {\n  name: string;\n};\n\n/**\n * Updates the version of the project based on the specified update type.\n *\n * This function performs a series of tasks to handle version updates:\n * 1. Validates the version update type.\n * 2. Checks if Git and GitHub CLI are installed.\n * 3. Verifies that the Git repository is clean.\n * 4. Runs spellcheck and linting.\n * 5. Builds the project.\n * 6. Updates version in files and changelog.\n * 7. Adds updated files to Git, tags the commit, and pushes to the repository.\n * 8. If an Obsidian plugin, copies the updated manifest and publishes a GitHub release.\n *\n * @param versionUpdateType - The type of version update to perform (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to a `TaskResult` indicating the success or failure of the version update.\n */\nexport async function updateVersion(versionUpdateType: string): Promise<TaskResult | void> {\n  if (!versionUpdateType) {\n    const npmOldVersion = process.env[\"npm_old_version\"];\n    const npmNewVersion = process.env[\"npm_new_version\"];\n\n    if (npmOldVersion && npmNewVersion) {\n      await updateVersionInFiles(npmOldVersion, false);\n      return updateVersion(npmNewVersion);\n    }\n  }\n\n  const isObsidianPlugin = existsSync(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson));\n  return await TaskResult.chain([\n    async (): Promise<void> => {\n      validate(versionUpdateType);\n      await checkGitInstalled();\n      await checkGitRepoClean();\n      await checkGitHubCliInstalled();\n    },\n    (): Promise<TaskResult> => spellcheck(),\n    async (): Promise<void> => {\n      await execFromRoot(\"npm run build\");\n    },\n    (): Promise<TaskResult> => lint(),\n    async (): Promise<void> => {\n      const newVersion = await getNewVersion(versionUpdateType);\n      await updateVersionInFiles(newVersion, isObsidianPlugin);\n      await updateChangelog(newVersion);\n      await addUpdatedFilesToGit(newVersion);\n      await addGitTag(newVersion);\n      await gitPush();\n      if (isObsidianPlugin) {\n        await copyUpdatedManifest();\n      }\n      await publishGitHubRelease(newVersion, isObsidianPlugin);\n    }\n  ]);\n}\n\n/**\n * Validates the version update type to ensure it is either a recognized type\n * or a valid manual version string.\n *\n * @param versionUpdateType - The version update type to validate.\n * @throws Error if the version update type is invalid.\n */\nexport function validate(versionUpdateType: string): void {\n  if (getVersionUpdateType(versionUpdateType) === VersionUpdateType.Invalid) {\n    throw new Error(\"Invalid version update type. Please use 'major', 'minor', 'patch', or 'x.y.z[-suffix]' format.\");\n  }\n}\n\n/**\n * Checks if Git is installed on the system.\n *\n * Throws an error if Git is not installed.\n *\n * @throws Error if Git is not installed.\n */\nexport async function checkGitInstalled(): Promise<void> {\n  try {\n    await execFromRoot(\"git --version\", { quiet: true });\n  } catch {\n    throw new Error(\"Git is not installed. Please install it from https://git-scm.com/\");\n  }\n}\n\n/**\n * Checks if the GitHub CLI is installed on the system.\n *\n * Throws an error if the GitHub CLI is not installed.\n *\n * @throws Error if the GitHub CLI is not installed.\n */\nexport async function checkGitHubCliInstalled(): Promise<void> {\n  try {\n    await execFromRoot(\"gh --version\", { quiet: true });\n  } catch {\n    throw new Error(\"GitHub CLI is not installed. Please install it from https://cli.github.com/\");\n  }\n}\n\n/**\n * Checks if the Git repository is clean, meaning there are no uncommitted changes.\n *\n * Throws an error if the Git repository is not clean.\n *\n * @throws Error if the Git repository is not clean.\n */\nexport async function checkGitRepoClean(): Promise<void> {\n  try {\n    const stdout = await execFromRoot(\"git status --porcelain --untracked-files=all\", { quiet: true });\n    if (stdout) {\n      throw new Error();\n    }\n  } catch {\n    throw new Error(\"Git repository is not clean. Please commit or stash your changes before releasing a new version.\");\n  }\n}\n\n/**\n * Determines the type of version update based on the input string.\n *\n * @param versionUpdateType - The input string representing the version update type.\n * @returns The corresponding `VersionUpdateType`.\n */\nexport function getVersionUpdateType(versionUpdateType: string): VersionUpdateType {\n  const versionUpdateTypeEnum = versionUpdateType as VersionUpdateType;\n  switch (versionUpdateTypeEnum) {\n    case VersionUpdateType.Major:\n    case VersionUpdateType.Minor:\n    case VersionUpdateType.Patch:\n    case VersionUpdateType.Beta:\n      return versionUpdateTypeEnum;\n\n    default:\n      if (/^\\d+\\.\\d+\\.\\d+(-[\\w\\d.-]+)?$/.test(versionUpdateType)) {\n        return VersionUpdateType.Manual;\n      }\n\n      return VersionUpdateType.Invalid;\n  }\n}\n\n/**\n * Updates the version in various files, including `package.json`, `package-lock.json`,\n * and Obsidian plugin manifests if applicable.\n *\n * @param newVersion - The new version string to update in the files.\n * @param isObsidianPlugin - Whether the project is an Obsidian plugin.\n * @returns A `Promise` that resolves when the update is complete.\n */\nexport async function updateVersionInFiles(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  await editNpmPackage((npmPackage) => {\n    npmPackage.version = newVersion;\n  });\n\n  await editNpmPackageLock((npmPackageLock) => {\n    npmPackageLock.version = newVersion;\n    const defaultPackage = npmPackageLock.packages?.[\"\"];\n    if (defaultPackage) {\n      defaultPackage.version = newVersion;\n    }\n  }, { skipIfMissing: true });\n\n  if (isObsidianPlugin) {\n    const latestObsidianVersion = await getLatestObsidianVersion();\n\n    await editJson<Manifest>(ObsidianPluginRepoPaths.ManifestJson, (manifest) => {\n      manifest.minAppVersion = latestObsidianVersion;\n      manifest.version = newVersion;\n    });\n\n    await editJson<Record<string, string>>(ObsidianPluginRepoPaths.VersionsJson, (versions) => {\n      versions[newVersion] = latestObsidianVersion;\n    });\n  }\n}\n\n/**\n * Generates a new version string based on the current version and the specified update type.\n *\n * @param versionUpdateType - The type of version update (major, minor, patch, beta, or manual).\n * @returns A `Promise` that resolves to the new version string.\n * @throws Error if the current version format is invalid.\n */\nexport async function getNewVersion(versionUpdateType: string): Promise<string> {\n  const versionType = getVersionUpdateType(versionUpdateType);\n  if (versionType === VersionUpdateType.Manual) {\n    return versionUpdateType;\n  }\n\n  const npmPackage = await readNpmPackage();\n  const currentVersion = npmPackage.version;\n\n  const match = currentVersion.match(/^(\\d+)\\.(\\d+)\\.(\\d+)(-beta.(\\d+))?/);\n  if (!match) {\n    throw new Error(`Invalid current version format: ${currentVersion}`);\n  }\n\n  let major = Number(match[1]);\n  let minor = Number(match[2]);\n  let patch = Number(match[3]);\n  let beta = match[5] ? Number(match[5]) : 0;\n\n  switch (versionType) {\n    case VersionUpdateType.Major:\n      major++;\n      minor = 0;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Minor:\n      minor++;\n      patch = 0;\n      beta = 0;\n      break;\n    case VersionUpdateType.Patch:\n      patch++;\n      beta = 0;\n      break;\n    case VersionUpdateType.Beta:\n      beta++;\n      break;\n  }\n\n  return `${major}.${minor}.${patch}${beta > 0 ? `-beta.${beta}` : \"\"}`;\n}\n\n/**\n * Fetches the latest version of Obsidian from the GitHub releases API.\n *\n * @returns A promise that resolves to the latest version of Obsidian.\n */\nasync function getLatestObsidianVersion(): Promise<string> {\n  const response = await fetch(\"https://api.github.com/repos/obsidianmd/obsidian-releases/releases/latest\");\n  const obsidianReleasesJson = await response.json() as ObsidianReleasesJson;\n  return obsidianReleasesJson.name;\n}\n\n/**\n * Updates the changelog file with new version information and commit messages.\n *\n * This function reads the current changelog, appends new entries for the latest version,\n * and prompts the user to review the changes.\n *\n * @param newVersion - The new version number to be added to the changelog.\n * @returns A promise that resolves when the changelog update is complete.\n */\nexport async function updateChangelog(newVersion: string): Promise<void> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  let previousChangelogLines: string[];\n  if (!existsSync(changelogPath)) {\n    previousChangelogLines = [];\n  } else {\n    const content = await readFile(changelogPath, \"utf-8\");\n    previousChangelogLines = content.split(\"\\n\").slice(2);\n    if (previousChangelogLines.at(-1) === \"\") {\n      previousChangelogLines.pop();\n    }\n  }\n\n  const lastTag = previousChangelogLines[0]?.replace(\"## \", \"\");\n  const commitRange = lastTag ? `${lastTag}..HEAD` : \"HEAD\";\n  const commitMessages = (await execFromRoot(`git log ${commitRange} --format=%s --first-parent`, { quiet: true })).split(/\\r?\\n/);\n\n  let newChangeLog = `# CHANGELOG\\n\\n## ${newVersion}\\n\\n`;\n\n  for (const message of commitMessages) {\n    newChangeLog += `- ${message}\\n`;\n  }\n\n  if (previousChangelogLines.length > 0) {\n    newChangeLog += \"\\n\";\n    for (const line of previousChangelogLines) {\n      newChangeLog += `${line}\\n`;\n    }\n  }\n\n  await writeFile(changelogPath, newChangeLog, \"utf-8\");\n\n  await createInterface(process.stdin, process.stdout).question(`Please update the ${ObsidianPluginRepoPaths.ChangelogMd} file. Press Enter when you are done...`);\n}\n\n/**\n * Adds updated files to the Git staging area and commits them with the new version message.\n *\n * @param newVersion - The new version number used as the commit message.\n * @returns A promise that resolves when the files have been added and committed.\n */\nexport async function addUpdatedFilesToGit(newVersion: string): Promise<void> {\n  const files = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.PackageJson,\n    ObsidianPluginRepoPaths.PackageLockJson,\n    ObsidianPluginRepoPaths.VersionsJson,\n    ObsidianPluginRepoPaths.ChangelogMd\n  ].filter(file => existsSync(resolvePathFromRoot(file)));\n  await execFromRoot([\"git\", \"add\", ...files], { quiet: true });\n  await execFromRoot(`git commit -m ${newVersion}`, { quiet: true });\n}\n\n/**\n * Creates a Git tag for the new version.\n *\n * @param newVersion - The new version number to use for the tag.\n * @returns A promise that resolves when the tag has been created.\n */\nexport async function addGitTag(newVersion: string): Promise<void> {\n  await execFromRoot(`git tag -a ${newVersion} -m ${newVersion}`, { quiet: true });\n}\n\n/**\n * Pushes commits and tags to the remote Git repository.\n *\n * @returns A promise that resolves when the push operation is complete.\n */\nexport async function gitPush(): Promise<void> {\n  await execFromRoot(\"git push --follow-tags\", { quiet: true });\n}\n\n/**\n * Copies the updated manifest file to the distribution build directory.\n *\n * @returns A promise that resolves when the copy operation is complete.\n */\nexport async function copyUpdatedManifest(): Promise<void> {\n  await cp(resolvePathFromRoot(ObsidianPluginRepoPaths.ManifestJson), resolvePathFromRoot(join(ObsidianPluginRepoPaths.DistBuild, ObsidianPluginRepoPaths.ManifestJson)), { force: true });\n}\n\n/**\n * Retrieves the release notes for a specific version from the changelog.\n *\n * @param newVersion - The new version number for which to get the release notes.\n * @returns A promise that resolves to the release notes for the specified version.\n */\nexport async function getReleaseNotes(newVersion: string): Promise<string> {\n  const changelogPath = resolvePathFromRoot(ObsidianPluginRepoPaths.ChangelogMd);\n  const content = await readFile(changelogPath, \"utf-8\");\n  const newVersionEscaped = newVersion.replaceAll(\".\", \"\\\\.\");\n  const match = content.match(new RegExp(`\\n## ${newVersionEscaped}\\n\\n((.|\\n)+?)\\n\\n##`));\n  let releaseNotes = match ? match[1] + \"\\n\\n\" : \"\";\n\n  const tags = (await execFromRoot(\"git tag --sort=-creatordate\", { quiet: true })).split(/\\r?\\n/);\n  const previousVersion = tags[1];\n  let changesUrl = \"\";\n\n  const repoUrl = await execFromRoot(\"gh repo view --json url -q .url\", { quiet: true });\n\n  if (previousVersion) {\n    changesUrl = `${repoUrl}/compare/${previousVersion}...${newVersion}`;\n  } else {\n    changesUrl = `${repoUrl}/commits/${newVersion}`;\n  }\n\n  releaseNotes += `**Full Changelog**: ${changesUrl}`;\n  return releaseNotes;\n}\n\n/**\n * Publishes a GitHub release for the new version.\n *\n * Handles the creation of a release and uploading files for either an Obsidian plugin or another project.\n *\n * @param newVersion - The new version number for the release.\n * @param isObsidianPlugin - A boolean indicating if the project is an Obsidian plugin.\n * @returns A promise that resolves when the release has been published.\n */\nexport async function publishGitHubRelease(newVersion: string, isObsidianPlugin: boolean): Promise<void> {\n  let filePaths: string[];\n\n  if (isObsidianPlugin) {\n    const buildDir = resolvePathFromRoot(ObsidianPluginRepoPaths.DistBuild);\n    const fileNames = await readdirPosix(buildDir);\n    filePaths = fileNames.map(fileName => join(buildDir, fileName));\n  } else {\n\n    const zip = new AdmZip();\n    zip.addLocalFolder(resolvePathFromRoot(ObsidianDevUtilsRepoPaths.Dist), ObsidianDevUtilsRepoPaths.Dist, (filename) => !filename.endsWith(\".zip\"));\n\n    const files = [\n      ObsidianDevUtilsRepoPaths.ChangelogMd,\n      ObsidianDevUtilsRepoPaths.License,\n      ObsidianDevUtilsRepoPaths.ReadmeMd,\n      ObsidianDevUtilsRepoPaths.PackageJson\n    ];\n\n    for (const file of files) {\n      zip.addLocalFile(resolvePathFromRoot(file));\n    }\n\n    const npmPackage = await readNpmPackage();\n    const distZipPath = resolvePathFromRoot(join(ObsidianDevUtilsRepoPaths.Dist, `${npmPackage.name}-${newVersion}.zip`));\n    zip.writeZip(distZipPath);\n    filePaths = [distZipPath];\n  }\n\n  await execFromRoot([\"gh\", \"release\", \"create\", newVersion, ...filePaths, \"--title\", `v${newVersion}`, \"--notes-file\", \"-\"], {\n    quiet: true,\n    stdin: await getReleaseNotes(newVersion)\n  });\n}\n"],
  "mappings": "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",
  "names": ["import_promises", "AdmZip"]
}

|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import type { QuerySettings } from "../settings.d.ts";
|
|
2
|
+
/** A function which maps an array element to some value. */
|
|
3
|
+
export type ArrayFunc<T, O> = (elem: T, index: number, arr: T[]) => O;
|
|
4
|
+
/** A function which compares two types. */
|
|
5
|
+
export type ArrayComparator<T> = (a: T, b: T) => number;
|
|
6
|
+
/** Finds the value of the lowest value type in a grouping. */
|
|
7
|
+
export type LowestKey<T> = T extends {
|
|
8
|
+
key: any;
|
|
9
|
+
rows: any;
|
|
10
|
+
} ? LowestKey<T["rows"][0]> : T;
|
|
11
|
+
/** A ridiculous type which properly types the result of the 'groupIn' command. */
|
|
12
|
+
export type Ingrouped<U, T> = T extends {
|
|
13
|
+
key: any;
|
|
14
|
+
rows: any;
|
|
15
|
+
} ? {
|
|
16
|
+
key: T["key"];
|
|
17
|
+
rows: Ingrouped<U, T["rows"][0]>;
|
|
18
|
+
} : {
|
|
19
|
+
key: U;
|
|
20
|
+
rows: T[];
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Proxied interface which allows manipulating array-based data. All functions on a data array produce a NEW array
|
|
24
|
+
* (i.e., the arrays are immutable).
|
|
25
|
+
*/
|
|
26
|
+
export interface DataArray<T> {
|
|
27
|
+
/** The total number of elements in the array. */
|
|
28
|
+
length: number;
|
|
29
|
+
/** Filter the data array down to just elements which match the given predicate. */
|
|
30
|
+
where(predicate: ArrayFunc<T, boolean>): DataArray<T>;
|
|
31
|
+
/** Alias for 'where' for people who want array semantics. */
|
|
32
|
+
filter(predicate: ArrayFunc<T, boolean>): DataArray<T>;
|
|
33
|
+
/** Map elements in the data array by applying a function to each. */
|
|
34
|
+
map<U>(f: ArrayFunc<T, U>): DataArray<U>;
|
|
35
|
+
/** Map elements in the data array by applying a function to each, then flatten the results to produce a new array. */
|
|
36
|
+
flatMap<U>(f: ArrayFunc<T, U[]>): DataArray<U>;
|
|
37
|
+
/** Mutably change each value in the array, returning the same array which you can further chain off of. */
|
|
38
|
+
mutate(f: ArrayFunc<T, void>): DataArray<T>;
|
|
39
|
+
/** Limit the total number of entries in the array to the given value. */
|
|
40
|
+
limit(count: number): DataArray<T>;
|
|
41
|
+
/**
|
|
42
|
+
* Take a slice of the array. If `start` is undefined, it is assumed to be 0; if `end` is undefined, it is assumed
|
|
43
|
+
* to be the end of the array.
|
|
44
|
+
*/
|
|
45
|
+
slice(start?: number, end?: number): DataArray<T>;
|
|
46
|
+
/** Concatenate the values in this data array with those of another iterable / data array / array. */
|
|
47
|
+
concat(other: Iterable<T>): DataArray<T>;
|
|
48
|
+
/** Return the first index of the given (optionally starting the search) */
|
|
49
|
+
indexOf(element: T, fromIndex?: number): number;
|
|
50
|
+
/** Return the first element that satisfies the given predicate. */
|
|
51
|
+
find(pred: ArrayFunc<T, boolean>): T | undefined;
|
|
52
|
+
/** Find the index of the first element that satisfies the given predicate. Returns -1 if nothing was found. */
|
|
53
|
+
findIndex(pred: ArrayFunc<T, boolean>, fromIndex?: number): number;
|
|
54
|
+
/** Returns true if the array contains the given element, and false otherwise. */
|
|
55
|
+
includes(element: T): boolean;
|
|
56
|
+
/**
|
|
57
|
+
* Return a string obtained by converting each element in the array to a string, and joining it with the
|
|
58
|
+
* given separator (which defaults to ', ').
|
|
59
|
+
*/
|
|
60
|
+
join(sep?: string): string;
|
|
61
|
+
/**
|
|
62
|
+
* Return a sorted array sorted by the given key; an optional comparator can be provided, which will
|
|
63
|
+
* be used to compare the keys in lieu of the default dataview comparator.
|
|
64
|
+
*/
|
|
65
|
+
sort<U>(key: ArrayFunc<T, U>, direction?: "asc" | "desc", comparator?: ArrayComparator<U>): DataArray<T>;
|
|
66
|
+
/**
|
|
67
|
+
* Mutably modify the current array with an in place sort; this is less flexible than a regular sort in exchange
|
|
68
|
+
* for being a little more performant. Only use this is performance is a serious consideration.
|
|
69
|
+
*/
|
|
70
|
+
sortInPlace<U>(key: (v: T) => U, direction?: "asc" | "desc", comparator?: ArrayComparator<U>): DataArray<T>;
|
|
71
|
+
/**
|
|
72
|
+
* Return an array where elements are grouped by the given key; the resulting array will have objects of the form
|
|
73
|
+
* { key: <key value>, rows: DataArray }.
|
|
74
|
+
*/
|
|
75
|
+
groupBy<U>(key: ArrayFunc<T, U>, comparator?: ArrayComparator<U>): DataArray<{
|
|
76
|
+
key: U;
|
|
77
|
+
rows: DataArray<T>;
|
|
78
|
+
}>;
|
|
79
|
+
/**
|
|
80
|
+
* If the array is not grouped, groups it as `groupBy` does; otherwise, groups the elements inside each current
|
|
81
|
+
* group. This allows for top-down recursive grouping which may be easier than bottom-up grouping.
|
|
82
|
+
*/
|
|
83
|
+
groupIn<U>(key: ArrayFunc<LowestKey<T>, U>, comparator?: ArrayComparator<U>): DataArray<Ingrouped<U, T>>;
|
|
84
|
+
/**
|
|
85
|
+
* Return distinct entries. If a key is provided, then rows with distinct keys are returned.
|
|
86
|
+
*/
|
|
87
|
+
distinct<U>(key?: ArrayFunc<T, U>, comparator?: ArrayComparator<U>): DataArray<T>;
|
|
88
|
+
/** Return true if the predicate is true for all values. */
|
|
89
|
+
every(f: ArrayFunc<T, boolean>): boolean;
|
|
90
|
+
/** Return true if the predicate is true for at least one value. */
|
|
91
|
+
some(f: ArrayFunc<T, boolean>): boolean;
|
|
92
|
+
/** Return true if the predicate is FALSE for all values. */
|
|
93
|
+
none(f: ArrayFunc<T, boolean>): boolean;
|
|
94
|
+
/** Return the first element in the data array. Returns undefined if the array is empty. */
|
|
95
|
+
first(): T;
|
|
96
|
+
/** Return the last element in the data array. Returns undefined if the array is empty. */
|
|
97
|
+
last(): T;
|
|
98
|
+
/** Map every element in this data array to the given key, and then flatten it.*/
|
|
99
|
+
to(key: string): DataArray<any>;
|
|
100
|
+
/** Map every element in this data array to the given key; unlike to(), does not flatten the result. */
|
|
101
|
+
into(key: string): DataArray<any>;
|
|
102
|
+
/**
|
|
103
|
+
* Recursively expand the given key, flattening a tree structure based on the key into a flat array. Useful for handling
|
|
104
|
+
* hierarchical data like tasks with 'subtasks'.
|
|
105
|
+
*/
|
|
106
|
+
expand(key: string): DataArray<any>;
|
|
107
|
+
/** Run a lambda on each element in the array. */
|
|
108
|
+
forEach(f: ArrayFunc<T, void>): void;
|
|
109
|
+
/** Calculate the sum of the elements in the array. */
|
|
110
|
+
sum(): number;
|
|
111
|
+
/** Calculate the average of the elements in the array. */
|
|
112
|
+
avg(): number;
|
|
113
|
+
/** Calculate the minimum of the elements in the array. */
|
|
114
|
+
min(): number;
|
|
115
|
+
/** Calculate the maximum of the elements in the array. */
|
|
116
|
+
max(): number;
|
|
117
|
+
/** Convert this to a plain javascript array. */
|
|
118
|
+
array(): T[];
|
|
119
|
+
/** Allow iterating directly over the array. */
|
|
120
|
+
[Symbol.iterator](): Iterator<T>;
|
|
121
|
+
/** Map indexes to values. */
|
|
122
|
+
[index: number]: any;
|
|
123
|
+
/** Automatic flattening of fields. Equivalent to implicitly calling `array.to("field")` */
|
|
124
|
+
[field: string]: any;
|
|
125
|
+
}
|
|
126
|
+
/** Provides utility functions for generating data arrays. */
|
|
127
|
+
export declare namespace DataArray {
|
|
128
|
+
/** Create a new Dataview data array. */
|
|
129
|
+
function wrap<T>(raw: T[] | DataArray<T>, settings: QuerySettings): DataArray<T>;
|
|
130
|
+
/** Create a new DataArray from an iterable object. */
|
|
131
|
+
function from<T>(raw: Iterable<T>, settings: QuerySettings): DataArray<T>;
|
|
132
|
+
/** Return true if the given object is a data array. */
|
|
133
|
+
function isDataArray(obj: any): obj is DataArray<any>;
|
|
134
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { STask } from "../data-model/serialized/markdown.d.ts";
|
|
2
|
+
/** A general function for deciding how to check a task given it's current state. */
|
|
3
|
+
export type TaskStatusSelector = (task: STask) => Promise<string>;
|
|
4
|
+
/**
|
|
5
|
+
* A dataview extension; allows for registering new functions, altering views, and altering some more
|
|
6
|
+
* advanced dataview behavior.
|
|
7
|
+
**/
|
|
8
|
+
export declare class Extension {
|
|
9
|
+
plugin: string;
|
|
10
|
+
/** All registered task status selectors for this extension. */
|
|
11
|
+
taskStatusSelectors: Record<string, TaskStatusSelector>;
|
|
12
|
+
constructor(plugin: string);
|
|
13
|
+
/** Register a task status selector under the given name. */
|
|
14
|
+
taskStatusSelector(name: string, selector: TaskStatusSelector): Extension;
|
|
15
|
+
}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
/** Fancy wrappers for the JavaScript API, used both by external plugins AND by the dataview javascript view. */
|
|
2
|
+
import type { App, Component } from "obsidian";
|
|
3
|
+
import type { FullIndex } from "../data-index/index.d.ts";
|
|
4
|
+
import type { DataviewApi, DataviewIOApi, QueryApiSettings, QueryResult } from "../api/plugin-api.d.ts";
|
|
5
|
+
import type { DataviewSettings, ExportSettings } from "../settings.d.ts";
|
|
6
|
+
import type { DataObject, Grouping, Link, Literal, Values, Widgets } from "../data-model/value.d.ts";
|
|
7
|
+
import type { BoundFunctionImpl } from "../expression/functions.d.ts";
|
|
8
|
+
import type { Context } from "../expression/context.d.ts";
|
|
9
|
+
import type { DateTime, Duration } from "luxon";
|
|
10
|
+
import * as Luxon from "luxon";
|
|
11
|
+
import type { DataArray } from "./data-array.d.ts";
|
|
12
|
+
import type { SListItem } from "../data-model/serialized/markdown.d.ts";
|
|
13
|
+
import type { Result } from "../api/result.d.ts";
|
|
14
|
+
/** Asynchronous API calls related to file / system IO. */
|
|
15
|
+
export declare class DataviewInlineIOApi {
|
|
16
|
+
api: DataviewIOApi;
|
|
17
|
+
currentFile: string;
|
|
18
|
+
constructor(api: DataviewIOApi, currentFile: string);
|
|
19
|
+
/** Load the contents of a CSV asynchronously, returning a data array of rows (or undefined if it does not exist). */
|
|
20
|
+
csv(path: string, originFile?: string): Promise<DataArray<DataObject> | undefined>;
|
|
21
|
+
/** Asynchronously load the contents of any link or path in an Obsidian vault. */
|
|
22
|
+
load(path: Link | string, originFile?: string): Promise<string | undefined>;
|
|
23
|
+
/** Normalize a link or path relative to an optional origin file. Returns a textual fully-qualified-path. */
|
|
24
|
+
normalize(path: Link | string, originFile?: string): string;
|
|
25
|
+
}
|
|
26
|
+
export declare class DataviewInlineApi {
|
|
27
|
+
/**
|
|
28
|
+
* The raw dataview indices, which track file <-> metadata relations. Use these if the intuitive API does not support
|
|
29
|
+
* your use case.
|
|
30
|
+
*/
|
|
31
|
+
index: FullIndex;
|
|
32
|
+
/** The component that handles the lifetime of this view. Use it if you are adding custom event handlers/components. */
|
|
33
|
+
component: Component;
|
|
34
|
+
/** The path to the current file this script is running in. */
|
|
35
|
+
currentFilePath: string;
|
|
36
|
+
/**
|
|
37
|
+
* The container which holds the output of this view. You can directly append fields to this, if you wish, though
|
|
38
|
+
* the rendering API is likely to be easier for straight-forward purposes.
|
|
39
|
+
*/
|
|
40
|
+
container: HTMLElement;
|
|
41
|
+
/** Directly access the Obsidian app object, such as for reaching out to other plugins. */
|
|
42
|
+
app: App;
|
|
43
|
+
/** The general plugin API which much of this inline API delegates to. */
|
|
44
|
+
api: DataviewApi;
|
|
45
|
+
/** Settings which determine defaults, incl. many rendering options. */
|
|
46
|
+
settings: DataviewSettings;
|
|
47
|
+
/** Evaluation context which expressions can be evaluated in. */
|
|
48
|
+
evaluationContext: Context;
|
|
49
|
+
/** Value utilities which allow for type-checking and comparisons. */
|
|
50
|
+
value: typeof Values;
|
|
51
|
+
/** Widget utility functions for creating built-in widgets. */
|
|
52
|
+
widget: typeof Widgets;
|
|
53
|
+
/** IO utilities which are largely asynchronous. */
|
|
54
|
+
io: DataviewInlineIOApi;
|
|
55
|
+
/** Re-exporting of luxon for people who can't easily require it. Sorry! */
|
|
56
|
+
luxon: typeof Luxon;
|
|
57
|
+
/** Dataview functions which can be called from DataviewJS. */
|
|
58
|
+
func: Record<string, BoundFunctionImpl>;
|
|
59
|
+
constructor(api: DataviewApi, component: Component, container: HTMLElement, currentFilePath: string);
|
|
60
|
+
/** Return an array of paths (as strings) corresponding to pages which match the query. */
|
|
61
|
+
pagePaths(query?: string): DataArray<string>;
|
|
62
|
+
/** Map a page path to the actual data contained within that page. */
|
|
63
|
+
page(path: string | Link): DataObject | undefined;
|
|
64
|
+
/** Return an array of page objects corresponding to pages which match the query. */
|
|
65
|
+
pages(query?: string): DataArray<any>;
|
|
66
|
+
/** Return the information about the current page. */
|
|
67
|
+
current(): Record<string, any> | undefined;
|
|
68
|
+
/** Execute a Dataview query, returning the results in programmatic form. */
|
|
69
|
+
query(source: string, originFile?: string, settings?: QueryApiSettings): Promise<Result<QueryResult, string>>;
|
|
70
|
+
/** Error-throwing version of {@link query}. */
|
|
71
|
+
tryQuery(source: string, originFile?: string, settings?: QueryApiSettings): Promise<QueryResult>;
|
|
72
|
+
/** Execute a Dataview query, returning the results in Markdown. */
|
|
73
|
+
queryMarkdown(source: string, originFile?: string, settings?: QueryApiSettings): Promise<Result<string, string>>;
|
|
74
|
+
/** Error-throwing version of {@link queryMarkdown}. */
|
|
75
|
+
tryQueryMarkdown(source: string, originFile?: string, settings?: QueryApiSettings): Promise<string>;
|
|
76
|
+
/**
|
|
77
|
+
* Evaluate a dataview expression (like '2 + 2' or 'link("hello")'), returning the evaluated result.
|
|
78
|
+
* This takes an optional second argument which provides definitions for variables, such as:
|
|
79
|
+
*
|
|
80
|
+
* ```
|
|
81
|
+
* dv.evaluate("x + 6", { x: 2 }) = 8
|
|
82
|
+
* dv.evaluate('link(target)', { target: "Okay" }) = [[Okay]]
|
|
83
|
+
* ```
|
|
84
|
+
*
|
|
85
|
+
* Note that `this` is implicitly available and refers to the current file.
|
|
86
|
+
*
|
|
87
|
+
* This method returns a Result type instead of throwing an error; you can check the result of the
|
|
88
|
+
* execution via `result.successful` and obtain `result.value` or `result.error` accordingly. If
|
|
89
|
+
* you'd rather this method throw on an error, use `dv.tryEvaluate`.
|
|
90
|
+
*/
|
|
91
|
+
evaluate(expression: string, context?: DataObject): Result<Literal, string>;
|
|
92
|
+
/** Error-throwing version of `dv.evaluate`. */
|
|
93
|
+
tryEvaluate(expression: string, context?: DataObject): Literal;
|
|
94
|
+
/** Execute a Dataview query and embed it into the current view. */
|
|
95
|
+
execute(source: string): Promise<void>;
|
|
96
|
+
/** Execute a DataviewJS query and embed it into the current view. */
|
|
97
|
+
executeJs(code: string): Promise<void>;
|
|
98
|
+
/**
|
|
99
|
+
* Convert an input element or array into a Dataview data-array. If the input is already a data array,
|
|
100
|
+
* it is returned unchanged.
|
|
101
|
+
*/
|
|
102
|
+
array(raw: any): DataArray<any>;
|
|
103
|
+
/** Return true if the given value is a javascript array OR a dataview data array. */
|
|
104
|
+
isArray(raw: any): raw is DataArray<any> | Array<any>;
|
|
105
|
+
/** Return true if the given value is a dataview data array; this returns FALSE for plain JS arrays. */
|
|
106
|
+
isDataArray(raw: unknown): raw is DataArray<any>;
|
|
107
|
+
/** Create a dataview file link to the given path. */
|
|
108
|
+
fileLink(path: string, embed?: boolean, display?: string): Link;
|
|
109
|
+
/** Create a dataview section link to the given path. */
|
|
110
|
+
sectionLink(path: string, section: string, embed?: boolean, display?: string): Link;
|
|
111
|
+
/** Create a dataview block link to the given path. */
|
|
112
|
+
blockLink(path: string, blockId: string, embed?: boolean, display?: string): Link;
|
|
113
|
+
/** Attempt to extract a date from a string, link or date. */
|
|
114
|
+
date(pathlike: string | Link | DateTime): DateTime | null;
|
|
115
|
+
/** Attempt to extract a duration from a string or duration. */
|
|
116
|
+
duration(dur: string | Duration): Duration | null;
|
|
117
|
+
/** Parse a raw textual value into a complex Dataview type, if possible. */
|
|
118
|
+
parse(value: string): Literal;
|
|
119
|
+
/** Convert a basic JS type into a Dataview type by parsing dates, links, durations, and so on. */
|
|
120
|
+
literal(value: any): Literal;
|
|
121
|
+
/** Deep clone the given literal, returning a new literal which is independent of the original. */
|
|
122
|
+
clone(value: Literal): Literal;
|
|
123
|
+
/**
|
|
124
|
+
* Compare two arbitrary JavaScript values using Dataview's default comparison rules. Returns a negative value if
|
|
125
|
+
* a < b, 0 if a = b, and a positive value if a > b.
|
|
126
|
+
*/
|
|
127
|
+
compare(a: any, b: any): number;
|
|
128
|
+
/** Return true if the two given JavaScript values are equal using Dataview's default comparison rules. */
|
|
129
|
+
equal(a: any, b: any): boolean;
|
|
130
|
+
/** Render an HTML element, containing arbitrary text. */
|
|
131
|
+
el<K extends keyof HTMLElementTagNameMap>(el: K, text: any, { container, ...options }?: DomElementInfo & {
|
|
132
|
+
container?: HTMLElement;
|
|
133
|
+
}): HTMLElementTagNameMap[K];
|
|
134
|
+
/** Render an HTML header; the level can be anything from 1 - 6. */
|
|
135
|
+
header(level: number, text: any, options?: DomElementInfo): HTMLHeadingElement;
|
|
136
|
+
/** Render an HTML paragraph, containing arbitrary text. */
|
|
137
|
+
paragraph(text: any, options?: DomElementInfo): HTMLParagraphElement;
|
|
138
|
+
/** Render an inline span, containing arbitrary text. */
|
|
139
|
+
span(text: any, options?: DomElementInfo): HTMLSpanElement;
|
|
140
|
+
/**
|
|
141
|
+
* Render HTML from the output of a template "view" saved as a file in the vault.
|
|
142
|
+
* Takes a filename and arbitrary input data.
|
|
143
|
+
*/
|
|
144
|
+
view(viewName: string, input: any): Promise<void>;
|
|
145
|
+
/** Render a dataview list of the given values. */
|
|
146
|
+
list(values?: any[] | DataArray<any>): Promise<void>;
|
|
147
|
+
/** Render a dataview table with the given headers, and the 2D array of values. */
|
|
148
|
+
table(headers: string[], values?: any[][] | DataArray<any>): Promise<void>;
|
|
149
|
+
/** Render a dataview task view with the given tasks. */
|
|
150
|
+
taskList(tasks: Grouping<SListItem>, groupByFile?: boolean): Promise<void>;
|
|
151
|
+
/** Render a table directly to markdown, returning the markdown. */
|
|
152
|
+
markdownTable(headers: string[], values?: any[][] | DataArray<any>, settings?: Partial<ExportSettings>): string;
|
|
153
|
+
/** Render a list directly to markdown, returning the markdown. */
|
|
154
|
+
markdownList(values?: any[] | DataArray<any> | undefined, settings?: Partial<ExportSettings>): string;
|
|
155
|
+
/** Render at ask list directly to markdown, returning the markdown. */
|
|
156
|
+
markdownTaskList(values: Grouping<SListItem>, settings?: Partial<ExportSettings>): string;
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Evaluate a script where 'this' for the script is set to the given context. Allows you to define global variables.
|
|
160
|
+
*/
|
|
161
|
+
export declare function evalInContext(script: string, context: any): any;
|
|
162
|
+
/**
|
|
163
|
+
* Evaluate a script possibly asynchronously, if the script contains `async/await` blocks.
|
|
164
|
+
*/
|
|
165
|
+
export declare function asyncEvalInContext(script: string, context: any): Promise<any>;
|