123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351 |
- module('Results - highlighting results');
- test('results:all with no data skips results:focus', function (assert) {
- assert.expect(0);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var results = new Results($select, new Options({}));
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- results.on('results:focus', function (params) {
- assert.ok(false, 'The results:focus event was triggered');
- });
- container.trigger('results:all', {
- data: {
- results: []
- }
- });
- });
- test('results:all triggers results:focus on the first item', function (assert) {
- assert.expect(2);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var results = new Results($select, new Options({}));
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- results.on('results:focus', function (params) {
- assert.equal(params.data.id, 'test');
- assert.equal(params.data.text, 'Test');
- });
- container.trigger('results:all', {
- data: {
- results: [
- {
- id: 'test',
- text: 'Test'
- }
- ]
- }
- });
- });
- test('results:append does not trigger results:focus', function (assert) {
- assert.expect(0);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var results = new Results($select, new Options({}));
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- results.on('results:focus', function () {
- assert.ok(false, 'The results:focus event was triggered');
- });
- container.trigger('results:append', {
- data: {
- results: [
- {
- id: 'test',
- text: 'Test'
- }
- ]
- }
- });
- });
- test('scrollAfterSelect triggers results:focus', function (assert) {
- assert.expect(3);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var options = new Options({ scrollAfterSelect: true });
- var results = new Results($select, options);
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- // check that default for scrollAfterSelect is true
- assert.equal(options.get('scrollAfterSelect'), true);
- results.append({
- results: [
- {
- id: 'test',
- text: 'Test'
- }
- ]
- });
- results.on('results:focus', function (params) {
- assert.equal(params.data.id, 'test');
- assert.equal(params.data.text, 'Test');
- });
- container.trigger('select', {});
- });
- test('!scrollAfterSelect does not trigger results:focus', function (assert) {
- assert.expect(1);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var options = new Options({ scrollAfterSelect: false });
- var results = new Results($select, options);
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- // check that default for scrollAfterSelect is false
- assert.equal(options.get('scrollAfterSelect'), false);
- results.append({
- results: [
- {
- id: 'test',
- text: 'Test'
- }
- ]
- });
- results.on('results:focus', function () {
- assert.ok(false, 'The results:focus event was triggered');
- });
- container.trigger('select', {});
- });
- test('tag result is highlighted with no other selections', function (assert) {
- assert.expect(2);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var Tags = require('select2/dropdown/tagsSearchHighlight');
- var TagResults = Utils.Decorate(Results, Tags);
- var results = new TagResults($select, new Options({}));
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([]);
- };
- results.render();
- results.bind(container, $container);
- results.on('results:focus', function (params) {
- assert.equal(params.data.id, 'tag');
- assert.equal(params.data.text, 'Tag');
- });
- var tagElement = $('<option data-select2-tag="true"></option>')[0];
- container.trigger('results:all', {
- data: {
- results: [
- {
- id: 'tag',
- text: 'Tag',
- element: tagElement
- }
- ]
- }
- });
- });
- test('tag result is highlighted with other selections', function (assert) {
- assert.expect(2);
- var $ = require('jquery');
- var $select = $('<select></select>');
- var $parent = $('<div></div>');
- var $container = $('<span></span>');
- var container = new MockContainer();
- $parent.appendTo($('#qunit-fixture'));
- $select.appendTo($parent);
- var Utils = require('select2/utils');
- var Options = require('select2/options');
- var Results = require('select2/results');
- var Tags = require('select2/dropdown/tagsSearchHighlight');
- var TagResults = Utils.Decorate(Results, Tags);
- var results = new TagResults($select, new Options({}));
- // Fake the data adapter for the `setClasses` method
- results.data = {};
- results.data.current = function (callback) {
- callback([{ id: 'test' }]);
- };
- results.render();
- results.bind(container, $container);
- results.on('results:focus', function (params) {
- assert.equal(params.data.id, 'tag');
- assert.equal(params.data.text, 'Tag');
- });
- var tagElement = $('<option data-select2-tag="true"></option>')[0];
- container.trigger('results:all', {
- data: {
- results: [
- {
- id: 'tag',
- text: 'Tag',
- element: tagElement
- },
- {
- id: 'test',
- text: 'Test'
- }
- ]
- }
- });
- });
|