UNPKG

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
/* 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": []
}
