Sha256: f4bda88be191f32338794496b0ec447a2c5ca7714c9fd95e53938bafeb37d2f3

Contents?: true

Size: 1.92 KB

Versions: 10

Compression:

Stored size: 1.92 KB

Contents

//////////////////////////////
// Draw triangles
//////////////////////////////

@mixin triangle($color: #000, $height: 1em, $width: 1em, $angle: 0) {
  
  @if nth($angle, 1) == "top" or nth($angle, 1) == "bottom" {
    $angle: "#{$angle}";
  }

  @if $angle == "top" {
    $angle: 0;
  }
  @if $angle == "top right" {
    $angle: 45 * 7;
  }
  @if $angle == "right" {
    $angle: 45 * 2;
  }
  @if $angle == "bottom right" {
    $angle: 45 * 1;
  }
  @if $angle == "bottom" {
    $angle: 45 * 4;
  }
  @if $angle == "bottom left" {
    $angle: 45 * 3;
  }
  @if $angle == "left" {
    $angle: 45 * 6;
  }
  @if $angle == "top left" {
    $angle: 45 * 5;
  }

  @if unit($height) == "" or unit($height) == "%" {
    @debug "in triangle #{$height} is not a compatable unit for height."
  }

  @if unit($width) == "" or unit($width) == "%" {
    @debug "in triangle #{$width} is not a compatable unit for width."
  }

  // offset 45deg to make each side start at 0
  $deg: $angle + 45;
  // if units, remove units
  @if unit($deg) == deg {
    $deg: $deg / 1deg;
  }
  // shift to be on a scale from 0 to 90.
  @while $deg > 90 {
    $deg: $deg - 90;
  }
  @while $deg < 0 {
    $deg: $deg + 90;
  }
  // Get a ratio of 90 to multiply by.
  $deg: $deg / 90;

  // make sure metrics are reset
  display: block;
  width: 0;
  height: 0;
  border: 0 solid transparent;

  // run through sides
  @if $angle <= 45 or $angle > 315 {
    border-bottom-color: $color;
    border-width: 0 ($width * abs($deg - 1)) $height ($width * $deg);
  }
  @if $angle > 45 and $angle <= 135 {
    border-left-color: $color;
    border-width: ($height * $deg) 0 ($height * abs($deg - 1)) $width;
  }
  @if $angle > 135 and $angle <= 225 {
    border-top-color: $color;
    border-width: $height ($width * $deg) 0 ($width * abs($deg - 1));
  }
  @if $angle > 225 and $angle <= 315 {
    border-right-color: $color;
    border-width: ($height * abs($deg - 1)) $width ($height * $deg) 0;
  }
}

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
toolkit-1.3.8 stylesheets/toolkit/_triangle.scss
toolkit-1.3.7 stylesheets/toolkit/_triangle.scss
toolkit-1.3.6 stylesheets/toolkit/_triangle.scss
toolkit-1.3.5 stylesheets/toolkit/_triangle.scss
toolkit-1.3.4 stylesheets/toolkit/_triangle.scss
toolkit-1.3.3 stylesheets/toolkit/_triangle.scss
toolkit-1.3.2 stylesheets/toolkit/_triangle.scss
toolkit-1.3.1 stylesheets/toolkit/_triangle.scss
toolkit-1.3.0 stylesheets/toolkit/_triangle.scss
toolkit-1.2.2 stylesheets/toolkit/_triangle.scss