diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/Joplin.d.ts index e30586e68..011168320 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/Joplin.d.ts @@ -8,20 +8,20 @@ import JoplinViews from './JoplinViews'; import JoplinInterop from './JoplinInterop'; import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; +import JoplinClipboard from './JoplinClipboard'; +import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * - * **This is a beta API** + * The API is now relatively stable and in general maintaining backward compatibility is a top priority, so you shouldn't except much breakages. * - * Please note that the plugin API is relatively new and should be considered Beta state. Besides possible bugs, what it means is that there might be necessary breaking changes from one version to the next. Whenever such change is needed, best effort will be done to: + * If a breaking change ever becomes needed, best effort will be done to: * - * - Maintain backward compatibility; - * - When possible, deprecate features instead of removing them; + * - Deprecate features instead of removing them, so as to give you time to fix the issue; * - Document breaking changes in the changelog; * - * So if you are developing a plugin, please keep an eye on the changelog as everything will be in there with information about how to update your code. There won't be any major API rewrite or architecture changes, but possibly small tweaks like function signature change, type change, etc. - * - * Eventually, the plugin API will be versioned to make this process smoother. + * So if you are developing a plugin, please keep an eye on the changelog as everything will be in there with information about how to update your code. */ export default class Joplin { private data_; @@ -33,8 +33,13 @@ export default class Joplin { private interop_; private settings_; private contentScripts_; - constructor(implementation: any, plugin: Plugin, store: any); + private clipboard_; + private window_; + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; + get clipboard(): JoplinClipboard; + get window(): JoplinWindow; get plugins(): JoplinPlugins; get workspace(): JoplinWorkspace; get contentScripts(): JoplinContentScripts; @@ -62,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinClipboard.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinClipboard.d.ts new file mode 100644 index 000000000..3abc4e9df --- /dev/null +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinClipboard.d.ts @@ -0,0 +1,23 @@ +export default class JoplinClipboard { + private electronClipboard_; + private electronNativeImage_; + constructor(electronClipboard: any, electronNativeImage: any); + readText(): Promise; + writeText(text: string): Promise; + readHtml(): Promise; + writeHtml(html: string): Promise; + /** + * Returns the image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format. + */ + readImage(): Promise; + /** + * Takes an image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format. + */ + writeImage(dataUrl: string): Promise; + /** + * Returns the list available formats (mime types). + * + * For example [ 'text/plain', 'text/html' ] + */ + availableFormats(): Promise; +} diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinCommands.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinCommands.d.ts index e4487cf33..babb249c5 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinCommands.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinCommands.d.ts @@ -15,7 +15,7 @@ import { Command } from './types'; * * * [Main screen commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/MainScreen/commands) * * [Global commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/commands) - * * [Editor commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/NoteEditor/commands/editorCommandDeclarations.ts) + * * [Editor commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/NoteEditor/editorCommandDeclarations.ts) * * To view what arguments are supported, you can open any of these files * and look at the `execute()` command. @@ -49,7 +49,7 @@ import { Command } from './types'; * */ export default class JoplinCommands { - /** + /** * desktop Executes the given * command. * @@ -68,8 +68,8 @@ export default class JoplinCommands { * await joplin.commands.execute('newFolder', "SOME_FOLDER_ID"); * ``` */ - execute(commandName: string, ...args: any[]): Promise; - /** + execute(commandName: string, ...args: any[]): Promise; + /** * desktop Registers a new command. * * ```typescript @@ -85,5 +85,5 @@ export default class JoplinCommands { * }); * ``` */ - register(command: Command): Promise; + register(command: Command): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinData.d.ts index fbde6ff9a..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinData.d.ts @@ -1,3 +1,5 @@ +import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -38,10 +40,34 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; post(path: Path, query?: any, body?: any, files?: any[]): Promise; put(path: Path, query?: any, body?: any, files?: any[]): Promise; delete(path: Path, query?: any): Promise; + itemType(itemId: string): Promise; + resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinFilters.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinFilters.d.ts index e086a720e..43bc1b2b7 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinFilters.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinFilters.d.ts @@ -5,6 +5,6 @@ * so for now disable filters. */ export default class JoplinFilters { - on(name: string, callback: Function): Promise; - off(name: string, callback: Function): Promise; + on(name: string, callback: Function): Promise; + off(name: string, callback: Function): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinInterop.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinInterop.d.ts index 1304c7512..8de655c83 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinInterop.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinInterop.d.ts @@ -12,6 +12,6 @@ import { ExportModule, ImportModule } from './types'; * You may also want to refer to the Joplin API documentation to see the list of properties for each item (note, notebook, etc.) - https://joplinapp.org/api/references/rest_api/ */ export default class JoplinInterop { - registerExportModule(module: ExportModule): Promise; - registerImportModule(module: ImportModule): Promise; + registerExportModule(module: ExportModule): Promise; + registerImportModule(module: ImportModule): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinSettings.d.ts index a22b9073c..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent)=> void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsDialogs.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsDialogs.d.ts index 043d488ea..8bc988739 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsDialogs.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsDialogs.d.ts @@ -2,7 +2,7 @@ import Plugin from '../Plugin'; import { ButtonSpec, ViewHandle, DialogResult } from './types'; /** * Allows creating and managing dialogs. A dialog is modal window that - * contains a webview and a row of buttons. You can update the update the + * contains a webview and a row of buttons. You can update the * webview using the `setHtml` method. Dialogs are hidden by default and * you need to call `open()` to open them. Once the user clicks on a * button, the `open` call will return an object indicating what button was @@ -59,4 +59,10 @@ export default class JoplinViewsDialogs { * Opens the dialog */ open(handle: ViewHandle): Promise; + /** + * Toggle on whether to fit the dialog size to the content or not. + * When set to false, the dialog is set to 90vw and 80vh + * @default true + */ + setFitToContent(handle: ViewHandle, status: boolean): Promise; } diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsPanels.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsPanels.d.ts index 20d3e1264..4d4c52701 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsPanels.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinViewsPanels.d.ts @@ -46,6 +46,23 @@ export default class JoplinViewsPanels { * */ onMessage(handle: ViewHandle, callback: Function): Promise; + /** + * Sends a message to the webview. + * + * The webview must have registered a message handler prior, otherwise the message is ignored. Use; + * + * ```javascript + * webviewApi.onMessage((message) => { ... }); + * ``` + * + * - `message` can be any JavaScript object, string or number + * + * The view API may have only one onMessage handler defined. + * This method is fire and forget so no response is returned. + * + * It is particularly useful when the webview needs to react to events emitted by the plugin or the joplin api. + */ + postMessage(handle: ViewHandle, message: any): void; /** * Shows the panel */ diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWindow.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWindow.d.ts new file mode 100644 index 000000000..231c55c3d --- /dev/null +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWindow.d.ts @@ -0,0 +1,24 @@ +import Plugin from '../Plugin'; +export interface Implementation { + injectCustomStyles(elementId: string, cssFilePath: string): Promise; +} +export default class JoplinWindow { + private plugin_; + private store_; + private implementation_; + constructor(implementation: Implementation, plugin: Plugin, store: any); + /** + * Loads a chrome CSS file. It will apply to the window UI elements, except + * for the note viewer. It is the same as the "Custom stylesheet for + * Joplin-wide app styles" setting. See the [Load CSS Demo](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/load_css) + * for an example. + */ + loadChromeCssFile(filePath: string): Promise; + /** + * Loads a note CSS file. It will apply to the note viewer, as well as any + * exported or printed note. It is the same as the "Custom stylesheet for + * rendered Markdown" setting. See the [Load CSS Demo](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/load_css) + * for an example. + */ + loadNoteCssFile(filePath: string): Promise; +} diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWorkspace.d.ts index 229175713..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/JoplinWorkspace.d.ts @@ -1,9 +1,13 @@ import { FolderEntity } from '../../database/types'; -import { Disposable } from './types'; +import { Disposable, MenuItem } from './types'; +export interface EditContextMenuFilterObject { + items: MenuItem[]; +} +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, - Delete = 3, + Delete = 3 } interface ItemChangeEvent { id: string; @@ -12,8 +16,12 @@ interface ItemChangeEvent { interface SyncStartEvent { withErrors: boolean; } -declare type ItemChangeHandler = (event: ItemChangeEvent)=> void; -declare type SyncStartHandler = (event: SyncStartEvent)=> void; +interface ResourceChangeEvent { + id: string; +} +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as @@ -38,6 +46,11 @@ export default class JoplinWorkspace { * Called when the content of the current note changes. */ onNoteChange(handler: ItemChangeHandler): Promise; + /** + * Called when a resource is changed. Currently this handled will not be + * called when a resource is added or deleted. + */ + onResourceChange(handler: ResourceChangeHandler): Promise; /** * Called when an alarm associated with a to-do is triggered. */ @@ -50,6 +63,11 @@ export default class JoplinWorkspace { * Called when the synchronisation process has finished. */ onSyncComplete(callback: Function): Promise; + /** + * Called just before the editor context menu is about to open. Allows + * adding items to it. + */ + filterEditorContextMenu(handler: FilterHandler): void; /** * Gets the currently selected note */ diff --git a/packages/app-cli/tests/support/plugins/clipboard/api/types.ts b/packages/app-cli/tests/support/plugins/clipboard/api/types.ts index 9c4aa7332..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/clipboard/api/types.ts +++ b/packages/app-cli/tests/support/plugins/clipboard/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -202,6 +204,31 @@ export interface Disposable { // dispose():void; } +export enum ModelType { + Note = 1, + Folder = 2, + Setting = 3, + Resource = 4, + Tag = 5, + NoteTag = 6, + Search = 7, + Alarm = 8, + MasterKey = 9, + ItemChange = 10, + NoteResource = 11, + ResourceLocalState = 12, + Revision = 13, + Migration = 14, + SmartFilter = 15, + Command = 16, +} + +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= @@ -269,6 +296,17 @@ export interface MenuItem { */ commandName?: string; + /** + * Arguments that should be passed to the command. They will be as rest + * parameters. + */ + commandArgs?: any[]; + + /** + * Set to "separator" to create a divider line + */ + type?: ('normal' | 'separator' | 'submenu' | 'checkbox' | 'radio'); + /** * Accelerator associated with the menu item */ @@ -334,12 +372,35 @@ export enum SettingItemType { Button = 6, } +export enum SettingItemSubType { + FilePathAndArgs = 'file_path_and_args', + FilePath = 'file_path', // Not supported on mobile! + DirectoryPath = 'directory_path', // Not supported on mobile! +} + +export enum AppType { + Desktop = 'desktop', + Mobile = 'mobile', + Cli = 'cli', +} + +export enum SettingStorage { + Database = 1, + File = 2, +} + // Redefine a simplified interface to mask internal details // and to remove function calls as they would have to be async. export interface SettingItem { value: any; type: SettingItemType; + /** + * Currently only used to display a file or directory selector. Always set + * `type` to `SettingItemType.String` when using this property. + */ + subType?: SettingItemSubType; + label: string; description?: string; @@ -372,7 +433,7 @@ export interface SettingItem { /** * Reserved property. Not used at the moment. */ - appTypes?: string[]; + appTypes?: AppType[]; /** * Set this to `true` to store secure data, such as passwords. Any such @@ -393,6 +454,11 @@ export interface SettingItem { minimum?: number; maximum?: number; step?: number; + + /** + * Either store the setting in the database or in settings.json. Defaults to database. + */ + storage?: SettingStorage; } export interface SettingSection { @@ -419,7 +485,7 @@ export type Path = string[]; // Content Script types // ================================================================= -export type PostMessageHandler = (id: string, message: any)=> Promise; +export type PostMessageHandler = (message: any)=> Promise; /** * When a content script is initialised, it receives a `context` object. diff --git a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/types.ts b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/codemirror_content_script/api/types.ts +++ b/packages/app-cli/tests/support/plugins/codemirror_content_script/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/content_script/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/content_script/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/content_script/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/content_script/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/content_script/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/content_script/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/content_script/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/content_script/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/content_script/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/content_script/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/content_script/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/content_script/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/content_script/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/content_script/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/content_script/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/content_script/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/content_script/api/types.ts b/packages/app-cli/tests/support/plugins/content_script/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/content_script/api/types.ts +++ b/packages/app-cli/tests/support/plugins/content_script/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/dialog/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/dialog/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/dialog/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/dialog/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/dialog/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/dialog/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/dialog/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/dialog/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/dialog/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/dialog/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/dialog/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/dialog/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/dialog/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/dialog/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/dialog/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/dialog/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/dialog/api/types.ts b/packages/app-cli/tests/support/plugins/dialog/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/dialog/api/types.ts +++ b/packages/app-cli/tests/support/plugins/dialog/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/editor_context_menu/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/editor_context_menu/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/editor_context_menu/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/editor_context_menu/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/editor_context_menu/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/editor_context_menu/api/types.ts b/packages/app-cli/tests/support/plugins/editor_context_menu/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/editor_context_menu/api/types.ts +++ b/packages/app-cli/tests/support/plugins/editor_context_menu/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/events/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/events/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/events/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/events/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/events/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/events/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/events/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/events/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/events/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/events/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/events/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/events/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/events/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/events/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/events/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/events/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/events/api/types.ts b/packages/app-cli/tests/support/plugins/events/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/events/api/types.ts +++ b/packages/app-cli/tests/support/plugins/events/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/external_assets/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/external_assets/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/external_assets/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/external_assets/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/external_assets/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/external_assets/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/external_assets/api/types.ts b/packages/app-cli/tests/support/plugins/external_assets/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/external_assets/api/types.ts +++ b/packages/app-cli/tests/support/plugins/external_assets/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/jpl_test/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/jpl_test/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/jpl_test/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/jpl_test/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/jpl_test/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/jpl_test/api/types.ts b/packages/app-cli/tests/support/plugins/jpl_test/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/jpl_test/api/types.ts +++ b/packages/app-cli/tests/support/plugins/jpl_test/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/json_export/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/json_export/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/json_export/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/json_export/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/json_export/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/json_export/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/json_export/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/json_export/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/json_export/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/json_export/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/json_export/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/json_export/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/json_export/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/json_export/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/json_export/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/json_export/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/json_export/api/types.ts b/packages/app-cli/tests/support/plugins/json_export/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/json_export/api/types.ts +++ b/packages/app-cli/tests/support/plugins/json_export/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/load_css/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/Joplin.d.ts index e30586e68..011168320 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/Joplin.d.ts @@ -8,20 +8,20 @@ import JoplinViews from './JoplinViews'; import JoplinInterop from './JoplinInterop'; import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; +import JoplinClipboard from './JoplinClipboard'; +import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * - * **This is a beta API** + * The API is now relatively stable and in general maintaining backward compatibility is a top priority, so you shouldn't except much breakages. * - * Please note that the plugin API is relatively new and should be considered Beta state. Besides possible bugs, what it means is that there might be necessary breaking changes from one version to the next. Whenever such change is needed, best effort will be done to: + * If a breaking change ever becomes needed, best effort will be done to: * - * - Maintain backward compatibility; - * - When possible, deprecate features instead of removing them; + * - Deprecate features instead of removing them, so as to give you time to fix the issue; * - Document breaking changes in the changelog; * - * So if you are developing a plugin, please keep an eye on the changelog as everything will be in there with information about how to update your code. There won't be any major API rewrite or architecture changes, but possibly small tweaks like function signature change, type change, etc. - * - * Eventually, the plugin API will be versioned to make this process smoother. + * So if you are developing a plugin, please keep an eye on the changelog as everything will be in there with information about how to update your code. */ export default class Joplin { private data_; @@ -33,8 +33,13 @@ export default class Joplin { private interop_; private settings_; private contentScripts_; - constructor(implementation: any, plugin: Plugin, store: any); + private clipboard_; + private window_; + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; + get clipboard(): JoplinClipboard; + get window(): JoplinWindow; get plugins(): JoplinPlugins; get workspace(): JoplinWorkspace; get contentScripts(): JoplinContentScripts; @@ -62,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinClipboard.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinClipboard.d.ts new file mode 100644 index 000000000..3abc4e9df --- /dev/null +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinClipboard.d.ts @@ -0,0 +1,23 @@ +export default class JoplinClipboard { + private electronClipboard_; + private electronNativeImage_; + constructor(electronClipboard: any, electronNativeImage: any); + readText(): Promise; + writeText(text: string): Promise; + readHtml(): Promise; + writeHtml(html: string): Promise; + /** + * Returns the image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format. + */ + readImage(): Promise; + /** + * Takes an image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format. + */ + writeImage(dataUrl: string): Promise; + /** + * Returns the list available formats (mime types). + * + * For example [ 'text/plain', 'text/html' ] + */ + availableFormats(): Promise; +} diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinCommands.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinCommands.d.ts index e4487cf33..babb249c5 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinCommands.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinCommands.d.ts @@ -15,7 +15,7 @@ import { Command } from './types'; * * * [Main screen commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/MainScreen/commands) * * [Global commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/commands) - * * [Editor commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/NoteEditor/commands/editorCommandDeclarations.ts) + * * [Editor commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/NoteEditor/editorCommandDeclarations.ts) * * To view what arguments are supported, you can open any of these files * and look at the `execute()` command. @@ -49,7 +49,7 @@ import { Command } from './types'; * */ export default class JoplinCommands { - /** + /** * desktop Executes the given * command. * @@ -68,8 +68,8 @@ export default class JoplinCommands { * await joplin.commands.execute('newFolder', "SOME_FOLDER_ID"); * ``` */ - execute(commandName: string, ...args: any[]): Promise; - /** + execute(commandName: string, ...args: any[]): Promise; + /** * desktop Registers a new command. * * ```typescript @@ -85,5 +85,5 @@ export default class JoplinCommands { * }); * ``` */ - register(command: Command): Promise; + register(command: Command): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinData.d.ts index fbde6ff9a..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinData.d.ts @@ -1,3 +1,5 @@ +import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -38,10 +40,34 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; post(path: Path, query?: any, body?: any, files?: any[]): Promise; put(path: Path, query?: any, body?: any, files?: any[]): Promise; delete(path: Path, query?: any): Promise; + itemType(itemId: string): Promise; + resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinFilters.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinFilters.d.ts index e086a720e..43bc1b2b7 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinFilters.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinFilters.d.ts @@ -5,6 +5,6 @@ * so for now disable filters. */ export default class JoplinFilters { - on(name: string, callback: Function): Promise; - off(name: string, callback: Function): Promise; + on(name: string, callback: Function): Promise; + off(name: string, callback: Function): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinInterop.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinInterop.d.ts index 1304c7512..8de655c83 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinInterop.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinInterop.d.ts @@ -12,6 +12,6 @@ import { ExportModule, ImportModule } from './types'; * You may also want to refer to the Joplin API documentation to see the list of properties for each item (note, notebook, etc.) - https://joplinapp.org/api/references/rest_api/ */ export default class JoplinInterop { - registerExportModule(module: ExportModule): Promise; - registerImportModule(module: ImportModule): Promise; + registerExportModule(module: ExportModule): Promise; + registerImportModule(module: ImportModule): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinSettings.d.ts index a22b9073c..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent)=> void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsDialogs.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsDialogs.d.ts index 043d488ea..8bc988739 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsDialogs.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsDialogs.d.ts @@ -2,7 +2,7 @@ import Plugin from '../Plugin'; import { ButtonSpec, ViewHandle, DialogResult } from './types'; /** * Allows creating and managing dialogs. A dialog is modal window that - * contains a webview and a row of buttons. You can update the update the + * contains a webview and a row of buttons. You can update the * webview using the `setHtml` method. Dialogs are hidden by default and * you need to call `open()` to open them. Once the user clicks on a * button, the `open` call will return an object indicating what button was @@ -59,4 +59,10 @@ export default class JoplinViewsDialogs { * Opens the dialog */ open(handle: ViewHandle): Promise; + /** + * Toggle on whether to fit the dialog size to the content or not. + * When set to false, the dialog is set to 90vw and 80vh + * @default true + */ + setFitToContent(handle: ViewHandle, status: boolean): Promise; } diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsPanels.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsPanels.d.ts index 20d3e1264..4d4c52701 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsPanels.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinViewsPanels.d.ts @@ -46,6 +46,23 @@ export default class JoplinViewsPanels { * */ onMessage(handle: ViewHandle, callback: Function): Promise; + /** + * Sends a message to the webview. + * + * The webview must have registered a message handler prior, otherwise the message is ignored. Use; + * + * ```javascript + * webviewApi.onMessage((message) => { ... }); + * ``` + * + * - `message` can be any JavaScript object, string or number + * + * The view API may have only one onMessage handler defined. + * This method is fire and forget so no response is returned. + * + * It is particularly useful when the webview needs to react to events emitted by the plugin or the joplin api. + */ + postMessage(handle: ViewHandle, message: any): void; /** * Shows the panel */ diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinWindow.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinWindow.d.ts new file mode 100644 index 000000000..231c55c3d --- /dev/null +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinWindow.d.ts @@ -0,0 +1,24 @@ +import Plugin from '../Plugin'; +export interface Implementation { + injectCustomStyles(elementId: string, cssFilePath: string): Promise; +} +export default class JoplinWindow { + private plugin_; + private store_; + private implementation_; + constructor(implementation: Implementation, plugin: Plugin, store: any); + /** + * Loads a chrome CSS file. It will apply to the window UI elements, except + * for the note viewer. It is the same as the "Custom stylesheet for + * Joplin-wide app styles" setting. See the [Load CSS Demo](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/load_css) + * for an example. + */ + loadChromeCssFile(filePath: string): Promise; + /** + * Loads a note CSS file. It will apply to the note viewer, as well as any + * exported or printed note. It is the same as the "Custom stylesheet for + * rendered Markdown" setting. See the [Load CSS Demo](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/load_css) + * for an example. + */ + loadNoteCssFile(filePath: string): Promise; +} diff --git a/packages/app-cli/tests/support/plugins/load_css/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/load_css/api/JoplinWorkspace.d.ts index 229175713..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/JoplinWorkspace.d.ts @@ -1,9 +1,13 @@ import { FolderEntity } from '../../database/types'; -import { Disposable } from './types'; +import { Disposable, MenuItem } from './types'; +export interface EditContextMenuFilterObject { + items: MenuItem[]; +} +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, - Delete = 3, + Delete = 3 } interface ItemChangeEvent { id: string; @@ -12,8 +16,12 @@ interface ItemChangeEvent { interface SyncStartEvent { withErrors: boolean; } -declare type ItemChangeHandler = (event: ItemChangeEvent)=> void; -declare type SyncStartHandler = (event: SyncStartEvent)=> void; +interface ResourceChangeEvent { + id: string; +} +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as @@ -38,6 +46,11 @@ export default class JoplinWorkspace { * Called when the content of the current note changes. */ onNoteChange(handler: ItemChangeHandler): Promise; + /** + * Called when a resource is changed. Currently this handled will not be + * called when a resource is added or deleted. + */ + onResourceChange(handler: ResourceChangeHandler): Promise; /** * Called when an alarm associated with a to-do is triggered. */ @@ -50,6 +63,11 @@ export default class JoplinWorkspace { * Called when the synchronisation process has finished. */ onSyncComplete(callback: Function): Promise; + /** + * Called just before the editor context menu is about to open. Allows + * adding items to it. + */ + filterEditorContextMenu(handler: FilterHandler): void; /** * Gets the currently selected note */ diff --git a/packages/app-cli/tests/support/plugins/load_css/api/types.ts b/packages/app-cli/tests/support/plugins/load_css/api/types.ts index 9c4aa7332..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/load_css/api/types.ts +++ b/packages/app-cli/tests/support/plugins/load_css/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -202,6 +204,31 @@ export interface Disposable { // dispose():void; } +export enum ModelType { + Note = 1, + Folder = 2, + Setting = 3, + Resource = 4, + Tag = 5, + NoteTag = 6, + Search = 7, + Alarm = 8, + MasterKey = 9, + ItemChange = 10, + NoteResource = 11, + ResourceLocalState = 12, + Revision = 13, + Migration = 14, + SmartFilter = 15, + Command = 16, +} + +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= @@ -269,6 +296,17 @@ export interface MenuItem { */ commandName?: string; + /** + * Arguments that should be passed to the command. They will be as rest + * parameters. + */ + commandArgs?: any[]; + + /** + * Set to "separator" to create a divider line + */ + type?: ('normal' | 'separator' | 'submenu' | 'checkbox' | 'radio'); + /** * Accelerator associated with the menu item */ @@ -334,12 +372,35 @@ export enum SettingItemType { Button = 6, } +export enum SettingItemSubType { + FilePathAndArgs = 'file_path_and_args', + FilePath = 'file_path', // Not supported on mobile! + DirectoryPath = 'directory_path', // Not supported on mobile! +} + +export enum AppType { + Desktop = 'desktop', + Mobile = 'mobile', + Cli = 'cli', +} + +export enum SettingStorage { + Database = 1, + File = 2, +} + // Redefine a simplified interface to mask internal details // and to remove function calls as they would have to be async. export interface SettingItem { value: any; type: SettingItemType; + /** + * Currently only used to display a file or directory selector. Always set + * `type` to `SettingItemType.String` when using this property. + */ + subType?: SettingItemSubType; + label: string; description?: string; @@ -372,7 +433,7 @@ export interface SettingItem { /** * Reserved property. Not used at the moment. */ - appTypes?: string[]; + appTypes?: AppType[]; /** * Set this to `true` to store secure data, such as passwords. Any such @@ -393,6 +454,11 @@ export interface SettingItem { minimum?: number; maximum?: number; step?: number; + + /** + * Either store the setting in the database or in settings.json. Defaults to database. + */ + storage?: SettingStorage; } export interface SettingSection { @@ -419,7 +485,7 @@ export type Path = string[]; // Content Script types // ================================================================= -export type PostMessageHandler = (id: string, message: any)=> Promise; +export type PostMessageHandler = (message: any)=> Promise; /** * When a content script is initialised, it receives a `context` object. diff --git a/packages/app-cli/tests/support/plugins/menu/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/menu/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/menu/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/menu/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/menu/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/menu/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/menu/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/menu/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/menu/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/menu/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/menu/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/menu/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/menu/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/menu/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/menu/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/menu/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/menu/api/types.ts b/packages/app-cli/tests/support/plugins/menu/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/menu/api/types.ts +++ b/packages/app-cli/tests/support/plugins/menu/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/multi_selection/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/multi_selection/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/multi_selection/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/multi_selection/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/multi_selection/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/multi_selection/api/types.ts b/packages/app-cli/tests/support/plugins/multi_selection/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/multi_selection/api/types.ts +++ b/packages/app-cli/tests/support/plugins/multi_selection/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/nativeModule/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/nativeModule/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/nativeModule/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/nativeModule/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/nativeModule/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/nativeModule/api/types.ts b/packages/app-cli/tests/support/plugins/nativeModule/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/nativeModule/api/types.ts +++ b/packages/app-cli/tests/support/plugins/nativeModule/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/post_messages/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/post_messages/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/post_messages/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/post_messages/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/post_messages/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/post_messages/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/post_messages/api/types.ts b/packages/app-cli/tests/support/plugins/post_messages/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/post_messages/api/types.ts +++ b/packages/app-cli/tests/support/plugins/post_messages/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/register_command/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/register_command/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/register_command/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/register_command/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/register_command/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/register_command/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/register_command/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/register_command/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/register_command/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/register_command/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/register_command/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/register_command/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/register_command/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/register_command/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/register_command/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/register_command/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/register_command/api/types.ts b/packages/app-cli/tests/support/plugins/register_command/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/register_command/api/types.ts +++ b/packages/app-cli/tests/support/plugins/register_command/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/selected_text/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/selected_text/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/selected_text/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/selected_text/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/selected_text/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/selected_text/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/selected_text/api/types.ts b/packages/app-cli/tests/support/plugins/selected_text/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/selected_text/api/types.ts +++ b/packages/app-cli/tests/support/plugins/selected_text/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/settings/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/settings/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/settings/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/settings/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/settings/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/settings/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/settings/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/settings/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/settings/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/settings/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/settings/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/settings/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/settings/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/settings/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/settings/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/settings/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/settings/api/types.ts b/packages/app-cli/tests/support/plugins/settings/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/settings/api/types.ts +++ b/packages/app-cli/tests/support/plugins/settings/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/toc/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/toc/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/toc/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/toc/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/toc/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/toc/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/toc/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/toc/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/toc/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/toc/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/toc/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/toc/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/toc/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/toc/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/toc/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/toc/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/toc/api/types.ts b/packages/app-cli/tests/support/plugins/toc/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/toc/api/types.ts +++ b/packages/app-cli/tests/support/plugins/toc/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/user_data/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/user_data/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/user_data/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/user_data/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/user_data/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/user_data/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/user_data/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/user_data/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/user_data/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/user_data/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/user_data/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/user_data/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/user_data/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/user_data/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/user_data/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/user_data/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/user_data/api/types.ts b/packages/app-cli/tests/support/plugins/user_data/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/user_data/api/types.ts +++ b/packages/app-cli/tests/support/plugins/user_data/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/app-cli/tests/support/plugins/withExternalModules/api/Joplin.d.ts b/packages/app-cli/tests/support/plugins/withExternalModules/api/Joplin.d.ts index c3a0200d0..011168320 100644 --- a/packages/app-cli/tests/support/plugins/withExternalModules/api/Joplin.d.ts +++ b/packages/app-cli/tests/support/plugins/withExternalModules/api/Joplin.d.ts @@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings'; import JoplinContentScripts from './JoplinContentScripts'; import JoplinClipboard from './JoplinClipboard'; import JoplinWindow from './JoplinWindow'; +import BasePlatformImplementation from '../BasePlatformImplementation'; /** * This is the main entry point to the Joplin API. You can access various services using the provided accessors. * @@ -34,7 +35,8 @@ export default class Joplin { private contentScripts_; private clipboard_; private window_; - constructor(implementation: any, plugin: Plugin, store: any); + private implementation_; + constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any); get data(): JoplinData; get clipboard(): JoplinClipboard; get window(): JoplinWindow; @@ -65,4 +67,5 @@ export default class Joplin { * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule) */ require(_path: string): any; + versionInfo(): Promise; } diff --git a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinData.d.ts b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinData.d.ts index c257ad558..aba4b21c7 100644 --- a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinData.d.ts +++ b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinData.d.ts @@ -1,4 +1,5 @@ import { ModelType } from '../../../BaseModel'; +import Plugin from '../Plugin'; import { Path } from './types'; /** * This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ @@ -39,6 +40,8 @@ import { Path } from './types'; export default class JoplinData { private api_; private pathSegmentRegex_; + private plugin; + constructor(plugin: Plugin); private serializeApiBody; private pathToString; get(path: Path, query?: any): Promise; @@ -47,4 +50,24 @@ export default class JoplinData { delete(path: Path, query?: any): Promise; itemType(itemId: string): Promise; resourcePath(resourceId: string): Promise; + /** + * Gets an item user data. User data are key/value pairs. The `key` can be any + * arbitrary string, while the `value` can be of any type supported by + * [JSON.stringify](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#description) + * + * User data is synchronised across devices, and each value wil be merged based on their timestamp: + * + * - If value is modified by client 1, then modified by client 2, it will take the value from client 2 + * - If value is modified by client 1, then deleted by client 2, the value will be deleted after merge + * - If value is deleted by client 1, then updated by client 2, the value will be restored and set to the value from client 2 after merge + */ + userDataGet(itemType: ModelType, itemId: string, key: string): Promise; + /** + * Sets a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataSet(itemType: ModelType, itemId: string, key: string, value: T): Promise; + /** + * Deletes a note user data. See {@link JoplinData.userDataGet} for more details. + */ + userDataDelete(itemType: ModelType, itemId: string, key: string): Promise; } diff --git a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinSettings.d.ts b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinSettings.d.ts index 74572b7ab..32ce9d4cb 100644 --- a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinSettings.d.ts +++ b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinSettings.d.ts @@ -6,7 +6,7 @@ export interface ChangeEvent { */ keys: string[]; } -export declare type ChangeHandler = (event: ChangeEvent) => void; +export type ChangeHandler = (event: ChangeEvent) => void; /** * 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. * diff --git a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinWorkspace.d.ts b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinWorkspace.d.ts index 0a12e26ed..626d6b6a8 100644 --- a/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinWorkspace.d.ts +++ b/packages/app-cli/tests/support/plugins/withExternalModules/api/JoplinWorkspace.d.ts @@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types'; export interface EditContextMenuFilterObject { items: MenuItem[]; } -declare type FilterHandler = (object: T) => Promise; +type FilterHandler = (object: T) => Promise; declare enum ItemChangeEventType { Create = 1, Update = 2, @@ -19,9 +19,9 @@ interface SyncStartEvent { interface ResourceChangeEvent { id: string; } -declare type ItemChangeHandler = (event: ItemChangeEvent) => void; -declare type SyncStartHandler = (event: SyncStartEvent) => void; -declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; +type ItemChangeHandler = (event: ItemChangeEvent) => void; +type SyncStartHandler = (event: SyncStartEvent) => void; +type ResourceChangeHandler = (event: ResourceChangeEvent) => void; /** * The workspace service provides access to all the parts of Joplin that * are being worked on - i.e. the currently selected notes or notebooks as diff --git a/packages/app-cli/tests/support/plugins/withExternalModules/api/types.ts b/packages/app-cli/tests/support/plugins/withExternalModules/api/types.ts index 640d08399..faef49187 100644 --- a/packages/app-cli/tests/support/plugins/withExternalModules/api/types.ts +++ b/packages/app-cli/tests/support/plugins/withExternalModules/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= @@ -221,6 +223,12 @@ export enum ModelType { Command = 16, } +export interface VersionInfo { + version: string; + profileVersion: number; + syncVersion: number; +} + // ================================================================= // Menu types // ================================================================= diff --git a/packages/generator-joplin/generators/app/templates/api/types.ts b/packages/generator-joplin/generators/app/templates/api/types.ts index f8ac2cf29..faef49187 100644 --- a/packages/generator-joplin/generators/app/templates/api/types.ts +++ b/packages/generator-joplin/generators/app/templates/api/types.ts @@ -1,3 +1,5 @@ +/* eslint-disable multiline-comment-style */ + // ================================================================= // Command API types // ================================================================= diff --git a/packages/generator-joplin/updateTypesAndDemos.sh b/packages/generator-joplin/updateTypesAndDemos.sh index 836c5014b..14eea8659 100755 --- a/packages/generator-joplin/updateTypesAndDemos.sh +++ b/packages/generator-joplin/updateTypesAndDemos.sh @@ -23,7 +23,6 @@ for DIR in $TEST_PLUGINS_DIR/*/ ; do echo "Updating $DIR/api/..." rsync -a "$API_SOURCE_DIR/" "$DIR/api/" fi - exit done