Browse Source

adding better scrolling via pulltorefresh submodule

pull/154/head
Simon Waldherr 12 years ago
parent
commit
f11d6823e6
  1. 3
      .gitmodules
  2. 105
      dist/ratchet.css
  3. 248
      dist/ratchet.js
  4. 5
      dist/template.html
  5. 6
      lib/css/bars.css
  6. 101
      lib/css/pulltorefresh.css
  7. 244
      lib/js/pulltorefresh.js
  8. 3
      lib/js/push.js
  9. 1
      submodules/pulltorefresh
  10. 55
      test/app/checkout.html
  11. 57
      test/app/choose-movie.html
  12. 55
      test/app/choose-theater.html
  13. 4
      test/app/css/app.css
  14. 56
      test/app/index.html
  15. 51
      test/app/settings.html
  16. 57
      test/app/theaters.html

3
.gitmodules vendored

@ -0,0 +1,3 @@
[submodule "submodules/pulltorefresh"]
path = submodules/pulltorefresh
url = git@github.com:SimonWaldherr/PullToRefresh.git

105
dist/ratchet.css vendored

@ -197,6 +197,12 @@ a {
border-bottom-width: 0;
}
/* Bars inside the scrollable div */
.bar-scrolling {
position: relative;
top: auto;
}
/* Title bar
-------------------------------------------------- */
@ -1283,4 +1289,103 @@ select {
.content.slide.right {
-webkit-transform: translate3d(100%, 0, 0);
transform: translate3d(100%, 0, 0);
}/* PullToRefresh styles
-------------------------------------------------- */
.scrollable {
overflow-y: auto;
height: auto;
-webkit-overflow-scrolling: touch;
position: absolute;
}
.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);
}
}

248
dist/ratchet.js vendored

@ -120,8 +120,7 @@
var bars = {
bartab : '.bar-tab',
bartitle : '.bar-title',
barfooter : '.bar-footer',
barheadersecondary : '.bar-header-secondary'
barfooter : '.bar-footer'
}
var cacheReplace = function (data, updates) {
@ -763,3 +762,248 @@
});
}();
/* ----------------------------------
* 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();
}

5
dist/template.html vendored

@ -42,7 +42,8 @@
</header>
<!-- Wrap all non-bar HTML in the .content div (this is actually what scrolls) -->
<div class="content">
<div class="content scrollable" id="list">
<div class="wrap">
<div class="content-padded">
<p class="welcome">Thanks for downloading Ratchet. This is an example HTML page that's linked up to compiled Ratchet CSS and JS, has the proper meta tags and the HTML structure. Need some more help before you start filling this with your own content? Check out some Ratchet resources:</p>
</div>
@ -73,7 +74,7 @@
</a>
</li>
</ul>
</div>
</div>
</body>

6
lib/css/bars.css

@ -37,6 +37,12 @@
border-bottom-width: 0;
}
/* Bars inside the scrollable div */
.bar-scrolling {
position: relative;
top: auto;
}
/* Title bar
-------------------------------------------------- */

101
lib/css/pulltorefresh.css

@ -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);
}
}

244
lib/js/pulltorefresh.js

@ -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();
}

3
lib/js/push.js

@ -25,8 +25,7 @@
var bars = {
bartab : '.bar-tab',
bartitle : '.bar-title',
barfooter : '.bar-footer',
barheadersecondary : '.bar-header-secondary'
barfooter : '.bar-footer'
}
var cacheReplace = function (data, updates) {

1
submodules/pulltorefresh

@ -0,0 +1 @@
Subproject commit a4a3875eb07f02cf4266ccb09f74263d2755ec02

55
test/app/checkout.html

@ -24,31 +24,9 @@
</a>
<h1 class="title">Buy tickets</h1>
</header>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
<div class="content">
<div class="content scrollable" id="list">
<div class="wrap">
<div class="">
<div class="checkout-form content-padded">
<form>
<div class="input-group">
@ -59,7 +37,6 @@
<input type="email" placeholder="Email">
</div>
</div>
<div class="input-group">
<div class="input-row">
<input type="text" placeholder="Name on card">
@ -71,11 +48,33 @@
<input type="text" placeholder="Security code">
</div>
</div>
<a class="button-positive button-block">Checkout</a>
</form>
</div>
</div>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
</body>
</html>

57
test/app/choose-movie.html

@ -17,44 +17,20 @@
</head>
<body>
<header class="bar-title">
<a class="button-prev" href="theaters.html" data-transition="slide-out">
Back
</a>
<h1 class="title">Choose a movie</h1>
</header>
<nav class="bar-standard bar-header-secondary">
<div class="content scrollable" id="list">
<div class="wrap">
<nav class="bar-standard bar-header-secondary bar-scrolling">
<form>
<input type="search" placeholder="Search for movies">
</form>
</nav>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item active">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
<div class="content">
<div class="">
<ul class="list">
<li class="list-divider">Recommended movies</li>
<li>
@ -119,7 +95,30 @@
<a class="button-positive" href="checkout.html" data-transition="slide-in">Buy Tickets</a>
</li>
</ul>
</div>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item active">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
</body>
</html>

55
test/app/choose-theater.html

@ -18,39 +18,15 @@
</head>
<body>
<header class="bar-title">
<a class="button-prev" href="index.html" data-transition="slide-out">
Back
</a>
<h1 class="title">Argo</h1>
</header>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
<div class="content">
<div class="content scrollable" id="list">
<div class="wrap">
<div class="">
<ul class="list">
<li class="list-divider">Theaters nearby</li>
<li>
@ -105,6 +81,29 @@
</li>
</ul>
</div>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
</body>
</html>

4
test/app/css/app.css

@ -10,3 +10,7 @@
.form-wrapper {
padding: 10px;
}
.scrollable {
bottom: 50px;
}

56
test/app/index.html

@ -17,41 +17,16 @@
</head>
<body>
<header class="bar-title">
<h1 class="title">Movie finder</h1>
</header>
<nav class="bar-standard bar-header-secondary">
<div class="content scrollable" id="list">
<div class="wrap">
<nav class="bar-standard bar-header-secondary bar-scrolling">
<form>
<input type="search" placeholder="Search">
</form>
</nav>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
<div class="content">
<div class="slider">
<ul>
<li>
@ -65,7 +40,6 @@
</li>
</ul>
</div>
<ul class="list">
<li class="list-divider">Recommended movies</li>
<li>
@ -154,7 +128,29 @@
</a>
</li>
</ul>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item active">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
</body>
</html>

51
test/app/settings.html

@ -18,11 +18,34 @@
</head>
<body>
<header class="bar-title">
<h1 class="title">Settings</h1>
</header>
<div class="content" id="list">
<div class="wrap">
<div class="">
<div class="form-wrapper">
<form>
<div class="input-group">
<div class="input-row">
<label>Full name</label>
<input type="text" placeholder="Mister Ratchet">
</div>
<div class="input-row">
<label>Email</label>
<input type="email" placeholder="ratchetframework@gmail.com">
</div>
<div class="input-row">
<label>Username</label>
<input type="text" placeholder="goRatchet">
</div>
</div>
<a class="button-block">Save changes</a>
</form>
</div>
</div>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item">
@ -45,29 +68,5 @@
</li>
</ul>
</nav>
<div class="content">
<div class="form-wrapper">
<form>
<div class="input-group">
<div class="input-row">
<label>Full name</label>
<input type="text" placeholder="Mister Ratchet">
</div>
<div class="input-row">
<label>Email</label>
<input type="email" placeholder="ratchetframework@gmail.com">
</div>
<div class="input-row">
<label>Username</label>
<input type="text" placeholder="goRatchet">
</div>
</div>
<a class="button-block">Save changes</a>
</form>
</div>
</div>
</body>
</html>

57
test/app/theaters.html

@ -17,41 +17,17 @@
</head>
<body>
<header class="bar-title">
<h1 class="title">Find a theater</h1>
</header>
<nav class="bar-standard bar-header-secondary">
<div class="content scrollable" id="list">
<div class="wrap">
<nav class="bar-standard bar-header-secondary bar-scrolling">
<form>
<input type="search" placeholder="Search">
</form>
</nav>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item active">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
<div class="content">
<div class="">
<ul class="list">
<li class="list-divider">Theaters nearby</li>
<li>
@ -126,6 +102,29 @@
</li>
</ul>
</div>
</div>
</div>
<nav class="bar-tab">
<ul class="tab-inner">
<li class="tab-item">
<a href="index.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Movies</div>
</a>
</li>
<li class="tab-item active">
<a href="theaters.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Theaters</div>
</a>
</li>
<li class="tab-item">
<a href="settings.html" data-transition="fade">
<img class="tab-icon" src="../../docs/img/icon-hamburger.png">
<div class="tab-label">Settings</div>
</a>
</li>
</ul>
</nav>
</body>
</html>
Loading…
Cancel
Save