2024-07-01 17:45:11 +02:00
|
|
|
// SPDX-FileCopyrightText: 2024 John Livingston <https://www.john-livingston.fr/>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { tplPoll } from '../templates/poll.js'
|
|
|
|
import { CustomElement } from 'shared/components/element.js'
|
|
|
|
import { api } from '@converse/headless/core'
|
|
|
|
import '../styles/poll.scss'
|
|
|
|
|
|
|
|
export default class MUCPollView extends CustomElement {
|
|
|
|
static get properties () {
|
|
|
|
return {
|
2024-07-04 15:15:28 +02:00
|
|
|
model: { type: Object, attribute: true },
|
|
|
|
collapsed: { type: Boolean, attribute: false },
|
|
|
|
buttonDisabled: { type: Boolean, attribute: false }
|
2024-07-01 17:45:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async initialize () {
|
2024-07-04 15:15:28 +02:00
|
|
|
this.collapsed = false
|
|
|
|
this.buttonDisabled = false
|
2024-07-01 17:45:11 +02:00
|
|
|
if (!this.model) {
|
|
|
|
return
|
|
|
|
}
|
2024-07-04 15:15:28 +02:00
|
|
|
this.listenTo(this.model, 'change:current_poll', () => {
|
|
|
|
this.buttonDisabled = false
|
|
|
|
this.requestUpdate()
|
|
|
|
})
|
2024-07-01 17:45:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
render () {
|
|
|
|
const currentPoll = this.model?.get('current_poll')
|
2024-07-01 18:06:26 +02:00
|
|
|
return tplPoll(this, currentPoll)
|
2024-07-01 17:45:11 +02:00
|
|
|
}
|
2024-07-04 15:15:28 +02:00
|
|
|
|
|
|
|
toggle () {
|
|
|
|
this.collapsed = !this.collapsed
|
|
|
|
}
|
|
|
|
|
|
|
|
voteFor (choice) {
|
|
|
|
if (this.buttonDisabled) { return }
|
|
|
|
|
|
|
|
const currentPoll = this.model?.get('current_poll')
|
|
|
|
if (!currentPoll) { return }
|
|
|
|
if (currentPoll.over) { return }
|
|
|
|
|
|
|
|
console.info('User has voted for choice: ', choice)
|
|
|
|
// We disable vote buttons until next refresh:
|
|
|
|
this.buttonDisabled = true
|
|
|
|
this.requestUpdate()
|
|
|
|
|
|
|
|
this.model.sendMessage({
|
|
|
|
body: '!' + choice.choice
|
|
|
|
})
|
|
|
|
}
|
2024-07-04 15:34:32 +02:00
|
|
|
|
|
|
|
closePoll (ev) {
|
|
|
|
ev.preventDefault()
|
|
|
|
this.model.set('current_poll', undefined)
|
|
|
|
}
|
2024-07-01 17:45:11 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
api.elements.define('livechat-converse-muc-poll', MUCPollView)
|