obsidian-dev-utils 16.6.4 → 17.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/README.md +26 -6
- package/dist/lib/Library.cjs +1 -1
- package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.cjs +2 -1
- package/dist/lib/obsidian/Plugin/ObsidianPluginRepoPaths.d.ts +2 -0
- package/dist/lib/obsidian/Plugin/PluginBase.cjs +4 -2
- package/dist/lib/scripts/ESLint/eslint.config.cjs +11 -2
- package/dist/lib/scripts/NodeModules.cjs +3 -1
- package/dist/lib/scripts/NodeModules.d.ts +1 -1
- package/dist/lib/scripts/build.cjs +30 -8
- package/dist/lib/scripts/build.d.ts +18 -6
- package/dist/lib/scripts/cli.cjs +4 -2
- package/dist/lib/scripts/esbuild/ObsidianPluginBuilder.cjs +33 -6
- package/dist/lib/scripts/esbuild/index.cjs +6 -6
- package/dist/lib/scripts/esbuild/index.d.ts +1 -1
- package/dist/lib/scripts/esbuild/renameCssPlugin.cjs +52 -0
- package/dist/lib/scripts/esbuild/renameCssPlugin.d.ts +8 -0
- package/package.json +17 -8
- package/dist/lib/scripts/esbuild/watchCssChangesPlugin.cjs +0 -56
- package/dist/lib/scripts/esbuild/watchCssChangesPlugin.d.ts +0 -5
package/CHANGELOG.md
CHANGED
@@ -1,5 +1,17 @@
|
|
1
1
|
# CHANGELOG
|
2
2
|
|
3
|
+
## 17.0.1
|
4
|
+
|
5
|
+
- Allow css imports
|
6
|
+
|
7
|
+
## 17.0.0
|
8
|
+
|
9
|
+
- Remove allowJs setting
|
10
|
+
- Update libs
|
11
|
+
- Add support for sass
|
12
|
+
- Add svelte compile
|
13
|
+
- Ensure onLayoutReady is called after onload completed
|
14
|
+
|
3
15
|
## 16.6.4
|
4
16
|
|
5
17
|
- Init require for each plugin separately
|
package/README.md
CHANGED
@@ -10,6 +10,10 @@
|
|
10
10
|
|
11
11
|
This package is ideal for developers who are building or maintaining plugins for Obsidian. It provides a range of tools to make the development process easier, including automated builds, linting, spellchecking, and more.
|
12
12
|
|
13
|
+
## Plugin Generator
|
14
|
+
|
15
|
+
There is a [Obsidian Plugin Yeoman Generator](https://github.com/mnaoumov/generator-obsidian-plugin) that sets up a new Obsidian plugin project with a basic structure and some useful scripts from this library.
|
16
|
+
|
13
17
|
## Installation
|
14
18
|
|
15
19
|
To install the package, run the following command:
|
@@ -40,21 +44,37 @@ npx obsidian-dev-utils build:clean
|
|
40
44
|
|
41
45
|
Cleans `dist` folder.
|
42
46
|
|
43
|
-
####
|
47
|
+
#### Compile code
|
44
48
|
|
45
49
|
```bash
|
46
|
-
npx obsidian-dev-utils build:
|
50
|
+
npx obsidian-dev-utils build:compile
|
47
51
|
```
|
48
52
|
|
49
|
-
|
53
|
+
Checks if code compiles.
|
54
|
+
|
55
|
+
#### Compile Svelte code
|
56
|
+
|
57
|
+
```bash
|
58
|
+
npx obsidian-dev-utils build:compile:svelte
|
59
|
+
```
|
50
60
|
|
51
|
-
|
61
|
+
Checks if Svelte code compiles.
|
62
|
+
|
63
|
+
#### Compile TypeScript code
|
52
64
|
|
53
65
|
```bash
|
54
|
-
npx obsidian-dev-utils build:
|
66
|
+
npx obsidian-dev-utils build:compile:typeScript
|
55
67
|
```
|
56
68
|
|
57
|
-
|
69
|
+
Checks if TypeScript code compiles.
|
70
|
+
|
71
|
+
#### Build static assets
|
72
|
+
|
73
|
+
```bash
|
74
|
+
npx obsidian-dev-utils build:static
|
75
|
+
```
|
76
|
+
|
77
|
+
Copies `static` folder to `dist` folder.
|
58
78
|
|
59
79
|
#### Build Development Version
|
60
80
|
|
package/dist/lib/Library.cjs
CHANGED
@@ -30,7 +30,7 @@ __export(Library_exports, {
|
|
30
30
|
LIBRARY_VERSION: () => LIBRARY_VERSION
|
31
31
|
});
|
32
32
|
module.exports = __toCommonJS(Library_exports);
|
33
|
-
const LIBRARY_VERSION = "
|
33
|
+
const LIBRARY_VERSION = "17.0.1";
|
34
34
|
const LIBRARY_NAME = "obsidian-dev-utils";
|
35
35
|
const LIBRARY_STYLES = ".obsidian-dev-utils {\n /* default styles */\n}\n\n.obsidian-dev-utils.alert-modal {\n /* default styles */\n}\n\n.obsidian-dev-utils.confirm-modal {\n /* default styles */\n}\n\n.obsidian-dev-utils.plugin-settings-tab {\n /* default styles */\n}\n\n.obsidian-dev-utils.plugin-settings-tab .value-component-invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n\n.obsidian-dev-utils.prompt-modal {\n /* default styles */\n}\n\n.obsidian-dev-utils.select-item-modal {\n /* default styles */\n}\n";
|
36
36
|
// Annotate the CommonJS export names for ESM import in node:
|
@@ -38,6 +38,7 @@ var ObsidianPluginRepoPaths = /* @__PURE__ */ ((ObsidianPluginRepoPaths2) => {
|
|
38
38
|
ObsidianPluginRepoPaths2["HotReload"] = ".hotreload";
|
39
39
|
ObsidianPluginRepoPaths2["Lib"] = "lib";
|
40
40
|
ObsidianPluginRepoPaths2["LibraryCjs"] = "Library.cjs";
|
41
|
+
ObsidianPluginRepoPaths2["MainCss"] = "main.css";
|
41
42
|
ObsidianPluginRepoPaths2["MainJs"] = "main.js";
|
42
43
|
ObsidianPluginRepoPaths2["MainTs"] = "main.ts";
|
43
44
|
ObsidianPluginRepoPaths2["ManifestJson"] = "manifest.json";
|
@@ -54,4 +55,4 @@ var ObsidianPluginRepoPaths = /* @__PURE__ */ ((ObsidianPluginRepoPaths2) => {
|
|
54
55
|
0 && (module.exports = {
|
55
56
|
ObsidianPluginRepoPaths
|
56
57
|
});
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
58
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL1BsdWdpbi9PYnNpZGlhblBsdWdpblJlcG9QYXRocy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb24gT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHNcbiAqIFRoaXMgZmlsZSBkZWZpbmVzIGFuIGVudW1lcmF0aW9uIGZvciBjb21tb24gZmlsZSBhbmQgZGlyZWN0b3J5IHBhdGhzIHVzZWQgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5cbi8qKlxuICogRW51bWVyYXRpb24gb2YgY29tbW9ubHkgdXNlZCBmaWxlIGFuZCBkaXJlY3RvcnkgcGF0aHMgaW4gT2JzaWRpYW4gcGx1Z2luIGRldmVsb3BtZW50LlxuICovXG5leHBvcnQgZW51bSBPYnNpZGlhblBsdWdpblJlcG9QYXRocyB7XG4gIC8qKiBSZXByZXNlbnRzIGFueSBwYXRoIHJlY3Vyc2l2ZWx5LiAqL1xuICBBbnlQYXRoID0gJyoqJyxcblxuICAvKiogUmVwcmVzZW50cyBhbnkgVHlwZVNjcmlwdCBmaWxlLiAqL1xuICBBbnlUcyA9ICcqLnRzJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgY2hhbmdlbG9nIGZpbGUuICovXG4gIENoYW5nZWxvZ01kID0gJ0NIQU5HRUxPRy5tZCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3QgPSAnZGlzdCcsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGJ1aWxkIGRpcmVjdG9yeSB3aXRoaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuICovXG4gIERpc3RCdWlsZCA9ICdkaXN0L2J1aWxkJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgZGV2ZWxvcG1lbnQgZGlyZWN0b3J5IHdpdGhpbiB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS4gKi9cbiAgRGlzdERldiA9ICdkaXN0L2RldicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIGhvdCByZWxvYWQgZmlsZS4gKi9cbiAgSG90UmVsb2FkID0gJy5ob3RyZWxvYWQnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBsaWIgZGlyZWN0b3J5LiAqL1xuICBMaWIgPSAnbGliJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgTGlicmFyeS5janMgZmlsZS4gKi9cbiAgTGlicmFyeUNqcyA9ICdMaWJyYXJ5LmNqcycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIG1haW4gQ1NTIGZpbGUuICovXG4gIE1haW5Dc3MgPSAnbWFpbi5jc3MnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYWluIEphdmFTY3JpcHQgZmlsZS4gKi9cbiAgTWFpbkpzID0gJ21haW4uanMnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYWluIFR5cGVTY3JpcHQgZmlsZS4gKi9cbiAgTWFpblRzID0gJ21haW4udHMnLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBtYW5pZmVzdCBmaWxlLiAqL1xuICBNYW5pZmVzdEpzb24gPSAnbWFuaWZlc3QuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIG5wbS1zaHJpbmt3cmFwLmpzb24gZmlsZS4gKi9cbiAgTnBtU2hyaW5rd3JhcEpzb24gPSAnbnBtLXNocmlua3dyYXAuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHBhY2thZ2UuanNvbiBmaWxlLiAqL1xuICBQYWNrYWdlSnNvbiA9ICdwYWNrYWdlLmpzb24nLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBwYWNrYWdlLWxvY2suanNvbiBmaWxlLiAqL1xuICBQYWNrYWdlTG9ja0pzb24gPSAncGFja2FnZS1sb2NrLmpzb24nLFxuXG4gIC8qKiBSZXByZXNlbnRzIHRoZSBzb3VyY2UgZGlyZWN0b3J5LiAqL1xuICBTcmMgPSAnc3JjJyxcblxuICAvKiogUmVwcmVzZW50cyB0aGUgc3R5bGVzLmNzcyBmaWxlLiAqL1xuICBTdHlsZXNDc3MgPSAnc3R5bGVzLmNzcycsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIFR5cGVTY3JpcHQgY29uZmlndXJhdGlvbiBmaWxlLiAqL1xuICBUc0NvbmZpZ0pzb24gPSAndHNjb25maWcuanNvbicsXG5cbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnNpb25zLmpzb24gZmlsZS4gKi9cbiAgVmVyc2lvbnNKc29uID0gJ3ZlcnNpb25zLmpzb24nXG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVFPLElBQUssMEJBQUwsa0JBQUtBLDZCQUFMO0FBRUwsRUFBQUEseUJBQUEsYUFBVTtBQUdWLEVBQUFBLHlCQUFBLFdBQVE7QUFHUixFQUFBQSx5QkFBQSxpQkFBYztBQUdkLEVBQUFBLHlCQUFBLFVBQU87QUFHUCxFQUFBQSx5QkFBQSxlQUFZO0FBR1osRUFBQUEseUJBQUEsYUFBVTtBQUdWLEVBQUFBLHlCQUFBLGVBQVk7QUFHWixFQUFBQSx5QkFBQSxTQUFNO0FBR04sRUFBQUEseUJBQUEsZ0JBQWE7QUFHYixFQUFBQSx5QkFBQSxhQUFVO0FBR1YsRUFBQUEseUJBQUEsWUFBUztBQUdULEVBQUFBLHlCQUFBLFlBQVM7QUFHVCxFQUFBQSx5QkFBQSxrQkFBZTtBQUdmLEVBQUFBLHlCQUFBLHVCQUFvQjtBQUdwQixFQUFBQSx5QkFBQSxpQkFBYztBQUdkLEVBQUFBLHlCQUFBLHFCQUFrQjtBQUdsQixFQUFBQSx5QkFBQSxTQUFNO0FBR04sRUFBQUEseUJBQUEsZUFBWTtBQUdaLEVBQUFBLHlCQUFBLGtCQUFlO0FBR2YsRUFBQUEseUJBQUEsa0JBQWU7QUEzREwsU0FBQUE7QUFBQSxHQUFBOyIsCiAgIm5hbWVzIjogWyJPYnNpZGlhblBsdWdpblJlcG9QYXRocyJdCn0K
|
@@ -24,6 +24,8 @@ export declare enum ObsidianPluginRepoPaths {
|
|
24
24
|
Lib = "lib",
|
25
25
|
/** Represents the Library.cjs file. */
|
26
26
|
LibraryCjs = "Library.cjs",
|
27
|
+
/** Represents the main CSS file. */
|
28
|
+
MainCss = "main.css",
|
27
29
|
/** Represents the main JavaScript file. */
|
28
30
|
MainJs = "main.js",
|
29
31
|
/** Represents the main TypeScript file. */
|
@@ -103,7 +103,9 @@ class PluginBase extends import_obsidian.Plugin {
|
|
103
103
|
abortController.abort();
|
104
104
|
});
|
105
105
|
await this.onloadComplete();
|
106
|
-
|
106
|
+
setTimeout(() => {
|
107
|
+
this.app.workspace.onLayoutReady(this.onLayoutReady.bind(this));
|
108
|
+
}, 0);
|
107
109
|
}
|
108
110
|
/**
|
109
111
|
* Saves the new plugin settings.
|
@@ -163,4 +165,4 @@ ${message}`);
|
|
163
165
|
0 && (module.exports = {
|
164
166
|
PluginBase
|
165
167
|
});
|
166
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\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 { ReadonlyDeep } from 'type-fest';\n\nimport {\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 the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<PluginSettings> {\n    return this._settings as ReadonlyDeep<PluginSettings>;\n  }\n\n  /**\n   * Gets a writable copy of the plugin settings.\n   *\n   * @returns A writable copy of the plugin settings.\n   */\n  public get settingsClone(): PluginSettings {\n    return this.createPluginSettings(this.settings.toJSON());\n  }\n\n  private _abortSignal!: AbortSignal;\n\n  private _settings!: PluginSettings;\n\n  private notice?: Notice;\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    initPluginContext(this.app, this.manifest.id);\n\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;AAWA,sBAIO;AAMP,mBAA4B;AAC5B,mBAA+C;AAC/C,sBAAqB;AACrB,2BAAkC;AAO3B,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,WAAyC;AAClD,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,gBAAgC;AACzC,WAAO,KAAK,qBAAqB,KAAK,SAAS,OAAO,CAAC;AAAA,EACzD;AAAA,EAEQ;AAAA,EAEA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcD,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,gDAAkB,KAAK,KAAK,KAAK,SAAS,EAAE;AAE5C,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,SAAS,qBAAqB;AACrC,YAAM,KAAK,aAAa,KAAK,SAAS;AAAA,IACxC;AAAA,EACF;AACF;",
  "names": []
}

|
168
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/Plugin/PluginBase.ts"],
  "sourcesContent": ["/**\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 { ReadonlyDeep } from 'type-fest';\n\nimport {\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 the readonly plugin settings.\n   *\n   * @returns The readonly plugin settings.\n   */\n  public get settings(): ReadonlyDeep<PluginSettings> {\n    return this._settings as ReadonlyDeep<PluginSettings>;\n  }\n\n  /**\n   * Gets a writable copy of the plugin settings.\n   *\n   * @returns A writable copy of the plugin settings.\n   */\n  public get settingsClone(): PluginSettings {\n    return this.createPluginSettings(this.settings.toJSON());\n  }\n\n  private _abortSignal!: AbortSignal;\n\n  private _settings!: PluginSettings;\n\n  private notice?: Notice;\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    initPluginContext(this.app, this.manifest.id);\n\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    setTimeout(() => {\n      this.app.workspace.onLayoutReady(this.onLayoutReady.bind(this));\n    }, 0);\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;AAWA,sBAIO;AAMP,mBAA4B;AAC5B,mBAA+C;AAC/C,sBAAqB;AACrB,2BAAkC;AAO3B,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,WAAyC;AAClD,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAW,gBAAgC;AACzC,WAAO,KAAK,qBAAqB,KAAK,SAAS,OAAO,CAAC;AAAA,EACzD;AAAA,EAEQ;AAAA,EAEA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcD,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,gDAAkB,KAAK,KAAK,KAAK,SAAS,EAAE;AAE5C,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,eAAW,MAAM;AACf,WAAK,IAAI,UAAU,cAAc,KAAK,cAAc,KAAK,IAAI,CAAC;AAAA,IAChE,GAAG,CAAC;AAAA,EACN;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,SAAS,qBAAqB;AACrC,YAAM,KAAK,aAAa,KAAK,SAAS;AAAA,IACxC;AAAA,EACF;AACF;",
  "names": []
}

|
@@ -158,7 +158,16 @@ const configs = import_typescript_eslint.default.config(
|
|
158
158
|
"import-x/no-relative-packages": "error",
|
159
159
|
"import-x/no-restricted-paths": "error",
|
160
160
|
"import-x/no-self-import": "error",
|
161
|
-
"import-x/no-unassigned-import":
|
161
|
+
"import-x/no-unassigned-import": [
|
162
|
+
"error",
|
163
|
+
{
|
164
|
+
allow: [
|
165
|
+
"**/*.css",
|
166
|
+
"**/*.sass",
|
167
|
+
"**/*.scss"
|
168
|
+
]
|
169
|
+
}
|
170
|
+
],
|
162
171
|
"import-x/no-unused-modules": "error",
|
163
172
|
"import-x/no-useless-path-segments": "error",
|
164
173
|
"import-x/no-webpack-loader-syntax": "error",
|
@@ -182,4 +191,4 @@ function excludeFilesProperty(config) {
|
|
182
191
|
0 && (module.exports = {
|
183
192
|
configs
|
184
193
|
});
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/ESLint/eslint.config.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation eslint.config\n * ESLint configuration for TypeScript projects with various plugins.\n *\n * This module exports ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n * such as `@typescript-eslint/parser`, `@typescript-eslint/eslint-plugin`,\n * `eslint-plugin-modules-newlines`, `@stylistic/eslint-plugin`.\n * It sets up parsers, plugins, and rules for maintaining code quality and consistency.\n *\n * @packageDocumentation eslint-config\n */\n\nimport type { Linter } from 'eslint';\n\nimport eslint from '@eslint/js';\n// eslint-disable-next-line import-x/no-rename-default\nimport stylistic from '@stylistic/eslint-plugin';\nimport eslintPluginImportX from 'eslint-plugin-import-x';\nimport eslintPluginModulesNewlines from 'eslint-plugin-modules-newlines';\nimport perfectionist from 'eslint-plugin-perfectionist';\n// eslint-disable-next-line import-x/no-rename-default\nimport tseslint from 'typescript-eslint';\n\nimport { join } from '../../Path.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport { getRootDir } from '../Root.ts';\n\n/**\n * The ESLint configurations for TypeScript projects.\n */\nexport const configs: Linter.Config[] = tseslint.config(\n  eslint.configs.recommended,\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  ...tseslint.configs.strictTypeChecked.map(excludeFilesProperty),\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  ...tseslint.configs.stylisticTypeChecked.map(excludeFilesProperty),\n  {\n    languageOptions: {\n      parserOptions: {\n        projectService: true,\n        tsconfigRootDir: getRootDir() ?? ''\n      }\n    }\n  },\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  stylistic.configs['recommended-flat'],\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  stylistic.configs.customize({\n    arrowParens: true,\n    braceStyle: '1tbs',\n    commaDangle: 'never',\n    flat: true,\n    semi: true\n  }),\n  eslintPluginImportX.flatConfigs.recommended,\n  eslintPluginImportX.flatConfigs.typescript,\n  eslintPluginImportX.flatConfigs.errors,\n  eslintPluginImportX.flatConfigs.warnings,\n  perfectionist.configs['recommended-alphabetical'],\n  {\n    files: [\n      join(ObsidianDevUtilsRepoPaths.Src, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs),\n      join(ObsidianDevUtilsRepoPaths.Scripts, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs)\n    ],\n    ignores: [\n      join(ObsidianDevUtilsRepoPaths.SrcObsidianTypesDataview)\n    ],\n    plugins: {\n      'modules-newlines': eslintPluginModulesNewlines\n    },\n    rules: {\n      '@stylistic/indent': 'off',\n      '@stylistic/indent-binary-ops': 'off',\n      '@stylistic/no-extra-semi': 'error',\n      '@stylistic/object-curly-newline': [\n        'error',\n        {\n          ExportDeclaration: {\n            minProperties: 2,\n            multiline: true\n          },\n          ImportDeclaration: {\n            minProperties: 2,\n            multiline: true\n          }\n        }\n      ],\n      '@stylistic/operator-linebreak': [\n        'error',\n        'before',\n        {\n          overrides: {\n            '=': 'after'\n          }\n        }\n      ],\n      '@stylistic/quotes': [\n        'error',\n        'single',\n        {\n          allowTemplateLiterals: false\n        }\n      ],\n      '@typescript-eslint/explicit-function-return-type': 'error',\n      '@typescript-eslint/explicit-member-accessibility': 'error',\n      '@typescript-eslint/no-unused-vars': [\n        'error',\n        {\n          args: 'all',\n          argsIgnorePattern: '^_',\n          caughtErrors: 'all',\n          caughtErrorsIgnorePattern: '^_',\n          destructuredArrayIgnorePattern: '^_',\n          ignoreRestSiblings: true,\n          varsIgnorePattern: '^_'\n        }\n      ],\n      'curly': 'error',\n      'eqeqeq': 'error',\n      'import-x/consistent-type-specifier-style': 'error',\n      'import-x/extensions': ['error', 'ignorePackages'],\n      'import-x/first': 'error',\n      'import-x/imports-first': 'error',\n      'import-x/newline-after-import': 'error',\n      'import-x/no-absolute-path': 'error',\n      'import-x/no-amd': 'error',\n      'import-x/no-anonymous-default-export': 'error',\n      'import-x/no-commonjs': 'error',\n      'import-x/no-cycle': 'error',\n      'import-x/no-default-export': 'error',\n      'import-x/no-deprecated': 'error',\n      'import-x/no-duplicates': 'error',\n      'import-x/no-dynamic-require': 'error',\n      'import-x/no-empty-named-blocks': 'error',\n      'import-x/no-extraneous-dependencies': 'error',\n      'import-x/no-import-module-exports': 'error',\n      'import-x/no-mutable-exports': 'error',\n      'import-x/no-named-default': 'error',\n      'import-x/no-namespace': 'error',\n      'import-x/no-nodejs-modules': 'error',\n      'import-x/no-relative-packages': 'error',\n      'import-x/no-restricted-paths': 'error',\n      'import-x/no-self-import': 'error',\n      'import-x/no-unassigned-import': 'error',\n      'import-x/no-unused-modules': 'error',\n      'import-x/no-useless-path-segments': 'error',\n      'import-x/no-webpack-loader-syntax': 'error',\n      'modules-newlines/export-declaration-newline': 'error',\n      'modules-newlines/import-declaration-newline': 'error'\n    },\n    settings: {\n      'import/resolver': {\n        typescript: {\n          alwaysTryTypes: true\n        }\n      }\n    }\n  }\n) as Linter.Config[];\n\nfunction excludeFilesProperty<Config extends { files?: unknown }>(config: Config): Omit<Config, 'files'> {\n  const { files: _files, ...configWithoutFiles } = config;\n  return configWithoutFiles;\n}\n"],
  "mappings": "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",
  "names": ["tseslint", "eslint", "stylistic", "eslintPluginImportX", "perfectionist", "eslintPluginModulesNewlines"]
}

|
194
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/ESLint/eslint.config.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation eslint.config\n * ESLint configuration for TypeScript projects with various plugins.\n *\n * This module exports ESLint configurations for TypeScript projects, integrating multiple ESLint plugins\n * such as `@typescript-eslint/parser`, `@typescript-eslint/eslint-plugin`,\n * `eslint-plugin-modules-newlines`, `@stylistic/eslint-plugin`.\n * It sets up parsers, plugins, and rules for maintaining code quality and consistency.\n *\n * @packageDocumentation eslint-config\n */\n\nimport type { Linter } from 'eslint';\n\nimport eslint from '@eslint/js';\n// eslint-disable-next-line import-x/no-rename-default\nimport stylistic from '@stylistic/eslint-plugin';\nimport eslintPluginImportX from 'eslint-plugin-import-x';\nimport eslintPluginModulesNewlines from 'eslint-plugin-modules-newlines';\nimport perfectionist from 'eslint-plugin-perfectionist';\n// eslint-disable-next-line import-x/no-rename-default\nimport tseslint from 'typescript-eslint';\n\nimport { join } from '../../Path.ts';\nimport { ObsidianDevUtilsRepoPaths } from '../ObsidianDevUtilsRepoPaths.ts';\nimport { getRootDir } from '../Root.ts';\n\n/**\n * The ESLint configurations for TypeScript projects.\n */\nexport const configs: Linter.Config[] = tseslint.config(\n  eslint.configs.recommended,\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  ...tseslint.configs.strictTypeChecked.map(excludeFilesProperty),\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  ...tseslint.configs.stylisticTypeChecked.map(excludeFilesProperty),\n  {\n    languageOptions: {\n      parserOptions: {\n        projectService: true,\n        tsconfigRootDir: getRootDir() ?? ''\n      }\n    }\n  },\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  stylistic.configs['recommended-flat'],\n  // eslint-disable-next-line import-x/no-named-as-default-member\n  stylistic.configs.customize({\n    arrowParens: true,\n    braceStyle: '1tbs',\n    commaDangle: 'never',\n    flat: true,\n    semi: true\n  }),\n  eslintPluginImportX.flatConfigs.recommended,\n  eslintPluginImportX.flatConfigs.typescript,\n  eslintPluginImportX.flatConfigs.errors,\n  eslintPluginImportX.flatConfigs.warnings,\n  perfectionist.configs['recommended-alphabetical'],\n  {\n    files: [\n      join(ObsidianDevUtilsRepoPaths.Src, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs),\n      join(ObsidianDevUtilsRepoPaths.Scripts, ObsidianDevUtilsRepoPaths.AnyPath, ObsidianDevUtilsRepoPaths.AnyTs)\n    ],\n    ignores: [\n      join(ObsidianDevUtilsRepoPaths.SrcObsidianTypesDataview)\n    ],\n    plugins: {\n      'modules-newlines': eslintPluginModulesNewlines\n    },\n    rules: {\n      '@stylistic/indent': 'off',\n      '@stylistic/indent-binary-ops': 'off',\n      '@stylistic/no-extra-semi': 'error',\n      '@stylistic/object-curly-newline': [\n        'error',\n        {\n          ExportDeclaration: {\n            minProperties: 2,\n            multiline: true\n          },\n          ImportDeclaration: {\n            minProperties: 2,\n            multiline: true\n          }\n        }\n      ],\n      '@stylistic/operator-linebreak': [\n        'error',\n        'before',\n        {\n          overrides: {\n            '=': 'after'\n          }\n        }\n      ],\n      '@stylistic/quotes': [\n        'error',\n        'single',\n        {\n          allowTemplateLiterals: false\n        }\n      ],\n      '@typescript-eslint/explicit-function-return-type': 'error',\n      '@typescript-eslint/explicit-member-accessibility': 'error',\n      '@typescript-eslint/no-unused-vars': [\n        'error',\n        {\n          args: 'all',\n          argsIgnorePattern: '^_',\n          caughtErrors: 'all',\n          caughtErrorsIgnorePattern: '^_',\n          destructuredArrayIgnorePattern: '^_',\n          ignoreRestSiblings: true,\n          varsIgnorePattern: '^_'\n        }\n      ],\n      'curly': 'error',\n      'eqeqeq': 'error',\n      'import-x/consistent-type-specifier-style': 'error',\n      'import-x/extensions': ['error', 'ignorePackages'],\n      'import-x/first': 'error',\n      'import-x/imports-first': 'error',\n      'import-x/newline-after-import': 'error',\n      'import-x/no-absolute-path': 'error',\n      'import-x/no-amd': 'error',\n      'import-x/no-anonymous-default-export': 'error',\n      'import-x/no-commonjs': 'error',\n      'import-x/no-cycle': 'error',\n      'import-x/no-default-export': 'error',\n      'import-x/no-deprecated': 'error',\n      'import-x/no-duplicates': 'error',\n      'import-x/no-dynamic-require': 'error',\n      'import-x/no-empty-named-blocks': 'error',\n      'import-x/no-extraneous-dependencies': 'error',\n      'import-x/no-import-module-exports': 'error',\n      'import-x/no-mutable-exports': 'error',\n      'import-x/no-named-default': 'error',\n      'import-x/no-namespace': 'error',\n      'import-x/no-nodejs-modules': 'error',\n      'import-x/no-relative-packages': 'error',\n      'import-x/no-restricted-paths': 'error',\n      'import-x/no-self-import': 'error',\n      'import-x/no-unassigned-import': [\n        'error',\n        {\n          allow: [\n            '**/*.css',\n            '**/*.sass',\n            '**/*.scss'\n          ]\n        }\n      ],\n      'import-x/no-unused-modules': 'error',\n      'import-x/no-useless-path-segments': 'error',\n      'import-x/no-webpack-loader-syntax': 'error',\n      'modules-newlines/export-declaration-newline': 'error',\n      'modules-newlines/import-declaration-newline': 'error'\n    },\n    settings: {\n      'import/resolver': {\n        typescript: {\n          alwaysTryTypes: true\n        }\n      }\n    }\n  }\n) as Linter.Config[];\n\nfunction excludeFilesProperty<Config extends { files?: unknown }>(config: Config): Omit<Config, 'files'> {\n  const { files: _files, ...configWithoutFiles } = config;\n  return configWithoutFiles;\n}\n"],
  "mappings": "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",
  "names": ["tseslint", "eslint", "stylistic", "eslintPluginImportX", "perfectionist", "eslintPluginModulesNewlines"]
}

|
@@ -49,6 +49,7 @@ __export(NodeModules_exports, {
|
|
49
49
|
readFile: () => import_promises.readFile,
|
50
50
|
readFileSync: () => import_node_fs.readFileSync,
|
51
51
|
readdir: () => import_promises.readdir,
|
52
|
+
rename: () => import_promises.rename,
|
52
53
|
rm: () => import_promises.rm,
|
53
54
|
spawn: () => import_node_child_process.spawn,
|
54
55
|
stat: () => import_promises.stat,
|
@@ -82,6 +83,7 @@ var import_node_url = require('node:url');
|
|
82
83
|
readFile,
|
83
84
|
readFileSync,
|
84
85
|
readdir,
|
86
|
+
rename,
|
85
87
|
rm,
|
86
88
|
spawn,
|
87
89
|
stat,
|
@@ -90,4 +92,4 @@ var import_node_url = require('node:url');
|
|
90
92
|
writeFile,
|
91
93
|
writeFileSync
|
92
94
|
});
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
95
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvTm9kZU1vZHVsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIE5vZGVNb2R1bGVzXG4gKiBDb250YWlucyB1dGlsaXR5IGZ1bmN0aW9ucyBmb3IgTm9kZS5qcyBtb2R1bGVzLlxuICovXG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlc1xuaW1wb3J0IHByb2Nlc3MgZnJvbSAnbm9kZTpwcm9jZXNzJztcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC14L25vLW5vZGVqcy1tb2R1bGVzLCBlc2xpbnQtcGx1Z2luLXRzZG9jLXJlcXVpcmVkL3RzZG9jLXJlcXVpcmVkXG5leHBvcnQgeyBzcGF3biB9IGZyb20gJ25vZGU6Y2hpbGRfcHJvY2Vzcyc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlcywgZXNsaW50LXBsdWdpbi10c2RvYy1yZXF1aXJlZC90c2RvYy1yZXF1aXJlZFxuZXhwb3J0IHtcbiAgZXhpc3RzU3luYyxcbiAgcmVhZEZpbGVTeW5jLFxuICBzdGF0U3luYyxcbiAgd2F0Y2gsXG4gIHdyaXRlRmlsZVN5bmNcbn0gZnJvbSAnbm9kZTpmcyc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlcywgZXNsaW50LXBsdWdpbi10c2RvYy1yZXF1aXJlZC90c2RvYy1yZXF1aXJlZFxuZXhwb3J0IHR5cGUge1xuICBEaXJlbnQsXG4gIEZTV2F0Y2hlcixcbiAgT2JqZWN0RW5jb2RpbmdPcHRpb25zLFxuICBQYXRoTGlrZSxcbiAgV2F0Y2hFdmVudFR5cGVcbn0gZnJvbSAnbm9kZTpmcyc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBlc2xpbnQtcGx1Z2luLXRzZG9jLXJlcXVpcmVkL3RzZG9jLXJlcXVpcmVkXG5leHBvcnQgeyBwcm9jZXNzIH07XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlcywgZXNsaW50LXBsdWdpbi10c2RvYy1yZXF1aXJlZC90c2RvYy1yZXF1aXJlZFxuZXhwb3J0IHtcbiAgY3AsXG4gIG1rZGlyLFxuICByZWFkZGlyLFxuICByZWFkRmlsZSxcbiAgcmVuYW1lLFxuICBybSxcbiAgc3RhdCxcbiAgd3JpdGVGaWxlXG59IGZyb20gJ25vZGU6ZnMvcHJvbWlzZXMnO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0LXgvbm8tbm9kZWpzLW1vZHVsZXMsIGVzbGludC1wbHVnaW4tdHNkb2MtcmVxdWlyZWQvdHNkb2MtcmVxdWlyZWRcbmV4cG9ydCB7XG4gIGJ1aWx0aW5Nb2R1bGVzLFxuICBjcmVhdGVSZXF1aXJlLFxuICBNb2R1bGVcbn0gZnJvbSAnbm9kZTptb2R1bGUnO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0LXgvbm8tbm9kZWpzLW1vZHVsZXMsIGVzbGludC1wbHVnaW4tdHNkb2MtcmVxdWlyZWQvdHNkb2MtcmVxdWlyZWRcbmV4cG9ydCB7XG4gIGFyY2gsXG4gIGVuZGlhbm5lc3Ncbn0gZnJvbSAnbm9kZTpvcyc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlcywgZXNsaW50LXBsdWdpbi10c2RvYy1yZXF1aXJlZC90c2RvYy1yZXF1aXJlZFxuZXhwb3J0IHsgY3JlYXRlSW50ZXJmYWNlIH0gZnJvbSAnbm9kZTpyZWFkbGluZS9wcm9taXNlcyc7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBpbXBvcnQteC9uby1ub2RlanMtbW9kdWxlcywgZXNsaW50LXBsdWdpbi10c2RvYy1yZXF1aXJlZC90c2RvYy1yZXF1aXJlZFxuZXhwb3J0IHsgZmlsZVVSTFRvUGF0aCB9IGZyb20gJ25vZGU6dXJsJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEscUNBQUFBO0FBQUEsRUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU1BLDBCQUFvQjtBQUdwQixnQ0FBc0I7QUFHdEIscUJBTU87QUFlUCxzQkFTTztBQUdQLHlCQUlPO0FBR1AscUJBR087QUFHUCxJQUFBQyxtQkFBZ0M7QUFHaEMsc0JBQThCOyIsCiAgIm5hbWVzIjogWyJwcm9jZXNzIiwgImltcG9ydF9wcm9taXNlcyJdCn0K
|
@@ -7,7 +7,7 @@ export { spawn } from 'node:child_process';
|
|
7
7
|
export { existsSync, readFileSync, statSync, watch, writeFileSync } from 'node:fs';
|
8
8
|
export type { Dirent, FSWatcher, ObjectEncodingOptions, PathLike, WatchEventType } from 'node:fs';
|
9
9
|
export { process };
|
10
|
-
export { cp, mkdir, readdir, readFile, rm, stat, writeFile } from 'node:fs/promises';
|
10
|
+
export { cp, mkdir, readdir, readFile, rename, rm, stat, writeFile } from 'node:fs/promises';
|
11
11
|
export { builtinModules, createRequire, Module } from 'node:module';
|
12
12
|
export { arch, endianness } from 'node:os';
|
13
13
|
export { createInterface } from 'node:readline/promises';
|
@@ -26,19 +26,42 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
26
26
|
var build_exports = {};
|
27
27
|
__export(build_exports, {
|
28
28
|
buildClean: () => buildClean,
|
29
|
-
|
30
|
-
|
29
|
+
buildCompile: () => buildCompile,
|
30
|
+
buildCompileSvelte: () => buildCompileSvelte,
|
31
|
+
buildCompileTypeScript: () => buildCompileTypeScript,
|
32
|
+
buildStatic: () => buildStatic
|
31
33
|
});
|
32
34
|
module.exports = __toCommonJS(build_exports);
|
35
|
+
var import_glob = require('glob');
|
36
|
+
var import_Debug = require('../Debug.cjs');
|
33
37
|
var import_Path = require('../Path.cjs');
|
34
38
|
var import_String = require('../String.cjs');
|
35
39
|
var import_Fs = require('./Fs.cjs');
|
40
|
+
var import_JSON = require('./JSON.cjs');
|
36
41
|
var import_NodeModules = require('./NodeModules.cjs');
|
37
42
|
var import_ObsidianDevUtilsRepoPaths = require('./ObsidianDevUtilsRepoPaths.cjs');
|
38
43
|
var import_Root = require('./Root.cjs');
|
39
44
|
async function buildClean() {
|
40
45
|
await (0, import_NodeModules.rm)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Dist, { force: true, recursive: true });
|
41
46
|
}
|
47
|
+
async function buildCompile() {
|
48
|
+
await buildCompileSvelte();
|
49
|
+
await buildCompileTypeScript();
|
50
|
+
}
|
51
|
+
async function buildCompileSvelte() {
|
52
|
+
const tsConfigPath = (0, import_Root.resolvePathFromRootSafe)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.TsConfigJson);
|
53
|
+
const tsConfig = await (0, import_JSON.readJson)(tsConfigPath);
|
54
|
+
const allFiles = await (0, import_glob.glob)(tsConfig.include ?? [], { ignore: tsConfig.exclude ?? [] });
|
55
|
+
const svelteFiles = allFiles.filter((file) => file.endsWith(".svelte") || file.endsWith(".svelte.js") || file.endsWith(".svelte.ts"));
|
56
|
+
if (svelteFiles.length === 0) {
|
57
|
+
(0, import_Debug.getLibDebugger)("build:buildCompileSvelte")("No Svelte files found in the project, skipping Svelte compilation");
|
58
|
+
return;
|
59
|
+
}
|
60
|
+
await (0, import_Root.execFromRoot)(["svelte-check", "--tsconfig", import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.TsConfigJson]);
|
61
|
+
}
|
62
|
+
async function buildCompileTypeScript() {
|
63
|
+
await (0, import_Root.execFromRoot)(["tsc", "--build", "--force"]);
|
64
|
+
}
|
42
65
|
async function buildStatic() {
|
43
66
|
for (const dirent of await (0, import_Fs.readdirPosix)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Static, { recursive: true, withFileTypes: true })) {
|
44
67
|
if (!dirent.isFile()) {
|
@@ -48,13 +71,12 @@ async function buildStatic() {
|
|
48
71
|
await (0, import_NodeModules.cp)((0, import_Path.join)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Static, path), (0, import_Path.join)(import_ObsidianDevUtilsRepoPaths.ObsidianDevUtilsRepoPaths.Dist, path));
|
49
72
|
}
|
50
73
|
}
|
51
|
-
async function buildValidate() {
|
52
|
-
await (0, import_Root.execFromRoot)(["tsc", "--build", "--force"]);
|
53
|
-
}
|
54
74
|
// Annotate the CommonJS export names for ESM import in node:
|
55
75
|
0 && (module.exports = {
|
56
76
|
buildClean,
|
57
|
-
|
58
|
-
|
77
|
+
buildCompile,
|
78
|
+
buildCompileSvelte,
|
79
|
+
buildCompileTypeScript,
|
80
|
+
buildStatic
|
59
81
|
});
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
82
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3NjcmlwdHMvYnVpbGQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQHBhY2thZ2VEb2N1bWVudGF0aW9uIGJ1aWxkXG4gKiBUaGlzIG1vZHVsZSBwcm92aWRlcyB1dGlsaXR5IGZ1bmN0aW9ucyB0byBoYW5kbGUgdGhlIGJ1aWxkIHByb2Nlc3MgZm9yIHN0YXRpYyBhc3NldHMgYW5kIGNsZWFuaW5nXG4gKiB0aGUgYnVpbGQgb3V0cHV0IGRpcmVjdG9yeS4gSXQgaW5jbHVkZXMgZnVuY3Rpb25zIHRvIGNvcHkgc3RhdGljIGZpbGVzIHRvIHRoZSBkaXN0cmlidXRpb24gZGlyZWN0b3J5XG4gKiBhbmQgdG8gcmVtb3ZlIHRoZSBleGlzdGluZyBidWlsZCBvdXRwdXQuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBUc0NvbmZpZ0pzb24gfSBmcm9tICd0eXBlLWZlc3QnO1xuXG5pbXBvcnQgeyBnbG9iIH0gZnJvbSAnZ2xvYic7XG5cbmltcG9ydCB7IGdldExpYkRlYnVnZ2VyIH0gZnJvbSAnLi4vRGVidWcudHMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJy4uL1BhdGgudHMnO1xuaW1wb3J0IHsgdHJpbVN0YXJ0IH0gZnJvbSAnLi4vU3RyaW5nLnRzJztcbmltcG9ydCB7IHJlYWRkaXJQb3NpeCB9IGZyb20gJy4vRnMudHMnO1xuaW1wb3J0IHsgcmVhZEpzb24gfSBmcm9tICcuL0pTT04udHMnO1xuaW1wb3J0IHtcbiAgY3AsXG4gIHJtXG59IGZyb20gJy4vTm9kZU1vZHVsZXMudHMnO1xuaW1wb3J0IHsgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocyB9IGZyb20gJy4vT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy50cyc7XG5pbXBvcnQge1xuICBleGVjRnJvbVJvb3QsXG4gIHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlXG59IGZyb20gJy4vUm9vdC50cyc7XG5cbi8qKlxuICogUmVtb3ZlcyB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeSBhbmQgaXRzIGNvbnRlbnRzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gZGVsZXRlcyB0aGUgZW50aXJlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkgdG8gZW5zdXJlIGEgY2xlYW4gYnVpbGQgZW52aXJvbm1lbnQuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgZGlyZWN0b3J5IGhhcyBiZWVuIHJlbW92ZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENsZWFuKCk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBybShPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLkRpc3QsIHsgZm9yY2U6IHRydWUsIHJlY3Vyc2l2ZTogdHJ1ZSB9KTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgY29kZS5cbiAqXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIHRoZSBjb2RlIGNvbXBpbGVzIHN1Y2Nlc3NmdWxseS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkQ29tcGlsZSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgYnVpbGRDb21waWxlU3ZlbHRlKCk7XG4gIGF3YWl0IGJ1aWxkQ29tcGlsZVR5cGVTY3JpcHQoKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgU3ZlbHRlIGNvZGUuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29kZSBjb21waWxlcyBzdWNjZXNzZnVsbHkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidWlsZENvbXBpbGVTdmVsdGUoKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHRzQ29uZmlnUGF0aCA9IHJlc29sdmVQYXRoRnJvbVJvb3RTYWZlKE9ic2lkaWFuRGV2VXRpbHNSZXBvUGF0aHMuVHNDb25maWdKc29uKTtcbiAgY29uc3QgdHNDb25maWcgPSBhd2FpdCByZWFkSnNvbjxUc0NvbmZpZ0pzb24+KHRzQ29uZmlnUGF0aCk7XG4gIGNvbnN0IGFsbEZpbGVzID0gYXdhaXQgZ2xvYih0c0NvbmZpZy5pbmNsdWRlID8/IFtdLCB7IGlnbm9yZTogdHNDb25maWcuZXhjbHVkZSA/PyBbXSB9KTtcbiAgY29uc3Qgc3ZlbHRlRmlsZXMgPSBhbGxGaWxlcy5maWx0ZXIoKGZpbGUpID0+IGZpbGUuZW5kc1dpdGgoJy5zdmVsdGUnKSB8fCBmaWxlLmVuZHNXaXRoKCcuc3ZlbHRlLmpzJykgfHwgZmlsZS5lbmRzV2l0aCgnLnN2ZWx0ZS50cycpKTtcblxuICBpZiAoc3ZlbHRlRmlsZXMubGVuZ3RoID09PSAwKSB7XG4gICAgZ2V0TGliRGVidWdnZXIoJ2J1aWxkOmJ1aWxkQ29tcGlsZVN2ZWx0ZScpKCdObyBTdmVsdGUgZmlsZXMgZm91bmQgaW4gdGhlIHByb2plY3QsIHNraXBwaW5nIFN2ZWx0ZSBjb21waWxhdGlvbicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGF3YWl0IGV4ZWNGcm9tUm9vdChbJ3N2ZWx0ZS1jaGVjaycsICctLXRzY29uZmlnJywgT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5Uc0NvbmZpZ0pzb25dKTtcbn1cblxuLyoqXG4gKiBDb21waWxlcyB0aGUgVHlwZVNjcmlwdCBjb2RlLlxuICpcbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvZGUgY29tcGlsZXMgc3VjY2Vzc2Z1bGx5LlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYnVpbGRDb21waWxlVHlwZVNjcmlwdCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgZXhlY0Zyb21Sb290KFsndHNjJywgJy0tYnVpbGQnLCAnLS1mb3JjZSddKTtcbn1cblxuLyoqXG4gKiBDb3BpZXMgYWxsIHN0YXRpYyBmaWxlcyBmcm9tIHRoZSBzdGF0aWMgYXNzZXRzIGRpcmVjdG9yeSB0byB0aGUgZGlzdHJpYnV0aW9uIGRpcmVjdG9yeS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHJlY3Vyc2l2ZWx5IHJlYWRzIHRoZSBjb250ZW50cyBvZiB0aGUgc3RhdGljIGFzc2V0cyBkaXJlY3RvcnkgYW5kIGNvcGllc1xuICogZWFjaCBmaWxlIHRvIHRoZSBjb3JyZXNwb25kaW5nIHBhdGggaW4gdGhlIGRpc3RyaWJ1dGlvbiBkaXJlY3RvcnkuXG4gKlxuICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiBhbGwgZmlsZXMgaGF2ZSBiZWVuIGNvcGllZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGJ1aWxkU3RhdGljKCk6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGRpcmVudCBvZiBhd2FpdCByZWFkZGlyUG9zaXgoT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5TdGF0aWMsIHsgcmVjdXJzaXZlOiB0cnVlLCB3aXRoRmlsZVR5cGVzOiB0cnVlIH0pKSB7XG4gICAgaWYgKCFkaXJlbnQuaXNGaWxlKCkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IHBhdGggPSB0cmltU3RhcnQoam9pbihkaXJlbnQucGFyZW50UGF0aCwgZGlyZW50Lm5hbWUpLCBPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYyArICcvJyk7XG4gICAgYXdhaXQgY3Aoam9pbihPYnNpZGlhbkRldlV0aWxzUmVwb1BhdGhzLlN0YXRpYywgcGF0aCksIGpvaW4oT2JzaWRpYW5EZXZVdGlsc1JlcG9QYXRocy5EaXN0LCBwYXRoKSk7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFTQSxrQkFBcUI7QUFFckIsbUJBQStCO0FBQy9CLGtCQUFxQjtBQUNyQixvQkFBMEI7QUFDMUIsZ0JBQTZCO0FBQzdCLGtCQUF5QjtBQUN6Qix5QkFHTztBQUNQLHVDQUEwQztBQUMxQyxrQkFHTztBQVNQLGVBQXNCLGFBQTRCO0FBQ2hELFlBQU0sdUJBQUcsMkRBQTBCLE1BQU0sRUFBRSxPQUFPLE1BQU0sV0FBVyxLQUFLLENBQUM7QUFDM0U7QUFPQSxlQUFzQixlQUE4QjtBQUNsRCxRQUFNLG1CQUFtQjtBQUN6QixRQUFNLHVCQUF1QjtBQUMvQjtBQU9BLGVBQXNCLHFCQUFvQztBQUN4RCxRQUFNLG1CQUFlLHFDQUF3QiwyREFBMEIsWUFBWTtBQUNuRixRQUFNLFdBQVcsVUFBTSxzQkFBdUIsWUFBWTtBQUMxRCxRQUFNLFdBQVcsVUFBTSxrQkFBSyxTQUFTLFdBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxTQUFTLFdBQVcsQ0FBQyxFQUFFLENBQUM7QUFDdEYsUUFBTSxjQUFjLFNBQVMsT0FBTyxDQUFDLFNBQVMsS0FBSyxTQUFTLFNBQVMsS0FBSyxLQUFLLFNBQVMsWUFBWSxLQUFLLEtBQUssU0FBUyxZQUFZLENBQUM7QUFFcEksTUFBSSxZQUFZLFdBQVcsR0FBRztBQUM1QixxQ0FBZSwwQkFBMEIsRUFBRSxtRUFBbUU7QUFDOUc7QUFBQSxFQUNGO0FBRUEsWUFBTSwwQkFBYSxDQUFDLGdCQUFnQixjQUFjLDJEQUEwQixZQUFZLENBQUM7QUFDM0Y7QUFPQSxlQUFzQix5QkFBd0M7QUFDNUQsWUFBTSwwQkFBYSxDQUFDLE9BQU8sV0FBVyxTQUFTLENBQUM7QUFDbEQ7QUFVQSxlQUFzQixjQUE2QjtBQUNqRCxhQUFXLFVBQVUsVUFBTSx3QkFBYSwyREFBMEIsUUFBUSxFQUFFLFdBQVcsTUFBTSxlQUFlLEtBQUssQ0FBQyxHQUFHO0FBQ25ILFFBQUksQ0FBQyxPQUFPLE9BQU8sR0FBRztBQUNwQjtBQUFBLElBQ0Y7QUFFQSxVQUFNLFdBQU8sNkJBQVUsa0JBQUssT0FBTyxZQUFZLE9BQU8sSUFBSSxHQUFHLDJEQUEwQixTQUFTLEdBQUc7QUFDbkcsY0FBTSwyQkFBRyxrQkFBSywyREFBMEIsUUFBUSxJQUFJLE9BQUcsa0JBQUssMkRBQTBCLE1BQU0sSUFBSSxDQUFDO0FBQUEsRUFDbkc7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -12,6 +12,24 @@
|
|
12
12
|
* @returns A promise that resolves when the directory has been removed.
|
13
13
|
*/
|
14
14
|
export declare function buildClean(): Promise<void>;
|
15
|
+
/**
|
16
|
+
* Compiles the code.
|
17
|
+
*
|
18
|
+
* @returns A promise that resolves when the code compiles successfully.
|
19
|
+
*/
|
20
|
+
export declare function buildCompile(): Promise<void>;
|
21
|
+
/**
|
22
|
+
* Compiles the Svelte code.
|
23
|
+
*
|
24
|
+
* @returns A promise that resolves when the code compiles successfully.
|
25
|
+
*/
|
26
|
+
export declare function buildCompileSvelte(): Promise<void>;
|
27
|
+
/**
|
28
|
+
* Compiles the TypeScript code.
|
29
|
+
*
|
30
|
+
* @returns A promise that resolves when the code compiles successfully.
|
31
|
+
*/
|
32
|
+
export declare function buildCompileTypeScript(): Promise<void>;
|
15
33
|
/**
|
16
34
|
* Copies all static files from the static assets directory to the distribution directory.
|
17
35
|
*
|
@@ -21,9 +39,3 @@ export declare function buildClean(): Promise<void>;
|
|
21
39
|
* @returns A promise that resolves when all files have been copied.
|
22
40
|
*/
|
23
41
|
export declare function buildStatic(): Promise<void>;
|
24
|
-
/**
|
25
|
-
* Validates if the TypeScript code compiles successfully.
|
26
|
-
*
|
27
|
-
* @returns A promise that resolves when the code compiles successfully.
|
28
|
-
*/
|
29
|
-
export declare function buildValidate(): Promise<void>;
|
package/dist/lib/scripts/cli.cjs
CHANGED
@@ -60,8 +60,10 @@ function cli(argv = import_NodeModules.process.argv.slice(NODE_SCRIPT_ARGV_SKIP_
|
|
60
60
|
program.name(packageJson.name ?? "(unknown)").description("CLI for Obsidian plugin development utilities").version(packageJson.version ?? "(unknown)");
|
61
61
|
addCommand(program, "build" /* Build */, "Build the plugin", () => (0, import_ObsidianPluginBuilder.buildObsidianPlugin)({ mode: import_ObsidianPluginBuilder.BuildMode.Production }));
|
62
62
|
addCommand(program, "build:clean" /* BuildClean */, "Clean the dist folder", () => (0, import_build.buildClean)());
|
63
|
+
addCommand(program, "build:compile" /* BuildCompile */, "Check if code compiles", () => (0, import_build.buildCompile)());
|
64
|
+
addCommand(program, "build:compile:svelte" /* BuildCompileSvelte */, "Check if Svelte code compiles", () => (0, import_build.buildCompileSvelte)());
|
65
|
+
addCommand(program, "build:compile:typescript" /* BuildCompileTypeScript */, "Check if TypeScript code compiles", () => (0, import_build.buildCompileTypeScript)());
|
63
66
|
addCommand(program, "build:static" /* BuildStatic */, "Copy static content to dist", () => (0, import_build.buildStatic)());
|
64
|
-
addCommand(program, "build:validate" /* BuildValidate */, "Validates if TypeScript code compiles", () => (0, import_build.buildValidate)());
|
65
67
|
addCommand(program, "dev" /* Dev */, "Build the plugin in development mode", () => (0, import_ObsidianPluginBuilder.buildObsidianPlugin)({ mode: import_ObsidianPluginBuilder.BuildMode.Development }));
|
66
68
|
addCommand(program, "format" /* Format */, "Format the source code", () => (0, import_format.format)());
|
67
69
|
addCommand(program, "format:check" /* FormatCheck */, "Check if the source code is formatted", () => (0, import_format.format)(false));
|
@@ -82,4 +84,4 @@ function addCommand(program, name, description, taskFn) {
|
|
82
84
|
0 && (module.exports = {
|
83
85
|
cli
|
84
86
|
});
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from 'commander';\n\nimport type { MaybePromise } from '../Async.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport { getDirname } from '../Path.ts';\nimport {\n  buildClean,\n  buildStatic,\n  buildValidate\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { process } from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildStatic = 'build:static',\n  BuildValidate = 'build:validate',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.BuildValidate, 'Validates if TypeScript code compiles', () => buildValidate());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAIO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,oBAAuB;AACvB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AAlC9B,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AAwC/O,MAAM,8BAA8B;AA0B7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F;AAAA,IAAkB,UAChB,6BAAY,YAAY;AACtB,YAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,YAAM,UAAU,IAAI,yBAAQ;AAE5B,cACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,iBAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,iBAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,iBAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,iBAAW,SAAS,sCAA4B,yCAAyC,UAAM,4BAAc,CAAC;AAC9G,iBAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,iBAAW,SAAS,uBAAqB,0BAA0B,UAAM,sBAAO,CAAC;AACjF,iBAAW,SAAS,kCAA0B,yCAAyC,UAAM,sBAAO,KAAK,CAAC;AAC1G,iBAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,iBAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,iBAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,iBAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,iBAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,YAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,aAAO,8BAAc,UAAU;AAAA,IACjC,CAAC;AAAA,EACH;AACF;AAYA,SAAS,WACP,SACA,MACA,aAEA,QACS;AACT,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

|
87
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/scripts/cli.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis['import.meta.url'] ?? (()=>{if(typeof __filename===\"string\"){const url=require(\"node:url\");return url.pathToFileURL(__filename).href}if(typeof window!==\"undefined\"){return window.location.href}return\"\"})();\n/**\n * @packageDocumentation cli\n * This module defines a CLI for managing various tasks related to Obsidian plugin development.\n * It leverages the `commander` library to define commands for building, linting, spellchecking,\n * and updating the version of the plugin. The CLI is designed to be flexible and can handle both\n * synchronous and asynchronous tasks.\n */\n\nimport { Command } from 'commander';\n\nimport type { MaybePromise } from '../Async.ts';\n\nimport { invokeAsyncSafely } from '../Async.ts';\nimport { getDirname } from '../Path.ts';\nimport {\n  buildClean,\n  buildCompile,\n  buildCompileSvelte,\n  buildCompileTypeScript,\n  buildStatic\n} from './build.ts';\nimport {\n  CliTaskResult,\n  wrapCliTask\n} from './CliUtils.ts';\nimport {\n  BuildMode,\n  buildObsidianPlugin\n} from './esbuild/ObsidianPluginBuilder.ts';\nimport { lint } from './ESLint/ESLint.ts';\nimport { format } from './format.ts';\nimport { process } from './NodeModules.ts';\nimport { readPackageJson } from './Npm.ts';\nimport { publish } from './NpmPublish.ts';\nimport { spellcheck } from './spellcheck.ts';\nimport { updateVersion } from './version.ts';\n/**\n * The number of leading arguments to skip when parsing command-line arguments.\n * The first two elements typically represent the Node.js executable and the script path:\n * `[\"node\", \"path/to/cli.cjs\", ...actualArgs]`\n */\nconst NODE_SCRIPT_ARGV_SKIP_COUNT = 2;\n\n/**\n * Enum representing the names of the commands available in the CLI.\n */\nenum CommandNames {\n  Build = 'build',\n  BuildClean = 'build:clean',\n  BuildCompile = 'build:compile',\n  BuildCompileSvelte = 'build:compile:svelte',\n  BuildCompileTypeScript = 'build:compile:typescript',\n  BuildStatic = 'build:static',\n  Dev = 'dev',\n  Format = 'format',\n  FormatCheck = 'format:check',\n  Lint = 'lint',\n  LintFix = 'lint:fix',\n  Publish = 'publish',\n  Spellcheck = 'spellcheck',\n  Version = 'version'\n}\n\n/**\n * Main function to run the CLI. It sets up the commands using the `commander` library and\n * handles the execution of tasks like building, cleaning, linting, spellchecking, and versioning.\n *\n * @param argv - The command-line arguments to parse. Defaults to `process.argv` minus the first two elements.\n */\nexport function cli(argv: string[] = process.argv.slice(NODE_SCRIPT_ARGV_SKIP_COUNT)): void {\n  invokeAsyncSafely(() =>\n    wrapCliTask(async () => {\n      const packageJson = await readPackageJson(getDirname(import.meta.url));\n      const program = new Command();\n\n      program\n        .name(packageJson.name ?? '(unknown)')\n        .description('CLI for Obsidian plugin development utilities')\n        .version(packageJson.version ?? '(unknown)');\n\n      addCommand(program, CommandNames.Build, 'Build the plugin', () => buildObsidianPlugin({ mode: BuildMode.Production }));\n      addCommand(program, CommandNames.BuildClean, 'Clean the dist folder', () => buildClean());\n      addCommand(program, CommandNames.BuildCompile, 'Check if code compiles', () => buildCompile());\n      addCommand(program, CommandNames.BuildCompileSvelte, 'Check if Svelte code compiles', () => buildCompileSvelte());\n      addCommand(program, CommandNames.BuildCompileTypeScript, 'Check if TypeScript code compiles', () => buildCompileTypeScript());\n      addCommand(program, CommandNames.BuildStatic, 'Copy static content to dist', () => buildStatic());\n      addCommand(program, CommandNames.Dev, 'Build the plugin in development mode', () => buildObsidianPlugin({ mode: BuildMode.Development }));\n      addCommand(program, CommandNames.Format, 'Format the source code', () => format());\n      addCommand(program, CommandNames.FormatCheck, 'Check if the source code is formatted', () => format(false));\n      addCommand(program, CommandNames.Lint, 'Lint the source code', () => lint());\n      addCommand(program, CommandNames.LintFix, 'Lint the source code and apply automatic fixes', () => lint(true));\n      addCommand(program, CommandNames.Publish, 'Publish to NPM', (isBeta: boolean) => publish(isBeta))\n        .argument('[isBeta]', 'Publish to NPM beta');\n      addCommand(program, CommandNames.Spellcheck, 'Spellcheck the source code', () => spellcheck());\n      addCommand(program, CommandNames.Version, 'Release a new version', (versionUpdateType: string) => updateVersion(versionUpdateType))\n        .argument('[versionUpdateType]', 'Version update type: major, minor, patch, beta, or x.y.z[-suffix]');\n      await program.parseAsync(argv, { from: 'user' });\n      return CliTaskResult.DoNotExit();\n    })\n  );\n}\n\n/**\n * Adds a command to the CLI program with the specified name, description, and task function.\n *\n * @param program - The `commander` program instance to which the command is added.\n * @param name - The name of the command.\n * @param description - A brief description of what the command does.\n * @param taskFn - The function to execute when the command is invoked. Can return a `TaskResult` or void.\n * @returns The `commander` command instance for further chaining.\n */\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\nfunction addCommand<Args extends unknown[]>(\n  program: Command,\n  name: string,\n  description: string,\n  // eslint-disable-next-line @typescript-eslint/no-invalid-void-type\n  taskFn: (...args: Args) => MaybePromise<CliTaskResult | void>\n): Command {\n  return program.command(name)\n    .description(description)\n    .action((...args: Args) => wrapCliTask(() => taskFn(...args)));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,uBAAwB;AAIxB,mBAAkC;AAClC,kBAA2B;AAC3B,mBAMO;AACP,sBAGO;AACP,mCAGO;AACP,oBAAqB;AACrB,oBAAuB;AACvB,yBAAwB;AACxB,iBAAgC;AAChC,wBAAwB;AACxB,wBAA2B;AAC3B,qBAA8B;AApC9B,IAAI,oBAAoB,WAAW,iBAAiB,MAAM,MAAI;AAAC,MAAG,OAAO,eAAa,UAAS;AAAC,UAAM,MAAI,QAAQ,UAAU;AAAE,WAAO,IAAI,cAAc,UAAU,EAAE;AAAA,EAAI;AAAC,MAAG,OAAO,WAAS,aAAY;AAAC,WAAO,OAAO,SAAS;AAAA,EAAI;AAAC,SAAM;AAAE,GAAG;AA0C/O,MAAM,8BAA8B;AA4B7B,SAAS,IAAI,OAAiB,2BAAQ,KAAK,MAAM,2BAA2B,GAAS;AAC1F;AAAA,IAAkB,UAChB,6BAAY,YAAY;AACtB,YAAM,cAAc,UAAM,gCAAgB,wBAAW,iBAAe,CAAC;AACrE,YAAM,UAAU,IAAI,yBAAQ;AAE5B,cACG,KAAK,YAAY,QAAQ,WAAW,EACpC,YAAY,+CAA+C,EAC3D,QAAQ,YAAY,WAAW,WAAW;AAE7C,iBAAW,SAAS,qBAAoB,oBAAoB,UAAM,kDAAoB,EAAE,MAAM,uCAAU,WAAW,CAAC,CAAC;AACrH,iBAAW,SAAS,gCAAyB,yBAAyB,UAAM,yBAAW,CAAC;AACxF,iBAAW,SAAS,oCAA2B,0BAA0B,UAAM,2BAAa,CAAC;AAC7F,iBAAW,SAAS,iDAAiC,iCAAiC,UAAM,iCAAmB,CAAC;AAChH,iBAAW,SAAS,yDAAqC,qCAAqC,UAAM,qCAAuB,CAAC;AAC5H,iBAAW,SAAS,kCAA0B,+BAA+B,UAAM,0BAAY,CAAC;AAChG,iBAAW,SAAS,iBAAkB,wCAAwC,UAAM,kDAAoB,EAAE,MAAM,uCAAU,YAAY,CAAC,CAAC;AACxI,iBAAW,SAAS,uBAAqB,0BAA0B,UAAM,sBAAO,CAAC;AACjF,iBAAW,SAAS,kCAA0B,yCAAyC,UAAM,sBAAO,KAAK,CAAC;AAC1G,iBAAW,SAAS,mBAAmB,wBAAwB,UAAM,oBAAK,CAAC;AAC3E,iBAAW,SAAS,0BAAsB,kDAAkD,UAAM,oBAAK,IAAI,CAAC;AAC5G,iBAAW,SAAS,yBAAsB,kBAAkB,CAAC,eAAoB,2BAAQ,MAAM,CAAC,EAC7F,SAAS,YAAY,qBAAqB;AAC7C,iBAAW,SAAS,+BAAyB,8BAA8B,UAAM,8BAAW,CAAC;AAC7F,iBAAW,SAAS,yBAAsB,yBAAyB,CAAC,0BAA8B,8BAAc,iBAAiB,CAAC,EAC/H,SAAS,uBAAuB,mEAAmE;AACtG,YAAM,QAAQ,WAAW,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/C,aAAO,8BAAc,UAAU;AAAA,IACjC,CAAC;AAAA,EACH;AACF;AAYA,SAAS,WACP,SACA,MACA,aAEA,QACS;AACT,SAAO,QAAQ,QAAQ,IAAI,EACxB,YAAY,WAAW,EACvB,OAAO,IAAI,aAAe,6BAAY,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC;AACjE;",
  "names": []
}

|
@@ -6,9 +6,11 @@ if you want to view the source, please visit the github repository of this plugi
|
|
6
6
|
(function init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
|
7
7
|
|
8
8
|
"use strict";
|
9
|
+
var __create = Object.create;
|
9
10
|
var __defProp = Object.defineProperty;
|
10
11
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
11
12
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
13
|
+
var __getProtoOf = Object.getPrototypeOf;
|
12
14
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
13
15
|
var __export = (target, all) => {
|
14
16
|
for (var name in all)
|
@@ -22,6 +24,14 @@ var __copyProps = (to, from, except, desc) => {
|
|
22
24
|
}
|
23
25
|
return to;
|
24
26
|
};
|
27
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
28
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
29
|
+
// file that has been converted to a CommonJS file using a Babel-
|
30
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
31
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
32
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
33
|
+
mod
|
34
|
+
));
|
25
35
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
26
36
|
var ObsidianPluginBuilder_exports = {};
|
27
37
|
__export(ObsidianPluginBuilder_exports, {
|
@@ -33,6 +43,9 @@ __export(ObsidianPluginBuilder_exports, {
|
|
33
43
|
module.exports = __toCommonJS(ObsidianPluginBuilder_exports);
|
34
44
|
var import_dotenv = require('dotenv');
|
35
45
|
var import_esbuild = require('esbuild');
|
46
|
+
var import_esbuild_sass_plugin = require('esbuild-sass-plugin');
|
47
|
+
var import_esbuild_svelte = __toESM(__extractDefault(require('esbuild-svelte')), 1);
|
48
|
+
var import_svelte_preprocess = require('svelte-preprocess');
|
36
49
|
var import_Error = require('../../Error.cjs');
|
37
50
|
var import_ObsidianPluginRepoPaths = require('../../obsidian/Plugin/ObsidianPluginRepoPaths.cjs');
|
38
51
|
var import_Path = require('../../Path.cjs');
|
@@ -45,7 +58,8 @@ var import_copyToObsidianPluginsFolderPlugin = require('./copyToObsidianPluginsF
|
|
45
58
|
var import_fixEsmPlugin = require('./fixEsmPlugin.cjs');
|
46
59
|
var import_fixSourceMapsPlugin = require('./fixSourceMapsPlugin.cjs');
|
47
60
|
var import_preprocessPlugin = require('./preprocessPlugin.cjs');
|
48
|
-
var
|
61
|
+
var import_renameCssPlugin = require('./renameCssPlugin.cjs');
|
62
|
+
const esbuildSvelte = import_esbuild_svelte.default;
|
49
63
|
var BuildMode = /* @__PURE__ */ ((BuildMode2) => {
|
50
64
|
BuildMode2[BuildMode2["Development"] = 0] = "Development";
|
51
65
|
BuildMode2[BuildMode2["Production"] = 1] = "Production";
|
@@ -57,7 +71,7 @@ if you want to view the source, please visit the github repository of this plugi
|
|
57
71
|
*/
|
58
72
|
`;
|
59
73
|
async function buildObsidianPlugin(options) {
|
60
|
-
await (0, import_build.
|
74
|
+
await (0, import_build.buildCompile)();
|
61
75
|
(0, import_dotenv.config)();
|
62
76
|
const obsidianPluginBuilderEnv = import_NodeModules.process.env;
|
63
77
|
const {
|
@@ -76,8 +90,7 @@ async function buildObsidianPlugin(options) {
|
|
76
90
|
}
|
77
91
|
await (0, import_NodeModules.mkdir)(distDir, { recursive: true });
|
78
92
|
const distFileNames = [
|
79
|
-
import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson
|
80
|
-
import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.StylesCss
|
93
|
+
import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.ManifestJson
|
81
94
|
];
|
82
95
|
if (!isProductionBuild) {
|
83
96
|
await (0, import_NodeModules.writeFile)((0, import_Path.join)(distDir, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.HotReload), "", "utf-8");
|
@@ -100,6 +113,7 @@ async function buildObsidianPlugin(options) {
|
|
100
113
|
js: banner
|
101
114
|
},
|
102
115
|
bundle: true,
|
116
|
+
conditions: ["browser"],
|
103
117
|
entryPoints: [
|
104
118
|
(0, import_Root.resolvePathFromRoot)((0, import_Path.join)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.Src, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.MainTs)) ?? (0, import_Error.throwExpression)(new Error("Could not determine the entry point for the plugin"))
|
105
119
|
],
|
@@ -127,8 +141,21 @@ async function buildObsidianPlugin(options) {
|
|
127
141
|
outfile: distPath,
|
128
142
|
platform: "node",
|
129
143
|
plugins: [
|
144
|
+
esbuildSvelte({
|
145
|
+
compilerOptions: {
|
146
|
+
css: "injected",
|
147
|
+
dev: !isProductionBuild
|
148
|
+
},
|
149
|
+
moduleCompilerOptions: {
|
150
|
+
dev: !isProductionBuild
|
151
|
+
},
|
152
|
+
preprocess: (0, import_svelte_preprocess.sveltePreprocess)()
|
153
|
+
}),
|
154
|
+
(0, import_esbuild_sass_plugin.sassPlugin)({
|
155
|
+
sourceMap: !isProductionBuild
|
156
|
+
}),
|
157
|
+
(0, import_renameCssPlugin.renameCssPlugin)(distDir),
|
130
158
|
(0, import_preprocessPlugin.preprocessPlugin)(),
|
131
|
-
(0, import_watchCssChangesPlugin.watchCssChangesPlugin)(),
|
132
159
|
(0, import_fixEsmPlugin.fixEsmPlugin)(),
|
133
160
|
(0, import_fixSourceMapsPlugin.fixSourceMapsPlugin)(isProductionBuild, distPath, pluginName),
|
134
161
|
...customEsbuildPlugins,
|
@@ -158,4 +185,4 @@ async function invokeEsbuild(buildContext, isProductionBuild) {
|
|
158
185
|
buildObsidianPlugin,
|
159
186
|
invokeEsbuild
|
160
187
|
});
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/ObsidianPluginBuilder.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation ObsidianPluginBuilder\n * This module provides functionality to build and bundle an Obsidian plugin using esbuild.\n * It includes functions to handle the build process based on different build modes (development or production),\n * and it sets up various esbuild plugins to preprocess, lint, fix source maps, and copy files to the Obsidian plugins folder.\n */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { config } from 'dotenv';\nimport { context } from 'esbuild';\n\nimport { throwExpression } from '../../Error.ts';\nimport { ObsidianPluginRepoPaths } from '../../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../../Path.ts';\nimport { buildValidate } from '../build.ts';\nimport { CliTaskResult } from '../CliUtils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { resolvePathFromRoot } from '../Root.ts';\nimport { copyToObsidianPluginsFolderPlugin } from './copyToObsidianPluginsFolderPlugin.ts';\nimport { fixEsmPlugin } from './fixEsmPlugin.ts';\nimport { fixSourceMapsPlugin } from './fixSourceMapsPlugin.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\nimport { watchCssChangesPlugin } from './watchCssChangesPlugin.ts';\n\n/**\n * Enumeration representing the build modes.\n */\nexport enum BuildMode {\n  /** Development mode for building the plugin */\n  Development,\n  /** Production mode for building the plugin */\n  Production\n}\n\n/**\n * Banner text to be included at the top of the generated files.\n */\nexport const banner = `/*\nTHIS IS A GENERATED/BUNDLED FILE BY ESBUILD\nif you want to view the source, please visit the github repository of this plugin\n*/\n`;\n\n/**\n * Options for building an Obsidian plugin.\n */\nexport interface BuildObsidianPluginOptions {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  customEsbuildPlugins?: Plugin[];\n\n  /**\n   * The build mode, either Development or Production\n   */\n  mode: BuildMode;\n\n  /**\n   * The directory for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_DIR` environment variable.\n   */\n  obsidianConfigDir?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_DIR: string;\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration directory.\n *\n * @param options - The parameters for building the plugin.\n * @returns A promise that resolves to a `TaskResult` indicating the success or failure of the build.\n */\nexport async function buildObsidianPlugin(options: BuildObsidianPluginOptions): Promise<CliTaskResult> {\n  await buildValidate();\n  config();\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const {\n    customEsbuildPlugins = [],\n    mode,\n    obsidianConfigDir: _obsidianConfigDir\n  } = options;\n\n  const obsidianConfigDir = _obsidianConfigDir ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_DIR ?? '';\n  const isProductionBuild = mode === BuildMode.Production;\n\n  const distDir = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);\n  if (!distDir) {\n    throw new Error('Could not determine the dist directory');\n  }\n\n  if (existsSync(distDir)) {\n    await rm(distDir, { recursive: true });\n  }\n  await mkdir(distDir, { recursive: true });\n\n  const distFileNames = [\n    ObsidianPluginRepoPaths.ManifestJson,\n    ObsidianPluginRepoPaths.StylesCss\n  ];\n  if (!isProductionBuild) {\n    await writeFile(join(distDir, ObsidianPluginRepoPaths.HotReload), '', 'utf-8');\n  }\n\n  for (const fileName of distFileNames) {\n    const localFile = resolvePathFromRoot(fileName);\n    if (!localFile) {\n      throw new Error(`Could not determine the local file for ${fileName}`);\n    }\n    const distFile = join(distDir, fileName);\n\n    if (existsSync(localFile)) {\n      await cp(localFile, distFile);\n    }\n  }\n\n  const distPath = join(distDir, ObsidianPluginRepoPaths.MainJs);\n\n  const packageJson = await readPackageJson();\n  const pluginName = packageJson.name ?? '(unknown)';\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    entryPoints: [\n      resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs))\n        ?? throwExpression(new Error('Could not determine the entry point for the plugin'))\n    ],\n    external: [\n      'obsidian',\n      'electron',\n      '@codemirror/autocomplete',\n      '@codemirror/collab',\n      '@codemirror/commands',\n      '@codemirror/language',\n      '@codemirror/lint',\n      '@codemirror/search',\n      '@codemirror/state',\n      '@codemirror/view',\n      '@lezer/common',\n      '@lezer/highlight',\n      '@lezer/lr',\n      'esbuild',\n      'eslint',\n      ...builtinModules\n    ],\n    format: 'cjs',\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      preprocessPlugin(),\n      watchCssChangesPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, distPath, pluginName),\n      ...customEsbuildPlugins,\n      copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName)\n    ],\n    sourcemap: isProductionBuild ? false : 'inline',\n    target: 'esnext',\n    treeShaking: true\n  };\n\n  const buildContext = await context(buildOptions);\n  return await invokeEsbuild(buildContext, isProductionBuild);\n}\n\n/**\n * Invokes the build process with the provided build context.\n *\n * @param buildContext - The build context generated by esbuild.\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @returns A promise that resolves to a `TaskResult` indicating the success or failure of the build.\n */\nexport async function invokeEsbuild(buildContext: BuildContext, isProductionBuild: boolean): Promise<CliTaskResult> {\n  if (isProductionBuild) {\n    const result = await buildContext.rebuild();\n    const isSuccess = result.errors.length === 0 && result.warnings.length === 0;\n    return CliTaskResult.Success(isSuccess);\n  } else {\n    await buildContext.watch();\n    return CliTaskResult.DoNotExit();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAaA,oBAAuB;AACvB,qBAAwB;AAExB,mBAAgC;AAChC,qCAAwC;AACxC,kBAAqB;AACrB,mBAA8B;AAC9B,sBAA8B;AAC9B,yBAQO;AACP,iBAAgC;AAChC,kBAAoC;AACpC,+CAAkD;AAClD,0BAA6B;AAC7B,iCAAoC;AACpC,8BAAiC;AACjC,mCAAsC;AAK/B,IAAK,YAAL,kBAAKA,eAAL;AAEL,EAAAA,sBAAA;AAEA,EAAAA,sBAAA;AAJU,SAAAA;AAAA,GAAA;AAUL,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AAoCtB,eAAsB,oBAAoB,SAA6D;AACrG,YAAM,4BAAc;AACpB,4BAAO;AACP,QAAM,2BAA2B,2BAAQ;AAEzC,QAAM;AAAA,IACJ,uBAAuB,CAAC;AAAA,IACxB;AAAA,IACA,mBAAmB;AAAA,EACrB,IAAI;AAEJ,QAAM,oBAAoB,sBAAsB,yBAAyB,uBAAuB;AAChG,QAAM,oBAAoB,SAAS;AAEnC,QAAM,cAAU,iCAAoB,oBAAoB,uDAAwB,YAAY,uDAAwB,OAAO;AAC3H,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,wCAAwC;AAAA,EAC1D;AAEA,UAAI,+BAAW,OAAO,GAAG;AACvB,cAAM,uBAAG,SAAS,EAAE,WAAW,KAAK,CAAC;AAAA,EACvC;AACA,YAAM,0BAAM,SAAS,EAAE,WAAW,KAAK,CAAC;AAExC,QAAM,gBAAgB;AAAA,IACpB,uDAAwB;AAAA,IACxB,uDAAwB;AAAA,EAC1B;AACA,MAAI,CAAC,mBAAmB;AACtB,cAAM,kCAAU,kBAAK,SAAS,uDAAwB,SAAS,GAAG,IAAI,OAAO;AAAA,EAC/E;AAEA,aAAW,YAAY,eAAe;AACpC,UAAM,gBAAY,iCAAoB,QAAQ;AAC9C,QAAI,CAAC,WAAW;AACd,YAAM,IAAI,MAAM,0CAA0C,QAAQ,EAAE;AAAA,IACtE;AACA,UAAM,eAAW,kBAAK,SAAS,QAAQ;AAEvC,YAAI,+BAAW,SAAS,GAAG;AACzB,gBAAM,uBAAG,WAAW,QAAQ;AAAA,IAC9B;AAAA,EACF;AAEA,QAAM,eAAW,kBAAK,SAAS,uDAAwB,MAAM;AAE7D,QAAM,cAAc,UAAM,4BAAgB;AAC1C,QAAM,aAAa,YAAY,QAAQ;AAEvC,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,aAAa;AAAA,UACX,qCAAoB,kBAAK,uDAAwB,KAAK,uDAAwB,MAAM,CAAC,SAChF,8BAAgB,IAAI,MAAM,oDAAoD,CAAC;AAAA,IACtF;AAAA,IACA,UAAU;AAAA,MACR;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL;AAAA,IACA,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,UAAU;AAAA,IACV,SAAS;AAAA,UACP,0CAAiB;AAAA,UACjB,oDAAsB;AAAA,UACtB,kCAAa;AAAA,UACb,gDAAoB,mBAAmB,UAAU,UAAU;AAAA,MAC3D,GAAG;AAAA,UACH,4EAAkC,mBAAmB,SAAS,mBAAmB,UAAU;AAAA,IAC7F;AAAA,IACA,WAAW,oBAAoB,QAAQ;AAAA,IACvC,QAAQ;AAAA,IACR,aAAa;AAAA,EACf;AAEA,QAAM,eAAe,UAAM,wBAAQ,YAAY;AAC/C,SAAO,MAAM,cAAc,cAAc,iBAAiB;AAC5D;AASA,eAAsB,cAAc,cAA4B,mBAAoD;AAClH,MAAI,mBAAmB;AACrB,UAAM,SAAS,MAAM,aAAa,QAAQ;AAC1C,UAAM,YAAY,OAAO,OAAO,WAAW,KAAK,OAAO,SAAS,WAAW;AAC3E,WAAO,8BAAc,QAAQ,SAAS;AAAA,EACxC,OAAO;AACL,UAAM,aAAa,MAAM;AACzB,WAAO,8BAAc,UAAU;AAAA,EACjC;AACF;",
  "names": ["BuildMode"]
}

|
188
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/scripts/esbuild/ObsidianPluginBuilder.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation ObsidianPluginBuilder\n * This module provides functionality to build and bundle an Obsidian plugin using esbuild.\n * It includes functions to handle the build process based on different build modes (development or production),\n * and it sets up various esbuild plugins to preprocess, lint, fix source maps, and copy files to the Obsidian plugins folder.\n */\n\nimport type {\n  BuildContext,\n  BuildOptions,\n  Plugin\n} from 'esbuild';\n\nimport { config } from 'dotenv';\nimport { context } from 'esbuild';\nimport { sassPlugin } from 'esbuild-sass-plugin';\nimport esbuildSvelte_ from 'esbuild-svelte';\nimport { sveltePreprocess } from 'svelte-preprocess';\n\nimport { throwExpression } from '../../Error.ts';\nimport { ObsidianPluginRepoPaths } from '../../obsidian/Plugin/ObsidianPluginRepoPaths.ts';\nimport { join } from '../../Path.ts';\nimport { buildCompile } from '../build.ts';\nimport { CliTaskResult } from '../CliUtils.ts';\nimport {\n  builtinModules,\n  cp,\n  existsSync,\n  mkdir,\n  process,\n  rm,\n  writeFile\n} from '../NodeModules.ts';\nimport { readPackageJson } from '../Npm.ts';\nimport { resolvePathFromRoot } from '../Root.ts';\nimport { copyToObsidianPluginsFolderPlugin } from './copyToObsidianPluginsFolderPlugin.ts';\nimport { fixEsmPlugin } from './fixEsmPlugin.ts';\nimport { fixSourceMapsPlugin } from './fixSourceMapsPlugin.ts';\nimport { preprocessPlugin } from './preprocessPlugin.ts';\nimport { renameCssPlugin } from './renameCssPlugin.ts';\n\nconst esbuildSvelte = esbuildSvelte_ as unknown as typeof esbuildSvelte_.default;\n\n/**\n * Enumeration representing the build modes.\n */\nexport enum BuildMode {\n  /** Development mode for building the plugin */\n  Development,\n  /** Production mode for building the plugin */\n  Production\n}\n\n/**\n * Banner text to be included at the top of the generated files.\n */\nexport const banner = `/*\nTHIS IS A GENERATED/BUNDLED FILE BY ESBUILD\nif you want to view the source, please visit the github repository of this plugin\n*/\n`;\n\n/**\n * Options for building an Obsidian plugin.\n */\nexport interface BuildObsidianPluginOptions {\n  /**\n   * Custom esbuild plugins to be used during the build process.\n   */\n  customEsbuildPlugins?: Plugin[];\n\n  /**\n   * The build mode, either Development or Production\n   */\n  mode: BuildMode;\n\n  /**\n   * The directory for Obsidian configuration. Defaults to the `OBSIDIAN_CONFIG_DIR` environment variable.\n   */\n  obsidianConfigDir?: string;\n}\n\ninterface ObsidianPluginBuilderEnv {\n  OBSIDIAN_CONFIG_DIR: string;\n}\n\n/**\n * Builds the Obsidian plugin based on the specified mode and configuration directory.\n *\n * @param options - The parameters for building the plugin.\n * @returns A promise that resolves to a `TaskResult` indicating the success or failure of the build.\n */\nexport async function buildObsidianPlugin(options: BuildObsidianPluginOptions): Promise<CliTaskResult> {\n  await buildCompile();\n  config();\n  const obsidianPluginBuilderEnv = process.env as Partial<ObsidianPluginBuilderEnv>;\n\n  const {\n    customEsbuildPlugins = [],\n    mode,\n    obsidianConfigDir: _obsidianConfigDir\n  } = options;\n\n  const obsidianConfigDir = _obsidianConfigDir ?? obsidianPluginBuilderEnv.OBSIDIAN_CONFIG_DIR ?? '';\n  const isProductionBuild = mode === BuildMode.Production;\n\n  const distDir = resolvePathFromRoot(isProductionBuild ? ObsidianPluginRepoPaths.DistBuild : ObsidianPluginRepoPaths.DistDev);\n  if (!distDir) {\n    throw new Error('Could not determine the dist directory');\n  }\n\n  if (existsSync(distDir)) {\n    await rm(distDir, { recursive: true });\n  }\n  await mkdir(distDir, { recursive: true });\n\n  const distFileNames = [\n    ObsidianPluginRepoPaths.ManifestJson\n  ];\n  if (!isProductionBuild) {\n    await writeFile(join(distDir, ObsidianPluginRepoPaths.HotReload), '', 'utf-8');\n  }\n\n  for (const fileName of distFileNames) {\n    const localFile = resolvePathFromRoot(fileName);\n    if (!localFile) {\n      throw new Error(`Could not determine the local file for ${fileName}`);\n    }\n    const distFile = join(distDir, fileName);\n\n    if (existsSync(localFile)) {\n      await cp(localFile, distFile);\n    }\n  }\n\n  const distPath = join(distDir, ObsidianPluginRepoPaths.MainJs);\n\n  const packageJson = await readPackageJson();\n  const pluginName = packageJson.name ?? '(unknown)';\n\n  const buildOptions: BuildOptions = {\n    banner: {\n      js: banner\n    },\n    bundle: true,\n    conditions: ['browser'],\n    entryPoints: [\n      resolvePathFromRoot(join(ObsidianPluginRepoPaths.Src, ObsidianPluginRepoPaths.MainTs))\n        ?? throwExpression(new Error('Could not determine the entry point for the plugin'))\n    ],\n    external: [\n      'obsidian',\n      'electron',\n      '@codemirror/autocomplete',\n      '@codemirror/collab',\n      '@codemirror/commands',\n      '@codemirror/language',\n      '@codemirror/lint',\n      '@codemirror/search',\n      '@codemirror/state',\n      '@codemirror/view',\n      '@lezer/common',\n      '@lezer/highlight',\n      '@lezer/lr',\n      'esbuild',\n      'eslint',\n      ...builtinModules\n    ],\n    format: 'cjs',\n    logLevel: 'info',\n    minify: isProductionBuild,\n    outfile: distPath,\n    platform: 'node',\n    plugins: [\n      esbuildSvelte({\n        compilerOptions: {\n          css: 'injected',\n          dev: !isProductionBuild\n        },\n        moduleCompilerOptions: {\n          dev: !isProductionBuild\n        },\n        preprocess: sveltePreprocess()\n      }),\n      sassPlugin({\n        sourceMap: !isProductionBuild\n      }),\n      renameCssPlugin(distDir),\n      preprocessPlugin(),\n      fixEsmPlugin(),\n      fixSourceMapsPlugin(isProductionBuild, distPath, pluginName),\n      ...customEsbuildPlugins,\n      copyToObsidianPluginsFolderPlugin(isProductionBuild, distDir, obsidianConfigDir, pluginName)\n    ],\n    sourcemap: isProductionBuild ? false : 'inline',\n    target: 'esnext',\n    treeShaking: true\n  };\n\n  const buildContext = await context(buildOptions);\n  return await invokeEsbuild(buildContext, isProductionBuild);\n}\n\n/**\n * Invokes the build process with the provided build context.\n *\n * @param buildContext - The build context generated by esbuild.\n * @param isProductionBuild - A boolean indicating whether the build is a production build.\n * @returns A promise that resolves to a `TaskResult` indicating the success or failure of the build.\n */\nexport async function invokeEsbuild(buildContext: BuildContext, isProductionBuild: boolean): Promise<CliTaskResult> {\n  if (isProductionBuild) {\n    const result = await buildContext.rebuild();\n    const isSuccess = result.errors.length === 0 && result.warnings.length === 0;\n    return CliTaskResult.Success(isSuccess);\n  } else {\n    await buildContext.watch();\n    return CliTaskResult.DoNotExit();\n  }\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAaA,oBAAuB;AACvB,qBAAwB;AACxB,iCAA2B;AAC3B,4BAA2B;AAC3B,+BAAiC;AAEjC,mBAAgC;AAChC,qCAAwC;AACxC,kBAAqB;AACrB,mBAA6B;AAC7B,sBAA8B;AAC9B,yBAQO;AACP,iBAAgC;AAChC,kBAAoC;AACpC,+CAAkD;AAClD,0BAA6B;AAC7B,iCAAoC;AACpC,8BAAiC;AACjC,6BAAgC;AAEhC,MAAM,gBAAgB,sBAAAA;AAKf,IAAK,YAAL,kBAAKC,eAAL;AAEL,EAAAA,sBAAA;AAEA,EAAAA,sBAAA;AAJU,SAAAA;AAAA,GAAA;AAUL,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AAoCtB,eAAsB,oBAAoB,SAA6D;AACrG,YAAM,2BAAa;AACnB,4BAAO;AACP,QAAM,2BAA2B,2BAAQ;AAEzC,QAAM;AAAA,IACJ,uBAAuB,CAAC;AAAA,IACxB;AAAA,IACA,mBAAmB;AAAA,EACrB,IAAI;AAEJ,QAAM,oBAAoB,sBAAsB,yBAAyB,uBAAuB;AAChG,QAAM,oBAAoB,SAAS;AAEnC,QAAM,cAAU,iCAAoB,oBAAoB,uDAAwB,YAAY,uDAAwB,OAAO;AAC3H,MAAI,CAAC,SAAS;AACZ,UAAM,IAAI,MAAM,wCAAwC;AAAA,EAC1D;AAEA,UAAI,+BAAW,OAAO,GAAG;AACvB,cAAM,uBAAG,SAAS,EAAE,WAAW,KAAK,CAAC;AAAA,EACvC;AACA,YAAM,0BAAM,SAAS,EAAE,WAAW,KAAK,CAAC;AAExC,QAAM,gBAAgB;AAAA,IACpB,uDAAwB;AAAA,EAC1B;AACA,MAAI,CAAC,mBAAmB;AACtB,cAAM,kCAAU,kBAAK,SAAS,uDAAwB,SAAS,GAAG,IAAI,OAAO;AAAA,EAC/E;AAEA,aAAW,YAAY,eAAe;AACpC,UAAM,gBAAY,iCAAoB,QAAQ;AAC9C,QAAI,CAAC,WAAW;AACd,YAAM,IAAI,MAAM,0CAA0C,QAAQ,EAAE;AAAA,IACtE;AACA,UAAM,eAAW,kBAAK,SAAS,QAAQ;AAEvC,YAAI,+BAAW,SAAS,GAAG;AACzB,gBAAM,uBAAG,WAAW,QAAQ;AAAA,IAC9B;AAAA,EACF;AAEA,QAAM,eAAW,kBAAK,SAAS,uDAAwB,MAAM;AAE7D,QAAM,cAAc,UAAM,4BAAgB;AAC1C,QAAM,aAAa,YAAY,QAAQ;AAEvC,QAAM,eAA6B;AAAA,IACjC,QAAQ;AAAA,MACN,IAAI;AAAA,IACN;AAAA,IACA,QAAQ;AAAA,IACR,YAAY,CAAC,SAAS;AAAA,IACtB,aAAa;AAAA,UACX,qCAAoB,kBAAK,uDAAwB,KAAK,uDAAwB,MAAM,CAAC,SAChF,8BAAgB,IAAI,MAAM,oDAAoD,CAAC;AAAA,IACtF;AAAA,IACA,UAAU;AAAA,MACR;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL;AAAA,IACA,QAAQ;AAAA,IACR,UAAU;AAAA,IACV,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,UAAU;AAAA,IACV,SAAS;AAAA,MACP,cAAc;AAAA,QACZ,iBAAiB;AAAA,UACf,KAAK;AAAA,UACL,KAAK,CAAC;AAAA,QACR;AAAA,QACA,uBAAuB;AAAA,UACrB,KAAK,CAAC;AAAA,QACR;AAAA,QACA,gBAAY,2CAAiB;AAAA,MAC/B,CAAC;AAAA,UACD,uCAAW;AAAA,QACT,WAAW,CAAC;AAAA,MACd,CAAC;AAAA,UACD,wCAAgB,OAAO;AAAA,UACvB,0CAAiB;AAAA,UACjB,kCAAa;AAAA,UACb,gDAAoB,mBAAmB,UAAU,UAAU;AAAA,MAC3D,GAAG;AAAA,UACH,4EAAkC,mBAAmB,SAAS,mBAAmB,UAAU;AAAA,IAC7F;AAAA,IACA,WAAW,oBAAoB,QAAQ;AAAA,IACvC,QAAQ;AAAA,IACR,aAAa;AAAA,EACf;AAEA,QAAM,eAAe,UAAM,wBAAQ,YAAY;AAC/C,SAAO,MAAM,cAAc,cAAc,iBAAiB;AAC5D;AASA,eAAsB,cAAc,cAA4B,mBAAoD;AAClH,MAAI,mBAAmB;AACrB,UAAM,SAAS,MAAM,aAAa,QAAQ;AAC1C,UAAM,YAAY,OAAO,OAAO,WAAW,KAAK,OAAO,SAAS,WAAW;AAC3E,WAAO,8BAAc,QAAQ,SAAS;AAAA,EACxC,OAAO;AACL,UAAM,aAAa,MAAM;AACzB,WAAO,8BAAc,UAAU;AAAA,EACjC;AACF;",
  "names": ["esbuildSvelte_", "BuildMode"]
}

|
@@ -41,8 +41,8 @@ __export(esbuild_exports, {
|
|
41
41
|
fixEsmPlugin: () => fixEsmPlugin,
|
42
42
|
fixSourceMapsPlugin: () => fixSourceMapsPlugin,
|
43
43
|
preprocessPlugin: () => preprocessPlugin,
|
44
|
-
|
45
|
-
|
44
|
+
renameCssPlugin: () => renameCssPlugin,
|
45
|
+
renameToCjsPlugin: () => renameToCjsPlugin
|
46
46
|
});
|
47
47
|
module.exports = __toCommonJS(esbuild_exports);
|
48
48
|
var copyToObsidianPluginsFolderPlugin = __toESM(__extractDefault(require('./copyToObsidianPluginsFolderPlugin.cjs')), 1);
|
@@ -51,8 +51,8 @@ var fixEsmPlugin = __toESM(__extractDefault(require('./fixEsmPlugin.cjs')), 1);
|
|
51
51
|
var fixSourceMapsPlugin = __toESM(__extractDefault(require('./fixSourceMapsPlugin.cjs')), 1);
|
52
52
|
var ObsidianPluginBuilder = __toESM(__extractDefault(require('./ObsidianPluginBuilder.cjs')), 1);
|
53
53
|
var preprocessPlugin = __toESM(__extractDefault(require('./preprocessPlugin.cjs')), 1);
|
54
|
+
var renameCssPlugin = __toESM(__extractDefault(require('./renameCssPlugin.cjs')), 1);
|
54
55
|
var renameToCjsPlugin = __toESM(__extractDefault(require('./renameToCjsPlugin.cjs')), 1);
|
55
|
-
var watchCssChangesPlugin = __toESM(__extractDefault(require('./watchCssChangesPlugin.cjs')), 1);
|
56
56
|
// Annotate the CommonJS export names for ESM import in node:
|
57
57
|
0 && (module.exports = {
|
58
58
|
Dependency,
|
@@ -61,7 +61,7 @@ var watchCssChangesPlugin = __toESM(__extractDefault(require('./watchCssChangesP
|
|
61
61
|
fixEsmPlugin,
|
62
62
|
fixSourceMapsPlugin,
|
63
63
|
preprocessPlugin,
|
64
|
-
|
65
|
-
|
64
|
+
renameCssPlugin,
|
65
|
+
renameToCjsPlugin
|
66
66
|
});
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
67
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyogVEhJUyBJUyBBIEdFTkVSQVRFRC9CVU5ETEVEIEZJTEUgQlkgQlVJTEQgU0NSSVBUICovXG5cbmV4cG9ydCAqIGFzIGNvcHlUb09ic2lkaWFuUGx1Z2luc0ZvbGRlclBsdWdpbiBmcm9tICcuL2NvcHlUb09ic2lkaWFuUGx1Z2luc0ZvbGRlclBsdWdpbi50cyc7XG5leHBvcnQgKiBhcyBEZXBlbmRlbmN5IGZyb20gJy4vRGVwZW5kZW5jeS50cyc7XG5leHBvcnQgKiBhcyBmaXhFc21QbHVnaW4gZnJvbSAnLi9maXhFc21QbHVnaW4udHMnO1xuZXhwb3J0ICogYXMgZml4U291cmNlTWFwc1BsdWdpbiBmcm9tICcuL2ZpeFNvdXJjZU1hcHNQbHVnaW4udHMnO1xuZXhwb3J0ICogYXMgT2JzaWRpYW5QbHVnaW5CdWlsZGVyIGZyb20gJy4vT2JzaWRpYW5QbHVnaW5CdWlsZGVyLnRzJztcbmV4cG9ydCAqIGFzIHByZXByb2Nlc3NQbHVnaW4gZnJvbSAnLi9wcmVwcm9jZXNzUGx1Z2luLnRzJztcbmV4cG9ydCAqIGFzIHJlbmFtZUNzc1BsdWdpbiBmcm9tICcuL3JlbmFtZUNzc1BsdWdpbi50cyc7XG5leHBvcnQgKiBhcyByZW5hbWVUb0Nqc1BsdWdpbiBmcm9tICcuL3JlbmFtZVRvQ2pzUGx1Z2luLnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUEsd0NBQW1EO0FBQ25ELGlCQUE0QjtBQUM1QixtQkFBOEI7QUFDOUIsMEJBQXFDO0FBQ3JDLDRCQUF1QztBQUN2Qyx1QkFBa0M7QUFDbEMsc0JBQWlDO0FBQ2pDLHdCQUFtQzsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -4,5 +4,5 @@ export * as fixEsmPlugin from './fixEsmPlugin.ts';
|
|
4
4
|
export * as fixSourceMapsPlugin from './fixSourceMapsPlugin.ts';
|
5
5
|
export * as ObsidianPluginBuilder from './ObsidianPluginBuilder.ts';
|
6
6
|
export * as preprocessPlugin from './preprocessPlugin.ts';
|
7
|
+
export * as renameCssPlugin from './renameCssPlugin.ts';
|
7
8
|
export * as renameToCjsPlugin from './renameToCjsPlugin.ts';
|
8
|
-
export * as watchCssChangesPlugin from './watchCssChangesPlugin.ts';
|
@@ -0,0 +1,52 @@
|
|
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 init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
|
7
|
+
|
8
|
+
"use strict";
|
9
|
+
var __defProp = Object.defineProperty;
|
10
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
11
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
12
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
13
|
+
var __export = (target, all) => {
|
14
|
+
for (var name in all)
|
15
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
16
|
+
};
|
17
|
+
var __copyProps = (to, from, except, desc) => {
|
18
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
19
|
+
for (let key of __getOwnPropNames(from))
|
20
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
21
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
22
|
+
}
|
23
|
+
return to;
|
24
|
+
};
|
25
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
26
|
+
var renameCssPlugin_exports = {};
|
27
|
+
__export(renameCssPlugin_exports, {
|
28
|
+
renameCssPlugin: () => renameCssPlugin
|
29
|
+
});
|
30
|
+
module.exports = __toCommonJS(renameCssPlugin_exports);
|
31
|
+
var import_ObsidianPluginRepoPaths = require('../../obsidian/Plugin/ObsidianPluginRepoPaths.cjs');
|
32
|
+
var import_Path = require('../../Path.cjs');
|
33
|
+
var import_NodeModules = require('../NodeModules.cjs');
|
34
|
+
function renameCssPlugin(distDir) {
|
35
|
+
return {
|
36
|
+
name: "rename-css",
|
37
|
+
setup(build) {
|
38
|
+
build.onEnd(async () => {
|
39
|
+
const mainCssPath = (0, import_Path.join)(distDir, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.MainCss);
|
40
|
+
const stylesCssPath = (0, import_Path.join)(distDir, import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.StylesCss);
|
41
|
+
if ((0, import_NodeModules.existsSync)(mainCssPath)) {
|
42
|
+
await (0, import_NodeModules.rename)(mainCssPath, stylesCssPath);
|
43
|
+
}
|
44
|
+
});
|
45
|
+
}
|
46
|
+
};
|
47
|
+
}
|
48
|
+
// Annotate the CommonJS export names for ESM import in node:
|
49
|
+
0 && (module.exports = {
|
50
|
+
renameCssPlugin
|
51
|
+
});
|
52
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC9yZW5hbWVDc3NQbHVnaW4udHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHsgUGx1Z2luIH0gZnJvbSAnZXNidWlsZCc7XG5cbmltcG9ydCB7IE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzIH0gZnJvbSAnLi4vLi4vb2JzaWRpYW4vUGx1Z2luL09ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7IGpvaW4gfSBmcm9tICcuLi8uLi9QYXRoLnRzJztcbmltcG9ydCB7XG4gIGV4aXN0c1N5bmMsXG4gIHJlbmFtZVxufSBmcm9tICcuLi9Ob2RlTW9kdWxlcy50cyc7XG5cbi8qKlxuICogUGx1Z2luIHRoYXQgcmVuYW1lcyB0aGUgQ1NTIGZpbGUgdG8gdGhlIGNvcnJlY3QgbmFtZS5cbiAqXG4gKiBAcGFyYW0gZGlzdERpciAtIFRoZSBkaXJlY3RvcnkgdG8gcmVuYW1lIHRoZSBDU1MgZmlsZSBpbi5cbiAqIEByZXR1cm5zIFRoZSBwbHVnaW4uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW5hbWVDc3NQbHVnaW4oZGlzdERpcjogc3RyaW5nKTogUGx1Z2luIHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAncmVuYW1lLWNzcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uRW5kKGFzeW5jICgpID0+IHtcbiAgICAgICAgY29uc3QgbWFpbkNzc1BhdGggPSBqb2luKGRpc3REaXIsIE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLk1haW5Dc3MpO1xuICAgICAgICBjb25zdCBzdHlsZXNDc3NQYXRoID0gam9pbihkaXN0RGlyLCBPYnNpZGlhblBsdWdpblJlcG9QYXRocy5TdHlsZXNDc3MpO1xuICAgICAgICBpZiAoZXhpc3RzU3luYyhtYWluQ3NzUGF0aCkpIHtcbiAgICAgICAgICBhd2FpdCByZW5hbWUobWFpbkNzc1BhdGgsIHN0eWxlc0Nzc1BhdGgpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLHFDQUF3QztBQUN4QyxrQkFBcUI7QUFDckIseUJBR087QUFRQSxTQUFTLGdCQUFnQixTQUF5QjtBQUN2RCxTQUFPO0FBQUEsSUFDTCxNQUFNO0FBQUEsSUFDTixNQUFNLE9BQWE7QUFDakIsWUFBTSxNQUFNLFlBQVk7QUFDdEIsY0FBTSxrQkFBYyxrQkFBSyxTQUFTLHVEQUF3QixPQUFPO0FBQ2pFLGNBQU0sb0JBQWdCLGtCQUFLLFNBQVMsdURBQXdCLFNBQVM7QUFDckUsZ0JBQUksK0JBQVcsV0FBVyxHQUFHO0FBQzNCLG9CQUFNLDJCQUFPLGFBQWEsYUFBYTtBQUFBLFFBQ3pDO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import type { Plugin } from 'esbuild';
|
2
|
+
/**
|
3
|
+
* Plugin that renames the CSS file to the correct name.
|
4
|
+
*
|
5
|
+
* @param distDir - The directory to rename the CSS file in.
|
6
|
+
* @returns The plugin.
|
7
|
+
*/
|
8
|
+
export declare function renameCssPlugin(distDir: string): Plugin;
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "obsidian-dev-utils",
|
3
|
-
"version": "
|
3
|
+
"version": "17.0.1",
|
4
4
|
"description": "This is the collection of useful functions that you can use for your Obsidian plugin development",
|
5
5
|
"keywords": [
|
6
6
|
"obsidian"
|
@@ -416,14 +416,14 @@
|
|
416
416
|
"package.json"
|
417
417
|
],
|
418
418
|
"scripts": {
|
419
|
-
"build": "npm-run-all build:clean build:
|
419
|
+
"build": "npm-run-all build:clean build:compile build:generate-index build:types build:lib build:generate-exports build:static",
|
420
420
|
"build:clean": "tsx scripts/build-clean.ts",
|
421
|
+
"build:compile": "tsx scripts/cli.ts build:compile",
|
421
422
|
"build:generate-exports": "tsx scripts/build-generate-exports.ts",
|
422
423
|
"build:generate-index": "tsx scripts/build-generate-index.ts",
|
423
424
|
"build:lib": "tsx scripts/build-lib.ts",
|
424
425
|
"build:static": "tsx scripts/cli.ts build:static",
|
425
426
|
"build:types": "tsx scripts/build-types.ts",
|
426
|
-
"build:validate": "tsc --build --force",
|
427
427
|
"format": "tsx scripts/cli.ts format",
|
428
428
|
"format:check": "tsx scripts/cli.ts format:check",
|
429
429
|
"lint": "tsx scripts/lint.ts",
|
@@ -436,9 +436,10 @@
|
|
436
436
|
"@eslint/js": "^9.19.0",
|
437
437
|
"@guardian/eslint-plugin-tsdoc-required": "^0.1.3",
|
438
438
|
"@lezer/common": "^1.2.3",
|
439
|
-
"@stylistic/eslint-plugin": "^
|
439
|
+
"@stylistic/eslint-plugin": "^3.0.0",
|
440
440
|
"@total-typescript/ts-reset": "^0.6.1",
|
441
441
|
"@tsconfig/strictest": "^2.0.5",
|
442
|
+
"@types/babel__core": "^7.20.5",
|
442
443
|
"@types/doctrine": "^0.0.9",
|
443
444
|
"@types/eslint": "^9.6.1",
|
444
445
|
"@types/eslint__js": "^8.42.3",
|
@@ -446,9 +447,10 @@
|
|
446
447
|
"@types/node": "^22.10.10",
|
447
448
|
"@types/parsimmon": "^1.10.9",
|
448
449
|
"@types/path-browserify": "^1.0.3",
|
450
|
+
"@types/pug": "^2.0.10",
|
449
451
|
"@types/shell-quote": "^1.7.5",
|
450
|
-
"@typescript-eslint/eslint-plugin": "^8.
|
451
|
-
"@typescript-eslint/parser": "^8.
|
452
|
+
"@typescript-eslint/eslint-plugin": "^8.22.0",
|
453
|
+
"@typescript-eslint/parser": "^8.22.0",
|
452
454
|
"better-typescript-lib": "^2.10.1",
|
453
455
|
"commander": "^13.1.0",
|
454
456
|
"compare-versions": "^6.1.1",
|
@@ -458,6 +460,8 @@
|
|
458
460
|
"dprint": "^0.48.0",
|
459
461
|
"enhanced-resolve": "^5.18.0",
|
460
462
|
"esbuild": "^0.24.2",
|
463
|
+
"esbuild-sass-plugin": "^3.3.1",
|
464
|
+
"esbuild-svelte": "^0.9.0",
|
461
465
|
"eslint": "^9.19.0",
|
462
466
|
"eslint-import-resolver-typescript": "^3.7.0",
|
463
467
|
"eslint-plugin-import-x": "^4.6.1",
|
@@ -472,16 +476,21 @@
|
|
472
476
|
"monkey-around": "^3.0.0",
|
473
477
|
"npm-run-all": "^4.1.5",
|
474
478
|
"obsidian": "^1.7.2",
|
475
|
-
"obsidian-typings": "^2.
|
479
|
+
"obsidian-typings": "^2.15.0",
|
476
480
|
"path-browserify": "^1.0.1",
|
481
|
+
"postcss": "^8.5.1",
|
482
|
+
"postcss-modules": "^6.0.1",
|
477
483
|
"preact": "^10.25.4",
|
478
484
|
"remark": "^15.0.1",
|
479
485
|
"remark-parse": "^11.0.0",
|
480
486
|
"remark-wiki-link": "^2.0.1",
|
487
|
+
"sass": "^1.83.4",
|
481
488
|
"shell-quote": "^1.8.2",
|
489
|
+
"svelte-check": "^4.1.4",
|
490
|
+
"svelte-preprocess": "^6.0.3",
|
482
491
|
"tsx": "^4.19.2",
|
483
492
|
"type-fest": "^4.33.0",
|
484
493
|
"typescript": "^5.7.3",
|
485
|
-
"typescript-eslint": "^8.
|
494
|
+
"typescript-eslint": "^8.22.0"
|
486
495
|
}
|
487
496
|
}
|
@@ -1,56 +0,0 @@
|
|
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 init(){const globalThisRecord=globalThis;globalThisRecord["__name"]??=name;if(!require.__isPatched){const originalRequire=require;require=Object.assign(id=>requirePatched(id,originalRequire),originalRequire,{__isPatched:true})}const newFuncs={__extractDefault:__name(()=>extractDefault,"__extractDefault"),process:__name(()=>({browser:true,cwd:__name(()=>"/","cwd"),env:{},platform:"android"}),"process")};for(const key of Object.keys(newFuncs)){globalThisRecord[key]??=newFuncs[key]?.()}function name(obj){return obj}__name(name,"name");function extractDefault(module){return module&&module.__esModule&&module.default?module.default:module}__name(extractDefault,"extractDefault");function requirePatched(id,originalRequire){const module=originalRequire(id);if(module){return extractDefault(module)}if(id==="process"||id==="node:process"){console.error(`Module not found: ${id}. Fake process object is returned instead.`);return globalThis.process}console.error(`Module not found: ${id}. Empty object is returned instead.`);return{}}__name(requirePatched,"requirePatched")})()
|
7
|
-
|
8
|
-
"use strict";
|
9
|
-
var __defProp = Object.defineProperty;
|
10
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
11
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
12
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
13
|
-
var __export = (target, all) => {
|
14
|
-
for (var name in all)
|
15
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
16
|
-
};
|
17
|
-
var __copyProps = (to, from, except, desc) => {
|
18
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
19
|
-
for (let key of __getOwnPropNames(from))
|
20
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
21
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
22
|
-
}
|
23
|
-
return to;
|
24
|
-
};
|
25
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
26
|
-
var watchCssChangesPlugin_exports = {};
|
27
|
-
__export(watchCssChangesPlugin_exports, {
|
28
|
-
watchCssChangesPlugin: () => watchCssChangesPlugin
|
29
|
-
});
|
30
|
-
module.exports = __toCommonJS(watchCssChangesPlugin_exports);
|
31
|
-
var import_ObsidianPluginRepoPaths = require('../../obsidian/Plugin/ObsidianPluginRepoPaths.cjs');
|
32
|
-
var import_NodeModules = require('../NodeModules.cjs');
|
33
|
-
var import_Root = require('../Root.cjs');
|
34
|
-
function watchCssChangesPlugin() {
|
35
|
-
const stylesCssPath = (0, import_Root.resolvePathFromRootSafe)(import_ObsidianPluginRepoPaths.ObsidianPluginRepoPaths.StylesCss);
|
36
|
-
const watchFiles = [];
|
37
|
-
if ((0, import_NodeModules.existsSync)(stylesCssPath)) {
|
38
|
-
watchFiles.push(stylesCssPath);
|
39
|
-
}
|
40
|
-
return {
|
41
|
-
name: "watch-css-changes",
|
42
|
-
setup(build) {
|
43
|
-
build.onResolve({ filter: /main\.ts/ }, (args) => {
|
44
|
-
return {
|
45
|
-
path: args.path,
|
46
|
-
watchFiles
|
47
|
-
};
|
48
|
-
});
|
49
|
-
}
|
50
|
-
};
|
51
|
-
}
|
52
|
-
// Annotate the CommonJS export names for ESM import in node:
|
53
|
-
0 && (module.exports = {
|
54
|
-
watchCssChangesPlugin
|
55
|
-
});
|
56
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL3NjcmlwdHMvZXNidWlsZC93YXRjaENzc0NoYW5nZXNQbHVnaW4udHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB0eXBlIHtcbiAgT25SZXNvbHZlUmVzdWx0LFxuICBQbHVnaW5cbn0gZnJvbSAnZXNidWlsZCc7XG5cbmltcG9ydCB7IE9ic2lkaWFuUGx1Z2luUmVwb1BhdGhzIH0gZnJvbSAnLi4vLi4vb2JzaWRpYW4vUGx1Z2luL09ic2lkaWFuUGx1Z2luUmVwb1BhdGhzLnRzJztcbmltcG9ydCB7IGV4aXN0c1N5bmMgfSBmcm9tICcuLi9Ob2RlTW9kdWxlcy50cyc7XG5pbXBvcnQgeyByZXNvbHZlUGF0aEZyb21Sb290U2FmZSB9IGZyb20gJy4uL1Jvb3QudHMnO1xuXG4vKipcbiAqIEByZXR1cm5zIEEgcGx1Z2luIHRoYXQgd2F0Y2hlcyBmb3IgY2hhbmdlcyB0byBDU1MgZmlsZXMgYW5kIHJlYnVpbGRzIHRoZSBwbHVnaW4gd2hlbiB0aGV5IGNoYW5nZS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHdhdGNoQ3NzQ2hhbmdlc1BsdWdpbigpOiBQbHVnaW4ge1xuICBjb25zdCBzdHlsZXNDc3NQYXRoID0gcmVzb2x2ZVBhdGhGcm9tUm9vdFNhZmUoT2JzaWRpYW5QbHVnaW5SZXBvUGF0aHMuU3R5bGVzQ3NzKTtcbiAgY29uc3Qgd2F0Y2hGaWxlczogc3RyaW5nW10gPSBbXTtcbiAgaWYgKGV4aXN0c1N5bmMoc3R5bGVzQ3NzUGF0aCkpIHtcbiAgICB3YXRjaEZpbGVzLnB1c2goc3R5bGVzQ3NzUGF0aCk7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIG5hbWU6ICd3YXRjaC1jc3MtY2hhbmdlcycsXG4gICAgc2V0dXAoYnVpbGQpOiB2b2lkIHtcbiAgICAgIGJ1aWxkLm9uUmVzb2x2ZSh7IGZpbHRlcjogL21haW5cXC50cy8gfSwgKGFyZ3MpOiBPblJlc29sdmVSZXN1bHQgPT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHBhdGg6IGFyZ3MucGF0aCxcbiAgICAgICAgICB3YXRjaEZpbGVzXG4gICAgICAgIH07XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUtBLHFDQUF3QztBQUN4Qyx5QkFBMkI7QUFDM0Isa0JBQXdDO0FBS2pDLFNBQVMsd0JBQWdDO0FBQzlDLFFBQU0sb0JBQWdCLHFDQUF3Qix1REFBd0IsU0FBUztBQUMvRSxRQUFNLGFBQXVCLENBQUM7QUFDOUIsVUFBSSwrQkFBVyxhQUFhLEdBQUc7QUFDN0IsZUFBVyxLQUFLLGFBQWE7QUFBQSxFQUMvQjtBQUVBLFNBQU87QUFBQSxJQUNMLE1BQU07QUFBQSxJQUNOLE1BQU0sT0FBYTtBQUNqQixZQUFNLFVBQVUsRUFBRSxRQUFRLFdBQVcsR0FBRyxDQUFDLFNBQTBCO0FBQ2pFLGVBQU87QUFBQSxVQUNMLE1BQU0sS0FBSztBQUFBLFVBQ1g7QUFBQSxRQUNGO0FBQUEsTUFDRixDQUFDO0FBQUEsSUFDSDtBQUFBLEVBQ0Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|