| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258 | module('Selection containers - Multiple');var MultipleSelection = require('select2/selection/multiple');var $ = require('jquery');var Options = require('select2/options');var Utils = require('select2/utils');var options = new Options({});test('display uses templateSelection', function (assert) {  var called = false;  var templateOptions = new Options({    templateSelection: function (data) {      called = true;      return data.text;    }  });  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    templateOptions  );  var out = selection.display({    text: 'test'  });  assert.ok(called);  assert.equal(out, 'test');});test('templateSelection can addClass', function (assert) {  var called = false;  var templateOptions = new Options({    templateSelection: function (data, container) {      called = true;      container.addClass('testclass');      return data.text;    }  });  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    templateOptions  );  var $container = selection.selectionContainer();  var out = selection.display({    text: 'test'  }, $container);  assert.ok(called);  assert.equal(out, 'test');  assert.ok($container.hasClass('testclass'));});test('empty update clears the selection', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  var $rendered = $selection.find('.select2-selection__rendered');  $rendered.text('testing');  selection.update([]);  assert.equal(    $rendered.text(),    '',    'There should have been nothing rendered'  );});test('empty update clears the selection title', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  selection.update([]);  var $rendered = $selection.find('.select2-selection__rendered li');  assert.equal(    $rendered.attr('title'),    undefined,    'The title should be removed if nothing is rendered'  );});test('update sets the title to the data text', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  selection.update([{    text: 'test'  }]);  var $rendered = $selection.find('.select2-selection__rendered li');  assert.equal(    $rendered.attr('title'),    'test',    'The title should have been set to the text'  );});test('update sets the title to the data title', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  selection.update([{    text: 'test',    title: 'correct'  }]);  var $rendered = $selection.find('.select2-selection__rendered li');  assert.equal(    $rendered.attr('title'),    'correct',    'The title should have taken precedence over the text'  );});test('update should clear title for placeholder options', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  selection.update([{    id: '',    text: ''  }]);  var $rendered = $selection.find('.select2-selection__rendered li');  assert.equal(    $rendered.attr('title'),    undefined,    'The title should be removed if a placeholder is rendered'  );});test('update should clear title for options without text', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  selection.update([{    id: ''  }]);  var $rendered = $selection.find('.select2-selection__rendered li');  assert.equal(    $rendered.attr('title'),    undefined,    'The title should be removed if there is no text or title property'  );});test('escapeMarkup is being used', function (assert) {  var selection = new MultipleSelection(    $('#qunit-fixture .multiple'),    options  );  var $selection = selection.render();  var $rendered = $selection.find('.select2-selection__rendered');  var unescapedText = '<script>bad("stuff");</script>';  selection.update([{    text: unescapedText  }]);  assert.equal(    $rendered.text().substr(1),    unescapedText,    'The text should be escaped by default to prevent injection'  );});test('clear button respects the disabled state', function (assert) {  var options = new Options({    disabled: true  });  var $select = $('#qunit-fixture .multiple');  var container = new MockContainer();  var $container = $('<div></div>');  var selection = new MultipleSelection(    $select,    options  );  var $selection = selection.render();  $container.append($selection);  selection.bind(container, $container);  // Select an option  selection.update([{    text: 'Test'  }]);  var $rendered = $selection.find('.select2-selection__rendered');  var $pill = $rendered.find('.select2-selection__choice');  assert.equal($pill.length, 1, 'There should only be one selection');  var $remove = $pill.find('.select2-selection__choice__remove');  assert.equal(    $remove.length,    1,    'The remove icon is displayed for the selection'  );  // Set up the unselect handler  selection.on('unselect', function (params) {    assert.ok(false, 'The unselect handler should not be triggered');  });  // Trigger the handler for the remove icon  $remove.trigger('click');});
 |