-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathiscroll.html
100 lines (89 loc) · 2.88 KB
/
iscroll.html
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<!DOCTYPE html>
<html>
<head>
<script src="http://cdnjs.cloudflare.com/ajax/libs/coffee-script/1.6.3/coffee-script.min.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script src="http://rawgithub.com/cubiq/iscroll/master/build/iscroll-probe.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/handlebars.js/1.0.0/handlebars.js"></script>
<script src="http://builds.emberjs.com/tags/v1.8.1/ember.js"></script>
<script src="../ember-cloaking.js"></script>
<style>
.ember-view {
-webkit-animation: debug .3s;
}
@-webkit-keyframes debug {
0% {
background-color: yellow;
}
100% {
background-color: inherit;
}
}
.scroll-wrap {
position: relative;
overflow: hidden;
border: 1px dotted black;
}
.lol {
width: 100%;
background: black;
opacity: .2;
position: absolute;
}
</style>
<script type="text/coffeescript">
App = Ember.Application.create()
App.Router.map ->
@resource 'scroll'
# random nums for view height
random_height = ->
Math.round( Math.random()*100 + 20 )
# create a lots of crap
model = ( { id: i, height: random_height() } for i in [0..500] )
App.ScrollRoute = Ember.Route.extend
model: ->
model
App.ScrollView = Em.View.extend
templateName: 'scroll'
classNames: ['scroll-wrap']
scrollTop:0
height: 500
didInsertElement: ->
@$().css 'height', @get('height')
iscroll = new IScroll @get('element'),
probeType: 2
mouseWheel: true
preventDefault: false
scrollbars: true
interactiveScrollbars: true
deceleration: 0.0012
@set 'iscroll', iscroll
iscroll.on 'scroll', => @set 'scrollTop', -iscroll.y
iscroll.on 'scrollEnd', => @set 'scrollTop', -iscroll.y
interval_id = setInterval ->
iscroll.refresh()
, 300
@set 'interval_id', interval_id
willDestroyElement: ->
@get('iscroll').destroy()
clearInterval(@get('interval_id'))
App.ItemView = Em.View.extend
templateName: 'item'
didInsertElement: ->
@$().css 'height', @get('context.height')
</script>
<title>Ember Cloaking Test (iScroll)</title>
</head>
<body>
<script type="text/x-handlebars">
{{#link-to "scroll"}}go to scroll{{/link-to}}
{{outlet}}
</script>
<script type="text/x-handlebars" data-template-name="scroll">
{{cloaked-collection itemViewClass="item" content=model wrapperTopBinding="view.scrollTop" wrapperHeightBinding="view.height"}}
</script>
<script type="text/x-handlebars" data-template-name="item">
#{{id}} ({{height}}px)
</script>
</body>
</html>