Dead simple responsive widgets, written using CSS3 transformations and available as a jQuery Plugin. Currently a sideshow and accordion are available, more to come!
Responsive designs are cool! Not only do they allow you to reach mobile and tablet users with minimal effort, they also make your context scale up for desktop users with larger screens.
Unfortunately it means in general you can't use fixed sizes throughout your CSS. While this may not be a problem for new sites, a lot of existing widgets are hard-coded to various sizes.
I had this problem when building my blog, and at our startup Quillu, so I developed a slideshow and accordion using various techniques to ensure they scale with their content and well as their containing div. This comes down to ensuring that width or height are never hard coded in the CSS. Also extensive use of CSS3, particularly the transitions ensures rich UI that works great in modern browsers, with graceful degradation for IE.
We though the work could be useful for others, so it was extracted into a library for reuse.
Check out the demo
- Works from large monitors to laptops, to tablets to mobiles.
- Pure CSS styling
- CSS3 based transitions (hardware accelerated where possible).
- Animations work on all modern browsers including mobile, (IE degrades gracefully by losing transitions).
- Minimal dependence on jQuery for convenience ( can substitute Zepto, or pure JavaScript).
- Simple lightweight design, adds little to your download size
- Compartmentalized, so use only what you want
- Best used with a responsive CSS framework like 1140px or 320plus
- Can be heavily customized by editing CSS
- Download / Clone files
- Add references to CSS / JS
- Add boilerplate placeholder HTML
- Use jQuery to attach widgets.
- See demo.html for examples.
Currently there are two widgets
A responsive CSS based animating sideshow with many options
-
Options
- Show / hide buttons
- Use keyboard navigation
- Auto start slideshow, set intervals
- Can use throttling with jQuery throttle plugin
-
Setup
-
Add references, make sure jQuery is available
<link rel="stylesheet" href="slidy.css"> <script src="slidy.js"></script>
-
Add boilerplate HTML to wherever your want the slideshow. This is usually some responsive container
<div id="slidyBanner" class="slidyContainer" title="Your tooltip text"> <div class="slidySlides"> <!-- Each slide is wrapped in figure section --> <!-- Slide 1 --> <!-- add the 'slidyCurrent' class to which slide you want as default --> <figure class="slidyCurrent"> <!-- Your context goes here --> <img alt="Uyuni, Bolivia" src="img/banner/16 Uyuni Salt Flats - 61 - Banner.jpg"> <!-- Use the figcaption element to add captions --> <figcaption>An Image</figcaption> </figure> <!-- Slide 2 --> <figure> <img alt="Shanghai, China" src="img/banner/2 Shanghai - 38 - Banner.jpg"> <figcaption>Another image</figcaption> </figure> <!-- Slide 3 --> <figure> <p> I am some text</p> <p> Your not limited to images, you can have what ever you want </p> <figcaption>Text</figcaption> </figure> <!-- Add more slides as necessary --> </div> </div>
-
Wire up with options
<script> $('.slidyContainer').slidy({ // Options go here, see slidy.js // These the defaults so don't only need to be specified if they are changed throttle: false, // Set to true, and include jQuery throttle plugin (http://benalman.com/projects/jquery-throttle-debounce-plugin/) throttleTime: 500, // number of ms to wait for throttling showArrows: true, // Show arrows for next/prev image movePrev: 'movePrev', // Div id to use for previous button moveNext: 'moveNext', // Div id to use for next button useKeybord: true, // use keys defined below to expand / collapse sections auto: false, // Start slideshow automatically interval: 6000, // Time between each slide initialInterval: 10000 // Initial interval when page loads }); </script>
-
A responsive CSS based animating accordion.
-
Options
- Use keyboard navigation
- Can use throttling with jQuery throttle plugin
-
Setup
-
Add references, make sure jQuery is available
<link rel="stylesheet" href="accordly.css"> <script src="accordly.js"></script>
-
Add boilerplate HTML to wherever your want the accordion. This is usually some responsive container
<div class="accordion"> <!-- Section 1 --> <section> <hgroup> <h4>Section 1 title</h4> </hgroup> <article> <h2> Put your content here </h2> </article> </section> <!-- Section 2 --> <section> <hgroup> <h4>Section 2 title</h4> </hgroup> <article> <h2> This is more context and can contain anything</h2> </article> </section> <!-- Add more sections as needed --> </div>
-
Wire up with options
$('.accordion').accordy({ // Options go here, see slidy.js // These the defaults so don't only need to be specified if they are changed throttle: false, // Set to true, and include jQuery throttle plugin (http://benalman.com/projects/jquery-throttle-debounce-plugin/) throttleTime: 500, // number of ms to wait for throttling useKeybord: true, // use keys defined below to expand / collapse sections keyPressUp: 75, //K keyPressDown: 74 //J });
-
We actively encourage additional widgets or improvements or features. As usual fork, and submit pull requests
- Add mobile touch events
- Find a workaround for webkit/mozilla bug, that stops transition with height is set to 100%
Dharmesh Malam ([email protected])
Copyright © 2011 by D MALAM
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.