X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=support%2Fdoc%2Fplugins%2Fguide.md;h=e567e6c1b352b689ee9ab6d1189067ebe6bc0c84;hb=9452d4fd3321148fb80b64a67bd9983fee6c208e;hp=26fcb8987793c826b988901991ed0646161c534b;hpb=b969539c838ae3012d7a7040c5e310bb9c834e95;p=github%2FChocobozzz%2FPeerTube.git diff --git a/support/doc/plugins/guide.md b/support/doc/plugins/guide.md index 26fcb8987..e567e6c1b 100644 --- a/support/doc/plugins/guide.md +++ b/support/doc/plugins/guide.md @@ -16,11 +16,10 @@ - [Add new transcoding profiles](#add-new-transcoding-profiles) - [Server helpers](#server-helpers) - [Client API (themes & plugins)](#client-api-themes--plugins) - - [Plugin static route](#plugin-static-route) + - [Get plugin static and router routes](#get-plugin-static-and-router-routes) - [Notifier](#notifier) - [Markdown Renderer](#markdown-renderer) - [Auth header](#auth-header) - - [Plugin router route](#plugin-router-route) - [Custom Modal](#custom-modal) - [Translate](#translate) - [Get public settings](#get-public-settings) @@ -30,6 +29,7 @@ - [Plugin selector on HTML elements](#plugin-selector-on-html-elements) - [HTML placeholder elements](#html-placeholder-elements) - [Add/remove left menu links](#addremove-left-menu-links) + - [Create client page](#create-client-page) - [Publishing](#publishing) - [Write a plugin/theme](#write-a-plugintheme) - [Clone the quickstart repository](#clone-the-quickstart-repository) @@ -531,7 +531,7 @@ See the [plugin API reference](https://docs.joinpeertube.org/api-plugins) to see ### Client API (themes & plugins) -#### Plugin static route +#### Get plugin static and router routes To get your plugin static route: @@ -542,6 +542,24 @@ function register (...) { } ``` +And to get your plugin router route, use `peertubeHelpers.getBaseRouterRoute()`: + +```js +function register (...) { + registerHook({ + target: 'action:video-watch.video.loaded', + handler: ({ video }) => { + fetch(peertubeHelpers.getBaseRouterRoute() + '/my/plugin/api', { + method: 'GET', + headers: peertubeHelpers.getAuthHeader() + }).then(res => res.json()) + .then(data => console.log('Hi %s.', data)) + } + }) +} +``` + + #### Notifier To notify the user with the PeerTube ToastModule: @@ -594,27 +612,6 @@ function register (...) { } ``` -#### Plugin router route - -**PeerTube >= 3.3** - -To get your plugin router route, you can use `peertubeHelpers.getBaseRouterRoute()`: - -```js -function register (...) { - registerHook({ - target: 'action:video-watch.video.loaded', - handler: ({ video }) => { - fetch(peertubeHelpers.getBaseRouterRoute() + '/my/plugin/api', { - method: 'GET', - headers: peertubeHelpers.getAuthHeader() - }).then(res => res.json()) - .then(data => console.log('Hi %s.', data)) - } - }) -} -``` - #### Custom Modal To show a custom modal: @@ -692,16 +689,31 @@ async function register ({ registerVideoField, peertubeHelpers }) { type: 'input-textarea', default: '', + // Optional, to hide a field depending on the current form state // liveVideo is in the options object when the user is creating/updating a live // videoToUpdate is in the options object when the user is updating a video hidden: ({ formValues, videoToUpdate, liveVideo }) => { return formValues.pluginData['other-field'] === 'toto' + }, + + // Optional, to display an error depending on the form state + error: ({ formValues, value }) => { + if (formValues['privacy'] !== 1 && formValues['privacy'] !== 2) return { error: false } + if (value === true) return { error: false } + + return { error: true, text: 'Should be enabled' } } } + const videoFormOptions = { + // Optional, to choose to put your setting in a specific tab in video form + // type: 'main' | 'plugin-settings' + tab: 'main' + } + for (const type of [ 'upload', 'import-url', 'import-torrent', 'update', 'go-live' ]) { - registerVideoField(commonOptions, { type }) + registerVideoField(commonOptions, { type, ...videoFormOptions }) } } ``` @@ -791,6 +803,21 @@ See the complete list on https://docs.joinpeertube.org/api-plugins Left menu links can be filtered (add/remove a section or add/remove links) using the `filter:left-menu.links.create.result` client hook. +#### Create client page + +To create a client page, register a new client route: + +```js +function register ({ registerClientRoute }) { + registerClientRoute({ + route: 'my-super/route', + onMount: ({ rootEl }) => { + rootEl.innerHTML = 'hello' + } + }) +} +``` + ### Publishing @@ -988,13 +1015,16 @@ You built files are in the `dist/` directory. Check `package.json` to correctly ### Test your plugin/theme +PeerTube dev server (ran with `npm run dev` on `localhost:3000`) can't inject plugin CSS. +It's the reason why we don't use the dev mode but build PeerTube instead. + You'll need to have a local PeerTube instance: * Follow the [dev prerequisites](https://github.com/Chocobozzz/PeerTube/blob/develop/.github/CONTRIBUTING.md#prerequisites) (to clone the repository, install dependencies and prepare the database) - * Build PeerTube (`--light` to only build the english language): + * Build PeerTube: ``` -$ npm run build -- --light +$ npm run build ``` * Build the CLI: @@ -1006,7 +1036,7 @@ $ npm run setup:cli * Run PeerTube (you can access to your instance on http://localhost:9000): ``` -$ NODE_ENV=test npm start +$ NODE_ENV=dev npm start ``` * Register the instance via the CLI: