Chore: Update plugin demo types

pull/8889/head
Laurent Cozic 2023-09-16 12:04:33 +01:00
parent 20f46c75c4
commit 087490500b
116 changed files with 1144 additions and 159 deletions

View File

@ -8,20 +8,20 @@ import JoplinViews from './JoplinViews';
import JoplinInterop from './JoplinInterop'; import JoplinInterop from './JoplinInterop';
import JoplinSettings from './JoplinSettings'; import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; 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 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; * - Deprecate features instead of removing them, so as to give you time to fix the issue;
* - When possible, deprecate features instead of removing them;
* - Document breaking changes in the changelog; * - 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. * 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.
*
* Eventually, the plugin API will be versioned to make this process smoother.
*/ */
export default class Joplin { export default class Joplin {
private data_; private data_;
@ -33,8 +33,13 @@ export default class Joplin {
private interop_; private interop_;
private settings_; private settings_;
private contentScripts_; 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 data(): JoplinData;
get clipboard(): JoplinClipboard;
get window(): JoplinWindow;
get plugins(): JoplinPlugins; get plugins(): JoplinPlugins;
get workspace(): JoplinWorkspace; get workspace(): JoplinWorkspace;
get contentScripts(): JoplinContentScripts; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -0,0 +1,23 @@
export default class JoplinClipboard {
private electronClipboard_;
private electronNativeImage_;
constructor(electronClipboard: any, electronNativeImage: any);
readText(): Promise<string>;
writeText(text: string): Promise<void>;
readHtml(): Promise<string>;
writeHtml(html: string): Promise<void>;
/**
* Returns the image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format.
*/
readImage(): Promise<string>;
/**
* 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<void>;
/**
* Returns the list available formats (mime types).
*
* For example [ 'text/plain', 'text/html' ]
*/
availableFormats(): Promise<string[]>;
}

View File

@ -15,7 +15,7 @@ import { Command } from './types';
* *
* * [Main screen commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/MainScreen/commands) * * [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) * * [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 * To view what arguments are supported, you can open any of these files
* and look at the `execute()` command. * and look at the `execute()` command.
@ -49,7 +49,7 @@ import { Command } from './types';
* *
*/ */
export default class JoplinCommands { export default class JoplinCommands {
/** /**
* <span class="platform-desktop">desktop</span> Executes the given * <span class="platform-desktop">desktop</span> Executes the given
* command. * command.
* *
@ -68,8 +68,8 @@ export default class JoplinCommands {
* await joplin.commands.execute('newFolder', "SOME_FOLDER_ID"); * await joplin.commands.execute('newFolder', "SOME_FOLDER_ID");
* ``` * ```
*/ */
execute(commandName: string, ...args: any[]): Promise<any | void>; execute(commandName: string, ...args: any[]): Promise<any | void>;
/** /**
* <span class="platform-desktop">desktop</span> Registers a new command. * <span class="platform-desktop">desktop</span> Registers a new command.
* *
* ```typescript * ```typescript
@ -85,5 +85,5 @@ export default class JoplinCommands {
* }); * });
* ``` * ```
*/ */
register(command: Command): Promise<void>; register(command: Command): Promise<void>;
} }

View File

@ -1,3 +1,5 @@
import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
post(path: Path, query?: any, body?: any, files?: any[]): Promise<any>; post(path: Path, query?: any, body?: any, files?: any[]): Promise<any>;
put(path: Path, query?: any, body?: any, files?: any[]): Promise<any>; put(path: Path, query?: any, body?: any, files?: any[]): Promise<any>;
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -5,6 +5,6 @@
* so for now disable filters. * so for now disable filters.
*/ */
export default class JoplinFilters { export default class JoplinFilters {
on(name: string, callback: Function): Promise<void>; on(name: string, callback: Function): Promise<void>;
off(name: string, callback: Function): Promise<void>; off(name: string, callback: Function): Promise<void>;
} }

View File

@ -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/ * 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 { export default class JoplinInterop {
registerExportModule(module: ExportModule): Promise<void>; registerExportModule(module: ExportModule): Promise<void>;
registerImportModule(module: ImportModule): Promise<void>; registerImportModule(module: ImportModule): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -2,7 +2,7 @@ import Plugin from '../Plugin';
import { ButtonSpec, ViewHandle, DialogResult } from './types'; import { ButtonSpec, ViewHandle, DialogResult } from './types';
/** /**
* Allows creating and managing dialogs. A dialog is modal window that * 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 * 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 * 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 * button, the `open` call will return an object indicating what button was
@ -59,4 +59,10 @@ export default class JoplinViewsDialogs {
* Opens the dialog * Opens the dialog
*/ */
open(handle: ViewHandle): Promise<DialogResult>; open(handle: ViewHandle): Promise<DialogResult>;
/**
* 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<boolean>;
} }

View File

@ -46,6 +46,23 @@ export default class JoplinViewsPanels {
* *
*/ */
onMessage(handle: ViewHandle, callback: Function): Promise<void>; onMessage(handle: ViewHandle, callback: Function): Promise<void>;
/**
* 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 * Shows the panel
*/ */

View File

@ -0,0 +1,24 @@
import Plugin from '../Plugin';
export interface Implementation {
injectCustomStyles(elementId: string, cssFilePath: string): Promise<void>;
}
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<void>;
/**
* 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<void>;
}

View File

@ -1,9 +1,13 @@
import { FolderEntity } from '../../database/types'; import { FolderEntity } from '../../database/types';
import { Disposable } from './types'; import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject {
items: MenuItem[];
}
type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
Delete = 3, Delete = 3
} }
interface ItemChangeEvent { interface ItemChangeEvent {
id: string; id: string;
@ -12,8 +16,12 @@ interface ItemChangeEvent {
interface SyncStartEvent { interface SyncStartEvent {
withErrors: boolean; withErrors: boolean;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent)=> void; interface ResourceChangeEvent {
declare type SyncStartHandler = (event: SyncStartEvent)=> void; 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 * 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 * 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. * Called when the content of the current note changes.
*/ */
onNoteChange(handler: ItemChangeHandler): Promise<Disposable>; onNoteChange(handler: ItemChangeHandler): Promise<Disposable>;
/**
* Called when a resource is changed. Currently this handled will not be
* called when a resource is added or deleted.
*/
onResourceChange(handler: ResourceChangeHandler): Promise<void>;
/** /**
* Called when an alarm associated with a to-do is triggered. * 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. * Called when the synchronisation process has finished.
*/ */
onSyncComplete(callback: Function): Promise<Disposable>; onSyncComplete(callback: Function): Promise<Disposable>;
/**
* Called just before the editor context menu is about to open. Allows
* adding items to it.
*/
filterEditorContextMenu(handler: FilterHandler<EditContextMenuFilterObject>): void;
/** /**
* Gets the currently selected note * Gets the currently selected note
*/ */

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -202,6 +204,31 @@ export interface Disposable {
// dispose():void; // 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 // Menu types
// ================================================================= // =================================================================
@ -269,6 +296,17 @@ export interface MenuItem {
*/ */
commandName?: string; 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 * Accelerator associated with the menu item
*/ */
@ -334,12 +372,35 @@ export enum SettingItemType {
Button = 6, 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 // Redefine a simplified interface to mask internal details
// and to remove function calls as they would have to be async. // and to remove function calls as they would have to be async.
export interface SettingItem { export interface SettingItem {
value: any; value: any;
type: SettingItemType; 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; label: string;
description?: string; description?: string;
@ -372,7 +433,7 @@ export interface SettingItem {
/** /**
* Reserved property. Not used at the moment. * Reserved property. Not used at the moment.
*/ */
appTypes?: string[]; appTypes?: AppType[];
/** /**
* Set this to `true` to store secure data, such as passwords. Any such * Set this to `true` to store secure data, such as passwords. Any such
@ -393,6 +454,11 @@ export interface SettingItem {
minimum?: number; minimum?: number;
maximum?: number; maximum?: number;
step?: number; step?: number;
/**
* Either store the setting in the database or in settings.json. Defaults to database.
*/
storage?: SettingStorage;
} }
export interface SettingSection { export interface SettingSection {
@ -419,7 +485,7 @@ export type Path = string[];
// Content Script types // Content Script types
// ================================================================= // =================================================================
export type PostMessageHandler = (id: string, message: any)=> Promise<any>; export type PostMessageHandler = (message: any)=> Promise<any>;
/** /**
* When a content script is initialised, it receives a `context` object. * When a content script is initialised, it receives a `context` object.

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -8,20 +8,20 @@ import JoplinViews from './JoplinViews';
import JoplinInterop from './JoplinInterop'; import JoplinInterop from './JoplinInterop';
import JoplinSettings from './JoplinSettings'; import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; 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 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; * - Deprecate features instead of removing them, so as to give you time to fix the issue;
* - When possible, deprecate features instead of removing them;
* - Document breaking changes in the changelog; * - 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. * 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.
*
* Eventually, the plugin API will be versioned to make this process smoother.
*/ */
export default class Joplin { export default class Joplin {
private data_; private data_;
@ -33,8 +33,13 @@ export default class Joplin {
private interop_; private interop_;
private settings_; private settings_;
private contentScripts_; 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 data(): JoplinData;
get clipboard(): JoplinClipboard;
get window(): JoplinWindow;
get plugins(): JoplinPlugins; get plugins(): JoplinPlugins;
get workspace(): JoplinWorkspace; get workspace(): JoplinWorkspace;
get contentScripts(): JoplinContentScripts; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -0,0 +1,23 @@
export default class JoplinClipboard {
private electronClipboard_;
private electronNativeImage_;
constructor(electronClipboard: any, electronNativeImage: any);
readText(): Promise<string>;
writeText(text: string): Promise<void>;
readHtml(): Promise<string>;
writeHtml(html: string): Promise<void>;
/**
* Returns the image in [data URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs) format.
*/
readImage(): Promise<string>;
/**
* 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<void>;
/**
* Returns the list available formats (mime types).
*
* For example [ 'text/plain', 'text/html' ]
*/
availableFormats(): Promise<string[]>;
}

View File

@ -15,7 +15,7 @@ import { Command } from './types';
* *
* * [Main screen commands](https://github.com/laurent22/joplin/tree/dev/packages/app-desktop/gui/MainScreen/commands) * * [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) * * [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 * To view what arguments are supported, you can open any of these files
* and look at the `execute()` command. * and look at the `execute()` command.
@ -49,7 +49,7 @@ import { Command } from './types';
* *
*/ */
export default class JoplinCommands { export default class JoplinCommands {
/** /**
* <span class="platform-desktop">desktop</span> Executes the given * <span class="platform-desktop">desktop</span> Executes the given
* command. * command.
* *
@ -68,8 +68,8 @@ export default class JoplinCommands {
* await joplin.commands.execute('newFolder', "SOME_FOLDER_ID"); * await joplin.commands.execute('newFolder', "SOME_FOLDER_ID");
* ``` * ```
*/ */
execute(commandName: string, ...args: any[]): Promise<any | void>; execute(commandName: string, ...args: any[]): Promise<any | void>;
/** /**
* <span class="platform-desktop">desktop</span> Registers a new command. * <span class="platform-desktop">desktop</span> Registers a new command.
* *
* ```typescript * ```typescript
@ -85,5 +85,5 @@ export default class JoplinCommands {
* }); * });
* ``` * ```
*/ */
register(command: Command): Promise<void>; register(command: Command): Promise<void>;
} }

View File

@ -1,3 +1,5 @@
import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
post(path: Path, query?: any, body?: any, files?: any[]): Promise<any>; post(path: Path, query?: any, body?: any, files?: any[]): Promise<any>;
put(path: Path, query?: any, body?: any, files?: any[]): Promise<any>; put(path: Path, query?: any, body?: any, files?: any[]): Promise<any>;
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -5,6 +5,6 @@
* so for now disable filters. * so for now disable filters.
*/ */
export default class JoplinFilters { export default class JoplinFilters {
on(name: string, callback: Function): Promise<void>; on(name: string, callback: Function): Promise<void>;
off(name: string, callback: Function): Promise<void>; off(name: string, callback: Function): Promise<void>;
} }

View File

@ -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/ * 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 { export default class JoplinInterop {
registerExportModule(module: ExportModule): Promise<void>; registerExportModule(module: ExportModule): Promise<void>;
registerImportModule(module: ImportModule): Promise<void>; registerImportModule(module: ImportModule): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -2,7 +2,7 @@ import Plugin from '../Plugin';
import { ButtonSpec, ViewHandle, DialogResult } from './types'; import { ButtonSpec, ViewHandle, DialogResult } from './types';
/** /**
* Allows creating and managing dialogs. A dialog is modal window that * 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 * 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 * 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 * button, the `open` call will return an object indicating what button was
@ -59,4 +59,10 @@ export default class JoplinViewsDialogs {
* Opens the dialog * Opens the dialog
*/ */
open(handle: ViewHandle): Promise<DialogResult>; open(handle: ViewHandle): Promise<DialogResult>;
/**
* 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<boolean>;
} }

View File

@ -46,6 +46,23 @@ export default class JoplinViewsPanels {
* *
*/ */
onMessage(handle: ViewHandle, callback: Function): Promise<void>; onMessage(handle: ViewHandle, callback: Function): Promise<void>;
/**
* 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 * Shows the panel
*/ */

View File

@ -0,0 +1,24 @@
import Plugin from '../Plugin';
export interface Implementation {
injectCustomStyles(elementId: string, cssFilePath: string): Promise<void>;
}
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<void>;
/**
* 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<void>;
}

View File

@ -1,9 +1,13 @@
import { FolderEntity } from '../../database/types'; import { FolderEntity } from '../../database/types';
import { Disposable } from './types'; import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject {
items: MenuItem[];
}
type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
Delete = 3, Delete = 3
} }
interface ItemChangeEvent { interface ItemChangeEvent {
id: string; id: string;
@ -12,8 +16,12 @@ interface ItemChangeEvent {
interface SyncStartEvent { interface SyncStartEvent {
withErrors: boolean; withErrors: boolean;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent)=> void; interface ResourceChangeEvent {
declare type SyncStartHandler = (event: SyncStartEvent)=> void; 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 * 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 * 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. * Called when the content of the current note changes.
*/ */
onNoteChange(handler: ItemChangeHandler): Promise<Disposable>; onNoteChange(handler: ItemChangeHandler): Promise<Disposable>;
/**
* Called when a resource is changed. Currently this handled will not be
* called when a resource is added or deleted.
*/
onResourceChange(handler: ResourceChangeHandler): Promise<void>;
/** /**
* Called when an alarm associated with a to-do is triggered. * 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. * Called when the synchronisation process has finished.
*/ */
onSyncComplete(callback: Function): Promise<Disposable>; onSyncComplete(callback: Function): Promise<Disposable>;
/**
* Called just before the editor context menu is about to open. Allows
* adding items to it.
*/
filterEditorContextMenu(handler: FilterHandler<EditContextMenuFilterObject>): void;
/** /**
* Gets the currently selected note * Gets the currently selected note
*/ */

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -202,6 +204,31 @@ export interface Disposable {
// dispose():void; // 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 // Menu types
// ================================================================= // =================================================================
@ -269,6 +296,17 @@ export interface MenuItem {
*/ */
commandName?: string; 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 * Accelerator associated with the menu item
*/ */
@ -334,12 +372,35 @@ export enum SettingItemType {
Button = 6, 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 // Redefine a simplified interface to mask internal details
// and to remove function calls as they would have to be async. // and to remove function calls as they would have to be async.
export interface SettingItem { export interface SettingItem {
value: any; value: any;
type: SettingItemType; 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; label: string;
description?: string; description?: string;
@ -372,7 +433,7 @@ export interface SettingItem {
/** /**
* Reserved property. Not used at the moment. * Reserved property. Not used at the moment.
*/ */
appTypes?: string[]; appTypes?: AppType[];
/** /**
* Set this to `true` to store secure data, such as passwords. Any such * Set this to `true` to store secure data, such as passwords. Any such
@ -393,6 +454,11 @@ export interface SettingItem {
minimum?: number; minimum?: number;
maximum?: number; maximum?: number;
step?: number; step?: number;
/**
* Either store the setting in the database or in settings.json. Defaults to database.
*/
storage?: SettingStorage;
} }
export interface SettingSection { export interface SettingSection {
@ -419,7 +485,7 @@ export type Path = string[];
// Content Script types // Content Script types
// ================================================================= // =================================================================
export type PostMessageHandler = (id: string, message: any)=> Promise<any>; export type PostMessageHandler = (message: any)=> Promise<any>;
/** /**
* When a content script is initialised, it receives a `context` object. * When a content script is initialised, it receives a `context` object.

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

View File

@ -1,4 +1,5 @@
import { ModelType } from '../../../BaseModel'; import { ModelType } from '../../../BaseModel';
import Plugin from '../Plugin';
import { Path } from './types'; import { Path } from './types';
/** /**
* This module provides access to the Joplin data API: https://joplinapp.org/api/references/rest_api/ * 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 { export default class JoplinData {
private api_; private api_;
private pathSegmentRegex_; private pathSegmentRegex_;
private plugin;
constructor(plugin: Plugin);
private serializeApiBody; private serializeApiBody;
private pathToString; private pathToString;
get(path: Path, query?: any): Promise<any>; get(path: Path, query?: any): Promise<any>;
@ -47,4 +50,24 @@ export default class JoplinData {
delete(path: Path, query?: any): Promise<any>; delete(path: Path, query?: any): Promise<any>;
itemType(itemId: string): Promise<ModelType>; itemType(itemId: string): Promise<ModelType>;
resourcePath(resourceId: string): Promise<string>; resourcePath(resourceId: string): Promise<string>;
/**
* 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<T>(itemType: ModelType, itemId: string, key: string): Promise<T>;
/**
* Sets a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataSet<T>(itemType: ModelType, itemId: string, key: string, value: T): Promise<void>;
/**
* Deletes a note user data. See {@link JoplinData.userDataGet} for more details.
*/
userDataDelete(itemType: ModelType, itemId: string, key: string): Promise<void>;
} }

View File

@ -6,7 +6,7 @@ export interface ChangeEvent {
*/ */
keys: string[]; 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. * 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.
* *

View File

@ -3,7 +3,7 @@ import { Disposable, MenuItem } from './types';
export interface EditContextMenuFilterObject { export interface EditContextMenuFilterObject {
items: MenuItem[]; items: MenuItem[];
} }
declare type FilterHandler<T> = (object: T) => Promise<void>; type FilterHandler<T> = (object: T) => Promise<void>;
declare enum ItemChangeEventType { declare enum ItemChangeEventType {
Create = 1, Create = 1,
Update = 2, Update = 2,
@ -19,9 +19,9 @@ interface SyncStartEvent {
interface ResourceChangeEvent { interface ResourceChangeEvent {
id: string; id: string;
} }
declare type ItemChangeHandler = (event: ItemChangeEvent) => void; type ItemChangeHandler = (event: ItemChangeEvent) => void;
declare type SyncStartHandler = (event: SyncStartEvent) => void; type SyncStartHandler = (event: SyncStartEvent) => void;
declare type ResourceChangeHandler = (event: ResourceChangeEvent) => void; type ResourceChangeHandler = (event: ResourceChangeEvent) => void;
/** /**
* The workspace service provides access to all the parts of Joplin that * 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 * are being worked on - i.e. the currently selected notes or notebooks as

View File

@ -1,3 +1,5 @@
/* eslint-disable multiline-comment-style */
// ================================================================= // =================================================================
// Command API types // Command API types
// ================================================================= // =================================================================
@ -221,6 +223,12 @@ export enum ModelType {
Command = 16, Command = 16,
} }
export interface VersionInfo {
version: string;
profileVersion: number;
syncVersion: number;
}
// ================================================================= // =================================================================
// Menu types // Menu types
// ================================================================= // =================================================================

View File

@ -10,6 +10,7 @@ import JoplinSettings from './JoplinSettings';
import JoplinContentScripts from './JoplinContentScripts'; import JoplinContentScripts from './JoplinContentScripts';
import JoplinClipboard from './JoplinClipboard'; import JoplinClipboard from './JoplinClipboard';
import JoplinWindow from './JoplinWindow'; 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 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 contentScripts_;
private clipboard_; private clipboard_;
private window_; private window_;
constructor(implementation: any, plugin: Plugin, store: any); private implementation_;
constructor(implementation: BasePlatformImplementation, plugin: Plugin, store: any);
get data(): JoplinData; get data(): JoplinData;
get clipboard(): JoplinClipboard; get clipboard(): JoplinClipboard;
get window(): JoplinWindow; 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) * [View the demo plugin](https://github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/nativeModule)
*/ */
require(_path: string): any; require(_path: string): any;
versionInfo(): Promise<import("./types").VersionInfo>;
} }

Some files were not shown because too many files have changed in this diff Show More