// Foundation by ZURB // foundation.zurb.com // Licensed under MIT Open Source @import 'global'; @import 'buttons'; // // @variables // $include-html-form-classes: $include-html-classes !default; // We use this to set the base for lots of form spacing and positioning styles $form-spacing: rem-calc(16) !default; // We use these to style the labels in different ways $form-label-pointer: pointer !default; $form-label-font-size: rem-calc(14) !default; $form-label-font-weight: $font-weight-normal !default; $form-label-line-height: 1.5 !default; $form-label-font-color: scale-color($black, $lightness: 30%) !default; $form-label-small-transform: capitalize !default; $form-label-bottom-margin: 0 !default; $input-font-family: inherit !default; $input-font-color: rgba(0,0,0,0.75) !default; $input-font-size: rem-calc(14) !default; $input-bg-color: $white !default; $input-focus-bg-color: scale-color($white, $lightness: -2%) !default; $input-border-color: scale-color($white, $lightness: -20%) !default; $input-focus-border-color: scale-color($white, $lightness: -40%) !default; $input-border-style: solid !default; $input-border-width: 1px !default; $input-border-radius: $global-radius !default; $input-disabled-bg: $gainsboro !default; $input-disabled-cursor: $cursor-default-value !default; $input-box-shadow: inset 0 1px 2px rgba(0,0,0,0.1) !default; $input-include-glowing-effect: false !default; // We use these to style the fieldset border and spacing. $fieldset-border-style: solid !default; $fieldset-border-width: 1px !default; $fieldset-border-color: $gainsboro !default; $fieldset-padding: rem-calc(20) !default; $fieldset-margin: rem-calc(18 0) !default; // We use these to style the legends when you use them $legend-bg: $white !default; $legend-font-weight: $font-weight-bold !default; $legend-padding: rem-calc(0 3) !default; // We use these to style the prefix and postfix input elements $input-prefix-bg: scale-color($white, $lightness: -5%) !default; $input-prefix-border-color: scale-color($white, $lightness: -20%) !default; $input-prefix-border-size: 1px !default; $input-prefix-border-type: solid !default; $input-prefix-overflow: visible !default; $input-prefix-font-color: $oil !default; $input-prefix-font-color-alt: $white !default; // We use this setting to turn on/off HTML5 number spinners (the up/down arrows) $input-number-spinners: true !default; // We use these to style the error states for inputs and labels $input-error-message-padding: rem-calc(6 9 9) !default; $input-error-message-top: -1px !default; $input-error-message-font-size: rem-calc(12) !default; $input-error-message-font-weight: $font-weight-normal !default; $input-error-message-font-style: italic !default; $input-error-message-font-color: $white !default; $input-error-message-bg-color: $alert-color !default; $input-error-message-font-color-alt: $oil !default; // We use this to style the glowing effect of inputs when focused $glowing-effect-fade-time: .45s !default; $glowing-effect-color: $input-focus-border-color !default; // We use this to style the transition when inputs are focused and when the glowing effect is disabled. $input-transition-fade-time: 0.15s !default; $input-transition-fade-timing-function: linear !default; // Select variables $select-bg-color: $ghost !default; $select-hover-bg-color: scale-color($select-bg-color, $lightness: -3%) !default; // // @MIXINS // // We use this mixin to give us form styles for rows inside of forms @mixin form-row-base { .row { margin: 0 ((-$form-spacing) / 2); .column, .columns { padding: 0 ($form-spacing / 2); } // Use this to collapse the margins of a form row &.collapse { margin: 0; .column, .columns { padding: 0; } input { @include side-radius($opposite-direction, 0); } } } input.column, input.columns, textarea.column, textarea.columns { padding-#{$default-float}: ($form-spacing / 2); } } // @MIXIN // // We use this mixin to give all basic form elements their style @mixin form-element { background-color: $input-bg-color; border: { style: $input-border-style; width: $input-border-width; color: $input-border-color; } box-shadow: $input-box-shadow; color: $input-font-color; display: block; font-family: $input-font-family; font-size: $input-font-size; height: ($input-font-size + ($form-spacing * 1.5) - rem-calc(1)); margin: 0 0 $form-spacing 0; padding: $form-spacing / 2; width: 100%; @include box-sizing(border-box); @if $input-include-glowing-effect { @include block-glowing-effect(focus, $glowing-effect-fade-time, $glowing-effect-color); } // Basic focus styles &:focus { background: $input-focus-bg-color; border-color: $input-focus-border-color; outline: none; } // Disbaled Styles &:disabled { background-color: $input-disabled-bg; cursor: $input-disabled-cursor; } // Disabled background input background color &[disabled], &[readonly], fieldset[disabled] & { background-color: $input-disabled-bg; cursor: $input-disabled-cursor; } } // @MIXIN // // We use this mixin to create form labels // // $alignment - Alignment options. Default: false. Options: [right, inline, false] // $base-style - Control whether or not the base styles come through. Default: true. @mixin form-label($alignment:false, $base-style:true) { // Control whether or not the base styles come through. @if $base-style { color: $form-label-font-color; cursor: $form-label-pointer; display: block; font-size: $form-label-font-size; font-weight: $form-label-font-weight; line-height: $form-label-line-height; margin-bottom: $form-label-bottom-margin; } // Alignment options @if $alignment == right { float: none !important; text-align: right; } @else if $alignment == inline { margin: 0 0 $form-spacing 0; padding: $form-spacing / 2 + rem-calc($input-border-width) 0; } } // We use this mixin to create postfix/prefix form Labels @mixin prefix-postfix-base { border-style: $input-prefix-border-type; border-width: $input-prefix-border-size; display: block; font-size: $form-label-font-size; height: ($input-font-size + ($form-spacing * 1.5) - rem-calc(1)); line-height: ($input-font-size + ($form-spacing * 1.5) - rem-calc(1)); overflow: $input-prefix-overflow; padding-bottom: 0; padding-top: 0; position: relative; text-align: center; width: 100%; z-index: 2; } // @MIXIN // // We use this mixin to create prefix label styles // $bg - Default:$input-prefix-bg || scale-color($white, $lightness: -5%) !default; // $is-button - Toggle position settings if prefix is a button. Default:false // @mixin prefix($bg:$input-prefix-bg, $border:$input-prefix-border-color, $is-button:false) { @if $bg { $bg-lightness: lightness($bg); background: $bg; border-#{$opposite-direction}: none; // Control the font color based on background brightness @if $bg-lightness > 70% or $bg == yellow { color: $input-prefix-font-color; } @else { color: $input-prefix-font-color-alt; } } @if $border { border-color: $border; } @if $is-button { border: none; padding-#{$default-float}: 0; padding-#{$opposite-direction}: 0; padding-bottom: 0; padding-top: 0; text-align: center; } } // @MIXIN // // We use this mixin to create postfix label styles // $bg - Default:$input-prefix-bg || scale-color($white, $lightness: -5%) !default; // $is-button - Toggle position settings if prefix is a button. Default: false @mixin postfix($bg:$input-prefix-bg, $border:$input-prefix-border-color, $is-button:false) { @if $bg { $bg-lightness: lightness($bg); background: $bg; border-#{$default-float}: none; // Control the font color based on background brightness @if $bg-lightness > 70% or $bg == yellow { color: $input-prefix-font-color; } @else { color: $input-prefix-font-color-alt; } } @if $border { border-color: $border; } @if $is-button { border: none; padding-#{$default-float}: 0; padding-#{$opposite-direction}: 0; padding-bottom: 0; padding-top: 0; text-align: center; } } // We use this mixin to style fieldsets @mixin fieldset { border: $fieldset-border-width $fieldset-border-style $fieldset-border-color; margin: $fieldset-margin; padding: $fieldset-padding; // and legend styles legend { background: $legend-bg; font-weight: $legend-font-weight; margin-#{$default-float}: rem-calc(-3); margin: 0; padding: $legend-padding; } } // @MIXIN // // We use this mixin to control border and background color of error inputs // $color - Default: $alert-color (found in settings file) @mixin form-error-color($color:$alert-color) { background-color: rgba($color, .1); border-color: $color; // Go back to normal on focus &:focus { background: $input-focus-bg-color; border-color: $input-focus-border-color; } } // @MIXIN // // We use this simple mixin to style labels for error inputs // $color - Default:$alert-color. Found in settings file @mixin form-label-error-color($color:$alert-color) { color: $color; } // @MIXIN // // We use this mixin to create error message styles // $bg - Default: $alert-color (Found in settings file) @mixin form-error-message($bg:$input-error-message-bg-color) { display: block; font-size: $input-error-message-font-size; font-style: $input-error-message-font-style; font-weight: $input-error-message-font-weight; margin-bottom: $form-spacing; margin-top: $input-error-message-top; padding: $input-error-message-padding; // We can control the text color based on the brightness of the background. $bg-lightness: lightness($bg); background: $bg; @if $bg-lightness < 70% or $bg == yellow { color: $input-error-message-font-color; } @else { color: $input-error-message-font-color-alt; } } // We use this mixin to style select elements @mixin form-select { -webkit-appearance: none !important; -moz-appearance: none !important; background-color: $select-bg-color; border-radius: 0; // Hide the dropdown arrow shown in newer IE versions &::-ms-expand { display: none; } // The custom arrow has some fake horizontal padding so we can align it // from the right side of the element without relying on CSS3 background-image: url(); // We can safely use leftmost and rightmost now background-position: if($text-direction == 'rtl', 0%, 100%) center; background-repeat: no-repeat; border: { style: $input-border-style; width: $input-border-width; color: $input-border-color; } color: $input-font-color; font-family: $input-font-family; font-size: $input-font-size; line-height: normal; padding: ($form-spacing / 2); @include radius(0); &.radius { @include radius($global-radius); } &:hover { background-color: $select-hover-bg-color; border-color: $input-focus-border-color; } // Disabled Styles &:disabled { background-color: $input-disabled-bg; cursor: $input-disabled-cursor; } } // We use this mixin to turn on/off HTML5 number spinners @mixin html5number($browser, $on:true) { @if $on==false { @if $browser==webkit { -webkit-appearance: none; margin: 0; } @else if $browser==moz { -moz-appearance: textfield; } } } @include exports("form") { @if $include-html-form-classes { /* Standard Forms */ form { margin: 0 0 $form-spacing; } /* Using forms within rows, we need to set some defaults */ form .row { @include form-row-base; } /* Label Styles */ label { @include form-label; &.right { @include form-label(right, false); } &.inline { @include form-label(inline, false); } /* Styles for required inputs */ small { text-transform: $form-label-small-transform; color: scale-color($form-label-font-color, $lightness: 15%); } } /* Attach elements to the beginning or end of an input */ .prefix, .postfix { @include prefix-postfix-base; } /* Adjust padding, alignment and radius if pre/post element is a button */ .postfix.button { @include button-size(false, false); @include postfix(false, false, true); } .prefix.button { @include button-size(false, false); @include prefix(false, false, true); } .prefix.button.radius { @include radius(0); @include side-radius($default-float, $button-radius); } .postfix.button.radius { @include radius(0); @include side-radius($opposite-direction, $button-radius); } .prefix.button.round { @include radius(0); @include side-radius($default-float, $button-round); } .postfix.button.round { @include radius(0); @include side-radius($opposite-direction, $button-round); } /* Separate prefix and postfix styles when on span or label so buttons keep their own */ span.prefix, label.prefix { @include prefix(); } span.postfix, label.postfix { @include postfix(); } /* We use this to get basic styling on all basic form elements */ #{text-inputs(all, 'input')} { -webkit-appearance: none; -moz-appearance: none; border-radius: 0; @include form-element; @if $input-include-glowing-effect == false { -webkit-transition: border-color $input-transition-fade-time $input-transition-fade-timing-function, background $input-transition-fade-time $input-transition-fade-timing-function; -moz-transition: border-color $input-transition-fade-time $input-transition-fade-timing-function, background $input-transition-fade-time $input-transition-fade-timing-function; -ms-transition: border-color $input-transition-fade-time $input-transition-fade-timing-function, background $input-transition-fade-time $input-transition-fade-timing-function; -o-transition: border-color $input-transition-fade-time $input-transition-fade-timing-function, background $input-transition-fade-time $input-transition-fade-timing-function; transition: border-color $input-transition-fade-time $input-transition-fade-timing-function, background $input-transition-fade-time $input-transition-fade-timing-function; } &.radius { @include radius($input-border-radius); } } form { .row { .prefix-radius.row.collapse { input, textarea, select, button { @include radius(0); @include side-radius($opposite-direction, $button-radius); } .prefix { @include radius(0); @include side-radius($default-float, $button-radius); } } .postfix-radius.row.collapse { input, textarea, select, button { @include radius(0); @include side-radius($default-float, $button-radius); } .postfix { @include radius(0); @include side-radius($opposite-direction, $button-radius); } } .prefix-round.row.collapse { input, textarea, select, button { @include radius(0); @include side-radius($opposite-direction, $button-round); } .prefix { @include radius(0); @include side-radius($default-float, $button-round); } } .postfix-round.row.collapse { input, textarea, select, button { @include radius(0); @include side-radius($default-float, $button-round); } .postfix { @include radius(0); @include side-radius($opposite-direction, $button-round); } } } } input[type="submit"] { -webkit-appearance: none; -moz-appearance: none; border-radius: 0; } /* Respect enforced amount of rows for textarea */ textarea[rows] { height: auto; } /* Not allow resize out of parent */ textarea { max-width: 100%; } /* Add height value for select elements to match text input height */ select { @include form-select; height: ($input-font-size + ($form-spacing * 1.5) - rem-calc(1)); &[multiple] { height: auto; } } /* Adjust margin for form elements below */ input[type="file"], input[type="checkbox"], input[type="radio"], select { margin: 0 0 $form-spacing 0; } input[type="checkbox"] + label, input[type="radio"] + label { display: inline-block; margin-#{$default-float}: $form-spacing * .5; margin-#{$opposite-direction}: $form-spacing; margin-bottom: 0; vertical-align: baseline; } /* Normalize file input width */ input[type="file"] { width:100%; } /* HTML5 Number spinners settings */ input[type=number] { @include html5number(moz, $input-number-spinners) } input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button { @include html5number(webkit, $input-number-spinners); } /* We add basic fieldset styling */ fieldset { @include fieldset; } /* Error Handling */ #{data('abide')} { .error small.error, .error span.error, span.error, small.error { @include form-error-message; } span.error, small.error { display: none; } } span.error, small.error { @include form-error-message; } .error { input, textarea, select { margin-bottom: 0; } input[type="checkbox"], input[type="radio"] { margin-bottom: $form-spacing } label, label.error { @include form-label-error-color; } small.error { @include form-error-message; } > label { > small { background: transparent; color: scale-color($form-label-font-color, $lightness: 15%); display: inline; font-size: 60%; font-style: normal; margin: 0; padding: 0; text-transform: $form-label-small-transform; } } span.error-message { display: block; } } input.error, textarea.error, select.error { margin-bottom: 0; } label.error { @include form-label-error-color; } } }