mirror of https://github.com/twbs/ratchet.git
Build mobile apps with simple HTML, CSS, and JS components.
http://goratchet.com/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
245 lines
9.8 KiB
245 lines
9.8 KiB
12 years ago
|
/* ----------------------------------
|
||
|
* 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();
|
||
|
}
|