@taiga-ui/core 4.5.0 → 4.6.0-canary.0a513eb

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/components/data-list/data-list.component.d.ts +3 -1
  2. package/components/dialog/dialog.component.d.ts +1 -1
  3. package/components/dialog/dialogs.component.d.ts +2 -2
  4. package/components/error/error.component.d.ts +1 -1
  5. package/components/notification/notification.directive.d.ts +1 -1
  6. package/components/textfield/textfield.component.d.ts +8 -7
  7. package/components/textfield/textfield.directive.d.ts +1 -2
  8. package/directives/appearance/appearance.directive.d.ts +3 -2
  9. package/directives/appearance/appearance.options.d.ts +6 -1
  10. package/directives/dropdown/dropdown.directive.d.ts +1 -1
  11. package/directives/hint/hint-describe.directive.d.ts +1 -0
  12. package/directives/hint/hint.component.d.ts +1 -1
  13. package/esm2022/components/alert/alert.component.mjs +6 -6
  14. package/esm2022/components/alert/alerts.component.mjs +2 -1
  15. package/esm2022/components/calendar/calendar-sheet.component.mjs +5 -5
  16. package/esm2022/components/calendar/calendar-spin.component.mjs +3 -3
  17. package/esm2022/components/calendar/calendar-year.component.mjs +3 -3
  18. package/esm2022/components/calendar/calendar.component.mjs +5 -5
  19. package/esm2022/components/data-list/data-list.component.mjs +13 -7
  20. package/esm2022/components/dialog/dialog.component.mjs +6 -5
  21. package/esm2022/components/dialog/dialogs.component.mjs +8 -15
  22. package/esm2022/components/error/error.component.mjs +8 -8
  23. package/esm2022/components/expand/expand.component.mjs +3 -3
  24. package/esm2022/components/root/root.component.mjs +7 -7
  25. package/esm2022/components/scrollbar/scroll-controls.component.mjs +5 -5
  26. package/esm2022/components/scrollbar/scrollbar.component.mjs +3 -3
  27. package/esm2022/components/scrollbar/scrollbar.directive.mjs +3 -3
  28. package/esm2022/components/spin-button/spin-button.component.mjs +3 -3
  29. package/esm2022/components/textfield/select.directive.mjs +3 -3
  30. package/esm2022/components/textfield/textfield.component.mjs +20 -15
  31. package/esm2022/components/textfield/textfield.directive.mjs +4 -6
  32. package/esm2022/directives/appearance/appearance.directive.mjs +1 -1
  33. package/esm2022/directives/appearance/appearance.options.mjs +1 -1
  34. package/esm2022/directives/dropdown/dropdown.component.mjs +2 -2
  35. package/esm2022/directives/dropdown/dropdown.directive.mjs +1 -2
  36. package/esm2022/directives/group/group.directive.mjs +5 -5
  37. package/esm2022/directives/hint/hint-describe.directive.mjs +5 -4
  38. package/esm2022/directives/hint/hint-unstyled.component.mjs +3 -3
  39. package/esm2022/directives/hint/hint.component.mjs +4 -3
  40. package/esm2022/directives/hint/hints.component.mjs +3 -3
  41. package/fesm2022/taiga-ui-core-components-alert.mjs +5 -5
  42. package/fesm2022/taiga-ui-core-components-alert.mjs.map +1 -1
  43. package/fesm2022/taiga-ui-core-components-calendar.mjs +13 -13
  44. package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
  45. package/fesm2022/taiga-ui-core-components-data-list.mjs +12 -6
  46. package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
  47. package/fesm2022/taiga-ui-core-components-dialog.mjs +10 -18
  48. package/fesm2022/taiga-ui-core-components-dialog.mjs.map +1 -1
  49. package/fesm2022/taiga-ui-core-components-error.mjs +7 -7
  50. package/fesm2022/taiga-ui-core-components-error.mjs.map +1 -1
  51. package/fesm2022/taiga-ui-core-components-expand.mjs +2 -2
  52. package/fesm2022/taiga-ui-core-components-expand.mjs.map +1 -1
  53. package/fesm2022/taiga-ui-core-components-root.mjs +7 -7
  54. package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
  55. package/fesm2022/taiga-ui-core-components-scrollbar.mjs +8 -8
  56. package/fesm2022/taiga-ui-core-components-scrollbar.mjs.map +1 -1
  57. package/fesm2022/taiga-ui-core-components-spin-button.mjs +3 -3
  58. package/fesm2022/taiga-ui-core-components-spin-button.mjs.map +1 -1
  59. package/fesm2022/taiga-ui-core-components-textfield.mjs +26 -21
  60. package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
  61. package/fesm2022/taiga-ui-core-directives-appearance.mjs.map +1 -1
  62. package/fesm2022/taiga-ui-core-directives-dropdown.mjs +2 -2
  63. package/fesm2022/taiga-ui-core-directives-dropdown.mjs.map +1 -1
  64. package/fesm2022/taiga-ui-core-directives-group.mjs +4 -4
  65. package/fesm2022/taiga-ui-core-directives-group.mjs.map +1 -1
  66. package/fesm2022/taiga-ui-core-directives-hint.mjs +9 -8
  67. package/fesm2022/taiga-ui-core-directives-hint.mjs.map +1 -1
  68. package/package.json +324 -324
  69. package/styles/components/group.less +10 -33
  70. package/styles/components/textfield.less +40 -22
  71. package/styles/theme/appearance/textfield.less +5 -0
  72. package/styles/theme/palette.less +4 -2
@@ -26,26 +26,23 @@
26
26
 
27
27
  --t-group-radius: var(--tui-radius-l);
28
28
  --t-group-margin: -1px;
29
- --t-group-clip: inset(-1px 1px -1px -1px);
29
+ --t-group-clip: inset(-1rem 1px -1rem -1rem);
30
30
 
31
31
  & > * {
32
32
  z-index: 1;
33
33
  flex: 1 1 0;
34
34
  min-inline-size: 0;
35
35
 
36
- &._disabled,
37
- &._disabled:hover {
36
+ &:disabled,
37
+ &._disabled {
38
38
  z-index: 0;
39
39
  }
40
40
 
41
- &:invalid {
41
+ &:invalid,
42
+ &[data-mode='invalid'] {
42
43
  z-index: 2;
43
44
 
44
45
  --t-group-clip: none;
45
-
46
- &:hover {
47
- z-index: 4;
48
- }
49
46
  }
50
47
 
51
48
  &:has(:invalid),
@@ -53,44 +50,28 @@
53
50
  z-index: 2;
54
51
 
55
52
  --t-group-clip: none;
56
-
57
- &:hover {
58
- z-index: 4;
59
- }
60
- }
61
-
62
- &:hover {
63
- z-index: 3;
64
-
65
- --t-group-clip: inset(-1px 0.5px -1px -1px);
66
- }
67
-
68
- &:has([data-state='hover']) {
69
- z-index: 3;
70
-
71
- --t-group-clip: none;
72
53
  }
73
54
 
74
55
  &:focus-within {
75
- z-index: 5;
56
+ z-index: 3;
76
57
 
77
58
  --t-group-clip: none;
78
59
  }
79
60
 
80
61
  &:has([data-focus='true']) {
81
- z-index: 5;
62
+ z-index: 3;
82
63
 
83
64
  --t-group-clip: none;
84
65
  }
85
66
 
86
67
  &[data-mode='checked'] {
87
- z-index: 6;
68
+ z-index: 4;
88
69
 
89
70
  --t-group-clip: none;
90
71
  }
91
72
 
92
73
  &:has([tuiBlock]:checked) {
93
- z-index: 6;
74
+ z-index: 4;
94
75
 
95
76
  --t-group-clip: none;
96
77
  }
@@ -124,7 +105,7 @@
124
105
  display: inline-flex;
125
106
  flex-direction: column;
126
107
 
127
- --t-group-clip: inset(-1px -1px 1px -1px);
108
+ --t-group-clip: inset(-1rem -1rem 1px -1rem);
128
109
 
129
110
  & > * {
130
111
  min-block-size: auto;
@@ -146,10 +127,6 @@
146
127
  &:only-child {
147
128
  border-radius: var(--t-group-radius);
148
129
  }
149
-
150
- &:hover {
151
- --t-group-clip: inset(-1px -1px 0.5px -1px);
152
- }
153
130
  }
154
131
  }
155
132
  }
@@ -25,10 +25,6 @@ tui-textfield {
25
25
  --t-right: 2.25rem;
26
26
  }
27
27
 
28
- &::before {
29
- margin-inline-end: 0.75rem;
30
- }
31
-
32
28
  &::after {
33
29
  margin-inline-start: 0.25rem;
34
30
  }
@@ -59,7 +55,7 @@ tui-textfield {
59
55
  }
60
56
 
61
57
  &::after {
62
- margin: 0 -0.175rem 0 0.25rem;
58
+ margin: 0 -0.175rem 0 0.575rem;
63
59
  font-size: 1rem;
64
60
  }
65
61
 
@@ -70,6 +66,7 @@ tui-textfield {
70
66
 
71
67
  .t-content {
72
68
  gap: 0;
69
+ margin-inline-end: -0.325rem;
73
70
  }
74
71
  }
75
72
 
@@ -93,13 +90,17 @@ tui-textfield {
93
90
  }
94
91
 
95
92
  &::after {
96
- margin: 0 -0.125rem 0 0.375rem;
93
+ margin: 0 -0.125rem 0 0.5rem;
97
94
  }
98
95
 
99
96
  input,
100
97
  select {
101
98
  font: var(--tui-font-text-s);
102
99
  }
100
+
101
+ .t-content {
102
+ margin-inline-end: -0.125rem;
103
+ }
103
104
  }
104
105
 
105
106
  /*
@@ -120,6 +121,7 @@ tui-textfield {
120
121
 
121
122
  &::before {
122
123
  z-index: 1;
124
+ margin-inline-end: 0.75rem;
123
125
  }
124
126
 
125
127
  &:has(:disabled:not(.t-filler, button, option))::before,
@@ -141,9 +143,11 @@ tui-textfield {
141
143
  select {
142
144
  padding-top: calc(var(--t-height) / 3);
143
145
 
144
- &::placeholder,
146
+ &:not(:-webkit-autofill)::placeholder,
145
147
  &._empty {
146
- color: transparent;
148
+ caret-color: var(--tui-text-primary);
149
+ color: transparent !important;
150
+ -webkit-text-fill-color: transparent !important;
147
151
  }
148
152
  }
149
153
  }
@@ -155,9 +159,11 @@ tui-textfield {
155
159
  select {
156
160
  padding-top: calc(var(--t-height) / 3);
157
161
 
158
- &::placeholder,
162
+ &:not(:-webkit-autofill)::placeholder,
159
163
  &._empty {
160
- color: transparent;
164
+ caret-color: var(--tui-text-primary);
165
+ color: transparent !important;
166
+ -webkit-text-fill-color: transparent !important;
161
167
  }
162
168
  }
163
169
  }
@@ -176,6 +182,15 @@ tui-textfield {
176
182
  padding: inherit;
177
183
  }
178
184
 
185
+ .t-template {
186
+ display: flex;
187
+ align-items: center;
188
+ }
189
+
190
+ &._with-template select {
191
+ color: transparent !important;
192
+ }
193
+
179
194
  input:defined,
180
195
  select:defined {
181
196
  pointer-events: auto;
@@ -191,7 +206,7 @@ tui-textfield {
191
206
  & ~ .t-content {
192
207
  opacity: var(--tui-disabled-opacity);
193
208
 
194
- [tuiTooltip] {
209
+ tui-icon {
195
210
  display: none;
196
211
  }
197
212
  }
@@ -218,7 +233,9 @@ tui-textfield {
218
233
  .appearance-focus({
219
234
  &::placeholder,
220
235
  &._empty {
221
- color: var(--tui-text-tertiary);
236
+ caret-color: var(--tui-text-primary);
237
+ color: transparent !important;
238
+ -webkit-text-fill-color: var(--tui-text-tertiary) !important;
222
239
  }
223
240
 
224
241
  & ~ label {
@@ -228,6 +245,13 @@ tui-textfield {
228
245
  }
229
246
  });
230
247
  }
248
+
249
+ .ios-only({
250
+ &._ios-fix {
251
+ position: fixed;
252
+ left: 1000rem;
253
+ }
254
+ });
231
255
  }
232
256
 
233
257
  label:not([data-orientation='vertical']) {
@@ -250,16 +274,6 @@ tui-textfield {
250
274
  cursor: pointer;
251
275
  }
252
276
 
253
- input:defined,
254
- select:defined {
255
- .ios-only({
256
- &._ios-fix {
257
- position: fixed;
258
- left: 1000rem;
259
- }
260
- });
261
- }
262
-
263
277
  button,
264
278
  a {
265
279
  pointer-events: auto;
@@ -271,6 +285,10 @@ tui-textfield {
271
285
  gap: 0.25rem;
272
286
  margin-inline-start: auto;
273
287
  isolation: isolate;
288
+
289
+ tui-icon {
290
+ pointer-events: auto;
291
+ }
274
292
  }
275
293
 
276
294
  .t-clear {
@@ -42,6 +42,11 @@
42
42
  caret-color: var(--tui-text-primary) !important;
43
43
  border-color: var(--tui-service-autofill-background) !important;
44
44
  box-shadow: 0 0 0 100rem var(--tui-service-autofill-background) inset !important;
45
+ transition: background-color 600000s 0s;
46
+
47
+ &::placeholder {
48
+ -webkit-text-fill-color: var(--tui-text-secondary);
49
+ }
45
50
  }
46
51
  }
47
52
 
@@ -11,8 +11,9 @@
11
11
  --tui-background-accent-opposite: #fff;
12
12
  --tui-background-accent-opposite-hover: #f6f6f6;
13
13
  --tui-background-accent-opposite-pressed: #ededed;
14
- --tui-background-elevation-1: #222;
15
- --tui-background-elevation-2: #222;
14
+ --tui-background-elevation-1: #292929;
15
+ --tui-background-elevation-2: #333;
16
+ --tui-background-elevation-3: #333;
16
17
  // Other
17
18
  --tui-service-autofill-background: rgb(85, 74, 42);
18
19
  --tui-border-normal: rgba(255, 255, 255, 0.14);
@@ -66,6 +67,7 @@
66
67
  --tui-background-accent-opposite-pressed: #808080;
67
68
  --tui-background-elevation-1: #fff;
68
69
  --tui-background-elevation-2: #fff;
70
+ --tui-background-elevation-3: #fff;
69
71
  // Other
70
72
  --tui-service-autofill-background: #fff5c0;
71
73
  --tui-service-selection-background: rgba(112, 182, 246, 0.12);