mirror of
https://github.com/nonebot/nonebot2.git
synced 2024-11-25 01:25:04 +08:00
220 lines
5.6 KiB
Vue
220 lines
5.6 KiB
Vue
<template>
|
|
<div class="qq-chat">
|
|
<v-app>
|
|
<v-main>
|
|
<v-card class="elevation-6">
|
|
<v-toolbar color="primary" dark dense flat>
|
|
<v-row no-gutters>
|
|
<v-col>
|
|
<v-row no-gutters justify="space-between">
|
|
<v-col cols="auto">
|
|
<v-icon small>fa-chevron-left</v-icon>
|
|
</v-col>
|
|
<v-col cols="auto">
|
|
<h3>🔥</h3>
|
|
</v-col>
|
|
</v-row>
|
|
</v-col>
|
|
<v-col cols="auto">
|
|
<h3 class="white--text">NoneBot</h3>
|
|
</v-col>
|
|
<v-col class="text-right">
|
|
<v-icon small>fa-user</v-icon>
|
|
</v-col>
|
|
</v-row>
|
|
</v-toolbar>
|
|
<v-container fluid ref="chat" class="chat chat-bg">
|
|
<template v-for="(item, index) in messages">
|
|
<v-row
|
|
v-if="item.position === 'right'"
|
|
justify="end"
|
|
:key="index"
|
|
class="message wow animate__fadeInRight"
|
|
data-wow-duration="0.7s"
|
|
>
|
|
<div
|
|
class="message-box"
|
|
v-html="
|
|
item.msg.replace(/\n/g, '<br/>').replace(/ /g, ' ')
|
|
"
|
|
></div>
|
|
<v-avatar color="blue lighten-2" size="36">
|
|
<v-icon small>fa-user</v-icon>
|
|
</v-avatar>
|
|
</v-row>
|
|
<v-row
|
|
v-else-if="item.position === 'left'"
|
|
justify="start"
|
|
:key="index"
|
|
class="message wow animate__fadeInLeft"
|
|
data-wow-duration="0.7s"
|
|
>
|
|
<v-avatar color="transparent" size="36">
|
|
<v-img src="/logo.png"></v-img>
|
|
</v-avatar>
|
|
<div
|
|
class="message-box"
|
|
v-html="
|
|
item.msg.replace(/\n/g, '<br/>').replace(/ /g, ' ')
|
|
"
|
|
></div>
|
|
</v-row>
|
|
<v-row
|
|
v-else
|
|
justify="center"
|
|
:key="index"
|
|
class="notify mt-1 wow animate__fadeIn"
|
|
data-wow-duration="0.7s"
|
|
>
|
|
<div class="notify-box">
|
|
<span style="display: inline; white-space: nowrap">
|
|
<v-icon x-small color="blue" left>fa-info-circle</v-icon>
|
|
</span>
|
|
<span
|
|
v-html="
|
|
item.msg.replace(/\n/g, '<br/>').replace(/ /g, ' ')
|
|
"
|
|
></span>
|
|
</div>
|
|
</v-row>
|
|
</template>
|
|
</v-container>
|
|
<v-container fluid class="chat-bg py-0">
|
|
<v-row dense class="mx-0">
|
|
<v-col>
|
|
<v-text-field
|
|
dense
|
|
solo
|
|
hide-details
|
|
height="28px"
|
|
></v-text-field>
|
|
</v-col>
|
|
<v-col cols="auto">
|
|
<v-btn
|
|
style="font-size: 0.8rem"
|
|
color="primary"
|
|
small
|
|
rounded
|
|
depressed
|
|
>发送</v-btn
|
|
>
|
|
</v-col>
|
|
</v-row>
|
|
<v-row class="text-center" no-gutters>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-microphone</v-icon>
|
|
</v-col>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-image</v-icon>
|
|
</v-col>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-camera</v-icon>
|
|
</v-col>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-wallet</v-icon>
|
|
</v-col>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-smile-wink</v-icon>
|
|
</v-col>
|
|
<v-col class="pa-1" cols="2">
|
|
<v-icon small>fa-plus-circle</v-icon>
|
|
</v-col>
|
|
</v-row>
|
|
</v-container>
|
|
</v-card>
|
|
</v-main>
|
|
</v-app>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { WOW } from "wowjs";
|
|
import "animate.css/animate.min.css";
|
|
|
|
export default {
|
|
name: "Messenger",
|
|
props: {
|
|
messages: {
|
|
type: Array,
|
|
default: () => [],
|
|
},
|
|
},
|
|
methods: {
|
|
initWOW: function() {
|
|
new WOW({
|
|
noxClass: "wow",
|
|
animateClass: "animate__animated",
|
|
offset: 0,
|
|
mobile: true,
|
|
live: true,
|
|
}).init();
|
|
},
|
|
},
|
|
mounted() {
|
|
this.initWOW();
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<style scoped>
|
|
.wow {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.chat {
|
|
min-height: 150px;
|
|
overflow-x: hidden;
|
|
}
|
|
.chat-bg {
|
|
background-color: #f3f6f9;
|
|
}
|
|
|
|
.message {
|
|
position: relative;
|
|
margin: 0;
|
|
}
|
|
.message .message-box {
|
|
position: relative;
|
|
width: fit-content;
|
|
max-width: 55%;
|
|
border-radius: 0.5rem;
|
|
padding: 0.6rem 0.8rem;
|
|
margin: 0.4rem 0.8rem;
|
|
background-color: #fff;
|
|
}
|
|
.message .message-box::after {
|
|
content: "";
|
|
position: absolute;
|
|
right: 100%;
|
|
top: 0;
|
|
width: 8px;
|
|
height: 12px;
|
|
color: #fff;
|
|
border: 0 solid transparent;
|
|
border-bottom: 7px solid;
|
|
border-radius: 0 0 0 8px;
|
|
}
|
|
.message.justify-end .message-box::after {
|
|
left: 100%;
|
|
right: auto;
|
|
border-radius: 0 0 8px 0;
|
|
}
|
|
|
|
.notify {
|
|
position: relative;
|
|
}
|
|
.notify .notify-box {
|
|
max-width: 70%;
|
|
background: #e0e0e0;
|
|
border-radius: 10px;
|
|
padding: 5px 12px;
|
|
font-size: 12px;
|
|
}
|
|
</style>
|
|
|
|
<style>
|
|
.v-application--wrap {
|
|
min-height: 0 !important;
|
|
}
|
|
</style>
|