设置ai弹窗滑动

This commit is contained in:
bjzhoujian
2025-12-02 10:57:24 +08:00
parent 6016e00ae8
commit 4e1940b36f
2 changed files with 52 additions and 9 deletions

View File

@@ -87,4 +87,16 @@
border: 1px solid #e7e7e7 !important; border: 1px solid #e7e7e7 !important;
box-shadow: 0px 1px 5px 1px rgba(92,98,111,.3); box-shadow: 0px 1px 5px 1px rgba(92,98,111,.3);
} }
</style>
#app {
pointer-events: none;
}
#app > *:not(.case-expert-dialog) {
pointer-events: auto;
}
.case-expert-dialog {
pointer-events: auto;
}
</style>

View File

@@ -33,6 +33,7 @@
class="welcome-message" class="welcome-message"
ref="messageContainer" ref="messageContainer"
@scroll="handleScroll" @scroll="handleScroll"
@wheel="handleWheel"
> >
<div class="message-text" v-for="(item, index) in messageList" :key="index"> <div class="message-text" v-for="(item, index) in messageList" :key="index">
<messages :messageData="item" :suggestions="suggestions" @getMinWindow="minimizeWindow"></messages> <messages :messageData="item" :suggestions="suggestions" @getMinWindow="minimizeWindow"></messages>
@@ -191,7 +192,7 @@ export default {
left: parseInt(dialogEl.style.left), left: parseInt(dialogEl.style.left),
top: parseInt(dialogEl.style.top) top: parseInt(dialogEl.style.top)
}; };
sessionStorage.setItem('aiCallDialogPosition', JSON.stringify(currentPosition)); // sessionStorage.setItem('aiCallDialogPosition', JSON.stringify(currentPosition));
// 移除全局事件监听 // 移除全局事件监听
document.removeEventListener('mousemove', handleMouseMove); document.removeEventListener('mousemove', handleMouseMove);
@@ -515,12 +516,12 @@ export default {
} }
// 检查是否有保存的位置状态 // 检查是否有保存的位置状态
const savedPosition = sessionStorage.getItem('aiCallDialogPosition'); // const savedPosition = sessionStorage.getItem('aiCallDialogPosition');
if (savedPosition) { // if (savedPosition) {
const { left, top } = JSON.parse(savedPosition); // const { left, top } = JSON.parse(savedPosition);
dialogEl.style.left = left + 'px'; // dialogEl.style.left = left + 'px';
dialogEl.style.top = top + 'px'; // dialogEl.style.top = top + 'px';
} // }
} }
let doc = document.querySelector('.welcome-message') let doc = document.querySelector('.welcome-message')
@@ -567,7 +568,7 @@ closeMinimizedWindow() {
console.log('关闭弹窗') console.log('关闭弹窗')
// 清除保存的状态 // 清除保存的状态
sessionStorage.removeItem('aiCallDialogSize'); sessionStorage.removeItem('aiCallDialogSize');
sessionStorage.removeItem('aiCallDialogPosition'); // sessionStorage.removeItem('aiCallDialogPosition');
this.$emit('close') this.$emit('close')
// 可以在这里执行其他逻辑 // 可以在这里执行其他逻辑
}, },
@@ -657,6 +658,31 @@ closeMinimizedWindow() {
} }
}, },
// 处理鼠标滚轮事件
handleWheel(event) {
const element = this.$refs.messageContainer;
if (!element) return;
// 阻止事件冒泡,防止滚动底层页面
event.stopPropagation();
// 计算滚动方向和距离
const delta = event.deltaY || event.detail || event.wheelDelta;
// 检查是否可以继续滚动
if (delta < 0 && element.scrollTop === 0) {
// 向上滚动且已在顶部,阻止默认行为
event.preventDefault();
} else if (delta > 0 && element.scrollHeight - element.scrollTop <= element.clientHeight) {
// 向下滚动且已在底部,阻止默认行为
event.preventDefault();
} else {
// 允许在容器内滚动
element.scrollTop += delta;
event.preventDefault();
}
},
// 最小化窗口的点击事件处理方法 // 最小化窗口的点击事件处理方法
onMinimizedWindowClick() { onMinimizedWindowClick() {
// 当点击最小化窗口时如果dialogVisible为false则通过事件通知父组件显示对话框 // 当点击最小化窗口时如果dialogVisible为false则通过事件通知父组件显示对话框
@@ -671,6 +697,9 @@ closeMinimizedWindow() {
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
::v-deep .el-dialog__wrapper{
position: unset!important;
}
.case-expert-dialog { .case-expert-dialog {
::v-deep .el-dialog{ ::v-deep .el-dialog{
background: url("./components/u762.svg") no-repeat ; background: url("./components/u762.svg") no-repeat ;
@@ -679,6 +708,8 @@ closeMinimizedWindow() {
overflow: hidden; overflow: hidden;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
pointer-events: auto;
z-index: 2000;
//background-color: rgba(255, 255, 255, 0.8); //background-color: rgba(255, 255, 255, 0.8);
} }