listen to all events.

This commit is contained in:
Miroslav Šedivý 2020-11-07 15:08:39 +01:00
parent b38696596a
commit f90c506928
3 changed files with 111 additions and 33 deletions

View file

@ -17,12 +17,25 @@ import {
AdminTargetPayload,
} from '../types/messages'
import EventEmitter from 'eventemitter3'
export class NekoMessages {
_eventEmmiter: EventEmitter
constructor(eventEmitter: EventEmitter) {
this._eventEmmiter = eventEmitter
}
private emit(event: string, ...payload: any) {
this._eventEmmiter.emit(event, ...payload)
}
/////////////////////////////
// System Events
/////////////////////////////
public [EVENT.SYSTEM.DISCONNECT]({ message }: DisconnectPayload) {
console.log('EVENT.SYSTEM.DISCONNECT')
this.emit('disconnect', message)
//this.onDisconnected(new Error(message))
//this.$vue.$swal({
// title: this.$vue.$t('connection.disconnected'),
@ -37,21 +50,19 @@ export class NekoMessages {
/////////////////////////////
public [EVENT.MEMBER.LIST]({ members }: MemberListPayload) {
console.log('EVENT.MEMBER.LIST')
this.emit('member.list', members)
//this.$accessor.user.setMembers(members)
}
public [EVENT.MEMBER.CONNECTED](member: MemberPayload) {
console.log('EVENT.MEMBER.CONNECTED')
this.emit('member.connected', member.id)
//this.$accessor.user.addMember(member)
}
public [EVENT.MEMBER.DISCONNECTED]({ id }: MemberDisconnectPayload) {
console.log('EVENT.MEMBER.DISCONNECTED')
//const member = this.member(id)
//if (!member) {
// return
//}
//
this.emit('member.disconnected', id)
//this.$accessor.user.delMember(id)
}
@ -60,6 +71,7 @@ export class NekoMessages {
/////////////////////////////
public [EVENT.CONTROL.LOCKED]({ id }: ControlPayload) {
console.log('EVENT.CONTROL.LOCKED')
this.emit('host.change', id)
//this.$accessor.remote.setHost(id)
//this.$accessor.remote.changeKeyboard()
//
@ -81,6 +93,7 @@ export class NekoMessages {
public [EVENT.CONTROL.RELEASE]({ id }: ControlPayload) {
console.log('EVENT.CONTROL.RELEASE')
this.emit('host.change', null)
//this.$accessor.remote.reset()
//const member = this.member(id)
//if (!member) {
@ -100,6 +113,7 @@ export class NekoMessages {
public [EVENT.CONTROL.REQUEST]({ id }: ControlPayload) {
console.log('EVENT.CONTROL.REQUEST')
this.emit('control.request', id)
//const member = this.member(id)
//if (!member) {
// return
@ -117,6 +131,7 @@ export class NekoMessages {
public [EVENT.CONTROL.REQUESTING]({ id }: ControlPayload) {
console.log('EVENT.CONTROL.REQUESTING')
this.emit('control.requesting', id)
//const member = this.member(id)
//if (!member || member.ignored) {
// return
@ -133,17 +148,14 @@ export class NekoMessages {
public [EVENT.CONTROL.GIVE]({ id, target }: ControlTargetPayload) {
console.log('EVENT.CONTROL.GIVE')
//const member = this.member(target)
//if (!member) {
// return
//}
//
//this.$accessor.remote.setHost(member)
this.emit('host.change', target)
//this.$accessor.remote.setHost(target)
//this.$accessor.remote.changeKeyboard()
}
public [EVENT.CONTROL.CLIPBOARD]({ text }: ControlClipboardPayload) {
console.log('EVENT.CONTROL.CLIPBOARD')
this.emit('clipboard.update', text)
//this.$accessor.remote.setClipboard(text)
}
@ -152,11 +164,13 @@ export class NekoMessages {
/////////////////////////////
public [EVENT.SCREEN.CONFIGURATIONS]({ configurations }: ScreenConfigurationsPayload) {
console.log('EVENT.SCREEN.CONFIGURATIONS')
this.emit('screen.configuration', configurations)
//this.$accessor.video.setConfigurations(configurations)
}
public [EVENT.SCREEN.RESOLUTION]({ id, width, height, rate }: ScreenResolutionPayload) {
console.log('EVENT.SCREEN.RESOLUTION')
this.emit('screen.size', width, height, rate)
//this.$accessor.video.setResolution({ width, height, rate })
}
@ -165,6 +179,7 @@ export class NekoMessages {
/////////////////////////////
public [EVENT.BROADCAST.STATUS](payload: BroadcastStatusPayload) {
console.log('EVENT.BROADCAST.STATUS')
this.emit('broadcast.status', payload)
//this.$accessor.settings.broadcastStatus(payload)
}
@ -172,65 +187,73 @@ export class NekoMessages {
// Admin Events
/////////////////////////////
public [EVENT.ADMIN.BAN]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.BAN')
this.emit('member.ban', id, target)
// TODO
}
public [EVENT.ADMIN.KICK]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.KICK')
this.emit('member.kick', id, target)
// TODO
}
public [EVENT.ADMIN.MUTE]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.MUTE')
//if (!target) {
// return
//}
//
this.emit('member.muted', id, target)
//this.$accessor.user.setMuted({ id: target, muted: true })
}
public [EVENT.ADMIN.UNMUTE]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.UNMUTE')
//if (!target) {
// return
//}
//
this.emit('member.unmuted', id, target)
//this.$accessor.user.setMuted({ id: target, muted: false })
}
public [EVENT.ADMIN.LOCK]({ id }: AdminPayload) {
console.log('EVENT.ADMIN.LOCK')
this.emit('room.locked', id)
//this.$accessor.setLocked(true)
}
public [EVENT.ADMIN.UNLOCK]({ id }: AdminPayload) {
console.log('EVENT.ADMIN.UNLOCK')
this.emit('room.unlocked', id)
//this.$accessor.setLocked(false)
}
public [EVENT.ADMIN.CONTROL]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.CONTROL')
this.emit('host.change', id)
//this.$accessor.remote.setHost(id)
//this.$accessor.remote.changeKeyboard()
}
public [EVENT.ADMIN.RELEASE]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.RELEASE')
this.emit('host.change', null)
//this.$accessor.remote.reset()
}
public [EVENT.ADMIN.GIVE]({ id, target }: AdminTargetPayload) {
if (!target) return
console.log('EVENT.ADMIN.GIVE')
//if (!target) {
// return
//}
//
//const member = this.member(target)
//if (member) {
// this.$accessor.remote.setHost(member)
// this.$accessor.remote.changeKeyboard()
//}
this.emit('host.change', target)
//this.$accessor.remote.setHost(target)
//this.$accessor.remote.changeKeyboard()
}
// Utilities