obsidian-dev-utils
Version:
This is the collection of useful functions that you can use for your Obsidian plugin development
259 lines (255 loc) • 24.8 kB
JavaScript
/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
(function initEsm() {
if (globalThis.process) {
return;
}
const browserProcess = {
browser: true,
cwd() {
return '/';
},
env: {},
platform: 'android'
};
globalThis.process = browserProcess;
})();
import {
requireApiVersion,
Setting
} from "obsidian";
import { CheckboxComponent } from "./Components/SettingComponents/CheckboxComponent.mjs";
import { CodeHighlighterComponent } from "./Components/SettingComponents/CodeHighlighterComponent.mjs";
import { DateComponent } from "./Components/SettingComponents/DateComponent.mjs";
import { DateTimeComponent } from "./Components/SettingComponents/DateTimeComponent.mjs";
import { EmailComponent } from "./Components/SettingComponents/EmailComponent.mjs";
import { FileComponent } from "./Components/SettingComponents/FileComponent.mjs";
import { MonthComponent } from "./Components/SettingComponents/MonthComponent.mjs";
import { MultipleDropdownComponent } from "./Components/SettingComponents/MultipleDropdownComponent.mjs";
import { MultipleEmailComponent } from "./Components/SettingComponents/MultipleEmailComponent.mjs";
import { MultipleFileComponent } from "./Components/SettingComponents/MultipleFileComponent.mjs";
import { MultipleTextComponent } from "./Components/SettingComponents/MultipleTextComponent.mjs";
import { NumberComponent } from "./Components/SettingComponents/NumberComponent.mjs";
import { PasswordComponent } from "./Components/SettingComponents/PasswordComponent.mjs";
import { TelephoneComponent } from "./Components/SettingComponents/TelephoneComponent.mjs";
import { TimeComponent } from "./Components/SettingComponents/TimeComponent.mjs";
import { TriStateCheckboxComponent } from "./Components/SettingComponents/TriStateCheckboxComponent.mjs";
import { TypedDropdownComponent } from "./Components/SettingComponents/TypedDropdownComponent.mjs";
import { TypedMultipleDropdownComponent } from "./Components/SettingComponents/TypedMultipleDropdownComponent.mjs";
import { UrlComponent } from "./Components/SettingComponents/UrlComponent.mjs";
import { WeekComponent } from "./Components/SettingComponents/WeekComponent.mjs";
class SettingEx extends Setting {
/**
* Adds a {@link CheckboxComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addCheckbox(cb) {
return this.addComponentClass(CheckboxComponent, cb);
}
/**
* Adds a {@link CodeHighlighterComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addCodeHighlighter(cb) {
return this.addComponentClass(CodeHighlighterComponent, cb);
}
/**
* Adds a component to the setting.
*
* @typeParam T - The type of the component to add.
* @param componentClass - The class of the component to add.
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addComponentClass(componentClass, cb) {
return this.addComponentSafe((el) => {
const component = new componentClass(el);
cb(component);
return component;
});
}
/**
* Adds a {@link DateComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addDate(cb) {
return this.addComponentClass(DateComponent, cb);
}
/**
* Adds a {@link DateTimeComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addDateTime(cb) {
return this.addComponentClass(DateTimeComponent, cb);
}
/**
* Adds an {@link EmailComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addEmail(cb) {
return this.addComponentClass(EmailComponent, cb);
}
/**
* Adds a {@link FileComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addFile(cb) {
return this.addComponentClass(FileComponent, cb);
}
/**
* Adds a {@link MonthComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addMonth(cb) {
return this.addComponentClass(MonthComponent, cb);
}
/**
* Adds a {@link MultipleDropdownComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addMultipleDropdown(cb) {
return this.addComponentClass(MultipleDropdownComponent, cb);
}
/**
* Adds a {@link MultipleEmailComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addMultipleEmail(cb) {
return this.addComponentClass(MultipleEmailComponent, cb);
}
/**
* Adds a {@link MultipleFileComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addMultipleFile(cb) {
return this.addComponentClass(MultipleFileComponent, cb);
}
/**
* Adds a {@link MultipleTextComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addMultipleText(cb) {
return this.addComponentClass(MultipleTextComponent, cb);
}
/**
* Adds a {@link NumberComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addNumber(cb) {
return this.addComponentClass(NumberComponent, cb);
}
/**
* Adds a {@link PasswordComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addPassword(cb) {
return this.addComponentClass(PasswordComponent, cb);
}
/**
* Adds a {@link TelephoneComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addTelephone(cb) {
return this.addComponentClass(TelephoneComponent, cb);
}
/**
* Adds a {@link TimeComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addTime(cb) {
return this.addComponentClass(TimeComponent, cb);
}
/**
* Adds a {@link TriStateCheckboxComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addTriStateCheckbox(cb) {
return this.addComponentClass(TriStateCheckboxComponent, cb);
}
/**
* Adds a {@link TypedDropdownComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addTypedDropdown(cb) {
return this.addComponentClass(TypedDropdownComponent, cb);
}
/**
* Adds a {@link TypedMultipleDropdownComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addTypedMultipleDropdown(cb) {
return this.addComponentClass(TypedMultipleDropdownComponent, cb);
}
/**
* Adds an {@link UrlComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addUrl(cb) {
return this.addComponentClass(UrlComponent, cb);
}
/**
* Adds a {@link WeekComponent} to the setting.
*
* @param cb - The callback to call with the component.
* @returns The setting instance.
*/
addWeek(cb) {
return this.addComponentClass(WeekComponent, cb);
}
addComponentSafe(cb) {
if (requireApiVersion("1.11.0")) {
return this.addComponent((el) => {
if (!requireApiVersion("0.16.0")) {
return cb(el);
}
return cb(el);
});
}
this.components.push(cb(this.controlEl));
return this;
}
}
export {
SettingEx
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/obsidian/SettingEx.ts"],
  "sourcesContent": ["/**\n * @packageDocumentation\n *\n * Extends the Setting class with additional methods for adding components.\n */\n\nimport type { BaseComponent } from 'obsidian';\n\nimport {\n  requireApiVersion,\n  Setting\n} from 'obsidian';\n\nimport { CheckboxComponent } from './Components/SettingComponents/CheckboxComponent.ts';\nimport { CodeHighlighterComponent } from './Components/SettingComponents/CodeHighlighterComponent.ts';\nimport { DateComponent } from './Components/SettingComponents/DateComponent.ts';\nimport { DateTimeComponent } from './Components/SettingComponents/DateTimeComponent.ts';\nimport { EmailComponent } from './Components/SettingComponents/EmailComponent.ts';\nimport { FileComponent } from './Components/SettingComponents/FileComponent.ts';\nimport { MonthComponent } from './Components/SettingComponents/MonthComponent.ts';\nimport { MultipleDropdownComponent } from './Components/SettingComponents/MultipleDropdownComponent.ts';\nimport { MultipleEmailComponent } from './Components/SettingComponents/MultipleEmailComponent.ts';\nimport { MultipleFileComponent } from './Components/SettingComponents/MultipleFileComponent.ts';\nimport { MultipleTextComponent } from './Components/SettingComponents/MultipleTextComponent.ts';\nimport { NumberComponent } from './Components/SettingComponents/NumberComponent.ts';\nimport { PasswordComponent } from './Components/SettingComponents/PasswordComponent.ts';\nimport { TelephoneComponent } from './Components/SettingComponents/TelephoneComponent.ts';\nimport { TimeComponent } from './Components/SettingComponents/TimeComponent.ts';\nimport { TriStateCheckboxComponent } from './Components/SettingComponents/TriStateCheckboxComponent.ts';\nimport { TypedDropdownComponent } from './Components/SettingComponents/TypedDropdownComponent.ts';\nimport { TypedMultipleDropdownComponent } from './Components/SettingComponents/TypedMultipleDropdownComponent.ts';\nimport { UrlComponent } from './Components/SettingComponents/UrlComponent.ts';\nimport { WeekComponent } from './Components/SettingComponents/WeekComponent.ts';\n\n/**\n * Extends the Setting class with additional methods for adding components.\n */\nexport class SettingEx extends Setting {\n  /**\n   * Adds a {@link CheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCheckbox(cb: (checkbox: CheckboxComponent) => void): this {\n    return this.addComponentClass(CheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link CodeHighlighterComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addCodeHighlighter(cb: (codeHighlighter: CodeHighlighterComponent) => void): this {\n    return this.addComponentClass(CodeHighlighterComponent, cb);\n  }\n\n  /**\n   * Adds a component to the setting.\n   *\n   * @typeParam T - The type of the component to add.\n   * @param componentClass - The class of the component to add.\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addComponentClass<T extends BaseComponent>(componentClass: new (containerEl: HTMLElement) => T, cb: (component: T) => void): this {\n    return this.addComponentSafe((el) => {\n      const component = new componentClass(el);\n      cb(component);\n      return component;\n    });\n  }\n\n  /**\n   * Adds a {@link DateComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDate(cb: (date: DateComponent) => void): this {\n    return this.addComponentClass(DateComponent, cb);\n  }\n\n  /**\n   * Adds a {@link DateTimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addDateTime(cb: (dateTime: DateTimeComponent) => void): this {\n    return this.addComponentClass(DateTimeComponent, cb);\n  }\n\n  /**\n   * Adds an {@link EmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addEmail(cb: (email: EmailComponent) => void): this {\n    return this.addComponentClass(EmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link FileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addFile(cb: (file: FileComponent) => void): this {\n    return this.addComponentClass(FileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MonthComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMonth(cb: (month: MonthComponent) => void): this {\n    return this.addComponentClass(MonthComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleDropdown(cb: (multipleDropdown: MultipleDropdownComponent) => void): this {\n    return this.addComponentClass(MultipleDropdownComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleEmailComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleEmail(cb: (multipleEmail: MultipleEmailComponent) => void): this {\n    return this.addComponentClass(MultipleEmailComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleFileComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleFile(cb: (multipleFile: MultipleFileComponent) => void): this {\n    return this.addComponentClass(MultipleFileComponent, cb);\n  }\n\n  /**\n   * Adds a {@link MultipleTextComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addMultipleText(cb: (multipleText: MultipleTextComponent) => void): this {\n    return this.addComponentClass(MultipleTextComponent, cb);\n  }\n\n  /**\n   * Adds a {@link NumberComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addNumber(cb: (number: NumberComponent) => void): this {\n    return this.addComponentClass(NumberComponent, cb);\n  }\n\n  /**\n   * Adds a {@link PasswordComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addPassword(cb: (password: PasswordComponent) => void): this {\n    return this.addComponentClass(PasswordComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TelephoneComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTelephone(cb: (telephone: TelephoneComponent) => void): this {\n    return this.addComponentClass(TelephoneComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TimeComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTime(cb: (time: TimeComponent) => void): this {\n    return this.addComponentClass(TimeComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TriStateCheckboxComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTriStateCheckbox(cb: (triStateCheckbox: TriStateCheckboxComponent) => void): this {\n    return this.addComponentClass(TriStateCheckboxComponent, cb);\n  }\n\n  /**\n   * Adds a {@link TypedDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedDropdown<T>(cb: (typedDropdown: TypedDropdownComponent<T>) => void): this {\n    return this.addComponentClass(TypedDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds a {@link TypedMultipleDropdownComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addTypedMultipleDropdown<T>(cb: (typedMultipleDropdown: TypedMultipleDropdownComponent<T>) => void): this {\n    return this.addComponentClass(TypedMultipleDropdownComponent<T>, cb);\n  }\n\n  /**\n   * Adds an {@link UrlComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addUrl(cb: (url: UrlComponent) => void): this {\n    return this.addComponentClass(UrlComponent, cb);\n  }\n\n  /**\n   * Adds a {@link WeekComponent} to the setting.\n   *\n   * @param cb - The callback to call with the component.\n   * @returns The setting instance.\n   */\n  public addWeek(cb: (week: WeekComponent) => void): this {\n    return this.addComponentClass(WeekComponent, cb);\n  }\n\n  private addComponentSafe(cb: (el: HTMLElement) => BaseComponent): this {\n    if (requireApiVersion('1.11.0')) {\n      return this.addComponent((el) => {\n        if (!requireApiVersion('0.16.0')) {\n          return cb(el);\n        }\n        return cb(el);\n      });\n    }\n\n    this.components.push(cb(this.controlEl));\n    return this;\n  }\n}\n"],
  "mappings": "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",
  "names": []
}
