mirror of https://github.com/twbs/ratchet.git
Simon Waldherr
12 years ago
16 changed files with 1127 additions and 428 deletions
@ -0,0 +1,3 @@ |
|||||||
|
[submodule "submodules/pulltorefresh"] |
||||||
|
path = submodules/pulltorefresh |
||||||
|
url = git@github.com:SimonWaldherr/PullToRefresh.git |
@ -0,0 +1,101 @@ |
|||||||
|
/* PullToRefresh styles |
||||||
|
-------------------------------------------------- */ |
||||||
|
|
||||||
|
.scrollable { |
||||||
|
overflow-y: auto; |
||||||
|
height: auto; |
||||||
|
-webkit-overflow-scrolling: touch; |
||||||
|
position: absolute; |
||||||
|
bottom: 50px; |
||||||
|
} |
||||||
|
|
||||||
|
.scrollable .wrap { |
||||||
|
min-height: 100%; |
||||||
|
padding-bottom: 1px; |
||||||
|
background: #f5f5f5; |
||||||
|
-webkit-transform: translateZ(0); |
||||||
|
-webkit-user-select: none; |
||||||
|
-moz-user-select: none; |
||||||
|
user-select: none; |
||||||
|
} |
||||||
|
|
||||||
|
.wrap { |
||||||
|
position: relative; |
||||||
|
} |
||||||
|
|
||||||
|
.ptr_box { |
||||||
|
position: absolute; |
||||||
|
top: -55px; |
||||||
|
line-height: 55px; |
||||||
|
display: block; |
||||||
|
text-align: center; |
||||||
|
height: 55px; |
||||||
|
left: 0px; |
||||||
|
right: 0px; |
||||||
|
} |
||||||
|
|
||||||
|
.ptr_container { |
||||||
|
position: relative; |
||||||
|
width: 230px; |
||||||
|
margin: auto; |
||||||
|
height: 40px; |
||||||
|
top: 15px; |
||||||
|
} |
||||||
|
|
||||||
|
.ptr_image { |
||||||
|
margin: 5px; |
||||||
|
margin-top: 20px; |
||||||
|
height: 30px; |
||||||
|
width: 30px; |
||||||
|
zoom: 0.5; |
||||||
|
background-image: url(''); |
||||||
|
-webkit-background-size: 100% 100%; |
||||||
|
-moz-background-size: 100% 100%; |
||||||
|
background-size: 100% 100%; |
||||||
|
background-repeat: repeat-x; |
||||||
|
display: inline-block; |
||||||
|
background-position: left center; |
||||||
|
float: left; |
||||||
|
position: relative; |
||||||
|
bottom: 0px; |
||||||
|
-webkit-backface-visibility: hidden |
||||||
|
} |
||||||
|
|
||||||
|
.ptr_image.loading { |
||||||
|
background-image: url(''); |
||||||
|
background-repeat: no-repeat; |
||||||
|
-webkit-animation-name: rotate; |
||||||
|
-webkit-animation-duration:0.5s; |
||||||
|
-webkit-animation-timing-function:linear; |
||||||
|
-webkit-animation-iteration-count:infinite; |
||||||
|
-webkit-animation-play-state:running; |
||||||
|
} |
||||||
|
|
||||||
|
.ptr_text { |
||||||
|
position: relative; |
||||||
|
top: -10px; |
||||||
|
left: 20px; |
||||||
|
float: left; |
||||||
|
font-size: 20px; |
||||||
|
} |
||||||
|
|
||||||
|
.inserted { |
||||||
|
border-top: 1px solid #0a0a0a; |
||||||
|
list-style-type: none; |
||||||
|
padding: 0; |
||||||
|
margin: 0; |
||||||
|
} |
||||||
|
|
||||||
|
.inserted ul { |
||||||
|
padding: 0px; |
||||||
|
margin: 0px; |
||||||
|
} |
||||||
|
|
||||||
|
@-webkit-keyframes rotate { |
||||||
|
from { |
||||||
|
-webkit-transform: rotate(0deg); |
||||||
|
} |
||||||
|
to { |
||||||
|
-webkit-transform: rotate(360deg); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,244 @@ |
|||||||
|
/* ---------------------------------- |
||||||
|
* PullToRefresh v0.003 |
||||||
|
* By Simon Waldherr |
||||||
|
* https://github.com/SimonWaldherr/PullToRefresh
|
||||||
|
* Licensed under The MIT License |
||||||
|
* http://opensource.org/licenses/MIT
|
||||||
|
* ---------------------------------- */ |
||||||
|
|
||||||
|
var ptr_scrollable_parent = false; |
||||||
|
|
||||||
|
function ptr_init() { |
||||||
|
document.getElementsByTagName('body')[0].className = !!('ontouchstart' in window) ?
|
||||||
|
document.getElementsByTagName('body')[0].className+=' touch' :
|
||||||
|
document.getElementsByTagName('body')[0].className+=' desktop'; |
||||||
|
var scrollables = document.getElementsByClassName('scrollable'); |
||||||
|
|
||||||
|
for(var i = 0; i<scrollables.length; i++) { |
||||||
|
if(scrollables[i].hasAttribute('data-url') != false) { |
||||||
|
var ptr_box = document.createElement('div'), |
||||||
|
ptr_container = document.createElement('div'), |
||||||
|
ptr_image = document.createElement('div'), |
||||||
|
ptr_text = document.createElement('div'); |
||||||
|
|
||||||
|
ptr_box.appendChild(ptr_container); |
||||||
|
ptr_container.appendChild(ptr_image); |
||||||
|
ptr_container.appendChild(ptr_text); |
||||||
|
ptr_text.innerHTML = 'Pull to refresh'; |
||||||
|
|
||||||
|
ptr_box.className = 'ptr_box'; |
||||||
|
ptr_container.className = 'ptr_container'; |
||||||
|
ptr_image.className = 'ptr_image'; |
||||||
|
ptr_text.className = 'ptr_text'; |
||||||
|
|
||||||
|
scrollables[i].firstElementChild.insertBefore(ptr_box, scrollables[i].firstElementChild.firstChild); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
document.addEventListener('touchstart',function(e) { |
||||||
|
var parent = e.target; |
||||||
|
|
||||||
|
if(typeof parent.className === null) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
for(var i = 0; i < 10; i++) { |
||||||
|
if(typeof parent.className !== 'undefined') { |
||||||
|
|
||||||
|
if(parent.className.match('scrollable')) { |
||||||
|
|
||||||
|
ptr_scrollable_parent = i; |
||||||
|
i = 10; |
||||||
|
|
||||||
|
if(parent.hasAttribute('data-url') != false) { |
||||||
|
if(typeof parent.getElementsByClassName('ptr_box')[0] != 'undefined') { |
||||||
|
|
||||||
|
} else { |
||||||
|
var ptr_box = document.createElement('div'), |
||||||
|
ptr_container = document.createElement('div'), |
||||||
|
ptr_image = document.createElement('div'), |
||||||
|
ptr_text = document.createElement('div'); |
||||||
|
|
||||||
|
ptr_box.appendChild(ptr_container); |
||||||
|
ptr_container.appendChild(ptr_image); |
||||||
|
ptr_container.appendChild(ptr_text); |
||||||
|
ptr_text.innerHTML = 'Pull to refresh'; |
||||||
|
|
||||||
|
ptr_box.className = 'ptr_box'; |
||||||
|
ptr_container.className = 'ptr_container'; |
||||||
|
ptr_image.className = 'ptr_image'; |
||||||
|
ptr_text.className = 'ptr_text'; |
||||||
|
|
||||||
|
parent.firstElementChild.insertBefore(ptr_box, parent.firstElementChild.firstChild); |
||||||
|
} |
||||||
|
} else if(typeof parent.getElementsByClassName('ptr_box')[0] != 'undefined') { |
||||||
|
parent.removeChild(parent.getElementsByClassName('ptr_box')[0]); |
||||||
|
} |
||||||
|
|
||||||
|
if(parent.scrollTop === 0) { |
||||||
|
parent.scrollTop = 1; |
||||||
|
} else if((parent.scrollTop+parent.offsetHeight) === parent.scrollHeight) { |
||||||
|
parent.scrollTop = parent.scrollTop-1; |
||||||
|
} |
||||||
|
} else { |
||||||
|
|
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
if((typeof parent.parentNode.tagName === 'undefined')) { |
||||||
|
i = 10; |
||||||
|
return false; |
||||||
|
} else if((parent.parentNode.tagName == 'BODY')||(parent.parentNode.tagName == 'HTML')) { |
||||||
|
i = 10; |
||||||
|
return false; |
||||||
|
} else { |
||||||
|
parent = parent.parentNode; |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
document.addEventListener('touchmove',function(e) { |
||||||
|
var parent = e.target; |
||||||
|
var scroll = false; |
||||||
|
var rotate = 90; |
||||||
|
|
||||||
|
if(ptr_scrollable_parent == false) { |
||||||
|
e.preventDefault(); |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
for(var i = 0; i < ptr_scrollable_parent; i++) { |
||||||
|
parent = parent.parentNode; |
||||||
|
} |
||||||
|
|
||||||
|
if((ptr_scrollable_parent != false)&&(parent.hasAttribute('data-url') != false)) { |
||||||
|
|
||||||
|
scroll = true; |
||||||
|
|
||||||
|
var ptr_element = parent; |
||||||
|
var ptr_wrapelement = ptr_element.getElementsByClassName('wrap')[0]; |
||||||
|
|
||||||
|
var top = ptr_element.scrollTop; |
||||||
|
var ptr = ptr_element.getElementsByClassName('ptr_box')[0]; |
||||||
|
|
||||||
|
if((ptr_wrapelement.className.indexOf(' active') === -1)&&(!ptr_wrapelement.getElementsByClassName('ptr_image')[0].className.match('loading'))) { |
||||||
|
if(ptr_element.scrollTop < -25) { |
||||||
|
rotate = (top < -40) ? -90 : 130 + (top*12+270); |
||||||
|
} |
||||||
|
|
||||||
|
if(ptr_element.scrollTop < 0) { |
||||||
|
ptr.style.opacity = 1.0; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['-webkit-transform'] = "scale(1) rotate("+rotate+"deg)"; |
||||||
|
|
||||||
|
if((ptr_element.scrollTop < -30)&&(ptr_element.scrollTop > -45)) { |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['width'] = "40px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-left'] = "10px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-right'] = "10px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['background-size'] = "50% 100%"; |
||||||
|
} else if(ptr_element.scrollTop >= -30) { |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['width'] = "30px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-left'] = "15px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-right'] = "15px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['background-size'] = "100% 100%"; |
||||||
|
} else { |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['width'] = "60px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-left'] = "0px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-right'] = "0px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['background-size'] = "34% 100%"; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
if(ptr_element.scrollTop < -51) { |
||||||
|
if(ptr_wrapelement.className.indexOf(' active') === -1) { |
||||||
|
ptr_wrapelement.className += ' active'; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_text')[0].innerHTML = 'Loading ...'; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].className += ' loading'; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['width'] = "30px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-left'] = "15px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['margin-right'] = "15px"; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].style['background-size'] = "100% 100%"; |
||||||
|
|
||||||
|
var ptr_element = parent; |
||||||
|
var ptr_wrapelement = ptr_element.getElementsByClassName('wrap')[0]; |
||||||
|
var ptr_eleId = parent.id; |
||||||
|
var time = new Date(); |
||||||
|
|
||||||
|
reqwest({ |
||||||
|
url: parent.getAttribute('data-url')+'?rt='+time.getTime() |
||||||
|
, type: 'html' |
||||||
|
, method: 'post' |
||||||
|
, data: { usertime: time.getTime() } |
||||||
|
, error: function () {
|
||||||
|
alert('Could not connect');
|
||||||
|
ptr_wrapelement.style.top = '0px'; |
||||||
|
ptr.getElementsByClassName('ptr_image')[0].className = ptr.getElementsByClassName('ptr_image')[0].className.replace(' loading', ''); |
||||||
|
ptr_wrapelement.className = ptr_wrapelement.className.replace(' active', ''); |
||||||
|
hideLoading(ptr_eleId); |
||||||
|
} |
||||||
|
, success: function (resp) { |
||||||
|
var ptrbox = document.getElementById(ptr_eleId).getElementsByClassName('ptr_box')[0]; |
||||||
|
var insert = document.createElement('div'); |
||||||
|
insert.innerHTML = resp; |
||||||
|
insert.className = 'inserted'; |
||||||
|
|
||||||
|
ptr_wrapelement.insertBefore(insert, ptrbox.nextSibling); |
||||||
|
ptr_wrapelement.style.top = '0px'; |
||||||
|
ptr.getElementsByClassName('ptr_image')[0].className = ptr.getElementsByClassName('ptr_image')[0].className.replace(' loading', ''); |
||||||
|
ptr_wrapelement.className = ptr_wrapelement.className.replace(' active', ''); |
||||||
|
var inserted = document.getElementsByClassName('inserted')[0]; |
||||||
|
ptr_element.scrollTop = inserted.clientHeight-51; |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_text')[0].innerHTML = ''; |
||||||
|
ptr.style.opacity = 0.0; |
||||||
|
|
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_image')[0].className = ptr_wrapelement.getElementsByClassName('ptr_image')[0].className.replace(' loading', ''); |
||||||
|
ptr_wrapelement.style.top = '0px'; |
||||||
|
|
||||||
|
ptr_scrollable_parent = false; |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
} else if(ptr_element.scrollTop != 0) { |
||||||
|
ptr_wrapelement.className = ptr_wrapelement.className.replace(' active', ''); |
||||||
|
ptr_wrapelement.getElementsByClassName('ptr_text')[0].innerHTML = 'Pull to refresh'; |
||||||
|
} |
||||||
|
} |
||||||
|
} else if((ptr_scrollable_parent != false)) { |
||||||
|
scroll = true; |
||||||
|
} |
||||||
|
|
||||||
|
if(scroll == false) { |
||||||
|
e.preventDefault(); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
document.addEventListener('touchend',function(e) { |
||||||
|
var parent = e.target; |
||||||
|
var scroll = false; |
||||||
|
|
||||||
|
for(var i = 0; i < ptr_scrollable_parent; i++) { |
||||||
|
parent = parent.parentNode; |
||||||
|
} |
||||||
|
|
||||||
|
if((parent.hasAttribute('data-url') != false)&&(ptr_scrollable_parent != false)) { |
||||||
|
if((parent.hasAttribute('data-url') != false)) { |
||||||
|
|
||||||
|
var ptr_element = parent; |
||||||
|
var ptr_wrapelement = ptr_element.getElementsByClassName('wrap')[0]; |
||||||
|
var ptr_eleId = parent.id; |
||||||
|
|
||||||
|
var top = ptr_element.scrollTop; |
||||||
|
var ptr = ptr_element.getElementsByClassName('ptr_box')[0]; |
||||||
|
|
||||||
|
if(ptr_wrapelement.getElementsByClassName('ptr_image')[0].className.match('loading')) { |
||||||
|
ptr_wrapelement.className = ptr_wrapelement.className.replace(' active', ''); |
||||||
|
ptr_wrapelement.style.top = '51px'; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
ptr_scrollable_parent = false; |
||||||
|
}); |
||||||
|
} |
||||||
|
window.onload = function() { |
||||||
|
ptr_init(); |
||||||
|
} |
Loading…
Reference in new issue