src/cm/media/js/lib/yui/yui_3.10.3/docs/node-menunav/node-menunav-6.html
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
<!DOCTYPE html>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
<html lang="en">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
<head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
    <meta charset="utf-8">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
    <title>Example: Left Nav With Submenus With Rounded Corners</title>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
    <link rel="stylesheet" href="http://fonts.googleapis.com/css?family=PT+Sans:400,700,400italic,700italic">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
    <link rel="stylesheet" href="../../build/cssgrids/cssgrids-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
    <link rel="stylesheet" href="../assets/css/main.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
    <link rel="stylesheet" href="../assets/vendor/prettify/prettify-min.css">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
    <link rel="shortcut icon" type="image/png" href="../assets/favicon.png">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
    <script src="../../build/yui/yui-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
</head>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
<body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
<!--
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
<a href="https://github.com/yui/yui3"><img style="position: absolute; top: 0; right: 0; border: 0;" src="https://s3.amazonaws.com/github/ribbons/forkme_right_darkblue_121621.png" alt="Fork me on GitHub"></a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
-->
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
<div id="doc">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
    <div id="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
        <h1><img src="http://yuilibrary.com/img/yui-logo.png"></h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
            <h1>Example: Left Nav With Submenus With Rounded Corners</h1>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
    <div class="yui3-g">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
        <div class="yui3-u-3-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
            <div id="main">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
                <div class="content"><div class="intro">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
    <p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
    This example demonstrates how to add rounded corners to submenus of a menu built using the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
    MenuNav Node Plugin.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
    </p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
<div class="example newwindow">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
    <a href="node-menunav-6-example.html" target="_blank" class="button">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
        View Example in New Window
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
    </a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
<h2>Creating the Rounded Corner HTML</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
<strong>Note:</strong> be sure to add the <code>yui3-skin-sam</code> classname to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
page's <code>&lt;body&gt;</code> element or to a parent element of the widget in order to apply
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
the default CSS skin. See <a href="http://yuilibrary.com/yui/docs/tutorials/skins/">Understanding Skinning</a>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
<pre class="code prettyprint">&lt;body class=&quot;yui3-skin-sam&quot;&gt; &lt;!-- You need this skin class --&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
One way to add rounded corners to submenus is to append decorator elements to the node representing
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
a submenu's bounding box.  As the name implies, decorator elements add no semantic value to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
markup, but enable additional styles to be applied.  When adding any decorator elements to create
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
effects like shadows or rounded corners, always add those elements via JavaScript, since it is only
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
when JavaScript is enabled that a menu's markup is transformed in a drop-down menu system via the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
MenuNav Node Plugin.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
Each rounded corner is created by applying a background image to a <code>&#60;div&#62;</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
A class name identifying the corner will be added to each <code>&#60;div&#62;</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
The <code>&#60;div&#62;</code>s used to create the right corners will be nested inside the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
<code>&#60;div&#62;</code>s used to create the left corners, and each <code>&#60;div&#62;</code>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
for the left corners will have an additional class name of <code>yui3-menu-corner</code>.  The
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
template for each set of rounded corners comes together as follows:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
<pre class="code prettyprint">&lt;!-- top-left and top-right corners --&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
&lt;div class=&quot;yui3-menu-corner yui3-menu-corner-tl&quot;&gt;&lt;div class=&quot;yui3-menu-corner-tr&quot;&gt;&lt;&#x2F;div&gt;&lt;&#x2F;div&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
&lt;!-- bottom-left and bottom-right corners --&gt;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
&lt;div class=&quot;yui3-menu-corner yui3-menu-corner-bl&quot;&gt;&lt;div class=&quot;yui3-menu-corner-br&quot;&gt;&lt;&#x2F;div&gt;&lt;&#x2F;div&gt;</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
The <code>&#60;div&#62;</code>s for each corner is created by passing a string
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
of HTML to Node's <a href="http://yuilibrary.com/yui/docs/api/classes/Node.html#method_create"><code>create</code></a> method.  Use
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
the <a href="http://yuilibrary.com/yui/docs/api/classes/Node.html#method_all"><code>all</code></a> method to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
retrieve Node instances for each submenu, and the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
<a href="http://yuilibrary.com/yui/docs/api/classes/Node.html#method_append"><code>append</code></a> and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
<a href="http://yuilibrary.com/yui/docs/api/classes/Node.html#method_prepend"><code>prepend</code></a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
methods to add the rounded corners <code>&#60;div&#62;</code>s to the bounding box of each submenu.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
<pre class="code prettyprint">&#x2F;&#x2F;  Call the &quot;use&quot; method, passing in &quot;node-menunav&quot;.  This will load the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
&#x2F;&#x2F;  script and CSS for the MenuNav Node Plugin and all of the required
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
&#x2F;&#x2F;  dependencies.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
YUI().use(&#x27;node-menunav&#x27;, function(Y) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
    &#x2F;&#x2F;  Retrieve the Node instance representing the root menu
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
    &#x2F;&#x2F;  (&lt;div id=&quot;productsandservices&quot;&gt;)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
    var menu = Y.one(&quot;#productsandservices&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
    &#x2F;&#x2F;  Use the &quot;all&quot; method to retrieve the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
    &#x2F;&#x2F;  Node instances representing each submenu.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
    menu.all(&quot;.yui3-menu&quot;).each(function (node) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
        &#x2F;&#x2F;  Add decorator elements used to create the rounded corners to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
        &#x2F;&#x2F;  bounding box of each submenu.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
        &#x2F;&#x2F; Insert the first decorator before the submenu&#x27;s content box
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
        node.prepend(&#x27;&lt;div class=&quot;yui3-menu-corner yui3-menu-corner-tl&quot;&gt;&lt;div class=&quot;yui3-menu-corner-tr&quot;&gt;&lt;&#x2F;div&gt;&lt;&#x2F;div&gt;&#x27;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
        &#x2F;&#x2F; Insert the second decorator after the submenu&#x27;s content box
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
        node.append(&#x27;&lt;div class=&quot;yui3-menu-corner yui3-menu-corner-bl&quot;&gt;&lt;div class=&quot;yui3-menu-corner-br&quot;&gt;&lt;&#x2F;div&gt;&lt;&#x2F;div&gt;&#x27;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
    });
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
    &#x2F;&#x2F;  Call the &quot;plug&quot; method of the Node instance, passing in a reference to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
    &#x2F;&#x2F;  MenuNav Node Plugin.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
    menu.plug(Y.Plugin.NodeMenuNav);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
    &#x2F;&#x2F;  Show the menu now that it is ready
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
    menu.get(&quot;ownerDocument&quot;).get(&quot;documentElement&quot;).removeClass(&quot;yui3-loading&quot;);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
});</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
<em>Note:</em> In keeping with the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
<a href="http://developer.yahoo.com/performance/">Exceptional Performance</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
team's recommendation, the script block used to instantiate the menu will be
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
<a href="http://developer.yahoo.com/performance/rules.html#js_bottom">placed at the bottom of the page</a>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
This not only improves performance, it helps ensure that the DOM subtree of the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
element representing the root menu
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
(<code>&#60;div id="productsandservices"&#62;</code>) is ready to be scripted.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
<h2>Create the Rounded Corner Background Image</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
For performance, each rounded corner <code>&#60;div&#62;</code> uses the same image as its
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
background image, but only reveals the relevant section of the image via the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
<code>background-position</code> property.  The complete image is as follows:
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
<img src="../assets/node-menunav/round.png" width="200" height="6" alt="Image used as the background image for the DIV elements used to create rounded corners">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
<h2>Styling the Rounded Corner HTML</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
With the rounded corner elements appended to each submenu, the next step is to define
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
the styles that create the rounded corner effect.  Start by overriding the values for
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
<code>border</code> and <code>padding</code> specified for the content box of each submenu in the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
Sam skin CSS.  The top and bottom borders are set to 0, since both borders will be drawn by the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
background image used to create the rounded corners.  The top and bottom padding will be created by
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
setting the height of each <code>&#60;div&#62;</code> inside the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
<code>&#60;div class="yui3-menu-corner"&#62;</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
<pre class="code prettyprint">&#x2F;*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
    Overide the values for border and padding specified for the content box of each submenu in
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
    the Sam skin CSS.  The top and bottom borders are set to 0, since both borders will be drawn
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
    by the background image used to create the rounded corners.  The top and bottom padding
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
    will be created by setting the height of each &lt;div&gt; inside the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
    &lt;div class=&quot;yui3-menu-corner&quot;&gt;.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
*&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
#productsandservices .yui3-menu .yui3-menu-content {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
    border-top: 0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
    border-bottom: 0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
    padding: 0;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
Next, define the styles for each corner element.  The <code>&#60;div&#62;</code>s for the top-left
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
and bottom-left corners define a right margin that will provide space for the their inner
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
<code>&#60;div&#62;</code>s to fill using a negative right margin.  Each inner
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
<code>&#60;div&#62;</code> will define a left margin to reveal the background image applied to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
its parent <code>&#60;div&#62;</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
<pre class="code prettyprint">.yui3-menu-corner {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
    margin-right: 4px;  &#x2F;*  Reserve space for the top-right and bottom-right corners. *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
    &#x2F;* The background image (sprite) for the top-left and bottom-left corners. *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
    background: url(..&#x2F;assets&#x2F;node-menunav&#x2F;round.png) no-repeat;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
.yui3-menu-corner div {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
    height: 4px;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
    margin: 0 -4px 0 4px;   &#x2F;*  Use a negative right margin to move the &lt;div&gt; into
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
                                the right margin of the parent element
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
                                (&lt;div class=&quot;yui3-menu-corner&quot;&gt;) to draw the top-right
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
                                and bottom-right corners.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
                                Apply a left margin to reveal the background image
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
                                applied to the parent element for the top-left and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
                                bottom-left corners. *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
    &#x2F;* The background image (sprite) for the top-right and bottom-right corners. *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
    background: url(..&#x2F;assets&#x2F;node-menunav&#x2F;round.png) no-repeat;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
    _position: relative;    &#x2F;*  Necessary to get negative margins working in IE 6
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
                                (Standards Mode and Quirks Mode and IE 7 (Quirks
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
                                Mode only). *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
    _font-size: 0;  &#x2F;*  Necessary to collapse the height of the &lt;div&gt; in IE 6
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
                        (Standards Mode and Quirks Mode and IE 7 (Quirks Mode only) so
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
                        that it renders at 4px tall.  *&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
<p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
The last step is to simply set <code>background-position</code> property for the bottom-left,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
top-right, and bottom-right corner elements to reveal the corresponding section of the corner
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
background image.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
<pre class="code prettyprint">&#x2F;*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
    Set the &quot;background-position&quot; property for the bottom-left, top-right, and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
    bottom-right corner elements to reveal the corresponding section of the corner
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
    background image.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
*&#x2F;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
.yui3-menu-corner-bl {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
    background-position: left bottom;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
.yui3-menu-corner .yui3-menu-corner-tr {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
    background-position: top right;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
.yui3-menu-corner .yui3-menu-corner-br {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
    background-position: right bottom;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
}</pre>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
        <div class="yui3-u-1-4">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
            <div class="sidebar">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   248
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   249
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   250
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   251
                    <div class="sidebox">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   252
                        <div class="hd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   253
                            <h2 class="no-toc">Examples</h2>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   254
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   255
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   256
                        <div class="bd">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   257
                            <ul class="examples">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   258
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   259
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   260
                                        <li data-description="Creating left navigation using the MenuNav Node Plugin.">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   261
                                            <a href="menunav-leftnav.html">Basic Left Nav</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   262
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   263
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   264
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   265
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   266
                                        <li data-description="Creating top navigation using the MenuNav Node Plugin">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   267
                                            <a href="node-menunav-2.html">Basic Top Nav</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   268
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   269
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   270
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   271
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   272
                                        <li data-description="Creating menu button navigation using the MenuNav Node Plugin">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   273
                                            <a href="node-menunav-3.html">Menu Button Top Nav</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   274
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   275
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   276
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   277
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   278
                                        <li data-description="Creating split button navigation using the MenuNav Node Plugin">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   279
                                            <a href="node-menunav-4.html">Split Button Top Nav</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   280
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   281
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   282
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   283
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   284
                                        <li data-description="Adding shadows to submenus of a left nav using the MenuNav Node Plugin">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   285
                                            <a href="node-menunav-5.html">Left Nav with Submenus with Shadows</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   286
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   287
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   288
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   289
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   290
                                        <li data-description="Adding rounded corners to submenus of a left nav using the MenuNav Node Plugin">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   291
                                            <a href="node-menunav-6.html">Left Nav With Submenus With Rounded Corners</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   292
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   293
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   294
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   295
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   296
                                        <li data-description="Skining a menu built using the MenuNav Node Plugin to look like the menus on Flickr">
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   297
                                            <a href="node-menunav-7.html">Skinning Menus Created Using the MenuNav Node Plugin</a>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   298
                                        </li>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   299
                                    
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   300
                                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   301
                            </ul>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   302
                        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   303
                    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   304
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   305
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   306
                
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   307
            </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   308
        </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   309
    </div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   310
</div>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   311
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   312
<script src="../assets/vendor/prettify/prettify-min.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   313
<script>prettyPrint();</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   314
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   315
<script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   316
YUI.Env.Tests = {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   317
    examples: [],
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   318
    project: '../assets',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   319
    assets: '../assets/node-menunav',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   320
    name: 'node-menunav-6',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   321
    title: 'Left Nav With Submenus With Rounded Corners',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   322
    newWindow: 'true',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   323
    auto:  false 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   324
};
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   325
YUI.Env.Tests.examples.push('menunav-leftnav');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   326
YUI.Env.Tests.examples.push('node-menunav-2');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   327
YUI.Env.Tests.examples.push('node-menunav-3');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   328
YUI.Env.Tests.examples.push('node-menunav-4');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   329
YUI.Env.Tests.examples.push('node-menunav-5');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   330
YUI.Env.Tests.examples.push('node-menunav-6');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   331
YUI.Env.Tests.examples.push('node-menunav-7');
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   332
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   333
</script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   334
<script src="../assets/yui/test-runner.js"></script>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   335
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   336
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   337
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   338
</body>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   339
</html>