2014-08-28 19:16:51 +00:00
|
|
|
define( [
|
2016-04-03 14:53:34 +00:00
|
|
|
"qunit",
|
2014-08-28 19:16:51 +00:00
|
|
|
"jquery",
|
2020-05-16 07:16:24 +00:00
|
|
|
"lib/helper",
|
2015-01-08 02:51:38 +00:00
|
|
|
"ui/widgets/checkboxradio"
|
2020-05-16 07:16:24 +00:00
|
|
|
], function( QUnit, $, helper ) {
|
2021-06-06 22:58:12 +00:00
|
|
|
"use strict";
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2020-05-16 07:16:24 +00:00
|
|
|
QUnit.module( "Checkboxradio: options", { afterEach: helper.moduleAfterEach } );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
function assertDisabled( checkbox, assert ) {
|
|
|
|
assert.hasClasses( checkbox.checkboxradio( "widget" ), "ui-state-disabled",
|
|
|
|
"label gets ui-state-disabled" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.is( ":disabled" ), true, "checkbox is disabled" );
|
2014-08-28 19:16:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function assertEnabled( checkbox, assert ) {
|
|
|
|
assert.lacksClasses( checkbox.checkboxradio( "widget" ), "ui-state-disabled",
|
|
|
|
"label has ui-state-disabled removed when disabled set to false" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.is( ":disabled" ), false,
|
2014-08-28 19:16:51 +00:00
|
|
|
"checkbox has disabled prop removed when disabled set to false" );
|
|
|
|
}
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "disabled", function( assert ) {
|
|
|
|
assert.expect( 6 );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
|
|
|
var checkbox = $( "#checkbox-option-disabled" );
|
2015-09-11 14:48:20 +00:00
|
|
|
checkbox.checkboxradio( {
|
2014-08-28 19:16:51 +00:00
|
|
|
disabled: true
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
assertDisabled( checkbox, assert );
|
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "disabled", false );
|
|
|
|
assertEnabled( checkbox, assert );
|
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "disabled", true );
|
|
|
|
assertDisabled( checkbox, assert );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "disabled - prop true on init", function( assert ) {
|
|
|
|
assert.expect( 2 );
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-disabled" );
|
|
|
|
|
|
|
|
checkbox.prop( "disabled", true );
|
|
|
|
checkbox.checkboxradio();
|
|
|
|
|
|
|
|
assertDisabled( checkbox, assert );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "disabled - explicit null value, checks the DOM", function( assert ) {
|
|
|
|
assert.expect( 2 );
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-disabled" );
|
|
|
|
|
|
|
|
checkbox.prop( "disabled", true );
|
2015-09-11 14:48:20 +00:00
|
|
|
checkbox.checkboxradio( {
|
2014-08-28 19:16:51 +00:00
|
|
|
disabled: null
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
assertDisabled( checkbox, assert );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
function assertNoIcon( assert, checkbox ) {
|
|
|
|
assert.strictEqual( checkbox.checkboxradio( "widget" ).find( "span.ui-icon" ).length, 0,
|
2014-08-28 19:16:51 +00:00
|
|
|
"Label does not contain an icon" );
|
|
|
|
}
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2014-08-28 19:16:51 +00:00
|
|
|
function assertIcon( checkbox, icon, assert ) {
|
|
|
|
var iconElement = checkbox.checkboxradio( "widget" ).find( ".ui-icon" );
|
|
|
|
|
|
|
|
icon = icon || "blank";
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( iconElement.length, 1,
|
2014-08-28 19:16:51 +00:00
|
|
|
"Label contains icon" );
|
|
|
|
assert.hasClasses( iconElement, "ui-checkboxradio-icon ui-corner-all ui-icon " +
|
|
|
|
"ui-icon-background ui-icon-" + icon,
|
|
|
|
"Icon has proper classes" );
|
2015-10-06 15:01:23 +00:00
|
|
|
if ( icon === "blank" ) {
|
2016-06-01 15:31:41 +00:00
|
|
|
assert.lacksClasses( iconElement, "ui-icon-check ui-state-checked" );
|
2015-10-06 15:01:23 +00:00
|
|
|
}
|
2014-08-28 19:16:51 +00:00
|
|
|
}
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "icon - false on init", function( assert ) {
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-icon" );
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 1 );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2015-09-11 14:48:20 +00:00
|
|
|
checkbox.checkboxradio( { icon: false } );
|
2016-04-03 14:53:34 +00:00
|
|
|
assertNoIcon( assert, checkbox );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "icon - default unchecked", function( assert ) {
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-icon" );
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 3 );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio();
|
|
|
|
assertIcon( checkbox, false, assert );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "icon - default checked", function( assert ) {
|
2015-10-06 15:01:23 +00:00
|
|
|
var checkbox = $( "#checkbox-option-icon" ).attr( "checked", true );
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 2 );
|
2015-10-06 15:01:23 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio();
|
2016-06-01 15:31:41 +00:00
|
|
|
assertIcon( checkbox, "check ui-state-checked", assert );
|
2015-10-06 15:01:23 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "icon", function( assert ) {
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-icon" );
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 9 );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.prop( "checked", true );
|
|
|
|
|
|
|
|
checkbox.checkboxradio();
|
2016-06-01 15:31:41 +00:00
|
|
|
assertIcon( checkbox, "check ui-state-checked", assert );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "icon", false );
|
2016-04-03 14:53:34 +00:00
|
|
|
assertNoIcon( assert, checkbox );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "icon", true );
|
2016-06-01 15:31:41 +00:00
|
|
|
assertIcon( checkbox, "check ui-state-checked", assert );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "icon", false );
|
2016-04-03 14:53:34 +00:00
|
|
|
assertNoIcon( assert, checkbox );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "icon", true );
|
2015-10-06 15:01:23 +00:00
|
|
|
checkbox.prop( "checked", false ).checkboxradio( "refresh" );
|
2014-08-28 19:16:51 +00:00
|
|
|
assertIcon( checkbox, false, assert );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "label - default", function( assert ) {
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-label" ),
|
|
|
|
widget;
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 2 );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio();
|
|
|
|
widget = checkbox.checkboxradio( "widget" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.checkboxradio( "option", "label" ),
|
2014-08-28 19:16:51 +00:00
|
|
|
"checkbox label", "When no value passed on create text from dom is used for option" );
|
2019-12-08 21:23:08 +00:00
|
|
|
assert.strictEqual( String.prototype.trim.call( widget.text() ),
|
2015-10-06 13:49:58 +00:00
|
|
|
"checkbox label", "When no value passed on create text from dom is used in dom" );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "label - explicit value", function( assert ) {
|
|
|
|
assert.expect( 5 );
|
2015-09-11 14:48:20 +00:00
|
|
|
var checkbox = $( "#checkbox-option-label" ).checkboxradio( {
|
2014-08-28 19:16:51 +00:00
|
|
|
label: "foo"
|
2015-09-11 14:48:20 +00:00
|
|
|
} ),
|
2014-08-28 19:16:51 +00:00
|
|
|
widget = checkbox.checkboxradio( "widget" ),
|
|
|
|
icon = widget.find( ".ui-icon" ),
|
|
|
|
iconSpace = widget.find( ".ui-checkboxradio-icon-space" );
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.checkboxradio( "option", "label" ),
|
2014-08-28 19:16:51 +00:00
|
|
|
"foo", "When value is passed on create value is used for option" );
|
2019-12-08 21:23:08 +00:00
|
|
|
assert.strictEqual( String.prototype.trim.call( widget.text() ),
|
2015-10-06 13:49:58 +00:00
|
|
|
"foo", "When value is passed on create value is used in dom" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( icon.length, 1,
|
2014-08-28 19:16:51 +00:00
|
|
|
"Icon is preserved when label is set on init when wrapped in label" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( iconSpace.length, 1,
|
2014-08-28 19:16:51 +00:00
|
|
|
"Icon space is preserved when label is set on init when wrapped in label" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( $( "#checkbox-option-label" ).length, 1,
|
2014-08-28 19:16:51 +00:00
|
|
|
"Element is preserved when label is set on init when wrapped in label" );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "label - explicit null value", function( assert ) {
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-label" ),
|
|
|
|
widget;
|
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.expect( 2 );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2015-10-27 20:05:52 +00:00
|
|
|
// The default null is a special value which means to check the DOM.
|
|
|
|
// We need to make sure that the option never return null.
|
|
|
|
// It should always be true or false after initialization.
|
2015-09-11 14:48:20 +00:00
|
|
|
checkbox.checkboxradio( {
|
2014-08-28 19:16:51 +00:00
|
|
|
label: null
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
widget = checkbox.checkboxradio( "widget" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.checkboxradio( "option", "label" ),
|
2014-08-28 19:16:51 +00:00
|
|
|
"checkbox label", "When null is passed on create text from dom is used for option" );
|
2019-12-08 21:23:08 +00:00
|
|
|
assert.strictEqual( String.prototype.trim.call( widget.text() ),
|
2015-10-06 13:49:58 +00:00
|
|
|
"checkbox label", "When null is passed on create text from dom is used in dom" );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
2016-04-03 14:53:34 +00:00
|
|
|
QUnit.test( "label", function( assert ) {
|
|
|
|
assert.expect( 4 );
|
2015-10-27 20:05:52 +00:00
|
|
|
|
2014-08-28 19:16:51 +00:00
|
|
|
var checkbox = $( "#checkbox-option-label" ),
|
|
|
|
widget;
|
|
|
|
|
|
|
|
checkbox.checkboxradio();
|
|
|
|
widget = checkbox.checkboxradio( "widget" );
|
|
|
|
checkbox.checkboxradio( "option", "label", "bar" );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.checkboxradio( "option", "label" ),
|
2014-08-28 19:16:51 +00:00
|
|
|
"bar", "When value is passed value is used for option" );
|
2019-12-08 21:23:08 +00:00
|
|
|
assert.strictEqual( String.prototype.trim.call( widget.text() ),
|
2015-10-06 13:49:58 +00:00
|
|
|
"bar", "When value is passed value is used in dom" );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
checkbox.checkboxradio( "option", "label", null );
|
2016-04-03 14:53:34 +00:00
|
|
|
assert.strictEqual( checkbox.checkboxradio( "option", "label" ),
|
2014-08-28 19:16:51 +00:00
|
|
|
"bar", "When null is passed text from dom is used for option" );
|
2019-12-08 21:23:08 +00:00
|
|
|
assert.strictEqual( String.prototype.trim.call( widget.text() ),
|
2015-10-06 13:49:58 +00:00
|
|
|
"bar", "When null is passed text from dom is used in dom" );
|
2015-09-11 14:48:20 +00:00
|
|
|
} );
|
2014-08-28 19:16:51 +00:00
|
|
|
|
|
|
|
} );
|