| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 | require({cache:{'url:dijit/form/templates/Select.html':"<table class=\"dijit dijitReset dijitInline dijitLeft\"\n\tdata-dojo-attach-point=\"_buttonNode,tableNode,focusNode\" cellspacing='0' cellpadding='0'\n\trole=\"combobox\" aria-haspopup=\"true\"\n\t><tbody role=\"presentation\"><tr role=\"presentation\"\n\t\t><td class=\"dijitReset dijitStretch dijitButtonContents dijitButtonNode\" role=\"presentation\"\n\t\t\t><span class=\"dijitReset dijitInline dijitButtonText\"  data-dojo-attach-point=\"containerNode,_popupStateNode\"></span\n\t\t\t><input type=\"hidden\" ${!nameAttrSetting} data-dojo-attach-point=\"valueNode\" value=\"${value}\" aria-hidden=\"true\"\n\t\t/></td><td class=\"dijitReset dijitRight dijitButtonNode dijitArrowButton dijitDownArrowButton\"\n\t\t\t\tdata-dojo-attach-point=\"titleNode\" role=\"presentation\"\n\t\t\t><div class=\"dijitReset dijitArrowButtonInner\" role=\"presentation\"></div\n\t\t\t><div class=\"dijitReset dijitArrowButtonChar\" role=\"presentation\">▼</div\n\t\t></td\n\t></tr></tbody\n></table>\n"}});define("dijit/form/Select", [	"dojo/_base/array", // array.forEach	"dojo/_base/declare", // declare	"dojo/dom-attr", // domAttr.set	"dojo/dom-class", // domClass.add domClass.remove domClass.toggle	"dojo/dom-construct", // domConstruct.create	"dojo/dom-geometry", // domGeometry.setMarginBox	"dojo/_base/event", // event.stop	"dojo/i18n", // i18n.getLocalization	"dojo/_base/lang", // lang.hitch	"./_FormSelectWidget",	"../_HasDropDown",	"../Menu",	"../MenuItem",	"../MenuSeparator",	"../Tooltip",	"dojo/text!./templates/Select.html",	"dojo/i18n!./nls/validate"], function(array, declare, domAttr, domClass, domConstruct, domGeometry, event, i18n, lang,			_FormSelectWidget, _HasDropDown, Menu, MenuItem, MenuSeparator, Tooltip, template){/*=====	var _FormSelectWidget = dijit.form._FormSelectWidget;	var _HasDropDown = dijit._HasDropDown;	var _FormSelectWidget = dijit._FormSelectWidget;	var Menu = dijit.Menu;	var MenuItem = dijit.MenuItem;	var MenuSeparator = dijit.MenuSeparator;	var Tooltip = dijit.Tooltip;=====*/// module://		dijit/form/Select// summary://		This is a "styleable" select box - it is basically a DropDownButton which//		can take a <select> as its input.var _SelectMenu = declare("dijit.form._SelectMenu", Menu, {	// summary:	//		An internally-used menu for dropdown that allows us a vertical scrollbar	buildRendering: function(){		// summary:		//		Stub in our own changes, so that our domNode is not a table		//		otherwise, we won't respond correctly to heights/overflows		this.inherited(arguments);		var o = (this.menuTableNode = this.domNode);		var n = (this.domNode = domConstruct.create("div", {style: {overflowX: "hidden", overflowY: "scroll"}}));		if(o.parentNode){			o.parentNode.replaceChild(n, o);		}		domClass.remove(o, "dijitMenuTable");		n.className = o.className + " dijitSelectMenu";		o.className = "dijitReset dijitMenuTable";		o.setAttribute("role", "listbox");		n.setAttribute("role", "presentation");		n.appendChild(o);	},	postCreate: function(){		// summary:		//		stop mousemove from selecting text on IE to be consistent with other browsers		this.inherited(arguments);		this.connect(this.domNode, "onmousemove", event.stop);	},	resize: function(/*Object*/ mb){		// summary:		//		Overridden so that we are able to handle resizing our		//		internal widget.  Note that this is not a "full" resize		//		implementation - it only works correctly if you pass it a		//		marginBox.		//		// mb: Object		//		The margin box to set this dropdown to.		if(mb){			domGeometry.setMarginBox(this.domNode, mb);			if("w" in mb){				// We've explicitly set the wrapper <div>'s width, so set <table> width to match.				// 100% is safer than a pixel value because there may be a scroll bar with				// browser/OS specific width.				this.menuTableNode.style.width = "100%";			}		}	}});var Select = declare("dijit.form.Select", [_FormSelectWidget, _HasDropDown], {	// summary:	//		This is a "styleable" select box - it is basically a DropDownButton which	//		can take a <select> as its input.	baseClass: "dijitSelect",	templateString: template,	// required: Boolean	//		Can be true or false, default is false.	required: false,	// state: [readonly] String	//		"Incomplete" if this select is required but unset (i.e. blank value), "" otherwise	state: "",	// message: String	//		Currently displayed error/prompt message	message: "",	//	tooltipPosition: String[]	//		See description of dijit.Tooltip.defaultPosition for details on this parameter.	tooltipPosition: [],	// emptyLabel: string	//		What to display in an "empty" dropdown	emptyLabel: " ",	//  	// _isLoaded: Boolean	//		Whether or not we have been loaded	_isLoaded: false,	// _childrenLoaded: Boolean	//		Whether or not our children have been loaded	_childrenLoaded: false,	_fillContent: function(){		// summary:		//		Set the value to be the first, or the selected index		this.inherited(arguments);		// set value from selected option		if(this.options.length && !this.value && this.srcNodeRef){			var si = this.srcNodeRef.selectedIndex || 0; // || 0 needed for when srcNodeRef is not a SELECT			this.value = this.options[si >= 0 ? si : 0].value;		}		// Create the dropDown widget		this.dropDown = new _SelectMenu({id: this.id + "_menu"});		domClass.add(this.dropDown.domNode, this.baseClass + "Menu");	},	_getMenuItemForOption: function(/*dijit.form.__SelectOption*/ option){		// summary:		//		For the given option, return the menu item that should be		//		used to display it.  This can be overridden as needed		if(!option.value && !option.label){			// We are a separator (no label set for it)			return new MenuSeparator();		}else{			// Just a regular menu option			var click = lang.hitch(this, "_setValueAttr", option);			var item = new MenuItem({				option: option,				label: option.label || this.emptyLabel,				onClick: click,				disabled: option.disabled || false			});			item.focusNode.setAttribute("role", "listitem");			return item;		}	},	_addOptionItem: function(/*dijit.form.__SelectOption*/ option){		// summary:		//		For the given option, add an option to our dropdown.		//		If the option doesn't have a value, then a separator is added		//		in that place.		if(this.dropDown){			this.dropDown.addChild(this._getMenuItemForOption(option));		}	},	_getChildren: function(){		if(!this.dropDown){			return [];		}		return this.dropDown.getChildren();	},	_loadChildren: function(/*Boolean*/ loadMenuItems){		// summary:		//		Resets the menu and the length attribute of the button - and		//		ensures that the label is appropriately set.		//	loadMenuItems: Boolean		//		actually loads the child menu items - we only do this when we are		//		populating for showing the dropdown.		if(loadMenuItems === true){			// this.inherited destroys this.dropDown's child widgets (MenuItems).			// Avoid this.dropDown (Menu widget) having a pointer to a destroyed widget (which will cause			// issues later in _setSelected). (see #10296)			if(this.dropDown){				delete this.dropDown.focusedChild;			}			if(this.options.length){				this.inherited(arguments);			}else{				// Drop down menu is blank but add one blank entry just so something appears on the screen				// to let users know that they are no choices (mimicing native select behavior)				array.forEach(this._getChildren(), function(child){ child.destroyRecursive(); });				var item = new MenuItem({label: " "});				this.dropDown.addChild(item);			}		}else{			this._updateSelection();		}		this._isLoaded = false;		this._childrenLoaded = true;		if(!this._loadingStore){			// Don't call this if we are loading - since we will handle it later			this._setValueAttr(this.value);		}	},	_setValueAttr: function(value){		this.inherited(arguments);		domAttr.set(this.valueNode, "value", this.get("value"));		this.validate(this.focused);	// to update this.state	},	_setDisabledAttr: function(/*Boolean*/ value){		this.inherited(arguments);		this.validate(this.focused);	// to update this.state	},	_setRequiredAttr: function(/*Boolean*/ value){		this._set("required", value);		this.focusNode.setAttribute("aria-required", value);		this.validate(this.focused);	// to update this.state	},	_setDisplay: function(/*String*/ newDisplay){		// summary:		//		sets the display for the given value (or values)		var lbl = newDisplay || this.emptyLabel;		this.containerNode.innerHTML = '<span class="dijitReset dijitInline ' + this.baseClass + 'Label">' + lbl + '</span>';		this.focusNode.setAttribute("aria-valuetext", lbl);	},	validate: function(/*Boolean*/ isFocused){		// summary:		//		Called by oninit, onblur, and onkeypress, and whenever required/disabled state changes		// description:		//		Show missing or invalid messages if appropriate, and highlight textbox field.		//		Used when a select is initially set to no value and the user is required to		//		set the value.		var isValid = this.disabled || this.isValid(isFocused);		this._set("state", isValid ? "" : "Incomplete");		this.focusNode.setAttribute("aria-invalid", isValid ? "false" : "true");		var message = isValid ? "" : this._missingMsg;		if(message && this.focused && this._hasBeenBlurred){			Tooltip.show(message, this.domNode, this.tooltipPosition, !this.isLeftToRight());		}else{			Tooltip.hide(this.domNode);		}		this._set("message", message);		return isValid;	},	isValid: function(/*Boolean*/ /*===== isFocused =====*/){		// summary:		//		Whether or not this is a valid value.  The only way a Select		//		can be invalid is when it's required but nothing is selected.		return (!this.required || this.value === 0 || !(/^\s*$/.test(this.value || ""))); // handle value is null or undefined	},	reset: function(){		// summary:		//		Overridden so that the state will be cleared.		this.inherited(arguments);		Tooltip.hide(this.domNode);		this.validate(this.focused);	// to update this.state	},	postMixInProperties: function(){		// summary:		//		set the missing message		this.inherited(arguments);		this._missingMsg = i18n.getLocalization("dijit.form", "validate",									this.lang).missingMessage;	},	postCreate: function(){		// summary:		//		stop mousemove from selecting text on IE to be consistent with other browsers		this.inherited(arguments);		this.connect(this.domNode, "onmousemove", event.stop);	},	_setStyleAttr: function(/*String||Object*/ value){		this.inherited(arguments);		domClass.toggle(this.domNode, this.baseClass + "FixedWidth", !!this.domNode.style.width);	},	isLoaded: function(){		return this._isLoaded;	},	loadDropDown: function(/*Function*/ loadCallback){		// summary:		//		populates the menu		this._loadChildren(true);		this._isLoaded = true;		loadCallback();	},	closeDropDown: function(){		// overriding _HasDropDown.closeDropDown()		this.inherited(arguments);		if(this.dropDown && this.dropDown.menuTableNode){			// Erase possible width: 100% setting from _SelectMenu.resize().			// Leaving it would interfere with the next openDropDown() call, which			// queries the natural size of the drop down.			this.dropDown.menuTableNode.style.width = "";		}	},	uninitialize: function(preserveDom){		if(this.dropDown && !this.dropDown._destroyed){			this.dropDown.destroyRecursive(preserveDom);			delete this.dropDown;		}		this.inherited(arguments);	},	_onFocus: function(){		this.validate(true);	// show tooltip if second focus of required tooltip, but no selection		this.inherited(arguments);	},	_onBlur: function(){		Tooltip.hide(this.domNode);		this.inherited(arguments);	}});Select._Menu = _SelectMenu;	// for monkey patchingreturn Select;});
 |