$.fn.extend({ select2Multiple: function(config = {}) { // Adding ID to each block var templateSelection = (state, parent) => { if (config.colorField !== undefined) { parent.css('background',state[config.colorField] || state.element.dataset[config.colorField]) } return $('' + (config.customSelection !== undefined ? config.customSelection(state) : state.text) + ''); }; var select2 = this.select2({ closeOnSelect: config.closeOnSelect || false, multiple: true, ajax: config.ajax, templateSelection: templateSelection, tags: config.dynamicCreation || true, tokenSeparators: config.dynamicCreationDelimiter || [',', ' '], }); // Add dynamic size select2.next().css('width', '100%'); // unlimited size if (config.unlimitedSize) { this[0].dataset.unlimitedSize = true; select2.next().find('.select2-selection').css('max-height', 'none'); select2.next().find('.select2-selection .select2-selection__rendered').css('width', '100%'); } // select all check this[0].dataset.singleDisplay = config.singleDisplay || false; if (this[0].dataset.selectAll === 'true') { $.each($(this).find('option'), (index, e) => { e.selected = true; }); this.trigger('change'); } if (config.singleDisplay) { $(this).updateSingleName(); } return select2 // Adding select all button .on('select2:open', function() { var selectElement = this; $('.select2-selection').scrollTo(0); $('.select2_select_all').remove(); if (selectElement.dataset.selectAllButton !== undefined) { $('
' + selectElement.dataset.selectAllButton + '
').prependTo('.select2-dropdown').on('click', function() { var elementsToSelect = $.map($(selectElement).find('option'), e => e.value); if ($(selectElement).find('option:selected').length === elementsToSelect.length) elementsToSelect = []; $(selectElement).val(elementsToSelect).trigger('change'); $(selectElement).select2('close'); $(selectElement).select2('open'); }); } }) // Prevent shake bug with multiple select .on('select2:open select2:close', function() { $('.select2-selection').scrollTo(0); }) // Prevent opening window when deleteing selection .on('select2:unselect', function() { var resultWindow = $('.select2-container--open'); if (resultWindow.length === 0) { $(this).select2('open'); } }) // Fxied scroll bug .on('select2:selecting select2:unselecting', function(e) { $(e.currentTarget).data('scrolltop', $('.select2-results__options').scrollTop()); $('.select2-selection').scrollTo(0); }) // Fxied scroll bug .on('select2:select select2:unselect change', function(e) { $('.select2-selection').scrollTo(0); $('.select2-results__options').scrollTop($(e.currentTarget).data('scrolltop')); if (this.dataset.singleDisplay === 'true') { $(this).updateSingleName(); } }); }, select2MultipleClearAll: function() { $(this).val([]).trigger('change'); }, // Create from multiple blocks single one with counter updateSingleName: function() { var template = ''; var selectElement = this; var selectedOptions = selectElement.next().find('.select2-selection__choice'); var optionsCounter = selectedOptions.length; var allOptionsSelected = this.find('option').length === optionsCounter; var optionText = allOptionsSelected ? this[0].dataset.selectMultipleAllSelected : optionsCounter + ' ' + this[0].dataset.selectMultipleName; if (optionsCounter > 1) { selectedOptions.remove(); template = '
  • ' + '×' + optionText + '
  • '; $(template).prependTo(selectElement.next().find('.select2-selection__rendered')).find('.select2-selection__choice__remove') .click(function() { selectElement.select2MultipleClearAll(); }); } } });