_triangle.scss 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. @mixin triangle($size, $color, $direction) {
  2. $width: nth($size, 1);
  3. $height: nth($size, length($size));
  4. $foreground-color: nth($color, 1);
  5. $background-color: if(length($color) == 2, nth($color, 2), transparent);
  6. height: 0;
  7. width: 0;
  8. @if ($direction == up) or ($direction == down) or ($direction == right) or ($direction == left) {
  9. $width: $width / 2;
  10. $height: if(length($size) > 1, $height, $height/2);
  11. @if $direction == up {
  12. border-bottom: $height solid $foreground-color;
  13. border-left: $width solid $background-color;
  14. border-right: $width solid $background-color;
  15. } @else if $direction == right {
  16. border-bottom: $width solid $background-color;
  17. border-left: $height solid $foreground-color;
  18. border-top: $width solid $background-color;
  19. } @else if $direction == down {
  20. border-left: $width solid $background-color;
  21. border-right: $width solid $background-color;
  22. border-top: $height solid $foreground-color;
  23. } @else if $direction == left {
  24. border-bottom: $width solid $background-color;
  25. border-right: $height solid $foreground-color;
  26. border-top: $width solid $background-color;
  27. }
  28. } @else if ($direction == up-right) or ($direction == up-left) {
  29. border-top: $height solid $foreground-color;
  30. @if $direction == up-right {
  31. border-left: $width solid $background-color;
  32. } @else if $direction == up-left {
  33. border-right: $width solid $background-color;
  34. }
  35. } @else if ($direction == down-right) or ($direction == down-left) {
  36. border-bottom: $height solid $foreground-color;
  37. @if $direction == down-right {
  38. border-left: $width solid $background-color;
  39. } @else if $direction == down-left {
  40. border-right: $width solid $background-color;
  41. }
  42. } @else if ($direction == inset-up) {
  43. border-color: $background-color $background-color $foreground-color;
  44. border-style: solid;
  45. border-width: $height $width;
  46. } @else if ($direction == inset-down) {
  47. border-color: $foreground-color $background-color $background-color;
  48. border-style: solid;
  49. border-width: $height $width;
  50. } @else if ($direction == inset-right) {
  51. border-color: $background-color $background-color $background-color $foreground-color;
  52. border-style: solid;
  53. border-width: $width $height;
  54. } @else if ($direction == inset-left) {
  55. border-color: $background-color $foreground-color $background-color $background-color;
  56. border-style: solid;
  57. border-width: $width $height;
  58. }
  59. }