summaryrefslogtreecommitdiff
path: root/scss/_lib.scss
blob: ef8cc8d536c0f65c69096c7aac44d864c9a0afaa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
@use "sass:color";
@use "scheme";
@use "font";

$scale: 0.068rem;
@function s($value: 1) {
    @return $value * $scale;
}

@mixin rounded($all, $tl: $all, $tr: $all, $br: $all, $bl: $all) {
    border-radius: s($tl) s($tr) s($br) s($bl);
    -gtk-outline-radius: s($tl) s($tr) s($br) s($bl);
}

@mixin border($colour, $alpha: 1, $width: 1, $style: solid, $force: false) {
    @if $force or scheme.$borders {
        border: s($width) $style color.change($colour, $alpha: $alpha);
    }
}

@mixin shadow($colour: black, $alpha: 0.64, $x: 0, $y: 0, $blur: 3, $spread: 0) {
    box-shadow: s($x) s($y) s($blur) s($spread) color.change($colour, $alpha: $alpha);
}

@mixin spacing($val: 5, $vertical: false) {
    $dir: if($vertical, bottom, right);

    & > *:not(:last-child) {
        margin-#{$dir}: s($val);
    }
}

@mixin element-decel($duration: 200ms) {
    transition: $duration cubic-bezier(0, 0.55, 0.45, 1);
}

@mixin fluent-decel($duration: 200ms) {
    transition: $duration cubic-bezier(0.1, 1, 0, 1);
}

@mixin overshot {
    transition-timing-function: cubic-bezier(0.05, 0.9, 0.1, 1.1);
}

@mixin ease-in-out {
    transition-timing-function: cubic-bezier(0.85, 0, 0.15, 1);
}