Merge pull request #10900 from dataease/pr@dev-v2@feat_table_hover_stop_scroll

feat(图表): 表格鼠标悬停暂停滚动 #9106 #9750 #10502
This commit is contained in:
wisonic-s 2024-07-11 14:56:51 +08:00 committed by GitHub
commit 56c0e8a635
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -28,6 +28,7 @@ import { customAttrTrans, customStyleTrans, recursionTransObj } from '@/utils/ca
import { deepCopy } from '@/utils/utils'
import { useEmitt } from '@/hooks/web/useEmitt'
import { trackBarStyleCheck } from '@/utils/canvasUtils'
import { type SpreadSheet } from '@antv/s2'
const dvMainStore = dvMainStoreWithOut()
const {
@ -142,7 +143,7 @@ const calcData = (view: Chart, callback, resetPageInfo = true) => {
}
}
//
let myChart = null
let myChart: SpreadSheet = null
//
let actualChart: ChartObj
const renderChartFromDialog = (viewInfo: Chart, chartDataInfo) => {
@ -164,7 +165,9 @@ const renderChart = (viewInfo: Chart, resetPageInfo: boolean) => {
setupPage(actualChart, resetPageInfo)
myChart?.facet.timer?.stop()
myChart?.facet.cancelScrollFrame()
myChart?.destroy()
myChart = null
const chartView = chartViewManager.getChartView(
viewInfo.render,
viewInfo.type
@ -207,21 +210,28 @@ const setupPage = (chart: ChartObj, resetPageInfo?: boolean) => {
}
}
const mouseMove = () => {
myChart?.facet.timer?.stop()
}
const mouseLeave = () => {
initScroll()
}
const initScroll = () => {
// *toptop<*
const customAttr = actualChart?.customAttr
const senior = actualChart?.senior
if (
myChart &&
senior?.scrollCfg?.open &&
chartData.value.tableRow?.length &&
(view.value.type === 'table-normal' || (view.value.type === 'table-info' && !state.showPage))
) {
//
myChart.facet.timer?.stop()
if (myChart.store.get('scrollY') !== 0) {
myChart.store.set('scrollY', 0)
myChart.render()
}
//
let scrolledOffset = myChart.store.get('scrollY') || 0
//
// 2 2 : = / 2 * 2
const offsetHeight = document.getElementById(containerId).offsetHeight
@ -239,8 +249,14 @@ const initScroll = () => {
if (scrollHeight < scrollBarSize) {
return
}
const viewHeight = offsetHeight - headerHeight - scrollBarSize
const scrollViewCount = chartData.value.tableRow.length - viewHeight / rowHeight
// ,1
if (scrolledOffset >= scrollHeight - 1) {
myChart.store.set('scrollY', 0)
myChart.render()
scrolledOffset = 0
}
const viewedHeight = offsetHeight - headerHeight - scrollBarSize + scrolledOffset
const scrollViewCount = chartData.value.tableRow.length - viewedHeight / rowHeight
const duration = (scrollViewCount / senior.scrollCfg.row) * senior.scrollCfg.interval
myChart.facet.scrollWithAnimation(
{ offsetY: { value: scrollHeight, animate: false } },
@ -462,6 +478,7 @@ onMounted(() => {
onBeforeUnmount(() => {
myChart?.facet.timer?.stop()
myChart?.destroy()
myChart = null
resizeObserver?.disconnect()
})
@ -501,9 +518,15 @@ const tablePageClass = computed(() => {
class="track-bar"
:style="state.trackBarStyle"
@trackClick="trackClick"
@mousemove="mouseMove"
/>
<div v-if="!isError" class="canvas-content">
<div style="position: relative; height: 100%" :id="containerId"></div>
<div
:id="containerId"
style="position: relative; height: 100%"
@mousemove="mouseMove"
@mouseleave="mouseLeave"
></div>
</div>
<el-row :style="autoStyle" v-if="showPage && !isError">
<div