Better compatibility with array data
When using array data, and an option is selected, the data that is attached to the DOM element will be run through `item` and should have any private, automatically generated attributes added and merged with it.
This commit is contained in:
parent
72ae0da879
commit
9e130956fc
18
dist/js/select2.amd.full.js
vendored
18
dist/js/select2.amd.full.js
vendored
@ -1044,10 +1044,11 @@ define('select2/data/select',[
|
|||||||
|
|
||||||
define('select2/data/array',[
|
define('select2/data/array',[
|
||||||
'./select',
|
'./select',
|
||||||
'../utils'
|
'../utils',
|
||||||
], function (SelectAdapter, Utils) {
|
'jquery'
|
||||||
|
], function (SelectAdapter, Utils, $) {
|
||||||
function ArrayAdapter ($element, options) {
|
function ArrayAdapter ($element, options) {
|
||||||
this.data = options.options.data;
|
this.data = options.get('data');
|
||||||
|
|
||||||
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
||||||
}
|
}
|
||||||
@ -1078,7 +1079,16 @@ define('select2/data/array',[
|
|||||||
|
|
||||||
$option.text(data.text);
|
$option.text(data.text);
|
||||||
$option.val(data.id);
|
$option.val(data.id);
|
||||||
$option.data('data', data);
|
$option.prop('disabled', data.disabled || false);
|
||||||
|
|
||||||
|
// Get any automatically generated data values
|
||||||
|
var detectedData = this.item($option);
|
||||||
|
|
||||||
|
// Merge it with the already present data
|
||||||
|
var combinedData = $.extend({}, data, detectedData);
|
||||||
|
|
||||||
|
// Override the option's data with the combined data
|
||||||
|
$option.data('data', combinedData);
|
||||||
|
|
||||||
return $option;
|
return $option;
|
||||||
};
|
};
|
||||||
|
18
dist/js/select2.amd.js
vendored
18
dist/js/select2.amd.js
vendored
@ -1044,10 +1044,11 @@ define('select2/data/select',[
|
|||||||
|
|
||||||
define('select2/data/array',[
|
define('select2/data/array',[
|
||||||
'./select',
|
'./select',
|
||||||
'../utils'
|
'../utils',
|
||||||
], function (SelectAdapter, Utils) {
|
'jquery'
|
||||||
|
], function (SelectAdapter, Utils, $) {
|
||||||
function ArrayAdapter ($element, options) {
|
function ArrayAdapter ($element, options) {
|
||||||
this.data = options.options.data;
|
this.data = options.get('data');
|
||||||
|
|
||||||
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
||||||
}
|
}
|
||||||
@ -1078,7 +1079,16 @@ define('select2/data/array',[
|
|||||||
|
|
||||||
$option.text(data.text);
|
$option.text(data.text);
|
||||||
$option.val(data.id);
|
$option.val(data.id);
|
||||||
$option.data('data', data);
|
$option.prop('disabled', data.disabled || false);
|
||||||
|
|
||||||
|
// Get any automatically generated data values
|
||||||
|
var detectedData = this.item($option);
|
||||||
|
|
||||||
|
// Merge it with the already present data
|
||||||
|
var combinedData = $.extend({}, data, detectedData);
|
||||||
|
|
||||||
|
// Override the option's data with the combined data
|
||||||
|
$option.data('data', combinedData);
|
||||||
|
|
||||||
return $option;
|
return $option;
|
||||||
};
|
};
|
||||||
|
18
dist/js/select2.full.js
vendored
18
dist/js/select2.full.js
vendored
@ -10582,10 +10582,11 @@ define('select2/data/select',[
|
|||||||
|
|
||||||
define('select2/data/array',[
|
define('select2/data/array',[
|
||||||
'./select',
|
'./select',
|
||||||
'../utils'
|
'../utils',
|
||||||
], function (SelectAdapter, Utils) {
|
'jquery'
|
||||||
|
], function (SelectAdapter, Utils, $) {
|
||||||
function ArrayAdapter ($element, options) {
|
function ArrayAdapter ($element, options) {
|
||||||
this.data = options.options.data;
|
this.data = options.get('data');
|
||||||
|
|
||||||
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
||||||
}
|
}
|
||||||
@ -10616,7 +10617,16 @@ define('select2/data/array',[
|
|||||||
|
|
||||||
$option.text(data.text);
|
$option.text(data.text);
|
||||||
$option.val(data.id);
|
$option.val(data.id);
|
||||||
$option.data('data', data);
|
$option.prop('disabled', data.disabled || false);
|
||||||
|
|
||||||
|
// Get any automatically generated data values
|
||||||
|
var detectedData = this.item($option);
|
||||||
|
|
||||||
|
// Merge it with the already present data
|
||||||
|
var combinedData = $.extend({}, data, detectedData);
|
||||||
|
|
||||||
|
// Override the option's data with the combined data
|
||||||
|
$option.data('data', combinedData);
|
||||||
|
|
||||||
return $option;
|
return $option;
|
||||||
};
|
};
|
||||||
|
2
dist/js/select2.full.min.js
vendored
2
dist/js/select2.full.min.js
vendored
File diff suppressed because one or more lines are too long
18
dist/js/select2.js
vendored
18
dist/js/select2.js
vendored
@ -1473,10 +1473,11 @@ define('select2/data/select',[
|
|||||||
|
|
||||||
define('select2/data/array',[
|
define('select2/data/array',[
|
||||||
'./select',
|
'./select',
|
||||||
'../utils'
|
'../utils',
|
||||||
], function (SelectAdapter, Utils) {
|
'jquery'
|
||||||
|
], function (SelectAdapter, Utils, $) {
|
||||||
function ArrayAdapter ($element, options) {
|
function ArrayAdapter ($element, options) {
|
||||||
this.data = options.options.data;
|
this.data = options.get('data');
|
||||||
|
|
||||||
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
||||||
}
|
}
|
||||||
@ -1507,7 +1508,16 @@ define('select2/data/array',[
|
|||||||
|
|
||||||
$option.text(data.text);
|
$option.text(data.text);
|
||||||
$option.val(data.id);
|
$option.val(data.id);
|
||||||
$option.data('data', data);
|
$option.prop('disabled', data.disabled || false);
|
||||||
|
|
||||||
|
// Get any automatically generated data values
|
||||||
|
var detectedData = this.item($option);
|
||||||
|
|
||||||
|
// Merge it with the already present data
|
||||||
|
var combinedData = $.extend({}, data, detectedData);
|
||||||
|
|
||||||
|
// Override the option's data with the combined data
|
||||||
|
$option.data('data', combinedData);
|
||||||
|
|
||||||
return $option;
|
return $option;
|
||||||
};
|
};
|
||||||
|
2
dist/js/select2.min.js
vendored
2
dist/js/select2.min.js
vendored
File diff suppressed because one or more lines are too long
18
src/js/select2/data/array.js
vendored
18
src/js/select2/data/array.js
vendored
@ -1,9 +1,10 @@
|
|||||||
define([
|
define([
|
||||||
'./select',
|
'./select',
|
||||||
'../utils'
|
'../utils',
|
||||||
], function (SelectAdapter, Utils) {
|
'jquery'
|
||||||
|
], function (SelectAdapter, Utils, $) {
|
||||||
function ArrayAdapter ($element, options) {
|
function ArrayAdapter ($element, options) {
|
||||||
this.data = options.options.data;
|
this.data = options.get('data');
|
||||||
|
|
||||||
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
ArrayAdapter.__super__.constructor.call(this, $element, options);
|
||||||
}
|
}
|
||||||
@ -34,7 +35,16 @@ define([
|
|||||||
|
|
||||||
$option.text(data.text);
|
$option.text(data.text);
|
||||||
$option.val(data.id);
|
$option.val(data.id);
|
||||||
$option.data('data', data);
|
$option.prop('disabled', data.disabled || false);
|
||||||
|
|
||||||
|
// Get any automatically generated data values
|
||||||
|
var detectedData = this.item($option);
|
||||||
|
|
||||||
|
// Merge it with the already present data
|
||||||
|
var combinedData = $.extend({}, data, detectedData);
|
||||||
|
|
||||||
|
// Override the option's data with the combined data
|
||||||
|
$option.data('data', combinedData);
|
||||||
|
|
||||||
return $option;
|
return $option;
|
||||||
};
|
};
|
||||||
|
@ -60,7 +60,7 @@ test('current works with existing selections', function (assert) {
|
|||||||
assert.equal(
|
assert.equal(
|
||||||
val.length,
|
val.length,
|
||||||
1,
|
1,
|
||||||
'There should only be one existing selection'
|
'There should only be one existing selection.'
|
||||||
);
|
);
|
||||||
|
|
||||||
var option = val[0];
|
var option = val[0];
|
||||||
@ -68,13 +68,13 @@ test('current works with existing selections', function (assert) {
|
|||||||
assert.equal(
|
assert.equal(
|
||||||
option.id,
|
option.id,
|
||||||
'3',
|
'3',
|
||||||
'The id should be equal to the value of the option tag'
|
'The id should be equal to the value of the option tag.'
|
||||||
);
|
);
|
||||||
|
|
||||||
assert.equal(
|
assert.equal(
|
||||||
option.text,
|
option.text,
|
||||||
'Three',
|
'Three',
|
||||||
'The text should be equal to the text of the option tag'
|
'The text should be equal to the text of the option tag.'
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -90,13 +90,24 @@ test('current works with selected data', function (assert) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
data.current(function (val) {
|
data.current(function (val) {
|
||||||
assert.deepEqual(
|
assert.equal(
|
||||||
val,
|
val.length,
|
||||||
[{
|
1,
|
||||||
id: '2',
|
'There should only be one option selected.'
|
||||||
text: '2'
|
);
|
||||||
}],
|
|
||||||
'The text and id should match the selected array data.'
|
var option = val[0];
|
||||||
|
|
||||||
|
assert.equal(
|
||||||
|
option.id,
|
||||||
|
'2',
|
||||||
|
'The id should match the original id from the array.'
|
||||||
|
);
|
||||||
|
|
||||||
|
assert.equal(
|
||||||
|
option.text,
|
||||||
|
'2',
|
||||||
|
'The text should match the original text from the array.'
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user