@material/web 1.0.1 → 1.0.2-nightly.6a1fb38.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.
Files changed (308) hide show
  1. package/all.d.ts +2 -0
  2. package/all.js +2 -0
  3. package/all.js.map +1 -1
  4. package/button/elevated-button.js +5 -1
  5. package/button/elevated-button.js.map +1 -1
  6. package/button/internal/_elevation.scss +32 -32
  7. package/button/internal/_icon.scss +22 -23
  8. package/button/internal/_outlined-button.scss +21 -19
  9. package/button/internal/_shared.scss +84 -77
  10. package/button/internal/_touch-target.scss +4 -0
  11. package/button/internal/button.d.ts +7 -11
  12. package/button/internal/button.js +52 -38
  13. package/button/internal/button.js.map +1 -1
  14. package/button/internal/elevated-button.d.ts +1 -1
  15. package/button/internal/elevated-button.js +1 -1
  16. package/button/internal/elevated-button.js.map +1 -1
  17. package/button/internal/filled-button.d.ts +1 -1
  18. package/button/internal/filled-button.js +1 -1
  19. package/button/internal/filled-button.js.map +1 -1
  20. package/button/internal/filled-tonal-button.d.ts +1 -1
  21. package/button/internal/filled-tonal-button.js +1 -1
  22. package/button/internal/filled-tonal-button.js.map +1 -1
  23. package/button/internal/outlined-button.d.ts +1 -1
  24. package/button/internal/outlined-button.js +2 -2
  25. package/button/internal/outlined-button.js.map +1 -1
  26. package/button/internal/outlined-styles.css.js +1 -1
  27. package/button/internal/outlined-styles.css.js.map +1 -1
  28. package/button/internal/shared-elevation-styles.css.js +1 -1
  29. package/button/internal/shared-elevation-styles.css.js.map +1 -1
  30. package/button/internal/shared-styles.css.js +1 -1
  31. package/button/internal/shared-styles.css.js.map +1 -1
  32. package/checkbox/internal/checkbox.d.ts +16 -23
  33. package/checkbox/internal/checkbox.js +38 -52
  34. package/checkbox/internal/checkbox.js.map +1 -1
  35. package/chips/filter-chip.js +5 -1
  36. package/chips/filter-chip.js.map +1 -1
  37. package/chips/harness.js.map +1 -1
  38. package/chips/input-chip.js +6 -1
  39. package/chips/input-chip.js.map +1 -1
  40. package/chips/internal/assist-chip.js +8 -4
  41. package/chips/internal/assist-chip.js.map +1 -1
  42. package/chips/internal/chip-set.js +6 -4
  43. package/chips/internal/chip-set.js.map +1 -1
  44. package/chips/internal/chip.d.ts +3 -0
  45. package/chips/internal/chip.js +7 -5
  46. package/chips/internal/chip.js.map +1 -1
  47. package/chips/internal/filter-chip.d.ts +2 -0
  48. package/chips/internal/filter-chip.js +11 -5
  49. package/chips/internal/filter-chip.js.map +1 -1
  50. package/chips/internal/input-chip.d.ts +2 -0
  51. package/chips/internal/input-chip.js +10 -4
  52. package/chips/internal/input-chip.js.map +1 -1
  53. package/chips/internal/multi-action-chip.js.map +1 -1
  54. package/chips/internal/trailing-icons.d.ts +1 -1
  55. package/chips/internal/trailing-icons.js +6 -5
  56. package/chips/internal/trailing-icons.js.map +1 -1
  57. package/common.d.ts +2 -0
  58. package/common.js +2 -0
  59. package/common.js.map +1 -1
  60. package/dialog/harness.js +1 -2
  61. package/dialog/harness.js.map +1 -1
  62. package/dialog/internal/_dialog.scss +1 -1
  63. package/dialog/internal/animations.js +14 -12
  64. package/dialog/internal/animations.js.map +1 -1
  65. package/dialog/internal/dialog-styles.css.js +1 -1
  66. package/dialog/internal/dialog-styles.css.js.map +1 -1
  67. package/dialog/internal/dialog.d.ts +6 -6
  68. package/dialog/internal/dialog.js +24 -24
  69. package/dialog/internal/dialog.js.map +1 -1
  70. package/fab/harness.js.map +1 -1
  71. package/fab/internal/fab.js.map +1 -1
  72. package/fab/internal/shared.js +10 -11
  73. package/fab/internal/shared.js.map +1 -1
  74. package/field/harness.js.map +1 -1
  75. package/field/internal/_content.scss +185 -174
  76. package/field/internal/_filled-field.scss +147 -136
  77. package/field/internal/_label.scss +83 -72
  78. package/field/internal/_outlined-field.scss +276 -262
  79. package/field/internal/_supporting-text.scss +53 -42
  80. package/field/internal/field.js +26 -22
  81. package/field/internal/field.js.map +1 -1
  82. package/field/internal/filled-styles.css.js +1 -1
  83. package/field/internal/filled-styles.css.js.map +1 -1
  84. package/field/internal/outlined-styles.css.js +1 -1
  85. package/field/internal/outlined-styles.css.js.map +1 -1
  86. package/field/internal/shared-styles.css.js +1 -1
  87. package/field/internal/shared-styles.css.js.map +1 -1
  88. package/focus/internal/focus-ring.d.ts +2 -0
  89. package/focus/internal/focus-ring.js +3 -3
  90. package/focus/internal/focus-ring.js.map +1 -1
  91. package/icon/internal/_icon.scss +7 -4
  92. package/icon/internal/icon-styles.css.js +1 -1
  93. package/icon/internal/icon-styles.css.js.map +1 -1
  94. package/iconbutton/internal/icon-button.d.ts +9 -4
  95. package/iconbutton/internal/icon-button.js +35 -22
  96. package/iconbutton/internal/icon-button.js.map +1 -1
  97. package/internal/aria/aria.d.ts +4 -26
  98. package/internal/aria/aria.js +10 -28
  99. package/internal/aria/aria.js.map +1 -1
  100. package/internal/aria/delegate.js +2 -2
  101. package/internal/aria/delegate.js.map +1 -1
  102. package/internal/controller/attachable-controller.js +3 -5
  103. package/internal/controller/attachable-controller.js.map +1 -1
  104. package/internal/controller/form-submitter.d.ts +3 -5
  105. package/internal/controller/form-submitter.js +5 -7
  106. package/internal/controller/form-submitter.js.map +1 -1
  107. package/internal/controller/is-rtl.js +2 -2
  108. package/internal/controller/is-rtl.js.map +1 -1
  109. package/internal/controller/string-converter.js +1 -1
  110. package/internal/controller/string-converter.js.map +1 -1
  111. package/internal/motion/animation.js.map +1 -1
  112. package/labs/behaviors/element-internals.d.ts +45 -0
  113. package/labs/behaviors/element-internals.js +50 -0
  114. package/labs/behaviors/element-internals.js.map +1 -0
  115. package/labs/behaviors/focusable.d.ts +39 -0
  116. package/labs/behaviors/focusable.js +82 -0
  117. package/labs/behaviors/focusable.js.map +1 -0
  118. package/labs/behaviors/form-associated.d.ts +199 -0
  119. package/labs/behaviors/form-associated.js +155 -0
  120. package/labs/behaviors/form-associated.js.map +1 -0
  121. package/labs/behaviors/mixin.d.ts +54 -0
  122. package/labs/behaviors/mixin.js +7 -0
  123. package/labs/behaviors/mixin.js.map +1 -0
  124. package/labs/card/_elevated-card.scss +6 -0
  125. package/labs/card/_filled-card.scss +6 -0
  126. package/labs/card/_outlined-card.scss +6 -0
  127. package/labs/card/elevated-card.d.ts +18 -0
  128. package/labs/card/elevated-card.js +21 -0
  129. package/labs/card/elevated-card.js.map +1 -0
  130. package/labs/card/filled-card.d.ts +18 -0
  131. package/labs/card/filled-card.js +21 -0
  132. package/labs/card/filled-card.js.map +1 -0
  133. package/labs/card/internal/_elevated-card.scss +35 -0
  134. package/labs/card/internal/_filled-card.scss +35 -0
  135. package/labs/card/internal/_outlined-card.scss +39 -0
  136. package/labs/card/internal/_shared.scss +40 -0
  137. package/labs/card/internal/card.d.ts +13 -0
  138. package/labs/card/internal/card.js +20 -0
  139. package/labs/card/internal/card.js.map +1 -0
  140. package/labs/card/internal/elevated-styles.css.js +9 -0
  141. package/labs/card/internal/elevated-styles.css.js.map +1 -0
  142. package/labs/card/internal/elevated-styles.scss +10 -0
  143. package/labs/card/internal/filled-styles.css.js +9 -0
  144. package/labs/card/internal/filled-styles.css.js.map +1 -0
  145. package/labs/card/internal/filled-styles.scss +10 -0
  146. package/labs/card/internal/outlined-styles.css.js +9 -0
  147. package/labs/card/internal/outlined-styles.css.js.map +1 -0
  148. package/labs/card/internal/outlined-styles.scss +10 -0
  149. package/labs/card/internal/shared-styles.css.js +9 -0
  150. package/labs/card/internal/shared-styles.css.js.map +1 -0
  151. package/labs/card/internal/shared-styles.scss +10 -0
  152. package/labs/card/outlined-card.d.ts +18 -0
  153. package/labs/card/outlined-card.js +21 -0
  154. package/labs/card/outlined-card.js.map +1 -0
  155. package/labs/item/internal/item.js +8 -8
  156. package/labs/item/internal/item.js.map +1 -1
  157. package/labs/navigationbar/internal/constants.js.map +1 -1
  158. package/labs/navigationbar/internal/navigation-bar.d.ts +3 -0
  159. package/labs/navigationbar/internal/navigation-bar.js +18 -11
  160. package/labs/navigationbar/internal/navigation-bar.js.map +1 -1
  161. package/labs/navigationdrawer/internal/navigation-drawer-modal.d.ts +3 -0
  162. package/labs/navigationdrawer/internal/navigation-drawer-modal.js +10 -3
  163. package/labs/navigationdrawer/internal/navigation-drawer-modal.js.map +1 -1
  164. package/labs/navigationdrawer/internal/navigation-drawer.d.ts +3 -0
  165. package/labs/navigationdrawer/internal/navigation-drawer.js +8 -1
  166. package/labs/navigationdrawer/internal/navigation-drawer.js.map +1 -1
  167. package/labs/navigationtab/harness.js.map +1 -1
  168. package/labs/navigationtab/internal/navigation-tab.d.ts +6 -0
  169. package/labs/navigationtab/internal/navigation-tab.js +43 -27
  170. package/labs/navigationtab/internal/navigation-tab.js.map +1 -1
  171. package/labs/navigationtab/internal/state.js.map +1 -1
  172. package/labs/segmentedbutton/internal/segmented-button.d.ts +3 -0
  173. package/labs/segmentedbutton/internal/segmented-button.js +26 -12
  174. package/labs/segmentedbutton/internal/segmented-button.js.map +1 -1
  175. package/labs/segmentedbuttonset/internal/segmented-button-set.d.ts +5 -0
  176. package/labs/segmentedbuttonset/internal/segmented-button-set.js +14 -9
  177. package/labs/segmentedbuttonset/internal/segmented-button-set.js.map +1 -1
  178. package/list/harness.d.ts +1 -1
  179. package/list/harness.js.map +1 -1
  180. package/list/internal/list-controller.d.ts +1 -1
  181. package/list/internal/list-controller.js +7 -3
  182. package/list/internal/list-controller.js.map +1 -1
  183. package/list/internal/list-navigation-helpers.js.map +1 -1
  184. package/list/internal/list.d.ts +2 -2
  185. package/list/internal/list.js +8 -6
  186. package/list/internal/list.js.map +1 -1
  187. package/list/internal/listitem/harness.d.ts +1 -1
  188. package/list/internal/listitem/harness.js.map +1 -1
  189. package/list/internal/listitem/list-item.d.ts +3 -2
  190. package/list/internal/listitem/list-item.js +19 -20
  191. package/list/internal/listitem/list-item.js.map +1 -1
  192. package/list/list-item.d.ts +4 -12
  193. package/list/list-item.js +4 -12
  194. package/list/list-item.js.map +1 -1
  195. package/menu/harness.js.map +1 -1
  196. package/menu/internal/_menu.scss +12 -1
  197. package/menu/internal/controllers/menuItemController.js +9 -4
  198. package/menu/internal/controllers/menuItemController.js.map +1 -1
  199. package/menu/internal/controllers/shared.d.ts +9 -1
  200. package/menu/internal/controllers/shared.js +4 -4
  201. package/menu/internal/controllers/shared.js.map +1 -1
  202. package/menu/internal/controllers/surfacePositionController.d.ts +15 -2
  203. package/menu/internal/controllers/surfacePositionController.js +124 -54
  204. package/menu/internal/controllers/surfacePositionController.js.map +1 -1
  205. package/menu/internal/controllers/typeaheadController.js +19 -14
  206. package/menu/internal/controllers/typeaheadController.js.map +1 -1
  207. package/menu/internal/menu-styles.css.js +1 -1
  208. package/menu/internal/menu-styles.css.js.map +1 -1
  209. package/menu/internal/menu.d.ts +43 -12
  210. package/menu/internal/menu.js +124 -57
  211. package/menu/internal/menu.js.map +1 -1
  212. package/menu/internal/menuitem/harness.js.map +1 -1
  213. package/menu/internal/menuitem/menu-item.d.ts +3 -2
  214. package/menu/internal/menuitem/menu-item.js +18 -19
  215. package/menu/internal/menuitem/menu-item.js.map +1 -1
  216. package/menu/internal/submenu/sub-menu.d.ts +8 -8
  217. package/menu/internal/submenu/sub-menu.js +31 -22
  218. package/menu/internal/submenu/sub-menu.js.map +1 -1
  219. package/menu/internal/types.js.map +1 -1
  220. package/package.json +1 -1
  221. package/progress/internal/_circular-progress.scss +2 -2
  222. package/progress/internal/_linear-progress.scss +1 -1
  223. package/progress/internal/circular-progress-styles.css.js +1 -1
  224. package/progress/internal/circular-progress-styles.css.js.map +1 -1
  225. package/progress/internal/circular-progress.js +11 -10
  226. package/progress/internal/circular-progress.js.map +1 -1
  227. package/progress/internal/linear-progress-styles.css.js +1 -1
  228. package/progress/internal/linear-progress-styles.css.js.map +1 -1
  229. package/progress/internal/linear-progress.d.ts +1 -1
  230. package/progress/internal/linear-progress.js +3 -3
  231. package/progress/internal/linear-progress.js.map +1 -1
  232. package/progress/internal/progress.js +4 -2
  233. package/progress/internal/progress.js.map +1 -1
  234. package/radio/internal/radio.d.ts +11 -27
  235. package/radio/internal/radio.js +30 -54
  236. package/radio/internal/radio.js.map +1 -1
  237. package/radio/internal/single-selection-controller.js +1 -1
  238. package/radio/internal/single-selection-controller.js.map +1 -1
  239. package/ripple/internal/ripple.js +14 -9
  240. package/ripple/internal/ripple.js.map +1 -1
  241. package/select/filled-select.js +1 -2
  242. package/select/filled-select.js.map +1 -1
  243. package/select/harness.js +1 -1
  244. package/select/harness.js.map +1 -1
  245. package/select/internal/select.d.ts +25 -34
  246. package/select/internal/select.js +101 -91
  247. package/select/internal/select.js.map +1 -1
  248. package/select/internal/selectoption/select-option.d.ts +8 -6
  249. package/select/internal/selectoption/select-option.js +23 -22
  250. package/select/internal/selectoption/select-option.js.map +1 -1
  251. package/select/internal/selectoption/selectOptionController.js +1 -1
  252. package/select/internal/selectoption/selectOptionController.js.map +1 -1
  253. package/select/outlined-select.js +1 -2
  254. package/select/outlined-select.js.map +1 -1
  255. package/slider/harness.js +5 -5
  256. package/slider/harness.js.map +1 -1
  257. package/slider/internal/slider.d.ts +16 -25
  258. package/slider/internal/slider.js +110 -114
  259. package/slider/internal/slider.js.map +1 -1
  260. package/switch/internal/switch.d.ts +9 -25
  261. package/switch/internal/switch.js +31 -57
  262. package/switch/internal/switch.js.map +1 -1
  263. package/tabs/harness.js +3 -3
  264. package/tabs/harness.js.map +1 -1
  265. package/tabs/internal/_tab.scss +27 -35
  266. package/tabs/internal/primary-tab.d.ts +0 -2
  267. package/tabs/internal/tab-styles.css.js +1 -1
  268. package/tabs/internal/tab-styles.css.js.map +1 -1
  269. package/tabs/internal/tab.d.ts +4 -5
  270. package/tabs/internal/tab.js +34 -22
  271. package/tabs/internal/tab.js.map +1 -1
  272. package/tabs/internal/tabs.d.ts +6 -2
  273. package/tabs/internal/tabs.js +18 -11
  274. package/tabs/internal/tabs.js.map +1 -1
  275. package/textfield/filled-text-field.js +1 -2
  276. package/textfield/filled-text-field.js.map +1 -1
  277. package/textfield/harness.js +3 -2
  278. package/textfield/harness.js.map +1 -1
  279. package/textfield/internal/text-field.d.ts +26 -18
  280. package/textfield/internal/text-field.js +81 -58
  281. package/textfield/internal/text-field.js.map +1 -1
  282. package/textfield/outlined-text-field.js +1 -2
  283. package/textfield/outlined-text-field.js.map +1 -1
  284. package/tokens/_index.scss +3 -0
  285. package/tokens/_md-comp-elevated-card.scss +63 -0
  286. package/tokens/_md-comp-filled-card.scss +63 -0
  287. package/tokens/_md-comp-icon.scss +2 -0
  288. package/tokens/_md-comp-outlined-card.scss +69 -0
  289. package/tokens/_md-comp-test-table.scss +1 -0
  290. package/internal/controller/element-internals.d.ts +0 -35
  291. package/internal/controller/element-internals.js +0 -24
  292. package/internal/controller/element-internals.js.map +0 -1
  293. package/select/internal/filled-forced-colors-styles.css.js +0 -9
  294. package/select/internal/filled-forced-colors-styles.css.js.map +0 -1
  295. package/select/internal/filled-forced-colors-styles.scss +0 -29
  296. package/select/internal/outlined-forced-colors-styles.css.js +0 -9
  297. package/select/internal/outlined-forced-colors-styles.css.js.map +0 -1
  298. package/select/internal/outlined-forced-colors-styles.scss +0 -29
  299. package/textfield/internal/filled-forced-colors-styles.css.js +0 -9
  300. package/textfield/internal/filled-forced-colors-styles.css.js.map +0 -1
  301. package/textfield/internal/filled-forced-colors-styles.scss +0 -29
  302. package/textfield/internal/outlined-forced-colors-styles.css.js +0 -9
  303. package/textfield/internal/outlined-forced-colors-styles.css.js.map +0 -1
  304. package/textfield/internal/outlined-forced-colors-styles.scss +0 -29
  305. /package/{select/internal/filled-forced-colors-styles.css.d.ts → labs/card/internal/elevated-styles.css.d.ts} +0 -0
  306. /package/{select/internal/outlined-forced-colors-styles.css.d.ts → labs/card/internal/filled-styles.css.d.ts} +0 -0
  307. /package/{textfield/internal/filled-forced-colors-styles.css.d.ts → labs/card/internal/outlined-styles.css.d.ts} +0 -0
  308. /package/{textfield/internal/outlined-forced-colors-styles.css.d.ts → labs/card/internal/shared-styles.css.d.ts} +0 -0
@@ -38,320 +38,334 @@ $_md-sys-motion: tokens.md-sys-motion-values();
38
38
  @mixin styles() {
39
39
  $tokens: tokens.md-comp-outlined-field-values();
40
40
 
41
- :host {
42
- @each $token, $value in $tokens {
43
- --_#{$token}: var(--md-outlined-field-#{$token}, #{$value});
41
+ @layer styles {
42
+ :host {
43
+ @each $token, $value in $tokens {
44
+ --_#{$token}: var(--md-outlined-field-#{$token}, #{$value});
45
+ }
46
+
47
+ // Support logical shape properties
48
+ --_container-shape-start-start: var(
49
+ --md-outlined-field-container-shape-start-start,
50
+ var(--_container-shape)
51
+ );
52
+ --_container-shape-start-end: var(
53
+ --md-outlined-field-container-shape-start-end,
54
+ var(--_container-shape)
55
+ );
56
+ --_container-shape-end-end: var(
57
+ --md-outlined-field-container-shape-end-end,
58
+ var(--_container-shape)
59
+ );
60
+ --_container-shape-end-start: var(
61
+ --md-outlined-field-container-shape-end-start,
62
+ var(--_container-shape)
63
+ );
44
64
  }
45
65
 
46
- // Support logical shape properties
47
- --_container-shape-start-start: var(
48
- --md-outlined-field-container-shape-start-start,
49
- var(--_container-shape)
50
- );
51
- --_container-shape-start-end: var(
52
- --md-outlined-field-container-shape-start-end,
53
- var(--_container-shape)
54
- );
55
- --_container-shape-end-end: var(
56
- --md-outlined-field-container-shape-end-end,
57
- var(--_container-shape)
58
- );
59
- --_container-shape-end-start: var(
60
- --md-outlined-field-container-shape-end-start,
61
- var(--_container-shape)
62
- );
63
- }
66
+ .outline {
67
+ border-color: var(--_outline-color);
68
+ border-radius: inherit;
69
+ display: flex;
70
+ // Allow events to target elements underneath the outline, such as icons.
71
+ pointer-events: none;
72
+ height: 100%;
73
+ position: absolute;
74
+ width: 100%;
75
+ z-index: 1;
76
+ }
64
77
 
65
- .outline {
66
- border-color: var(--_outline-color);
67
- border-radius: inherit;
68
- color: var(--_outline-color); // Needed for Firefox HCM
69
- display: flex;
70
- // Allow events to target elements underneath the outline, such as icons.
71
- pointer-events: none;
72
- height: 100%;
73
- position: absolute;
74
- width: 100%;
75
- z-index: 1;
76
- }
78
+ .outline-start,
79
+ .outline-panel-inactive,
80
+ .outline-panel-active,
81
+ .outline-end {
82
+ // ::before is inactive border, ::after is active border. Borders are
83
+ // absolutely positioned within their elements.
84
+ &::before,
85
+ &::after {
86
+ border: inherit;
87
+ content: '';
88
+ inset: 0;
89
+ position: absolute;
90
+ }
91
+ }
77
92
 
78
- .outline-start,
79
- .outline-panel-inactive,
80
- .outline-panel-active,
81
- .outline-end {
82
- // ::before is inactive border, ::after is active border. Borders are
83
- // absolutely positioned within their elements.
84
- &::before,
85
- &::after {
93
+ .outline-start,
94
+ .outline-end {
86
95
  border: inherit;
87
- content: '';
88
- inset: 0;
89
- position: absolute;
96
+ border-radius: inherit;
97
+ box-sizing: border-box;
98
+ position: relative;
99
+
100
+ &::before,
101
+ &::after {
102
+ border-bottom-style: solid;
103
+ border-top-style: solid;
104
+ }
105
+
106
+ &::after {
107
+ opacity: 0;
108
+ transition: opacity map.get($_md-sys-motion, 'duration-short3')
109
+ map.get($_md-sys-motion, 'easing-emphasized');
110
+ }
90
111
  }
91
- }
92
-
93
- .outline-start,
94
- .outline-end {
95
- border: inherit;
96
- border-radius: inherit;
97
- box-sizing: border-box;
98
- position: relative;
99
112
 
100
- &::before,
101
- &::after {
102
- border-bottom-style: solid;
103
- border-top-style: solid;
113
+ .focused .outline-start::after,
114
+ .focused .outline-end::after {
115
+ opacity: 1;
104
116
  }
105
117
 
106
- &::after {
107
- opacity: 0;
108
- transition: opacity map.get($_md-sys-motion, 'duration-short3')
109
- map.get($_md-sys-motion, 'easing-emphasized');
118
+ .outline-start {
119
+ &::before,
120
+ &::after {
121
+ border-inline-start-style: solid;
122
+ border-inline-end-style: none;
123
+ border-start-start-radius: inherit;
124
+ border-start-end-radius: 0;
125
+ border-end-start-radius: inherit;
126
+ border-end-end-radius: 0;
127
+ margin-inline-end: var(--_outline-label-padding);
128
+ }
110
129
  }
111
- }
112
130
 
113
- .focused .outline-start::after,
114
- .focused .outline-end::after {
115
- opacity: 1;
116
- }
131
+ .outline-end {
132
+ flex-grow: 1;
133
+ margin-inline-start: calc(-1 * var(--_outline-label-padding));
134
+
135
+ &::before,
136
+ &::after {
137
+ border-inline-start-style: none;
138
+ border-inline-end-style: solid;
139
+ border-start-start-radius: 0;
140
+ border-start-end-radius: inherit;
141
+ border-end-start-radius: 0;
142
+ border-end-end-radius: inherit;
143
+ }
144
+ }
117
145
 
118
- .outline-start {
119
- &::before,
120
- &::after {
121
- border-inline-start-style: solid;
122
- border-inline-end-style: none;
123
- border-start-start-radius: inherit;
124
- border-start-end-radius: 0;
125
- border-end-start-radius: inherit;
126
- border-end-end-radius: 0;
146
+ .outline-notch {
147
+ align-items: flex-start;
148
+ border: inherit;
149
+ display: flex;
150
+ margin-inline-start: calc(-1 * var(--_outline-label-padding));
127
151
  margin-inline-end: var(--_outline-label-padding);
152
+ max-width: calc(100% - var(--_leading-space) - var(--_trailing-space));
153
+ padding: 0 var(--_outline-label-padding);
154
+ position: relative;
128
155
  }
129
- }
130
-
131
- .outline-end {
132
- flex-grow: 1;
133
- margin-inline-start: calc(-1 * var(--_outline-label-padding));
134
156
 
135
- &::before,
136
- &::after {
137
- border-inline-start-style: none;
138
- border-inline-end-style: solid;
139
- border-start-start-radius: 0;
140
- border-start-end-radius: inherit;
141
- border-end-start-radius: 0;
142
- border-end-end-radius: inherit;
157
+ .no-label .outline-notch {
158
+ display: none;
143
159
  }
144
- }
145
-
146
- .outline-notch {
147
- align-items: flex-start;
148
- border: inherit;
149
- display: flex;
150
- margin-inline-start: calc(-1 * var(--_outline-label-padding));
151
- margin-inline-end: var(--_outline-label-padding);
152
- max-width: calc(100% - var(--_leading-space) - var(--_trailing-space));
153
- padding: 0 var(--_outline-label-padding);
154
- position: relative;
155
- }
156
160
 
157
- .no-label .outline-notch {
158
- display: none;
159
- }
161
+ .outline-panel-inactive,
162
+ .outline-panel-active {
163
+ border: inherit;
164
+ border-bottom-style: solid;
165
+ inset: 0;
166
+ position: absolute;
160
167
 
161
- .outline-panel-inactive,
162
- .outline-panel-active {
163
- border: inherit;
164
- border-bottom-style: solid;
165
- inset: 0;
166
- position: absolute;
167
-
168
- &::before,
169
- &::after {
170
- border-top-style: solid;
171
- border-bottom: none;
172
- bottom: auto;
173
- transform: scaleX(1);
174
- transition: transform map.get($_md-sys-motion, 'duration-short3')
175
- map.get($_md-sys-motion, 'easing-emphasized');
168
+ &::before,
169
+ &::after {
170
+ border-top-style: solid;
171
+ border-bottom: none;
172
+ bottom: auto;
173
+ transform: scaleX(1);
174
+ transition: transform map.get($_md-sys-motion, 'duration-short3')
175
+ map.get($_md-sys-motion, 'easing-emphasized');
176
+ }
177
+
178
+ // Note: no need to do any RTL flipping here. If RTLCSS flips this, it's also
179
+ // ok, we just need one to be left and one to be right.
180
+ &::before {
181
+ right: 50%;
182
+ transform-origin: top left;
183
+ }
184
+
185
+ &::after {
186
+ left: 50%;
187
+ transform-origin: top right;
188
+ }
176
189
  }
177
190
 
178
- // Note: no need to do any RTL flipping here. If RTLCSS flips this, it's also
179
- // ok, we just need one to be left and one to be right.
180
- &::before {
181
- right: 50%;
182
- transform-origin: top left;
191
+ .populated .outline-panel-inactive,
192
+ .populated .outline-panel-active,
193
+ .focused .outline-panel-inactive,
194
+ .focused .outline-panel-active {
195
+ &::before,
196
+ &::after {
197
+ transform: scaleX(0);
198
+ }
183
199
  }
184
200
 
185
- &::after {
186
- left: 50%;
187
- transform-origin: top right;
201
+ .outline-panel-active {
202
+ opacity: 0;
203
+ transition: opacity map.get($_md-sys-motion, 'duration-short3')
204
+ map.get($_md-sys-motion, 'easing-emphasized');
188
205
  }
189
- }
190
206
 
191
- .populated .outline-panel-inactive,
192
- .populated .outline-panel-active,
193
- .focused .outline-panel-inactive,
194
- .focused .outline-panel-active {
195
- &::before,
196
- &::after {
197
- transform: scaleX(0);
207
+ .focused .outline-panel-active {
208
+ opacity: 1;
198
209
  }
199
- }
200
-
201
- .outline-panel-active {
202
- opacity: 0;
203
- transition: opacity map.get($_md-sys-motion, 'duration-short3')
204
- map.get($_md-sys-motion, 'easing-emphasized');
205
- }
206
210
 
207
- .focused .outline-panel-active {
208
- opacity: 1;
209
- }
211
+ .outline-label {
212
+ display: flex;
213
+ max-width: 100%;
214
+ // Center the floating label within the outline stroke
215
+ transform: translateY(calc(-100% + var(--_label-text-padding-bottom)));
216
+ }
210
217
 
211
- .outline-label {
212
- display: flex;
213
- max-width: 100%;
214
- // Center the floating label within the outline stroke
215
- transform: translateY(calc(-100% + var(--_label-text-padding-bottom)));
216
- }
218
+ // Add padding that will grow to compensate for the outline's shape.
219
+ // This is needed to prevent the outline border from clipping with the label
220
+ // and is mirrored in the container padding to align the content and resting
221
+ // label with the adjusted floating label.
222
+ $shape-start: max(
223
+ var(--_container-shape-start-start),
224
+ var(--_container-shape-end-start)
225
+ );
226
+ $shape-end: max(
227
+ var(--_container-shape-start-end),
228
+ var(--_container-shape-end-end)
229
+ );
230
+ $start-space: max(
231
+ var(--_leading-space),
232
+ $shape-start + var(--_outline-label-padding)
233
+ );
234
+ $end-space: max(var(--_trailing-space), $shape-end);
217
235
 
218
- // Add padding that will grow to compensate for the outline's shape.
219
- // This is needed to prevent the outline border from clipping with the label
220
- // and is mirrored in the container padding to align the content and resting
221
- // label with the adjusted floating label.
222
- $shape-start: max(
223
- var(--_container-shape-start-start),
224
- var(--_container-shape-end-start)
225
- );
226
- $shape-end: max(
227
- var(--_container-shape-start-end),
228
- var(--_container-shape-end-end)
229
- );
230
- $start-space: max(
231
- var(--_leading-space),
232
- $shape-start + var(--_outline-label-padding)
233
- );
234
- $end-space: max(var(--_trailing-space), $shape-end);
236
+ .outline-start,
237
+ .field:not(.with-start) .content ::slotted(*) {
238
+ padding-inline-start: $start-space;
239
+ }
235
240
 
236
- .outline-start,
237
- .field:not(.with-start) .content ::slotted(*) {
238
- padding-inline-start: $start-space;
239
- }
241
+ .field:not(.with-start) .label-wrapper {
242
+ margin-inline-start: $start-space;
243
+ }
240
244
 
241
- .field:not(.with-start) .label-wrapper {
242
- margin-inline-start: $start-space;
243
- }
245
+ .field:not(.with-end) .content ::slotted(*) {
246
+ padding-inline-end: $end-space;
247
+ }
244
248
 
245
- .field:not(.with-end) .content ::slotted(*) {
246
- padding-inline-end: $end-space;
247
- }
249
+ .field:not(.with-end) .label-wrapper {
250
+ margin-inline-end: $end-space;
251
+ }
248
252
 
249
- .field:not(.with-end) .label-wrapper {
250
- margin-inline-end: $end-space;
251
- }
253
+ .outline-start::before,
254
+ .outline-end::before,
255
+ .outline-panel-inactive,
256
+ .outline-panel-inactive::before,
257
+ .outline-panel-inactive::after {
258
+ border-width: var(--_outline-width);
259
+ }
252
260
 
253
- .outline-start::before,
254
- .outline-end::before,
255
- .outline-panel-inactive,
256
- .outline-panel-inactive::before,
257
- .outline-panel-inactive::after {
258
- border-width: var(--_outline-width);
259
- }
261
+ // States
260
262
 
261
- // States
263
+ :hover .outline {
264
+ border-color: var(--_hover-outline-color);
265
+ color: var(--_hover-outline-color); // Needed for Firefox HCM
266
+ }
262
267
 
263
- :hover .outline {
264
- border-color: var(--_hover-outline-color);
265
- color: var(--_hover-outline-color); // Needed for Firefox HCM
266
- }
268
+ :hover .outline-start::before,
269
+ :hover .outline-end::before,
270
+ :hover .outline-panel-inactive,
271
+ :hover .outline-panel-inactive::before,
272
+ :hover .outline-panel-inactive::after {
273
+ border-width: var(--_hover-outline-width);
274
+ }
267
275
 
268
- :hover .outline-start::before,
269
- :hover .outline-end::before,
270
- :hover .outline-panel-inactive,
271
- :hover .outline-panel-inactive::before,
272
- :hover .outline-panel-inactive::after {
273
- border-width: var(--_hover-outline-width);
274
- }
276
+ .focused .outline {
277
+ border-color: var(--_focus-outline-color);
278
+ color: var(--_focus-outline-color); // Needed for Firefox HCM
279
+ }
275
280
 
276
- .focused .outline {
277
- border-color: var(--_focus-outline-color);
278
- color: var(--_focus-outline-color); // Needed for Firefox HCM
279
- }
281
+ .outline-start::after,
282
+ .outline-end::after,
283
+ .outline-panel-active,
284
+ .outline-panel-active::before,
285
+ .outline-panel-active::after {
286
+ border-width: var(--_focus-outline-width);
287
+ }
280
288
 
281
- .outline-start::after,
282
- .outline-end::after,
283
- .outline-panel-active,
284
- .outline-panel-active::before,
285
- .outline-panel-active::after {
286
- border-width: var(--_focus-outline-width);
287
- }
289
+ .disabled .outline {
290
+ border-color: var(--_disabled-outline-color);
291
+ color: var(--_disabled-outline-color); // Needed for Firefox HCM
292
+ }
288
293
 
289
- .disabled .outline {
290
- border-color: var(--_disabled-outline-color);
291
- color: var(--_disabled-outline-color); // Needed for Firefox HCM
292
- }
294
+ .disabled .outline-start,
295
+ .disabled .outline-end,
296
+ .disabled .outline-panel-inactive {
297
+ opacity: var(--_disabled-outline-opacity);
298
+ }
293
299
 
294
- .disabled .outline-start,
295
- .disabled .outline-end,
296
- .disabled .outline-panel-inactive {
297
- opacity: var(--_disabled-outline-opacity);
298
- }
300
+ .disabled .outline-start::before,
301
+ .disabled .outline-end::before,
302
+ .disabled .outline-panel-inactive,
303
+ .disabled .outline-panel-inactive::before,
304
+ .disabled .outline-panel-inactive::after {
305
+ border-width: var(--_disabled-outline-width);
306
+ }
299
307
 
300
- .disabled .outline-start::before,
301
- .disabled .outline-end::before,
302
- .disabled .outline-panel-inactive,
303
- .disabled .outline-panel-inactive::before,
304
- .disabled .outline-panel-inactive::after {
305
- border-width: var(--_disabled-outline-width);
306
- }
308
+ .error .outline {
309
+ border-color: var(--_error-outline-color);
310
+ color: var(--_error-outline-color); // Needed for Firefox HCM
311
+ }
307
312
 
308
- .error .outline {
309
- border-color: var(--_error-outline-color);
310
- color: var(--_error-outline-color); // Needed for Firefox HCM
311
- }
313
+ .error:hover .outline {
314
+ border-color: var(--_error-hover-outline-color);
315
+ // Needed for Firefox HCM
316
+ color: var(--_error-hover-outline-color);
317
+ }
312
318
 
313
- .error:hover .outline {
314
- border-color: var(--_error-hover-outline-color);
315
- // Needed for Firefox HCM
316
- color: var(--_error-hover-outline-color);
317
- }
319
+ .error.focused .outline {
320
+ border-color: var(--_error-focus-outline-color);
321
+ // Needed for Firefox HCM
322
+ color: var(--_error-focus-outline-color);
323
+ }
318
324
 
319
- .error.focused .outline {
320
- border-color: var(--_error-focus-outline-color);
321
- // Needed for Firefox HCM
322
- color: var(--_error-focus-outline-color);
323
- }
325
+ // Move the container up and to the left so that the resize handle doesn't
326
+ // overlap the focus outline. Content is moved back the opposite direction.
327
+ .resizable .container {
328
+ bottom: var(--_focus-outline-width);
329
+ inset-inline-end: var(--_focus-outline-width);
330
+ // Ensures the container doesn't create an overhang that can be clicked on.
331
+ clip-path: inset(
332
+ var(--_focus-outline-width) 0 0 var(--_focus-outline-width)
333
+ );
334
+ }
324
335
 
325
- // Move the container up and to the left so that the resize handle doesn't
326
- // overlap the focus outline. Content is moved back the opposite direction.
327
- .resizable .container {
328
- bottom: var(--_focus-outline-width);
329
- inset-inline-end: var(--_focus-outline-width);
330
- // Ensures the container doesn't create an overhang that can be clicked on.
331
- clip-path: inset(
332
- var(--_focus-outline-width) 0 0 var(--_focus-outline-width)
333
- );
334
- }
336
+ .resizable .container > * {
337
+ top: var(--_focus-outline-width);
338
+ inset-inline-start: var(--_focus-outline-width);
339
+ }
335
340
 
336
- .resizable .container > * {
337
- top: var(--_focus-outline-width);
338
- inset-inline-start: var(--_focus-outline-width);
339
- }
341
+ // TODO(https://bugs.chromium.org/p/chromium/issues/detail?id=1420655):
342
+ // remove :host and :host-context once Chrome supports :dir
343
+ :host-context([dir='rtl']),
344
+ :host([dir='rtl']) {
345
+ .resizable .container {
346
+ clip-path: inset(
347
+ var(--_focus-outline-width) var(--_focus-outline-width) 0 0
348
+ );
349
+ }
350
+ }
340
351
 
341
- // TODO(https://bugs.chromium.org/p/chromium/issues/detail?id=1420655):
342
- // remove :host and :host-context once Chrome supports :dir
343
- :host-context([dir='rtl']),
344
- :host([dir='rtl']) {
345
- .resizable .container {
352
+ .resizable .container:dir(rtl) {
346
353
  clip-path: inset(
347
354
  var(--_focus-outline-width) var(--_focus-outline-width) 0 0
348
355
  );
349
356
  }
350
357
  }
351
358
 
352
- .resizable .container:dir(rtl) {
353
- clip-path: inset(
354
- var(--_focus-outline-width) var(--_focus-outline-width) 0 0
355
- );
359
+ @layer hcm {
360
+ @media (forced-colors: active) {
361
+ .disabled .outline {
362
+ border-color: GrayText;
363
+ color: GrayText; // Needed for Firefox HCM
364
+ }
365
+
366
+ .disabled :is(.outline-start, .outline-end, .outline-panel-inactive) {
367
+ opacity: 1;
368
+ }
369
+ }
356
370
  }
357
371
  }