mirror of
https://github.com/yangjian102621/geekai.git
synced 2025-09-18 01:06:39 +08:00
the sidebar drawer function is ready
This commit is contained in:
parent
8733cdb981
commit
3bf83cd48c
@ -6,14 +6,15 @@
|
|||||||
<li class="new-chat"><a>
|
<li class="new-chat"><a>
|
||||||
<span class="icon"><el-icon><Plus/></el-icon></span>
|
<span class="icon"><el-icon><Plus/></el-icon></span>
|
||||||
<span class="text">新建会话</span>
|
<span class="text">新建会话</span>
|
||||||
|
<span class="btn" @click="toggleSidebar"><el-button size="small" type="info" circle><el-icon><CloseBold/></el-icon></el-button></span>
|
||||||
</a></li>
|
</a></li>
|
||||||
<li><a>
|
<li><a>
|
||||||
<span class="icon"><el-icon><ChatRound/></el-icon></span>
|
<span class="icon"><el-icon><ChatRound/></el-icon></span>
|
||||||
<span class="text">新建会话</span>
|
<span class="text">会话一</span>
|
||||||
</a></li>
|
</a></li>
|
||||||
<li class="active"><a>
|
<li class="active"><a>
|
||||||
<span class="icon"><el-icon><ChatRound/></el-icon></span>
|
<span class="icon"><el-icon><ChatRound/></el-icon></span>
|
||||||
<span class="text">新建会话</span>
|
<span class="text">会话二</span>
|
||||||
</a></li>
|
</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</nav>
|
</nav>
|
||||||
@ -21,7 +22,7 @@
|
|||||||
|
|
||||||
<div class="main-content" v-loading="loading" element-loading-background="rgba(122, 122, 122, 0.8)">
|
<div class="main-content" v-loading="loading" element-loading-background="rgba(122, 122, 122, 0.8)">
|
||||||
<div class="title">
|
<div class="title">
|
||||||
<span class="icon">
|
<span class="icon" @click="toggleSidebar">
|
||||||
<el-icon><Fold/></el-icon>
|
<el-icon><Fold/></el-icon>
|
||||||
</span>
|
</span>
|
||||||
<span class="text">响应式页面布局代码</span>
|
<span class="text">响应式页面布局代码</span>
|
||||||
@ -87,8 +88,6 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<config-dialog v-model:show="showConfigDialog" :user="userInfo"></config-dialog>
|
|
||||||
|
|
||||||
<div class="token-dialog">
|
<div class="token-dialog">
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="showLoginDialog"
|
v-model="showLoginDialog"
|
||||||
@ -122,27 +121,25 @@
|
|||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {defineComponent, nextTick} from "vue"
|
import {defineComponent, nextTick} from "vue"
|
||||||
import {ChatRound, Fold, Lock, Plus, RefreshRight, VideoPause} from "@element-plus/icons-vue";
|
import {ChatRound, CloseBold, Fold, Lock, Plus, RefreshRight, VideoPause} from "@element-plus/icons-vue";
|
||||||
import {httpGet, httpPost} from "@/utils/http";
|
import {httpGet, httpPost} from "@/utils/http";
|
||||||
import hl from "highlight.js";
|
import hl from "highlight.js";
|
||||||
import ChatReply from "@/components/ChatReply.vue";
|
import ChatReply from "@/components/ChatReply.vue";
|
||||||
import ChatPrompt from "@/components/ChatPrompt.vue";
|
import ChatPrompt from "@/components/ChatPrompt.vue";
|
||||||
import {getSessionId, getUserInfo, setLoginUser} from "@/utils/storage";
|
import {getSessionId, getUserInfo, setLoginUser} from "@/utils/storage";
|
||||||
import {ElMessage, ElMessageBox} from "element-plus";
|
import {ElMessage, ElMessageBox} from "element-plus";
|
||||||
import {randString} from "@/utils/libs";
|
import {isMobile, randString} from "@/utils/libs";
|
||||||
import Clipboard from "clipboard";
|
import Clipboard from "clipboard";
|
||||||
import ConfigDialog from "@/components/ConfigDialog.vue";
|
|
||||||
|
|
||||||
// 免费版 ChatGPT
|
// 免费版 ChatGPT
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'ChatFree',
|
name: 'ChatFree',
|
||||||
components: {ConfigDialog, Lock, VideoPause, RefreshRight, ChatPrompt, ChatReply, ChatRound, Plus, Fold},
|
components: {CloseBold, Lock, VideoPause, RefreshRight, ChatPrompt, ChatReply, ChatRound, Plus, Fold},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
chatData: [],
|
chatData: [],
|
||||||
inputValue: '', // 聊天内容
|
inputValue: '', // 聊天内容
|
||||||
|
|
||||||
showConfigDialog: false,
|
|
||||||
userInfo: {},
|
userInfo: {},
|
||||||
showLoginDialog: false,
|
showLoginDialog: false,
|
||||||
role: 'gpt',
|
role: 'gpt',
|
||||||
@ -177,13 +174,19 @@ export default defineComponent({
|
|||||||
})
|
})
|
||||||
|
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
this.inputBoxWidth = document.getElementById('sidebar') ?
|
if (isMobile()) {
|
||||||
window.innerWidth - document.getElementById('sidebar').offsetWidth - 20 : window.innerWidth - 20;
|
this.inputBoxWidth = window.innerWidth - 20;
|
||||||
|
} else {
|
||||||
|
this.inputBoxWidth = window.innerWidth - document.getElementById('sidebar').offsetWidth - 20;
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
window.addEventListener("resize", () => {
|
window.addEventListener("resize", () => {
|
||||||
this.inputBoxWidth = document.getElementById('sidebar') ?
|
if (isMobile()) {
|
||||||
window.innerWidth - document.getElementById('sidebar').offsetWidth - 20 : window.innerWidth - 20;
|
this.inputBoxWidth = window.innerWidth - 20;
|
||||||
|
} else {
|
||||||
|
this.inputBoxWidth = window.innerWidth - document.getElementById('sidebar').offsetWidth - 20;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
this.connect();
|
this.connect();
|
||||||
@ -446,7 +449,12 @@ export default defineComponent({
|
|||||||
this.showStopGenerate = true;
|
this.showStopGenerate = true;
|
||||||
this.showReGenerate = false;
|
this.showReGenerate = false;
|
||||||
this.socket.send('重新生成上述问题的答案:' + this.previousText);
|
this.socket.send('重新生成上述问题的答案:' + this.previousText);
|
||||||
}
|
},
|
||||||
|
|
||||||
|
// 显示/关闭侧边栏
|
||||||
|
toggleSidebar: function () {
|
||||||
|
document.getElementById("sidebar").classList.toggle('show');
|
||||||
|
},
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
@ -466,6 +474,7 @@ export default defineComponent({
|
|||||||
nav {
|
nav {
|
||||||
margin 0
|
margin 0
|
||||||
padding 0
|
padding 0
|
||||||
|
width 100%
|
||||||
|
|
||||||
ul {
|
ul {
|
||||||
list-style-type: none
|
list-style-type: none
|
||||||
@ -487,6 +496,7 @@ export default defineComponent({
|
|||||||
a {
|
a {
|
||||||
display flex
|
display flex
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
|
position relative
|
||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
font-size 16px;
|
font-size 16px;
|
||||||
@ -510,6 +520,13 @@ export default defineComponent({
|
|||||||
|
|
||||||
li.new-chat {
|
li.new-chat {
|
||||||
border: 1px solid #4A4B4D;
|
border: 1px solid #4A4B4D;
|
||||||
|
|
||||||
|
.btn {
|
||||||
|
display none
|
||||||
|
position absolute
|
||||||
|
right -2px;
|
||||||
|
top -2px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -537,6 +554,7 @@ export default defineComponent({
|
|||||||
.el-icon {
|
.el-icon {
|
||||||
font-size 24px;
|
font-size 24px;
|
||||||
cursor pointer
|
cursor pointer
|
||||||
|
padding-left 10px
|
||||||
}
|
}
|
||||||
|
|
||||||
.text {
|
.text {
|
||||||
@ -669,7 +687,23 @@ export default defineComponent({
|
|||||||
width: 90%;
|
width: 90%;
|
||||||
position absolute;
|
position absolute;
|
||||||
z-index 9999;
|
z-index 9999;
|
||||||
display none
|
top: 0;
|
||||||
|
left: -350px;
|
||||||
|
transition: transform 0.3s ease-in-out;
|
||||||
|
|
||||||
|
nav {
|
||||||
|
ul {
|
||||||
|
li.new-chat {
|
||||||
|
.btn {
|
||||||
|
display inline
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar.show {
|
||||||
|
transform: translateX(350px);
|
||||||
}
|
}
|
||||||
|
|
||||||
.main-content {
|
.main-content {
|
||||||
@ -680,7 +714,7 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
|
|
||||||
.chat-container {
|
.chat-container {
|
||||||
height: calc(100vh - 50px);
|
height: calc(100vh - 40px);
|
||||||
|
|
||||||
.chat-box {
|
.chat-box {
|
||||||
height: calc(100vh - 120px);
|
height: calc(100vh - 120px);
|
||||||
|
Loading…
Reference in New Issue
Block a user