<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head><title>Multi-select Widget</title>
<script language="JavaScript" type="text/javascript"> <!--
/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * * The initial developer of the code is Andy Edmonds. * Portions created by the Initial Developer are Copyright (C) 2001 * the Initial Developer. All Rights Reserved. * * Contributor(s): * Andy Edmonds <andy@uzilla.net> * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ // CUSTOMIZABLE VALUES var multis = "methods,datasources,lifecycle"; var isEdit = false; // Using numeric count for number of specified values var inSequence = true; // Set to false to disable auto-sequential expansion var autoCollapse = true; // Only allow one container to be expanded at a time
// TRACKING VARIABLES -- do not change var arMultis = multis.split(","); var curOpen = false; var sequenceNum = 0; //Tracker for auto-sequential expansion var isOpen = -1; // Currently open element for auto-collapse //,activity,agent,condition";
function initMultiSelect() { var isEdit = false; var i, viewSummary, viewOptions;
for(i=0;i<arMultis.length;i++) { viewSummary = document.getElementById("summary_" + arMultis[i]); viewOptions = document.getElementById("options_" + arMultis[i]); // In edit default to all collapsed // In new mode, default to editing first element // If any checkbox is selected, dont reset edit flag if(!isEdit) { isEdit = populateSummary(viewSummary, viewOptions); } else { populateSummary(viewSummary, viewOptions); } if(isEdit) inSequence = false; showSummary(viewSummary, viewOptions); } // If it's an edit if(!isEdit && inSequence) { var firstField = arMultis[0]; // Show first option panel showOptions( document.getElementById("summary_" + firstField), document.getElementById("options_" + firstField) ) } }
function populateSummary(sum,opt) { var editString = "<input type='button' value='Edit Selections' onclick='showOptions(this.parentNode,this.parentNode.previousSibling);'>"; var curNode; var numChecked = 0; var sumStr = ''; // Get all checkboxes inside current div var inputs = opt.getElementsByTagName("input"); //alert(inputs.length + " inputs in " + opt.id); for(var i=0;i<inputs.length;i++) { curNode = inputs.item(i); //alert(i); if(curNode.nodeName == "INPUT" && curNode.getAttribute("type") == "checkbox") { if(curNode.checked) { if(numChecked > 0) sumStr += "; "; numChecked++; sumStr += curNode.getAttribute("value") + ''; //alert("At " + i + " of " + curNode.getAttribute("value")); } } } // Options selected? summarize. Otherwise? instruct. if(sumStr.length) { sum.innerHTML = sumStr + ".<br/>" + editString; } else { // No current selectiongs, provide help msg sum.innerHTML = "Please click Edit Selections to specify" + ".<br/>" + editString; } // Pass back positive if items are already checked return numChecked; }
function showSummary(sum, opt) { sum.style.display = 'inline'; opt.style.display = 'none'; isOpen = -1; }
function showOptions(sum, opt) { sum.style.display = 'none'; opt.style.display = 'inline'; if(isOpen > -1 && autoCollapse) { showSummary( document.getElementById("summary_" + arMultis[isOpen]), document.getElementById("options_" + arMultis[isOpen]) ) } isOpen = getOffset(sum.getAttribute("id")); }
function getOffset(label) { for(var i=0;i<arMultis.length;i++) { if(label.indexOf(arMultis[i]) > -1) return i; } }
function saveOptions(optNode) { var sumNode = document.getElementById("summary_" +optNode.getAttribute("id").split("_")[1]); populateSummary(sumNode,optNode); showSummary(sumNode,optNode); if(inSequence) { // check to see if the user is editing sequentialy if(optNode.id.indexOf(arMultis[sequenceNum]) > -1) { // They're editing in sequence sequenceNum++; // Is there a next element to show? if(sequenceNum < arMultis.length) { var nextField = arMultis[sequenceNum]; showOptions( document.getElementById("summary_" + nextField), document.getElementById("options_" + nextField) ) } } else { inSequence = false; } } } //--> </script></head>
<body onload="initMultiSelect()">
<table cellpadding="8" cellspacing="0" width="942"> <tbody><tr> <td valign="top" width="12%">Usability Methods</td> <td bgcolor="#ffffff" width="88%"> <div style="display: inline;" id="options_methods"><table><tbody><tr><td valign="top"> <input name="methods" value="Card Sorting" id="cardsort" type="checkbox"><label for="carsort">Card Sorting</label><br> <input name="methods" value="Contextual Task Analysis" id="cta" type="checkbox"><label for="cta">Contextual Task Analysis</label> <br> <input name="methods" value="Ethnography" id="ethno" type="checkbox"><label for="ethno">Ethnography</label><br>
</td><td valign="top"> <input name="methods" value="Heuristic Review" id="heur" type="checkbox"><label for="heur">Heuristic Review</label><br> <input name="methods" value="Remote Usability Testing" id="remote" type="checkbox"><label for="remote">Remote Usability Testing</label><br> <input name="methods" value="Usability Testing" id="ut" type="checkbox"><label for="ut">Usability Testing</label><br> </td></tr></tbody></table> <input value="Close" style="float: left;" onclick="saveOptions(this.parentNode);" type="button"></div><div style="display: none;" id="summary_methods">Please click Edit Selections to specify.<br><input value="Edit Selections" onclick="showOptions(this.parentNode,this.parentNode.previousSibling);" type="button"></div> </td> </tr> <tr bgcolor="#dddddd"> <td id="label_activity" valign="top">Datasources</td> <td valign="top"> <div style="display: none;" id="options_datasources"> <table><tbody><tr><td valign="top"> <input name="methods" value="Competitive Review" ic="comp" type="checkbox"><label for="comp">Competitive Review</label><br> <input name="methods" value="Performance Data" id="perf" type="checkbox"><label for="perf">Performance Data</label><br> <input name="methods" value="Verbal Protocol" label="protocol" type="checkbox"><label for="protocol">Verbal Protocol</label><br>
</td><td valign="top"> <input name="methods" value="User Surveys" id="survey" type="checkbox"><label for="survey">User Surveys</label><br> <input name="methods" value="Support Requests" id="support" type="checkbox"><label for="support">Support Requests</label><br> <input name="methods" value="Usage Data" id="usage" type="checkbox"><label for="usage">Usage Data</label><br> </td></tr></tbody></table> <input value="Close" style="float: left;" onclick="saveOptions(this.parentNode);" type="button"></div><div style="display: inline;" id="summary_datasources">Please click Edit Selections to specify.<br><input value="Edit Selections" onclick="showOptions(this.parentNode,this.parentNode.previousSibling);" type="button"></div> </td> </tr><tr><td valign="top">Lifecycle </td> <td valign="top"> <div style="display: none;" id="options_lifecycle"> <table><tbody><tr><td valign="top"> <input name="methods" value="Acceptance Testing" id="at" type="checkbox"><label for="at">Acceptance Testing</label><br> <input name="methods" value="Iterative Design" id="iterative" type="checkbox"><label for="iterative">Iterative Design</label><br> <input name="methods" value="Needs Analysis" id="needs" type="checkbox"><label for="needs">Needs Analysis</label><br>
</td><td valign="top">
<input name="methods" value="Rapid Prototyping" id="proto" type="checkbox"><label for="proto">Rapid prototyping</label><br> <input name="methods" value="Requirements Definition" id="reqs" type="checkbox"><label for="reqs">Requirements Definition</label><br> <input name="methods" value="Specification" id="spec" type="checkbox"><label for="spec">Specification</label><br>
</td></tr></tbody></table>
<input value="Close" style="float: left;" onclick="saveOptions(this.parentNode);" type="button"></div><div style="display: inline;" id="summary_lifecycle">Please click Edit Selections to specify.<br><input value="Edit Selections" onclick="showOptions(this.parentNode,this.parentNode.previousSibling);" type="button"></div> </td> </tr>
</tbody></table>
</body></html>
|