thelounge/client/components/MessageTypes/away.vue

44 lines
981 B
Vue

<template>
<span class="content">
<ParsedMessage v-if="message.self" :network="network" :message="message" />
<template v-else>
<Username :user="message.from" />
is away
<i v-if="awayMessage" class="away-message"
>(<ParsedMessage :network="network" :message="message" />)</i
>
</template>
</span>
</template>
<script lang="ts">
import {computed, defineComponent, PropType} from "vue";
import type {ClientNetwork, ClientMessage} from "../../js/types";
import ParsedMessage from "../ParsedMessage.vue";
import Username from "../Username.vue";
export default defineComponent({
name: "MessageTypeAway",
components: {
ParsedMessage,
Username,
},
props: {
network: {
type: Object as PropType<ClientNetwork>,
required: true,
},
message: {
type: Object as PropType<ClientMessage>,
required: true,
},
},
setup(props) {
const awayMessage = computed(() => props.message.text.trim());
return {
awayMessage,
};
},
});
</script>