https://github.com/sha-red/compass-mixins/tree/master/lib
extended with more sass frameworks and as django app.
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
221 lines
8.7 KiB
221 lines
8.7 KiB
@import "../layout/grid-background"; |
|
|
|
// The base font size. |
|
$base-font-size: 16px !default; |
|
|
|
// The base line height determines the basic unit of vertical rhythm. |
|
$base-line-height: 24px !default; |
|
|
|
// Set the default border style for rhythm borders. |
|
$default-rhythm-border-style: solid !default; |
|
|
|
// The default font size in all browsers. |
|
$browser-default-font-size: 16px; |
|
|
|
// Set to false if you want to use absolute pixels in sizing your typography. |
|
$relative-font-sizing: true !default; |
|
|
|
// Allows the `adjust-font-size-to` mixin and the `lines-for-font-size` function |
|
// to round the line height to the nearest half line height instead of the |
|
// nearest integral line height to avoid large spacing between lines. |
|
$round-to-nearest-half-line: false !default; |
|
|
|
// Ensure there is at least this many pixels |
|
// of vertical padding above and below the text. |
|
$min-line-padding: 2px !default; |
|
|
|
// $base-font-size but in your output unit of choice. |
|
// Defaults to 1em when `$relative-font-sizing` is true. |
|
$font-unit: if($relative-font-sizing, 1em, $base-font-size) !default; |
|
|
|
// The basic unit of font rhythm. |
|
$base-rhythm-unit: $base-line-height / $base-font-size * $font-unit; |
|
|
|
// The leader is the amount of whitespace in a line. |
|
// It might be useful in your calculations. |
|
$base-leader: ($base-line-height - $base-font-size) * $font-unit / $base-font-size; |
|
|
|
// The half-leader is the amount of whitespace above and below a line. |
|
// It might be useful in your calculations. |
|
$base-half-leader: $base-leader / 2; |
|
|
|
// True if a number has a relative unit. |
|
@function relative-unit($number) { |
|
@return unit($number) == "%" or unit($number) == "em" or unit($number) == "rem" |
|
} |
|
|
|
// True if a number has an absolute unit. |
|
@function absolute-unit($number) { |
|
@return not (relative-unit($number) or unitless($number)); |
|
} |
|
|
|
@if $relative-font-sizing and not relative-unit($font-unit) { |
|
@warn "$relative-font-sizing is true but $font-unit is set to #{$font-unit} which is not a relative unit."; |
|
} |
|
|
|
// Establishes a font baseline for the given font-size. |
|
@mixin establish-baseline($font-size: $base-font-size) { |
|
// IE 6 refuses to resize fonts set in pixels and it weirdly resizes fonts |
|
// whose root is set in ems. So we set the root font size in percentages of |
|
// the default font size. |
|
* html { |
|
font-size: 100% * ($font-size / $browser-default-font-size); |
|
} |
|
html { |
|
font-size: $font-size; |
|
@include adjust-leading-to(1, if($relative-font-sizing, $font-size, $base-font-size)); |
|
} |
|
} |
|
|
|
// Resets the line-height to 1 vertical rhythm unit. |
|
// Does not work on elements whose font-size is different from $base-font-size. |
|
// |
|
// @deprecated This mixin will be removed in the next release. |
|
// Please use the `adjust-leading-to` mixin instead. |
|
@mixin reset-baseline { |
|
@include adjust-leading-to(1, if($relative-font-sizing, $base-font-size, $base-font-size)); |
|
} |
|
|
|
// Show a background image that can be used to debug your alignments. |
|
// Include the $img argument if you would rather use your own image than the |
|
// Compass default gradient image. |
|
@mixin debug-vertical-alignment($img: false) { |
|
@if $img { |
|
background: image-url($img); |
|
} @else { |
|
@include baseline-grid-background($base-rhythm-unit); |
|
} |
|
} |
|
|
|
// Adjust a block to have a different font size and line height to maintain the |
|
// rhythm. $lines specifies how many multiples of the baseline rhythm each line |
|
// of this font should use up. It does not have to be an integer, but it |
|
// defaults to the smallest integer that is large enough to fit the font. |
|
// Use $from-size to adjust from a font-size other than the base font-size. |
|
@mixin adjust-font-size-to($to-size, $lines: lines-for-font-size($to-size), $from-size: $base-font-size) { |
|
@if not $relative-font-sizing and $from-size != $base-font-size { |
|
@warn "$relative-font-sizing is false but a relative font size was passed to adjust-font-size-to"; |
|
} |
|
font-size: $font-unit * $to-size / $from-size; |
|
@include adjust-leading-to($lines, if($relative-font-sizing, $to-size, $base-font-size)); |
|
} |
|
|
|
// Adjust a block to have different line height to maintain the rhythm. |
|
// $lines specifies how many multiples of the baseline rhythm each line of this |
|
// font should use up. It does not have to be an integer, but it defaults to the |
|
// smallest integer that is large enough to fit the font. |
|
@mixin adjust-leading-to($lines, $font-size: $base-font-size) { |
|
line-height: rhythm($lines, $font-size); |
|
} |
|
|
|
// Calculate rhythm units. |
|
@function rhythm( |
|
$lines: 1, |
|
$font-size: $base-font-size, |
|
$offset: 0 |
|
) { |
|
@if not $relative-font-sizing and $font-size != $base-font-size { |
|
@warn "$relative-font-sizing is false but a relative font size was passed to the rhythm function"; |
|
} |
|
$rhythm: $font-unit * ($lines * $base-line-height - $offset) / $font-size; |
|
// Round the pixels down to nearest integer. |
|
@if unit($rhythm) == px { |
|
$rhythm: floor($rhythm); |
|
} |
|
@return $rhythm; |
|
} |
|
|
|
// Calculate the minimum multiple of rhythm units needed to contain the font-size. |
|
@function lines-for-font-size($font-size) { |
|
$lines: if($round-to-nearest-half-line, |
|
ceil(2 * $font-size / $base-line-height) / 2, |
|
ceil($font-size / $base-line-height)); |
|
@if $lines * $base-line-height - $font-size < $min-line-padding * 2 { |
|
$lines: $lines + if($round-to-nearest-half-line, 0.5, 1); |
|
} |
|
@return $lines; |
|
} |
|
|
|
// Apply leading whitespace. The $property can be margin or padding. |
|
@mixin leader($lines: 1, $font-size: $base-font-size, $property: margin) { |
|
#{$property}-top: rhythm($lines, $font-size); |
|
} |
|
|
|
// Apply leading whitespace as padding. |
|
@mixin padding-leader($lines: 1, $font-size: $base-font-size) { |
|
padding-top: rhythm($lines, $font-size); |
|
} |
|
|
|
// Apply leading whitespace as margin. |
|
@mixin margin-leader($lines: 1, $font-size: $base-font-size) { |
|
margin-top: rhythm($lines, $font-size); |
|
} |
|
|
|
// Apply trailing whitespace. The $property can be margin or padding. |
|
@mixin trailer($lines: 1, $font-size: $base-font-size, $property: margin) { |
|
#{$property}-bottom: rhythm($lines, $font-size); |
|
} |
|
|
|
// Apply trailing whitespace as padding. |
|
@mixin padding-trailer($lines: 1, $font-size: $base-font-size) { |
|
padding-bottom: rhythm($lines, $font-size); |
|
} |
|
|
|
// Apply trailing whitespace as margin. |
|
@mixin margin-trailer($lines: 1, $font-size: $base-font-size) { |
|
margin-bottom: rhythm($lines, $font-size); |
|
} |
|
|
|
// Shorthand mixin to apply whitespace for top and bottom margins and padding. |
|
@mixin rhythm($leader: 0, $padding-leader: 0, $padding-trailer: 0, $trailer: 0, $font-size: $base-font-size) { |
|
@include leader($leader, $font-size); |
|
@include padding-leader($padding-leader, $font-size); |
|
@include padding-trailer($padding-trailer, $font-size); |
|
@include trailer($trailer, $font-size); |
|
} |
|
|
|
// Apply a border and whitespace to any side without destroying the vertical |
|
// rhythm. The whitespace must be greater than the width of the border. |
|
@mixin apply-side-rhythm-border($side, $width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@if not $relative-font-sizing and $font-size != $base-font-size { |
|
@warn "$relative-font-sizing is false but a relative font size was passed to apply-side-rhythm-border"; |
|
} |
|
border-#{$side}: { |
|
style: $border-style; |
|
width: $font-unit * $width / $font-size; |
|
}; |
|
padding-#{$side}: rhythm($lines, $font-size, $offset: $width); |
|
} |
|
|
|
// Apply borders and whitespace equally to all sides. |
|
@mixin rhythm-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@if not $relative-font-sizing and $font-size != $base-font-size { |
|
@warn "$relative-font-sizing is false but a relative font size was passed to rhythm-borders"; |
|
} |
|
border: { |
|
style: $border-style; |
|
width: $font-unit * $width / $font-size; |
|
}; |
|
padding: rhythm($lines, $font-size, $offset: $width); |
|
} |
|
|
|
// Apply a leading border. |
|
@mixin leading-border($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@include apply-side-rhythm-border(top, $width, $lines, $font-size, $border-style); |
|
} |
|
|
|
// Apply a trailing border. |
|
@mixin trailing-border($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@include apply-side-rhythm-border(bottom, $width, $lines, $font-size, $border-style); |
|
} |
|
|
|
// Apply both leading and trailing borders. |
|
@mixin horizontal-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@include leading-border($width, $lines, $font-size, $border-style); |
|
@include trailing-border($width, $lines, $font-size, $border-style); |
|
} |
|
|
|
// Alias for `horizontal-borders` mixin. |
|
@mixin h-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) { |
|
@include horizontal-borders($width, $lines, $font-size, $border-style); |
|
}
|
|
|