mirror of
https://github.com/jgthms/bulma.git
synced 2025-01-09 15:44:25 +00:00
199 lines
6.5 KiB
Sass
199 lines
6.5 KiB
Sass
@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
|
|
@if type-of($custom-colors) == 'map'
|
|
@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
|
|
@if type-of($name) == 'string' and (type-of($components) == 'list' or type-of($components) == 'color') and length($components) >= 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
|
|
@if type-of($components) == 'color'
|
|
$color-base: $components
|
|
$color-invert: findColorInvert($color-base)
|
|
$color-light: findLightColor($color-base)
|
|
$color-dark: findDarkColor($color-base)
|
|
@else if type-of($components) == 'list'
|
|
$color-base: nth($components, 1)
|
|
// If Invert, Light and Dark are provided
|
|
@if length($components) > 3
|
|
$color-invert: nth($components, 2)
|
|
$color-light: nth($components, 3)
|
|
$color-dark: nth($components, 4)
|
|
// If only Invert and Light are provided
|
|
@else if length($components) > 2
|
|
$color-invert: nth($components, 2)
|
|
$color-light: nth($components, 3)
|
|
$color-dark: findDarkColor($color-base)
|
|
// If only Invert is provided
|
|
@else
|
|
$color-invert: nth($components, 2)
|
|
$color-light: findLightColor($color-base)
|
|
$color-dark: findDarkColor($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
|
|
@if type-of($color-base) == 'color'
|
|
// 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)))
|
|
$merged-colors: map_merge($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: $value / $number
|
|
@return $value
|
|
|
|
@function colorLuminance($color)
|
|
@if type-of($color) != 'color'
|
|
@return 0.55
|
|
$color-rgb: ('red': red($color),'green': green($color),'blue': blue($color))
|
|
@each $name, $value in $color-rgb
|
|
$adjusted: 0
|
|
$value: $value / 255
|
|
@if $value < 0.03928
|
|
$value: $value / 12.92
|
|
@else
|
|
$value: ($value + .055) / 1.055
|
|
$value: powerNumber($value, 2)
|
|
$color-rgb: map-merge($color-rgb, ($name: $value))
|
|
@return (map-get($color-rgb, 'red') * .2126) + (map-get($color-rgb, 'green') * .7152) + (map-get($color-rgb, 'blue') * .0722)
|
|
|
|
@function findColorInvert($color, $fallback: null)
|
|
@if type-of($color) == 'color'
|
|
@if (colorLuminance($color) > 0.55)
|
|
@return rgba(0, 0, 0, 0.7)
|
|
@else
|
|
@return #fff
|
|
@else if type-of($fallback) == 'color'
|
|
@if (colorLuminance($fallback) > 0.55)
|
|
@return rgba(0, 0, 0, 0.7)
|
|
@else
|
|
@return #fff
|
|
@return $color
|
|
|
|
@function findLightColor($color, $fallback: null)
|
|
@if type-of($color) == 'color'
|
|
$l: 96%
|
|
@if lightness($color) > 96%
|
|
$l: lightness($color)
|
|
@return change-color($color, $lightness: $l)
|
|
@else if type-of($fallback) == 'color'
|
|
$l: 96%
|
|
@if lightness($fallback) > 96%
|
|
$l: lightness($fallback)
|
|
@return change-color($fallback, $lightness: $l)
|
|
@return $color
|
|
|
|
@function calculateDarkColor($color)
|
|
$base-l: 29%
|
|
$luminance: colorLuminance($color)
|
|
$luminance-delta: (0.53 - $luminance)
|
|
$target-l: round($base-l + ($luminance-delta * 53))
|
|
@return change-color($color, $lightness: max($base-l, $target-l))
|
|
|
|
@function findDarkColor($color, $fallback: null)
|
|
@if type-of($color) == 'color'
|
|
@return calculateDarkColor($color)
|
|
@else if type-of($fallback) == 'color'
|
|
@return calculateDarkColor($fallback)
|
|
@return $color
|
|
|
|
@function bulmaRgba($color, $alpha)
|
|
@if type-of($color) != 'color'
|
|
@return $color
|
|
@return rgba($color, $alpha)
|
|
|
|
@function bulmaDarken($color, $amount)
|
|
@if type-of($color) != 'color'
|
|
@return $color
|
|
@return darken($color, $amount)
|
|
|
|
@function bulmaLighten($color, $amount)
|
|
@if type-of($color) != 'color'
|
|
@return $color
|
|
@return lighten($color, $amount)
|
|
|
|
@function bulmaToRGB($color)
|
|
@return red($color), green($color), blue($color)
|
|
|
|
=registerCSSVar($name, $value, $at-root: true)
|
|
@if $at-root
|
|
@at-root :root
|
|
--#{$name}: #{$value}
|
|
@else
|
|
--#{$name}: #{$value}
|
|
|
|
=registerCSSVars($list, $at-root: true)
|
|
@if $at-root
|
|
@at-root :root
|
|
@each $name, $value in $list
|
|
--#{$name}: #{$value}
|
|
@else
|
|
@each $name, $value in $list
|
|
--#{$name}: #{$value}
|
|
|
|
// bulmaDarken($color, 5%)
|
|
// bulmaDarken($color, 10%)
|
|
// bulmaDarken($color, 2.5%)
|
|
// bulmaRgba($color, 0.25)
|
|
// bulmaDarken($color-light, 10%)
|
|
// bulmaDarken($color-light, 2.5%)
|
|
// bulmaDarken($color-light, 5%)
|
|
// bulmaLighten($color-dark, 10%)
|
|
// bulmaDarken($color-invert, 5%)
|
|
// bulmaRgba($color-invert, 0.9)
|
|
// bulmaRgba($color-invert, 0.7)
|
|
=registerCSSVarColor($name, $components, $prefix: '')
|
|
$color: nth($components, 1)
|
|
$base: $prefix + $name
|
|
|
|
--#{$base}-h: #{hue($color)}
|
|
--#{$base}-s: #{saturation($color)}
|
|
--#{$base}-l: #{lightness($color)}
|
|
--#{$base}-a: 1
|
|
--#{$base}: hsla(var(--#{$base}-h), var(--#{$base}-s), var(--#{$base}-l), var(--#{$base}-a))
|
|
|
|
// Invert color
|
|
--#{$base}-invert: #{findColorInvert($color)}
|
|
|
|
// Light color
|
|
$light-l: 96%
|
|
@if lightness($color) > 96%
|
|
$light-l: lightness($color)
|
|
--#{$base}-light-l: #{$light-l}
|
|
--#{$base}-light: hsla(var(--#{$base}-h), var(--#{$base}-s), var(--#{$base}-light-l), var(--#{$base}-a))
|
|
|
|
// Dark color
|
|
$base-l: 29%
|
|
$luminance: colorLuminance($color)
|
|
$luminance-delta: (0.53 - $luminance)
|
|
$dark-l: round($base-l + ($luminance-delta * 53))
|
|
--#{$base}-dark-l: #{$dark-l}
|
|
--#{$base}-dark: hsla(var(--#{$base}-h), var(--#{$base}-s), var(--#{$base}-dark-l), var(--#{$base}-a))
|
|
|
|
=registerCSSVarColors($colors, $prefix: '')
|
|
@each $name, $components in $colors
|
|
+registerCSSVarColor($name, $components, $prefix)
|
|
|
|
@function assignCSSVar($name, $fallback)
|
|
// +registerCSSVar($name, $fallback)
|
|
@return var(--#{$name}, #{$fallback})
|