summaryrefslogtreecommitdiffstats
path: root/packages/excalidraw/components/Switch.scss
blob: 894f806060bb6581c4c9137bad69bc7fe229e25f (plain) (blame)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
@import "../css/variables.module.scss";

.excalidraw {
  --Switch-disabled-color: var(--color-border-outline);
  --Switch-disabled-toggled-background: var(--color-border-outline-variant);
  --Switch-disabled-border: var(--color-border-outline-variant);
  --Switch-track-background: var(--island-bg-color);
  --Switch-thumb-background: var(--color-on-surface);
  --Switch-hover-background: var(--color-brand-hover);
  --Switch-active-background: var(--color-brand-active);

  .Switch {
    position: relative;
    box-sizing: border-box;

    width: 40px;
    height: 20px;
    border-radius: 12px;

    transition-property: background, border;
    transition-duration: 150ms;
    transition-timing-function: ease-out;

    background: var(--Switch-track-background);
    border: 1px solid var(--Switch-disabled-color);

    &:hover {
      background: var(--Switch-track-background);
      border: 1px solid var(--Switch-hover-background);
    }

    &:active {
      border: 1px solid var(--Switch-active-background);
    }

    &.toggled {
      background: var(--color-primary);
      border: 1px solid var(--color-primary);

      &:hover {
        background: var(--color-primary-darker);
        border: 1px solid var(--color-primary-darker);
      }
    }

    &.disabled {
      background: var(--Switch-track-background);
      border: 1px solid var(--Switch-disabled-border);

      &.toggled {
        background: var(--Switch-disabled-toggled-background);
        border: 1px solid var(--Switch-disabled-toggled-background);
      }
    }

    &:before {
      content: "";
      box-sizing: border-box;
      display: block;
      pointer-events: none;
      position: absolute;

      border-radius: 100%;
      transition: all 150ms ease-out;

      width: 10px;
      height: 10px;
      top: 4px;
      left: 4px;

      background: var(--Switch-thumb-background);
    }

    &:active:before {
      width: 12px;
    }

    &.toggled:before {
      width: 14px;
      height: 14px;
      left: 22px;
      top: 2px;

      background: var(--Switch-track-background);
    }

    &.toggled:active:before {
      width: 16px;
      left: 20px;
    }

    &.disabled:before {
      background: var(--Switch-disabled-color);
    }

    &.disabled.toggled:before {
      background: var(--Switch-disabled-color);
    }

    & input {
      width: 100%;
      height: 100%;
      margin: 0;

      border-radius: 12px;

      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;

      cursor: pointer;

      &:disabled {
        cursor: unset;
      }
    }
  }
}