activeadmin-rb 1.4.0 → 1.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -1
- data/.travis.yml +17 -12
- data/CHANGELOG.md +10 -1
- data/Gemfile +3 -11
- data/activeadmin-rb.gemspec +3 -2
- data/app/views/active_admin/devise/confirmations/new.html.erb +1 -1
- data/app/views/active_admin/devise/passwords/edit.html.erb +1 -1
- data/app/views/active_admin/devise/passwords/new.html.erb +1 -1
- data/app/views/active_admin/devise/registrations/new.html.erb +1 -1
- data/app/views/active_admin/devise/shared/_error_messages.html.erb +15 -0
- data/app/views/active_admin/devise/unlocks/new.html.erb +1 -1
- data/docs/documentation.md +1 -1
- data/features/index/filters.feature +3 -3
- data/features/index/pagination.feature +3 -3
- data/features/registering_assets.feature +4 -8
- data/features/support/env.rb +4 -0
- data/gemfiles/rails_42.gemfile +2 -1
- data/gemfiles/rails_50.gemfile +2 -1
- data/gemfiles/rails_51.gemfile +2 -1
- data/gemfiles/rails_52.gemfile +2 -1
- data/gemfiles/rails_60.gemfile +13 -0
- data/lib/active_admin.rb +1 -0
- data/lib/active_admin/application.rb +4 -3
- data/lib/active_admin/asset_registration.rb +0 -8
- data/lib/active_admin/version.rb +1 -1
- data/lib/bug_report_templates/active_admin_master.rb +3 -4
- data/spec/bug_report_templates_spec.rb +6 -4
- data/spec/support/active_admin_integration_spec_helper.rb +15 -7
- data/spec/support/rails_template.rb +8 -6
- data/spec/unit/asset_registration_spec.rb +0 -29
- data/spec/unit/auto_link_spec.rb +26 -16
- data/spec/unit/comments_spec.rb +22 -7
- data/spec/unit/filters/filter_form_builder_spec.rb +10 -10
- data/spec/unit/form_builder_spec.rb +1 -1
- data/spec/unit/pretty_format_spec.rb +73 -22
- data/spec/unit/resource_controller/data_access_spec.rb +3 -3
- data/spec/unit/routing_spec.rb +1 -1
- data/spec/unit/view_helpers/flash_helper_spec.rb +1 -1
- data/spec/unit/view_helpers/form_helper_spec.rb +2 -2
- data/spec/unit/views/components/attributes_table_spec.rb +1 -1
- metadata +20 -36
- data/vendor/assets/javascripts/jquery-ui/data.js +0 -41
- data/vendor/assets/javascripts/jquery-ui/disable-selection.js +0 -48
- data/vendor/assets/javascripts/jquery-ui/escape-selector.js +0 -23
- data/vendor/assets/javascripts/jquery-ui/focusable.js +0 -86
- data/vendor/assets/javascripts/jquery-ui/ie.js +0 -17
- data/vendor/assets/javascripts/jquery-ui/keycode.js +0 -47
- data/vendor/assets/javascripts/jquery-ui/plugin.js +0 -46
- data/vendor/assets/javascripts/jquery-ui/position.js +0 -500
- data/vendor/assets/javascripts/jquery-ui/safe-active-element.js +0 -42
- data/vendor/assets/javascripts/jquery-ui/safe-blur.js +0 -23
- data/vendor/assets/javascripts/jquery-ui/scroll-parent.js +0 -47
- data/vendor/assets/javascripts/jquery-ui/tabbable.js +0 -38
- data/vendor/assets/javascripts/jquery-ui/unique-id.js +0 -51
- data/vendor/assets/javascripts/jquery-ui/version.js +0 -17
- data/vendor/assets/javascripts/jquery-ui/widget.js +0 -735
- data/vendor/assets/javascripts/jquery-ui/widgets/button.js +0 -391
- data/vendor/assets/javascripts/jquery-ui/widgets/checkboxradio.js +0 -300
- data/vendor/assets/javascripts/jquery-ui/widgets/controlgroup.js +0 -300
- data/vendor/assets/javascripts/jquery-ui/widgets/datepicker.js +0 -2123
- data/vendor/assets/javascripts/jquery-ui/widgets/dialog.js +0 -954
- data/vendor/assets/javascripts/jquery-ui/widgets/draggable.js +0 -1259
- data/vendor/assets/javascripts/jquery-ui/widgets/mouse.js +0 -230
- data/vendor/assets/javascripts/jquery-ui/widgets/resizable.js +0 -1207
- data/vendor/assets/javascripts/jquery-ui/widgets/sortable.js +0 -1561
- data/vendor/assets/javascripts/jquery-ui/widgets/tabs.js +0 -931
@@ -1,391 +0,0 @@
|
|
1
|
-
//= require jquery-ui/widgets/controlgroup
|
2
|
-
//= require jquery-ui/widgets/checkboxradio
|
3
|
-
//= require jquery-ui/keycode
|
4
|
-
//= require jquery-ui/widget
|
5
|
-
|
6
|
-
/*!
|
7
|
-
* jQuery UI Button 1.12.1
|
8
|
-
* http://jqueryui.com
|
9
|
-
*
|
10
|
-
* Copyright jQuery Foundation and other contributors
|
11
|
-
* Released under the MIT license.
|
12
|
-
* http://jquery.org/license
|
13
|
-
*/
|
14
|
-
|
15
|
-
//>>label: Button
|
16
|
-
//>>group: Widgets
|
17
|
-
//>>description: Enhances a form with themeable buttons.
|
18
|
-
//>>docs: http://api.jqueryui.com/button/
|
19
|
-
//>>demos: http://jqueryui.com/button/
|
20
|
-
//>>css.structure: ../../themes/base/core.css
|
21
|
-
//>>css.structure: ../../themes/base/button.css
|
22
|
-
//>>css.theme: ../../themes/base/theme.css
|
23
|
-
|
24
|
-
( function( factory ) {
|
25
|
-
if ( typeof define === "function" && define.amd ) {
|
26
|
-
|
27
|
-
// AMD. Register as an anonymous module.
|
28
|
-
define( [
|
29
|
-
"jquery",
|
30
|
-
|
31
|
-
// These are only for backcompat
|
32
|
-
// TODO: Remove after 1.12
|
33
|
-
"./controlgroup",
|
34
|
-
"./checkboxradio",
|
35
|
-
|
36
|
-
"../keycode",
|
37
|
-
"../widget"
|
38
|
-
], factory );
|
39
|
-
} else {
|
40
|
-
|
41
|
-
// Browser globals
|
42
|
-
factory( jQuery );
|
43
|
-
}
|
44
|
-
}( function( $ ) {
|
45
|
-
|
46
|
-
$.widget( "ui.button", {
|
47
|
-
version: "1.12.1",
|
48
|
-
defaultElement: "<button>",
|
49
|
-
options: {
|
50
|
-
classes: {
|
51
|
-
"ui-button": "ui-corner-all"
|
52
|
-
},
|
53
|
-
disabled: null,
|
54
|
-
icon: null,
|
55
|
-
iconPosition: "beginning",
|
56
|
-
label: null,
|
57
|
-
showLabel: true
|
58
|
-
},
|
59
|
-
|
60
|
-
_getCreateOptions: function() {
|
61
|
-
var disabled,
|
62
|
-
|
63
|
-
// This is to support cases like in jQuery Mobile where the base widget does have
|
64
|
-
// an implementation of _getCreateOptions
|
65
|
-
options = this._super() || {};
|
66
|
-
|
67
|
-
this.isInput = this.element.is( "input" );
|
68
|
-
|
69
|
-
disabled = this.element[ 0 ].disabled;
|
70
|
-
if ( disabled != null ) {
|
71
|
-
options.disabled = disabled;
|
72
|
-
}
|
73
|
-
|
74
|
-
this.originalLabel = this.isInput ? this.element.val() : this.element.html();
|
75
|
-
if ( this.originalLabel ) {
|
76
|
-
options.label = this.originalLabel;
|
77
|
-
}
|
78
|
-
|
79
|
-
return options;
|
80
|
-
},
|
81
|
-
|
82
|
-
_create: function() {
|
83
|
-
if ( !this.option.showLabel & !this.options.icon ) {
|
84
|
-
this.options.showLabel = true;
|
85
|
-
}
|
86
|
-
|
87
|
-
// We have to check the option again here even though we did in _getCreateOptions,
|
88
|
-
// because null may have been passed on init which would override what was set in
|
89
|
-
// _getCreateOptions
|
90
|
-
if ( this.options.disabled == null ) {
|
91
|
-
this.options.disabled = this.element[ 0 ].disabled || false;
|
92
|
-
}
|
93
|
-
|
94
|
-
this.hasTitle = !!this.element.attr( "title" );
|
95
|
-
|
96
|
-
// Check to see if the label needs to be set or if its already correct
|
97
|
-
if ( this.options.label && this.options.label !== this.originalLabel ) {
|
98
|
-
if ( this.isInput ) {
|
99
|
-
this.element.val( this.options.label );
|
100
|
-
} else {
|
101
|
-
this.element.html( this.options.label );
|
102
|
-
}
|
103
|
-
}
|
104
|
-
this._addClass( "ui-button", "ui-widget" );
|
105
|
-
this._setOption( "disabled", this.options.disabled );
|
106
|
-
this._enhance();
|
107
|
-
|
108
|
-
if ( this.element.is( "a" ) ) {
|
109
|
-
this._on( {
|
110
|
-
"keyup": function( event ) {
|
111
|
-
if ( event.keyCode === $.ui.keyCode.SPACE ) {
|
112
|
-
event.preventDefault();
|
113
|
-
|
114
|
-
// Support: PhantomJS <= 1.9, IE 8 Only
|
115
|
-
// If a native click is available use it so we actually cause navigation
|
116
|
-
// otherwise just trigger a click event
|
117
|
-
if ( this.element[ 0 ].click ) {
|
118
|
-
this.element[ 0 ].click();
|
119
|
-
} else {
|
120
|
-
this.element.trigger( "click" );
|
121
|
-
}
|
122
|
-
}
|
123
|
-
}
|
124
|
-
} );
|
125
|
-
}
|
126
|
-
},
|
127
|
-
|
128
|
-
_enhance: function() {
|
129
|
-
if ( !this.element.is( "button" ) ) {
|
130
|
-
this.element.attr( "role", "button" );
|
131
|
-
}
|
132
|
-
|
133
|
-
if ( this.options.icon ) {
|
134
|
-
this._updateIcon( "icon", this.options.icon );
|
135
|
-
this._updateTooltip();
|
136
|
-
}
|
137
|
-
},
|
138
|
-
|
139
|
-
_updateTooltip: function() {
|
140
|
-
this.title = this.element.attr( "title" );
|
141
|
-
|
142
|
-
if ( !this.options.showLabel && !this.title ) {
|
143
|
-
this.element.attr( "title", this.options.label );
|
144
|
-
}
|
145
|
-
},
|
146
|
-
|
147
|
-
_updateIcon: function( option, value ) {
|
148
|
-
var icon = option !== "iconPosition",
|
149
|
-
position = icon ? this.options.iconPosition : value,
|
150
|
-
displayBlock = position === "top" || position === "bottom";
|
151
|
-
|
152
|
-
// Create icon
|
153
|
-
if ( !this.icon ) {
|
154
|
-
this.icon = $( "<span>" );
|
155
|
-
|
156
|
-
this._addClass( this.icon, "ui-button-icon", "ui-icon" );
|
157
|
-
|
158
|
-
if ( !this.options.showLabel ) {
|
159
|
-
this._addClass( "ui-button-icon-only" );
|
160
|
-
}
|
161
|
-
} else if ( icon ) {
|
162
|
-
|
163
|
-
// If we are updating the icon remove the old icon class
|
164
|
-
this._removeClass( this.icon, null, this.options.icon );
|
165
|
-
}
|
166
|
-
|
167
|
-
// If we are updating the icon add the new icon class
|
168
|
-
if ( icon ) {
|
169
|
-
this._addClass( this.icon, null, value );
|
170
|
-
}
|
171
|
-
|
172
|
-
this._attachIcon( position );
|
173
|
-
|
174
|
-
// If the icon is on top or bottom we need to add the ui-widget-icon-block class and remove
|
175
|
-
// the iconSpace if there is one.
|
176
|
-
if ( displayBlock ) {
|
177
|
-
this._addClass( this.icon, null, "ui-widget-icon-block" );
|
178
|
-
if ( this.iconSpace ) {
|
179
|
-
this.iconSpace.remove();
|
180
|
-
}
|
181
|
-
} else {
|
182
|
-
|
183
|
-
// Position is beginning or end so remove the ui-widget-icon-block class and add the
|
184
|
-
// space if it does not exist
|
185
|
-
if ( !this.iconSpace ) {
|
186
|
-
this.iconSpace = $( "<span> </span>" );
|
187
|
-
this._addClass( this.iconSpace, "ui-button-icon-space" );
|
188
|
-
}
|
189
|
-
this._removeClass( this.icon, null, "ui-wiget-icon-block" );
|
190
|
-
this._attachIconSpace( position );
|
191
|
-
}
|
192
|
-
},
|
193
|
-
|
194
|
-
_destroy: function() {
|
195
|
-
this.element.removeAttr( "role" );
|
196
|
-
|
197
|
-
if ( this.icon ) {
|
198
|
-
this.icon.remove();
|
199
|
-
}
|
200
|
-
if ( this.iconSpace ) {
|
201
|
-
this.iconSpace.remove();
|
202
|
-
}
|
203
|
-
if ( !this.hasTitle ) {
|
204
|
-
this.element.removeAttr( "title" );
|
205
|
-
}
|
206
|
-
},
|
207
|
-
|
208
|
-
_attachIconSpace: function( iconPosition ) {
|
209
|
-
this.icon[ /^(?:end|bottom)/.test( iconPosition ) ? "before" : "after" ]( this.iconSpace );
|
210
|
-
},
|
211
|
-
|
212
|
-
_attachIcon: function( iconPosition ) {
|
213
|
-
this.element[ /^(?:end|bottom)/.test( iconPosition ) ? "append" : "prepend" ]( this.icon );
|
214
|
-
},
|
215
|
-
|
216
|
-
_setOptions: function( options ) {
|
217
|
-
var newShowLabel = options.showLabel === undefined ?
|
218
|
-
this.options.showLabel :
|
219
|
-
options.showLabel,
|
220
|
-
newIcon = options.icon === undefined ? this.options.icon : options.icon;
|
221
|
-
|
222
|
-
if ( !newShowLabel && !newIcon ) {
|
223
|
-
options.showLabel = true;
|
224
|
-
}
|
225
|
-
this._super( options );
|
226
|
-
},
|
227
|
-
|
228
|
-
_setOption: function( key, value ) {
|
229
|
-
if ( key === "icon" ) {
|
230
|
-
if ( value ) {
|
231
|
-
this._updateIcon( key, value );
|
232
|
-
} else if ( this.icon ) {
|
233
|
-
this.icon.remove();
|
234
|
-
if ( this.iconSpace ) {
|
235
|
-
this.iconSpace.remove();
|
236
|
-
}
|
237
|
-
}
|
238
|
-
}
|
239
|
-
|
240
|
-
if ( key === "iconPosition" ) {
|
241
|
-
this._updateIcon( key, value );
|
242
|
-
}
|
243
|
-
|
244
|
-
// Make sure we can't end up with a button that has neither text nor icon
|
245
|
-
if ( key === "showLabel" ) {
|
246
|
-
this._toggleClass( "ui-button-icon-only", null, !value );
|
247
|
-
this._updateTooltip();
|
248
|
-
}
|
249
|
-
|
250
|
-
if ( key === "label" ) {
|
251
|
-
if ( this.isInput ) {
|
252
|
-
this.element.val( value );
|
253
|
-
} else {
|
254
|
-
|
255
|
-
// If there is an icon, append it, else nothing then append the value
|
256
|
-
// this avoids removal of the icon when setting label text
|
257
|
-
this.element.html( value );
|
258
|
-
if ( this.icon ) {
|
259
|
-
this._attachIcon( this.options.iconPosition );
|
260
|
-
this._attachIconSpace( this.options.iconPosition );
|
261
|
-
}
|
262
|
-
}
|
263
|
-
}
|
264
|
-
|
265
|
-
this._super( key, value );
|
266
|
-
|
267
|
-
if ( key === "disabled" ) {
|
268
|
-
this._toggleClass( null, "ui-state-disabled", value );
|
269
|
-
this.element[ 0 ].disabled = value;
|
270
|
-
if ( value ) {
|
271
|
-
this.element.blur();
|
272
|
-
}
|
273
|
-
}
|
274
|
-
},
|
275
|
-
|
276
|
-
refresh: function() {
|
277
|
-
|
278
|
-
// Make sure to only check disabled if its an element that supports this otherwise
|
279
|
-
// check for the disabled class to determine state
|
280
|
-
var isDisabled = this.element.is( "input, button" ) ?
|
281
|
-
this.element[ 0 ].disabled : this.element.hasClass( "ui-button-disabled" );
|
282
|
-
|
283
|
-
if ( isDisabled !== this.options.disabled ) {
|
284
|
-
this._setOptions( { disabled: isDisabled } );
|
285
|
-
}
|
286
|
-
|
287
|
-
this._updateTooltip();
|
288
|
-
}
|
289
|
-
} );
|
290
|
-
|
291
|
-
// DEPRECATED
|
292
|
-
if ( $.uiBackCompat !== false ) {
|
293
|
-
|
294
|
-
// Text and Icons options
|
295
|
-
$.widget( "ui.button", $.ui.button, {
|
296
|
-
options: {
|
297
|
-
text: true,
|
298
|
-
icons: {
|
299
|
-
primary: null,
|
300
|
-
secondary: null
|
301
|
-
}
|
302
|
-
},
|
303
|
-
|
304
|
-
_create: function() {
|
305
|
-
if ( this.options.showLabel && !this.options.text ) {
|
306
|
-
this.options.showLabel = this.options.text;
|
307
|
-
}
|
308
|
-
if ( !this.options.showLabel && this.options.text ) {
|
309
|
-
this.options.text = this.options.showLabel;
|
310
|
-
}
|
311
|
-
if ( !this.options.icon && ( this.options.icons.primary ||
|
312
|
-
this.options.icons.secondary ) ) {
|
313
|
-
if ( this.options.icons.primary ) {
|
314
|
-
this.options.icon = this.options.icons.primary;
|
315
|
-
} else {
|
316
|
-
this.options.icon = this.options.icons.secondary;
|
317
|
-
this.options.iconPosition = "end";
|
318
|
-
}
|
319
|
-
} else if ( this.options.icon ) {
|
320
|
-
this.options.icons.primary = this.options.icon;
|
321
|
-
}
|
322
|
-
this._super();
|
323
|
-
},
|
324
|
-
|
325
|
-
_setOption: function( key, value ) {
|
326
|
-
if ( key === "text" ) {
|
327
|
-
this._super( "showLabel", value );
|
328
|
-
return;
|
329
|
-
}
|
330
|
-
if ( key === "showLabel" ) {
|
331
|
-
this.options.text = value;
|
332
|
-
}
|
333
|
-
if ( key === "icon" ) {
|
334
|
-
this.options.icons.primary = value;
|
335
|
-
}
|
336
|
-
if ( key === "icons" ) {
|
337
|
-
if ( value.primary ) {
|
338
|
-
this._super( "icon", value.primary );
|
339
|
-
this._super( "iconPosition", "beginning" );
|
340
|
-
} else if ( value.secondary ) {
|
341
|
-
this._super( "icon", value.secondary );
|
342
|
-
this._super( "iconPosition", "end" );
|
343
|
-
}
|
344
|
-
}
|
345
|
-
this._superApply( arguments );
|
346
|
-
}
|
347
|
-
} );
|
348
|
-
|
349
|
-
$.fn.button = ( function( orig ) {
|
350
|
-
return function() {
|
351
|
-
if ( !this.length || ( this.length && this[ 0 ].tagName !== "INPUT" ) ||
|
352
|
-
( this.length && this[ 0 ].tagName === "INPUT" && (
|
353
|
-
this.attr( "type" ) !== "checkbox" && this.attr( "type" ) !== "radio"
|
354
|
-
) ) ) {
|
355
|
-
return orig.apply( this, arguments );
|
356
|
-
}
|
357
|
-
if ( !$.ui.checkboxradio ) {
|
358
|
-
$.error( "Checkboxradio widget missing" );
|
359
|
-
}
|
360
|
-
if ( arguments.length === 0 ) {
|
361
|
-
return this.checkboxradio( {
|
362
|
-
"icon": false
|
363
|
-
} );
|
364
|
-
}
|
365
|
-
return this.checkboxradio.apply( this, arguments );
|
366
|
-
};
|
367
|
-
} )( $.fn.button );
|
368
|
-
|
369
|
-
$.fn.buttonset = function() {
|
370
|
-
if ( !$.ui.controlgroup ) {
|
371
|
-
$.error( "Controlgroup widget missing" );
|
372
|
-
}
|
373
|
-
if ( arguments[ 0 ] === "option" && arguments[ 1 ] === "items" && arguments[ 2 ] ) {
|
374
|
-
return this.controlgroup.apply( this,
|
375
|
-
[ arguments[ 0 ], "items.button", arguments[ 2 ] ] );
|
376
|
-
}
|
377
|
-
if ( arguments[ 0 ] === "option" && arguments[ 1 ] === "items" ) {
|
378
|
-
return this.controlgroup.apply( this, [ arguments[ 0 ], "items.button" ] );
|
379
|
-
}
|
380
|
-
if ( typeof arguments[ 0 ] === "object" && arguments[ 0 ].items ) {
|
381
|
-
arguments[ 0 ].items = {
|
382
|
-
button: arguments[ 0 ].items
|
383
|
-
};
|
384
|
-
}
|
385
|
-
return this.controlgroup.apply( this, arguments );
|
386
|
-
};
|
387
|
-
}
|
388
|
-
|
389
|
-
return $.ui.button;
|
390
|
-
|
391
|
-
} ) );
|
@@ -1,300 +0,0 @@
|
|
1
|
-
//= require jquery-ui/widget
|
2
|
-
|
3
|
-
/*!
|
4
|
-
* jQuery UI Controlgroup 1.12.1
|
5
|
-
* http://jqueryui.com
|
6
|
-
*
|
7
|
-
* Copyright jQuery Foundation and other contributors
|
8
|
-
* Released under the MIT license.
|
9
|
-
* http://jquery.org/license
|
10
|
-
*/
|
11
|
-
|
12
|
-
//>>label: Controlgroup
|
13
|
-
//>>group: Widgets
|
14
|
-
//>>description: Visually groups form control widgets
|
15
|
-
//>>docs: http://api.jqueryui.com/controlgroup/
|
16
|
-
//>>demos: http://jqueryui.com/controlgroup/
|
17
|
-
//>>css.structure: ../../themes/base/core.css
|
18
|
-
//>>css.structure: ../../themes/base/controlgroup.css
|
19
|
-
//>>css.theme: ../../themes/base/theme.css
|
20
|
-
|
21
|
-
( function( factory ) {
|
22
|
-
if ( typeof define === "function" && define.amd ) {
|
23
|
-
|
24
|
-
// AMD. Register as an anonymous module.
|
25
|
-
define( [
|
26
|
-
"jquery",
|
27
|
-
"../widget"
|
28
|
-
], factory );
|
29
|
-
} else {
|
30
|
-
|
31
|
-
// Browser globals
|
32
|
-
factory( jQuery );
|
33
|
-
}
|
34
|
-
}( function( $ ) {
|
35
|
-
var controlgroupCornerRegex = /ui-corner-([a-z]){2,6}/g;
|
36
|
-
|
37
|
-
return $.widget( "ui.controlgroup", {
|
38
|
-
version: "1.12.1",
|
39
|
-
defaultElement: "<div>",
|
40
|
-
options: {
|
41
|
-
direction: "horizontal",
|
42
|
-
disabled: null,
|
43
|
-
onlyVisible: true,
|
44
|
-
items: {
|
45
|
-
"button": "input[type=button], input[type=submit], input[type=reset], button, a",
|
46
|
-
"controlgroupLabel": ".ui-controlgroup-label",
|
47
|
-
"checkboxradio": "input[type='checkbox'], input[type='radio']",
|
48
|
-
"selectmenu": "select",
|
49
|
-
"spinner": ".ui-spinner-input"
|
50
|
-
}
|
51
|
-
},
|
52
|
-
|
53
|
-
_create: function() {
|
54
|
-
this._enhance();
|
55
|
-
},
|
56
|
-
|
57
|
-
// To support the enhanced option in jQuery Mobile, we isolate DOM manipulation
|
58
|
-
_enhance: function() {
|
59
|
-
this.element.attr( "role", "toolbar" );
|
60
|
-
this.refresh();
|
61
|
-
},
|
62
|
-
|
63
|
-
_destroy: function() {
|
64
|
-
this._callChildMethod( "destroy" );
|
65
|
-
this.childWidgets.removeData( "ui-controlgroup-data" );
|
66
|
-
this.element.removeAttr( "role" );
|
67
|
-
if ( this.options.items.controlgroupLabel ) {
|
68
|
-
this.element
|
69
|
-
.find( this.options.items.controlgroupLabel )
|
70
|
-
.find( ".ui-controlgroup-label-contents" )
|
71
|
-
.contents().unwrap();
|
72
|
-
}
|
73
|
-
},
|
74
|
-
|
75
|
-
_initWidgets: function() {
|
76
|
-
var that = this,
|
77
|
-
childWidgets = [];
|
78
|
-
|
79
|
-
// First we iterate over each of the items options
|
80
|
-
$.each( this.options.items, function( widget, selector ) {
|
81
|
-
var labels;
|
82
|
-
var options = {};
|
83
|
-
|
84
|
-
// Make sure the widget has a selector set
|
85
|
-
if ( !selector ) {
|
86
|
-
return;
|
87
|
-
}
|
88
|
-
|
89
|
-
if ( widget === "controlgroupLabel" ) {
|
90
|
-
labels = that.element.find( selector );
|
91
|
-
labels.each( function() {
|
92
|
-
var element = $( this );
|
93
|
-
|
94
|
-
if ( element.children( ".ui-controlgroup-label-contents" ).length ) {
|
95
|
-
return;
|
96
|
-
}
|
97
|
-
element.contents()
|
98
|
-
.wrapAll( "<span class='ui-controlgroup-label-contents'></span>" );
|
99
|
-
} );
|
100
|
-
that._addClass( labels, null, "ui-widget ui-widget-content ui-state-default" );
|
101
|
-
childWidgets = childWidgets.concat( labels.get() );
|
102
|
-
return;
|
103
|
-
}
|
104
|
-
|
105
|
-
// Make sure the widget actually exists
|
106
|
-
if ( !$.fn[ widget ] ) {
|
107
|
-
return;
|
108
|
-
}
|
109
|
-
|
110
|
-
// We assume everything is in the middle to start because we can't determine
|
111
|
-
// first / last elements until all enhancments are done.
|
112
|
-
if ( that[ "_" + widget + "Options" ] ) {
|
113
|
-
options = that[ "_" + widget + "Options" ]( "middle" );
|
114
|
-
} else {
|
115
|
-
options = { classes: {} };
|
116
|
-
}
|
117
|
-
|
118
|
-
// Find instances of this widget inside controlgroup and init them
|
119
|
-
that.element
|
120
|
-
.find( selector )
|
121
|
-
.each( function() {
|
122
|
-
var element = $( this );
|
123
|
-
var instance = element[ widget ]( "instance" );
|
124
|
-
|
125
|
-
// We need to clone the default options for this type of widget to avoid
|
126
|
-
// polluting the variable options which has a wider scope than a single widget.
|
127
|
-
var instanceOptions = $.widget.extend( {}, options );
|
128
|
-
|
129
|
-
// If the button is the child of a spinner ignore it
|
130
|
-
// TODO: Find a more generic solution
|
131
|
-
if ( widget === "button" && element.parent( ".ui-spinner" ).length ) {
|
132
|
-
return;
|
133
|
-
}
|
134
|
-
|
135
|
-
// Create the widget if it doesn't exist
|
136
|
-
if ( !instance ) {
|
137
|
-
instance = element[ widget ]()[ widget ]( "instance" );
|
138
|
-
}
|
139
|
-
if ( instance ) {
|
140
|
-
instanceOptions.classes =
|
141
|
-
that._resolveClassesValues( instanceOptions.classes, instance );
|
142
|
-
}
|
143
|
-
element[ widget ]( instanceOptions );
|
144
|
-
|
145
|
-
// Store an instance of the controlgroup to be able to reference
|
146
|
-
// from the outermost element for changing options and refresh
|
147
|
-
var widgetElement = element[ widget ]( "widget" );
|
148
|
-
$.data( widgetElement[ 0 ], "ui-controlgroup-data",
|
149
|
-
instance ? instance : element[ widget ]( "instance" ) );
|
150
|
-
|
151
|
-
childWidgets.push( widgetElement[ 0 ] );
|
152
|
-
} );
|
153
|
-
} );
|
154
|
-
|
155
|
-
this.childWidgets = $( $.unique( childWidgets ) );
|
156
|
-
this._addClass( this.childWidgets, "ui-controlgroup-item" );
|
157
|
-
},
|
158
|
-
|
159
|
-
_callChildMethod: function( method ) {
|
160
|
-
this.childWidgets.each( function() {
|
161
|
-
var element = $( this ),
|
162
|
-
data = element.data( "ui-controlgroup-data" );
|
163
|
-
if ( data && data[ method ] ) {
|
164
|
-
data[ method ]();
|
165
|
-
}
|
166
|
-
} );
|
167
|
-
},
|
168
|
-
|
169
|
-
_updateCornerClass: function( element, position ) {
|
170
|
-
var remove = "ui-corner-top ui-corner-bottom ui-corner-left ui-corner-right ui-corner-all";
|
171
|
-
var add = this._buildSimpleOptions( position, "label" ).classes.label;
|
172
|
-
|
173
|
-
this._removeClass( element, null, remove );
|
174
|
-
this._addClass( element, null, add );
|
175
|
-
},
|
176
|
-
|
177
|
-
_buildSimpleOptions: function( position, key ) {
|
178
|
-
var direction = this.options.direction === "vertical";
|
179
|
-
var result = {
|
180
|
-
classes: {}
|
181
|
-
};
|
182
|
-
result.classes[ key ] = {
|
183
|
-
"middle": "",
|
184
|
-
"first": "ui-corner-" + ( direction ? "top" : "left" ),
|
185
|
-
"last": "ui-corner-" + ( direction ? "bottom" : "right" ),
|
186
|
-
"only": "ui-corner-all"
|
187
|
-
}[ position ];
|
188
|
-
|
189
|
-
return result;
|
190
|
-
},
|
191
|
-
|
192
|
-
_spinnerOptions: function( position ) {
|
193
|
-
var options = this._buildSimpleOptions( position, "ui-spinner" );
|
194
|
-
|
195
|
-
options.classes[ "ui-spinner-up" ] = "";
|
196
|
-
options.classes[ "ui-spinner-down" ] = "";
|
197
|
-
|
198
|
-
return options;
|
199
|
-
},
|
200
|
-
|
201
|
-
_buttonOptions: function( position ) {
|
202
|
-
return this._buildSimpleOptions( position, "ui-button" );
|
203
|
-
},
|
204
|
-
|
205
|
-
_checkboxradioOptions: function( position ) {
|
206
|
-
return this._buildSimpleOptions( position, "ui-checkboxradio-label" );
|
207
|
-
},
|
208
|
-
|
209
|
-
_selectmenuOptions: function( position ) {
|
210
|
-
var direction = this.options.direction === "vertical";
|
211
|
-
return {
|
212
|
-
width: direction ? "auto" : false,
|
213
|
-
classes: {
|
214
|
-
middle: {
|
215
|
-
"ui-selectmenu-button-open": "",
|
216
|
-
"ui-selectmenu-button-closed": ""
|
217
|
-
},
|
218
|
-
first: {
|
219
|
-
"ui-selectmenu-button-open": "ui-corner-" + ( direction ? "top" : "tl" ),
|
220
|
-
"ui-selectmenu-button-closed": "ui-corner-" + ( direction ? "top" : "left" )
|
221
|
-
},
|
222
|
-
last: {
|
223
|
-
"ui-selectmenu-button-open": direction ? "" : "ui-corner-tr",
|
224
|
-
"ui-selectmenu-button-closed": "ui-corner-" + ( direction ? "bottom" : "right" )
|
225
|
-
},
|
226
|
-
only: {
|
227
|
-
"ui-selectmenu-button-open": "ui-corner-top",
|
228
|
-
"ui-selectmenu-button-closed": "ui-corner-all"
|
229
|
-
}
|
230
|
-
|
231
|
-
}[ position ]
|
232
|
-
};
|
233
|
-
},
|
234
|
-
|
235
|
-
_resolveClassesValues: function( classes, instance ) {
|
236
|
-
var result = {};
|
237
|
-
$.each( classes, function( key ) {
|
238
|
-
var current = instance.options.classes[ key ] || "";
|
239
|
-
current = $.trim( current.replace( controlgroupCornerRegex, "" ) );
|
240
|
-
result[ key ] = ( current + " " + classes[ key ] ).replace( /\s+/g, " " );
|
241
|
-
} );
|
242
|
-
return result;
|
243
|
-
},
|
244
|
-
|
245
|
-
_setOption: function( key, value ) {
|
246
|
-
if ( key === "direction" ) {
|
247
|
-
this._removeClass( "ui-controlgroup-" + this.options.direction );
|
248
|
-
}
|
249
|
-
|
250
|
-
this._super( key, value );
|
251
|
-
if ( key === "disabled" ) {
|
252
|
-
this._callChildMethod( value ? "disable" : "enable" );
|
253
|
-
return;
|
254
|
-
}
|
255
|
-
|
256
|
-
this.refresh();
|
257
|
-
},
|
258
|
-
|
259
|
-
refresh: function() {
|
260
|
-
var children,
|
261
|
-
that = this;
|
262
|
-
|
263
|
-
this._addClass( "ui-controlgroup ui-controlgroup-" + this.options.direction );
|
264
|
-
|
265
|
-
if ( this.options.direction === "horizontal" ) {
|
266
|
-
this._addClass( null, "ui-helper-clearfix" );
|
267
|
-
}
|
268
|
-
this._initWidgets();
|
269
|
-
|
270
|
-
children = this.childWidgets;
|
271
|
-
|
272
|
-
// We filter here because we need to track all childWidgets not just the visible ones
|
273
|
-
if ( this.options.onlyVisible ) {
|
274
|
-
children = children.filter( ":visible" );
|
275
|
-
}
|
276
|
-
|
277
|
-
if ( children.length ) {
|
278
|
-
|
279
|
-
// We do this last because we need to make sure all enhancment is done
|
280
|
-
// before determining first and last
|
281
|
-
$.each( [ "first", "last" ], function( index, value ) {
|
282
|
-
var instance = children[ value ]().data( "ui-controlgroup-data" );
|
283
|
-
|
284
|
-
if ( instance && that[ "_" + instance.widgetName + "Options" ] ) {
|
285
|
-
var options = that[ "_" + instance.widgetName + "Options" ](
|
286
|
-
children.length === 1 ? "only" : value
|
287
|
-
);
|
288
|
-
options.classes = that._resolveClassesValues( options.classes, instance );
|
289
|
-
instance.element[ instance.widgetName ]( options );
|
290
|
-
} else {
|
291
|
-
that._updateCornerClass( children[ value ](), value );
|
292
|
-
}
|
293
|
-
} );
|
294
|
-
|
295
|
-
// Finally call the refresh method on each of the child widgets.
|
296
|
-
this._callChildMethod( "refresh" );
|
297
|
-
}
|
298
|
-
}
|
299
|
-
} );
|
300
|
-
} ) );
|