@wordpress/components 19.14.0 → 19.17.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 (1156) hide show
  1. package/CHANGELOG.md +138 -12
  2. package/build/angle-picker-control/index.js +2 -2
  3. package/build/angle-picker-control/index.js.map +1 -1
  4. package/build/autocomplete/get-default-use-items.js +5 -1
  5. package/build/autocomplete/get-default-use-items.js.map +1 -1
  6. package/build/autocomplete/index.js +5 -1
  7. package/build/autocomplete/index.js.map +1 -1
  8. package/build/base-control/index.js +6 -3
  9. package/build/base-control/index.js.map +1 -1
  10. package/build/base-control/styles/base-control-styles.js +8 -8
  11. package/build/base-control/styles/base-control-styles.js.map +1 -1
  12. package/build/border-control/border-control/component.js +38 -25
  13. package/build/border-control/border-control/component.js.map +1 -1
  14. package/build/border-control/border-control/hook.js +4 -7
  15. package/build/border-control/border-control/hook.js.map +1 -1
  16. package/build/border-control/border-control-dropdown/component.js +13 -7
  17. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  18. package/build/border-control/border-control-dropdown/hook.js +0 -4
  19. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  20. package/build/border-control/styles.js +29 -60
  21. package/build/border-control/styles.js.map +1 -1
  22. package/build/box-control/all-input-control.js +2 -27
  23. package/build/box-control/all-input-control.js.map +1 -1
  24. package/build/box-control/axial-input-controls.js +1 -1
  25. package/build/box-control/axial-input-controls.js.map +1 -1
  26. package/build/box-control/index.js +11 -6
  27. package/build/box-control/index.js.map +1 -1
  28. package/build/box-control/styles/box-control-styles.js +17 -9
  29. package/build/box-control/styles/box-control-styles.js.map +1 -1
  30. package/build/box-control/utils.js +37 -8
  31. package/build/box-control/utils.js.map +1 -1
  32. package/build/color-palette/index.js +14 -2
  33. package/build/color-palette/index.js.map +1 -1
  34. package/build/color-picker/hex-input.js +7 -5
  35. package/build/color-picker/hex-input.js.map +1 -1
  36. package/build/color-picker/index.native.js +35 -34
  37. package/build/color-picker/index.native.js.map +1 -1
  38. package/build/color-picker/input-with-slider.js +6 -3
  39. package/build/color-picker/input-with-slider.js.map +1 -1
  40. package/build/color-picker/styles.js +33 -50
  41. package/build/color-picker/styles.js.map +1 -1
  42. package/build/color-picker/use-deprecated-props.js +22 -31
  43. package/build/color-picker/use-deprecated-props.js.map +1 -1
  44. package/build/combobox-control/index.js +33 -19
  45. package/build/combobox-control/index.js.map +1 -1
  46. package/build/combobox-control/styles.js +39 -0
  47. package/build/combobox-control/styles.js.map +1 -0
  48. package/build/custom-select-control/index.js +29 -9
  49. package/build/custom-select-control/index.js.map +1 -1
  50. package/build/date-time/time/index.js +6 -2
  51. package/build/date-time/time/index.js.map +1 -1
  52. package/build/date-time/time/styles.js +17 -24
  53. package/build/date-time/time/styles.js.map +1 -1
  54. package/build/divider/component.js +0 -1
  55. package/build/divider/component.js.map +1 -1
  56. package/build/divider/index.js.map +1 -1
  57. package/build/divider/styles.js +5 -5
  58. package/build/divider/styles.js.map +1 -1
  59. package/build/dropdown/dropdown-content-wrapper.js +60 -0
  60. package/build/dropdown/dropdown-content-wrapper.js.map +1 -0
  61. package/build/dropdown/styles.js +42 -0
  62. package/build/dropdown/styles.js.map +1 -0
  63. package/build/dropdown/types.js +6 -0
  64. package/build/dropdown/types.js.map +1 -0
  65. package/build/dropdown-menu/index.js +5 -5
  66. package/build/dropdown-menu/index.js.map +1 -1
  67. package/build/dropdown-menu/index.native.js +5 -5
  68. package/build/dropdown-menu/index.native.js.map +1 -1
  69. package/build/elevation/component.js +15 -15
  70. package/build/elevation/component.js.map +1 -1
  71. package/build/elevation/hook.js +6 -18
  72. package/build/elevation/hook.js.map +1 -1
  73. package/build/elevation/index.js.map +1 -1
  74. package/build/elevation/styles.js +1 -1
  75. package/build/elevation/styles.js.map +1 -1
  76. package/build/external-link/index.js +7 -3
  77. package/build/external-link/index.js.map +1 -1
  78. package/build/flex/flex/component.js +20 -26
  79. package/build/flex/flex/component.js.map +1 -1
  80. package/build/flex/flex/hook.js +6 -16
  81. package/build/flex/flex/hook.js.map +1 -1
  82. package/build/flex/flex/index.js.map +1 -1
  83. package/build/flex/flex-block/component.js +18 -12
  84. package/build/flex/flex-block/component.js.map +1 -1
  85. package/build/flex/flex-block/hook.js +0 -4
  86. package/build/flex/flex-block/hook.js.map +1 -1
  87. package/build/flex/flex-block/index.js.map +1 -1
  88. package/build/flex/flex-item/component.js +18 -12
  89. package/build/flex/flex-item/component.js.map +1 -1
  90. package/build/flex/flex-item/hook.js +1 -5
  91. package/build/flex/flex-item/hook.js.map +1 -1
  92. package/build/flex/flex-item/index.js.map +1 -1
  93. package/build/flex/index.js.map +1 -1
  94. package/build/flex/styles.js +5 -5
  95. package/build/flex/styles.js.map +1 -1
  96. package/build/focal-point-picker/grid.js +2 -7
  97. package/build/focal-point-picker/grid.js.map +1 -1
  98. package/build/focal-point-picker/index.native.js +8 -8
  99. package/build/focal-point-picker/index.native.js.map +1 -1
  100. package/build/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  101. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  102. package/build/focal-point-picker/styles/focal-point-style.js +5 -5
  103. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  104. package/build/focal-point-picker/tooltip/index.native.js +11 -12
  105. package/build/focal-point-picker/tooltip/index.native.js.map +1 -1
  106. package/build/font-size-picker/index.js +15 -6
  107. package/build/font-size-picker/index.js.map +1 -1
  108. package/build/form-token-field/index.js +28 -9
  109. package/build/form-token-field/index.js.map +1 -1
  110. package/build/form-token-field/styles.js +40 -0
  111. package/build/form-token-field/styles.js.map +1 -0
  112. package/build/form-token-field/suggestions-list.js +21 -13
  113. package/build/form-token-field/suggestions-list.js.map +1 -1
  114. package/build/grid/component.js +7 -8
  115. package/build/grid/component.js.map +1 -1
  116. package/build/grid/hook.js +1 -5
  117. package/build/grid/hook.js.map +1 -1
  118. package/build/grid/index.js.map +1 -1
  119. package/build/grid/utils.js +4 -7
  120. package/build/grid/utils.js.map +1 -1
  121. package/build/h-stack/component.js +5 -9
  122. package/build/h-stack/component.js.map +1 -1
  123. package/build/h-stack/hook.js +8 -10
  124. package/build/h-stack/hook.js.map +1 -1
  125. package/build/h-stack/index.js.map +1 -1
  126. package/build/h-stack/utils.js +7 -18
  127. package/build/h-stack/utils.js.map +1 -1
  128. package/build/icon/index.js.map +1 -1
  129. package/build/index.js +31 -1
  130. package/build/index.js.map +1 -1
  131. package/build/input-control/index.js +7 -0
  132. package/build/input-control/index.js.map +1 -1
  133. package/build/input-control/input-base.js +24 -3
  134. package/build/input-control/input-base.js.map +1 -1
  135. package/build/input-control/input-prefix-wrapper.js +54 -0
  136. package/build/input-control/input-prefix-wrapper.js.map +1 -0
  137. package/build/input-control/input-suffix-wrapper.js +54 -0
  138. package/build/input-control/input-suffix-wrapper.js.map +1 -0
  139. package/build/input-control/reducer/actions.js +3 -1
  140. package/build/input-control/reducer/actions.js.map +1 -1
  141. package/build/input-control/reducer/reducer.js +28 -11
  142. package/build/input-control/reducer/reducer.js.map +1 -1
  143. package/build/input-control/reducer/state.js.map +1 -1
  144. package/build/input-control/styles/input-control-styles.js +61 -42
  145. package/build/input-control/styles/input-control-styles.js.map +1 -1
  146. package/build/menu-item/index.js +1 -3
  147. package/build/menu-item/index.js.map +1 -1
  148. package/build/mobile/focal-point-settings-panel/index.native.js +1 -1
  149. package/build/mobile/focal-point-settings-panel/index.native.js.map +1 -1
  150. package/build/mobile/global-styles-context/utils.native.js +23 -3
  151. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  152. package/build/mobile/image/index.native.js +31 -5
  153. package/build/mobile/image/index.native.js.map +1 -1
  154. package/build/mobile/link-picker/link-picker-screen.native.js +10 -4
  155. package/build/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  156. package/build/mobile/media-edit/index.native.js +1 -7
  157. package/build/mobile/media-edit/index.native.js.map +1 -1
  158. package/build/mobile/picker/index.ios.js +16 -3
  159. package/build/mobile/picker/index.ios.js.map +1 -1
  160. package/build/modal/index.js +17 -3
  161. package/build/modal/index.js.map +1 -1
  162. package/build/navigation/index.js +4 -1
  163. package/build/navigation/index.js.map +1 -1
  164. package/build/navigation/item/base.js +3 -0
  165. package/build/navigation/item/base.js.map +1 -1
  166. package/build/placeholder/index.js +11 -14
  167. package/build/placeholder/index.js.map +1 -1
  168. package/build/placeholder/types.js +6 -0
  169. package/build/placeholder/types.js.map +1 -0
  170. package/build/popover/index.js +129 -75
  171. package/build/popover/index.js.map +1 -1
  172. package/build/radio-control/index.js +1 -3
  173. package/build/radio-control/index.js.map +1 -1
  174. package/build/range-control/index.js +54 -40
  175. package/build/range-control/index.js.map +1 -1
  176. package/build/range-control/input-range.js +5 -7
  177. package/build/range-control/input-range.js.map +1 -1
  178. package/build/range-control/mark.js +5 -7
  179. package/build/range-control/mark.js.map +1 -1
  180. package/build/range-control/rail.js +10 -16
  181. package/build/range-control/rail.js.map +1 -1
  182. package/build/range-control/styles/range-control-styles.js +74 -74
  183. package/build/range-control/styles/range-control-styles.js.map +1 -1
  184. package/build/range-control/tooltip.js +5 -7
  185. package/build/range-control/tooltip.js.map +1 -1
  186. package/build/range-control/types.js +6 -0
  187. package/build/range-control/types.js.map +1 -0
  188. package/build/range-control/utils.js +23 -30
  189. package/build/range-control/utils.js.map +1 -1
  190. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  191. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  192. package/build/resizable-box/resize-tooltip/utils.js +2 -7
  193. package/build/resizable-box/resize-tooltip/utils.js.map +1 -1
  194. package/build/sandbox/index.native.js +13 -2
  195. package/build/sandbox/index.native.js.map +1 -1
  196. package/build/scroll-lock/index.js +35 -6
  197. package/build/scroll-lock/index.js.map +1 -1
  198. package/build/scrollable/component.js +7 -8
  199. package/build/scrollable/component.js.map +1 -1
  200. package/build/scrollable/hook.js +0 -8
  201. package/build/scrollable/hook.js.map +1 -1
  202. package/build/scrollable/index.js.map +1 -1
  203. package/build/scrollable/styles.js +7 -7
  204. package/build/scrollable/styles.js.map +1 -1
  205. package/build/select-control/index.js +1 -3
  206. package/build/select-control/index.js.map +1 -1
  207. package/build/select-control/styles/select-control-styles.js +32 -12
  208. package/build/select-control/styles/select-control-styles.js.map +1 -1
  209. package/build/shortcut/index.js +6 -21
  210. package/build/shortcut/index.js.map +1 -1
  211. package/build/shortcut/types.js +6 -0
  212. package/build/shortcut/types.js.map +1 -0
  213. package/build/slot-fill/index.native.js +6 -8
  214. package/build/slot-fill/index.native.js.map +1 -1
  215. package/build/slot-fill/provider.js +4 -8
  216. package/build/slot-fill/provider.js.map +1 -1
  217. package/build/slot-fill/slot.js +4 -8
  218. package/build/slot-fill/slot.js.map +1 -1
  219. package/build/spacer/component.js +3 -1
  220. package/build/spacer/component.js.map +1 -1
  221. package/build/spacer/hook.js +2 -2
  222. package/build/spacer/hook.js.map +1 -1
  223. package/build/spacer/index.js.map +1 -1
  224. package/build/style-provider/index.js +10 -7
  225. package/build/style-provider/index.js.map +1 -1
  226. package/build/style-provider/types.js +6 -0
  227. package/build/style-provider/types.js.map +1 -0
  228. package/build/swatch/index.js +2 -0
  229. package/build/swatch/index.js.map +1 -1
  230. package/build/swatch/types.js +6 -0
  231. package/build/swatch/types.js.map +1 -0
  232. package/build/text/hook.js +5 -8
  233. package/build/text/hook.js.map +1 -1
  234. package/build/text-highlight/index.js +22 -5
  235. package/build/text-highlight/index.js.map +1 -1
  236. package/build/text-highlight/types.js +6 -0
  237. package/build/text-highlight/types.js.map +1 -0
  238. package/build/tip/index.js +5 -11
  239. package/build/tip/index.js.map +1 -1
  240. package/build/tip/types.js +6 -0
  241. package/build/tip/types.js.map +1 -0
  242. package/build/toggle-group-control/toggle-group-control/component.js +4 -1
  243. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  244. package/build/toggle-group-control/toggle-group-control/styles.js +20 -4
  245. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  246. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +7 -9
  247. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  248. package/build/toolbar-group/index.js +3 -3
  249. package/build/toolbar-group/index.js.map +1 -1
  250. package/build/tools-panel/styles.js +13 -10
  251. package/build/tools-panel/styles.js.map +1 -1
  252. package/build/tools-panel/tools-panel/hook.js +1 -1
  253. package/build/tools-panel/tools-panel/hook.js.map +1 -1
  254. package/build/tooltip/index.js +51 -14
  255. package/build/tooltip/index.js.map +1 -1
  256. package/build/tree-select/index.js +4 -4
  257. package/build/tree-select/index.js.map +1 -1
  258. package/build/ui/context/use-context-system.js +7 -2
  259. package/build/ui/context/use-context-system.js.map +1 -1
  260. package/build/ui/tooltip/styles.js +4 -4
  261. package/build/ui/tooltip/styles.js.map +1 -1
  262. package/build/ui/utils/get-valid-children.js.map +1 -1
  263. package/build/ui/utils/space.js +7 -1
  264. package/build/ui/utils/space.js.map +1 -1
  265. package/build/unit-control/styles/unit-control-styles.js +38 -29
  266. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  267. package/build/utils/base-label.js +24 -0
  268. package/build/utils/base-label.js.map +1 -0
  269. package/build/utils/box-sizing.js +22 -0
  270. package/build/utils/box-sizing.js.map +1 -0
  271. package/build/utils/style-mixins.js +16 -0
  272. package/build/utils/style-mixins.js.map +1 -1
  273. package/build/visually-hidden/component.js +12 -13
  274. package/build/visually-hidden/component.js.map +1 -1
  275. package/build/visually-hidden/index.js.map +1 -1
  276. package/build/visually-hidden/styles.js +3 -1
  277. package/build/visually-hidden/styles.js.map +1 -1
  278. package/build/visually-hidden/types.js +6 -0
  279. package/build/visually-hidden/types.js.map +1 -0
  280. package/build-module/angle-picker-control/index.js +2 -2
  281. package/build-module/angle-picker-control/index.js.map +1 -1
  282. package/build-module/autocomplete/get-default-use-items.js +3 -2
  283. package/build-module/autocomplete/get-default-use-items.js.map +1 -1
  284. package/build-module/autocomplete/index.js +3 -2
  285. package/build-module/autocomplete/index.js.map +1 -1
  286. package/build-module/base-control/index.js +7 -5
  287. package/build-module/base-control/index.js.map +1 -1
  288. package/build-module/base-control/styles/base-control-styles.js +9 -9
  289. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  290. package/build-module/border-control/border-control/component.js +37 -25
  291. package/build-module/border-control/border-control/component.js.map +1 -1
  292. package/build-module/border-control/border-control/hook.js +4 -7
  293. package/build-module/border-control/border-control/hook.js.map +1 -1
  294. package/build-module/border-control/border-control-dropdown/component.js +12 -7
  295. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  296. package/build-module/border-control/border-control-dropdown/hook.js +0 -4
  297. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  298. package/build-module/border-control/styles.js +30 -54
  299. package/build-module/border-control/styles.js.map +1 -1
  300. package/build-module/box-control/all-input-control.js +3 -28
  301. package/build-module/box-control/all-input-control.js.map +1 -1
  302. package/build-module/box-control/axial-input-controls.js +1 -1
  303. package/build-module/box-control/axial-input-controls.js.map +1 -1
  304. package/build-module/box-control/index.js +5 -5
  305. package/build-module/box-control/index.js.map +1 -1
  306. package/build-module/box-control/styles/box-control-styles.js +18 -10
  307. package/build-module/box-control/styles/box-control-styles.js.map +1 -1
  308. package/build-module/box-control/utils.js +35 -7
  309. package/build-module/box-control/utils.js.map +1 -1
  310. package/build-module/color-palette/index.js +10 -1
  311. package/build-module/color-palette/index.js.map +1 -1
  312. package/build-module/color-picker/hex-input.js +6 -4
  313. package/build-module/color-picker/hex-input.js.map +1 -1
  314. package/build-module/color-picker/index.native.js +36 -35
  315. package/build-module/color-picker/index.native.js.map +1 -1
  316. package/build-module/color-picker/input-with-slider.js +6 -3
  317. package/build-module/color-picker/input-with-slider.js.map +1 -1
  318. package/build-module/color-picker/styles.js +25 -48
  319. package/build-module/color-picker/styles.js.map +1 -1
  320. package/build-module/color-picker/use-deprecated-props.js +22 -31
  321. package/build-module/color-picker/use-deprecated-props.js.map +1 -1
  322. package/build-module/combobox-control/index.js +32 -19
  323. package/build-module/combobox-control/index.js.map +1 -1
  324. package/build-module/combobox-control/styles.js +27 -0
  325. package/build-module/combobox-control/styles.js.map +1 -0
  326. package/build-module/custom-select-control/index.js +28 -11
  327. package/build-module/custom-select-control/index.js.map +1 -1
  328. package/build-module/date-time/time/index.js +6 -3
  329. package/build-module/date-time/time/index.js.map +1 -1
  330. package/build-module/date-time/time/styles.js +15 -21
  331. package/build-module/date-time/time/styles.js.map +1 -1
  332. package/build-module/divider/component.js +0 -1
  333. package/build-module/divider/component.js.map +1 -1
  334. package/build-module/divider/index.js.map +1 -1
  335. package/build-module/divider/styles.js +5 -5
  336. package/build-module/divider/styles.js.map +1 -1
  337. package/build-module/dropdown/dropdown-content-wrapper.js +47 -0
  338. package/build-module/dropdown/dropdown-content-wrapper.js.map +1 -0
  339. package/build-module/dropdown/styles.js +31 -0
  340. package/build-module/dropdown/styles.js.map +1 -0
  341. package/build-module/dropdown/types.js +2 -0
  342. package/build-module/dropdown/types.js.map +1 -0
  343. package/build-module/dropdown-menu/index.js +5 -4
  344. package/build-module/dropdown-menu/index.js.map +1 -1
  345. package/build-module/dropdown-menu/index.native.js +5 -4
  346. package/build-module/dropdown-menu/index.native.js.map +1 -1
  347. package/build-module/elevation/component.js +15 -15
  348. package/build-module/elevation/component.js.map +1 -1
  349. package/build-module/elevation/hook.js +6 -18
  350. package/build-module/elevation/hook.js.map +1 -1
  351. package/build-module/elevation/index.js.map +1 -1
  352. package/build-module/elevation/styles.js +1 -1
  353. package/build-module/elevation/styles.js.map +1 -1
  354. package/build-module/external-link/index.js +7 -2
  355. package/build-module/external-link/index.js.map +1 -1
  356. package/build-module/flex/flex/component.js +20 -26
  357. package/build-module/flex/flex/component.js.map +1 -1
  358. package/build-module/flex/flex/hook.js +6 -15
  359. package/build-module/flex/flex/hook.js.map +1 -1
  360. package/build-module/flex/flex/index.js.map +1 -1
  361. package/build-module/flex/flex-block/component.js +18 -12
  362. package/build-module/flex/flex-block/component.js.map +1 -1
  363. package/build-module/flex/flex-block/hook.js +0 -4
  364. package/build-module/flex/flex-block/hook.js.map +1 -1
  365. package/build-module/flex/flex-block/index.js.map +1 -1
  366. package/build-module/flex/flex-item/component.js +18 -12
  367. package/build-module/flex/flex-item/component.js.map +1 -1
  368. package/build-module/flex/flex-item/hook.js +1 -5
  369. package/build-module/flex/flex-item/hook.js.map +1 -1
  370. package/build-module/flex/flex-item/index.js.map +1 -1
  371. package/build-module/flex/index.js.map +1 -1
  372. package/build-module/flex/styles.js +5 -5
  373. package/build-module/flex/styles.js.map +1 -1
  374. package/build-module/focal-point-picker/grid.js +2 -6
  375. package/build-module/focal-point-picker/grid.js.map +1 -1
  376. package/build-module/focal-point-picker/index.native.js +8 -8
  377. package/build-module/focal-point-picker/index.native.js.map +1 -1
  378. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  379. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  380. package/build-module/focal-point-picker/styles/focal-point-style.js +5 -5
  381. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  382. package/build-module/focal-point-picker/tooltip/index.native.js +11 -12
  383. package/build-module/focal-point-picker/tooltip/index.native.js.map +1 -1
  384. package/build-module/font-size-picker/index.js +14 -6
  385. package/build-module/font-size-picker/index.js.map +1 -1
  386. package/build-module/form-token-field/index.js +25 -8
  387. package/build-module/form-token-field/index.js.map +1 -1
  388. package/build-module/form-token-field/styles.js +28 -0
  389. package/build-module/form-token-field/styles.js.map +1 -0
  390. package/build-module/form-token-field/suggestions-list.js +21 -13
  391. package/build-module/form-token-field/suggestions-list.js.map +1 -1
  392. package/build-module/grid/component.js +7 -8
  393. package/build-module/grid/component.js.map +1 -1
  394. package/build-module/grid/hook.js +1 -5
  395. package/build-module/grid/hook.js.map +1 -1
  396. package/build-module/grid/index.js.map +1 -1
  397. package/build-module/grid/utils.js +3 -8
  398. package/build-module/grid/utils.js.map +1 -1
  399. package/build-module/h-stack/component.js +3 -7
  400. package/build-module/h-stack/component.js.map +1 -1
  401. package/build-module/h-stack/hook.js +10 -12
  402. package/build-module/h-stack/hook.js.map +1 -1
  403. package/build-module/h-stack/index.js.map +1 -1
  404. package/build-module/h-stack/utils.js +7 -19
  405. package/build-module/h-stack/utils.js.map +1 -1
  406. package/build-module/icon/index.js.map +1 -1
  407. package/build-module/index.js +4 -1
  408. package/build-module/index.js.map +1 -1
  409. package/build-module/input-control/index.js +6 -0
  410. package/build-module/input-control/index.js.map +1 -1
  411. package/build-module/input-control/input-base.js +25 -5
  412. package/build-module/input-control/input-base.js.map +1 -1
  413. package/build-module/input-control/input-prefix-wrapper.js +41 -0
  414. package/build-module/input-control/input-prefix-wrapper.js.map +1 -0
  415. package/build-module/input-control/input-suffix-wrapper.js +41 -0
  416. package/build-module/input-control/input-suffix-wrapper.js.map +1 -0
  417. package/build-module/input-control/reducer/actions.js +1 -0
  418. package/build-module/input-control/reducer/actions.js.map +1 -1
  419. package/build-module/input-control/reducer/reducer.js +28 -11
  420. package/build-module/input-control/reducer/reducer.js.map +1 -1
  421. package/build-module/input-control/reducer/state.js.map +1 -1
  422. package/build-module/input-control/styles/input-control-styles.js +58 -42
  423. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  424. package/build-module/menu-item/index.js +1 -2
  425. package/build-module/menu-item/index.js.map +1 -1
  426. package/build-module/mobile/focal-point-settings-panel/index.native.js +2 -2
  427. package/build-module/mobile/focal-point-settings-panel/index.native.js.map +1 -1
  428. package/build-module/mobile/global-styles-context/utils.native.js +23 -4
  429. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  430. package/build-module/mobile/image/index.native.js +33 -8
  431. package/build-module/mobile/image/index.native.js.map +1 -1
  432. package/build-module/mobile/link-picker/link-picker-screen.native.js +11 -4
  433. package/build-module/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  434. package/build-module/mobile/media-edit/index.native.js +1 -6
  435. package/build-module/mobile/media-edit/index.native.js.map +1 -1
  436. package/build-module/mobile/picker/index.ios.js +14 -3
  437. package/build-module/mobile/picker/index.ios.js.map +1 -1
  438. package/build-module/modal/index.js +19 -5
  439. package/build-module/modal/index.js.map +1 -1
  440. package/build-module/navigation/index.js +4 -1
  441. package/build-module/navigation/index.js.map +1 -1
  442. package/build-module/navigation/item/base.js +3 -0
  443. package/build-module/navigation/item/base.js.map +1 -1
  444. package/build-module/placeholder/index.js +10 -15
  445. package/build-module/placeholder/index.js.map +1 -1
  446. package/build-module/placeholder/types.js +2 -0
  447. package/build-module/placeholder/types.js.map +1 -0
  448. package/build-module/popover/index.js +128 -75
  449. package/build-module/popover/index.js.map +1 -1
  450. package/build-module/radio-control/index.js +1 -2
  451. package/build-module/radio-control/index.js.map +1 -1
  452. package/build-module/range-control/index.js +54 -40
  453. package/build-module/range-control/index.js.map +1 -1
  454. package/build-module/range-control/input-range.js +5 -6
  455. package/build-module/range-control/input-range.js.map +1 -1
  456. package/build-module/range-control/mark.js +5 -6
  457. package/build-module/range-control/mark.js.map +1 -1
  458. package/build-module/range-control/rail.js +10 -15
  459. package/build-module/range-control/rail.js.map +1 -1
  460. package/build-module/range-control/styles/range-control-styles.js +74 -76
  461. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  462. package/build-module/range-control/tooltip.js +5 -6
  463. package/build-module/range-control/tooltip.js.map +1 -1
  464. package/build-module/range-control/types.js +2 -0
  465. package/build-module/range-control/types.js.map +1 -0
  466. package/build-module/range-control/utils.js +23 -30
  467. package/build-module/range-control/utils.js.map +1 -1
  468. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  469. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  470. package/build-module/resizable-box/resize-tooltip/utils.js +2 -6
  471. package/build-module/resizable-box/resize-tooltip/utils.js.map +1 -1
  472. package/build-module/sandbox/index.native.js +13 -3
  473. package/build-module/sandbox/index.native.js.map +1 -1
  474. package/build-module/scroll-lock/index.js +32 -6
  475. package/build-module/scroll-lock/index.js.map +1 -1
  476. package/build-module/scrollable/component.js +7 -8
  477. package/build-module/scrollable/component.js.map +1 -1
  478. package/build-module/scrollable/hook.js +0 -8
  479. package/build-module/scrollable/hook.js.map +1 -1
  480. package/build-module/scrollable/index.js.map +1 -1
  481. package/build-module/scrollable/styles.js +7 -7
  482. package/build-module/scrollable/styles.js.map +1 -1
  483. package/build-module/select-control/index.js +1 -2
  484. package/build-module/select-control/index.js.map +1 -1
  485. package/build-module/select-control/styles/select-control-styles.js +32 -12
  486. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  487. package/build-module/shortcut/index.js +6 -20
  488. package/build-module/shortcut/index.js.map +1 -1
  489. package/build-module/shortcut/types.js +2 -0
  490. package/build-module/shortcut/types.js.map +1 -0
  491. package/build-module/slot-fill/index.native.js +6 -7
  492. package/build-module/slot-fill/index.native.js.map +1 -1
  493. package/build-module/slot-fill/provider.js +4 -7
  494. package/build-module/slot-fill/provider.js.map +1 -1
  495. package/build-module/slot-fill/slot.js +4 -7
  496. package/build-module/slot-fill/slot.js.map +1 -1
  497. package/build-module/spacer/component.js +3 -1
  498. package/build-module/spacer/component.js.map +1 -1
  499. package/build-module/spacer/hook.js +2 -2
  500. package/build-module/spacer/hook.js.map +1 -1
  501. package/build-module/spacer/index.js.map +1 -1
  502. package/build-module/style-provider/index.js +10 -5
  503. package/build-module/style-provider/index.js.map +1 -1
  504. package/build-module/style-provider/types.js +2 -0
  505. package/build-module/style-provider/types.js.map +1 -0
  506. package/build-module/swatch/index.js +2 -0
  507. package/build-module/swatch/index.js.map +1 -1
  508. package/build-module/swatch/types.js +2 -0
  509. package/build-module/swatch/types.js.map +1 -0
  510. package/build-module/text/hook.js +5 -7
  511. package/build-module/text/hook.js.map +1 -1
  512. package/build-module/text-highlight/index.js +23 -6
  513. package/build-module/text-highlight/index.js.map +1 -1
  514. package/build-module/text-highlight/types.js +2 -0
  515. package/build-module/text-highlight/types.js.map +1 -0
  516. package/build-module/tip/index.js +6 -10
  517. package/build-module/tip/index.js.map +1 -1
  518. package/build-module/tip/types.js +2 -0
  519. package/build-module/tip/types.js.map +1 -0
  520. package/build-module/toggle-group-control/toggle-group-control/component.js +4 -1
  521. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  522. package/build-module/toggle-group-control/toggle-group-control/styles.js +15 -3
  523. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  524. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +6 -7
  525. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  526. package/build-module/toolbar-group/index.js +3 -2
  527. package/build-module/toolbar-group/index.js.map +1 -1
  528. package/build-module/tools-panel/styles.js +12 -11
  529. package/build-module/tools-panel/styles.js.map +1 -1
  530. package/build-module/tools-panel/tools-panel/hook.js +1 -1
  531. package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
  532. package/build-module/tooltip/index.js +53 -16
  533. package/build-module/tooltip/index.js.map +1 -1
  534. package/build-module/tree-select/index.js +5 -5
  535. package/build-module/tree-select/index.js.map +1 -1
  536. package/build-module/ui/context/use-context-system.js +7 -2
  537. package/build-module/ui/context/use-context-system.js.map +1 -1
  538. package/build-module/ui/tooltip/styles.js +4 -4
  539. package/build-module/ui/tooltip/styles.js.map +1 -1
  540. package/build-module/ui/utils/get-valid-children.js.map +1 -1
  541. package/build-module/ui/utils/space.js +7 -1
  542. package/build-module/ui/utils/space.js.map +1 -1
  543. package/build-module/unit-control/styles/unit-control-styles.js +39 -30
  544. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  545. package/build-module/utils/base-label.js +18 -0
  546. package/build-module/utils/base-label.js.map +1 -0
  547. package/build-module/utils/box-sizing.js +16 -0
  548. package/build-module/utils/box-sizing.js.map +1 -0
  549. package/build-module/utils/style-mixins.js +2 -0
  550. package/build-module/utils/style-mixins.js.map +1 -1
  551. package/build-module/visually-hidden/component.js +12 -13
  552. package/build-module/visually-hidden/component.js.map +1 -1
  553. package/build-module/visually-hidden/index.js.map +1 -1
  554. package/build-module/visually-hidden/styles.js +3 -1
  555. package/build-module/visually-hidden/styles.js.map +1 -1
  556. package/build-module/visually-hidden/types.js +2 -0
  557. package/build-module/visually-hidden/types.js.map +1 -0
  558. package/build-style/style-rtl.css +75 -75
  559. package/build-style/style.css +77 -73
  560. package/build-types/base-control/index.d.ts +4 -3
  561. package/build-types/base-control/index.d.ts.map +1 -1
  562. package/build-types/base-control/stories/index.d.ts +1 -1
  563. package/build-types/base-control/stories/index.d.ts.map +1 -1
  564. package/build-types/base-control/styles/base-control-styles.d.ts.map +1 -1
  565. package/build-types/base-control/types.d.ts +0 -1
  566. package/build-types/base-control/types.d.ts.map +1 -1
  567. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  568. package/build-types/border-control/border-control/hook.d.ts +2 -2
  569. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  570. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  571. package/build-types/border-control/border-control-dropdown/hook.d.ts +0 -1
  572. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  573. package/build-types/border-control/stories/index.d.ts.map +1 -1
  574. package/build-types/border-control/styles.d.ts +1 -4
  575. package/build-types/border-control/styles.d.ts.map +1 -1
  576. package/build-types/card/card-divider/hook.d.ts +1 -1
  577. package/build-types/color-palette/index.d.ts +1 -0
  578. package/build-types/color-palette/index.d.ts.map +1 -1
  579. package/build-types/color-picker/color-display.d.ts +13 -0
  580. package/build-types/color-picker/color-display.d.ts.map +1 -0
  581. package/build-types/color-picker/hex-input.d.ts.map +1 -1
  582. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  583. package/build-types/color-picker/styles.d.ts +30 -31
  584. package/build-types/color-picker/styles.d.ts.map +1 -1
  585. package/build-types/color-picker/use-deprecated-props.d.ts.map +1 -1
  586. package/build-types/date-time/time/index.d.ts.map +1 -1
  587. package/build-types/date-time/time/styles.d.ts +0 -4
  588. package/build-types/date-time/time/styles.d.ts.map +1 -1
  589. package/build-types/divider/component.d.ts +2 -3
  590. package/build-types/divider/component.d.ts.map +1 -1
  591. package/build-types/divider/index.d.ts +1 -1
  592. package/build-types/divider/index.d.ts.map +1 -1
  593. package/build-types/divider/styles.d.ts +6 -2
  594. package/build-types/divider/styles.d.ts.map +1 -1
  595. package/build-types/divider/test/index.d.ts +2 -0
  596. package/build-types/divider/test/index.d.ts.map +1 -0
  597. package/build-types/divider/types.d.ts +18 -10
  598. package/build-types/divider/types.d.ts.map +1 -1
  599. package/build-types/dropdown/dropdown-content-wrapper.d.ts +23 -0
  600. package/build-types/dropdown/dropdown-content-wrapper.d.ts.map +1 -0
  601. package/build-types/dropdown/styles.d.ts +7 -0
  602. package/build-types/dropdown/styles.d.ts.map +1 -0
  603. package/build-types/dropdown/types.d.ts +9 -0
  604. package/build-types/dropdown/types.d.ts.map +1 -0
  605. package/build-types/dropdown-menu/index.d.ts.map +1 -1
  606. package/build-types/elevation/component.d.ts +11 -10
  607. package/build-types/elevation/component.d.ts.map +1 -1
  608. package/build-types/elevation/hook.d.ts +6 -7
  609. package/build-types/elevation/hook.d.ts.map +1 -1
  610. package/build-types/elevation/index.d.ts +2 -2
  611. package/build-types/elevation/index.d.ts.map +1 -1
  612. package/build-types/elevation/stories/index.d.ts +22 -0
  613. package/build-types/elevation/stories/index.d.ts.map +1 -0
  614. package/build-types/elevation/styles.d.ts +1 -1
  615. package/build-types/elevation/styles.d.ts.map +1 -1
  616. package/build-types/elevation/test/index.d.ts +2 -0
  617. package/build-types/elevation/test/index.d.ts.map +1 -0
  618. package/build-types/elevation/types.d.ts +12 -19
  619. package/build-types/elevation/types.d.ts.map +1 -1
  620. package/build-types/external-link/index.d.ts.map +1 -1
  621. package/build-types/flex/flex/component.d.ts +16 -21
  622. package/build-types/flex/flex/component.d.ts.map +1 -1
  623. package/build-types/flex/flex/hook.d.ts +5 -2
  624. package/build-types/flex/flex/hook.d.ts.map +1 -1
  625. package/build-types/flex/flex/index.d.ts +2 -2
  626. package/build-types/flex/flex/index.d.ts.map +1 -1
  627. package/build-types/flex/flex-block/component.d.ts +14 -7
  628. package/build-types/flex/flex-block/component.d.ts.map +1 -1
  629. package/build-types/flex/flex-block/hook.d.ts +6 -3
  630. package/build-types/flex/flex-block/hook.d.ts.map +1 -1
  631. package/build-types/flex/flex-block/index.d.ts +2 -2
  632. package/build-types/flex/flex-block/index.d.ts.map +1 -1
  633. package/build-types/flex/flex-item/component.d.ts +14 -7
  634. package/build-types/flex/flex-item/component.d.ts.map +1 -1
  635. package/build-types/flex/flex-item/hook.d.ts +6 -3
  636. package/build-types/flex/flex-item/hook.d.ts.map +1 -1
  637. package/build-types/flex/flex-item/index.d.ts +2 -2
  638. package/build-types/flex/flex-item/index.d.ts.map +1 -1
  639. package/build-types/flex/index.d.ts +3 -3
  640. package/build-types/flex/index.d.ts.map +1 -1
  641. package/build-types/flex/stories/index.d.ts +13 -0
  642. package/build-types/flex/stories/index.d.ts.map +1 -0
  643. package/build-types/flex/styles.d.ts +5 -5
  644. package/build-types/flex/styles.d.ts.map +1 -1
  645. package/build-types/flex/test/index.d.ts +2 -0
  646. package/build-types/flex/test/index.d.ts.map +1 -0
  647. package/build-types/flex/types.d.ts +17 -10
  648. package/build-types/flex/types.d.ts.map +1 -1
  649. package/build-types/flyout/context.d.ts +6 -0
  650. package/build-types/flyout/context.d.ts.map +1 -0
  651. package/build-types/flyout/flyout/component.d.ts +21 -0
  652. package/build-types/flyout/flyout/component.d.ts.map +1 -0
  653. package/build-types/flyout/flyout/hook.d.ts +270 -0
  654. package/build-types/flyout/flyout/hook.d.ts.map +1 -0
  655. package/build-types/flyout/flyout/index.d.ts +3 -0
  656. package/build-types/flyout/flyout/index.d.ts.map +1 -0
  657. package/build-types/flyout/flyout-content/component.d.ts +3 -0
  658. package/build-types/flyout/flyout-content/component.d.ts.map +1 -0
  659. package/build-types/flyout/flyout-content/index.d.ts +2 -0
  660. package/build-types/flyout/flyout-content/index.d.ts.map +1 -0
  661. package/build-types/flyout/index.d.ts +2 -0
  662. package/build-types/flyout/index.d.ts.map +1 -0
  663. package/build-types/flyout/styles.d.ts +22 -0
  664. package/build-types/flyout/styles.d.ts.map +1 -0
  665. package/build-types/flyout/types.d.ts +80 -0
  666. package/build-types/flyout/types.d.ts.map +1 -0
  667. package/build-types/flyout/utils.d.ts +8 -0
  668. package/build-types/flyout/utils.d.ts.map +1 -0
  669. package/build-types/form-token-field/index.d.ts.map +1 -1
  670. package/build-types/form-token-field/stories/index.d.ts +6 -0
  671. package/build-types/form-token-field/stories/index.d.ts.map +1 -1
  672. package/build-types/form-token-field/styles.d.ts +14 -0
  673. package/build-types/form-token-field/styles.d.ts.map +1 -0
  674. package/build-types/form-token-field/suggestions-list.d.ts +1 -1
  675. package/build-types/form-token-field/suggestions-list.d.ts.map +1 -1
  676. package/build-types/form-token-field/types.d.ts +22 -3
  677. package/build-types/form-token-field/types.d.ts.map +1 -1
  678. package/build-types/grid/component.d.ts +3 -3
  679. package/build-types/grid/component.d.ts.map +1 -1
  680. package/build-types/grid/hook.d.ts +5 -2
  681. package/build-types/grid/hook.d.ts.map +1 -1
  682. package/build-types/grid/index.d.ts +2 -2
  683. package/build-types/grid/index.d.ts.map +1 -1
  684. package/build-types/grid/stories/index.d.ts +9 -0
  685. package/build-types/grid/stories/index.d.ts.map +1 -0
  686. package/build-types/grid/test/grid.d.ts +2 -0
  687. package/build-types/grid/test/grid.d.ts.map +1 -0
  688. package/build-types/grid/types.d.ts +16 -15
  689. package/build-types/grid/types.d.ts.map +1 -1
  690. package/build-types/grid/utils.d.ts +50 -69
  691. package/build-types/grid/utils.d.ts.map +1 -1
  692. package/build-types/h-stack/component.d.ts +3 -2
  693. package/build-types/h-stack/component.d.ts.map +1 -1
  694. package/build-types/h-stack/hook.d.ts +5 -3
  695. package/build-types/h-stack/hook.d.ts.map +1 -1
  696. package/build-types/h-stack/index.d.ts +2 -2
  697. package/build-types/h-stack/index.d.ts.map +1 -1
  698. package/build-types/h-stack/stories/index.d.ts +9 -0
  699. package/build-types/h-stack/stories/index.d.ts.map +1 -0
  700. package/build-types/h-stack/test/index.d.ts +2 -0
  701. package/build-types/h-stack/test/index.d.ts.map +1 -0
  702. package/build-types/h-stack/utils.d.ts +8 -4
  703. package/build-types/h-stack/utils.d.ts.map +1 -1
  704. package/build-types/icon/index.d.ts +1 -1
  705. package/build-types/icon/index.d.ts.map +1 -1
  706. package/build-types/input-control/index.d.ts +1 -1
  707. package/build-types/input-control/index.d.ts.map +1 -1
  708. package/build-types/input-control/input-base.d.ts +1 -1
  709. package/build-types/input-control/input-base.d.ts.map +1 -1
  710. package/build-types/input-control/input-prefix-wrapper.d.ts +19 -0
  711. package/build-types/input-control/input-prefix-wrapper.d.ts.map +1 -0
  712. package/build-types/input-control/input-suffix-wrapper.d.ts +19 -0
  713. package/build-types/input-control/input-suffix-wrapper.d.ts.map +1 -0
  714. package/build-types/input-control/reducer/actions.d.ts +3 -1
  715. package/build-types/input-control/reducer/actions.d.ts.map +1 -1
  716. package/build-types/input-control/reducer/reducer.d.ts +2 -2
  717. package/build-types/input-control/reducer/reducer.d.ts.map +1 -1
  718. package/build-types/input-control/reducer/state.d.ts +2 -2
  719. package/build-types/input-control/reducer/state.d.ts.map +1 -1
  720. package/build-types/input-control/stories/index.d.ts +10 -0
  721. package/build-types/input-control/stories/index.d.ts.map +1 -1
  722. package/build-types/input-control/styles/input-control-styles.d.ts +21 -0
  723. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  724. package/build-types/input-control/types.d.ts +45 -3
  725. package/build-types/input-control/types.d.ts.map +1 -1
  726. package/build-types/menu-item/index.d.ts.map +1 -1
  727. package/build-types/placeholder/index.d.ts +16 -0
  728. package/build-types/placeholder/index.d.ts.map +1 -0
  729. package/build-types/placeholder/stories/index.d.ts +12 -0
  730. package/build-types/placeholder/stories/index.d.ts.map +1 -0
  731. package/build-types/placeholder/types.d.ts +47 -0
  732. package/build-types/placeholder/types.d.ts.map +1 -0
  733. package/build-types/popover/index.d.ts +1 -1
  734. package/build-types/popover/index.d.ts.map +1 -1
  735. package/build-types/popover/utils.d.ts +70 -0
  736. package/build-types/popover/utils.d.ts.map +1 -0
  737. package/build-types/radio-control/index.d.ts.map +1 -1
  738. package/build-types/range-control/index.d.ts +54 -29
  739. package/build-types/range-control/index.d.ts.map +1 -1
  740. package/build-types/range-control/input-range.d.ts +7 -10
  741. package/build-types/range-control/input-range.d.ts.map +1 -1
  742. package/build-types/range-control/mark.d.ts +4 -7
  743. package/build-types/range-control/mark.d.ts.map +1 -1
  744. package/build-types/range-control/rail.d.ts +4 -9
  745. package/build-types/range-control/rail.d.ts.map +1 -1
  746. package/build-types/range-control/stories/index.d.ts +48 -0
  747. package/build-types/range-control/stories/index.d.ts.map +1 -0
  748. package/build-types/range-control/styles/range-control-styles.d.ts +32 -40
  749. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  750. package/build-types/range-control/test/index.d.ts +2 -0
  751. package/build-types/range-control/test/index.d.ts.map +1 -0
  752. package/build-types/range-control/tooltip.d.ts +4 -11
  753. package/build-types/range-control/tooltip.d.ts.map +1 -1
  754. package/build-types/range-control/types.d.ts +304 -0
  755. package/build-types/range-control/types.d.ts.map +1 -0
  756. package/build-types/range-control/utils.d.ts +15 -33
  757. package/build-types/range-control/utils.d.ts.map +1 -1
  758. package/build-types/resizable-box/resize-tooltip/utils.d.ts.map +1 -1
  759. package/build-types/scroll-lock/index.d.ts +32 -3
  760. package/build-types/scroll-lock/index.d.ts.map +1 -1
  761. package/build-types/scroll-lock/stories/index.d.ts +9 -0
  762. package/build-types/scroll-lock/stories/index.d.ts.map +1 -0
  763. package/build-types/scroll-lock/test/index.d.ts +2 -0
  764. package/build-types/scroll-lock/test/index.d.ts.map +1 -0
  765. package/build-types/scrollable/component.d.ts +3 -3
  766. package/build-types/scrollable/component.d.ts.map +1 -1
  767. package/build-types/scrollable/hook.d.ts +5 -2
  768. package/build-types/scrollable/hook.d.ts.map +1 -1
  769. package/build-types/scrollable/index.d.ts +2 -2
  770. package/build-types/scrollable/index.d.ts.map +1 -1
  771. package/build-types/scrollable/stories/index.d.ts +9 -0
  772. package/build-types/scrollable/stories/index.d.ts.map +1 -0
  773. package/build-types/scrollable/styles.d.ts +7 -7
  774. package/build-types/scrollable/styles.d.ts.map +1 -1
  775. package/build-types/scrollable/test/index.d.ts +2 -0
  776. package/build-types/scrollable/test/index.d.ts.map +1 -0
  777. package/build-types/scrollable/types.d.ts +9 -6
  778. package/build-types/scrollable/types.d.ts.map +1 -1
  779. package/build-types/select-control/index.d.ts.map +1 -1
  780. package/build-types/select-control/styles/select-control-styles.d.ts +1 -1
  781. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  782. package/build-types/select-control/types.d.ts +1 -1
  783. package/build-types/select-control/types.d.ts.map +1 -1
  784. package/build-types/shortcut/index.d.ts +5 -24
  785. package/build-types/shortcut/index.d.ts.map +1 -1
  786. package/build-types/shortcut/test/index.d.ts +2 -0
  787. package/build-types/shortcut/test/index.d.ts.map +1 -0
  788. package/build-types/shortcut/types.d.ts +14 -0
  789. package/build-types/shortcut/types.d.ts.map +1 -0
  790. package/build-types/slot-fill/provider.d.ts.map +1 -1
  791. package/build-types/slot-fill/slot.d.ts.map +1 -1
  792. package/build-types/spacer/component.d.ts +5 -3
  793. package/build-types/spacer/component.d.ts.map +1 -1
  794. package/build-types/spacer/hook.d.ts +2 -2
  795. package/build-types/spacer/hook.d.ts.map +1 -1
  796. package/build-types/spacer/index.d.ts +1 -1
  797. package/build-types/spacer/index.d.ts.map +1 -1
  798. package/build-types/spacer/test/index.d.ts +2 -0
  799. package/build-types/spacer/test/index.d.ts.map +1 -0
  800. package/build-types/spacer/types.d.ts +41 -29
  801. package/build-types/spacer/types.d.ts.map +1 -1
  802. package/build-types/style-provider/index.d.ts +7 -4
  803. package/build-types/style-provider/index.d.ts.map +1 -1
  804. package/build-types/style-provider/types.d.ts +15 -0
  805. package/build-types/style-provider/types.d.ts.map +1 -0
  806. package/build-types/swatch/index.d.ts +5 -0
  807. package/build-types/swatch/index.d.ts.map +1 -0
  808. package/build-types/swatch/types.d.ts +11 -0
  809. package/build-types/swatch/types.d.ts.map +1 -0
  810. package/build-types/text/hook.d.ts.map +1 -1
  811. package/build-types/text-highlight/index.d.ts +23 -0
  812. package/build-types/text-highlight/index.d.ts.map +1 -0
  813. package/build-types/text-highlight/stories/index.d.ts +12 -0
  814. package/build-types/text-highlight/stories/index.d.ts.map +1 -0
  815. package/build-types/text-highlight/test/index.d.ts +2 -0
  816. package/build-types/text-highlight/test/index.d.ts.map +1 -0
  817. package/build-types/text-highlight/types.d.ts +17 -0
  818. package/build-types/text-highlight/types.d.ts.map +1 -0
  819. package/build-types/tip/index.d.ts +5 -14
  820. package/build-types/tip/index.d.ts.map +1 -1
  821. package/build-types/tip/stories/index.d.ts +12 -0
  822. package/build-types/tip/stories/index.d.ts.map +1 -0
  823. package/build-types/tip/types.d.ts +11 -0
  824. package/build-types/tip/types.d.ts.map +1 -0
  825. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +5 -1
  826. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  827. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +0 -1
  828. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  829. package/build-types/toggle-group-control/types.d.ts +6 -0
  830. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  831. package/build-types/tools-panel/styles.d.ts +1 -1
  832. package/build-types/tools-panel/styles.d.ts.map +1 -1
  833. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  834. package/build-types/tooltip/index.d.ts.map +1 -1
  835. package/build-types/tree-select/index.d.ts.map +1 -1
  836. package/build-types/tree-select/types.d.ts +1 -0
  837. package/build-types/tree-select/types.d.ts.map +1 -1
  838. package/build-types/ui/context/use-context-system.d.ts.map +1 -1
  839. package/build-types/ui/form-group/form-group.d.ts +1 -1
  840. package/build-types/ui/form-group/types.d.ts +1 -1
  841. package/build-types/ui/form-group/types.d.ts.map +1 -1
  842. package/build-types/ui/form-group/use-form-group.d.ts +3 -3
  843. package/build-types/ui/tooltip/styles.d.ts.map +1 -1
  844. package/build-types/ui/utils/get-valid-children.d.ts +2 -2
  845. package/build-types/ui/utils/get-valid-children.d.ts.map +1 -1
  846. package/build-types/ui/utils/space.d.ts +7 -1
  847. package/build-types/ui/utils/space.d.ts.map +1 -1
  848. package/build-types/unit-control/index.d.ts +3 -3
  849. package/build-types/unit-control/index.d.ts.map +1 -1
  850. package/build-types/unit-control/stories/index.d.ts.map +1 -1
  851. package/build-types/unit-control/styles/unit-control-styles.d.ts +0 -1
  852. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
  853. package/build-types/unit-control/types.d.ts +2 -8
  854. package/build-types/unit-control/types.d.ts.map +1 -1
  855. package/build-types/utils/base-label.d.ts +2 -0
  856. package/build-types/utils/base-label.d.ts.map +1 -0
  857. package/build-types/utils/box-sizing.d.ts +2 -0
  858. package/build-types/utils/box-sizing.d.ts.map +1 -0
  859. package/build-types/utils/hooks/use-combined-ref.d.ts +8 -0
  860. package/build-types/utils/hooks/use-combined-ref.d.ts.map +1 -0
  861. package/build-types/utils/style-mixins.d.ts +2 -0
  862. package/build-types/visually-hidden/component.d.ts +8 -10
  863. package/build-types/visually-hidden/component.d.ts.map +1 -1
  864. package/build-types/visually-hidden/index.d.ts +1 -1
  865. package/build-types/visually-hidden/index.d.ts.map +1 -1
  866. package/build-types/visually-hidden/stories/index.d.ts +14 -0
  867. package/build-types/visually-hidden/stories/index.d.ts.map +1 -0
  868. package/build-types/visually-hidden/styles.d.ts +5 -2
  869. package/build-types/visually-hidden/styles.d.ts.map +1 -1
  870. package/build-types/visually-hidden/test/index.d.ts +2 -0
  871. package/build-types/visually-hidden/test/index.d.ts.map +1 -0
  872. package/build-types/visually-hidden/types.d.ts +11 -0
  873. package/build-types/visually-hidden/types.d.ts.map +1 -0
  874. package/package.json +17 -17
  875. package/src/angle-picker-control/index.js +1 -2
  876. package/src/autocomplete/get-default-use-items.js +3 -2
  877. package/src/autocomplete/index.js +3 -2
  878. package/src/base-control/index.tsx +5 -3
  879. package/src/base-control/stories/index.tsx +1 -0
  880. package/src/base-control/styles/base-control-styles.ts +10 -1
  881. package/src/base-control/types.ts +0 -1
  882. package/src/border-control/border-control/component.tsx +41 -32
  883. package/src/border-control/border-control/hook.ts +5 -10
  884. package/src/border-control/border-control-dropdown/component.tsx +50 -45
  885. package/src/border-control/border-control-dropdown/hook.ts +0 -5
  886. package/src/border-control/stories/index.tsx +3 -0
  887. package/src/border-control/styles.ts +25 -70
  888. package/src/border-control/test/index.js +19 -8
  889. package/src/box-control/all-input-control.js +3 -27
  890. package/src/box-control/axial-input-controls.js +1 -1
  891. package/src/box-control/index.js +6 -7
  892. package/src/box-control/styles/box-control-styles.js +1 -2
  893. package/src/box-control/utils.js +38 -13
  894. package/src/button/README.md +1 -1
  895. package/src/card/test/__snapshots__/index.js.snap +8 -8
  896. package/src/color-palette/index.js +19 -8
  897. package/src/color-palette/style.scss +5 -0
  898. package/src/color-palette/test/utils.ts +19 -1
  899. package/src/color-picker/hex-input.tsx +5 -3
  900. package/src/color-picker/index.native.js +20 -27
  901. package/src/color-picker/input-with-slider.tsx +4 -1
  902. package/src/color-picker/styles.ts +3 -16
  903. package/src/color-picker/use-deprecated-props.ts +24 -43
  904. package/src/combobox-control/README.md +7 -0
  905. package/src/combobox-control/index.js +34 -17
  906. package/src/combobox-control/stories/index.js +51 -6
  907. package/src/combobox-control/style.scss +1 -1
  908. package/src/combobox-control/styles.ts +27 -0
  909. package/src/confirm-dialog/README.md +1 -1
  910. package/src/custom-gradient-picker/style.scss +0 -12
  911. package/src/custom-select-control/index.js +47 -28
  912. package/src/custom-select-control/stories/index.js +7 -2
  913. package/src/custom-select-control/style.scss +5 -34
  914. package/src/date-time/time/index.tsx +7 -5
  915. package/src/date-time/time/styles.ts +3 -6
  916. package/src/divider/README.md +12 -5
  917. package/src/divider/component.tsx +2 -3
  918. package/src/divider/index.ts +1 -1
  919. package/src/divider/stories/index.tsx +4 -4
  920. package/src/divider/styles.ts +7 -7
  921. package/src/divider/test/__snapshots__/{index.js.snap → index.tsx.snap} +7 -7
  922. package/src/divider/test/index.tsx +40 -0
  923. package/src/divider/types.ts +21 -15
  924. package/src/draggable/README.md +1 -1
  925. package/src/dropdown/dropdown-content-wrapper.tsx +59 -0
  926. package/src/dropdown/stories/index.js +60 -69
  927. package/src/dropdown/styles.ts +38 -0
  928. package/src/dropdown/types.ts +8 -0
  929. package/src/dropdown-menu/index.js +3 -4
  930. package/src/dropdown-menu/index.native.js +3 -5
  931. package/src/elevation/README.md +16 -14
  932. package/src/elevation/component.tsx +48 -0
  933. package/src/elevation/{hook.js → hook.ts} +23 -20
  934. package/src/elevation/{index.js → index.ts} +0 -0
  935. package/src/elevation/stories/index.tsx +85 -0
  936. package/src/elevation/{styles.js → styles.ts} +0 -0
  937. package/src/elevation/test/__snapshots__/{index.js.snap → index.tsx.snap} +19 -13
  938. package/src/elevation/test/index.tsx +64 -0
  939. package/src/elevation/types.ts +12 -19
  940. package/src/external-link/index.tsx +20 -4
  941. package/src/flex/flex/README.md +20 -18
  942. package/src/flex/flex/component.tsx +59 -0
  943. package/src/flex/flex/{hook.js → hook.ts} +14 -13
  944. package/src/flex/flex/{index.js → index.ts} +0 -0
  945. package/src/flex/flex-block/README.md +3 -7
  946. package/src/flex/flex-block/component.tsx +41 -0
  947. package/src/flex/flex-block/{hook.js → hook.ts} +5 -5
  948. package/src/flex/flex-block/{index.js → index.ts} +0 -0
  949. package/src/flex/flex-item/README.md +6 -9
  950. package/src/flex/flex-item/component.tsx +41 -0
  951. package/src/flex/flex-item/{hook.js → hook.ts} +10 -7
  952. package/src/flex/flex-item/{index.js → index.ts} +0 -0
  953. package/src/flex/{index.js → index.ts} +0 -0
  954. package/src/flex/stories/index.tsx +81 -0
  955. package/src/flex/{styles.js → styles.ts} +0 -0
  956. package/src/flex/test/__snapshots__/{index.js.snap → index.tsx.snap} +49 -9
  957. package/src/flex/test/index.tsx +84 -0
  958. package/src/flex/types.ts +17 -10
  959. package/src/focal-point-picker/grid.js +2 -5
  960. package/src/focal-point-picker/index.native.js +8 -8
  961. package/src/focal-point-picker/styles/focal-point-picker-style.js +0 -5
  962. package/src/focal-point-picker/styles/focal-point-style.js +0 -1
  963. package/src/focal-point-picker/tooltip/index.native.js +10 -11
  964. package/src/font-size-picker/index.js +18 -7
  965. package/src/font-size-picker/stories/index.js +6 -0
  966. package/src/form-token-field/README.md +2 -1
  967. package/src/form-token-field/index.tsx +50 -26
  968. package/src/form-token-field/stories/index.tsx +14 -0
  969. package/src/form-token-field/style.scss +2 -12
  970. package/src/form-token-field/styles.ts +32 -0
  971. package/src/form-token-field/suggestions-list.tsx +23 -16
  972. package/src/form-token-field/test/index.js +1 -1
  973. package/src/form-token-field/types.ts +23 -2
  974. package/src/grid/README.md +33 -19
  975. package/src/grid/{component.js → component.tsx} +13 -9
  976. package/src/grid/{hook.js → hook.ts} +5 -5
  977. package/src/grid/{index.js → index.ts} +0 -0
  978. package/src/grid/stories/index.tsx +72 -0
  979. package/src/grid/test/{grid.js → grid.tsx} +4 -4
  980. package/src/grid/types.ts +16 -17
  981. package/src/grid/{utils.js → utils.ts} +9 -7
  982. package/src/guide/style.scss +1 -0
  983. package/src/h-stack/{component.js → component.tsx} +8 -8
  984. package/src/h-stack/{hook.js → hook.tsx} +21 -16
  985. package/src/h-stack/{index.js → index.ts} +0 -0
  986. package/src/h-stack/stories/index.tsx +92 -0
  987. package/src/h-stack/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
  988. package/src/h-stack/test/{index.js → index.tsx} +0 -0
  989. package/src/h-stack/{utils.js → utils.ts} +14 -14
  990. package/src/higher-order/navigate-regions/README.md +4 -1
  991. package/src/icon/index.tsx +1 -1
  992. package/src/index.js +7 -1
  993. package/src/input-control/index.tsx +6 -0
  994. package/src/input-control/input-base.tsx +28 -13
  995. package/src/input-control/input-prefix-wrapper.tsx +48 -0
  996. package/src/input-control/input-suffix-wrapper.tsx +48 -0
  997. package/src/input-control/reducer/actions.ts +3 -1
  998. package/src/input-control/reducer/reducer.ts +27 -10
  999. package/src/input-control/reducer/state.ts +7 -2
  1000. package/src/input-control/stories/index.tsx +15 -2
  1001. package/src/input-control/styles/input-control-styles.tsx +28 -12
  1002. package/src/input-control/test/index.js +20 -4
  1003. package/src/input-control/types.ts +52 -3
  1004. package/src/menu-item/index.js +1 -2
  1005. package/src/mobile/focal-point-settings-panel/index.native.js +2 -2
  1006. package/src/mobile/global-styles-context/utils.native.js +21 -4
  1007. package/src/mobile/image/index.native.js +38 -7
  1008. package/src/mobile/link-picker/link-picker-screen.native.js +12 -4
  1009. package/src/mobile/media-edit/index.native.js +2 -7
  1010. package/src/mobile/picker/index.ios.js +16 -0
  1011. package/src/mobile/picker/styles.native.scss +8 -0
  1012. package/src/modal/index.js +21 -2
  1013. package/src/modal/stories/index.js +17 -1
  1014. package/src/modal/style.scss +14 -19
  1015. package/src/navigation/index.js +3 -0
  1016. package/src/navigation/item/base.js +2 -1
  1017. package/src/panel/style.scss +4 -1
  1018. package/src/placeholder/README.md +49 -9
  1019. package/src/placeholder/{index.js → index.tsx} +27 -23
  1020. package/src/placeholder/stories/index.tsx +64 -0
  1021. package/src/placeholder/style.scss +0 -4
  1022. package/src/placeholder/types.ts +48 -0
  1023. package/src/popover/README.md +9 -2
  1024. package/src/popover/index.js +160 -79
  1025. package/src/popover/stories/index.js +199 -96
  1026. package/src/popover/style.scss +61 -7
  1027. package/src/popover/test/index.js +23 -1
  1028. package/src/radio-control/index.tsx +1 -2
  1029. package/src/range-control/README.md +108 -80
  1030. package/src/range-control/{index.js → index.tsx} +78 -48
  1031. package/src/range-control/{input-range.js → input-range.tsx} +11 -7
  1032. package/src/range-control/{mark.js → mark.tsx} +15 -9
  1033. package/src/range-control/{rail.js → rail.tsx} +40 -23
  1034. package/src/range-control/stories/index.tsx +244 -0
  1035. package/src/range-control/styles/{range-control-styles.js → range-control-styles.ts} +28 -36
  1036. package/src/range-control/test/index.tsx +341 -0
  1037. package/src/range-control/{tooltip.js → tooltip.tsx} +19 -14
  1038. package/src/range-control/types.ts +328 -0
  1039. package/src/range-control/utils.ts +135 -0
  1040. package/src/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +1 -1
  1041. package/src/resizable-box/resize-tooltip/utils.ts +2 -3
  1042. package/src/sandbox/index.native.js +14 -1
  1043. package/src/scroll-lock/README.md +1 -1
  1044. package/src/scroll-lock/{index.js → index.tsx} +34 -7
  1045. package/src/scroll-lock/stories/index.tsx +96 -0
  1046. package/src/scroll-lock/test/index.tsx +26 -0
  1047. package/src/scrollable/README.md +14 -8
  1048. package/src/scrollable/{component.js → component.tsx} +13 -10
  1049. package/src/scrollable/{hook.js → hook.ts} +5 -7
  1050. package/src/scrollable/{index.js → index.ts} +0 -0
  1051. package/src/scrollable/stories/{index.js → index.tsx} +29 -34
  1052. package/src/scrollable/{styles.js → styles.ts} +0 -0
  1053. package/src/scrollable/test/__snapshots__/{index.js.snap → index.tsx.snap} +1 -0
  1054. package/src/scrollable/test/index.tsx +34 -0
  1055. package/src/scrollable/types.ts +10 -5
  1056. package/src/select-control/index.tsx +1 -2
  1057. package/src/select-control/styles/select-control-styles.ts +33 -10
  1058. package/src/select-control/test/select-control.tsx +22 -15
  1059. package/src/select-control/types.ts +1 -0
  1060. package/src/shortcut/index.tsx +32 -0
  1061. package/src/shortcut/test/__snapshots__/index.tsx.snap +15 -0
  1062. package/src/shortcut/test/index.tsx +41 -0
  1063. package/src/shortcut/types.ts +10 -0
  1064. package/src/slot-fill/index.native.js +2 -7
  1065. package/src/slot-fill/provider.js +3 -7
  1066. package/src/slot-fill/slot.js +21 -24
  1067. package/src/spacer/README.md +43 -37
  1068. package/src/spacer/component.tsx +5 -3
  1069. package/src/spacer/hook.ts +4 -2
  1070. package/src/spacer/index.ts +1 -1
  1071. package/src/spacer/test/__snapshots__/{index.js.snap → index.tsx.snap} +1 -0
  1072. package/src/spacer/test/index.tsx +149 -0
  1073. package/src/spacer/types.ts +41 -29
  1074. package/src/style-provider/index.tsx +41 -0
  1075. package/src/style-provider/types.ts +15 -0
  1076. package/src/swatch/{index.js → index.tsx} +4 -1
  1077. package/src/swatch/types.ts +11 -0
  1078. package/src/tab-panel/README.md +1 -1
  1079. package/src/text/hook.js +5 -3
  1080. package/src/text-highlight/README.md +6 -6
  1081. package/src/text-highlight/index.tsx +49 -0
  1082. package/src/text-highlight/stories/index.tsx +33 -0
  1083. package/src/text-highlight/test/index.tsx +93 -0
  1084. package/src/text-highlight/types.ts +16 -0
  1085. package/src/tip/index.tsx +22 -0
  1086. package/src/tip/stories/index.tsx +33 -0
  1087. package/src/tip/types.ts +11 -0
  1088. package/src/toggle-group-control/stories/index.js +19 -3
  1089. package/src/toggle-group-control/test/__snapshots__/index.js.snap +28 -4
  1090. package/src/toggle-group-control/toggle-group-control/component.tsx +3 -3
  1091. package/src/toggle-group-control/toggle-group-control/styles.ts +22 -2
  1092. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +0 -4
  1093. package/src/toggle-group-control/types.ts +6 -0
  1094. package/src/toolbar-group/index.js +1 -2
  1095. package/src/tools-panel/styles.ts +7 -16
  1096. package/src/tools-panel/test/__snapshots__/index.js.snap +2 -11
  1097. package/src/tools-panel/tools-panel/README.md +94 -21
  1098. package/src/tools-panel/tools-panel/hook.ts +6 -1
  1099. package/src/tooltip/index.js +56 -10
  1100. package/src/tooltip/stories/index.js +28 -13
  1101. package/src/tooltip/style.scss +1 -1
  1102. package/src/tree-select/index.tsx +7 -6
  1103. package/src/tree-select/types.ts +4 -0
  1104. package/src/ui/context/test/context-system-provider.js +101 -1
  1105. package/src/ui/context/use-context-system.js +7 -2
  1106. package/src/ui/form-group/types.ts +1 -1
  1107. package/src/ui/tooltip/styles.js +1 -0
  1108. package/src/ui/tooltip/test/__snapshots__/index.js.snap +1 -0
  1109. package/src/ui/utils/get-valid-children.ts +4 -2
  1110. package/src/ui/utils/space.ts +7 -1
  1111. package/src/unit-control/stories/index.tsx +16 -23
  1112. package/src/unit-control/styles/unit-control-styles.ts +100 -46
  1113. package/src/unit-control/test/__snapshots__/index.tsx.snap +4 -4
  1114. package/src/unit-control/types.ts +2 -8
  1115. package/src/utils/base-label.ts +13 -0
  1116. package/src/utils/box-sizing.ts +14 -0
  1117. package/src/utils/style-mixins.js +2 -0
  1118. package/src/visually-hidden/{component.js → component.tsx} +23 -15
  1119. package/src/visually-hidden/{index.js → index.ts} +0 -0
  1120. package/src/visually-hidden/stories/index.tsx +66 -0
  1121. package/src/visually-hidden/{styles.js → styles.ts} +6 -2
  1122. package/src/visually-hidden/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
  1123. package/src/visually-hidden/test/index.tsx +17 -0
  1124. package/src/visually-hidden/types.ts +11 -0
  1125. package/tsconfig.json +3 -0
  1126. package/tsconfig.tsbuildinfo +1 -1
  1127. package/src/divider/test/index.js +0 -41
  1128. package/src/elevation/component.js +0 -43
  1129. package/src/elevation/stories/index.js +0 -148
  1130. package/src/elevation/test/index.js +0 -51
  1131. package/src/flex/flex/component.js +0 -60
  1132. package/src/flex/flex-block/component.js +0 -30
  1133. package/src/flex/flex-item/component.js +0 -30
  1134. package/src/flex/stories/index.js +0 -29
  1135. package/src/flex/test/index.js +0 -77
  1136. package/src/grid/stories/index.js +0 -49
  1137. package/src/h-stack/stories/index.js +0 -22
  1138. package/src/placeholder/stories/index.js +0 -44
  1139. package/src/popover/stories/_utils.js +0 -64
  1140. package/src/range-control/stories/index.js +0 -180
  1141. package/src/range-control/test/index.js +0 -320
  1142. package/src/range-control/utils.js +0 -131
  1143. package/src/scroll-lock/stories/index.js +0 -71
  1144. package/src/scroll-lock/test/index.js +0 -53
  1145. package/src/scrollable/test/index.js +0 -31
  1146. package/src/shortcut/index.js +0 -41
  1147. package/src/shortcut/test/index.js +0 -37
  1148. package/src/spacer/test/index.js +0 -146
  1149. package/src/style-provider/index.js +0 -31
  1150. package/src/text-highlight/index.js +0 -28
  1151. package/src/text-highlight/stories/index.js +0 -28
  1152. package/src/text-highlight/test/index.js +0 -120
  1153. package/src/tip/index.js +0 -24
  1154. package/src/tip/stories/index.js +0 -26
  1155. package/src/visually-hidden/stories/index.js +0 -42
  1156. package/src/visually-hidden/test/index.js +0 -19
@@ -15,6 +15,8 @@ var _i18n = require("@wordpress/i18n");
15
15
 
16
16
  var _icons = require("@wordpress/icons");
17
17
 
18
+ var _baseControl = require("../base-control");
19
+
18
20
  var _button = _interopRequireDefault(require("../button"));
19
21
 
20
22
  var _rangeControl = _interopRequireDefault(require("../range-control"));
@@ -50,6 +52,9 @@ function FontSizePicker(_ref, ref) {
50
52
  fontSizes = [],
51
53
  disableCustomFontSizes = false,
52
54
  onChange,
55
+
56
+ /** @type {'default' | '__unstable-large'} */
57
+ size = 'default',
53
58
  value,
54
59
  withSlider = false,
55
60
  withReset = true
@@ -67,9 +72,9 @@ function FontSizePicker(_ref, ref) {
67
72
 
68
73
  const fontSizesContainComplexValues = fontSizes.some(_ref2 => {
69
74
  let {
70
- size
75
+ size: sizeArg
71
76
  } = _ref2;
72
- return !(0, _utils.isSimpleCssValue)(size);
77
+ return !(0, _utils.isSimpleCssValue)(sizeArg);
73
78
  });
74
79
  const shouldUseSelectControl = fontSizes.length > 5;
75
80
  const options = (0, _element.useMemo)(() => (0, _utils.getFontSizeOptions)(shouldUseSelectControl, fontSizes, disableCustomFontSizes, fontSizesContainComplexValues), [shouldUseSelectControl, fontSizes, disableCustomFontSizes, fontSizesContainComplexValues]);
@@ -120,9 +125,9 @@ function FontSizePicker(_ref, ref) {
120
125
  }, (0, _i18n.__)('Font size')), (0, _element.createElement)(_flex.Flex, {
121
126
  justify: "space-between",
122
127
  className: `${baseClassName}__header`
123
- }, (0, _element.createElement)(_flex.FlexItem, null, (0, _i18n.__)('Size'), headerHint && (0, _element.createElement)("span", {
128
+ }, (0, _element.createElement)(_flex.FlexItem, null, (0, _element.createElement)(_baseControl.BaseControl.VisualLabel, null, (0, _i18n.__)('Size'), headerHint && (0, _element.createElement)("span", {
124
129
  className: `${baseClassName}__header__hint`
125
- }, headerHint)), !disableCustomFontSizes && (0, _element.createElement)(_flex.FlexItem, null, (0, _element.createElement)(_button.default, {
130
+ }, headerHint))), !disableCustomFontSizes && (0, _element.createElement)(_flex.FlexItem, null, (0, _element.createElement)(_button.default, {
126
131
  label: showCustomValueControl ? (0, _i18n.__)('Use size preset') : (0, _i18n.__)('Set custom size'),
127
132
  icon: _icons.settings,
128
133
  onClick: () => {
@@ -133,6 +138,7 @@ function FontSizePicker(_ref, ref) {
133
138
  }))), (0, _element.createElement)("div", {
134
139
  className: `${baseClassName}__controls`
135
140
  }, !!fontSizes.length && shouldUseSelectControl && !showCustomValueControl && (0, _element.createElement)(_customSelectControl.default, {
141
+ __nextUnconstrainedWidth: true,
136
142
  className: `${baseClassName}__select`,
137
143
  label: (0, _i18n.__)('Font size'),
138
144
  hideLabelFromVision: true,
@@ -148,7 +154,8 @@ function FontSizePicker(_ref, ref) {
148
154
  if (selectedItem.key === _utils.CUSTOM_FONT_SIZE) {
149
155
  setShowCustomValueControl(true);
150
156
  }
151
- }
157
+ },
158
+ size: size
152
159
  }), !shouldUseSelectControl && !showCustomValueControl && (0, _element.createElement)(_toggleGroupControl.ToggleGroupControl, {
153
160
  label: (0, _i18n.__)('Font size'),
154
161
  hideLabelFromVision: true,
@@ -156,7 +163,8 @@ function FontSizePicker(_ref, ref) {
156
163
  onChange: newValue => {
157
164
  onChange(hasUnits ? newValue : Number(newValue));
158
165
  },
159
- isBlock: true
166
+ isBlock: true,
167
+ size: size
160
168
  }, options.map(option => (0, _element.createElement)(_toggleGroupControl.ToggleGroupControlOption, {
161
169
  key: option.key,
162
170
  value: option.value,
@@ -180,6 +188,7 @@ function FontSizePicker(_ref, ref) {
180
188
  onChange(hasUnits ? nextSize : parseInt(nextSize, 10));
181
189
  }
182
190
  },
191
+ size: size,
183
192
  units: hasUnits ? units : []
184
193
  })), withReset && (0, _element.createElement)(_flex.FlexItem, {
185
194
  isBlock: true
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/font-size-picker/index.js"],"names":["FontSizePicker","ref","fallbackFontSize","fontSizes","disableCustomFontSizes","onChange","value","withSlider","withReset","hasUnits","size","includes","noUnitsValue","parseInt","isPixelValue","endsWith","units","availableUnits","fontSizesContainComplexValues","some","shouldUseSelectControl","length","options","selectedOption","isCustomValue","slug","CUSTOM_FONT_SIZE","showCustomValueControl","setShowCustomValueControl","headerHint","hint","name","unit","currentFontSizeSR","baseClassName","settings","find","option","key","selectedItem","Number","newValue","map","label","nextSize","parseFloat","undefined"],"mappings":";;;;;;;;;AAKA;;;;AAFA;;AACA;;AAMA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAIA;;;;;;AApBA;AACA;AACA;;AAKA;AACA;AACA;AAmBA,SAASA,cAAT,OAUCC,GAVD,EAWE;AAAA;;AAAA,MAVD;AACCC,IAAAA,gBADD;AAECC,IAAAA,SAAS,GAAG,EAFb;AAGCC,IAAAA,sBAAsB,GAAG,KAH1B;AAICC,IAAAA,QAJD;AAKCC,IAAAA,KALD;AAMCC,IAAAA,UAAU,GAAG,KANd;AAOCC,IAAAA,SAAS,GAAG;AAPb,GAUC;AACD,QAAMC,QAAQ,GAAG,CAAE,OAAOH,KAAT,EAAgB,QAAOH,SAAP,aAAOA,SAAP,sCAAOA,SAAS,CAAI,CAAJ,CAAhB,gDAAO,YAAkBO,IAAzB,CAAhB,EAAgDC,QAAhD,CAChB,QADgB,CAAjB;AAGA,QAAMC,YAAY,GAAG,CAAEH,QAAF,GAAaH,KAAb,GAAqBO,QAAQ,CAAEP,KAAF,CAAlD;AACA,QAAMQ,YAAY,GAAG,OAAOR,KAAP,KAAiB,QAAjB,KAA6BA,KAA7B,aAA6BA,KAA7B,0CAA6BA,KAAK,CAAES,QAApC,oDAA6B,qBAAAT,KAAK,EAAc,IAAd,CAAlC,CAArB;AACA,QAAMU,KAAK,GAAG,iCAAgB;AAC7BC,IAAAA,cAAc,EAAE,CAAE,IAAF,EAAQ,IAAR,EAAc,KAAd;AADa,GAAhB,CAAd;AAIA;AACD;AACA;AACA;;AACC,QAAMC,6BAA6B,GAAGf,SAAS,CAACgB,IAAV,CACrC;AAAA,QAAE;AAAET,MAAAA;AAAF,KAAF;AAAA,WAAgB,CAAE,6BAAkBA,IAAlB,CAAlB;AAAA,GADqC,CAAtC;AAGA,QAAMU,sBAAsB,GAAGjB,SAAS,CAACkB,MAAV,GAAmB,CAAlD;AACA,QAAMC,OAAO,GAAG,sBACf,MACC,+BACCF,sBADD,EAECjB,SAFD,EAGCC,sBAHD,EAICc,6BAJD,CAFc,EAQf,CACCE,sBADD,EAECjB,SAFD,EAGCC,sBAHD,EAICc,6BAJD,CARe,CAAhB;AAeA,QAAMK,cAAc,GAAG,8BAAmBpB,SAAnB,EAA8BG,KAA9B,CAAvB;AACA,QAAMkB,aAAa,GAAGD,cAAc,CAACE,IAAf,KAAwBC,uBAA9C;AACA,QAAM,CAAEC,sBAAF,EAA0BC,yBAA1B,IAAwD,uBAC7D,CAAExB,sBAAF,IAA4BoB,aADiC,CAA9D;AAGA,QAAMK,UAAU,GAAG,sBAAS,MAAM;AACjC,QAAKF,sBAAL,EAA8B;AAC7B,aAAQ,IAAI,cAAI,QAAJ,CAAgB,GAA5B;AACA,KAHgC,CAKjC;AACA;;;AACA,QAAKH,aAAL,EAAqB;AACpB,aAAO,6BAAkBlB,KAAlB,KAA8B,IAAIA,KAAO,GAAhD;AACA;;AACD,QAAKc,sBAAL,EAA8B;AAC7B,aACC,6BAAkBG,cAAlB,aAAkBA,cAAlB,uBAAkBA,cAAc,CAAEb,IAAlC,KACC,IAAIa,cAAL,aAAKA,cAAL,uBAAKA,cAAc,CAAEb,IAAM,GAF5B;AAIA,KAfgC,CAgBjC;;;AACA,QAAIoB,IAAI,GAAGP,cAAc,CAACQ,IAA1B;;AACA,QACC,CAAEb,6BAAF,IACA,OAAOK,cAAc,CAACb,IAAtB,KAA+B,QAFhC,EAGE;AACD,YAAM,GAAIsB,IAAJ,IAAa,sCAA2BT,cAAc,CAACb,IAA1C,CAAnB;AACAoB,MAAAA,IAAI,IAAK,IAAIE,IAAM,GAAnB;AACA;;AACD,WAAOF,IAAP;AACA,GA1BkB,EA0BhB,CACFH,sBADE,EAEFJ,cAFE,aAEFA,cAFE,uBAEFA,cAAc,CAAEQ,IAFd,EAGFR,cAHE,aAGFA,cAHE,uBAGFA,cAAc,CAAEb,IAHd,EAIFJ,KAJE,EAKFkB,aALE,EAMFJ,sBANE,EAOFF,6BAPE,CA1BgB,CAAnB;;AAoCA,MAAK,CAAEI,OAAP,EAAiB;AAChB,WAAO,IAAP;AACA,GA5EA,CA8ED;AACA;;;AACA,QAAMW,iBAAiB,GAAG,oBACzB;AACA,gBAAI,kCAAJ,CAFyB,EAGzBV,cAAc,CAACQ,IAHU,CAA1B;AAKA,QAAMG,aAAa,GAAG,6BAAtB;AACA,SACC;AAAU,IAAA,SAAS,EAAGA;AAAtB,KAA6CjC,GAAG,GAAG,EAAH,GAAQ;AAAEA,IAAAA;AAAF,GAAxD,GACC,4BAAC,8BAAD;AAAgB,IAAA,EAAE,EAAC;AAAnB,KAA8B,cAAI,WAAJ,CAA9B,CADD,EAEC,4BAAC,UAAD;AACC,IAAA,OAAO,EAAC,eADT;AAEC,IAAA,SAAS,EAAI,GAAGiC,aAAe;AAFhC,KAIC,4BAAC,cAAD,QACG,cAAI,MAAJ,CADH,EAEGL,UAAU,IACX;AAAM,IAAA,SAAS,EAAI,GAAGK,aAAe;AAArC,KACGL,UADH,CAHF,CAJD,EAYG,CAAEzB,sBAAF,IACD,4BAAC,cAAD,QACC,4BAAC,eAAD;AACC,IAAA,KAAK,EACJuB,sBAAsB,GACnB,cAAI,iBAAJ,CADmB,GAEnB,cAAI,iBAAJ,CAJL;AAMC,IAAA,IAAI,EAAGQ,eANR;AAOC,IAAA,OAAO,EAAG,MAAM;AACfP,MAAAA,yBAAyB,CACxB,CAAED,sBADsB,CAAzB;AAGA,KAXF;AAYC,IAAA,SAAS,EAAGA,sBAZb;AAaC,IAAA,OAAO;AAbR,IADD,CAbF,CAFD,EAkCC;AAAK,IAAA,SAAS,EAAI,GAAGO,aAAe;AAApC,KACG,CAAC,CAAE/B,SAAS,CAACkB,MAAb,IACDD,sBADC,IAED,CAAEO,sBAFD,IAGA,4BAAC,4BAAD;AACC,IAAA,SAAS,EAAI,GAAGO,aAAe,UADhC;AAEC,IAAA,KAAK,EAAG,cAAI,WAAJ,CAFT;AAGC,IAAA,mBAAmB,MAHpB;AAIC,IAAA,WAAW,EAAGD,iBAJf;AAKC,IAAA,OAAO,EAAGX,OALX;AAMC,IAAA,KAAK,EAAGA,OAAO,CAACc,IAAR,CACLC,MAAF,IAAcA,MAAM,CAACC,GAAP,KAAef,cAAc,CAACE,IADrC,CANT;AASC,IAAA,QAAQ,EAAG,SAAwB;AAAA,UAAtB;AAAEc,QAAAA;AAAF,OAAsB;AAClClC,MAAAA,QAAQ,CACPI,QAAQ,GACL8B,YAAY,CAAC7B,IADR,GAEL8B,MAAM,CAAED,YAAY,CAAC7B,IAAf,CAHF,CAAR;;AAKA,UAAK6B,YAAY,CAACD,GAAb,KAAqBZ,uBAA1B,EAA6C;AAC5CE,QAAAA,yBAAyB,CAAE,IAAF,CAAzB;AACA;AACD;AAlBF,IAJH,EAyBG,CAAER,sBAAF,IAA4B,CAAEO,sBAA9B,IACD,4BAAC,sCAAD;AACC,IAAA,KAAK,EAAG,cAAI,WAAJ,CADT;AAEC,IAAA,mBAAmB,MAFpB;AAGC,IAAA,KAAK,EAAGrB,KAHT;AAIC,IAAA,QAAQ,EAAKmC,QAAF,IAAgB;AAC1BpC,MAAAA,QAAQ,CACPI,QAAQ,GAAGgC,QAAH,GAAcD,MAAM,CAAEC,QAAF,CADrB,CAAR;AAGA,KARF;AASC,IAAA,OAAO;AATR,KAWGnB,OAAO,CAACoB,GAAR,CAAeL,MAAF,IACd,4BAAC,4CAAD;AACC,IAAA,GAAG,EAAGA,MAAM,CAACC,GADd;AAEC,IAAA,KAAK,EAAGD,MAAM,CAAC/B,KAFhB;AAGC,IAAA,KAAK,EAAG+B,MAAM,CAACM,KAHhB;AAIC,kBAAaN,MAAM,CAACN,IAJrB;AAKC,IAAA,WAAW,EAAG;AALf,IADC,CAXH,CA1BF,EAgDG,CAAExB,UAAF,IACD,CAAEH,sBADD,IAEDuB,sBAFC,IAGA,4BAAC,UAAD;AACC,IAAA,OAAO,EAAC,eADT;AAEC,IAAA,SAAS,EAAI,GAAGO,aAAe;AAFhC,KAIC,4BAAC,cAAD;AAAU,IAAA,OAAO;AAAjB,KACC,4BAAC,oBAAD;AACC,IAAA,KAAK,EAAG,cAAI,QAAJ,CADT;AAEC,IAAA,aAAa,EAAC,KAFf;AAGC,IAAA,mBAAmB,MAHpB;AAIC,IAAA,KAAK,EAAG5B,KAJT;AAKC,IAAA,QAAQ,EAAKsC,QAAF,IAAgB;AAC1B,UACC,MAAMC,UAAU,CAAED,QAAF,CAAhB,IACA,CAAEA,QAFH,EAGE;AACDvC,QAAAA,QAAQ,CAAEyC,SAAF,CAAR;AACA,OALD,MAKO;AACNzC,QAAAA,QAAQ,CACPI,QAAQ,GACLmC,QADK,GAEL/B,QAAQ,CAAE+B,QAAF,EAAY,EAAZ,CAHJ,CAAR;AAKA;AACD,KAlBF;AAmBC,IAAA,KAAK,EAAGnC,QAAQ,GAAGO,KAAH,GAAW;AAnB5B,IADD,CAJD,EA2BGR,SAAS,IACV,4BAAC,cAAD;AAAU,IAAA,OAAO;AAAjB,KACC,4BAAC,eAAD;AACC,IAAA,SAAS,EAAC,iCADX;AAEC,IAAA,QAAQ,EAAGF,KAAK,KAAKwC,SAFtB;AAGC,IAAA,OAAO,EAAG,MAAM;AACfzC,MAAAA,QAAQ,CAAEyC,SAAF,CAAR;AACA,KALF;AAMC,IAAA,OAAO,MANR;AAOC,IAAA,OAAO,EAAC;AAPT,KASG,cAAI,OAAJ,CATH,CADD,CA5BF,CAnDH,CAlCD,EAkIGvC,UAAU,IACX,4BAAC,qBAAD;AACC,IAAA,SAAS,EAAI,GAAG2B,aAAe,gBADhC;AAEC,IAAA,KAAK,EAAG,cAAI,aAAJ,CAFT;AAGC,IAAA,KAAK,EAAKpB,YAAY,IAAIF,YAAlB,IAAoC,EAH7C;AAIC,IAAA,eAAe,EAAGV,gBAJnB;AAKC,IAAA,QAAQ,EAAKuC,QAAF,IAAgB;AAC1BpC,MAAAA,QAAQ,CAAEI,QAAQ,GAAGgC,QAAQ,GAAG,IAAd,GAAqBA,QAA/B,CAAR;AACA,KAPF;AAQC,IAAA,GAAG,EAAG,EARP;AASC,IAAA,GAAG,EAAG;AATP,IAnIF,CADD;AAkJA;;eAEc,yBAAYzC,cAAZ,C","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __, sprintf } from '@wordpress/i18n';\nimport { settings } from '@wordpress/icons';\nimport { useState, useMemo, forwardRef } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport Button from '../button';\nimport RangeControl from '../range-control';\nimport { Flex, FlexItem } from '../flex';\nimport { default as UnitControl, useCustomUnits } from '../unit-control';\nimport CustomSelectControl from '../custom-select-control';\nimport { VisuallyHidden } from '../visually-hidden';\nimport {\n\tToggleGroupControl,\n\tToggleGroupControlOption,\n} from '../toggle-group-control';\nimport {\n\tgetFontSizeOptions,\n\tgetSelectedOption,\n\tsplitValueAndUnitFromSize,\n\tisSimpleCssValue,\n\tCUSTOM_FONT_SIZE,\n} from './utils';\n\nfunction FontSizePicker(\n\t{\n\t\tfallbackFontSize,\n\t\tfontSizes = [],\n\t\tdisableCustomFontSizes = false,\n\t\tonChange,\n\t\tvalue,\n\t\twithSlider = false,\n\t\twithReset = true,\n\t},\n\tref\n) {\n\tconst hasUnits = [ typeof value, typeof fontSizes?.[ 0 ]?.size ].includes(\n\t\t'string'\n\t);\n\tconst noUnitsValue = ! hasUnits ? value : parseInt( value );\n\tconst isPixelValue = typeof value === 'number' || value?.endsWith?.( 'px' );\n\tconst units = useCustomUnits( {\n\t\tavailableUnits: [ 'px', 'em', 'rem' ],\n\t} );\n\n\t/**\n\t * The main font size UI displays a toggle group when the presets are less\n\t * than six and a select control when they are more.\n\t */\n\tconst fontSizesContainComplexValues = fontSizes.some(\n\t\t( { size } ) => ! isSimpleCssValue( size )\n\t);\n\tconst shouldUseSelectControl = fontSizes.length > 5;\n\tconst options = useMemo(\n\t\t() =>\n\t\t\tgetFontSizeOptions(\n\t\t\t\tshouldUseSelectControl,\n\t\t\t\tfontSizes,\n\t\t\t\tdisableCustomFontSizes,\n\t\t\t\tfontSizesContainComplexValues\n\t\t\t),\n\t\t[\n\t\t\tshouldUseSelectControl,\n\t\t\tfontSizes,\n\t\t\tdisableCustomFontSizes,\n\t\t\tfontSizesContainComplexValues,\n\t\t]\n\t);\n\tconst selectedOption = getSelectedOption( fontSizes, value );\n\tconst isCustomValue = selectedOption.slug === CUSTOM_FONT_SIZE;\n\tconst [ showCustomValueControl, setShowCustomValueControl ] = useState(\n\t\t! disableCustomFontSizes && isCustomValue\n\t);\n\tconst headerHint = useMemo( () => {\n\t\tif ( showCustomValueControl ) {\n\t\t\treturn `(${ __( 'Custom' ) })`;\n\t\t}\n\n\t\t// If we have a custom value that is not available in the font sizes,\n\t\t// show it as a hint as long as it's a simple CSS value.\n\t\tif ( isCustomValue ) {\n\t\t\treturn isSimpleCssValue( value ) && `(${ value })`;\n\t\t}\n\t\tif ( shouldUseSelectControl ) {\n\t\t\treturn (\n\t\t\t\tisSimpleCssValue( selectedOption?.size ) &&\n\t\t\t\t`(${ selectedOption?.size })`\n\t\t\t);\n\t\t}\n\t\t// Calculate the `hint` for toggle group control.\n\t\tlet hint = selectedOption.name;\n\t\tif (\n\t\t\t! fontSizesContainComplexValues &&\n\t\t\ttypeof selectedOption.size === 'string'\n\t\t) {\n\t\t\tconst [ , unit ] = splitValueAndUnitFromSize( selectedOption.size );\n\t\t\thint += `(${ unit })`;\n\t\t}\n\t\treturn hint;\n\t}, [\n\t\tshowCustomValueControl,\n\t\tselectedOption?.name,\n\t\tselectedOption?.size,\n\t\tvalue,\n\t\tisCustomValue,\n\t\tshouldUseSelectControl,\n\t\tfontSizesContainComplexValues,\n\t] );\n\n\tif ( ! options ) {\n\t\treturn null;\n\t}\n\n\t// This is used for select control only. We need to add support\n\t// for ToggleGroupControl.\n\tconst currentFontSizeSR = sprintf(\n\t\t// translators: %s: Currently selected font size.\n\t\t__( 'Currently selected font size: %s' ),\n\t\tselectedOption.name\n\t);\n\tconst baseClassName = 'components-font-size-picker';\n\treturn (\n\t\t<fieldset className={ baseClassName } { ...( ref ? {} : { ref } ) }>\n\t\t\t<VisuallyHidden as=\"legend\">{ __( 'Font size' ) }</VisuallyHidden>\n\t\t\t<Flex\n\t\t\t\tjustify=\"space-between\"\n\t\t\t\tclassName={ `${ baseClassName }__header` }\n\t\t\t>\n\t\t\t\t<FlexItem>\n\t\t\t\t\t{ __( 'Size' ) }\n\t\t\t\t\t{ headerHint && (\n\t\t\t\t\t\t<span className={ `${ baseClassName }__header__hint` }>\n\t\t\t\t\t\t\t{ headerHint }\n\t\t\t\t\t\t</span>\n\t\t\t\t\t) }\n\t\t\t\t</FlexItem>\n\t\t\t\t{ ! disableCustomFontSizes && (\n\t\t\t\t\t<FlexItem>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tlabel={\n\t\t\t\t\t\t\t\tshowCustomValueControl\n\t\t\t\t\t\t\t\t\t? __( 'Use size preset' )\n\t\t\t\t\t\t\t\t\t: __( 'Set custom size' )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\ticon={ settings }\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetShowCustomValueControl(\n\t\t\t\t\t\t\t\t\t! showCustomValueControl\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tisPressed={ showCustomValueControl }\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t/>\n\t\t\t\t\t</FlexItem>\n\t\t\t\t) }\n\t\t\t</Flex>\n\t\t\t<div className={ `${ baseClassName }__controls` }>\n\t\t\t\t{ !! fontSizes.length &&\n\t\t\t\t\tshouldUseSelectControl &&\n\t\t\t\t\t! showCustomValueControl && (\n\t\t\t\t\t\t<CustomSelectControl\n\t\t\t\t\t\t\tclassName={ `${ baseClassName }__select` }\n\t\t\t\t\t\t\tlabel={ __( 'Font size' ) }\n\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\tdescribedBy={ currentFontSizeSR }\n\t\t\t\t\t\t\toptions={ options }\n\t\t\t\t\t\t\tvalue={ options.find(\n\t\t\t\t\t\t\t\t( option ) => option.key === selectedOption.slug\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\tonChange={ ( { selectedItem } ) => {\n\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\thasUnits\n\t\t\t\t\t\t\t\t\t\t? selectedItem.size\n\t\t\t\t\t\t\t\t\t\t: Number( selectedItem.size )\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tif ( selectedItem.key === CUSTOM_FONT_SIZE ) {\n\t\t\t\t\t\t\t\t\tsetShowCustomValueControl( true );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t{ ! shouldUseSelectControl && ! showCustomValueControl && (\n\t\t\t\t\t<ToggleGroupControl\n\t\t\t\t\t\tlabel={ __( 'Font size' ) }\n\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\thasUnits ? newValue : Number( newValue )\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tisBlock\n\t\t\t\t\t>\n\t\t\t\t\t\t{ options.map( ( option ) => (\n\t\t\t\t\t\t\t<ToggleGroupControlOption\n\t\t\t\t\t\t\t\tkey={ option.key }\n\t\t\t\t\t\t\t\tvalue={ option.value }\n\t\t\t\t\t\t\t\tlabel={ option.label }\n\t\t\t\t\t\t\t\taria-label={ option.name }\n\t\t\t\t\t\t\t\tshowTooltip={ true }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) ) }\n\t\t\t\t\t</ToggleGroupControl>\n\t\t\t\t) }\n\t\t\t\t{ ! withSlider &&\n\t\t\t\t\t! disableCustomFontSizes &&\n\t\t\t\t\tshowCustomValueControl && (\n\t\t\t\t\t\t<Flex\n\t\t\t\t\t\t\tjustify=\"space-between\"\n\t\t\t\t\t\t\tclassName={ `${ baseClassName }__custom-size-control` }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<FlexItem isBlock>\n\t\t\t\t\t\t\t\t<UnitControl\n\t\t\t\t\t\t\t\t\tlabel={ __( 'Custom' ) }\n\t\t\t\t\t\t\t\t\tlabelPosition=\"top\"\n\t\t\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\t\t\t\tonChange={ ( nextSize ) => {\n\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t0 === parseFloat( nextSize ) ||\n\t\t\t\t\t\t\t\t\t\t\t! nextSize\n\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\tonChange( undefined );\n\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\t\t\t\thasUnits\n\t\t\t\t\t\t\t\t\t\t\t\t\t? nextSize\n\t\t\t\t\t\t\t\t\t\t\t\t\t: parseInt( nextSize, 10 )\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\tunits={ hasUnits ? units : [] }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</FlexItem>\n\t\t\t\t\t\t\t{ withReset && (\n\t\t\t\t\t\t\t\t<FlexItem isBlock>\n\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\tclassName=\"components-color-palette__clear\"\n\t\t\t\t\t\t\t\t\t\tdisabled={ value === undefined }\n\t\t\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\t\t\tonChange( undefined );\n\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\t\t\t\tvariant=\"secondary\"\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{ __( 'Reset' ) }\n\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t</FlexItem>\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t</Flex>\n\t\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ withSlider && (\n\t\t\t\t<RangeControl\n\t\t\t\t\tclassName={ `${ baseClassName }__custom-input` }\n\t\t\t\t\tlabel={ __( 'Custom Size' ) }\n\t\t\t\t\tvalue={ ( isPixelValue && noUnitsValue ) || '' }\n\t\t\t\t\tinitialPosition={ fallbackFontSize }\n\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\tonChange( hasUnits ? newValue + 'px' : newValue );\n\t\t\t\t\t} }\n\t\t\t\t\tmin={ 12 }\n\t\t\t\t\tmax={ 100 }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</fieldset>\n\t);\n}\n\nexport default forwardRef( FontSizePicker );\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/font-size-picker/index.js"],"names":["FontSizePicker","ref","fallbackFontSize","fontSizes","disableCustomFontSizes","onChange","size","value","withSlider","withReset","hasUnits","includes","noUnitsValue","parseInt","isPixelValue","endsWith","units","availableUnits","fontSizesContainComplexValues","some","sizeArg","shouldUseSelectControl","length","options","selectedOption","isCustomValue","slug","CUSTOM_FONT_SIZE","showCustomValueControl","setShowCustomValueControl","headerHint","hint","name","unit","currentFontSizeSR","baseClassName","settings","find","option","key","selectedItem","Number","newValue","map","label","nextSize","parseFloat","undefined"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __, sprintf } from '@wordpress/i18n';\nimport { settings } from '@wordpress/icons';\nimport { useState, useMemo, forwardRef } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { BaseControl } from '../base-control';\nimport Button from '../button';\nimport RangeControl from '../range-control';\nimport { Flex, FlexItem } from '../flex';\nimport { default as UnitControl, useCustomUnits } from '../unit-control';\nimport CustomSelectControl from '../custom-select-control';\nimport { VisuallyHidden } from '../visually-hidden';\nimport {\n\tToggleGroupControl,\n\tToggleGroupControlOption,\n} from '../toggle-group-control';\nimport {\n\tgetFontSizeOptions,\n\tgetSelectedOption,\n\tsplitValueAndUnitFromSize,\n\tisSimpleCssValue,\n\tCUSTOM_FONT_SIZE,\n} from './utils';\n\nfunction FontSizePicker(\n\t{\n\t\tfallbackFontSize,\n\t\tfontSizes = [],\n\t\tdisableCustomFontSizes = false,\n\t\tonChange,\n\t\t/** @type {'default' | '__unstable-large'} */\n\t\tsize = 'default',\n\t\tvalue,\n\t\twithSlider = false,\n\t\twithReset = true,\n\t},\n\tref\n) {\n\tconst hasUnits = [ typeof value, typeof fontSizes?.[ 0 ]?.size ].includes(\n\t\t'string'\n\t);\n\tconst noUnitsValue = ! hasUnits ? value : parseInt( value );\n\tconst isPixelValue = typeof value === 'number' || value?.endsWith?.( 'px' );\n\tconst units = useCustomUnits( {\n\t\tavailableUnits: [ 'px', 'em', 'rem' ],\n\t} );\n\n\t/**\n\t * The main font size UI displays a toggle group when the presets are less\n\t * than six and a select control when they are more.\n\t */\n\tconst fontSizesContainComplexValues = fontSizes.some(\n\t\t( { size: sizeArg } ) => ! isSimpleCssValue( sizeArg )\n\t);\n\tconst shouldUseSelectControl = fontSizes.length > 5;\n\tconst options = useMemo(\n\t\t() =>\n\t\t\tgetFontSizeOptions(\n\t\t\t\tshouldUseSelectControl,\n\t\t\t\tfontSizes,\n\t\t\t\tdisableCustomFontSizes,\n\t\t\t\tfontSizesContainComplexValues\n\t\t\t),\n\t\t[\n\t\t\tshouldUseSelectControl,\n\t\t\tfontSizes,\n\t\t\tdisableCustomFontSizes,\n\t\t\tfontSizesContainComplexValues,\n\t\t]\n\t);\n\tconst selectedOption = getSelectedOption( fontSizes, value );\n\tconst isCustomValue = selectedOption.slug === CUSTOM_FONT_SIZE;\n\tconst [ showCustomValueControl, setShowCustomValueControl ] = useState(\n\t\t! disableCustomFontSizes && isCustomValue\n\t);\n\tconst headerHint = useMemo( () => {\n\t\tif ( showCustomValueControl ) {\n\t\t\treturn `(${ __( 'Custom' ) })`;\n\t\t}\n\n\t\t// If we have a custom value that is not available in the font sizes,\n\t\t// show it as a hint as long as it's a simple CSS value.\n\t\tif ( isCustomValue ) {\n\t\t\treturn isSimpleCssValue( value ) && `(${ value })`;\n\t\t}\n\t\tif ( shouldUseSelectControl ) {\n\t\t\treturn (\n\t\t\t\tisSimpleCssValue( selectedOption?.size ) &&\n\t\t\t\t`(${ selectedOption?.size })`\n\t\t\t);\n\t\t}\n\t\t// Calculate the `hint` for toggle group control.\n\t\tlet hint = selectedOption.name;\n\t\tif (\n\t\t\t! fontSizesContainComplexValues &&\n\t\t\ttypeof selectedOption.size === 'string'\n\t\t) {\n\t\t\tconst [ , unit ] = splitValueAndUnitFromSize( selectedOption.size );\n\t\t\thint += `(${ unit })`;\n\t\t}\n\t\treturn hint;\n\t}, [\n\t\tshowCustomValueControl,\n\t\tselectedOption?.name,\n\t\tselectedOption?.size,\n\t\tvalue,\n\t\tisCustomValue,\n\t\tshouldUseSelectControl,\n\t\tfontSizesContainComplexValues,\n\t] );\n\n\tif ( ! options ) {\n\t\treturn null;\n\t}\n\n\t// This is used for select control only. We need to add support\n\t// for ToggleGroupControl.\n\tconst currentFontSizeSR = sprintf(\n\t\t// translators: %s: Currently selected font size.\n\t\t__( 'Currently selected font size: %s' ),\n\t\tselectedOption.name\n\t);\n\tconst baseClassName = 'components-font-size-picker';\n\treturn (\n\t\t<fieldset className={ baseClassName } { ...( ref ? {} : { ref } ) }>\n\t\t\t<VisuallyHidden as=\"legend\">{ __( 'Font size' ) }</VisuallyHidden>\n\t\t\t<Flex\n\t\t\t\tjustify=\"space-between\"\n\t\t\t\tclassName={ `${ baseClassName }__header` }\n\t\t\t>\n\t\t\t\t<FlexItem>\n\t\t\t\t\t<BaseControl.VisualLabel>\n\t\t\t\t\t\t{ __( 'Size' ) }\n\t\t\t\t\t\t{ headerHint && (\n\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\tclassName={ `${ baseClassName }__header__hint` }\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{ headerHint }\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</BaseControl.VisualLabel>\n\t\t\t\t</FlexItem>\n\t\t\t\t{ ! disableCustomFontSizes && (\n\t\t\t\t\t<FlexItem>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tlabel={\n\t\t\t\t\t\t\t\tshowCustomValueControl\n\t\t\t\t\t\t\t\t\t? __( 'Use size preset' )\n\t\t\t\t\t\t\t\t\t: __( 'Set custom size' )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\ticon={ settings }\n\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\tsetShowCustomValueControl(\n\t\t\t\t\t\t\t\t\t! showCustomValueControl\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tisPressed={ showCustomValueControl }\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t/>\n\t\t\t\t\t</FlexItem>\n\t\t\t\t) }\n\t\t\t</Flex>\n\t\t\t<div className={ `${ baseClassName }__controls` }>\n\t\t\t\t{ !! fontSizes.length &&\n\t\t\t\t\tshouldUseSelectControl &&\n\t\t\t\t\t! showCustomValueControl && (\n\t\t\t\t\t\t<CustomSelectControl\n\t\t\t\t\t\t\t__nextUnconstrainedWidth\n\t\t\t\t\t\t\tclassName={ `${ baseClassName }__select` }\n\t\t\t\t\t\t\tlabel={ __( 'Font size' ) }\n\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\tdescribedBy={ currentFontSizeSR }\n\t\t\t\t\t\t\toptions={ options }\n\t\t\t\t\t\t\tvalue={ options.find(\n\t\t\t\t\t\t\t\t( option ) => option.key === selectedOption.slug\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\tonChange={ ( { selectedItem } ) => {\n\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\thasUnits\n\t\t\t\t\t\t\t\t\t\t? selectedItem.size\n\t\t\t\t\t\t\t\t\t\t: Number( selectedItem.size )\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\tif ( selectedItem.key === CUSTOM_FONT_SIZE ) {\n\t\t\t\t\t\t\t\t\tsetShowCustomValueControl( true );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tsize={ size }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t{ ! shouldUseSelectControl && ! showCustomValueControl && (\n\t\t\t\t\t<ToggleGroupControl\n\t\t\t\t\t\tlabel={ __( 'Font size' ) }\n\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\thasUnits ? newValue : Number( newValue )\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tisBlock\n\t\t\t\t\t\tsize={ size }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ options.map( ( option ) => (\n\t\t\t\t\t\t\t<ToggleGroupControlOption\n\t\t\t\t\t\t\t\tkey={ option.key }\n\t\t\t\t\t\t\t\tvalue={ option.value }\n\t\t\t\t\t\t\t\tlabel={ option.label }\n\t\t\t\t\t\t\t\taria-label={ option.name }\n\t\t\t\t\t\t\t\tshowTooltip={ true }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) ) }\n\t\t\t\t\t</ToggleGroupControl>\n\t\t\t\t) }\n\t\t\t\t{ ! withSlider &&\n\t\t\t\t\t! disableCustomFontSizes &&\n\t\t\t\t\tshowCustomValueControl && (\n\t\t\t\t\t\t<Flex\n\t\t\t\t\t\t\tjustify=\"space-between\"\n\t\t\t\t\t\t\tclassName={ `${ baseClassName }__custom-size-control` }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<FlexItem isBlock>\n\t\t\t\t\t\t\t\t<UnitControl\n\t\t\t\t\t\t\t\t\tlabel={ __( 'Custom' ) }\n\t\t\t\t\t\t\t\t\tlabelPosition=\"top\"\n\t\t\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\t\t\t\tonChange={ ( nextSize ) => {\n\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t0 === parseFloat( nextSize ) ||\n\t\t\t\t\t\t\t\t\t\t\t! nextSize\n\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\tonChange( undefined );\n\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\tonChange(\n\t\t\t\t\t\t\t\t\t\t\t\thasUnits\n\t\t\t\t\t\t\t\t\t\t\t\t\t? nextSize\n\t\t\t\t\t\t\t\t\t\t\t\t\t: parseInt( nextSize, 10 )\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\tsize={ size }\n\t\t\t\t\t\t\t\t\tunits={ hasUnits ? units : [] }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</FlexItem>\n\t\t\t\t\t\t\t{ withReset && (\n\t\t\t\t\t\t\t\t<FlexItem isBlock>\n\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\tclassName=\"components-color-palette__clear\"\n\t\t\t\t\t\t\t\t\t\tdisabled={ value === undefined }\n\t\t\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\t\t\tonChange( undefined );\n\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\t\t\t\tvariant=\"secondary\"\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{ __( 'Reset' ) }\n\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t</FlexItem>\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t</Flex>\n\t\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ withSlider && (\n\t\t\t\t<RangeControl\n\t\t\t\t\tclassName={ `${ baseClassName }__custom-input` }\n\t\t\t\t\tlabel={ __( 'Custom Size' ) }\n\t\t\t\t\tvalue={ ( isPixelValue && noUnitsValue ) || '' }\n\t\t\t\t\tinitialPosition={ fallbackFontSize }\n\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\tonChange( hasUnits ? newValue + 'px' : newValue );\n\t\t\t\t\t} }\n\t\t\t\t\tmin={ 12 }\n\t\t\t\t\tmax={ 100 }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</fieldset>\n\t);\n}\n\nexport default forwardRef( FontSizePicker );\n"]}
@@ -30,8 +30,14 @@ var _token = _interopRequireDefault(require("./token"));
30
30
 
31
31
  var _tokenInput = _interopRequireDefault(require("./token-input"));
32
32
 
33
+ var _styles = require("./styles");
34
+
33
35
  var _suggestionsList = _interopRequireDefault(require("./suggestions-list"));
34
36
 
37
+ var _flex = require("../flex");
38
+
39
+ var _baseControlStyles = require("../base-control/styles/base-control-styles");
40
+
35
41
  /**
36
42
  * External dependencies
37
43
  */
@@ -43,7 +49,7 @@ var _suggestionsList = _interopRequireDefault(require("./suggestions-list"));
43
49
  /**
44
50
  * Internal dependencies
45
51
  */
46
-
52
+ const identity = value => value;
47
53
  /**
48
54
  * A `FormTokenField` is a field similar to the tags and categories fields in the interim editor chrome,
49
55
  * or the "to" field in Mail on OS X. Tokens can be entered by typing them or selecting them from a list of suggested tokens.
@@ -54,6 +60,8 @@ var _suggestionsList = _interopRequireDefault(require("./suggestions-list"));
54
60
  * The `value` property is handled in a manner similar to controlled form components.
55
61
  * See [Forms](http://facebook.github.io/react/docs/forms.html) in the React Documentation for more information.
56
62
  */
63
+
64
+
57
65
  function FormTokenField(props) {
58
66
  const {
59
67
  autoCapitalize,
@@ -65,7 +73,7 @@ function FormTokenField(props) {
65
73
  suggestions = [],
66
74
  maxSuggestions = 100,
67
75
  value = [],
68
- displayTransform = _lodash.identity,
76
+ displayTransform = identity,
69
77
  saveTransform = token => token.trim(),
70
78
  onChange = () => {},
71
79
  onInputChange = () => {},
@@ -79,9 +87,11 @@ function FormTokenField(props) {
79
87
  remove: (0, _i18n.__)('Remove item'),
80
88
  __experimentalInvalid: (0, _i18n.__)('Invalid item')
81
89
  },
90
+ __experimentalRenderItem,
82
91
  __experimentalExpandOnFocus = false,
83
92
  __experimentalValidateInput = () => true,
84
- __experimentalShowHowTo = true
93
+ __experimentalShowHowTo = true,
94
+ __next36pxDefaultSize = false
85
95
  } = props;
86
96
  const instanceId = (0, _compose.useInstanceId)(FormTokenField); // We reset to these initial values again in the onBlur
87
97
 
@@ -547,8 +557,9 @@ function FormTokenField(props) {
547
557
  const status = typeof token !== 'string' ? token.status : undefined;
548
558
  const termPosition = index + 1;
549
559
  const termsCount = tokens.length;
550
- return (0, _element.createElement)(_token.default, {
551
- key: 'token-' + _value,
560
+ return (0, _element.createElement)(_flex.FlexItem, {
561
+ key: 'token-' + _value
562
+ }, (0, _element.createElement)(_token.default, {
552
563
  value: _value,
553
564
  status: status,
554
565
  title: typeof token !== 'string' ? token.title : undefined,
@@ -561,7 +572,7 @@ function FormTokenField(props) {
561
572
  messages: messages,
562
573
  termsCount: termsCount,
563
574
  termPosition: termPosition
564
- });
575
+ }));
565
576
  }
566
577
 
567
578
  function renderInput() {
@@ -606,7 +617,7 @@ function FormTokenField(props) {
606
617
  /* eslint-disable jsx-a11y/no-static-element-interactions */
607
618
 
608
619
 
609
- return (0, _element.createElement)("div", tokenFieldProps, (0, _element.createElement)("label", {
620
+ return (0, _element.createElement)("div", tokenFieldProps, (0, _element.createElement)(_baseControlStyles.StyledLabel, {
610
621
  htmlFor: `components-form-token-input-${instanceId}`,
611
622
  className: "components-form-token-field__label"
612
623
  }, label), (0, _element.createElement)("div", {
@@ -615,7 +626,14 @@ function FormTokenField(props) {
615
626
  tabIndex: -1,
616
627
  onMouseDown: onContainerTouched,
617
628
  onTouchStart: onContainerTouched
618
- }, renderTokensAndInput(), isExpanded && (0, _element.createElement)(_suggestionsList.default, {
629
+ }, (0, _element.createElement)(_styles.TokensAndInputWrapperFlex, {
630
+ justify: "flex-start",
631
+ align: "center",
632
+ gap: 1,
633
+ wrap: true,
634
+ __next36pxDefaultSize: __next36pxDefaultSize,
635
+ hasTokens: !!value.length
636
+ }, renderTokensAndInput()), isExpanded && (0, _element.createElement)(_suggestionsList.default, {
619
637
  instanceId: instanceId,
620
638
  match: saveTransform(incompleteTokenValue),
621
639
  displayTransform: displayTransform,
@@ -623,7 +641,8 @@ function FormTokenField(props) {
623
641
  selectedIndex: selectedSuggestionIndex,
624
642
  scrollIntoView: selectedSuggestionScroll,
625
643
  onHover: onSuggestionHovered,
626
- onSelect: onSuggestionSelected
644
+ onSelect: onSuggestionSelected,
645
+ __experimentalRenderItem: __experimentalRenderItem
627
646
  })), __experimentalShowHowTo && (0, _element.createElement)("p", {
628
647
  id: `components-form-token-suggestions-howto-${instanceId}`,
629
648
  className: "components-form-token-field__help"
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/form-token-field/index.tsx"],"names":["FormTokenField","props","autoCapitalize","autoComplete","maxLength","placeholder","label","className","suggestions","maxSuggestions","value","displayTransform","identity","saveTransform","token","trim","onChange","onInputChange","onFocus","undefined","isBorderless","disabled","tokenizeOnSpace","messages","added","removed","remove","__experimentalInvalid","__experimentalExpandOnFocus","__experimentalValidateInput","__experimentalShowHowTo","instanceId","incompleteTokenValue","setIncompleteTokenValue","inputOffsetFromEnd","setInputOffsetFromEnd","isActive","setIsActive","isExpanded","setIsExpanded","selectedSuggestionIndex","setSelectedSuggestionIndex","selectedSuggestionScroll","setSelectedSuggestionScroll","prevSuggestions","prevValue","input","tokensAndInput","debouncedSpeak","speak","hasFocus","focus","suggestionsDidUpdate","updateSuggestions","current","ownerDocument","activeElement","onFocusHandler","event","target","onBlur","inputHasValidValue","onKeyDown","preventDefault","defaultPrevented","keyCode","BACKSPACE","handleDeleteKey","deleteTokenBeforeInput","ENTER","addCurrentToken","LEFT","handleLeftArrowKey","UP","handleUpArrowKey","RIGHT","handleRightArrowKey","DOWN","handleDownArrowKey","DELETE","deleteTokenAfterInput","SPACE","ESCAPE","handleEscapeKey","onKeyPress","charCode","handleCommaKey","onContainerTouched","onTokenClickRemove","deleteToken","onSuggestionHovered","suggestion","index","getMatchingSuggestions","indexOf","onSuggestionSelected","addNewToken","onInputChangeHandler","text","separator","items","split","tokenValue","length","addNewTokens","slice","_deleteToken","isInputEmpty","moveInputBeforePreviousToken","moveInputAfterNextToken","HTMLInputElement","moveInputToIndex","Math","max","prevInputOffsetFromEnd","min","getIndexOfInput","selectedSuggestion","getSelectedSuggestion","tokens","tokensToAdd","map","filter","Boolean","valueContainsToken","newValue","splice","newTokens","item","getTokenValue","searchValue","_suggestions","_value","_maxSuggestions","_saveTransform","match","startsWithMatch","containsMatch","normalizedValue","toLocaleLowerCase","forEach","push","concat","resetSelectedSuggestion","inputHasMinimumChars","matchingSuggestions","hasMatchingSuggestions","message","renderTokensAndInput","components","renderToken","renderInput","status","termPosition","termsCount","title","onMouseEnter","onMouseLeave","inputProps","key","classes","tokenFieldProps","tabIndex","Object","assign"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { last, clone, uniq, map, difference, identity, some } from 'lodash';\nimport classnames from 'classnames';\nimport type { KeyboardEvent, MouseEvent, TouchEvent } from 'react';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useRef, useState } from '@wordpress/element';\nimport { __, _n, sprintf } from '@wordpress/i18n';\nimport { useDebounce, useInstanceId, usePrevious } from '@wordpress/compose';\nimport { speak } from '@wordpress/a11y';\nimport {\n\tBACKSPACE,\n\tENTER,\n\tUP,\n\tDOWN,\n\tLEFT,\n\tRIGHT,\n\tSPACE,\n\tDELETE,\n\tESCAPE,\n} from '@wordpress/keycodes';\nimport isShallowEqual from '@wordpress/is-shallow-equal';\n\n/**\n * Internal dependencies\n */\nimport Token from './token';\nimport TokenInput from './token-input';\nimport SuggestionsList from './suggestions-list';\nimport type { FormTokenFieldProps, TokenItem } from './types';\n\n/**\n * A `FormTokenField` is a field similar to the tags and categories fields in the interim editor chrome,\n * or the \"to\" field in Mail on OS X. Tokens can be entered by typing them or selecting them from a list of suggested tokens.\n *\n * Up to one hundred suggestions that match what the user has typed so far will be shown from which the user can pick from (auto-complete).\n * Tokens are separated by the \",\" character. Suggestions can be selected with the up or down arrows and added with the tab or enter key.\n *\n * The `value` property is handled in a manner similar to controlled form components.\n * See [Forms](http://facebook.github.io/react/docs/forms.html) in the React Documentation for more information.\n */\nexport function FormTokenField( props: FormTokenFieldProps ) {\n\tconst {\n\t\tautoCapitalize,\n\t\tautoComplete,\n\t\tmaxLength,\n\t\tplaceholder,\n\t\tlabel = __( 'Add item' ),\n\t\tclassName,\n\t\tsuggestions = [],\n\t\tmaxSuggestions = 100,\n\t\tvalue = [],\n\t\tdisplayTransform = identity,\n\t\tsaveTransform = ( token ) => token.trim(),\n\t\tonChange = () => {},\n\t\tonInputChange = () => {},\n\t\tonFocus = undefined,\n\t\tisBorderless = false,\n\t\tdisabled = false,\n\t\ttokenizeOnSpace = false,\n\t\tmessages = {\n\t\t\tadded: __( 'Item added.' ),\n\t\t\tremoved: __( 'Item removed.' ),\n\t\t\tremove: __( 'Remove item' ),\n\t\t\t__experimentalInvalid: __( 'Invalid item' ),\n\t\t},\n\t\t__experimentalExpandOnFocus = false,\n\t\t__experimentalValidateInput = () => true,\n\t\t__experimentalShowHowTo = true,\n\t} = props;\n\n\tconst instanceId = useInstanceId( FormTokenField );\n\n\t// We reset to these initial values again in the onBlur\n\tconst [ incompleteTokenValue, setIncompleteTokenValue ] = useState( '' );\n\tconst [ inputOffsetFromEnd, setInputOffsetFromEnd ] = useState( 0 );\n\tconst [ isActive, setIsActive ] = useState( false );\n\tconst [ isExpanded, setIsExpanded ] = useState( false );\n\tconst [ selectedSuggestionIndex, setSelectedSuggestionIndex ] =\n\t\tuseState( -1 );\n\tconst [ selectedSuggestionScroll, setSelectedSuggestionScroll ] =\n\t\tuseState( false );\n\n\tconst prevSuggestions = usePrevious< string[] >( suggestions );\n\tconst prevValue = usePrevious< ( string | TokenItem )[] >( value );\n\n\tconst input = useRef< HTMLInputElement >( null );\n\tconst tokensAndInput = useRef< HTMLInputElement >( null );\n\n\tconst debouncedSpeak = useDebounce( speak, 500 );\n\n\tuseEffect( () => {\n\t\t// Make sure to focus the input when the isActive state is true.\n\t\tif ( isActive && ! hasFocus() ) {\n\t\t\tfocus();\n\t\t}\n\t}, [ isActive ] );\n\n\tuseEffect( () => {\n\t\tconst suggestionsDidUpdate = ! isShallowEqual(\n\t\t\tsuggestions,\n\t\t\tprevSuggestions || []\n\t\t);\n\n\t\tif ( suggestionsDidUpdate || value !== prevValue ) {\n\t\t\tupdateSuggestions( suggestionsDidUpdate );\n\t\t}\n\n\t\t// TODO: updateSuggestions() should first be refactored so its actual deps are clearer.\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ suggestions, prevSuggestions, value, prevValue ] );\n\n\tuseEffect( () => {\n\t\tupdateSuggestions();\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ incompleteTokenValue ] );\n\n\tif ( disabled && isActive ) {\n\t\tsetIsActive( false );\n\t\tsetIncompleteTokenValue( '' );\n\t}\n\n\tfunction focus() {\n\t\tinput.current?.focus();\n\t}\n\n\tfunction hasFocus() {\n\t\treturn input.current === input.current?.ownerDocument.activeElement;\n\t}\n\n\tfunction onFocusHandler( event: FocusEvent ) {\n\t\t// If focus is on the input or on the container, set the isActive state to true.\n\t\tif ( hasFocus() || event.target === tokensAndInput.current ) {\n\t\t\tsetIsActive( true );\n\t\t\tsetIsExpanded( __experimentalExpandOnFocus || isExpanded );\n\t\t} else {\n\t\t\t/*\n\t\t\t * Otherwise, focus is on one of the token \"remove\" buttons and we\n\t\t\t * set the isActive state to false to prevent the input to be\n\t\t\t * re-focused, see componentDidUpdate().\n\t\t\t */\n\t\t\tsetIsActive( false );\n\t\t}\n\n\t\tif ( 'function' === typeof onFocus ) {\n\t\t\tonFocus( event );\n\t\t}\n\t}\n\n\tfunction onBlur() {\n\t\tif ( inputHasValidValue() ) {\n\t\t\tsetIsActive( false );\n\t\t} else {\n\t\t\t// Reset to initial state\n\t\t\tsetIncompleteTokenValue( '' );\n\t\t\tsetInputOffsetFromEnd( 0 );\n\t\t\tsetIsActive( false );\n\t\t\tsetIsExpanded( false );\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\t}\n\n\tfunction onKeyDown( event: KeyboardEvent ) {\n\t\tlet preventDefault = false;\n\n\t\tif ( event.defaultPrevented ) {\n\t\t\treturn;\n\t\t}\n\t\t// TODO: replace to event.code;\n\t\tswitch ( event.keyCode ) {\n\t\t\tcase BACKSPACE:\n\t\t\t\tpreventDefault = handleDeleteKey( deleteTokenBeforeInput );\n\t\t\t\tbreak;\n\t\t\tcase ENTER:\n\t\t\t\tpreventDefault = addCurrentToken();\n\t\t\t\tbreak;\n\t\t\tcase LEFT:\n\t\t\t\tpreventDefault = handleLeftArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase UP:\n\t\t\t\tpreventDefault = handleUpArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase RIGHT:\n\t\t\t\tpreventDefault = handleRightArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase DOWN:\n\t\t\t\tpreventDefault = handleDownArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase DELETE:\n\t\t\t\tpreventDefault = handleDeleteKey( deleteTokenAfterInput );\n\t\t\t\tbreak;\n\t\t\tcase SPACE:\n\t\t\t\tif ( tokenizeOnSpace ) {\n\t\t\t\t\tpreventDefault = addCurrentToken();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase ESCAPE:\n\t\t\t\tpreventDefault = handleEscapeKey( event );\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif ( preventDefault ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onKeyPress( event: KeyboardEvent ) {\n\t\tlet preventDefault = false;\n\t\t// TODO: replace to event.code;\n\t\tswitch ( event.charCode ) {\n\t\t\tcase 44: // Comma.\n\t\t\t\tpreventDefault = handleCommaKey();\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif ( preventDefault ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onContainerTouched( event: MouseEvent | TouchEvent ) {\n\t\t// Prevent clicking/touching the tokensAndInput container from blurring\n\t\t// the input and adding the current token.\n\t\tif ( event.target === tokensAndInput.current && isActive ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onTokenClickRemove( event: { value: string } ) {\n\t\tdeleteToken( event.value );\n\t\tfocus();\n\t}\n\n\tfunction onSuggestionHovered( suggestion: string ) {\n\t\tconst index = getMatchingSuggestions().indexOf( suggestion );\n\n\t\tif ( index >= 0 ) {\n\t\t\tsetSelectedSuggestionIndex( index );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\t}\n\n\tfunction onSuggestionSelected( suggestion: string ) {\n\t\taddNewToken( suggestion );\n\t}\n\n\tfunction onInputChangeHandler( event: { value: string } ) {\n\t\tconst text = event.value;\n\t\tconst separator = tokenizeOnSpace ? /[ ,\\t]+/ : /[,\\t]+/;\n\t\tconst items = text.split( separator );\n\t\tconst tokenValue = last( items ) || '';\n\n\t\tif ( items.length > 1 ) {\n\t\t\taddNewTokens( items.slice( 0, -1 ) );\n\t\t}\n\t\tsetIncompleteTokenValue( tokenValue );\n\t\tonInputChange( tokenValue );\n\t}\n\n\tfunction handleDeleteKey( _deleteToken: () => void ) {\n\t\tlet preventDefault = false;\n\t\tif ( hasFocus() && isInputEmpty() ) {\n\t\t\t_deleteToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleLeftArrowKey() {\n\t\tlet preventDefault = false;\n\t\tif ( isInputEmpty() ) {\n\t\t\tmoveInputBeforePreviousToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleRightArrowKey() {\n\t\tlet preventDefault = false;\n\t\tif ( isInputEmpty() ) {\n\t\t\tmoveInputAfterNextToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleUpArrowKey() {\n\t\tsetSelectedSuggestionIndex( ( index ) => {\n\t\t\treturn (\n\t\t\t\t( index === 0\n\t\t\t\t\t? getMatchingSuggestions(\n\t\t\t\t\t\t\tincompleteTokenValue,\n\t\t\t\t\t\t\tsuggestions,\n\t\t\t\t\t\t\tvalue,\n\t\t\t\t\t\t\tmaxSuggestions,\n\t\t\t\t\t\t\tsaveTransform\n\t\t\t\t\t ).length\n\t\t\t\t\t: index ) - 1\n\t\t\t);\n\t\t} );\n\t\tsetSelectedSuggestionScroll( true );\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleDownArrowKey() {\n\t\tsetSelectedSuggestionIndex( ( index ) => {\n\t\t\treturn (\n\t\t\t\t( index + 1 ) %\n\t\t\t\tgetMatchingSuggestions(\n\t\t\t\t\tincompleteTokenValue,\n\t\t\t\t\tsuggestions,\n\t\t\t\t\tvalue,\n\t\t\t\t\tmaxSuggestions,\n\t\t\t\t\tsaveTransform\n\t\t\t\t).length\n\t\t\t);\n\t\t} );\n\n\t\tsetSelectedSuggestionScroll( true );\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleEscapeKey( event: KeyboardEvent ) {\n\t\tif ( event.target instanceof HTMLInputElement ) {\n\t\t\tsetIncompleteTokenValue( event.target.value );\n\t\t\tsetIsExpanded( false );\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleCommaKey() {\n\t\tif ( inputHasValidValue() ) {\n\t\t\taddNewToken( incompleteTokenValue );\n\t\t}\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction moveInputToIndex( index: number ) {\n\t\tsetInputOffsetFromEnd( value.length - Math.max( index, -1 ) - 1 );\n\t}\n\n\tfunction moveInputBeforePreviousToken() {\n\t\tsetInputOffsetFromEnd( ( prevInputOffsetFromEnd ) => {\n\t\t\treturn Math.min( prevInputOffsetFromEnd + 1, value.length );\n\t\t} );\n\t}\n\n\tfunction moveInputAfterNextToken() {\n\t\tsetInputOffsetFromEnd( ( prevInputOffsetFromEnd ) => {\n\t\t\treturn Math.max( prevInputOffsetFromEnd - 1, 0 );\n\t\t} );\n\t}\n\n\tfunction deleteTokenBeforeInput() {\n\t\tconst index = getIndexOfInput() - 1;\n\n\t\tif ( index > -1 ) {\n\t\t\tdeleteToken( value[ index ] );\n\t\t}\n\t}\n\n\tfunction deleteTokenAfterInput() {\n\t\tconst index = getIndexOfInput();\n\n\t\tif ( index < value.length ) {\n\t\t\tdeleteToken( value[ index ] );\n\t\t\t// Update input offset since it's the offset from the last token.\n\t\t\tmoveInputToIndex( index );\n\t\t}\n\t}\n\n\tfunction addCurrentToken() {\n\t\tlet preventDefault = false;\n\t\tconst selectedSuggestion = getSelectedSuggestion();\n\n\t\tif ( selectedSuggestion ) {\n\t\t\taddNewToken( selectedSuggestion );\n\t\t\tpreventDefault = true;\n\t\t} else if ( inputHasValidValue() ) {\n\t\t\taddNewToken( incompleteTokenValue );\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction addNewTokens( tokens: string[] ) {\n\t\tconst tokensToAdd = uniq(\n\t\t\ttokens\n\t\t\t\t.map( saveTransform )\n\t\t\t\t.filter( Boolean )\n\t\t\t\t.filter( ( token ) => ! valueContainsToken( token ) )\n\t\t);\n\n\t\tif ( tokensToAdd.length > 0 ) {\n\t\t\tconst newValue = clone( value );\n\t\t\tnewValue.splice( getIndexOfInput(), 0, ...tokensToAdd );\n\t\t\tonChange( newValue );\n\t\t}\n\t}\n\n\tfunction addNewToken( token: string ) {\n\t\tif ( ! __experimentalValidateInput( token ) ) {\n\t\t\tspeak( messages.__experimentalInvalid, 'assertive' );\n\t\t\treturn;\n\t\t}\n\t\taddNewTokens( [ token ] );\n\t\tspeak( messages.added, 'assertive' );\n\n\t\tsetIncompleteTokenValue( '' );\n\t\tsetSelectedSuggestionIndex( -1 );\n\t\tsetSelectedSuggestionScroll( false );\n\t\tsetIsExpanded( ! __experimentalExpandOnFocus );\n\n\t\tif ( isActive ) {\n\t\t\tfocus();\n\t\t}\n\t}\n\n\tfunction deleteToken( token: string | TokenItem ) {\n\t\tconst newTokens = value.filter( ( item ) => {\n\t\t\treturn getTokenValue( item ) !== getTokenValue( token );\n\t\t} );\n\t\tonChange( newTokens );\n\t\tspeak( messages.removed, 'assertive' );\n\t}\n\n\tfunction getTokenValue( token: { value: string } | string ) {\n\t\tif ( 'object' === typeof token ) {\n\t\t\treturn token.value;\n\t\t}\n\n\t\treturn token;\n\t}\n\n\tfunction getMatchingSuggestions(\n\t\tsearchValue = incompleteTokenValue,\n\t\t_suggestions = suggestions,\n\t\t_value = value,\n\t\t_maxSuggestions = maxSuggestions,\n\t\t_saveTransform = saveTransform\n\t) {\n\t\tlet match = _saveTransform( searchValue );\n\t\tconst startsWithMatch: string[] = [];\n\t\tconst containsMatch: string[] = [];\n\t\tconst normalizedValue = _value.map( ( item ) => {\n\t\t\tif ( typeof item === 'string' ) {\n\t\t\t\treturn item;\n\t\t\t}\n\t\t\treturn item.value;\n\t\t} );\n\n\t\tif ( match.length === 0 ) {\n\t\t\t_suggestions = difference( _suggestions, normalizedValue );\n\t\t} else {\n\t\t\tmatch = match.toLocaleLowerCase();\n\n\t\t\t_suggestions.forEach( ( suggestion ) => {\n\t\t\t\tconst index = suggestion.toLocaleLowerCase().indexOf( match );\n\t\t\t\tif ( normalizedValue.indexOf( suggestion ) === -1 ) {\n\t\t\t\t\tif ( index === 0 ) {\n\t\t\t\t\t\tstartsWithMatch.push( suggestion );\n\t\t\t\t\t} else if ( index > 0 ) {\n\t\t\t\t\t\tcontainsMatch.push( suggestion );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\n\t\t\t_suggestions = startsWithMatch.concat( containsMatch );\n\t\t}\n\n\t\treturn _suggestions.slice( 0, _maxSuggestions );\n\t}\n\n\tfunction getSelectedSuggestion() {\n\t\tif ( selectedSuggestionIndex !== -1 ) {\n\t\t\treturn getMatchingSuggestions()[ selectedSuggestionIndex ];\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tfunction valueContainsToken( token: string ) {\n\t\treturn some( value, ( item ) => {\n\t\t\treturn getTokenValue( token ) === getTokenValue( item );\n\t\t} );\n\t}\n\n\tfunction getIndexOfInput() {\n\t\treturn value.length - inputOffsetFromEnd;\n\t}\n\n\tfunction isInputEmpty() {\n\t\treturn incompleteTokenValue.length === 0;\n\t}\n\n\tfunction inputHasValidValue() {\n\t\treturn saveTransform( incompleteTokenValue ).length > 0;\n\t}\n\n\tfunction updateSuggestions( resetSelectedSuggestion = true ) {\n\t\tconst inputHasMinimumChars = incompleteTokenValue.trim().length > 1;\n\t\tconst matchingSuggestions =\n\t\t\tgetMatchingSuggestions( incompleteTokenValue );\n\t\tconst hasMatchingSuggestions = matchingSuggestions.length > 0;\n\n\t\tsetIsExpanded(\n\t\t\t__experimentalExpandOnFocus ||\n\t\t\t\t( inputHasMinimumChars && hasMatchingSuggestions )\n\t\t);\n\n\t\tif ( resetSelectedSuggestion ) {\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\n\t\tif ( inputHasMinimumChars ) {\n\t\t\tconst message = hasMatchingSuggestions\n\t\t\t\t? sprintf(\n\t\t\t\t\t\t/* translators: %d: number of results. */\n\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t'%d result found, use up and down arrow keys to navigate.',\n\t\t\t\t\t\t\t'%d results found, use up and down arrow keys to navigate.',\n\t\t\t\t\t\t\tmatchingSuggestions.length\n\t\t\t\t\t\t),\n\t\t\t\t\t\tmatchingSuggestions.length\n\t\t\t\t )\n\t\t\t\t: __( 'No results.' );\n\n\t\t\tdebouncedSpeak( message, 'assertive' );\n\t\t}\n\t}\n\n\tfunction renderTokensAndInput() {\n\t\tconst components = map( value, renderToken );\n\t\tcomponents.splice( getIndexOfInput(), 0, renderInput() );\n\n\t\treturn components;\n\t}\n\n\tfunction renderToken(\n\t\ttoken: string | TokenItem,\n\t\tindex: number,\n\t\ttokens: ( string | TokenItem )[]\n\t) {\n\t\tconst _value = getTokenValue( token );\n\t\tconst status = typeof token !== 'string' ? token.status : undefined;\n\t\tconst termPosition = index + 1;\n\t\tconst termsCount = tokens.length;\n\n\t\treturn (\n\t\t\t<Token\n\t\t\t\tkey={ 'token-' + _value }\n\t\t\t\tvalue={ _value }\n\t\t\t\tstatus={ status }\n\t\t\t\ttitle={ typeof token !== 'string' ? token.title : undefined }\n\t\t\t\tdisplayTransform={ displayTransform }\n\t\t\t\tonClickRemove={ onTokenClickRemove }\n\t\t\t\tisBorderless={\n\t\t\t\t\t( typeof token !== 'string' && token.isBorderless ) ||\n\t\t\t\t\tisBorderless\n\t\t\t\t}\n\t\t\t\tonMouseEnter={\n\t\t\t\t\ttypeof token !== 'string' ? token.onMouseEnter : undefined\n\t\t\t\t}\n\t\t\t\tonMouseLeave={\n\t\t\t\t\ttypeof token !== 'string' ? token.onMouseLeave : undefined\n\t\t\t\t}\n\t\t\t\tdisabled={ 'error' !== status && disabled }\n\t\t\t\tmessages={ messages }\n\t\t\t\ttermsCount={ termsCount }\n\t\t\t\ttermPosition={ termPosition }\n\t\t\t/>\n\t\t);\n\t}\n\n\tfunction renderInput() {\n\t\tconst inputProps = {\n\t\t\tinstanceId,\n\t\t\tautoCapitalize,\n\t\t\tautoComplete,\n\t\t\tplaceholder: value.length === 0 ? placeholder : '',\n\t\t\tkey: 'input',\n\t\t\tdisabled,\n\t\t\tvalue: incompleteTokenValue,\n\t\t\tonBlur,\n\t\t\tisExpanded,\n\t\t\tselectedSuggestionIndex,\n\t\t};\n\n\t\treturn (\n\t\t\t<TokenInput\n\t\t\t\t{ ...inputProps }\n\t\t\t\tonChange={\n\t\t\t\t\t! ( maxLength && value.length >= maxLength )\n\t\t\t\t\t\t? onInputChangeHandler\n\t\t\t\t\t\t: undefined\n\t\t\t\t}\n\t\t\t\tref={ input }\n\t\t\t/>\n\t\t);\n\t}\n\n\tconst classes = classnames(\n\t\tclassName,\n\t\t'components-form-token-field__input-container',\n\t\t{\n\t\t\t'is-active': isActive,\n\t\t\t'is-disabled': disabled,\n\t\t}\n\t);\n\n\tlet tokenFieldProps = {\n\t\tclassName: 'components-form-token-field',\n\t\ttabIndex: -1,\n\t};\n\tconst matchingSuggestions = getMatchingSuggestions();\n\n\tif ( ! disabled ) {\n\t\ttokenFieldProps = Object.assign( {}, tokenFieldProps, {\n\t\t\tonKeyDown,\n\t\t\tonKeyPress,\n\t\t\tonFocus: onFocusHandler,\n\t\t} );\n\t}\n\n\t// Disable reason: There is no appropriate role which describes the\n\t// input container intended accessible usability.\n\t// TODO: Refactor click detection to use blur to stop propagation.\n\t/* eslint-disable jsx-a11y/no-static-element-interactions */\n\treturn (\n\t\t<div { ...tokenFieldProps }>\n\t\t\t<label\n\t\t\t\thtmlFor={ `components-form-token-input-${ instanceId }` }\n\t\t\t\tclassName=\"components-form-token-field__label\"\n\t\t\t>\n\t\t\t\t{ label }\n\t\t\t</label>\n\t\t\t<div\n\t\t\t\tref={ tokensAndInput }\n\t\t\t\tclassName={ classes }\n\t\t\t\ttabIndex={ -1 }\n\t\t\t\tonMouseDown={ onContainerTouched }\n\t\t\t\tonTouchStart={ onContainerTouched }\n\t\t\t>\n\t\t\t\t{ renderTokensAndInput() }\n\t\t\t\t{ isExpanded && (\n\t\t\t\t\t<SuggestionsList\n\t\t\t\t\t\tinstanceId={ instanceId }\n\t\t\t\t\t\tmatch={ saveTransform( incompleteTokenValue ) }\n\t\t\t\t\t\tdisplayTransform={ displayTransform }\n\t\t\t\t\t\tsuggestions={ matchingSuggestions }\n\t\t\t\t\t\tselectedIndex={ selectedSuggestionIndex }\n\t\t\t\t\t\tscrollIntoView={ selectedSuggestionScroll }\n\t\t\t\t\t\tonHover={ onSuggestionHovered }\n\t\t\t\t\t\tonSelect={ onSuggestionSelected }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ __experimentalShowHowTo && (\n\t\t\t\t<p\n\t\t\t\t\tid={ `components-form-token-suggestions-howto-${ instanceId }` }\n\t\t\t\t\tclassName=\"components-form-token-field__help\"\n\t\t\t\t>\n\t\t\t\t\t{ tokenizeOnSpace\n\t\t\t\t\t\t? __(\n\t\t\t\t\t\t\t\t'Separate with commas, spaces, or the Enter key.'\n\t\t\t\t\t\t )\n\t\t\t\t\t\t: __( 'Separate with commas or the Enter key.' ) }\n\t\t\t\t</p>\n\t\t\t) }\n\t\t</div>\n\t);\n\t/* eslint-enable jsx-a11y/no-static-element-interactions */\n}\n\nexport default FormTokenField;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/form-token-field/index.tsx"],"names":["identity","value","FormTokenField","props","autoCapitalize","autoComplete","maxLength","placeholder","label","className","suggestions","maxSuggestions","displayTransform","saveTransform","token","trim","onChange","onInputChange","onFocus","undefined","isBorderless","disabled","tokenizeOnSpace","messages","added","removed","remove","__experimentalInvalid","__experimentalRenderItem","__experimentalExpandOnFocus","__experimentalValidateInput","__experimentalShowHowTo","__next36pxDefaultSize","instanceId","incompleteTokenValue","setIncompleteTokenValue","inputOffsetFromEnd","setInputOffsetFromEnd","isActive","setIsActive","isExpanded","setIsExpanded","selectedSuggestionIndex","setSelectedSuggestionIndex","selectedSuggestionScroll","setSelectedSuggestionScroll","prevSuggestions","prevValue","input","tokensAndInput","debouncedSpeak","speak","hasFocus","focus","suggestionsDidUpdate","updateSuggestions","current","ownerDocument","activeElement","onFocusHandler","event","target","onBlur","inputHasValidValue","onKeyDown","preventDefault","defaultPrevented","keyCode","BACKSPACE","handleDeleteKey","deleteTokenBeforeInput","ENTER","addCurrentToken","LEFT","handleLeftArrowKey","UP","handleUpArrowKey","RIGHT","handleRightArrowKey","DOWN","handleDownArrowKey","DELETE","deleteTokenAfterInput","SPACE","ESCAPE","handleEscapeKey","onKeyPress","charCode","handleCommaKey","onContainerTouched","onTokenClickRemove","deleteToken","onSuggestionHovered","suggestion","index","getMatchingSuggestions","indexOf","onSuggestionSelected","addNewToken","onInputChangeHandler","text","separator","items","split","tokenValue","length","addNewTokens","slice","_deleteToken","isInputEmpty","moveInputBeforePreviousToken","moveInputAfterNextToken","HTMLInputElement","moveInputToIndex","Math","max","prevInputOffsetFromEnd","min","getIndexOfInput","selectedSuggestion","getSelectedSuggestion","tokens","tokensToAdd","map","filter","Boolean","valueContainsToken","newValue","splice","newTokens","item","getTokenValue","searchValue","_suggestions","_value","_maxSuggestions","_saveTransform","match","startsWithMatch","containsMatch","normalizedValue","toLocaleLowerCase","forEach","push","concat","resetSelectedSuggestion","inputHasMinimumChars","matchingSuggestions","hasMatchingSuggestions","message","renderTokensAndInput","components","renderToken","renderInput","status","termPosition","termsCount","title","onMouseEnter","onMouseLeave","inputProps","key","classes","tokenFieldProps","tabIndex","Object","assign"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { last, clone, uniq, map, difference, some } from 'lodash';\nimport classnames from 'classnames';\nimport type { KeyboardEvent, MouseEvent, TouchEvent } from 'react';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useRef, useState } from '@wordpress/element';\nimport { __, _n, sprintf } from '@wordpress/i18n';\nimport { useDebounce, useInstanceId, usePrevious } from '@wordpress/compose';\nimport { speak } from '@wordpress/a11y';\nimport {\n\tBACKSPACE,\n\tENTER,\n\tUP,\n\tDOWN,\n\tLEFT,\n\tRIGHT,\n\tSPACE,\n\tDELETE,\n\tESCAPE,\n} from '@wordpress/keycodes';\nimport isShallowEqual from '@wordpress/is-shallow-equal';\n\n/**\n * Internal dependencies\n */\nimport Token from './token';\nimport TokenInput from './token-input';\nimport { TokensAndInputWrapperFlex } from './styles';\nimport SuggestionsList from './suggestions-list';\nimport type { FormTokenFieldProps, TokenItem } from './types';\nimport { FlexItem } from '../flex';\nimport { StyledLabel } from '../base-control/styles/base-control-styles';\n\nconst identity = ( value: string ) => value;\n\n/**\n * A `FormTokenField` is a field similar to the tags and categories fields in the interim editor chrome,\n * or the \"to\" field in Mail on OS X. Tokens can be entered by typing them or selecting them from a list of suggested tokens.\n *\n * Up to one hundred suggestions that match what the user has typed so far will be shown from which the user can pick from (auto-complete).\n * Tokens are separated by the \",\" character. Suggestions can be selected with the up or down arrows and added with the tab or enter key.\n *\n * The `value` property is handled in a manner similar to controlled form components.\n * See [Forms](http://facebook.github.io/react/docs/forms.html) in the React Documentation for more information.\n */\nexport function FormTokenField( props: FormTokenFieldProps ) {\n\tconst {\n\t\tautoCapitalize,\n\t\tautoComplete,\n\t\tmaxLength,\n\t\tplaceholder,\n\t\tlabel = __( 'Add item' ),\n\t\tclassName,\n\t\tsuggestions = [],\n\t\tmaxSuggestions = 100,\n\t\tvalue = [],\n\t\tdisplayTransform = identity,\n\t\tsaveTransform = ( token ) => token.trim(),\n\t\tonChange = () => {},\n\t\tonInputChange = () => {},\n\t\tonFocus = undefined,\n\t\tisBorderless = false,\n\t\tdisabled = false,\n\t\ttokenizeOnSpace = false,\n\t\tmessages = {\n\t\t\tadded: __( 'Item added.' ),\n\t\t\tremoved: __( 'Item removed.' ),\n\t\t\tremove: __( 'Remove item' ),\n\t\t\t__experimentalInvalid: __( 'Invalid item' ),\n\t\t},\n\t\t__experimentalRenderItem,\n\t\t__experimentalExpandOnFocus = false,\n\t\t__experimentalValidateInput = () => true,\n\t\t__experimentalShowHowTo = true,\n\t\t__next36pxDefaultSize = false,\n\t} = props;\n\n\tconst instanceId = useInstanceId( FormTokenField );\n\n\t// We reset to these initial values again in the onBlur\n\tconst [ incompleteTokenValue, setIncompleteTokenValue ] = useState( '' );\n\tconst [ inputOffsetFromEnd, setInputOffsetFromEnd ] = useState( 0 );\n\tconst [ isActive, setIsActive ] = useState( false );\n\tconst [ isExpanded, setIsExpanded ] = useState( false );\n\tconst [ selectedSuggestionIndex, setSelectedSuggestionIndex ] =\n\t\tuseState( -1 );\n\tconst [ selectedSuggestionScroll, setSelectedSuggestionScroll ] =\n\t\tuseState( false );\n\n\tconst prevSuggestions = usePrevious< string[] >( suggestions );\n\tconst prevValue = usePrevious< ( string | TokenItem )[] >( value );\n\n\tconst input = useRef< HTMLInputElement >( null );\n\tconst tokensAndInput = useRef< HTMLInputElement >( null );\n\n\tconst debouncedSpeak = useDebounce( speak, 500 );\n\n\tuseEffect( () => {\n\t\t// Make sure to focus the input when the isActive state is true.\n\t\tif ( isActive && ! hasFocus() ) {\n\t\t\tfocus();\n\t\t}\n\t}, [ isActive ] );\n\n\tuseEffect( () => {\n\t\tconst suggestionsDidUpdate = ! isShallowEqual(\n\t\t\tsuggestions,\n\t\t\tprevSuggestions || []\n\t\t);\n\n\t\tif ( suggestionsDidUpdate || value !== prevValue ) {\n\t\t\tupdateSuggestions( suggestionsDidUpdate );\n\t\t}\n\n\t\t// TODO: updateSuggestions() should first be refactored so its actual deps are clearer.\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ suggestions, prevSuggestions, value, prevValue ] );\n\n\tuseEffect( () => {\n\t\tupdateSuggestions();\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ incompleteTokenValue ] );\n\n\tif ( disabled && isActive ) {\n\t\tsetIsActive( false );\n\t\tsetIncompleteTokenValue( '' );\n\t}\n\n\tfunction focus() {\n\t\tinput.current?.focus();\n\t}\n\n\tfunction hasFocus() {\n\t\treturn input.current === input.current?.ownerDocument.activeElement;\n\t}\n\n\tfunction onFocusHandler( event: FocusEvent ) {\n\t\t// If focus is on the input or on the container, set the isActive state to true.\n\t\tif ( hasFocus() || event.target === tokensAndInput.current ) {\n\t\t\tsetIsActive( true );\n\t\t\tsetIsExpanded( __experimentalExpandOnFocus || isExpanded );\n\t\t} else {\n\t\t\t/*\n\t\t\t * Otherwise, focus is on one of the token \"remove\" buttons and we\n\t\t\t * set the isActive state to false to prevent the input to be\n\t\t\t * re-focused, see componentDidUpdate().\n\t\t\t */\n\t\t\tsetIsActive( false );\n\t\t}\n\n\t\tif ( 'function' === typeof onFocus ) {\n\t\t\tonFocus( event );\n\t\t}\n\t}\n\n\tfunction onBlur() {\n\t\tif ( inputHasValidValue() ) {\n\t\t\tsetIsActive( false );\n\t\t} else {\n\t\t\t// Reset to initial state\n\t\t\tsetIncompleteTokenValue( '' );\n\t\t\tsetInputOffsetFromEnd( 0 );\n\t\t\tsetIsActive( false );\n\t\t\tsetIsExpanded( false );\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\t}\n\n\tfunction onKeyDown( event: KeyboardEvent ) {\n\t\tlet preventDefault = false;\n\n\t\tif ( event.defaultPrevented ) {\n\t\t\treturn;\n\t\t}\n\t\t// TODO: replace to event.code;\n\t\tswitch ( event.keyCode ) {\n\t\t\tcase BACKSPACE:\n\t\t\t\tpreventDefault = handleDeleteKey( deleteTokenBeforeInput );\n\t\t\t\tbreak;\n\t\t\tcase ENTER:\n\t\t\t\tpreventDefault = addCurrentToken();\n\t\t\t\tbreak;\n\t\t\tcase LEFT:\n\t\t\t\tpreventDefault = handleLeftArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase UP:\n\t\t\t\tpreventDefault = handleUpArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase RIGHT:\n\t\t\t\tpreventDefault = handleRightArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase DOWN:\n\t\t\t\tpreventDefault = handleDownArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase DELETE:\n\t\t\t\tpreventDefault = handleDeleteKey( deleteTokenAfterInput );\n\t\t\t\tbreak;\n\t\t\tcase SPACE:\n\t\t\t\tif ( tokenizeOnSpace ) {\n\t\t\t\t\tpreventDefault = addCurrentToken();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase ESCAPE:\n\t\t\t\tpreventDefault = handleEscapeKey( event );\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif ( preventDefault ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onKeyPress( event: KeyboardEvent ) {\n\t\tlet preventDefault = false;\n\t\t// TODO: replace to event.code;\n\t\tswitch ( event.charCode ) {\n\t\t\tcase 44: // Comma.\n\t\t\t\tpreventDefault = handleCommaKey();\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif ( preventDefault ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onContainerTouched( event: MouseEvent | TouchEvent ) {\n\t\t// Prevent clicking/touching the tokensAndInput container from blurring\n\t\t// the input and adding the current token.\n\t\tif ( event.target === tokensAndInput.current && isActive ) {\n\t\t\tevent.preventDefault();\n\t\t}\n\t}\n\n\tfunction onTokenClickRemove( event: { value: string } ) {\n\t\tdeleteToken( event.value );\n\t\tfocus();\n\t}\n\n\tfunction onSuggestionHovered( suggestion: string ) {\n\t\tconst index = getMatchingSuggestions().indexOf( suggestion );\n\n\t\tif ( index >= 0 ) {\n\t\t\tsetSelectedSuggestionIndex( index );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\t}\n\n\tfunction onSuggestionSelected( suggestion: string ) {\n\t\taddNewToken( suggestion );\n\t}\n\n\tfunction onInputChangeHandler( event: { value: string } ) {\n\t\tconst text = event.value;\n\t\tconst separator = tokenizeOnSpace ? /[ ,\\t]+/ : /[,\\t]+/;\n\t\tconst items = text.split( separator );\n\t\tconst tokenValue = last( items ) || '';\n\n\t\tif ( items.length > 1 ) {\n\t\t\taddNewTokens( items.slice( 0, -1 ) );\n\t\t}\n\t\tsetIncompleteTokenValue( tokenValue );\n\t\tonInputChange( tokenValue );\n\t}\n\n\tfunction handleDeleteKey( _deleteToken: () => void ) {\n\t\tlet preventDefault = false;\n\t\tif ( hasFocus() && isInputEmpty() ) {\n\t\t\t_deleteToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleLeftArrowKey() {\n\t\tlet preventDefault = false;\n\t\tif ( isInputEmpty() ) {\n\t\t\tmoveInputBeforePreviousToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleRightArrowKey() {\n\t\tlet preventDefault = false;\n\t\tif ( isInputEmpty() ) {\n\t\t\tmoveInputAfterNextToken();\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction handleUpArrowKey() {\n\t\tsetSelectedSuggestionIndex( ( index ) => {\n\t\t\treturn (\n\t\t\t\t( index === 0\n\t\t\t\t\t? getMatchingSuggestions(\n\t\t\t\t\t\t\tincompleteTokenValue,\n\t\t\t\t\t\t\tsuggestions,\n\t\t\t\t\t\t\tvalue,\n\t\t\t\t\t\t\tmaxSuggestions,\n\t\t\t\t\t\t\tsaveTransform\n\t\t\t\t\t ).length\n\t\t\t\t\t: index ) - 1\n\t\t\t);\n\t\t} );\n\t\tsetSelectedSuggestionScroll( true );\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleDownArrowKey() {\n\t\tsetSelectedSuggestionIndex( ( index ) => {\n\t\t\treturn (\n\t\t\t\t( index + 1 ) %\n\t\t\t\tgetMatchingSuggestions(\n\t\t\t\t\tincompleteTokenValue,\n\t\t\t\t\tsuggestions,\n\t\t\t\t\tvalue,\n\t\t\t\t\tmaxSuggestions,\n\t\t\t\t\tsaveTransform\n\t\t\t\t).length\n\t\t\t);\n\t\t} );\n\n\t\tsetSelectedSuggestionScroll( true );\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleEscapeKey( event: KeyboardEvent ) {\n\t\tif ( event.target instanceof HTMLInputElement ) {\n\t\t\tsetIncompleteTokenValue( event.target.value );\n\t\t\tsetIsExpanded( false );\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction handleCommaKey() {\n\t\tif ( inputHasValidValue() ) {\n\t\t\taddNewToken( incompleteTokenValue );\n\t\t}\n\n\t\treturn true; // PreventDefault.\n\t}\n\n\tfunction moveInputToIndex( index: number ) {\n\t\tsetInputOffsetFromEnd( value.length - Math.max( index, -1 ) - 1 );\n\t}\n\n\tfunction moveInputBeforePreviousToken() {\n\t\tsetInputOffsetFromEnd( ( prevInputOffsetFromEnd ) => {\n\t\t\treturn Math.min( prevInputOffsetFromEnd + 1, value.length );\n\t\t} );\n\t}\n\n\tfunction moveInputAfterNextToken() {\n\t\tsetInputOffsetFromEnd( ( prevInputOffsetFromEnd ) => {\n\t\t\treturn Math.max( prevInputOffsetFromEnd - 1, 0 );\n\t\t} );\n\t}\n\n\tfunction deleteTokenBeforeInput() {\n\t\tconst index = getIndexOfInput() - 1;\n\n\t\tif ( index > -1 ) {\n\t\t\tdeleteToken( value[ index ] );\n\t\t}\n\t}\n\n\tfunction deleteTokenAfterInput() {\n\t\tconst index = getIndexOfInput();\n\n\t\tif ( index < value.length ) {\n\t\t\tdeleteToken( value[ index ] );\n\t\t\t// Update input offset since it's the offset from the last token.\n\t\t\tmoveInputToIndex( index );\n\t\t}\n\t}\n\n\tfunction addCurrentToken() {\n\t\tlet preventDefault = false;\n\t\tconst selectedSuggestion = getSelectedSuggestion();\n\n\t\tif ( selectedSuggestion ) {\n\t\t\taddNewToken( selectedSuggestion );\n\t\t\tpreventDefault = true;\n\t\t} else if ( inputHasValidValue() ) {\n\t\t\taddNewToken( incompleteTokenValue );\n\t\t\tpreventDefault = true;\n\t\t}\n\n\t\treturn preventDefault;\n\t}\n\n\tfunction addNewTokens( tokens: string[] ) {\n\t\tconst tokensToAdd = uniq(\n\t\t\ttokens\n\t\t\t\t.map( saveTransform )\n\t\t\t\t.filter( Boolean )\n\t\t\t\t.filter( ( token ) => ! valueContainsToken( token ) )\n\t\t);\n\n\t\tif ( tokensToAdd.length > 0 ) {\n\t\t\tconst newValue = clone( value );\n\t\t\tnewValue.splice( getIndexOfInput(), 0, ...tokensToAdd );\n\t\t\tonChange( newValue );\n\t\t}\n\t}\n\n\tfunction addNewToken( token: string ) {\n\t\tif ( ! __experimentalValidateInput( token ) ) {\n\t\t\tspeak( messages.__experimentalInvalid, 'assertive' );\n\t\t\treturn;\n\t\t}\n\t\taddNewTokens( [ token ] );\n\t\tspeak( messages.added, 'assertive' );\n\n\t\tsetIncompleteTokenValue( '' );\n\t\tsetSelectedSuggestionIndex( -1 );\n\t\tsetSelectedSuggestionScroll( false );\n\t\tsetIsExpanded( ! __experimentalExpandOnFocus );\n\n\t\tif ( isActive ) {\n\t\t\tfocus();\n\t\t}\n\t}\n\n\tfunction deleteToken( token: string | TokenItem ) {\n\t\tconst newTokens = value.filter( ( item ) => {\n\t\t\treturn getTokenValue( item ) !== getTokenValue( token );\n\t\t} );\n\t\tonChange( newTokens );\n\t\tspeak( messages.removed, 'assertive' );\n\t}\n\n\tfunction getTokenValue( token: { value: string } | string ) {\n\t\tif ( 'object' === typeof token ) {\n\t\t\treturn token.value;\n\t\t}\n\n\t\treturn token;\n\t}\n\n\tfunction getMatchingSuggestions(\n\t\tsearchValue = incompleteTokenValue,\n\t\t_suggestions = suggestions,\n\t\t_value = value,\n\t\t_maxSuggestions = maxSuggestions,\n\t\t_saveTransform = saveTransform\n\t) {\n\t\tlet match = _saveTransform( searchValue );\n\t\tconst startsWithMatch: string[] = [];\n\t\tconst containsMatch: string[] = [];\n\t\tconst normalizedValue = _value.map( ( item ) => {\n\t\t\tif ( typeof item === 'string' ) {\n\t\t\t\treturn item;\n\t\t\t}\n\t\t\treturn item.value;\n\t\t} );\n\n\t\tif ( match.length === 0 ) {\n\t\t\t_suggestions = difference( _suggestions, normalizedValue );\n\t\t} else {\n\t\t\tmatch = match.toLocaleLowerCase();\n\n\t\t\t_suggestions.forEach( ( suggestion ) => {\n\t\t\t\tconst index = suggestion.toLocaleLowerCase().indexOf( match );\n\t\t\t\tif ( normalizedValue.indexOf( suggestion ) === -1 ) {\n\t\t\t\t\tif ( index === 0 ) {\n\t\t\t\t\t\tstartsWithMatch.push( suggestion );\n\t\t\t\t\t} else if ( index > 0 ) {\n\t\t\t\t\t\tcontainsMatch.push( suggestion );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} );\n\n\t\t\t_suggestions = startsWithMatch.concat( containsMatch );\n\t\t}\n\n\t\treturn _suggestions.slice( 0, _maxSuggestions );\n\t}\n\n\tfunction getSelectedSuggestion() {\n\t\tif ( selectedSuggestionIndex !== -1 ) {\n\t\t\treturn getMatchingSuggestions()[ selectedSuggestionIndex ];\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tfunction valueContainsToken( token: string ) {\n\t\treturn some( value, ( item ) => {\n\t\t\treturn getTokenValue( token ) === getTokenValue( item );\n\t\t} );\n\t}\n\n\tfunction getIndexOfInput() {\n\t\treturn value.length - inputOffsetFromEnd;\n\t}\n\n\tfunction isInputEmpty() {\n\t\treturn incompleteTokenValue.length === 0;\n\t}\n\n\tfunction inputHasValidValue() {\n\t\treturn saveTransform( incompleteTokenValue ).length > 0;\n\t}\n\n\tfunction updateSuggestions( resetSelectedSuggestion = true ) {\n\t\tconst inputHasMinimumChars = incompleteTokenValue.trim().length > 1;\n\t\tconst matchingSuggestions =\n\t\t\tgetMatchingSuggestions( incompleteTokenValue );\n\t\tconst hasMatchingSuggestions = matchingSuggestions.length > 0;\n\n\t\tsetIsExpanded(\n\t\t\t__experimentalExpandOnFocus ||\n\t\t\t\t( inputHasMinimumChars && hasMatchingSuggestions )\n\t\t);\n\n\t\tif ( resetSelectedSuggestion ) {\n\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\tsetSelectedSuggestionScroll( false );\n\t\t}\n\n\t\tif ( inputHasMinimumChars ) {\n\t\t\tconst message = hasMatchingSuggestions\n\t\t\t\t? sprintf(\n\t\t\t\t\t\t/* translators: %d: number of results. */\n\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t'%d result found, use up and down arrow keys to navigate.',\n\t\t\t\t\t\t\t'%d results found, use up and down arrow keys to navigate.',\n\t\t\t\t\t\t\tmatchingSuggestions.length\n\t\t\t\t\t\t),\n\t\t\t\t\t\tmatchingSuggestions.length\n\t\t\t\t )\n\t\t\t\t: __( 'No results.' );\n\n\t\t\tdebouncedSpeak( message, 'assertive' );\n\t\t}\n\t}\n\n\tfunction renderTokensAndInput() {\n\t\tconst components = map( value, renderToken );\n\t\tcomponents.splice( getIndexOfInput(), 0, renderInput() );\n\n\t\treturn components;\n\t}\n\n\tfunction renderToken(\n\t\ttoken: string | TokenItem,\n\t\tindex: number,\n\t\ttokens: ( string | TokenItem )[]\n\t) {\n\t\tconst _value = getTokenValue( token );\n\t\tconst status = typeof token !== 'string' ? token.status : undefined;\n\t\tconst termPosition = index + 1;\n\t\tconst termsCount = tokens.length;\n\n\t\treturn (\n\t\t\t<FlexItem key={ 'token-' + _value }>\n\t\t\t\t<Token\n\t\t\t\t\tvalue={ _value }\n\t\t\t\t\tstatus={ status }\n\t\t\t\t\ttitle={\n\t\t\t\t\t\ttypeof token !== 'string' ? token.title : undefined\n\t\t\t\t\t}\n\t\t\t\t\tdisplayTransform={ displayTransform }\n\t\t\t\t\tonClickRemove={ onTokenClickRemove }\n\t\t\t\t\tisBorderless={\n\t\t\t\t\t\t( typeof token !== 'string' && token.isBorderless ) ||\n\t\t\t\t\t\tisBorderless\n\t\t\t\t\t}\n\t\t\t\t\tonMouseEnter={\n\t\t\t\t\t\ttypeof token !== 'string'\n\t\t\t\t\t\t\t? token.onMouseEnter\n\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t}\n\t\t\t\t\tonMouseLeave={\n\t\t\t\t\t\ttypeof token !== 'string'\n\t\t\t\t\t\t\t? token.onMouseLeave\n\t\t\t\t\t\t\t: undefined\n\t\t\t\t\t}\n\t\t\t\t\tdisabled={ 'error' !== status && disabled }\n\t\t\t\t\tmessages={ messages }\n\t\t\t\t\ttermsCount={ termsCount }\n\t\t\t\t\ttermPosition={ termPosition }\n\t\t\t\t/>\n\t\t\t</FlexItem>\n\t\t);\n\t}\n\n\tfunction renderInput() {\n\t\tconst inputProps = {\n\t\t\tinstanceId,\n\t\t\tautoCapitalize,\n\t\t\tautoComplete,\n\t\t\tplaceholder: value.length === 0 ? placeholder : '',\n\t\t\tkey: 'input',\n\t\t\tdisabled,\n\t\t\tvalue: incompleteTokenValue,\n\t\t\tonBlur,\n\t\t\tisExpanded,\n\t\t\tselectedSuggestionIndex,\n\t\t};\n\n\t\treturn (\n\t\t\t<TokenInput\n\t\t\t\t{ ...inputProps }\n\t\t\t\tonChange={\n\t\t\t\t\t! ( maxLength && value.length >= maxLength )\n\t\t\t\t\t\t? onInputChangeHandler\n\t\t\t\t\t\t: undefined\n\t\t\t\t}\n\t\t\t\tref={ input }\n\t\t\t/>\n\t\t);\n\t}\n\n\tconst classes = classnames(\n\t\tclassName,\n\t\t'components-form-token-field__input-container',\n\t\t{\n\t\t\t'is-active': isActive,\n\t\t\t'is-disabled': disabled,\n\t\t}\n\t);\n\n\tlet tokenFieldProps = {\n\t\tclassName: 'components-form-token-field',\n\t\ttabIndex: -1,\n\t};\n\tconst matchingSuggestions = getMatchingSuggestions();\n\n\tif ( ! disabled ) {\n\t\ttokenFieldProps = Object.assign( {}, tokenFieldProps, {\n\t\t\tonKeyDown,\n\t\t\tonKeyPress,\n\t\t\tonFocus: onFocusHandler,\n\t\t} );\n\t}\n\n\t// Disable reason: There is no appropriate role which describes the\n\t// input container intended accessible usability.\n\t// TODO: Refactor click detection to use blur to stop propagation.\n\t/* eslint-disable jsx-a11y/no-static-element-interactions */\n\treturn (\n\t\t<div { ...tokenFieldProps }>\n\t\t\t<StyledLabel\n\t\t\t\thtmlFor={ `components-form-token-input-${ instanceId }` }\n\t\t\t\tclassName=\"components-form-token-field__label\"\n\t\t\t>\n\t\t\t\t{ label }\n\t\t\t</StyledLabel>\n\t\t\t<div\n\t\t\t\tref={ tokensAndInput }\n\t\t\t\tclassName={ classes }\n\t\t\t\ttabIndex={ -1 }\n\t\t\t\tonMouseDown={ onContainerTouched }\n\t\t\t\tonTouchStart={ onContainerTouched }\n\t\t\t>\n\t\t\t\t<TokensAndInputWrapperFlex\n\t\t\t\t\tjustify=\"flex-start\"\n\t\t\t\t\talign=\"center\"\n\t\t\t\t\tgap={ 1 }\n\t\t\t\t\twrap={ true }\n\t\t\t\t\t__next36pxDefaultSize={ __next36pxDefaultSize }\n\t\t\t\t\thasTokens={ !! value.length }\n\t\t\t\t>\n\t\t\t\t\t{ renderTokensAndInput() }\n\t\t\t\t</TokensAndInputWrapperFlex>\n\t\t\t\t{ isExpanded && (\n\t\t\t\t\t<SuggestionsList\n\t\t\t\t\t\tinstanceId={ instanceId }\n\t\t\t\t\t\tmatch={ saveTransform( incompleteTokenValue ) }\n\t\t\t\t\t\tdisplayTransform={ displayTransform }\n\t\t\t\t\t\tsuggestions={ matchingSuggestions }\n\t\t\t\t\t\tselectedIndex={ selectedSuggestionIndex }\n\t\t\t\t\t\tscrollIntoView={ selectedSuggestionScroll }\n\t\t\t\t\t\tonHover={ onSuggestionHovered }\n\t\t\t\t\t\tonSelect={ onSuggestionSelected }\n\t\t\t\t\t\t__experimentalRenderItem={ __experimentalRenderItem }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ __experimentalShowHowTo && (\n\t\t\t\t<p\n\t\t\t\t\tid={ `components-form-token-suggestions-howto-${ instanceId }` }\n\t\t\t\t\tclassName=\"components-form-token-field__help\"\n\t\t\t\t>\n\t\t\t\t\t{ tokenizeOnSpace\n\t\t\t\t\t\t? __(\n\t\t\t\t\t\t\t\t'Separate with commas, spaces, or the Enter key.'\n\t\t\t\t\t\t )\n\t\t\t\t\t\t: __( 'Separate with commas or the Enter key.' ) }\n\t\t\t\t</p>\n\t\t\t) }\n\t\t</div>\n\t);\n\t/* eslint-enable jsx-a11y/no-static-element-interactions */\n}\n\nexport default FormTokenField;\n"]}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.TokensAndInputWrapperFlex = void 0;
9
+
10
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
11
+
12
+ var _react = require("@emotion/react");
13
+
14
+ var _flex = require("../flex");
15
+
16
+ var _space = require("../ui/utils/space");
17
+
18
+ /**
19
+ * External dependencies
20
+ */
21
+
22
+ /**
23
+ * Internal dependencies
24
+ */
25
+ const deprecatedPaddings = _ref => {
26
+ let {
27
+ __next36pxDefaultSize,
28
+ hasTokens
29
+ } = _ref;
30
+ return !__next36pxDefaultSize && /*#__PURE__*/(0, _react.css)("padding-top:", (0, _space.space)(hasTokens ? 1 : 0.5), ";padding-bottom:", (0, _space.space)(hasTokens ? 1 : 0.5), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:deprecatedPaddings;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvZm9ybS10b2tlbi1maWVsZC9zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JJIiwiZmlsZSI6IkB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvZm9ybS10b2tlbi1maWVsZC9zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IEZsZXggfSBmcm9tICcuLi9mbGV4JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdWkvdXRpbHMvc3BhY2UnO1xuXG50eXBlIFRva2Vuc0FuZElucHV0V3JhcHBlclByb3BzID0ge1xuXHRfX25leHQzNnB4RGVmYXVsdFNpemU6IGJvb2xlYW47XG5cdGhhc1Rva2VuczogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGRlcHJlY2F0ZWRQYWRkaW5ncyA9ICgge1xuXHRfX25leHQzNnB4RGVmYXVsdFNpemUsXG5cdGhhc1Rva2Vucyxcbn06IFRva2Vuc0FuZElucHV0V3JhcHBlclByb3BzICkgPT5cblx0ISBfX25leHQzNnB4RGVmYXVsdFNpemUgJiZcblx0Y3NzYFxuXHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggaGFzVG9rZW5zID8gMSA6IDAuNSApIH07XG5cdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBoYXNUb2tlbnMgPyAxIDogMC41ICkgfTtcblx0YDtcblxuZXhwb3J0IGNvbnN0IFRva2Vuc0FuZElucHV0V3JhcHBlckZsZXggPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZzogNXB4ICR7IHNwYWNlKCAxICkgfTtcblxuXHQkeyBkZXByZWNhdGVkUGFkZGluZ3MgfVxuYDtcbiJdfQ== */");
31
+ };
32
+
33
+ const TokensAndInputWrapperFlex = ( /*#__PURE__*/0, _base.default)(_flex.Flex, process.env.NODE_ENV === "production" ? {
34
+ target: "ehq8nmi0"
35
+ } : {
36
+ target: "ehq8nmi0",
37
+ label: "TokensAndInputWrapperFlex"
38
+ })("padding:5px ", (0, _space.space)(1), ";", deprecatedPaddings, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvZm9ybS10b2tlbi1maWVsZC9zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJ1RCIsImZpbGUiOiJAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2Zvcm0tdG9rZW4tZmllbGQvc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vZmxleCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3VpL3V0aWxzL3NwYWNlJztcblxudHlwZSBUb2tlbnNBbmRJbnB1dFdyYXBwZXJQcm9wcyA9IHtcblx0X19uZXh0MzZweERlZmF1bHRTaXplOiBib29sZWFuO1xuXHRoYXNUb2tlbnM6IGJvb2xlYW47XG59O1xuXG5jb25zdCBkZXByZWNhdGVkUGFkZGluZ3MgPSAoIHtcblx0X19uZXh0MzZweERlZmF1bHRTaXplLFxuXHRoYXNUb2tlbnMsXG59OiBUb2tlbnNBbmRJbnB1dFdyYXBwZXJQcm9wcyApID0+XG5cdCEgX19uZXh0MzZweERlZmF1bHRTaXplICYmXG5cdGNzc2Bcblx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIGhhc1Rva2VucyA/IDEgOiAwLjUgKSB9O1xuXHRcdHBhZGRpbmctYm90dG9tOiAkeyBzcGFjZSggaGFzVG9rZW5zID8gMSA6IDAuNSApIH07XG5cdGA7XG5cbmV4cG9ydCBjb25zdCBUb2tlbnNBbmRJbnB1dFdyYXBwZXJGbGV4ID0gc3R5bGVkKCBGbGV4IClgXG5cdHBhZGRpbmc6IDVweCAkeyBzcGFjZSggMSApIH07XG5cblx0JHsgZGVwcmVjYXRlZFBhZGRpbmdzIH1cbmA7XG4iXX0= */"));
39
+ exports.TokensAndInputWrapperFlex = TokensAndInputWrapperFlex;
40
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/components/src/form-token-field/styles.ts"],"names":["deprecatedPaddings","__next36pxDefaultSize","hasTokens","css","TokensAndInputWrapperFlex","Flex"],"mappings":";;;;;;;;;;;AAIA;;AAKA;;AACA;;AAVA;AACA;AACA;;AAIA;AACA;AACA;AASA,MAAMA,kBAAkB,GAAG;AAAA,MAAE;AAC5BC,IAAAA,qBAD4B;AAE5BC,IAAAA;AAF4B,GAAF;AAAA,SAI1B,CAAED,qBAAF,qBACAE,UADA,kBAEiB,kBAAOD,SAAS,GAAG,CAAH,GAAO,GAAvB,CAFjB,sBAGoB,kBAAOA,SAAS,GAAG,CAAH,GAAO,GAAvB,CAHpB,44CAJ0B;AAAA,CAA3B;;AAUO,MAAME,yBAAyB,GAAG,iCAAQC,UAAR;AAAA;AAAA;AAAA;AAAA;AAAA,EAAH,iBACrB,kBAAO,CAAP,CADqB,OAGlCL,kBAHkC,i0CAA/B","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\n\n/**\n * Internal dependencies\n */\nimport { Flex } from '../flex';\nimport { space } from '../ui/utils/space';\n\ntype TokensAndInputWrapperProps = {\n\t__next36pxDefaultSize: boolean;\n\thasTokens: boolean;\n};\n\nconst deprecatedPaddings = ( {\n\t__next36pxDefaultSize,\n\thasTokens,\n}: TokensAndInputWrapperProps ) =>\n\t! __next36pxDefaultSize &&\n\tcss`\n\t\tpadding-top: ${ space( hasTokens ? 1 : 0.5 ) };\n\t\tpadding-bottom: ${ space( hasTokens ? 1 : 0.5 ) };\n\t`;\n\nexport const TokensAndInputWrapperFlex = styled( Flex )`\n\tpadding: 5px ${ space( 1 ) };\n\n\t${ deprecatedPaddings }\n`;\n"]}
@@ -25,11 +25,6 @@ var _compose = require("@wordpress/compose");
25
25
  /**
26
26
  * WordPress dependencies
27
27
  */
28
- const {
29
- setTimeout,
30
- clearTimeout
31
- } = window;
32
-
33
28
  const handleMouseDown = e => {
34
29
  // By preventing default here, we will not lose focus of <input> when clicking a suggestion.
35
30
  e.preventDefault();
@@ -44,7 +39,8 @@ function SuggestionsList(_ref) {
44
39
  onSelect,
45
40
  suggestions = [],
46
41
  displayTransform,
47
- instanceId
42
+ instanceId,
43
+ __experimentalRenderItem
48
44
  } = _ref;
49
45
  const [scrollingIntoView, setScrollingIntoView] = (0, _element.useState)(false);
50
46
  const listRef = (0, _compose.useRefEffect)(listNode => {
@@ -57,14 +53,14 @@ function SuggestionsList(_ref) {
57
53
  (0, _domScrollIntoView.default)(listNode.children[selectedIndex], listNode, {
58
54
  onlyScrollIfNeeded: true
59
55
  });
60
- id = setTimeout(() => {
56
+ id = window.setTimeout(() => {
61
57
  setScrollingIntoView(false);
62
58
  }, 100);
63
59
  }
64
60
 
65
61
  return () => {
66
62
  if (id !== undefined) {
67
- clearTimeout(id);
63
+ window.clearTimeout(id);
68
64
  }
69
65
  };
70
66
  }, [selectedIndex, scrollIntoView]);
@@ -109,8 +105,24 @@ function SuggestionsList(_ref) {
109
105
  const className = (0, _classnames.default)('components-form-token-field__suggestion', {
110
106
  'is-selected': index === selectedIndex
111
107
  });
108
+ let output;
109
+
110
+ if (typeof __experimentalRenderItem === 'function') {
111
+ output = __experimentalRenderItem({
112
+ item: suggestion
113
+ });
114
+ } else if (matchText) {
115
+ output = (0, _element.createElement)("span", {
116
+ "aria-label": displayTransform(suggestion)
117
+ }, matchText.suggestionBeforeMatch, (0, _element.createElement)("strong", {
118
+ className: "components-form-token-field__suggestion-match"
119
+ }, matchText.suggestionMatch), matchText.suggestionAfterMatch);
120
+ } else {
121
+ output = displayTransform(suggestion);
122
+ }
112
123
  /* eslint-disable jsx-a11y/click-events-have-key-events */
113
124
 
125
+
114
126
  return (0, _element.createElement)("li", {
115
127
  id: `components-form-token-suggestions-${instanceId}-${index}`,
116
128
  role: "option",
@@ -120,11 +132,7 @@ function SuggestionsList(_ref) {
120
132
  onClick: handleClick(suggestion),
121
133
  onMouseEnter: handleHover(suggestion),
122
134
  "aria-selected": index === selectedIndex
123
- }, matchText ? (0, _element.createElement)("span", {
124
- "aria-label": displayTransform(suggestion)
125
- }, matchText.suggestionBeforeMatch, (0, _element.createElement)("strong", {
126
- className: "components-form-token-field__suggestion-match"
127
- }, matchText.suggestionMatch), matchText.suggestionAfterMatch) : displayTransform(suggestion));
135
+ }, output);
128
136
  /* eslint-enable jsx-a11y/click-events-have-key-events */
129
137
  }));
130
138
  }