summaryrefslogtreecommitdiffhomepage
path: root/packages/ui/src/components/text-field.css
blob: c94376be742c6c360b18ecc45d483d22b4effb24 (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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
[data-component="input"] {
  width: 100%;

  [data-slot="input-input"] {
    width: 100%;
    color: var(--text-strong);

    /* text-14-regular */
    font-family: var(--font-family-sans);
    font-size: 14px;
    font-style: normal;
    font-weight: var(--font-weight-regular);
    line-height: var(--line-height-large); /* 142.857% */
    letter-spacing: var(--letter-spacing-normal);

    &:focus {
      outline: none;
    }

    &::placeholder {
      color: var(--text-weak);
    }
  }

  &[data-variant="normal"] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;

    [data-slot="input-label"] {
      color: var(--text-weak);

      /* text-12-medium */
      font-family: var(--font-family-sans);
      font-size: var(--font-size-small);
      font-style: normal;
      font-weight: var(--font-weight-medium);
      line-height: 18px; /* 150% */
      letter-spacing: var(--letter-spacing-normal);
    }

    [data-slot="input-wrapper"] {
      display: flex;
      align-items: start;
      justify-content: space-between;
      width: 100%;
      padding-right: 4px;

      border-radius: var(--radius-md);
      border: 1px solid var(--border-weak-base);
      background: var(--input-base);

      &:focus-within:not(:has([data-readonly])) {
        border-color: transparent;
        /* border/shadow-xs/select */
        box-shadow:
          0 0 0 3px var(--border-weak-selected),
          0 0 0 1px var(--border-selected),
          0 1px 2px -1px rgba(19, 16, 16, 0.25),
          0 1px 2px 0 rgba(19, 16, 16, 0.08),
          0 1px 3px 0 rgba(19, 16, 16, 0.12);
      }

      &:has([data-invalid]) {
        background: var(--surface-critical-weak);
        border: 1px solid var(--border-critical-selected);
      }

      &:not(:has([data-slot="input-copy-button"])) {
        padding-right: 0;
      }
    }

    [data-slot="input-input"] {
      color: var(--text-strong);

      display: flex;
      height: 32px;
      padding: 2px 12px;
      align-items: center;
      flex: 1;
      min-width: 0;

      background: transparent;
      border: none;

      /* text-14-regular */
      font-family: var(--font-family-sans);
      font-size: 14px;
      font-style: normal;
      font-weight: var(--font-weight-regular);
      line-height: var(--line-height-large); /* 142.857% */
      letter-spacing: var(--letter-spacing-normal);

      &:focus {
        outline: none;
      }

      &::placeholder {
        color: var(--text-weak);
      }
    }

    textarea[data-slot="input-input"] {
      height: auto;
      min-height: 32px;
      padding: 6px 12px;
      resize: none;
    }

    [data-slot="input-copy-button"] {
      flex-shrink: 0;
      margin-top: 4px;
      color: var(--icon-base);

      &:hover {
        color: var(--icon-strong-base);
      }
    }

    [data-slot="input-error"] {
      color: var(--text-on-critical-base);

      /* text-12-medium */
      font-family: var(--font-family-sans);
      font-size: var(--font-size-small);
      font-style: normal;
      font-weight: var(--font-weight-medium);
      line-height: 18px; /* 150% */
      letter-spacing: var(--letter-spacing-normal);
    }
  }
}