@wordpress/components 19.7.0-next.e230fbab09.0 → 19.8.1

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 (539) hide show
  1. package/CHANGELOG.md +57 -1
  2. package/README.md +38 -0
  3. package/build/base-control/index.js +41 -32
  4. package/build/base-control/index.js.map +1 -1
  5. package/build/base-control/styles/base-control-styles.js +43 -22
  6. package/build/base-control/styles/base-control-styles.js.map +1 -1
  7. package/build/base-control/types.js +6 -0
  8. package/build/base-control/types.js.map +1 -0
  9. package/build/border-box-control/border-box-control/component.js +124 -0
  10. package/build/border-box-control/border-box-control/component.js.map +1 -0
  11. package/build/border-box-control/border-box-control/hook.js +113 -0
  12. package/build/border-box-control/border-box-control/hook.js.map +1 -0
  13. package/build/border-box-control/border-box-control/index.js +24 -0
  14. package/build/border-box-control/border-box-control/index.js.map +1 -0
  15. package/build/border-box-control/border-box-control-linked-button/component.js +59 -0
  16. package/build/border-box-control/border-box-control-linked-button/component.js.map +1 -0
  17. package/build/border-box-control/border-box-control-linked-button/hook.js +41 -0
  18. package/build/border-box-control/border-box-control-linked-button/hook.js.map +1 -0
  19. package/build/border-box-control/border-box-control-linked-button/index.js +16 -0
  20. package/build/border-box-control/border-box-control-linked-button/index.js.map +1 -0
  21. package/build/border-box-control/border-box-control-split-controls/component.js +93 -0
  22. package/build/border-box-control/border-box-control-split-controls/component.js.map +1 -0
  23. package/build/border-box-control/border-box-control-split-controls/hook.js +45 -0
  24. package/build/border-box-control/border-box-control-split-controls/hook.js.map +1 -0
  25. package/build/border-box-control/border-box-control-split-controls/index.js +16 -0
  26. package/build/border-box-control/border-box-control-split-controls/index.js.map +1 -0
  27. package/build/border-box-control/border-box-control-visualizer/component.js +40 -0
  28. package/build/border-box-control/border-box-control-visualizer/component.js.map +1 -0
  29. package/build/border-box-control/border-box-control-visualizer/hook.js +43 -0
  30. package/build/border-box-control/border-box-control-visualizer/hook.js.map +1 -0
  31. package/build/border-box-control/border-box-control-visualizer/index.js +16 -0
  32. package/build/border-box-control/border-box-control-visualizer/index.js.map +1 -0
  33. package/build/border-box-control/index.js +44 -0
  34. package/build/border-box-control/index.js.map +1 -0
  35. package/build/border-box-control/styles.js +76 -0
  36. package/build/border-box-control/styles.js.map +1 -0
  37. package/build/border-box-control/types.js +6 -0
  38. package/build/border-box-control/types.js.map +1 -0
  39. package/build/border-box-control/utils.js +161 -0
  40. package/build/border-box-control/utils.js.map +1 -0
  41. package/build/border-control/border-control/component.js +119 -0
  42. package/build/border-control/border-control/component.js.map +1 -0
  43. package/build/border-control/border-control/hook.js +130 -0
  44. package/build/border-control/border-control/hook.js.map +1 -0
  45. package/build/border-control/border-control/index.js +24 -0
  46. package/build/border-control/border-control/index.js.map +1 -0
  47. package/build/border-control/border-control-dropdown/component.js +196 -0
  48. package/build/border-control/border-control-dropdown/component.js.map +1 -0
  49. package/build/border-control/border-control-dropdown/hook.js +105 -0
  50. package/build/border-control/border-control-dropdown/hook.js.map +1 -0
  51. package/build/border-control/border-control-dropdown/index.js +16 -0
  52. package/build/border-control/border-control-dropdown/index.js.map +1 -0
  53. package/build/border-control/border-control-style-picker/component.js +101 -0
  54. package/build/border-control/border-control-style-picker/component.js.map +1 -0
  55. package/build/border-control/border-control-style-picker/hook.js +45 -0
  56. package/build/border-control/border-control-style-picker/hook.js.map +1 -0
  57. package/build/border-control/border-control-style-picker/index.js +16 -0
  58. package/build/border-control/border-control-style-picker/index.js.map +1 -0
  59. package/build/border-control/index.js +24 -0
  60. package/build/border-control/index.js.map +1 -0
  61. package/build/border-control/styles.js +125 -0
  62. package/build/border-control/styles.js.map +1 -0
  63. package/build/border-control/types.js +6 -0
  64. package/build/border-control/types.js.map +1 -0
  65. package/build/box-control/all-input-control.js +3 -7
  66. package/build/box-control/all-input-control.js.map +1 -1
  67. package/build/box-control/axial-input-controls.js +20 -15
  68. package/build/box-control/axial-input-controls.js.map +1 -1
  69. package/build/box-control/input-controls.js +21 -16
  70. package/build/box-control/input-controls.js.map +1 -1
  71. package/build/box-control/utils.js +25 -11
  72. package/build/box-control/utils.js.map +1 -1
  73. package/build/card/styles.js +22 -17
  74. package/build/card/styles.js.map +1 -1
  75. package/build/checkbox-control/index.js +21 -1
  76. package/build/checkbox-control/index.js.map +1 -1
  77. package/build/color-palette/index.js +53 -4
  78. package/build/color-palette/index.js.map +1 -1
  79. package/build/custom-select-control/index.js +12 -4
  80. package/build/custom-select-control/index.js.map +1 -1
  81. package/build/divider/styles.js +28 -16
  82. package/build/divider/styles.js.map +1 -1
  83. package/build/focal-point-picker/controls.js +2 -3
  84. package/build/focal-point-picker/controls.js.map +1 -1
  85. package/build/form-file-upload/index.js +4 -1
  86. package/build/form-file-upload/index.js.map +1 -1
  87. package/build/guide/index.js +14 -8
  88. package/build/guide/index.js.map +1 -1
  89. package/build/index.js +40 -0
  90. package/build/index.js.map +1 -1
  91. package/build/input-control/input-field.js +21 -14
  92. package/build/input-control/input-field.js.map +1 -1
  93. package/build/input-control/reducer/actions.js +1 -3
  94. package/build/input-control/reducer/actions.js.map +1 -1
  95. package/build/input-control/reducer/reducer.js +1 -43
  96. package/build/input-control/reducer/reducer.js.map +1 -1
  97. package/build/item-group/styles.js +14 -14
  98. package/build/item-group/styles.js.map +1 -1
  99. package/build/mobile/picker/index.android.js +0 -3
  100. package/build/mobile/picker/index.android.js.map +1 -1
  101. package/build/number-control/index.js +15 -10
  102. package/build/number-control/index.js.map +1 -1
  103. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  104. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  105. package/build/surface/styles.js +8 -8
  106. package/build/surface/styles.js.map +1 -1
  107. package/build/toggle-group-control/index.js +8 -0
  108. package/build/toggle-group-control/index.js.map +1 -1
  109. package/build/toggle-group-control/toggle-group-control/component.js +10 -1
  110. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  111. package/build/toggle-group-control/toggle-group-control/styles.js +14 -3
  112. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  113. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +90 -0
  114. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  115. package/build/toggle-group-control/toggle-group-control-option/component.js +9 -90
  116. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  117. package/build/toggle-group-control/toggle-group-control-option-base/component.js +127 -0
  118. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -0
  119. package/build/toggle-group-control/toggle-group-control-option-base/index.js +16 -0
  120. package/build/toggle-group-control/toggle-group-control-option-base/index.js.map +1 -0
  121. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +66 -0
  122. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -0
  123. package/build/toggle-group-control/toggle-group-control-option-icon/component.js +55 -0
  124. package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -0
  125. package/build/toggle-group-control/toggle-group-control-option-icon/index.js +16 -0
  126. package/build/toggle-group-control/toggle-group-control-option-icon/index.js.map +1 -0
  127. package/build/toolbar-dropdown-menu/index.js +1 -1
  128. package/build/toolbar-dropdown-menu/index.js.map +1 -1
  129. package/build/tree-grid/index.js +4 -1
  130. package/build/tree-grid/index.js.map +1 -1
  131. package/build/unit-control/index.js +56 -29
  132. package/build/unit-control/index.js.map +1 -1
  133. package/build/unit-control/unit-select-control.js +2 -4
  134. package/build/unit-control/unit-select-control.js.map +1 -1
  135. package/build/utils/colors-values.js +5 -3
  136. package/build/utils/colors-values.js.map +1 -1
  137. package/build/utils/config-values.js +9 -4
  138. package/build/utils/config-values.js.map +1 -1
  139. package/build-module/base-control/index.js +39 -35
  140. package/build-module/base-control/index.js.map +1 -1
  141. package/build-module/base-control/styles/base-control-styles.js +44 -16
  142. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  143. package/build-module/base-control/types.js +2 -0
  144. package/build-module/base-control/types.js.map +1 -0
  145. package/build-module/border-box-control/border-box-control/component.js +104 -0
  146. package/build-module/border-box-control/border-box-control/component.js.map +1 -0
  147. package/build-module/border-box-control/border-box-control/hook.js +97 -0
  148. package/build-module/border-box-control/border-box-control/hook.js.map +1 -0
  149. package/build-module/border-box-control/border-box-control/index.js +3 -0
  150. package/build-module/border-box-control/border-box-control/index.js.map +1 -0
  151. package/build-module/border-box-control/border-box-control-linked-button/component.js +42 -0
  152. package/build-module/border-box-control/border-box-control-linked-button/component.js.map +1 -0
  153. package/build-module/border-box-control/border-box-control-linked-button/hook.js +26 -0
  154. package/build-module/border-box-control/border-box-control-linked-button/hook.js.map +1 -0
  155. package/build-module/border-box-control/border-box-control-linked-button/index.js +2 -0
  156. package/build-module/border-box-control/border-box-control-linked-button/index.js.map +1 -0
  157. package/build-module/border-box-control/border-box-control-split-controls/component.js +77 -0
  158. package/build-module/border-box-control/border-box-control-split-controls/component.js.map +1 -0
  159. package/build-module/border-box-control/border-box-control-split-controls/hook.js +30 -0
  160. package/build-module/border-box-control/border-box-control-split-controls/hook.js.map +1 -0
  161. package/build-module/border-box-control/border-box-control-split-controls/index.js +2 -0
  162. package/build-module/border-box-control/border-box-control-split-controls/index.js.map +1 -0
  163. package/build-module/border-box-control/border-box-control-visualizer/component.js +27 -0
  164. package/build-module/border-box-control/border-box-control-visualizer/component.js.map +1 -0
  165. package/build-module/border-box-control/border-box-control-visualizer/hook.js +28 -0
  166. package/build-module/border-box-control/border-box-control-visualizer/hook.js.map +1 -0
  167. package/build-module/border-box-control/border-box-control-visualizer/index.js +2 -0
  168. package/build-module/border-box-control/border-box-control-visualizer/index.js.map +1 -0
  169. package/build-module/border-box-control/index.js +4 -0
  170. package/build-module/border-box-control/index.js.map +1 -0
  171. package/build-module/border-box-control/styles.js +66 -0
  172. package/build-module/border-box-control/styles.js.map +1 -0
  173. package/build-module/border-box-control/types.js +2 -0
  174. package/build-module/border-box-control/types.js.map +1 -0
  175. package/build-module/border-box-control/utils.js +127 -0
  176. package/build-module/border-box-control/utils.js.map +1 -0
  177. package/build-module/border-control/border-control/component.js +100 -0
  178. package/build-module/border-control/border-control/component.js.map +1 -0
  179. package/build-module/border-control/border-control/hook.js +115 -0
  180. package/build-module/border-control/border-control/hook.js.map +1 -0
  181. package/build-module/border-control/border-control/index.js +3 -0
  182. package/build-module/border-control/border-control/index.js.map +1 -0
  183. package/build-module/border-control/border-control-dropdown/component.js +174 -0
  184. package/build-module/border-control/border-control-dropdown/component.js.map +1 -0
  185. package/build-module/border-control/border-control-dropdown/hook.js +89 -0
  186. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -0
  187. package/build-module/border-control/border-control-dropdown/index.js +2 -0
  188. package/build-module/border-control/border-control-dropdown/index.js.map +1 -0
  189. package/build-module/border-control/border-control-style-picker/component.js +81 -0
  190. package/build-module/border-control/border-control-style-picker/component.js.map +1 -0
  191. package/build-module/border-control/border-control-style-picker/hook.js +30 -0
  192. package/build-module/border-control/border-control-style-picker/hook.js.map +1 -0
  193. package/build-module/border-control/border-control-style-picker/index.js +2 -0
  194. package/build-module/border-control/border-control-style-picker/index.js.map +1 -0
  195. package/build-module/border-control/index.js +3 -0
  196. package/build-module/border-control/index.js.map +1 -0
  197. package/build-module/border-control/styles.js +90 -0
  198. package/build-module/border-control/styles.js.map +1 -0
  199. package/build-module/border-control/types.js +2 -0
  200. package/build-module/border-control/types.js.map +1 -0
  201. package/build-module/box-control/all-input-control.js +4 -8
  202. package/build-module/box-control/all-input-control.js.map +1 -1
  203. package/build-module/box-control/axial-input-controls.js +18 -14
  204. package/build-module/box-control/axial-input-controls.js.map +1 -1
  205. package/build-module/box-control/input-controls.js +18 -14
  206. package/build-module/box-control/input-controls.js.map +1 -1
  207. package/build-module/box-control/utils.js +25 -11
  208. package/build-module/box-control/utils.js.map +1 -1
  209. package/build-module/card/styles.js +23 -18
  210. package/build-module/card/styles.js.map +1 -1
  211. package/build-module/checkbox-control/index.js +24 -3
  212. package/build-module/checkbox-control/index.js.map +1 -1
  213. package/build-module/color-palette/index.js +52 -4
  214. package/build-module/color-palette/index.js.map +1 -1
  215. package/build-module/custom-select-control/index.js +12 -4
  216. package/build-module/custom-select-control/index.js.map +1 -1
  217. package/build-module/divider/styles.js +29 -10
  218. package/build-module/divider/styles.js.map +1 -1
  219. package/build-module/focal-point-picker/controls.js +2 -3
  220. package/build-module/focal-point-picker/controls.js.map +1 -1
  221. package/build-module/form-file-upload/index.js +4 -1
  222. package/build-module/form-file-upload/index.js.map +1 -1
  223. package/build-module/guide/index.js +14 -8
  224. package/build-module/guide/index.js.map +1 -1
  225. package/build-module/index.js +3 -1
  226. package/build-module/index.js.map +1 -1
  227. package/build-module/input-control/input-field.js +21 -13
  228. package/build-module/input-control/input-field.js.map +1 -1
  229. package/build-module/input-control/reducer/actions.js +0 -1
  230. package/build-module/input-control/reducer/actions.js.map +1 -1
  231. package/build-module/input-control/reducer/reducer.js +2 -39
  232. package/build-module/input-control/reducer/reducer.js.map +1 -1
  233. package/build-module/item-group/styles.js +14 -14
  234. package/build-module/item-group/styles.js.map +1 -1
  235. package/build-module/mobile/picker/index.android.js +0 -3
  236. package/build-module/mobile/picker/index.android.js.map +1 -1
  237. package/build-module/number-control/index.js +15 -9
  238. package/build-module/number-control/index.js.map +1 -1
  239. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  240. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  241. package/build-module/surface/styles.js +8 -8
  242. package/build-module/surface/styles.js.map +1 -1
  243. package/build-module/toggle-group-control/index.js +1 -0
  244. package/build-module/toggle-group-control/index.js.map +1 -1
  245. package/build-module/toggle-group-control/toggle-group-control/component.js +8 -1
  246. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  247. package/build-module/toggle-group-control/toggle-group-control/styles.js +11 -3
  248. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  249. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +86 -0
  250. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  251. package/build-module/toggle-group-control/toggle-group-control-option/component.js +9 -79
  252. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  253. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +105 -0
  254. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -0
  255. package/build-module/toggle-group-control/toggle-group-control-option-base/index.js +2 -0
  256. package/build-module/toggle-group-control/toggle-group-control-option-base/index.js.map +1 -0
  257. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +55 -0
  258. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -0
  259. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +50 -0
  260. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -0
  261. package/build-module/toggle-group-control/toggle-group-control-option-icon/index.js +2 -0
  262. package/build-module/toggle-group-control/toggle-group-control-option-icon/index.js.map +1 -0
  263. package/build-module/toolbar-dropdown-menu/index.js +1 -1
  264. package/build-module/toolbar-dropdown-menu/index.js.map +1 -1
  265. package/build-module/tree-grid/index.js +4 -1
  266. package/build-module/tree-grid/index.js.map +1 -1
  267. package/build-module/unit-control/index.js +54 -27
  268. package/build-module/unit-control/index.js.map +1 -1
  269. package/build-module/unit-control/unit-select-control.js +2 -3
  270. package/build-module/unit-control/unit-select-control.js.map +1 -1
  271. package/build-module/utils/colors-values.js +5 -3
  272. package/build-module/utils/colors-values.js.map +1 -1
  273. package/build-module/utils/config-values.js +8 -4
  274. package/build-module/utils/config-values.js.map +1 -1
  275. package/build-style/style-rtl.css +33 -185
  276. package/build-style/style.css +33 -185
  277. package/build-types/base-control/index.d.ts +35 -71
  278. package/build-types/base-control/index.d.ts.map +1 -1
  279. package/build-types/base-control/stories/index.d.ts +25 -0
  280. package/build-types/base-control/stories/index.d.ts.map +1 -0
  281. package/build-types/base-control/styles/base-control-styles.d.ts +10 -5
  282. package/build-types/base-control/styles/base-control-styles.d.ts.map +1 -1
  283. package/build-types/base-control/types.d.ts +41 -0
  284. package/build-types/base-control/types.d.ts.map +1 -0
  285. package/build-types/border-box-control/border-box-control/component.d.ts +4 -0
  286. package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -0
  287. package/build-types/border-box-control/border-box-control/hook.d.ts +282 -0
  288. package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -0
  289. package/build-types/border-box-control/border-box-control/index.d.ts +3 -0
  290. package/build-types/border-box-control/border-box-control/index.d.ts.map +1 -0
  291. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +4 -0
  292. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts.map +1 -0
  293. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +266 -0
  294. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts.map +1 -0
  295. package/build-types/border-box-control/border-box-control-linked-button/index.d.ts +2 -0
  296. package/build-types/border-box-control/border-box-control-linked-button/index.d.ts.map +1 -0
  297. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +4 -0
  298. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts.map +1 -0
  299. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +274 -0
  300. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -0
  301. package/build-types/border-box-control/border-box-control-split-controls/index.d.ts +2 -0
  302. package/build-types/border-box-control/border-box-control-split-controls/index.d.ts.map +1 -0
  303. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts +4 -0
  304. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts.map +1 -0
  305. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +266 -0
  306. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts.map +1 -0
  307. package/build-types/border-box-control/border-box-control-visualizer/index.d.ts +2 -0
  308. package/build-types/border-box-control/border-box-control-visualizer/index.d.ts.map +1 -0
  309. package/build-types/border-box-control/index.d.ts +4 -0
  310. package/build-types/border-box-control/index.d.ts.map +1 -0
  311. package/build-types/border-box-control/styles.d.ts +8 -0
  312. package/build-types/border-box-control/styles.d.ts.map +1 -0
  313. package/build-types/border-box-control/types.d.ts +91 -0
  314. package/build-types/border-box-control/types.d.ts.map +1 -0
  315. package/build-types/border-box-control/utils.d.ts +24 -0
  316. package/build-types/border-box-control/utils.d.ts.map +1 -0
  317. package/build-types/border-control/border-control/component.d.ts +4 -0
  318. package/build-types/border-control/border-control/component.d.ts.map +1 -0
  319. package/build-types/border-control/border-control/hook.d.ts +285 -0
  320. package/build-types/border-control/border-control/hook.d.ts.map +1 -0
  321. package/build-types/border-control/border-control/index.d.ts +3 -0
  322. package/build-types/border-control/border-control/index.d.ts.map +1 -0
  323. package/build-types/border-control/border-control-dropdown/component.d.ts +4 -0
  324. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -0
  325. package/build-types/border-control/border-control-dropdown/hook.d.ts +280 -0
  326. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -0
  327. package/build-types/border-control/border-control-dropdown/index.d.ts +2 -0
  328. package/build-types/border-control/border-control-dropdown/index.d.ts.map +1 -0
  329. package/build-types/border-control/border-control-style-picker/component.d.ts +4 -0
  330. package/build-types/border-control/border-control-style-picker/component.d.ts.map +1 -0
  331. package/build-types/border-control/border-control-style-picker/hook.d.ts +269 -0
  332. package/build-types/border-control/border-control-style-picker/hook.d.ts.map +1 -0
  333. package/build-types/border-control/border-control-style-picker/index.d.ts +2 -0
  334. package/build-types/border-control/border-control-style-picker/index.d.ts.map +1 -0
  335. package/build-types/border-control/index.d.ts +3 -0
  336. package/build-types/border-control/index.d.ts.map +1 -0
  337. package/build-types/border-control/styles.d.ts +18 -0
  338. package/build-types/border-control/styles.d.ts.map +1 -0
  339. package/build-types/border-control/types.d.ts +163 -0
  340. package/build-types/border-control/types.d.ts.map +1 -0
  341. package/build-types/card/card-divider/hook.d.ts +1 -1
  342. package/build-types/card/styles.d.ts.map +1 -1
  343. package/build-types/color-indicator/index.d.ts +7 -0
  344. package/build-types/color-indicator/index.d.ts.map +1 -0
  345. package/build-types/color-palette/index.d.ts.map +1 -1
  346. package/build-types/color-picker/styles.d.ts +1 -1
  347. package/build-types/divider/stories/index.d.ts +1 -0
  348. package/build-types/divider/stories/index.d.ts.map +1 -1
  349. package/build-types/divider/styles.d.ts.map +1 -1
  350. package/build-types/divider/types.d.ts +8 -1
  351. package/build-types/divider/types.d.ts.map +1 -1
  352. package/build-types/input-control/input-field.d.ts.map +1 -1
  353. package/build-types/input-control/reducer/actions.d.ts +1 -3
  354. package/build-types/input-control/reducer/actions.d.ts.map +1 -1
  355. package/build-types/input-control/reducer/reducer.d.ts +3 -9
  356. package/build-types/input-control/reducer/reducer.d.ts.map +1 -1
  357. package/build-types/input-control/stories/index.d.ts +17 -0
  358. package/build-types/input-control/stories/index.d.ts.map +1 -0
  359. package/build-types/input-control/types.d.ts +2 -2
  360. package/build-types/input-control/types.d.ts.map +1 -1
  361. package/build-types/item-group/styles.d.ts.map +1 -1
  362. package/build-types/number-control/index.d.ts +3 -3
  363. package/build-types/number-control/index.d.ts.map +1 -1
  364. package/build-types/range-control/styles/range-control-styles.d.ts +1 -1
  365. package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts.map +1 -1
  366. package/build-types/spinner/styles/spinner-styles.d.ts +5 -0
  367. package/build-types/spinner/styles/spinner-styles.d.ts.map +1 -0
  368. package/build-types/toggle-group-control/index.d.ts +1 -0
  369. package/build-types/toggle-group-control/index.d.ts.map +1 -1
  370. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  371. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +5 -0
  372. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  373. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts +9 -0
  374. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts.map +1 -0
  375. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -2
  376. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
  377. package/build-types/toggle-group-control/toggle-group-control-option/styles.d.ts +0 -4
  378. package/build-types/toggle-group-control/toggle-group-control-option/styles.d.ts.map +1 -1
  379. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts +25 -0
  380. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -0
  381. package/build-types/toggle-group-control/toggle-group-control-option-base/index.d.ts +2 -0
  382. package/build-types/toggle-group-control/toggle-group-control-option-base/index.d.ts.map +1 -0
  383. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +15 -0
  384. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -0
  385. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +37 -0
  386. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -0
  387. package/build-types/toggle-group-control/toggle-group-control-option-icon/index.d.ts +2 -0
  388. package/build-types/toggle-group-control/toggle-group-control-option-icon/index.d.ts.map +1 -0
  389. package/build-types/toggle-group-control/types.d.ts +24 -8
  390. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  391. package/build-types/ui/form-group/form-group.d.ts +2 -2
  392. package/build-types/unit-control/index.d.ts +12 -5
  393. package/build-types/unit-control/index.d.ts.map +1 -1
  394. package/build-types/unit-control/stories/index.d.ts +33 -0
  395. package/build-types/unit-control/stories/index.d.ts.map +1 -0
  396. package/build-types/unit-control/styles/unit-control-styles.d.ts +1 -1
  397. package/build-types/unit-control/types.d.ts +28 -7
  398. package/build-types/unit-control/types.d.ts.map +1 -1
  399. package/build-types/unit-control/unit-select-control.d.ts.map +1 -1
  400. package/build-types/utils/colors-values.d.ts +78 -18
  401. package/build-types/utils/colors-values.d.ts.map +1 -1
  402. package/build-types/utils/config-values.d.ts +71 -71
  403. package/build-types/utils/config-values.d.ts.map +1 -1
  404. package/package.json +17 -17
  405. package/src/animate/README.md +1 -1
  406. package/src/base-control/README.md +20 -12
  407. package/src/base-control/index.tsx +124 -0
  408. package/src/base-control/stories/index.tsx +80 -0
  409. package/src/base-control/styles/{base-control-styles.js → base-control-styles.ts} +23 -1
  410. package/src/base-control/types.ts +42 -0
  411. package/src/border-box-control/border-box-control/README.md +178 -0
  412. package/src/border-box-control/border-box-control/component.tsx +123 -0
  413. package/src/border-box-control/border-box-control/hook.ts +119 -0
  414. package/src/border-box-control/border-box-control/index.ts +2 -0
  415. package/src/border-box-control/border-box-control-linked-button/component.tsx +50 -0
  416. package/src/border-box-control/border-box-control-linked-button/hook.ts +30 -0
  417. package/src/border-box-control/border-box-control-linked-button/index.ts +1 -0
  418. package/src/border-box-control/border-box-control-split-controls/component.tsx +90 -0
  419. package/src/border-box-control/border-box-control-split-controls/hook.ts +34 -0
  420. package/src/border-box-control/border-box-control-split-controls/index.ts +1 -0
  421. package/src/border-box-control/border-box-control-visualizer/component.tsx +28 -0
  422. package/src/border-box-control/border-box-control-visualizer/hook.ts +30 -0
  423. package/src/border-box-control/border-box-control-visualizer/index.ts +1 -0
  424. package/src/border-box-control/index.ts +3 -0
  425. package/src/border-box-control/stories/index.js +104 -0
  426. package/src/border-box-control/styles.ts +69 -0
  427. package/src/border-box-control/test/index.js +354 -0
  428. package/src/border-box-control/test/utils.js +305 -0
  429. package/src/border-box-control/types.ts +98 -0
  430. package/src/border-box-control/utils.ts +151 -0
  431. package/src/border-control/border-control/README.md +181 -0
  432. package/src/border-control/border-control/component.tsx +112 -0
  433. package/src/border-control/border-control/hook.ts +145 -0
  434. package/src/border-control/border-control/index.ts +2 -0
  435. package/src/border-control/border-control-dropdown/component.tsx +252 -0
  436. package/src/border-control/border-control-dropdown/hook.ts +98 -0
  437. package/src/border-control/border-control-dropdown/index.ts +1 -0
  438. package/src/border-control/border-control-style-picker/component.tsx +89 -0
  439. package/src/border-control/border-control-style-picker/hook.ts +34 -0
  440. package/src/border-control/border-control-style-picker/index.ts +1 -0
  441. package/src/border-control/index.ts +2 -0
  442. package/src/border-control/stories/index.js +118 -0
  443. package/src/border-control/styles.ts +190 -0
  444. package/src/border-control/test/index.js +436 -0
  445. package/src/border-control/types.ts +173 -0
  446. package/src/box-control/all-input-control.js +2 -10
  447. package/src/box-control/axial-input-controls.js +32 -21
  448. package/src/box-control/input-controls.js +30 -19
  449. package/src/box-control/utils.js +29 -12
  450. package/src/card/styles.js +11 -5
  451. package/src/card/test/__snapshots__/index.js.snap +83 -66
  452. package/src/card/test/index.js +7 -5
  453. package/src/checkbox-control/index.js +34 -3
  454. package/src/checkbox-control/stories/index.js +44 -0
  455. package/src/checkbox-control/style.scss +4 -2
  456. package/src/color-palette/README.md +6 -0
  457. package/src/color-palette/index.js +73 -8
  458. package/src/color-palette/stories/index.js +69 -26
  459. package/src/color-palette/style.scss +11 -3
  460. package/src/color-palette/test/__snapshots__/index.js.snap +662 -12
  461. package/src/color-palette/test/index.js +1 -1
  462. package/src/custom-select-control/index.js +15 -3
  463. package/src/custom-select-control/stories/index.js +77 -74
  464. package/src/custom-select-control/style.scss +23 -4
  465. package/src/disabled/README.md +7 -10
  466. package/src/divider/stories/index.tsx +26 -23
  467. package/src/divider/styles.ts +9 -0
  468. package/src/divider/types.ts +11 -1
  469. package/src/flyout/test/__snapshots__/index.js.snap +7 -7
  470. package/src/focal-point-picker/controls.js +2 -3
  471. package/src/font-size-picker/test/index.js +0 -2
  472. package/src/form-file-upload/README.md +18 -0
  473. package/src/form-file-upload/index.js +3 -0
  474. package/src/form-file-upload/test/index.js +73 -11
  475. package/src/form-toggle/README.md +1 -1
  476. package/src/guide/index.js +12 -13
  477. package/src/guide/style.scss +0 -4
  478. package/src/index.js +8 -0
  479. package/src/input-control/input-field.tsx +23 -12
  480. package/src/input-control/reducer/actions.ts +1 -7
  481. package/src/input-control/reducer/reducer.ts +0 -29
  482. package/src/input-control/types.ts +2 -1
  483. package/src/item-group/styles.ts +1 -0
  484. package/src/item-group/test/__snapshots__/index.js.snap +11 -10
  485. package/src/mobile/picker/index.android.js +0 -1
  486. package/src/number-control/README.md +14 -0
  487. package/src/number-control/index.js +13 -12
  488. package/src/number-control/stories/index.js +14 -7
  489. package/src/number-control/test/index.js +79 -1
  490. package/src/range-control/stories/index.js +91 -119
  491. package/src/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +1 -0
  492. package/src/surface/styles.js +1 -1
  493. package/src/surface/test/__snapshots__/index.js.snap +11 -11
  494. package/src/toggle-group-control/index.ts +1 -0
  495. package/src/toggle-group-control/stories/index.js +37 -7
  496. package/src/toggle-group-control/test/__snapshots__/index.js.snap +269 -32
  497. package/src/toggle-group-control/test/index.js +43 -10
  498. package/src/toggle-group-control/toggle-group-control/component.tsx +10 -0
  499. package/src/toggle-group-control/toggle-group-control/styles.ts +14 -0
  500. package/src/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.tsx +86 -0
  501. package/src/toggle-group-control/toggle-group-control-option/README.md +8 -5
  502. package/src/toggle-group-control/toggle-group-control-option/component.tsx +18 -97
  503. package/src/toggle-group-control/toggle-group-control-option-base/README.md +27 -0
  504. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +129 -0
  505. package/src/toggle-group-control/toggle-group-control-option-base/index.ts +1 -0
  506. package/src/toggle-group-control/{toggle-group-control-option → toggle-group-control-option-base}/styles.ts +4 -13
  507. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +56 -0
  508. package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +56 -0
  509. package/src/toggle-group-control/toggle-group-control-option-icon/index.ts +1 -0
  510. package/src/toggle-group-control/types.ts +33 -8
  511. package/src/toolbar-dropdown-menu/index.js +1 -1
  512. package/src/toolbar-group/style.scss +0 -73
  513. package/src/tools-panel/test/__snapshots__/index.js.snap +8 -8
  514. package/src/tree-grid/README.md +1 -1
  515. package/src/tree-grid/index.js +4 -0
  516. package/src/tree-grid/test/index.js +61 -17
  517. package/src/unit-control/README.md +7 -3
  518. package/src/unit-control/index.tsx +65 -31
  519. package/src/unit-control/stories/index.tsx +170 -0
  520. package/src/unit-control/test/index.js +263 -100
  521. package/src/unit-control/types.ts +65 -42
  522. package/src/unit-control/unit-select-control.tsx +2 -3
  523. package/src/utils/colors-values.js +4 -3
  524. package/src/utils/config-values.js +9 -4
  525. package/tsconfig.json +3 -0
  526. package/tsconfig.tsbuildinfo +1 -1
  527. package/build/guide/finish-button.js +0 -44
  528. package/build/guide/finish-button.js.map +0 -1
  529. package/build/toggle-group-control/toggle-group-control-option/styles.js +0 -73
  530. package/build/toggle-group-control/toggle-group-control-option/styles.js.map +0 -1
  531. package/build-module/guide/finish-button.js +0 -34
  532. package/build-module/guide/finish-button.js.map +0 -1
  533. package/build-module/toggle-group-control/toggle-group-control-option/styles.js +0 -61
  534. package/build-module/toggle-group-control/toggle-group-control-option/styles.js.map +0 -1
  535. package/src/base-control/index.js +0 -111
  536. package/src/base-control/stories/index.js +0 -81
  537. package/src/guide/finish-button.js +0 -26
  538. package/src/guide/test/finish-button.js +0 -49
  539. package/src/unit-control/stories/index.js +0 -127
@@ -0,0 +1,173 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import type { CSSProperties } from 'react';
5
+
6
+ export type Border = {
7
+ color?: CSSProperties[ 'borderColor' ];
8
+ style?: CSSProperties[ 'borderStyle' ];
9
+ width?: CSSProperties[ 'borderWidth' ];
10
+ };
11
+
12
+ export type Color = {
13
+ name: string;
14
+ color: CSSProperties[ 'color' ];
15
+ };
16
+
17
+ export type ColorOrigin = {
18
+ name: string;
19
+ colors: Color[];
20
+ };
21
+
22
+ export type Colors = ColorOrigin[] | Color[];
23
+
24
+ export type ColorProps = {
25
+ /**
26
+ * An array of color definitions. This may also be a multi-dimensional array
27
+ * where colors are organized by multiple origins.
28
+ */
29
+ colors?: Colors;
30
+ /**
31
+ * This toggles the ability to choose custom colors.
32
+ */
33
+ disableCustomColors?: boolean;
34
+ /**
35
+ * This controls whether the alpha channel will be offered when selecting
36
+ * custom colors.
37
+ */
38
+ enableAlpha?: boolean;
39
+ /**
40
+ * This is passed on to the color related sub-components which need to be
41
+ * made aware of whether the colors prop contains multiple origins.
42
+ */
43
+ __experimentalHasMultipleOrigins?: boolean;
44
+ /**
45
+ * This is passed on to the color related sub-components so they may render
46
+ * more effectively when used within a sidebar.
47
+ */
48
+ __experimentalIsRenderedInSidebar?: boolean;
49
+ };
50
+
51
+ export type LabelProps = {
52
+ /**
53
+ * Provides control over whether the label will only be visible to
54
+ * screen readers.
55
+ */
56
+ hideLabelFromVision?: boolean;
57
+ /**
58
+ * If provided, a label will be generated using this as the content.
59
+ */
60
+ label?: string;
61
+ };
62
+
63
+ export type BorderControlProps = ColorProps &
64
+ LabelProps & {
65
+ /**
66
+ * This controls whether to include border style options within the
67
+ * `BorderDropdown` sub-component.
68
+ *
69
+ * @default true
70
+ */
71
+ enableStyle?: boolean;
72
+ /**
73
+ * This flags the `BorderControl` to render with a more compact
74
+ * appearance. It restricts the width of the control and prevents it
75
+ * from expanding to take up additional space.
76
+ */
77
+ isCompact?: boolean;
78
+ /**
79
+ * A callback function invoked when the border value is changed via an
80
+ * interaction that selects or clears, border color, style, or width.
81
+ */
82
+ onChange: ( value?: Border ) => void;
83
+ /**
84
+ * A custom CSS class name to be assigned to the border control's
85
+ * dropdown popover content.
86
+ */
87
+ popoverContentClassName?: string;
88
+ /**
89
+ * If opted into, sanitizing the border means that if no width or color
90
+ * have been selected, the border style is also cleared and `undefined`
91
+ * is returned as the new border value.
92
+ *
93
+ * @default true
94
+ */
95
+ shouldSanitizeBorder?: boolean;
96
+ /**
97
+ * Whether or not to show the header for the border color and style
98
+ * picker dropdown. The header includes a label for the color picker
99
+ * and a close button.
100
+ */
101
+ showDropdownHeader?: boolean;
102
+ /**
103
+ * An object representing a border or `undefined`. Used to set the
104
+ * current border configuration for this component.
105
+ */
106
+ value?: Border;
107
+ /**
108
+ * Controls the visual width of the `BorderControl`. It has no effect if
109
+ * the `isCompact` prop is set to `true`.
110
+ */
111
+ width?: CSSProperties[ 'width' ];
112
+ /**
113
+ * Flags whether this `BorderControl` should also render a
114
+ * `RangeControl` for additional control over a border's width.
115
+ */
116
+ withSlider?: boolean;
117
+ };
118
+
119
+ export type DropdownProps = ColorProps & {
120
+ /**
121
+ * An object representing a border or `undefined`. This component will
122
+ * extract the border color and style selections from this object to use as
123
+ * values for its popover controls.
124
+ */
125
+ border?: Border;
126
+ /**
127
+ * A custom CSS class name to be assigned to the border control's
128
+ * dropdown popover content.
129
+ */
130
+ contentClassName?: string;
131
+ /**
132
+ * This controls whether to render border style options.
133
+ *
134
+ * @default true
135
+ */
136
+ enableStyle?: boolean;
137
+ /**
138
+ * A callback invoked when the border color or style selections change.
139
+ */
140
+ onChange: ( newBorder?: Border ) => void;
141
+ /**
142
+ * Any previous style selection made by the user. This can be used to
143
+ * reapply that previous selection when, for example, a zero border width is
144
+ * to a non-zero value.
145
+ */
146
+ previousStyleSelection?: string;
147
+ /**
148
+ * Whether or not to render a header for the border color and style picker
149
+ * dropdown. The header includes a label for the color picker and a
150
+ * close button.
151
+ */
152
+ showDropdownHeader?: boolean;
153
+ };
154
+
155
+ export type StylePickerProps = LabelProps & {
156
+ /**
157
+ * A callback function invoked when a border style is selected or cleared.
158
+ */
159
+ onChange: ( style?: string ) => void;
160
+ /**
161
+ * The currently selected border style if there is one. Styles available via
162
+ * this control are `solid`, `dashed` & `dotted`, however the possibility
163
+ * to store other valid CSS values is maintained e.g. `none`, `inherit` etc.
164
+ */
165
+ value?: string;
166
+ };
167
+
168
+ export type PopoverProps = {
169
+ /**
170
+ * Callback function to invoke when closing the border dropdown's popover.
171
+ */
172
+ onClose: () => void;
173
+ };
@@ -10,7 +10,6 @@ import {
10
10
  ALL_SIDES,
11
11
  LABELS,
12
12
  getAllValue,
13
- getAllUnitFallback,
14
13
  isValuesMixed,
15
14
  isValuesDefined,
16
15
  } from './utils';
@@ -26,17 +25,11 @@ export default function AllInputControl( {
26
25
  setSelectedUnits,
27
26
  ...props
28
27
  } ) {
29
- const allValue = getAllValue( values, sides );
28
+ const allValue = getAllValue( values, selectedUnits, sides );
30
29
  const hasValues = isValuesDefined( values );
31
- const isMixed = hasValues && isValuesMixed( values, sides );
30
+ const isMixed = hasValues && isValuesMixed( values, selectedUnits, sides );
32
31
  const allPlaceholder = isMixed ? LABELS.mixed : null;
33
32
 
34
- // Set meaningful unit selection if no allValue and user has previously
35
- // selected units without assigning values while controls were unlinked.
36
- const allUnitFallback = ! allValue
37
- ? getAllUnitFallback( selectedUnits )
38
- : undefined;
39
-
40
33
  const handleOnFocus = ( event ) => {
41
34
  onFocus( event, { side: 'all' } );
42
35
  };
@@ -104,7 +97,6 @@ export default function AllInputControl( {
104
97
  disableUnits={ isMixed }
105
98
  isOnly
106
99
  value={ allValue }
107
- unit={ allUnitFallback }
108
100
  onChange={ handleOnChange }
109
101
  onUnitChange={ handleOnUnitChange }
110
102
  onFocus={ handleOnFocus }
@@ -1,6 +1,7 @@
1
1
  /**
2
2
  * Internal dependencies
3
3
  */
4
+ import { parseQuantityAndUnitFromRawValue } from '../unit-control/utils';
4
5
  import UnitControl from './unit-control';
5
6
  import { LABELS } from './utils';
6
7
  import { Layout } from './styles/box-control-styles';
@@ -113,27 +114,37 @@ export default function AxialInputControls( {
113
114
  align="top"
114
115
  className="component-box-control__vertical-horizontal-input-controls"
115
116
  >
116
- { filteredSides.map( ( side ) => (
117
- <UnitControl
118
- { ...props }
119
- isFirst={ first === side }
120
- isLast={ last === side }
121
- isOnly={ only === side }
122
- value={ side === 'vertical' ? values.top : values.left }
123
- unit={
124
- side === 'vertical'
125
- ? selectedUnits.top
126
- : selectedUnits.left
127
- }
128
- onChange={ createHandleOnChange( side ) }
129
- onUnitChange={ createHandleOnUnitChange( side ) }
130
- onFocus={ createHandleOnFocus( side ) }
131
- onHoverOn={ createHandleOnHoverOn( side ) }
132
- onHoverOff={ createHandleOnHoverOff( side ) }
133
- label={ LABELS[ side ] }
134
- key={ side }
135
- />
136
- ) ) }
117
+ { filteredSides.map( ( side ) => {
118
+ const [
119
+ parsedQuantity,
120
+ parsedUnit,
121
+ ] = parseQuantityAndUnitFromRawValue(
122
+ side === 'vertical' ? values.top : values.left
123
+ );
124
+ const selectedUnit =
125
+ side === 'vertical'
126
+ ? selectedUnits.top
127
+ : selectedUnits.left;
128
+ return (
129
+ <UnitControl
130
+ { ...props }
131
+ isFirst={ first === side }
132
+ isLast={ last === side }
133
+ isOnly={ only === side }
134
+ value={ [
135
+ parsedQuantity,
136
+ selectedUnit ?? parsedUnit,
137
+ ].join( '' ) }
138
+ onChange={ createHandleOnChange( side ) }
139
+ onUnitChange={ createHandleOnUnitChange( side ) }
140
+ onFocus={ createHandleOnFocus( side ) }
141
+ onHoverOn={ createHandleOnHoverOn( side ) }
142
+ onHoverOff={ createHandleOnHoverOff( side ) }
143
+ label={ LABELS[ side ] }
144
+ key={ side }
145
+ />
146
+ );
147
+ } ) }
137
148
  </Layout>
138
149
  );
139
150
  }
@@ -7,6 +7,7 @@ import { noop } from 'lodash';
7
7
  * Internal dependencies
8
8
  */
9
9
  import UnitControl from './unit-control';
10
+ import { parseQuantityAndUnitFromRawValue } from '../unit-control/utils';
10
11
  import { ALL_SIDES, LABELS } from './utils';
11
12
  import { LayoutContainer, Layout } from './styles/box-control-styles';
12
13
 
@@ -91,25 +92,35 @@ export default function BoxInputControls( {
91
92
  align="top"
92
93
  className="component-box-control__input-controls"
93
94
  >
94
- { filteredSides.map( ( side ) => (
95
- <UnitControl
96
- { ...props }
97
- isFirst={ first === side }
98
- isLast={ last === side }
99
- isOnly={ only === side }
100
- value={ values[ side ] }
101
- unit={
102
- values[ side ] ? undefined : selectedUnits[ side ]
103
- }
104
- onChange={ createHandleOnChange( side ) }
105
- onUnitChange={ createHandleOnUnitChange( side ) }
106
- onFocus={ createHandleOnFocus( side ) }
107
- onHoverOn={ createHandleOnHoverOn( side ) }
108
- onHoverOff={ createHandleOnHoverOff( side ) }
109
- label={ LABELS[ side ] }
110
- key={ `box-control-${ side }` }
111
- />
112
- ) ) }
95
+ { filteredSides.map( ( side ) => {
96
+ const [
97
+ parsedQuantity,
98
+ parsedUnit,
99
+ ] = parseQuantityAndUnitFromRawValue( values[ side ] );
100
+
101
+ const computedUnit = values[ side ]
102
+ ? parsedUnit
103
+ : selectedUnits[ side ];
104
+
105
+ return (
106
+ <UnitControl
107
+ { ...props }
108
+ isFirst={ first === side }
109
+ isLast={ last === side }
110
+ isOnly={ only === side }
111
+ value={ [ parsedQuantity, computedUnit ].join(
112
+ ''
113
+ ) }
114
+ onChange={ createHandleOnChange( side ) }
115
+ onUnitChange={ createHandleOnUnitChange( side ) }
116
+ onFocus={ createHandleOnFocus( side ) }
117
+ onHoverOn={ createHandleOnHoverOn( side ) }
118
+ onHoverOff={ createHandleOnHoverOff( side ) }
119
+ label={ LABELS[ side ] }
120
+ key={ `box-control-${ side }` }
121
+ />
122
+ );
123
+ } ) }
113
124
  </Layout>
114
125
  </LayoutContainer>
115
126
  );
@@ -61,24 +61,32 @@ function mode( arr ) {
61
61
  * Gets the 'all' input value and unit from values data.
62
62
  *
63
63
  * @param {Object} values Box values.
64
+ * @param {Object} selectedUnits Box units.
64
65
  * @param {Array} availableSides Available box sides to evaluate.
65
66
  *
66
67
  * @return {string} A value + unit for the 'all' input.
67
68
  */
68
- export function getAllValue( values = {}, availableSides = ALL_SIDES ) {
69
+ export function getAllValue(
70
+ values = {},
71
+ selectedUnits,
72
+ availableSides = ALL_SIDES
73
+ ) {
69
74
  const sides = normalizeSides( availableSides );
70
75
  const parsedQuantitiesAndUnits = sides.map( ( side ) =>
71
76
  parseQuantityAndUnitFromRawValue( values[ side ] )
72
77
  );
73
- const allValues = parsedQuantitiesAndUnits.map(
78
+ const allParsedQuantities = parsedQuantitiesAndUnits.map(
74
79
  ( value ) => value[ 0 ] ?? ''
75
80
  );
76
- const allUnits = parsedQuantitiesAndUnits.map( ( value ) => value[ 1 ] );
81
+ const allParsedUnits = parsedQuantitiesAndUnits.map(
82
+ ( value ) => value[ 1 ]
83
+ );
77
84
 
78
- const value = allValues.every( ( v ) => v === allValues[ 0 ] )
79
- ? allValues[ 0 ]
85
+ const commonQuantity = allParsedQuantities.every(
86
+ ( v ) => v === allParsedQuantities[ 0 ]
87
+ )
88
+ ? allParsedQuantities[ 0 ]
80
89
  : '';
81
- const unit = mode( allUnits );
82
90
 
83
91
  /**
84
92
  * The isNumber check is important. On reset actions, the incoming value
@@ -89,9 +97,17 @@ export function getAllValue( values = {}, availableSides = ALL_SIDES ) {
89
97
  * isNumber() is more specific for these cases, rather than relying on a
90
98
  * simple truthy check.
91
99
  */
92
- const allValue = isNumber( value ) ? `${ value }${ unit }` : undefined;
100
+ let commonUnit;
101
+ if ( isNumber( commonQuantity ) ) {
102
+ commonUnit = mode( allParsedUnits );
103
+ } else {
104
+ // Set meaningful unit selection if no commonQuantity and user has previously
105
+ // selected units without assigning values while controls were unlinked.
106
+ commonUnit =
107
+ getAllUnitFallback( selectedUnits ) ?? mode( allParsedUnits );
108
+ }
93
109
 
94
- return allValue;
110
+ return [ commonQuantity, commonUnit ].join( '' );
95
111
  }
96
112
 
97
113
  /**
@@ -113,13 +129,14 @@ export function getAllUnitFallback( selectedUnits ) {
113
129
  /**
114
130
  * Checks to determine if values are mixed.
115
131
  *
116
- * @param {Object} values Box values.
117
- * @param {Array} sides Available box sides to evaluate.
132
+ * @param {Object} values Box values.
133
+ * @param {Object} selectedUnits Box units.
134
+ * @param {Array} sides Available box sides to evaluate.
118
135
  *
119
136
  * @return {boolean} Whether values are mixed.
120
137
  */
121
- export function isValuesMixed( values = {}, sides = ALL_SIDES ) {
122
- const allValue = getAllValue( values, sides );
138
+ export function isValuesMixed( values = {}, selectedUnits, sides = ALL_SIDES ) {
139
+ const allValue = getAllValue( values, selectedUnits, sides );
123
140
  const isMixed = isNaN( parseFloat( allValue ) );
124
141
 
125
142
  return isMixed;
@@ -8,6 +8,12 @@ import { css } from '@emotion/react';
8
8
  */
9
9
  import { COLORS, CONFIG } from '../utils';
10
10
 
11
+ // Since the border for `Card` is rendered via the `box-shadow` property
12
+ // (as opposed to the `border` property), the value of the border radius needs
13
+ // to be adjusted by removing 1px (this is because the `box-shadow` renders
14
+ // as an "outer radius").
15
+ const adjustedBorderRadius = `calc(${ CONFIG.cardBorderRadius } - 1px)`;
16
+
11
17
  export const Card = css`
12
18
  box-shadow: 0 0 0 1px ${ CONFIG.surfaceBorderColor };
13
19
  outline: none;
@@ -62,13 +68,13 @@ export const Divider = css`
62
68
 
63
69
  export const borderRadius = css`
64
70
  &:first-of-type {
65
- border-top-left-radius: ${ CONFIG.cardBorderRadius };
66
- border-top-right-radius: ${ CONFIG.cardBorderRadius };
71
+ border-top-left-radius: ${ adjustedBorderRadius };
72
+ border-top-right-radius: ${ adjustedBorderRadius };
67
73
  }
68
74
 
69
75
  &:last-of-type {
70
- border-bottom-left-radius: ${ CONFIG.cardBorderRadius };
71
- border-bottom-right-radius: ${ CONFIG.cardBorderRadius };
76
+ border-bottom-left-radius: ${ adjustedBorderRadius };
77
+ border-bottom-right-radius: ${ adjustedBorderRadius };
72
78
  }
73
79
  `;
74
80
 
@@ -85,7 +91,7 @@ export const borderless = css`
85
91
  `;
86
92
 
87
93
  export const rounded = css`
88
- border-radius: ${ CONFIG.cardBorderRadius };
94
+ border-radius: ${ adjustedBorderRadius };
89
95
  `;
90
96
 
91
97
  const xSmallCardPadding = css`