obsidian-dev-utils 2.16.0 → 2.17.1

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 (120) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/lib/@types/compare-versions.d.ts +1 -1
  3. package/dist/lib/@types.cjs +1 -1
  4. package/dist/lib/@types.d.ts +5 -5
  5. package/dist/lib/Async.cjs +1 -1
  6. package/dist/lib/Async.d.ts +12 -12
  7. package/dist/lib/Blob.cjs +1 -1
  8. package/dist/lib/Blob.d.ts +1 -1
  9. package/dist/lib/CodeGenerator.cjs +1 -1
  10. package/dist/lib/CodeGenerator.d.ts +1 -1
  11. package/dist/lib/DocumentFragment.cjs +1 -1
  12. package/dist/lib/DocumentFragment.d.ts +1 -1
  13. package/dist/lib/Error.cjs +1 -1
  14. package/dist/lib/Error.d.ts +1 -1
  15. package/dist/lib/Fs.cjs +1 -1
  16. package/dist/lib/Fs.d.ts +1 -1
  17. package/dist/lib/JSON.cjs +10 -8
  18. package/dist/lib/JSON.d.ts +28 -14
  19. package/dist/lib/Npm.cjs +11 -9
  20. package/dist/lib/Npm.d.ts +19 -13
  21. package/dist/lib/Object.cjs +1 -1
  22. package/dist/lib/Object.d.ts +3 -3
  23. package/dist/lib/Path.cjs +10 -10
  24. package/dist/lib/Path.d.ts +75 -10
  25. package/dist/lib/RegExp.cjs +1 -1
  26. package/dist/lib/RegExp.d.ts +1 -1
  27. package/dist/lib/Root.cjs +9 -8
  28. package/dist/lib/Root.d.ts +57 -24
  29. package/dist/lib/String.cjs +1 -1
  30. package/dist/lib/String.d.ts +2 -2
  31. package/dist/lib/ValueProvider.cjs +1 -1
  32. package/dist/lib/ValueProvider.d.ts +5 -5
  33. package/dist/lib/bin/ESLint/@types/@guardian__eslint-plugin-tsdoc-required.d.ts +10 -0
  34. package/dist/lib/bin/ESLint/@types/@stylistic__eslint-plugin.d.ts +1 -1
  35. package/dist/lib/bin/ESLint/@types/@typescript-eslint__eslint-plugin.d.ts +1 -1
  36. package/dist/lib/bin/ESLint/@types/@typescript-eslint__parser.d.ts +1 -1
  37. package/dist/lib/bin/ESLint/@types/eslint-plugin-deprecation.d.ts +1 -1
  38. package/dist/lib/bin/ESLint/@types/eslint-plugin-import.d.ts +1 -1
  39. package/dist/lib/bin/ESLint/@types/eslint-plugin-modules-newlines.d.ts +1 -1
  40. package/dist/lib/bin/ESLint/@types/eslint-plugin-verify-tsdoc.d.ts +10 -0
  41. package/dist/lib/bin/ESLint/@types/globals.d.ts +1 -1
  42. package/dist/lib/bin/ESLint/ESLint.cjs +11 -11
  43. package/dist/lib/bin/ESLint/ESLint.d.ts +7 -5
  44. package/dist/lib/bin/ESLint/eslint.config.cjs +1 -1
  45. package/dist/lib/bin/ESLint/eslint.config.d.ts +2 -4
  46. package/dist/lib/bin/ObsidianDevUtilsRepoPaths.cjs +1 -1
  47. package/dist/lib/bin/ObsidianDevUtilsRepoPaths.d.ts +1 -1
  48. package/dist/lib/bin/build.cjs +1 -1
  49. package/dist/lib/bin/build.d.ts +1 -1
  50. package/dist/lib/bin/cli.cjs +1 -1
  51. package/dist/lib/bin/cli.d.ts +1 -1
  52. package/dist/lib/bin/esbuild/Dependency.cjs +1 -1
  53. package/dist/lib/bin/esbuild/Dependency.d.ts +1 -1
  54. package/dist/lib/bin/esbuild/ObsidianPluginBuilder.cjs +7 -6
  55. package/dist/lib/bin/esbuild/ObsidianPluginBuilder.d.ts +21 -9
  56. package/dist/lib/bin/esbuild/copyToObsidianPluginsFolderPlugin.cjs +1 -1
  57. package/dist/lib/bin/esbuild/copyToObsidianPluginsFolderPlugin.d.ts +1 -1
  58. package/dist/lib/bin/esbuild/fixSourceMapsPlugin.cjs +1 -1
  59. package/dist/lib/bin/esbuild/fixSourceMapsPlugin.d.ts +1 -1
  60. package/dist/lib/bin/esbuild/lintPlugin.cjs +1 -1
  61. package/dist/lib/bin/esbuild/lintPlugin.d.ts +1 -1
  62. package/dist/lib/bin/esbuild/preprocessPlugin.cjs +1 -1
  63. package/dist/lib/bin/esbuild/preprocessPlugin.d.ts +2 -2
  64. package/dist/lib/bin/esbuild/renameToCjsPlugin.cjs +1 -1
  65. package/dist/lib/bin/esbuild/renameToCjsPlugin.d.ts +1 -1
  66. package/dist/lib/bin/spellcheck.cjs +1 -1
  67. package/dist/lib/bin/spellcheck.d.ts +1 -1
  68. package/dist/lib/bin/version.cjs +1 -1
  69. package/dist/lib/bin/version.d.ts +1 -1
  70. package/dist/lib/cli.cjs +2 -8
  71. package/dist/lib/cli.d.ts +2 -8
  72. package/dist/lib/obsidian/App.cjs +1 -1
  73. package/dist/lib/obsidian/App.d.ts +1 -1
  74. package/dist/lib/obsidian/AttachmentPath.cjs +1 -1
  75. package/dist/lib/obsidian/AttachmentPath.d.ts +1 -1
  76. package/dist/lib/obsidian/Backlink.cjs +15 -13
  77. package/dist/lib/obsidian/Backlink.d.ts +36 -16
  78. package/dist/lib/obsidian/Callout.cjs +9 -8
  79. package/dist/lib/obsidian/Callout.d.ts +26 -11
  80. package/dist/lib/obsidian/Dataview.cjs +28 -24
  81. package/dist/lib/obsidian/Dataview.d.ts +132 -79
  82. package/dist/lib/obsidian/DataviewLink.cjs +1 -1
  83. package/dist/lib/obsidian/DataviewLink.d.ts +7 -9
  84. package/dist/lib/obsidian/FrontMatter.cjs +1 -1
  85. package/dist/lib/obsidian/FrontMatter.d.ts +15 -18
  86. package/dist/lib/obsidian/Link.cjs +33 -30
  87. package/dist/lib/obsidian/Link.d.ts +93 -41
  88. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.cjs +1 -1
  89. package/dist/lib/obsidian/MarkdownCodeBlockProcessor.d.ts +1 -1
  90. package/dist/lib/obsidian/MetadataCache.cjs +1 -1
  91. package/dist/lib/obsidian/MetadataCache.d.ts +11 -10
  92. package/dist/lib/obsidian/Modal/Alert.cjs +1 -1
  93. package/dist/lib/obsidian/Modal/Alert.d.ts +4 -4
  94. package/dist/lib/obsidian/Modal/Prompt.cjs +8 -7
  95. package/dist/lib/obsidian/Modal/Prompt.d.ts +26 -11
  96. package/dist/lib/obsidian/Modal/SelectItem.cjs +1 -1
  97. package/dist/lib/obsidian/Modal/SelectItem.d.ts +26 -11
  98. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.cjs +1 -1
  99. package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.d.ts +1 -1
  100. package/dist/lib/obsidian/Plugin/Plugin.cjs +1 -1
  101. package/dist/lib/obsidian/Plugin/Plugin.d.ts +6 -6
  102. package/dist/lib/obsidian/Plugin/PluginBase.cjs +10 -11
  103. package/dist/lib/obsidian/Plugin/PluginBase.d.ts +14 -15
  104. package/dist/lib/obsidian/Plugin/PluginSettings.cjs +1 -1
  105. package/dist/lib/obsidian/Plugin/PluginSettings.d.ts +9 -9
  106. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.cjs +12 -19
  107. package/dist/lib/obsidian/Plugin/PluginSettingsTabBase.d.ts +27 -22
  108. package/dist/lib/obsidian/ResourceUrl.cjs +1 -1
  109. package/dist/lib/obsidian/ResourceUrl.d.ts +1 -1
  110. package/dist/lib/obsidian/TAbstractFile.cjs +1 -1
  111. package/dist/lib/obsidian/TAbstractFile.d.ts +4 -4
  112. package/dist/lib/obsidian/TFile.cjs +1 -1
  113. package/dist/lib/obsidian/TFile.d.ts +1 -1
  114. package/dist/lib/obsidian/TFolder.cjs +1 -1
  115. package/dist/lib/obsidian/TFolder.d.ts +11 -8
  116. package/dist/lib/obsidian/Vault.cjs +1 -1
  117. package/dist/lib/obsidian/Vault.d.ts +1 -1
  118. package/dist/lib/url.cjs +1 -1
  119. package/dist/lib/url.d.ts +1 -1
  120. package/package.json +7 -4
@@ -1,37 +1,56 @@
1
1
  /**
2
- * @module Backlink
2
+ * @packageDocumentation Backlink
3
3
  * Provides utility functions for working with backlinks.
4
4
  */
5
5
  import { type DataviewInlineApi } from "./Dataview.ts";
6
6
  import { type PathOrAbstractFile } from "./TAbstractFile.ts";
7
7
  import type { PathOrFile } from "./TFile.ts";
8
8
  /**
9
- * Renders delayed backlinks.
10
- *
11
- * @param {Object} options - The options for rendering delayed backlinks.
12
- * @param {DataviewInlineApi} options.dv - The Dataview inline API.
13
- * @param {PathOrFile[]} options.files - The array of files.
14
- * @param {string} [options.title="Backlinks"] - The title for the backlinks.
15
- * @returns {void}
9
+ * Options for rendering delayed backlinks.
16
10
  */
17
- export declare function renderDelayedBacklinks({ dv, files, title }: {
11
+ type RenderDelayedBacklinksOptions = {
12
+ /**
13
+ * The DataviewInlineApi instance.
14
+ */
18
15
  dv: DataviewInlineApi;
16
+ /**
17
+ * An array of PathOrFile.
18
+ */
19
19
  files: PathOrFile[];
20
+ /**
21
+ * The title for the rendered backlinks. Defaults to "Backlinks".
22
+ */
20
23
  title?: string;
21
- }): void;
24
+ };
22
25
  /**
23
- * Renders delayed backlinks for a specific folder.
26
+ * Renders delayed backlinks.
24
27
  *
25
28
  * @param options - The options for rendering delayed backlinks.
26
- * @param options.dv - The DataviewInlineApi instance.
27
- * @param options.folder - The folder path. If not provided, the current file's folder will be used.
28
- * @param options.title - The title for the rendered backlinks. Defaults to "Folder Backlinks".
29
29
  */
30
- export declare function renderDelayedBacklinksForFolder({ dv, folder, title }: {
30
+ export declare function renderDelayedBacklinks(options: RenderDelayedBacklinksOptions): void;
31
+ /**
32
+ * Options for rendering delayed backlinks for a folder.
33
+ */
34
+ type RenderDelayedBacklinksForFolderOptions = {
35
+ /**
36
+ * The DataviewInlineApi instance.
37
+ */
31
38
  dv: DataviewInlineApi;
39
+ /**
40
+ * The folder path. If not provided, the current file's folder will be used.
41
+ */
32
42
  folder?: string;
43
+ /**
44
+ * The title for the rendered backlinks. Defaults to "Folder Backlinks".
45
+ */
33
46
  title?: string;
34
- }): void;
47
+ };
48
+ /**
49
+ * Renders delayed backlinks for a specific folder.
50
+ *
51
+ * @param options - The options for rendering delayed backlinks.
52
+ */
53
+ export declare function renderDelayedBacklinksForFolder(options: RenderDelayedBacklinksForFolderOptions): void;
35
54
  /**
36
55
  * Renders a backlinks table using the provided DataviewInlineApi and optional array of PathOrAbstractFile.
37
56
  *
@@ -40,3 +59,4 @@ export declare function renderDelayedBacklinksForFolder({ dv, folder, title }: {
40
59
  * @returns A Promise that resolves when the backlinks table has been rendered.
41
60
  */
42
61
  export declare function renderBacklinksTable(dv: DataviewInlineApi, pathOrFiles?: PathOrAbstractFile[]): Promise<void>;
62
+ export {};
@@ -53,13 +53,14 @@ function getModifier(mode) {
53
53
  return "";
54
54
  }
55
55
  }
56
- function renderCallout({
57
- dv,
58
- type = "NOTE",
59
- mode = 1 /* FoldableCollapsed */,
60
- header = "",
61
- contentProvider = ""
62
- }) {
56
+ function renderCallout(options) {
57
+ const {
58
+ dv,
59
+ type = "NOTE",
60
+ mode = 1 /* FoldableCollapsed */,
61
+ header = "",
62
+ contentProvider = ""
63
+ } = options;
63
64
  const modifier = getModifier(mode);
64
65
  const callout = dv.paragraph(`> [!${type}]${modifier} ${header}
65
66
  >
@@ -97,4 +98,4 @@ function wrapForCallout(content) {
97
98
  renderCallout,
98
99
  wrapForCallout
99
100
  });
100
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NhbGxvdXQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbXCJpbXBvcnQubWV0YS51cmxcIl0gPz8gKCgpPT5yZXF1aXJlKFwibm9kZTp1cmxcIikucGF0aFRvRmlsZVVSTChfX2ZpbGVuYW1lKSkoKTtcbnZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzW1wicHJvY2Vzc1wiXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBtb2R1bGUgQ2FsbG91dFxuICogVGhpcyBtb2R1bGUgcHJvdmlkZXMgdXRpbGl0eSBmdW5jdGlvbnMgZm9yIHJlbmRlcmluZyBjYWxsb3V0cyBpbiBEYXRhdmlldy5cbiAqL1xuXG5cbmltcG9ydCB7IGludm9rZUFzeW5jU2FmZWx5IH0gZnJvbSBcIi4uL0FzeW5jLnRzXCI7XG5cbmltcG9ydCB7XG4gIGdldFJlbmRlcmVkQ29udGFpbmVyLFxuICB0eXBlIERhdGF2aWV3SW5saW5lQXBpLFxufSBmcm9tIFwiLi9EYXRhdmlldy50c1wiO1xuXG5pbXBvcnQge1xuICByZXNvbHZlVmFsdWUsXG4gIHR5cGUgVmFsdWVQcm92aWRlclxufSBmcm9tIFwiLi4vVmFsdWVQcm92aWRlci50c1wiO1xuXG4vKipcbiAqIEVudW0gcmVwcmVzZW50aW5nIHRoZSBtb2RlIG9mIGEgY2FsbG91dC5cbiAqL1xuZXhwb3J0IGVudW0gQ2FsbG91dE1vZGUge1xuICAvKiogRGVmYXVsdCBtb2RlLCB3aXRoIG5vIHNwZWNpYWwgYmVoYXZpb3IuICovXG4gIERlZmF1bHQsXG5cbiAgLyoqIEZvbGRhYmxlIG1vZGUgd2l0aCB0aGUgY2FsbG91dCBjb2xsYXBzZWQuICovXG4gIEZvbGRhYmxlQ29sbGFwc2VkLFxuXG4gIC8qKiBGb2xkYWJsZSBtb2RlIHdpdGggdGhlIGNhbGxvdXQgZXhwYW5kZWQuICovXG4gIEZvbGRhYmxlRXhwYW5kZWRcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBtb2RpZmllciBzdHJpbmcgYmFzZWQgb24gdGhlIGNhbGxvdXQgbW9kZS5cbiAqXG4gKiBAcGFyYW0gbW9kZSAtIFRoZSBtb2RlIG9mIHRoZSBjYWxsb3V0LlxuICogQHJldHVybnMgVGhlIGNvcnJlc3BvbmRpbmcgbW9kaWZpZXIgc3RyaW5nLlxuICovXG5mdW5jdGlvbiBnZXRNb2RpZmllcihtb2RlOiBDYWxsb3V0TW9kZSk6IHN0cmluZyB7XG4gIHN3aXRjaCAobW9kZSkge1xuICAgIGNhc2UgQ2FsbG91dE1vZGUuRm9sZGFibGVDb2xsYXBzZWQ6XG4gICAgICByZXR1cm4gXCItXCI7XG4gICAgY2FzZSBDYWxsb3V0TW9kZS5Gb2xkYWJsZUV4cGFuZGVkOlxuICAgICAgcmV0dXJuIFwiK1wiO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufVxuXG4vKipcbiAqIFJlbmRlcnMgYSBjYWxsb3V0IGJsb2NrIGluIERhdGF2aWV3LlxuICpcbiAqIEBwYXJhbSBkdiAtIFRoZSBEYXRhdmlld0lubGluZUFwaSBpbnN0YW5jZS5cbiAqIEBwYXJhbSB0eXBlIC0gVGhlIHR5cGUgb2YgdGhlIGNhbGxvdXQsIGRlZmF1bHQgaXMgYFwiTk9URVwiYC5cbiAqIEBwYXJhbSBtb2RlIC0gVGhlIGNhbGxvdXQgbW9kZSwgZGVmYXVsdCBpcyBgQ2FsbG91dE1vZGUuRm9sZGFibGVDb2xsYXBzZWRgLlxuICogQHBhcmFtIGhlYWRlciAtIFRoZSBoZWFkZXIgdGV4dCBvZiB0aGUgY2FsbG91dCwgZGVmYXVsdCBpcyBhbiBlbXB0eSBzdHJpbmcuXG4gKiBAcGFyYW0gY29udGVudFByb3ZpZGVyIC0gQW4gb3B0aW9uYWwgcHJvdmlkZXIgZm9yIHRoZSBjb250ZW50LCB3aGljaCBjYW4gYmUgZWl0aGVyIGEgc3RyaW5nIG9yIGEgTm9kZS5cbiAqIEBwYXJhbSBjb250ZW50UmVuZGVyZXIgLSBBbiBvcHRpb25hbCBmdW5jdGlvbiB0byByZW5kZXIgdGhlIGNvbnRlbnQgYXN5bmNocm9ub3VzbHkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJDYWxsb3V0KHtcbiAgZHYsXG4gIHR5cGUgPSBcIk5PVEVcIixcbiAgbW9kZSA9IENhbGxvdXRNb2RlLkZvbGRhYmxlQ29sbGFwc2VkLFxuICBoZWFkZXIgPSBcIlwiLFxuICBjb250ZW50UHJvdmlkZXIgPSBcIlwiXG59OiB7XG4gIGR2OiBEYXRhdmlld0lubGluZUFwaSxcbiAgdHlwZT86IHN0cmluZyxcbiAgbW9kZT86IENhbGxvdXRNb2RlLFxuICBoZWFkZXI/OiBzdHJpbmcsXG4gIGNvbnRlbnRQcm92aWRlcj86IFZhbHVlUHJvdmlkZXI8c3RyaW5nIHwgTm9kZSB8IHZvaWQ+XG59KTogdm9pZCB7XG4gIGNvbnN0IG1vZGlmaWVyID0gZ2V0TW9kaWZpZXIobW9kZSk7XG4gIGNvbnN0IGNhbGxvdXQgPSBkdi5wYXJhZ3JhcGgoYD4gWyEke3R5cGV9XSR7bW9kaWZpZXJ9ICR7aGVhZGVyfVxcbj5cXG4+IDxkaXYgY2xhc3M9XCJjb250ZW50XCI+PC9kaXY+YCk7XG4gIGNvbnN0IGNvbnRlbnREaXYgPSBjYWxsb3V0LnF1ZXJ5U2VsZWN0b3I8SFRNTERpdkVsZW1lbnQ+KFwiLmNvbnRlbnRcIikhO1xuICBkdi5wYXJhZ3JhcGgoXCJMb2FkaW5nLi4uIFx1MjNGM1wiLCB7IGNvbnRhaW5lcjogY29udGVudERpdiB9KTtcblxuICBjb25zdCBvYnNlcnZlciA9IG5ldyBJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllczogSW50ZXJzZWN0aW9uT2JzZXJ2ZXJFbnRyeVtdKSA9PiB7XG4gICAgZm9yIChjb25zdCBlbnRyeSBvZiBlbnRyaWVzKSB7XG4gICAgICBpZiAoZW50cnkuaXNJbnRlcnNlY3RpbmcpIHtcbiAgICAgICAgb2JzZXJ2ZXIudW5vYnNlcnZlKGVudHJ5LnRhcmdldCk7XG4gICAgICAgIGludm9rZUFzeW5jU2FmZWx5KGxvYWRDb250ZW50KCkpO1xuICAgICAgfVxuICAgIH1cbiAgfSk7XG4gIG9ic2VydmVyLm9ic2VydmUoY29udGVudERpdik7XG5cbiAgYXN5bmMgZnVuY3Rpb24gbG9hZENvbnRlbnQoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgc2xlZXAoNTApO1xuICAgIGxldCBjb250ZW50OiBzdHJpbmcgfCBOb2RlIHwgdm9pZDtcblxuICAgIGNvbnN0IHBhcmFncmFwaCA9IGF3YWl0IGdldFJlbmRlcmVkQ29udGFpbmVyKGR2LCBhc3luYygpID0+IHtcbiAgICAgIGNvbnRlbnQgPSBhd2FpdCByZXNvbHZlVmFsdWUoY29udGVudFByb3ZpZGVyKTtcbiAgICB9KTtcblxuICAgIGNvbnRlbnQgPz89IHBhcmFncmFwaDtcblxuICAgIGNvbnRlbnREaXYuZW1wdHkoKTtcbiAgICBkdi5wYXJhZ3JhcGgoY29udGVudCwgeyBjb250YWluZXI6IGNvbnRlbnREaXYgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBXcmFwcyB0aGUgcHJvdmlkZWQgY29udGVudCBpbiBibG9ja3F1b3RlIHN5bnRheCBmb3IgYSBjYWxsb3V0LlxuICpcbiAqIEBwYXJhbSBjb250ZW50IC0gVGhlIGNvbnRlbnQgdG8gd3JhcC5cbiAqIEByZXR1cm5zIFRoZSBjb250ZW50IHdyYXBwZWQgaW4gYmxvY2txdW90ZSBzeW50YXguXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB3cmFwRm9yQ2FsbG91dChjb250ZW50OiBzdHJpbmcpOiBzdHJpbmcge1xuICBjb25zdCBsaW5lcyA9IGNvbnRlbnQuc3BsaXQoXCJcXG5cIik7XG4gIGNvbnN0IHByZWZpeGVkTGluZXMgPSBsaW5lcy5tYXAoKGxpbmUpID0+IGA+ICR7bGluZX1gKTtcbiAgcmV0dXJuIHByZWZpeGVkTGluZXMuam9pbihcIlxcblwiKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFZQSxtQkFBa0M7QUFFbEMsc0JBR087QUFFUCwyQkFHTztBQXRCUCxJQUFJLG9CQUFvQixXQUFXLGlCQUFpQixNQUFNLE1BQUksUUFBUSxVQUFVLEVBQUUsY0FBYyxVQUFVLEdBQUc7QUFDN0csSUFBSSxZQUFZLFdBQVcsU0FBUyxLQUFLO0FBQUEsRUFDdkMsT0FBTyxNQUFJO0FBQUEsRUFDWCxPQUFPLENBQUM7QUFBQSxFQUNSLFlBQVk7QUFDZDtBQXNCTyxJQUFLLGNBQUwsa0JBQUtBLGlCQUFMO0FBRUwsRUFBQUEsMEJBQUE7QUFHQSxFQUFBQSwwQkFBQTtBQUdBLEVBQUFBLDBCQUFBO0FBUlUsU0FBQUE7QUFBQSxHQUFBO0FBaUJaLFNBQVMsWUFBWSxNQUEyQjtBQUM5QyxVQUFRLE1BQU07QUFBQSxJQUNaLEtBQUs7QUFDSCxhQUFPO0FBQUEsSUFDVCxLQUFLO0FBQ0gsYUFBTztBQUFBLElBQ1Q7QUFDRSxhQUFPO0FBQUEsRUFDWDtBQUNGO0FBWU8sU0FBUyxjQUFjO0FBQUEsRUFDNUI7QUFBQSxFQUNBLE9BQU87QUFBQSxFQUNQLE9BQU87QUFBQSxFQUNQLFNBQVM7QUFBQSxFQUNULGtCQUFrQjtBQUNwQixHQU1TO0FBQ1AsUUFBTSxXQUFXLFlBQVksSUFBSTtBQUNqQyxRQUFNLFVBQVUsR0FBRyxVQUFVLE9BQU8sSUFBSSxJQUFJLFFBQVEsSUFBSSxNQUFNO0FBQUE7QUFBQSw4QkFBb0M7QUFDbEcsUUFBTSxhQUFhLFFBQVEsY0FBOEIsVUFBVTtBQUNuRSxLQUFHLFVBQVUscUJBQWdCLEVBQUUsV0FBVyxXQUFXLENBQUM7QUFFdEQsUUFBTSxXQUFXLElBQUkscUJBQXFCLENBQUMsWUFBeUM7QUFDbEYsZUFBVyxTQUFTLFNBQVM7QUFDM0IsVUFBSSxNQUFNLGdCQUFnQjtBQUN4QixpQkFBUyxVQUFVLE1BQU0sTUFBTTtBQUMvQiw0Q0FBa0IsWUFBWSxDQUFDO0FBQUEsTUFDakM7QUFBQSxJQUNGO0FBQUEsRUFDRixDQUFDO0FBQ0QsV0FBUyxRQUFRLFVBQVU7QUFFM0IsaUJBQWUsY0FBNkI7QUFDMUMsVUFBTSxNQUFNLEVBQUU7QUFDZCxRQUFJO0FBRUosVUFBTSxZQUFZLFVBQU0sc0NBQXFCLElBQUksWUFBVztBQUMxRCxnQkFBVSxVQUFNLG1DQUFhLGVBQWU7QUFBQSxJQUM5QyxDQUFDO0FBRUQsZ0JBQVk7QUFFWixlQUFXLE1BQU07QUFDakIsT0FBRyxVQUFVLFNBQVMsRUFBRSxXQUFXLFdBQVcsQ0FBQztBQUFBLEVBQ2pEO0FBQ0Y7QUFRTyxTQUFTLGVBQWUsU0FBeUI7QUFDdEQsUUFBTSxRQUFRLFFBQVEsTUFBTSxJQUFJO0FBQ2hDLFFBQU0sZ0JBQWdCLE1BQU0sSUFBSSxDQUFDLFNBQVMsS0FBSyxJQUFJLEVBQUU7QUFDckQsU0FBTyxjQUFjLEtBQUssSUFBSTtBQUNoQzsiLAogICJuYW1lcyI6IFsiQ2FsbG91dE1vZGUiXQp9Cg==
101
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0NhbGxvdXQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbInZhciBfX2ltcG9ydF9tZXRhX3VybCA9IGdsb2JhbFRoaXNbXCJpbXBvcnQubWV0YS51cmxcIl0gPz8gKCgpPT5yZXF1aXJlKFwibm9kZTp1cmxcIikucGF0aFRvRmlsZVVSTChfX2ZpbGVuYW1lKSkoKTtcbnZhciBfX3Byb2Nlc3MgPSBnbG9iYWxUaGlzW1wicHJvY2Vzc1wiXSA/PyB7XG4gIFwiY3dkXCI6ICgpPT5cIi9cIixcbiAgXCJlbnZcIjoge30sXG4gIFwicGxhdGZvcm1cIjogXCJhbmRyb2lkXCJcbn07XG4vKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvbiBDYWxsb3V0XG4gKiBUaGlzIG1vZHVsZSBwcm92aWRlcyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgcmVuZGVyaW5nIGNhbGxvdXRzIGluIERhdGF2aWV3LlxuICovXG5cblxuaW1wb3J0IHsgaW52b2tlQXN5bmNTYWZlbHkgfSBmcm9tIFwiLi4vQXN5bmMudHNcIjtcblxuaW1wb3J0IHtcbiAgZ2V0UmVuZGVyZWRDb250YWluZXIsXG4gIHR5cGUgRGF0YXZpZXdJbmxpbmVBcGksXG59IGZyb20gXCIuL0RhdGF2aWV3LnRzXCI7XG5cbmltcG9ydCB7XG4gIHJlc29sdmVWYWx1ZSxcbiAgdHlwZSBWYWx1ZVByb3ZpZGVyXG59IGZyb20gXCIuLi9WYWx1ZVByb3ZpZGVyLnRzXCI7XG5cbi8qKlxuICogRW51bSByZXByZXNlbnRpbmcgdGhlIG1vZGUgb2YgYSBjYWxsb3V0LlxuICovXG5leHBvcnQgZW51bSBDYWxsb3V0TW9kZSB7XG4gIC8qKiBEZWZhdWx0IG1vZGUsIHdpdGggbm8gc3BlY2lhbCBiZWhhdmlvci4gKi9cbiAgRGVmYXVsdCxcblxuICAvKiogRm9sZGFibGUgbW9kZSB3aXRoIHRoZSBjYWxsb3V0IGNvbGxhcHNlZC4gKi9cbiAgRm9sZGFibGVDb2xsYXBzZWQsXG5cbiAgLyoqIEZvbGRhYmxlIG1vZGUgd2l0aCB0aGUgY2FsbG91dCBleHBhbmRlZC4gKi9cbiAgRm9sZGFibGVFeHBhbmRlZFxufVxuXG4vKipcbiAqIFJldHVybnMgdGhlIG1vZGlmaWVyIHN0cmluZyBiYXNlZCBvbiB0aGUgY2FsbG91dCBtb2RlLlxuICpcbiAqIEBwYXJhbSBtb2RlIC0gVGhlIG1vZGUgb2YgdGhlIGNhbGxvdXQuXG4gKiBAcmV0dXJucyBUaGUgY29ycmVzcG9uZGluZyBtb2RpZmllciBzdHJpbmcuXG4gKi9cbmZ1bmN0aW9uIGdldE1vZGlmaWVyKG1vZGU6IENhbGxvdXRNb2RlKTogc3RyaW5nIHtcbiAgc3dpdGNoIChtb2RlKSB7XG4gICAgY2FzZSBDYWxsb3V0TW9kZS5Gb2xkYWJsZUNvbGxhcHNlZDpcbiAgICAgIHJldHVybiBcIi1cIjtcbiAgICBjYXNlIENhbGxvdXRNb2RlLkZvbGRhYmxlRXhwYW5kZWQ6XG4gICAgICByZXR1cm4gXCIrXCI7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBcIlwiO1xuICB9XG59XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgcmVuZGVyaW5nIGEgY2FsbG91dCBibG9jayBpbiBEYXRhdmlldy5cbiAqL1xudHlwZSBSZW5kZXJDYWxsb3V0T3B0aW9ucyA9IHtcbiAgLyoqXG4gICAqIFRoZSBEYXRhdmlld0lubGluZUFwaSBpbnN0YW5jZS5cbiAgICovXG4gIGR2OiBEYXRhdmlld0lubGluZUFwaTtcblxuICAvKipcbiAgICogVGhlIHR5cGUgb2YgdGhlIGNhbGxvdXQsIGRlZmF1bHQgaXMgYFwiTk9URVwiYC5cbiAgICovXG4gIHR5cGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBjYWxsb3V0IG1vZGUsIGRlZmF1bHQgaXMgYENhbGxvdXRNb2RlLkZvbGRhYmxlQ29sbGFwc2VkYC5cbiAgICovXG4gIG1vZGU/OiBDYWxsb3V0TW9kZTtcblxuICAvKipcbiAgICogVGhlIGhlYWRlciB0ZXh0IG9mIHRoZSBjYWxsb3V0LCBkZWZhdWx0IGlzIGFuIGVtcHR5IHN0cmluZy5cbiAgICovXG4gIGhlYWRlcj86IHN0cmluZztcblxuICAvKipcbiAgICogQW4gb3B0aW9uYWwgcHJvdmlkZXIgZm9yIHRoZSBjb250ZW50LCB3aGljaCBjYW4gYmUgZWl0aGVyIGEgc3RyaW5nIG9yIGEgTm9kZS5cbiAgICovXG4gIGNvbnRlbnRQcm92aWRlcj86IFZhbHVlUHJvdmlkZXI8c3RyaW5nIHwgTm9kZSB8IHZvaWQ+O1xufTtcblxuLyoqXG4gKiBSZW5kZXJzIGEgY2FsbG91dCBibG9jayBpbiBEYXRhdmlldy5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRoZSBvcHRpb25zIGZvciByZW5kZXJpbmcgdGhlIGNhbGxvdXQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJDYWxsb3V0KG9wdGlvbnM6IFJlbmRlckNhbGxvdXRPcHRpb25zKTogdm9pZCB7XG4gIGNvbnN0IHtcbiAgICBkdixcbiAgICB0eXBlID0gXCJOT1RFXCIsXG4gICAgbW9kZSA9IENhbGxvdXRNb2RlLkZvbGRhYmxlQ29sbGFwc2VkLFxuICAgIGhlYWRlciA9IFwiXCIsXG4gICAgY29udGVudFByb3ZpZGVyID0gXCJcIlxuICB9ID0gb3B0aW9ucztcbiAgY29uc3QgbW9kaWZpZXIgPSBnZXRNb2RpZmllcihtb2RlKTtcbiAgY29uc3QgY2FsbG91dCA9IGR2LnBhcmFncmFwaChgPiBbISR7dHlwZX1dJHttb2RpZmllcn0gJHtoZWFkZXJ9XFxuPlxcbj4gPGRpdiBjbGFzcz1cImNvbnRlbnRcIj48L2Rpdj5gKTtcbiAgY29uc3QgY29udGVudERpdiA9IGNhbGxvdXQucXVlcnlTZWxlY3RvcjxIVE1MRGl2RWxlbWVudD4oXCIuY29udGVudFwiKSE7XG4gIGR2LnBhcmFncmFwaChcIkxvYWRpbmcuLi4gXHUyM0YzXCIsIHsgY29udGFpbmVyOiBjb250ZW50RGl2IH0pO1xuXG4gIGNvbnN0IG9ic2VydmVyID0gbmV3IEludGVyc2VjdGlvbk9ic2VydmVyKChlbnRyaWVzOiBJbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5W10pID0+IHtcbiAgICBmb3IgKGNvbnN0IGVudHJ5IG9mIGVudHJpZXMpIHtcbiAgICAgIGlmIChlbnRyeS5pc0ludGVyc2VjdGluZykge1xuICAgICAgICBvYnNlcnZlci51bm9ic2VydmUoZW50cnkudGFyZ2V0KTtcbiAgICAgICAgaW52b2tlQXN5bmNTYWZlbHkobG9hZENvbnRlbnQoKSk7XG4gICAgICB9XG4gICAgfVxuICB9KTtcbiAgb2JzZXJ2ZXIub2JzZXJ2ZShjb250ZW50RGl2KTtcblxuICBhc3luYyBmdW5jdGlvbiBsb2FkQ29udGVudCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBzbGVlcCg1MCk7XG4gICAgbGV0IGNvbnRlbnQ6IHN0cmluZyB8IE5vZGUgfCB2b2lkO1xuXG4gICAgY29uc3QgcGFyYWdyYXBoID0gYXdhaXQgZ2V0UmVuZGVyZWRDb250YWluZXIoZHYsIGFzeW5jKCkgPT4ge1xuICAgICAgY29udGVudCA9IGF3YWl0IHJlc29sdmVWYWx1ZShjb250ZW50UHJvdmlkZXIpO1xuICAgIH0pO1xuXG4gICAgY29udGVudCA/Pz0gcGFyYWdyYXBoO1xuXG4gICAgY29udGVudERpdi5lbXB0eSgpO1xuICAgIGR2LnBhcmFncmFwaChjb250ZW50LCB7IGNvbnRhaW5lcjogY29udGVudERpdiB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRoZSBwcm92aWRlZCBjb250ZW50IGluIGJsb2NrcXVvdGUgc3ludGF4IGZvciBhIGNhbGxvdXQuXG4gKlxuICogQHBhcmFtIGNvbnRlbnQgLSBUaGUgY29udGVudCB0byB3cmFwLlxuICogQHJldHVybnMgVGhlIGNvbnRlbnQgd3JhcHBlZCBpbiBibG9ja3F1b3RlIHN5bnRheC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHdyYXBGb3JDYWxsb3V0KGNvbnRlbnQ6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGxpbmVzID0gY29udGVudC5zcGxpdChcIlxcblwiKTtcbiAgY29uc3QgcHJlZml4ZWRMaW5lcyA9IGxpbmVzLm1hcCgobGluZSkgPT4gYD4gJHtsaW5lfWApO1xuICByZXR1cm4gcHJlZml4ZWRMaW5lcy5qb2luKFwiXFxuXCIpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVlBLG1CQUFrQztBQUVsQyxzQkFHTztBQUVQLDJCQUdPO0FBdEJQLElBQUksb0JBQW9CLFdBQVcsaUJBQWlCLE1BQU0sTUFBSSxRQUFRLFVBQVUsRUFBRSxjQUFjLFVBQVUsR0FBRztBQUM3RyxJQUFJLFlBQVksV0FBVyxTQUFTLEtBQUs7QUFBQSxFQUN2QyxPQUFPLE1BQUk7QUFBQSxFQUNYLE9BQU8sQ0FBQztBQUFBLEVBQ1IsWUFBWTtBQUNkO0FBc0JPLElBQUssY0FBTCxrQkFBS0EsaUJBQUw7QUFFTCxFQUFBQSwwQkFBQTtBQUdBLEVBQUFBLDBCQUFBO0FBR0EsRUFBQUEsMEJBQUE7QUFSVSxTQUFBQTtBQUFBLEdBQUE7QUFpQlosU0FBUyxZQUFZLE1BQTJCO0FBQzlDLFVBQVEsTUFBTTtBQUFBLElBQ1osS0FBSztBQUNILGFBQU87QUFBQSxJQUNULEtBQUs7QUFDSCxhQUFPO0FBQUEsSUFDVDtBQUNFLGFBQU87QUFBQSxFQUNYO0FBQ0Y7QUFxQ08sU0FBUyxjQUFjLFNBQXFDO0FBQ2pFLFFBQU07QUFBQSxJQUNKO0FBQUEsSUFDQSxPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxTQUFTO0FBQUEsSUFDVCxrQkFBa0I7QUFBQSxFQUNwQixJQUFJO0FBQ0osUUFBTSxXQUFXLFlBQVksSUFBSTtBQUNqQyxRQUFNLFVBQVUsR0FBRyxVQUFVLE9BQU8sSUFBSSxJQUFJLFFBQVEsSUFBSSxNQUFNO0FBQUE7QUFBQSw4QkFBb0M7QUFDbEcsUUFBTSxhQUFhLFFBQVEsY0FBOEIsVUFBVTtBQUNuRSxLQUFHLFVBQVUscUJBQWdCLEVBQUUsV0FBVyxXQUFXLENBQUM7QUFFdEQsUUFBTSxXQUFXLElBQUkscUJBQXFCLENBQUMsWUFBeUM7QUFDbEYsZUFBVyxTQUFTLFNBQVM7QUFDM0IsVUFBSSxNQUFNLGdCQUFnQjtBQUN4QixpQkFBUyxVQUFVLE1BQU0sTUFBTTtBQUMvQiw0Q0FBa0IsWUFBWSxDQUFDO0FBQUEsTUFDakM7QUFBQSxJQUNGO0FBQUEsRUFDRixDQUFDO0FBQ0QsV0FBUyxRQUFRLFVBQVU7QUFFM0IsaUJBQWUsY0FBNkI7QUFDMUMsVUFBTSxNQUFNLEVBQUU7QUFDZCxRQUFJO0FBRUosVUFBTSxZQUFZLFVBQU0sc0NBQXFCLElBQUksWUFBVztBQUMxRCxnQkFBVSxVQUFNLG1DQUFhLGVBQWU7QUFBQSxJQUM5QyxDQUFDO0FBRUQsZ0JBQVk7QUFFWixlQUFXLE1BQU07QUFDakIsT0FBRyxVQUFVLFNBQVMsRUFBRSxXQUFXLFdBQVcsQ0FBQztBQUFBLEVBQ2pEO0FBQ0Y7QUFRTyxTQUFTLGVBQWUsU0FBeUI7QUFDdEQsUUFBTSxRQUFRLFFBQVEsTUFBTSxJQUFJO0FBQ2hDLFFBQU0sZ0JBQWdCLE1BQU0sSUFBSSxDQUFDLFNBQVMsS0FBSyxJQUFJLEVBQUU7QUFDckQsU0FBTyxjQUFjLEtBQUssSUFBSTtBQUNoQzsiLAogICJuYW1lcyI6IFsiQ2FsbG91dE1vZGUiXQp9Cg==
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @module Callout
2
+ * @packageDocumentation Callout
3
3
  * This module provides utility functions for rendering callouts in Dataview.
4
4
  */
5
5
  import { type DataviewInlineApi } from "./Dataview.ts";
@@ -16,22 +16,36 @@ export declare enum CalloutMode {
16
16
  FoldableExpanded = 2
17
17
  }
18
18
  /**
19
- * Renders a callout block in Dataview.
20
- *
21
- * @param dv - The DataviewInlineApi instance.
22
- * @param type - The type of the callout, default is `"NOTE"`.
23
- * @param mode - The callout mode, default is `CalloutMode.FoldableCollapsed`.
24
- * @param header - The header text of the callout, default is an empty string.
25
- * @param contentProvider - An optional provider for the content, which can be either a string or a Node.
26
- * @param contentRenderer - An optional function to render the content asynchronously.
19
+ * Options for rendering a callout block in Dataview.
27
20
  */
28
- export declare function renderCallout({ dv, type, mode, header, contentProvider }: {
21
+ type RenderCalloutOptions = {
22
+ /**
23
+ * The DataviewInlineApi instance.
24
+ */
29
25
  dv: DataviewInlineApi;
26
+ /**
27
+ * The type of the callout, default is `"NOTE"`.
28
+ */
30
29
  type?: string;
30
+ /**
31
+ * The callout mode, default is `CalloutMode.FoldableCollapsed`.
32
+ */
31
33
  mode?: CalloutMode;
34
+ /**
35
+ * The header text of the callout, default is an empty string.
36
+ */
32
37
  header?: string;
38
+ /**
39
+ * An optional provider for the content, which can be either a string or a Node.
40
+ */
33
41
  contentProvider?: ValueProvider<string | Node | void>;
34
- }): void;
42
+ };
43
+ /**
44
+ * Renders a callout block in Dataview.
45
+ *
46
+ * @param options - The options for rendering the callout.
47
+ */
48
+ export declare function renderCallout(options: RenderCalloutOptions): void;
35
49
  /**
36
50
  * Wraps the provided content in blockquote syntax for a callout.
37
51
  *
@@ -39,3 +53,4 @@ export declare function renderCallout({ dv, type, mode, header, contentProvider
39
53
  * @returns The content wrapped in blockquote syntax.
40
54
  */
41
55
  export declare function wrapForCallout(content: string): string;
56
+ export {};
@@ -71,11 +71,12 @@ const paginationCss = `
71
71
  margin: 0 5px;
72
72
  }
73
73
  `;
74
- async function renderPaginatedList({
75
- dv,
76
- rows,
77
- itemsPerPageOptions = [10, 20, 50, 100]
78
- }) {
74
+ async function renderPaginatedList(options) {
75
+ const {
76
+ dv,
77
+ rows,
78
+ itemsPerPageOptions = [10, 20, 50, 100]
79
+ } = options;
79
80
  await renderPaginated({
80
81
  dv,
81
82
  rows,
@@ -85,12 +86,13 @@ async function renderPaginatedList({
85
86
  }
86
87
  });
87
88
  }
88
- async function renderPaginatedTable({
89
- dv,
90
- headers,
91
- rows,
92
- itemsPerPageOptions = [10, 20, 50, 100]
93
- }) {
89
+ async function renderPaginatedTable(options) {
90
+ const {
91
+ dv,
92
+ headers,
93
+ rows,
94
+ itemsPerPageOptions = [10, 20, 50, 100]
95
+ } = options;
94
96
  await renderPaginated({
95
97
  dv,
96
98
  rows,
@@ -100,12 +102,13 @@ async function renderPaginatedTable({
100
102
  }
101
103
  });
102
104
  }
103
- async function renderPaginated({
104
- dv,
105
- rows,
106
- itemsPerPageOptions = [10, 20, 50, 100],
107
- renderer
108
- }) {
105
+ async function renderPaginated(options) {
106
+ const {
107
+ dv,
108
+ rows,
109
+ itemsPerPageOptions = [10, 20, 50, 100],
110
+ renderer
111
+ } = options;
109
112
  if (rows.length === 0) {
110
113
  dv.paragraph("No items found");
111
114
  return;
@@ -202,12 +205,13 @@ async function getRenderedContainer(dv, renderer) {
202
205
  }
203
206
  return tempContainer;
204
207
  }
205
- function renderIframe({
206
- dv,
207
- relativePathOrFile,
208
- width = "100%",
209
- height = "600px"
210
- }) {
208
+ function renderIframe(options) {
209
+ const {
210
+ dv,
211
+ relativePathOrFile,
212
+ width = "100%",
213
+ height = "600px"
214
+ } = options;
211
215
  dv.el("iframe", "", {
212
216
  attr: {
213
217
  src: (0, import_ResourceUrl.relativePathToResourceUrl)(dv.app, (0, import_TAbstractFile.getPath)(relativePathOrFile), dv.current().file.path),
@@ -235,4 +239,4 @@ ${resultFence}`);
235
239
  renderPaginatedList,
236
240
  renderPaginatedTable
237
241
  });
238
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.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 * @module Dataview\n * This module provides utility functions for working with Dataview in Obsidian.\n */\n\nimport \"../@types/compare-versions.d.ts\";\n\nimport type { DataviewInlineApi as DataviewInlineApiOriginal } from \"./@types/Dataview/api/inline-api.d.ts\";\nimport type {\n  DataArray,\n  DataviewApi,\n  DateTime,\n  Link,\n  SMarkdownPage\n} from \"./@types/Dataview/index.d.ts\";\n\nimport {\n  convertAsyncToSync,\n  type MaybePromise\n} from \"../Async.ts\";\nimport { relativePathToResourceUrl } from \"../obsidian/ResourceUrl.ts\";\nimport { errorToString } from \"../Error.ts\";\nimport type { PathOrFile } from \"./TFile.ts\";\nimport { getPath } from \"./TAbstractFile.ts\";\n\ndeclare global {\n  /**\n   * The DataviewAPI object represents the API for interacting with Dataview in Obsidian.\n   *\n   * @var {DataviewApi | undefined}\n   */\n  // eslint-disable-next-line no-var\n  var DataviewAPI: DataviewApi | undefined;\n}\n\nexport type {\n  DateTime,\n  Link\n};\n\n/**\n * Extends the `DataviewInlineApiOriginal` interface to provide additional methods for interacting with Dataview.\n *\n * @interface DataviewInlineApi\n * @extends {DataviewInlineApiOriginal}\n *\n * @method current\n * @param {SMarkdownPage} [CustomPage] - A custom page type that extends the default SMarkdownPage.\n * @returns {Page<CustomPage>} The current page.\n *\n * @method array\n * @param {T[]} arr - An array of items.\n * @returns {DataArray<T>} A DataArray containing the provided items.\n *\n * @method pages\n * @param {string} [query] - A query string to filter the pages.\n * @returns {DataArray<Page<CustomPage>>} A DataArray containing the pages.\n *\n * @method paragraph\n * @param {unknown} text - The text content of the paragraph.\n * @param {DomElementInfo & { container?: HTMLElement }} [options] - Additional options for the paragraph.\n * @returns {HTMLParagraphElement} The created paragraph element.\n */\nexport interface DataviewInlineApi extends DataviewInlineApiOriginal {\n  current<CustomPage = SMarkdownPage>(): Page<CustomPage>;\n  array<T>(arr: T[]): DataArray<T>;\n  pages<CustomPage = SMarkdownPage>(query?: string): DataArray<Page<CustomPage>>;\n  paragraph(text: unknown, options?: DomElementInfo & { container?: HTMLElement }): HTMLParagraphElement;\n}\n\n/**\n * Reloads the current file cache using the Dataview API.\n *\n * @async\n * @function reloadCurrentFileCache\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @returns {Promise<void>} A promise that resolves when the cache is reloaded.\n */\nexport async function reloadCurrentFileCache(dv: DataviewInlineApi): Promise<void> {\n  await DataviewAPI?.index.reload(dv.app.vault.getFileByPath(dv.current().file.path)!);\n}\n\nexport type Page<T = SMarkdownPage> = SMarkdownPage & T;\n\ntype PageFile = Page[\"file\"];\nexport type PageFiles = DataArray<PageFile> | PageFile[];\n\nconst paginationCss = `\n.pagination .page-link.disabled {\n  pointer-events: none;\n  color: gray;\n}\n\n.pagination .page-link {\n  margin: 0 5px;\n  cursor: pointer;\n  text-decoration: none;\n  color: blue;\n}\n\n.pagination .page-link:hover:not(.disabled) {\n  text-decoration: underline;\n}\n.pagination .page-link.current {\n  font-weight: bold;\n  text-decoration: underline;\n}\n\n.pagination select,\n.pagination input {\n  margin: 0 5px;\n}\n`;\n\ntype ArrayOrDataArray<T> = T[] | DataArray<T>;\n\n/**\n * Renders a paginated list using the provided DataviewInlineApi instance.\n *\n * @async\n * @function renderPaginatedList\n * @template T\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @param {ArrayOrDataArray<T>} rows - The list of items to paginate.\n * @param {number[]} [itemsPerPageOptions=[10, 20, 50, 100]] - Options for items per page.\n * @returns {Promise<void>} A promise that resolves when the list is rendered.\n */\nexport async function renderPaginatedList<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    }\n  });\n}\n\n/**\n * Renders a paginated table using the provided DataviewInlineApi instance.\n *\n * @async\n * @function renderPaginatedTable\n * @template T\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @param {string[]} headers - The headers of the table.\n * @param {ArrayOrDataArray<T>} rows - The rows of the table to paginate.\n * @param {number[]} [itemsPerPageOptions=[10, 20, 50, 100]] - Options for items per page.\n * @returns {Promise<void>} A promise that resolves when the table is rendered.\n */\nexport async function renderPaginatedTable<T extends unknown[]>({\n  dv,\n  headers,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  headers: string[],\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    }\n  });\n}\n\n/**\n * Helper function to render paginated content using the specified renderer.\n *\n * @async\n * @template T\n * @function renderPaginated\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @param {ArrayOrDataArray<T>} rows - The rows to paginate.\n * @param {number[]} itemsPerPageOptions - Options for items per page.\n * @param {function(ArrayOrDataArray<T>): MaybePromise<void>} renderer - The renderer function to display the paginated content.\n * @returns {Promise<void>} A promise that resolves when the content is rendered.\n */\nasync function renderPaginated<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100],\n  renderer\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions: number[],\n  renderer: (rows: ArrayOrDataArray<T>) => MaybePromise<void>\n}): Promise<void> {\n  if (rows.length === 0) {\n    dv.paragraph(\"No items found\");\n    return;\n  }\n  const container = dv.container;\n  let itemsPerPage = itemsPerPageOptions[0]!;\n  let totalPages = Math.ceil(rows.length / itemsPerPage);\n  await renderPage(1);\n\n  function createPaginationControls(pageNumber: number): void {\n    const paginationDiv = container.createEl(\"div\", { cls: \"pagination\" });\n    const paginationRow1Div = paginationDiv.createDiv();\n\n    createPageLink(\"First\", 1, pageNumber === 1);\n    createPageLink(\"Prev\", pageNumber - 1, pageNumber === 1);\n\n    if (pageNumber > 3) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    for (let i = Math.max(1, pageNumber - 2); i <= Math.min(totalPages, pageNumber + 2); i++) {\n      const pageLink = createPageLink(i.toString(), i, i === pageNumber);\n      if (i === pageNumber) {\n        pageLink.addClass(\"current\");\n      }\n    }\n\n    if (pageNumber < totalPages - 2) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    createPageLink(\"Next\", pageNumber + 1, pageNumber === totalPages);\n    createPageLink(\"Last\", totalPages, pageNumber === totalPages);\n\n    const paginationRow2Div = paginationDiv.createDiv();\n\n    paginationRow2Div.createEl(\"span\", { text: \" Items per page: \" });\n\n    const itemsPerPageSelect = paginationRow2Div.createEl(\"select\");\n    itemsPerPageOptions.forEach((option: number): void => {\n      itemsPerPageSelect.createEl(\"option\", { text: option.toString(), value: option.toString() });\n    });\n    itemsPerPageSelect.value = itemsPerPage.toString();\n    itemsPerPageSelect.addEventListener(\"change\", convertAsyncToSync(async (): Promise<void> => {\n      itemsPerPage = parseInt(itemsPerPageSelect.value);\n      totalPages = Math.ceil(rows.length / itemsPerPage);\n      await renderPage(1);\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: \"  Jump to page: \" });\n\n    const jumpToPageInput = paginationRow2Div.createEl(\"input\", { type: \"number\", attr: { min: 1, max: totalPages } });\n    jumpToPageInput.addEventListener(\"keydown\", convertAsyncToSync(async (event: KeyboardEvent): Promise<void> => {\n      if (event.key === \"Enter\") {\n        const page = parseInt(jumpToPageInput.value);\n        if (page >= 1 && page <= totalPages) {\n          await renderPage(page);\n        }\n      }\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: `  Page ${pageNumber} of ${totalPages}, Total items: ${rows.length}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl(\"a\", { cls: \"page-link\", text: text, href: `#${pageNumber}` });\n      if (disabled) {\n        link.addClass(\"disabled\");\n        link.onclick = (event: MouseEvent): void => event.preventDefault();\n      } else {\n        link.addEventListener(\"click\", convertAsyncToSync(async (event: MouseEvent): Promise<void> => {\n          event.preventDefault();\n          await renderPage(pageNumber);\n        }));\n      }\n      return link;\n    }\n  }\n\n  async function renderPage(pageNumber: number): Promise<void> {\n    container.empty();\n    container.createEl(\"style\", { text: paginationCss });\n\n    const startIndex = (pageNumber - 1) * itemsPerPage;\n    const endIndex = startIndex + itemsPerPage;\n    const rowsForCurrentPage = rows.slice(startIndex, endIndex);\n\n    const oldContainer = dv.container;\n\n    dv.container = container;\n    try {\n      await renderer(rowsForCurrentPage);\n    } catch (e) {\n      dv.paragraph(\"\u274C\" + errorToString(e));\n    } finally {\n      dv.container = oldContainer;\n    }\n\n    createPaginationControls(pageNumber);\n  }\n}\n\n/**\n * Renders the content using the provided renderer function in a temporary container,\n * and then returns the container.\n *\n * @async\n * @function getRenderedContainer\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @param {() => MaybePromise<void>} renderer - The function responsible for rendering the content.\n * @returns {Promise<HTMLParagraphElement>} A promise that resolves to the HTML paragraph element\n * that was used as the temporary container.\n */\nexport async function getRenderedContainer(dv: DataviewInlineApi, renderer: () => MaybePromise<void>): Promise<HTMLParagraphElement> {\n  const tempContainer = dv.paragraph(\"\");\n  dv.container = tempContainer;\n  dv.container.empty();\n\n  try {\n    await renderer();\n  } catch (e) {\n    dv.paragraph(\"\u274C\" + errorToString(e));\n  } finally {\n    dv.container = tempContainer.parentElement!;\n    tempContainer.remove();\n  }\n\n  return tempContainer;\n}\n\n/**\n * Renders an iframe in the Dataview container with the specified relative path, width, and height.\n *\n * @function renderIframe\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.\n * @param {PathOrFile} relativePath - The relative path to the resource to be displayed in the iframe.\n * @param {string} [width=\"100%\"] - The width of the iframe. Defaults to \"100%\".\n * @param {string} [height=\"600px\"] - The height of the iframe. Defaults to \"600px\".\n * @returns {void} This function does not return a value.\n */\nexport function renderIframe({\n  dv,\n  relativePathOrFile,\n  width = \"100%\",\n  height = \"600px\"\n}: {\n  dv: DataviewInlineApi,\n  relativePathOrFile: PathOrFile,\n  width: string,\n  height: string\n}): void {\n  dv.el(\"iframe\", \"\", {\n    attr: {\n      src: relativePathToResourceUrl(dv.app, getPath(relativePathOrFile), dv.current().file.path),\n      width,\n      height\n    }\n  });\n}\n\n/**\n * Inserts a code block into the specified Dataview instance using the provided language and code.\n *\n * @function insertCodeBlock\n * @param {DataviewInlineApi} dv - The DataviewInlineApi instance to insert the code block into.\n * @param {string} language - The language identifier for the code block.\n * @param {string} code - The code content to be inserted into the code block.\n * @returns {void} This function does not return a value.\n */\nexport function insertCodeBlock(dv: DataviewInlineApi, language: string, code: string): void {\n  const fenceMatches = code.matchAll(/^`{3,}/gm);\n  const fenceLengths = Array.from(fenceMatches).map((fenceMatch) => fenceMatch[0].length);\n  const maxFenceLength = Math.max(0, ...fenceLengths);\n  const resultFenceLength = Math.max(3, maxFenceLength + 1);\n  const resultFence = \"`\".repeat(resultFenceLength);\n\n  dv.paragraph(`${resultFence}${language}\n${code}\n${resultFence}`);\n}\n"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

242
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.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 * @packageDocumentation Dataview\n * This module provides utility functions for working with Dataview in Obsidian.\n */\n\nimport \"../@types/compare-versions.d.ts\";\n\nimport type { DataviewInlineApi as DataviewInlineApiOriginal } from \"./@types/Dataview/api/inline-api.d.ts\";\nimport type {\n  DataArray,\n  DataviewApi,\n  SMarkdownPage\n} from \"./@types/Dataview/index.d.ts\";\n\n/**\n * Export DateTime and Link types from the Dataview API.\n */\nexport type {\n  DateTime,\n  Link\n} from \"./@types/Dataview/index.d.ts\";\n\nimport {\n  convertAsyncToSync,\n  type MaybePromise\n} from \"../Async.ts\";\nimport { relativePathToResourceUrl } from \"../obsidian/ResourceUrl.ts\";\nimport { errorToString } from \"../Error.ts\";\nimport type { PathOrFile } from \"./TFile.ts\";\nimport { getPath } from \"./TAbstractFile.ts\";\nimport type { CombinedFrontMatter } from \"./FrontMatter.ts\";\n\ndeclare global {\n  /**\n   * The DataviewAPI object represents the API for interacting with Dataview in Obsidian.\n   */\n  // eslint-disable-next-line no-var\n  var DataviewAPI: DataviewApi | undefined;\n}\n\n/**\n * DomElementInfo with an optional container.\n */\ntype DomElementInfoWithContainer = DomElementInfo & { container?: HTMLElement };\n\n/**\n * Extended interface for the Dataview Inline API, providing additional methods for custom page types and array handling.\n *\n * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.\n */\nexport interface DataviewInlineApi extends DataviewInlineApiOriginal {\n  /**\n   * Retrieves the current page, with an optional custom page type.\n   *\n   * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.\n   * @returns The current page.\n   */\n  current<CustomFrontMatter = unknown>(): CombinedPage<CustomFrontMatter>;\n\n  /**\n   * Wraps an array of items into a `DataArray` object.\n   *\n   * @typeParam T - The type of the items in the array.\n   * @param arr - The array of items to wrap.\n   * @returns A `DataArray` containing the items.\n   */\n  array<T>(arr: T[]): DataArray<T>;\n\n  /**\n   * Retrieves pages based on an optional query, with an optional custom page type.\n   *\n   * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.\n   * @param query - An optional string query to filter the pages.\n   * @returns A `DataArray` of pages matching the query.\n   */\n  pages<CustomFrontMatter = unknown>(query?: string): DataArray<CombinedPage<CustomFrontMatter>>;\n\n  /**\n   * Creates a paragraph HTML element with the provided text and optional DOM element options.\n   *\n   * @param text - The content of the paragraph.\n   * @param options - Optional DOM element options, including an optional container.\n   * @returns The created HTML paragraph element.\n   */\n  paragraph(\n    text: unknown,\n    options?: DomElementInfoWithContainer\n  ): HTMLParagraphElement;\n}\n\n/**\n * Reloads the current file cache using the Dataview API.\n *\n * @param dv - The DataviewInlineApi instance.\n * @returns A promise that resolves when the cache is reloaded.\n */\nexport async function reloadCurrentFileCache(dv: DataviewInlineApi): Promise<void> {\n  await DataviewAPI?.index.reload(dv.app.vault.getFileByPath(dv.current().file.path)!);\n}\n\n/**\n * The combined page type, which includes the front matter and the SMarkdownPage.\n */\nexport type CombinedPage<CustomFrontMatter = unknown> = SMarkdownPage & CombinedFrontMatter<CustomFrontMatter>;\n\ntype PageFile = SMarkdownPage[\"file\"];\n\n\n/**\n * List of page files.\n */\nexport type PageFiles = ArrayOrDataArray<PageFile>;\n\nconst paginationCss = `\n.pagination .page-link.disabled {\n  pointer-events: none;\n  color: gray;\n}\n\n.pagination .page-link {\n  margin: 0 5px;\n  cursor: pointer;\n  text-decoration: none;\n  color: blue;\n}\n\n.pagination .page-link:hover:not(.disabled) {\n  text-decoration: underline;\n}\n.pagination .page-link.current {\n  font-weight: bold;\n  text-decoration: underline;\n}\n\n.pagination select,\n.pagination input {\n  margin: 0 5px;\n}\n`;\n\ntype ArrayOrDataArray<T> = T[] | DataArray<T>;\n\n/**\n * Options for rendering a paginated list using the Dataview API.\n */\ntype RenderPaginatedListOptions<T> = {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The list of items to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n\n  /**\n   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n};\n\n/**\n * Renders a paginated list using the provided DataviewInlineApi instance.\n *\n * @typeParam T - The type of items in the list.\n *\n * @param options - The options for rendering the paginated list.\n *\n * @returns A promise that resolves when the list is rendered.\n */\nexport async function renderPaginatedList<T>(options: RenderPaginatedListOptions<T>): Promise<void> {\n  const {\n    dv,\n    rows,\n    itemsPerPageOptions = [10, 20, 50, 100]\n  } = options;\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    }\n  });\n}\n\n/**\n * Options for rendering a paginated table using the Dataview API.\n */\ntype RenderPaginatedTableOptions<T> = {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The headers of the table.\n   */\n  headers: string[];\n\n  /**\n   * The rows of the table to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n\n  /**\n   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n};\n\n/**\n * Renders a paginated table using the provided DataviewInlineApi instance.\n *\n * @typeParam T - The type of items in the table rows.\n *\n * @param options - The options for rendering the paginated table.\n *\n * @returns A promise that resolves when the table is rendered.\n */\nexport async function renderPaginatedTable<T extends unknown[]>(options: RenderPaginatedTableOptions<T>): Promise<void> {\n  const {\n    dv,\n    headers,\n    rows,\n    itemsPerPageOptions = [10, 20, 50, 100]\n  } = options;\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    }\n  });\n}\n\n/**\n * Options for rendering a paginated element using the Dataview API.\n */\ntype RenderPaginatedOptions<T> = {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The rows to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n\n  /**\n   * Options for items per page.\n   */\n  itemsPerPageOptions: number[];\n\n  /**\n   * The renderer function to display the paginated content.\n   * @param rows - The rows to render.\n   * @returns A promise that resolves when the content is rendered.\n   */\n  renderer: (rows: ArrayOrDataArray<T>) => MaybePromise<void>;\n};\n\n/**\n * Helper function to render paginated content using the specified renderer.\n *\n * @typeParam T - The type of items to paginate.\n *\n * @param options - The options for rendering the paginated content.\n *\n * @returns A promise that resolves when the content is rendered.\n */\nasync function renderPaginated<T>(options: RenderPaginatedOptions<T>): Promise<void> {\n  const {\n    dv,\n    rows,\n    itemsPerPageOptions = [10, 20, 50, 100],\n    renderer\n  } = options;\n  if (rows.length === 0) {\n    dv.paragraph(\"No items found\");\n    return;\n  }\n  const container = dv.container;\n  let itemsPerPage = itemsPerPageOptions[0]!;\n  let totalPages = Math.ceil(rows.length / itemsPerPage);\n  await renderPage(1);\n\n  function createPaginationControls(pageNumber: number): void {\n    const paginationDiv = container.createEl(\"div\", { cls: \"pagination\" });\n    const paginationRow1Div = paginationDiv.createDiv();\n\n    createPageLink(\"First\", 1, pageNumber === 1);\n    createPageLink(\"Prev\", pageNumber - 1, pageNumber === 1);\n\n    if (pageNumber > 3) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    for (let i = Math.max(1, pageNumber - 2); i <= Math.min(totalPages, pageNumber + 2); i++) {\n      const pageLink = createPageLink(i.toString(), i, i === pageNumber);\n      if (i === pageNumber) {\n        pageLink.addClass(\"current\");\n      }\n    }\n\n    if (pageNumber < totalPages - 2) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    createPageLink(\"Next\", pageNumber + 1, pageNumber === totalPages);\n    createPageLink(\"Last\", totalPages, pageNumber === totalPages);\n\n    const paginationRow2Div = paginationDiv.createDiv();\n\n    paginationRow2Div.createEl(\"span\", { text: \" Items per page: \" });\n\n    const itemsPerPageSelect = paginationRow2Div.createEl(\"select\");\n    itemsPerPageOptions.forEach((option: number): void => {\n      itemsPerPageSelect.createEl(\"option\", { text: option.toString(), value: option.toString() });\n    });\n    itemsPerPageSelect.value = itemsPerPage.toString();\n    itemsPerPageSelect.addEventListener(\"change\", convertAsyncToSync(async (): Promise<void> => {\n      itemsPerPage = parseInt(itemsPerPageSelect.value);\n      totalPages = Math.ceil(rows.length / itemsPerPage);\n      await renderPage(1);\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: \"  Jump to page: \" });\n\n    const jumpToPageInput = paginationRow2Div.createEl(\"input\", { type: \"number\", attr: { min: 1, max: totalPages } });\n    jumpToPageInput.addEventListener(\"keydown\", convertAsyncToSync(async (event: KeyboardEvent): Promise<void> => {\n      if (event.key === \"Enter\") {\n        const page = parseInt(jumpToPageInput.value);\n        if (page >= 1 && page <= totalPages) {\n          await renderPage(page);\n        }\n      }\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: `  Page ${pageNumber} of ${totalPages}, Total items: ${rows.length}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl(\"a\", { cls: \"page-link\", text: text, href: `#${pageNumber}` });\n      if (disabled) {\n        link.addClass(\"disabled\");\n        link.onclick = (event: MouseEvent): void => event.preventDefault();\n      } else {\n        link.addEventListener(\"click\", convertAsyncToSync(async (event: MouseEvent): Promise<void> => {\n          event.preventDefault();\n          await renderPage(pageNumber);\n        }));\n      }\n      return link;\n    }\n  }\n\n  async function renderPage(pageNumber: number): Promise<void> {\n    container.empty();\n    container.createEl(\"style\", { text: paginationCss });\n\n    const startIndex = (pageNumber - 1) * itemsPerPage;\n    const endIndex = startIndex + itemsPerPage;\n    const rowsForCurrentPage = rows.slice(startIndex, endIndex);\n\n    const oldContainer = dv.container;\n\n    dv.container = container;\n    try {\n      await renderer(rowsForCurrentPage);\n    } catch (e) {\n      dv.paragraph(\"\u274C\" + errorToString(e));\n    } finally {\n      dv.container = oldContainer;\n    }\n\n    createPaginationControls(pageNumber);\n  }\n}\n\n/**\n * Renders the content using the provided renderer function in a temporary container,\n * and then returns the container.\n *\n * @param dv - The DataviewInlineApi instance.\n * @param renderer - The function responsible for rendering the content.\n * @returns A promise that resolves to the HTML paragraph element\n * that was used as the temporary container.\n */\nexport async function getRenderedContainer(dv: DataviewInlineApi, renderer: () => MaybePromise<void>): Promise<HTMLParagraphElement> {\n  const tempContainer = dv.paragraph(\"\");\n  dv.container = tempContainer;\n  dv.container.empty();\n\n  try {\n    await renderer();\n  } catch (e) {\n    dv.paragraph(\"\u274C\" + errorToString(e));\n  } finally {\n    dv.container = tempContainer.parentElement!;\n    tempContainer.remove();\n  }\n\n  return tempContainer;\n}\n\n/**\n * Options for rendering an iframe in the Dataview container.\n */\ntype RenderIframeOptions = {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The relative path to the resource to be displayed in the iframe.\n   */\n  relativePathOrFile: PathOrFile;\n\n  /**\n   * The width of the iframe.\n   */\n  width: string;\n\n  /**\n   * The height of the iframe.\n   */\n  height: string;\n};\n\n/**\n * Renders an iframe in the Dataview container with the specified relative path, width, and height.\n *\n * @param options - The options for rendering the iframe.\n *\n * @returns This function does not return a value.\n */\nexport function renderIframe(options: RenderIframeOptions): void {\n  const {\n    dv,\n    relativePathOrFile,\n    width = \"100%\",\n    height = \"600px\"\n  } = options;\n  dv.el(\"iframe\", \"\", {\n    attr: {\n      src: relativePathToResourceUrl(dv.app, getPath(relativePathOrFile), dv.current().file.path),\n      width,\n      height\n    }\n  });\n}\n\n/**\n * Inserts a code block into the specified Dataview instance using the provided language and code.\n *\n * @param dv - The DataviewInlineApi instance to insert the code block into.\n * @param language - The language identifier for the code block.\n * @param code - The code content to be inserted into the code block.\n * @returns This function does not return a value.\n */\nexport function insertCodeBlock(dv: DataviewInlineApi, language: string, code: string): void {\n  const fenceMatches = code.matchAll(/^`{3,}/gm);\n  const fenceLengths = Array.from(fenceMatches).map((fenceMatch) => fenceMatch[0].length);\n  const maxFenceLength = Math.max(0, ...fenceLengths);\n  const resultFenceLength = Math.max(3, maxFenceLength + 1);\n  const resultFence = \"`\".repeat(resultFenceLength);\n\n  dv.paragraph(`${resultFence}${language}\n${code}\n${resultFence}`);\n}\n"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

@@ -1,134 +1,187 @@
1
1
  /**
2
- * @module Dataview
2
+ * @packageDocumentation Dataview
3
3
  * This module provides utility functions for working with Dataview in Obsidian.
4
4
  */
5
5
  import "../@types/compare-versions.d.ts";
6
6
  import type { DataviewInlineApi as DataviewInlineApiOriginal } from "./@types/Dataview/api/inline-api.d.ts";
7
- import type { DataArray, DataviewApi, DateTime, Link, SMarkdownPage } from "./@types/Dataview/index.d.ts";
7
+ import type { DataArray, DataviewApi, SMarkdownPage } from "./@types/Dataview/index.d.ts";
8
+ /**
9
+ * Export DateTime and Link types from the Dataview API.
10
+ */
11
+ export type { DateTime, Link } from "./@types/Dataview/index.d.ts";
8
12
  import { type MaybePromise } from "../Async.ts";
9
13
  import type { PathOrFile } from "./TFile.ts";
14
+ import type { CombinedFrontMatter } from "./FrontMatter.ts";
10
15
  declare global {
11
16
  /**
12
17
  * The DataviewAPI object represents the API for interacting with Dataview in Obsidian.
13
- *
14
- * @var {DataviewApi | undefined}
15
18
  */
16
19
  var DataviewAPI: DataviewApi | undefined;
17
20
  }
18
- export type { DateTime, Link };
19
21
  /**
20
- * Extends the `DataviewInlineApiOriginal` interface to provide additional methods for interacting with Dataview.
21
- *
22
- * @interface DataviewInlineApi
23
- * @extends {DataviewInlineApiOriginal}
24
- *
25
- * @method current
26
- * @param {SMarkdownPage} [CustomPage] - A custom page type that extends the default SMarkdownPage.
27
- * @returns {Page<CustomPage>} The current page.
28
- *
29
- * @method array
30
- * @param {T[]} arr - An array of items.
31
- * @returns {DataArray<T>} A DataArray containing the provided items.
32
- *
33
- * @method pages
34
- * @param {string} [query] - A query string to filter the pages.
35
- * @returns {DataArray<Page<CustomPage>>} A DataArray containing the pages.
22
+ * DomElementInfo with an optional container.
23
+ */
24
+ type DomElementInfoWithContainer = DomElementInfo & {
25
+ container?: HTMLElement;
26
+ };
27
+ /**
28
+ * Extended interface for the Dataview Inline API, providing additional methods for custom page types and array handling.
36
29
  *
37
- * @method paragraph
38
- * @param {unknown} text - The text content of the paragraph.
39
- * @param {DomElementInfo & { container?: HTMLElement }} [options] - Additional options for the paragraph.
40
- * @returns {HTMLParagraphElement} The created paragraph element.
30
+ * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.
41
31
  */
42
32
  export interface DataviewInlineApi extends DataviewInlineApiOriginal {
43
- current<CustomPage = SMarkdownPage>(): Page<CustomPage>;
33
+ /**
34
+ * Retrieves the current page, with an optional custom page type.
35
+ *
36
+ * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.
37
+ * @returns The current page.
38
+ */
39
+ current<CustomFrontMatter = unknown>(): CombinedPage<CustomFrontMatter>;
40
+ /**
41
+ * Wraps an array of items into a `DataArray` object.
42
+ *
43
+ * @typeParam T - The type of the items in the array.
44
+ * @param arr - The array of items to wrap.
45
+ * @returns A `DataArray` containing the items.
46
+ */
44
47
  array<T>(arr: T[]): DataArray<T>;
45
- pages<CustomPage = SMarkdownPage>(query?: string): DataArray<Page<CustomPage>>;
46
- paragraph(text: unknown, options?: DomElementInfo & {
47
- container?: HTMLElement;
48
- }): HTMLParagraphElement;
48
+ /**
49
+ * Retrieves pages based on an optional query, with an optional custom page type.
50
+ *
51
+ * @typeParam CustomPage - The type of the custom page. Defaults to `SMarkdownPage`.
52
+ * @param query - An optional string query to filter the pages.
53
+ * @returns A `DataArray` of pages matching the query.
54
+ */
55
+ pages<CustomFrontMatter = unknown>(query?: string): DataArray<CombinedPage<CustomFrontMatter>>;
56
+ /**
57
+ * Creates a paragraph HTML element with the provided text and optional DOM element options.
58
+ *
59
+ * @param text - The content of the paragraph.
60
+ * @param options - Optional DOM element options, including an optional container.
61
+ * @returns The created HTML paragraph element.
62
+ */
63
+ paragraph(text: unknown, options?: DomElementInfoWithContainer): HTMLParagraphElement;
49
64
  }
50
65
  /**
51
66
  * Reloads the current file cache using the Dataview API.
52
67
  *
53
- * @async
54
- * @function reloadCurrentFileCache
55
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.
56
- * @returns {Promise<void>} A promise that resolves when the cache is reloaded.
68
+ * @param dv - The DataviewInlineApi instance.
69
+ * @returns A promise that resolves when the cache is reloaded.
57
70
  */
58
71
  export declare function reloadCurrentFileCache(dv: DataviewInlineApi): Promise<void>;
59
- export type Page<T = SMarkdownPage> = SMarkdownPage & T;
60
- type PageFile = Page["file"];
61
- export type PageFiles = DataArray<PageFile> | PageFile[];
72
+ /**
73
+ * The combined page type, which includes the front matter and the SMarkdownPage.
74
+ */
75
+ export type CombinedPage<CustomFrontMatter = unknown> = SMarkdownPage & CombinedFrontMatter<CustomFrontMatter>;
76
+ type PageFile = SMarkdownPage["file"];
77
+ /**
78
+ * List of page files.
79
+ */
80
+ export type PageFiles = ArrayOrDataArray<PageFile>;
62
81
  type ArrayOrDataArray<T> = T[] | DataArray<T>;
63
82
  /**
64
- * Renders a paginated list using the provided DataviewInlineApi instance.
65
- *
66
- * @async
67
- * @function renderPaginatedList
68
- * @template T
69
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.
70
- * @param {ArrayOrDataArray<T>} rows - The list of items to paginate.
71
- * @param {number[]} [itemsPerPageOptions=[10, 20, 50, 100]] - Options for items per page.
72
- * @returns {Promise<void>} A promise that resolves when the list is rendered.
83
+ * Options for rendering a paginated list using the Dataview API.
73
84
  */
74
- export declare function renderPaginatedList<T>({ dv, rows, itemsPerPageOptions }: {
85
+ type RenderPaginatedListOptions<T> = {
86
+ /**
87
+ * The DataviewInlineApi instance.
88
+ */
75
89
  dv: DataviewInlineApi;
90
+ /**
91
+ * The list of items to paginate.
92
+ */
76
93
  rows: ArrayOrDataArray<T>;
94
+ /**
95
+ * Options for items per page. Defaults to `[10, 20, 50, 100]`.
96
+ */
77
97
  itemsPerPageOptions?: number[];
78
- }): Promise<void>;
98
+ };
79
99
  /**
80
- * Renders a paginated table using the provided DataviewInlineApi instance.
100
+ * Renders a paginated list using the provided DataviewInlineApi instance.
101
+ *
102
+ * @typeParam T - The type of items in the list.
103
+ *
104
+ * @param options - The options for rendering the paginated list.
81
105
  *
82
- * @async
83
- * @function renderPaginatedTable
84
- * @template T
85
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.
86
- * @param {string[]} headers - The headers of the table.
87
- * @param {ArrayOrDataArray<T>} rows - The rows of the table to paginate.
88
- * @param {number[]} [itemsPerPageOptions=[10, 20, 50, 100]] - Options for items per page.
89
- * @returns {Promise<void>} A promise that resolves when the table is rendered.
106
+ * @returns A promise that resolves when the list is rendered.
107
+ */
108
+ export declare function renderPaginatedList<T>(options: RenderPaginatedListOptions<T>): Promise<void>;
109
+ /**
110
+ * Options for rendering a paginated table using the Dataview API.
90
111
  */
91
- export declare function renderPaginatedTable<T extends unknown[]>({ dv, headers, rows, itemsPerPageOptions }: {
112
+ type RenderPaginatedTableOptions<T> = {
113
+ /**
114
+ * The DataviewInlineApi instance.
115
+ */
92
116
  dv: DataviewInlineApi;
117
+ /**
118
+ * The headers of the table.
119
+ */
93
120
  headers: string[];
121
+ /**
122
+ * The rows of the table to paginate.
123
+ */
94
124
  rows: ArrayOrDataArray<T>;
125
+ /**
126
+ * Options for items per page. Defaults to `[10, 20, 50, 100]`.
127
+ */
95
128
  itemsPerPageOptions?: number[];
96
- }): Promise<void>;
129
+ };
130
+ /**
131
+ * Renders a paginated table using the provided DataviewInlineApi instance.
132
+ *
133
+ * @typeParam T - The type of items in the table rows.
134
+ *
135
+ * @param options - The options for rendering the paginated table.
136
+ *
137
+ * @returns A promise that resolves when the table is rendered.
138
+ */
139
+ export declare function renderPaginatedTable<T extends unknown[]>(options: RenderPaginatedTableOptions<T>): Promise<void>;
97
140
  /**
98
141
  * Renders the content using the provided renderer function in a temporary container,
99
142
  * and then returns the container.
100
143
  *
101
- * @async
102
- * @function getRenderedContainer
103
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.
104
- * @param {() => MaybePromise<void>} renderer - The function responsible for rendering the content.
105
- * @returns {Promise<HTMLParagraphElement>} A promise that resolves to the HTML paragraph element
144
+ * @param dv - The DataviewInlineApi instance.
145
+ * @param renderer - The function responsible for rendering the content.
146
+ * @returns A promise that resolves to the HTML paragraph element
106
147
  * that was used as the temporary container.
107
148
  */
108
149
  export declare function getRenderedContainer(dv: DataviewInlineApi, renderer: () => MaybePromise<void>): Promise<HTMLParagraphElement>;
109
150
  /**
110
- * Renders an iframe in the Dataview container with the specified relative path, width, and height.
111
- *
112
- * @function renderIframe
113
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance.
114
- * @param {PathOrFile} relativePath - The relative path to the resource to be displayed in the iframe.
115
- * @param {string} [width="100%"] - The width of the iframe. Defaults to "100%".
116
- * @param {string} [height="600px"] - The height of the iframe. Defaults to "600px".
117
- * @returns {void} This function does not return a value.
151
+ * Options for rendering an iframe in the Dataview container.
118
152
  */
119
- export declare function renderIframe({ dv, relativePathOrFile, width, height }: {
153
+ type RenderIframeOptions = {
154
+ /**
155
+ * The DataviewInlineApi instance.
156
+ */
120
157
  dv: DataviewInlineApi;
158
+ /**
159
+ * The relative path to the resource to be displayed in the iframe.
160
+ */
121
161
  relativePathOrFile: PathOrFile;
162
+ /**
163
+ * The width of the iframe.
164
+ */
122
165
  width: string;
166
+ /**
167
+ * The height of the iframe.
168
+ */
123
169
  height: string;
124
- }): void;
170
+ };
171
+ /**
172
+ * Renders an iframe in the Dataview container with the specified relative path, width, and height.
173
+ *
174
+ * @param options - The options for rendering the iframe.
175
+ *
176
+ * @returns This function does not return a value.
177
+ */
178
+ export declare function renderIframe(options: RenderIframeOptions): void;
125
179
  /**
126
180
  * Inserts a code block into the specified Dataview instance using the provided language and code.
127
181
  *
128
- * @function insertCodeBlock
129
- * @param {DataviewInlineApi} dv - The DataviewInlineApi instance to insert the code block into.
130
- * @param {string} language - The language identifier for the code block.
131
- * @param {string} code - The code content to be inserted into the code block.
132
- * @returns {void} This function does not return a value.
182
+ * @param dv - The DataviewInlineApi instance to insert the code block into.
183
+ * @param language - The language identifier for the code block.
184
+ * @param code - The code content to be inserted into the code block.
185
+ * @returns This function does not return a value.
133
186
  */
134
187
  export declare function insertCodeBlock(dv: DataviewInlineApi, language: string, code: string): void;