fomantic-ui 2.9.4-beta.1 → 2.9.4-beta.100

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (296) hide show
  1. package/.all-contributorsrc +29 -1
  2. package/.eslintrc.js +17 -0
  3. package/.github/FUNDING.yml +1 -1
  4. package/.github/workflows/ci.yml +8 -8
  5. package/.github/workflows/depsreview.yml +14 -0
  6. package/.github/workflows/nightly.yml +1 -1
  7. package/.github/workflows/release.yml +1 -1
  8. package/CONTRIBUTORS.md +5 -0
  9. package/README.md +2 -12
  10. package/dist/components/accordion.css +1 -1
  11. package/dist/components/accordion.js +4 -2
  12. package/dist/components/accordion.min.css +1 -1
  13. package/dist/components/accordion.min.js +2 -2
  14. package/dist/components/ad.css +1 -1
  15. package/dist/components/ad.min.css +1 -1
  16. package/dist/components/api.js +7 -3
  17. package/dist/components/api.min.js +2 -2
  18. package/dist/components/breadcrumb.css +1 -1
  19. package/dist/components/breadcrumb.min.css +1 -1
  20. package/dist/components/button.css +21 -3
  21. package/dist/components/button.min.css +2 -2
  22. package/dist/components/calendar.css +1 -1
  23. package/dist/components/calendar.js +47 -12
  24. package/dist/components/calendar.min.css +1 -1
  25. package/dist/components/calendar.min.js +3 -3
  26. package/dist/components/card.css +1 -1
  27. package/dist/components/card.min.css +1 -1
  28. package/dist/components/checkbox.css +1 -1
  29. package/dist/components/checkbox.js +10 -4
  30. package/dist/components/checkbox.min.css +1 -1
  31. package/dist/components/checkbox.min.js +3 -3
  32. package/dist/components/comment.css +1 -1
  33. package/dist/components/comment.min.css +1 -1
  34. package/dist/components/container.css +1 -1
  35. package/dist/components/container.min.css +1 -1
  36. package/dist/components/dimmer.css +7 -3
  37. package/dist/components/dimmer.js +4 -2
  38. package/dist/components/dimmer.min.css +2 -2
  39. package/dist/components/dimmer.min.js +2 -2
  40. package/dist/components/divider.css +1 -1
  41. package/dist/components/divider.min.css +1 -1
  42. package/dist/components/dropdown.css +46 -40
  43. package/dist/components/dropdown.js +110 -35
  44. package/dist/components/dropdown.min.css +2 -2
  45. package/dist/components/dropdown.min.js +3 -3
  46. package/dist/components/embed.css +1 -1
  47. package/dist/components/embed.js +17 -7
  48. package/dist/components/embed.min.css +1 -1
  49. package/dist/components/embed.min.js +3 -3
  50. package/dist/components/emoji.css +4309 -3713
  51. package/dist/components/emoji.min.css +2 -2
  52. package/dist/components/feed.css +12 -1
  53. package/dist/components/feed.min.css +2 -2
  54. package/dist/components/flag.css +3 -1
  55. package/dist/components/flag.min.css +2 -2
  56. package/dist/components/flyout.css +3 -3
  57. package/dist/components/flyout.js +4 -2
  58. package/dist/components/flyout.min.css +1 -1
  59. package/dist/components/flyout.min.js +2 -2
  60. package/dist/components/form.css +28 -7
  61. package/dist/components/form.js +74 -29
  62. package/dist/components/form.min.css +2 -2
  63. package/dist/components/form.min.js +3 -3
  64. package/dist/components/grid.css +5 -5
  65. package/dist/components/grid.min.css +2 -2
  66. package/dist/components/header.css +4 -1
  67. package/dist/components/header.min.css +2 -2
  68. package/dist/components/icon.css +1 -1
  69. package/dist/components/icon.min.css +1 -1
  70. package/dist/components/image.css +1 -1
  71. package/dist/components/image.min.css +1 -1
  72. package/dist/components/input.css +30 -10
  73. package/dist/components/input.min.css +2 -2
  74. package/dist/components/item.css +1 -1
  75. package/dist/components/item.min.css +1 -1
  76. package/dist/components/label.css +7 -2
  77. package/dist/components/label.min.css +2 -2
  78. package/dist/components/list.css +1 -1
  79. package/dist/components/list.min.css +1 -1
  80. package/dist/components/loader.css +1 -1
  81. package/dist/components/loader.min.css +1 -1
  82. package/dist/components/menu.css +1 -2
  83. package/dist/components/menu.min.css +2 -2
  84. package/dist/components/message.css +2 -1
  85. package/dist/components/message.min.css +2 -2
  86. package/dist/components/modal.css +3 -3
  87. package/dist/components/modal.js +7 -3
  88. package/dist/components/modal.min.css +1 -1
  89. package/dist/components/modal.min.js +2 -2
  90. package/dist/components/nag.css +1 -1
  91. package/dist/components/nag.js +11 -5
  92. package/dist/components/nag.min.css +1 -1
  93. package/dist/components/nag.min.js +3 -3
  94. package/dist/components/placeholder.css +1 -1
  95. package/dist/components/placeholder.min.css +1 -1
  96. package/dist/components/popup.css +1 -2
  97. package/dist/components/popup.js +10 -4
  98. package/dist/components/popup.min.css +2 -2
  99. package/dist/components/popup.min.js +2 -2
  100. package/dist/components/progress.css +15 -6
  101. package/dist/components/progress.js +4 -2
  102. package/dist/components/progress.min.css +2 -2
  103. package/dist/components/progress.min.js +2 -2
  104. package/dist/components/rail.css +1 -1
  105. package/dist/components/rail.min.css +1 -1
  106. package/dist/components/rating.css +1 -1
  107. package/dist/components/rating.js +4 -2
  108. package/dist/components/rating.min.css +1 -1
  109. package/dist/components/rating.min.js +2 -2
  110. package/dist/components/reset.css +1 -1
  111. package/dist/components/reset.min.css +1 -1
  112. package/dist/components/reveal.css +1 -1
  113. package/dist/components/reveal.min.css +1 -1
  114. package/dist/components/search.css +34 -23
  115. package/dist/components/search.js +78 -14
  116. package/dist/components/search.min.css +2 -2
  117. package/dist/components/search.min.js +3 -3
  118. package/dist/components/segment.css +1 -1
  119. package/dist/components/segment.min.css +1 -1
  120. package/dist/components/shape.css +1 -1
  121. package/dist/components/shape.js +7 -5
  122. package/dist/components/shape.min.css +1 -1
  123. package/dist/components/shape.min.js +3 -3
  124. package/dist/components/sidebar.css +1 -1
  125. package/dist/components/sidebar.js +4 -2
  126. package/dist/components/sidebar.min.css +1 -1
  127. package/dist/components/sidebar.min.js +2 -2
  128. package/dist/components/site.css +14 -6
  129. package/dist/components/site.js +4 -2
  130. package/dist/components/site.min.css +2 -2
  131. package/dist/components/site.min.js +2 -2
  132. package/dist/components/slider.css +152 -2
  133. package/dist/components/slider.js +142 -44
  134. package/dist/components/slider.min.css +2 -2
  135. package/dist/components/slider.min.js +3 -3
  136. package/dist/components/state.js +4 -2
  137. package/dist/components/state.min.js +2 -2
  138. package/dist/components/statistic.css +1 -1
  139. package/dist/components/statistic.min.css +1 -1
  140. package/dist/components/step.css +992 -86
  141. package/dist/components/step.min.css +2 -2
  142. package/dist/components/sticky.css +1 -1
  143. package/dist/components/sticky.js +4 -2
  144. package/dist/components/sticky.min.css +1 -1
  145. package/dist/components/sticky.min.js +2 -2
  146. package/dist/components/tab.css +1 -1
  147. package/dist/components/tab.js +4 -2
  148. package/dist/components/tab.min.css +1 -1
  149. package/dist/components/tab.min.js +2 -2
  150. package/dist/components/table.css +32 -21
  151. package/dist/components/table.min.css +2 -2
  152. package/dist/components/text.css +1 -1
  153. package/dist/components/text.min.css +1 -1
  154. package/dist/components/toast.css +1 -1
  155. package/dist/components/toast.js +7 -3
  156. package/dist/components/toast.min.css +1 -1
  157. package/dist/components/toast.min.js +3 -3
  158. package/dist/components/transition.css +1 -1
  159. package/dist/components/transition.js +7 -3
  160. package/dist/components/transition.min.css +1 -1
  161. package/dist/components/transition.min.js +2 -2
  162. package/dist/components/visibility.js +4 -2
  163. package/dist/components/visibility.min.js +2 -2
  164. package/dist/semantic.css +6226 -3986
  165. package/dist/semantic.js +580 -195
  166. package/dist/semantic.min.css +3 -3
  167. package/dist/semantic.min.js +3 -3
  168. package/dist/themes/basic/assets/fonts/LICENSE.txt +91 -0
  169. package/dist/themes/default/assets/fonts/LICENSE_Lato.txt +94 -0
  170. package/dist/themes/default/assets/fonts/LICENSE_icons.txt +165 -0
  171. package/dist/themes/github/assets/fonts/LICENSE.txt +94 -0
  172. package/dist/themes/material/assets/fonts/LICENSE.txt +202 -0
  173. package/package.json +14 -14
  174. package/semantic.json.example +1 -1
  175. package/src/definitions/behaviors/api.js +6 -2
  176. package/src/definitions/behaviors/form.js +73 -28
  177. package/src/definitions/behaviors/state.js +3 -1
  178. package/src/definitions/behaviors/visibility.js +3 -1
  179. package/src/definitions/collections/form.less +56 -27
  180. package/src/definitions/collections/grid.less +85 -70
  181. package/src/definitions/collections/menu.less +38 -27
  182. package/src/definitions/collections/message.less +1 -0
  183. package/src/definitions/collections/table.less +183 -157
  184. package/src/definitions/elements/button.less +61 -25
  185. package/src/definitions/elements/container.less +6 -4
  186. package/src/definitions/elements/divider.less +4 -1
  187. package/src/definitions/elements/emoji.less +3 -1
  188. package/src/definitions/elements/header.less +12 -4
  189. package/src/definitions/elements/icon.less +35 -28
  190. package/src/definitions/elements/input.less +35 -19
  191. package/src/definitions/elements/label.less +19 -8
  192. package/src/definitions/elements/list.less +28 -21
  193. package/src/definitions/elements/loader.less +17 -12
  194. package/src/definitions/elements/segment.less +12 -7
  195. package/src/definitions/elements/step.less +405 -87
  196. package/src/definitions/globals/site.js +3 -1
  197. package/src/definitions/globals/site.less +17 -12
  198. package/src/definitions/modules/accordion.js +3 -1
  199. package/src/definitions/modules/accordion.less +15 -13
  200. package/src/definitions/modules/calendar.js +46 -11
  201. package/src/definitions/modules/calendar.less +6 -4
  202. package/src/definitions/modules/checkbox.js +9 -3
  203. package/src/definitions/modules/checkbox.less +12 -6
  204. package/src/definitions/modules/dimmer.js +3 -1
  205. package/src/definitions/modules/dimmer.less +16 -10
  206. package/src/definitions/modules/dropdown.js +109 -34
  207. package/src/definitions/modules/dropdown.less +109 -78
  208. package/src/definitions/modules/embed.js +16 -6
  209. package/src/definitions/modules/flyout.js +3 -1
  210. package/src/definitions/modules/flyout.less +51 -45
  211. package/src/definitions/modules/modal.js +6 -2
  212. package/src/definitions/modules/modal.less +109 -82
  213. package/src/definitions/modules/nag.js +10 -4
  214. package/src/definitions/modules/nag.less +8 -4
  215. package/src/definitions/modules/popup.js +9 -3
  216. package/src/definitions/modules/popup.less +3 -1
  217. package/src/definitions/modules/progress.js +3 -1
  218. package/src/definitions/modules/progress.less +24 -6
  219. package/src/definitions/modules/rating.js +3 -1
  220. package/src/definitions/modules/search.js +77 -13
  221. package/src/definitions/modules/search.less +41 -25
  222. package/src/definitions/modules/shape.js +6 -4
  223. package/src/definitions/modules/sidebar.js +3 -1
  224. package/src/definitions/modules/slider.js +141 -43
  225. package/src/definitions/modules/slider.less +129 -27
  226. package/src/definitions/modules/sticky.js +3 -1
  227. package/src/definitions/modules/tab.js +3 -1
  228. package/src/definitions/modules/toast.js +6 -2
  229. package/src/definitions/modules/toast.less +35 -24
  230. package/src/definitions/modules/transition.js +6 -2
  231. package/src/definitions/views/card.less +7 -5
  232. package/src/definitions/views/feed.less +14 -1
  233. package/src/definitions/views/item.less +7 -5
  234. package/src/themes/basic/assets/fonts/LICENSE.txt +91 -0
  235. package/src/themes/default/assets/fonts/LICENSE_Lato.txt +94 -0
  236. package/src/themes/default/assets/fonts/LICENSE_icons.txt +165 -0
  237. package/src/themes/default/collections/form.variables +1 -0
  238. package/src/themes/default/elements/button.variables +3 -0
  239. package/src/themes/default/elements/emoji.variables +172 -23
  240. package/src/themes/default/elements/flag.variables +3 -3
  241. package/src/themes/default/elements/step.variables +33 -0
  242. package/src/themes/default/globals/site.variables +3 -0
  243. package/src/themes/default/globals/variation.variables +24 -2
  244. package/src/themes/default/modules/dropdown.variables +3 -0
  245. package/src/themes/default/modules/progress.variables +1 -1
  246. package/src/themes/default/modules/search.variables +15 -12
  247. package/src/themes/default/modules/slider.variables +10 -0
  248. package/src/themes/default/views/feed.variables +3 -0
  249. package/src/themes/github/assets/fonts/LICENSE.txt +94 -0
  250. package/src/themes/joypixels/elements/emoji.variables +183 -22
  251. package/src/themes/material/assets/fonts/LICENSE.txt +202 -0
  252. package/tasks/admin/components/create.js +4 -4
  253. package/tasks/admin/components/init.js +2 -2
  254. package/tasks/admin/components/update.js +3 -3
  255. package/tasks/admin/distributions/create.js +3 -3
  256. package/tasks/admin/distributions/init.js +2 -2
  257. package/tasks/admin/distributions/update.js +4 -4
  258. package/tasks/build/assets.js +1 -1
  259. package/tasks/build/css.js +19 -10
  260. package/tasks/build/javascript.js +12 -5
  261. package/tasks/check-install.js +1 -1
  262. package/tasks/config/defaults.js +4 -0
  263. package/tasks/config/project/release.js +19 -1
  264. package/tasks/config/tasks.js +7 -7
  265. package/tasks/docs/build.js +3 -3
  266. package/tasks/docs/metadata.js +1 -1
  267. package/tasks/docs/serve.js +3 -1
  268. package/tasks/install.js +2 -2
  269. package/tasks/watch.js +1 -1
  270. package/types/fomantic-ui-accordion.d.ts +1 -1
  271. package/types/fomantic-ui-api.d.ts +9 -3
  272. package/types/fomantic-ui-calendar.d.ts +114 -13
  273. package/types/fomantic-ui-checkbox.d.ts +14 -4
  274. package/types/fomantic-ui-dimmer.d.ts +1 -1
  275. package/types/fomantic-ui-dropdown.d.ts +82 -44
  276. package/types/fomantic-ui-embed.d.ts +19 -2
  277. package/types/fomantic-ui-flyout.d.ts +25 -11
  278. package/types/fomantic-ui-form.d.ts +128 -20
  279. package/types/fomantic-ui-modal.d.ts +101 -5
  280. package/types/fomantic-ui-nag.d.ts +4 -4
  281. package/types/fomantic-ui-popup.d.ts +38 -12
  282. package/types/fomantic-ui-progress.d.ts +12 -6
  283. package/types/fomantic-ui-rating.d.ts +1 -1
  284. package/types/fomantic-ui-search.d.ts +138 -22
  285. package/types/fomantic-ui-shape.d.ts +2 -2
  286. package/types/fomantic-ui-sidebar.d.ts +4 -4
  287. package/types/fomantic-ui-slider.d.ts +56 -4
  288. package/types/fomantic-ui-sticky.d.ts +1 -1
  289. package/types/fomantic-ui-tab.d.ts +6 -6
  290. package/types/fomantic-ui-toast.d.ts +14 -2
  291. package/types/fomantic-ui-transition.d.ts +41 -7
  292. package/types/fomantic-ui-visibility.d.ts +3 -3
  293. package/types/index.d.ts +25 -25
  294. package/types/tests.ts +188 -0
  295. package/types/tsconfig.json +1 -1
  296. package/types/fomantic-ui-tests.ts +0 -25
@@ -127,6 +127,9 @@
127
127
  module.change.values(settings.values);
128
128
  module.remove.initialLoad();
129
129
  }
130
+ if (module.get.placeholderText() !== '') {
131
+ module.set.placeholderText();
132
+ }
130
133
 
131
134
  module.refreshData();
132
135
 
@@ -793,7 +796,7 @@
793
796
  }
794
797
  if (module.is.multiple()) {
795
798
  $.each(preSelected, function (index, value) {
796
- $item.filter('[data-value="' + value + '"]')
799
+ $item.filter('[data-' + metadata.value + '="' + value + '"]')
797
800
  .addClass(className.filtered)
798
801
  ;
799
802
  });
@@ -890,11 +893,13 @@
890
893
  ? query
891
894
  : module.get.query()
892
895
  ),
893
- results = null,
894
- escapedTerm = module.escape.string(searchTerm),
895
- regExpFlags = (settings.ignoreSearchCase ? 'i' : '') + 'gm',
896
+ results = null,
897
+ escapedTerm = module.escape.string(searchTerm),
898
+ regExpIgnore = settings.ignoreSearchCase ? 'i' : '',
899
+ regExpFlags = regExpIgnore + 'gm',
896
900
  beginsWithRegExp = new RegExp('^' + escapedTerm, regExpFlags)
897
901
  ;
902
+ module.remove.filteredItem();
898
903
  // avoid loop if we're matching nothing
899
904
  if (module.has.query()) {
900
905
  results = [];
@@ -938,12 +943,34 @@
938
943
  ;
939
944
  }
940
945
  module.debug('Showing only matched items', searchTerm);
941
- module.remove.filteredItem();
942
946
  if (results) {
943
947
  $item
944
948
  .not(results)
945
949
  .addClass(className.filtered)
946
950
  ;
951
+ if (settings.highlightMatches && (settings.match === 'both' || settings.match === 'text')) {
952
+ var querySplit = query.split(''),
953
+ diacriticReg = settings.ignoreDiacritics ? '[\u0300-\u036F]?' : '',
954
+ htmlReg = '(?![^<]*>)',
955
+ markedRegExp = new RegExp(htmlReg + '(' + querySplit.join(diacriticReg + ')(.*?)' + htmlReg + '(') + diacriticReg + ')', regExpIgnore),
956
+ markedReplacer = function () {
957
+ var args = [].slice.call(arguments, 1, querySplit.length * 2).map(function (x, i) {
958
+ return i & 1 ? x : '<mark>' + x + '</mark>'; // eslint-disable-line no-bitwise
959
+ });
960
+
961
+ return args.join('');
962
+ }
963
+ ;
964
+ $.each(results, function (index, result) {
965
+ var $result = $(result),
966
+ markedHTML = module.get.choiceText($result, true)
967
+ ;
968
+ if (settings.ignoreDiacritics) {
969
+ markedHTML = markedHTML.normalize('NFD');
970
+ }
971
+ $result.html(markedHTML.replace(markedRegExp, markedReplacer));
972
+ });
973
+ }
947
974
  }
948
975
 
949
976
  if (!module.has.query()) {
@@ -979,8 +1006,10 @@
979
1006
  termLength = term.length,
980
1007
  queryLength = query.length
981
1008
  ;
982
- query = settings.ignoreSearchCase ? query.toLowerCase() : query;
983
- term = settings.ignoreSearchCase ? term.toLowerCase() : term;
1009
+ if (settings.ignoreSearchCase) {
1010
+ query = query.toLowerCase();
1011
+ term = term.toLowerCase();
1012
+ }
984
1013
  if (queryLength > termLength) {
985
1014
  return false;
986
1015
  }
@@ -1187,7 +1216,7 @@
1187
1216
  if (!itemActivated && !pageLostFocus) {
1188
1217
  if (settings.forceSelection) {
1189
1218
  module.forceSelection();
1190
- } else if (!settings.allowAdditions) {
1219
+ } else if (!settings.allowAdditions && !settings.keepSearchTerm && !module.has.menuSearch()) {
1191
1220
  module.remove.searchTerm();
1192
1221
  }
1193
1222
  module.hide();
@@ -1202,7 +1231,9 @@
1202
1231
  if (module.is.searchSelection()) {
1203
1232
  module.remove.searchTerm();
1204
1233
  }
1205
- module.hide();
1234
+ if (settings.collapseOnClearable) {
1235
+ module.hide();
1236
+ }
1206
1237
  event.stopPropagation();
1207
1238
  },
1208
1239
  },
@@ -1236,7 +1267,9 @@
1236
1267
  module.set.filtered();
1237
1268
  }
1238
1269
  clearTimeout(module.timer);
1239
- module.timer = setTimeout(function () { module.search(); }, settings.delay.search);
1270
+ module.timer = setTimeout(function () {
1271
+ module.search();
1272
+ }, settings.delay.search);
1240
1273
  },
1241
1274
  label: {
1242
1275
  click: function (event) {
@@ -1413,7 +1446,9 @@
1413
1446
  module.remove.userAddition();
1414
1447
  }
1415
1448
  if (!settings.keepSearchTerm) {
1416
- module.remove.filteredItem();
1449
+ if (module.is.multiple()) {
1450
+ module.remove.filteredItem();
1451
+ }
1417
1452
  module.remove.searchTerm();
1418
1453
  }
1419
1454
  if (!module.is.visible() && $target.length > 0) {
@@ -2587,7 +2622,7 @@
2587
2622
  } else {
2588
2623
  $combo.text(text);
2589
2624
  }
2590
- } else if (settings.action === 'activate') {
2625
+ } else if (settings.action === 'activate' || isFunction(settings.action)) {
2591
2626
  if (text !== module.get.placeholderText() || isNotPlaceholder) {
2592
2627
  $text.removeClass(className.placeholder);
2593
2628
  }
@@ -2647,7 +2682,7 @@
2647
2682
  module.set.scrollPosition($nextValue);
2648
2683
  $selectedItem.removeClass(className.selected);
2649
2684
  $nextValue.addClass(className.selected);
2650
- if (settings.selectOnKeydown && module.is.single() && !$nextItem.hasClass(className.actionable)) {
2685
+ if (settings.selectOnKeydown && module.is.single() && (!$nextItem || !$nextItem.hasClass(className.actionable))) {
2651
2686
  module.set.selectedItem($nextValue);
2652
2687
  }
2653
2688
  }
@@ -2768,19 +2803,27 @@
2768
2803
  $selectedItem = settings.allowAdditions
2769
2804
  ? $selectedItem || module.get.itemWithAdditions(value)
2770
2805
  : $selectedItem || module.get.item(value);
2771
- if (!$selectedItem) {
2806
+ if (!$selectedItem && value !== undefined) {
2772
2807
  return false;
2773
2808
  }
2774
- module.debug('Setting selected menu item to', $selectedItem);
2775
- if (module.is.multiple() && !keepSearchTerm) {
2776
- module.remove.searchWidth();
2777
- }
2778
- if (module.is.single()) {
2809
+ if (isMultiple) {
2810
+ if (!keepSearchTerm) {
2811
+ module.remove.searchWidth();
2812
+ }
2813
+ if (settings.useLabels) {
2814
+ module.remove.selectedItem();
2815
+ if (value === undefined) {
2816
+ module.remove.labels($module.find(selector.label), true);
2817
+ }
2818
+ }
2819
+ } else {
2779
2820
  module.remove.activeItem();
2780
2821
  module.remove.selectedItem();
2781
- } else if (settings.useLabels) {
2782
- module.remove.selectedItem();
2783
2822
  }
2823
+ if (!$selectedItem) {
2824
+ return false;
2825
+ }
2826
+ module.debug('Setting selected menu item to', $selectedItem);
2784
2827
  // select each item
2785
2828
  $selectedItem
2786
2829
  .each(function () {
@@ -2806,8 +2849,8 @@
2806
2849
  module.save.remoteData(selectedText, selectedValue);
2807
2850
  }
2808
2851
  if (settings.useLabels) {
2809
- module.add.value(selectedValue, selectedText, $selected, preventChangeTrigger);
2810
2852
  module.add.label(selectedValue, selectedText, shouldAnimate);
2853
+ module.add.value(selectedValue, selectedText, $selected, preventChangeTrigger);
2811
2854
  module.set.activeItem($selected);
2812
2855
  module.filterActive();
2813
2856
  module.select.nextAvailable($selectedItem);
@@ -3080,6 +3123,12 @@
3080
3123
  $item.removeClass(className.active);
3081
3124
  },
3082
3125
  filteredItem: function () {
3126
+ if (settings.highlightMatches) {
3127
+ $.each($item, function (index, item) {
3128
+ var $markItem = $(item);
3129
+ $markItem.html($markItem.html().replace(/<\/?mark>/g, ''));
3130
+ });
3131
+ }
3083
3132
  if (settings.useLabels && module.has.maxSelections()) {
3084
3133
  return;
3085
3134
  }
@@ -3424,7 +3473,12 @@
3424
3473
  return $selectedMenu.hasClass(className.leftward);
3425
3474
  },
3426
3475
  clearable: function () {
3427
- return $module.hasClass(className.clearable) || settings.clearable;
3476
+ var hasClearableClass = $module.hasClass(className.clearable);
3477
+ if (!hasClearableClass && settings.clearable) {
3478
+ $module.addClass(className.clearable);
3479
+ }
3480
+
3481
+ return hasClearableClass || settings.clearable;
3428
3482
  },
3429
3483
  disabled: function () {
3430
3484
  return $module.hasClass(className.disabled);
@@ -3747,12 +3801,16 @@
3747
3801
  show: function () {
3748
3802
  module.verbose('Delaying show event to ensure user intent');
3749
3803
  clearTimeout(module.timer);
3750
- module.timer = setTimeout(function () { module.show(); }, settings.delay.show);
3804
+ module.timer = setTimeout(function () {
3805
+ module.show();
3806
+ }, settings.delay.show);
3751
3807
  },
3752
3808
  hide: function () {
3753
3809
  module.verbose('Delaying hide event to ensure user intent');
3754
3810
  clearTimeout(module.timer);
3755
- module.timer = setTimeout(function () { module.hide(); }, settings.delay.hide);
3811
+ module.timer = setTimeout(function () {
3812
+ module.hide();
3813
+ }, settings.delay.hide);
3756
3814
  },
3757
3815
  },
3758
3816
 
@@ -3785,6 +3843,7 @@
3785
3843
  return text.replace(regExp.escape, '\\$&');
3786
3844
  },
3787
3845
  htmlEntities: function (string, forceAmpersand) {
3846
+ forceAmpersand = typeof forceAmpersand === 'number' ? false : forceAmpersand;
3788
3847
  var
3789
3848
  badChars = /["'<>`]/g,
3790
3849
  shouldEscape = /["&'<>`]/,
@@ -3801,8 +3860,7 @@
3801
3860
  ;
3802
3861
  if (shouldEscape.test(string)) {
3803
3862
  string = string.replace(forceAmpersand ? /&/g : /&(?![\d#a-z]{1,12};)/gi, '&amp;');
3804
-
3805
- return string.replace(badChars, escapedChar);
3863
+ string = string.replace(badChars, escapedChar);
3806
3864
  }
3807
3865
 
3808
3866
  return string;
@@ -3878,7 +3936,9 @@
3878
3936
  });
3879
3937
  }
3880
3938
  clearTimeout(module.performance.timer);
3881
- module.performance.timer = setTimeout(function () { module.performance.display(); }, 500);
3939
+ module.performance.timer = setTimeout(function () {
3940
+ module.performance.display();
3941
+ }, 500);
3882
3942
  },
3883
3943
  display: function () {
3884
3944
  var
@@ -4005,6 +4065,7 @@
4005
4065
 
4006
4066
  match: 'both', // what to match against with search selection (both, text, or label)
4007
4067
  fullTextSearch: 'exact', // search anywhere in value (set to 'exact' to require exact matches)
4068
+ highlightMatches: false, // Whether search result should highlight matching strings
4008
4069
  ignoreDiacritics: false, // match results also if they contain diacritics of the same base character (for example searching for "a" will also match "á" or "â" or "à", etc...)
4009
4070
  hideDividers: false, // Whether to hide any divider elements (specified in selector.divider) that are sibling to any items when searched (set to true will hide all dividers, set to 'empty' will hide them when they are not followed by a visible item)
4010
4071
 
@@ -4038,6 +4099,7 @@
4038
4099
  headerDivider: true, // whether option headers should have an additional divider line underneath when converted from <select> <optgroup>
4039
4100
 
4040
4101
  collapseOnActionable: true, // whether the dropdown should collapse upon selection of an actionable item
4102
+ collapseOnClearable: false, // whether the dropdown should collapse upon clicking the clearable icon
4041
4103
 
4042
4104
  // label settings on multi-select
4043
4105
  label: {
@@ -4120,9 +4182,11 @@
4120
4182
  descriptionVertical: 'descriptionVertical', // whether description should be vertical
4121
4183
  value: 'value', // actual dropdown value
4122
4184
  text: 'text', // displayed text when selected
4185
+ data: 'data', // custom data attributes
4123
4186
  type: 'type', // type of dropdown element
4124
4187
  image: 'image', // optional image path
4125
4188
  imageClass: 'imageClass', // optional individual class for image
4189
+ alt: 'alt', // optional alt text for image
4126
4190
  icon: 'icon', // optional icon name
4127
4191
  iconClass: 'iconClass', // optional individual class for icon (for example to use flag instead)
4128
4192
  class: 'class', // optional individual class for item/header
@@ -4229,8 +4293,7 @@
4229
4293
  ;
4230
4294
  if (shouldEscape.test(string)) {
4231
4295
  string = string.replace(/&(?![\d#a-z]{1,12};)/gi, '&amp;');
4232
-
4233
- return string.replace(badChars, escapedChar);
4296
+ string = string.replace(badChars, escapedChar);
4234
4297
  }
4235
4298
 
4236
4299
  return string;
@@ -4265,9 +4328,21 @@
4265
4328
  $.each(values, function (index, option) {
4266
4329
  var
4267
4330
  itemType = option[fields.type] || 'item',
4268
- isMenu = itemType.indexOf('menu') !== -1
4331
+ isMenu = itemType.indexOf('menu') !== -1,
4332
+ maybeData = '',
4333
+ dataObject = option[fields.data]
4269
4334
  ;
4270
-
4335
+ if (dataObject) {
4336
+ var dataKey,
4337
+ dataKeyEscaped
4338
+ ;
4339
+ for (dataKey in dataObject) {
4340
+ dataKeyEscaped = String(dataKey).replace(/\W/g, '');
4341
+ if (Object.prototype.hasOwnProperty.call(dataObject, dataKey) && ['text', 'value'].indexOf(dataKeyEscaped.toLowerCase()) === -1) {
4342
+ maybeData += ' data-' + dataKeyEscaped + '="' + deQuote(String(dataObject[dataKey])) + '"';
4343
+ }
4344
+ }
4345
+ }
4271
4346
  if (itemType === 'item' || isMenu) {
4272
4347
  var
4273
4348
  maybeText = option[fields.text]
@@ -4284,12 +4359,12 @@
4284
4359
  : '',
4285
4360
  hasDescription = escape(option[fields.description] || '', preserveHTML) !== ''
4286
4361
  ;
4287
- html += '<div class="' + deQuote(maybeActionable + maybeDisabled + maybeDescriptionVertical + (option[fields.class] || className.item)) + '" data-value="' + deQuote(option[fields.value], true) + '"' + maybeText + '>';
4362
+ html += '<div class="' + deQuote(maybeActionable + maybeDisabled + maybeDescriptionVertical + (option[fields.class] || className.item)) + '" data-value="' + deQuote(option[fields.value], true) + '"' + maybeText + maybeData + '>';
4288
4363
  if (isMenu) {
4289
4364
  html += '<i class="' + (itemType.indexOf('left') !== -1 ? 'left' : '') + ' dropdown icon"></i>';
4290
4365
  }
4291
4366
  if (option[fields.image]) {
4292
- html += '<img class="' + deQuote(option[fields.imageClass] || className.image) + '" src="' + deQuote(option[fields.image]) + '">';
4367
+ html += '<img class="' + deQuote(option[fields.imageClass] || className.image) + '" src="' + deQuote(option[fields.image]) + (option[fields.alt] ? '" alt="' + deQuote(option[fields.alt]) : '') + '">';
4293
4368
  }
4294
4369
  if (option[fields.icon]) {
4295
4370
  html += '<i class="' + deQuote(option[fields.icon] + ' ' + (option[fields.iconClass] || className.icon)) + '"></i>';