-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathslidePager.coffee
60 lines (51 loc) · 1.63 KB
/
slidePager.coffee
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
class window.SlidePager
constructor: (options) ->
@$body = $("body")
@number = 1111
@beforenumber = 1111
shiftRight: ->
@selectPanel("right")
shiftLeft: ->
@selectPanel("left")
shiftUp: ->
@selectPanel("up")
shiftDown: ->
@selectPanel("down")
$dataname: (number)->
return $("[data-js="+number+"]")
isBack: (latestState) ->
return @beforeState[@beforeState.length-1] == latestState
selectPanel: (dir)->
switch dir
when "left"
if parseInt((@number+ "").slice(0,1)) >= parseInt((@number+ "").slice(2,3))
@movePanel(1000, dir)
else
@movePanel(-10, dir)
when "up"
if parseInt((@number+ "").slice(1,2)) >= parseInt((@number+ "").slice(3,4))
@movePanel(100, dir)
else
@movePanel(-1, dir)
when "right"
if parseInt((@number+ "").slice(2,3)) >= parseInt((@number+ "").slice(0,1))
@movePanel(10, dir)
else
@movePanel(-1000, dir)
when "down"
if parseInt((@number+ "").slice(3,4)) >= parseInt((@number+ "").slice(1,2))
@movePanel(1, dir)
else
@movePanel(-100, dir)
movePanel: (num, dir) ->
if @$dataname(@number+num).hasClass("pages")
e = $.Event( "transing" )
$(window).trigger( e )
@$dataname(@number).addClass("move"+dir).on "transitionend", =>
@$dataname(@beforenumber).removeClass("active")
@$dataname(@beforenumber).removeClass("move"+dir)
e = $.Event( "transfinish" )
$(window).trigger( e )
@beforenumber = @number
@number += num
@$dataname(@number).addClass("active")