Blame view

app/assets/javascripts/parallax.coffee 1.48 KB
Georg Hopp authored
1 2 3 4 5 6 7 8 9
#
# OK, this is not really a parallax... I just want to see my content move
# somewhat faster than the background... hey, ho, let's go
#
window.App ||= {}

content_top = content_left = width_delta = height_delta = 0

App.init = ->
Georg Hopp authored
10
	$('a[href*=\\#]').each ->
11 12 13 14 15
		lpath = location.pathname.replace(/^\//,'')
		tpath = this.pathname.replace(/^\//,'')
		if lpath == tpath and
		location.hostname == this.hostname and
		this.hash.replace(/#/,'')
Georg Hopp authored
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
			$targetId = $(this.hash)
			$targetAnchor = $('[name=' + this.hash.slice(1) + ']')
			$target = if $targetId.length
				$targetId
			else
				if $targetAnchor.length
					$targetAnchor
				else
  				false

		if $target
			targetOffset = $target.offset().top

			$(this).click ->
				$("#nav li a").removeClass("active")
				$(this).addClass('active')
				$('html, body').animate({scrollTop: targetOffset}, 1000)
				return false
Georg Hopp authored
34 35 36

App.scroll = ->
	v_scroll = $(document).scrollTop()
Georg Hopp authored
37
	section = Math.floor(v_scroll / $(window).innerHeight())
38 39 40 41
	[section, section+1].forEach (section) ->
		bg_pos = -((v_scroll-(section*$(window).innerHeight()))/2)
		section_element = $($(".section")[section])
		if section_element and section_element.css("background-image") != "none"
Georg Hopp authored
42 43
			content = section_element.find(".content")
			content.css("display", "none")
44 45 46
			section_element.css(
				"background-position",
				"center " + bg_pos + "px")
Georg Hopp authored
47
			content.css("display", "block")
Georg Hopp authored
48 49 50 51 52 53 54 55

$(document).on "page:change", ->
	App.init()

$(window).on "scroll", ->
	App.scroll()

# vim: set ts=2 sw=2: