Pony.fm/resources/scripts/app/directives/scroll-recorder.coffee

45 lines
1.7 KiB
CoffeeScript
Raw Normal View History

# Pony.fm - A community for pony fan music.
2018-04-21 06:25:36 +02:00
# Copyright (C) 2015 Feld0
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
module.exports = angular.module('ponyfm').directive 'pfmScrollRecorder', () ->
2015-10-25 03:35:37 +01:00
(scope, element, attrs) ->
timeout = null
onScroll = null
lastInView = null
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
element.scroll (e) ->
(window.clearTimeout timeout) if timeout
timeout = window.setTimeout (-> onScroll e), 500
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
onScroll = (e) -> scope.safeApply ->
items = element.find 'li:not(.empty)'
itemHeight = (items.eq 0).height()
itemsArray = items.get()
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
elementViewTop = element.offset().top
elementViewBottom = elementViewTop + element.height()
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
for i in [itemsArray.length - 1..0]
listItem = $ itemsArray[i]
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
listItemTop = listItem.offset().top + itemHeight
isInView = listItemTop > elementViewTop && listItemTop < elementViewBottom
if isInView
lastInView = listItem
break
2015-08-31 17:42:21 +02:00
2015-10-25 03:35:37 +01:00
scope.$emit 'element-in-view', angular.element(lastInView).scope()