2018-11-05 05:06:39 -05:00
|
|
|
/* eslint-disable
|
|
|
|
max-len,
|
|
|
|
no-return-assign,
|
|
|
|
*/
|
|
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
|
|
// Fix any style issues and re-enable lint.
|
|
|
|
/*
|
|
|
|
* decaffeinate suggestions:
|
|
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
|
|
*/
|
2020-05-19 05:02:56 -04:00
|
|
|
import App from '../base'
|
2018-11-05 05:06:39 -05:00
|
|
|
|
2023-10-13 05:13:49 -04:00
|
|
|
export default App.directive('updateScrollBottomOn', [
|
|
|
|
'$timeout',
|
2023-10-17 04:36:46 -04:00
|
|
|
function ($timeout) {
|
|
|
|
return {
|
|
|
|
restrict: 'A',
|
|
|
|
link(scope, element, attrs, ctrls) {
|
|
|
|
// We keep the offset from the bottom fixed whenever the event fires
|
|
|
|
//
|
|
|
|
// ^ | ^
|
|
|
|
// | | | scrollTop
|
|
|
|
// | | v
|
|
|
|
// | |-----------
|
|
|
|
// | | ^
|
|
|
|
// | | |
|
|
|
|
// | | | clientHeight (viewable area)
|
|
|
|
// | | |
|
|
|
|
// | | |
|
|
|
|
// | | v
|
|
|
|
// | |-----------
|
|
|
|
// | | ^
|
|
|
|
// | | | scrollBottom
|
|
|
|
// v | v
|
|
|
|
// \
|
|
|
|
// scrollHeight
|
2020-05-19 05:02:56 -04:00
|
|
|
|
2023-10-17 04:36:46 -04:00
|
|
|
let scrollBottom = 0
|
|
|
|
element.on(
|
|
|
|
'scroll',
|
|
|
|
e =>
|
|
|
|
(scrollBottom =
|
|
|
|
element[0].scrollHeight -
|
|
|
|
element[0].scrollTop -
|
|
|
|
element[0].clientHeight)
|
|
|
|
)
|
2018-11-05 05:06:39 -05:00
|
|
|
|
2023-10-17 04:36:46 -04:00
|
|
|
return scope.$on(attrs.updateScrollBottomOn, () =>
|
|
|
|
$timeout(
|
|
|
|
() =>
|
|
|
|
element.scrollTop(
|
|
|
|
element[0].scrollHeight - element[0].clientHeight - scrollBottom
|
|
|
|
),
|
|
|
|
0
|
|
|
|
)
|
2023-10-13 05:13:49 -04:00
|
|
|
)
|
2023-10-17 04:36:46 -04:00
|
|
|
},
|
|
|
|
}
|
|
|
|
},
|
2023-10-13 05:13:49 -04:00
|
|
|
])
|