UNPKG

components

Version:
336 lines (277 loc) 6.62 kB
/*! /* CSS Buttons */ /* --------------------------------------------------------- */ @import "variables.less"; @import "mixins.less"; /* Button psuedo states */ /* ------------------------- */ /* Easily pump out default styles, as well as :hover, :focus, :active, */ /* and disabled options for all buttons */ .btn-pseudo-states(@color, @background, @border) { color: @color; background-color: @background; border-color: @border; &:hover, &:focus, &:active, &.active { background-color: darken(@background, 10%); border-color: darken(@border, 10%); } &.disabled, &[disabled], fieldset[disabled] & { &:hover, &:focus, &:active, &.active { background-color: @background; border-color: @border } } } .btn-inverse-pseudo-states(@color: #222, @background, @border) { .btn-pseudo-states(@color, @background, @border); &:hover, &:focus, &:active, &.active { color: @color; background-color: darken(@background, 10%); border-color: darken(@border, 10%); } } /* Base styles */ /* -------------------------------------------------- */ /* Core styles */ .btn { display: inline-block; padding: @padding-large-vertical (@padding-large-horizontal * 1.6); margin-bottom: 0; /* For input.btn */ font-size: @font-size-base; font-weight: 500; line-height: @font-size-base; letter-spacing: 1px; text-align: center; text-transform: uppercase; text-shadow: none; vertical-align: middle; cursor: pointer; border: 1px solid transparent; /* ensure that buttons do not have a border */ border-radius: 100px; white-space: nowrap; .transition-duration(0.1s); .transition-property(~"color, background-color"); .transition-timing-function(cubic-bezier(0.694, 0.0482, 0.335, 1)); .user-select(none); &:focus { .tab-focus(); } &:hover, &:focus { color: #fff; text-decoration: none; } &:active, &.active { outline: 0; background-image: none; .box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); } &.disabled, &[disabled], fieldset[disabled] & { cursor: default; pointer-events: none; /* Future-proof disabling of clicks */ .opacity(.65); .box-shadow(none); } } /* Alternate buttons */ /* -------------------------------------------------- */ .btn-default { .btn-pseudo-states(@btn-default-color, @btn-default-bg, @btn-default-border); } .btn-primary { .btn-pseudo-states(@btn-primary-color, @btn-primary-bg, @btn-primary-border); } /* Warning appears as orange */ .btn-warning { .btn-pseudo-states(@btn-warning-color, @btn-warning-bg, @btn-warning-border); } /* Danger and error appear as red */ .btn-danger { .btn-pseudo-states(@btn-danger-color, @btn-danger-bg, @btn-danger-border); } /* Success appears as green */ .btn-success { .btn-pseudo-states(@btn-success-color, @btn-success-bg, @btn-success-border); } /* Info appears as blue-green */ .btn-info { .btn-pseudo-states(@btn-info-color, @btn-info-bg, @btn-info-border); } /* Jade appears as green-blue */ .btn-jade { .btn-pseudo-states(@btn-jade-color, @btn-jade-bg, @btn-jade-border); } /* Inverse appears as white */ .btn-inverse { .btn-inverse-pseudo-states(@btn-inverse-color, @btn-inverse-bg, @btn-inverse-border); } /* Link buttons */ /* ------------------------- */ /* Make a button look and behave like a link */ .btn-link, .btn-link:active, .btn-link[disabled], fieldset[disabled] .btn-link { background-color: transparent; background-image: none; .box-shadow(none); } .btn-link, .btn-link:hover, .btn-link:focus, .btn-link:active { border-color: transparent; } .btn-link { color: @link-color; font-weight: normal; cursor: pointer; border-radius: 0; } .btn-link:hover, .btn-link:focus { color: @link-hover-color; text-decoration: underline; background-color: transparent; } .btn-link { &[disabled], fieldset[disabled] & { &:hover, &:focus { color: @gray-dark; text-decoration: none; } } } /* Button Sizes */ /* -------------------------------------------------- */ .btn-jumbo { padding: (@padding-large-vertical * 1.9) (@padding-large-horizontal * 3); font-size: @font-size-large; } .btn-large { padding: (@padding-large-vertical * 1.5) (@padding-large-horizontal * 2.5); font-size: @font-size-large; } .btn-small { padding: @padding-small-vertical @padding-large-horizontal; font-size: @font-size-small; line-height: 1.5; /* ensure proper height of button next to small input */ } .btn-mini { padding: (@padding-small-vertical - 2px) (@padding-large-horizontal - 2px); font-size: (@font-size-small - 1); line-height: 1; /* ensure proper height of button next to small input */ } /* Button Sizes */ /* -------------------------------------------------- */ /* Large button */ .button-large { width: 100%; font-family: "Open Sans", @font-family-sans-serif; padding: 0 30px; font-size: 17px; line-height: 64px; letter-spacing: 1px; border-radius: 40px; } /* Small button */ .button-small { padding: 9px 25px; font-size: 12px; } /* Mini button */ .button-mini { padding: 6px 20px; font-size: 10px; } /* Block button */ /* -------------------------------------------------- */ .btn-block { display: block; width: 100%; padding-left: 0; padding-right: 0; } /* Vertically space out multiple block buttons */ .btn-block + .btn-block { margin-top: 5px; } /* Specificity overrides */ input[type="submit"], input[type="reset"], input[type="button"] { &.btn-block { width: 100%; } } /* Centered button */ .button-centered { position: absolute; top: 50%; left: 50%; } /* Alternate styles */ /* -------------------------------------------------- */ .button-jade { color: @btn-jade-color; background: @btn-jade-bg; .transition(all 0.1s ease-out); &:hover { color: @btn-jade-color; background: @btn-jade-bg-hover; } } /* Cool gray */ .button-coolgray { color: #fff; background-color: #3f4546; } .button-white { color: #222; background: #fff; &:hover { color: #222; background: #e5e5e5; } } .button-dark { color: #fff; background-color: #222; &:hover { background-color: #444; } } /* Buttons */ /* -------------------------------- */ .btn-facebook { display: block; width: 180px; padding-left: 24px; font-size: 18px; font-weight: 300; line-height: 56px; text-decoration: none; background-color: #3a5898; background-position: 12px center; background-repeat: no-repeat; border-radius: 10px; &:hover { background-color: #2f4a84; } }