@carbon/styles 1.77.2 → 1.78.0-rc.0

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.
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@carbon/styles",
3
3
  "description": "Styles for the Carbon Design System",
4
- "version": "1.77.2",
4
+ "version": "1.78.0-rc.0",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
7
7
  "type": "git",
@@ -41,12 +41,12 @@
41
41
  },
42
42
  "dependencies": {
43
43
  "@carbon/colors": "^11.30.0",
44
- "@carbon/feature-flags": "^0.24.0",
45
- "@carbon/grid": "^11.32.2",
46
- "@carbon/layout": "^11.30.2",
44
+ "@carbon/feature-flags": "^0.25.0-rc.0",
45
+ "@carbon/grid": "^11.33.0-rc.0",
46
+ "@carbon/layout": "^11.31.0-rc.0",
47
47
  "@carbon/motion": "^11.25.0",
48
- "@carbon/themes": "^11.48.2",
49
- "@carbon/type": "^11.36.2",
48
+ "@carbon/themes": "^11.49.0-rc.0",
49
+ "@carbon/type": "^11.37.0-rc.0",
50
50
  "@ibm/plex": "6.0.0-next.6",
51
51
  "@ibm/plex-mono": "0.0.3-alpha.0",
52
52
  "@ibm/plex-sans": "0.0.3-alpha.0",
@@ -75,5 +75,5 @@
75
75
  "scss/**/*.css",
76
76
  "css/**/*.css"
77
77
  ],
78
- "gitHead": "5c8f7e2a47c2bfb2865f1f2f4efe55b26f45ad5c"
78
+ "gitHead": "0c142888f7e3aefd5a5b5b0b2c34c2552894bb56"
79
79
  }
@@ -13,6 +13,7 @@
13
13
  'enable-experimental-tile-contrast': false,
14
14
  'enable-v12-tile-radio-icons': false,
15
15
  'enable-v12-structured-list-visible-icons': false,
16
+ 'enable-dialog-element': false,
16
17
  )
17
18
  !default
18
19
  );
@@ -25,6 +25,7 @@
25
25
  @use 'data-table/skeleton';
26
26
  @use 'data-table/sort';
27
27
  @use 'date-picker';
28
+ @use 'dialog';
28
29
  @use 'dropdown';
29
30
  @use 'file-uploader';
30
31
  @use 'fluid-combo-box';
@@ -57,6 +57,11 @@
57
57
  }
58
58
  }
59
59
 
60
+ .#{$prefix}--breadcrumb-item .#{$prefix}--link:active,
61
+ .#{$prefix}--breadcrumb-item .#{$prefix}--link:visited:active:hover {
62
+ color: $text-primary;
63
+ }
64
+
60
65
  .#{$prefix}--breadcrumb-item::after {
61
66
  color: $text-primary;
62
67
  content: '/';
@@ -96,20 +101,40 @@
96
101
  .#{$prefix}--breadcrumb-item .#{$prefix}--overflow-menu {
97
102
  position: relative;
98
103
  block-size: convert.to-rem(18px);
99
- inline-size: convert.to-rem(20px);
104
+ inline-size: $spacing-05;
100
105
 
101
106
  &:focus {
107
+ border: none;
108
+ box-shadow: none;
102
109
  outline: 1px solid $focus;
110
+ outline-offset: 0;
103
111
  }
104
112
 
105
113
  &:hover {
106
114
  background: transparent;
115
+
116
+ &::after {
117
+ background: $link-primary-hover;
118
+ }
119
+ }
120
+
121
+ &:active {
122
+ &::after {
123
+ background: $text-primary;
124
+ }
125
+ }
126
+
127
+ &:focus,
128
+ &:hover {
129
+ &::after {
130
+ opacity: 1;
131
+ }
107
132
  }
108
133
 
109
134
  // Used to mimic link underline
110
135
  &::after {
111
136
  position: absolute;
112
- background: $link-primary-hover;
137
+ background: $focus;
113
138
  block-size: 1px;
114
139
  content: '';
115
140
  inline-size: convert.to-rem(12px);
@@ -123,16 +148,6 @@
123
148
  }
124
149
  }
125
150
 
126
- .#{$prefix}--breadcrumb--sm
127
- .#{$prefix}--breadcrumb-item
128
- .#{$prefix}--overflow-menu {
129
- inline-size: $spacing-05;
130
- }
131
-
132
- .#{$prefix}--breadcrumb-item .#{$prefix}--overflow-menu:hover::after {
133
- opacity: 1;
134
- }
135
-
136
151
  .#{$prefix}--breadcrumb-item
137
152
  .#{$prefix}--overflow-menu.#{$prefix}--overflow-menu--open {
138
153
  background: transparent;
@@ -153,6 +168,12 @@
153
168
  fill: $link-primary-hover;
154
169
  }
155
170
 
171
+ .#{$prefix}--breadcrumb-item
172
+ .#{$prefix}--overflow-menu:active
173
+ .#{$prefix}--overflow-menu__icon {
174
+ fill: $text-primary;
175
+ }
176
+
156
177
  .#{$prefix}--breadcrumb-menu-options:focus {
157
178
  outline: none;
158
179
  }
@@ -176,6 +197,23 @@
176
197
  inset-inline-start: initial;
177
198
  }
178
199
 
200
+ .#{$prefix}--breadcrumb
201
+ .#{$prefix}--overflow-menu.#{$prefix}--btn--icon-only {
202
+ min-block-size: 1.125rem;
203
+ padding-inline: 0;
204
+ }
205
+
206
+ .#{$prefix}--breadcrumb--sm
207
+ .#{$prefix}--breadcrumb-item
208
+ .#{$prefix}--overflow-menu {
209
+ block-size: $spacing-05;
210
+ inline-size: $spacing-05;
211
+ min-block-size: $spacing-05;
212
+ .#{$prefix}--overflow-menu__icon {
213
+ transform: translateY(3px);
214
+ }
215
+ }
216
+
179
217
  // Skeleton State
180
218
  .#{$prefix}--breadcrumb.#{$prefix}--skeleton .#{$prefix}--link {
181
219
  @include skeleton;
@@ -183,10 +221,4 @@
183
221
  block-size: 1rem;
184
222
  inline-size: convert.to-rem(100px);
185
223
  }
186
-
187
- .#{$prefix}--breadcrumb
188
- .#{$prefix}--overflow-menu.#{$prefix}--btn--icon-only {
189
- min-block-size: 1.125rem;
190
- padding-inline: 0;
191
- }
192
224
  }
@@ -18,16 +18,14 @@
18
18
  @use '../../utilities/component-reset';
19
19
  @use '../../utilities/focus-outline' as *;
20
20
  @use '../../utilities/high-contrast-mode' as *;
21
- @use '../../utilities/z-index' as *;
22
21
 
23
22
  /// Dialog styles
24
23
  /// @access public
25
24
  /// @group dialog
26
25
  @mixin dialog {
27
26
  .#{$prefix}--dialog {
28
- /* size */
29
27
  padding: 0;
30
- border: 1px solid $border-subtle-01;
28
+ border: none;
31
29
  background-color: $layer;
32
30
  color: $text-primary;
33
31
  inline-size: 48rem;
@@ -101,15 +99,6 @@
101
99
  min-block-size: $spacing-09;
102
100
  }
103
101
 
104
- .#{$prefix}--dialog__content {
105
- padding: $spacing-05;
106
- block-size: 100%;
107
- }
108
-
109
- .#{$prefix}--dialog--modal {
110
- border: 1px solid transparent;
111
- }
112
-
113
102
  /* Transition the :backdrop when the dialog modal is promoted to the top layer */
114
103
  .#{$prefix}--dialog::backdrop {
115
104
  background-color: $overlay;
@@ -7,6 +7,7 @@
7
7
 
8
8
  @use '../button';
9
9
  @use '../../config' as *;
10
+ @use '../../feature-flags' as *;
10
11
  @use '../../breakpoint' as *;
11
12
  @use '../../motion' as *;
12
13
  @use '../../spacing' as *;
@@ -23,34 +24,57 @@
23
24
  /// Modal styles
24
25
  /// @access public
25
26
  /// @group modal
26
- @mixin modal {
27
+ @mixin modal(
28
+ $enable-experimental-focus-wrap-without-sentinels: false,
29
+ $enable-dialog-element: false
30
+ ) {
27
31
  .#{$prefix}--modal {
28
- position: fixed;
29
- z-index: z('modal');
30
- display: flex;
31
- align-items: center;
32
- justify-content: center;
33
- background-color: $overlay;
34
- block-size: 100vh;
35
- content: '';
36
- inline-size: 100vw;
37
- inset-block-start: 0;
38
- inset-inline-start: 0;
39
- opacity: 0;
40
- transition:
41
- opacity $duration-moderate-02 motion(exit, expressive),
42
- visibility 0ms linear $duration-moderate-02;
43
- visibility: hidden;
44
-
45
- &.is-visible {
46
- opacity: 1;
32
+ // For modals using the native dialog element, the modal visibility is handled
33
+ // by the Dialog styles.
34
+ @if not(
35
+ enabled('enable-experimental-focus-wrap-without-sentinels') or
36
+ $enable-experimental-focus-wrap-without-sentinels or
37
+ enabled('enable-dialog-element') or
38
+ $enable-dialog-element
39
+ )
40
+ {
41
+ position: fixed;
42
+ z-index: z('modal');
43
+ display: flex;
44
+ align-items: center;
45
+ justify-content: center;
46
+ background-color: $overlay;
47
+ block-size: 100vh;
48
+ content: '';
49
+ inline-size: 100vw;
50
+ inset-block-start: 0;
51
+ inset-inline-start: 0;
52
+ opacity: 0;
47
53
  transition:
48
- opacity $duration-moderate-02 motion(entrance, expressive),
49
- visibility 0ms linear;
50
- visibility: inherit;
54
+ opacity $duration-moderate-02 motion(exit, expressive),
55
+ visibility 0ms linear $duration-moderate-02;
56
+ visibility: hidden;
57
+ }
51
58
 
52
- @media screen and (prefers-reduced-motion: reduce) {
53
- transition: none;
59
+ // For modals using the native dialog element, the modal visibility is handled
60
+ // by the Dialog styles.
61
+ @if not(
62
+ enabled('enable-experimental-focus-wrap-without-sentinels') or
63
+ $enable-experimental-focus-wrap-without-sentinels or
64
+ enabled('enable-dialog-element') or
65
+ $enable-dialog-element
66
+ )
67
+ {
68
+ &.is-visible {
69
+ opacity: 1;
70
+ transition:
71
+ opacity $duration-moderate-02 motion(entrance, expressive),
72
+ visibility 0ms linear;
73
+ visibility: inherit;
74
+
75
+ @media screen and (prefers-reduced-motion: reduce) {
76
+ transition: none;
77
+ }
54
78
  }
55
79
  }
56
80