2014-08-23 03:39:35 +00:00
|
|
|
/*!
|
|
|
|
* jQuery UI Controlgroup @VERSION
|
|
|
|
* http://jqueryui.com
|
|
|
|
*
|
2015-08-09 15:48:43 +00:00
|
|
|
* Copyright jQuery Foundation and other contributors
|
2014-08-23 03:39:35 +00:00
|
|
|
* Released under the MIT license.
|
|
|
|
* http://jquery.org/license
|
|
|
|
*/
|
2015-08-09 15:48:43 +00:00
|
|
|
|
|
|
|
//>>label: Controlgroup
|
|
|
|
//>>group: Widgets
|
|
|
|
//>>description: Visually groups form control widgets
|
|
|
|
//>>docs: http://api.jqueryui.com/controlgroup/
|
|
|
|
//>>demos: http://jqueryui.com/controlgroup/
|
2015-10-21 23:08:44 +00:00
|
|
|
//>>css.structure: ../../themes/base/core.css
|
|
|
|
//>>css.structure: ../../themes/base/controlgroup.css
|
|
|
|
//>>css.theme: ../../themes/base/theme.css
|
2015-08-09 15:48:43 +00:00
|
|
|
|
2014-08-23 03:39:35 +00:00
|
|
|
( function( factory ) {
|
|
|
|
if ( typeof define === "function" && define.amd ) {
|
|
|
|
|
|
|
|
// AMD. Register as an anonymous module.
|
|
|
|
define( [
|
|
|
|
"jquery",
|
2015-08-09 04:30:34 +00:00
|
|
|
"../widget"
|
2014-08-23 03:39:35 +00:00
|
|
|
], factory );
|
|
|
|
} else {
|
|
|
|
|
|
|
|
// Browser globals
|
|
|
|
factory( jQuery );
|
|
|
|
}
|
|
|
|
}( function( $ ) {
|
|
|
|
|
|
|
|
return $.widget( "ui.controlgroup", {
|
|
|
|
version: "@VERSION",
|
|
|
|
defaultElement: "<div>",
|
|
|
|
options: {
|
2015-09-16 05:49:08 +00:00
|
|
|
direction: "horizontal",
|
2014-08-23 03:39:35 +00:00
|
|
|
disabled: null,
|
2015-09-30 13:38:42 +00:00
|
|
|
onlyVisible: true,
|
2014-08-23 03:39:35 +00:00
|
|
|
items: {
|
|
|
|
"button": "input[type=button], input[type=submit], input[type=reset], button, a",
|
2015-09-16 05:49:08 +00:00
|
|
|
"controlgroupLabel": ".ui-controlgroup-label",
|
2014-08-23 03:39:35 +00:00
|
|
|
"checkboxradio": "input[type='checkbox'], input[type='radio']",
|
2015-08-10 14:08:51 +00:00
|
|
|
"selectmenu": "select",
|
2015-09-16 05:49:08 +00:00
|
|
|
"spinner": ".ui-spinner-input"
|
|
|
|
}
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
_create: function() {
|
|
|
|
this._enhance();
|
|
|
|
},
|
|
|
|
|
|
|
|
// To support the enhanced option in jQuery Mobile, we isolate DOM manipulation
|
|
|
|
_enhance: function() {
|
|
|
|
this.element.attr( "role", "toolbar" );
|
|
|
|
this.refresh();
|
|
|
|
},
|
|
|
|
|
|
|
|
_destroy: function() {
|
|
|
|
this._callChildMethod( "destroy" );
|
|
|
|
this.childWidgets.removeData( "ui-controlgroup-data" );
|
|
|
|
this.element.removeAttr( "role" );
|
2015-10-25 22:07:34 +00:00
|
|
|
if ( this.options.items.controlgroupLabel ) {
|
|
|
|
this.element
|
|
|
|
.find( this.options.items.controlgroupLabel )
|
|
|
|
.find( ".ui-controlgroup-label-contents" )
|
|
|
|
.contents().unwrap();
|
|
|
|
}
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
_initWidgets: function() {
|
|
|
|
var that = this,
|
|
|
|
childWidgets = [];
|
|
|
|
|
|
|
|
// First we iterate over each of the items options
|
|
|
|
$.each( this.options.items, function( widget, selector ) {
|
2015-10-06 13:19:32 +00:00
|
|
|
var labels;
|
|
|
|
var options = {};
|
2014-08-23 03:39:35 +00:00
|
|
|
|
2015-10-25 22:07:34 +00:00
|
|
|
// Make sure the widget has a selector set
|
|
|
|
if ( !selector ) {
|
2015-09-30 15:47:33 +00:00
|
|
|
return;
|
2015-10-06 13:19:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ( widget === "controlgroupLabel" ) {
|
2015-08-12 15:24:30 +00:00
|
|
|
labels = that.element.find( selector );
|
2015-08-17 12:43:31 +00:00
|
|
|
labels.each( function() {
|
|
|
|
$( this ).contents().wrapAll( "<span class='ui-controlgroup-label-contents'></span>" );
|
|
|
|
} );
|
2015-08-12 15:24:30 +00:00
|
|
|
that._addClass( labels, null, "ui-widget ui-widget-content ui-state-default" );
|
2015-09-16 05:49:08 +00:00
|
|
|
childWidgets = childWidgets.concat( labels.get() );
|
2015-09-30 15:47:33 +00:00
|
|
|
return;
|
2014-08-23 03:39:35 +00:00
|
|
|
}
|
2015-09-30 15:47:33 +00:00
|
|
|
|
2015-10-25 22:07:34 +00:00
|
|
|
// Make sure the widget actually exists
|
|
|
|
if ( !$.fn[ widget ] ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-09-30 15:47:33 +00:00
|
|
|
// We assume everything is in the middle to start because we can't determine
|
|
|
|
// first / last elements until all enhancments are done.
|
|
|
|
if ( that[ "_" + widget + "Options" ] ) {
|
|
|
|
options = that[ "_" + widget + "Options" ]( "middle" );
|
|
|
|
}
|
|
|
|
|
|
|
|
// Find instances of this widget inside controlgroup and init them
|
2015-10-06 13:19:32 +00:00
|
|
|
that.element
|
|
|
|
.find( selector )[ widget ]( options )
|
|
|
|
.each( function() {
|
|
|
|
var element = $( this );
|
|
|
|
|
|
|
|
// Store an instance of the controlgroup to be able to reference
|
|
|
|
// from the outermost element for changing options and refresh
|
|
|
|
var widgetElement = element[ widget ]( "widget" );
|
|
|
|
$.data( widgetElement[ 0 ], "ui-controlgroup-data",
|
|
|
|
element[ widget ]( "instance" ) );
|
|
|
|
|
|
|
|
childWidgets.push( widgetElement[ 0 ] );
|
|
|
|
} );
|
2014-08-23 03:39:35 +00:00
|
|
|
} );
|
|
|
|
|
|
|
|
this.childWidgets = $( $.unique( childWidgets ) );
|
2015-08-12 15:24:30 +00:00
|
|
|
this._addClass( this.childWidgets, "ui-controlgroup-item" );
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
_callChildMethod: function( method ) {
|
|
|
|
this.childWidgets.each( function() {
|
|
|
|
var element = $( this ),
|
|
|
|
data = element.data( "ui-controlgroup-data" );
|
2015-09-11 14:49:19 +00:00
|
|
|
if ( data && data[ method ] ) {
|
2015-08-10 14:08:51 +00:00
|
|
|
data[ method ]();
|
|
|
|
}
|
2014-08-23 03:39:35 +00:00
|
|
|
} );
|
|
|
|
},
|
|
|
|
|
2015-08-14 13:49:48 +00:00
|
|
|
_updateCornerClass: function( element, position ) {
|
2015-09-16 05:49:08 +00:00
|
|
|
var remove = "ui-corner-top ui-corner-bottom ui-corner-left ui-corner-right";
|
|
|
|
var add = this._buildSimpleOptions( position, "label" ).classes.label;
|
2015-08-14 13:49:48 +00:00
|
|
|
|
|
|
|
this._removeClass( element, null, remove );
|
|
|
|
this._addClass( element, null, add );
|
|
|
|
},
|
|
|
|
|
2015-09-16 05:49:08 +00:00
|
|
|
_buildSimpleOptions: function( position, key ) {
|
|
|
|
var direction = this.options.direction === "vertical";
|
2014-08-23 03:39:35 +00:00
|
|
|
var result = {
|
|
|
|
classes: {}
|
|
|
|
};
|
|
|
|
result.classes[ key ] = {
|
|
|
|
"middle": null,
|
|
|
|
"first": "ui-corner-" + ( direction ? "top" : "left" ),
|
|
|
|
"last": "ui-corner-" + ( direction ? "bottom" : "right" )
|
|
|
|
}[ position ];
|
|
|
|
|
|
|
|
return result;
|
|
|
|
},
|
|
|
|
|
2015-09-16 05:49:08 +00:00
|
|
|
_spinnerOptions: function( position ) {
|
|
|
|
var options = this._buildSimpleOptions( position, "ui-spinner" );
|
2015-08-10 14:08:51 +00:00
|
|
|
|
|
|
|
options.classes[ "ui-spinner-up" ] = "";
|
|
|
|
options.classes[ "ui-spinner-down" ] = "";
|
|
|
|
|
|
|
|
return options;
|
|
|
|
},
|
|
|
|
|
2015-09-16 05:49:08 +00:00
|
|
|
_buttonOptions: function( position ) {
|
|
|
|
return this._buildSimpleOptions( position, "ui-button" );
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
|
2015-09-16 05:49:08 +00:00
|
|
|
_checkboxradioOptions: function( position ) {
|
|
|
|
return this._buildSimpleOptions( position, "ui-checkboxradio-label" );
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
|
2015-09-16 05:49:08 +00:00
|
|
|
_selectmenuOptions: function( position ) {
|
|
|
|
var direction = this.options.direction === "vertical";
|
2014-08-23 03:39:35 +00:00
|
|
|
return {
|
|
|
|
width: direction ? "auto" : false,
|
|
|
|
classes: {
|
|
|
|
middle: {
|
|
|
|
"ui-selectmenu-button-open": null,
|
|
|
|
"ui-selectmenu-button-closed": null
|
|
|
|
},
|
|
|
|
first: {
|
2015-09-16 05:49:08 +00:00
|
|
|
"ui-selectmenu-button-open": "ui-corner-" + ( direction ? "top" : "tl" ),
|
|
|
|
"ui-selectmenu-button-closed": "ui-corner-" + ( direction ? "top" : "left" )
|
2014-08-23 03:39:35 +00:00
|
|
|
},
|
|
|
|
last: {
|
2015-09-16 05:49:08 +00:00
|
|
|
"ui-selectmenu-button-open": direction ? null : "ui-corner-tr",
|
|
|
|
"ui-selectmenu-button-closed": "ui-corner-" + ( direction ? "bottom" : "right" )
|
2014-08-23 03:39:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}[ position ]
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
_setOption: function( key, value ) {
|
|
|
|
if ( key === "direction" ) {
|
|
|
|
this._removeClass( "ui-controlgroup-" + this.options.direction );
|
|
|
|
}
|
|
|
|
|
|
|
|
this._super( key, value );
|
|
|
|
if ( key === "disabled" ) {
|
|
|
|
this._callChildMethod( value ? "disable" : "enable" );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.refresh();
|
|
|
|
},
|
|
|
|
|
|
|
|
refresh: function() {
|
|
|
|
var children,
|
|
|
|
that = this;
|
|
|
|
|
|
|
|
this._addClass( "ui-controlgroup ui-controlgroup-" + this.options.direction );
|
|
|
|
|
|
|
|
if ( this.options.direction === "horizontal" ) {
|
|
|
|
this._addClass( null, "ui-helper-clearfix" );
|
|
|
|
}
|
|
|
|
this._initWidgets();
|
|
|
|
|
|
|
|
children = this.childWidgets;
|
|
|
|
|
|
|
|
// We filter here because we need to track all childWidgets not just the visible ones
|
2015-09-30 13:38:42 +00:00
|
|
|
if ( this.options.onlyVisible ) {
|
2014-08-23 03:39:35 +00:00
|
|
|
children = children.filter( ":visible" );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( children.length ) {
|
|
|
|
|
|
|
|
// We do this last because we need to make sure all enhancment is done
|
|
|
|
// before determining first and last
|
2015-08-10 14:08:51 +00:00
|
|
|
$.each( [ "first", "last" ], function( index, value ) {
|
|
|
|
var instance = children[ value ]().data( "ui-controlgroup-data" );
|
2015-08-12 15:24:30 +00:00
|
|
|
|
2015-09-11 14:49:19 +00:00
|
|
|
if ( instance && that[ "_" + instance.widgetName + "Options" ] ) {
|
2015-08-10 14:08:51 +00:00
|
|
|
instance.element[ instance.widgetName ](
|
2015-09-16 05:49:08 +00:00
|
|
|
that[ "_" + instance.widgetName + "Options" ]( value )
|
2014-08-23 03:39:35 +00:00
|
|
|
);
|
2015-08-14 13:49:48 +00:00
|
|
|
} else {
|
|
|
|
that._updateCornerClass( children[ value ](), value );
|
2014-08-23 03:39:35 +00:00
|
|
|
}
|
|
|
|
} );
|
|
|
|
|
|
|
|
// Finally call the refresh method on each of the child widgets.
|
|
|
|
this._callChildMethod( "refresh" );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} );
|
|
|
|
} ) );
|