2020-10-21 00:23:55 +01:00
|
|
|
import Plugin from '../Plugin';
|
|
|
|
import { SettingItem, SettingSection } from './types';
|
2021-01-11 23:34:06 +00:00
|
|
|
export interface ChangeEvent {
|
|
|
|
/**
|
|
|
|
* Setting keys that have been changed
|
|
|
|
*/
|
|
|
|
keys: string[];
|
|
|
|
}
|
2023-09-16 12:04:33 +01:00
|
|
|
export type ChangeHandler = (event: ChangeEvent) => void;
|
2020-10-21 00:23:55 +01:00
|
|
|
/**
|
|
|
|
* This API allows registering new settings and setting sections, as well as getting and setting settings. Once a setting has been registered it will appear in the config screen and be editable by the user.
|
|
|
|
*
|
|
|
|
* Settings are essentially key/value pairs.
|
|
|
|
*
|
|
|
|
* Note: Currently this API does **not** provide access to Joplin's built-in settings. This is by design as plugins that modify user settings could give unexpected results
|
|
|
|
*
|
2020-11-13 17:09:28 +00:00
|
|
|
* [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/settings)
|
2020-10-21 00:23:55 +01:00
|
|
|
*/
|
|
|
|
export default class JoplinSettings {
|
|
|
|
private plugin_;
|
|
|
|
constructor(plugin: Plugin);
|
|
|
|
/**
|
2021-05-10 11:33:28 +02:00
|
|
|
* Registers new settings.
|
|
|
|
* Note that registering a setting item is dynamic and will be gone next time Joplin starts.
|
2020-10-21 00:23:55 +01:00
|
|
|
* What it means is that you need to register the setting every time the plugin starts (for example in the onStart event).
|
|
|
|
* The setting value however will be preserved from one launch to the next so there is no risk that it will be lost even if for some
|
|
|
|
* reason the plugin fails to start at some point.
|
|
|
|
*/
|
2021-05-10 11:33:28 +02:00
|
|
|
registerSettings(settings: Record<string, SettingItem>): Promise<void>;
|
|
|
|
/**
|
|
|
|
* @deprecated Use joplin.settings.registerSettings()
|
|
|
|
*
|
|
|
|
* Registers a new setting.
|
|
|
|
*/
|
2020-10-21 00:23:55 +01:00
|
|
|
registerSetting(key: string, settingItem: SettingItem): Promise<void>;
|
|
|
|
/**
|
|
|
|
* Registers a new setting section. Like for registerSetting, it is dynamic and needs to be done every time the plugin starts.
|
|
|
|
*/
|
|
|
|
registerSection(name: string, section: SettingSection): Promise<void>;
|
|
|
|
/**
|
2024-11-17 16:38:07 +00:00
|
|
|
* Gets setting values (only applies to setting you registered from your plugin)
|
|
|
|
*/
|
|
|
|
values(keys: string[] | string): Promise<Record<string, unknown>>;
|
|
|
|
/**
|
|
|
|
* @deprecated Use joplin.settings.values()
|
|
|
|
*
|
2020-10-21 00:23:55 +01:00
|
|
|
* Gets a setting value (only applies to setting you registered from your plugin)
|
|
|
|
*/
|
|
|
|
value(key: string): Promise<any>;
|
|
|
|
/**
|
|
|
|
* Sets a setting value (only applies to setting you registered from your plugin)
|
|
|
|
*/
|
|
|
|
setValue(key: string, value: any): Promise<void>;
|
|
|
|
/**
|
|
|
|
* Gets a global setting value, including app-specific settings and those set by other plugins.
|
|
|
|
*
|
|
|
|
* The list of available settings is not documented yet, but can be found by looking at the source code:
|
|
|
|
*
|
2020-12-11 13:28:59 +00:00
|
|
|
* https://github.com/laurent22/joplin/blob/dev/packages/lib/models/Setting.ts#L142
|
2020-10-21 00:23:55 +01:00
|
|
|
*/
|
|
|
|
globalValue(key: string): Promise<any>;
|
2021-01-11 23:34:06 +00:00
|
|
|
/**
|
|
|
|
* Called when one or multiple settings of your plugin have been changed.
|
|
|
|
* - For performance reasons, this event is triggered with a delay.
|
|
|
|
* - You will only get events for your own plugin settings.
|
|
|
|
*/
|
|
|
|
onChange(handler: ChangeHandler): Promise<void>;
|
2020-10-21 00:23:55 +01:00
|
|
|
}
|