fomantic-ui 2.9.3-beta.3 → 2.9.3-beta.30

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 (263) hide show
  1. package/.github/workflows/ci.yml +2 -2
  2. package/dist/components/accordion.css +1 -1
  3. package/dist/components/accordion.js +2 -2
  4. package/dist/components/accordion.min.css +1 -1
  5. package/dist/components/accordion.min.js +2 -2
  6. package/dist/components/ad.css +1 -1
  7. package/dist/components/ad.min.css +1 -1
  8. package/dist/components/api.js +3 -3
  9. package/dist/components/api.min.js +2 -2
  10. package/dist/components/breadcrumb.css +1 -1
  11. package/dist/components/breadcrumb.min.css +1 -1
  12. package/dist/components/button.css +2 -2
  13. package/dist/components/button.min.css +2 -2
  14. package/dist/components/calendar.css +1 -1
  15. package/dist/components/calendar.js +2 -2
  16. package/dist/components/calendar.min.css +1 -1
  17. package/dist/components/calendar.min.js +2 -2
  18. package/dist/components/card.css +1 -1
  19. package/dist/components/card.min.css +1 -1
  20. package/dist/components/checkbox.css +1 -1
  21. package/dist/components/checkbox.js +2 -2
  22. package/dist/components/checkbox.min.css +1 -1
  23. package/dist/components/checkbox.min.js +2 -2
  24. package/dist/components/comment.css +6 -1
  25. package/dist/components/comment.min.css +2 -2
  26. package/dist/components/container.css +62 -1
  27. package/dist/components/container.min.css +2 -2
  28. package/dist/components/dimmer.css +3 -3
  29. package/dist/components/dimmer.js +2 -2
  30. package/dist/components/dimmer.min.css +2 -2
  31. package/dist/components/dimmer.min.js +2 -2
  32. package/dist/components/divider.css +1 -1
  33. package/dist/components/divider.min.css +1 -1
  34. package/dist/components/dropdown.css +42 -4
  35. package/dist/components/dropdown.js +18 -15
  36. package/dist/components/dropdown.min.css +2 -2
  37. package/dist/components/dropdown.min.js +2 -2
  38. package/dist/components/embed.css +1 -1
  39. package/dist/components/embed.js +2 -2
  40. package/dist/components/embed.min.css +1 -1
  41. package/dist/components/embed.min.js +2 -2
  42. package/dist/components/emoji.css +1 -1
  43. package/dist/components/emoji.min.css +1 -1
  44. package/dist/components/feed.css +1 -1
  45. package/dist/components/feed.min.css +1 -1
  46. package/dist/components/flag.css +3 -2
  47. package/dist/components/flag.min.css +2 -2
  48. package/dist/components/flyout.css +1 -1
  49. package/dist/components/flyout.js +5 -3
  50. package/dist/components/flyout.min.css +1 -1
  51. package/dist/components/flyout.min.js +2 -2
  52. package/dist/components/form.css +53 -20
  53. package/dist/components/form.js +54 -28
  54. package/dist/components/form.min.css +2 -2
  55. package/dist/components/form.min.js +2 -2
  56. package/dist/components/grid.css +107 -107
  57. package/dist/components/grid.min.css +2 -2
  58. package/dist/components/header.css +1 -1
  59. package/dist/components/header.min.css +1 -1
  60. package/dist/components/icon.css +1 -1
  61. package/dist/components/icon.min.css +1 -1
  62. package/dist/components/image.css +1 -1
  63. package/dist/components/image.min.css +1 -1
  64. package/dist/components/input.css +3 -27
  65. package/dist/components/input.min.css +2 -2
  66. package/dist/components/item.css +6 -1
  67. package/dist/components/item.min.css +2 -2
  68. package/dist/components/label.css +21 -2
  69. package/dist/components/label.min.css +2 -2
  70. package/dist/components/list.css +13 -13
  71. package/dist/components/list.min.css +2 -2
  72. package/dist/components/loader.css +282 -282
  73. package/dist/components/loader.min.css +2 -2
  74. package/dist/components/menu.css +13 -7
  75. package/dist/components/menu.min.css +2 -2
  76. package/dist/components/message.css +1 -1
  77. package/dist/components/message.min.css +1 -1
  78. package/dist/components/modal.css +10 -3
  79. package/dist/components/modal.js +10 -10
  80. package/dist/components/modal.min.css +2 -2
  81. package/dist/components/modal.min.js +2 -2
  82. package/dist/components/nag.css +1 -1
  83. package/dist/components/nag.js +3 -3
  84. package/dist/components/nag.min.css +1 -1
  85. package/dist/components/nag.min.js +2 -2
  86. package/dist/components/placeholder.css +1 -1
  87. package/dist/components/placeholder.min.css +1 -1
  88. package/dist/components/popup.css +41 -40
  89. package/dist/components/popup.js +11 -9
  90. package/dist/components/popup.min.css +2 -2
  91. package/dist/components/popup.min.js +2 -2
  92. package/dist/components/progress.css +1 -1
  93. package/dist/components/progress.js +2 -2
  94. package/dist/components/progress.min.css +1 -1
  95. package/dist/components/progress.min.js +2 -2
  96. package/dist/components/rail.css +1 -1
  97. package/dist/components/rail.min.css +1 -1
  98. package/dist/components/rating.css +1 -1
  99. package/dist/components/rating.js +2 -2
  100. package/dist/components/rating.min.css +1 -1
  101. package/dist/components/rating.min.js +2 -2
  102. package/dist/components/reset.css +1 -1
  103. package/dist/components/reset.min.css +1 -1
  104. package/dist/components/reveal.css +1 -1
  105. package/dist/components/reveal.min.css +1 -1
  106. package/dist/components/search.css +26 -1
  107. package/dist/components/search.js +5 -4
  108. package/dist/components/search.min.css +2 -2
  109. package/dist/components/search.min.js +2 -2
  110. package/dist/components/segment.css +159 -33
  111. package/dist/components/segment.min.css +2 -2
  112. package/dist/components/shape.css +1 -1
  113. package/dist/components/shape.js +2 -2
  114. package/dist/components/shape.min.css +1 -1
  115. package/dist/components/shape.min.js +2 -2
  116. package/dist/components/sidebar.css +1 -1
  117. package/dist/components/sidebar.js +2 -2
  118. package/dist/components/sidebar.min.css +1 -1
  119. package/dist/components/sidebar.min.js +2 -2
  120. package/dist/components/site.css +1 -1
  121. package/dist/components/site.js +2 -2
  122. package/dist/components/site.min.css +1 -1
  123. package/dist/components/site.min.js +2 -2
  124. package/dist/components/slider.css +1 -1
  125. package/dist/components/slider.js +123 -27
  126. package/dist/components/slider.min.css +1 -1
  127. package/dist/components/slider.min.js +2 -2
  128. package/dist/components/state.js +2 -2
  129. package/dist/components/state.min.js +2 -2
  130. package/dist/components/statistic.css +1 -1
  131. package/dist/components/statistic.min.css +1 -1
  132. package/dist/components/step.css +1 -1
  133. package/dist/components/step.min.css +1 -1
  134. package/dist/components/sticky.css +1 -1
  135. package/dist/components/sticky.js +2 -2
  136. package/dist/components/sticky.min.css +1 -1
  137. package/dist/components/sticky.min.js +2 -2
  138. package/dist/components/tab.css +1 -1
  139. package/dist/components/tab.js +2 -2
  140. package/dist/components/tab.min.css +1 -1
  141. package/dist/components/tab.min.js +2 -2
  142. package/dist/components/table.css +65 -1
  143. package/dist/components/table.min.css +2 -2
  144. package/dist/components/text.css +1 -1
  145. package/dist/components/text.min.css +1 -1
  146. package/dist/components/toast.css +6 -1
  147. package/dist/components/toast.js +2 -2
  148. package/dist/components/toast.min.css +2 -2
  149. package/dist/components/toast.min.js +2 -2
  150. package/dist/components/transition.css +1 -1
  151. package/dist/components/transition.js +3 -3
  152. package/dist/components/transition.min.css +1 -1
  153. package/dist/components/transition.min.js +2 -2
  154. package/dist/components/visibility.js +2 -2
  155. package/dist/components/visibility.min.js +2 -2
  156. package/dist/semantic.css +1077 -592
  157. package/dist/semantic.js +266 -136
  158. package/dist/semantic.min.css +2 -2
  159. package/dist/semantic.min.js +2 -2
  160. package/package.json +1 -1
  161. package/src/definitions/behaviors/api.js +2 -2
  162. package/src/definitions/behaviors/form.js +53 -27
  163. package/src/definitions/behaviors/state.js +1 -1
  164. package/src/definitions/behaviors/visibility.js +1 -1
  165. package/src/definitions/collections/breadcrumb.less +2 -1
  166. package/src/definitions/collections/form.less +27 -13
  167. package/src/definitions/collections/grid.less +108 -107
  168. package/src/definitions/collections/menu.less +31 -23
  169. package/src/definitions/collections/message.less +2 -1
  170. package/src/definitions/collections/table.less +68 -1
  171. package/src/definitions/elements/button.less +4 -2
  172. package/src/definitions/elements/container.less +65 -1
  173. package/src/definitions/elements/divider.less +2 -1
  174. package/src/definitions/elements/emoji.less +2 -1
  175. package/src/definitions/elements/flag.less +2 -1
  176. package/src/definitions/elements/header.less +2 -1
  177. package/src/definitions/elements/icon.less +2 -1
  178. package/src/definitions/elements/image.less +2 -1
  179. package/src/definitions/elements/input.less +4 -3
  180. package/src/definitions/elements/label.less +23 -2
  181. package/src/definitions/elements/list.less +14 -13
  182. package/src/definitions/elements/loader.less +73 -72
  183. package/src/definitions/elements/placeholder.less +2 -1
  184. package/src/definitions/elements/rail.less +2 -1
  185. package/src/definitions/elements/reveal.less +2 -1
  186. package/src/definitions/elements/segment.less +112 -14
  187. package/src/definitions/elements/step.less +2 -1
  188. package/src/definitions/elements/text.less +2 -1
  189. package/src/definitions/globals/reset.less +2 -1
  190. package/src/definitions/globals/site.js +1 -1
  191. package/src/definitions/globals/site.less +2 -1
  192. package/src/definitions/modules/accordion.js +1 -1
  193. package/src/definitions/modules/accordion.less +2 -1
  194. package/src/definitions/modules/calendar.js +1 -1
  195. package/src/definitions/modules/calendar.less +2 -1
  196. package/src/definitions/modules/checkbox.js +1 -1
  197. package/src/definitions/modules/checkbox.less +2 -1
  198. package/src/definitions/modules/dimmer.js +1 -1
  199. package/src/definitions/modules/dimmer.less +4 -3
  200. package/src/definitions/modules/dropdown.js +17 -14
  201. package/src/definitions/modules/dropdown.less +55 -4
  202. package/src/definitions/modules/embed.js +1 -1
  203. package/src/definitions/modules/embed.less +2 -1
  204. package/src/definitions/modules/flyout.js +4 -2
  205. package/src/definitions/modules/flyout.less +2 -1
  206. package/src/definitions/modules/modal.js +9 -9
  207. package/src/definitions/modules/modal.less +13 -3
  208. package/src/definitions/modules/nag.js +2 -2
  209. package/src/definitions/modules/nag.less +3 -1
  210. package/src/definitions/modules/popup.js +10 -8
  211. package/src/definitions/modules/popup.less +42 -39
  212. package/src/definitions/modules/progress.js +1 -1
  213. package/src/definitions/modules/progress.less +2 -1
  214. package/src/definitions/modules/rating.js +1 -1
  215. package/src/definitions/modules/rating.less +2 -1
  216. package/src/definitions/modules/search.js +4 -3
  217. package/src/definitions/modules/search.less +33 -1
  218. package/src/definitions/modules/shape.js +1 -1
  219. package/src/definitions/modules/shape.less +2 -1
  220. package/src/definitions/modules/sidebar.js +1 -1
  221. package/src/definitions/modules/sidebar.less +2 -1
  222. package/src/definitions/modules/slider.js +122 -26
  223. package/src/definitions/modules/slider.less +2 -1
  224. package/src/definitions/modules/sticky.js +1 -1
  225. package/src/definitions/modules/sticky.less +2 -1
  226. package/src/definitions/modules/tab.js +1 -1
  227. package/src/definitions/modules/tab.less +2 -1
  228. package/src/definitions/modules/toast.js +1 -1
  229. package/src/definitions/modules/toast.less +9 -1
  230. package/src/definitions/modules/transition.js +2 -2
  231. package/src/definitions/modules/transition.less +2 -1
  232. package/src/definitions/views/ad.less +2 -1
  233. package/src/definitions/views/card.less +2 -1
  234. package/src/definitions/views/comment.less +9 -1
  235. package/src/definitions/views/feed.less +2 -1
  236. package/src/definitions/views/item.less +9 -1
  237. package/src/definitions/views/statistic.less +2 -1
  238. package/src/overrides.less +7 -0
  239. package/src/theme.less +7 -6
  240. package/src/themes/amazon/elements/button.variables +5 -1
  241. package/src/themes/bootstrap3/elements/button.variables +5 -1
  242. package/src/themes/chubby/elements/header.variables +6 -1
  243. package/src/themes/default/collections/message.variables +3 -9
  244. package/src/themes/default/collections/table.variables +3 -0
  245. package/src/themes/default/elements/button.variables +1 -3
  246. package/src/themes/default/elements/container.variables +3 -0
  247. package/src/themes/default/elements/flag.variables +1 -1
  248. package/src/themes/default/elements/label.variables +5 -0
  249. package/src/themes/default/elements/segment.variables +8 -0
  250. package/src/themes/default/globals/site.variables +20 -1
  251. package/src/themes/default/globals/variation.variables +10 -1
  252. package/src/themes/default/modules/dropdown.variables +6 -0
  253. package/src/themes/default/modules/modal.variables +4 -0
  254. package/src/themes/default/modules/popup.variables +3 -1
  255. package/src/themes/default/modules/search.variables +3 -0
  256. package/src/themes/default/modules/toast.variables +1 -0
  257. package/src/themes/default/views/card.variables +4 -12
  258. package/src/themes/github/elements/button.variables +5 -1
  259. package/src/themes/twitter/elements/button.variables +5 -1
  260. package/tasks/admin/distributions/create.js +8 -3
  261. package/tasks/config/project/install.js +3 -0
  262. package/tasks/config/tasks.js +1 -8
  263. package/tasks/install.js +15 -5
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "fomantic-ui",
3
- "version": "2.9.3-beta.3+880333c",
3
+ "version": "2.9.3-beta.30+139eccc",
4
4
  "description": "Fomantic empowers designers and developers by creating a shared vocabulary for UI.",
5
5
  "keywords": [
6
6
  "fomantic-ui",
@@ -646,7 +646,7 @@
646
646
  module.debug('Adding error state');
647
647
  module.set.error();
648
648
  if (module.should.removeError()) {
649
- setTimeout(module.remove.error, settings.errorDuration);
649
+ setTimeout(function () { module.remove.error(); }, settings.errorDuration);
650
650
  }
651
651
  }
652
652
  module.debug('API Request failed', errorMessage, xhr);
@@ -970,7 +970,7 @@
970
970
  });
971
971
  }
972
972
  clearTimeout(module.performance.timer);
973
- module.performance.timer = setTimeout(module.performance.display, 500);
973
+ module.performance.timer = setTimeout(function () { module.performance.display(); }, 500);
974
974
  },
975
975
  display: function () {
976
976
  var
@@ -77,6 +77,7 @@
77
77
  initialize: function () {
78
78
  // settings grabbed at run time
79
79
  module.get.settings();
80
+ $module.addClass(className.initial);
80
81
  if (methodInvoked) {
81
82
  if (instance === undefined) {
82
83
  module.instantiate();
@@ -130,10 +131,13 @@
130
131
  module.bindEvents();
131
132
  },
132
133
 
133
- submit: function () {
134
+ submit: function (event) {
134
135
  module.verbose('Submitting form', $module);
135
136
  submitting = true;
136
137
  $module.trigger('submit');
138
+ if (event) {
139
+ event.preventDefault();
140
+ }
137
141
  },
138
142
 
139
143
  attachEvents: function (selector, action) {
@@ -159,6 +163,7 @@
159
163
  .on('click' + eventNamespace, selector.reset, module.reset)
160
164
  .on('click' + eventNamespace, selector.clear, module.clear)
161
165
  ;
166
+ $field.on('invalid' + eventNamespace, module.event.field.invalid);
162
167
  if (settings.keyboardShortcuts) {
163
168
  $module.on('keydown' + eventNamespace, selector.field, module.event.field.keydown);
164
169
  }
@@ -274,8 +279,12 @@
274
279
  var
275
280
  allValid = true
276
281
  ;
277
- $.each(validation, function (fieldName, field) {
278
- if (!module.validate.field(field, fieldName, true)) {
282
+ $field.each(function (index, el) {
283
+ var $el = $(el),
284
+ validation = module.get.validation($el) || {},
285
+ identifier = module.get.identifier(validation, $el)
286
+ ;
287
+ if (!module.validate.field(validation, identifier, true)) {
279
288
  allValid = false;
280
289
  }
281
290
  });
@@ -431,9 +440,8 @@
431
440
  if (!event.ctrlKey && key === keyCode.enter && isInput && !isInDropdown && !isCheckbox) {
432
441
  if (!keyHeldDown) {
433
442
  $field.one('keyup' + eventNamespace, module.event.field.keyup);
434
- module.submit();
443
+ module.submit(event);
435
444
  module.debug('Enter pressed on input submitting form');
436
- event.preventDefault();
437
445
  }
438
446
  keyHeldDown = true;
439
447
  }
@@ -441,15 +449,18 @@
441
449
  keyup: function () {
442
450
  keyHeldDown = false;
443
451
  },
452
+ invalid: function (event) {
453
+ event.preventDefault();
454
+ },
444
455
  blur: function (event) {
445
456
  var
446
457
  $field = $(this),
447
- $fieldGroup = $field.closest($group),
448
- validationRules = module.get.validation($field)
458
+ validationRules = module.get.validation($field) || {},
459
+ identifier = module.get.identifier(validationRules, $field)
449
460
  ;
450
- if (validationRules && (settings.on === 'blur' || ($fieldGroup.hasClass(className.error) && settings.revalidate))) {
461
+ if (settings.on === 'blur' || (!$module.hasClass(className.initial) && settings.revalidate)) {
451
462
  module.debug('Revalidating field', $field, validationRules);
452
- module.validate.field(validationRules);
463
+ module.validate.field(validationRules, identifier);
453
464
  if (!settings.inline) {
454
465
  module.validate.form(false, true);
455
466
  }
@@ -458,14 +469,14 @@
458
469
  change: function (event) {
459
470
  var
460
471
  $field = $(this),
461
- $fieldGroup = $field.closest($group),
462
- validationRules = module.get.validation($field)
472
+ validationRules = module.get.validation($field) || {},
473
+ identifier = module.get.identifier(validationRules, $field)
463
474
  ;
464
- if (validationRules && (settings.on === 'change' || ($fieldGroup.hasClass(className.error) && settings.revalidate))) {
475
+ if (settings.on === 'change' || (!$module.hasClass(className.initial) && settings.revalidate)) {
465
476
  clearTimeout(module.timer);
466
477
  module.timer = setTimeout(function () {
467
478
  module.debug('Revalidating field', $field, validationRules);
468
- module.validate.field(validationRules);
479
+ module.validate.field(validationRules, identifier);
469
480
  if (!settings.inline) {
470
481
  module.validate.form(false, true);
471
482
  }
@@ -531,6 +542,9 @@
531
542
 
532
543
  return fullFields;
533
544
  },
545
+ identifier: function (validation, $el) {
546
+ return validation.identifier || $el.attr('id') || $el.attr('name') || $el.data(metadata.validate);
547
+ },
534
548
  prompt: function (rule, field) {
535
549
  var
536
550
  ruleName = module.get.ruleName(rule),
@@ -643,7 +657,7 @@
643
657
  var $field = typeof identifier === 'string'
644
658
  ? module.get.field(identifier)
645
659
  : identifier,
646
- $label = $field.closest(selector.group).find('label').eq(0)
660
+ $label = $field.closest(selector.group).find('label:not(:empty)').eq(0)
647
661
  ;
648
662
 
649
663
  return $label.length === 1
@@ -974,7 +988,7 @@
974
988
  $message.empty();
975
989
  },
976
990
  states: function () {
977
- $module.removeClass(className.error).removeClass(className.success);
991
+ $module.removeClass(className.error).removeClass(className.success).addClass(className.initial);
978
992
  if (!settings.inline) {
979
993
  module.remove.errors();
980
994
  }
@@ -1211,7 +1225,7 @@
1211
1225
  return rule.type === 'empty';
1212
1226
  }) !== 0
1213
1227
  : false,
1214
- identifier = validation.identifier || $el.attr('id') || $el.attr('name') || $el.data(metadata.validate)
1228
+ identifier = module.get.identifier(validation, $el)
1215
1229
  ;
1216
1230
  if (isRequired && !isDisabled && !hasEmptyRule && identifier !== undefined) {
1217
1231
  if (isCheckbox) {
@@ -1243,7 +1257,7 @@
1243
1257
  if (keyHeldDown) {
1244
1258
  return false;
1245
1259
  }
1246
-
1260
+ $module.removeClass(className.initial);
1247
1261
  // reset errors
1248
1262
  formErrors = [];
1249
1263
  if (module.determine.isValid()) {
@@ -1315,13 +1329,25 @@
1315
1329
  ? module.get.field(field.depends)
1316
1330
  : false,
1317
1331
  fieldValid = true,
1318
- fieldErrors = []
1332
+ fieldErrors = [],
1333
+ isDisabled = $field.filter(':not(:disabled)').length === 0,
1334
+ validationMessage = $field[0].validationMessage,
1335
+ errorLimit
1319
1336
  ;
1320
1337
  if (!field.identifier) {
1321
1338
  module.debug('Using field name as identifier', identifier);
1322
1339
  field.identifier = identifier;
1323
1340
  }
1324
- var isDisabled = $field.filter(':not(:disabled)').length === 0;
1341
+ if (validationMessage) {
1342
+ module.debug('Field is natively invalid', identifier);
1343
+ fieldErrors.push(validationMessage);
1344
+ fieldValid = false;
1345
+ if (showErrors) {
1346
+ $field.closest($group).addClass(className.error);
1347
+ }
1348
+ } else if (showErrors) {
1349
+ $field.closest($group).removeClass(className.error);
1350
+ }
1325
1351
  if (isDisabled) {
1326
1352
  module.debug('Field is disabled. Skipping', identifier);
1327
1353
  } else if (field.optional && module.is.blank($field)) {
@@ -1329,11 +1355,9 @@
1329
1355
  } else if (field.depends && module.is.empty($dependsField)) {
1330
1356
  module.debug('Field depends on another value that is not present or empty. Skipping', $dependsField);
1331
1357
  } else if (field.rules !== undefined) {
1332
- if (showErrors) {
1333
- $field.closest($group).removeClass(className.error);
1334
- }
1358
+ errorLimit = field.errorLimit || settings.errorLimit;
1335
1359
  $.each(field.rules, function (index, rule) {
1336
- if (module.has.field(identifier)) {
1360
+ if (module.has.field(identifier) && (!errorLimit || fieldErrors.length < errorLimit)) {
1337
1361
  var invalidFields = module.validate.rule(field, rule, true) || [];
1338
1362
  if (invalidFields.length > 0) {
1339
1363
  module.debug('Field is invalid', identifier, rule.type);
@@ -1348,7 +1372,7 @@
1348
1372
  }
1349
1373
  if (fieldValid) {
1350
1374
  if (showErrors) {
1351
- module.remove.prompt(identifier, fieldErrors);
1375
+ module.remove.prompt(identifier);
1352
1376
  settings.onValid.call($field);
1353
1377
  }
1354
1378
  } else {
@@ -1470,7 +1494,7 @@
1470
1494
  });
1471
1495
  }
1472
1496
  clearTimeout(module.performance.timer);
1473
- module.performance.timer = setTimeout(module.performance.display, 500);
1497
+ module.performance.timer = setTimeout(function () { module.performance.display(); }, 500);
1474
1498
  },
1475
1499
  display: function () {
1476
1500
  var
@@ -1585,6 +1609,7 @@
1585
1609
  preventLeaving: false,
1586
1610
  errorFocus: true,
1587
1611
  dateHandling: 'date', // 'date', 'input', 'formatter'
1612
+ errorLimit: 0,
1588
1613
 
1589
1614
  onValid: function () {},
1590
1615
  onInvalid: function () {},
@@ -1638,8 +1663,8 @@
1638
1663
  isExactly: '{name} must be exactly "{ruleValue}"',
1639
1664
  not: '{name} cannot be set to "{ruleValue}"',
1640
1665
  notExactly: '{name} cannot be set to exactly "{ruleValue}"',
1641
- contain: '{name} must contain "{ruleValue}"',
1642
- containExactly: '{name} must contain exactly "{ruleValue}"',
1666
+ contains: '{name} must contain "{ruleValue}"',
1667
+ containsExactly: '{name} must contain exactly "{ruleValue}"',
1643
1668
  doesntContain: '{name} cannot contain "{ruleValue}"',
1644
1669
  doesntContainExactly: '{name} cannot contain exactly "{ruleValue}"',
1645
1670
  minLength: '{name} must be at least {ruleValue} characters',
@@ -1673,6 +1698,7 @@
1673
1698
  },
1674
1699
 
1675
1700
  className: {
1701
+ initial: 'initial',
1676
1702
  error: 'error',
1677
1703
  label: 'ui basic red pointing prompt label',
1678
1704
  pressed: 'down',
@@ -482,7 +482,7 @@
482
482
  });
483
483
  }
484
484
  clearTimeout(module.performance.timer);
485
- module.performance.timer = setTimeout(module.performance.display, 500);
485
+ module.performance.timer = setTimeout(function () { module.performance.display(); }, 500);
486
486
  },
487
487
  display: function () {
488
488
  var
@@ -1088,7 +1088,7 @@
1088
1088
  });
1089
1089
  }
1090
1090
  clearTimeout(module.performance.timer);
1091
- module.performance.timer = setTimeout(module.performance.display, 500);
1091
+ module.performance.timer = setTimeout(function () { module.performance.display(); }, 500);
1092
1092
  },
1093
1093
  display: function () {
1094
1094
  var
@@ -115,4 +115,5 @@
115
115
  });
116
116
  }
117
117
 
118
- .loadUIOverrides();
118
+ // stylelint-disable no-invalid-position-at-import-rule
119
+ @import (multiple, optional) "../../overrides.less";
@@ -527,6 +527,12 @@
527
527
  color: @c;
528
528
  }
529
529
 
530
+ @supports selector(:has(.f)) {
531
+ .ui.form .fields:has(.@{state}) > label {
532
+ color: @c;
533
+ }
534
+ }
535
+
530
536
  .ui.form .fields.@{state} .field .ui.label,
531
537
  .ui.form .field.@{state} .ui.label {
532
538
  background-color: @lbg;
@@ -579,14 +585,7 @@
579
585
  box-shadow: @formStates[@@state][boxShadow];
580
586
  }
581
587
  & when (@state=error) and (@variationFormInvalid) {
582
- .ui.form .field input:not(:placeholder-shown):invalid {
583
- color: @c;
584
- background: @bg;
585
- border-color: @formStates[@@state][borderColor];
586
- border-radius: @formStates[@@state][borderRadius];
587
- box-shadow: @formStates[@@state][boxShadow];
588
- }
589
- .ui.form .field input:not(:-ms-input-placeholder):invalid when (@supportIE) {
588
+ .ui.form:not(.initial) .field input:invalid {
590
589
  color: @c;
591
590
  background: @bg;
592
591
  border-color: @formStates[@@state][borderColor];
@@ -729,6 +728,12 @@
729
728
  .ui.inverted.form .@{state}.field label {
730
729
  color: @lbg;
731
730
  }
731
+
732
+ @supports selector(:has(.f)) {
733
+ .ui.inverted.form .fields:has(.@{state}) > label {
734
+ color: @lbg;
735
+ }
736
+ }
732
737
  }
733
738
  });
734
739
  }
@@ -804,10 +809,11 @@
804
809
  Required Field
805
810
  --------------------- */
806
811
 
807
- .ui.form .required.fields:not(.grouped) > .field > label::after,
812
+ .ui.form .required.fields:not(.grouped):not(.inline) > .field > label::after,
813
+ .ui.form .required.fields.inline > label::after,
808
814
  .ui.form .required.fields.grouped > label::after,
809
815
  .ui.form .required.field > label::after,
810
- .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
816
+ .ui.form .required.fields:not(.grouped):not(.inline) > .field > .checkbox::after,
811
817
  .ui.form .required.field > .checkbox::after,
812
818
  .ui.form label.required::after {
813
819
  margin: @requiredMargin;
@@ -815,7 +821,8 @@
815
821
  color: @requiredColor;
816
822
  }
817
823
 
818
- .ui.form .required.fields:not(.grouped) > .field > label::after,
824
+ .ui.form .required.fields:not(.grouped):not(.inline) > .field > label::after,
825
+ .ui.form .required.fields.inline > label::after,
819
826
  .ui.form .required.fields.grouped > label::after,
820
827
  .ui.form .required.field > label::after,
821
828
  .ui.form label.required::after {
@@ -823,7 +830,7 @@
823
830
  vertical-align: top;
824
831
  }
825
832
 
826
- .ui.form .required.fields:not(.grouped) > .field > .checkbox::after,
833
+ .ui.form .required.fields:not(.grouped):not(.inline) > .field > .checkbox::after,
827
834
  .ui.form .required.field > .checkbox::after {
828
835
  position: absolute;
829
836
  top: 0;
@@ -831,6 +838,12 @@
831
838
  }
832
839
  }
833
840
 
841
+ .ui.ui.ui.ui.form .fields > label:empty::after,
842
+ .ui.ui.ui.ui.form .field > label:empty::after {
843
+ content: " ";
844
+ display: inline-block;
845
+ }
846
+
834
847
  /*******************************
835
848
  Variations
836
849
  *******************************/
@@ -1160,4 +1173,5 @@
1160
1173
  });
1161
1174
  }
1162
1175
 
1163
- .loadUIOverrides();
1176
+ // stylelint-disable no-invalid-position-at-import-rule
1177
+ @import (multiple, optional) "../../overrides.less";