Browse Source

Add the navigation drawer component

pull/689/head
Roi Avinoam 10 years ago
parent
commit
304b16ed61
  1. 3
      Gruntfile.js
  2. 38
      dist/css/ratchet.css
  3. 2
      dist/css/ratchet.min.css
  4. 48
      dist/js/ratchet.js
  5. 2
      dist/js/ratchet.min.js
  6. 1
      docs/_includes/jump.html
  7. 4
      docs/assets/css/docs.css
  8. 2
      docs/assets/css/docs.min.css
  9. 31
      docs/components.html
  10. 38
      docs/dist/css/ratchet.css
  11. 2
      docs/dist/css/ratchet.min.css
  12. 48
      docs/dist/js/ratchet.js
  13. 2
      docs/dist/js/ratchet.min.js
  14. 47
      js/drawers.js
  15. 7
      sass/docs.scss
  16. 38
      sass/drawer.scss
  17. 1
      sass/ratchet.scss

3
Gruntfile.js

@ -55,7 +55,8 @@ module.exports = function(grunt) {
'js/push.js', 'js/push.js',
'js/segmented-controllers.js', 'js/segmented-controllers.js',
'js/sliders.js', 'js/sliders.js',
'js/toggles.js' 'js/toggles.js',
'js/drawers.js'
], ],
dest: '<%= meta.distPath %>js/<%= pkg.name %>.js' dest: '<%= meta.distPath %>js/<%= pkg.name %>.js'
} }

38
dist/css/ratchet.css vendored

@ -1088,6 +1088,44 @@ select {
border-radius: 6px; border-radius: 6px;
} }
.drawer {
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
padding: inherit;
background-color: transparent;
-webkit-transition: background-color .2s linear, left 0 linear .2s;
-moz-transition: background-color .2s linear, left 0 linear .2s;
transition: background-color .2s linear, left 0 linear .2s;
}
.drawer.active {
left: 0;
background-color: rgba(0, 0, 0, .3);
-webkit-transition: background-color .2s linear;
-moz-transition: background-color .2s linear;
transition: background-color .2s linear;
}
.drawer > .drawer-inner {
position: relative;
left: -100%;
width: 80%;
height: 100%;
overflow: hidden;
background: white;
box-shadow: 1px 0 2px rgba(0, 0, 0, .3);
-webkit-transition: left .2s linear;
-moz-transition: left .2s linear;
transition: left .2s linear;
}
.drawer.active > .drawer-inner {
left: 0;
}
.modal { .modal {
position: fixed; position: fixed;
top: 0; top: 0;

2
dist/css/ratchet.min.css vendored

File diff suppressed because one or more lines are too long

48
dist/js/ratchet.js vendored

@ -962,3 +962,51 @@
}); });
}()); }());
/* ========================================================================
* Ratchet: drawer.js v2.0.2
* http://goratchet.com/components#drawer
* ========================================================================
* Copyright 2014 Connor Sears
* Licensed under MIT (https://github.com/twbs/ratchet/blob/master/LICENSE)
* ======================================================================== */
!(function () {
'use strict';
var findDrawers = function (target) {
var i;
var drawers = document.querySelectorAll('a');
for (; target && target !== document; target = target.parentNode) {
for (i = drawers.length; i--;) {
if (drawers[i] === target) {
return target;
}
}
}
};
var getDrawer = function (event) {
var drawerToggle = findDrawers(event.target);
if (drawerToggle && drawerToggle.hash) {
return document.querySelector(drawerToggle.hash);
}
};
window.addEventListener('touchend', function (event) {
if (event.target.classList.contains('drawer')) {
// click directly on the drawer, but not on it's inner element
event.target.classList.remove('active');
return;
}
var drawer = getDrawer(event);
if (drawer) {
if (drawer && drawer.classList.contains('drawer')) {
drawer.classList.toggle('active');
}
event.preventDefault(); // prevents rewriting url (apps can still use hash values in url)
}
});
}());

2
dist/js/ratchet.min.js vendored

File diff suppressed because one or more lines are too long

1
docs/_includes/jump.html

@ -16,6 +16,7 @@
<a class="docs-component-item" href="#popovers" data-ignore="push">Popovers</a> <a class="docs-component-item" href="#popovers" data-ignore="push">Popovers</a>
<a class="docs-component-item" href="#modals" data-ignore="push">Modals</a> <a class="docs-component-item" href="#modals" data-ignore="push">Modals</a>
<a class="docs-component-item" href="#sliders" data-ignore="push">Sliders</a> <a class="docs-component-item" href="#sliders" data-ignore="push">Sliders</a>
<a class="docs-component-item" href="#drawers" data-ignore="push">Drawers</a>
<a class="docs-component-item" href="#push" data-ignore="push">Push</a> <a class="docs-component-item" href="#push" data-ignore="push">Push</a>
<a class="docs-component-item" href="#ratchicons" data-ignore="push">Ratchicons</a> <a class="docs-component-item" href="#ratchicons" data-ignore="push">Ratchicons</a>
</div> </div>

4
docs/assets/css/docs.css

@ -820,6 +820,10 @@ code {
margin: 10px; margin: 10px;
} }
#drawersInDevice #iwindow > .btn {
margin: 10px;
}
@media screen and (min-width: 768px) { @media screen and (min-width: 768px) {
.slider .slide { .slider .slide {
cursor: -webkit-grab; cursor: -webkit-grab;

2
docs/assets/css/docs.min.css vendored

File diff suppressed because one or more lines are too long

31
docs/components.html

@ -1191,6 +1191,37 @@ document
</article> </article>
<article class="component" id="drawers">
<h3 class="component-title">Drawers</h3>
<p class="component-description">Overlapping navigation drawer</p>
<div class="component-example">
<a href="#myDrawer" class="btn">Open Drawer</a>
<nav class="drawer" id="myDrawer">
<div class="drawer-inner">
<ul class="table-view">
<li class="table-view-cell">Home</li>
<li class="table-view-cell">Settings</li>
</ul>
</div>
</nav>
</div>
{% highlight html %}
<a href="#myDrawer" class="btn">Open Drawer</a>
<nav class="drawer" id="myDrawer">
<div class="drawer-inner">
<ul class="table-view">
<li class="table-view-cell">Home</li>
<li class="table-view-cell">Settings</li>
</ul>
</div>
</nav>
{% endhighlight %}
</article>
<!-- Push docs --> <!-- Push docs -->
<article class="component" id="push"> <article class="component" id="push">
<h3 class="component-title">Push</h3> <h3 class="component-title">Push</h3>

38
docs/dist/css/ratchet.css vendored

@ -1088,6 +1088,44 @@ select {
border-radius: 6px; border-radius: 6px;
} }
.drawer {
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
padding: inherit;
background-color: transparent;
-webkit-transition: background-color .2s linear, left 0 linear .2s;
-moz-transition: background-color .2s linear, left 0 linear .2s;
transition: background-color .2s linear, left 0 linear .2s;
}
.drawer.active {
left: 0;
background-color: rgba(0, 0, 0, .3);
-webkit-transition: background-color .2s linear;
-moz-transition: background-color .2s linear;
transition: background-color .2s linear;
}
.drawer > .drawer-inner {
position: relative;
left: -100%;
width: 80%;
height: 100%;
overflow: hidden;
background: white;
box-shadow: 1px 0 2px rgba(0, 0, 0, .3);
-webkit-transition: left .2s linear;
-moz-transition: left .2s linear;
transition: left .2s linear;
}
.drawer.active > .drawer-inner {
left: 0;
}
.modal { .modal {
position: fixed; position: fixed;
top: 0; top: 0;

2
docs/dist/css/ratchet.min.css vendored

File diff suppressed because one or more lines are too long

48
docs/dist/js/ratchet.js vendored

@ -962,3 +962,51 @@
}); });
}()); }());
/* ========================================================================
* Ratchet: drawer.js v2.0.2
* http://goratchet.com/components#drawer
* ========================================================================
* Copyright 2014 Connor Sears
* Licensed under MIT (https://github.com/twbs/ratchet/blob/master/LICENSE)
* ======================================================================== */
!(function () {
'use strict';
var findDrawers = function (target) {
var i;
var drawers = document.querySelectorAll('a');
for (; target && target !== document; target = target.parentNode) {
for (i = drawers.length; i--;) {
if (drawers[i] === target) {
return target;
}
}
}
};
var getDrawer = function (event) {
var drawerToggle = findDrawers(event.target);
if (drawerToggle && drawerToggle.hash) {
return document.querySelector(drawerToggle.hash);
}
};
window.addEventListener('touchend', function (event) {
if (event.target.classList.contains('drawer')) {
// click directly on the drawer, but not on it's inner element
event.target.classList.remove('active');
return;
}
var drawer = getDrawer(event);
if (drawer) {
if (drawer && drawer.classList.contains('drawer')) {
drawer.classList.toggle('active');
}
event.preventDefault(); // prevents rewriting url (apps can still use hash values in url)
}
});
}());

2
docs/dist/js/ratchet.min.js vendored

File diff suppressed because one or more lines are too long

47
js/drawers.js

@ -0,0 +1,47 @@
/* ========================================================================
* Ratchet: drawer.js v2.0.2
* http://goratchet.com/components#drawer
* ========================================================================
* Copyright 2014 Connor Sears
* Licensed under MIT (https://github.com/twbs/ratchet/blob/master/LICENSE)
* ======================================================================== */
!(function () {
'use strict';
var findDrawers = function (target) {
var i;
var drawers = document.querySelectorAll('a');
for (; target && target !== document; target = target.parentNode) {
for (i = drawers.length; i--;) {
if (drawers[i] === target) {
return target;
}
}
}
};
var getDrawer = function (event) {
var drawerToggle = findDrawers(event.target);
if (drawerToggle && drawerToggle.hash) {
return document.querySelector(drawerToggle.hash);
}
};
window.addEventListener('touchend', function (event) {
if (event.target.classList.contains('drawer')) {
// click directly on the drawer, but not on it's inner element
event.target.classList.remove('active');
return;
}
var drawer = getDrawer(event);
if (drawer) {
if (drawer && drawer.classList.contains('drawer')) {
drawer.classList.toggle('active');
}
event.preventDefault(); // prevents rewriting url (apps can still use hash values in url)
}
});
}());

7
sass/docs.scss

@ -847,6 +847,13 @@ code {
} }
} }
// Drawer
#drawersInDevice {
#iwindow > .btn {
margin: 10px;
}
}
// Sliders // Sliders
@media screen and (min-width: 768px) { @media screen and (min-width: 768px) {
.slider .slide { .slider .slide {

38
sass/drawer.scss

@ -0,0 +1,38 @@
//
// DRAWER
// --------------------------------------------------
.drawer {
position: absolute;
padding: inherit;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background-color: rgba(0,0,0,0);
// wait for the drawer-inner animation to finish before hiding the backdrop
@include transition(background-color .25s linear, left 0 linear .25s);
}
.drawer.active {
left: 0;
background-color: rgba(0,0,0,.3);
@include transition(background-color .25s linear);
}
.drawer > .drawer-inner {
position: relative;
left: -100%;
width: 80%;
height: 100%;
background: white;
overflow: hidden;
@include box-shadow(1px 0 2px rgba(0,0,0,.3));
@include transition(left .25s linear);
}
.drawer.active > .drawer-inner {
left: 0;
}

1
sass/ratchet.scss

@ -19,6 +19,7 @@
@import "forms.scss"; @import "forms.scss";
@import "segmented-controls.scss"; @import "segmented-controls.scss";
@import "popovers.scss"; @import "popovers.scss";
@import "drawer.scss";
// Javascript components // Javascript components
@import "modals.scss"; @import "modals.scss";

Loading…
Cancel
Save