summaryrefslogtreecommitdiffhomepage
path: root/packages/css/src/components/select.css
blob: 2403bfb26388c23a0c1dcd331f45d0ce5f726997 (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
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
119
120
[data-component="select"] {
  &:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }

  &:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--color-primary);
  }

  [data-slot="section"] {
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-light);
    text-transform: uppercase;
    color: var(--text-default-text-weak);
    opacity: 0.6;
    margin-top: calc(var(--spacing) * 3);
    margin-left: calc(var(--spacing) * 2);
    &:first-child {
      margin-top: 0;
    }
  }

  [data-slot="item"] {
    position: relative;
    display: flex;
    align-items: center;
    padding: calc(var(--spacing) * 2) calc(var(--spacing) * 2);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--text-default-text);
    cursor: pointer;
    transition:
      background-color 0.2s ease-in-out,
      color 0.2s ease-in-out;
    outline: none;
    user-select: none;

    &[data-highlighted] {
      background-color: var(--surface-default-surface);
    }

    &[data-disabled] {
      pointer-events: none;
      opacity: 0.5;
    }

    [data-slot="item-indicator"] {
      margin-left: auto;
    }
  }

  [data-slot="trigger"] {
    [data-slot="value"] {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    [data-slot="icon"] {
      width: fit-content;
      height: fit-content;
      flex-shrink: 0;
      color: var(--text-default-text-weak);
      transition: transform 0.1s ease-in-out;
    }
  }
}

[data-component="select-content"] {
  min-width: 8rem;
  overflow: hidden;
  border-radius: var(--radius-md);
  border-width: 1px;
  border-style: solid;
  border-color: var(--border-default-border-weak);
  background-color: var(--surface-raised-surface-raised);
  padding: calc(var(--spacing) * 1);
  box-shadow: var(--shadow-md);
  z-index: 50;

  &[data-closed] {
    animation: select-close 0.15s ease-out;
  }

  &[data-expanded] {
    animation: select-open 0.15s ease-out;
  }

  [data-slot="list"] {
    overflow-y: auto;
    max-height: 12rem;
    white-space: nowrap;
    overflow-x: hidden;
  }
}

@keyframes select-open {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes select-close {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.95);
  }
}