mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-25 20:03:12 +03:00
9ba5750ca9
Also introduces a new format of file opening comment, to outline what happens and a contents list.
102 lines
2.9 KiB
SCSS
102 lines
2.9 KiB
SCSS
// ------------------------------------------------------------
|
|
// Mixins
|
|
//
|
|
// Mixins defined here are very general and used in mul
|
|
//
|
|
// * baseline()
|
|
// * clearfix()
|
|
// * tab-focus()
|
|
// * triangle()
|
|
// * set-triangle-color()
|
|
// ------------------------------------------------------------
|
|
|
|
|
|
//
|
|
// Baseline margin
|
|
// --------------------------------------------------
|
|
|
|
@mixin baseline {
|
|
margin: 1.6em 0;
|
|
}
|
|
|
|
|
|
//
|
|
// Fix for clearing float-based overflows
|
|
// --------------------------------------------------
|
|
|
|
@mixin clearfix {
|
|
&:after {
|
|
content: "";
|
|
display: table;
|
|
clear: both;
|
|
}
|
|
}
|
|
|
|
|
|
//
|
|
// WebKit-style focus
|
|
// From Bootstrap
|
|
// --------------------------------------------------
|
|
@mixin tab-focus() {
|
|
// Default
|
|
outline: thin dotted;
|
|
// WebKit
|
|
outline: 0px auto -webkit-focus-ring-color;
|
|
outline-offset: -2px;
|
|
}
|
|
|
|
|
|
//
|
|
// Simple SCSS mixin to create CSS triangles
|
|
// Example: @include css-triangle (10px, #fff, "up");
|
|
// --------------------------------------------------
|
|
|
|
@mixin triangle($size: 20px, $color: #000, $direction: "down", $type: "normal") {
|
|
$verticalSize: $size;
|
|
width: 0;
|
|
height: 0;
|
|
|
|
@if $type == "shallow" {
|
|
$verticalSize: floor($size * $popover_triangle_shallow_multiplier);
|
|
}
|
|
|
|
@if $direction == "down" {
|
|
border-left: $size solid #{set-triangle-color($direction, "left", $color)};
|
|
border-right: $size solid #{set-triangle-color($direction, "right", $color)};
|
|
border-top: $verticalSize solid #{set-triangle-color($direction, "top", $color)};
|
|
}
|
|
|
|
@if $direction == "up" {
|
|
border-left: $size solid #{set-triangle-color($direction, "left", $color)};
|
|
border-right: $size solid #{set-triangle-color($direction, "right", $color)};
|
|
border-bottom: $verticalSize solid #{set-triangle-color($direction, "bottom", $color)};
|
|
}
|
|
|
|
@if $direction == "left" {
|
|
border-right: $verticalSize solid #{set-triangle-color($direction, "right", $color)};
|
|
border-top: $size solid #{set-triangle-color($direction, "top", $color)};
|
|
border-bottom: $size solid #{set-triangle-color($direction, "bottom", $color)};
|
|
}
|
|
|
|
@if $direction == "right" {
|
|
border-left: $verticalSize solid #{set-triangle-color($direction, "left", $color)};
|
|
border-bottom: $size solid #{set-triangle-color($direction, "bottom", $color)};
|
|
border-top: $size solid #{set-triangle-color($direction, "top", $color)};
|
|
}
|
|
}
|
|
|
|
|
|
//
|
|
// Utility function to return the relevant colour depending on what type of arrow it is
|
|
// --------------------------------------------------
|
|
|
|
@function set-triangle-color($direction, $side, $color) {
|
|
@if $direction == "left" and $side == "right"
|
|
or $direction == "right" and $side == "left"
|
|
or $direction == "down" and $side == "top"
|
|
or $direction == "up" and $side == "bottom" {
|
|
@return $color
|
|
} @else {
|
|
@return "transparent";
|
|
}
|
|
} |