----------------------------------------------------------- New Message on BDOTNET
----------------------------------------------------------- From: salil Message 2 in Discussion Hi Sujith!! Try this code.in ur server.hope it will execute. //////////////////////// <html> <head> <title>marketing top bar</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <!-- THREE STEPS TO INSTALL CASCADING MENU: 1. Copy the coding into the HEAD of your HTML document 2. Add the onLoad event handler into the BODY tag 3. Put the last coding into the BODY of your HTML document --> <!-- STEP ONE: Paste this code into the HEAD of your HTML document --> <SCRIPT LANGUAGE="JavaScript"> <!-- Original: Angus Turnbull --> <!-- Web Site: http://gusnz.cjb.net --> <!-- This script and many more are available free online at --> <!-- The JavaScript Source!! http://javascript.internet.com --> <!-- Begin var isDOM = (document.getElementById ? true : false); var isIE4 = ((document.all && !isDOM) ? true : false); var isNS4 = (document.layers ? true : false); function getRef(id) { if (isDOM) return document.getElementById(id); if (isIE4) return document.all[id]; if (isNS4) return document.layers[id]; } function getSty(id) { return (isNS4 ? getRef(id) : getRef(id).style); } // Hide timeout. var popTimer = 0; // Array showing highlighted menu items. var litNow = new Array(); function popOver(menuNum, itemNum) { clearTimeout(popTimer); hideAllBut(menuNum); litNow = getTree(menuNum, itemNum); changeCol(litNow, true); targetNum = menu[menuNum][itemNum].target; if (targetNum > 0) { thisX = parseInt(menu[menuNum][0].ref.left) + parseInt(menu[menuNum][itemNum].ref.left); thisY = parseInt(menu[menuNum][0].ref.top) + parseInt(menu[menuNum][itemNum].ref.top); with (menu[targetNum][0].ref) { left = parseInt(thisX + menu[targetNum][0].x); top = parseInt(thisY + menu[targetNum][0].y); visibility = 'visible'; } } } function popOut(menuNum, itemNum) { if ((menuNum == 0) && !menu[menuNum][itemNum].target) hideAllBut(0) else popTimer = setTimeout('hideAllBut(0)', 500); } function getTree(menuNum, itemNum) { // Array index is the menu number. The contents are null (if that menu is not a parent) // or the item number in that menu that is an ancestor (to light it up). itemArray = new Array(menu.length); while(1) { itemArray[menuNum] = itemNum; // If we've reached the top of the hierarchy, return. if (menuNum == 0) return itemArray; itemNum = menu[menuNum][0].parentItem; menuNum = menu[menuNum][0].parentMenu; } } // Pass an array and a boolean to specify colour change, true = over colour. function changeCol(changeArray, isOver) { for (menuCount = 0; menuCount < changeArray.length; menuCount++) { if (changeArray[menuCount]) { newCol = isOver ? menu[menuCount][0].overCol : menu[menuCount][0].backCol; // Change the colours of the div/layer background. with (menu[menuCount][changeArray[menuCount]].ref) { if (isNS4) bgColor = newCol; else backgroundColor = newCol; } } } } function hideAllBut(menuNum) { var keepMenus = getTree(menuNum, 1); for (count = 0; count < menu.length; count++) if (!keepMenus[count]) menu[count][0].ref.visibility = 'hidden'; changeCol(litNow, false); } // *** MENU CONSTRUCTION FUNCTIONS *** function Menu(isVert, popInd, x, y, width, overCol, backCol, borderClass, textClass) { // True or false - a vertical menu? this.isVert = isVert; // The popout indicator used (if any) for this menu. this.popInd = popInd // Position and size settings. this.x = x; this.y = y; this.width = width; // Colours of menu and items. this.overCol = overCol; this.backCol = backCol; // The stylesheet class used for item borders and the text within items. this.borderClass = borderClass; this.textClass = textClass; // Parent menu and item numbers, indexed later. this.parentMenu = null; this.parentItem = null; // Reference to the object's style properties (set later). this.ref = null; } function Item(text, href, frame, length, spacing, target) { this.text = text; this.href = href; this.frame = frame; this.length = length; this.spacing = spacing; this.target = target; // Reference to the object's style properties (set later). this.ref = null; } function writeMenus() { if (!isDOM && !isIE4 && !isNS4) return; for (currMenu = 0; currMenu < menu.length; currMenu++) with (menu[currMenu][0]) { // Variable for holding HTML for items and positions of next item. var str = '', itemX = 0, itemY = 0; // Remember, items start from 1 in the array (0 is menu object itself, above). // Also use properties of each item nested in the other with() for construction. for (currItem = 1; currItem < menu[currMenu].length; currItem++) with (menu[currMenu][currItem]) { var itemID = 'menu' + currMenu + 'item' + currItem; // The width and height of the menu item - dependent on orientation! var w = (isVert ? width : length); var h = (isVert ? length : width); // Create a div or layer text string with appropriate styles/properties. // Thanks to Paul Maden (www.paulmaden.com) for helping debug this in IE4, apparently // the width must be a miniumum of 3 for it to work in that browser. if (isDOM || isIE4) { str += '<div id="' + itemID + '" style="position: absolute; left: ' + itemX + '; top: ' + itemY + '; width: ' + w + '; height: ' + h + '; visibility: inherit; '; if (backCol) str += 'background: ' + backCol + '; '; str += '" '; } if (isNS4) { str += '<layer id="' + itemID + '" left="' + itemX + '" top="' + itemY + '" width="' + w + '" height="' + h + '" visibility="inherit" '; if (backCol) str += 'bgcolor="' + backCol + '" '; } if (borderClass) str += 'class="' + borderClass + '" '; // Add mouseover handlers and finish div/layer. str += 'onMouseOver="popOver(' + currMenu + ',' + currItem + ')" onMouseOut="popOut(' + currMenu + ',' + currItem + ')">'; // Add contents of item (default: table with link inside). // In IE/NS6+, add padding if there's a border to emulate NS4's layer padding. // If a target frame is specified, also add that to the <a> tag. str += '<table width="' + (w - 8) + '" border="0" cellspacing="0" cellpadding="' + (!isNS4 && borderClass ? 3 : 0) + '"><tr><td align="left" height="' + (h - 7) + '">' + '<a class="' + textClass + '" href="' + href + '"' + (frame ? ' target="' + frame + '">' : '>') + text + '</a></td>'; if (target > 0) { // Set target's parents to this menu item. menu[target][0].parentMenu = currMenu; menu[target][0].parentItem = currItem; // Add a popout indicator. if (popInd) str += '<td class="' + textClass + '" align="right">' + popInd + '</td>'; } str += '</tr></table>' + (isNS4 ? '</layer>' : '</div>'); if (isVert) itemY += length + spacing; else itemX += length + spacing; } if (isDOM) { var newDiv = document.createElement('div'); document.getElementsByTagName('body').item(0).appendChild(newDiv); newDiv.innerHTML = str; ref = newDiv.style; ref.position = 'absolute'; ref.visibility = 'hidden'; } // Insert a div tag to the end of the BODY with menu HTML in place for IE4. if (isIE4) { document.body.insertAdjacentHTML('beforeEnd', '<div id="menu' + currMenu + 'div" ' + 'style="position: absolute; visibility: hidden">' + str + '</div>'); ref = getSty('menu' + currMenu + 'div'); } // In NS4, create a reference to a new layer and write the items to it. if (isNS4) { ref = new Layer(0); ref.document.write(str); ref.document.close(); } for (currItem = 1; currItem < menu[currMenu].length; currItem++) { itemName = 'menu' + currMenu + 'item' + currItem; if (isDOM || isIE4) menu[currMenu][currItem].ref = getSty(itemName); if (isNS4) menu[currMenu][currItem].ref = ref.document[itemName]; } } with(menu[0][0]) { ref.left = x; ref.top = y; ref.visibility = 'visible'; } } // Syntaxes: *** START EDITING HERE, READ THIS SECTION CAREFULLY! *** // // menu[menuNumber][0] = new Menu(Vertical menu? (true/false), 'popout indicator', left, top, // width, 'mouseover colour', 'background colour', 'border stylesheet', 'text stylesheet'); // // Left and Top are measured on-the-fly relative to the top-left corner of its trigger, or // for the root menu, the top-left corner of the page. // // menu[menuNumber][itemNumber] = new Item('Text', 'URL', 'target frame', length of menu item, // additional spacing to next menu item, number of target menu to popout); // // If no target menu (popout) is desired, set it to 0. Likewise, if your site does not use // frames, pass an empty string as a frame target. // // Something that needs explaining - the Vertical Menu setup. You can see most menus below // are 'true', that is they are vertical, except for the first root menu. The 'length' and // 'width' of an item depends on its orientation -- length is how long the item runs for in // the direction of the menu, and width is the lateral dimension of the menu. Just look at // the examples and tweak the numbers, they'll make sense eventually :). var menu = new Array(); // Default colours passed to most menu constructors (just passed to functions, not // a global variable - makes things easier to change later in bulk). var defOver = '#336699', defBack = '#003366'; // Default 'length' of menu items - item height if menu is vertical, width if horizontal. var defLength = 22; // Menu 0 is the special, 'root' menu from which everything else arises. menu[0] = new Array(); // A non-vertical menu with a few different colours and no popout indicator, as an example. // *** MOVE ROOT MENU AROUND HERE *** it's positioned at (5, 0) and is 17px high now. menu[0][0] = new Menu(false, '', 5, 0, 17, '#669999', '#006666', '', 'itemText'); // Notice how the targets are all set to nonzero values... // The 'length' of each of these items is 40, and there is spacing of 10 to the next item. // Most of the links are set to '#' hashes, make sure you change them to actual files. menu[0][1] = new Item(' Marketing', '#', '', 60, 10, 1); menu[0][2] = new Item(' Reports', '#', '', 60, 10, 2); menu[0][3] = new Item(' Analysis', '#', '', 60, 10, 3); // An example of a link with a target frame/window as well... // Marketing menu. menu[1] = new Array(); // The File menu is positioned 0px across and 22 down from its trigger, and is 80 wide. // All text in this menu has the stylesheet class 'item' -- see the <style> section above. // We've passed a 'greater-than' sign '>' as a popout indicator. Try an image...? menu[1][0] = new Menu(true, '>', 0, 22, 180, defOver, defBack, 'itemBorder', 'itemText'); menu[1][1] = new Item('Order Confirmation', 'orderconfirm.asp', '', defLength, 0, 0); menu[1][2] = new Item('Delivery Challan','#','', defLength, 0, 4); // Non-zero target means this will trigger a popout -- menu[4] which is the 'Reopen' menu. menu[1][3] = new Item('Invoice', '#', '',defLength, 0, 6); menu[1][4] = new Item('CFC/Stationary', '#', '', defLength, 0, 7); menu[1][5] = new Item('Production Program', '#', '', defLength, 0, 0); menu[1][6] = new Item('Adding/Editing Parts', '#', '', defLength, 0, 0); menu[1][7] = new Item('Min/Max level of Production', '#', '', defLength, 0, 0); menu[1][8] = new Item('Pilot Run', '#', '', defLength, 0, 0); menu[1][9] = new Item('User Name For Production', '#', '', defLength, 0, 0); menu[1][10] = new Item('Invoice Settlement', '#', '', defLength, 0, 0); menu[1][11] = new Item('Rejection Entry', '#', '', defLength, 0, 0); menu[1][12] = new Item('Product Gatepass', '#', '', defLength, 0, 8); menu[1][13] = new Item('Product Details', '#', '', defLength, 0, 0); // Reports menu. menu[2] = new Array(); menu[2][0] = new Menu(true, '>', 0, 22, 180, defOver, defBack, 'itemBorder', 'itemText'); menu[2][1] = new Item('DC Report', '#', '', defLength, 0, 9); menu[2][2] = new Item('Pending OC', '#', '', defLength, 0, 10); menu[2][3] = new Item('Semifinished Stock', '#', '', defLength, 0, 0); menu[2][4] = new Item('Stock as per PriceList', '#', '', defLength, 0, 0); menu[2][5] = new Item('Stock Details', '#', '', defLength, 0, 0); menu[2][6] = new Item('Cent.Excise Return', '#', '', defLength, 0, 0); menu[2][7] = new Item('Sales Register', '#', '', defLength, 0, 0); menu[2][8] = new Item('Stok Register', '#', '', defLength, 0, 0); menu[2][9] = new Item('Excise Updation Register', '#', '', defLength, 0, 0); menu[2][10] = new Item('Modelwise Sales', '#', '', defLength, 0, 0); menu[2][11] = new Item('CRF Index', '#', '', defLength, 0, 11); menu[2][12] = new Item('Monthwise Production List', '#', '', defLength, 0, 0); menu[2][13] = new Item('Prod Record from QC', '#', '', defLength, 0, 0); menu[2][14] = new Item('Field Failure Analysis', '#', '', defLength, 0, 12); menu[2][15] = new Item('Materials in QC', '#', '', defLength, 0, 0); menu[2][16] = new Item('Products Crossing Storage period', '#', '', defLength, 0, 0); menu[2][17] = new Item('Quality Certificate', '#', '', defLength, 0, 0); menu[2][18] = new Item('Batchwise Stock', '#', '', defLength, 0, 0); // Help menu menu[3] = new Array(); menu[3][0] = new Menu(true, '>', 0, 22, 180, defOver, defBack, 'itemBorder', 'itemText'); menu[3][1] = new Item('Product Wise', '#', '', defLength, 0, 0); menu[3][2] = new Item('Turnover ProductWise', '#', '', defLength, 0, 0); menu[3][3] = new Item('Monthly Total All', '#', '', defLength, 0, 0); menu[3][4] = new Item('Advance Payments', '#', '', defLength, 0, 0); menu[3][5] = new Item('Dealers At a glance', '#', '', defLength, 0, 5); menu[3][6] = new Item('Non Dealers Performance', '#', '', defLength, 0, 0); menu[3][7] = new Item('Productwise Summary', '#', '', defLength, 0, 0); menu[3][8] = new Item('COD Details', '#', '', defLength, 0, 0); menu[3][9] = new Item('Discount Basis', '#', '', defLength, 0, 0); // Reopen menu menu[4] = new Array(); // This is across but not down... a horizontal popout (with crazy stylesheets :)... menu[4][0] = new Menu(true, '>', 145, 0, 160, '#333366', '#666699', 'crazyBorder', 'crazyText'); // These items are lengthier than normal, and have extra spacing due to the fancy borders. menu[4][1] = new Item('Delivery Challan', '#', '', 36, 0, 0); menu[4][2] = new Item('Print Delivery Challan', '#', '', 36, 0, 0); // Reopen menu menu[5] = new Array(); // This is across but not down... a horizontal popout (with crazy stylesheets :)... menu[5][0] = new Menu(true, '>', 145, 0, 160, '#333366', '#666699', 'crazyBorder', 'crazyText'); // These items are lengthier than normal, and have extra spacing due to the fancy borders. menu[5][1] = new Item('Invoice Entry', '#', '', 36, 0, 0); menu[5][2] = new Item('Edit Shipping Address', '#', '', 36, 0, 0); menu[5][3] = new Item('Print Invoice', '#', '', 36, 0, 0); menu[5][4] = new Item('Bank Documents', '#', '', 36, 0, 0); // Reopen menu menu[6] = new Array(); // This is across but not down... a horizontal popout (with crazy stylesheets :)... menu[6][0] = new Menu(true, '>', 145, 0, 160, '#333366', '#666699', 'crazyBorder', 'crazyText'); // These items are lengthier than normal, and have extra spacing due to the fancy borders. menu[6][1] = new Item('Invoice Entry', '#', '', 36, 0, 0); menu[6][2] = new Item('Edit Shipping Address', '#', '', 36, 0, 0); menu[6][3] = new Item('Print Invoice', '#', '', 36, 0, 0); menu[6][4] = new Item('Bank Documents', '#', '', 36, 0, 0); // Reopen Menu menu[7]=new Array(); menu[7][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[7][1]=new Item('CFC Entry','#', '', 36,0,0); menu[7][2]=new Item('Stationary Entry','#', '', 36,0,0); menu[7][3]=new Item('Report','#', '', 36,0,0); // Reopen Menu menu[8]=new Array(); menu[8][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[8][1]=new Item('Gate Pass Entry','#', '', 36,0,0); menu[8][2]=new Item('Pending GP','#', '', 36,0,0); // Reopen Menu menu[9]=new Array(); menu[9][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[9][1]=new Item('Party / Prod / All','#', '', 36,0,0); menu[9][2]=new Item('Modelwise Report ','#', '', 36,0,0); menu[9][3]=new Item('Batchwise DC', '#', '', 36,0,0); menu[9][4]=new Item('Party Modelwise','#','',36,0,0); // Reopen Menu menu[10]=new Array(); menu[10][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[10][1]=new Item('All','#', '', 36,0,0); menu[10][2]=new Item('Product Wise ','#', '', 36,0,0); menu[10][3]=new Item('Particular Parts', '#', '', 36,0,0); menu[10][4]=new Item('Product Partywise','#','',36,0,0); menu[10][4]=new Item('OC Crossed Delivery Schedule','#','',36,0,0); // Reopen Menu menu[11]=new Array(); menu[11][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[11][1]=new Item('Invoice Wise','#', '', 36,0,0); menu[11][2]=new Item('OC wise ','#', '', 36,0,0); // Reopen Menu menu[12]=new Array(); menu[12][0]=new Menu(true,'>',145,0,160,'#333366','#666699','crazyBorder','crazyText'); //These items are lengthier than normal and have extra spacing due to the fancy borders. menu[12][1]=new Item('Product Performance Review','#', '', 36,0,0); menu[12][2]=new Item('AOQL limit Field Failure rvw ','#', '', 36,0,0); menu[12][3]=new Item('AOQL List', '#', '', 36,0,0); menu[12][4]=new Item('Field Failure Arts','#','',36,0,0); // *** OPTIONAL CODE FROM HERE DOWN *** // These two lines handle the window resize bug in NS4. See <body onResize="...">. // I recommend you leave this here as otherwise when you resize NS4's width menus are hidden. var popOldWidth = window.innerWidth; nsResizeHandler = new Function('if (popOldWidth != window.innerWidth) location.reload()'); // This is a quick snippet that captures all clicks on the document and hides the menus // every time you click. Use if you want. if (isNS4) document.captureEvents(Event.CLICK); document.onclick = clickHandle; function clickHandle(evt) { if (isNS4) document.routeEvent(evt); hideAllBut(0); } // This is just the moving command for the example. function moveRoot() { with(menu[0][0].ref) left = ((parseInt(left) < 100) ? 100 : 5); } // End --> </script> <!-- *** IMPORTANT STYLESHEET SECTION - Change the border classes and text colours *** --> <style> .itemBorder { border: 1px solid black } .itemText { text-decoration: none; color: #FFFFFF; font: 12px Arial, Helvetica } .crazyBorder { border: 2px outset #663399 } .crazyText { text-decoration: none; color: #FFCC99; font: Bold 12px Arial, Helvetica } </style> </HEAD> <!-- STEP TWO: Insert the onLoad event handler into your BODY tag --> <BODY marginwidth="0" marginheight="0" style="margin: 0" onLoad="writeMenus()" onResize="if (isNS4) nsResizeHandler()"> <!-- STEP THREE: Copy this code into the BODY of your HTML document --> <!-- It's important that you position the menu over a background, like a table/image --> <table bgcolor="#006666" width="27%" border="0" cellpadding="0" cellspacing="0" height="18"> <tr><td height="17"><font size="1"> </font></td></tr></table> </body> </html> It is a very imple code.u can see it.onlything u just go through it and if u want to add the new fields then go to array menu[][] for submenu also u see next sub array if any doubt further plz ask. thanx salil ----------------------------------------------------------- To stop getting this e-mail, or change how often it arrives, go to your E-mail Settings. http://groups.msn.com/bdotnet/_emailsettings.msnw Need help? If you've forgotten your password, please go to Passport Member Services. http://groups.msn.com/_passportredir.msnw?ppmprop=help For other questions or feedback, go to our Contact Us page. http://groups.msn.com/contact If you do not want to receive future e-mail from this MSN group, or if you received this message by mistake, please click the "Remove" link below. On the pre-addressed e-mail message that opens, simply click "Send". Your e-mail address will be deleted from this group's mailing list. mailto:[EMAIL PROTECTED]
