2020-10-09 18:35:46 +01:00
import Plugin from '../Plugin' ;
import createViewHandle from '../utils/createViewHandle' ;
2020-11-13 17:09:28 +00:00
import WebviewController , { ContainerType } from '../WebviewController' ;
2020-10-09 18:35:46 +01:00
import { ViewHandle } from './types' ;
/ * *
2020-11-13 17:09:28 +00:00
* Allows creating and managing view panels . View panels currently are
* displayed at the right of the sidebar and allows displaying any HTML
* content ( within a webview ) and update it in real - time . For example it
* could be used to display a table of content for the active note , or
* display various metadata or graph .
2020-10-09 18:35:46 +01:00
*
2020-11-05 16:58:23 +00:00
* [ View the demo plugin ] ( https : //github.com/laurent22/joplin/tree/dev/packages/app-cli/tests/support/plugins/toc)
2020-10-09 18:35:46 +01:00
* /
export default class JoplinViewsPanels {
private store : any ;
private plugin : Plugin ;
constructor ( plugin : Plugin , store : any ) {
this . store = store ;
this . plugin = plugin ;
}
2020-11-12 19:13:28 +00:00
private controller ( handle : ViewHandle ) : WebviewController {
2020-10-09 18:35:46 +01:00
return this . plugin . viewController ( handle ) as WebviewController ;
}
/ * *
* Creates a new panel
* /
2020-11-13 17:09:28 +00:00
async create ( id : string ) : Promise < ViewHandle > {
if ( ! id ) {
this . plugin . deprecationNotice ( '1.5' , 'Creating a view without an ID is deprecated. To fix it, change your call to `joplin.views.panels.create("my-unique-id")`' ) ;
id = ` ${ this . plugin . viewCount } ` ;
}
const handle = createViewHandle ( this . plugin , id ) ;
const controller = new WebviewController ( handle , this . plugin . id , this . store , this . plugin . baseDir , ContainerType . Panel ) ;
2020-10-09 18:35:46 +01:00
this . plugin . addViewController ( controller ) ;
return handle ;
}
/ * *
* Sets the panel webview HTML
* /
2020-11-12 19:13:28 +00:00
async setHtml ( handle : ViewHandle , html : string ) {
2020-10-09 18:35:46 +01:00
return this . controller ( handle ) . html = html ;
}
/ * *
* Adds and loads a new JS or CSS files into the panel .
* /
2020-11-12 19:13:28 +00:00
async addScript ( handle : ViewHandle , scriptPath : string ) {
2020-10-09 18:35:46 +01:00
return this . controller ( handle ) . addScript ( scriptPath ) ;
}
/ * *
* Called when a message is sent from the webview ( using postMessage ) .
* /
2020-11-12 19:13:28 +00:00
async onMessage ( handle : ViewHandle , callback : Function ) {
2020-10-09 18:35:46 +01:00
return this . controller ( handle ) . onMessage ( callback ) ;
}
}