add indeterminate checkbox support

This commit is contained in:
Mark Otto 2015-01-01 12:01:55 -08:00
parent 82403407d8
commit 401ace65f4
3 changed files with 24 additions and 9 deletions

View File

@ -10,7 +10,6 @@
*/
/* global ZeroClipboard */
/* global SimpleJekyllSearch */
!function ($) {
'use strict';
@ -102,6 +101,9 @@
$(this).prev('.progress-striped').toggleClass('progress-animated')
})
// Custom indeterminate checkbox
$('.bs-example-indeterminate input').prop('indeterminate', true)
// Config ZeroClipboard
ZeroClipboard.config({
moviePath: '/assets/flash/ZeroClipboard.swf',

View File

@ -29,6 +29,22 @@ In the checked states, we use **base64 embedded SVG icons** from [Open Iconic](h
</label>
{% endexample %}
Custom checkboxes can also utilize the `:indeterminate` pseudo class.
<div class="bs-example bs-example-indeterminate">
<label class="c-input c-checkbox">
<input type="checkbox">
<span class="c-indicator"></span>
Check this custom checkbox
</label>
</div>
**Heads up!** You'll need to set this state manually via JavaScript as there is no available HTML attribute for specifying it. If you're using jQuery, something like this should suffice:
{% highlight js %}
$('.your-checkbox').prop('indeterminate', true)
{% endhighlight %}
### Radios
{% example html %}

View File

@ -73,6 +73,11 @@
input:checked ~ .c-indicator {
background-image: url();
}
input:indeterminate ~ .c-indicator {
background-color: #0074d9;
background-image: url();
}
}
// Radios
@ -89,14 +94,6 @@
}
}
// Alternately, use another character
.control-x input:checked ~ .c-indicator {
background-image: url();
}
.control-dash input:checked ~ .c-indicator {
background-image: url();
}
// Layout options
//
// By default radios and checkboxes are `inline-block` with no additional spacing