element-plus/packages/utils/scroll-into-view.ts
三咲智子 55348b30b6
style: use prettier (#3228)
* style: use prettier

* style: just prettier format, no code changes

* style: eslint fix
object-shorthand, prefer-const

* style: fix no-void

* style: no-console
2021-09-04 19:29:28 +08:00

37 lines
893 B
TypeScript

import isServer from './isServer'
export default function scrollIntoView(
container: HTMLElement,
selected: HTMLElement
): void {
if (isServer) return
if (!selected) {
container.scrollTop = 0
return
}
const offsetParents = []
let pointer = selected.offsetParent
while (
pointer !== null &&
container !== pointer &&
container.contains(pointer)
) {
offsetParents.push(pointer)
pointer = (pointer as HTMLElement).offsetParent
}
const top =
selected.offsetTop +
offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0)
const bottom = top + selected.offsetHeight
const viewRectTop = container.scrollTop
const viewRectBottom = viewRectTop + container.clientHeight
if (top < viewRectTop) {
container.scrollTop = top
} else if (bottom > viewRectBottom) {
container.scrollTop = bottom - container.clientHeight
}
}