2024-05-23 17:17:28 +02:00
|
|
|
// SPDX-FileCopyrightText: 2024 Mehdi Benadel <https://mehdibenadel.com>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2024-05-23 17:27:49 +02:00
|
|
|
import { html } from 'lit'
|
2024-06-12 16:26:35 +02:00
|
|
|
import { customElement, state } from 'lit/decorators.js'
|
2024-05-23 16:56:11 +02:00
|
|
|
import { ptTr } from '../../lib/directives/translation'
|
2024-05-23 22:52:39 +02:00
|
|
|
import { Task } from '@lit/task'
|
2024-05-23 14:41:11 +02:00
|
|
|
import type { ChannelLiveChatInfos } from 'shared/lib/types'
|
|
|
|
import { ChannelDetailsService } from '../services/channel-details'
|
|
|
|
import { provide } from '@lit/context'
|
2024-05-23 16:56:11 +02:00
|
|
|
import { channelDetailsServiceContext } from '../contexts/channel'
|
2024-05-23 17:09:58 +02:00
|
|
|
import { LivechatElement } from '../../lib/elements/livechat'
|
2024-05-23 14:41:11 +02:00
|
|
|
|
2024-05-23 15:52:12 +02:00
|
|
|
@customElement('livechat-channel-home')
|
2024-05-23 17:09:58 +02:00
|
|
|
export class ChannelHomeElement extends LivechatElement {
|
2024-05-23 14:41:11 +02:00
|
|
|
@state()
|
2024-05-24 14:08:48 +02:00
|
|
|
public _channels?: ChannelLiveChatInfos[]
|
2024-05-23 14:41:11 +02:00
|
|
|
|
|
|
|
@provide({ context: channelDetailsServiceContext })
|
2024-05-24 14:08:48 +02:00
|
|
|
private _channelDetailsService?: ChannelDetailsService
|
2024-05-23 14:41:11 +02:00
|
|
|
|
2024-05-23 22:52:39 +02:00
|
|
|
private readonly _asyncTaskRender = new Task(this, {
|
2024-06-12 16:26:35 +02:00
|
|
|
task: async () => {
|
2024-05-23 14:41:11 +02:00
|
|
|
// 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.')
|
|
|
|
}
|
|
|
|
|
2024-06-12 16:26:35 +02:00
|
|
|
this._channelDetailsService = new ChannelDetailsService(this.ptOptions)
|
|
|
|
this._channels = await this._channelDetailsService.fetchUserChannels(username)
|
2024-05-23 14:41:11 +02:00
|
|
|
},
|
2024-06-12 16:26:35 +02:00
|
|
|
args: () => []
|
2024-05-23 22:52:39 +02:00
|
|
|
})
|
2024-05-23 14:41:11 +02:00
|
|
|
|
2024-05-23 22:52:39 +02:00
|
|
|
protected override render = (): unknown => {
|
2024-05-23 14:41:11 +02:00
|
|
|
return this._asyncTaskRender.render({
|
2024-06-11 16:25:05 +02:00
|
|
|
pending: () => html`<livechat-spinner></livechat-spinner>`,
|
|
|
|
error: () => html`<livechat-error></livechat-error>`,
|
2024-05-23 14:41:11 +02:00
|
|
|
complete: () => html`
|
|
|
|
<div class="margin-content peertube-plugin-livechat-configuration peertube-plugin-livechat-configuration-home">
|
|
|
|
<h1>
|
|
|
|
${ptTr(LOC_LIVECHAT_CONFIGURATION_TITLE)}
|
2024-06-04 15:54:00 +02:00
|
|
|
<livechat-help-button .page=${'documentation/user/streamers/channel'}>
|
2024-05-23 15:52:12 +02:00
|
|
|
</livechat-help-button>
|
2024-05-23 14:41:11 +02:00
|
|
|
</h1>
|
|
|
|
<p>${ptTr(LOC_LIVECHAT_CONFIGURATION_DESC)}</p>
|
|
|
|
<p>${ptTr(LOC_LIVECHAT_CONFIGURATION_PLEASE_SELECT)}</p>
|
|
|
|
<ul class="peertube-plugin-livechat-configuration-home-channels">
|
|
|
|
${this._channels?.map((channel) => html`
|
|
|
|
<li>
|
2024-08-29 11:28:58 +02:00
|
|
|
<a href="${channel.livechatConfigurationUri}" aria-hidden="true">
|
2024-05-23 22:52:39 +02:00
|
|
|
${channel.avatar
|
|
|
|
? html`<img class="avatar channel" src="${channel.avatar.path}">`
|
2024-06-11 16:25:05 +02:00
|
|
|
: html`<div class="avatar channel initial gray"></div>`
|
2024-05-23 14:41:11 +02:00
|
|
|
}
|
|
|
|
</a>
|
|
|
|
<div class="peertube-plugin-livechat-configuration-home-info">
|
|
|
|
<a href="${channel.livechatConfigurationUri}">
|
|
|
|
<div>${channel.displayName}</div>
|
|
|
|
<div>${channel.name}</div>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
</li>
|
|
|
|
`)}
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
`
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|