@planningcenter/tapestry 2.3.0-rc.1 → 2.3.0-rc.11

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 (59) hide show
  1. package/dist/componentRegistration.js.map +1 -1
  2. package/dist/components/Banner/Banner.js.map +1 -1
  3. package/dist/components/button/BaseButton.d.ts +2 -0
  4. package/dist/components/button/BaseButton.d.ts.map +1 -1
  5. package/dist/components/button/BaseButton.js +8 -5
  6. package/dist/components/button/BaseButton.js.map +1 -1
  7. package/dist/components/button/Button.js.map +1 -1
  8. package/dist/components/button/DropdownButton.js.map +1 -1
  9. package/dist/components/button/DropdownIconButton.js.map +1 -1
  10. package/dist/components/button/IconButton.js.map +1 -1
  11. package/dist/components/button/LoadingButton.d.ts +12 -0
  12. package/dist/components/button/LoadingButton.d.ts.map +1 -1
  13. package/dist/components/button/LoadingButton.js +11 -8
  14. package/dist/components/button/LoadingButton.js.map +1 -1
  15. package/dist/components/button/PageHeaderActionsDropdownButton.js.map +1 -1
  16. package/dist/components/checkbox/Checkbox.js.map +1 -1
  17. package/dist/components/internal/LoadingSpinner.js.map +1 -1
  18. package/dist/components/link/BaseLink.js.map +1 -1
  19. package/dist/components/link/IconLink.js.map +1 -1
  20. package/dist/components/link/Link.js.map +1 -1
  21. package/dist/components/page-header/PageHeader.js.map +1 -1
  22. package/dist/components/page-header/index.js.map +1 -1
  23. package/dist/components/sidenav/Sidenav.js.map +1 -1
  24. package/dist/components/sidenav/SidenavItem.js.map +1 -1
  25. package/dist/components/sidenav/SidenavSection.js.map +1 -1
  26. package/dist/components/sidenav/index.js.map +1 -1
  27. package/dist/index.css +51 -40
  28. package/dist/index.css.map +1 -1
  29. package/dist/jsTokens.js.map +1 -1
  30. package/dist/reactRender.css +539 -528
  31. package/dist/reactRender.css.map +1 -1
  32. package/dist/reactRenderLegacy.css +539 -528
  33. package/dist/reactRenderLegacy.css.map +1 -1
  34. package/dist/tapestry-render/dist/buildComponent-DTliJ3_n.js +110 -110
  35. package/dist/tapestry-render/dist/buildComponent-DTliJ3_n.js.map +1 -1
  36. package/dist/tapestry-render/dist/index.js.map +1 -1
  37. package/dist/tapestry-render/dist/legacy.js.map +1 -1
  38. package/dist/tapestry-render/dist/registry.js.map +1 -1
  39. package/dist/tapestry-wc/dist/components/p-BGI0jdHO.js.map +1 -1
  40. package/dist/tapestry-wc/dist/components/p-CLwAWmuf.js.map +1 -1
  41. package/dist/tapestry-wc/dist/components/p-CeCAMGrz.js.map +1 -1
  42. package/dist/tapestry-wc/dist/components/p-D_UI812x.js.map +1 -1
  43. package/dist/tapestry-wc/dist/components/p-m4YsmAHe.js.map +1 -1
  44. package/dist/tapestry-wc/dist/components/tds-page-header.js.map +1 -1
  45. package/dist/tapestry-wc/dist/components/tds-sidenav-item.js.map +1 -1
  46. package/dist/tapestry-wc/dist/components/tds-sidenav-section.js.map +1 -1
  47. package/dist/tapestry-wc/dist/components/tds-sidenav.js.map +1 -1
  48. package/dist/tokens/ts/tokens.d.ts +19 -1
  49. package/dist/tokens/ts/tokens.d.ts.map +1 -1
  50. package/dist/tokens/ts/tokens.js +20 -2
  51. package/dist/tokens/ts/tokens.js.map +1 -1
  52. package/dist/tokens-dark.css +2 -2
  53. package/dist/tokens.css +19 -1
  54. package/dist/tokens.css.map +1 -1
  55. package/dist/unstable.css +51 -40
  56. package/dist/unstable.css.map +1 -1
  57. package/dist/utilities/Icon.js.map +1 -1
  58. package/dist/utilities/buttonLinkShared.js.map +1 -1
  59. package/package.json +3 -3
@@ -1,627 +1,622 @@
1
1
  @layer t-critical, t-component;
2
2
 
3
-
4
- @media (prefers-reduced-motion: no-preference) {
5
-
6
- :root {
7
- interpolate-size: allow-keywords;
8
- }
3
+ @layer t-critical {
4
+ tds-page-header:not(.hydrated) {
5
+ display: none;
9
6
  }
7
+ }
10
8
 
11
- @layer tds-component {
12
- tds-sidenav, .tds-sidenav {
13
- --tds-sidenav-indent: 12px;
14
- --tds-sidenav-item-depth: 0;
9
+ @layer t-component {
10
+ .tds-page-header {
11
+ --tds-page-header-background-color: var(--t-fill-color-product-current-gradient-tint, var(--t-surface-color-card));
12
+ --tds-page-header-background-color-inactive: var(--t-fill-color-neutral-090);
13
+ --tds-page-header-color: var(--t-text-color-default-primary);
14
+ --tds-page-header-headline-color: var(--t-text-color-default-headline);
15
+ --tds-page-header-headline-font-size: var(--t-font-size-2xl);
16
+ --tds-page-header-padding-x: var(--t-spacing-2);
17
+ --tds-page-header-padding-y: var(--t-spacing-2);
18
+ --tds-page-header-nav-padding-x: var(--tds-page-header-padding-x, var(--t-spacing-3));
19
+ --tds-page-header-nav-gap: var(--t-spacing-1);
20
+ --tds-page-header-nav-background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, .1) 100%);
21
+ --tds-page-header-nav-item-padding-x: var(--t-spacing-1);
22
+ --tds-page-header-nav-item-padding-y: var(--t-spacing-1);
23
+ --tds-page-header-nav-item-color: var(--t-text-color-default-secondary);
24
+ --tds-page-header-nav-item-background-color: var(--t-fill-color-transparency-light-060);
25
+ --tds-page-header-nav-item-border-width: 1px;
15
26
 
16
- --tds-sidenav-item-transition: background-color .2s cubic-bezier(.19, .91, .38, 1);
27
+ --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-background-color);
28
+ --tds-page-header-nav-item-border-bottom-color: var(--t-border-color-default-base);
17
29
 
18
- --tds-sidenav-item-icon-size: var(--t-element-size-md);
19
- --tds-sidenav-item-background-hover: var(--t-fill-color-button-interaction-ghost-hover);
20
- --tds-sidenav-item-background-active: var(--t-fill-color-button-interaction-ghost-active);
21
- --tds-sidenav-item-background-selected: var(--t-fill-color-button-interaction-ghost-active);
30
+ --tds-page-header-nav-item-color-hover: var(--t-text-color-default-primary);
31
+ --tds-page-header-nav-item-background-color-hover: var(--t-fill-color-neutral-080);
32
+ --tds-page-header-nav-item-border-color-hover: var(--tds-page-header-nav-item-background-color-hover);
22
33
 
23
- --tds-sidenav-item-nested-background-hover: var(--tds-sidenav-item-background-hover);
24
- --tds-sidenav-item-nested-background-active: var(--tds-sidenav-item-background-hover);
25
- --tds-sidenav-item-nested-background-selected: transparent;
34
+ --tds-page-header-nav-item-background-color-active: var(--t-fill-color-neutral-060);
35
+ --tds-page-header-nav-item-border-color-active: var(--tds-page-header-nav-item-background-color-hover);
26
36
 
27
- --tds-sidenav-item-nested-border-color: var(--t-fill-color-neutral-050);
28
- --tds-sidenav-item-nested-border-color-hover: var(--t-fill-color-neutral-050);
29
- --tds-sidenav-item-nested-border-color-selected: var(--t-border-color-status-info);
37
+ --tds-page-header-nav-item-color-disabled: var(--t-text-color-default-disabled);
38
+ --tds-page-header-nav-item-background-color-disabled: var(--t-fill-color-neutral-080);
39
+ --tds-page-header-nav-item-border-color-disabled: var(--tds-page-header-nav-item-background-color-disabled);
30
40
 
31
- --tds-sidenav-item-icon-color: var(--t-icon-color-default-secondary);
32
- --tds-sidenav-item-icon-color-selected: var(--t-icon-color-default-primary);
41
+ --tds-page-header-nav-item-color-selected: var(--t-text-color-default-primary);
42
+ --tds-page-header-nav-item-background-color-selected: var(--t-surface-color-card);
43
+ --tds-page-header-nav-item-border-color-selected: var(--tds-page-header-nav-item-background-color-selected);
44
+ --tds-page-header-nav-item-border-bottom-color-selected: var(--tds-page-header-nav-item-background-color-selected);
45
+ --tds-page-header-nav-item-indicator-color: var(--t-icon-color-status-warning-primary);
33
46
  }
34
47
 
35
- .is-classic tds-sidenav, .is-classic .tds-sidenav,
36
- .tds-sidenav--theme-gray {
37
- --tds-sidenav-item-background-hover: var(--t-fill-color-neutral-080);
38
- --tds-sidenav-item-background-active: var(--t-fill-color-neutral-070);
39
- --tds-sidenav-item-background-selected: var(--t-fill-color-neutral-050);
40
- --tds-sidenav-item-nested-border-color-hover: var(--t-fill-color-neutral-050);
41
- --tds-sidenav-item-nested-border-color-selected: var(--t-fill-color-neutral-010);
48
+ .tds-page-header--profile {
49
+ --tds-page-header-padding-y: 20px;
50
+ }
51
+ @media (min-width: 600px) {
52
+ .tds-page-header {
53
+ --tds-page-header-background-color: var(--t-surface-color-card);
54
+ --tds-page-header-color: var(--t-text-color-default-secondary);
55
+ --tds-page-header-padding-x: var(--t-spacing-3);
56
+ --tds-page-header-headline-font-size: var(--t-font-size-3xl);
57
+ --tds-page-header-nav-gap: var(--t-spacing-half);
58
+ --tds-page-header-nav-background: transparent;
59
+ --tds-page-header-nav-item-padding-x: var(--t-spacing-2);
60
+ --tds-page-header-nav-item-border-width: 1px;
61
+ --tds-page-header-nav-item-color: var(--t-text-color-default-primary);
62
+ --tds-page-header-nav-item-background-color: var(--t-fill-color-neutral-070);
63
+ --tds-page-header-nav-item-border-color-selected: var(--t-border-color-default-base);
64
+ }
42
65
  }
43
66
  }
44
67
 
45
- .tds-sidenav :where(nav,ul,.tds-sidenav-section) {
46
- display: flex;
47
- }
68
+ .tds-page-header {
69
+ display: flex;
70
+ flex-direction: column;
71
+ padding-top: var(--tds-page-header-padding-y);
72
+ color: var(--tds-page-header-color);
73
+ background: var(--tds-page-header-background-color);
74
+ border-bottom: 1px solid var(--t-border-color-default-base);
75
+ }
48
76
 
49
- .tds-sidenav :where(nav,ul,.tds-sidenav-section,.tds-sidenav-collapse) {
50
- flex-direction: column;
51
- gap: var(--t-spacing-half);
52
- width: 100%;
53
- }
77
+ .tds-page-header:not(.has-nav) {
78
+ padding-bottom: var(--tds-page-header-padding-y);
79
+ }
54
80
 
55
- .tds-sidenav-section-list {
56
- width: 100%;
57
- padding: 0;
58
- margin: 0;
59
- list-style: none;
81
+ .tds-page-header.inactive {
82
+ background: var(--tds-page-header-background-color-inactive);
60
83
  }
61
84
 
62
- .tds-sidenav-section-header {
85
+ .tds-page-header__title-bar {
63
86
  display: flex;
64
- align-items: baseline;
87
+ flex-direction: column;
88
+ gap: var(--t-spacing-2) var(--t-spacing-1);
89
+ align-items: flex-start;
65
90
  justify-content: space-between;
66
- padding-top: var(--t-spacing-2);
91
+ padding: 0 var(--tds-page-header-padding-x);
67
92
  }
68
93
 
69
- .tds-sidenav-section-header h2 {
70
- margin: 0;
71
- font-size: var(--t-font-size-sm);
72
- font-weight: var(--t-font-weight-semibold);
73
- line-height: 1.35;
74
- color: var(--t-text-color-default-secondary);
75
- text-transform: uppercase;
76
- }
77
-
78
- .tds-sidenav-section:first-of-type .tds-sidenav-section-header {
79
- padding-top: 0;
80
- }
81
-
82
- .tds-sidenav-section-header [slot="label-actions"] {
83
- display: flex;
84
- gap: var(--t-spacing-half);
85
- align-items: center;
86
- }
87
-
88
- .tds-sidenav-section [slot="section-actions"] {
89
- display: flex;
90
- gap: 12px;
94
+ .tds-page-header--profile > .tds-page-header__title-bar {
91
95
  align-items: center;
92
- min-height: 42px;
93
- padding: var(--t-spacing-1) 0;
94
96
  }
95
97
 
96
- .tds-sidenav-section-list,
97
- .tds-sidenav-item {
98
+ .tds-page-header__primary {
98
99
  width: 100%;
99
- padding: 0;
100
- margin: 0;
101
100
  }
102
101
 
103
- .tds-sidenav-item :is(a,button) {
104
- position: relative;
105
- display: flex;
106
- gap: 12px;
107
- align-items: center;
108
- width: 100%;
109
- padding: 12px;
110
- overflow: hidden;
111
- font-size: var(--t-font-size-sm);
112
- line-height: 18px;
113
- color: var(--t-text-color-default-headline);
114
- white-space: nowrap;
115
- text-decoration: none;
116
- -webkit-appearance: none;
117
- -moz-appearance: none;
118
- appearance: none;
119
- cursor: pointer;
120
- background-color: var(--tds-sidenav-item-background, transparent);
121
- border: 0;
122
- border-radius: var(--t-border-radius-default);
123
- transition: var(--tds-sidenav-item-transition);
124
- }
125
-
126
- :is(.tds-sidenav-item :is(a,button)):not(:has(.prefix,.suffix)),:is(.tds-sidenav-item :is(a,button)) :is(:not(.prefix,.suffix)) {
127
- display: block;
128
- flex: 1;
129
- overflow: hidden;
130
- text-overflow: ellipsis;
131
- text-align: left;
132
- white-space: nowrap;
133
- }
134
-
135
- :is(.tds-sidenav-item :is(a,button)):hover,:is(.tds-sidenav-item :is(a,button)):focus-visible {
136
- --tds-sidenav-item-background: var(--tds-sidenav-item-background-hover);
137
- color: var(--t-text-color-default-headline);
138
- text-decoration: none;
139
- }
140
-
141
- :is(.tds-sidenav-item :is(a,button)):active {
142
- --tds-sidenav-item-background: var(--tds-sidenav-item-background-active);
143
- }
102
+ .tds-page-header__primary h1 {
103
+ margin: 0;
104
+ font-size: var(--tds-page-header-headline-font-size);
105
+ font-weight: var(--t-font-weight-normal);
106
+ line-height: 32px;
107
+ color: var(--tds-page-header-headline-color);
108
+ overflow-wrap: break-word;
109
+ }
144
110
 
145
- :is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"]) {
146
- overflow: hidden;
147
- color: var(--tds-sidenav-item-icon-color);
148
- }
111
+ .tds-page-header [slot="actions"] {
112
+ width: 100%;
113
+ }
149
114
 
150
- :is(:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"])),:is(:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"])) svg {
151
- display: block;
152
- width: var(--tds-sidenav-item-icon-size);
153
- height: var(--tds-sidenav-item-icon-size);
154
- }
115
+ .has-multi-actions.tds-page-header [slot="actions"],
116
+ .has-multi-actions.tds-page-header .tds-page-header__actions {
117
+ display: flex;
118
+ flex-flow: row wrap;
119
+ gap: var(--t-spacing-half) var(--t-spacing-1);
120
+ align-items: flex-start;
121
+ justify-content: flex-start;
122
+ min-width: 0;
123
+ }
155
124
 
156
- :is(.tds-sidenav-item :is(a,button)):has(.prefix,[slot="prefix"]) + .tds-sidenav-section {
157
- --tds-sidenav-indent: 19px;
158
- }
125
+ .tds-page-header nav[slot="navigation"]:not(:has(ul)),
126
+ .tds-page-header nav.tds-page-header__nav:not(:has(ul)),
127
+ .tds-page-header nav[slot="navigation"] ul,
128
+ .tds-page-header nav.tds-page-header__nav ul {
129
+ display: flex;
130
+ gap: var(--tds-page-header-nav-gap);
131
+ padding: var(--t-spacing-2) var(--tds-page-header-nav-padding-x) 0;
132
+ margin: 0 0 -1px;
133
+ overflow: auto;
134
+ list-style: none;
135
+ background: var(--tds-page-header-nav-background);
136
+ }
159
137
 
160
- [aria-expanded="true"]:is(.tds-sidenav-item :is(a,button)) + .tds-sidenav-section-list {
161
- visibility: visible;
162
- block-size: auto;
163
- opacity: 1;
164
- }
138
+ .tds-page-header nav[slot="navigation"] a,
139
+ .tds-page-header nav[slot="navigation"] button,
140
+ .tds-page-header nav.tds-page-header__nav a,
141
+ .tds-page-header nav.tds-page-header__nav button {
142
+ position: relative;
143
+ display: inline-flex;
144
+ padding: var(--tds-page-header-nav-item-padding-y) var(--tds-page-header-nav-item-padding-x);
145
+ font-size: var(--t-font-size-sm);
146
+ line-height: 22px;
147
+ color: var(--tds-page-header-nav-item-color);
148
+ white-space: nowrap;
149
+ text-decoration: none;
150
+ -webkit-appearance: none;
151
+ -moz-appearance: none;
152
+ appearance: none;
153
+ cursor: pointer;
154
+ outline-offset: -2px;
155
+ background-color: var(--tds-page-header-nav-item-background-color);
156
+ background-clip: padding-box;
157
+ border: var(--tds-page-header-nav-item-border-width) solid var(--tds-page-header-nav-item-border-color);
158
+ border-bottom: 1px solid var(--tds-page-header-nav-item-border-bottom-color);
159
+ border-radius: var(--t-border-radius-md) var(--t-border-radius-md) 0 0;
160
+ }
165
161
 
166
- .tds-sidenav-item.selected > :is(a,button),.tds-sidenav-item:has(.tds-sidenav-section):has(.selected) > :is(a,button) {
167
- --tds-sidenav-item-background: var(--tds-sidenav-item-background-selected);
168
- --tds-sidenav-item-icon-color: var(--tds-sidenav-item-icon-color-selected);
162
+ .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator) {
163
+ position: relative;
164
+ }
169
165
 
170
- --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-selected);
171
- font-weight: var(--t-font-weight-semibold);
172
- }
166
+ .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator) :is(a, button) {
167
+ -webkit-mask: radial-gradient(8px at calc(100% - 3px) 0, #0000 98%, #000);
168
+ mask: radial-gradient(8px at calc(100% - 3px) 0, #0000 98%, #000);
169
+ }
173
170
 
174
- .tds-sidenav-item:has(.tds-sidenav-section) {
175
- display: flex;
176
- flex-direction: column;
177
- gap: var(--t-spacing-half);
178
- }
171
+ .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::before,
172
+ .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::after {
173
+ position: absolute;
174
+ top: -5px;
175
+ right: -2px;
176
+ width: 10px;
177
+ height: 10px;
178
+ content: "";
179
+ background: var(--tds-page-header-nav-item-indicator-color);
180
+ border-radius: 50%;
181
+ }
179
182
 
180
- .tds-sidenav-item .tds-sidenav-section-list {
181
- --tds-sidenav-item-depth: 1;
182
- gap: 0;
183
+ @media (prefers-reduced-motion: no-preference) {
184
+ .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::after {
185
+ animation: indicator-pulse 1.25s ease infinite;
183
186
  }
187
+ }
184
188
 
185
- .tds-sidenav-action--toggle + :is(.tds-sidenav-item .tds-sidenav-section-list) {
186
- visibility: hidden;
187
- block-size: 0;
188
- overflow-y: clip;
189
- opacity: 0;
190
- transition: content-visibility .2s allow-discrete, opacity .2s, block-size .2s;
191
- }
192
-
193
- :is(.tds-sidenav-item .tds-sidenav-section-list) .tds-sidenav-section-list {
194
- --tds-sidenav-item-depth: 2;
195
- }
196
-
197
- :is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button) {
198
- min-height: var(--t-element-size-2xl);
199
- padding-block: 9px;
200
- padding-left: calc((var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth)) + var(--tds-sidenav-indent) + var(--t-spacing-fourth));
201
- line-height: 1;
202
- background-color: transparent;
203
- }
204
-
205
- :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::before {
206
- position: absolute;
207
- top: 0;
208
- bottom: 0;
209
- left: calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
210
- width: 2px;
211
- content: "";
212
- background-color: var(--tds-sidenav-item-nested-border-color);
213
- transition: var(--tds-sidenav-item-transition);
214
- }
215
-
216
- :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::after {
217
- position: absolute;
218
- inset: 0 0 0 calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
219
- z-index: -1;
220
- height: 100%;
221
- content: "";
222
- background-color: var(--tds-sidenav-item-nested-background);
223
- border-radius: 0 var(--t-border-radius-default) var(--t-border-radius-default) 0;
224
- transition: var(--tds-sidenav-item-transition);
225
- }
226
-
227
- :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):not(:has(.prefix,.suffix)),:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)) :is(:not(.prefix,.suffix)) {
228
- display: block;
229
- text-align: left;
230
- white-space: normal;
231
- }
232
-
233
- :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):hover,:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):focus-visible {
234
- --tds-sidenav-item-nested-border-color: var(--tds-sidenav-item-nested-border-color-hover);
235
- --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-hover);
236
- }
189
+ .tds-page-header nav[slot="navigation"] a.selected,
190
+ .tds-page-header nav[slot="navigation"] button.selected,
191
+ .tds-page-header nav.tds-page-header__nav a.selected,
192
+ .tds-page-header nav.tds-page-header__nav button.selected {
193
+ --tds-page-header-nav-item-color: var(--tds-page-header-nav-item-color-selected);
194
+ --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-border-color-selected);
195
+ --tds-page-header-nav-item-background-color: var(--tds-page-header-nav-item-background-color-selected);
196
+ --tds-page-header-nav-item-border-bottom-color: var(--tds-page-header-nav-item-background-color-selected);
197
+ }
237
198
 
238
- :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):active {
239
- --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-active);
240
- }
199
+ .tds-page-header nav[slot="navigation"] a:not(.selected):hover,
200
+ .tds-page-header nav[slot="navigation"] button:not(.selected):hover,
201
+ .tds-page-header nav.tds-page-header__nav a:not(.selected):hover,
202
+ .tds-page-header nav.tds-page-header__nav button:not(.selected):hover {
203
+ --tds-page-header-nav-item-color: var(--tds-page-header-nav-item-color-hover);
204
+ --tds-page-header-nav-item-background-color: var(--tds-page-header-nav-item-background-color-hover);
205
+ --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-border-color-hover);
206
+ }
241
207
 
242
- .selected:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button) {
243
- --tds-sidenav-item-nested-border-color: var(--tds-sidenav-item-nested-border-color-selected);
244
- font-weight: var(--t-font-weight-medium);
245
- }
208
+ .tds-page-header nav[slot="navigation"] a:not(.selected):active,
209
+ .tds-page-header nav[slot="navigation"] button:not(.selected):active,
210
+ .tds-page-header nav.tds-page-header__nav a:not(.selected):active,
211
+ .tds-page-header nav.tds-page-header__nav button:not(.selected):active {
212
+ background-color: var(--tds-page-header-nav-item-background-color-active);
213
+ }
246
214
 
247
- .tds-sidenav-responsive-header {
248
- display: flex;
249
- gap: var(--t-spacing-2);
250
- align-items: center;
251
- width: 100%;
215
+ .tds-page-header nav[slot="navigation"] a:not(.selected):disabled,
216
+ .tds-page-header nav[slot="navigation"] button:not(.selected):disabled,
217
+ .tds-page-header nav.tds-page-header__nav a:not(.selected):disabled,
218
+ .tds-page-header nav.tds-page-header__nav button:not(.selected):disabled {
219
+ color: var(--tds-page-header-nav-item-color-disabled);
220
+ cursor: not-allowed;
221
+ background-color: var(--tds-page-header-nav-item-background-color-disabled);
222
+ opacity: 1;
252
223
  }
253
224
 
254
- .tds-sidenav-responsive-header .tds-sidenav-responsive-header-toggle {
255
- order: 0;
225
+ @media (min-width: 960px) {
226
+ .tds-page-header__primary {
227
+ flex: 1 1 max-content;
228
+ width: auto;
229
+ min-width: 0;
230
+ max-width: 100%;
256
231
  }
257
232
 
258
- .tds-sidenav-responsive-header .tds-sidenav-responsive-header-label {
259
- flex: 1;
260
- order: 1;
261
- margin: 0;
262
- font-size: var(--t-font-size-lg);
263
- font-weight: var(--t-font-weight-medium);
264
- color: var(--t-text-color-default-headline);
233
+ .tds-page-header__title-bar,
234
+ .tds-page-header--profile .tds-page-header__title-bar {
235
+ flex-flow: row nowrap;
236
+ row-gap: 12px;
237
+ align-items: flex-start;
265
238
  }
266
239
 
267
- @media (max-width: 719px) {
268
- .tds-sidenav-collapse {
269
- z-index: 10001;
270
- display: none;
271
- max-width: min(448px, calc(100vw - 48px));
272
- padding: 0;
273
- margin: 12px 0;
274
- overflow: hidden;
275
- outline: 0;
276
- background: var(--t-surface-color-card);
277
- border: 0;
278
- border-radius: 6px;
279
- box-shadow: 0 8px 20px 0 rgba(0, 0, 0, .25);
280
- will-change: transform;
281
- position-area: bottom span-right;
240
+ .tds-page-header [slot="actions"] {
241
+ width: auto;
282
242
  }
283
243
 
284
- .tds-sidenav-scroll-container {
285
- --webkit-overflow-scrolling: touch;
286
- display: block;
287
- width: 100%;
288
- height: -moz-fit-content;
289
- height: fit-content;
290
- padding: var(--t-spacing-2);
291
- overflow-y: auto;
244
+ .has-multi-actions.tds-page-header [slot="actions"],
245
+ .has-multi-actions.tds-page-header .tds-page-header__actions {
246
+ justify-content: flex-end;
292
247
  }
248
+ }
293
249
 
294
- .tds-sidenav-item :is(a, button) :is(.prefix) {
295
- display: none;
296
- }
250
+ .tds-page-header-phone,
251
+ .tds-page-header-email {
252
+ color: var(--tds-page-header-color);
253
+ white-space: nowrap;
254
+ }
297
255
 
298
- /* Modern browsers only */
299
- @supports selector(:popover-open) {
300
- .tds-sidenav-collapse:popover-open {
301
- display: flex;
302
- }
303
- }
256
+ /* Truncate email */
304
257
 
305
- /* Older browsers only, running the polyfill */
306
- @supports not selector(:popover-open) {
307
- .tds-sidenav-collapse.\:popover-open {
308
- display: flex;
309
- }
310
- }
258
+ .tds-page-header-email {
259
+ max-width: 100%;
260
+ overflow: hidden;
261
+ text-overflow: ellipsis;
311
262
  }
312
263
 
313
- @media (min-width: 720px) {
314
- .tds-sidenav-responsive-header {
315
- display: none;
264
+ @keyframes indicator-pulse {
265
+ 0% {
266
+ opacity: .3;
267
+ transform: scale(.9);
316
268
  }
317
- }
318
269
 
319
- :is(tds-sidenav,tds-sidenav-section,tds-sidenav-item):not(.hydrated) > :not([slot="ssr"]) {
320
- display: none;
321
- }
270
+ 100% {
271
+ opacity: 0;
272
+ transform: scale(1.75);
273
+ }
274
+ }
322
275
 
323
- :is(tds-sidenav,tds-sidenav-section,tds-sidenav-item):not(.hydrated) > [slot="ssr"] {
324
- display: block;
325
- }
326
276
 
327
- tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
328
- display: flex;
329
- flex-direction: column;
330
- }
277
+ @media (prefers-reduced-motion: no-preference) {
331
278
 
332
- @layer t-critical {
333
- tds-page-header:not(.hydrated) {
334
- display: none;
335
- }
279
+ :root {
280
+ interpolate-size: allow-keywords;
336
281
  }
282
+ }
337
283
 
338
- @layer t-component {
339
- .tds-page-header {
340
- --tds-page-header-background-color: var(--t-fill-color-product-current-gradient-tint, var(--t-surface-color-card));
341
- --tds-page-header-background-color-inactive: var(--t-fill-color-neutral-090);
342
- --tds-page-header-color: var(--t-text-color-default-primary);
343
- --tds-page-header-headline-color: var(--t-text-color-default-headline);
344
- --tds-page-header-headline-font-size: var(--t-font-size-2xl);
345
- --tds-page-header-padding-x: var(--t-spacing-2);
346
- --tds-page-header-padding-y: var(--t-spacing-2);
347
- --tds-page-header-nav-padding-x: var(--tds-page-header-padding-x, var(--t-spacing-3));
348
- --tds-page-header-nav-gap: var(--t-spacing-1);
349
- --tds-page-header-nav-background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, .1) 100%);
350
- --tds-page-header-nav-item-padding-x: var(--t-spacing-1);
351
- --tds-page-header-nav-item-padding-y: var(--t-spacing-1);
352
- --tds-page-header-nav-item-color: var(--t-text-color-default-secondary);
353
- --tds-page-header-nav-item-background-color: var(--t-fill-color-transparency-light-060);
354
- --tds-page-header-nav-item-border-width: 1px;
284
+ @layer tds-component {
285
+ tds-sidenav, .tds-sidenav {
286
+ --tds-sidenav-indent: 12px;
287
+ --tds-sidenav-item-depth: 0;
355
288
 
356
- --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-background-color);
357
- --tds-page-header-nav-item-border-bottom-color: var(--t-border-color-default-base);
289
+ --tds-sidenav-item-transition: background-color .2s cubic-bezier(.19, .91, .38, 1);
358
290
 
359
- --tds-page-header-nav-item-color-hover: var(--t-text-color-default-primary);
360
- --tds-page-header-nav-item-background-color-hover: var(--t-fill-color-neutral-080);
361
- --tds-page-header-nav-item-border-color-hover: var(--tds-page-header-nav-item-background-color-hover);
291
+ --tds-sidenav-item-icon-size: var(--t-element-size-md);
292
+ --tds-sidenav-item-background-hover: var(--t-fill-color-button-interaction-ghost-hover);
293
+ --tds-sidenav-item-background-active: var(--t-fill-color-button-interaction-ghost-active);
294
+ --tds-sidenav-item-background-selected: var(--t-fill-color-button-interaction-ghost-active);
362
295
 
363
- --tds-page-header-nav-item-background-color-active: var(--t-fill-color-neutral-060);
364
- --tds-page-header-nav-item-border-color-active: var(--tds-page-header-nav-item-background-color-hover);
296
+ --tds-sidenav-item-nested-background-hover: var(--tds-sidenav-item-background-hover);
297
+ --tds-sidenav-item-nested-background-active: var(--tds-sidenav-item-background-hover);
298
+ --tds-sidenav-item-nested-background-selected: transparent;
365
299
 
366
- --tds-page-header-nav-item-color-disabled: var(--t-text-color-default-disabled);
367
- --tds-page-header-nav-item-background-color-disabled: var(--t-fill-color-neutral-080);
368
- --tds-page-header-nav-item-border-color-disabled: var(--tds-page-header-nav-item-background-color-disabled);
300
+ --tds-sidenav-item-nested-border-color: var(--t-fill-color-neutral-050);
301
+ --tds-sidenav-item-nested-border-color-hover: var(--t-fill-color-neutral-050);
302
+ --tds-sidenav-item-nested-border-color-selected: var(--t-border-color-status-info);
369
303
 
370
- --tds-page-header-nav-item-color-selected: var(--t-text-color-default-primary);
371
- --tds-page-header-nav-item-background-color-selected: var(--t-surface-color-card);
372
- --tds-page-header-nav-item-border-color-selected: var(--tds-page-header-nav-item-background-color-selected);
373
- --tds-page-header-nav-item-border-bottom-color-selected: var(--tds-page-header-nav-item-background-color-selected);
374
- --tds-page-header-nav-item-indicator-color: var(--t-icon-color-status-warning-primary);
304
+ --tds-sidenav-item-icon-color: var(--t-icon-color-default-secondary);
305
+ --tds-sidenav-item-icon-color-selected: var(--t-icon-color-default-primary);
375
306
  }
376
307
 
377
- .tds-page-header--profile {
378
- --tds-page-header-padding-y: 20px;
379
- }
380
- @media (min-width: 600px) {
381
- .tds-page-header {
382
- --tds-page-header-background-color: var(--t-surface-color-card);
383
- --tds-page-header-color: var(--t-text-color-default-secondary);
384
- --tds-page-header-padding-x: var(--t-spacing-3);
385
- --tds-page-header-headline-font-size: var(--t-font-size-3xl);
386
- --tds-page-header-nav-gap: var(--t-spacing-half);
387
- --tds-page-header-nav-background: transparent;
388
- --tds-page-header-nav-item-padding-x: var(--t-spacing-2);
389
- --tds-page-header-nav-item-border-width: 1px;
390
- --tds-page-header-nav-item-color: var(--t-text-color-default-primary);
391
- --tds-page-header-nav-item-background-color: var(--t-fill-color-neutral-070);
392
- --tds-page-header-nav-item-border-color-selected: var(--t-border-color-default-base);
393
- }
308
+ .is-classic tds-sidenav, .is-classic .tds-sidenav,
309
+ .tds-sidenav--theme-gray {
310
+ --tds-sidenav-item-background-hover: var(--t-fill-color-neutral-080);
311
+ --tds-sidenav-item-background-active: var(--t-fill-color-neutral-070);
312
+ --tds-sidenav-item-background-selected: var(--t-fill-color-neutral-050);
313
+ --tds-sidenav-item-nested-border-color-hover: var(--t-fill-color-neutral-050);
314
+ --tds-sidenav-item-nested-border-color-selected: var(--t-fill-color-neutral-010);
394
315
  }
395
316
  }
396
317
 
397
- .tds-page-header {
398
- display: flex;
399
- flex-direction: column;
400
- padding-top: var(--tds-page-header-padding-y);
401
- color: var(--tds-page-header-color);
402
- background: var(--tds-page-header-background-color);
403
- border-bottom: 1px solid var(--t-border-color-default-base);
404
- }
318
+ .tds-sidenav :where(nav,ul,.tds-sidenav-section) {
319
+ display: flex;
320
+ }
405
321
 
406
- .tds-page-header:not(.has-nav) {
407
- padding-bottom: var(--tds-page-header-padding-y);
408
- }
322
+ .tds-sidenav :where(nav,ul,.tds-sidenav-section,.tds-sidenav-collapse) {
323
+ flex-direction: column;
324
+ gap: var(--t-spacing-half);
325
+ width: 100%;
326
+ }
409
327
 
410
- .tds-page-header.inactive {
411
- background: var(--tds-page-header-background-color-inactive);
328
+ .tds-sidenav-section-list {
329
+ width: 100%;
330
+ padding: 0;
331
+ margin: 0;
332
+ list-style: none;
412
333
  }
413
334
 
414
- .tds-page-header__title-bar {
335
+ .tds-sidenav-section-header {
415
336
  display: flex;
416
- flex-direction: column;
417
- gap: var(--t-spacing-2) var(--t-spacing-1);
418
- align-items: flex-start;
337
+ align-items: baseline;
419
338
  justify-content: space-between;
420
- padding: 0 var(--tds-page-header-padding-x);
339
+ padding-top: var(--t-spacing-2);
421
340
  }
422
341
 
423
- .tds-page-header--profile > .tds-page-header__title-bar {
342
+ .tds-sidenav-section-header h2 {
343
+ margin: 0;
344
+ font-size: var(--t-font-size-sm);
345
+ font-weight: var(--t-font-weight-semibold);
346
+ line-height: 1.35;
347
+ color: var(--t-text-color-default-secondary);
348
+ text-transform: uppercase;
349
+ }
350
+
351
+ .tds-sidenav-section:first-of-type .tds-sidenav-section-header {
352
+ padding-top: 0;
353
+ }
354
+
355
+ .tds-sidenav-section-header [slot="label-actions"] {
356
+ display: flex;
357
+ gap: var(--t-spacing-half);
358
+ align-items: center;
359
+ }
360
+
361
+ .tds-sidenav-section [slot="section-actions"] {
362
+ display: flex;
363
+ gap: 12px;
424
364
  align-items: center;
365
+ min-height: 42px;
366
+ padding: var(--t-spacing-1) 0;
425
367
  }
426
368
 
427
- .tds-page-header__primary {
369
+ .tds-sidenav-section-list,
370
+ .tds-sidenav-item {
428
371
  width: 100%;
429
- }
430
-
431
- .tds-page-header__primary h1 {
372
+ padding: 0;
432
373
  margin: 0;
433
- font-size: var(--tds-page-header-headline-font-size);
434
- font-weight: var(--t-font-weight-normal);
435
- line-height: 32px;
436
- color: var(--tds-page-header-headline-color);
437
- overflow-wrap: break-word;
438
374
  }
439
375
 
440
- .tds-page-header [slot="actions"] {
441
- width: 100%;
442
- }
376
+ .tds-sidenav-item :is(a,button) {
377
+ position: relative;
378
+ display: flex;
379
+ gap: 12px;
380
+ align-items: center;
381
+ width: 100%;
382
+ padding: 12px;
383
+ overflow: hidden;
384
+ font-size: var(--t-font-size-sm);
385
+ line-height: 18px;
386
+ color: var(--t-text-color-default-headline);
387
+ white-space: nowrap;
388
+ text-decoration: none;
389
+ -webkit-appearance: none;
390
+ -moz-appearance: none;
391
+ appearance: none;
392
+ cursor: pointer;
393
+ background-color: var(--tds-sidenav-item-background, transparent);
394
+ border: 0;
395
+ border-radius: var(--t-border-radius-default);
396
+ transition: var(--tds-sidenav-item-transition);
397
+ }
443
398
 
444
- .has-multi-actions.tds-page-header [slot="actions"],
445
- .has-multi-actions.tds-page-header .tds-page-header__actions {
446
- display: flex;
447
- flex-flow: row wrap;
448
- gap: var(--t-spacing-half) var(--t-spacing-1);
449
- align-items: flex-start;
450
- justify-content: flex-start;
451
- min-width: 0;
452
- }
399
+ :is(.tds-sidenav-item :is(a,button)):not(:has(.prefix,.suffix)),:is(.tds-sidenav-item :is(a,button)) :is(:not(.prefix,.suffix)) {
400
+ display: block;
401
+ flex: 1;
402
+ overflow: hidden;
403
+ text-overflow: ellipsis;
404
+ text-align: left;
405
+ white-space: nowrap;
406
+ }
453
407
 
454
- .tds-page-header nav[slot="navigation"]:not(:has(ul)),
455
- .tds-page-header nav.tds-page-header__nav:not(:has(ul)),
456
- .tds-page-header nav[slot="navigation"] ul,
457
- .tds-page-header nav.tds-page-header__nav ul {
458
- display: flex;
459
- gap: var(--tds-page-header-nav-gap);
460
- padding: var(--t-spacing-2) var(--tds-page-header-nav-padding-x) 0;
461
- margin: 0 0 -1px;
462
- overflow: auto;
463
- list-style: none;
464
- background: var(--tds-page-header-nav-background);
465
- }
408
+ :is(.tds-sidenav-item :is(a,button)):hover,:is(.tds-sidenav-item :is(a,button)):focus-visible {
409
+ --tds-sidenav-item-background: var(--tds-sidenav-item-background-hover);
410
+ color: var(--t-text-color-default-headline);
411
+ text-decoration: none;
412
+ }
466
413
 
467
- .tds-page-header nav[slot="navigation"] a,
468
- .tds-page-header nav[slot="navigation"] button,
469
- .tds-page-header nav.tds-page-header__nav a,
470
- .tds-page-header nav.tds-page-header__nav button {
471
- position: relative;
472
- display: inline-flex;
473
- padding: var(--tds-page-header-nav-item-padding-y) var(--tds-page-header-nav-item-padding-x);
474
- font-size: var(--t-font-size-sm);
475
- line-height: 22px;
476
- color: var(--tds-page-header-nav-item-color);
477
- white-space: nowrap;
478
- text-decoration: none;
479
- -webkit-appearance: none;
480
- -moz-appearance: none;
481
- appearance: none;
482
- cursor: pointer;
483
- outline-offset: -2px;
484
- background-color: var(--tds-page-header-nav-item-background-color);
485
- background-clip: padding-box;
486
- border: var(--tds-page-header-nav-item-border-width) solid var(--tds-page-header-nav-item-border-color);
487
- border-bottom: 1px solid var(--tds-page-header-nav-item-border-bottom-color);
488
- border-radius: var(--t-border-radius-md) var(--t-border-radius-md) 0 0;
489
- }
414
+ :is(.tds-sidenav-item :is(a,button)):active {
415
+ --tds-sidenav-item-background: var(--tds-sidenav-item-background-active);
416
+ }
417
+
418
+ :is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"]) {
419
+ overflow: hidden;
420
+ color: var(--tds-sidenav-item-icon-color);
421
+ }
422
+
423
+ :is(:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"])),:is(:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"])) svg {
424
+ display: block;
425
+ width: var(--tds-sidenav-item-icon-size);
426
+ height: var(--tds-sidenav-item-icon-size);
427
+ }
428
+
429
+ :is(.tds-sidenav-item :is(a,button)):has(.prefix,[slot="prefix"]) + .tds-sidenav-section {
430
+ --tds-sidenav-indent: 19px;
431
+ }
490
432
 
491
- .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator) {
492
- position: relative;
493
- }
433
+ [aria-expanded="true"]:is(.tds-sidenav-item :is(a,button)) + .tds-sidenav-section-list {
434
+ visibility: visible;
435
+ block-size: auto;
436
+ opacity: 1;
437
+ }
494
438
 
495
- .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator) :is(a, button) {
496
- -webkit-mask: radial-gradient(8px at calc(100% - 3px) 0, #0000 98%, #000);
497
- mask: radial-gradient(8px at calc(100% - 3px) 0, #0000 98%, #000);
498
- }
439
+ .tds-sidenav-item.selected > :is(a,button),.tds-sidenav-item:has(.tds-sidenav-section):has(.selected) > :is(a,button) {
440
+ --tds-sidenav-item-background: var(--tds-sidenav-item-background-selected);
441
+ --tds-sidenav-item-icon-color: var(--tds-sidenav-item-icon-color-selected);
499
442
 
500
- .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::before,
501
- .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::after {
502
- position: absolute;
503
- top: -5px;
504
- right: -2px;
505
- width: 10px;
506
- height: 10px;
507
- content: "";
508
- background: var(--tds-page-header-nav-item-indicator-color);
509
- border-radius: 50%;
510
- }
443
+ --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-selected);
444
+ font-weight: var(--t-font-weight-semibold);
445
+ }
511
446
 
512
- @media (prefers-reduced-motion: no-preference) {
513
- .tds-page-header nav:is([slot="navigation"], .tds-page-header__nav) li:has(.indicator)::after {
514
- animation: indicator-pulse 1.25s ease infinite;
447
+ .tds-sidenav-item:has(.tds-sidenav-section) {
448
+ display: flex;
449
+ flex-direction: column;
450
+ gap: var(--t-spacing-half);
515
451
  }
516
- }
517
452
 
518
- .tds-page-header nav[slot="navigation"] a.selected,
519
- .tds-page-header nav[slot="navigation"] button.selected,
520
- .tds-page-header nav.tds-page-header__nav a.selected,
521
- .tds-page-header nav.tds-page-header__nav button.selected {
522
- --tds-page-header-nav-item-color: var(--tds-page-header-nav-item-color-selected);
523
- --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-border-color-selected);
524
- --tds-page-header-nav-item-background-color: var(--tds-page-header-nav-item-background-color-selected);
525
- --tds-page-header-nav-item-border-bottom-color: var(--tds-page-header-nav-item-background-color-selected);
526
- }
453
+ .tds-sidenav-item .tds-sidenav-section-list {
454
+ --tds-sidenav-item-depth: 1;
455
+ gap: 0;
456
+ }
527
457
 
528
- .tds-page-header nav[slot="navigation"] a:not(.selected):hover,
529
- .tds-page-header nav[slot="navigation"] button:not(.selected):hover,
530
- .tds-page-header nav.tds-page-header__nav a:not(.selected):hover,
531
- .tds-page-header nav.tds-page-header__nav button:not(.selected):hover {
532
- --tds-page-header-nav-item-color: var(--tds-page-header-nav-item-color-hover);
533
- --tds-page-header-nav-item-background-color: var(--tds-page-header-nav-item-background-color-hover);
534
- --tds-page-header-nav-item-border-color: var(--tds-page-header-nav-item-border-color-hover);
535
- }
458
+ .tds-sidenav-action--toggle + :is(.tds-sidenav-item .tds-sidenav-section-list) {
459
+ visibility: hidden;
460
+ block-size: 0;
461
+ overflow-y: clip;
462
+ opacity: 0;
463
+ transition: content-visibility .2s allow-discrete, opacity .2s, block-size .2s;
464
+ }
536
465
 
537
- .tds-page-header nav[slot="navigation"] a:not(.selected):active,
538
- .tds-page-header nav[slot="navigation"] button:not(.selected):active,
539
- .tds-page-header nav.tds-page-header__nav a:not(.selected):active,
540
- .tds-page-header nav.tds-page-header__nav button:not(.selected):active {
541
- background-color: var(--tds-page-header-nav-item-background-color-active);
542
- }
466
+ :is(.tds-sidenav-item .tds-sidenav-section-list) .tds-sidenav-section-list {
467
+ --tds-sidenav-item-depth: 2;
468
+ }
543
469
 
544
- .tds-page-header nav[slot="navigation"] a:not(.selected):disabled,
545
- .tds-page-header nav[slot="navigation"] button:not(.selected):disabled,
546
- .tds-page-header nav.tds-page-header__nav a:not(.selected):disabled,
547
- .tds-page-header nav.tds-page-header__nav button:not(.selected):disabled {
548
- color: var(--tds-page-header-nav-item-color-disabled);
549
- cursor: not-allowed;
550
- background-color: var(--tds-page-header-nav-item-background-color-disabled);
551
- opacity: 1;
470
+ :is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button) {
471
+ min-height: var(--t-element-size-2xl);
472
+ padding-block: 9px;
473
+ padding-left: calc((var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth)) + var(--tds-sidenav-indent) + var(--t-spacing-fourth));
474
+ line-height: 1;
475
+ background-color: transparent;
476
+ }
477
+
478
+ :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::before {
479
+ position: absolute;
480
+ top: 0;
481
+ bottom: 0;
482
+ left: calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
483
+ width: 2px;
484
+ content: "";
485
+ background-color: var(--tds-sidenav-item-nested-border-color);
486
+ transition: var(--tds-sidenav-item-transition);
487
+ }
488
+
489
+ :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::after {
490
+ position: absolute;
491
+ inset: 0 0 0 calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
492
+ z-index: -1;
493
+ height: 100%;
494
+ content: "";
495
+ background-color: var(--tds-sidenav-item-nested-background);
496
+ border-radius: 0 var(--t-border-radius-default) var(--t-border-radius-default) 0;
497
+ transition: var(--tds-sidenav-item-transition);
498
+ }
499
+
500
+ :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):not(:has(.prefix,.suffix)),:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)) :is(:not(.prefix,.suffix)) {
501
+ display: block;
502
+ text-align: left;
503
+ white-space: normal;
504
+ }
505
+
506
+ :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):hover,:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):focus-visible {
507
+ --tds-sidenav-item-nested-border-color: var(--tds-sidenav-item-nested-border-color-hover);
508
+ --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-hover);
509
+ }
510
+
511
+ :is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):active {
512
+ --tds-sidenav-item-nested-background: var(--tds-sidenav-item-nested-background-active);
513
+ }
514
+
515
+ .selected:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button) {
516
+ --tds-sidenav-item-nested-border-color: var(--tds-sidenav-item-nested-border-color-selected);
517
+ font-weight: var(--t-font-weight-medium);
518
+ }
519
+
520
+ .tds-sidenav-responsive-header {
521
+ display: flex;
522
+ gap: var(--t-spacing-2);
523
+ align-items: center;
524
+ width: 100%;
552
525
  }
553
526
 
554
- @media (min-width: 960px) {
555
- .tds-page-header__primary {
556
- flex: 1 1 max-content;
557
- width: auto;
558
- min-width: 0;
559
- max-width: 100%;
527
+ .tds-sidenav-responsive-header .tds-sidenav-responsive-header-toggle {
528
+ order: 0;
560
529
  }
561
530
 
562
- .tds-page-header__title-bar,
563
- .tds-page-header--profile .tds-page-header__title-bar {
564
- flex-flow: row nowrap;
565
- row-gap: 12px;
566
- align-items: flex-start;
531
+ .tds-sidenav-responsive-header .tds-sidenav-responsive-header-label {
532
+ flex: 1;
533
+ order: 1;
534
+ margin: 0;
535
+ font-size: var(--t-font-size-lg);
536
+ font-weight: var(--t-font-weight-medium);
537
+ color: var(--t-text-color-default-headline);
567
538
  }
568
539
 
569
- .tds-page-header [slot="actions"] {
570
- width: auto;
540
+ @media (max-width: 719px) {
541
+ .tds-sidenav-collapse {
542
+ z-index: 10001;
543
+ display: none;
544
+ max-width: min(448px, calc(100vw - 48px));
545
+ padding: 0;
546
+ margin: 12px 0;
547
+ overflow: hidden;
548
+ outline: 0;
549
+ background: var(--t-surface-color-card);
550
+ border: 0;
551
+ border-radius: 6px;
552
+ box-shadow: 0 8px 20px 0 rgba(0, 0, 0, .25);
553
+ will-change: transform;
554
+ position-area: bottom span-right;
571
555
  }
572
556
 
573
- .has-multi-actions.tds-page-header [slot="actions"],
574
- .has-multi-actions.tds-page-header .tds-page-header__actions {
575
- justify-content: flex-end;
557
+ .tds-sidenav-scroll-container {
558
+ --webkit-overflow-scrolling: touch;
559
+ display: block;
560
+ width: 100%;
561
+ height: -moz-fit-content;
562
+ height: fit-content;
563
+ padding: var(--t-spacing-2);
564
+ overflow-y: auto;
576
565
  }
577
- }
578
-
579
- .tds-page-header-phone,
580
- .tds-page-header-email {
581
- color: var(--tds-page-header-color);
582
- white-space: nowrap;
583
- }
584
566
 
585
- /* Truncate email */
567
+ .tds-sidenav-item :is(a, button) :is(.prefix) {
568
+ display: none;
569
+ }
586
570
 
587
- .tds-page-header-email {
588
- max-width: 100%;
589
- overflow: hidden;
590
- text-overflow: ellipsis;
591
- }
571
+ /* Modern browsers only */
572
+ @supports selector(:popover-open) {
573
+ .tds-sidenav-collapse:popover-open {
574
+ display: flex;
575
+ }
576
+ }
592
577
 
593
- @keyframes indicator-pulse {
594
- 0% {
595
- opacity: .3;
596
- transform: scale(.9);
578
+ /* Older browsers only, running the polyfill */
579
+ @supports not selector(:popover-open) {
580
+ .tds-sidenav-collapse.\:popover-open {
581
+ display: flex;
582
+ }
597
583
  }
584
+ }
598
585
 
599
- 100% {
600
- opacity: 0;
601
- transform: scale(1.75);
586
+ @media (min-width: 720px) {
587
+ .tds-sidenav-responsive-header {
588
+ display: none;
602
589
  }
603
590
  }
604
591
 
592
+ :is(tds-sidenav,tds-sidenav-section,tds-sidenav-item):not(.hydrated) > :not([slot="ssr"]) {
593
+ display: none;
594
+ }
595
+
596
+ :is(tds-sidenav,tds-sidenav-section,tds-sidenav-item):not(.hydrated) > [slot="ssr"] {
597
+ display: block;
598
+ }
599
+
600
+ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
601
+ display: flex;
602
+ flex-direction: column;
603
+ }
604
+
605
605
  .tds-loading-spinner {
606
- --tds-loading-spinner-border-width: 4px; /* Default for md size */
607
- --tds-loading-spinner-border-color: var(--t-fill-color-transparency-light-040);
608
- --tds-loading-spinner-border-top-color: currentcolor;
609
606
  --tds-loading-spinner-size: 1.25em;
610
- --tds-loading-spinner-visibility: hidden;
611
- --tds-loading-spinner-animation-play-state: paused;
612
607
 
613
608
  position: absolute;
614
609
  right: 0;
615
610
  left: 0;
616
- visibility: var(--tds-loading-spinner-visibility);
611
+ visibility: var(--tds-loading-spinner-visibility, hidden);
617
612
  width: var(--tds-loading-spinner-size);
618
613
  height: var(--tds-loading-spinner-size);
619
614
  margin: auto;
620
- border: var(--tds-loading-spinner-border-width) solid var(--tds-loading-spinner-border-color);
621
- border-top: var(--tds-loading-spinner-border-width) solid var(--tds-loading-spinner-border-top-color);
615
+ border: var(--tds-loading-spinner-track-width, 4px) solid var(--tds-loading-spinner-track-color, var(--t-fill-color-transparency-dark-020));
616
+ border-top-color: var(--tds-loading-spinner-color, currentcolor);
622
617
  border-radius: 50%;
623
618
  animation: spinner-rotate 500ms infinite linear;
624
- animation-play-state: var(--tds-loading-spinner-animation-play-state);
619
+ animation-play-state: var(--tds-loading-spinner-animation-play-state, paused);
625
620
  }
626
621
 
627
622
  @keyframes spinner-rotate {
@@ -739,6 +734,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
739
734
  --t-icon-color-status-success-secondary: hsl(97, 57%, 40%);
740
735
  --t-icon-color-status-warning-primary: hsl(42, 84%, 49%);
741
736
  --t-icon-color-status-error-primary: hsl(8, 60%, 47%);
737
+ --t-fill-color-neutral-100: hsl(0, 0%, 100%);
742
738
  --t-fill-color-neutral-000: hsl(0, 0%, 12%);
743
739
  --t-fill-color-neutral-010: hsl(0, 0%, 24%);
744
740
  --t-fill-color-neutral-020: hsl(0, 0%, 42%);
@@ -750,7 +746,6 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
750
746
  --t-fill-color-neutral-070: hsl(0, 0%, 95%);
751
747
  --t-fill-color-neutral-080: hsl(0, 0%, 97%);
752
748
  --t-fill-color-neutral-090: hsl(0, 0%, 98%);
753
- --t-fill-color-neutral-100: hsl(0, 0%, 100%);
754
749
  --t-fill-color-interaction-default: hsl(204, 100%, 40%);
755
750
  --t-fill-color-interaction-hover: hsl(204, 100%, 35%);
756
751
  --t-fill-color-interaction-active: hsl(204, 100%, 30%);
@@ -1023,6 +1018,24 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1023
1018
  --t-border-color-control-warning: hsl(42, 84%, 63%);
1024
1019
  --t-border-color-control-error: hsl(8, 60%, 47%);
1025
1020
  --t-border-color-control-disabled: hsl(0, 0%, 88%);
1021
+ --t-form-background-color: var(--t-fill-color-neutral-100);
1022
+ --t-form-background-color-disabled: var(--t-fill-color-neutral-070);
1023
+ --t-form-background-color-error: var(--t-fill-color-neutral-100);
1024
+ --t-form-background-color-readonly: var(--t-fill-color-neutral-070);
1025
+ --t-form-border-color: var(--t-border-color-default-base);
1026
+ --t-form-border-color-disabled: var(--t-border-color-default-base);
1027
+ --t-form-border-color-error: var(--t-border-color-status-error);
1028
+ --t-form-border-color-focus: var(--t-fill-color-interaction-default);
1029
+ --t-form-border-color-hover: var(--t-border-color-default-dark);
1030
+ --t-form-border-color-readonly: hsla(0, 0%, 100%, 0);
1031
+ --t-form-border-radius: var(--t-border-radius-md);
1032
+ --t-form-border-width: var(--t-border-width-default);
1033
+ --t-form-font-color: var(--t-text-color-default-primary);
1034
+ --t-form-font-color-disabled: var(--t-text-color-default-disabled);
1035
+ --t-form-font-color-error: var(--t-text-color-status-error);
1036
+ --t-form-font-color-readonly: var(--t-text-color-default-primary);
1037
+ --t-form-picker-icon-color: var(--t-icon-color-default-primary);
1038
+ --t-form-placeholder-color: var(--t-text-color-default-placeholder);
1026
1039
  --t-border-size-default: var(--t-border-width-default);
1027
1040
  --t-border-size-thick: var(--t-border-width-thick);
1028
1041
  --t-font-weight-semi-bold: var(--t-font-weight-semibold);
@@ -1128,16 +1141,15 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1128
1141
  }
1129
1142
 
1130
1143
  .tds-btn:disabled,.tds-btn.disabled {
1144
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-transparency-dark-020);
1145
+ --tds-btn-loading-spinner-color: var(--t-text-color-status-neutral);
1146
+ color: var(--tds-btn-color-disabled);
1131
1147
  pointer-events: none;
1148
+ background-color: var(--tds-btn-bg-disabled);
1149
+ border-color: var(--tds-btn-border-color-disabled);
1150
+ opacity: var(--tds-btn-disabled-opacity);
1132
1151
  }
1133
1152
 
1134
- :is(.tds-btn:disabled,.tds-btn.disabled):not(.tds-btn--loading) {
1135
- color: var(--tds-btn-color-disabled);
1136
- background-color: var(--tds-btn-bg-disabled);
1137
- border-color: var(--tds-btn-border-color-disabled);
1138
- opacity: var(--tds-btn-disabled-opacity);
1139
- }
1140
-
1141
1153
  .tds-btn svg:not(.symbol) {
1142
1154
  display: block;
1143
1155
  inline-size: auto;
@@ -1146,6 +1158,14 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1146
1158
  color: var(--tds-btn-icon-color, currentColor);
1147
1159
  }
1148
1160
 
1161
+ .tds-btn .tds-loading-spinner {
1162
+ --tds-loading-spinner-track-color: var(--tds-btn-loading-spinner-track-color);
1163
+ --tds-loading-spinner-track-width: var(--tds-btn-loading-spinner-track-width);
1164
+ --tds-loading-spinner-color: var(--tds-btn-loading-spinner-color);
1165
+ --tds-loading-spinner-visibility: var(--tds-btn-loading-spinner-visibility);
1166
+ --tds-loading-spinner-animation-play-state: var(--tds-btn-loading-spinner-animation-play-state);
1167
+ }
1168
+
1149
1169
  @media (prefers-reduced-motion: reduce) {
1150
1170
 
1151
1171
  .tds-btn {
@@ -1178,12 +1198,9 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1178
1198
  --tds-btn-padding-truncated-x: 4px;
1179
1199
  --tds-btn-min-height: 24px;
1180
1200
  --tds-btn-font-size: var(--t-font-size-sm);
1201
+ --tds-btn-loading-spinner-track-width: 3px;
1181
1202
  }
1182
1203
 
1183
- .tds-btn--sm .tds-loading-spinner {
1184
- --tds-loading-spinner-border-width: 3px;
1185
- }
1186
-
1187
1204
  /* Effective height 20px */
1188
1205
 
1189
1206
  .tds-btn--xs {
@@ -1192,12 +1209,9 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1192
1209
  --tds-btn-padding-truncated-x: 5px;
1193
1210
  --tds-btn-min-height: 20px;
1194
1211
  --tds-btn-font-size: var(--t-font-size-xs);
1212
+ --tds-btn-loading-spinner-track-width: 3px;
1195
1213
  }
1196
1214
 
1197
- .tds-btn--xs .tds-loading-spinner {
1198
- --tds-loading-spinner-border-width: 3px;
1199
- }
1200
-
1201
1215
  .tds-btn--neutral {
1202
1216
  --tds-btn-color: var(--t-text-color-status-neutral);
1203
1217
  --tds-btn-bg: var(--t-fill-color-button-neutral-solid-default);
@@ -1226,6 +1240,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1226
1240
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1227
1241
  --tds-btn-bg-disabled: var(--t-fill-color-button-interaction-solid-disabled);
1228
1242
  --tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
1243
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-transparency-light-020);
1229
1244
  }
1230
1245
 
1231
1246
  .tds-btn--delete {
@@ -1241,6 +1256,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1241
1256
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1242
1257
  --tds-btn-bg-disabled: var(--t-fill-color-button-delete-solid-disabled);
1243
1258
  --tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
1259
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-transparency-light-020);
1244
1260
  }
1245
1261
 
1246
1262
  .tds-btn--outline-neutral {
@@ -1257,11 +1273,6 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1257
1273
  --tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
1258
1274
  }
1259
1275
 
1260
- .tds-btn--outline-neutral .tds-loading-spinner {
1261
- --tds-loading-spinner-border-color: var(--t-fill-color-transparency-dark-020);
1262
- --tds-loading-spinner-border-top-color: currentcolor;
1263
- }
1264
-
1265
1276
  .tds-btn--outline-interaction {
1266
1277
  --tds-btn-color: var(--t-text-color-interaction-primary);
1267
1278
  --tds-btn-border-color: var(--t-border-color-button-info);
@@ -1274,6 +1285,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1274
1285
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1275
1286
  --tds-btn-bg-disabled: var(--t-fill-color-button-interaction-outline-dim-disabled);
1276
1287
  --tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
1288
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-status-info-ghost);
1277
1289
  }
1278
1290
 
1279
1291
  .tds-btn--outline-delete {
@@ -1288,6 +1300,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1288
1300
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1289
1301
  --tds-btn-bg-disabled: var(--t-fill-color-button-delete-outline-dim-disabled);
1290
1302
  --tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
1303
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-status-error-ghost);
1291
1304
  }
1292
1305
 
1293
1306
  .tds-btn--ghost-neutral {
@@ -1304,11 +1317,6 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1304
1317
  --tds-btn-border-color-disabled: transparent;
1305
1318
  }
1306
1319
 
1307
- .tds-btn--ghost-neutral .tds-loading-spinner {
1308
- --tds-loading-spinner-border-color: var(--t-fill-color-transparency-dark-020);
1309
- --tds-loading-spinner-border-top-color: currentcolor;
1310
- }
1311
-
1312
1320
  .tds-btn--ghost-interaction {
1313
1321
  --tds-btn-color: var(--t-text-color-interaction-primary);
1314
1322
  --tds-btn-border-color: transparent;
@@ -1321,6 +1329,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1321
1329
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1322
1330
  --tds-btn-bg-disabled: transparent;
1323
1331
  --tds-btn-border-color-disabled: transparent;
1332
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-status-info-ghost);
1324
1333
  }
1325
1334
 
1326
1335
  .tds-btn--ghost-delete {
@@ -1335,6 +1344,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1335
1344
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1336
1345
  --tds-btn-bg-disabled: transparent;
1337
1346
  --tds-btn-border-color-disabled: transparent;
1347
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-status-error-ghost);
1338
1348
  }
1339
1349
 
1340
1350
  .tds-btn--inline-text {
@@ -1352,6 +1362,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1352
1362
  --tds-btn-font-size: inherit;
1353
1363
  --tds-btn-font-weight: inherit;
1354
1364
  --tds-btn-line-height: inherit;
1365
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-status-info-ghost);
1355
1366
  font-family: inherit;
1356
1367
  font-style: inherit;
1357
1368
  vertical-align: inherit;
@@ -1374,6 +1385,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1374
1385
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1375
1386
  --tds-btn-bg-disabled: var(--t-fill-color-button-interaction-solid-disabled);
1376
1387
  --tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
1388
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-transparency-light-020);
1377
1389
  }
1378
1390
 
1379
1391
  .tds-btn--secondary-page-header {
@@ -1422,6 +1434,7 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1422
1434
  --tds-btn-color-disabled: var(--t-text-color-default-disabled);
1423
1435
  --tds-btn-bg-disabled: var(--t-fill-color-button-interaction-solid-disabled);
1424
1436
  --tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
1437
+ --tds-btn-loading-spinner-track-color: var(--t-fill-color-transparency-light-020);
1425
1438
  }
1426
1439
 
1427
1440
  .tds-btn--pill {
@@ -1475,14 +1488,12 @@ tds-sidenav-section:not(.hydrated) > [slot="ssr"] {
1475
1488
  }
1476
1489
 
1477
1490
  .tds-btn--loading {
1491
+ --tds-btn-loading-spinner-visibility: visible;
1492
+ --tds-btn-loading-spinner-animation-play-state: running;
1493
+
1478
1494
  position: relative;
1479
1495
  }
1480
1496
 
1481
- .tds-btn--loading .tds-loading-spinner {
1482
- --tds-loading-spinner-visibility: visible;
1483
- --tds-loading-spinner-animation-play-state: running;
1484
- }
1485
-
1486
1497
  .tds-btn--loading :not(.tds-loading-spinner) {
1487
1498
  visibility: hidden;
1488
1499
  }