obsidian-dev-utils 3.32.0 → 3.33.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,9 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 3.33.0
4
+
5
+ - Refactor yaml parsing
6
+
3
7
  ## 3.32.0
4
8
 
5
9
  - `getNoteFilesSorted`
@@ -30,9 +30,8 @@ __export(FrontMatter_exports, {
30
30
  processFrontMatter: () => processFrontMatter
31
31
  });
32
32
  module.exports = __toCommonJS(FrontMatter_exports);
33
- var import_js_yaml = require('js-yaml');
34
33
  var import_obsidian = require('obsidian');
35
- var import_Error = require('../Error.cjs');
34
+ var import_Object = require('../Object.cjs');
36
35
  var import_FileSystem = require('./FileSystem.cjs');
37
36
  var import_Vault = require('./Vault.cjs');
38
37
  var __import_meta_url = globalThis["import.meta.url"] ?? (() => {
@@ -46,15 +45,6 @@ var __process = globalThis["process"] ?? {
46
45
  "env": {},
47
46
  "platform": "android"
48
47
  };
49
- const TIMESTAMP_TYPE = new import_js_yaml.Type("tag:yaml.org,2002:timestamp", {
50
- kind: "scalar",
51
- resolve: (data) => data != null,
52
- construct: (data) => String(data),
53
- represent: (data) => data
54
- });
55
- const NO_TIMESTAMPS_YAML_SCHEMA = import_js_yaml.DEFAULT_SCHEMA.extend({
56
- explicit: [TIMESTAMP_TYPE]
57
- });
58
48
  const FRONT_MATTER_REG_EXP = /^---\r?\n((?:.|\r?\n)*?)\r?\n?---(?:\r?\n|$)((?:.|\r?\n)*)/;
59
49
  async function processFrontMatter(app, pathOrFile, frontMatterFn) {
60
50
  const file = (0, import_FileSystem.getFile)(app, pathOrFile);
@@ -63,24 +53,26 @@ async function processFrontMatter(app, pathOrFile, frontMatterFn) {
63
53
  let frontMatterStr;
64
54
  let mainContent;
65
55
  if (match) {
66
- frontMatterStr = match[1] ?? (0, import_Error.throwExpression)(new Error("Front matter match is null"));
67
- mainContent = match[2] ?? (0, import_Error.throwExpression)(new Error("Front matter match is null"));
56
+ frontMatterStr = match[1]?.trim() ?? "";
57
+ mainContent = match[2]?.trim() ?? "";
68
58
  } else {
69
59
  frontMatterStr = "";
70
- mainContent = content;
60
+ mainContent = content.trim();
71
61
  }
72
62
  if (!mainContent) {
73
63
  mainContent = "\n";
74
64
  } else {
75
- mainContent = "\n" + mainContent.trim() + "\n";
65
+ mainContent = `
66
+ ${mainContent}
67
+ `;
68
+ }
69
+ const oldFrontMatter = (0, import_obsidian.parseYaml)(frontMatterStr) ?? {};
70
+ const newFrontMatter = (0, import_obsidian.parseYaml)(frontMatterStr) ?? {};
71
+ await frontMatterFn(newFrontMatter);
72
+ if ((0, import_Object.deepEqual)(oldFrontMatter, newFrontMatter)) {
73
+ return content;
76
74
  }
77
- const frontMatter = (0, import_js_yaml.load)(frontMatterStr, { schema: NO_TIMESTAMPS_YAML_SCHEMA }) ?? {};
78
- await frontMatterFn(frontMatter);
79
- let newFrontMatterStr = (0, import_js_yaml.dump)(frontMatter, {
80
- lineWidth: -1,
81
- quotingType: '"',
82
- schema: NO_TIMESTAMPS_YAML_SCHEMA
83
- });
75
+ let newFrontMatterStr = (0, import_obsidian.stringifyYaml)(newFrontMatter);
84
76
  if (newFrontMatterStr === "{}\n") {
85
77
  newFrontMatterStr = "";
86
78
  }
@@ -127,4 +119,4 @@ async function deleteAlias(app, pathOrFile, alias) {
127
119
  deleteAlias,
128
120
  processFrontMatter
129
121
  });
130
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/FrontMatter.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename!==\"string\"){return new URL(window.location.href)}return require(\"node:url\").pathToFileURL(__filename)})();\nvar __process = globalThis['process'] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation FrontMatter\n * This module provides utility functions for processing and managing YAML front matter in Obsidian notes.\n */\n\nimport {\n  DEFAULT_SCHEMA,\n  dump,\n  load,\n  Type\n} from 'js-yaml';\nimport { App } from 'obsidian';\n\nimport type { MaybePromise } from '../Async.ts';\nimport { throwExpression } from '../Error.ts';\nimport type { PathOrFile } from './FileSystem.ts';\nimport { getFile } from './FileSystem.ts';\nimport { processWithRetry } from './Vault.ts';\n\n/**\n * Represents the front matter of an Obsidian file.\n * @see {@link https://help.obsidian.md/Editing+and+formatting/Properties#Default+properties}\n */\nexport interface ObsidianFrontMatter {\n  /**\n   * An array of aliases for the note.\n   */\n  aliases?: string[];\n\n  /**\n   * An array of CSS classes to apply to the note.\n   */\n  cssclasses?: string[];\n\n  /**\n   * An array of tags for the note.\n   */\n  tags?: string[];\n}\n\n/**\n * Represents the front matter for publishing in Obsidian.\n * @see {@link https://help.obsidian.md/Editing+and+formatting/Properties#Properties+for+Obsidian+Publish}\n */\nexport interface ObsidianPublishFrontMatter {\n  /**\n   * The cover image for the note.\n   */\n  cover?: string;\n\n  /**\n   * The description for the note.\n   */\n  description?: string;\n\n  /**\n   * The image for the note.\n   */\n  image?: string;\n\n  /**\n   * The permanent link for the note.\n   */\n  permalink?: string;\n\n  /**\n   * Whether the note is published.\n   */\n  publish?: boolean;\n}\n\n/**\n * Represents the combined front matter of a document.\n * It is a union of custom front matter, Obsidian front matter, and additional properties.\n * @typeParam CustomFrontMatter - The type of custom front matter.\n */\nexport type CombinedFrontMatter<CustomFrontMatter> = CustomFrontMatter & ObsidianFrontMatter & Record<string, unknown>;\n\nconst TIMESTAMP_TYPE = new Type('tag:yaml.org,2002:timestamp', {\n  kind: 'scalar',\n  resolve: (data: unknown): boolean => data != null,\n  construct: (data: unknown): string => String(data),\n  represent: (data: object): unknown => data\n});\n\nconst NO_TIMESTAMPS_YAML_SCHEMA = DEFAULT_SCHEMA.extend({\n  explicit: [TIMESTAMP_TYPE]\n});\n\nconst FRONT_MATTER_REG_EXP = /^---\\r?\\n((?:.|\\r?\\n)*?)\\r?\\n?---(?:\\r?\\n|$)((?:.|\\r?\\n)*)/;\n\n/**\n * Processes the front matter of a given file, allowing modifications via a provided function.\n *\n * @typeParam CustomFrontMatter - The type of custom front matter.\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param frontMatterFn - A function that modifies the front matter.\n * @returns A promise that resolves when the front matter has been processed and saved.\n */\nexport async function processFrontMatter<CustomFrontMatter = unknown>(app: App, pathOrFile: PathOrFile, frontMatterFn: (frontMatter: CombinedFrontMatter<CustomFrontMatter>) => MaybePromise<void>): Promise<void> {\n  const file = getFile(app, pathOrFile);\n\n  await processWithRetry(app, file, async (content) => {\n    const match = FRONT_MATTER_REG_EXP.exec(content);\n    let frontMatterStr: string;\n    let mainContent: string;\n    if (match) {\n      frontMatterStr = match[1] ?? throwExpression(new Error('Front matter match is null'));\n      mainContent = match[2] ?? throwExpression(new Error('Front matter match is null'));\n    } else {\n      frontMatterStr = '';\n      mainContent = content;\n    }\n\n    if (!mainContent) {\n      mainContent = '\\n';\n    } else {\n      mainContent = '\\n' + mainContent.trim() + '\\n';\n    }\n\n    const frontMatter = (load(frontMatterStr, { schema: NO_TIMESTAMPS_YAML_SCHEMA }) ?? {}) as CombinedFrontMatter<CustomFrontMatter>;\n    await frontMatterFn(frontMatter);\n    let newFrontMatterStr = dump(frontMatter, {\n      lineWidth: -1,\n      quotingType: '\"',\n      schema: NO_TIMESTAMPS_YAML_SCHEMA\n    });\n    if (newFrontMatterStr === '{}\\n') {\n      newFrontMatterStr = '';\n    }\n\n    const newContent = `---\n${newFrontMatterStr}---\n${mainContent}`;\n\n    return newContent;\n  });\n}\n\n/**\n * Adds an alias to the front matter of a given file if it does not already exist.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param alias - The alias to add.\n * @returns A promise that resolves when the alias has been added.\n */\nexport async function addAlias(app: App, pathOrFile: PathOrFile, alias?: string): Promise<void> {\n  if (!alias) {\n    return;\n  }\n\n  const file = getFile(app, pathOrFile);\n  if (alias === file.basename) {\n    return;\n  }\n\n  await processFrontMatter(app, pathOrFile, (frontMatter) => {\n    if (!frontMatter.aliases) {\n      frontMatter.aliases = [];\n    }\n\n    if (!frontMatter.aliases.includes(alias)) {\n      frontMatter.aliases.push(alias);\n    }\n  });\n}\n\n/**\n * Deletes an alias from the front matter of a given file if it exists.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param alias - The alias to delete.\n * @returns A promise that resolves when the alias has been deleted.\n */\nexport async function deleteAlias(app: App, pathOrFile: PathOrFile, alias?: string): Promise<void> {\n  if (!alias) {\n    return;\n  }\n\n  await processFrontMatter(app, pathOrFile, (frontMatter) => {\n    if (!frontMatter.aliases) {\n      return;\n    }\n\n    frontMatter.aliases = frontMatter.aliases.filter((a) => a != alias);\n\n    if (frontMatter.aliases.length === 0) {\n      delete frontMatter.aliases;\n    }\n  });\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,qBAKO;AACP,sBAAoB;AAGpB,mBAAgC;AAEhC,wBAAwB;AACxB,mBAAiC;AAvBjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,WAAO,IAAI,IAAI,OAAO,SAAS,IAAI;AAAA,EAAC;AAAC,SAAO,QAAQ,UAAU,EAAE,cAAc,UAAU;AAAC,GAAG;AAC5L,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AA+EA,MAAM,iBAAiB,IAAI,oBAAK,+BAA+B;AAAA,EAC7D,MAAM;AAAA,EACN,SAAS,CAAC,SAA2B,QAAQ;AAAA,EAC7C,WAAW,CAAC,SAA0B,OAAO,IAAI;AAAA,EACjD,WAAW,CAAC,SAA0B;AACxC,CAAC;AAED,MAAM,4BAA4B,8BAAe,OAAO;AAAA,EACtD,UAAU,CAAC,cAAc;AAC3B,CAAC;AAED,MAAM,uBAAuB;AAW7B,eAAsB,mBAAgD,KAAU,YAAwB,eAA2G;AACjN,QAAM,WAAO,2BAAQ,KAAK,UAAU;AAEpC,YAAM,+BAAiB,KAAK,MAAM,OAAO,YAAY;AACnD,UAAM,QAAQ,qBAAqB,KAAK,OAAO;AAC/C,QAAI;AACJ,QAAI;AACJ,QAAI,OAAO;AACT,uBAAiB,MAAM,CAAC,SAAK,8BAAgB,IAAI,MAAM,4BAA4B,CAAC;AACpF,oBAAc,MAAM,CAAC,SAAK,8BAAgB,IAAI,MAAM,4BAA4B,CAAC;AAAA,IACnF,OAAO;AACL,uBAAiB;AACjB,oBAAc;AAAA,IAChB;AAEA,QAAI,CAAC,aAAa;AAChB,oBAAc;AAAA,IAChB,OAAO;AACL,oBAAc,OAAO,YAAY,KAAK,IAAI;AAAA,IAC5C;AAEA,UAAM,kBAAe,qBAAK,gBAAgB,EAAE,QAAQ,0BAA0B,CAAC,KAAK,CAAC;AACrF,UAAM,cAAc,WAAW;AAC/B,QAAI,wBAAoB,qBAAK,aAAa;AAAA,MACxC,WAAW;AAAA,MACX,aAAa;AAAA,MACb,QAAQ;AAAA,IACV,CAAC;AACD,QAAI,sBAAsB,QAAQ;AAChC,0BAAoB;AAAA,IACtB;AAEA,UAAM,aAAa;AAAA,EACrB,iBAAiB;AAAA,EACjB,WAAW;AAET,WAAO;AAAA,EACT,CAAC;AACH;AAUA,eAAsB,SAAS,KAAU,YAAwB,OAA+B;AAC9F,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AAEA,QAAM,WAAO,2BAAQ,KAAK,UAAU;AACpC,MAAI,UAAU,KAAK,UAAU;AAC3B;AAAA,EACF;AAEA,QAAM,mBAAmB,KAAK,YAAY,CAAC,gBAAgB;AACzD,QAAI,CAAC,YAAY,SAAS;AACxB,kBAAY,UAAU,CAAC;AAAA,IACzB;AAEA,QAAI,CAAC,YAAY,QAAQ,SAAS,KAAK,GAAG;AACxC,kBAAY,QAAQ,KAAK,KAAK;AAAA,IAChC;AAAA,EACF,CAAC;AACH;AAUA,eAAsB,YAAY,KAAU,YAAwB,OAA+B;AACjG,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AAEA,QAAM,mBAAmB,KAAK,YAAY,CAAC,gBAAgB;AACzD,QAAI,CAAC,YAAY,SAAS;AACxB;AAAA,IACF;AAEA,gBAAY,UAAU,YAAY,QAAQ,OAAO,CAAC,MAAM,KAAK,KAAK;AAElE,QAAI,YAAY,QAAQ,WAAW,GAAG;AACpC,aAAO,YAAY;AAAA,IACrB;AAAA,EACF,CAAC;AACH;",
  "names": []
}

122
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/FrontMatter.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename!==\"string\"){return new URL(window.location.href)}return require(\"node:url\").pathToFileURL(__filename)})();\nvar __process = globalThis['process'] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\n/**\n * @packageDocumentation FrontMatter\n * This module provides utility functions for processing and managing YAML front matter in Obsidian notes.\n */\n\nimport {\n  App,\n  parseYaml,\n  stringifyYaml\n} from 'obsidian';\n\nimport type { MaybePromise } from '../Async.ts';\nimport { deepEqual } from '../Object.ts';\nimport type { PathOrFile } from './FileSystem.ts';\nimport { getFile } from './FileSystem.ts';\nimport { processWithRetry } from './Vault.ts';\n\n/**\n * Represents the front matter of an Obsidian file.\n * @see {@link https://help.obsidian.md/Editing+and+formatting/Properties#Default+properties}\n */\nexport interface ObsidianFrontMatter {\n  /**\n   * An array of aliases for the note.\n   */\n  aliases?: string[];\n\n  /**\n   * An array of CSS classes to apply to the note.\n   */\n  cssclasses?: string[];\n\n  /**\n   * An array of tags for the note.\n   */\n  tags?: string[];\n}\n\n/**\n * Represents the front matter for publishing in Obsidian.\n * @see {@link https://help.obsidian.md/Editing+and+formatting/Properties#Properties+for+Obsidian+Publish}\n */\nexport interface ObsidianPublishFrontMatter {\n  /**\n   * The cover image for the note.\n   */\n  cover?: string;\n\n  /**\n   * The description for the note.\n   */\n  description?: string;\n\n  /**\n   * The image for the note.\n   */\n  image?: string;\n\n  /**\n   * The permanent link for the note.\n   */\n  permalink?: string;\n\n  /**\n   * Whether the note is published.\n   */\n  publish?: boolean;\n}\n\n/**\n * Represents the combined front matter of a document.\n * It is a union of custom front matter, Obsidian front matter, and additional properties.\n * @typeParam CustomFrontMatter - The type of custom front matter.\n */\nexport type CombinedFrontMatter<CustomFrontMatter> = CustomFrontMatter & ObsidianFrontMatter & Record<string, unknown>;\n\nconst FRONT_MATTER_REG_EXP = /^---\\r?\\n((?:.|\\r?\\n)*?)\\r?\\n?---(?:\\r?\\n|$)((?:.|\\r?\\n)*)/;\n\n/**\n * Processes the front matter of a given file, allowing modifications via a provided function.\n *\n * @typeParam CustomFrontMatter - The type of custom front matter.\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param frontMatterFn - A function that modifies the front matter.\n * @returns A promise that resolves when the front matter has been processed and saved.\n */\nexport async function processFrontMatter<CustomFrontMatter = unknown>(app: App, pathOrFile: PathOrFile, frontMatterFn: (frontMatter: CombinedFrontMatter<CustomFrontMatter>) => MaybePromise<void>): Promise<void> {\n  const file = getFile(app, pathOrFile);\n\n  await processWithRetry(app, file, async (content) => {\n    const match = FRONT_MATTER_REG_EXP.exec(content);\n    let frontMatterStr: string;\n    let mainContent: string;\n    if (match) {\n      frontMatterStr = match[1]?.trim() ?? '';\n      mainContent = match[2]?.trim() ?? '';\n    } else {\n      frontMatterStr = '';\n      mainContent = content.trim();\n    }\n\n    if (!mainContent) {\n      mainContent = '\\n';\n    } else {\n      mainContent = `\\n${mainContent}\\n`;\n    }\n\n    const oldFrontMatter = (parseYaml(frontMatterStr) ?? {}) as CombinedFrontMatter<CustomFrontMatter>;\n    const newFrontMatter = (parseYaml(frontMatterStr) ?? {}) as CombinedFrontMatter<CustomFrontMatter>;\n    await frontMatterFn(newFrontMatter);\n\n    if (deepEqual(oldFrontMatter, newFrontMatter)) {\n      return content;\n    }\n\n    let newFrontMatterStr = stringifyYaml(newFrontMatter);\n    if (newFrontMatterStr === '{}\\n') {\n      newFrontMatterStr = '';\n    }\n\n    const newContent = `---\\n${newFrontMatterStr}---\\n${mainContent}`;\n    return newContent;\n  });\n}\n\n/**\n * Adds an alias to the front matter of a given file if it does not already exist.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param alias - The alias to add.\n * @returns A promise that resolves when the alias has been added.\n */\nexport async function addAlias(app: App, pathOrFile: PathOrFile, alias?: string): Promise<void> {\n  if (!alias) {\n    return;\n  }\n\n  const file = getFile(app, pathOrFile);\n  if (alias === file.basename) {\n    return;\n  }\n\n  await processFrontMatter(app, pathOrFile, (frontMatter) => {\n    if (!frontMatter.aliases) {\n      frontMatter.aliases = [];\n    }\n\n    if (!frontMatter.aliases.includes(alias)) {\n      frontMatter.aliases.push(alias);\n    }\n  });\n}\n\n/**\n * Deletes an alias from the front matter of a given file if it exists.\n *\n * @param app - The Obsidian app instance.\n * @param pathOrFile - The path or TFile object representing the note.\n * @param alias - The alias to delete.\n * @returns A promise that resolves when the alias has been deleted.\n */\nexport async function deleteAlias(app: App, pathOrFile: PathOrFile, alias?: string): Promise<void> {\n  if (!alias) {\n    return;\n  }\n\n  await processFrontMatter(app, pathOrFile, (frontMatter) => {\n    if (!frontMatter.aliases) {\n      return;\n    }\n\n    frontMatter.aliases = frontMatter.aliases.filter((a) => a != alias);\n\n    if (frontMatter.aliases.length === 0) {\n      delete frontMatter.aliases;\n    }\n  });\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWA,sBAIO;AAGP,oBAA0B;AAE1B,wBAAwB;AACxB,mBAAiC;AArBjC,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,WAAO,IAAI,IAAI,OAAO,SAAS,IAAI;AAAA,EAAC;AAAC,SAAO,QAAQ,UAAU,EAAE,cAAc,UAAU;AAAC,GAAG;AAC5L,IAAI,YAAY,WAAW,SAAS,KAAK;AAAA,EACvC,OAAO,MAAI;AAAA,EACX,OAAO,CAAC;AAAA,EACR,YAAY;AACd;AA6EA,MAAM,uBAAuB;AAW7B,eAAsB,mBAAgD,KAAU,YAAwB,eAA2G;AACjN,QAAM,WAAO,2BAAQ,KAAK,UAAU;AAEpC,YAAM,+BAAiB,KAAK,MAAM,OAAO,YAAY;AACnD,UAAM,QAAQ,qBAAqB,KAAK,OAAO;AAC/C,QAAI;AACJ,QAAI;AACJ,QAAI,OAAO;AACT,uBAAiB,MAAM,CAAC,GAAG,KAAK,KAAK;AACrC,oBAAc,MAAM,CAAC,GAAG,KAAK,KAAK;AAAA,IACpC,OAAO;AACL,uBAAiB;AACjB,oBAAc,QAAQ,KAAK;AAAA,IAC7B;AAEA,QAAI,CAAC,aAAa;AAChB,oBAAc;AAAA,IAChB,OAAO;AACL,oBAAc;AAAA,EAAK,WAAW;AAAA;AAAA,IAChC;AAEA,UAAM,qBAAkB,2BAAU,cAAc,KAAK,CAAC;AACtD,UAAM,qBAAkB,2BAAU,cAAc,KAAK,CAAC;AACtD,UAAM,cAAc,cAAc;AAElC,YAAI,yBAAU,gBAAgB,cAAc,GAAG;AAC7C,aAAO;AAAA,IACT;AAEA,QAAI,wBAAoB,+BAAc,cAAc;AACpD,QAAI,sBAAsB,QAAQ;AAChC,0BAAoB;AAAA,IACtB;AAEA,UAAM,aAAa;AAAA,EAAQ,iBAAiB;AAAA,EAAQ,WAAW;AAC/D,WAAO;AAAA,EACT,CAAC;AACH;AAUA,eAAsB,SAAS,KAAU,YAAwB,OAA+B;AAC9F,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AAEA,QAAM,WAAO,2BAAQ,KAAK,UAAU;AACpC,MAAI,UAAU,KAAK,UAAU;AAC3B;AAAA,EACF;AAEA,QAAM,mBAAmB,KAAK,YAAY,CAAC,gBAAgB;AACzD,QAAI,CAAC,YAAY,SAAS;AACxB,kBAAY,UAAU,CAAC;AAAA,IACzB;AAEA,QAAI,CAAC,YAAY,QAAQ,SAAS,KAAK,GAAG;AACxC,kBAAY,QAAQ,KAAK,KAAK;AAAA,IAChC;AAAA,EACF,CAAC;AACH;AAUA,eAAsB,YAAY,KAAU,YAAwB,OAA+B;AACjG,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AAEA,QAAM,mBAAmB,KAAK,YAAY,CAAC,gBAAgB;AACzD,QAAI,CAAC,YAAY,SAAS;AACxB;AAAA,IACF;AAEA,gBAAY,UAAU,YAAY,QAAQ,OAAO,CAAC,MAAM,KAAK,KAAK;AAElE,QAAI,YAAY,QAAQ,WAAW,GAAG;AACpC,aAAO,YAAY;AAAA,IACrB;AAAA,EACF,CAAC;AACH;",
  "names": []
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "obsidian-dev-utils",
3
- "version": "3.32.0",
3
+ "version": "3.33.0",
4
4
  "description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
5
5
  "main": "./dist/lib/index.cjs",
6
6
  "types": "./dist/lib/index.d.ts",
@@ -41,7 +41,6 @@
41
41
  "@types/doctrine": "^0.0.9",
42
42
  "@types/eslint": "^9.6.1",
43
43
  "@types/eslint__js": "^8.42.3",
44
- "@types/js-yaml": "^4.0.9",
45
44
  "@types/luxon": "^3.4.2",
46
45
  "@types/node": "^22.5.4",
47
46
  "@types/parsimmon": "^1.10.9",
@@ -63,7 +62,6 @@
63
62
  "eslint-plugin-verify-tsdoc": "^1.0.18",
64
63
  "eventemitter3": "^5.0.1",
65
64
  "glob": "^11.0.0",
66
- "js-yaml": "^4.1.0",
67
65
  "localforage": "^1.10.0",
68
66
  "lru-cache": "^11.0.1",
69
67
  "npm-run-all": "^4.1.5",