Restructure logo JS to use `setInterval`
This commit is contained in:
parent
9f46ca4443
commit
567d87d90f
|
@ -1,6 +1,5 @@
|
||||||
NProgress.configure(showSpinner: false)
|
NProgress.configure(showSpinner: false)
|
||||||
|
|
||||||
delay = 150
|
|
||||||
defaultClass = 'tanuki-shape'
|
defaultClass = 'tanuki-shape'
|
||||||
pieces = [
|
pieces = [
|
||||||
'path#tanuki-right-cheek',
|
'path#tanuki-right-cheek',
|
||||||
|
@ -9,39 +8,36 @@ pieces = [
|
||||||
'path#tanuki-left-eye, path#tanuki-left-ear',
|
'path#tanuki-left-eye, path#tanuki-left-ear',
|
||||||
'path#tanuki-left-cheek',
|
'path#tanuki-left-cheek',
|
||||||
]
|
]
|
||||||
|
pieceIndex = 0
|
||||||
firstPiece = pieces[0]
|
firstPiece = pieces[0]
|
||||||
timeout = null
|
|
||||||
|
currentTimer = null
|
||||||
|
delay = 150
|
||||||
|
|
||||||
clearHighlights = ->
|
clearHighlights = ->
|
||||||
$(".#{defaultClass}.highlight").attr('class', defaultClass)
|
$(".#{defaultClass}.highlight").attr('class', defaultClass)
|
||||||
|
|
||||||
start = ->
|
start = ->
|
||||||
clearHighlights()
|
clearHighlights()
|
||||||
|
pieceIndex = 0
|
||||||
pieces.reverse() unless pieces[0] == firstPiece
|
pieces.reverse() unless pieces[0] == firstPiece
|
||||||
work(0)
|
currentTimer = setInterval(work, delay)
|
||||||
|
|
||||||
stop = ->
|
stop = ->
|
||||||
window.clearTimeout(timeout)
|
clearInterval(currentTimer)
|
||||||
clearHighlights()
|
clearHighlights()
|
||||||
|
|
||||||
work = (pieceIndex) ->
|
work = ->
|
||||||
# jQuery's addClass won't work on an SVG. Who knew!
|
clearHighlights()
|
||||||
$piece = $(pieces[pieceIndex])
|
$(pieces[pieceIndex]).attr('class', "#{defaultClass} highlight")
|
||||||
$piece.attr('class', "#{defaultClass} highlight")
|
|
||||||
|
|
||||||
timeout = setTimeout(->
|
# If we hit the last piece, reset the index and then reverse the array to
|
||||||
$piece.attr('class', defaultClass)
|
# get a nice back-and-forth sweeping look
|
||||||
|
if pieceIndex == pieces.length - 1
|
||||||
|
pieceIndex = 0
|
||||||
|
pieces.reverse()
|
||||||
|
else
|
||||||
|
pieceIndex++
|
||||||
|
|
||||||
# If we hit the last piece, reset the index and then reverse the array to
|
$(document).on('page:fetch', start)
|
||||||
# get a nice back-and-forth sweeping look
|
$(document).on('page:change', stop)
|
||||||
if pieceIndex + 1 >= pieces.length
|
|
||||||
nextIndex = 0
|
|
||||||
pieces.reverse()
|
|
||||||
else
|
|
||||||
nextIndex = pieceIndex + 1
|
|
||||||
|
|
||||||
work(nextIndex)
|
|
||||||
, delay)
|
|
||||||
|
|
||||||
$(document).on 'page:fetch', start
|
|
||||||
$(document).on 'page:change', stop
|
|
||||||
|
|
Loading…
Reference in New Issue