Settings simplification to prepare translations. Diagnostic button is initialized by frontend.

This commit is contained in:
John Livingston 2021-06-11 14:30:46 +02:00
parent af5740a399
commit 80ef06c65f
4 changed files with 38 additions and 6 deletions

View File

@ -1 +1,2 @@
declare const PLUGIN_CHAT_PACKAGE_NAME: string declare const PLUGIN_CHAT_PACKAGE_NAME: string
declare const PLUGIN_CHAT_SHORT_NAME: string

View File

@ -1,6 +1,38 @@
import type { ChatType } from 'shared/lib/types' import type { ChatType } from 'shared/lib/types'
function register ({ registerSettingsScript }: RegisterOptions): void { interface ActionPluginSettingsParams {
npmName: string
}
function register ({ registerHook, registerSettingsScript, peertubeHelpers }: RegisterOptions): void {
function getBaseRoute (): string {
// NB: this will come with Peertube > 3.2.1 (3.3.0?)
if (peertubeHelpers.getBaseRouterRoute) {
return peertubeHelpers.getBaseRouterRoute()
}
// We are guessing the route with the correct plugin version with this trick:
const staticBase = peertubeHelpers.getBaseStaticRoute()
// we can't use '/plugins/livechat/router', because the loaded html page needs correct relative paths.
return staticBase.replace(/\/static.*$/, '/router')
}
registerHook({
target: 'action:admin-plugin-settings.init',
handler: ({ npmName }: ActionPluginSettingsParams) => {
if (npmName !== PLUGIN_CHAT_PACKAGE_NAME) {
console.log(`[peertube-plugin-livechat] Settings for ${npmName}, not ${PLUGIN_CHAT_PACKAGE_NAME}. Returning.`)
return
}
console.log('[peertube-plugin-livechat] Initializing diagnostic button')
const diagButtons = document.querySelectorAll('.peertube-plugin-livechat-launch-diagnostic')
diagButtons.forEach(diagButton => {
if (diagButton.hasAttribute('href')) { return }
// TODO: use a modal instead of a target=_blank
diagButton.setAttribute('href', getBaseRoute() + '/settings/diagnostic')
diagButton.setAttribute('target', '_blank')
})
}
})
registerSettingsScript({ registerSettingsScript({
isSettingHidden: options => { isSettingHidden: options => {
const name = options.setting.name const name = options.setting.name

View File

@ -1,4 +1,3 @@
import { getBaseRouterRoute } from './helpers'
import { ensureProsodyRunning, ensureProsodyNotRunning } from './prosody/ctl' import { ensureProsodyRunning, ensureProsodyNotRunning } from './prosody/ctl'
import type { ChatType } from '../../shared/lib/types' import type { ChatType } from '../../shared/lib/types'
@ -17,14 +16,13 @@ function initSettings (options: RegisterServerOptions): void {
descriptionHTML: `Please read the descriptionHTML: `Please read the
<a href="https://github.com/JohnXLivingston/peertube-plugin-livechat/blob/main/README.md" target="_blank"> <a href="https://github.com/JohnXLivingston/peertube-plugin-livechat/blob/main/README.md" target="_blank">
documentation documentation
</a> before trying to use this plugin.` </a> first.`
}) })
registerSetting({ registerSetting({
type: 'html', type: 'html',
private: true, private: true,
descriptionHTML: `Before asking for help, please use the diagnostic tool: descriptionHTML: `Before asking for help, please use the diagnostic tool:
<a href="${getBaseRouterRoute(options)}settings/diagnostic" target="_blank">Launch diagnostic</a> <a class="peertube-plugin-livechat-launch-diagnostic">Launch diagnostic</a>`
<br>`
}) })
// ********** Chat Mode // ********** Chat Mode

View File

@ -36,7 +36,8 @@ let config = clientFiles.map(f => ({
}, },
plugins: [ plugins: [
new webpack.DefinePlugin({ new webpack.DefinePlugin({
PLUGIN_CHAT_PACKAGE_NAME: JSON.stringify(packagejson.name) PLUGIN_CHAT_PACKAGE_NAME: JSON.stringify(packagejson.name),
PLUGIN_CHAT_SHORT_NAME: JSON.stringify(packagejson.name.replace(/^peertube-plugin-/, ''))
}), }),
new EsmWebpackPlugin() new EsmWebpackPlugin()
] ]