obsidian-dev-utils 13.15.1-beta.6 → 13.15.1-beta.8

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.
@@ -37,28 +37,28 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
37
37
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
38
38
  var Debug_exports = {};
39
39
  __export(Debug_exports, {
40
- enableNamespaces: () => enableNamespaces,
40
+ enableLibraryDebuggers: () => enableLibraryDebuggers,
41
+ getDebugController: () => getDebugController,
41
42
  getDebugger: () => getDebugger,
42
43
  getLibDebugger: () => getLibDebugger,
43
- initDebugHelpers: () => initDebugHelpers
44
+ showInitialDebugMessage: () => showInitialDebugMessage
44
45
  });
45
46
  module.exports = __toCommonJS(Debug_exports);
46
47
  var import_debug = __toESM(__extractDefault(require('debug')), 1);
47
- let currentPluginId = "";
48
+ var import_Library = require('./Library.cjs');
49
+ var import_PluginId = require('./obsidian/Plugin/PluginId.cjs');
48
50
  const NAMESPACE_SEPARATOR = ",";
49
51
  const NEGATED_NAMESPACE_PREFIX = "-";
50
- function enableNamespaces(namespaces) {
51
- const set = new Set(getNamespaces());
52
- for (const namespace of toArray(namespaces)) {
53
- if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {
54
- const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;
55
- if (set.has(negatedNamespace)) {
56
- set.delete(negatedNamespace);
57
- }
58
- }
59
- set.add(namespace);
60
- }
61
- setNamespaces(Array.from(set));
52
+ function enableLibraryDebuggers() {
53
+ enableNamespaces([import_Library.LIBRARY_NAME, `${import_Library.LIBRARY_NAME}:*`]);
54
+ }
55
+ function getDebugController() {
56
+ return {
57
+ disable: disableNamespaces,
58
+ enable: enableNamespaces,
59
+ get: getNamespaces,
60
+ set: setNamespaces
61
+ };
62
62
  }
63
63
  function getDebugger(namespace, framesToSkip = 0) {
64
64
  const debugInstance = (0, import_debug.default)(namespace);
@@ -71,17 +71,11 @@ function getDebugger(namespace, framesToSkip = 0) {
71
71
  return debugInstance;
72
72
  }
73
73
  function getLibDebugger(namespace) {
74
- const prefix = currentPluginId ? `${currentPluginId}:` : "";
75
- return getDebugger(`${prefix}obsidian-dev-utils:${namespace}`);
74
+ const pluginId = (0, import_PluginId.getPluginId)();
75
+ const prefix = pluginId ? `${pluginId}:` : "";
76
+ return getDebugger(`${prefix}${import_Library.LIBRARY_NAME}:${namespace}`);
76
77
  }
77
- function initDebugHelpers(pluginId) {
78
- currentPluginId = pluginId;
79
- window.DEBUG = {
80
- disable: disableNamespaces,
81
- enable: enableNamespaces,
82
- get: getNamespaces,
83
- set: setNamespaces
84
- };
78
+ function showInitialDebugMessage(pluginId) {
85
79
  const isEnabled = import_debug.default.enabled(pluginId);
86
80
  const state = isEnabled ? "enabled" : "disabled";
87
81
  const changeAction = isEnabled ? "disable" : "enable";
@@ -104,6 +98,19 @@ function disableNamespaces(namespaces) {
104
98
  }
105
99
  setNamespaces(Array.from(set));
106
100
  }
101
+ function enableNamespaces(namespaces) {
102
+ const set = new Set(getNamespaces());
103
+ for (const namespace of toArray(namespaces)) {
104
+ if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {
105
+ const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;
106
+ if (set.has(negatedNamespace)) {
107
+ set.delete(negatedNamespace);
108
+ }
109
+ }
110
+ set.add(namespace);
111
+ }
112
+ setNamespaces(Array.from(set));
113
+ }
107
114
  function getNamespaces() {
108
115
  return toArray(import_debug.default.load() ?? "");
109
116
  }
@@ -145,9 +152,10 @@ function toArray(namespaces) {
145
152
  }
146
153
  // Annotate the CommonJS export names for ESM import in node:
147
154
  0 && (module.exports = {
148
- enableNamespaces,
155
+ enableLibraryDebuggers,
156
+ getDebugController,
149
157
  getDebugger,
150
158
  getLibDebugger,
151
- initDebugHelpers
159
+ showInitialDebugMessage
152
160
  });
153
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Debug.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Debug\n * Contains utility functions for debugging.\n */\n\nimport type { Debugger } from 'debug';\n\nimport debug from 'debug';\n\nimport type { DebugController } from './DebugController.ts';\n\ninterface DebuggerEx extends Debugger {\n  printStackTrace(stackTrace: string, title?: string): void;\n}\n\ninterface DebugWrapper {\n  DEBUG: DebugController;\n}\n\nlet currentPluginId = '';\nconst NAMESPACE_SEPARATOR = ',';\nconst NEGATED_NAMESPACE_PREFIX = '-';\n\n/**\n * Enables the specified namespaces.\n *\n * @param namespaces - The namespaces to enable.\n */\nexport function enableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n      if (set.has(negatedNamespace)) {\n        set.delete(negatedNamespace);\n      }\n    }\n    set.add(namespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\n/**\n * Returns a debugger instance with a log function that includes the caller's file name and line number.\n *\n * @param namespace - The namespace for the debugger instance.\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A debugger instance with a log function that includes the caller's file name and line number.\n */\nexport function getDebugger(namespace: string, framesToSkip = 0): DebuggerEx {\n  const debugInstance = debug(namespace) as DebuggerEx;\n  debugInstance.log = (message: string, ...args: unknown[]): void => {\n    logWithCaller(namespace, framesToSkip, message, ...args);\n  };\n  debugInstance.printStackTrace = (stackTrace, title): void => {\n    printStackTrace(namespace, stackTrace, title);\n  };\n  return debugInstance;\n}\n\n/**\n * Returns a debugger instance for the `obsidian-dev-utils` library.\n *\n * @param namespace - The namespace for the debugger instance.\n * @returns A debugger instance for the `obsidian-dev-utils` library.\n */\nexport function getLibDebugger(namespace: string): DebuggerEx {\n  const prefix = currentPluginId ? `${currentPluginId}:` : '';\n  return getDebugger(`${prefix}obsidian-dev-utils:${namespace}`);\n}\n\n/**\n * Adds the DEBUG variable to the window object.\n *\n * @param pluginId - The plugin ID.\n */\nexport function initDebugHelpers(pluginId: string): void {\n  currentPluginId = pluginId;\n  (window as Partial<DebugWrapper>).DEBUG = {\n    disable: disableNamespaces,\n    enable: enableNamespaces,\n    get: getNamespaces,\n    set: setNamespaces\n  };\n\n  const isEnabled = debug.enabled(pluginId);\n  const state = isEnabled ? 'enabled' : 'disabled';\n  const changeAction = isEnabled ? 'disable' : 'enable';\n  const namespaces = getNamespaces();\n  setNamespaces(pluginId);\n  getDebugger(pluginId)(`Debug messages for plugin ${pluginId} are ${state}. See https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging how to ${changeAction} them.`);\n  setNamespaces(namespaces);\n}\n\nfunction disableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      continue;\n    }\n    const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n    if (set.has(namespace)) {\n      set.delete(namespace);\n    }\n    set.add(negatedNamespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction getNamespaces(): string[] {\n  return toArray(debug.load() ?? '');\n}\n\nfunction isInObsidian(): boolean {\n  return typeof window !== 'undefined';\n}\n\nfunction logWithCaller(namespace: string, framesToSkip: number, message: string, ...args: unknown[]): void {\n  if (!debug.enabled(namespace)) {\n    return;\n  }\n\n  /**\n   * The caller line index is 4 because the call stack is as follows:\n   *\n   * 0: Error\n   * 1:     at logWithCaller (?:?:?)\n   * 2:     at debugInstance.log (?:?:?)\n   * 3:     at debug (?:?:?)\n   * 4:     at functionName (path/to/caller.js:?:?)\n   */\n  const CALLER_LINE_INDEX = 4;\n\n  const stackLines = new Error().stack?.split('\\n') ?? [];\n  const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? '';\n  console.debug(message, ...args);\n  if (isInObsidian()) {\n    printStackTrace(namespace, callerLine, 'Debug message caller');\n  }\n}\n\nfunction printStackTrace(namespace: string, stackTrace: string, title?: string): void {\n  const _debugger = debug(namespace);\n\n  if (!_debugger.enabled) {\n    return;\n  }\n\n  if (!stackTrace) {\n    stackTrace = '(unavailable)';\n  }\n  if (!title) {\n    title = 'Caller stack trace';\n  }\n\n  _debugger(title);\n  const prefix = isInObsidian() ? 'StackTraceFakeError\\n' : '';\n  console.debug(`${prefix}${stackTrace}`);\n}\n\nfunction setNamespaces(namespaces: string | string[]): void {\n  debug.enable(toArray(namespaces).join(NAMESPACE_SEPARATOR));\n}\n\nfunction toArray(namespaces: string | string[]): string[] {\n  return typeof namespaces === 'string' ? namespaces.split(NAMESPACE_SEPARATOR).filter(Boolean) : namespaces.flatMap(toArray);\n}\n"],
  "mappings": "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",
  "names": ["debug"]
}

161
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Debug.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Debug\n * Contains utility functions for debugging.\n */\n\nimport type { Debugger } from 'debug';\n\nimport debug from 'debug';\n\nimport type { DebugController } from './DebugController.ts';\n\nimport { LIBRARY_NAME } from './Library.ts';\nimport { getPluginId } from './obsidian/Plugin/PluginId.ts';\n\ninterface DebuggerEx extends Debugger {\n  printStackTrace(stackTrace: string, title?: string): void;\n}\n\nconst NAMESPACE_SEPARATOR = ',';\nconst NEGATED_NAMESPACE_PREFIX = '-';\n\n/**\n * Enables the debuggers for the `obsidian-dev-utils` library.\n */\nexport function enableLibraryDebuggers(): void {\n  enableNamespaces([LIBRARY_NAME, `${LIBRARY_NAME}:*`]);\n}\n\n/**\n * Returns a debug controller.\n *\n * @returns A debug controller.\n */\nexport function getDebugController(): DebugController {\n  return {\n    disable: disableNamespaces,\n    enable: enableNamespaces,\n    get: getNamespaces,\n    set: setNamespaces\n  };\n}\n\n/**\n * Returns a debugger instance with a log function that includes the caller's file name and line number.\n *\n * @param namespace - The namespace for the debugger instance.\n * @param framesToSkip - The number of frames to skip in the stack trace.\n * @returns A debugger instance with a log function that includes the caller's file name and line number.\n */\nexport function getDebugger(namespace: string, framesToSkip = 0): DebuggerEx {\n  const debugInstance = debug(namespace) as DebuggerEx;\n  debugInstance.log = (message: string, ...args: unknown[]): void => {\n    logWithCaller(namespace, framesToSkip, message, ...args);\n  };\n  debugInstance.printStackTrace = (stackTrace, title): void => {\n    printStackTrace(namespace, stackTrace, title);\n  };\n  return debugInstance;\n}\n\n/**\n * Returns a debugger instance for the `obsidian-dev-utils` library.\n *\n * @param namespace - The namespace for the debugger instance.\n * @returns A debugger instance for the `obsidian-dev-utils` library.\n */\nexport function getLibDebugger(namespace: string): DebuggerEx {\n  const pluginId = getPluginId();\n  const prefix = pluginId ? `${pluginId}:` : '';\n  return getDebugger(`${prefix}${LIBRARY_NAME}:${namespace}`);\n}\n\n/**\n * Shows an initial debug message.\n *\n * @param pluginId - The plugin ID.\n */\nexport function showInitialDebugMessage(pluginId: string): void {\n  const isEnabled = debug.enabled(pluginId);\n  const state = isEnabled ? 'enabled' : 'disabled';\n  const changeAction = isEnabled ? 'disable' : 'enable';\n  const namespaces = getNamespaces();\n  setNamespaces(pluginId);\n  getDebugger(pluginId)(`Debug messages for plugin ${pluginId} are ${state}. See https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging how to ${changeAction} them.`);\n  setNamespaces(namespaces);\n}\n\nfunction disableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      continue;\n    }\n    const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n    if (set.has(namespace)) {\n      set.delete(namespace);\n    }\n    set.add(negatedNamespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction enableNamespaces(namespaces: string | string[]): void {\n  const set = new Set(getNamespaces());\n  for (const namespace of toArray(namespaces)) {\n    if (!namespace.startsWith(NEGATED_NAMESPACE_PREFIX)) {\n      const negatedNamespace = NEGATED_NAMESPACE_PREFIX + namespace;\n      if (set.has(negatedNamespace)) {\n        set.delete(negatedNamespace);\n      }\n    }\n    set.add(namespace);\n  }\n  setNamespaces(Array.from(set));\n}\n\nfunction getNamespaces(): string[] {\n  return toArray(debug.load() ?? '');\n}\n\nfunction isInObsidian(): boolean {\n  return typeof window !== 'undefined';\n}\n\nfunction logWithCaller(namespace: string, framesToSkip: number, message: string, ...args: unknown[]): void {\n  if (!debug.enabled(namespace)) {\n    return;\n  }\n\n  /**\n   * The caller line index is 4 because the call stack is as follows:\n   *\n   * 0: Error\n   * 1:     at logWithCaller (?:?:?)\n   * 2:     at debugInstance.log (?:?:?)\n   * 3:     at debug (?:?:?)\n   * 4:     at functionName (path/to/caller.js:?:?)\n   */\n  const CALLER_LINE_INDEX = 4;\n\n  const stackLines = new Error().stack?.split('\\n') ?? [];\n  const callerLine = stackLines[CALLER_LINE_INDEX + framesToSkip] ?? '';\n  console.debug(message, ...args);\n  if (isInObsidian()) {\n    printStackTrace(namespace, callerLine, 'Debug message caller');\n  }\n}\n\nfunction printStackTrace(namespace: string, stackTrace: string, title?: string): void {\n  const _debugger = debug(namespace);\n\n  if (!_debugger.enabled) {\n    return;\n  }\n\n  if (!stackTrace) {\n    stackTrace = '(unavailable)';\n  }\n  if (!title) {\n    title = 'Caller stack trace';\n  }\n\n  _debugger(title);\n  const prefix = isInObsidian() ? 'StackTraceFakeError\\n' : '';\n  console.debug(`${prefix}${stackTrace}`);\n}\n\n/**\n * Sets the namespaces to enable.\n *\n * @param namespaces - The namespaces to enable.\n */\nfunction setNamespaces(namespaces: string | string[]): void {\n  debug.enable(toArray(namespaces).join(NAMESPACE_SEPARATOR));\n}\n\nfunction toArray(namespaces: string | string[]): string[] {\n  return typeof namespaces === 'string' ? namespaces.split(NAMESPACE_SEPARATOR).filter(Boolean) : namespaces.flatMap(toArray);\n}\n"],
  "mappings": "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",
  "names": ["debug"]
}

@@ -3,15 +3,20 @@
3
3
  * Contains utility functions for debugging.
4
4
  */
5
5
  import type { Debugger } from 'debug';
6
+ import type { DebugController } from './DebugController.ts';
6
7
  interface DebuggerEx extends Debugger {
7
8
  printStackTrace(stackTrace: string, title?: string): void;
8
9
  }
9
10
  /**
10
- * Enables the specified namespaces.
11
+ * Enables the debuggers for the `obsidian-dev-utils` library.
12
+ */
13
+ export declare function enableLibraryDebuggers(): void;
14
+ /**
15
+ * Returns a debug controller.
11
16
  *
12
- * @param namespaces - The namespaces to enable.
17
+ * @returns A debug controller.
13
18
  */
14
- export declare function enableNamespaces(namespaces: string | string[]): void;
19
+ export declare function getDebugController(): DebugController;
15
20
  /**
16
21
  * Returns a debugger instance with a log function that includes the caller's file name and line number.
17
22
  *
@@ -28,9 +33,9 @@ export declare function getDebugger(namespace: string, framesToSkip?: number): D
28
33
  */
29
34
  export declare function getLibDebugger(namespace: string): DebuggerEx;
30
35
  /**
31
- * Adds the DEBUG variable to the window object.
36
+ * Shows an initial debug message.
32
37
  *
33
38
  * @param pluginId - The plugin ID.
34
39
  */
35
- export declare function initDebugHelpers(pluginId: string): void;
40
+ export declare function showInitialDebugMessage(pluginId: string): void;
36
41
  export {};
@@ -0,0 +1,44 @@
1
+ /*
2
+ THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
3
+ if you want to view the source, please visit the github repository of this plugin
4
+ */
5
+
6
+ function __extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}
7
+
8
+ (function patchRequireEsmDefault(){const __require=require;require=Object.assign(id=>{const module=__require(id)??{};return __extractDefault(module)},__require)})()
9
+
10
+ "use strict";
11
+ var __defProp = Object.defineProperty;
12
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
13
+ var __getOwnPropNames = Object.getOwnPropertyNames;
14
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
15
+ var __export = (target, all) => {
16
+ for (var name in all)
17
+ __defProp(target, name, { get: all[name], enumerable: true });
18
+ };
19
+ var __copyProps = (to, from, except, desc) => {
20
+ if (from && typeof from === "object" || typeof from === "function") {
21
+ for (let key of __getOwnPropNames(from))
22
+ if (!__hasOwnProp.call(to, key) && key !== except)
23
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
24
+ }
25
+ return to;
26
+ };
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var Library_exports = {};
29
+ __export(Library_exports, {
30
+ LIBRARY_NAME: () => LIBRARY_NAME,
31
+ LIBRARY_STYLES: () => LIBRARY_STYLES,
32
+ LIBRARY_VERSION: () => LIBRARY_VERSION
33
+ });
34
+ module.exports = __toCommonJS(Library_exports);
35
+ const LIBRARY_VERSION = "13.15.1-beta.8";
36
+ const LIBRARY_NAME = "obsidian-dev-utils";
37
+ const LIBRARY_STYLES = ".obsidian-dev-utils.plugin-settings-tab .value-component-invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n";
38
+ // Annotate the CommonJS export names for ESM import in node:
39
+ 0 && (module.exports = {
40
+ LIBRARY_NAME,
41
+ LIBRARY_STYLES,
42
+ LIBRARY_VERSION
43
+ });
44
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL0xpYnJhcnkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogVGhlIHZlcnNpb24gb2YgdGhlIGBvYnNpZGlhbi1kZXYtdXRpbHNgIGxpYnJhcnkuXG4gKi9cbmV4cG9ydCBjb25zdCBMSUJSQVJZX1ZFUlNJT04gPSAnJChMSUJSQVJZX1ZFUlNJT04pJztcblxuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgYG9ic2lkaWFuLWRldi11dGlsc2AgbGlicmFyeS5cbiAqL1xuZXhwb3J0IGNvbnN0IExJQlJBUllfTkFNRSA9ICdvYnNpZGlhbi1kZXYtdXRpbHMnO1xuXG4vKipcbiAqIFRoZSBzdHlsZXMgb2YgdGhlIGBvYnNpZGlhbi1kZXYtdXRpbHNgIGxpYnJhcnkuXG4gKi9cbmV4cG9ydCBjb25zdCBMSUJSQVJZX1NUWUxFUyA9ICckKExJQlJBUllfU1RZTEVTKSc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUdPLE1BQU0sa0JBQWtCO0FBS3hCLE1BQU0sZUFBZTtBQUtyQixNQUFNLGlCQUFpQjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,12 @@
1
+ /**
2
+ * The version of the `obsidian-dev-utils` library.
3
+ */
4
+ export declare const LIBRARY_VERSION = "$(LIBRARY_VERSION)";
5
+ /**
6
+ * The name of the `obsidian-dev-utils` library.
7
+ */
8
+ export declare const LIBRARY_NAME = "obsidian-dev-utils";
9
+ /**
10
+ * The styles of the `obsidian-dev-utils` library.
11
+ */
12
+ export declare const LIBRARY_STYLES = "$(LIBRARY_STYLES)";
@@ -44,6 +44,7 @@ __export(index_exports, {
44
44
  Error: () => Error2,
45
45
  Function: () => Function,
46
46
  HTMLElement: () => HTMLElement,
47
+ Library: () => Library,
47
48
  Object: () => Object2,
48
49
  Path: () => Path,
49
50
  RegExp: () => RegExp,
@@ -63,6 +64,7 @@ var DebugController = __toESM(__extractDefault(require('./DebugController.cjs'))
63
64
  var Error2 = __toESM(__extractDefault(require('./Error.cjs')), 1);
64
65
  var Function = __toESM(__extractDefault(require('./Function.cjs')), 1);
65
66
  var HTMLElement = __toESM(__extractDefault(require('./HTMLElement.cjs')), 1);
67
+ var Library = __toESM(__extractDefault(require('./Library.cjs')), 1);
66
68
  var Object2 = __toESM(__extractDefault(require('./Object.cjs')), 1);
67
69
  var obsidian = __toESM(__extractDefault(require('./obsidian/index.cjs')), 1);
68
70
  var Path = __toESM(__extractDefault(require('./Path.cjs')), 1);
@@ -80,6 +82,7 @@ var ValueProvider = __toESM(__extractDefault(require('./ValueProvider.cjs')), 1)
80
82
  Error,
81
83
  Function,
82
84
  HTMLElement,
85
+ Library,
83
86
  Object,
84
87
  Path,
85
88
  RegExp,
@@ -90,4 +93,4 @@ var ValueProvider = __toESM(__extractDefault(require('./ValueProvider.cjs')), 1)
90
93
  scripts,
91
94
  url
92
95
  });
93
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgX3R5cGVzIGZyb20gJy4vQHR5cGVzLnRzJztcbmV4cG9ydCAqIGFzIEFzeW5jIGZyb20gJy4vQXN5bmMudHMnO1xuZXhwb3J0ICogYXMgQmxvYiBmcm9tICcuL0Jsb2IudHMnO1xuZXhwb3J0ICogYXMgRGVidWcgZnJvbSAnLi9EZWJ1Zy50cyc7XG5leHBvcnQgKiBhcyBEZWJ1Z0NvbnRyb2xsZXIgZnJvbSAnLi9EZWJ1Z0NvbnRyb2xsZXIudHMnO1xuZXhwb3J0ICogYXMgRXJyb3IgZnJvbSAnLi9FcnJvci50cyc7XG5leHBvcnQgKiBhcyBGdW5jdGlvbiBmcm9tICcuL0Z1bmN0aW9uLnRzJztcbmV4cG9ydCAqIGFzIEhUTUxFbGVtZW50IGZyb20gJy4vSFRNTEVsZW1lbnQudHMnO1xuZXhwb3J0ICogYXMgT2JqZWN0IGZyb20gJy4vT2JqZWN0LnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuIGZyb20gJy4vb2JzaWRpYW4vaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUGF0aCBmcm9tICcuL1BhdGgudHMnO1xuZXhwb3J0ICogYXMgUmVnRXhwIGZyb20gJy4vUmVnRXhwLnRzJztcbmV4cG9ydCAqIGFzIHNjcmlwdHMgZnJvbSAnLi9zY3JpcHRzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIFN0cmluZyBmcm9tICcuL1N0cmluZy50cyc7XG5leHBvcnQgKiBhcyB1cmwgZnJvbSAnLi91cmwudHMnO1xuZXhwb3J0ICogYXMgVmFsdWVQcm92aWRlciBmcm9tICcuL1ZhbHVlUHJvdmlkZXIudHMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLGVBQUFBO0FBQUEsRUFBQTtBQUFBO0FBQUEsZ0JBQUFDO0FBQUEsRUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLGFBQXdCO0FBQ3hCLFlBQXVCO0FBQ3ZCLFdBQXNCO0FBQ3RCLFlBQXVCO0FBQ3ZCLHNCQUFpQztBQUNqQyxJQUFBRCxTQUF1QjtBQUN2QixlQUEwQjtBQUMxQixrQkFBNkI7QUFDN0IsSUFBQUMsVUFBd0I7QUFDeEIsZUFBMEI7QUFDMUIsV0FBc0I7QUFDdEIsYUFBd0I7QUFDeEIsY0FBeUI7QUFDekIsYUFBd0I7QUFDeEIsVUFBcUI7QUFDckIsb0JBQStCOyIsCiAgIm5hbWVzIjogWyJFcnJvciIsICJPYmplY3QiXQp9Cg==
96
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgX3R5cGVzIGZyb20gJy4vQHR5cGVzLnRzJztcbmV4cG9ydCAqIGFzIEFzeW5jIGZyb20gJy4vQXN5bmMudHMnO1xuZXhwb3J0ICogYXMgQmxvYiBmcm9tICcuL0Jsb2IudHMnO1xuZXhwb3J0ICogYXMgRGVidWcgZnJvbSAnLi9EZWJ1Zy50cyc7XG5leHBvcnQgKiBhcyBEZWJ1Z0NvbnRyb2xsZXIgZnJvbSAnLi9EZWJ1Z0NvbnRyb2xsZXIudHMnO1xuZXhwb3J0ICogYXMgRXJyb3IgZnJvbSAnLi9FcnJvci50cyc7XG5leHBvcnQgKiBhcyBGdW5jdGlvbiBmcm9tICcuL0Z1bmN0aW9uLnRzJztcbmV4cG9ydCAqIGFzIEhUTUxFbGVtZW50IGZyb20gJy4vSFRNTEVsZW1lbnQudHMnO1xuZXhwb3J0ICogYXMgTGlicmFyeSBmcm9tICcuL0xpYnJhcnkudHMnO1xuZXhwb3J0ICogYXMgT2JqZWN0IGZyb20gJy4vT2JqZWN0LnRzJztcbmV4cG9ydCAqIGFzIG9ic2lkaWFuIGZyb20gJy4vb2JzaWRpYW4vaW5kZXgudHMnO1xuZXhwb3J0ICogYXMgUGF0aCBmcm9tICcuL1BhdGgudHMnO1xuZXhwb3J0ICogYXMgUmVnRXhwIGZyb20gJy4vUmVnRXhwLnRzJztcbmV4cG9ydCAqIGFzIHNjcmlwdHMgZnJvbSAnLi9zY3JpcHRzL2luZGV4LnRzJztcbmV4cG9ydCAqIGFzIFN0cmluZyBmcm9tICcuL1N0cmluZy50cyc7XG5leHBvcnQgKiBhcyB1cmwgZnJvbSAnLi91cmwudHMnO1xuZXhwb3J0ICogYXMgVmFsdWVQcm92aWRlciBmcm9tICcuL1ZhbHVlUHJvdmlkZXIudHMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLGVBQUFBO0FBQUEsRUFBQTtBQUFBO0FBQUE7QUFBQSxnQkFBQUM7QUFBQSxFQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUEsYUFBd0I7QUFDeEIsWUFBdUI7QUFDdkIsV0FBc0I7QUFDdEIsWUFBdUI7QUFDdkIsc0JBQWlDO0FBQ2pDLElBQUFELFNBQXVCO0FBQ3ZCLGVBQTBCO0FBQzFCLGtCQUE2QjtBQUM3QixjQUF5QjtBQUN6QixJQUFBQyxVQUF3QjtBQUN4QixlQUEwQjtBQUMxQixXQUFzQjtBQUN0QixhQUF3QjtBQUN4QixjQUF5QjtBQUN6QixhQUF3QjtBQUN4QixVQUFxQjtBQUNyQixvQkFBK0I7IiwKICAibmFtZXMiOiBbIkVycm9yIiwgIk9iamVjdCJdCn0K
@@ -6,6 +6,7 @@ export * as DebugController from './DebugController.ts';
6
6
  export * as Error from './Error.ts';
7
7
  export * as Function from './Function.ts';
8
8
  export * as HTMLElement from './HTMLElement.ts';
9
+ export * as Library from './Library.ts';
9
10
  export * as Object from './Object.ts';
10
11
  export * as obsidian from './obsidian/index.ts';
11
12
  export * as Path from './Path.ts';
@@ -32,27 +32,18 @@ __export(App_exports, {
32
32
  getObsidianDevUtilsState: () => getObsidianDevUtilsState
33
33
  });
34
34
  module.exports = __toCommonJS(App_exports);
35
+ var import_Error = require('../Error.cjs');
35
36
  class ValueWrapper {
36
37
  constructor(value) {
37
38
  this.value = value;
38
39
  }
39
40
  }
40
41
  function getApp() {
41
- let canRequire;
42
42
  try {
43
- globalThis.require.resolve("obsidian/app");
44
- canRequire = true;
45
- } catch {
46
- canRequire = false;
47
- }
48
- if (canRequire) {
49
43
  return globalThis.require('obsidian/app');
44
+ } catch {
45
+ return globalThis.app ?? (0, import_Error.throwExpression)(new Error("Obsidian app not found"));
50
46
  }
51
- const app = globalThis.app;
52
- if (app) {
53
- return app;
54
- }
55
- throw new Error("Obsidian app not found");
56
47
  }
57
48
  function getObsidianDevUtilsState(app, key, defaultValue) {
58
49
  const sharedStateWrapper = app;
@@ -65,4 +56,4 @@ function getObsidianDevUtilsState(app, key, defaultValue) {
65
56
  getApp,
66
57
  getObsidianDevUtilsState
67
58
  });
68
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0FwcC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gQXBwXG4gKiBQcm92aWRlcyBhIHV0aWxpdHkgdG8gcmV0cmlldmUgdGhlIE9ic2lkaWFuIGBBcHBgIGluc3RhbmNlLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG4vKipcbiAqIFdyYXBwZXIgdHlwZSBmb3IgYWNjZXNzaW5nIHRoZSBgQXBwYCBpbnN0YW5jZSBnbG9iYWxseS5cbiAqL1xuaW50ZXJmYWNlIEFwcFdyYXBwZXIge1xuICAvKipcbiAgICogQW4gb3B0aW9uYWwgcmVmZXJlbmNlIHRvIHRoZSBPYnNpZGlhbiBgQXBwYCBpbnN0YW5jZS5cbiAgICovXG4gIGFwcDogQXBwO1xufVxuXG5pbnRlcmZhY2UgT2JzaWRpYW5EZXZVdGlsc1N0YXRlV3JhcHBlciB7XG4gIG9ic2lkaWFuRGV2VXRpbHNTdGF0ZTogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG59XG5cbi8qKlxuICogV3JhcHBlciB0eXBlIGZvciBzdG9yaW5nIHNoYXJlZCBzdGF0ZSBpbiB0aGUgT2JzaWRpYW4gYXBwLlxuICovXG5leHBvcnQgY2xhc3MgVmFsdWVXcmFwcGVyPFQ+IHtcbiAgcHVibGljIGNvbnN0cnVjdG9yKHB1YmxpYyB2YWx1ZTogVCkgeyB9XG59XG5cbi8qKlxuICogUmV0cmlldmVzIHRoZSBPYnNpZGlhbiBgQXBwYCBpbnN0YW5jZS5cbiAqXG4gKiBAcmV0dXJucyBUaGUgYEFwcGAgaW5zdGFuY2UuXG4gKiBAdGhyb3dzIFdpbGwgdGhyb3cgYW4gZXJyb3IgaWYgdGhlIGBBcHBgIGluc3RhbmNlIGNhbm5vdCBiZSBmb3VuZC5cbiAqXG4gKiBAc2VlIHtAbGluayBodHRwczovL2dpdGh1Yi5jb20vbW5hb3Vtb3Yvb2JzaWRpYW4tZml4LXJlcXVpcmUtbW9kdWxlcy8/dGFiPXJlYWRtZS1vdi1maWxlI29ic2lkaWFuYXBwLW1vZHVsZX1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEFwcCgpOiBBcHAge1xuICBsZXQgY2FuUmVxdWlyZTogYm9vbGVhbjtcbiAgdHJ5IHtcbiAgICBnbG9iYWxUaGlzLnJlcXVpcmUucmVzb2x2ZSgnb2JzaWRpYW4vYXBwJyk7XG4gICAgY2FuUmVxdWlyZSA9IHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIGNhblJlcXVpcmUgPSBmYWxzZTtcbiAgfVxuXG4gIGlmIChjYW5SZXF1aXJlKSB7XG4gICAgcmV0dXJuIGdsb2JhbFRoaXMucmVxdWlyZSgnb2JzaWRpYW4vYXBwJykgYXMgQXBwO1xuICB9XG5cbiAgY29uc3QgYXBwID0gKGdsb2JhbFRoaXMgYXMgUGFydGlhbDxBcHBXcmFwcGVyPikuYXBwO1xuICBpZiAoYXBwKSB7XG4gICAgcmV0dXJuIGFwcDtcbiAgfVxuXG4gIHRocm93IG5ldyBFcnJvcignT2JzaWRpYW4gYXBwIG5vdCBmb3VuZCcpO1xufVxuXG4vKipcbiAqIFJldHJpZXZlcyBvciBjcmVhdGVzIGEgc2hhcmVkIHN0YXRlIHdyYXBwZXIgb2JqZWN0IGZvciBhIGdpdmVuIGtleSBpbiB0aGUgT2JzaWRpYW4gYXBwLlxuICpcbiAqIEBwYXJhbSBhcHAgLSBUaGUgT2JzaWRpYW4gYXBwIGluc3RhbmNlLlxuICogQHBhcmFtIGtleSAtIFRoZSBrZXkgdG8gc3RvcmUgb3IgcmV0cmlldmUgdGhlIHNoYXJlZCBzdGF0ZS5cbiAqIEBwYXJhbSBkZWZhdWx0VmFsdWUgLSBUaGUgZGVmYXVsdCB2YWx1ZSB0byB1c2UgaWYgdGhlIHNoYXJlZCBzdGF0ZSBkb2VzIG5vdCBleGlzdC5cbiAqIEByZXR1cm5zIFRoZSBWYWx1ZVdyYXBwZXIgb2JqZWN0IHRoYXQgc3RvcmVzIHRoZSBzaGFyZWQgc3RhdGUuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRPYnNpZGlhbkRldlV0aWxzU3RhdGU8VD4oYXBwOiBBcHAsIGtleTogc3RyaW5nLCBkZWZhdWx0VmFsdWU6IFQpOiBWYWx1ZVdyYXBwZXI8VD4ge1xuICBjb25zdCBzaGFyZWRTdGF0ZVdyYXBwZXIgPSBhcHAgYXMgUGFydGlhbDxPYnNpZGlhbkRldlV0aWxzU3RhdGVXcmFwcGVyPjtcbiAgY29uc3Qgc2hhcmVkU3RhdGUgPSBzaGFyZWRTdGF0ZVdyYXBwZXIub2JzaWRpYW5EZXZVdGlsc1N0YXRlID8/PSB7fTtcbiAgcmV0dXJuIChzaGFyZWRTdGF0ZVtrZXldID8/PSBuZXcgVmFsdWVXcmFwcGVyPFQ+KGRlZmF1bHRWYWx1ZSkpIGFzIFZhbHVlV3JhcHBlcjxUPjtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBd0JPLE1BQU0sYUFBZ0I7QUFBQSxFQUNwQixZQUFtQixPQUFVO0FBQVY7QUFBQSxFQUFZO0FBQ3hDO0FBVU8sU0FBUyxTQUFjO0FBQzVCLE1BQUk7QUFDSixNQUFJO0FBQ0YsZUFBVyxRQUFRLFFBQVEsY0FBYztBQUN6QyxpQkFBYTtBQUFBLEVBQ2YsUUFBUTtBQUNOLGlCQUFhO0FBQUEsRUFDZjtBQUVBLE1BQUksWUFBWTtBQUNkLFdBQU8sV0FBVyxRQUFRLGNBQWM7QUFBQSxFQUMxQztBQUVBLFFBQU0sTUFBTyxXQUFtQztBQUNoRCxNQUFJLEtBQUs7QUFDUCxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sSUFBSSxNQUFNLHdCQUF3QjtBQUMxQztBQVVPLFNBQVMseUJBQTRCLEtBQVUsS0FBYSxjQUFrQztBQUNuRyxRQUFNLHFCQUFxQjtBQUMzQixRQUFNLGNBQWMsbUJBQW1CLDBCQUEwQixDQUFDO0FBQ2xFLFNBQVEsWUFBWSxHQUFHLE1BQU0sSUFBSSxhQUFnQixZQUFZO0FBQy9EOyIsCiAgIm5hbWVzIjogW10KfQo=
59
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL29ic2lkaWFuL0FwcC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gQXBwXG4gKiBQcm92aWRlcyBhIHV0aWxpdHkgdG8gcmV0cmlldmUgdGhlIE9ic2lkaWFuIGBBcHBgIGluc3RhbmNlLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyB0aHJvd0V4cHJlc3Npb24gfSBmcm9tICcuLi9FcnJvci50cyc7XG5cbi8qKlxuICogV3JhcHBlciB0eXBlIGZvciBhY2Nlc3NpbmcgdGhlIGBBcHBgIGluc3RhbmNlIGdsb2JhbGx5LlxuICovXG5pbnRlcmZhY2UgQXBwV3JhcHBlciB7XG4gIC8qKlxuICAgKiBBbiBvcHRpb25hbCByZWZlcmVuY2UgdG8gdGhlIE9ic2lkaWFuIGBBcHBgIGluc3RhbmNlLlxuICAgKi9cbiAgYXBwOiBBcHA7XG59XG5cbmludGVyZmFjZSBPYnNpZGlhbkRldlV0aWxzU3RhdGVXcmFwcGVyIHtcbiAgb2JzaWRpYW5EZXZVdGlsc1N0YXRlOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbn1cblxuLyoqXG4gKiBXcmFwcGVyIHR5cGUgZm9yIHN0b3Jpbmcgc2hhcmVkIHN0YXRlIGluIHRoZSBPYnNpZGlhbiBhcHAuXG4gKi9cbmV4cG9ydCBjbGFzcyBWYWx1ZVdyYXBwZXI8VD4ge1xuICBwdWJsaWMgY29uc3RydWN0b3IocHVibGljIHZhbHVlOiBUKSB7IH1cbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgdGhlIE9ic2lkaWFuIGBBcHBgIGluc3RhbmNlLlxuICpcbiAqIEByZXR1cm5zIFRoZSBgQXBwYCBpbnN0YW5jZS5cbiAqIEB0aHJvd3MgV2lsbCB0aHJvdyBhbiBlcnJvciBpZiB0aGUgYEFwcGAgaW5zdGFuY2UgY2Fubm90IGJlIGZvdW5kLlxuICpcbiAqIEBzZWUge0BsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS9tbmFvdW1vdi9vYnNpZGlhbi1jb2Rlc2NyaXB0LXRvb2xraXQ/dGFiPXJlYWRtZS1vdi1maWxlI29ic2lkaWFuYXBwLW1vZHVsZX1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEFwcCgpOiBBcHAge1xuICB0cnkge1xuICAgIHJldHVybiBnbG9iYWxUaGlzLnJlcXVpcmUoJ29ic2lkaWFuL2FwcCcpIGFzIEFwcDtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIChnbG9iYWxUaGlzIGFzIFBhcnRpYWw8QXBwV3JhcHBlcj4pLmFwcCA/PyB0aHJvd0V4cHJlc3Npb24obmV3IEVycm9yKCdPYnNpZGlhbiBhcHAgbm90IGZvdW5kJykpO1xuICB9XG59XG5cbi8qKlxuICogUmV0cmlldmVzIG9yIGNyZWF0ZXMgYSBzaGFyZWQgc3RhdGUgd3JhcHBlciBvYmplY3QgZm9yIGEgZ2l2ZW4ga2V5IGluIHRoZSBPYnNpZGlhbiBhcHAuXG4gKlxuICogQHBhcmFtIGFwcCAtIFRoZSBPYnNpZGlhbiBhcHAgaW5zdGFuY2UuXG4gKiBAcGFyYW0ga2V5IC0gVGhlIGtleSB0byBzdG9yZSBvciByZXRyaWV2ZSB0aGUgc2hhcmVkIHN0YXRlLlxuICogQHBhcmFtIGRlZmF1bHRWYWx1ZSAtIFRoZSBkZWZhdWx0IHZhbHVlIHRvIHVzZSBpZiB0aGUgc2hhcmVkIHN0YXRlIGRvZXMgbm90IGV4aXN0LlxuICogQHJldHVybnMgVGhlIFZhbHVlV3JhcHBlciBvYmplY3QgdGhhdCBzdG9yZXMgdGhlIHNoYXJlZCBzdGF0ZS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldE9ic2lkaWFuRGV2VXRpbHNTdGF0ZTxUPihhcHA6IEFwcCwga2V5OiBzdHJpbmcsIGRlZmF1bHRWYWx1ZTogVCk6IFZhbHVlV3JhcHBlcjxUPiB7XG4gIGNvbnN0IHNoYXJlZFN0YXRlV3JhcHBlciA9IGFwcCBhcyBQYXJ0aWFsPE9ic2lkaWFuRGV2VXRpbHNTdGF0ZVdyYXBwZXI+O1xuICBjb25zdCBzaGFyZWRTdGF0ZSA9IHNoYXJlZFN0YXRlV3JhcHBlci5vYnNpZGlhbkRldlV0aWxzU3RhdGUgPz89IHt9O1xuICByZXR1cm4gKHNoYXJlZFN0YXRlW2tleV0gPz89IG5ldyBWYWx1ZVdyYXBwZXI8VD4oZGVmYXVsdFZhbHVlKSkgYXMgVmFsdWVXcmFwcGVyPFQ+O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFPQSxtQkFBZ0M7QUFtQnpCLE1BQU0sYUFBZ0I7QUFBQSxFQUNwQixZQUFtQixPQUFVO0FBQVY7QUFBQSxFQUFZO0FBQ3hDO0FBVU8sU0FBUyxTQUFjO0FBQzVCLE1BQUk7QUFDRixXQUFPLFdBQVcsUUFBUSxjQUFjO0FBQUEsRUFDMUMsUUFBUTtBQUNOLFdBQVEsV0FBbUMsV0FBTyw4QkFBZ0IsSUFBSSxNQUFNLHdCQUF3QixDQUFDO0FBQUEsRUFDdkc7QUFDRjtBQVVPLFNBQVMseUJBQTRCLEtBQVUsS0FBYSxjQUFrQztBQUNuRyxRQUFNLHFCQUFxQjtBQUMzQixRQUFNLGNBQWMsbUJBQW1CLDBCQUEwQixDQUFDO0FBQ2xFLFNBQVEsWUFBWSxHQUFHLE1BQU0sSUFBSSxhQUFnQixZQUFZO0FBQy9EOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -16,7 +16,7 @@ export declare class ValueWrapper<T> {
16
16
  * @returns The `App` instance.
17
17
  * @throws Will throw an error if the `App` instance cannot be found.
18
18
  *
19
- * @see {@link https://github.com/mnaoumov/obsidian-fix-require-modules/?tab=readme-ov-file#obsidianapp-module}
19
+ * @see {@link https://github.com/mnaoumov/obsidian-codescript-toolkit?tab=readme-ov-file#obsidianapp-module}
20
20
  */
21
21
  export declare function getApp(): App;
22
22
  /**
@@ -35,7 +35,6 @@ __export(Dataview_exports, {
35
35
  renderPaginatedTable: () => renderPaginatedTable
36
36
  });
37
37
  module.exports = __toCommonJS(Dataview_exports);
38
- var import_compare_versions_d = undefined;
39
38
  var import_Async = require('../Async.cjs');
40
39
  var import_Error = require('../Error.cjs');
41
40
  var import_FileSystem = require('./FileSystem.cjs');
@@ -239,4 +238,4 @@ async function renderPaginated(options) {
239
238
  renderPaginatedList,
240
239
  renderPaginatedTable
241
240
  });
242
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Dataview\n * This module provides utility functions for working with Dataview in Obsidian.\n */\n\n// eslint-disable-next-line import-x/no-unassigned-import\nimport '../@types/compare-versions.d.ts';\n\nimport type { MaybePromise } from '../Async.ts';\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';\nimport type { PathOrFile } from './FileSystem.ts';\nimport type { CombinedFrontmatter } from './Frontmatter.ts';\n\nimport { convertAsyncToSync } from '../Async.ts';\nimport {\n  errorToString,\n  throwExpression\n} from '../Error.ts';\nimport {\n  getFile,\n  getPath\n} from './FileSystem.ts';\nimport { relativePathToResourceUrl } from './ResourceUrl.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\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 * The combined page type, which includes the front matter and the SMarkdownPage.\n */\nexport type CombinedPage<CustomFrontmatter = unknown> = CombinedFrontmatter<CustomFrontmatter> & SMarkdownPage;\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   * 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 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   * 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 * DomElementInfo with an optional container.\n */\nexport type DomElementInfoWithContainer = { container?: HTMLElement } & DomElementInfo;\n\n/**\n * The combined file type, which includes the front matter and the SMarkdownFile.\n */\nexport type PageFile = SMarkdownPage['file'];\n\n/**\n * List of page files.\n */\nexport type PageFiles = ArrayOrDataArray<PageFile>;\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(getFile(dv.app, dv.current().file.path));\n}\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\n/**\n * Array or DataArray type.\n */\nexport type ArrayOrDataArray<T> = DataArray<T> | T[];\n\n/**\n * Options for rendering an iframe in the Dataview container.\n */\nexport interface RenderIframeOptions {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The height of the iframe.\n   */\n  height: string;\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/**\n * Options for rendering a paginated list using the Dataview API.\n */\nexport interface RenderPaginatedListOptions<T> {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n\n  /**\n   * The list of items to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n}\n\n/**\n * Options for rendering a paginated element using the Dataview API.\n */\nexport interface RenderPaginatedOptions<T> {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\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   * The rows to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n}\n\n/**\n * Options for rendering a paginated table using the Dataview API.\n */\nexport interface 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   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n\n  /**\n   * The rows of the table to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\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 ?? throwExpression(new Error('Container parent not found'));\n    tempContainer.remove();\n  }\n\n  return tempContainer;\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\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    height = '600px',\n    relativePathOrFile,\n    width = '100%'\n  } = options;\n  dv.el('iframe', '', {\n    attr: {\n      height,\n      src: relativePathToResourceUrl(dv.app, getPath(dv.app, relativePathOrFile), dv.current().file.path),\n      width\n    }\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    rows\n  } = options;\n  await renderPaginated({\n    dv,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    },\n    rows\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    rows\n  } = options;\n  await renderPaginated({\n    dv,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    },\n    rows\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    renderer,\n    rows\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] ?? throwExpression(new Error('Items per page options are empty'));\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', { attr: { max: totalPages, min: 1 }, type: 'number' });\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.toString()} of ${totalPages.toString()}, Total items: ${rows.length.toString()}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl('a', { cls: 'page-link', href: `#${pageNumber.toString()}`, text: text });\n      if (disabled) {\n        link.addClass('disabled');\n        link.onclick = (event: MouseEvent): void => {\n          event.preventDefault();\n        };\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"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

241
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation Dataview\n * This module provides utility functions for working with Dataview in Obsidian.\n */\n\nimport type { MaybePromise } from '../Async.ts';\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';\nimport type { PathOrFile } from './FileSystem.ts';\nimport type { CombinedFrontmatter } from './Frontmatter.ts';\n\nimport { convertAsyncToSync } from '../Async.ts';\nimport {\n  errorToString,\n  throwExpression\n} from '../Error.ts';\nimport {\n  getFile,\n  getPath\n} from './FileSystem.ts';\nimport { relativePathToResourceUrl } from './ResourceUrl.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\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 * The combined page type, which includes the front matter and the SMarkdownPage.\n */\nexport type CombinedPage<CustomFrontmatter = unknown> = CombinedFrontmatter<CustomFrontmatter> & SMarkdownPage;\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   * 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 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   * 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 * DomElementInfo with an optional container.\n */\nexport type DomElementInfoWithContainer = { container?: HTMLElement } & DomElementInfo;\n\n/**\n * The combined file type, which includes the front matter and the SMarkdownFile.\n */\nexport type PageFile = SMarkdownPage['file'];\n\n/**\n * List of page files.\n */\nexport type PageFiles = ArrayOrDataArray<PageFile>;\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(getFile(dv.app, dv.current().file.path));\n}\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\n/**\n * Array or DataArray type.\n */\nexport type ArrayOrDataArray<T> = DataArray<T> | T[];\n\n/**\n * Options for rendering an iframe in the Dataview container.\n */\nexport interface RenderIframeOptions {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * The height of the iframe.\n   */\n  height: string;\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/**\n * Options for rendering a paginated list using the Dataview API.\n */\nexport interface RenderPaginatedListOptions<T> {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\n\n  /**\n   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n\n  /**\n   * The list of items to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n}\n\n/**\n * Options for rendering a paginated element using the Dataview API.\n */\nexport interface RenderPaginatedOptions<T> {\n  /**\n   * The DataviewInlineApi instance.\n   */\n  dv: DataviewInlineApi;\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   * The rows to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\n}\n\n/**\n * Options for rendering a paginated table using the Dataview API.\n */\nexport interface 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   * Options for items per page. Defaults to `[10, 20, 50, 100]`.\n   */\n  itemsPerPageOptions?: number[];\n\n  /**\n   * The rows of the table to paginate.\n   */\n  rows: ArrayOrDataArray<T>;\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 ?? throwExpression(new Error('Container parent not found'));\n    tempContainer.remove();\n  }\n\n  return tempContainer;\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\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    height = '600px',\n    relativePathOrFile,\n    width = '100%'\n  } = options;\n  dv.el('iframe', '', {\n    attr: {\n      height,\n      src: relativePathToResourceUrl(dv.app, getPath(dv.app, relativePathOrFile), dv.current().file.path),\n      width\n    }\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    rows\n  } = options;\n  await renderPaginated({\n    dv,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    },\n    rows\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    rows\n  } = options;\n  await renderPaginated({\n    dv,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    },\n    rows\n  });\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    itemsPerPageOptions = [10, 20, 50, 100],\n    renderer,\n    rows\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] ?? throwExpression(new Error('Items per page options are empty'));\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', { attr: { max: totalPages, min: 1 }, type: 'number' });\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.toString()} of ${totalPages.toString()}, Total items: ${rows.length.toString()}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl('a', { cls: 'page-link', href: `#${pageNumber.toString()}`, text: text });\n      if (disabled) {\n        link.addClass('disabled');\n        link.onclick = (event: MouseEvent): void => {\n          event.preventDefault();\n        };\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"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

@@ -2,7 +2,6 @@
2
2
  * @packageDocumentation Dataview
3
3
  * This module provides utility functions for working with Dataview in Obsidian.
4
4
  */
5
- import '../@types/compare-versions.d.ts';
6
5
  import type { MaybePromise } from '../Async.ts';
7
6
  import type { DataviewInlineApi as DataviewInlineApiOriginal } from './@types/Dataview/api/inline-api.d.ts';
8
7
  import type { DataArray, DataviewApi, SMarkdownPage } from './@types/Dataview/index.d.ts';
@@ -38,6 +38,8 @@ var ObsidianPluginRepoPaths = /* @__PURE__ */ ((ObsidianPluginRepoPaths2) => {
38
38
  ObsidianPluginRepoPaths2["DistBuild"] = "dist/build";
39
39
  ObsidianPluginRepoPaths2["DistDev"] = "dist/dev";
40
40
  ObsidianPluginRepoPaths2["HotReload"] = ".hotreload";
41
+ ObsidianPluginRepoPaths2["Lib"] = "lib";
42
+ ObsidianPluginRepoPaths2["LibraryCjs"] = "Library.cjs";
41
43
  ObsidianPluginRepoPaths2["MainJs"] = "main.js";
42
44
  ObsidianPluginRepoPaths2["MainTs"] = "main.ts";
43
45
  ObsidianPluginRepoPaths2["ManifestJson"] = "manifest.json";
@@ -53,4 +55,4 @@ var ObsidianPluginRepoPaths = /* @__PURE__ */ ((ObsidianPluginRepoPaths2) => {
53
55
  0 && (module.exports = {
54
56
  ObsidianPluginRepoPaths
55
57
  });
56
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL1BsdWdpbi9PYnNpZGlhblBsdWdpblJlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHNcbiAqIFRoaXMgZmlsZSBkZWZpbmVzIGFuIGVudW1lcmF0aW9uIGZvciBjb21tb24gZmlsZSBhbmQgZGlyZWN0b3J5IHBhdGhzIHVzZWQgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5cbi8qKlxuICogRW51bWVyYXRpb24gb2YgY29tbW9ubHkgdXNlZCBmaWxlIGFuZCBkaXJlY3RvcnkgcGF0aHMgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5leHBvcnQgZW51bSBPYnNpZGlhblBsdWdpblJlcG9QYXRocyB7XG4gIC8qKiBSZXByZXNlbnRzIGFueSBwYXRoIHJlY3Vyc2l2ZWx5LiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogUmVwcmVzZW50cyBhbnkgVHlwZVNjcmlwdCBmaWxlLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgY2hhbmdlbG9nIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3QgPSAnZGlzdCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGJ1aWxkIGRpcmVjdG9yeSB3aXRoaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3RCdWlsZCA9ICdkaXN0L2J1aWxkJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgZGV2ZWxvcG1lbnQgZGlyZWN0b3J5IHdpdGhpbiB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS4gKi9cbiAgRGlzdERldiA9ICdkaXN0L2RldicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGhvdCByZWxvYWQgZmlsZS4gKi9cbiAgSG90UmVsb2FkID0gJy5ob3RyZWxvYWQnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYWluIEphdmFTY3JpcHQgZmlsZS4gKi9cbiAgTWFpbkpzID0gJ21haW4uanMnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYWluIFR5cGVTY3JpcHQgZmlsZS4gKi9cbiAgTWFpblRzID0gJ21haW4udHMnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYW5pZmVzdCBmaWxlLiAqL1xuICBNYW5pZmVzdEpzb24gPSAnbWFuaWZlc3QuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHBhY2thZ2UuanNvbiBmaWxlLiAqL1xuICBQYWNrYWdlSnNvbiA9ICdwYWNrYWdlLmpzb24nLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBwYWNrYWdlLWxvY2suanNvbiBmaWxlLiAqL1xuICBQYWNrYWdlTG9ja0pzb24gPSAncGFja2FnZS1sb2NrLmpzb24nLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBzb3VyY2UgZGlyZWN0b3J5LiAqL1xuICBTcmMgPSAnc3JjJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgc3R5bGVzLmNzcyBmaWxlLiAqL1xuICBTdHlsZXNDc3MgPSAnc3R5bGVzLmNzcycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIFR5cGVTY3JpcHQgY29uZmlndXJhdGlvbiBmaWxlLiAqL1xuICBUc0NvbmZpZ0pzb24gPSAndHNjb25maWcuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnNpb25zLmpzb24gZmlsZS4gKi9cbiAgVmVyc2lvbnNKc29uID0gJ3ZlcnNpb25zLmpzb24nXG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBUU8sSUFBSywwQkFBTCxrQkFBS0EsNkJBQUw7QUFFTCxFQUFBQSx5QkFBQSxhQUFVO0FBR1YsRUFBQUEseUJBQUEsV0FBUTtBQUdSLEVBQUFBLHlCQUFBLGlCQUFjO0FBR2QsRUFBQUEseUJBQUEsVUFBTztBQUdQLEVBQUFBLHlCQUFBLGVBQVk7QUFHWixFQUFBQSx5QkFBQSxhQUFVO0FBR1YsRUFBQUEseUJBQUEsZUFBWTtBQUdaLEVBQUFBLHlCQUFBLFlBQVM7QUFHVCxFQUFBQSx5QkFBQSxZQUFTO0FBR1QsRUFBQUEseUJBQUEsa0JBQWU7QUFHZixFQUFBQSx5QkFBQSxpQkFBYztBQUdkLEVBQUFBLHlCQUFBLHFCQUFrQjtBQUdsQixFQUFBQSx5QkFBQSxTQUFNO0FBR04sRUFBQUEseUJBQUEsZUFBWTtBQUdaLEVBQUFBLHlCQUFBLGtCQUFlO0FBR2YsRUFBQUEseUJBQUEsa0JBQWU7QUEvQ0wsU0FBQUE7QUFBQSxHQUFBOyIsCiAgIm5hbWVzIjogWyJPYnNpZGlhblBsdWdpblJlcG9QYXRocyJdCn0K
58
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL1BsdWdpbi9PYnNpZGlhblBsdWdpblJlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHNcbiAqIFRoaXMgZmlsZSBkZWZpbmVzIGFuIGVudW1lcmF0aW9uIGZvciBjb21tb24gZmlsZSBhbmQgZGlyZWN0b3J5IHBhdGhzIHVzZWQgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5cbi8qKlxuICogRW51bWVyYXRpb24gb2YgY29tbW9ubHkgdXNlZCBmaWxlIGFuZCBkaXJlY3RvcnkgcGF0aHMgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5leHBvcnQgZW51bSBPYnNpZGlhblBsdWdpblJlcG9QYXRocyB7XG4gIC8qKiBSZXByZXNlbnRzIGFueSBwYXRoIHJlY3Vyc2l2ZWx5LiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogUmVwcmVzZW50cyBhbnkgVHlwZVNjcmlwdCBmaWxlLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgY2hhbmdlbG9nIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3QgPSAnZGlzdCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGJ1aWxkIGRpcmVjdG9yeSB3aXRoaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3RCdWlsZCA9ICdkaXN0L2J1aWxkJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgZGV2ZWxvcG1lbnQgZGlyZWN0b3J5IHdpdGhpbiB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS4gKi9cbiAgRGlzdERldiA9ICdkaXN0L2RldicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGhvdCByZWxvYWQgZmlsZS4gKi9cbiAgSG90UmVsb2FkID0gJy5ob3RyZWxvYWQnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBsaWIgZGlyZWN0b3J5LiAqL1xuICBMaWIgPSAnbGliJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgTGlicmFyeS5janMgZmlsZS4gKi9cbiAgTGlicmFyeUNqcyA9ICdMaWJyYXJ5LmNqcycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIG1haW4gSmF2YVNjcmlwdCBmaWxlLiAqL1xuICBNYWluSnMgPSAnbWFpbi5qcycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIG1haW4gVHlwZVNjcmlwdCBmaWxlLiAqL1xuICBNYWluVHMgPSAnbWFpbi50cycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIG1hbmlmZXN0IGZpbGUuICovXG4gIE1hbmlmZXN0SnNvbiA9ICdtYW5pZmVzdC5qc29uJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgcGFja2FnZS5qc29uIGZpbGUuICovXG4gIFBhY2thZ2VKc29uID0gJ3BhY2thZ2UuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHBhY2thZ2UtbG9jay5qc29uIGZpbGUuICovXG4gIFBhY2thZ2VMb2NrSnNvbiA9ICdwYWNrYWdlLWxvY2suanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHNvdXJjZSBkaXJlY3RvcnkuICovXG4gIFNyYyA9ICdzcmMnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBzdHlsZXMuY3NzIGZpbGUuICovXG4gIFN0eWxlc0NzcyA9ICdzdHlsZXMuY3NzJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgVHlwZVNjcmlwdCBjb25maWd1cmF0aW9uIGZpbGUuICovXG4gIFRzQ29uZmlnSnNvbiA9ICd0c2NvbmZpZy5qc29uJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgdmVyc2lvbnMuanNvbiBmaWxlLiAqL1xuICBWZXJzaW9uc0pzb24gPSAndmVyc2lvbnMuanNvbidcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFRTyxJQUFLLDBCQUFMLGtCQUFLQSw2QkFBTDtBQUVMLEVBQUFBLHlCQUFBLGFBQVU7QUFHVixFQUFBQSx5QkFBQSxXQUFRO0FBR1IsRUFBQUEseUJBQUEsaUJBQWM7QUFHZCxFQUFBQSx5QkFBQSxVQUFPO0FBR1AsRUFBQUEseUJBQUEsZUFBWTtBQUdaLEVBQUFBLHlCQUFBLGFBQVU7QUFHVixFQUFBQSx5QkFBQSxlQUFZO0FBR1osRUFBQUEseUJBQUEsU0FBTTtBQUdOLEVBQUFBLHlCQUFBLGdCQUFhO0FBR2IsRUFBQUEseUJBQUEsWUFBUztBQUdULEVBQUFBLHlCQUFBLFlBQVM7QUFHVCxFQUFBQSx5QkFBQSxrQkFBZTtBQUdmLEVBQUFBLHlCQUFBLGlCQUFjO0FBR2QsRUFBQUEseUJBQUEscUJBQWtCO0FBR2xCLEVBQUFBLHlCQUFBLFNBQU07QUFHTixFQUFBQSx5QkFBQSxlQUFZO0FBR1osRUFBQUEseUJBQUEsa0JBQWU7QUFHZixFQUFBQSx5QkFBQSxrQkFBZTtBQXJETCxTQUFBQTtBQUFBLEdBQUE7IiwKICAibmFtZXMiOiBbIk9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzIl0KfQo=
@@ -20,6 +20,10 @@ export declare enum ObsidianPluginRepoPaths {
20
20
  DistDev = "dist/dev",
21
21
  /** Represents the hot reload file. */
22
22
  HotReload = ".hotreload",
23
+ /** Represents the lib directory. */
24
+ Lib = "lib",
25
+ /** Represents the Library.cjs file. */
26
+ LibraryCjs = "Library.cjs",
23
27
  /** Represents the main JavaScript file. */
24
28
  MainJs = "main.js",
25
29
  /** Represents the main TypeScript file. */
@@ -34,6 +34,7 @@ var import_obsidian = require('obsidian');
34
34
  var import_Debug = require('../../Debug.cjs');
35
35
  var import_Error = require('../../Error.cjs');
36
36
  var import_Function = require('../../Function.cjs');
37
+ var import_PluginContext = require('./PluginContext.cjs');
37
38
  var __process = globalThis["process"] ?? {
38
39
  "browser": true,
39
40
  "cwd": () => "/",
@@ -76,7 +77,7 @@ class PluginBase extends import_obsidian.Plugin {
76
77
  */
77
78
  constructor(app, manifest) {
78
79
  super(app, manifest);
79
- (0, import_Debug.initDebugHelpers)(manifest.id);
80
+ (0, import_PluginContext.initPluginContext)(app, manifest.id);
80
81
  }
81
82
  /**
82
83
  * Logs a message to the console.
@@ -179,4 +180,4 @@ ${message}`);
179
180
  0 && (module.exports = {
180
181
  PluginBase
181
182
  });
182
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation PluginBase\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { PluginManifest } from 'obsidian';\n\nimport {\n  App,\n  Notice,\n  Plugin,\n  PluginSettingTab\n} from 'obsidian';\n\nimport type { MaybePromise } from '../../Async.ts';\nimport type { EmptySettings } from './EmptySettings.ts';\nimport type { PluginSettingsBase } from './PluginSettingsBase.ts';\n\nimport {\n  getDebugger,\n  initDebugHelpers\n} from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noop } from '../../Function.ts';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginSettings - The type representing the plugin settings object.\n */\nexport abstract class PluginBase<PluginSettings extends PluginSettingsBase = EmptySettings> extends Plugin {\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets a copy of the current plugin settings.\n   *\n   * @returns A copy of the plugin settings.\n   */\n  public get settingsCopy(): PluginSettings {\n    return this.createPluginSettings(this.settings.toJSON());\n  }\n\n  /**\n   * Gets the plugin settings.\n   *\n   * @returns The plugin settings.\n   */\n  protected get settings(): PluginSettings {\n    return this._settings;\n  }\n\n  private _abortSignal!: AbortSignal;\n\n  private _settings!: PluginSettings;\n\n  private notice?: Notice;\n\n  /**\n   * Constructs a new PluginBase instance.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n    initDebugHelpers(manifest.id);\n  }\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await this.loadSettings();\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    await this.loadSettings();\n    const pluginSettingsTab = this.createPluginSettingsTab();\n    if (pluginSettingsTab) {\n      this.addSettingTab(pluginSettingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n    await this.onloadComplete();\n    this.app.workspace.onLayoutReady(this.onLayoutReady.bind(this));\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param newSettings - The new settings to save.\n   * @returns A promise that resolves when the settings are saved.\n   */\n  public async saveSettings(newSettings: PluginSettings): Promise<void> {\n    const json = newSettings.toJSON();\n    this._settings = this.createPluginSettings(json);\n    await this.saveData(json);\n  }\n\n  /**\n   * Creates the plugin settings. This method must be implemented by subclasses.\n   *\n   * @param data - The data to create the plugin settings from.\n   * @returns The plugin settings.\n   */\n  protected abstract createPluginSettings(data: unknown): PluginSettings;\n\n  /**\n   * Creates a plugin settings tab. This method must be implemented by subclasses.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected abstract createPluginSettingsTab(): null | PluginSettingTab;\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   *\n   * @returns A promise or void indicating the completion of the layout setup.\n   */\n  protected onLayoutReady(): MaybePromise<void> {\n    noop();\n  }\n\n  /**\n   * Called when the plugin loading is complete. This method must be implemented by subclasses to perform\n   * any additional setup required after loading is complete.\n   *\n   * @returns A promise or void indicating the completion of the load process.\n   */\n  protected onloadComplete(): MaybePromise<void> {\n    noop();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  /**\n   * Loads the plugin settings from the saved data.\n   *\n   * @returns A promise that resolves when the settings are loaded.\n   */\n  private async loadSettings(): Promise<void> {\n    const data = await this.loadData() as unknown;\n    this._settings = this.createPluginSettings(data);\n    if (this._settings.shouldSaveAfterLoad()) {\n      await this.saveSettings(this._settings);\n    }\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBA,sBAKO;AAMP,mBAGO;AACP,mBAA+C;AAC/C,sBAAqB;AAjCrB,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAmCO,MAAe,mBAA8E,uBAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMzG,IAAW,cAA2B;AACpC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,eAA+B;AACxC,WAAO,KAAK,qBAAqB,KAAK,SAAS,OAAO,CAAC;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAc,WAA2B;AACvC,WAAO,KAAK;AAAA,EACd;AAAA,EAEQ;AAAA,EAEA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQD,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AACnB,uCAAiB,SAAS,EAAE;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcO,aAAa,YAAoB,MAAuB;AAE7D,UAAM,iBAAiB;AACvB,UAAM,gBAAY,0BAAY,KAAK,SAAS,IAAI,cAAc;AAC9D,cAAU,SAAS,GAAG,IAAI;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,2BAA0C;AAC9D,UAAM,KAAK,aAAa;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,SAAwB;AAC5C,SAAK,aAAS,6CAA+B,MAAM;AACjD,WAAK,WAAW,6EAA6E;AAAA,IAC/F,CAAC,CAAC;AAEF,UAAM,KAAK,aAAa;AACxB,UAAM,oBAAoB,KAAK,wBAAwB;AACvD,QAAI,mBAAmB;AACrB,WAAK,cAAc,iBAAiB;AAAA,IACtC;AAEA,UAAM,kBAAkB,IAAI,gBAAgB;AAC5C,SAAK,eAAe,gBAAgB;AACpC,SAAK,SAAS,MAAM;AAClB,sBAAgB,MAAM;AAAA,IACxB,CAAC;AACD,UAAM,KAAK,eAAe;AAC1B,SAAK,IAAI,UAAU,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAa,aAAa,aAA4C;AACpE,UAAM,OAAO,YAAY,OAAO;AAChC,SAAK,YAAY,KAAK,qBAAqB,IAAI;AAC/C,UAAM,KAAK,SAAS,IAAI;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuBU,gBAAoC;AAC5C,8BAAK;AAAA,EACP;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQU,iBAAqC;AAC7C,8BAAK;AAAA,EACP;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,WAAW,SAAuB;AAC1C,QAAI,KAAK,QAAQ;AACf,WAAK,OAAO,KAAK;AAAA,IACnB;AAEA,SAAK,SAAS,IAAI,uBAAO,GAAG,KAAK,SAAS,IAAI;AAAA,EAAK,OAAO,EAAE;AAAA,EAC9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAc,eAA8B;AAC1C,UAAM,OAAO,MAAM,KAAK,SAAS;AACjC,SAAK,YAAY,KAAK,qBAAqB,IAAI;AAC/C,QAAI,KAAK,UAAU,oBAAoB,GAAG;AACxC,YAAM,KAAK,aAAa,KAAK,SAAS;AAAA,IACxC;AAAA,EACF;AACF;",
  "names": []
}

183
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["var __process = globalThis['process'] ?? {\n  \"browser\": true,\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation PluginBase\n * Base class for Obsidian plugins providing utility methods for settings management, error handling, and notifications.\n *\n * This class simplifies the process of managing plugin settings, displaying notifications, and handling errors.\n * Subclasses should implement methods to create default settings and settings tabs, and complete plugin-specific\n * loading tasks.\n */\n\nimport type { PluginManifest } from 'obsidian';\n\nimport {\n  App,\n  Notice,\n  Plugin,\n  PluginSettingTab\n} from 'obsidian';\n\nimport type { MaybePromise } from '../../Async.ts';\nimport type { EmptySettings } from './EmptySettings.ts';\nimport type { PluginSettingsBase } from './PluginSettingsBase.ts';\n\nimport { getDebugger } from '../../Debug.ts';\nimport { registerAsyncErrorEventHandler } from '../../Error.ts';\nimport { noop } from '../../Function.ts';\nimport { initPluginContext } from './PluginContext.ts';\n\n/**\n * Base class for creating Obsidian plugins with built-in support for settings management, error handling, and notifications.\n *\n * @typeParam PluginSettings - The type representing the plugin settings object.\n */\nexport abstract class PluginBase<PluginSettings extends PluginSettingsBase = EmptySettings> extends Plugin {\n  /**\n   * Gets the AbortSignal used for aborting long-running operations.\n   *\n   * @returns The abort signal.\n   */\n  public get abortSignal(): AbortSignal {\n    return this._abortSignal;\n  }\n\n  /**\n   * Gets a copy of the current plugin settings.\n   *\n   * @returns A copy of the plugin settings.\n   */\n  public get settingsCopy(): PluginSettings {\n    return this.createPluginSettings(this.settings.toJSON());\n  }\n\n  /**\n   * Gets the plugin settings.\n   *\n   * @returns The plugin settings.\n   */\n  protected get settings(): PluginSettings {\n    return this._settings;\n  }\n\n  private _abortSignal!: AbortSignal;\n\n  private _settings!: PluginSettings;\n\n  private notice?: Notice;\n\n  /**\n   * Constructs a new PluginBase instance.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n    initPluginContext(app, manifest.id);\n  }\n\n  /**\n   * Logs a message to the console.\n   *\n   * Use instead of `console.debug()`.\n   *\n   * Those messages are not shown by default, but they can be shown by enabling `your-plugin-id` debugger namespace.\n   *\n   * @see {@link https://github.com/mnaoumov/obsidian-dev-utils/?tab=readme-ov-file#debugging} for more information.\n   *\n   * @param message - The message to log.\n   * @param args - The arguments to log.\n   */\n  public consoleDebug(message: string, ...args: unknown[]): void {\n    // Skip the `consoleDebug()` call itself\n    const FRAMES_TO_SKIP = 1;\n    const _debugger = getDebugger(this.manifest.id, FRAMES_TO_SKIP);\n    _debugger(message, ...args);\n  }\n\n  /**\n   * Called when the external settings change.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await this.loadSettings();\n  }\n\n  /**\n   * Called when the plugin is loaded\n   */\n  public override async onload(): Promise<void> {\n    this.register(registerAsyncErrorEventHandler(() => {\n      this.showNotice('An unhandled error occurred. Please check the console for more information.');\n    }));\n\n    await this.loadSettings();\n    const pluginSettingsTab = this.createPluginSettingsTab();\n    if (pluginSettingsTab) {\n      this.addSettingTab(pluginSettingsTab);\n    }\n\n    const abortController = new AbortController();\n    this._abortSignal = abortController.signal;\n    this.register(() => {\n      abortController.abort();\n    });\n    await this.onloadComplete();\n    this.app.workspace.onLayoutReady(this.onLayoutReady.bind(this));\n  }\n\n  /**\n   * Saves the new plugin settings.\n   *\n   * @param newSettings - The new settings to save.\n   * @returns A promise that resolves when the settings are saved.\n   */\n  public async saveSettings(newSettings: PluginSettings): Promise<void> {\n    const json = newSettings.toJSON();\n    this._settings = this.createPluginSettings(json);\n    await this.saveData(json);\n  }\n\n  /**\n   * Creates the plugin settings. This method must be implemented by subclasses.\n   *\n   * @param data - The data to create the plugin settings from.\n   * @returns The plugin settings.\n   */\n  protected abstract createPluginSettings(data: unknown): PluginSettings;\n\n  /**\n   * Creates a plugin settings tab. This method must be implemented by subclasses.\n   *\n   * @returns The settings tab or null if not applicable.\n   */\n  protected abstract createPluginSettingsTab(): null | PluginSettingTab;\n\n  /**\n   * Called when the layout is ready. This method can be overridden by subclasses to perform actions once\n   * the layout is ready.\n   *\n   * @returns A promise or void indicating the completion of the layout setup.\n   */\n  protected onLayoutReady(): MaybePromise<void> {\n    noop();\n  }\n\n  /**\n   * Called when the plugin loading is complete. This method must be implemented by subclasses to perform\n   * any additional setup required after loading is complete.\n   *\n   * @returns A promise or void indicating the completion of the load process.\n   */\n  protected onloadComplete(): MaybePromise<void> {\n    noop();\n  }\n\n  /**\n   * Displays a notice message to the user.\n   *\n   * @param message - The message to display.\n   */\n  protected showNotice(message: string): void {\n    if (this.notice) {\n      this.notice.hide();\n    }\n\n    this.notice = new Notice(`${this.manifest.name}\\n${message}`);\n  }\n\n  /**\n   * Loads the plugin settings from the saved data.\n   *\n   * @returns A promise that resolves when the settings are loaded.\n   */\n  private async loadSettings(): Promise<void> {\n    const data = await this.loadData() as unknown;\n    this._settings = this.createPluginSettings(data);\n    if (this._settings.shouldSaveAfterLoad()) {\n      await this.saveSettings(this._settings);\n    }\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAiBA,sBAKO;AAMP,mBAA4B;AAC5B,mBAA+C;AAC/C,sBAAqB;AACrB,2BAAkC;AA/BlC,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,WAAW;AAAA,EACX,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AAiCO,MAAe,mBAA8E,uBAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMzG,IAAW,cAA2B;AACpC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,eAA+B;AACxC,WAAO,KAAK,qBAAqB,KAAK,SAAS,OAAO,CAAC;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAc,WAA2B;AACvC,WAAO,KAAK;AAAA,EACd;AAAA,EAEQ;AAAA,EAEA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQD,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AACnB,gDAAkB,KAAK,SAAS,EAAE;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcO,aAAa,YAAoB,MAAuB;AAE7D,UAAM,iBAAiB;AACvB,UAAM,gBAAY,0BAAY,KAAK,SAAS,IAAI,cAAc;AAC9D,cAAU,SAAS,GAAG,IAAI;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,2BAA0C;AAC9D,UAAM,KAAK,aAAa;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAsB,SAAwB;AAC5C,SAAK,aAAS,6CAA+B,MAAM;AACjD,WAAK,WAAW,6EAA6E;AAAA,IAC/F,CAAC,CAAC;AAEF,UAAM,KAAK,aAAa;AACxB,UAAM,oBAAoB,KAAK,wBAAwB;AACvD,QAAI,mBAAmB;AACrB,WAAK,cAAc,iBAAiB;AAAA,IACtC;AAEA,UAAM,kBAAkB,IAAI,gBAAgB;AAC5C,SAAK,eAAe,gBAAgB;AACpC,SAAK,SAAS,MAAM;AAClB,sBAAgB,MAAM;AAAA,IACxB,CAAC;AACD,UAAM,KAAK,eAAe;AAC1B,SAAK,IAAI,UAAU,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAa,aAAa,aAA4C;AACpE,UAAM,OAAO,YAAY,OAAO;AAChC,SAAK,YAAY,KAAK,qBAAqB,IAAI;AAC/C,UAAM,KAAK,SAAS,IAAI;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuBU,gBAAoC;AAC5C,8BAAK;AAAA,EACP;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQU,iBAAqC;AAC7C,8BAAK;AAAA,EACP;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,WAAW,SAAuB;AAC1C,QAAI,KAAK,QAAQ;AACf,WAAK,OAAO,KAAK;AAAA,IACnB;AAEA,SAAK,SAAS,IAAI,uBAAO,GAAG,KAAK,SAAS,IAAI;AAAA,EAAK,OAAO,EAAE;AAAA,EAC9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAc,eAA8B;AAC1C,UAAM,OAAO,MAAM,KAAK,SAAS;AACjC,SAAK,YAAY,KAAK,qBAAqB,IAAI;AAC/C,QAAI,KAAK,UAAU,oBAAoB,GAAG;AACxC,YAAM,KAAK,aAAa,KAAK,SAAS;AAAA,IACxC;AAAA,EACF;AACF;",
  "names": []
}
