The problem is how to apply a style on a part of an option.
I have a SELECT like this:
<select id="my_select">
<option value="1">Item 1 <span class="color-red">20 calls</span></option>
<option value="2">Item 2 <span class="color-red">10 calls</span></option>
<option value="2">Item 3 <span class="color-red">30 calls</span></option>
</select>
Browsers don't allow tags within OPTION's and strip them.
So a possible workaround is using HTML entities:
<select id="my_select">
<option value="1">Item 1 <span class="color-red">20 calls</span></option>
<option value="2">Item 2 <span class="color-red">10 calls</span></option>
<option value="2">Item 3 <span class="color-red">30 calls</span></option>
</select>
Now a browser sees the entire content of each OPTION as a text. And here's the Jquery code:
$('#my_select').select2({
minimumResultsForSearch: -1
});
The last thing I stumbled on is replacing the entities "<" and ">" with "<" and ">" symbols respectively AFTER the Select2 is rendered and on a dropdown, to get in the first option box "Item 1" in default black color and "20 calls" in red color (CSS is available: .color-red {color:red;}). And the same for the other option boxes.
I've tried to find the answer in the documentation, but nothing worked. For example,
$('#my_select').select2({
minimumResultsForSearch: -1,
templateResult: function (item) {
item.text.replace (/>/g,'>').replace (/</g,'<');
}
});
Any ideas on how to solve this are greatly appreciated.
You need to rewrite the escapeMarkup
option to allow HTML content.
In templateResult
you inform how and in what way you want to render the content, in this case I use the return of a data-text attribute in each option.
$('#my_select').select2({
minimumResultsForSearch: -1,
escapeMarkup: function(item) {
return item;
},
templateResult: function(item) {
return $(item.element).data('text');
}
});
.color-red {
color: #ff0000;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/select2.min.css" rel="stylesheet" />
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/select2.min.js"></script>
<select id="my_select" style="width: 100%;">
<option></option>
<option value="1" data-text='Item 1 <span class="color-red">20 calls</span>'>Item 1 20 calls</option>
<option value="2" data-text='Item 2 <span class="color-red">10 calls</span>'>Item 2 10 calls</option>
<option value="3" data-text='Item 3 <span class="color-red">30 calls</span>'>Item 3 30 calls</option>
</select>