Saturday, October 08, 2011

CREATE YOUR OWN DASHBOARD MENU


In this tutorial we are going to create our own dashboard menu as in Leopard dashboard. Dashboard menu in Leopard usually uses as a container for a tons of widgets we have and that will be nice if we have one on our web application. First, take a look at below demo to know the result we want to build.
Basic Technique
The dashboard will be hidden out of the webpage, in this case on the bottom of the page. We can do that by setting the dahboard position into absolute, put its bottom position with minus point and set the body’s overflow properties into hidden.
The problem with this technique is our document content will also hidden since the body’s overflow properties was set into hidden, we can solve them by moving the dashboard into the top of the page, but in this demo we’ll continue to put them on the bottom.
Expected Result:
Picture 5


Build Dashboard
We’ll separate the dashboard contents into 3 parts : toggle for showing and hiding dahsboard, dashboard menu for wrapping widgets list and dot container for wrapping dashboard’s background with metallic effect. Wrap them all on one div (as a container) so we can easily move these 3 parts only by styling this div.
  1. <div id="dashboard">  
  2.     <img src="images/toggle.png" id="toggle">  
  3. <div id="dashboard-menu">  
  4.           
  5.     div>  
  6. <div id="dot-container">  
  7.           
  8.     div>  
  9. div>  
Now we will styling them. Set the dashboard’s width into 100%, position absolute, bottom into 0px and also add inset box shadow into them to make emboss effect. Put the toggle’s position on top of the dashboard to make it always visible even the dashboard is hidden.
  1. #dashboard {  
  2.     font-familyArial;  
  3.     font-stylenormal;  
  4.     background#a3acb7;  
  5.     displayblock;  
  6.     width: 100%;  
  7.     height150px;  
  8.     margin-rightauto;  
  9.     margin-leftauto;  
  10.     -webkit-box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
  11.     -moz-box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
  12.     box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
  13.     positionabsolute;  
  14.     bottombottom0px;  
  15. }  
  16.   
  17. #dashboard-menu {  
  18.     positionabsolute;  
  19.     displayblock;  
  20.     z-index: 2;  
  21. }  
  22.   
  23. #dot-container {  
  24.     displayblock;  
  25.     width: 200%;  
  26.     text-alignleft;  
  27.     positionabsolute;  
  28.     left: 0;  
  29.     top: 0;  
  30.     z-index: 1;  
  31. }  
  32.   
  33. #toggle {  
  34.     displayinline-block;  
  35.     margin-top: -3em;  
  36.     left: 0;  
  37.     positionabsolute;  
  38.     cursorpointer;  
  39. }  
Expected Result:
Picture 6


Create Metallic Effect With CSS and jQuery
The most interesting technique is how to create metallic effect on dashboard’s background using only CSS and jQuery. The effect are a groups of black circle div with white shadow on it, we can repeat them horizontally until it’s equal to document width and after that repeat them vertically. Move some pixel the odd dots group’s position to make it more real.
  1.   
  2. <div id="dot-container">  
  3.     <span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span>  
  4. div>  
  5.   
  6.   
  7. <div id="dot-container">  
  8. <div style="margin-left:0em; margin-bottom: -.5em">  
  9.         <span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span>  
  10.     div>  
  11. <div style="margin-left:0.4em; margin-bottom: -.5em">  
  12.         <span class="dot"> span><span class="dot"> span><span class="dot"> span><span class="dot"> span>  
  13.     div>  
  14. div>  
  1. .dot {  
  2.     background#1f1f1f;  
  3.     width4px;  
  4.     height4px;  
  5.     displayinline-block;  
  6.     -webkit-border-radius: 4px;  
  7.     -moz-border-radius: 4px;  
  8.     border-radius: 4px;  
  9.     -webkit-box-shadow: 0px 1px 0px #ffffff;  
  10.     -moz-box-shadow: 0px 1px 0px #ffffff;  
  11.     box-shadow: 0px 1px 0px #ffffff;  
  12.     margin-right: .3em;  
  13. }  
Expected Result:
Picture
We won’t create each dot by copy and paste the span since jQuery can generate and repeat them dynamically. Repeat horizontally the dots until it’s equal to document’s width and after that repeat them vertically. The last thing to do is insert them into dot container div.
  1. //Create base variable, check document width and count how much dot per line.  
  2. var a, b, element = '';  
  3. documentWidth       = $(window).width();  
  4. dotLength           = parseInt(documentWidth/10);  
  5.   
  6. //Loop dot per line  
  7. for(a=0; a<= 11; a++) {  
  8.   
  9.     //Check is even or odd to add some pixel to the margin left  
  10.     className= ((a%2) == 0) ? '0' : '0.4em';  
  11.     element     = element + ' 
  12. +className+'; margin-bottom: -.5em">\n';  
  13.   
  14.         //Loop to create the dot  
  15.         for(b=0; b<=dotLength; b++) {  
  16.             element = element + '\t ';  
  17.         }  
  18.   
  19.     element = element + '
 
  •  
  • ';  
  • }  
  •   
  • //Insert dots on #dot-container  
  • $('#dot-container').html(element);  


  • Put The Widgets
    The dashboard was setted perfectly, now we’ll put the widgets list. Put each widgets on unordered list and add its widget name below the widget.
    1. <div id="dashboard-menu">  
    2. <ul>  
    3. <li>  
    4.         <img src="images/gauge.png"> <br> Dashboard  
    5.         li>  
    6. <li>  
    7.         <img src="images/mail.png"> <br> E-Mail Client  
    8.         li>  
    9. <li>  
    10.         <img src="images/calendar.png"> <br> Calendar  
    11.         li>  
    12. <li>  
    13.         <img src="images/map.png"> <br> Geolocation  
    14.         li>  
    15. <li>  
    16.         <img src="images/note.png"> <br> Sticky Note  
    17.         li>  
    18. <li>  
    19.         <img src="images/wireless.png"> <br> AirPort  
    20.         li>  
    21. <li>  
    22.         <img src="images/calculator.png"> <br> Calculator  
    23.         li>  
    24. ul>  
    25. div>  
    Expected Result:
    Picture 12


    The list still appear vertical, now we must set them into horizontal orientation by set its display properties into inline-block. Add the distance on each widget and set its margin properly.
    1. #dashboard-menu {  
    2.     positionabsolute;  
    3.     displayblock;  
    4.     left: -65em;  
    5.     z-index: 2;  
    6. }  
    7.   
    8.     #dashboard-menu ul li {  
    9.         displayinline-block;  
    10.         text-aligncenter;  
    11.         margin-right: 2em;  
    12.         margin-top: 1em;  
    13.         color#313235;  
    14.         text-shadow0px 1px 0px #fff;  
    15.         font-weightbold;  
    16.     }  
    17.   
    18.     li img {  
    19.         margin-bottom: .7em;  
    20.         border: 0;  
    21.         cursorpointer;  
    22.     }  
    Expected Result:
    Picture 13


    We want the widgets is moving from left to right when the dashboard is show up, so we need to set its left property into -65em.


    Hide and Seek
    Now we’ll add some jQuery code to the dashboard to make it able showing and hiding. Firstly we must hide the dashboard position by setting its position with some minus pixels, so it will be hidden.
    1. #dashboard {  
    2.     font-familyArial;  
    3.     font-stylenormal;  
    4.     background#a3acb7;  
    5.     displayblock;  
    6.     width: 100%;  
    7.     height150px;  
    8.     margin-rightauto;  
    9.     margin-leftauto;  
    10.     -webkit-box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
    11.     -moz-box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
    12.     box-shadow: inset 0px 0px 20px rgba(0, 0, 0, .6);  
    13.     positionabsolute;  
    14.     bottombottom: -150px;  
    15. }  
    Add toggle function to the image toggle, the first function will rotate the image toggle by set its rotate property into 45 degree (we need zachstronaut’s plugin for doing this), show the dashboard by set its bottom property value into 0px and show the menu by set its left into 3em. These action is in animate function so any change will have animation. For the second function we just need to revert these value.
    1. //Add event toggle on #toggle  
    2. $('#toggle').toggle(  
    3.   
    4.     function() {  
    5.   
    6.         //Rotate toggle  
    7.         $(this).stop().animate({rotate : '-=45deg'});  
    8.         $('#dashboard').stop().animate({bottom : '0px'});  
    9.         $('#dashboard-menu').stop().animate({left : '3em'});  
    10.     },  
    11.   
    12.     function() {  
    13.   
    14.         //Revert rotate toggle  
    15.         $(this).stop().animate({rotate : '0deg'});  
    16.         $('#dashboard').stop().animate({bottom : '-150px'}, 700);  
    17.         $('#dashboard-menu').stop().animate({left : '-65em'});  
    18.     }  
    19. );  
    That’s it we just made our simple dashboard menu, hope you enjoy my post and thank your for reading! :)

    No comments:

    Post a Comment