@wordpress/components 19.7.0 → 19.8.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 (398) hide show
  1. package/CHANGELOG.md +27 -1
  2. package/README.md +38 -0
  3. package/build/base-control/index.js +35 -31
  4. package/build/base-control/index.js.map +1 -1
  5. package/build/base-control/styles/base-control-styles.js +18 -18
  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/card/styles.js +22 -17
  66. package/build/card/styles.js.map +1 -1
  67. package/build/custom-select-control/index.js +4 -1
  68. package/build/custom-select-control/index.js.map +1 -1
  69. package/build/index.js +40 -0
  70. package/build/index.js.map +1 -1
  71. package/build/item-group/styles.js +14 -14
  72. package/build/item-group/styles.js.map +1 -1
  73. package/build/mobile/picker/index.android.js +0 -3
  74. package/build/mobile/picker/index.android.js.map +1 -1
  75. package/build/surface/styles.js +8 -8
  76. package/build/surface/styles.js.map +1 -1
  77. package/build/toggle-group-control/index.js +8 -0
  78. package/build/toggle-group-control/index.js.map +1 -1
  79. package/build/toggle-group-control/toggle-group-control/component.js +10 -1
  80. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  81. package/build/toggle-group-control/toggle-group-control/styles.js +14 -3
  82. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  83. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +90 -0
  84. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  85. package/build/toggle-group-control/toggle-group-control-option/component.js +9 -87
  86. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  87. package/build/toggle-group-control/toggle-group-control-option-base/component.js +127 -0
  88. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -0
  89. package/build/toggle-group-control/toggle-group-control-option-base/index.js +16 -0
  90. package/build/toggle-group-control/toggle-group-control-option-base/index.js.map +1 -0
  91. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +66 -0
  92. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -0
  93. package/build/toggle-group-control/toggle-group-control-option-icon/component.js +55 -0
  94. package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -0
  95. package/build/toggle-group-control/toggle-group-control-option-icon/index.js +16 -0
  96. package/build/toggle-group-control/toggle-group-control-option-icon/index.js.map +1 -0
  97. package/build/toolbar-dropdown-menu/index.js +1 -1
  98. package/build/toolbar-dropdown-menu/index.js.map +1 -1
  99. package/build/unit-control/index.js +7 -2
  100. package/build/unit-control/index.js.map +1 -1
  101. package/build/utils/colors-values.js +5 -3
  102. package/build/utils/colors-values.js.map +1 -1
  103. package/build/utils/config-values.js +9 -4
  104. package/build/utils/config-values.js.map +1 -1
  105. package/build-module/base-control/index.js +33 -34
  106. package/build-module/base-control/index.js.map +1 -1
  107. package/build-module/base-control/styles/base-control-styles.js +18 -18
  108. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  109. package/build-module/base-control/types.js +2 -0
  110. package/build-module/base-control/types.js.map +1 -0
  111. package/build-module/border-box-control/border-box-control/component.js +104 -0
  112. package/build-module/border-box-control/border-box-control/component.js.map +1 -0
  113. package/build-module/border-box-control/border-box-control/hook.js +97 -0
  114. package/build-module/border-box-control/border-box-control/hook.js.map +1 -0
  115. package/build-module/border-box-control/border-box-control/index.js +3 -0
  116. package/build-module/border-box-control/border-box-control/index.js.map +1 -0
  117. package/build-module/border-box-control/border-box-control-linked-button/component.js +42 -0
  118. package/build-module/border-box-control/border-box-control-linked-button/component.js.map +1 -0
  119. package/build-module/border-box-control/border-box-control-linked-button/hook.js +26 -0
  120. package/build-module/border-box-control/border-box-control-linked-button/hook.js.map +1 -0
  121. package/build-module/border-box-control/border-box-control-linked-button/index.js +2 -0
  122. package/build-module/border-box-control/border-box-control-linked-button/index.js.map +1 -0
  123. package/build-module/border-box-control/border-box-control-split-controls/component.js +77 -0
  124. package/build-module/border-box-control/border-box-control-split-controls/component.js.map +1 -0
  125. package/build-module/border-box-control/border-box-control-split-controls/hook.js +30 -0
  126. package/build-module/border-box-control/border-box-control-split-controls/hook.js.map +1 -0
  127. package/build-module/border-box-control/border-box-control-split-controls/index.js +2 -0
  128. package/build-module/border-box-control/border-box-control-split-controls/index.js.map +1 -0
  129. package/build-module/border-box-control/border-box-control-visualizer/component.js +27 -0
  130. package/build-module/border-box-control/border-box-control-visualizer/component.js.map +1 -0
  131. package/build-module/border-box-control/border-box-control-visualizer/hook.js +28 -0
  132. package/build-module/border-box-control/border-box-control-visualizer/hook.js.map +1 -0
  133. package/build-module/border-box-control/border-box-control-visualizer/index.js +2 -0
  134. package/build-module/border-box-control/border-box-control-visualizer/index.js.map +1 -0
  135. package/build-module/border-box-control/index.js +4 -0
  136. package/build-module/border-box-control/index.js.map +1 -0
  137. package/build-module/border-box-control/styles.js +66 -0
  138. package/build-module/border-box-control/styles.js.map +1 -0
  139. package/build-module/border-box-control/types.js +2 -0
  140. package/build-module/border-box-control/types.js.map +1 -0
  141. package/build-module/border-box-control/utils.js +127 -0
  142. package/build-module/border-box-control/utils.js.map +1 -0
  143. package/build-module/border-control/border-control/component.js +100 -0
  144. package/build-module/border-control/border-control/component.js.map +1 -0
  145. package/build-module/border-control/border-control/hook.js +115 -0
  146. package/build-module/border-control/border-control/hook.js.map +1 -0
  147. package/build-module/border-control/border-control/index.js +3 -0
  148. package/build-module/border-control/border-control/index.js.map +1 -0
  149. package/build-module/border-control/border-control-dropdown/component.js +174 -0
  150. package/build-module/border-control/border-control-dropdown/component.js.map +1 -0
  151. package/build-module/border-control/border-control-dropdown/hook.js +89 -0
  152. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -0
  153. package/build-module/border-control/border-control-dropdown/index.js +2 -0
  154. package/build-module/border-control/border-control-dropdown/index.js.map +1 -0
  155. package/build-module/border-control/border-control-style-picker/component.js +81 -0
  156. package/build-module/border-control/border-control-style-picker/component.js.map +1 -0
  157. package/build-module/border-control/border-control-style-picker/hook.js +30 -0
  158. package/build-module/border-control/border-control-style-picker/hook.js.map +1 -0
  159. package/build-module/border-control/border-control-style-picker/index.js +2 -0
  160. package/build-module/border-control/border-control-style-picker/index.js.map +1 -0
  161. package/build-module/border-control/index.js +3 -0
  162. package/build-module/border-control/index.js.map +1 -0
  163. package/build-module/border-control/styles.js +90 -0
  164. package/build-module/border-control/styles.js.map +1 -0
  165. package/build-module/border-control/types.js +2 -0
  166. package/build-module/border-control/types.js.map +1 -0
  167. package/build-module/card/styles.js +23 -18
  168. package/build-module/card/styles.js.map +1 -1
  169. package/build-module/custom-select-control/index.js +4 -1
  170. package/build-module/custom-select-control/index.js.map +1 -1
  171. package/build-module/index.js +3 -1
  172. package/build-module/index.js.map +1 -1
  173. package/build-module/item-group/styles.js +14 -14
  174. package/build-module/item-group/styles.js.map +1 -1
  175. package/build-module/mobile/picker/index.android.js +0 -3
  176. package/build-module/mobile/picker/index.android.js.map +1 -1
  177. package/build-module/surface/styles.js +8 -8
  178. package/build-module/surface/styles.js.map +1 -1
  179. package/build-module/toggle-group-control/index.js +1 -0
  180. package/build-module/toggle-group-control/index.js.map +1 -1
  181. package/build-module/toggle-group-control/toggle-group-control/component.js +8 -1
  182. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  183. package/build-module/toggle-group-control/toggle-group-control/styles.js +11 -3
  184. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  185. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +86 -0
  186. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  187. package/build-module/toggle-group-control/toggle-group-control-option/component.js +9 -76
  188. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  189. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +105 -0
  190. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -0
  191. package/build-module/toggle-group-control/toggle-group-control-option-base/index.js +2 -0
  192. package/build-module/toggle-group-control/toggle-group-control-option-base/index.js.map +1 -0
  193. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +55 -0
  194. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -0
  195. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +50 -0
  196. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -0
  197. package/build-module/toggle-group-control/toggle-group-control-option-icon/index.js +2 -0
  198. package/build-module/toggle-group-control/toggle-group-control-option-icon/index.js.map +1 -0
  199. package/build-module/toolbar-dropdown-menu/index.js +1 -1
  200. package/build-module/toolbar-dropdown-menu/index.js.map +1 -1
  201. package/build-module/unit-control/index.js +7 -2
  202. package/build-module/unit-control/index.js.map +1 -1
  203. package/build-module/utils/colors-values.js +5 -3
  204. package/build-module/utils/colors-values.js.map +1 -1
  205. package/build-module/utils/config-values.js +8 -4
  206. package/build-module/utils/config-values.js.map +1 -1
  207. package/build-style/style-rtl.css +4 -1
  208. package/build-style/style.css +4 -1
  209. package/build-types/base-control/index.d.ts +35 -76
  210. package/build-types/base-control/index.d.ts.map +1 -1
  211. package/build-types/base-control/stories/index.d.ts +25 -0
  212. package/build-types/base-control/stories/index.d.ts.map +1 -0
  213. package/build-types/base-control/styles/base-control-styles.d.ts +6 -5
  214. package/build-types/base-control/styles/base-control-styles.d.ts.map +1 -1
  215. package/build-types/base-control/types.d.ts +41 -0
  216. package/build-types/base-control/types.d.ts.map +1 -0
  217. package/build-types/border-box-control/border-box-control/component.d.ts +4 -0
  218. package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -0
  219. package/build-types/border-box-control/border-box-control/hook.d.ts +282 -0
  220. package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -0
  221. package/build-types/border-box-control/border-box-control/index.d.ts +3 -0
  222. package/build-types/border-box-control/border-box-control/index.d.ts.map +1 -0
  223. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +4 -0
  224. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts.map +1 -0
  225. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +266 -0
  226. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts.map +1 -0
  227. package/build-types/border-box-control/border-box-control-linked-button/index.d.ts +2 -0
  228. package/build-types/border-box-control/border-box-control-linked-button/index.d.ts.map +1 -0
  229. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +4 -0
  230. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts.map +1 -0
  231. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +274 -0
  232. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -0
  233. package/build-types/border-box-control/border-box-control-split-controls/index.d.ts +2 -0
  234. package/build-types/border-box-control/border-box-control-split-controls/index.d.ts.map +1 -0
  235. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts +4 -0
  236. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts.map +1 -0
  237. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +266 -0
  238. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts.map +1 -0
  239. package/build-types/border-box-control/border-box-control-visualizer/index.d.ts +2 -0
  240. package/build-types/border-box-control/border-box-control-visualizer/index.d.ts.map +1 -0
  241. package/build-types/border-box-control/index.d.ts +4 -0
  242. package/build-types/border-box-control/index.d.ts.map +1 -0
  243. package/build-types/border-box-control/styles.d.ts +8 -0
  244. package/build-types/border-box-control/styles.d.ts.map +1 -0
  245. package/build-types/border-box-control/types.d.ts +91 -0
  246. package/build-types/border-box-control/types.d.ts.map +1 -0
  247. package/build-types/border-box-control/utils.d.ts +24 -0
  248. package/build-types/border-box-control/utils.d.ts.map +1 -0
  249. package/build-types/border-control/border-control/component.d.ts +4 -0
  250. package/build-types/border-control/border-control/component.d.ts.map +1 -0
  251. package/build-types/border-control/border-control/hook.d.ts +285 -0
  252. package/build-types/border-control/border-control/hook.d.ts.map +1 -0
  253. package/build-types/border-control/border-control/index.d.ts +3 -0
  254. package/build-types/border-control/border-control/index.d.ts.map +1 -0
  255. package/build-types/border-control/border-control-dropdown/component.d.ts +4 -0
  256. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -0
  257. package/build-types/border-control/border-control-dropdown/hook.d.ts +280 -0
  258. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -0
  259. package/build-types/border-control/border-control-dropdown/index.d.ts +2 -0
  260. package/build-types/border-control/border-control-dropdown/index.d.ts.map +1 -0
  261. package/build-types/border-control/border-control-style-picker/component.d.ts +4 -0
  262. package/build-types/border-control/border-control-style-picker/component.d.ts.map +1 -0
  263. package/build-types/border-control/border-control-style-picker/hook.d.ts +269 -0
  264. package/build-types/border-control/border-control-style-picker/hook.d.ts.map +1 -0
  265. package/build-types/border-control/border-control-style-picker/index.d.ts +2 -0
  266. package/build-types/border-control/border-control-style-picker/index.d.ts.map +1 -0
  267. package/build-types/border-control/index.d.ts +3 -0
  268. package/build-types/border-control/index.d.ts.map +1 -0
  269. package/build-types/border-control/styles.d.ts +18 -0
  270. package/build-types/border-control/styles.d.ts.map +1 -0
  271. package/build-types/border-control/types.d.ts +163 -0
  272. package/build-types/border-control/types.d.ts.map +1 -0
  273. package/build-types/card/styles.d.ts.map +1 -1
  274. package/build-types/color-indicator/index.d.ts +7 -0
  275. package/build-types/color-indicator/index.d.ts.map +1 -0
  276. package/build-types/item-group/styles.d.ts.map +1 -1
  277. package/build-types/toggle-group-control/index.d.ts +1 -0
  278. package/build-types/toggle-group-control/index.d.ts.map +1 -1
  279. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  280. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +5 -0
  281. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  282. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts +9 -0
  283. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts.map +1 -0
  284. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -2
  285. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
  286. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts +25 -0
  287. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -0
  288. package/build-types/toggle-group-control/toggle-group-control-option-base/index.d.ts +2 -0
  289. package/build-types/toggle-group-control/toggle-group-control-option-base/index.d.ts.map +1 -0
  290. package/build-types/toggle-group-control/{toggle-group-control-option → toggle-group-control-option-base}/styles.d.ts +0 -0
  291. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -0
  292. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +37 -0
  293. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -0
  294. package/build-types/toggle-group-control/toggle-group-control-option-icon/index.d.ts +2 -0
  295. package/build-types/toggle-group-control/toggle-group-control-option-icon/index.d.ts.map +1 -0
  296. package/build-types/toggle-group-control/types.d.ts +24 -8
  297. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  298. package/build-types/ui/form-group/form-group.d.ts +2 -2
  299. package/build-types/unit-control/index.d.ts +6 -2
  300. package/build-types/unit-control/index.d.ts.map +1 -1
  301. package/build-types/unit-control/types.d.ts +5 -1
  302. package/build-types/unit-control/types.d.ts.map +1 -1
  303. package/build-types/utils/colors-values.d.ts +78 -18
  304. package/build-types/utils/colors-values.d.ts.map +1 -1
  305. package/build-types/utils/config-values.d.ts +71 -71
  306. package/build-types/utils/config-values.d.ts.map +1 -1
  307. package/package.json +17 -17
  308. package/src/animate/README.md +1 -1
  309. package/src/base-control/README.md +11 -11
  310. package/src/base-control/index.tsx +124 -0
  311. package/src/base-control/stories/index.tsx +80 -0
  312. package/src/base-control/styles/{base-control-styles.js → base-control-styles.ts} +0 -0
  313. package/src/base-control/types.ts +42 -0
  314. package/src/border-box-control/border-box-control/README.md +178 -0
  315. package/src/border-box-control/border-box-control/component.tsx +123 -0
  316. package/src/border-box-control/border-box-control/hook.ts +119 -0
  317. package/src/border-box-control/border-box-control/index.ts +2 -0
  318. package/src/border-box-control/border-box-control-linked-button/component.tsx +50 -0
  319. package/src/border-box-control/border-box-control-linked-button/hook.ts +30 -0
  320. package/src/border-box-control/border-box-control-linked-button/index.ts +1 -0
  321. package/src/border-box-control/border-box-control-split-controls/component.tsx +90 -0
  322. package/src/border-box-control/border-box-control-split-controls/hook.ts +34 -0
  323. package/src/border-box-control/border-box-control-split-controls/index.ts +1 -0
  324. package/src/border-box-control/border-box-control-visualizer/component.tsx +28 -0
  325. package/src/border-box-control/border-box-control-visualizer/hook.ts +30 -0
  326. package/src/border-box-control/border-box-control-visualizer/index.ts +1 -0
  327. package/src/border-box-control/index.ts +3 -0
  328. package/src/border-box-control/stories/index.js +104 -0
  329. package/src/border-box-control/styles.ts +69 -0
  330. package/src/border-box-control/test/index.js +354 -0
  331. package/src/border-box-control/test/utils.js +305 -0
  332. package/src/border-box-control/types.ts +98 -0
  333. package/src/border-box-control/utils.ts +151 -0
  334. package/src/border-control/border-control/README.md +181 -0
  335. package/src/border-control/border-control/component.tsx +112 -0
  336. package/src/border-control/border-control/hook.ts +145 -0
  337. package/src/border-control/border-control/index.ts +2 -0
  338. package/src/border-control/border-control-dropdown/component.tsx +252 -0
  339. package/src/border-control/border-control-dropdown/hook.ts +98 -0
  340. package/src/border-control/border-control-dropdown/index.ts +1 -0
  341. package/src/border-control/border-control-style-picker/component.tsx +89 -0
  342. package/src/border-control/border-control-style-picker/hook.ts +34 -0
  343. package/src/border-control/border-control-style-picker/index.ts +1 -0
  344. package/src/border-control/index.ts +2 -0
  345. package/src/border-control/stories/index.js +118 -0
  346. package/src/border-control/styles.ts +190 -0
  347. package/src/border-control/test/index.js +436 -0
  348. package/src/border-control/types.ts +173 -0
  349. package/src/card/styles.js +11 -5
  350. package/src/card/test/__snapshots__/index.js.snap +83 -66
  351. package/src/card/test/index.js +7 -5
  352. package/src/color-palette/README.md +6 -0
  353. package/src/color-palette/stories/index.js +8 -1
  354. package/src/custom-select-control/index.js +7 -1
  355. package/src/custom-select-control/style.scss +5 -1
  356. package/src/disabled/README.md +7 -10
  357. package/src/flyout/test/__snapshots__/index.js.snap +7 -7
  358. package/src/form-toggle/README.md +1 -1
  359. package/src/index.js +8 -0
  360. package/src/item-group/styles.ts +1 -0
  361. package/src/item-group/test/__snapshots__/index.js.snap +11 -10
  362. package/src/mobile/picker/index.android.js +0 -1
  363. package/src/surface/styles.js +1 -1
  364. package/src/surface/test/__snapshots__/index.js.snap +11 -11
  365. package/src/toggle-group-control/index.ts +1 -0
  366. package/src/toggle-group-control/stories/index.js +37 -7
  367. package/src/toggle-group-control/test/__snapshots__/index.js.snap +269 -5
  368. package/src/toggle-group-control/test/index.js +43 -10
  369. package/src/toggle-group-control/toggle-group-control/component.tsx +10 -0
  370. package/src/toggle-group-control/toggle-group-control/styles.ts +14 -0
  371. package/src/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.tsx +86 -0
  372. package/src/toggle-group-control/toggle-group-control-option/README.md +8 -5
  373. package/src/toggle-group-control/toggle-group-control-option/component.tsx +18 -94
  374. package/src/toggle-group-control/toggle-group-control-option-base/README.md +27 -0
  375. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +129 -0
  376. package/src/toggle-group-control/toggle-group-control-option-base/index.ts +1 -0
  377. package/src/toggle-group-control/{toggle-group-control-option → toggle-group-control-option-base}/styles.ts +4 -1
  378. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +56 -0
  379. package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +56 -0
  380. package/src/toggle-group-control/toggle-group-control-option-icon/index.ts +1 -0
  381. package/src/toggle-group-control/types.ts +33 -8
  382. package/src/toolbar-dropdown-menu/index.js +1 -1
  383. package/src/tools-panel/test/__snapshots__/index.js.snap +8 -8
  384. package/src/unit-control/README.md +6 -0
  385. package/src/unit-control/index.tsx +6 -1
  386. package/src/unit-control/test/index.js +120 -0
  387. package/src/unit-control/types.ts +5 -1
  388. package/src/utils/colors-values.js +4 -3
  389. package/src/utils/config-values.js +9 -4
  390. package/tsconfig.json +3 -0
  391. package/tsconfig.tsbuildinfo +1 -1
  392. package/build/toggle-group-control/toggle-group-control-option/styles.js +0 -66
  393. package/build/toggle-group-control/toggle-group-control-option/styles.js.map +0 -1
  394. package/build-module/toggle-group-control/toggle-group-control-option/styles.js +0 -55
  395. package/build-module/toggle-group-control/toggle-group-control-option/styles.js.map +0 -1
  396. package/build-types/toggle-group-control/toggle-group-control-option/styles.d.ts.map +0 -1
  397. package/src/base-control/index.js +0 -118
  398. package/src/base-control/stories/index.js +0 -81
@@ -0,0 +1,98 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useMemo } from '@wordpress/element';
5
+
6
+ /**
7
+ * Internal dependencies
8
+ */
9
+ import * as styles from '../styles';
10
+ import { parseQuantityAndUnitFromRawValue } from '../../unit-control/utils';
11
+ import { useContextSystem, WordPressComponentProps } from '../../ui/context';
12
+ import { useCx } from '../../utils/hooks/use-cx';
13
+
14
+ import type { DropdownProps } from '../types';
15
+
16
+ export function useBorderControlDropdown(
17
+ props: WordPressComponentProps< DropdownProps, 'div' >
18
+ ) {
19
+ const {
20
+ border,
21
+ className,
22
+ colors,
23
+ contentClassName,
24
+ onChange,
25
+ previousStyleSelection,
26
+ ...otherProps
27
+ } = useContextSystem( props, 'BorderControlDropdown' );
28
+
29
+ const [ widthValue ] = parseQuantityAndUnitFromRawValue( border?.width );
30
+ const hasZeroWidth = widthValue === 0;
31
+
32
+ const onColorChange = ( color?: string ) => {
33
+ const style =
34
+ border?.style === 'none' ? previousStyleSelection : border?.style;
35
+ const width = hasZeroWidth && !! color ? '1px' : border?.width;
36
+
37
+ onChange( { color, style, width } );
38
+ };
39
+
40
+ const onStyleChange = ( style?: string ) => {
41
+ const width = hasZeroWidth && !! style ? '1px' : border?.width;
42
+ onChange( { ...border, style, width } );
43
+ };
44
+
45
+ const onReset = () => {
46
+ onChange( {
47
+ ...border,
48
+ color: undefined,
49
+ style: undefined,
50
+ } );
51
+ };
52
+
53
+ // Generate class names.
54
+ const cx = useCx();
55
+ const classes = useMemo( () => {
56
+ return cx( styles.borderControlDropdown(), className );
57
+ }, [ className, cx ] );
58
+
59
+ const indicatorClassName = useMemo( () => {
60
+ return cx( styles.borderColorIndicator );
61
+ }, [ cx ] );
62
+
63
+ const indicatorWrapperClassName = useMemo( () => {
64
+ return cx( styles.colorIndicatorWrapper( border ) );
65
+ }, [ border, cx ] );
66
+
67
+ const popoverClassName = useMemo( () => {
68
+ return cx( styles.borderControlPopover, contentClassName );
69
+ }, [ cx, contentClassName ] );
70
+
71
+ const popoverControlsClassName = useMemo( () => {
72
+ return cx( styles.borderControlPopoverControls );
73
+ }, [ cx ] );
74
+
75
+ const popoverContentClassName = useMemo( () => {
76
+ return cx( styles.borderControlPopoverContent );
77
+ }, [ cx ] );
78
+
79
+ const resetButtonClassName = useMemo( () => {
80
+ return cx( styles.resetButton );
81
+ }, [ cx ] );
82
+
83
+ return {
84
+ ...otherProps,
85
+ border,
86
+ className: classes,
87
+ colors,
88
+ indicatorClassName,
89
+ indicatorWrapperClassName,
90
+ onColorChange,
91
+ onStyleChange,
92
+ onReset,
93
+ popoverClassName,
94
+ popoverContentClassName,
95
+ popoverControlsClassName,
96
+ resetButtonClassName,
97
+ };
98
+ }
@@ -0,0 +1 @@
1
+ export { default } from './component';
@@ -0,0 +1,89 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { lineDashed, lineDotted, lineSolid } from '@wordpress/icons';
5
+ import { __ } from '@wordpress/i18n';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import Button from '../../button';
11
+ import { StyledLabel } from '../../base-control/styles/base-control-styles';
12
+ import { View } from '../../view';
13
+ import { Flex } from '../../flex';
14
+ import { VisuallyHidden } from '../../visually-hidden';
15
+ import { contextConnect, WordPressComponentProps } from '../../ui/context';
16
+ import { useBorderControlStylePicker } from './hook';
17
+
18
+ import type { LabelProps, StylePickerProps } from '../types';
19
+
20
+ const BORDER_STYLES = [
21
+ { label: __( 'Solid' ), icon: lineSolid, value: 'solid' },
22
+ { label: __( 'Dashed' ), icon: lineDashed, value: 'dashed' },
23
+ { label: __( 'Dotted' ), icon: lineDotted, value: 'dotted' },
24
+ ];
25
+
26
+ const Label = ( props: LabelProps ) => {
27
+ const { label, hideLabelFromVision } = props;
28
+
29
+ if ( ! label ) {
30
+ return null;
31
+ }
32
+
33
+ return hideLabelFromVision ? (
34
+ <VisuallyHidden as="label">{ label }</VisuallyHidden>
35
+ ) : (
36
+ <StyledLabel>{ label }</StyledLabel>
37
+ );
38
+ };
39
+
40
+ const BorderControlStylePicker = (
41
+ props: WordPressComponentProps< StylePickerProps, 'div' >,
42
+ forwardedRef: React.ForwardedRef< any >
43
+ ) => {
44
+ const {
45
+ buttonClassName,
46
+ hideLabelFromVision,
47
+ label,
48
+ onChange,
49
+ value,
50
+ ...otherProps
51
+ } = useBorderControlStylePicker( props );
52
+
53
+ return (
54
+ <View { ...otherProps } ref={ forwardedRef }>
55
+ <Label
56
+ label={ label }
57
+ hideLabelFromVision={ hideLabelFromVision }
58
+ />
59
+ <Flex justify="flex-start" gap={ 1 }>
60
+ { BORDER_STYLES.map( ( borderStyle ) => (
61
+ <Button
62
+ key={ borderStyle.value }
63
+ className={ buttonClassName }
64
+ icon={ borderStyle.icon }
65
+ isSmall
66
+ isPressed={ borderStyle.value === value }
67
+ onClick={ () =>
68
+ onChange(
69
+ borderStyle.value === value
70
+ ? undefined
71
+ : borderStyle.value
72
+ )
73
+ }
74
+ aria-label={ borderStyle.label }
75
+ label={ borderStyle.label }
76
+ showTooltip={ true }
77
+ />
78
+ ) ) }
79
+ </Flex>
80
+ </View>
81
+ );
82
+ };
83
+
84
+ const ConnectedBorderControlStylePicker = contextConnect(
85
+ BorderControlStylePicker,
86
+ 'BorderControlStylePicker'
87
+ );
88
+
89
+ export default ConnectedBorderControlStylePicker;
@@ -0,0 +1,34 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useMemo } from '@wordpress/element';
5
+
6
+ /**
7
+ * Internal dependencies
8
+ */
9
+ import * as styles from '../styles';
10
+ import { useContextSystem, WordPressComponentProps } from '../../ui/context';
11
+ import { useCx } from '../../utils/hooks/use-cx';
12
+
13
+ import type { StylePickerProps } from '../types';
14
+
15
+ export function useBorderControlStylePicker(
16
+ props: WordPressComponentProps< StylePickerProps, 'div' >
17
+ ) {
18
+ const { className, ...otherProps } = useContextSystem(
19
+ props,
20
+ 'BorderControlStylePicker'
21
+ );
22
+
23
+ // Generate class names.
24
+ const cx = useCx();
25
+ const classes = useMemo( () => {
26
+ return cx( styles.borderControlStylePicker, className );
27
+ }, [ className, cx ] );
28
+
29
+ const buttonClassName = useMemo( () => {
30
+ return cx( styles.borderStyleButton );
31
+ }, [ cx ] );
32
+
33
+ return { ...otherProps, className: classes, buttonClassName };
34
+ }
@@ -0,0 +1 @@
1
+ export { default } from './component';
@@ -0,0 +1,2 @@
1
+ export { default as BorderControl } from './border-control/component';
2
+ export { useBorderControl } from './border-control/hook';
@@ -0,0 +1,118 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import styled from '@emotion/styled';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { useState } from '@wordpress/element';
10
+
11
+ /**
12
+ * Internal dependencies
13
+ */
14
+ import { BorderControl } from '../';
15
+ import { Provider as SlotFillProvider } from '../../slot-fill';
16
+ import Popover from '../../popover';
17
+
18
+ export default {
19
+ title: 'Components (Experimental)/BorderControl',
20
+ component: BorderControl,
21
+ };
22
+
23
+ // Available border colors.
24
+ const colors = [
25
+ { name: 'Gray 0', color: '#f6f7f7' },
26
+ { name: 'Gray 5', color: '#dcdcde' },
27
+ { name: 'Gray 20', color: '#a7aaad' },
28
+ { name: 'Gray 70', color: '#3c434a' },
29
+ { name: 'Gray 100', color: '#101517' },
30
+ { name: 'Blue 20', color: '#72aee6' },
31
+ { name: 'Blue 40', color: '#3582c4' },
32
+ { name: 'Blue 70', color: '#0a4b78' },
33
+ { name: 'Red 40', color: '#e65054' },
34
+ { name: 'Red 70', color: '#8a2424' },
35
+ { name: 'Green 10', color: '#68de7c' },
36
+ { name: 'Green 40', color: '#00a32a' },
37
+ { name: 'Green 60', color: '#007017' },
38
+ { name: 'Yellow 10', color: '#f2d675' },
39
+ { name: 'Yellow 40', color: '#bd8600' },
40
+ ];
41
+
42
+ // Multiple origin colors.
43
+ const multipleOriginColors = [
44
+ {
45
+ name: 'Default',
46
+ colors: [
47
+ { name: 'Gray 0', color: '#f6f7f7' },
48
+ { name: 'Gray 5', color: '#dcdcde' },
49
+ { name: 'Gray 20', color: '#a7aaad' },
50
+ { name: 'Gray 70', color: '#3c434a' },
51
+ { name: 'Gray 100', color: '#101517' },
52
+ ],
53
+ },
54
+ {
55
+ name: 'Theme',
56
+ colors: [
57
+ { name: 'Blue 20', color: '#72aee6' },
58
+ { name: 'Blue 40', color: '#3582c4' },
59
+ { name: 'Blue 70', color: '#0a4b78' },
60
+ { name: 'Red 40', color: '#e65054' },
61
+ { name: 'Red 70', color: '#8a2424' },
62
+ ],
63
+ },
64
+ {
65
+ name: 'User',
66
+ colors: [
67
+ { name: 'Green 10', color: '#68de7c' },
68
+ { name: 'Green 40', color: '#00a32a' },
69
+ { name: 'Green 60', color: '#007017' },
70
+ { name: 'Yellow 10', color: '#f2d675' },
71
+ { name: 'Yellow 40', color: '#bd8600' },
72
+ ],
73
+ },
74
+ ];
75
+
76
+ const _default = ( props ) => {
77
+ const [ border, setBorder ] = useState();
78
+ const onChange = ( newBorder ) => setBorder( newBorder );
79
+ const { __experimentalHasMultipleOrigins } = props;
80
+
81
+ return (
82
+ <SlotFillProvider>
83
+ <WrapperView>
84
+ <BorderControl
85
+ { ...props }
86
+ colors={
87
+ __experimentalHasMultipleOrigins
88
+ ? multipleOriginColors
89
+ : colors
90
+ }
91
+ label="Border"
92
+ onChange={ onChange }
93
+ value={ border }
94
+ width={ ! props.isCompact && props.width }
95
+ />
96
+ </WrapperView>
97
+ <Popover.Slot />
98
+ </SlotFillProvider>
99
+ );
100
+ };
101
+
102
+ export const Default = _default.bind( {} );
103
+ Default.args = {
104
+ disableCustomColors: false,
105
+ enableAlpha: true,
106
+ enableStyle: true,
107
+ isCompact: true,
108
+ shouldSanitizeBorder: true,
109
+ showDropdownHeader: false,
110
+ width: '110px',
111
+ withSlider: true,
112
+ __experimentalIsRenderedInSidebar: false,
113
+ __experimentalHasMultipleOrigins: false,
114
+ };
115
+
116
+ const WrapperView = styled.div`
117
+ max-width: 280px;
118
+ `;
@@ -0,0 +1,190 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { css } from '@emotion/react';
5
+ import type { CSSProperties } from 'react';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import { COLORS, CONFIG, rtl } from '../utils';
11
+ import { space } from '../ui/utils/space';
12
+ import {
13
+ StyledField,
14
+ StyledLabel,
15
+ } from '../base-control/styles/base-control-styles';
16
+ import { BackdropUI } from '../input-control/styles/input-control-styles';
17
+ import { Root as UnitControlWrapper } from '../unit-control/styles/unit-control-styles';
18
+
19
+ import type { Border } from './types';
20
+
21
+ const labelStyles = css`
22
+ font-weight: 500;
23
+ `;
24
+
25
+ export const borderControl = css`
26
+ position: relative;
27
+ `;
28
+
29
+ export const innerWrapper = () => css`
30
+ border: ${ CONFIG.borderWidth } solid ${ COLORS.gray[ 200 ] };
31
+ border-radius: 2px;
32
+ flex: 1 0 40%;
33
+
34
+ /*
35
+ * Needs more thought. Aim is to prevent the border for BorderBoxControl
36
+ * showing through the control. Likely needs to take into account
37
+ * light/dark themes etc.
38
+ */
39
+ background: #fff;
40
+
41
+ /*
42
+ * Forces the width control to fill available space given UnitControl
43
+ * passes its className directly through to the input.
44
+ */
45
+ ${ UnitControlWrapper } {
46
+ flex: 1;
47
+ ${ rtl( { marginLeft: 0 } )() }
48
+ }
49
+ `;
50
+
51
+ export const wrapperWidth = ( width: CSSProperties[ 'width' ] ) => {
52
+ return css`
53
+ width: ${ width };
54
+ flex: 0 0 auto;
55
+ `;
56
+ };
57
+
58
+ export const borderControlDropdown = () => css`
59
+ background: #fff;
60
+ ${ rtl(
61
+ {
62
+ borderRadius: `1px 0 0 1px`,
63
+ borderRight: `${ CONFIG.borderWidth } solid ${ COLORS.gray[ 200 ] }`,
64
+ },
65
+ {
66
+ borderRadius: `0 1px 1px 0`,
67
+ borderLeft: `${ CONFIG.borderWidth } solid ${ COLORS.gray[ 200 ] }`,
68
+ }
69
+ )() }
70
+
71
+ && > button {
72
+ padding: ${ space( 1 ) };
73
+ border-radius: inherit;
74
+ }
75
+ `;
76
+
77
+ export const colorIndicatorBorder = ( border?: Border ) => {
78
+ const { color, style } = border || {};
79
+
80
+ const fallbackColor =
81
+ !! style && style !== 'none' ? COLORS.gray[ 300 ] : undefined;
82
+
83
+ return css`
84
+ border-style: ${ style === 'none' ? 'solid' : style };
85
+ border-color: ${ color || fallbackColor };
86
+ `;
87
+ };
88
+
89
+ export const colorIndicatorWrapper = ( border?: Border ) => {
90
+ const { style } = border || {};
91
+
92
+ return css`
93
+ border-radius: 9999px;
94
+ border: 2px solid transparent;
95
+ ${ style ? colorIndicatorBorder( border ) : undefined }
96
+ width: 28px;
97
+ height: 28px;
98
+ padding: 2px;
99
+
100
+ /*
101
+ * ColorIndicator
102
+ *
103
+ * The transparent colors used here ensure visibility of the indicator
104
+ * over the active state of the border control dropdown's toggle button.
105
+ */
106
+ & > span {
107
+ background: linear-gradient(
108
+ -45deg,
109
+ transparent 48%,
110
+ rgb( 0 0 0 / 20% ) 48%,
111
+ rgb( 0 0 0 / 20% ) 52%,
112
+ transparent 52%
113
+ );
114
+ }
115
+ `;
116
+ };
117
+
118
+ export const borderControlPopover = css`
119
+ /* Remove padding from content, this will be re-added via inner elements*/
120
+ && > div > div {
121
+ padding: 0;
122
+ }
123
+ `;
124
+
125
+ export const borderControlPopoverControls = css`
126
+ padding: ${ space( 2 ) };
127
+
128
+ > div:first-of-type > ${ StyledLabel } {
129
+ margin-bottom: 0;
130
+ ${ labelStyles }
131
+ }
132
+
133
+ && ${ StyledLabel } + button:not( .has-text ) {
134
+ min-width: 24px;
135
+ padding: 0;
136
+ }
137
+ `;
138
+
139
+ export const borderControlPopoverContent = css``;
140
+ export const borderColorIndicator = css``;
141
+
142
+ export const resetButton = css`
143
+ justify-content: center;
144
+ width: 100%;
145
+
146
+ /* Override button component styling */
147
+ && {
148
+ border-top: ${ CONFIG.borderWidth } solid ${ COLORS.gray[ 200 ] };
149
+ height: 46px;
150
+ }
151
+ `;
152
+
153
+ export const borderWidthControl = () => css`
154
+ /* Target the InputControl's backdrop */
155
+ &&& ${ BackdropUI } {
156
+ border: none;
157
+ }
158
+
159
+ /* Specificity required to overcome UnitControl padding */
160
+ /* See packages/components/src/unit-control/styles/unit-control-styles.ts */
161
+ &&& input {
162
+ ${ rtl( { paddingRight: 0 } )() }
163
+ }
164
+ `;
165
+
166
+ export const borderControlStylePicker = css`
167
+ ${ StyledLabel } {
168
+ ${ labelStyles }
169
+ }
170
+ `;
171
+
172
+ export const borderStyleButton = css`
173
+ &&&&& {
174
+ min-width: 30px;
175
+ width: 30px;
176
+ height: 30px;
177
+ padding: 3px;
178
+ }
179
+ `;
180
+
181
+ export const borderSlider = () => css`
182
+ flex: 1 1 60%;
183
+ ${ rtl( { marginRight: space( 3 ) } )() }
184
+
185
+ ${ StyledField } {
186
+ margin-bottom: 0;
187
+ font-size: 0;
188
+ display: flex;
189
+ }
190
+ `;