aboutsummaryrefslogtreecommitdiff
path: root/src/components/chat/chat_layout_utils.js
blob: f07ba2a181b570e5a599e028f69ff84ffa3dc1dc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// Captures a scroll position
export const getScrollPosition = (el) => {
  return {
    scrollTop: el.scrollTop,
    scrollHeight: el.scrollHeight,
    offsetHeight: el.offsetHeight
  }
}

// A helper function that is used to keep the scroll position fixed as the new elements are added to the top
// Takes two scroll positions, before and after the update.
export const getNewTopPosition = (previousPosition, newPosition) => {
  return previousPosition.scrollTop + (newPosition.scrollHeight - previousPosition.scrollHeight)
}

export const isBottomedOut = (el, offset = 0) => {
  if (!el) { return }
  const scrollHeight = el.scrollTop + offset
  const totalHeight = el.scrollHeight - el.offsetHeight
  return totalHeight <= scrollHeight
}

// Height of the scrollable container. The dynamic height is needed to ensure the mobile browser panel doesn't overlap or hide the posting form.
export const scrollableContainerHeight = (inner, header, footer) => {
  const height = parseFloat(getComputedStyle(inner, null).height.replace('px', ''))
  return height - header.clientHeight - footer.clientHeight
}