@wordpress/components 32.4.1-next.v.202603161435.0 → 32.5.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 (209) hide show
  1. package/CHANGELOG.md +18 -1
  2. package/build/alignment-matrix-control/cell.cjs +2 -2
  3. package/build/alignment-matrix-control/cell.cjs.map +1 -1
  4. package/build/alignment-matrix-control/index.cjs +2 -2
  5. package/build/alignment-matrix-control/index.cjs.map +1 -1
  6. package/build/angle-picker-control/angle-circle.cjs +2 -2
  7. package/build/angle-picker-control/angle-circle.cjs.map +1 -1
  8. package/build/combobox-control/index.cjs +5 -1
  9. package/build/combobox-control/index.cjs.map +2 -2
  10. package/build/custom-gradient-picker/index.cjs +9 -1
  11. package/build/custom-gradient-picker/index.cjs.map +2 -2
  12. package/build/form-token-field/token-input.cjs +2 -1
  13. package/build/form-token-field/token-input.cjs.map +2 -2
  14. package/build/radio-control/index.cjs +1 -0
  15. package/build/radio-control/index.cjs.map +2 -2
  16. package/build/toggle-group-control/toggle-group-control/as-button-group.cjs +1 -0
  17. package/build/toggle-group-control/toggle-group-control/as-button-group.cjs.map +2 -2
  18. package/build/toggle-group-control/toggle-group-control/component.cjs +15 -9
  19. package/build/toggle-group-control/toggle-group-control/component.cjs.map +3 -3
  20. package/build/toggle-group-control/toggle-group-control/styles.cjs +6 -32
  21. package/build/toggle-group-control/toggle-group-control/styles.cjs.map +3 -3
  22. package/build/validated-form-controls/control-with-error.cjs +26 -3
  23. package/build/validated-form-controls/control-with-error.cjs.map +2 -2
  24. package/build/validated-form-controls/validity-indicator.cjs +2 -0
  25. package/build/validated-form-controls/validity-indicator.cjs.map +2 -2
  26. package/build-module/alignment-matrix-control/cell.mjs +2 -2
  27. package/build-module/alignment-matrix-control/cell.mjs.map +1 -1
  28. package/build-module/alignment-matrix-control/index.mjs +2 -2
  29. package/build-module/alignment-matrix-control/index.mjs.map +1 -1
  30. package/build-module/angle-picker-control/angle-circle.mjs +2 -2
  31. package/build-module/angle-picker-control/angle-circle.mjs.map +1 -1
  32. package/build-module/combobox-control/index.mjs +5 -1
  33. package/build-module/combobox-control/index.mjs.map +2 -2
  34. package/build-module/custom-gradient-picker/index.mjs +10 -2
  35. package/build-module/custom-gradient-picker/index.mjs.map +2 -2
  36. package/build-module/form-token-field/token-input.mjs +2 -1
  37. package/build-module/form-token-field/token-input.mjs.map +2 -2
  38. package/build-module/radio-control/index.mjs +1 -0
  39. package/build-module/radio-control/index.mjs.map +2 -2
  40. package/build-module/toggle-group-control/toggle-group-control/as-button-group.mjs +1 -0
  41. package/build-module/toggle-group-control/toggle-group-control/as-button-group.mjs.map +2 -2
  42. package/build-module/toggle-group-control/toggle-group-control/component.mjs +17 -11
  43. package/build-module/toggle-group-control/toggle-group-control/component.mjs.map +2 -2
  44. package/build-module/toggle-group-control/toggle-group-control/styles.mjs +6 -21
  45. package/build-module/toggle-group-control/toggle-group-control/styles.mjs.map +2 -2
  46. package/build-module/validated-form-controls/control-with-error.mjs +27 -4
  47. package/build-module/validated-form-controls/control-with-error.mjs.map +2 -2
  48. package/build-module/validated-form-controls/validity-indicator.mjs +2 -0
  49. package/build-module/validated-form-controls/validity-indicator.mjs.map +2 -2
  50. package/build-style/style-rtl.css +14 -11
  51. package/build-style/style.css +14 -11
  52. package/build-types/alignment-matrix-control/stories/index.story.d.ts +1 -1
  53. package/build-types/alignment-matrix-control/stories/index.story.d.ts.map +1 -1
  54. package/build-types/angle-picker-control/stories/index.story.d.ts +1 -1
  55. package/build-types/animate/stories/index.story.d.ts +7 -7
  56. package/build-types/animate/stories/index.story.d.ts.map +1 -1
  57. package/build-types/base-control/stories/index.story.d.ts +1 -1
  58. package/build-types/border-box-control/stories/index.story.d.ts +1 -1
  59. package/build-types/border-control/stories/index.story.d.ts +5 -5
  60. package/build-types/box-control/stories/index.story.d.ts +7 -7
  61. package/build-types/box-control/stories/index.story.d.ts.map +1 -1
  62. package/build-types/button/stories/e2e/index.story.d.ts +1 -1
  63. package/build-types/button/stories/e2e/index.story.d.ts.map +1 -1
  64. package/build-types/button/stories/index.story.d.ts +7 -7
  65. package/build-types/button/stories/index.story.d.ts.map +1 -1
  66. package/build-types/circular-option-picker/stories/index.story.d.ts +5 -5
  67. package/build-types/circular-option-picker/stories/index.story.d.ts.map +1 -1
  68. package/build-types/combobox-control/index.d.ts.map +1 -1
  69. package/build-types/combobox-control/stories/index.story.d.ts +4 -4
  70. package/build-types/combobox-control/stories/index.story.d.ts.map +1 -1
  71. package/build-types/confirm-dialog/stories/index.story.d.ts +2 -2
  72. package/build-types/confirm-dialog/stories/index.story.d.ts.map +1 -1
  73. package/build-types/custom-gradient-picker/index.d.ts.map +1 -1
  74. package/build-types/custom-gradient-picker/stories/index.story.d.ts +1 -1
  75. package/build-types/custom-gradient-picker/stories/index.story.d.ts.map +1 -1
  76. package/build-types/custom-gradient-picker/test/index.d.ts +2 -0
  77. package/build-types/custom-gradient-picker/test/index.d.ts.map +1 -0
  78. package/build-types/custom-select-control/stories/index.story.d.ts +3 -3
  79. package/build-types/custom-select-control/stories/index.story.d.ts.map +1 -1
  80. package/build-types/custom-select-control-v2/stories/index.story.d.ts +3 -3
  81. package/build-types/date-time/stories/time.story.d.ts +1 -1
  82. package/build-types/date-time/stories/time.story.d.ts.map +1 -1
  83. package/build-types/drop-zone/stories/index.story.d.ts +1 -1
  84. package/build-types/drop-zone/stories/index.story.d.ts.map +1 -1
  85. package/build-types/duotone-picker/stories/duotone-picker.story.d.ts +1 -1
  86. package/build-types/duotone-picker/stories/duotone-picker.story.d.ts.map +1 -1
  87. package/build-types/duotone-picker/stories/duotone-swatch.story.d.ts +3 -3
  88. package/build-types/duotone-picker/stories/duotone-swatch.story.d.ts.map +1 -1
  89. package/build-types/focal-point-picker/stories/index.story.d.ts +4 -4
  90. package/build-types/form-file-upload/stories/index.story.d.ts +5 -5
  91. package/build-types/form-file-upload/stories/index.story.d.ts.map +1 -1
  92. package/build-types/form-token-field/token-input.d.ts.map +1 -1
  93. package/build-types/guide/stories/index.story.d.ts +1 -1
  94. package/build-types/guide/stories/index.story.d.ts.map +1 -1
  95. package/build-types/icon/stories/index.story.d.ts +4 -4
  96. package/build-types/icon/stories/index.story.d.ts.map +1 -1
  97. package/build-types/input-control/stories/index.story.d.ts +7 -7
  98. package/build-types/input-control/stories/index.story.d.ts.map +1 -1
  99. package/build-types/keyboard-shortcuts/stories/index.story.d.ts +1 -1
  100. package/build-types/keyboard-shortcuts/stories/index.story.d.ts.map +1 -1
  101. package/build-types/menu-group/stories/index.story.d.ts +1 -1
  102. package/build-types/menu-group/stories/index.story.d.ts.map +1 -1
  103. package/build-types/menu-item/stories/index.story.d.ts +4 -4
  104. package/build-types/navigation/stories/index.story.d.ts +6 -6
  105. package/build-types/navigation/stories/index.story.d.ts.map +1 -1
  106. package/build-types/notice/stories/index.story.d.ts +5 -5
  107. package/build-types/notice/stories/index.story.d.ts.map +1 -1
  108. package/build-types/number-control/stories/index.story.d.ts +1 -1
  109. package/build-types/palette-edit/stories/index.story.d.ts +2 -2
  110. package/build-types/palette-edit/stories/index.story.d.ts.map +1 -1
  111. package/build-types/progress-bar/stories/index.story.d.ts +1 -1
  112. package/build-types/progress-bar/stories/index.story.d.ts.map +1 -1
  113. package/build-types/query-controls/stories/index.story.d.ts +1 -1
  114. package/build-types/query-controls/stories/index.story.d.ts.map +1 -1
  115. package/build-types/radio-control/index.d.ts.map +1 -1
  116. package/build-types/resizable-box/stories/index.story.d.ts +2 -2
  117. package/build-types/responsive-wrapper/stories/index.story.d.ts +1 -1
  118. package/build-types/responsive-wrapper/stories/index.story.d.ts.map +1 -1
  119. package/build-types/sandbox/stories/index.story.d.ts +1 -1
  120. package/build-types/sandbox/stories/index.story.d.ts.map +1 -1
  121. package/build-types/search-control/stories/index.story.d.ts +1 -1
  122. package/build-types/select-control/stories/index.story.d.ts +5 -5
  123. package/build-types/shortcut/stories/index.story.d.ts +1 -1
  124. package/build-types/shortcut/stories/index.story.d.ts.map +1 -1
  125. package/build-types/tab-panel/stories/index.story.d.ts +4 -4
  126. package/build-types/tab-panel/stories/index.story.d.ts.map +1 -1
  127. package/build-types/tabs/stories/index.story.d.ts +7 -7
  128. package/build-types/tabs/stories/index.story.d.ts.map +1 -1
  129. package/build-types/text/stories/index.story.d.ts +3 -3
  130. package/build-types/theme/stories/index.story.d.ts +1 -1
  131. package/build-types/toggle-control/stories/index.story.d.ts +2 -2
  132. package/build-types/toggle-group-control/stories/index.story.d.ts.map +1 -1
  133. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts.map +1 -1
  134. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  135. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +0 -4
  136. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  137. package/build-types/toolbar/stories/index.story.d.ts +3 -3
  138. package/build-types/toolbar/stories/index.story.d.ts.map +1 -1
  139. package/build-types/tooltip/stories/index.story.d.ts +1 -1
  140. package/build-types/tooltip/stories/index.story.d.ts.map +1 -1
  141. package/build-types/tree-grid/stories/index.story.d.ts +1 -1
  142. package/build-types/tree-grid/stories/index.story.d.ts.map +1 -1
  143. package/build-types/tree-select/stories/index.story.d.ts +1 -1
  144. package/build-types/tree-select/stories/index.story.d.ts.map +1 -1
  145. package/build-types/v-stack/stories/index.story.d.ts +1 -1
  146. package/build-types/validated-form-controls/control-with-error.d.ts.map +1 -1
  147. package/build-types/validated-form-controls/test/checkbox-control.d.ts +2 -0
  148. package/build-types/validated-form-controls/test/checkbox-control.d.ts.map +1 -0
  149. package/build-types/validated-form-controls/test/combobox-control.d.ts +2 -0
  150. package/build-types/validated-form-controls/test/combobox-control.d.ts.map +1 -0
  151. package/build-types/validated-form-controls/test/custom-select-control.d.ts +2 -0
  152. package/build-types/validated-form-controls/test/custom-select-control.d.ts.map +1 -0
  153. package/build-types/validated-form-controls/test/form-token-field.d.ts +2 -0
  154. package/build-types/validated-form-controls/test/form-token-field.d.ts.map +1 -0
  155. package/build-types/validated-form-controls/test/input-control.d.ts +2 -0
  156. package/build-types/validated-form-controls/test/input-control.d.ts.map +1 -0
  157. package/build-types/validated-form-controls/test/number-control.d.ts +2 -0
  158. package/build-types/validated-form-controls/test/number-control.d.ts.map +1 -0
  159. package/build-types/validated-form-controls/test/radio-control.d.ts +2 -0
  160. package/build-types/validated-form-controls/test/radio-control.d.ts.map +1 -0
  161. package/build-types/validated-form-controls/test/range-control.d.ts +2 -0
  162. package/build-types/validated-form-controls/test/range-control.d.ts.map +1 -0
  163. package/build-types/validated-form-controls/test/select-control.d.ts +2 -0
  164. package/build-types/validated-form-controls/test/select-control.d.ts.map +1 -0
  165. package/build-types/validated-form-controls/test/text-control.d.ts +2 -0
  166. package/build-types/validated-form-controls/test/text-control.d.ts.map +1 -0
  167. package/build-types/validated-form-controls/test/textarea-control.d.ts +2 -0
  168. package/build-types/validated-form-controls/test/textarea-control.d.ts.map +1 -0
  169. package/build-types/validated-form-controls/test/toggle-control.d.ts +2 -0
  170. package/build-types/validated-form-controls/test/toggle-control.d.ts.map +1 -0
  171. package/build-types/validated-form-controls/test/toggle-group-control.d.ts +2 -0
  172. package/build-types/validated-form-controls/test/toggle-group-control.d.ts.map +1 -0
  173. package/build-types/validated-form-controls/validity-indicator.d.ts +2 -1
  174. package/build-types/validated-form-controls/validity-indicator.d.ts.map +1 -1
  175. package/package.json +24 -24
  176. package/src/button/style.scss +16 -5
  177. package/src/combobox-control/index.tsx +6 -0
  178. package/src/combobox-control/stories/index.story.tsx +3 -2
  179. package/src/combobox-control/test/index.tsx +16 -9
  180. package/src/custom-gradient-picker/index.tsx +15 -4
  181. package/src/custom-gradient-picker/test/index.tsx +81 -0
  182. package/src/form-token-field/token-input.tsx +7 -1
  183. package/src/guide/style.scss +3 -0
  184. package/src/modal/style.scss +4 -7
  185. package/src/radio-control/index.tsx +1 -0
  186. package/src/radio-control/test/index.tsx +5 -5
  187. package/src/snackbar/style.scss +1 -1
  188. package/src/toggle-group-control/stories/index.story.tsx +1 -0
  189. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +124 -164
  190. package/src/toggle-group-control/test/index.tsx +54 -0
  191. package/src/toggle-group-control/toggle-group-control/as-button-group.tsx +1 -0
  192. package/src/toggle-group-control/toggle-group-control/component.tsx +13 -8
  193. package/src/toggle-group-control/toggle-group-control/styles.ts +0 -6
  194. package/src/validated-form-controls/control-with-error.tsx +44 -4
  195. package/src/validated-form-controls/test/checkbox-control.tsx +49 -0
  196. package/src/validated-form-controls/test/combobox-control.tsx +61 -0
  197. package/src/validated-form-controls/test/control-with-error.tsx +182 -1
  198. package/src/validated-form-controls/test/custom-select-control.tsx +60 -0
  199. package/src/validated-form-controls/test/form-token-field.tsx +52 -0
  200. package/src/validated-form-controls/test/input-control.tsx +42 -0
  201. package/src/validated-form-controls/test/number-control.tsx +44 -0
  202. package/src/validated-form-controls/test/radio-control.tsx +61 -0
  203. package/src/validated-form-controls/test/range-control.tsx +73 -0
  204. package/src/validated-form-controls/test/select-control.tsx +57 -0
  205. package/src/validated-form-controls/test/text-control.tsx +49 -0
  206. package/src/validated-form-controls/test/textarea-control.tsx +51 -0
  207. package/src/validated-form-controls/test/toggle-control.tsx +49 -0
  208. package/src/validated-form-controls/test/toggle-group-control.tsx +28 -0
  209. package/src/validated-form-controls/validity-indicator.tsx +3 -0
@@ -28,6 +28,7 @@ export function UnForwardedTokenInput(
28
28
  onChange,
29
29
  onFocus,
30
30
  onBlur,
31
+ 'aria-describedby': ariaDescribedBy,
31
32
  ...restProps
32
33
  } = props;
33
34
 
@@ -86,7 +87,12 @@ export function UnForwardedTokenInput(
86
87
  ? `components-form-token-suggestions-${ instanceId }-${ selectedSuggestionIndex }`
87
88
  : undefined
88
89
  }
89
- aria-describedby={ `components-form-token-suggestions-howto-${ instanceId }` }
90
+ aria-describedby={ [
91
+ `components-form-token-suggestions-howto-${ instanceId }`,
92
+ ariaDescribedBy,
93
+ ]
94
+ .filter( Boolean )
95
+ .join( ' ' ) }
90
96
  />
91
97
  );
92
98
  }
@@ -6,9 +6,11 @@
6
6
 
7
7
  .components-guide {
8
8
  $image-height: 300px;
9
+ // TODO: Replace with a --wpds-dimension-surface-width-* token.
9
10
  $image-width: 320px;
10
11
 
11
12
  @include break-small() {
13
+ // TODO: Replace with a --wpds-dimension-surface-width-* token.
12
14
  width: 600px;
13
15
  }
14
16
 
@@ -86,6 +88,7 @@
86
88
 
87
89
  .components-modal__frame.components-guide {
88
90
  border: none;
91
+ // TODO: Replace with a --wpds-dimension-surface-width-* token.
89
92
  min-width: 312px;
90
93
  max-height: 575px;
91
94
 
@@ -65,7 +65,7 @@
65
65
  border-radius: $radius-large;
66
66
  margin: auto;
67
67
  width: auto;
68
- min-width: $modal-min-width;
68
+ min-width: var(--wpds-dimension-surface-width-sm);
69
69
  max-width: calc(100% - #{$grid-unit-20 * 2});
70
70
  max-height: calc(100% - #{$header-height * 2});
71
71
 
@@ -88,17 +88,14 @@
88
88
  width: 100%;
89
89
  }
90
90
 
91
- // The following widths were selected to align with existing baselines
92
- // found elsewhere in the editor.
93
- // See https://github.com/WordPress/gutenberg/pull/54471#issuecomment-1723818809
94
91
  &.has-size-small {
95
- max-width: $modal-width-small;
92
+ max-width: var(--wpds-dimension-surface-width-md);
96
93
  }
97
94
  &.has-size-medium {
98
- max-width: $modal-width-medium;
95
+ max-width: var(--wpds-dimension-surface-width-lg);
99
96
  }
100
97
  &.has-size-large {
101
- max-width: $modal-width-large;
98
+ max-width: var(--wpds-dimension-surface-width-2xl);
102
99
  }
103
100
 
104
101
  }
@@ -87,6 +87,7 @@ export function RadioControl(
87
87
  return (
88
88
  <fieldset
89
89
  id={ id }
90
+ role="radiogroup"
90
91
  className={ clsx( className, 'components-radio-control' ) }
91
92
  aria-describedby={ !! help ? generateHelpId( id ) : undefined }
92
93
  >
@@ -56,18 +56,18 @@ describe.each( [
56
56
  const [ , Component ] = modeAndComponent;
57
57
 
58
58
  describe( 'semantics and labelling', () => {
59
- it( 'should group all radios under a fieldset with an accessible label (legend)', () => {
59
+ it( 'should render a radiogroup with an accessible label (legend)', () => {
60
60
  const onChangeSpy = jest.fn();
61
61
  render(
62
62
  <Component { ...defaultProps } onChange={ onChangeSpy } />
63
63
  );
64
64
 
65
65
  expect(
66
- screen.getByRole( 'group', { name: defaultProps.label } )
66
+ screen.getByRole( 'radiogroup', { name: defaultProps.label } )
67
67
  ).toBeVisible();
68
68
  } );
69
69
 
70
- it( 'should group all radios under a fieldset with an accessible label even when the label is visually hidden', () => {
70
+ it( 'should render a radiogroup with an accessible label even when the label is visually hidden', () => {
71
71
  const onChangeSpy = jest.fn();
72
72
  render(
73
73
  <Component
@@ -78,7 +78,7 @@ describe.each( [
78
78
  );
79
79
 
80
80
  expect(
81
- screen.getByRole( 'group', { name: defaultProps.label } )
81
+ screen.getByRole( 'radiogroup', { name: defaultProps.label } )
82
82
  ).toBeVisible();
83
83
  } );
84
84
 
@@ -93,7 +93,7 @@ describe.each( [
93
93
  );
94
94
 
95
95
  expect(
96
- screen.getByRole( 'group', { name: defaultProps.label } )
96
+ screen.getByRole( 'radiogroup', { name: defaultProps.label } )
97
97
  ).toHaveAccessibleDescription( 'Test help text' );
98
98
  } );
99
99
 
@@ -14,7 +14,7 @@
14
14
  color: $white;
15
15
  padding: $grid-unit-15 ($grid-unit-05 * 5);
16
16
  width: 100%;
17
- max-width: 600px;
17
+ max-width: var(--wpds-dimension-surface-width-lg);
18
18
  box-sizing: border-box;
19
19
  cursor: pointer;
20
20
 
@@ -90,6 +90,7 @@ Default.args = {
90
90
  { value: 'right', label: 'Right' },
91
91
  { value: 'justify', label: 'Justify' },
92
92
  ].map( mapPropsToOptionComponent ),
93
+ help: 'Help text to describe the control.',
93
94
  isBlock: true,
94
95
  label: 'Label',
95
96
  };