You've already forked joplin
mirror of
https://github.com/laurent22/joplin.git
synced 2025-06-27 23:28:38 +02:00
Plugins: Added support for content scripts
- For now, supports Markdown-it plugins - Also fixed slow rendering of notes in some cases - Simplified how Markdown-It plugins are created and cleaned MdToHtml code commit89576de289
Merge:c75aa21f
5292fc14
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:23:00 2020 +0100 Merge branch 'release-1.3' into plugin_content_scripts commitc75aa21ffd
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:19:52 2020 +0100 Fixed tests commit075187729d
Author: Laurent Cozic <laurent@cozic.net> Date: Wed Oct 21 00:11:53 2020 +0100 Fixed tests commit14696b8c65
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 23:27:58 2020 +0100 Fixed slow rendering of note commit61c09f5bf8
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 22:35:21 2020 +0100 Clean up commit9f7ea7d865
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 20:05:31 2020 +0100 Updated doc commit98bf3bde8d
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 19:56:34 2020 +0100 Finished converting plugins commitfe90d92e01
Author: Laurent Cozic <laurent@cozic.net> Date: Tue Oct 20 17:52:02 2020 +0100 Simplified how Markdown-It plugins are created commit47c7b864cb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 16:40:11 2020 +0100 Clean up rules commitd927a238bb
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:29:40 2020 +0100 Fixed tests commit388a56c5dd
Author: Laurent Cozic <laurent@cozic.net> Date: Mon Oct 19 14:00:47 2020 +0100 Add support for content scripts
This commit is contained in:
@ -2,11 +2,22 @@ import { PluginManifest } from './utils/types';
|
||||
import ViewController from './ViewController';
|
||||
import shim from 'lib/shim';
|
||||
import { ViewHandle } from './utils/createViewHandle';
|
||||
import { ContentScriptType } from './api/types';
|
||||
import Logger from 'lib/Logger';
|
||||
|
||||
interface ViewControllers {
|
||||
[key:string]: ViewController
|
||||
}
|
||||
|
||||
export interface ContentScript {
|
||||
id: string,
|
||||
path: string,
|
||||
}
|
||||
|
||||
interface ContentScripts {
|
||||
[type:string]: ContentScript[];
|
||||
}
|
||||
|
||||
export default class Plugin {
|
||||
|
||||
private id_:string;
|
||||
@ -14,16 +25,18 @@ export default class Plugin {
|
||||
private manifest_:PluginManifest;
|
||||
private scriptText_:string;
|
||||
private enabled_:boolean = true;
|
||||
// @ts-ignore Should be useful later on
|
||||
private logger_:any = null;
|
||||
private logger_:Logger = null;
|
||||
private viewControllers_:ViewControllers = {};
|
||||
private contentScripts_:ContentScripts = {};
|
||||
private dispatch_:Function;
|
||||
|
||||
constructor(id:string, baseDir:string, manifest:PluginManifest, scriptText:string, logger:any) {
|
||||
constructor(id:string, baseDir:string, manifest:PluginManifest, scriptText:string, logger:Logger, dispatch:Function) {
|
||||
this.id_ = id;
|
||||
this.baseDir_ = shim.fsDriver().resolve(baseDir);
|
||||
this.manifest_ = manifest;
|
||||
this.scriptText_ = scriptText;
|
||||
this.logger_ = logger;
|
||||
this.dispatch_ = dispatch;
|
||||
}
|
||||
|
||||
public get id():string {
|
||||
@ -46,6 +59,30 @@ export default class Plugin {
|
||||
return this.baseDir_;
|
||||
}
|
||||
|
||||
public registerContentScript(type:ContentScriptType, id:string, path:string) {
|
||||
if (!this.contentScripts_[type]) this.contentScripts_[type] = [];
|
||||
|
||||
const absolutePath = shim.fsDriver().resolveRelativePathWithinDir(this.baseDir, path);
|
||||
|
||||
this.contentScripts_[type].push({ id, path: absolutePath });
|
||||
|
||||
this.logger_.debug(`Plugin: ${this.id}: Registered content script: ${type}: ${id}: ${absolutePath}`);
|
||||
|
||||
this.dispatch_({
|
||||
type: 'PLUGIN_CONTENT_SCRIPTS_ADD',
|
||||
pluginId: this.id,
|
||||
contentScript: {
|
||||
type: type,
|
||||
id: id,
|
||||
path: absolutePath,
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
public contentScriptsByType(type:ContentScriptType):ContentScript[] {
|
||||
return this.contentScripts_[type] ? this.contentScripts_[type] : [];
|
||||
}
|
||||
|
||||
public addViewController(v:ViewController) {
|
||||
if (this.viewControllers_[v.handle]) throw new Error(`View already added: ${v.handle}`);
|
||||
this.viewControllers_[v.handle] = v;
|
||||
|
Reference in New Issue
Block a user