obsidian-dev-utils 57.0.2 → 58.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.
Files changed (29) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/lib/cjs/library.cjs +1 -1
  3. package/dist/lib/cjs/obsidian/components/async-component.cjs +28 -11
  4. package/dist/lib/cjs/obsidian/components/async-component.d.cts +14 -0
  5. package/dist/lib/cjs/obsidian/plugin/components/index.cjs +4 -4
  6. package/dist/lib/cjs/obsidian/plugin/components/index.d.cts +1 -1
  7. package/dist/lib/cjs/obsidian/plugin/components/layout-ready-component.cjs +124 -0
  8. package/dist/lib/cjs/obsidian/plugin/components/layout-ready-component.d.cts +18 -0
  9. package/dist/lib/cjs/obsidian/plugin/plugin.cjs +47 -81
  10. package/dist/lib/cjs/obsidian/plugin/plugin.d.cts +13 -51
  11. package/dist/lib/cjs/strict-proxy.cjs +15 -4
  12. package/dist/lib/cjs/strict-proxy.d.cts +12 -0
  13. package/dist/lib/esm/library.mjs +1 -1
  14. package/dist/lib/esm/obsidian/components/async-component.d.mts +14 -0
  15. package/dist/lib/esm/obsidian/components/async-component.mjs +25 -10
  16. package/dist/lib/esm/obsidian/plugin/components/index.d.mts +1 -1
  17. package/dist/lib/esm/obsidian/plugin/components/index.mjs +3 -3
  18. package/dist/lib/esm/obsidian/plugin/components/layout-ready-component.d.mts +18 -0
  19. package/dist/lib/esm/obsidian/plugin/components/layout-ready-component.mjs +24 -0
  20. package/dist/lib/esm/obsidian/plugin/plugin.d.mts +13 -51
  21. package/dist/lib/esm/obsidian/plugin/plugin.mjs +48 -85
  22. package/dist/lib/esm/strict-proxy.d.mts +12 -0
  23. package/dist/lib/esm/strict-proxy.mjs +14 -4
  24. package/obsidian/Plugin/components/{lifecycle-events-component → layout-ready-component}/package.json +3 -3
  25. package/package.json +3 -3
  26. package/dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.cjs +0 -211
  27. package/dist/lib/cjs/obsidian/plugin/components/lifecycle-events-component.d.cts +0 -63
  28. package/dist/lib/esm/obsidian/plugin/components/lifecycle-events-component.d.mts +0 -63
  29. package/dist/lib/esm/obsidian/plugin/components/lifecycle-events-component.mjs +0 -106
package/CHANGELOG.md CHANGED
@@ -1,5 +1,10 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## 58.0.0
4
+
5
+ - chore: update libs
6
+ - refactor!: simplify PluginBase to IoC container with children-first loading
7
+
3
8
  ## 57.0.2
4
9
 
5
10
  - chore: lint
@@ -130,7 +130,7 @@ __export(library_exports, {
130
130
  LIBRARY_VERSION: () => LIBRARY_VERSION
131
131
  });
132
132
  module.exports = __toCommonJS(library_exports);
133
- const LIBRARY_VERSION = "57.0.2";
133
+ const LIBRARY_VERSION = "58.0.0";
134
134
  const LIBRARY_NAME = "obsidian-dev-utils";
135
135
  const LIBRARY_STYLES = ".obsidian-dev-utils.code-highlighter-component textarea, .obsidian-dev-utils.code-highlighter-component pre, .obsidian-dev-utils.code-highlighter-component code {\n font-family: var(--font-monospace);\n line-height: var(--line-height-normal);\n margin: 0;\n}\n.obsidian-dev-utils.code-highlighter-component textarea, .obsidian-dev-utils.code-highlighter-component code {\n font-size: var(--code-size);\n}\n.obsidian-dev-utils.code-highlighter-component textarea {\n background: transparent;\n color: transparent;\n z-index: 2;\n width: 20em;\n height: 10em;\n}\n.obsidian-dev-utils.code-highlighter-component pre {\n position: absolute;\n pointer-events: none;\n border: var(--input-border-width) solid transparent;\n overflow: auto;\n inset: 0;\n padding: var(--size-4-1) var(--size-4-2);\n z-index: 1;\n}\n.obsidian-dev-utils.code-highlighter-component pre::after {\n content: \"\";\n display: block;\n height: var(--bottom-gap, 0);\n}\n.obsidian-dev-utils.code-highlighter-component pre.is-placeholder {\n opacity: 0.6;\n}\n.obsidian-dev-utils.code-highlighter-component code {\n display: block;\n padding: 0;\n}\n\n.obsidian-dev-utils input[type=url] {\n height: var(--input-height);\n}\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=tel],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=url],\n.obsidian-dev-utils input[type=week] {\n -webkit-app-region: no-drag;\n background: var(--background-modifier-form-field);\n border: var(--input-border-width) solid var(--background-modifier-border);\n color: var(--text-normal);\n font-family: inherit;\n padding: var(--size-4-1) var(--size-4-2);\n font-size: var(--font-ui-small);\n border-radius: var(--input-radius);\n outline: none;\n}\n@media (hover: hover) {\n .obsidian-dev-utils input[type=month]:hover,\n .obsidian-dev-utils input[type=tel]:hover,\n .obsidian-dev-utils input[type=time]:hover,\n .obsidian-dev-utils input[type=url]:hover,\n .obsidian-dev-utils input[type=week]:hover {\n border-color: var(--background-modifier-border-hover);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n }\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus,\n.obsidian-dev-utils input[type=tel]:active,\n.obsidian-dev-utils input[type=tel]:focus,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus {\n border-color: var(--background-modifier-border-focus);\n transition: box-shadow 0.15s ease-in-out, border 0.15s ease-in-out;\n}\n.obsidian-dev-utils input[type=month]:active, .obsidian-dev-utils input[type=month]:focus, .obsidian-dev-utils input[type=month]:focus-visible,\n.obsidian-dev-utils input[type=tel]:active,\n.obsidian-dev-utils input[type=tel]:focus,\n.obsidian-dev-utils input[type=tel]:focus-visible,\n.obsidian-dev-utils input[type=time]:active,\n.obsidian-dev-utils input[type=time]:focus,\n.obsidian-dev-utils input[type=time]:focus-visible,\n.obsidian-dev-utils input[type=url]:active,\n.obsidian-dev-utils input[type=url]:focus,\n.obsidian-dev-utils input[type=url]:focus-visible,\n.obsidian-dev-utils input[type=week]:active,\n.obsidian-dev-utils input[type=week]:focus,\n.obsidian-dev-utils input[type=week]:focus-visible {\n box-shadow: 0 0 0 2px var(--background-modifier-border-focus);\n}\n.obsidian-dev-utils input[type=month]::placeholder,\n.obsidian-dev-utils input[type=tel]::placeholder,\n.obsidian-dev-utils input[type=time]::placeholder,\n.obsidian-dev-utils input[type=url]::placeholder,\n.obsidian-dev-utils input[type=week]::placeholder {\n color: var(--text-faint);\n}\n.mod-rtl input[type=month],\n.mod-rtl input[type=time],\n.mod-rtl input[type=week],\n.is-rtl input[type=month],\n.is-rtl input[type=time],\n.is-rtl input[type=week],\n.rtl input[type=month],\n.rtl input[type=time],\n.rtl input[type=week] {\n direction: rtl;\n}\n.mod-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=month]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl input[type=week]::-webkit-calendar-picker-indicator,\n.rtl input[type=month]::-webkit-calendar-picker-indicator,\n.rtl input[type=time]::-webkit-calendar-picker-indicator,\n.rtl input[type=week]::-webkit-calendar-picker-indicator {\n right: var(--size-4-1);\n left: auto;\n}\n\n.obsidian-dev-utils input[type=month],\n.obsidian-dev-utils input[type=time],\n.obsidian-dev-utils input[type=week] {\n font-variant-numeric: tabular-nums;\n position: relative;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-text,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-text {\n color: var(--text-faint);\n padding-inline-end: 0;\n}\n.obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n position: absolute;\n left: var(--size-4-1);\n right: auto;\n opacity: 0.5;\n}\n.obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-month-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-day-field:focus, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:active, .obsidian-dev-utils input[type=month]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=time]::-webkit-datetime-edit-year-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-month-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-day-field:focus,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:active,\n.obsidian-dev-utils input[type=week]::-webkit-datetime-edit-year-field:focus {\n background-color: var(--text-selection);\n color: var(--text-normal);\n cursor: text;\n}\n.mod-rtl .obsidian-dev-utils input[type=month], .is-rtl .obsidian-dev-utils input[type=month], .rtl .obsidian-dev-utils input[type=month],\n.mod-rtl .obsidian-dev-utils input[type=time],\n.is-rtl .obsidian-dev-utils input[type=time],\n.rtl .obsidian-dev-utils input[type=time],\n.mod-rtl .obsidian-dev-utils input[type=week],\n.is-rtl .obsidian-dev-utils input[type=week],\n.rtl .obsidian-dev-utils input[type=week] {\n direction: rtl;\n}\n.mod-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .is-rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator, .rtl .obsidian-dev-utils input[type=month]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator,\n.mod-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.is-rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator,\n.rtl .obsidian-dev-utils input[type=week]::-webkit-calendar-picker-indicator {\n left: auto;\n right: var(--size-4-1);\n}\n\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=month],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=time],\nbody:not(.is-ios):not(.is-android) .obsidian-dev-utils input[type=week] {\n padding-inline-start: var(--size-4-6);\n}\n\n.obsidian-dev-utils input[type=time]::-webkit-calendar-picker-indicator {\n margin-inline-start: 0;\n}\n\n.obsidian-dev-utilsprogress.loop {\n min-width: 200px;\n}\n\n.obsidian-dev-utils.modal-container .ok-button {\n margin-right: 10px;\n margin-top: 20px;\n}\n\n.obsidian-dev-utils .multiple-dropdown-component select,\n.obsidian-dev-utils .multiple-dropdown-component select:focus,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown {\n height: auto;\n padding-top: 3px;\n}\n.obsidian-dev-utils .multiple-dropdown-component select option:checked,\n.obsidian-dev-utils .multiple-dropdown-component select:focus option:checked,\n.obsidian-dev-utils .multiple-dropdown-component .dropdown option:checked {\n background-color: #1967d2;\n color: #fff;\n}\n\n.obsidian-dev-utils.plugin-settings-tab a:focus {\n outline: 2px solid var(--link-color);\n}\n\n.obsidian-dev-utils.prompt-modal .text-box {\n width: 100%;\n}\n\n.obsidian-dev-utils.tri-state-checkbox-component input[type=checkbox]:indeterminate {\n appearance: checkbox;\n}\n\n.obsidian-dev-utils :invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n.obsidian-dev-utils input.metadata-input-text:active:invalid, .obsidian-dev-utils input.metadata-input-text:focus-visible:invalid, .obsidian-dev-utils input.metadata-input-text:focus:invalid,\n.obsidian-dev-utils input[type=date]:active:invalid,\n.obsidian-dev-utils input[type=date]:focus-visible:invalid,\n.obsidian-dev-utils input[type=date]:focus:invalid,\n.obsidian-dev-utils input[type=datetime-local]:active:invalid,\n.obsidian-dev-utils input[type=datetime-local]:focus-visible:invalid,\n.obsidian-dev-utils input[type=datetime-local]:focus:invalid,\n.obsidian-dev-utils input[type=email]:active:invalid,\n.obsidian-dev-utils input[type=email]:focus-visible:invalid,\n.obsidian-dev-utils input[type=email]:focus:invalid,\n.obsidian-dev-utils input[type=number]:active:invalid,\n.obsidian-dev-utils input[type=number]:focus-visible:invalid,\n.obsidian-dev-utils input[type=number]:focus:invalid,\n.obsidian-dev-utils input[type=password]:active:invalid,\n.obsidian-dev-utils input[type=password]:focus-visible:invalid,\n.obsidian-dev-utils input[type=password]:focus:invalid,\n.obsidian-dev-utils input[type=search]:active:invalid,\n.obsidian-dev-utils input[type=search]:focus-visible:invalid,\n.obsidian-dev-utils input[type=search]:focus:invalid,\n.obsidian-dev-utils input[type=text]:active:invalid,\n.obsidian-dev-utils input[type=text]:focus-visible:invalid,\n.obsidian-dev-utils input[type=text]:focus:invalid,\n.obsidian-dev-utils textarea:active:invalid,\n.obsidian-dev-utils textarea:focus-visible:invalid,\n.obsidian-dev-utils textarea:focus:invalid {\n box-shadow: 0 0 0 2px var(--text-error);\n}\n.obsidian-dev-utils.setting-component-wrapper {\n position: relative;\n display: inline-flex;\n}\n.obsidian-dev-utils.overlay-validator {\n caret-color: transparent;\n cursor: default;\n position: absolute;\n background-color: transparent;\n border: none;\n outline: none;\n pointer-events: none;\n z-index: 9999;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n}\n.obsidian-dev-utils.tooltip.tooltip-validator {\n position: absolute;\n top: calc(100% + 8px);\n width: max-content;\n}\n\n/*# sourceMappingURL=data:application/json;charset=utf-8,%7B%22version%22:3,%22sourceRoot%22:%22%22,%22sources%22:%5B%22../src/styles/code-highlighter-component.scss%22,%22../src/styles/input.scss%22,%22../src/styles/input-time.scss%22,%22../src/styles/loop.scss%22,%22../src/styles/modal-container.scss%22,%22../src/styles/multiple-dropdown-component.scss%22,%22../src/styles/plugin-settings-tab.scss%22,%22../src/styles/prompt-modal.scss%22,%22../src/styles/tri-state-checkbox-component.scss%22,%22../src/styles/validation.scss%22%5D,%22names%22:%5B%5D,%22mappings%22:%22AAEI;EACE;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;;;ACzCJ;EACE;;AAGF;AAAA;AAAA;AAAA;AAAA;EAKE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;AAAA;AAAA;AAAA;AAAA;IACE;IACA,YACE;;;AAMR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA,YACE;;AAIJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAGF;AAAA;AAAA;AAAA;AAAA;EACE;;AASE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGE;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AC7DV;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;AAGF;AAAA;AAAA;EACE;EACA;EACA;EACA;;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAEE;EACA;EACA;;AAIK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAGP;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;EACA;;;AAKF;AAAA;AAAA;EACE;;;AAMJ;EACE;;;ACjDJ;EACE;;;ACAA;EACE;EACA;;;ACFF;AAAA;AAAA;EAGE;EACA;;AAEA;AAAA;AAAA;EACE;EACA;;;ACRJ;EACE;;;ACDF;EACE;;;ACDF;EACE;;;ACEJ;EAJA;;AAoBI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EApBJ;;AA0BA;EACE;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE;EACA;EACA%22,%22file%22:%22styles.css%22,%22sourcesContent%22:%5B%22.obsidian-dev-utils%20%7B%5Cn%20%20&.code-highlighter-component%20%7B%5Cn%20%20%20%20textarea,%20pre,%20code%20%7B%5Cn%20%20%20%20%20%20font-family:%20var(--font-monospace);%5Cn%20%20%20%20%20%20line-height:%20var(--line-height-normal);%5Cn%20%20%20%20%20%20margin:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20textarea,%20code%20%7B%5Cn%20%20%20%20%20%20font-size:%20var(--code-size);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20textarea%20%7B%5Cn%20%20%20%20%20%20background:%20transparent;%5Cn%20%20%20%20%20%20color:%20transparent;%5Cn%20%20%20%20%20%20z-index:%202;%5Cn%20%20%20%20%20%20width:%2020em;%5Cn%20%20%20%20%20%20height:%2010em;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20pointer-events:%20none;%5Cn%20%20%20%20%20%20border:%20var(--input-border-width)%20solid%20transparent;%5Cn%20%20%20%20%20%20overflow:%20auto;%5Cn%20%20%20%20%20%20inset:%200;%5Cn%20%20%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20%20%20z-index:%201;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre::after%20%7B%5Cn%20%20%20%20%20%20content:%20%5C%22%5C%22;%5Cn%20%20%20%20%20%20display:%20block;%5Cn%20%20%20%20%20%20height:%20var(--bottom-gap,%200);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20pre.is-placeholder%20%7B%5Cn%20%20%20%20%20%20opacity:%200.6;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20code%20%7B%5Cn%20%20%20%20%20%20display:%20block;%5Cn%20%20%20%20%20%20padding:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='url'%5D%20%7B%5Cn%20%20%20%20height:%20var(--input-height)%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='tel'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='url'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20-webkit-app-region:%20no-drag;%5Cn%20%20%20%20background:%20var(--background-modifier-form-field);%5Cn%20%20%20%20border:%20var(--input-border-width)%20solid%20var(--background-modifier-border);%5Cn%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20font-family:%20inherit;%5Cn%20%20%20%20padding:%20var(--size-4-1)%20var(--size-4-2);%5Cn%20%20%20%20font-size:%20var(--font-ui-small);%5Cn%20%20%20%20border-radius:%20var(--input-radius);%5Cn%20%20%20%20outline:%20none;%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20@media%20(hover:%20hover)%20%7B%5Cn%20%20%20%20%20%20%20%20&:hover%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20border-color:%20var(--background-modifier-border-hover);%5Cn%20%20%20%20%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20border-color:%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%20%20transition:%5Cn%20%20%20%20%20%20%20%20box-shadow%200.15s%20ease-in-out,%5Cn%20%20%20%20%20%20%20%20border%200.15s%20ease-in-out;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus,%5Cn%20%20%20%20&:focus-visible%20%7B%5Cn%20%20%20%20%20%20box-shadow:%200%200%200%202px%20var(--background-modifier-border-focus);%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::placeholder%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20@at-root%20%7B%5Cn%20%20%20%20.mod-rtl,%5Cn%20%20%20%20.is-rtl,%5Cn%20%20%20%20.rtl%20%7B%5Cn%20%20%20%20%20%20&%20%7B%5Cn%20%20%20%20%20%20%20%20input%5Btype='month'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='time'%5D,%5Cn%20%20%20%20%20%20%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%20%20%7D%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20input%5Btype='month'%5D,%5Cn%20%20input%5Btype='time'%5D,%5Cn%20%20input%5Btype='week'%5D%20%7B%5Cn%20%20%20%20font-variant-numeric:%20tabular-nums;%5Cn%20%20%20%20position:%20relative;%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-text%20%7B%5Cn%20%20%20%20%20%20color:%20var(--text-faint);%5Cn%20%20%20%20%20%20padding-inline-end:%200;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20position:%20absolute;%5Cn%20%20%20%20%20%20left:%20var(--size-4-1);%5Cn%20%20%20%20%20%20right:%20auto;%5Cn%20%20%20%20%20%20opacity:%200.5;%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20&::-webkit-datetime-edit-month-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-day-field,%5Cn%20%20%20%20&::-webkit-datetime-edit-year-field%20%7B%5Cn%20%20%20%20%20%20&:active,%5Cn%20%20%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20var(--text-selection);%5Cn%20%20%20%20%20%20%20%20color:%20var(--text-normal);%5Cn%20%20%20%20%20%20%20%20cursor:%20text;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20.mod-rtl%20&,%5Cn%20%20%20%20%20%20.is-rtl%20&,%5Cn%20%20%20%20%20%20.rtl%20&%20%7B%5Cn%20%20%20%20%20%20direction:%20rtl;%5Cn%5Cn%20%20%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20%20%20left:%20auto;%5Cn%20%20%20%20%20%20%20%20right:%20var(--size-4-1);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%5Cn%20%20%20%20@at-root%20%7B%5Cn%20%20%20%20%20%20body:not(.is-ios):not(.is-android)%20&%20%7B%5Cn%20%20%20%20%20%20%20%20padding-inline-start:%20var(--size-4-6);%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20input%5Btype='time'%5D%20%7B%5Cn%20%20%20%20&::-webkit-calendar-picker-indicator%20%7B%5Cn%20%20%20%20%20%20margin-inline-start:%200;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&progress.loop%20%7B%5Cn%20%20%20%20min-width:%20200px;%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.modal-container%20%7B%5Cn%20%20%20%20.ok-button%20%7B%5Cn%20%20%20%20%20%20margin-right:%2010px;%5Cn%20%20%20%20%20%20margin-top:%2020px;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20.multiple-dropdown-component%20%7B%5Cn%20%20%20%20select,%5Cn%20%20%20%20select:focus,%5Cn%20%20%20%20.dropdown%20%7B%5Cn%20%20%20%20%20%20height:%20auto;%5Cn%20%20%20%20%20%20padding-top:%203px;%5Cn%5Cn%20%20%20%20%20%20option:checked%20%7B%5Cn%20%20%20%20%20%20%20%20background-color:%20%231967d2;%5Cn%20%20%20%20%20%20%20%20color:%20%23fff;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.plugin-settings-tab%20%7B%5Cn%20%20%20%20a:focus%20%7B%5Cn%20%20%20%20%20%20outline:%202px%20solid%20var(--link-color);%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cn%20%20&.prompt-modal%20%7B%5Cn%20%20%20%20.text-box%20%7B%5Cn%20%20%20%20%20%20width:%20100%25;%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%7D%5Cn%22,%22.obsidian-dev-utils%20%7B%5Cr%5Cn%20%20&.tri-state-checkbox-component%20%7B%5Cr%5Cn%20%20%20%20input%5Btype='checkbox'%5D:indeterminate%20%7B%5Cr%5Cn%20%20%20%20%20%20appearance:%20checkbox;%5Cr%5Cn%20%20%20%20%7D%5Cr%5Cn%20%20%7D%5Cr%5Cn%7D%5Cr%5Cn%22,%22@mixin%20invalid%20%7B%5Cn%20%20box-shadow:%200%200%200%202px%20var(--text-error);%5Cn%7D%5Cn%5Cn.obsidian-dev-utils%20%7B%5Cn%20%20:invalid%20%7B%5Cn%20%20%20%20@include%20invalid;%5Cn%20%20%7D%5Cn%5Cn%20%20input.metadata-input-text,%5Cn%20%20input%5Btype='date'%5D,%5Cn%20%20input%5Btype='datetime-local'%5D,%5Cn%20%20input%5Btype='email'%5D,%5Cn%20%20input%5Btype='number'%5D,%5Cn%20%20input%5Btype='password'%5D,%5Cn%20%20input%5Btype='search'%5D,%5Cn%20%20input%5Btype='text'%5D,%5Cn%20%20textarea%20%7B%5Cn%20%20%20%20&:active,%5Cn%20%20%20%20&:focus-visible,%5Cn%20%20%20%20&:focus%20%7B%5Cn%20%20%20%20%20%20&:invalid%20%7B%5Cn%20%20%20%20%20%20%20%20@include%20invalid;%5Cn%20%20%20%20%20%20%7D%5Cn%20%20%20%20%7D%5Cn%20%20%7D%5Cn%5Cn%20%20&.setting-component-wrapper%20%7B%5Cn%20%20%20%20position:%20relative;%5Cn%20%20%20%20display:%20inline-flex;%5Cn%20%20%7D%5Cn%5Cn%20%20&.overlay-validator%20%7B%5Cn%20%20%20%20caret-color:%20transparent;%5Cn%20%20%20%20cursor:%20default;%5Cn%20%20%20%20position:%20absolute;%5Cn%20%20%20%20background-color:%20transparent;%5Cn%20%20%20%20border:%20none;%5Cn%20%20%20%20outline:%20none;%5Cn%20%20%20%20pointer-events:%20none;%5Cn%20%20%20%20z-index:%209999;%5Cn%20%20%20%20left:%200;%5Cn%20%20%20%20top:%200;%5Cn%20%20%20%20width:%20100%25;%5Cn%20%20%20%20height:%20100%25;%5Cn%20%20%7D%5Cn%5Cn%20%20&.tooltip.tooltip-validator%20%7B%5Cn%20%20%20%20position:%20absolute;%5Cn%20%20%20%20top:%20calc(100%25%20+%208px);%5Cn%20%20%20%20width:%20max-content;%5Cn%20%20%7D%5Cn%7D%5Cn%22%5D%7D */\n";
136
136
  // Annotate the CommonJS export names for ESM import in node:
@@ -125,7 +125,9 @@ var __copyProps = (to, from, except, desc) => {
125
125
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
126
126
  var async_component_exports = {};
127
127
  __export(async_component_exports, {
128
- AsyncComponentBase: () => AsyncComponentBase
128
+ AsyncComponentBase: () => AsyncComponentBase,
129
+ loadAsync: () => loadAsync,
130
+ loadChildrenFirstAsync: () => loadChildrenFirstAsync
129
131
  });
130
132
  module.exports = __toCommonJS(async_component_exports);
131
133
  var import_obsidian = require('obsidian');
@@ -138,14 +140,7 @@ class AsyncComponentBase extends import_obsidian.Component {
138
140
  */
139
141
  // eslint-disable-next-line @typescript-eslint/no-misused-promises -- Obsidian's load() handles async returns at runtime.
140
142
  async load() {
141
- if (this._loaded) {
142
- return;
143
- }
144
- this._loaded = true;
145
- await this.onload();
146
- for (const child of this._children) {
147
- await child.load();
148
- }
143
+ await loadAsync(this);
149
144
  }
150
145
  /**
151
146
  * Override this method to perform async initialization.
@@ -157,8 +152,30 @@ class AsyncComponentBase extends import_obsidian.Component {
157
152
  await Promise.resolve();
158
153
  }
159
154
  }
155
+ async function loadAsync(component) {
156
+ if (component._loaded) {
157
+ return;
158
+ }
159
+ component._loaded = true;
160
+ await component.onload();
161
+ for (const child of component._children) {
162
+ await loadAsync(child);
163
+ }
164
+ }
165
+ async function loadChildrenFirstAsync(component) {
166
+ if (component._loaded) {
167
+ return;
168
+ }
169
+ for (const child of component._children) {
170
+ await loadChildrenFirstAsync(child);
171
+ }
172
+ component._loaded = true;
173
+ await component.onload();
174
+ }
160
175
  // Annotate the CommonJS export names for ESM import in node:
161
176
  0 && (module.exports = {
162
- AsyncComponentBase
177
+ AsyncComponentBase,
178
+ loadAsync,
179
+ loadChildrenFirstAsync
163
180
  });
164
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL2NvbXBvbmVudHMvYXN5bmMtY29tcG9uZW50LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBmaWxlXG4gKlxuICogQmFzZSBjbGFzcyBmb3IgY29tcG9uZW50cyB0aGF0IG5lZWQgYXN5bmMgbGlmZWN5Y2xlIG1ldGhvZHMuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBQcm9taXNhYmxlIH0gZnJvbSAndHlwZS1mZXN0JztcblxuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnb2JzaWRpYW4nO1xuXG4vKipcbiAqIEEge0BsaW5rIENvbXBvbmVudH0gdGhhdCBzdXBwb3J0cyBhc3luYyBsaWZlY3ljbGUgbWV0aG9kcy5cbiAqXG4gKiBPYnNpZGlhbidzIGBDb21wb25lbnQubG9hZCgpYCBjYXB0dXJlcyB0aGUgcmV0dXJuIHZhbHVlIG9mIGBvbmxvYWQoKWAgYW5kIGluY2x1ZGVzIFByb21pc2VzXG4gKiBpbiBhIGBQcm9taXNlLmFsbCgpYC4gVGhpcyBjbGFzcyBvdmVycmlkZXMgYGxvYWQoKWAgdG8gYGF3YWl0YCBgb25sb2FkKClgIGJlZm9yZSBsb2FkaW5nIGNoaWxkcmVuLFxuICogZW5zdXJpbmcgb3JkZXJlZCBpbml0aWFsaXphdGlvbi5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFzeW5jQ29tcG9uZW50QmFzZSBleHRlbmRzIENvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBMb2FkcyB0aGlzIGNvbXBvbmVudCBhbmQgaXRzIGNoaWxkcmVuIHNlcXVlbnRpYWxseS5cbiAgICpcbiAgICogVW5saWtlIENvbXBvbmVudCdzIGBsb2FkKClgIHdoaWNoIHJ1bnMgYG9ubG9hZCgpYCBhbmQgY2hpbGRyZW4gY29uY3VycmVudGx5LFxuICAgKiB0aGlzIGF3YWl0cyBgb25sb2FkKClgIGZpcnN0LCB0aGVuIGxvYWRzIGNoaWxkcmVuIGluIG9yZGVyLlxuICAgKi9cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1taXN1c2VkLXByb21pc2VzIC0tIE9ic2lkaWFuJ3MgbG9hZCgpIGhhbmRsZXMgYXN5bmMgcmV0dXJucyBhdCBydW50aW1lLlxuICBwdWJsaWMgb3ZlcnJpZGUgYXN5bmMgbG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAodGhpcy5fbG9hZGVkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX2xvYWRlZCA9IHRydWU7XG4gICAgYXdhaXQgdGhpcy5vbmxvYWQoKTtcblxuICAgIGZvciAoY29uc3QgY2hpbGQgb2YgdGhpcy5fY2hpbGRyZW4pIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tY29uZnVzaW5nLXZvaWQtZXhwcmVzc2lvbiAtLSBDb21wb25lbnQubG9hZCgpIHJldHVybnMgdm9pZHxQcm9taXNlIGF0IHJ1bnRpbWUgZGVzcGl0ZSB2b2lkIHR5cGluZy5cbiAgICAgIGF3YWl0IChjaGlsZC5sb2FkKCkgYXMgUHJvbWlzYWJsZTx2b2lkPik7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIE92ZXJyaWRlIHRoaXMgbWV0aG9kIHRvIHBlcmZvcm0gYXN5bmMgaW5pdGlhbGl6YXRpb24uXG4gICAqXG4gICAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiBpbml0aWFsaXphdGlvbiBpcyBjb21wbGV0ZS5cbiAgICovXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbWlzdXNlZC1wcm9taXNlcyAtLSBJbnRlbnRpb25hbCBhc3luYyBvdmVycmlkZTsgY2FsbGVkIGZyb20gb3VyIG93biBhc3luYyBsb2FkKCkuXG4gIHB1YmxpYyBvdmVycmlkZSBhc3luYyBvbmxvYWQoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgUHJvbWlzZS5yZXNvbHZlKCk7XG4gIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQVFBLHNCQUEwQjtBQVNuQixNQUFlLDJCQUEyQiwwQkFBVTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFRekQsTUFBc0IsT0FBc0I7QUFDMUMsUUFBSSxLQUFLLFNBQVM7QUFDaEI7QUFBQSxJQUNGO0FBQ0EsU0FBSyxVQUFVO0FBQ2YsVUFBTSxLQUFLLE9BQU87QUFFbEIsZUFBVyxTQUFTLEtBQUssV0FBVztBQUVsQyxZQUFPLE1BQU0sS0FBSztBQUFBLElBQ3BCO0FBQUEsRUFDRjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUUEsTUFBc0IsU0FBd0I7QUFDNUMsVUFBTSxRQUFRLFFBQVE7QUFBQSxFQUN4QjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
181
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL2NvbXBvbmVudHMvYXN5bmMtY29tcG9uZW50LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBmaWxlXG4gKlxuICogQmFzZSBjbGFzcyBmb3IgY29tcG9uZW50cyB0aGF0IG5lZWQgYXN5bmMgbGlmZWN5Y2xlIG1ldGhvZHMuXG4gKi9cblxuaW1wb3J0IHR5cGUgeyBQcm9taXNhYmxlIH0gZnJvbSAndHlwZS1mZXN0JztcblxuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnb2JzaWRpYW4nO1xuXG4vKipcbiAqIEEge0BsaW5rIENvbXBvbmVudH0gdGhhdCBzdXBwb3J0cyBhc3luYyBsaWZlY3ljbGUgbWV0aG9kcy5cbiAqXG4gKiBPYnNpZGlhbidzIGBDb21wb25lbnQubG9hZCgpYCBjYXB0dXJlcyB0aGUgcmV0dXJuIHZhbHVlIG9mIGBvbmxvYWQoKWAgYW5kIGluY2x1ZGVzIFByb21pc2VzXG4gKiBpbiBhIGBQcm9taXNlLmFsbCgpYC4gVGhpcyBjbGFzcyBvdmVycmlkZXMgYGxvYWQoKWAgdG8gYGF3YWl0YCBgb25sb2FkKClgIGJlZm9yZSBsb2FkaW5nIGNoaWxkcmVuLFxuICogZW5zdXJpbmcgb3JkZXJlZCBpbml0aWFsaXphdGlvbi5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFzeW5jQ29tcG9uZW50QmFzZSBleHRlbmRzIENvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBMb2FkcyB0aGlzIGNvbXBvbmVudCBhbmQgaXRzIGNoaWxkcmVuIHNlcXVlbnRpYWxseS5cbiAgICpcbiAgICogVW5saWtlIENvbXBvbmVudCdzIGBsb2FkKClgIHdoaWNoIHJ1bnMgYG9ubG9hZCgpYCBhbmQgY2hpbGRyZW4gY29uY3VycmVudGx5LFxuICAgKiB0aGlzIGF3YWl0cyBgb25sb2FkKClgIGZpcnN0LCB0aGVuIGxvYWRzIGNoaWxkcmVuIGluIG9yZGVyLlxuICAgKi9cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1taXN1c2VkLXByb21pc2VzIC0tIE9ic2lkaWFuJ3MgbG9hZCgpIGhhbmRsZXMgYXN5bmMgcmV0dXJucyBhdCBydW50aW1lLlxuICBwdWJsaWMgb3ZlcnJpZGUgYXN5bmMgbG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBsb2FkQXN5bmModGhpcyk7XG4gIH1cblxuICAvKipcbiAgICogT3ZlcnJpZGUgdGhpcyBtZXRob2QgdG8gcGVyZm9ybSBhc3luYyBpbml0aWFsaXphdGlvbi5cbiAgICpcbiAgICogQHJldHVybnMgQSB7QGxpbmsgUHJvbWlzZX0gdGhhdCByZXNvbHZlcyB3aGVuIGluaXRpYWxpemF0aW9uIGlzIGNvbXBsZXRlLlxuICAgKi9cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1taXN1c2VkLXByb21pc2VzIC0tIEludGVudGlvbmFsIGFzeW5jIG92ZXJyaWRlOyBjYWxsZWQgZnJvbSBvdXIgb3duIGFzeW5jIGxvYWQoKS5cbiAgcHVibGljIG92ZXJyaWRlIGFzeW5jIG9ubG9hZCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBhd2FpdCBQcm9taXNlLnJlc29sdmUoKTtcbiAgfVxufVxuXG4vKipcbiAqIExvYWRzIGEgY29tcG9uZW50IGFuZCBpdHMgY2hpbGRyZW4gc2VxdWVudGlhbGx5LlxuICpcbiAqIEBwYXJhbSBjb21wb25lbnQgLSBUaGUgY29tcG9uZW50IHRvIGxvYWQuXG4gKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBsb2FkZWQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBsb2FkQXN5bmMoY29tcG9uZW50OiBDb21wb25lbnQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgaWYgKGNvbXBvbmVudC5fbG9hZGVkKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbXBvbmVudC5fbG9hZGVkID0gdHJ1ZTtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1jb25mdXNpbmctdm9pZC1leHByZXNzaW9uIC0tIENvbXBvbmVudC5sb2FkKCkgcmV0dXJucyB2b2lkfFByb21pc2UgYXQgcnVudGltZSBkZXNwaXRlIHZvaWQgdHlwaW5nLlxuICBhd2FpdCAoY29tcG9uZW50Lm9ubG9hZCgpIGFzIFByb21pc2FibGU8dm9pZD4pO1xuXG4gIGZvciAoY29uc3QgY2hpbGQgb2YgY29tcG9uZW50Ll9jaGlsZHJlbikge1xuICAgIGF3YWl0IGxvYWRBc3luYyhjaGlsZCk7XG4gIH1cbn1cblxuLyoqXG4gKiBMb2FkcyBhIGNvbXBvbmVudCBhbmQgaXRzIGNoaWxkcmVuIChjaGlsZHJlbiBmaXJzdCkuXG4gKlxuICogQHBhcmFtIGNvbXBvbmVudCAtIFRoZSBjb21wb25lbnQgdG8gbG9hZC5cbiAqIEByZXR1cm5zIEEge0BsaW5rIFByb21pc2V9IHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgY29tcG9uZW50IGlzIGxvYWRlZC5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvYWRDaGlsZHJlbkZpcnN0QXN5bmMoY29tcG9uZW50OiBDb21wb25lbnQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgaWYgKGNvbXBvbmVudC5fbG9hZGVkKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgZm9yIChjb25zdCBjaGlsZCBvZiBjb21wb25lbnQuX2NoaWxkcmVuKSB7XG4gICAgYXdhaXQgbG9hZENoaWxkcmVuRmlyc3RBc3luYyhjaGlsZCk7XG4gIH1cblxuICBjb21wb25lbnQuX2xvYWRlZCA9IHRydWU7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tY29uZnVzaW5nLXZvaWQtZXhwcmVzc2lvbiAtLSBDb21wb25lbnQubG9hZCgpIHJldHVybnMgdm9pZHxQcm9taXNlIGF0IHJ1bnRpbWUgZGVzcGl0ZSB2b2lkIHR5cGluZy5cbiAgYXdhaXQgKGNvbXBvbmVudC5vbmxvYWQoKSBhcyBQcm9taXNhYmxlPHZvaWQ+KTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFRQSxzQkFBMEI7QUFTbkIsTUFBZSwyQkFBMkIsMEJBQVU7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBUXpELE1BQXNCLE9BQXNCO0FBQzFDLFVBQU0sVUFBVSxJQUFJO0FBQUEsRUFDdEI7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVFBLE1BQXNCLFNBQXdCO0FBQzVDLFVBQU0sUUFBUSxRQUFRO0FBQUEsRUFDeEI7QUFDRjtBQVFBLGVBQXNCLFVBQVUsV0FBcUM7QUFDbkUsTUFBSSxVQUFVLFNBQVM7QUFDckI7QUFBQSxFQUNGO0FBQ0EsWUFBVSxVQUFVO0FBRXBCLFFBQU8sVUFBVSxPQUFPO0FBRXhCLGFBQVcsU0FBUyxVQUFVLFdBQVc7QUFDdkMsVUFBTSxVQUFVLEtBQUs7QUFBQSxFQUN2QjtBQUNGO0FBUUEsZUFBc0IsdUJBQXVCLFdBQXFDO0FBQ2hGLE1BQUksVUFBVSxTQUFTO0FBQ3JCO0FBQUEsRUFDRjtBQUVBLGFBQVcsU0FBUyxVQUFVLFdBQVc7QUFDdkMsVUFBTSx1QkFBdUIsS0FBSztBQUFBLEVBQ3BDO0FBRUEsWUFBVSxVQUFVO0FBRXBCLFFBQU8sVUFBVSxPQUFPO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -26,3 +26,17 @@ export declare abstract class AsyncComponentBase extends Component {
26
26
  */
27
27
  onload(): Promise<void>;
28
28
  }
29
+ /**
30
+ * Loads a component and its children sequentially.
31
+ *
32
+ * @param component - The component to load.
33
+ * @returns A {@link Promise} that resolves when the component is loaded.
34
+ */
35
+ export declare function loadAsync(component: Component): Promise<void>;
36
+ /**
37
+ * Loads a component and its children (children first).
38
+ *
39
+ * @param component - The component to load.
40
+ * @returns A {@link Promise} that resolves when the component is loaded.
41
+ */
42
+ export declare function loadChildrenFirstAsync(component: Component): Promise<void>;
@@ -139,7 +139,7 @@ __export(components_exports, {
139
139
  async_error_handler_component: () => async_error_handler_component,
140
140
  console_debug_component: () => console_debug_component,
141
141
  i18n_component: () => i18n_component,
142
- lifecycle_events_component: () => lifecycle_events_component,
142
+ layout_ready_component: () => layout_ready_component,
143
143
  plugin_context_component: () => plugin_context_component,
144
144
  plugin_notice_component: () => plugin_notice_component,
145
145
  plugin_settings_component: () => plugin_settings_component,
@@ -150,7 +150,7 @@ var abort_signal_component = __toESM(__extractDefault(require('./abort-signal-co
150
150
  var async_error_handler_component = __toESM(__extractDefault(require('./async-error-handler-component.cjs')), 1);
151
151
  var console_debug_component = __toESM(__extractDefault(require('./console-debug-component.cjs')), 1);
152
152
  var i18n_component = __toESM(__extractDefault(require('./i18n-component.cjs')), 1);
153
- var lifecycle_events_component = __toESM(__extractDefault(require('./lifecycle-events-component.cjs')), 1);
153
+ var layout_ready_component = __toESM(__extractDefault(require('./layout-ready-component.cjs')), 1);
154
154
  var plugin_context_component = __toESM(__extractDefault(require('./plugin-context-component.cjs')), 1);
155
155
  var plugin_notice_component = __toESM(__extractDefault(require('./plugin-notice-component.cjs')), 1);
156
156
  var plugin_settings_component = __toESM(__extractDefault(require('./plugin-settings-component.cjs')), 1);
@@ -161,10 +161,10 @@ var plugin_settings_tab_component = __toESM(__extractDefault(require('./plugin-s
161
161
  async_error_handler_component,
162
162
  console_debug_component,
163
163
  i18n_component,
164
- lifecycle_events_component,
164
+ layout_ready_component,
165
165
  plugin_context_component,
166
166
  plugin_notice_component,
167
167
  plugin_settings_component,
168
168
  plugin_settings_tab_component
169
169
  });
170
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgYWJvcnRfc2lnbmFsX2NvbXBvbmVudCBmcm9tICcuL2Fib3J0LXNpZ25hbC1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgYXN5bmNfZXJyb3JfaGFuZGxlcl9jb21wb25lbnQgZnJvbSAnLi9hc3luYy1lcnJvci1oYW5kbGVyLWNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBjb25zb2xlX2RlYnVnX2NvbXBvbmVudCBmcm9tICcuL2NvbnNvbGUtZGVidWctY29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIGkxOG5fY29tcG9uZW50IGZyb20gJy4vaTE4bi1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgbGlmZWN5Y2xlX2V2ZW50c19jb21wb25lbnQgZnJvbSAnLi9saWZlY3ljbGUtZXZlbnRzLWNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBwbHVnaW5fY29udGV4dF9jb21wb25lbnQgZnJvbSAnLi9wbHVnaW4tY29udGV4dC1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgcGx1Z2luX25vdGljZV9jb21wb25lbnQgZnJvbSAnLi9wbHVnaW4tbm90aWNlLWNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBwbHVnaW5fc2V0dGluZ3NfY29tcG9uZW50IGZyb20gJy4vcGx1Z2luLXNldHRpbmdzLWNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBwbHVnaW5fc2V0dGluZ3NfdGFiX2NvbXBvbmVudCBmcm9tICcuL3BsdWdpbi1zZXR0aW5ncy10YWItY29tcG9uZW50LnRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUEsNkJBQXdDO0FBQ3hDLG9DQUErQztBQUMvQyw4QkFBeUM7QUFDekMscUJBQWdDO0FBQ2hDLGlDQUE0QztBQUM1QywrQkFBMEM7QUFDMUMsOEJBQXlDO0FBQ3pDLGdDQUEyQztBQUMzQyxvQ0FBK0M7IiwKICAibmFtZXMiOiBbXQp9Cg==
170
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKiBUSElTIElTIEEgR0VORVJBVEVEL0JVTkRMRUQgRklMRSBCWSBCVUlMRCBTQ1JJUFQgKi9cblxuZXhwb3J0ICogYXMgYWJvcnRfc2lnbmFsX2NvbXBvbmVudCBmcm9tICcuL2Fib3J0LXNpZ25hbC1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgYXN5bmNfZXJyb3JfaGFuZGxlcl9jb21wb25lbnQgZnJvbSAnLi9hc3luYy1lcnJvci1oYW5kbGVyLWNvbXBvbmVudC50cyc7XG5leHBvcnQgKiBhcyBjb25zb2xlX2RlYnVnX2NvbXBvbmVudCBmcm9tICcuL2NvbnNvbGUtZGVidWctY29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIGkxOG5fY29tcG9uZW50IGZyb20gJy4vaTE4bi1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgbGF5b3V0X3JlYWR5X2NvbXBvbmVudCBmcm9tICcuL2xheW91dC1yZWFkeS1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgcGx1Z2luX2NvbnRleHRfY29tcG9uZW50IGZyb20gJy4vcGx1Z2luLWNvbnRleHQtY29tcG9uZW50LnRzJztcbmV4cG9ydCAqIGFzIHBsdWdpbl9ub3RpY2VfY29tcG9uZW50IGZyb20gJy4vcGx1Z2luLW5vdGljZS1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgcGx1Z2luX3NldHRpbmdzX2NvbXBvbmVudCBmcm9tICcuL3BsdWdpbi1zZXR0aW5ncy1jb21wb25lbnQudHMnO1xuZXhwb3J0ICogYXMgcGx1Z2luX3NldHRpbmdzX3RhYl9jb21wb25lbnQgZnJvbSAnLi9wbHVnaW4tc2V0dGluZ3MtdGFiLWNvbXBvbmVudC50cyc7XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUVBLDZCQUF3QztBQUN4QyxvQ0FBK0M7QUFDL0MsOEJBQXlDO0FBQ3pDLHFCQUFnQztBQUNoQyw2QkFBd0M7QUFDeEMsK0JBQTBDO0FBQzFDLDhCQUF5QztBQUN6QyxnQ0FBMkM7QUFDM0Msb0NBQStDOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -2,7 +2,7 @@ export * as abort_signal_component from './abort-signal-component.cjs';
2
2
  export * as async_error_handler_component from './async-error-handler-component.cjs';
3
3
  export * as console_debug_component from './console-debug-component.cjs';
4
4
  export * as i18n_component from './i18n-component.cjs';
5
- export * as lifecycle_events_component from './lifecycle-events-component.cjs';
5
+ export * as layout_ready_component from './layout-ready-component.cjs';
6
6
  export * as plugin_context_component from './plugin-context-component.cjs';
7
7
  export * as plugin_notice_component from './plugin-notice-component.cjs';
8
8
  export * as plugin_settings_component from './plugin-settings-component.cjs';
@@ -0,0 +1,124 @@
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 initCjs() {
7
+ // eslint-disable-next-line obsidianmd/no-global-this -- Actively use globalThis.
8
+ const globalThisRecord = globalThis;
9
+ globalThisRecord['__name'] ??= name;
10
+ const originalRequire = require;
11
+ if (originalRequire && !originalRequire.__isPatched) {
12
+ // eslint-disable-next-line no-global-assign, no-implicit-globals -- We need to patch the `require()` function.
13
+ require = Object.assign(
14
+ (id) => requirePatched(id),
15
+ originalRequire,
16
+ {
17
+ __isPatched: true
18
+ }
19
+ );
20
+ }
21
+
22
+ const newFuncs = {
23
+ __extractDefault() {
24
+ return extractDefault;
25
+ },
26
+ process() {
27
+ const browserProcess = {
28
+ browser: true,
29
+ cwd() {
30
+ return '/';
31
+ },
32
+ env: {},
33
+ platform: 'android'
34
+ };
35
+ return browserProcess;
36
+ }
37
+ };
38
+
39
+ for (const key of Object.keys(newFuncs)) {
40
+ globalThisRecord[key] ??= newFuncs[key]?.();
41
+ }
42
+
43
+ function name(obj) {
44
+ return obj;
45
+ }
46
+
47
+ function extractDefault(module) {
48
+ return module && module.__esModule && 'default' in module ? module.default : module;
49
+ }
50
+
51
+ const OBSIDIAN_BUILT_IN_MODULE_NAMES = [
52
+ 'obsidian',
53
+ '@codemirror/autocomplete',
54
+ '@codemirror/collab',
55
+ '@codemirror/commands',
56
+ '@codemirror/language',
57
+ '@codemirror/lint',
58
+ '@codemirror/search',
59
+ '@codemirror/state',
60
+ '@codemirror/text',
61
+ '@codemirror/view',
62
+ '@lezer/common',
63
+ '@lezer/lr',
64
+ '@lezer/highlight'];
65
+
66
+
67
+ const DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES = [
68
+ '@codemirror/closebrackets',
69
+ '@codemirror/comment',
70
+ '@codemirror/fold',
71
+ '@codemirror/gutter',
72
+ '@codemirror/highlight',
73
+ '@codemirror/history',
74
+ '@codemirror/matchbrackets',
75
+ '@codemirror/panel',
76
+ '@codemirror/rangeset',
77
+ '@codemirror/rectangular-selection',
78
+ '@codemirror/stream-parser',
79
+ '@codemirror/tooltip'];
80
+
81
+
82
+ function requirePatched(id) {
83
+ if (OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id) || DEPRECATED_OBSIDIAN_BUILT_IN_MODULE_NAMES.includes(id)) {
84
+ return originalRequire?.(id);
85
+ }
86
+
87
+ // eslint-disable-next-line @typescript-eslint/no-deprecated, obsidianmd/no-global-this -- Need access to app. Actively use globalThis.
88
+ if (globalThis.app.isMobile) {
89
+ if (id === 'process' || id === 'node:process') {
90
+ // eslint-disable-next-line no-console -- Valid usage.
91
+ console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Fake process object is returned instead.`);
92
+ // eslint-disable-next-line obsidianmd/no-global-this -- Actively use globalThis.
93
+ return globalThis.process;
94
+ }
95
+ } else {
96
+ const module = originalRequire?.(id);
97
+ if (module) {
98
+ return extractDefault(module);
99
+ }
100
+ }
101
+
102
+ // eslint-disable-next-line no-console -- Valid usage.
103
+ console.debug(`The most likely you can safely ignore this error. Module not found: ${id}. Empty object is returned instead.`);
104
+ return {};
105
+ }
106
+ })();
107
+
108
+ "use strict";
109
+ var __defProp = Object.defineProperty;
110
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
111
+ var __getOwnPropNames = Object.getOwnPropertyNames;
112
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
113
+ var __copyProps = (to, from, except, desc) => {
114
+ if (from && typeof from === "object" || typeof from === "function") {
115
+ for (let key of __getOwnPropNames(from))
116
+ if (!__hasOwnProp.call(to, key) && key !== except)
117
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
118
+ }
119
+ return to;
120
+ };
121
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
122
+ var layout_ready_component_exports = {};
123
+ module.exports = __toCommonJS(layout_ready_component_exports);
124
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL29ic2lkaWFuL3BsdWdpbi9jb21wb25lbnRzL2xheW91dC1yZWFkeS1jb21wb25lbnQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQGZpbGVcbiAqXG4gKiBJbnRlcmZhY2UgZm9yIGNvbXBvbmVudHMgdGhhdCBuZWVkIHRvIHBlcmZvcm0gd29yayB3aGVuIHRoZSB3b3Jrc3BhY2UgbGF5b3V0IGlzIHJlYWR5LlxuICovXG5cbmltcG9ydCB0eXBlIHsgUHJvbWlzYWJsZSB9IGZyb20gJ3R5cGUtZmVzdCc7XG5cbi8qKlxuICogQ29tcG9uZW50cyBpbXBsZW1lbnRpbmcgdGhpcyBpbnRlcmZhY2Ugd2lsbCBoYXZlIHtAbGluayBvbkxheW91dFJlYWR5fSBjYWxsZWRcbiAqIGJ5IFBsdWdpbkJhc2UgYWZ0ZXIgdGhlIHdvcmtzcGFjZSBsYXlvdXQgaXMgcmVhZHksIHdpdGggZXJyb3IgaXNvbGF0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExheW91dFJlYWR5Q29tcG9uZW50IHtcbiAgLyoqXG4gICAqIENhbGxlZCB3aGVuIHRoZSB3b3Jrc3BhY2UgbGF5b3V0IGlzIHJlYWR5LlxuICAgKlxuICAgKiBAcmV0dXJucyBBIHtAbGluayBQcm9taXNlfSB0aGF0IHJlc29sdmVzIHdoZW4gbGF5b3V0LXJlYWR5IHdvcmsgaXMgY29tcGxldGUuXG4gICAqL1xuICBvbkxheW91dFJlYWR5KCk6IFByb21pc2FibGU8dm9pZD47XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,18 @@
1
+ /**
2
+ * @file
3
+ *
4
+ * Interface for components that need to perform work when the workspace layout is ready.
5
+ */
6
+ import type { Promisable } from 'type-fest';
7
+ /**
8
+ * Components implementing this interface will have {@link onLayoutReady} called
9
+ * by PluginBase after the workspace layout is ready, with error isolation.
10
+ */
11
+ export interface LayoutReadyComponent {
12
+ /**
13
+ * Called when the workspace layout is ready.
14
+ *
15
+ * @returns A {@link Promise} that resolves when layout-ready work is complete.
16
+ */
17
+ onLayoutReady(): Promisable<void>;
18
+ }
@@ -133,12 +133,12 @@ module.exports = __toCommonJS(plugin_exports);
133
133
  var import_obsidian = require('obsidian');
134
134
  var import_async = require('../../async.cjs');
135
135
  var import_error = require('../../error.cjs');
136
- var import_function = require('../../function.cjs');
136
+ var import_strict_proxy = require('../../strict-proxy.cjs');
137
+ var import_async_component = require('../components/async-component.cjs');
137
138
  var import_abort_signal_component = require('./components/abort-signal-component.cjs');
138
139
  var import_async_error_handler_component = require('./components/async-error-handler-component.cjs');
139
140
  var import_console_debug_component = require('./components/console-debug-component.cjs');
140
141
  var import_i18n_component = require('./components/i18n-component.cjs');
141
- var import_lifecycle_events_component = require('./components/lifecycle-events-component.cjs');
142
142
  var import_plugin_context_component = require('./components/plugin-context-component.cjs');
143
143
  var import_plugin_notice_component = require('./components/plugin-notice-component.cjs');
144
144
  var import_plugin_settings_component = require('./components/plugin-settings-component.cjs');
@@ -151,10 +151,6 @@ class PluginBase extends import_obsidian.Plugin {
151
151
  * The console debug component. Provides namespaced debug logging.
152
152
  */
153
153
  consoleDebugComponent;
154
- /**
155
- * The lifecycle events component. Provides load, layoutReady, and unload events.
156
- */
157
- lifecycleEventsComponent;
158
154
  /**
159
155
  * The notice component. Displays notices to the user.
160
156
  */
@@ -163,7 +159,6 @@ class PluginBase extends import_obsidian.Plugin {
163
159
  * The settings component. Manages plugin settings lifecycle.
164
160
  */
165
161
  settingsComponent;
166
- preloadComponents = [];
167
162
  singletonComponents = /* @__PURE__ */ new Map();
168
163
  /**
169
164
  * Creates a new PluginBase.
@@ -173,95 +168,66 @@ class PluginBase extends import_obsidian.Plugin {
173
168
  */
174
169
  constructor(app, manifest) {
175
170
  super(app, manifest);
176
- this.registerComponent({ component: new import_plugin_context_component.PluginContextComponent(app, manifest.id), shouldPreload: true });
177
- this.registerComponent({ component: new import_i18n_component.I18nComponent(), shouldPreload: true });
178
- this.noticeComponent = this.registerComponent({ component: new import_plugin_notice_component.PluginNoticeComponent(manifest.name) });
179
- this.registerComponent({ component: new import_async_error_handler_component.AsyncErrorHandlerComponent(this.noticeComponent) });
180
- this.abortSignalComponent = this.registerComponent({ component: new import_abort_signal_component.AbortSignalComponent(manifest.id) });
181
- this.consoleDebugComponent = this.registerComponent({ component: new import_console_debug_component.ConsoleDebugComponent(manifest.id) });
182
- this.lifecycleEventsComponent = this.registerComponent({ component: new import_lifecycle_events_component.LifecycleEventsComponent(app) });
183
- this.settingsComponent = this.registerComponent({ component: new import_plugin_settings_component.EmptyPluginSettingsComponent(), shouldPreload: true });
184
- }
185
- /**
186
- * Called when the external settings change.
187
- *
188
- * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.
189
- */
190
- async onExternalSettingsChange() {
191
- await super.onExternalSettingsChange?.();
192
- await this.settingsComponent.onExternalSettingsChange();
193
- }
194
- /**
195
- * Called when the plugin is loaded. Force-loads components that must be ready
196
- * before plugin logic, then calls `onloadImpl()`.
197
- *
198
- * Usually, you don't need to override this method. Override {@link onloadImpl} instead.
199
- */
200
- async onload() {
201
- await super.onload();
202
- for (const component of this.preloadComponents) {
203
- await component.load();
204
- }
205
- await this.onloadImpl();
206
- (0, import_async.invokeAsyncSafelyAfterDelay)(this.afterLoad.bind(this));
207
- }
208
- /**
209
- * Called when the layout is ready.
210
- */
211
- async onLayoutReady() {
212
- await (0, import_function.noopAsync)();
171
+ this.addChild(new import_plugin_context_component.PluginContextComponent(app, manifest.id));
172
+ this.addChild(new import_i18n_component.I18nComponent());
173
+ this.noticeComponent = this.addChild(new import_plugin_notice_component.PluginNoticeComponent(manifest.name));
174
+ this.addChild(new import_async_error_handler_component.AsyncErrorHandlerComponent(this.noticeComponent));
175
+ this.abortSignalComponent = this.addChild(new import_abort_signal_component.AbortSignalComponent(manifest.id));
176
+ this.consoleDebugComponent = this.addChild(new import_console_debug_component.ConsoleDebugComponent(manifest.id));
177
+ this.settingsComponent = this.addChild(new import_plugin_settings_component.EmptyPluginSettingsComponent());
213
178
  }
214
179
  /**
215
- * Called after all pre-load components are initialized. Override this to add plugin-specific logic.
216
- *
217
- * @remarks It is important to call `super.onloadImpl()` in overridden method.
218
- */
219
- async onloadImpl() {
220
- await (0, import_function.noopAsync)();
221
- }
222
- /**
223
- * Registers a component with the plugin.
180
+ * Adds a component to the plugin.
224
181
  *
225
182
  * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton —
226
- * registering another component with the same key replaces the previous one.
183
+ * adding another component with the same key replaces the previous one.
227
184
  * Components without a `COMPONENT_KEY` are multi-instance and simply added.
228
185
  *
229
186
  * @typeParam T - The component type.
230
- * @param params - The registration params.
231
- * @returns The registered component.
187
+ * @param component - The component to add.
188
+ * @returns The added component.
232
189
  */
233
- registerComponent(params) {
234
- const singletonKey = params.component.constructor.COMPONENT_KEY;
190
+ addChild(component) {
191
+ if (this._loaded) {
192
+ return super.addChild(component);
193
+ }
194
+ const singletonKey = component.constructor.COMPONENT_KEY;
235
195
  if (singletonKey) {
236
196
  const oldComponent = this.singletonComponents.get(singletonKey);
237
197
  if (oldComponent) {
238
198
  this.removeChild(oldComponent);
239
- const preloadIndex = this.preloadComponents.indexOf(oldComponent);
240
- if (preloadIndex !== -1) {
241
- this.preloadComponents.splice(preloadIndex, 1);
242
- }
243
199
  }
244
- this.singletonComponents.set(singletonKey, params.component);
200
+ this.singletonComponents.set(singletonKey, component);
245
201
  }
246
- this.addChild(params.component);
247
- if (params.shouldPreload) {
248
- this.preloadComponents.push(params.component);
249
- }
250
- return params.component;
202
+ return super.addChild(component);
251
203
  }
252
- async afterLoad() {
253
- if (this.abortSignalComponent.abortSignal.aborted) {
254
- return;
255
- }
256
- await this.lifecycleEventsComponent.triggerLifecycleEvent("load");
257
- this.app.workspace.onLayoutReady((0, import_async.convertAsyncToSync)(this.onLayoutReadyBase.bind(this)));
204
+ /**
205
+ * Loads the plugin and its components.
206
+ */
207
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises -- Obsidian's load() handles async returns at runtime.
208
+ async load() {
209
+ await (0, import_async_component.loadChildrenFirstAsync)(this);
210
+ this.app.workspace.onLayoutReady(() => {
211
+ (0, import_async.invokeAsyncSafelyAfterDelay)(
212
+ async () => {
213
+ for (const child of this._children) {
214
+ await (0, import_strict_proxy.bypassStrictProxy)(child).onLayoutReady?.();
215
+ }
216
+ },
217
+ 0,
218
+ void 0,
219
+ this.abortSignalComponent.abortSignal
220
+ );
221
+ });
258
222
  }
259
- async onLayoutReadyBase() {
260
- try {
261
- await this.onLayoutReady();
262
- } finally {
263
- await this.lifecycleEventsComponent.triggerLifecycleEvent("layoutReady");
264
- }
223
+ /**
224
+ * Called when the external settings change.
225
+ *
226
+ * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.
227
+ */
228
+ async onExternalSettingsChange() {
229
+ await super.onExternalSettingsChange?.();
230
+ await this.settingsComponent.onExternalSettingsChange();
265
231
  }
266
232
  }
267
233
  async function reloadPlugin(plugin) {
@@ -281,4 +247,4 @@ async function showErrorAndDisablePlugin(plugin, message) {
281
247
  reloadPlugin,
282
248
  showErrorAndDisablePlugin
283
249
  });
284
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/plugin/plugin.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Base class for Obsidian plugins using a component-based architecture.\n *\n * PluginBase registers universal components (context, i18n, error handling, abort signal, lifecycle events, debug).\n * Subclasses add their own components via {@link registerComponent} in their constructor.\n * Any universal component can be replaced by calling {@link registerComponent} with a new instance of the same class.\n */\n\nimport type {\n  App,\n  PluginManifest\n} from 'obsidian';\nimport type { Promisable } from 'type-fest';\n\nimport {\n  Component,\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { PluginSettingsComponentBase } from './components/plugin-settings-component.ts';\n\nimport {\n  convertAsyncToSync,\n  invokeAsyncSafelyAfterDelay\n} from '../../async.ts';\nimport { printError } from '../../error.ts';\nimport { noopAsync } from '../../function.ts';\nimport { AbortSignalComponent } from './components/abort-signal-component.ts';\nimport { AsyncErrorHandlerComponent } from './components/async-error-handler-component.ts';\nimport { ConsoleDebugComponent } from './components/console-debug-component.ts';\nimport { I18nComponent } from './components/i18n-component.ts';\nimport { LifecycleEventsComponent } from './components/lifecycle-events-component.ts';\nimport { PluginContextComponent } from './components/plugin-context-component.ts';\nimport { PluginNoticeComponent } from './components/plugin-notice-component.ts';\nimport { EmptyPluginSettingsComponent } from './components/plugin-settings-component.ts';\n\n/**\n * Params for {@link PluginBase.registerComponent}.\n *\n * @typeParam T - The component type.\n */\nexport interface RegisterComponentParams<T extends Component = Component> {\n  /**\n   * The component to register.\n   */\n  readonly component: T;\n\n  /**\n   * Whether this component should be loaded before the plugin's `onloadImpl()` runs.\n   * Components marked with this flag are force-loaded during `onload()`, ensuring they are\n   * fully initialized before plugin logic executes.\n   */\n  readonly shouldPreload?: boolean;\n}\n\ninterface ComponentClassWithKey {\n  COMPONENT_KEY: symbol;\n}\n\n/**\n * Base class for creating Obsidian plugins with a component-based architecture.\n *\n * Registers universal components automatically. Subclasses add or replace components\n * via {@link registerComponent} in their constructor.\n */\nexport abstract class PluginBase extends ObsidianPlugin {\n  /**\n   * The abort signal component. Aborted when the plugin is unloaded.\n   */\n  protected readonly abortSignalComponent: AbortSignalComponent;\n\n  /**\n   * The console debug component. Provides namespaced debug logging.\n   */\n  protected readonly consoleDebugComponent: ConsoleDebugComponent;\n\n  /**\n   * The lifecycle events component. Provides load, layoutReady, and unload events.\n   */\n  protected readonly lifecycleEventsComponent: LifecycleEventsComponent;\n\n  /**\n   * The notice component. Displays notices to the user.\n   */\n  protected readonly noticeComponent: PluginNoticeComponent;\n\n  /**\n   * The settings component. Manages plugin settings lifecycle.\n   */\n  protected readonly settingsComponent: PluginSettingsComponentBase<object>;\n\n  private readonly preloadComponents: Component[] = [];\n  private readonly singletonComponents = new Map<symbol, Component>();\n\n  /**\n   * Creates a new PluginBase.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n\n    this.registerComponent({ component: new PluginContextComponent(app, manifest.id), shouldPreload: true });\n    this.registerComponent({ component: new I18nComponent(), shouldPreload: true });\n    this.noticeComponent = this.registerComponent({ component: new PluginNoticeComponent(manifest.name) });\n    this.registerComponent({ component: new AsyncErrorHandlerComponent(this.noticeComponent) });\n    this.abortSignalComponent = this.registerComponent({ component: new AbortSignalComponent(manifest.id) });\n    this.consoleDebugComponent = this.registerComponent({ component: new ConsoleDebugComponent(manifest.id) });\n    this.lifecycleEventsComponent = this.registerComponent({ component: new LifecycleEventsComponent(app) });\n    this.settingsComponent = this.registerComponent({ component: new EmptyPluginSettingsComponent(), shouldPreload: true });\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this.settingsComponent.onExternalSettingsChange();\n  }\n\n  /**\n   * Called when the plugin is loaded. Force-loads components that must be ready\n   * before plugin logic, then calls `onloadImpl()`.\n   *\n   * Usually, you don't need to override this method. Override {@link onloadImpl} instead.\n   */\n  public override async onload(): Promise<void> {\n    await super.onload();\n\n    for (const component of this.preloadComponents) {\n      // eslint-disable-next-line @typescript-eslint/no-confusing-void-expression -- Component.load() returns void|Promise at runtime despite void typing.\n      await (component.load() as Promisable<void>);\n    }\n\n    await this.onloadImpl();\n    invokeAsyncSafelyAfterDelay(this.afterLoad.bind(this));\n  }\n\n  /**\n   * Called when the layout is ready.\n   */\n  protected async onLayoutReady(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Called after all pre-load components are initialized. Override this to add plugin-specific logic.\n   *\n   * @remarks It is important to call `super.onloadImpl()` in overridden method.\n   */\n  protected async onloadImpl(): Promise<void> {\n    await noopAsync();\n  }\n\n  /**\n   * Registers a component with the plugin.\n   *\n   * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton \u2014\n   * registering another component with the same key replaces the previous one.\n   * Components without a `COMPONENT_KEY` are multi-instance and simply added.\n   *\n   * @typeParam T - The component type.\n   * @param params - The registration params.\n   * @returns The registered component.\n   */\n  protected registerComponent<T extends Component>(params: RegisterComponentParams<T>): T {\n    const singletonKey = (params.component.constructor as Partial<ComponentClassWithKey>).COMPONENT_KEY;\n\n    if (singletonKey) {\n      const oldComponent = this.singletonComponents.get(singletonKey);\n      if (oldComponent) {\n        this.removeChild(oldComponent);\n        const preloadIndex = this.preloadComponents.indexOf(oldComponent);\n        if (preloadIndex !== -1) {\n          this.preloadComponents.splice(preloadIndex, 1);\n        }\n      }\n      this.singletonComponents.set(singletonKey, params.component);\n    }\n\n    this.addChild(params.component);\n\n    if (params.shouldPreload) {\n      this.preloadComponents.push(params.component);\n    }\n\n    return params.component;\n  }\n\n  private async afterLoad(): Promise<void> {\n    if (this.abortSignalComponent.abortSignal.aborted) {\n      return;\n    }\n    await this.lifecycleEventsComponent.triggerLifecycleEvent('load');\n    this.app.workspace.onLayoutReady(convertAsyncToSync(this.onLayoutReadyBase.bind(this)));\n  }\n\n  private async onLayoutReadyBase(): Promise<void> {\n    try {\n      await this.onLayoutReady();\n    } finally {\n      await this.lifecycleEventsComponent.triggerLifecycleEvent('layoutReady');\n    }\n  }\n}\n\n/**\n * Reloads the specified plugin by disabling and then re-enabling it.\n *\n * @param plugin - The plugin to reload.\n * @returns A {@link Promise} that resolves when the plugin is reloaded.\n */\nexport async function reloadPlugin(plugin: ObsidianPlugin): Promise<void> {\n  const plugins = plugin.app.plugins;\n  const pluginId = plugin.manifest.id;\n  await plugins.disablePlugin(pluginId);\n  await plugins.enablePlugin(pluginId);\n}\n\n/**\n * Displays an error message as a notice, logs it to the console, and disables the specified plugin.\n *\n * @param plugin - The plugin to disable.\n * @param message - The error message to display and log.\n * @returns A {@link Promise} that resolves when the plugin is disabled.\n */\nexport async function showErrorAndDisablePlugin(plugin: ObsidianPlugin, message: string): Promise<void> {\n  new Notice(message);\n  printError(new Error(message));\n  await plugin.app.plugins.disablePlugin(plugin.manifest.id);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBA,sBAIO;AAIP,mBAGO;AACP,mBAA2B;AAC3B,sBAA0B;AAC1B,oCAAqC;AACrC,2CAA2C;AAC3C,qCAAsC;AACtC,4BAA8B;AAC9B,wCAAyC;AACzC,sCAAuC;AACvC,qCAAsC;AACtC,uCAA6C;AA+BtC,MAAe,mBAAmB,gBAAAA,OAAe;AAAA;AAAA;AAAA;AAAA,EAInC;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA,EAEF,oBAAiC,CAAC;AAAA,EAClC,sBAAsB,oBAAI,IAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ3D,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AAEnB,SAAK,kBAAkB,EAAE,WAAW,IAAI,uDAAuB,KAAK,SAAS,EAAE,GAAG,eAAe,KAAK,CAAC;AACvG,SAAK,kBAAkB,EAAE,WAAW,IAAI,oCAAc,GAAG,eAAe,KAAK,CAAC;AAC9E,SAAK,kBAAkB,KAAK,kBAAkB,EAAE,WAAW,IAAI,qDAAsB,SAAS,IAAI,EAAE,CAAC;AACrG,SAAK,kBAAkB,EAAE,WAAW,IAAI,gEAA2B,KAAK,eAAe,EAAE,CAAC;AAC1F,SAAK,uBAAuB,KAAK,kBAAkB,EAAE,WAAW,IAAI,mDAAqB,SAAS,EAAE,EAAE,CAAC;AACvG,SAAK,wBAAwB,KAAK,kBAAkB,EAAE,WAAW,IAAI,qDAAsB,SAAS,EAAE,EAAE,CAAC;AACzG,SAAK,2BAA2B,KAAK,kBAAkB,EAAE,WAAW,IAAI,2DAAyB,GAAG,EAAE,CAAC;AACvG,SAAK,oBAAoB,KAAK,kBAAkB,EAAE,WAAW,IAAI,8DAA6B,GAAG,eAAe,KAAK,CAAC;AAAA,EACxH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,yBAAyB;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAsB,SAAwB;AAC5C,UAAM,MAAM,OAAO;AAEnB,eAAW,aAAa,KAAK,mBAAmB;AAE9C,YAAO,UAAU,KAAK;AAAA,IACxB;AAEA,UAAM,KAAK,WAAW;AACtB,kDAA4B,KAAK,UAAU,KAAK,IAAI,CAAC;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA,EAKA,MAAgB,gBAA+B;AAC7C,cAAM,2BAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAgB,aAA4B;AAC1C,cAAM,2BAAU;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaU,kBAAuC,QAAuC;AACtF,UAAM,eAAgB,OAAO,UAAU,YAA+C;AAEtF,QAAI,cAAc;AAChB,YAAM,eAAe,KAAK,oBAAoB,IAAI,YAAY;AAC9D,UAAI,cAAc;AAChB,aAAK,YAAY,YAAY;AAC7B,cAAM,eAAe,KAAK,kBAAkB,QAAQ,YAAY;AAChE,YAAI,iBAAiB,IAAI;AACvB,eAAK,kBAAkB,OAAO,cAAc,CAAC;AAAA,QAC/C;AAAA,MACF;AACA,WAAK,oBAAoB,IAAI,cAAc,OAAO,SAAS;AAAA,IAC7D;AAEA,SAAK,SAAS,OAAO,SAAS;AAE9B,QAAI,OAAO,eAAe;AACxB,WAAK,kBAAkB,KAAK,OAAO,SAAS;AAAA,IAC9C;AAEA,WAAO,OAAO;AAAA,EAChB;AAAA,EAEA,MAAc,YAA2B;AACvC,QAAI,KAAK,qBAAqB,YAAY,SAAS;AACjD;AAAA,IACF;AACA,UAAM,KAAK,yBAAyB,sBAAsB,MAAM;AAChE,SAAK,IAAI,UAAU,kBAAc,iCAAmB,KAAK,kBAAkB,KAAK,IAAI,CAAC,CAAC;AAAA,EACxF;AAAA,EAEA,MAAc,oBAAmC;AAC/C,QAAI;AACF,YAAM,KAAK,cAAc;AAAA,IAC3B,UAAE;AACA,YAAM,KAAK,yBAAyB,sBAAsB,aAAa;AAAA,IACzE;AAAA,EACF;AACF;AAQA,eAAsB,aAAa,QAAuC;AACxE,QAAM,UAAU,OAAO,IAAI;AAC3B,QAAM,WAAW,OAAO,SAAS;AACjC,QAAM,QAAQ,cAAc,QAAQ;AACpC,QAAM,QAAQ,aAAa,QAAQ;AACrC;AASA,eAAsB,0BAA0B,QAAwB,SAAgC;AACtG,MAAI,uBAAO,OAAO;AAClB,+BAAW,IAAI,MAAM,OAAO,CAAC;AAC7B,QAAM,OAAO,IAAI,QAAQ,cAAc,OAAO,SAAS,EAAE;AAC3D;",
  "names": ["ObsidianPlugin"]
}

250
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../src/obsidian/plugin/plugin.ts"],
  "sourcesContent": ["/**\n * @file\n *\n * Base class for Obsidian plugins using a component-based architecture.\n *\n * PluginBase registers universal components (context, i18n, error handling, abort signal, lifecycle events, debug).\n * Subclasses add their own components via {@link registerComponent} in their constructor.\n * Any universal component can be replaced by calling {@link registerComponent} with a new instance of the same class.\n */\n\nimport type {\n  App,\n  PluginManifest\n} from 'obsidian';\n\nimport {\n  Component,\n  Notice,\n  Plugin as ObsidianPlugin\n} from 'obsidian';\n\nimport type { LayoutReadyComponent } from './components/layout-ready-component.ts';\nimport type { PluginSettingsComponentBase } from './components/plugin-settings-component.ts';\n\nimport { invokeAsyncSafelyAfterDelay } from '../../async.ts';\nimport { printError } from '../../error.ts';\nimport { bypassStrictProxy } from '../../strict-proxy.ts';\nimport { loadChildrenFirstAsync } from '../components/async-component.ts';\nimport { AbortSignalComponent } from './components/abort-signal-component.ts';\nimport { AsyncErrorHandlerComponent } from './components/async-error-handler-component.ts';\nimport { ConsoleDebugComponent } from './components/console-debug-component.ts';\nimport { I18nComponent } from './components/i18n-component.ts';\nimport { PluginContextComponent } from './components/plugin-context-component.ts';\nimport { PluginNoticeComponent } from './components/plugin-notice-component.ts';\nimport { EmptyPluginSettingsComponent } from './components/plugin-settings-component.ts';\n\ninterface ComponentClassWithKey {\n  COMPONENT_KEY: symbol;\n}\n\n/**\n * Base class for creating Obsidian plugins with a component-based architecture.\n *\n * Registers universal components automatically. Subclasses add or replace components\n * via {@link registerComponent} in their constructor.\n */\nexport abstract class PluginBase extends ObsidianPlugin {\n  /**\n   * The abort signal component. Aborted when the plugin is unloaded.\n   */\n  protected readonly abortSignalComponent: AbortSignalComponent;\n\n  /**\n   * The console debug component. Provides namespaced debug logging.\n   */\n  protected readonly consoleDebugComponent: ConsoleDebugComponent;\n\n  /**\n   * The notice component. Displays notices to the user.\n   */\n  protected readonly noticeComponent: PluginNoticeComponent;\n\n  /**\n   * The settings component. Manages plugin settings lifecycle.\n   */\n  protected readonly settingsComponent: PluginSettingsComponentBase<object>;\n\n  private readonly singletonComponents = new Map<symbol, Component>();\n\n  /**\n   * Creates a new PluginBase.\n   *\n   * @param app - The Obsidian app instance.\n   * @param manifest - The plugin manifest.\n   */\n  public constructor(app: App, manifest: PluginManifest) {\n    super(app, manifest);\n\n    this.addChild(new PluginContextComponent(app, manifest.id));\n    this.addChild(new I18nComponent());\n    this.noticeComponent = this.addChild(new PluginNoticeComponent(manifest.name));\n    this.addChild(new AsyncErrorHandlerComponent(this.noticeComponent));\n    this.abortSignalComponent = this.addChild(new AbortSignalComponent(manifest.id));\n    this.consoleDebugComponent = this.addChild(new ConsoleDebugComponent(manifest.id));\n    this.settingsComponent = this.addChild(new EmptyPluginSettingsComponent());\n  }\n\n  /**\n   * Adds a component to the plugin.\n   *\n   * If the component's class defines a static `COMPONENT_KEY` symbol, it is treated as a singleton \u2014\n   * adding another component with the same key replaces the previous one.\n   * Components without a `COMPONENT_KEY` are multi-instance and simply added.\n   *\n   * @typeParam T - The component type.\n   * @param component - The component to add.\n   * @returns The added component.\n   */\n  public override addChild<T extends Component>(component: T): T {\n    if (this._loaded) {\n      return super.addChild(component);\n    }\n\n    const singletonKey = (component.constructor as Partial<ComponentClassWithKey>).COMPONENT_KEY;\n\n    if (singletonKey) {\n      const oldComponent = this.singletonComponents.get(singletonKey);\n      if (oldComponent) {\n        this.removeChild(oldComponent);\n      }\n      this.singletonComponents.set(singletonKey, component);\n    }\n\n    return super.addChild(component);\n  }\n\n  /**\n   * Loads the plugin and its components.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-misused-promises -- Obsidian's load() handles async returns at runtime.\n  public override async load(): Promise<void> {\n    await loadChildrenFirstAsync(this);\n    this.app.workspace.onLayoutReady(() => {\n      invokeAsyncSafelyAfterDelay(\n        async () => {\n          for (const child of this._children) {\n            await (bypassStrictProxy(child) as Partial<LayoutReadyComponent>).onLayoutReady?.();\n          }\n        },\n        0,\n        undefined,\n        this.abortSignalComponent.abortSignal\n      );\n    });\n  }\n\n  /**\n   * Called when the external settings change.\n   *\n   * Override in subclass if needed. Make sure to call `await super.onExternalSettingsChange()` first.\n   */\n  public override async onExternalSettingsChange(): Promise<void> {\n    await super.onExternalSettingsChange?.();\n    await this.settingsComponent.onExternalSettingsChange();\n  }\n}\n\n/**\n * Reloads the specified plugin by disabling and then re-enabling it.\n *\n * @param plugin - The plugin to reload.\n * @returns A {@link Promise} that resolves when the plugin is reloaded.\n */\nexport async function reloadPlugin(plugin: ObsidianPlugin): Promise<void> {\n  const plugins = plugin.app.plugins;\n  const pluginId = plugin.manifest.id;\n  await plugins.disablePlugin(pluginId);\n  await plugins.enablePlugin(pluginId);\n}\n\n/**\n * Displays an error message as a notice, logs it to the console, and disables the specified plugin.\n *\n * @param plugin - The plugin to disable.\n * @param message - The error message to display and log.\n * @returns A {@link Promise} that resolves when the plugin is disabled.\n */\nexport async function showErrorAndDisablePlugin(plugin: ObsidianPlugin, message: string): Promise<void> {\n  new Notice(message);\n  printError(new Error(message));\n  await plugin.app.plugins.disablePlugin(plugin.manifest.id);\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAeA,sBAIO;AAKP,mBAA4C;AAC5C,mBAA2B;AAC3B,0BAAkC;AAClC,6BAAuC;AACvC,oCAAqC;AACrC,2CAA2C;AAC3C,qCAAsC;AACtC,4BAA8B;AAC9B,sCAAuC;AACvC,qCAAsC;AACtC,uCAA6C;AAYtC,MAAe,mBAAmB,gBAAAA,OAAe;AAAA;AAAA;AAAA;AAAA,EAInC;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA;AAAA;AAAA;AAAA,EAKA;AAAA,EAEF,sBAAsB,oBAAI,IAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQ3D,YAAY,KAAU,UAA0B;AACrD,UAAM,KAAK,QAAQ;AAEnB,SAAK,SAAS,IAAI,uDAAuB,KAAK,SAAS,EAAE,CAAC;AAC1D,SAAK,SAAS,IAAI,oCAAc,CAAC;AACjC,SAAK,kBAAkB,KAAK,SAAS,IAAI,qDAAsB,SAAS,IAAI,CAAC;AAC7E,SAAK,SAAS,IAAI,gEAA2B,KAAK,eAAe,CAAC;AAClE,SAAK,uBAAuB,KAAK,SAAS,IAAI,mDAAqB,SAAS,EAAE,CAAC;AAC/E,SAAK,wBAAwB,KAAK,SAAS,IAAI,qDAAsB,SAAS,EAAE,CAAC;AACjF,SAAK,oBAAoB,KAAK,SAAS,IAAI,8DAA6B,CAAC;AAAA,EAC3E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAagB,SAA8B,WAAiB;AAC7D,QAAI,KAAK,SAAS;AAChB,aAAO,MAAM,SAAS,SAAS;AAAA,IACjC;AAEA,UAAM,eAAgB,UAAU,YAA+C;AAE/E,QAAI,cAAc;AAChB,YAAM,eAAe,KAAK,oBAAoB,IAAI,YAAY;AAC9D,UAAI,cAAc;AAChB,aAAK,YAAY,YAAY;AAAA,MAC/B;AACA,WAAK,oBAAoB,IAAI,cAAc,SAAS;AAAA,IACtD;AAEA,WAAO,MAAM,SAAS,SAAS;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAsB,OAAsB;AAC1C,cAAM,+CAAuB,IAAI;AACjC,SAAK,IAAI,UAAU,cAAc,MAAM;AACrC;AAAA,QACE,YAAY;AACV,qBAAW,SAAS,KAAK,WAAW;AAClC,sBAAO,uCAAkB,KAAK,EAAoC,gBAAgB;AAAA,UACpF;AAAA,QACF;AAAA,QACA;AAAA,QACA;AAAA,QACA,KAAK,qBAAqB;AAAA,MAC5B;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAsB,2BAA0C;AAC9D,UAAM,MAAM,2BAA2B;AACvC,UAAM,KAAK,kBAAkB,yBAAyB;AAAA,EACxD;AACF;AAQA,eAAsB,aAAa,QAAuC;AACxE,QAAM,UAAU,OAAO,IAAI;AAC3B,QAAM,WAAW,OAAO,SAAS;AACjC,QAAM,QAAQ,cAAc,QAAQ;AACpC,QAAM,QAAQ,aAAa,QAAQ;AACrC;AASA,eAAsB,0BAA0B,QAAwB,SAAgC;AACtG,MAAI,uBAAO,OAAO;AAClB,+BAAW,IAAI,MAAM,OAAO,CAAC;AAC7B,QAAM,OAAO,IAAI,QAAQ,cAAc,OAAO,SAAS,EAAE;AAC3D;",
  "names": ["ObsidianPlugin"]
}
