obsidian-dev-utils 58.0.1 → 59.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +4 -0
- package/dist/lib/cjs/library.cjs +1 -1
- package/dist/lib/cjs/obsidian/command-handlers/command-handler-component.cjs +9 -10
- package/dist/lib/cjs/obsidian/command-handlers/command-handler-component.d.cts +8 -4
- package/dist/lib/cjs/obsidian/command-handlers/open-settings-command-handler.cjs +7 -8
- package/dist/lib/cjs/obsidian/command-handlers/open-settings-command-handler.d.cts +8 -4
- package/dist/lib/cjs/obsidian/components/setting-components/checkbox-component.cjs +2 -2
- package/dist/lib/cjs/obsidian/markdown.cjs +21 -13
- package/dist/lib/cjs/obsidian/modals/alert.cjs +11 -14
- package/dist/lib/cjs/obsidian/modals/alert.d.cts +3 -11
- package/dist/lib/cjs/obsidian/modals/confirm.cjs +14 -16
- package/dist/lib/cjs/obsidian/modals/modal.cjs +13 -9
- package/dist/lib/cjs/obsidian/modals/modal.d.cts +15 -8
- package/dist/lib/cjs/obsidian/modals/prompt.cjs +17 -18
- package/dist/lib/cjs/obsidian/plugin/components/plugin-context-component.cjs +11 -12
- package/dist/lib/cjs/obsidian/plugin/components/plugin-context-component.d.cts +9 -5
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-component.cjs +1 -1
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-component.d.cts +3 -3
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-tab-component.cjs +17 -10
- package/dist/lib/cjs/obsidian/plugin/components/plugin-settings-tab-component.d.cts +8 -4
- package/dist/lib/cjs/obsidian/plugin/plugin-context.cjs +9 -3
- package/dist/lib/cjs/obsidian/plugin/plugin-context.d.cts +1 -1
- package/dist/lib/cjs/obsidian/plugin/plugin-settings-tab.cjs +2 -2
- package/dist/lib/cjs/obsidian/plugin/plugin.cjs +2 -2
- package/dist/lib/esm/library.mjs +1 -1
- package/dist/lib/esm/obsidian/command-handlers/command-handler-component.d.mts +8 -4
- package/dist/lib/esm/obsidian/command-handlers/command-handler-component.mjs +9 -10
- package/dist/lib/esm/obsidian/command-handlers/open-settings-command-handler.d.mts +8 -4
- package/dist/lib/esm/obsidian/command-handlers/open-settings-command-handler.mjs +7 -8
- package/dist/lib/esm/obsidian/components/setting-components/checkbox-component.mjs +2 -2
- package/dist/lib/esm/obsidian/markdown.mjs +21 -13
- package/dist/lib/esm/obsidian/modals/alert.d.mts +3 -11
- package/dist/lib/esm/obsidian/modals/alert.mjs +12 -14
- package/dist/lib/esm/obsidian/modals/confirm.mjs +15 -16
- package/dist/lib/esm/obsidian/modals/modal.d.mts +15 -8
- package/dist/lib/esm/obsidian/modals/modal.mjs +12 -9
- package/dist/lib/esm/obsidian/modals/prompt.mjs +18 -18
- package/dist/lib/esm/obsidian/plugin/components/plugin-context-component.d.mts +9 -5
- package/dist/lib/esm/obsidian/plugin/components/plugin-context-component.mjs +11 -12
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-component.d.mts +3 -3
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-component.mjs +1 -1
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-tab-component.d.mts +8 -4
- package/dist/lib/esm/obsidian/plugin/components/plugin-settings-tab-component.mjs +17 -10
- package/dist/lib/esm/obsidian/plugin/plugin-context.d.mts +1 -1
- package/dist/lib/esm/obsidian/plugin/plugin-context.mjs +9 -3
- package/dist/lib/esm/obsidian/plugin/plugin-settings-tab.mjs +2 -2
- package/dist/lib/esm/obsidian/plugin/plugin.mjs +2 -2
- package/package.json +1 -1
|
@@ -5,19 +5,11 @@
|
|
|
5
5
|
*
|
|
6
6
|
* This module exports a function to display a modal with a message in Obsidian. The modal includes an "OK" button to close it.
|
|
7
7
|
*/
|
|
8
|
-
import type {
|
|
8
|
+
import type { ModalParamsBase } from './modal.mjs';
|
|
9
9
|
/**
|
|
10
|
-
*
|
|
10
|
+
* Parameters for {@link AlertModal}.
|
|
11
11
|
*/
|
|
12
|
-
export interface AlertParams {
|
|
13
|
-
/**
|
|
14
|
-
* An Obsidian app instance.
|
|
15
|
-
*/
|
|
16
|
-
readonly app: App;
|
|
17
|
-
/**
|
|
18
|
-
* A CSS class to apply to the modal.
|
|
19
|
-
*/
|
|
20
|
-
readonly cssClass?: string;
|
|
12
|
+
export interface AlertParams extends ModalParamsBase {
|
|
21
13
|
/**
|
|
22
14
|
* A message to display in the modal.
|
|
23
15
|
*/
|
|
@@ -25,21 +25,19 @@ import { t } from "i18next";
|
|
|
25
25
|
import { ButtonComponent } from "obsidian";
|
|
26
26
|
import { CssClass } from "../../css-class.mjs";
|
|
27
27
|
import {
|
|
28
|
+
addCssClass,
|
|
28
29
|
ModalBase,
|
|
29
30
|
showModal
|
|
30
31
|
} from "./modal.mjs";
|
|
31
32
|
class AlertModal extends ModalBase {
|
|
32
|
-
|
|
33
|
+
message;
|
|
34
|
+
okButtonText;
|
|
35
|
+
title;
|
|
33
36
|
constructor(params, resolve) {
|
|
34
|
-
super(params,
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
message: params.message,
|
|
39
|
-
okButtonText: t(($) => $.obsidianDevUtils.buttons.ok),
|
|
40
|
-
title: ""
|
|
41
|
-
};
|
|
42
|
-
this.params = { ...DEFAULT_OPTIONS, ...params };
|
|
37
|
+
super(addCssClass(params, CssClass.AlertModal), resolve);
|
|
38
|
+
this.message = params.message;
|
|
39
|
+
this.okButtonText = params.okButtonText ?? t(($) => $.obsidianDevUtils.buttons.ok);
|
|
40
|
+
this.title = params.title ?? "";
|
|
43
41
|
}
|
|
44
42
|
onClose() {
|
|
45
43
|
super.onClose();
|
|
@@ -47,10 +45,10 @@ class AlertModal extends ModalBase {
|
|
|
47
45
|
}
|
|
48
46
|
onOpen() {
|
|
49
47
|
super.onOpen();
|
|
50
|
-
this.titleEl.setText(this.
|
|
51
|
-
this.contentEl.createEl("p", { text: this.
|
|
48
|
+
this.titleEl.setText(this.title);
|
|
49
|
+
this.contentEl.createEl("p", { text: this.message });
|
|
52
50
|
const okButton = new ButtonComponent(this.contentEl);
|
|
53
|
-
okButton.setButtonText(this.
|
|
51
|
+
okButton.setButtonText(this.okButtonText);
|
|
54
52
|
okButton.setCta();
|
|
55
53
|
okButton.onClick(this.close.bind(this));
|
|
56
54
|
okButton.setClass(CssClass.OkButton);
|
|
@@ -62,4 +60,4 @@ async function alert(params) {
|
|
|
62
60
|
export {
|
|
63
61
|
alert
|
|
64
62
|
};
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL21vZGFscy9hbGVydC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIFV0aWxpdHkgZm9yIGRpc3BsYXlpbmcgYWxlcnQgbW9kYWxzIGluIE9ic2lkaWFuLlxuICpcbiAqIFRoaXMgbW9kdWxlIGV4cG9ydHMgYSBmdW5jdGlvbiB0byBkaXNwbGF5IGEgbW9kYWwgd2l0aCBhIG1lc3NhZ2UgaW4gT2JzaWRpYW4uIFRoZSBtb2RhbCBpbmNsdWRlcyBhbiBcIk9LXCIgYnV0dG9uIHRvIGNsb3NlIGl0LlxuICovXG5cbmltcG9ydCB7IHQgfSBmcm9tICdpMThuZXh0JztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHR5cGUgeyBQcm9taXNlUmVzb2x2ZSB9IGZyb20gJy4uLy4uL2FzeW5jLnRzJztcbmltcG9ydCB0eXBlIHsgTW9kYWxQYXJhbXNCYXNlIH0gZnJvbSAnLi9tb2RhbC50cyc7XG5cbmltcG9ydCB7IENzc0NsYXNzIH0gZnJvbSAnLi4vLi4vY3NzLWNsYXNzLnRzJztcbmltcG9ydCB7XG4gIGFkZENzc0NsYXNzLFxuICBNb2RhbEJhc2UsXG4gIHNob3dNb2RhbFxufSBmcm9tICcuL21vZGFsLnRzJztcblxuLyoqXG4gKiBQYXJhbWV0ZXJzIGZvciB7QGxpbmsgQWxlcnRNb2RhbH0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWxlcnRQYXJhbXMgZXh0ZW5kcyBNb2RhbFBhcmFtc0Jhc2Uge1xuICAvKipcbiAgICogQSBtZXNzYWdlIHRvIGRpc3BsYXkgaW4gdGhlIG1vZGFsLlxuICAgKi9cbiAgcmVhZG9ubHkgbWVzc2FnZTogRG9jdW1lbnRGcmFnbWVudCB8IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXh0IGZvciB0aGUgXCJPS1wiIGJ1dHRvbi5cbiAgICovXG4gIHJlYWRvbmx5IG9rQnV0dG9uVGV4dD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0aXRsZSBvZiB0aGUgbW9kYWwuXG4gICAqL1xuICByZWFkb25seSB0aXRsZT86IERvY3VtZW50RnJhZ21lbnQgfCBzdHJpbmc7XG59XG5cbmNsYXNzIEFsZXJ0TW9kYWwgZXh0ZW5kcyBNb2RhbEJhc2U8dm9pZD4ge1xuICBwcml2YXRlIHJlYWRvbmx5IG1lc3NhZ2U6IERvY3VtZW50RnJhZ21lbnQgfCBzdHJpbmc7XG4gIHByaXZhdGUgcmVhZG9ubHkgb2tCdXR0b25UZXh0OiBzdHJpbmc7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGl0bGU6IERvY3VtZW50RnJhZ21lbnQgfCBzdHJpbmc7XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKHBhcmFtczogQWxlcnRQYXJhbXMsIHJlc29sdmU6IFByb21pc2VSZXNvbHZlPHZvaWQ+KSB7XG4gICAgc3VwZXIoYWRkQ3NzQ2xhc3MocGFyYW1zLCBDc3NDbGFzcy5BbGVydE1vZGFsKSwgcmVzb2x2ZSk7XG4gICAgdGhpcy5tZXNzYWdlID0gcGFyYW1zLm1lc3NhZ2U7XG4gICAgdGhpcy5va0J1dHRvblRleHQgPSBwYXJhbXMub2tCdXR0b25UZXh0ID8/IHQoKCQpID0+ICQub2JzaWRpYW5EZXZVdGlscy5idXR0b25zLm9rKTtcbiAgICB0aGlzLnRpdGxlID0gcGFyYW1zLnRpdGxlID8/ICcnO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIG9uQ2xvc2UoKTogdm9pZCB7XG4gICAgc3VwZXIub25DbG9zZSgpO1xuICAgIHRoaXMucmVzb2x2ZSgpO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIG9uT3BlbigpOiB2b2lkIHtcbiAgICBzdXBlci5vbk9wZW4oKTtcbiAgICB0aGlzLnRpdGxlRWwuc2V0VGV4dCh0aGlzLnRpdGxlKTtcbiAgICB0aGlzLmNvbnRlbnRFbC5jcmVhdGVFbCgncCcsIHsgdGV4dDogdGhpcy5tZXNzYWdlIH0pO1xuICAgIGNvbnN0IG9rQnV0dG9uID0gbmV3IEJ1dHRvbkNvbXBvbmVudCh0aGlzLmNvbnRlbnRFbCk7XG4gICAgb2tCdXR0b24uc2V0QnV0dG9uVGV4dCh0aGlzLm9rQnV0dG9uVGV4dCk7XG4gICAgb2tCdXR0b24uc2V0Q3RhKCk7XG4gICAgb2tCdXR0b24ub25DbGljayh0aGlzLmNsb3NlLmJpbmQodGhpcykpO1xuICAgIG9rQnV0dG9uLnNldENsYXNzKENzc0NsYXNzLk9rQnV0dG9uKTtcbiAgfVxufVxuXG4vKipcbiAqIERpc3BsYXlzIGFuIGFsZXJ0IG1vZGFsIGluIE9ic2lkaWFuIHdpdGggYSBzcGVjaWZpZWQgbWVzc2FnZS5cbiAqXG4gKiBAcGFyYW0gcGFyYW1zIC0gVGhlIHBhcmFtZXRlcnMgZm9yIHRoZSBhbGVydCBtb2RhbC5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgbW9kYWwgaXMgY2xvc2VkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYWxlcnQocGFyYW1zOiBBbGVydFBhcmFtcyk6IFByb21pc2U8dm9pZD4ge1xuICBhd2FpdCBzaG93TW9kYWwoKHJlc29sdmUpID0+IG5ldyBBbGVydE1vZGFsKHBhcmFtcywgcmVzb2x2ZSkpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFRQSxTQUFTLFNBQVM7QUFDbEIsU0FBUyx1QkFBdUI7QUFLaEMsU0FBUyxnQkFBZ0I7QUFDekI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBc0JQLE1BQU0sbUJBQW1CLFVBQWdCO0FBQUEsRUFDdEI7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBRVYsWUFBWSxRQUFxQixTQUErQjtBQUNyRSxVQUFNLFlBQVksUUFBUSxTQUFTLFVBQVUsR0FBRyxPQUFPO0FBQ3ZELFNBQUssVUFBVSxPQUFPO0FBQ3RCLFNBQUssZUFBZSxPQUFPLGdCQUFnQixFQUFFLENBQUMsTUFBTSxFQUFFLGlCQUFpQixRQUFRLEVBQUU7QUFDakYsU0FBSyxRQUFRLE9BQU8sU0FBUztBQUFBLEVBQy9CO0FBQUEsRUFFZ0IsVUFBZ0I7QUFDOUIsVUFBTSxRQUFRO0FBQ2QsU0FBSyxRQUFRO0FBQUEsRUFDZjtBQUFBLEVBRWdCLFNBQWU7QUFDN0IsVUFBTSxPQUFPO0FBQ2IsU0FBSyxRQUFRLFFBQVEsS0FBSyxLQUFLO0FBQy9CLFNBQUssVUFBVSxTQUFTLEtBQUssRUFBRSxNQUFNLEtBQUssUUFBUSxDQUFDO0FBQ25ELFVBQU0sV0FBVyxJQUFJLGdCQUFnQixLQUFLLFNBQVM7QUFDbkQsYUFBUyxjQUFjLEtBQUssWUFBWTtBQUN4QyxhQUFTLE9BQU87QUFDaEIsYUFBUyxRQUFRLEtBQUssTUFBTSxLQUFLLElBQUksQ0FBQztBQUN0QyxhQUFTLFNBQVMsU0FBUyxRQUFRO0FBQUEsRUFDckM7QUFDRjtBQVFBLGVBQXNCLE1BQU0sUUFBb0M7QUFDOUQsUUFBTSxVQUFVLENBQUMsWUFBWSxJQUFJLFdBQVcsUUFBUSxPQUFPLENBQUM7QUFDOUQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
@@ -25,23 +25,22 @@ import { ButtonComponent } from "obsidian";
|
|
|
25
25
|
import { CssClass } from "../../css-class.mjs";
|
|
26
26
|
import { t } from "../i18n/i18n.mjs";
|
|
27
27
|
import {
|
|
28
|
+
addCssClass,
|
|
28
29
|
ModalBase,
|
|
29
30
|
showModal
|
|
30
31
|
} from "./modal.mjs";
|
|
31
32
|
class ConfirmModal extends ModalBase {
|
|
33
|
+
cancelButtonText;
|
|
32
34
|
isConfirmed = false;
|
|
33
|
-
|
|
35
|
+
message;
|
|
36
|
+
okButtonText;
|
|
37
|
+
title;
|
|
34
38
|
constructor(params, resolve) {
|
|
35
|
-
super(params,
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
message: params.message,
|
|
41
|
-
okButtonText: t(($) => $.obsidianDevUtils.buttons.ok),
|
|
42
|
-
title: ""
|
|
43
|
-
};
|
|
44
|
-
this.params = { ...DEFAULT_OPTIONS, ...params };
|
|
39
|
+
super(addCssClass(params, CssClass.ConfirmModal), resolve);
|
|
40
|
+
this.cancelButtonText = params.cancelButtonText ?? t(($) => $.obsidianDevUtils.buttons.cancel);
|
|
41
|
+
this.message = params.message;
|
|
42
|
+
this.okButtonText = params.okButtonText ?? t(($) => $.obsidianDevUtils.buttons.ok);
|
|
43
|
+
this.title = params.title ?? "";
|
|
45
44
|
}
|
|
46
45
|
onClose() {
|
|
47
46
|
super.onClose();
|
|
@@ -49,10 +48,10 @@ class ConfirmModal extends ModalBase {
|
|
|
49
48
|
}
|
|
50
49
|
onOpen() {
|
|
51
50
|
super.onOpen();
|
|
52
|
-
this.titleEl.setText(this.
|
|
53
|
-
this.contentEl.createEl("p", { text: this.
|
|
51
|
+
this.titleEl.setText(this.title);
|
|
52
|
+
this.contentEl.createEl("p", { text: this.message });
|
|
54
53
|
const okButton = new ButtonComponent(this.contentEl);
|
|
55
|
-
okButton.setButtonText(this.
|
|
54
|
+
okButton.setButtonText(this.okButtonText);
|
|
56
55
|
okButton.setCta();
|
|
57
56
|
okButton.onClick(() => {
|
|
58
57
|
this.isConfirmed = true;
|
|
@@ -60,7 +59,7 @@ class ConfirmModal extends ModalBase {
|
|
|
60
59
|
});
|
|
61
60
|
okButton.setClass(CssClass.OkButton);
|
|
62
61
|
const cancelButton = new ButtonComponent(this.contentEl);
|
|
63
|
-
cancelButton.setButtonText(this.
|
|
62
|
+
cancelButton.setButtonText(this.cancelButtonText);
|
|
64
63
|
cancelButton.onClick(this.close.bind(this));
|
|
65
64
|
cancelButton.setClass(CssClass.CancelButton);
|
|
66
65
|
}
|
|
@@ -71,4 +70,4 @@ async function confirm(params) {
|
|
|
71
70
|
export {
|
|
72
71
|
confirm
|
|
73
72
|
};
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL21vZGFscy9jb25maXJtLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBmaWxlXG4gKlxuICogVXRpbGl0eSBmb3IgZGlzcGxheWluZyBjb25maXJtIG1vZGFscyBpbiBPYnNpZGlhbi5cbiAqXG4gKiBUaGlzIG1vZHVsZSBleHBvcnRzIGEgZnVuY3Rpb24gdG8gZGlzcGxheSBhIG1vZGFsIHdpdGggYSBtZXNzYWdlIGluIE9ic2lkaWFuLiBUaGUgbW9kYWwgaW5jbHVkZXMgXCJPS1wiIGFuZCBcIkNhbmNlbFwiIGJ1dHRvbnMgdG8gY29uZmlybSBvciBjYW5jZWwgdGhlIGFjdGlvbi5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IEFwcCB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgdHlwZSB7IFByb21pc2VSZXNvbHZlIH0gZnJvbSAnLi4vLi4vYXN5bmMudHMnO1xuXG5pbXBvcnQgeyBDc3NDbGFzcyB9IGZyb20gJy4uLy4uL2Nzcy1jbGFzcy50cyc7XG5pbXBvcnQgeyB0IH0gZnJvbSAnLi4vaTE4bi9pMThuLnRzJztcbmltcG9ydCB7XG4gIGFkZENzc0NsYXNzLFxuICBNb2RhbEJhc2UsXG4gIHNob3dNb2RhbFxufSBmcm9tICcuL21vZGFsLnRzJztcblxuLyoqXG4gKiBPcHRpb25zIGZvciB7QGxpbmsgY29uZmlybX0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlybVBhcmFtcyB7XG4gIC8qKlxuICAgKiBBbiBPYnNpZGlhbiBhcHAgaW5zdGFuY2UuXG4gICAqL1xuICByZWFkb25seSBhcHA6IEFwcDtcblxuICAvKipcbiAgICogQSB0ZXh0IGZvciB0aGUgXCJDYW5jZWxcIiBidXR0b24uXG4gICAqL1xuICByZWFkb25seSBjYW5jZWxCdXR0b25UZXh0Pzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBIENTUyBjbGFzcyB0byBhcHBseSB0byB0aGUgbW9kYWwuXG4gICAqL1xuICByZWFkb25seSBjc3NDbGFzcz86IHN0cmluZztcblxuICAvKipcbiAgICogQSBtZXNzYWdlIHRvIGRpc3BsYXkgaW4gdGhlIG1vZGFsLlxuICAgKi9cbiAgcmVhZG9ubHkgbWVzc2FnZTogRG9jdW1lbnRGcmFnbWVudCB8IHN0cmluZztcblxuICAvKipcbiAgICogQSB0ZXh0IGZvciB0aGUgXCJPS1wiIGJ1dHRvbi5cbiAgICovXG4gIHJlYWRvbmx5IG9rQnV0dG9uVGV4dD86IHN0cmluZztcblxuICAvKipcbiAgICogQSB0aXRsZSBvZiB0aGUgbW9kYWwuXG4gICAqL1xuICByZWFkb25seSB0aXRsZT86IERvY3VtZW50RnJhZ21lbnQgfCBzdHJpbmc7XG59XG5cbmNsYXNzIENvbmZpcm1Nb2RhbCBleHRlbmRzIE1vZGFsQmFzZTxib29sZWFuPiB7XG4gIHByaXZhdGUgcmVhZG9ubHkgY2FuY2VsQnV0dG9uVGV4dDogc3RyaW5nO1xuICBwcml2YXRlIGlzQ29uZmlybWVkID0gZmFsc2U7XG4gIHByaXZhdGUgcmVhZG9ubHkgbWVzc2FnZTogRG9jdW1lbnRGcmFnbWVudCB8IHN0cmluZztcbiAgcHJpdmF0ZSByZWFkb25seSBva0J1dHRvblRleHQ6IHN0cmluZztcbiAgcHJpdmF0ZSByZWFkb25seSB0aXRsZTogRG9jdW1lbnRGcmFnbWVudCB8IHN0cmluZztcblxuICBwdWJsaWMgY29uc3RydWN0b3IocGFyYW1zOiBDb25maXJtUGFyYW1zLCByZXNvbHZlOiBQcm9taXNlUmVzb2x2ZTxib29sZWFuPikge1xuICAgIHN1cGVyKGFkZENzc0NsYXNzKHBhcmFtcywgQ3NzQ2xhc3MuQ29uZmlybU1vZGFsKSwgcmVzb2x2ZSk7XG4gICAgdGhpcy5jYW5jZWxCdXR0b25UZXh0ID0gcGFyYW1zLmNhbmNlbEJ1dHRvblRleHQgPz8gdCgoJCkgPT4gJC5vYnNpZGlhbkRldlV0aWxzLmJ1dHRvbnMuY2FuY2VsKTtcbiAgICB0aGlzLm1lc3NhZ2UgPSBwYXJhbXMubWVzc2FnZTtcbiAgICB0aGlzLm9rQnV0dG9uVGV4dCA9IHBhcmFtcy5va0J1dHRvblRleHQgPz8gdCgoJCkgPT4gJC5vYnNpZGlhbkRldlV0aWxzLmJ1dHRvbnMub2spO1xuICAgIHRoaXMudGl0bGUgPSBwYXJhbXMudGl0bGUgPz8gJyc7XG4gIH1cblxuICBwdWJsaWMgb3ZlcnJpZGUgb25DbG9zZSgpOiB2b2lkIHtcbiAgICBzdXBlci5vbkNsb3NlKCk7XG4gICAgdGhpcy5yZXNvbHZlKHRoaXMuaXNDb25maXJtZWQpO1xuICB9XG5cbiAgcHVibGljIG92ZXJyaWRlIG9uT3BlbigpOiB2b2lkIHtcbiAgICBzdXBlci5vbk9wZW4oKTtcbiAgICB0aGlzLnRpdGxlRWwuc2V0VGV4dCh0aGlzLnRpdGxlKTtcbiAgICB0aGlzLmNvbnRlbnRFbC5jcmVhdGVFbCgncCcsIHsgdGV4dDogdGhpcy5tZXNzYWdlIH0pO1xuICAgIGNvbnN0IG9rQnV0dG9uID0gbmV3IEJ1dHRvbkNvbXBvbmVudCh0aGlzLmNvbnRlbnRFbCk7XG4gICAgb2tCdXR0b24uc2V0QnV0dG9uVGV4dCh0aGlzLm9rQnV0dG9uVGV4dCk7XG4gICAgb2tCdXR0b24uc2V0Q3RhKCk7XG4gICAgb2tCdXR0b24ub25DbGljaygoKSA9PiB7XG4gICAgICB0aGlzLmlzQ29uZmlybWVkID0gdHJ1ZTtcbiAgICAgIHRoaXMuY2xvc2UoKTtcbiAgICB9KTtcbiAgICBva0J1dHRvbi5zZXRDbGFzcyhDc3NDbGFzcy5Pa0J1dHRvbik7XG5cbiAgICBjb25zdCBjYW5jZWxCdXR0b24gPSBuZXcgQnV0dG9uQ29tcG9uZW50KHRoaXMuY29udGVudEVsKTtcbiAgICBjYW5jZWxCdXR0b24uc2V0QnV0dG9uVGV4dCh0aGlzLmNhbmNlbEJ1dHRvblRleHQpO1xuICAgIGNhbmNlbEJ1dHRvbi5vbkNsaWNrKHRoaXMuY2xvc2UuYmluZCh0aGlzKSk7XG4gICAgY2FuY2VsQnV0dG9uLnNldENsYXNzKENzc0NsYXNzLkNhbmNlbEJ1dHRvbik7XG4gIH1cbn1cblxuLyoqXG4gKiBEaXNwbGF5cyBhbiBjb25maXJtIG1vZGFsIGluIE9ic2lkaWFuIHdpdGggYSBzcGVjaWZpZWQgbWVzc2FnZS5cbiAqXG4gKiBAcGFyYW0gcGFyYW1zIC0gVGhlIHBhcmFtZXRlcnMgZm9yIHRoZSBjb25maXJtIG1vZGFsLlxuICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aXRoIGEgYm9vbGVhbiBpbmRpY2F0aW5nIHdoZXRoZXIgdGhlIFwiT0tcIiBidXR0b24gd2FzIGNsaWNrZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjb25maXJtKHBhcmFtczogQ29uZmlybVBhcmFtcyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICByZXR1cm4gYXdhaXQgc2hvd01vZGFsPGJvb2xlYW4+KChyZXNvbHZlKSA9PiBuZXcgQ29uZmlybU1vZGFsKHBhcmFtcywgcmVzb2x2ZSkpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFVQSxTQUFTLHVCQUF1QjtBQUloQyxTQUFTLGdCQUFnQjtBQUN6QixTQUFTLFNBQVM7QUFDbEI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBcUNQLE1BQU0scUJBQXFCLFVBQW1CO0FBQUEsRUFDM0I7QUFBQSxFQUNULGNBQWM7QUFBQSxFQUNMO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUVWLFlBQVksUUFBdUIsU0FBa0M7QUFDMUUsVUFBTSxZQUFZLFFBQVEsU0FBUyxZQUFZLEdBQUcsT0FBTztBQUN6RCxTQUFLLG1CQUFtQixPQUFPLG9CQUFvQixFQUFFLENBQUMsTUFBTSxFQUFFLGlCQUFpQixRQUFRLE1BQU07QUFDN0YsU0FBSyxVQUFVLE9BQU87QUFDdEIsU0FBSyxlQUFlLE9BQU8sZ0JBQWdCLEVBQUUsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLFFBQVEsRUFBRTtBQUNqRixTQUFLLFFBQVEsT0FBTyxTQUFTO0FBQUEsRUFDL0I7QUFBQSxFQUVnQixVQUFnQjtBQUM5QixVQUFNLFFBQVE7QUFDZCxTQUFLLFFBQVEsS0FBSyxXQUFXO0FBQUEsRUFDL0I7QUFBQSxFQUVnQixTQUFlO0FBQzdCLFVBQU0sT0FBTztBQUNiLFNBQUssUUFBUSxRQUFRLEtBQUssS0FBSztBQUMvQixTQUFLLFVBQVUsU0FBUyxLQUFLLEVBQUUsTUFBTSxLQUFLLFFBQVEsQ0FBQztBQUNuRCxVQUFNLFdBQVcsSUFBSSxnQkFBZ0IsS0FBSyxTQUFTO0FBQ25ELGFBQVMsY0FBYyxLQUFLLFlBQVk7QUFDeEMsYUFBUyxPQUFPO0FBQ2hCLGFBQVMsUUFBUSxNQUFNO0FBQ3JCLFdBQUssY0FBYztBQUNuQixXQUFLLE1BQU07QUFBQSxJQUNiLENBQUM7QUFDRCxhQUFTLFNBQVMsU0FBUyxRQUFRO0FBRW5DLFVBQU0sZUFBZSxJQUFJLGdCQUFnQixLQUFLLFNBQVM7QUFDdkQsaUJBQWEsY0FBYyxLQUFLLGdCQUFnQjtBQUNoRCxpQkFBYSxRQUFRLEtBQUssTUFBTSxLQUFLLElBQUksQ0FBQztBQUMxQyxpQkFBYSxTQUFTLFNBQVMsWUFBWTtBQUFBLEVBQzdDO0FBQ0Y7QUFRQSxlQUFzQixRQUFRLFFBQXlDO0FBQ3JFLFNBQU8sTUFBTSxVQUFtQixDQUFDLFlBQVksSUFBSSxhQUFhLFFBQVEsT0FBTyxDQUFDO0FBQ2hGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -13,30 +13,37 @@ export interface ModalParamsBase {
|
|
|
13
13
|
/**
|
|
14
14
|
* An Obsidian app instance.
|
|
15
15
|
*/
|
|
16
|
-
app: App;
|
|
16
|
+
readonly app: App;
|
|
17
17
|
/**
|
|
18
18
|
* A CSS class to apply to the modal.
|
|
19
19
|
*/
|
|
20
|
-
|
|
20
|
+
readonly cssClasses?: string[];
|
|
21
21
|
}
|
|
22
22
|
/**
|
|
23
23
|
* A base class for displaying modals in Obsidian.
|
|
24
24
|
*/
|
|
25
|
-
export declare abstract class ModalBase<Value
|
|
26
|
-
protected resolve: PromiseResolve<Value>;
|
|
25
|
+
export declare abstract class ModalBase<Value> extends Modal {
|
|
26
|
+
protected readonly resolve: PromiseResolve<Value>;
|
|
27
27
|
/**
|
|
28
28
|
* Creates a new modal.
|
|
29
29
|
*
|
|
30
|
-
* @param
|
|
30
|
+
* @param params - The options.
|
|
31
31
|
* @param resolve - The resolve function.
|
|
32
|
-
* @param modalCssClass - The modal CSS class.
|
|
33
32
|
*/
|
|
34
|
-
constructor(
|
|
33
|
+
constructor(params: ModalParamsBase, resolve: PromiseResolve<Value>);
|
|
35
34
|
}
|
|
35
|
+
/**
|
|
36
|
+
* Adds a CSS class to the modal parameters.
|
|
37
|
+
*
|
|
38
|
+
* @param params - The modal parameters.
|
|
39
|
+
* @param cssClass - The CSS class to add.
|
|
40
|
+
* @returns The modal parameters with the CSS class added.
|
|
41
|
+
*/
|
|
42
|
+
export declare function addCssClass(params: ModalParamsBase, cssClass: string): ModalParamsBase;
|
|
36
43
|
/**
|
|
37
44
|
* Displays a modal in Obsidian.
|
|
38
45
|
*
|
|
39
46
|
* @param modalCreator - A function that creates a modal.
|
|
40
47
|
* @returns A {@link Promise} that resolves when the modal is closed.
|
|
41
48
|
*/
|
|
42
|
-
export declare function showModal<
|
|
49
|
+
export declare function showModal<Value>(modalCreator: (resolve: PromiseResolve<Value>) => Modal): Promise<Value>;
|
|
@@ -27,20 +27,22 @@ class ModalBase extends Modal {
|
|
|
27
27
|
/**
|
|
28
28
|
* Creates a new modal.
|
|
29
29
|
*
|
|
30
|
-
* @param
|
|
30
|
+
* @param params - The options.
|
|
31
31
|
* @param resolve - The resolve function.
|
|
32
|
-
* @param modalCssClass - The modal CSS class.
|
|
33
32
|
*/
|
|
34
|
-
constructor(
|
|
35
|
-
super(
|
|
33
|
+
constructor(params, resolve) {
|
|
34
|
+
super(params.app);
|
|
36
35
|
this.resolve = resolve;
|
|
37
|
-
addPluginCssClasses(this.containerEl,
|
|
38
|
-
if (options.cssClass) {
|
|
39
|
-
this.containerEl.addClass(options.cssClass);
|
|
40
|
-
}
|
|
36
|
+
addPluginCssClasses(this.containerEl, params.cssClasses);
|
|
41
37
|
}
|
|
42
38
|
resolve;
|
|
43
39
|
}
|
|
40
|
+
function addCssClass(params, cssClass) {
|
|
41
|
+
return {
|
|
42
|
+
...params,
|
|
43
|
+
cssClasses: [...params.cssClasses ?? [], cssClass]
|
|
44
|
+
};
|
|
45
|
+
}
|
|
44
46
|
async function showModal(modalCreator) {
|
|
45
47
|
return await new Promise((resolve) => {
|
|
46
48
|
const modal = modalCreator(resolve);
|
|
@@ -49,6 +51,7 @@ async function showModal(modalCreator) {
|
|
|
49
51
|
}
|
|
50
52
|
export {
|
|
51
53
|
ModalBase,
|
|
54
|
+
addCssClass,
|
|
52
55
|
showModal
|
|
53
56
|
};
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL21vZGFscy9tb2RhbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIFRoaXMgbW9kdWxlIGV4cG9ydHMgYSBiYXNlIGNsYXNzIGZvciBkaXNwbGF5aW5nIG1vZGFscyBpbiBPYnNpZGlhbi5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7IEFwcCB9IGZyb20gJ29ic2lkaWFuJztcblxuaW1wb3J0IHsgTW9kYWwgfSBmcm9tICdvYnNpZGlhbic7XG5cbmltcG9ydCB0eXBlIHsgUHJvbWlzZVJlc29sdmUgfSBmcm9tICcuLi8uLi9hc3luYy50cyc7XG5cbmltcG9ydCB7IGFkZFBsdWdpbkNzc0NsYXNzZXMgfSBmcm9tICcuLi9wbHVnaW4vcGx1Z2luLWNvbnRleHQudHMnO1xuXG4vKipcbiAqIEJhc2Ugb3B0aW9ucyBmb3IgYSBtb2RhbC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBNb2RhbFBhcmFtc0Jhc2Uge1xuICAvKipcbiAgICogQW4gT2JzaWRpYW4gYXBwIGluc3RhbmNlLlxuICAgKi9cbiAgcmVhZG9ubHkgYXBwOiBBcHA7XG5cbiAgLyoqXG4gICAqIEEgQ1NTIGNsYXNzIHRvIGFwcGx5IHRvIHRoZSBtb2RhbC5cbiAgICovXG4gIHJlYWRvbmx5IGNzc0NsYXNzZXM/OiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBBIGJhc2UgY2xhc3MgZm9yIGRpc3BsYXlpbmcgbW9kYWxzIGluIE9ic2lkaWFuLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTW9kYWxCYXNlPFZhbHVlPiBleHRlbmRzIE1vZGFsIHtcbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgbW9kYWwuXG4gICAqXG4gICAqIEBwYXJhbSBwYXJhbXMgLSBUaGUgb3B0aW9ucy5cbiAgICogQHBhcmFtIHJlc29sdmUgLSBUaGUgcmVzb2x2ZSBmdW5jdGlvbi5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihwYXJhbXM6IE1vZGFsUGFyYW1zQmFzZSwgcHJvdGVjdGVkIHJlYWRvbmx5IHJlc29sdmU6IFByb21pc2VSZXNvbHZlPFZhbHVlPikge1xuICAgIHN1cGVyKHBhcmFtcy5hcHApO1xuICAgIGFkZFBsdWdpbkNzc0NsYXNzZXModGhpcy5jb250YWluZXJFbCwgcGFyYW1zLmNzc0NsYXNzZXMpO1xuICB9XG59XG5cbi8qKlxuICogQWRkcyBhIENTUyBjbGFzcyB0byB0aGUgbW9kYWwgcGFyYW1ldGVycy5cbiAqXG4gKiBAcGFyYW0gcGFyYW1zIC0gVGhlIG1vZGFsIHBhcmFtZXRlcnMuXG4gKiBAcGFyYW0gY3NzQ2xhc3MgLSBUaGUgQ1NTIGNsYXNzIHRvIGFkZC5cbiAqIEByZXR1cm5zIFRoZSBtb2RhbCBwYXJhbWV0ZXJzIHdpdGggdGhlIENTUyBjbGFzcyBhZGRlZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGFkZENzc0NsYXNzKHBhcmFtczogTW9kYWxQYXJhbXNCYXNlLCBjc3NDbGFzczogc3RyaW5nKTogTW9kYWxQYXJhbXNCYXNlIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5wYXJhbXMsXG4gICAgY3NzQ2xhc3NlczogWy4uLihwYXJhbXMuY3NzQ2xhc3NlcyA/PyBbXSksIGNzc0NsYXNzXVxuICB9O1xufVxuXG4vKipcbiAqIERpc3BsYXlzIGEgbW9kYWwgaW4gT2JzaWRpYW4uXG4gKlxuICogQHBhcmFtIG1vZGFsQ3JlYXRvciAtIEEgZnVuY3Rpb24gdGhhdCBjcmVhdGVzIGEgbW9kYWwuXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIG1vZGFsIGlzIGNsb3NlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNob3dNb2RhbDxWYWx1ZT4obW9kYWxDcmVhdG9yOiAocmVzb2x2ZTogUHJvbWlzZVJlc29sdmU8VmFsdWU+KSA9PiBNb2RhbCk6IFByb21pc2U8VmFsdWU+IHtcbiAgcmV0dXJuIGF3YWl0IG5ldyBQcm9taXNlPFZhbHVlPigocmVzb2x2ZSkgPT4ge1xuICAgIGNvbnN0IG1vZGFsID0gbW9kYWxDcmVhdG9yKHJlc29sdmUpO1xuICAgIG1vZGFsLm9wZW4oKTtcbiAgfSk7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFBLFNBQVMsYUFBYTtBQUl0QixTQUFTLDJCQUEyQjtBQW9CN0IsTUFBZSxrQkFBeUIsTUFBTTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBTzVDLFlBQVksUUFBNEMsU0FBZ0M7QUFDN0YsVUFBTSxPQUFPLEdBQUc7QUFENkM7QUFFN0Qsd0JBQW9CLEtBQUssYUFBYSxPQUFPLFVBQVU7QUFBQSxFQUN6RDtBQUFBLEVBSCtEO0FBSWpFO0FBU08sU0FBUyxZQUFZLFFBQXlCLFVBQW1DO0FBQ3RGLFNBQU87QUFBQSxJQUNMLEdBQUc7QUFBQSxJQUNILFlBQVksQ0FBQyxHQUFJLE9BQU8sY0FBYyxDQUFDLEdBQUksUUFBUTtBQUFBLEVBQ3JEO0FBQ0Y7QUFRQSxlQUFzQixVQUFpQixjQUF5RTtBQUM5RyxTQUFPLE1BQU0sSUFBSSxRQUFlLENBQUMsWUFBWTtBQUMzQyxVQUFNLFFBQVEsYUFBYSxPQUFPO0FBQ2xDLFVBQU0sS0FBSztBQUFBLEVBQ2IsQ0FBQztBQUNIOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -33,25 +33,25 @@ import { CssClass } from "../../css-class.mjs";
|
|
|
33
33
|
import { noop } from "../../function.mjs";
|
|
34
34
|
import { t } from "../i18n/i18n.mjs";
|
|
35
35
|
import {
|
|
36
|
+
addCssClass,
|
|
36
37
|
ModalBase,
|
|
37
38
|
showModal
|
|
38
39
|
} from "./modal.mjs";
|
|
39
40
|
class PromptModal extends ModalBase {
|
|
41
|
+
cancelButtonText;
|
|
40
42
|
isOkClicked = false;
|
|
41
|
-
|
|
43
|
+
okButtonText;
|
|
44
|
+
placeholder;
|
|
45
|
+
title;
|
|
42
46
|
value;
|
|
47
|
+
valueValidator;
|
|
43
48
|
constructor(params, resolve) {
|
|
44
|
-
super(params,
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
placeholder: "",
|
|
51
|
-
title: "",
|
|
52
|
-
valueValidator: noop
|
|
53
|
-
};
|
|
54
|
-
this.params = { ...DEFAULT_OPTIONS, ...params };
|
|
49
|
+
super(addCssClass(params, CssClass.PromptModal), resolve);
|
|
50
|
+
this.cancelButtonText = params.cancelButtonText ?? t(($) => $.obsidianDevUtils.buttons.cancel);
|
|
51
|
+
this.okButtonText = params.okButtonText ?? t(($) => $.obsidianDevUtils.buttons.ok);
|
|
52
|
+
this.placeholder = params.placeholder ?? "";
|
|
53
|
+
this.title = params.title ?? "";
|
|
54
|
+
this.valueValidator = params.valueValidator ?? noop;
|
|
55
55
|
this.value = params.defaultValue ?? "";
|
|
56
56
|
}
|
|
57
57
|
onClose() {
|
|
@@ -60,17 +60,17 @@ class PromptModal extends ModalBase {
|
|
|
60
60
|
}
|
|
61
61
|
onOpen() {
|
|
62
62
|
super.onOpen();
|
|
63
|
-
this.titleEl.setText(this.
|
|
63
|
+
this.titleEl.setText(this.title);
|
|
64
64
|
const textComponent = new TextComponent(this.contentEl);
|
|
65
65
|
const inputEl = textComponent.inputEl;
|
|
66
66
|
const validate = async () => {
|
|
67
|
-
const errorMessage = await this.
|
|
67
|
+
const errorMessage = await this.valueValidator(inputEl.value);
|
|
68
68
|
inputEl.setCustomValidity(errorMessage ?? "");
|
|
69
69
|
inputEl.reportValidity();
|
|
70
70
|
};
|
|
71
71
|
textComponent.setValue(this.value);
|
|
72
72
|
textComponent.inputEl.select();
|
|
73
|
-
textComponent.setPlaceholder(this.
|
|
73
|
+
textComponent.setPlaceholder(this.placeholder);
|
|
74
74
|
inputEl.addClass(CssClass.TextBox);
|
|
75
75
|
textComponent.onChange((newValue) => {
|
|
76
76
|
this.value = newValue;
|
|
@@ -86,14 +86,14 @@ class PromptModal extends ModalBase {
|
|
|
86
86
|
inputEl.addEventListener("focus", convertAsyncToSync(validate));
|
|
87
87
|
invokeAsyncSafely(validate);
|
|
88
88
|
const okButton = new ButtonComponent(this.contentEl);
|
|
89
|
-
okButton.setButtonText(this.
|
|
89
|
+
okButton.setButtonText(this.okButtonText);
|
|
90
90
|
okButton.setCta();
|
|
91
91
|
okButton.onClick((event) => {
|
|
92
92
|
this.handleOk(event, textComponent);
|
|
93
93
|
});
|
|
94
94
|
okButton.setClass(CssClass.OkButton);
|
|
95
95
|
const cancelButton = new ButtonComponent(this.contentEl);
|
|
96
|
-
cancelButton.setButtonText(this.
|
|
96
|
+
cancelButton.setButtonText(this.cancelButtonText);
|
|
97
97
|
cancelButton.onClick(this.close.bind(this));
|
|
98
98
|
cancelButton.setClass(CssClass.CancelButton);
|
|
99
99
|
}
|
|
@@ -112,4 +112,4 @@ async function prompt(params) {
|
|
|
112
112
|
export {
|
|
113
113
|
prompt
|
|
114
114
|
};
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/modals/prompt.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Utility for displaying a prompt modal in Obsidian.\n *\n * This module exports a function to display a modal that prompts the user for input. The modal includes \"OK\" and \"Cancel\" buttons.\n */\n\nimport type { App } from 'obsidian';\nimport type { Promisable } from 'type-fest';\n\nimport {\n  ButtonComponent,\n  TextComponent\n} from 'obsidian';\n\nimport type { PromiseResolve } from '../../async.ts';\nimport type { MaybeReturn } from '../../type.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafely\n} from '../../async.ts';\nimport { CssClass } from '../../css-class.ts';\nimport { noop } from '../../function.ts';\nimport { t } from '../i18n/i18n.ts';\nimport {\n  addCssClass,\n  ModalBase,\n  showModal\n} from './modal.ts';\n\n/**\n * Options for {@link prompt}.\n */\nexport interface PromptParams {\n  /**\n   * An Obsidian app instance.\n   */\n  readonly app: App;\n\n  /**\n   * A text for the \"Cancel\" button.\n   */\n  readonly cancelButtonText?: string;\n\n  /**\n   * A default value to pre-fill the input field.\n   */\n  readonly defaultValue?: string;\n\n  /**\n   * A text for the \"OK\" button.\n   */\n  readonly okButtonText?: string;\n\n  /**\n   * A placeholder text for the input field.\n   */\n  readonly placeholder?: string;\n\n  /**\n   * A title of the modal.\n   */\n  readonly title?: DocumentFragment | string;\n\n  /**\n   * A function to validate the input value.\n   *\n   * @param value - The input value to validate.\n   * @returns an error message if the value is invalid, or `null` if the value is valid.\n   */\n  readonly valueValidator?: (value: string) => Promisable<MaybeReturn<string>>;\n}\n\nclass PromptModal extends ModalBase<null | string> {\n  private readonly cancelButtonText: string;\n  private isOkClicked = false;\n  private readonly okButtonText: string;\n  private readonly placeholder: string;\n  private readonly title: DocumentFragment | string;\n  private value: string;\n  private readonly valueValidator: (value: string) => Promisable<MaybeReturn<string>>;\n\n  public constructor(params: PromptParams, resolve: PromiseResolve<null | string>) {\n    super(addCssClass(params, CssClass.PromptModal), resolve);\n    this.cancelButtonText = params.cancelButtonText ?? t(($) => $.obsidianDevUtils.buttons.cancel);\n    this.okButtonText = params.okButtonText ?? t(($) => $.obsidianDevUtils.buttons.ok);\n    this.placeholder = params.placeholder ?? '';\n    this.title = params.title ?? '';\n    this.valueValidator = params.valueValidator ?? noop;\n    this.value = params.defaultValue ?? '';\n  }\n\n  public override onClose(): void {\n    super.onClose();\n    this.resolve(this.isOkClicked ? this.value : null);\n  }\n\n  public override onOpen(): void {\n    super.onOpen();\n    this.titleEl.setText(this.title);\n    const textComponent = new TextComponent(this.contentEl);\n    const inputEl = textComponent.inputEl;\n\n    const validate = async (): Promise<void> => {\n      const errorMessage = await this.valueValidator(inputEl.value) as string | undefined;\n      inputEl.setCustomValidity(errorMessage ?? '');\n      inputEl.reportValidity();\n    };\n\n    textComponent.setValue(this.value);\n    textComponent.inputEl.select();\n    textComponent.setPlaceholder(this.placeholder);\n    inputEl.addClass(CssClass.TextBox);\n    textComponent.onChange((newValue) => {\n      this.value = newValue;\n    });\n    inputEl.addEventListener('keydown', (event: KeyboardEvent) => {\n      if (event.key === 'Enter') {\n        this.handleOk(event, textComponent);\n      } else if (event.key === 'Escape') {\n        this.close();\n      }\n    });\n    inputEl.addEventListener('input', convertAsyncToSync(validate));\n    inputEl.addEventListener('focus', convertAsyncToSync(validate));\n    invokeAsyncSafely(validate);\n    const okButton = new ButtonComponent(this.contentEl);\n    okButton.setButtonText(this.okButtonText);\n    okButton.setCta();\n    okButton.onClick((event) => {\n      this.handleOk(event, textComponent);\n    });\n    okButton.setClass(CssClass.OkButton);\n    const cancelButton = new ButtonComponent(this.contentEl);\n    cancelButton.setButtonText(this.cancelButtonText);\n    cancelButton.onClick(this.close.bind(this));\n    cancelButton.setClass(CssClass.CancelButton);\n  }\n\n  private handleOk(event: Event, textComponent: TextComponent): void {\n    event.preventDefault();\n    if (!textComponent.inputEl.checkValidity()) {\n      return;\n    }\n\n    this.isOkClicked = true;\n    this.close();\n  }\n}\n\n/**\n * Displays a prompt modal in Obsidian to get user input.\n *\n * @param params - The parameters for the prompt modal.\n * @returns A {@link Promise} that resolves with the user input or `null` if the prompt was cancelled.\n */\nexport async function prompt(params: PromptParams): Promise<null | string> {\n  return await showModal<null | string>((resolve) => new PromptModal(params, resolve));\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAWA;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAKP;AAAA,EACE;AAAA,EACA;AAAA,OACK;AACP,SAAS,gBAAgB;AACzB,SAAS,YAAY;AACrB,SAAS,SAAS;AAClB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AA6CP,MAAM,oBAAoB,UAAyB;AAAA,EAChC;AAAA,EACT,cAAc;AAAA,EACL;AAAA,EACA;AAAA,EACA;AAAA,EACT;AAAA,EACS;AAAA,EAEV,YAAY,QAAsB,SAAwC;AAC/E,UAAM,YAAY,QAAQ,SAAS,WAAW,GAAG,OAAO;AACxD,SAAK,mBAAmB,OAAO,oBAAoB,EAAE,CAAC,MAAM,EAAE,iBAAiB,QAAQ,MAAM;AAC7F,SAAK,eAAe,OAAO,gBAAgB,EAAE,CAAC,MAAM,EAAE,iBAAiB,QAAQ,EAAE;AACjF,SAAK,cAAc,OAAO,eAAe;AACzC,SAAK,QAAQ,OAAO,SAAS;AAC7B,SAAK,iBAAiB,OAAO,kBAAkB;AAC/C,SAAK,QAAQ,OAAO,gBAAgB;AAAA,EACtC;AAAA,EAEgB,UAAgB;AAC9B,UAAM,QAAQ;AACd,SAAK,QAAQ,KAAK,cAAc,KAAK,QAAQ,IAAI;AAAA,EACnD;AAAA,EAEgB,SAAe;AAC7B,UAAM,OAAO;AACb,SAAK,QAAQ,QAAQ,KAAK,KAAK;AAC/B,UAAM,gBAAgB,IAAI,cAAc,KAAK,SAAS;AACtD,UAAM,UAAU,cAAc;AAE9B,UAAM,WAAW,YAA2B;AAC1C,YAAM,eAAe,MAAM,KAAK,eAAe,QAAQ,KAAK;AAC5D,cAAQ,kBAAkB,gBAAgB,EAAE;AAC5C,cAAQ,eAAe;AAAA,IACzB;AAEA,kBAAc,SAAS,KAAK,KAAK;AACjC,kBAAc,QAAQ,OAAO;AAC7B,kBAAc,eAAe,KAAK,WAAW;AAC7C,YAAQ,SAAS,SAAS,OAAO;AACjC,kBAAc,SAAS,CAAC,aAAa;AACnC,WAAK,QAAQ;AAAA,IACf,CAAC;AACD,YAAQ,iBAAiB,WAAW,CAAC,UAAyB;AAC5D,UAAI,MAAM,QAAQ,SAAS;AACzB,aAAK,SAAS,OAAO,aAAa;AAAA,MACpC,WAAW,MAAM,QAAQ,UAAU;AACjC,aAAK,MAAM;AAAA,MACb;AAAA,IACF,CAAC;AACD,YAAQ,iBAAiB,SAAS,mBAAmB,QAAQ,CAAC;AAC9D,YAAQ,iBAAiB,SAAS,mBAAmB,QAAQ,CAAC;AAC9D,sBAAkB,QAAQ;AAC1B,UAAM,WAAW,IAAI,gBAAgB,KAAK,SAAS;AACnD,aAAS,cAAc,KAAK,YAAY;AACxC,aAAS,OAAO;AAChB,aAAS,QAAQ,CAAC,UAAU;AAC1B,WAAK,SAAS,OAAO,aAAa;AAAA,IACpC,CAAC;AACD,aAAS,SAAS,SAAS,QAAQ;AACnC,UAAM,eAAe,IAAI,gBAAgB,KAAK,SAAS;AACvD,iBAAa,cAAc,KAAK,gBAAgB;AAChD,iBAAa,QAAQ,KAAK,MAAM,KAAK,IAAI,CAAC;AAC1C,iBAAa,SAAS,SAAS,YAAY;AAAA,EAC7C;AAAA,EAEQ,SAAS,OAAc,eAAoC;AACjE,UAAM,eAAe;AACrB,QAAI,CAAC,cAAc,QAAQ,cAAc,GAAG;AAC1C;AAAA,IACF;AAEA,SAAK,cAAc;AACnB,SAAK,MAAM;AAAA,EACb;AACF;AAQA,eAAsB,OAAO,QAA8C;AACzE,SAAO,MAAM,UAAyB,CAAC,YAAY,IAAI,YAAY,QAAQ,OAAO,CAAC;AACrF;",
  "names": []
}

|
|
@@ -5,25 +5,29 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import type { App } from 'obsidian';
|
|
7
7
|
import { Component } from 'obsidian';
|
|
8
|
+
interface PluginContextComponentConstructorParams {
|
|
9
|
+
readonly app: App;
|
|
10
|
+
readonly pluginId: string;
|
|
11
|
+
}
|
|
8
12
|
/**
|
|
9
13
|
* Initializes plugin context (plugin ID, debug controller, library styles) on load.
|
|
10
14
|
*/
|
|
11
15
|
export declare class PluginContextComponent extends Component {
|
|
12
|
-
private readonly app;
|
|
13
|
-
private readonly pluginId;
|
|
14
16
|
/**
|
|
15
17
|
* The singleton key for the {@link PluginContextComponent} class.
|
|
16
18
|
*/
|
|
17
19
|
static readonly COMPONENT_KEY: unique symbol;
|
|
20
|
+
private readonly app;
|
|
21
|
+
private readonly pluginId;
|
|
18
22
|
/**
|
|
19
23
|
* Creates a new plugin context component.
|
|
20
24
|
*
|
|
21
|
-
* @param
|
|
22
|
-
* @param pluginId - The plugin ID.
|
|
25
|
+
* @param params - The constructor parameters.
|
|
23
26
|
*/
|
|
24
|
-
constructor(
|
|
27
|
+
constructor(params: PluginContextComponentConstructorParams);
|
|
25
28
|
/**
|
|
26
29
|
* Initializes the plugin context and debug controller.
|
|
27
30
|
*/
|
|
28
31
|
onload(): void;
|
|
29
32
|
}
|
|
33
|
+
export {};
|
|
@@ -29,22 +29,21 @@ import {
|
|
|
29
29
|
} from "../plugin-context.mjs";
|
|
30
30
|
class PluginContextComponent extends Component {
|
|
31
31
|
/**
|
|
32
|
-
*
|
|
33
|
-
*
|
|
34
|
-
* @param app - The Obsidian app instance.
|
|
35
|
-
* @param pluginId - The plugin ID.
|
|
32
|
+
* The singleton key for the {@link PluginContextComponent} class.
|
|
36
33
|
*/
|
|
37
|
-
|
|
38
|
-
super();
|
|
39
|
-
this.app = app;
|
|
40
|
-
this.pluginId = pluginId;
|
|
41
|
-
}
|
|
34
|
+
static COMPONENT_KEY = Symbol(PluginContextComponent.name);
|
|
42
35
|
app;
|
|
43
36
|
pluginId;
|
|
44
37
|
/**
|
|
45
|
-
*
|
|
38
|
+
* Creates a new plugin context component.
|
|
39
|
+
*
|
|
40
|
+
* @param params - The constructor parameters.
|
|
46
41
|
*/
|
|
47
|
-
|
|
42
|
+
constructor(params) {
|
|
43
|
+
super();
|
|
44
|
+
this.app = params.app;
|
|
45
|
+
this.pluginId = params.pluginId;
|
|
46
|
+
}
|
|
48
47
|
/**
|
|
49
48
|
* Initializes the plugin context and debug controller.
|
|
50
49
|
*/
|
|
@@ -58,4 +57,4 @@ class PluginContextComponent extends Component {
|
|
|
58
57
|
export {
|
|
59
58
|
PluginContextComponent
|
|
60
59
|
};
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL3BsdWdpbi1jb250ZXh0LWNvbXBvbmVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAZmlsZVxuICpcbiAqIENvbXBvbmVudCB0aGF0IGluaXRpYWxpemVzIHRoZSBwbHVnaW4gY29udGV4dCwgZGVidWcgY29udHJvbGxlciwgYW5kIGxpYnJhcnkgc3R5bGVzLlxuICovXG5cbmltcG9ydCB0eXBlIHsgQXBwIH0gZnJvbSAnb2JzaWRpYW4nO1xuXG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdvYnNpZGlhbic7XG5cbmltcG9ydCB7IEFsbFdpbmRvd3NFdmVudEhhbmRsZXIgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL2FsbC13aW5kb3dzLWV2ZW50LWhhbmRsZXIudHMnO1xuaW1wb3J0IHtcbiAgaW5pdERlYnVnQ29udHJvbGxlcixcbiAgaW5pdFBsdWdpbkNvbnRleHRcbn0gZnJvbSAnLi4vcGx1Z2luLWNvbnRleHQudHMnO1xuXG5pbnRlcmZhY2UgUGx1Z2luQ29udGV4dENvbXBvbmVudENvbnN0cnVjdG9yUGFyYW1zIHtcbiAgcmVhZG9ubHkgYXBwOiBBcHA7XG4gIHJlYWRvbmx5IHBsdWdpbklkOiBzdHJpbmc7XG59XG5cbi8qKlxuICogSW5pdGlhbGl6ZXMgcGx1Z2luIGNvbnRleHQgKHBsdWdpbiBJRCwgZGVidWcgY29udHJvbGxlciwgbGlicmFyeSBzdHlsZXMpIG9uIGxvYWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBQbHVnaW5Db250ZXh0Q29tcG9uZW50IGV4dGVuZHMgQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoZSBzaW5nbGV0b24ga2V5IGZvciB0aGUge0BsaW5rIFBsdWdpbkNvbnRleHRDb21wb25lbnR9IGNsYXNzLlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBDT01QT05FTlRfS0VZID0gU3ltYm9sKFBsdWdpbkNvbnRleHRDb21wb25lbnQubmFtZSk7XG4gIHByaXZhdGUgcmVhZG9ubHkgYXBwOiBBcHA7XG4gIHByaXZhdGUgcmVhZG9ubHkgcGx1Z2luSWQ6IHN0cmluZztcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBwbHVnaW4gY29udGV4dCBjb21wb25lbnQuXG4gICAqXG4gICAqIEBwYXJhbSBwYXJhbXMgLSBUaGUgY29uc3RydWN0b3IgcGFyYW1ldGVycy5cbiAgICovXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcihwYXJhbXM6IFBsdWdpbkNvbnRleHRDb21wb25lbnRDb25zdHJ1Y3RvclBhcmFtcykge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5hcHAgPSBwYXJhbXMuYXBwO1xuICAgIHRoaXMucGx1Z2luSWQgPSBwYXJhbXMucGx1Z2luSWQ7XG4gIH1cblxuICAvKipcbiAgICogSW5pdGlhbGl6ZXMgdGhlIHBsdWdpbiBjb250ZXh0IGFuZCBkZWJ1ZyBjb250cm9sbGVyLlxuICAgKi9cbiAgcHVibGljIG92ZXJyaWRlIG9ubG9hZCgpOiB2b2lkIHtcbiAgICBpbml0UGx1Z2luQ29udGV4dCh0aGlzLmFwcCwgdGhpcy5wbHVnaW5JZCk7XG4gICAgbmV3IEFsbFdpbmRvd3NFdmVudEhhbmRsZXIodGhpcy5hcHAsIHRoaXMpLnJlZ2lzdGVyQWxsV2luZG93c0hhbmRsZXIoKHdpbikgPT4ge1xuICAgICAgaW5pdERlYnVnQ29udHJvbGxlcih3aW4sIHRoaXMpO1xuICAgIH0pO1xuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVFBLFNBQVMsaUJBQWlCO0FBRTFCLFNBQVMsOEJBQThCO0FBQ3ZDO0FBQUEsRUFDRTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBVUEsTUFBTSwrQkFBK0IsVUFBVTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBSXBELE9BQXVCLGdCQUFnQixPQUFPLHVCQUF1QixJQUFJO0FBQUEsRUFDeEQ7QUFBQSxFQUNBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBT1YsWUFBWSxRQUFpRDtBQUNsRSxVQUFNO0FBQ04sU0FBSyxNQUFNLE9BQU87QUFDbEIsU0FBSyxXQUFXLE9BQU87QUFBQSxFQUN6QjtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBS2dCLFNBQWU7QUFDN0Isc0JBQWtCLEtBQUssS0FBSyxLQUFLLFFBQVE7QUFDekMsUUFBSSx1QkFBdUIsS0FBSyxLQUFLLElBQUksRUFBRSwwQkFBMEIsQ0FBQyxRQUFRO0FBQzVFLDBCQUFvQixLQUFLLElBQUk7QUFBQSxJQUMvQixDQUFDO0FBQUEsRUFDSDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -16,7 +16,7 @@ import { AsyncComponentBase } from '../../components/async-component.mjs';
|
|
|
16
16
|
/**
|
|
17
17
|
* Params for creating a {@link PluginSettingsComponentBase}.
|
|
18
18
|
*/
|
|
19
|
-
export interface
|
|
19
|
+
export interface PluginSettingsComponentConstructorParams {
|
|
20
20
|
/**
|
|
21
21
|
* A function to load data from the plugin's data file.
|
|
22
22
|
*
|
|
@@ -115,7 +115,7 @@ export declare abstract class PluginSettingsComponentBase<PluginSettings extends
|
|
|
115
115
|
*
|
|
116
116
|
* @param params - The params for loading/saving data.
|
|
117
117
|
*/
|
|
118
|
-
constructor(params:
|
|
118
|
+
constructor(params: PluginSettingsComponentConstructorParams);
|
|
119
119
|
/**
|
|
120
120
|
* Edits the plugin settings and saves them.
|
|
121
121
|
*
|
|
@@ -287,7 +287,7 @@ export declare class EmptyPluginSettingsComponent extends PluginSettingsComponen
|
|
|
287
287
|
*
|
|
288
288
|
* @param params - The params. Uses no-op load/save by default.
|
|
289
289
|
*/
|
|
290
|
-
constructor(params?:
|
|
290
|
+
constructor(params?: PluginSettingsComponentConstructorParams);
|
|
291
291
|
/**
|
|
292
292
|
* Creates empty default settings.
|
|
293
293
|
*
|