2017-12-05 02:02:41 -08:00
|
|
|
<template>
|
2018-04-10 14:20:42 -07:00
|
|
|
<div class="chat-panel" v-if="!this.collapsed">
|
2018-03-31 11:14:36 -07:00
|
|
|
<div class="panel panel-default">
|
2018-04-10 14:17:05 -07:00
|
|
|
<div class="panel-heading timeline-heading chat-heading" @click.stop.prevent="togglePanel">
|
2018-01-26 06:11:34 -08:00
|
|
|
<div class="title">
|
|
|
|
{{$t('chat.title')}}
|
2018-04-10 14:17:05 -07:00
|
|
|
<i class="icon-cancel" style="float: right;"></i>
|
2018-01-26 06:11:34 -08:00
|
|
|
</div>
|
2017-12-05 02:02:41 -08:00
|
|
|
</div>
|
2018-01-26 06:11:34 -08:00
|
|
|
<div class="chat-window" v-chat-scroll>
|
2017-12-05 05:20:34 -08:00
|
|
|
<div class="chat-message" v-for="message in messages" :key="message.id">
|
2017-12-05 02:02:41 -08:00
|
|
|
<span class="chat-avatar">
|
|
|
|
<img :src="message.author.avatar" />
|
|
|
|
</span>
|
2018-04-10 14:17:05 -07:00
|
|
|
<div class="chat-content">
|
2018-12-05 17:05:35 -08:00
|
|
|
<router-link class="chat-name" :to="{ name: 'user-profile', params: { name: message.author.username } }">
|
2018-04-10 14:17:05 -07:00
|
|
|
{{message.author.username}}
|
|
|
|
</router-link>
|
|
|
|
<br>
|
|
|
|
<span class="chat-text">
|
|
|
|
{{message.text}}
|
|
|
|
</span>
|
|
|
|
</div>
|
2017-12-05 02:02:41 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="chat-input">
|
2018-04-10 14:19:28 -07:00
|
|
|
<textarea @keyup.enter="submit(currentMessage)" v-model="currentMessage" class="chat-input-textarea" rows="1"></textarea>
|
2017-12-05 02:02:41 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2018-04-10 14:17:05 -07:00
|
|
|
<div v-else class="chat-panel">
|
|
|
|
<div class="panel panel-default">
|
2018-04-12 09:51:33 -07:00
|
|
|
<div class="panel-heading stub timeline-heading chat-heading" @click.stop.prevent="togglePanel">
|
2018-04-10 14:17:05 -07:00
|
|
|
<div class="title">
|
2018-04-14 00:19:09 -07:00
|
|
|
<i class="icon-comment-empty"></i>
|
2018-04-10 14:17:05 -07:00
|
|
|
{{$t('chat.title')}}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2017-12-05 02:02:41 -08:00
|
|
|
</template>
|
|
|
|
|
2018-01-26 06:11:34 -08:00
|
|
|
<script src="./chat_panel.js"></script>
|
2017-12-05 02:02:41 -08:00
|
|
|
|
|
|
|
<style lang="scss">
|
2018-04-01 12:07:25 -07:00
|
|
|
@import '../../_variables.scss';
|
2018-04-14 00:19:09 -07:00
|
|
|
|
|
|
|
.floating-chat {
|
|
|
|
position: fixed;
|
|
|
|
right: 0px;
|
|
|
|
bottom: 0px;
|
|
|
|
z-index: 1000;
|
|
|
|
}
|
|
|
|
|
2018-04-10 14:17:05 -07:00
|
|
|
.chat-heading {
|
|
|
|
cursor: pointer;
|
2018-04-14 00:19:09 -07:00
|
|
|
.icon-comment-empty {
|
|
|
|
color: $fallback--fg;
|
|
|
|
color: var(--fg, $fallback--fg);
|
|
|
|
}
|
2018-04-10 14:17:05 -07:00
|
|
|
}
|
2018-04-01 12:07:25 -07:00
|
|
|
|
|
|
|
.chat-window {
|
2018-04-14 00:19:09 -07:00
|
|
|
width: 345px;
|
|
|
|
max-height: 40vh;
|
2018-04-07 09:30:27 -07:00
|
|
|
overflow-y: auto;
|
|
|
|
overflow-x: hidden;
|
2018-04-01 12:07:25 -07:00
|
|
|
}
|
|
|
|
|
2018-04-10 14:17:05 -07:00
|
|
|
.chat-name {
|
|
|
|
}
|
|
|
|
|
2018-04-01 12:07:25 -07:00
|
|
|
.chat-message {
|
2018-04-10 14:17:05 -07:00
|
|
|
display: flex;
|
2018-04-07 09:30:27 -07:00
|
|
|
padding: 0.2em 0.5em
|
2018-04-01 12:07:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.chat-avatar {
|
2018-04-07 09:30:27 -07:00
|
|
|
img {
|
2018-04-10 14:17:05 -07:00
|
|
|
height: 24px;
|
|
|
|
width: 24px;
|
2018-04-07 09:30:27 -07:00
|
|
|
border-radius: $fallback--avatarRadius;
|
|
|
|
border-radius: var(--avatarRadius, $fallback--avatarRadius);
|
|
|
|
margin-right: 0.5em;
|
2018-04-10 14:17:05 -07:00
|
|
|
margin-top: 0.25em;
|
2018-04-07 09:30:27 -07:00
|
|
|
}
|
2018-04-01 12:07:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
.chat-input {
|
2018-04-07 09:30:27 -07:00
|
|
|
display: flex;
|
2018-04-10 14:19:28 -07:00
|
|
|
textarea {
|
|
|
|
flex: 1;
|
|
|
|
margin: 0.6em;
|
|
|
|
min-height: 3.5em;
|
|
|
|
resize: none;
|
2018-04-07 09:30:27 -07:00
|
|
|
}
|
2018-04-01 12:07:25 -07:00
|
|
|
}
|
2017-12-05 02:02:41 -08:00
|
|
|
</style>
|