bulma/sass/utilities/functions.scss

311 lines
7.7 KiB
SCSS
Raw Normal View History

2024-11-11 10:22:12 +00:00
@use "sass:color";
2024-03-21 16:11:54 +00:00
@use "sass:list";
2024-11-11 10:22:12 +00:00
@use "sass:map";
2024-03-21 16:11:54 +00:00
@use "sass:math";
2024-11-11 10:22:12 +00:00
@use "sass:meta";
@use "sass:string";
2024-03-21 16:11:54 +00:00
@function mergeColorMaps($bulma-colors, $custom-colors) {
// We return at least Bulma's hard-coded colors
$merged-colors: $bulma-colors;
// We want a map as input
2024-11-11 10:22:12 +00:00
@if meta.type-of($custom-colors) == "map" {
2024-03-21 16:11:54 +00:00
@each $name, $components in $custom-colors {
// The color name should be a string
// and the components either a single color
// or a colors list with at least one element
2024-11-11 10:22:12 +00:00
@if meta.type-of($name) ==
2024-03-21 16:11:54 +00:00
"string" and
2024-11-11 10:22:12 +00:00
(
2024-11-11 10:32:08 +00:00
meta.type-of($components) ==
"list" or
meta.type-of($components) ==
"color"
2024-11-11 10:22:12 +00:00
) and
2024-11-11 10:32:08 +00:00
list.length($components) >=
2024-03-21 16:11:54 +00:00
1
{
$color-base: null;
$color-invert: null;
$color-light: null;
$color-dark: null;
$value: null;
// The param can either be a single color
// or a list of 2 colors
2024-11-11 10:22:12 +00:00
@if meta.type-of($components) == "color" {
2024-03-21 16:11:54 +00:00
$color-base: $components;
$color-invert: bulmaFindColorInvert($color-base);
$color-light: bulmaFindLightColor($color-base);
$color-dark: bulmaFindDarkColor($color-base);
2024-11-11 10:22:12 +00:00
} @else if meta.type-of($components) == "list" {
2024-03-21 16:11:54 +00:00
$color-base: list.nth($components, 1);
// If Invert, Light and Dark are provided
2024-11-11 10:32:08 +00:00
@if list.length($components) > 3 {
2024-03-21 16:11:54 +00:00
$color-invert: list.nth($components, 2);
$color-light: list.nth($components, 3);
$color-dark: list.nth($components, 4);
// If only Invert and Light are provided
2024-11-11 10:32:08 +00:00
} @else if list.length($components) > 2 {
2024-03-21 16:11:54 +00:00
$color-invert: list.nth($components, 2);
$color-light: list.nth($components, 3);
$color-dark: bulmaFindDarkColor($color-base);
// If only Invert is provided
} @else {
$color-invert: list.nth($components, 2);
$color-light: bulmaFindLightColor($color-base);
$color-dark: bulmaFindDarkColor($color-base);
}
}
$value: $color-base, $color-invert, $color-light, $color-dark;
// We only want to merge the map if the color base is an actual color
2024-11-11 10:22:12 +00:00
@if meta.type-of($color-base) == "color" {
2024-03-21 16:11:54 +00:00
// We merge this colors elements as map with Bulma's colors map
// (we can override them this way, no multiple definition for the same name)
// $merged-colors: map_merge($merged-colors, ($name: ($color-base, $color-invert, $color-light, $color-dark)))
2024-11-11 10:32:08 +00:00
$merged-colors: map.merge(
2024-03-21 16:11:54 +00:00
$merged-colors,
(
$name: $value,
)
);
}
}
}
}
@return $merged-colors;
}
@function powerNumber($number, $exp) {
$value: 1;
@if $exp > 0 {
@for $i from 1 through $exp {
$value: $value * $number;
}
} @else if $exp < 0 {
@for $i from 1 through -$exp {
$value: math.div($value, $number);
}
}
@return $value;
}
@function bulmaColorLuminance($color) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) != "color" {
2024-03-21 16:11:54 +00:00
@return 0.55;
}
$color-rgb: (
2024-11-11 10:22:12 +00:00
"red": color.channel($color, "red", $space: rgb),
"green": color.channel($color, "green", $space: rgb),
"blue": color.channel($color, "blue", $space: rgb),
2024-03-21 16:11:54 +00:00
);
@each $name, $value in $color-rgb {
$adjusted: 0;
$value: math.div($value, 255);
@if $value < 0.03928 {
$value: math.div($value, 12.92);
} @else {
$value: math.div($value + 0.055, 1.055);
$value: powerNumber($value, 2);
}
2024-11-11 10:22:12 +00:00
$color-rgb: map.merge(
2024-03-21 16:11:54 +00:00
$color-rgb,
(
$name: $value,
)
);
}
2024-11-11 10:22:12 +00:00
@return map.get($color-rgb, "red") * 0.2126 + map.get($color-rgb, "green") *
0.7152 + map.get($color-rgb, "blue") * 0.0722;
2024-03-21 16:11:54 +00:00
}
@function bulmaFindColorInvert($color) {
@if bulmaColorLuminance($color) > 0.55 {
@return rgba(#000, 0.7);
} @else {
@return #fff;
}
}
@function bulmaFindLightColor($color, $l: 96%) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) == "color" {
2024-03-21 16:11:54 +00:00
$l: 96%;
2024-11-11 10:22:12 +00:00
@if color.channel($color, "lightness", $space: hsl) > 96% {
$l: color.channel($color, "lightness", $space: hsl);
2024-03-21 16:11:54 +00:00
}
2024-11-11 10:32:08 +00:00
@return color.change($color, $lightness: $l);
2024-03-21 16:11:54 +00:00
}
@return $background;
}
@function bulmaFindDarkColor($color, $base-l: 29%) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) == "color" {
2024-03-21 16:11:54 +00:00
$luminance: bulmaColorLuminance($color);
$luminance-delta: 0.53 - $luminance;
$target-l: math.round($base-l + $luminance-delta * 53);
2024-03-21 16:11:54 +00:00
2024-11-11 10:32:08 +00:00
@return color.change($color, $lightness: max($base-l, $target-l));
2024-03-21 16:11:54 +00:00
}
@return $text-strong;
}
@function bulmaRgba($color, $alpha) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) != "color" {
2024-03-21 16:11:54 +00:00
@return $color;
}
@return rgba($color, $alpha);
}
@function bulmaDarken($color, $amount) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) != "color" {
2024-03-21 16:11:54 +00:00
@return $color;
}
2024-11-11 10:22:12 +00:00
@return color.adjust($color, $lightness: -$amount, $space: hsl);
2024-03-21 16:11:54 +00:00
}
@function bulmaLighten($color, $amount) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($color) != "color" {
2024-03-21 16:11:54 +00:00
@return $color;
}
2024-11-11 10:22:12 +00:00
@return color.adjust($color, $lightness: $amount, $space: hsl);
2024-03-21 16:11:54 +00:00
}
@function bulmaColorBrightness($n) {
$color-brightness: math.round(
2024-11-11 10:22:12 +00:00
math.div(
(color.channel($n, "red", $space: rgb) * 299) +
(color.channel($n, "green", $space: rgb) * 587) +
(color.channel($n, "blue", $space: rgb) * 114),
1000
)
2024-03-21 16:11:54 +00:00
);
$light-color: math.round(
2024-11-11 10:22:12 +00:00
math.div(
(color.channel(#ffffff, "red", $space: rgb) * 299) +
(color.channel(#ffffff, "green", $space: rgb) * 587) +
(color.channel(#ffffff, "blue", $space: rgb) * 114),
1000
)
2024-03-21 16:11:54 +00:00
);
@if abs($color-brightness) < math.div($light-color, 2) {
@return "dark";
}
@return "bright";
}
@function bulmaEnoughContrast($foreground, $background) {
2024-11-11 10:22:12 +00:00
$r: (
max(
color.channel($foreground, "red", $space: rgb),
color.channel($background, "red", $space: rgb)
)
) -
(
min(
color.channel($foreground, "red", $space: rgb),
color.channel($background, "red", $space: rgb)
)
);
$g: (
max(
color.channel($foreground, "green", $space: rgb),
color.channel($background, "green", $space: rgb)
)
) -
(
min(
color.channel($foreground, "green", $space: rgb),
color.channel($background, "green", $space: rgb)
)
);
$b: (
max(
color.channel($foreground, "blue", $space: rgb),
color.channel($background, "blue", $space: rgb)
)
) -
(
min(
color.channel($foreground, "blue", $space: rgb),
color.channel($background, "blue", $space: rgb)
)
);
2024-03-21 16:11:54 +00:00
$sum-rgb: $r + $g + $b;
@if $sum-rgb < 500 {
@return false;
}
@return true;
}
// By Cory Simmons https://corysimmons.com/
@function bulmaStringToNumber($value) {
2024-11-11 10:22:12 +00:00
@if meta.type-of($value) == "number" {
2024-03-21 16:11:54 +00:00
@return $value;
2024-11-11 10:22:12 +00:00
} @else if meta.type-of($value) != "string" {
2024-03-21 16:11:54 +00:00
$_: log("Value for `to-number` should be a number or a string.");
}
$result: 0;
$digits: 0;
2024-11-11 10:22:12 +00:00
$minus: string.slice($value, 1, 1) == "-";
2024-03-21 16:11:54 +00:00
$numbers: (
"0": 0,
"1": 1,
"2": 2,
"3": 3,
"4": 4,
"5": 5,
"6": 6,
"7": 7,
"8": 8,
"9": 9,
);
2024-11-11 10:22:12 +00:00
@for $i from if($minus, 2, 1) through string.length($value) {
$character: string.slice($value, $i, $i);
2024-03-21 16:11:54 +00:00
2024-11-11 10:22:12 +00:00
@if not(list.index(map.keys($numbers), $character) or $character == ".") {
@return to-length(
if($minus, -$result, $result),
string.slice($value, $i)
);
2024-03-21 16:11:54 +00:00
}
@if $character == "." {
$digits: 1;
} @else if $digits == 0 {
2024-11-11 10:22:12 +00:00
$result: $result * 10 + map.get($numbers, $character);
2024-03-21 16:11:54 +00:00
} @else {
$digits: $digits * 10;
2024-11-11 10:22:12 +00:00
$result: $result + map.get($numbers, $character) / $digits;
2024-03-21 16:11:54 +00:00
}
}
@return if($minus, -$result, $result);
}