123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- <!DOCTYPE html>
- <html>
- <!--
- Copyright 2010 The Closure Library Authors. All Rights Reserved.
- Use of this source code is governed by the Apache License, Version 2.0.
- See the COPYING file for details.
- -->
- <head>
- <title>goog.ui.SubMenu</title>
- <script src="../base.js"></script>
- <script>
- goog.require('goog.debug');
- goog.require('goog.positioning.Corner');
- goog.require('goog.ui.Menu');
- goog.require('goog.ui.SubMenu');
- goog.require('goog.ui.PopupMenu');
- </script>
- <link rel="stylesheet" href="css/demo.css">
- <link rel="stylesheet" href="../css/menu.css">
- <link rel="stylesheet" href="../css/menuitem.css">
- <link rel="stylesheet" href="../css/menuseparator.css">
- <link rel="stylesheet" href="../css/submenu.css">
- </head>
- <body>
- <h1>goog.ui.SubMenu</h1>
- <p>Demonstration of different hierarchical menus which share its submenus.
- A flyweight pattern demonstration for submenus.</p>
- <p><button id="button">Open menu</button></p>
- <div id="sharedMenu" class="goog-menu">
- <div class="goog-menuitem">Google</div>
- <div class="goog-menuitem">Yahoo</div>
- <div class="goog-menuitem">MSN</div>
- <hr>
- <div class="goog-menuitem">Bla...</div>
- </div>
- <script>
- // Popup menu with sub menus
- var menu = new goog.ui.PopupMenu();
- menu.attach(document.getElementById('button'),
- goog.positioning.Corner.BOTTOM_LEFT,
- goog.positioning.Corner.TOP_LEFT);
- var sharedDecoratedSubmenu = new goog.ui.Menu();
- sharedDecoratedSubmenu.decorate(document.getElementById('sharedMenu'));
- var sharedSubmenu = new goog.ui.Menu();
- var sa = new goog.ui.SubMenu('Shared sub one');
- sa.addItem(new goog.ui.MenuItem('Shared sub sub one'));
- sa.addItem(new goog.ui.MenuItem('Shared sub sub two'));
- sharedSubmenu.addItem(sa);
- sharedSubmenu.addItem(new goog.ui.MenuItem('Shared sub two'));
- sharedSubmenu.addItem(new goog.ui.MenuItem('Shared sub three'));
- var sb = new goog.ui.SubMenu('Shared sub four');
- sb.setMenu(sharedDecoratedSubmenu);
- sharedSubmenu.addItem(sb);
- var a = new goog.ui.SubMenu('Zero');
- var b = new goog.ui.SubMenu('Ten');
- var c = new goog.ui.SubMenu('Twenty');
- var d = new goog.ui.SubMenu('Thirty');
- var e = new goog.ui.SubMenu('Has shared one');
- var f = new goog.ui.SubMenu('Has shared two');
- var g = new goog.ui.SubMenu('Has shared three');
- var h = new goog.ui.SubMenu('Has decorated shared one');
- var i = new goog.ui.SubMenu('Has decorated shared two');
- var j = new goog.ui.SubMenu('Has decorated shared three');
- e.setMenu(sharedSubmenu);
- f.setMenu(sharedSubmenu);
- g.setMenu(sharedSubmenu);
- h.setMenu(sharedDecoratedSubmenu);
- i.setMenu(sharedDecoratedSubmenu);
- j.setMenu(sharedDecoratedSubmenu);
- var aa = new goog.ui.SubMenu('One')
- aa.setEnabled(false);
- aa.addItem(new goog.ui.MenuItem('Add'));
- aa.addItem(new goog.ui.MenuItem('Subtract'));
- aa.addItem(new goog.ui.MenuItem('Multiply'));
- a.addItem(aa);
- a.addItem(new goog.ui.MenuItem('Two'));
- a.addItem(new goog.ui.MenuItem('Three'));
- a.addItem(new goog.ui.MenuItem('Four'));
- b.addItem(new goog.ui.MenuItem('Eleven'));
- b.addItem(new goog.ui.MenuItem('Thirteen'));
- b.addItem(new goog.ui.MenuItem('Fourteen'));
- b.addItem(new goog.ui.MenuItem('Fifteen'));
- c.addItem(new goog.ui.MenuItem('Twenty-one'));
- var cb = new goog.ui.SubMenu('Twenty-Two')
- cb.addItem(new goog.ui.MenuItem('Add'));
- cb.addItem(new goog.ui.MenuItem('Subtract'));
- cb.addItem(new goog.ui.MenuItem('Multiply'));
- var cbd = new goog.ui.SubMenu('More')
- cbd.addItem(new goog.ui.MenuItem('Square Root'));
- cbd.addItem(new goog.ui.MenuItem('Power'));
- cbd.addItem(new goog.ui.MenuItem('Square'));
- cb.addItem(cbd);
- c.addItem(cb);
- c.addItem(new goog.ui.MenuItem('Twenty-three'));
- c.addItem(new goog.ui.MenuItem('Twenty-four'));
- d.addItem(new goog.ui.MenuItem('Thirty-one'));
- d.addItem(new goog.ui.MenuItem('Thirty-two'));
- d.addItem(new goog.ui.MenuItem('Thirty-three'));
- d.addItem(new goog.ui.MenuItem('Thirty-four'));
- menu.addItem(a);
- menu.addItem(new goog.ui.MenuItem('AaAaAaAaAaAa'));
- menu.addItem(new goog.ui.MenuItem('BbBbBbBbBbBb'));
- menu.addItem(b);
- menu.addItem(c);
- menu.addItem(d);
- menu.addItem(e);
- menu.addItem(f);
- menu.addItem(g);
- menu.addItem(h);
- menu.addItem(i);
- menu.addItem(j);
- var ccc = new goog.ui.MenuItem('CcCcCcCcCcCc');
- ccc.setEnabled(false);
- menu.addItem(ccc);
- menu.addItem(new goog.ui.MenuItem('DdDdDdDdDdDd'));
- menu.render();
- menu.getElement().id = 'foo';
- goog.events.listen(menu, 'action', function(e) {
- var action = e.target.getCaption();
- alert(action);
- });
- </script>
- </body>
- </html>
|