thelounge/client/components/Username.vue

54 lines
1 KiB
Vue
Raw Normal View History

<template>
<span
:class="['user', nickColor, {active: active}]"
:data-name="user.nick"
role="button"
2020-01-27 10:44:36 +01:00
v-on="onHover ? {mouseenter: hover} : {}"
2019-11-23 15:26:20 +01:00
@click.prevent="openContextMenu"
@contextmenu.prevent="openContextMenu"
><slot>{{ mode }}{{ user.nick }}</slot></span
2019-07-17 11:33:59 +02:00
>
</template>
<script>
2020-03-16 18:58:40 +01:00
import eventbus from "../js/eventbus";
2019-11-16 18:24:03 +01:00
import colorClass from "../js/helpers/colorClass";
export default {
name: "Username",
props: {
user: Object,
active: Boolean,
2018-07-11 01:25:21 +02:00
onHover: Function,
2020-04-24 09:20:40 +02:00
channel: Object,
network: Object,
2018-07-11 01:25:21 +02:00
},
computed: {
mode() {
// Message objects have a singular mode, but user objects have modes array
if (this.user.modes) {
return this.user.modes[0];
}
return this.user.mode;
},
nickColor() {
return colorClass(this.user.nick);
},
},
2018-07-11 01:25:21 +02:00
methods: {
hover() {
return this.onHover(this.user);
2018-07-11 01:25:21 +02:00
},
2019-11-23 15:26:20 +01:00
openContextMenu(event) {
2020-03-16 18:58:40 +01:00
eventbus.emit("contextmenu:user", {
2019-11-23 15:26:20 +01:00
event: event,
user: this.user,
2020-04-24 09:20:40 +02:00
network: this.network,
channel: this.channel,
2019-11-23 15:26:20 +01:00
});
2019-11-09 23:21:34 +01:00
},
},
};
</script>