import type { RegisterClientOptions } from '@peertube/peertube-types/client' // Must use require for mustache, import seems buggy. const Mustache = require('mustache') /** * Renders the livechat moderation setup home page. * @param registerClientOptions Peertube client options * @returns The page content */ async function renderModerationHome (registerClientOptions: RegisterClientOptions): Promise { const { peertubeHelpers } = registerClientOptions try { // Getting the current username in localStorage. Don't know any cleaner way to do. const username = window.localStorage.getItem('username') if (!username) { throw new Error('Can\'t get the current username.') } const channels = await (await fetch( '/api/v1/accounts/' + encodeURIComponent(username) + '/video-channels?start=0&count=100&sort=name', { method: 'GET', headers: peertubeHelpers.getAuthHeader() } )).json() if (!channels || !('data' in channels) || !Array.isArray(channels.data)) { throw new Error('Can\'t get the channel list.') } for (const channel of channels.data) { channel.livechatModerationUri = '/p/livechat/moderation/channel?channelId=' + encodeURIComponent(channel.id) } const view = { title: await peertubeHelpers.translate(LOC_LIVECHAT_MODERATION_TITLE), description: await peertubeHelpers.translate(LOC_LIVECHAT_MODERATION_DESC), please_select: await peertubeHelpers.translate(LOC_LIVECHAT_MODERATION_PLEASE_SELECT), channels: channels.data } return Mustache.render(`

{{title}}

{{description}}

{{please_select}}

`, view) as string } catch (err: any) { peertubeHelpers.notifier.error(err.toString()) return '' } } export { renderModerationHome }