/* ------------------------------------------------------------------------------
*
*  # Form related components
*
*  Overrides for bootstrap form related components
*
*  Version: 1.1
*  Latest update: Mar 10, 2015
*
* ---------------------------------------------------------------------------- */


/* Form controls
----------------------------------*/

// Normalize non-controls
// -------------------------

// Legend
legend {
    font-size: @font-size-small;
    padding-top: (@line-height-computed / 2);
    padding-bottom: (@line-height-computed / 2);
    text-transform: uppercase;

    // Remove top padding in first items
    fieldset:first-child & {
        &:first-child {
            padding-top: 0;
        }
    }

    // Control arrow
    .control-arrow {
        float: right;
        color: @text-muted;

        &:hover {
            color: @text-color;
        }
    }
}

// Label
label {
    margin-bottom: @padding-base-vertical;
    font-weight: 400;
}


// Normalize form controls
// -------------------------

// Multiple select
select[multiple],
select[size] {
    height: 200px;
    padding: @padding-base-vertical;

    // Option
    option {
        padding: @padding-base-vertical @padding-base-horizontal;
        border-radius: @input-border-radius;

        + option {
            margin-top: 1px;
        }
    }
}

// Focus for file, radio, and checkbox
input[type="file"]:focus,
input[type="radio"]:focus,
input[type="checkbox"]:focus {
    outline: 0;
}


// Common form controls
// -------------------------

.form-control {
    .box-shadow(none);

    // Remove outline and shadow on focus
    &:focus {
        outline: 0;
        .box-shadow(none);
    }
    &[class*=bg-]:focus {
        border-color: transparent;
    }

    // Placeholder in colored input
    &[class*=bg-] {
        .placeholder(@input-placeholder-light);
    }
}


// Form controls options
// -------------------------

// Rounded input
.input-rounded {
    border-radius: 100px;
}

// Roundless input
.input-roundless {
    border-radius: 0;
}

// Transparent input
.form-control-unstyled {
    padding: 0;
    border: 0;
    background-color: transparent;
}

// Remove inputs shadow in mobile browsers 
input[type="text"],
input[type="password"],
input[type="search"],
input[type="email"],
input[type="number"],
input[type="datetime"],
input[type="datetime-local"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="week"],
input[type="url"],
input[type="tel"],
textarea {
    -webkit-appearance: none;
}



/* Form components
----------------------------------*/

// Form groups
// -------------------------

.form-group {
    margin-bottom: @form-group-margin-bottom;
    position: relative;

    // Form group nesting
    .form-group {
        &:last-child {
            margin-bottom: 0;
        }
    }

    // Vertical spacing for stacked columns
    //
    // When nested form groups stack, add top margin for each column, except first.
    @media (max-width: @screen-sm-max) {
        div[class*="col-md-"]:not(.control-label) + div[class*="col-md-"] {
            margin-top: @form-group-margin-bottom;
        }
    }
    @media (max-width: @screen-md-max) {
        div[class*="col-lg-"]:not(.control-label) + div[class*="col-lg-"] {
            margin-top: @form-group-margin-bottom;
        }
    }
    @media (max-width: @screen-xs-max) {
        div[class*="col-sm-"]:not(.control-label) + div[class*="col-sm-"] {
            margin-top: @form-group-margin-bottom;
        }
    }
}


// Floating labels
// -------------------------

.form-group-material {

    // Labels
    > .control-label {
        position: relative;
        top: @padding-base-vertical;
        .opacity(0);

        // Top spacing for contextual icon
        ~ .form-control-feedback {
            top: (@line-height-computed + @padding-base-vertical);
        }
    }

    // Display label
    > .control-label.is-visible {
        top: 0;
        .opacity(1);
    }

    // Label animation
    > .control-label.animate {
        .transition(all linear 0.1s);
    }
}


// Checkboxes and radios
// -------------------------

// Containers
.radio,
.checkbox {

    // Make them vertically centered depending on the base input height
    margin-top: ((@input-height-base - @line-height-computed) / 2);
    margin-bottom: ((@input-height-base - @line-height-computed) / 2);

    // Inner label element
    label {
        padding-left: (@checkbox-size + @content-padding-small);
    }
}

// Checkbox and radio inputs
.radio input[type="radio"],
.radio-inline input[type="radio"],
.checkbox input[type="checkbox"],
.checkbox-inline input[type="checkbox"] {
    margin-left: 0;
    left: 0;
}

// Siblings
.radio + .radio,
.checkbox + .checkbox {
    margin-top: 0;
}

// Radios and checkboxes on same line
.radio-inline,
.checkbox-inline {
    position: relative;
    padding-left: (@checkbox-size + @content-padding-small);
}


//
// Right position
//

// Radio
.radio-right {
    &.radio-inline,
    label {
        padding-left: 0;
        padding-right: (@checkbox-size + @content-padding-small);
    }

    input[type="radio"] {
        left: auto;
        right: 0;
    }
}

// Checkbox
.checkbox-right:extend(.radio-right all) {
    &.checkbox-inline,
    label {
        &:extend(.radio-right.radio-inline);
    }
    input[type="checkbox"] {
        &:extend(.radio-right input[type="radio"]);
    }
}

// Inline siblings
.radio-inline + .radio-inline,
.checkbox-inline + .checkbox-inline {
    margin-left: @content-padding-base;
}

// Disabled state
.radio,
.checkbox {
    &,
    &-inline {
        &.disabled,
        fieldset[disabled] & {
            color: @gray-light;
        }
    }
}



/* Form control sizing
----------------------------------*/

// The `.form-group-* form-control` variations are sadly duplicated to avoid the
// issue documented in https://github.com/twbs/bootstrap/issues/15074.

// XLarge
.input-xlg {
    .input-size(@input-height-xlarge; @padding-xlarge-vertical; @padding-xlarge-horizontal; @font-size-xlarge; @line-height-xlarge; @input-border-radius-large);
}
.form-group-xlg {
    .form-control {
        .input-size(@input-height-xlarge; @padding-xlarge-vertical; @padding-xlarge-horizontal; @font-size-xlarge; @line-height-xlarge; @input-border-radius-large);
    }
    .form-control-static {
        height: @input-height-xlarge;
        min-height: (@line-height-computed + @font-size-xlarge);
        padding: @padding-xlarge-vertical @padding-xlarge-horizontal;
        font-size: @font-size-xlarge;
        line-height: @line-height-xlarge;
    }
}

// Mini
.input-xs {
    .input-size(@input-height-mini; @padding-xs-vertical; @padding-xs-horizontal; @font-size-small; @line-height-small; @input-border-radius-small);
}
.form-group-xs {
    .form-control {
        .input-size(@input-height-mini; @padding-xs-vertical; @padding-xs-horizontal; @font-size-small; @line-height-small; @input-border-radius-small);
    }
    .form-control-static {
        height: @input-height-mini;
        min-height: (@line-height-computed + @font-size-small);
        padding: @padding-xs-vertical @padding-xs-horizontal;
        font-size: @font-size-small;
        line-height: @line-height-small;
    }
}



/* Form helpers
----------------------------------*/

// Form control feedback states
// -------------------------

// Default right icon position
.has-feedback {

    // Ensure icons don't overlap text
    .form-control {
        padding-right: @input-height-base;

        &.input-xlg {
            padding-right: @input-height-xlarge;
        }

        &.input-lg {
            padding-right: @input-height-large;
        }

        &.input-sm {
            padding-right: @input-height-small;
        }

        &.input-xs {
            padding-right: @input-height-mini;
        }
    }
}

// Feedback icon
.form-control-feedback {
    width: @input-height-base + 2;
    color: @input-color;
    z-index: 3;

    // Change color if comes after colored input
    input[class*=bg-] + & {
        color: #fff;
    }
}

// Left icon position
.has-feedback-left {
    .form-control {
        padding-right: @padding-base-horizontal;
        padding-left: @input-height-base;

        &.input-xlg {
            padding-right: @padding-xlarge-vertical;
            padding-left: @input-height-xlarge;
        }

        &.input-lg {
            padding-right: @padding-large-horizontal;
            padding-left: @input-height-large;
        }

        &.input-sm {
            padding-right: @padding-small-horizontal;
            padding-left: @input-height-small;
        }

        &.input-xs {
            padding-right: @padding-xs-horizontal;
            padding-left: @input-height-mini;
        }
    }
    .form-control-feedback {
        right: auto;
        left: 0;
    }
}


//
// Sizing
//

// XLarge
.input-xlg + .form-control-feedback,
.form-group-xlg > .form-control-feedback {
    width: @input-height-xlarge + 2;
    height: @input-height-xlarge;
    line-height: @input-height-xlarge;
}

// Large
.input-lg + .form-control-feedback,
.form-group-lg > .form-control-feedback {
    width: @input-height-large + 2;
}

// Small
.input-sm + .form-control-feedback,
.form-group-sm > .form-control-feedback {
    width: @input-height-small + 2;
}

// Mini
.input-xs + .form-control-feedback,
.form-group-xs > .form-control-feedback {
    width: @input-height-mini + 2;
    height: @input-height-mini;
    line-height: @input-height-mini;
}


//
// Feedback states
//

.has-success,
.has-warning,
.has-error {
    .form-control:focus {
        .box-shadow(none);
    }
}



// Help text
// -------------------------

// Block helpers
.help-block {
    color: @text-muted;
    font-size: @font-size-small;
    margin-top: @padding-base-vertical;
    margin-bottom: @padding-base-vertical;
}

// Inline helpers
.help-inline {
    display: inline-block;
    color: @text-muted;
    font-size: @font-size-small;
    margin-top: (@padding-base-vertical + 1);
    margin-bottom: (@padding-base-vertical + 1);

    // Remove gutter if inside column
    .form-horizontal .form-group > div[class*="col-"] + & {
        margin-left: (@grid-gutter-width / 2);
        margin-right: (@grid-gutter-width / 2);
    }

    // Inline help works only on large screens
    @media (min-width: @screen-md) {
        display: inline-block;
        margin-top: (@padding-base-vertical + 1);
        margin-bottom: (@padding-base-vertical + 1);
        vertical-align: top;

        // Inline text helper
        &:not(.label) {
            color: @text-muted
        }

        // In large group
        .form-group-lg & {
            margin-top: (@padding-large-vertical + 1);
        }

        // In small group
        .form-group-sm & {
            margin-top: (@padding-small-vertical + 1);
        }

        // In mini group
        .form-group-xs & {
            margin-top: (@padding-xs-vertical + 1);
        }
    }
}



/* Form layouts
----------------------------------*/

// Inline forms
// -------------------------

.form-inline {
    @media (min-width: @screen-sm-min) {

        // Inline-block all the things for "inline"
        .form-group {
            & + .form-group {
                margin-left: @content-padding-base;
            }

            // Label setup
            > label {
                margin-right: @element-horizontal-spacing;
                position: relative;
                top: 1px;
            }
        }
    }
}


// Horizontal forms
// -------------------------

.form-horizontal {

    // Make form groups behave like rows
    .form-group {

        // Nesting
        .form-group {
            margin-left: 0;
            margin-right: 0;
        }
    }

    // Control label
    @media (min-width: @screen-sm-min) {
        .control-label {
            padding-bottom: @padding-base-vertical;
            padding-top: 0;

            &:not(.text-right) {
                text-align: left;
            }
        }
    }

    // Bottom padding for stacked control labels
    .control-label {
        @media (min-width: @screen-xs) {
            &[class*=col-xs-] {
                padding-top: (@padding-base-vertical + 1);
            }
        }

        @media (min-width: @screen-md) {
            &[class*=col-md-] {
                padding-top: (@padding-base-vertical + 1);
            }
        }

        @media (min-width: @screen-sm) {
            &[class*=col-sm-] {
                padding-top: (@padding-base-vertical + 1);
            }
        }

        @media (min-width: @screen-lg) {
            &[class*=col-lg-] {
                padding-top: (@padding-base-vertical + 1);
            }
        }
    }

    // Validation state icons
    .has-feedback {
        > .form-control-feedback {
            right: 0;
        }
    }
    .has-feedback-left {
        .form-control-feedback {
            right: auto;
            left: (@grid-gutter-width / 2);
        }

        > .form-control-feedback {
            left: 0;
        }
    }


    //
    // Form group sizes
    //

    // XLarge
    .form-group-xlg {
        @media (min-width: @screen-sm-min) {
            .control-label {
                font-size: @font-size-xlarge;
                padding-top: (@padding-xlarge-vertical + 1);
            }
        }
    }

    // Large
    .form-group-lg {
        @media (min-width: @screen-sm-min) {
            .control-label {
                padding-top: (@padding-large-vertical + 1);
            }
        }
    }

    // Small
    .form-group-sm {
        @media (min-width: @screen-sm-min) {
            .control-label {
                padding-top: (@padding-small-vertical + 1);
            }
        }
    }

    // Mini
    .form-group-xs {
        @media (min-width: @screen-sm-min) {
            .control-label {
                font-size: @font-size-small;
                padding-top: (@padding-xs-vertical + 1);
            }
        }
    }
}