mirror of
https://github.com/tenrok/vue2-datepicker.git
synced 2026-06-01 17:14:07 +03:00
24 lines
749 B
JavaScript
24 lines
749 B
JavaScript
export default function scrollIntoView (container, selected) {
|
|
if (!selected) {
|
|
container.scrollTop = 0
|
|
return
|
|
}
|
|
|
|
const offsetParents = []
|
|
let pointer = selected.offsetParent
|
|
while (pointer && container !== pointer && container.contains(pointer)) {
|
|
offsetParents.push(pointer)
|
|
pointer = pointer.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
|
|
}
|
|
}
|