Auto viewer mode (WIP).

This commit is contained in:
John Livingston
2022-01-07 19:20:28 +01:00
parent 69380bd8e4
commit 9a4608863b
6 changed files with 103 additions and 4 deletions

View File

@ -36,3 +36,18 @@ body.livechat-readonly.livechat-noscroll {
display: none;
}
}
// Viewer mode
.livechat-viewer-mode-nick {
display: none;
}
body[livechat-viewer-mode="on"] {
.livechat-viewer-mode-nick {
display: initial;
}
.livechat-viewer-mode-panel {
display: none;
}
}

View File

@ -0,0 +1,40 @@
import { __ } from 'i18n'
import { _converse, api } from '@converse/headless/core'
import { html } from 'lit'
import tplMucBottomPanel from '../../src/plugins/muc-views/templates/muc-bottom-panel.js'
async function setNickname (ev, model) {
ev.preventDefault()
const nick = ev.target.nick.value.trim()
nick && await model.setNickname(nick)
_converse.api.trigger('livechatViewerModeSetNickname')
}
export default (o) => {
if (api.settings.get('livechat_viewer_mode')) {
const model = o.model
const i18nNickname = __('Nickname')
const i18nJoin = __('Enter groupchat')
return html`
<div class="livechat-viewer-mode-nick chatroom-form-container muc-nickname-form"
@submit=${ev => setNickname(ev, model)}>
<form class="converse-form chatroom-form converse-centered-form">
<fieldset class="form-group">
<input type="text"
required="required"
name="nick"
value=""
class="form-control"
placeholder="${i18nNickname}"/>
</fieldset>
<fieldset class="form-group">
<input type="submit" class="btn btn-primary" name="join" value="${i18nJoin}"/>
</fieldset>
</form>
</div>
<span class="livechat-viewer-mode-panel">
${tplMucBottomPanel(o)}
</span>`
}
return tplMucBottomPanel(o)
}

View File

@ -7,8 +7,7 @@ module.exports = merge(prod, {
resolve: {
extensions: ['.js'],
alias: {
// To override a template, use this syntax:
// 'templates/muc_sidebar.js': path.resolve(__dirname, 'custom/templates/muc_sidebar.js')
'./templates/muc-bottom-panel.js': path.resolve('custom/templates/muc-bottom-panel.js'),
'../../templates/background_logo.js$': path.resolve(__dirname, 'custom/templates/background_logo.js'),
'shared/styles/index.scss$': path.resolve(__dirname, 'custom/shared/styles/livechat.scss')
}