@wordpress/components 19.15.0 → 20.0.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 (1313) hide show
  1. package/CHANGELOG.md +161 -0
  2. package/CONTRIBUTING.md +10 -10
  3. package/build/alignment-matrix-control/index.js +1 -1
  4. package/build/alignment-matrix-control/index.js.map +1 -1
  5. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
  6. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  7. package/build/angle-picker-control/index.js +5 -2
  8. package/build/angle-picker-control/index.js.map +1 -1
  9. package/build/angle-picker-control/styles/angle-picker-control-styles.js +14 -4
  10. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  11. package/build/autocomplete/index.js +9 -11
  12. package/build/autocomplete/index.js.map +1 -1
  13. package/build/base-control/index.js +6 -3
  14. package/build/base-control/index.js.map +1 -1
  15. package/build/base-control/styles/base-control-styles.js +8 -8
  16. package/build/base-control/styles/base-control-styles.js.map +1 -1
  17. package/build/base-field/styles.js +5 -5
  18. package/build/base-field/styles.js.map +1 -1
  19. package/build/border-control/border-control/component.js +38 -25
  20. package/build/border-control/border-control/component.js.map +1 -1
  21. package/build/border-control/border-control/hook.js +4 -7
  22. package/build/border-control/border-control/hook.js.map +1 -1
  23. package/build/border-control/border-control-dropdown/component.js +13 -7
  24. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  25. package/build/border-control/border-control-dropdown/hook.js +0 -4
  26. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  27. package/build/border-control/styles.js +29 -60
  28. package/build/border-control/styles.js.map +1 -1
  29. package/build/box-control/all-input-control.js +2 -27
  30. package/build/box-control/all-input-control.js.map +1 -1
  31. package/build/box-control/axial-input-controls.js +1 -1
  32. package/build/box-control/axial-input-controls.js.map +1 -1
  33. package/build/box-control/index.js +10 -5
  34. package/build/box-control/index.js.map +1 -1
  35. package/build/box-control/styles/box-control-styles.js +17 -9
  36. package/build/box-control/styles/box-control-styles.js.map +1 -1
  37. package/build/box-control/styles/box-control-visualizer-styles.js +8 -8
  38. package/build/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  39. package/build/box-control/utils.js +37 -8
  40. package/build/box-control/utils.js.map +1 -1
  41. package/build/card/card/component.js +6 -11
  42. package/build/card/card/component.js.map +1 -1
  43. package/build/card/card/hook.js +0 -10
  44. package/build/card/card/hook.js.map +1 -1
  45. package/build/card/card/index.js.map +1 -1
  46. package/build/card/card-body/component.js +7 -8
  47. package/build/card/card-body/component.js.map +1 -1
  48. package/build/card/card-body/hook.js +0 -4
  49. package/build/card/card-body/hook.js.map +1 -1
  50. package/build/card/card-body/index.js.map +1 -1
  51. package/build/card/card-divider/component.js +7 -8
  52. package/build/card/card-divider/component.js.map +1 -1
  53. package/build/card/card-divider/hook.js +0 -4
  54. package/build/card/card-divider/hook.js.map +1 -1
  55. package/build/card/card-divider/index.js.map +1 -1
  56. package/build/card/card-footer/component.js +7 -8
  57. package/build/card/card-footer/component.js.map +1 -1
  58. package/build/card/card-footer/hook.js +0 -4
  59. package/build/card/card-footer/hook.js.map +1 -1
  60. package/build/card/card-footer/index.js.map +1 -1
  61. package/build/card/card-header/component.js +7 -8
  62. package/build/card/card-header/component.js.map +1 -1
  63. package/build/card/card-header/hook.js +0 -4
  64. package/build/card/card-header/hook.js.map +1 -1
  65. package/build/card/card-header/index.js.map +1 -1
  66. package/build/card/card-media/component.js +7 -7
  67. package/build/card/card-media/component.js.map +1 -1
  68. package/build/card/card-media/hook.js +0 -4
  69. package/build/card/card-media/hook.js.map +1 -1
  70. package/build/card/card-media/index.js.map +1 -1
  71. package/build/card/context.js.map +1 -1
  72. package/build/card/index.js.map +1 -1
  73. package/build/card/styles.js +17 -17
  74. package/build/card/styles.js.map +1 -1
  75. package/build/color-list-picker/index.js +16 -5
  76. package/build/color-list-picker/index.js.map +1 -1
  77. package/build/color-palette/index.js +36 -14
  78. package/build/color-palette/index.js.map +1 -1
  79. package/build/color-palette/index.native.js +3 -3
  80. package/build/color-palette/index.native.js.map +1 -1
  81. package/build/color-picker/hex-input.js +2 -1
  82. package/build/color-picker/hex-input.js.map +1 -1
  83. package/build/color-picker/input-with-slider.js +3 -2
  84. package/build/color-picker/input-with-slider.js.map +1 -1
  85. package/build/color-picker/styles.js +10 -15
  86. package/build/color-picker/styles.js.map +1 -1
  87. package/build/combobox-control/index.js +26 -17
  88. package/build/combobox-control/index.js.map +1 -1
  89. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  90. package/build/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  91. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  92. package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  93. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  94. package/build/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  95. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  96. package/build/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  97. package/build/custom-gradient-picker/index.js +19 -4
  98. package/build/custom-gradient-picker/index.js.map +1 -1
  99. package/build/custom-select-control/index.js +43 -13
  100. package/build/custom-select-control/index.js.map +1 -1
  101. package/build/custom-select-control/styles.js +34 -0
  102. package/build/custom-select-control/styles.js.map +1 -0
  103. package/build/date-time/constants.js +9 -0
  104. package/build/date-time/constants.js.map +1 -0
  105. package/build/date-time/date/index.js +175 -186
  106. package/build/date-time/date/index.js.map +1 -1
  107. package/build/date-time/date/styles.js +59 -40
  108. package/build/date-time/date/styles.js.map +1 -1
  109. package/build/date-time/date-time/index.js +5 -2
  110. package/build/date-time/date-time/index.js.map +1 -1
  111. package/build/date-time/time/index.js +28 -19
  112. package/build/date-time/time/index.js.map +1 -1
  113. package/build/date-time/time/styles.js +17 -24
  114. package/build/date-time/time/styles.js.map +1 -1
  115. package/build/date-time/utils.js +27 -0
  116. package/build/date-time/utils.js.map +1 -0
  117. package/build/dimension-control/index.js +2 -6
  118. package/build/dimension-control/index.js.map +1 -1
  119. package/build/disabled/index.js +28 -11
  120. package/build/disabled/index.js.map +1 -1
  121. package/build/disabled/styles/disabled-styles.js +3 -3
  122. package/build/disabled/styles/disabled-styles.js.map +1 -1
  123. package/build/disabled/types.js +6 -0
  124. package/build/disabled/types.js.map +1 -0
  125. package/build/divider/component.js +0 -1
  126. package/build/divider/component.js.map +1 -1
  127. package/build/divider/index.js.map +1 -1
  128. package/build/divider/styles.js +5 -5
  129. package/build/divider/styles.js.map +1 -1
  130. package/build/drop-zone/index.js +2 -4
  131. package/build/drop-zone/index.js.map +1 -1
  132. package/build/dropdown/dropdown-content-wrapper.js +60 -0
  133. package/build/dropdown/dropdown-content-wrapper.js.map +1 -0
  134. package/build/dropdown/index.js +5 -6
  135. package/build/dropdown/index.js.map +1 -1
  136. package/build/dropdown/styles.js +42 -0
  137. package/build/dropdown/styles.js.map +1 -0
  138. package/build/dropdown/types.js +6 -0
  139. package/build/dropdown/types.js.map +1 -0
  140. package/build/duotone-picker/custom-duotone-bar.js +2 -2
  141. package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
  142. package/build/duotone-picker/duotone-picker.js +9 -1
  143. package/build/duotone-picker/duotone-picker.js.map +1 -1
  144. package/build/duotone-picker/duotone-swatch.js +13 -3
  145. package/build/duotone-picker/duotone-swatch.js.map +1 -1
  146. package/build/elevation/component.js +15 -15
  147. package/build/elevation/component.js.map +1 -1
  148. package/build/elevation/hook.js +5 -17
  149. package/build/elevation/hook.js.map +1 -1
  150. package/build/elevation/index.js.map +1 -1
  151. package/build/elevation/styles.js +1 -1
  152. package/build/elevation/styles.js.map +1 -1
  153. package/build/external-link/index.js +6 -0
  154. package/build/external-link/index.js.map +1 -1
  155. package/build/flex/flex/component.js +20 -26
  156. package/build/flex/flex/component.js.map +1 -1
  157. package/build/flex/flex/hook.js +6 -16
  158. package/build/flex/flex/hook.js.map +1 -1
  159. package/build/flex/flex/index.js.map +1 -1
  160. package/build/flex/flex-block/component.js +18 -12
  161. package/build/flex/flex-block/component.js.map +1 -1
  162. package/build/flex/flex-block/hook.js +0 -4
  163. package/build/flex/flex-block/hook.js.map +1 -1
  164. package/build/flex/flex-block/index.js.map +1 -1
  165. package/build/flex/flex-item/component.js +18 -12
  166. package/build/flex/flex-item/component.js.map +1 -1
  167. package/build/flex/flex-item/hook.js +1 -5
  168. package/build/flex/flex-item/hook.js.map +1 -1
  169. package/build/flex/flex-item/index.js.map +1 -1
  170. package/build/flex/index.js.map +1 -1
  171. package/build/flex/styles.js +5 -5
  172. package/build/flex/styles.js.map +1 -1
  173. package/build/focal-point-picker/index.js +4 -6
  174. package/build/focal-point-picker/index.js.map +1 -1
  175. package/build/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  176. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  177. package/build/focal-point-picker/styles/focal-point-style.js +5 -5
  178. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  179. package/build/font-size-picker/index.js +56 -18
  180. package/build/font-size-picker/index.js.map +1 -1
  181. package/build/font-size-picker/utils.js +32 -22
  182. package/build/font-size-picker/utils.js.map +1 -1
  183. package/build/form-token-field/index.js +35 -22
  184. package/build/form-token-field/index.js.map +1 -1
  185. package/build/form-token-field/suggestions-list.js +19 -6
  186. package/build/form-token-field/suggestions-list.js.map +1 -1
  187. package/build/gradient-picker/index.js +15 -3
  188. package/build/gradient-picker/index.js.map +1 -1
  189. package/build/guide/index.js +5 -3
  190. package/build/guide/index.js.map +1 -1
  191. package/build/guide/page-control.js +3 -7
  192. package/build/guide/page-control.js.map +1 -1
  193. package/build/index.js +31 -1
  194. package/build/index.js.map +1 -1
  195. package/build/input-control/index.js +7 -0
  196. package/build/input-control/index.js.map +1 -1
  197. package/build/input-control/input-base.js +24 -3
  198. package/build/input-control/input-base.js.map +1 -1
  199. package/build/input-control/input-prefix-wrapper.js +54 -0
  200. package/build/input-control/input-prefix-wrapper.js.map +1 -0
  201. package/build/input-control/input-suffix-wrapper.js +54 -0
  202. package/build/input-control/input-suffix-wrapper.js.map +1 -0
  203. package/build/input-control/reducer/actions.js +3 -1
  204. package/build/input-control/reducer/actions.js.map +1 -1
  205. package/build/input-control/reducer/reducer.js +28 -11
  206. package/build/input-control/reducer/reducer.js.map +1 -1
  207. package/build/input-control/reducer/state.js.map +1 -1
  208. package/build/input-control/styles/input-control-styles.js +61 -42
  209. package/build/input-control/styles/input-control-styles.js.map +1 -1
  210. package/build/item-group/styles.js +10 -10
  211. package/build/item-group/styles.js.map +1 -1
  212. package/build/mobile/bottom-sheet/index.native.js +3 -6
  213. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  214. package/build/mobile/global-styles-context/utils.native.js +26 -4
  215. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  216. package/build/mobile/image/index.native.js +9 -5
  217. package/build/mobile/image/index.native.js.map +1 -1
  218. package/build/mobile/link-picker/link-picker-screen.native.js +10 -4
  219. package/build/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  220. package/build/mobile/media-edit/index.native.js +1 -7
  221. package/build/mobile/media-edit/index.native.js.map +1 -1
  222. package/build/mobile/picker/index.android.js +3 -3
  223. package/build/mobile/picker/index.android.js.map +1 -1
  224. package/build/mobile/picker/index.ios.js +16 -3
  225. package/build/mobile/picker/index.ios.js.map +1 -1
  226. package/build/modal/index.js +1 -3
  227. package/build/modal/index.js.map +1 -1
  228. package/build/navigable-container/container.js +9 -8
  229. package/build/navigable-container/container.js.map +1 -1
  230. package/build/navigable-container/menu.js +3 -9
  231. package/build/navigable-container/menu.js.map +1 -1
  232. package/build/navigator/navigator-back-button/hook.js +0 -4
  233. package/build/navigator/navigator-back-button/hook.js.map +1 -1
  234. package/build/navigator/navigator-button/hook.js +0 -4
  235. package/build/navigator/navigator-button/hook.js.map +1 -1
  236. package/build/notice/list.js +10 -6
  237. package/build/notice/list.js.map +1 -1
  238. package/build/palette-edit/index.js +1 -0
  239. package/build/palette-edit/index.js.map +1 -1
  240. package/build/palette-edit/styles.js +10 -10
  241. package/build/palette-edit/styles.js.map +1 -1
  242. package/build/placeholder/index.js +11 -14
  243. package/build/placeholder/index.js.map +1 -1
  244. package/build/placeholder/types.js +6 -0
  245. package/build/placeholder/types.js.map +1 -0
  246. package/build/popover/index.js +202 -145
  247. package/build/popover/index.js.map +1 -1
  248. package/build/popover/utils.js +178 -0
  249. package/build/popover/utils.js.map +1 -0
  250. package/build/radio-control/index.js +1 -3
  251. package/build/radio-control/index.js.map +1 -1
  252. package/build/range-control/index.js +3 -0
  253. package/build/range-control/index.js.map +1 -1
  254. package/build/range-control/styles/range-control-styles.js +51 -45
  255. package/build/range-control/styles/range-control-styles.js.map +1 -1
  256. package/build/range-control/utils.js +1 -1
  257. package/build/range-control/utils.js.map +1 -1
  258. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  259. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  260. package/build/sandbox/index.native.js +13 -2
  261. package/build/sandbox/index.native.js.map +1 -1
  262. package/build/scroll-lock/index.js +35 -6
  263. package/build/scroll-lock/index.js.map +1 -1
  264. package/build/select-control/chevron-down.js +30 -0
  265. package/build/select-control/chevron-down.js.map +1 -0
  266. package/build/select-control/index.js +8 -10
  267. package/build/select-control/index.js.map +1 -1
  268. package/build/select-control/styles/select-control-styles.js +54 -19
  269. package/build/select-control/styles/select-control-styles.js.map +1 -1
  270. package/build/shortcut/index.js +4 -13
  271. package/build/shortcut/index.js.map +1 -1
  272. package/build/shortcut/types.js +6 -0
  273. package/build/shortcut/types.js.map +1 -0
  274. package/build/snackbar/list.js +5 -3
  275. package/build/snackbar/list.js.map +1 -1
  276. package/build/spacer/component.js +3 -1
  277. package/build/spacer/component.js.map +1 -1
  278. package/build/spinner/index.js +2 -0
  279. package/build/spinner/index.js.map +1 -1
  280. package/build/style-provider/index.js +10 -7
  281. package/build/style-provider/index.js.map +1 -1
  282. package/build/style-provider/types.js +6 -0
  283. package/build/style-provider/types.js.map +1 -0
  284. package/build/text/hook.js +5 -8
  285. package/build/text/hook.js.map +1 -1
  286. package/build/text/styles.js +7 -7
  287. package/build/text/styles.js.map +1 -1
  288. package/build/toggle-group-control/toggle-group-control/component.js +19 -8
  289. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  290. package/build/toggle-group-control/toggle-group-control/styles.js +22 -4
  291. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  292. package/build/toggle-group-control/toggle-group-control-option/component.js +15 -5
  293. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  294. package/build/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  295. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  296. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +20 -9
  297. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  298. package/build/toggle-group-control/toggle-group-control-option-icon/component.js +26 -7
  299. package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  300. package/build/tools-panel/styles.js +13 -10
  301. package/build/tools-panel/styles.js.map +1 -1
  302. package/build/tools-panel/tools-panel/hook.js +1 -1
  303. package/build/tools-panel/tools-panel/hook.js.map +1 -1
  304. package/build/tooltip/index.js +52 -21
  305. package/build/tooltip/index.js.map +1 -1
  306. package/build/tree-grid/index.js +4 -10
  307. package/build/tree-grid/index.js.map +1 -1
  308. package/build/tree-select/index.js +2 -2
  309. package/build/tree-select/index.js.map +1 -1
  310. package/build/ui/context/context-connect.js +1 -3
  311. package/build/ui/context/context-connect.js.map +1 -1
  312. package/build/ui/context/use-context-system.js +7 -2
  313. package/build/ui/context/use-context-system.js.map +1 -1
  314. package/build/ui/tooltip/styles.js +4 -4
  315. package/build/ui/tooltip/styles.js.map +1 -1
  316. package/build/ui/utils/space.js +7 -1
  317. package/build/ui/utils/space.js.map +1 -1
  318. package/build/unit-control/index.js +2 -3
  319. package/build/unit-control/index.js.map +1 -1
  320. package/build/unit-control/styles/unit-control-styles.js +38 -29
  321. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  322. package/build/utils/base-label.js +24 -0
  323. package/build/utils/base-label.js.map +1 -0
  324. package/build/utils/box-sizing.js +22 -0
  325. package/build/utils/box-sizing.js.map +1 -0
  326. package/build/utils/colors-values.js +52 -142
  327. package/build/utils/colors-values.js.map +1 -1
  328. package/build/utils/config-values.js +1 -1
  329. package/build/utils/config-values.js.map +1 -1
  330. package/build/utils/input/input-control.js +1 -1
  331. package/build/utils/input/input-control.js.map +1 -1
  332. package/build/utils/rtl.js +6 -5
  333. package/build/utils/rtl.js.map +1 -1
  334. package/build/utils/strings.js +50 -0
  335. package/build/utils/strings.js.map +1 -0
  336. package/build/utils/style-mixins.js +16 -0
  337. package/build/utils/style-mixins.js.map +1 -1
  338. package/build-module/alignment-matrix-control/index.js +1 -1
  339. package/build-module/alignment-matrix-control/index.js.map +1 -1
  340. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
  341. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  342. package/build-module/angle-picker-control/index.js +5 -2
  343. package/build-module/angle-picker-control/index.js.map +1 -1
  344. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +13 -4
  345. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  346. package/build-module/autocomplete/index.js +9 -10
  347. package/build-module/autocomplete/index.js.map +1 -1
  348. package/build-module/base-control/index.js +7 -5
  349. package/build-module/base-control/index.js.map +1 -1
  350. package/build-module/base-control/styles/base-control-styles.js +9 -9
  351. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  352. package/build-module/base-field/styles.js +5 -5
  353. package/build-module/base-field/styles.js.map +1 -1
  354. package/build-module/border-control/border-control/component.js +37 -25
  355. package/build-module/border-control/border-control/component.js.map +1 -1
  356. package/build-module/border-control/border-control/hook.js +4 -7
  357. package/build-module/border-control/border-control/hook.js.map +1 -1
  358. package/build-module/border-control/border-control-dropdown/component.js +12 -7
  359. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  360. package/build-module/border-control/border-control-dropdown/hook.js +0 -4
  361. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  362. package/build-module/border-control/styles.js +30 -54
  363. package/build-module/border-control/styles.js.map +1 -1
  364. package/build-module/box-control/all-input-control.js +3 -28
  365. package/build-module/box-control/all-input-control.js.map +1 -1
  366. package/build-module/box-control/axial-input-controls.js +1 -1
  367. package/build-module/box-control/axial-input-controls.js.map +1 -1
  368. package/build-module/box-control/index.js +4 -4
  369. package/build-module/box-control/index.js.map +1 -1
  370. package/build-module/box-control/styles/box-control-styles.js +18 -10
  371. package/build-module/box-control/styles/box-control-styles.js.map +1 -1
  372. package/build-module/box-control/styles/box-control-visualizer-styles.js +8 -8
  373. package/build-module/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  374. package/build-module/box-control/utils.js +35 -7
  375. package/build-module/box-control/utils.js.map +1 -1
  376. package/build-module/card/card/component.js +5 -10
  377. package/build-module/card/card/component.js.map +1 -1
  378. package/build-module/card/card/hook.js +0 -9
  379. package/build-module/card/card/hook.js.map +1 -1
  380. package/build-module/card/card/index.js.map +1 -1
  381. package/build-module/card/card-body/component.js +7 -8
  382. package/build-module/card/card-body/component.js.map +1 -1
  383. package/build-module/card/card-body/hook.js +0 -4
  384. package/build-module/card/card-body/hook.js.map +1 -1
  385. package/build-module/card/card-body/index.js.map +1 -1
  386. package/build-module/card/card-divider/component.js +7 -8
  387. package/build-module/card/card-divider/component.js.map +1 -1
  388. package/build-module/card/card-divider/hook.js +0 -4
  389. package/build-module/card/card-divider/hook.js.map +1 -1
  390. package/build-module/card/card-divider/index.js.map +1 -1
  391. package/build-module/card/card-footer/component.js +7 -8
  392. package/build-module/card/card-footer/component.js.map +1 -1
  393. package/build-module/card/card-footer/hook.js +0 -4
  394. package/build-module/card/card-footer/hook.js.map +1 -1
  395. package/build-module/card/card-footer/index.js.map +1 -1
  396. package/build-module/card/card-header/component.js +7 -8
  397. package/build-module/card/card-header/component.js.map +1 -1
  398. package/build-module/card/card-header/hook.js +0 -4
  399. package/build-module/card/card-header/hook.js.map +1 -1
  400. package/build-module/card/card-header/index.js.map +1 -1
  401. package/build-module/card/card-media/component.js +7 -7
  402. package/build-module/card/card-media/component.js.map +1 -1
  403. package/build-module/card/card-media/hook.js +0 -4
  404. package/build-module/card/card-media/hook.js.map +1 -1
  405. package/build-module/card/card-media/index.js.map +1 -1
  406. package/build-module/card/context.js.map +1 -1
  407. package/build-module/card/index.js.map +1 -1
  408. package/build-module/card/styles.js +17 -17
  409. package/build-module/card/styles.js.map +1 -1
  410. package/build-module/color-list-picker/index.js +13 -5
  411. package/build-module/color-list-picker/index.js.map +1 -1
  412. package/build-module/color-palette/index.js +32 -12
  413. package/build-module/color-palette/index.js.map +1 -1
  414. package/build-module/color-palette/index.native.js +4 -4
  415. package/build-module/color-palette/index.native.js.map +1 -1
  416. package/build-module/color-picker/hex-input.js +2 -1
  417. package/build-module/color-picker/hex-input.js.map +1 -1
  418. package/build-module/color-picker/input-with-slider.js +3 -2
  419. package/build-module/color-picker/input-with-slider.js.map +1 -1
  420. package/build-module/color-picker/styles.js +10 -16
  421. package/build-module/color-picker/styles.js.map +1 -1
  422. package/build-module/combobox-control/index.js +24 -15
  423. package/build-module/combobox-control/index.js.map +1 -1
  424. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  425. package/build-module/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  426. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  427. package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  428. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  429. package/build-module/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  430. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  431. package/build-module/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  432. package/build-module/custom-gradient-picker/index.js +16 -3
  433. package/build-module/custom-gradient-picker/index.js.map +1 -1
  434. package/build-module/custom-select-control/index.js +41 -16
  435. package/build-module/custom-select-control/index.js.map +1 -1
  436. package/build-module/custom-select-control/styles.js +22 -0
  437. package/build-module/custom-select-control/styles.js.map +1 -0
  438. package/build-module/date-time/constants.js +2 -0
  439. package/build-module/date-time/constants.js.map +1 -0
  440. package/build-module/date-time/date/index.js +178 -184
  441. package/build-module/date-time/date/index.js.map +1 -1
  442. package/build-module/date-time/date/styles.js +47 -38
  443. package/build-module/date-time/date/styles.js.map +1 -1
  444. package/build-module/date-time/date-time/index.js +4 -2
  445. package/build-module/date-time/date-time/index.js.map +1 -1
  446. package/build-module/date-time/time/index.js +26 -19
  447. package/build-module/date-time/time/index.js.map +1 -1
  448. package/build-module/date-time/time/styles.js +15 -21
  449. package/build-module/date-time/time/styles.js.map +1 -1
  450. package/build-module/date-time/utils.js +19 -0
  451. package/build-module/date-time/utils.js.map +1 -0
  452. package/build-module/dimension-control/index.js +1 -5
  453. package/build-module/dimension-control/index.js.map +1 -1
  454. package/build-module/disabled/index.js +28 -11
  455. package/build-module/disabled/index.js.map +1 -1
  456. package/build-module/disabled/styles/disabled-styles.js +3 -3
  457. package/build-module/disabled/styles/disabled-styles.js.map +1 -1
  458. package/build-module/disabled/types.js +2 -0
  459. package/build-module/disabled/types.js.map +1 -0
  460. package/build-module/divider/component.js +0 -1
  461. package/build-module/divider/component.js.map +1 -1
  462. package/build-module/divider/index.js.map +1 -1
  463. package/build-module/divider/styles.js +5 -5
  464. package/build-module/divider/styles.js.map +1 -1
  465. package/build-module/drop-zone/index.js +2 -3
  466. package/build-module/drop-zone/index.js.map +1 -1
  467. package/build-module/dropdown/dropdown-content-wrapper.js +47 -0
  468. package/build-module/dropdown/dropdown-content-wrapper.js.map +1 -0
  469. package/build-module/dropdown/index.js +5 -6
  470. package/build-module/dropdown/index.js.map +1 -1
  471. package/build-module/dropdown/styles.js +31 -0
  472. package/build-module/dropdown/styles.js.map +1 -0
  473. package/build-module/dropdown/types.js +2 -0
  474. package/build-module/dropdown/types.js.map +1 -0
  475. package/build-module/duotone-picker/custom-duotone-bar.js +1 -1
  476. package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
  477. package/build-module/duotone-picker/duotone-picker.js +7 -1
  478. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  479. package/build-module/duotone-picker/duotone-swatch.js +11 -3
  480. package/build-module/duotone-picker/duotone-swatch.js.map +1 -1
  481. package/build-module/elevation/component.js +15 -15
  482. package/build-module/elevation/component.js.map +1 -1
  483. package/build-module/elevation/hook.js +5 -17
  484. package/build-module/elevation/hook.js.map +1 -1
  485. package/build-module/elevation/index.js.map +1 -1
  486. package/build-module/elevation/styles.js +1 -1
  487. package/build-module/elevation/styles.js.map +1 -1
  488. package/build-module/external-link/index.js +6 -0
  489. package/build-module/external-link/index.js.map +1 -1
  490. package/build-module/flex/flex/component.js +20 -26
  491. package/build-module/flex/flex/component.js.map +1 -1
  492. package/build-module/flex/flex/hook.js +6 -15
  493. package/build-module/flex/flex/hook.js.map +1 -1
  494. package/build-module/flex/flex/index.js.map +1 -1
  495. package/build-module/flex/flex-block/component.js +18 -12
  496. package/build-module/flex/flex-block/component.js.map +1 -1
  497. package/build-module/flex/flex-block/hook.js +0 -4
  498. package/build-module/flex/flex-block/hook.js.map +1 -1
  499. package/build-module/flex/flex-block/index.js.map +1 -1
  500. package/build-module/flex/flex-item/component.js +18 -12
  501. package/build-module/flex/flex-item/component.js.map +1 -1
  502. package/build-module/flex/flex-item/hook.js +1 -5
  503. package/build-module/flex/flex-item/hook.js.map +1 -1
  504. package/build-module/flex/flex-item/index.js.map +1 -1
  505. package/build-module/flex/index.js.map +1 -1
  506. package/build-module/flex/styles.js +5 -5
  507. package/build-module/flex/styles.js.map +1 -1
  508. package/build-module/focal-point-picker/index.js +4 -5
  509. package/build-module/focal-point-picker/index.js.map +1 -1
  510. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  511. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  512. package/build-module/focal-point-picker/styles/focal-point-style.js +5 -5
  513. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  514. package/build-module/font-size-picker/index.js +51 -18
  515. package/build-module/font-size-picker/index.js.map +1 -1
  516. package/build-module/font-size-picker/utils.js +31 -23
  517. package/build-module/font-size-picker/utils.js.map +1 -1
  518. package/build-module/form-token-field/index.js +35 -22
  519. package/build-module/form-token-field/index.js.map +1 -1
  520. package/build-module/form-token-field/suggestions-list.js +19 -6
  521. package/build-module/form-token-field/suggestions-list.js.map +1 -1
  522. package/build-module/gradient-picker/index.js +14 -3
  523. package/build-module/gradient-picker/index.js.map +1 -1
  524. package/build-module/guide/index.js +5 -3
  525. package/build-module/guide/index.js.map +1 -1
  526. package/build-module/guide/page-control.js +3 -6
  527. package/build-module/guide/page-control.js.map +1 -1
  528. package/build-module/index.js +4 -1
  529. package/build-module/index.js.map +1 -1
  530. package/build-module/input-control/index.js +6 -0
  531. package/build-module/input-control/index.js.map +1 -1
  532. package/build-module/input-control/input-base.js +25 -5
  533. package/build-module/input-control/input-base.js.map +1 -1
  534. package/build-module/input-control/input-prefix-wrapper.js +41 -0
  535. package/build-module/input-control/input-prefix-wrapper.js.map +1 -0
  536. package/build-module/input-control/input-suffix-wrapper.js +41 -0
  537. package/build-module/input-control/input-suffix-wrapper.js.map +1 -0
  538. package/build-module/input-control/reducer/actions.js +1 -0
  539. package/build-module/input-control/reducer/actions.js.map +1 -1
  540. package/build-module/input-control/reducer/reducer.js +28 -11
  541. package/build-module/input-control/reducer/reducer.js.map +1 -1
  542. package/build-module/input-control/reducer/state.js.map +1 -1
  543. package/build-module/input-control/styles/input-control-styles.js +58 -42
  544. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  545. package/build-module/item-group/styles.js +10 -10
  546. package/build-module/item-group/styles.js.map +1 -1
  547. package/build-module/mobile/bottom-sheet/index.native.js +3 -5
  548. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  549. package/build-module/mobile/global-styles-context/utils.native.js +24 -4
  550. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  551. package/build-module/mobile/image/index.native.js +12 -8
  552. package/build-module/mobile/image/index.native.js.map +1 -1
  553. package/build-module/mobile/link-picker/link-picker-screen.native.js +11 -4
  554. package/build-module/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  555. package/build-module/mobile/media-edit/index.native.js +1 -6
  556. package/build-module/mobile/media-edit/index.native.js.map +1 -1
  557. package/build-module/mobile/picker/index.android.js +3 -3
  558. package/build-module/mobile/picker/index.android.js.map +1 -1
  559. package/build-module/mobile/picker/index.ios.js +14 -3
  560. package/build-module/mobile/picker/index.ios.js.map +1 -1
  561. package/build-module/modal/index.js +1 -2
  562. package/build-module/modal/index.js.map +1 -1
  563. package/build-module/navigable-container/container.js +9 -7
  564. package/build-module/navigable-container/container.js.map +1 -1
  565. package/build-module/navigable-container/menu.js +3 -8
  566. package/build-module/navigable-container/menu.js.map +1 -1
  567. package/build-module/navigator/navigator-back-button/hook.js +0 -4
  568. package/build-module/navigator/navigator-back-button/hook.js.map +1 -1
  569. package/build-module/navigator/navigator-button/hook.js +0 -4
  570. package/build-module/navigator/navigator-button/hook.js.map +1 -1
  571. package/build-module/notice/list.js +10 -5
  572. package/build-module/notice/list.js.map +1 -1
  573. package/build-module/palette-edit/index.js +1 -0
  574. package/build-module/palette-edit/index.js.map +1 -1
  575. package/build-module/palette-edit/styles.js +10 -10
  576. package/build-module/palette-edit/styles.js.map +1 -1
  577. package/build-module/placeholder/index.js +10 -15
  578. package/build-module/placeholder/index.js.map +1 -1
  579. package/build-module/placeholder/types.js +2 -0
  580. package/build-module/placeholder/types.js.map +1 -0
  581. package/build-module/popover/index.js +202 -147
  582. package/build-module/popover/index.js.map +1 -1
  583. package/build-module/popover/utils.js +164 -0
  584. package/build-module/popover/utils.js.map +1 -0
  585. package/build-module/radio-control/index.js +1 -2
  586. package/build-module/radio-control/index.js.map +1 -1
  587. package/build-module/range-control/index.js +3 -0
  588. package/build-module/range-control/index.js.map +1 -1
  589. package/build-module/range-control/styles/range-control-styles.js +51 -45
  590. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  591. package/build-module/range-control/utils.js +1 -1
  592. package/build-module/range-control/utils.js.map +1 -1
  593. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  594. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  595. package/build-module/sandbox/index.native.js +13 -3
  596. package/build-module/sandbox/index.native.js.map +1 -1
  597. package/build-module/scroll-lock/index.js +32 -6
  598. package/build-module/scroll-lock/index.js.map +1 -1
  599. package/build-module/select-control/chevron-down.js +21 -0
  600. package/build-module/select-control/chevron-down.js.map +1 -0
  601. package/build-module/select-control/index.js +8 -9
  602. package/build-module/select-control/index.js.map +1 -1
  603. package/build-module/select-control/styles/select-control-styles.js +48 -17
  604. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  605. package/build-module/shortcut/index.js +4 -13
  606. package/build-module/shortcut/index.js.map +1 -1
  607. package/build-module/shortcut/types.js +2 -0
  608. package/build-module/shortcut/types.js.map +1 -0
  609. package/build-module/snackbar/list.js +5 -2
  610. package/build-module/snackbar/list.js.map +1 -1
  611. package/build-module/spacer/component.js +3 -1
  612. package/build-module/spacer/component.js.map +1 -1
  613. package/build-module/spinner/index.js +2 -0
  614. package/build-module/spinner/index.js.map +1 -1
  615. package/build-module/style-provider/index.js +10 -5
  616. package/build-module/style-provider/index.js.map +1 -1
  617. package/build-module/style-provider/types.js +2 -0
  618. package/build-module/style-provider/types.js.map +1 -0
  619. package/build-module/text/hook.js +5 -7
  620. package/build-module/text/hook.js.map +1 -1
  621. package/build-module/text/styles.js +7 -7
  622. package/build-module/text/styles.js.map +1 -1
  623. package/build-module/toggle-group-control/toggle-group-control/component.js +17 -7
  624. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  625. package/build-module/toggle-group-control/toggle-group-control/styles.js +16 -3
  626. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  627. package/build-module/toggle-group-control/toggle-group-control-option/component.js +17 -3
  628. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  629. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  630. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  631. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +16 -7
  632. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  633. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +27 -5
  634. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  635. package/build-module/tools-panel/styles.js +12 -11
  636. package/build-module/tools-panel/styles.js.map +1 -1
  637. package/build-module/tools-panel/tools-panel/hook.js +1 -1
  638. package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
  639. package/build-module/tooltip/index.js +54 -22
  640. package/build-module/tooltip/index.js.map +1 -1
  641. package/build-module/tree-grid/index.js +4 -9
  642. package/build-module/tree-grid/index.js.map +1 -1
  643. package/build-module/tree-select/index.js +3 -3
  644. package/build-module/tree-select/index.js.map +1 -1
  645. package/build-module/ui/context/context-connect.js +1 -2
  646. package/build-module/ui/context/context-connect.js.map +1 -1
  647. package/build-module/ui/context/use-context-system.js +7 -2
  648. package/build-module/ui/context/use-context-system.js.map +1 -1
  649. package/build-module/ui/tooltip/styles.js +4 -4
  650. package/build-module/ui/tooltip/styles.js.map +1 -1
  651. package/build-module/ui/utils/space.js +7 -1
  652. package/build-module/ui/utils/space.js.map +1 -1
  653. package/build-module/unit-control/index.js +2 -2
  654. package/build-module/unit-control/index.js.map +1 -1
  655. package/build-module/unit-control/styles/unit-control-styles.js +39 -30
  656. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  657. package/build-module/utils/base-label.js +18 -0
  658. package/build-module/utils/base-label.js.map +1 -0
  659. package/build-module/utils/box-sizing.js +16 -0
  660. package/build-module/utils/box-sizing.js.map +1 -0
  661. package/build-module/utils/colors-values.js +52 -141
  662. package/build-module/utils/colors-values.js.map +1 -1
  663. package/build-module/utils/config-values.js +1 -1
  664. package/build-module/utils/config-values.js.map +1 -1
  665. package/build-module/utils/input/input-control.js +1 -1
  666. package/build-module/utils/input/input-control.js.map +1 -1
  667. package/build-module/utils/rtl.js +6 -4
  668. package/build-module/utils/rtl.js.map +1 -1
  669. package/build-module/utils/strings.js +37 -0
  670. package/build-module/utils/strings.js.map +1 -0
  671. package/build-module/utils/style-mixins.js +2 -0
  672. package/build-module/utils/style-mixins.js.map +1 -1
  673. package/build-style/style-rtl.css +236 -1281
  674. package/build-style/style.css +237 -1281
  675. package/build-types/base-control/index.d.ts +4 -3
  676. package/build-types/base-control/index.d.ts.map +1 -1
  677. package/build-types/base-control/stories/index.d.ts +1 -1
  678. package/build-types/base-control/stories/index.d.ts.map +1 -1
  679. package/build-types/base-control/styles/base-control-styles.d.ts.map +1 -1
  680. package/build-types/base-control/types.d.ts +0 -1
  681. package/build-types/base-control/types.d.ts.map +1 -1
  682. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  683. package/build-types/border-control/border-control/hook.d.ts +1 -1
  684. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  685. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  686. package/build-types/border-control/border-control-dropdown/hook.d.ts +0 -1
  687. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  688. package/build-types/border-control/stories/index.d.ts.map +1 -1
  689. package/build-types/border-control/styles.d.ts +1 -4
  690. package/build-types/border-control/styles.d.ts.map +1 -1
  691. package/build-types/card/card/component.d.ts +3 -3
  692. package/build-types/card/card/component.d.ts.map +1 -1
  693. package/build-types/card/card/hook.d.ts +7 -2
  694. package/build-types/card/card/hook.d.ts.map +1 -1
  695. package/build-types/card/card/index.d.ts +2 -2
  696. package/build-types/card/card/index.d.ts.map +1 -1
  697. package/build-types/card/card-body/component.d.ts +3 -3
  698. package/build-types/card/card-body/component.d.ts.map +1 -1
  699. package/build-types/card/card-body/hook.d.ts +5 -2
  700. package/build-types/card/card-body/hook.d.ts.map +1 -1
  701. package/build-types/card/card-body/index.d.ts +2 -2
  702. package/build-types/card/card-body/index.d.ts.map +1 -1
  703. package/build-types/card/card-divider/component.d.ts +3 -3
  704. package/build-types/card/card-divider/component.d.ts.map +1 -1
  705. package/build-types/card/card-divider/hook.d.ts +6 -3
  706. package/build-types/card/card-divider/hook.d.ts.map +1 -1
  707. package/build-types/card/card-divider/index.d.ts +2 -2
  708. package/build-types/card/card-divider/index.d.ts.map +1 -1
  709. package/build-types/card/card-footer/component.d.ts +3 -3
  710. package/build-types/card/card-footer/component.d.ts.map +1 -1
  711. package/build-types/card/card-footer/hook.d.ts +5 -2
  712. package/build-types/card/card-footer/hook.d.ts.map +1 -1
  713. package/build-types/card/card-footer/index.d.ts +2 -2
  714. package/build-types/card/card-footer/index.d.ts.map +1 -1
  715. package/build-types/card/card-header/component.d.ts +3 -3
  716. package/build-types/card/card-header/component.d.ts.map +1 -1
  717. package/build-types/card/card-header/hook.d.ts +5 -2
  718. package/build-types/card/card-header/hook.d.ts.map +1 -1
  719. package/build-types/card/card-header/index.d.ts +2 -2
  720. package/build-types/card/card-header/index.d.ts.map +1 -1
  721. package/build-types/card/card-media/component.d.ts +3 -4
  722. package/build-types/card/card-media/component.d.ts.map +1 -1
  723. package/build-types/card/card-media/hook.d.ts +6 -5
  724. package/build-types/card/card-media/hook.d.ts.map +1 -1
  725. package/build-types/card/card-media/index.d.ts +2 -2
  726. package/build-types/card/card-media/index.d.ts.map +1 -1
  727. package/build-types/card/context.d.ts +3 -2
  728. package/build-types/card/context.d.ts.map +1 -1
  729. package/build-types/card/index.d.ts +6 -6
  730. package/build-types/card/index.d.ts.map +1 -1
  731. package/build-types/card/stories/index.d.ts +12 -0
  732. package/build-types/card/stories/index.d.ts.map +1 -0
  733. package/build-types/card/styles.d.ts +20 -22
  734. package/build-types/card/styles.d.ts.map +1 -1
  735. package/build-types/card/test/index.d.ts +2 -0
  736. package/build-types/card/test/index.d.ts.map +1 -0
  737. package/build-types/card/types.d.ts +7 -1
  738. package/build-types/card/types.d.ts.map +1 -1
  739. package/build-types/color-palette/index.d.ts +3 -1
  740. package/build-types/color-palette/index.d.ts.map +1 -1
  741. package/build-types/color-picker/hex-input.d.ts.map +1 -1
  742. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  743. package/build-types/color-picker/styles.d.ts +2 -2
  744. package/build-types/color-picker/styles.d.ts.map +1 -1
  745. package/build-types/date-time/constants.d.ts +2 -0
  746. package/build-types/date-time/constants.d.ts.map +1 -0
  747. package/build-types/date-time/date/index.d.ts +3 -1
  748. package/build-types/date-time/date/index.d.ts.map +1 -1
  749. package/build-types/date-time/date/styles.d.ts +22 -8
  750. package/build-types/date-time/date/styles.d.ts.map +1 -1
  751. package/build-types/date-time/date/test/index.d.ts +1 -1
  752. package/build-types/date-time/date/test/index.d.ts.map +1 -1
  753. package/build-types/date-time/date-time/index.d.ts.map +1 -1
  754. package/build-types/date-time/time/index.d.ts.map +1 -1
  755. package/build-types/date-time/time/styles.d.ts +0 -4
  756. package/build-types/date-time/time/styles.d.ts.map +1 -1
  757. package/build-types/date-time/utils.d.ts +8 -0
  758. package/build-types/date-time/utils.d.ts.map +1 -0
  759. package/build-types/disabled/index.d.ts +35 -28
  760. package/build-types/disabled/index.d.ts.map +1 -1
  761. package/build-types/disabled/stories/index.d.ts +13 -0
  762. package/build-types/disabled/stories/index.d.ts.map +1 -0
  763. package/build-types/disabled/styles/disabled-styles.d.ts +2 -1
  764. package/build-types/disabled/styles/disabled-styles.d.ts.map +1 -1
  765. package/build-types/disabled/test/index.d.ts +2 -0
  766. package/build-types/disabled/test/index.d.ts.map +1 -0
  767. package/build-types/disabled/types.d.ts +14 -0
  768. package/build-types/disabled/types.d.ts.map +1 -0
  769. package/build-types/divider/component.d.ts +2 -3
  770. package/build-types/divider/component.d.ts.map +1 -1
  771. package/build-types/divider/index.d.ts +1 -1
  772. package/build-types/divider/index.d.ts.map +1 -1
  773. package/build-types/divider/styles.d.ts +6 -2
  774. package/build-types/divider/styles.d.ts.map +1 -1
  775. package/build-types/divider/test/index.d.ts +2 -0
  776. package/build-types/divider/test/index.d.ts.map +1 -0
  777. package/build-types/divider/types.d.ts +18 -10
  778. package/build-types/divider/types.d.ts.map +1 -1
  779. package/build-types/dropdown/dropdown-content-wrapper.d.ts +23 -0
  780. package/build-types/dropdown/dropdown-content-wrapper.d.ts.map +1 -0
  781. package/build-types/dropdown/index.d.ts.map +1 -1
  782. package/build-types/dropdown/styles.d.ts +7 -0
  783. package/build-types/dropdown/styles.d.ts.map +1 -0
  784. package/build-types/dropdown/types.d.ts +9 -0
  785. package/build-types/dropdown/types.d.ts.map +1 -0
  786. package/build-types/elevation/component.d.ts +11 -10
  787. package/build-types/elevation/component.d.ts.map +1 -1
  788. package/build-types/elevation/hook.d.ts +6 -7
  789. package/build-types/elevation/hook.d.ts.map +1 -1
  790. package/build-types/elevation/index.d.ts +2 -2
  791. package/build-types/elevation/index.d.ts.map +1 -1
  792. package/build-types/elevation/stories/index.d.ts +22 -0
  793. package/build-types/elevation/stories/index.d.ts.map +1 -0
  794. package/build-types/elevation/styles.d.ts +1 -1
  795. package/build-types/elevation/styles.d.ts.map +1 -1
  796. package/build-types/elevation/test/index.d.ts +2 -0
  797. package/build-types/elevation/test/index.d.ts.map +1 -0
  798. package/build-types/elevation/types.d.ts +12 -19
  799. package/build-types/elevation/types.d.ts.map +1 -1
  800. package/build-types/external-link/index.d.ts.map +1 -1
  801. package/build-types/flex/flex/component.d.ts +16 -21
  802. package/build-types/flex/flex/component.d.ts.map +1 -1
  803. package/build-types/flex/flex/hook.d.ts +5 -2
  804. package/build-types/flex/flex/hook.d.ts.map +1 -1
  805. package/build-types/flex/flex/index.d.ts +2 -2
  806. package/build-types/flex/flex/index.d.ts.map +1 -1
  807. package/build-types/flex/flex-block/component.d.ts +14 -7
  808. package/build-types/flex/flex-block/component.d.ts.map +1 -1
  809. package/build-types/flex/flex-block/hook.d.ts +6 -3
  810. package/build-types/flex/flex-block/hook.d.ts.map +1 -1
  811. package/build-types/flex/flex-block/index.d.ts +2 -2
  812. package/build-types/flex/flex-block/index.d.ts.map +1 -1
  813. package/build-types/flex/flex-item/component.d.ts +14 -7
  814. package/build-types/flex/flex-item/component.d.ts.map +1 -1
  815. package/build-types/flex/flex-item/hook.d.ts +6 -3
  816. package/build-types/flex/flex-item/hook.d.ts.map +1 -1
  817. package/build-types/flex/flex-item/index.d.ts +2 -2
  818. package/build-types/flex/flex-item/index.d.ts.map +1 -1
  819. package/build-types/flex/index.d.ts +3 -3
  820. package/build-types/flex/index.d.ts.map +1 -1
  821. package/build-types/flex/stories/index.d.ts +13 -0
  822. package/build-types/flex/stories/index.d.ts.map +1 -0
  823. package/build-types/flex/styles.d.ts +5 -5
  824. package/build-types/flex/styles.d.ts.map +1 -1
  825. package/build-types/flex/test/index.d.ts +2 -0
  826. package/build-types/flex/test/index.d.ts.map +1 -0
  827. package/build-types/flex/types.d.ts +17 -10
  828. package/build-types/flex/types.d.ts.map +1 -1
  829. package/build-types/form-token-field/index.d.ts.map +1 -1
  830. package/build-types/form-token-field/stories/index.d.ts +7 -0
  831. package/build-types/form-token-field/stories/index.d.ts.map +1 -1
  832. package/build-types/form-token-field/suggestions-list.d.ts +1 -1
  833. package/build-types/form-token-field/suggestions-list.d.ts.map +1 -1
  834. package/build-types/form-token-field/test/index.d.ts +2 -0
  835. package/build-types/form-token-field/test/index.d.ts.map +1 -0
  836. package/build-types/form-token-field/types.d.ts +22 -3
  837. package/build-types/form-token-field/types.d.ts.map +1 -1
  838. package/build-types/input-control/index.d.ts +1 -1
  839. package/build-types/input-control/index.d.ts.map +1 -1
  840. package/build-types/input-control/input-base.d.ts +1 -1
  841. package/build-types/input-control/input-base.d.ts.map +1 -1
  842. package/build-types/input-control/input-prefix-wrapper.d.ts +19 -0
  843. package/build-types/input-control/input-prefix-wrapper.d.ts.map +1 -0
  844. package/build-types/input-control/input-suffix-wrapper.d.ts +19 -0
  845. package/build-types/input-control/input-suffix-wrapper.d.ts.map +1 -0
  846. package/build-types/input-control/reducer/actions.d.ts +3 -1
  847. package/build-types/input-control/reducer/actions.d.ts.map +1 -1
  848. package/build-types/input-control/reducer/reducer.d.ts +2 -2
  849. package/build-types/input-control/reducer/reducer.d.ts.map +1 -1
  850. package/build-types/input-control/reducer/state.d.ts +2 -2
  851. package/build-types/input-control/reducer/state.d.ts.map +1 -1
  852. package/build-types/input-control/stories/index.d.ts +10 -0
  853. package/build-types/input-control/stories/index.d.ts.map +1 -1
  854. package/build-types/input-control/styles/input-control-styles.d.ts +21 -0
  855. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  856. package/build-types/input-control/types.d.ts +45 -3
  857. package/build-types/input-control/types.d.ts.map +1 -1
  858. package/build-types/navigable-container/menu.d.ts.map +1 -1
  859. package/build-types/navigator/navigator-back-button/hook.d.ts +0 -3
  860. package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
  861. package/build-types/navigator/navigator-button/hook.d.ts +0 -3
  862. package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
  863. package/build-types/placeholder/index.d.ts +16 -0
  864. package/build-types/placeholder/index.d.ts.map +1 -0
  865. package/build-types/placeholder/stories/index.d.ts +12 -0
  866. package/build-types/placeholder/stories/index.d.ts.map +1 -0
  867. package/build-types/placeholder/test/index.d.ts +2 -0
  868. package/build-types/placeholder/test/index.d.ts.map +1 -0
  869. package/build-types/placeholder/types.d.ts +47 -0
  870. package/build-types/placeholder/types.d.ts.map +1 -0
  871. package/build-types/popover/index.d.ts +2 -2
  872. package/build-types/popover/index.d.ts.map +1 -1
  873. package/build-types/popover/utils.d.ts +27 -0
  874. package/build-types/popover/utils.d.ts.map +1 -0
  875. package/build-types/radio-control/index.d.ts.map +1 -1
  876. package/build-types/range-control/index.d.ts +2 -2
  877. package/build-types/range-control/index.d.ts.map +1 -1
  878. package/build-types/range-control/styles/range-control-styles.d.ts +5 -2
  879. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  880. package/build-types/range-control/types.d.ts +6 -4
  881. package/build-types/range-control/types.d.ts.map +1 -1
  882. package/build-types/range-control/utils.d.ts.map +1 -1
  883. package/build-types/scroll-lock/index.d.ts +32 -3
  884. package/build-types/scroll-lock/index.d.ts.map +1 -1
  885. package/build-types/scroll-lock/stories/index.d.ts +9 -0
  886. package/build-types/scroll-lock/stories/index.d.ts.map +1 -0
  887. package/build-types/scroll-lock/test/index.d.ts +2 -0
  888. package/build-types/scroll-lock/test/index.d.ts.map +1 -0
  889. package/build-types/select-control/chevron-down.d.ts +4 -0
  890. package/build-types/select-control/chevron-down.d.ts.map +1 -0
  891. package/build-types/select-control/index.d.ts.map +1 -1
  892. package/build-types/select-control/styles/select-control-styles.d.ts +9 -1
  893. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  894. package/build-types/select-control/types.d.ts +1 -1
  895. package/build-types/select-control/types.d.ts.map +1 -1
  896. package/build-types/shortcut/index.d.ts +5 -24
  897. package/build-types/shortcut/index.d.ts.map +1 -1
  898. package/build-types/shortcut/test/index.d.ts +2 -0
  899. package/build-types/shortcut/test/index.d.ts.map +1 -0
  900. package/build-types/shortcut/types.d.ts +14 -0
  901. package/build-types/shortcut/types.d.ts.map +1 -0
  902. package/build-types/spacer/component.d.ts +3 -1
  903. package/build-types/spacer/component.d.ts.map +1 -1
  904. package/build-types/spinner/index.d.ts.map +1 -1
  905. package/build-types/style-provider/index.d.ts +7 -4
  906. package/build-types/style-provider/index.d.ts.map +1 -1
  907. package/build-types/style-provider/types.d.ts +15 -0
  908. package/build-types/style-provider/types.d.ts.map +1 -0
  909. package/build-types/text/hook.d.ts.map +1 -1
  910. package/build-types/toggle-group-control/stories/index.d.ts +25 -0
  911. package/build-types/toggle-group-control/stories/index.d.ts.map +1 -0
  912. package/build-types/toggle-group-control/test/index.d.ts +2 -0
  913. package/build-types/toggle-group-control/test/index.d.ts.map +1 -0
  914. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +6 -3
  915. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  916. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +6 -1
  917. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  918. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -7
  919. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
  920. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  921. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +4 -1
  922. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  923. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +11 -9
  924. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -1
  925. package/build-types/toggle-group-control/types.d.ts +27 -8
  926. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  927. package/build-types/tools-panel/styles.d.ts +1 -1
  928. package/build-types/tools-panel/styles.d.ts.map +1 -1
  929. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  930. package/build-types/tooltip/index.d.ts.map +1 -1
  931. package/build-types/tree-select/index.d.ts.map +1 -1
  932. package/build-types/tree-select/types.d.ts +1 -0
  933. package/build-types/tree-select/types.d.ts.map +1 -1
  934. package/build-types/ui/context/context-connect.d.ts +3 -0
  935. package/build-types/ui/context/context-connect.d.ts.map +1 -1
  936. package/build-types/ui/context/use-context-system.d.ts.map +1 -1
  937. package/build-types/ui/form-group/use-form-group.d.ts +2 -2
  938. package/build-types/ui/tooltip/styles.d.ts.map +1 -1
  939. package/build-types/ui/utils/space.d.ts +7 -1
  940. package/build-types/ui/utils/space.d.ts.map +1 -1
  941. package/build-types/unit-control/index.d.ts +4 -3
  942. package/build-types/unit-control/index.d.ts.map +1 -1
  943. package/build-types/unit-control/stories/index.d.ts.map +1 -1
  944. package/build-types/unit-control/styles/unit-control-styles.d.ts +0 -1
  945. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
  946. package/build-types/unit-control/types.d.ts +7 -9
  947. package/build-types/unit-control/types.d.ts.map +1 -1
  948. package/build-types/utils/base-label.d.ts +2 -0
  949. package/build-types/utils/base-label.d.ts.map +1 -0
  950. package/build-types/utils/box-sizing.d.ts +2 -0
  951. package/build-types/utils/box-sizing.d.ts.map +1 -0
  952. package/build-types/utils/colors-values.d.ts +18 -97
  953. package/build-types/utils/colors-values.d.ts.map +1 -1
  954. package/build-types/utils/rtl.d.ts.map +1 -1
  955. package/build-types/utils/strings.d.ts +2 -0
  956. package/build-types/utils/strings.d.ts.map +1 -0
  957. package/build-types/utils/style-mixins.d.ts +2 -0
  958. package/package.json +22 -21
  959. package/src/alignment-matrix-control/index.js +1 -1
  960. package/src/alignment-matrix-control/stories/index.js +49 -24
  961. package/src/alignment-matrix-control/styles/alignment-matrix-control-styles.js +1 -3
  962. package/src/angle-picker-control/index.js +7 -2
  963. package/src/angle-picker-control/stories/index.js +8 -5
  964. package/src/angle-picker-control/styles/angle-picker-control-styles.js +12 -3
  965. package/src/autocomplete/index.js +9 -18
  966. package/src/base-control/index.tsx +5 -3
  967. package/src/base-control/stories/index.tsx +1 -0
  968. package/src/base-control/styles/base-control-styles.ts +11 -2
  969. package/src/base-control/types.ts +0 -1
  970. package/src/base-field/styles.js +1 -1
  971. package/src/base-field/test/__snapshots__/index.js.snap +2 -2
  972. package/src/border-control/border-control/component.tsx +41 -32
  973. package/src/border-control/border-control/hook.ts +4 -9
  974. package/src/border-control/border-control-dropdown/component.tsx +50 -45
  975. package/src/border-control/border-control-dropdown/hook.ts +0 -5
  976. package/src/border-control/stories/index.tsx +3 -0
  977. package/src/border-control/styles.ts +25 -70
  978. package/src/border-control/test/index.js +19 -8
  979. package/src/box-control/all-input-control.js +3 -27
  980. package/src/box-control/axial-input-controls.js +1 -1
  981. package/src/box-control/index.js +5 -6
  982. package/src/box-control/styles/box-control-styles.js +1 -2
  983. package/src/box-control/styles/box-control-visualizer-styles.js +0 -1
  984. package/src/box-control/test/index.js +8 -8
  985. package/src/box-control/utils.js +38 -13
  986. package/src/button/test/index.js +188 -146
  987. package/src/card/card/{component.js → component.tsx} +13 -9
  988. package/src/card/card/{hook.js → hook.ts} +11 -11
  989. package/src/card/card/{index.js → index.ts} +0 -0
  990. package/src/card/card-body/{component.js → component.tsx} +13 -9
  991. package/src/card/card-body/{hook.js → hook.ts} +5 -5
  992. package/src/card/card-body/{index.js → index.ts} +0 -0
  993. package/src/card/card-divider/{component.js → component.tsx} +16 -10
  994. package/src/card/card-divider/{hook.js → hook.ts} +5 -5
  995. package/src/card/card-divider/{index.js → index.ts} +0 -0
  996. package/src/card/card-footer/{component.js → component.tsx} +13 -9
  997. package/src/card/card-footer/{hook.js → hook.ts} +5 -5
  998. package/src/card/card-footer/{index.js → index.ts} +0 -0
  999. package/src/card/card-header/{component.js → component.tsx} +13 -9
  1000. package/src/card/card-header/{hook.js → hook.ts} +5 -5
  1001. package/src/card/card-header/{index.js → index.ts} +0 -0
  1002. package/src/card/card-media/{component.js → component.tsx} +13 -8
  1003. package/src/card/card-media/{hook.js → hook.ts} +5 -5
  1004. package/src/card/card-media/{index.js → index.ts} +0 -0
  1005. package/src/card/{context.js → context.ts} +0 -0
  1006. package/src/card/{index.js → index.ts} +0 -0
  1007. package/src/card/stories/index.tsx +75 -0
  1008. package/src/card/{styles.js → styles.ts} +0 -0
  1009. package/src/card/test/__snapshots__/{index.js.snap → index.tsx.snap} +8 -8
  1010. package/src/card/test/{index.js → index.tsx} +3 -3
  1011. package/src/card/types.ts +8 -1
  1012. package/src/color-list-picker/index.js +15 -3
  1013. package/src/color-list-picker/style.scss +11 -0
  1014. package/src/color-palette/index.js +51 -24
  1015. package/src/color-palette/index.native.js +10 -6
  1016. package/src/color-palette/stories/index.js +1 -1
  1017. package/src/color-palette/style.scss +5 -0
  1018. package/src/color-palette/test/__snapshots__/index.js.snap +17 -3
  1019. package/src/color-palette/test/utils.ts +19 -1
  1020. package/src/color-picker/hex-input.tsx +2 -1
  1021. package/src/color-picker/input-with-slider.tsx +2 -1
  1022. package/src/color-picker/styles.ts +3 -11
  1023. package/src/combobox-control/README.md +7 -0
  1024. package/src/combobox-control/index.js +25 -15
  1025. package/src/combobox-control/stories/index.js +57 -7
  1026. package/src/combobox-control/style.scss +0 -1
  1027. package/src/confirm-dialog/README.md +1 -1
  1028. package/src/confirm-dialog/test/index.js +85 -62
  1029. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  1030. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +54 -50
  1031. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -3
  1032. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/test/utils.js +0 -0
  1033. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  1034. package/src/custom-gradient-picker/index.js +18 -3
  1035. package/src/custom-gradient-picker/stories/index.js +4 -3
  1036. package/src/custom-gradient-picker/style.scss +30 -39
  1037. package/src/custom-select-control/README.md +10 -0
  1038. package/src/custom-select-control/index.js +54 -29
  1039. package/src/custom-select-control/stories/index.js +7 -2
  1040. package/src/custom-select-control/style.scss +2 -43
  1041. package/src/custom-select-control/styles.ts +28 -0
  1042. package/src/custom-select-control/test/index.js +4 -1
  1043. package/src/date-time/constants.ts +1 -0
  1044. package/src/date-time/date/index.tsx +289 -184
  1045. package/src/date-time/date/styles.ts +86 -27
  1046. package/src/date-time/date/test/index.tsx +18 -28
  1047. package/src/date-time/date-time/index.tsx +3 -2
  1048. package/src/date-time/time/index.tsx +30 -24
  1049. package/src/date-time/time/styles.ts +3 -6
  1050. package/src/date-time/utils.ts +17 -0
  1051. package/src/dimension-control/index.js +1 -5
  1052. package/src/disabled/index.tsx +80 -0
  1053. package/src/disabled/stories/index.tsx +87 -0
  1054. package/src/disabled/styles/{disabled-styles.js → disabled-styles.tsx} +0 -0
  1055. package/src/disabled/test/index.tsx +174 -0
  1056. package/src/disabled/types.ts +13 -0
  1057. package/src/divider/README.md +12 -5
  1058. package/src/divider/component.tsx +2 -3
  1059. package/src/divider/index.ts +1 -1
  1060. package/src/divider/stories/index.tsx +4 -4
  1061. package/src/divider/styles.ts +7 -7
  1062. package/src/divider/test/__snapshots__/{index.js.snap → index.tsx.snap} +7 -7
  1063. package/src/divider/test/index.tsx +40 -0
  1064. package/src/divider/types.ts +21 -15
  1065. package/src/draggable/README.md +1 -1
  1066. package/src/drop-zone/index.js +2 -3
  1067. package/src/dropdown/dropdown-content-wrapper.tsx +59 -0
  1068. package/src/dropdown/index.js +3 -5
  1069. package/src/dropdown/stories/index.js +60 -69
  1070. package/src/dropdown/styles.ts +38 -0
  1071. package/src/dropdown/types.ts +8 -0
  1072. package/src/dropdown-menu/stories/index.js +13 -2
  1073. package/src/duotone-picker/custom-duotone-bar.js +1 -1
  1074. package/src/duotone-picker/duotone-picker.js +34 -26
  1075. package/src/duotone-picker/duotone-swatch.js +12 -5
  1076. package/src/duotone-picker/stories/duotone-picker.js +66 -0
  1077. package/src/duotone-picker/stories/duotone-swatch.js +32 -0
  1078. package/src/elevation/README.md +16 -14
  1079. package/src/elevation/component.tsx +48 -0
  1080. package/src/elevation/{hook.js → hook.ts} +20 -17
  1081. package/src/elevation/{index.js → index.ts} +0 -0
  1082. package/src/elevation/stories/index.tsx +85 -0
  1083. package/src/elevation/{styles.js → styles.ts} +0 -0
  1084. package/src/elevation/test/__snapshots__/{index.js.snap → index.tsx.snap} +19 -13
  1085. package/src/elevation/test/index.tsx +64 -0
  1086. package/src/elevation/types.ts +12 -19
  1087. package/src/external-link/index.tsx +10 -0
  1088. package/src/flex/flex/README.md +20 -18
  1089. package/src/flex/flex/component.tsx +59 -0
  1090. package/src/flex/flex/{hook.js → hook.ts} +14 -13
  1091. package/src/flex/flex/{index.js → index.ts} +0 -0
  1092. package/src/flex/flex-block/README.md +3 -7
  1093. package/src/flex/flex-block/component.tsx +41 -0
  1094. package/src/flex/flex-block/{hook.js → hook.ts} +5 -5
  1095. package/src/flex/flex-block/{index.js → index.ts} +0 -0
  1096. package/src/flex/flex-item/README.md +6 -9
  1097. package/src/flex/flex-item/component.tsx +41 -0
  1098. package/src/flex/flex-item/{hook.js → hook.ts} +10 -7
  1099. package/src/flex/flex-item/{index.js → index.ts} +0 -0
  1100. package/src/flex/{index.js → index.ts} +0 -0
  1101. package/src/flex/stories/index.tsx +81 -0
  1102. package/src/flex/{styles.js → styles.ts} +0 -0
  1103. package/src/flex/test/__snapshots__/{index.js.snap → index.tsx.snap} +49 -9
  1104. package/src/flex/test/index.tsx +84 -0
  1105. package/src/flex/types.ts +17 -10
  1106. package/src/focal-point-picker/index.js +10 -5
  1107. package/src/focal-point-picker/styles/focal-point-picker-style.js +0 -5
  1108. package/src/focal-point-picker/styles/focal-point-style.js +0 -2
  1109. package/src/focal-point-picker/test/index.js +78 -45
  1110. package/src/font-size-picker/index.js +160 -132
  1111. package/src/font-size-picker/stories/index.js +7 -0
  1112. package/src/font-size-picker/style.scss +8 -5
  1113. package/src/font-size-picker/test/index.js +13 -6
  1114. package/src/font-size-picker/test/{util.js → utils.js} +77 -1
  1115. package/src/font-size-picker/utils.js +38 -23
  1116. package/src/form-token-field/README.md +3 -1
  1117. package/src/form-token-field/index.tsx +46 -35
  1118. package/src/form-token-field/stories/index.tsx +22 -0
  1119. package/src/form-token-field/style.scss +0 -5
  1120. package/src/form-token-field/suggestions-list.tsx +21 -12
  1121. package/src/form-token-field/test/index.tsx +2106 -0
  1122. package/src/form-token-field/types.ts +23 -2
  1123. package/src/gradient-picker/index.js +22 -7
  1124. package/src/gradient-picker/stories/index.js +56 -81
  1125. package/src/guide/index.js +3 -1
  1126. package/src/guide/page-control.js +1 -6
  1127. package/src/guide/stories/index.js +12 -11
  1128. package/src/guide/test/index.js +54 -37
  1129. package/src/guide/test/page-control.js +14 -17
  1130. package/src/higher-order/with-notices/test/index.js +4 -2
  1131. package/src/higher-order/with-spoken-messages/test/index.js +1 -1
  1132. package/src/index.js +7 -1
  1133. package/src/input-control/index.tsx +6 -0
  1134. package/src/input-control/input-base.tsx +28 -13
  1135. package/src/input-control/input-prefix-wrapper.tsx +48 -0
  1136. package/src/input-control/input-suffix-wrapper.tsx +48 -0
  1137. package/src/input-control/reducer/actions.ts +3 -1
  1138. package/src/input-control/reducer/reducer.ts +27 -10
  1139. package/src/input-control/reducer/state.ts +7 -2
  1140. package/src/input-control/stories/index.tsx +15 -2
  1141. package/src/input-control/styles/input-control-styles.tsx +28 -12
  1142. package/src/input-control/test/index.js +20 -4
  1143. package/src/input-control/types.ts +52 -3
  1144. package/src/item-group/styles.ts +3 -3
  1145. package/src/menu-group/test/index.js +18 -7
  1146. package/src/mobile/bottom-sheet/index.native.js +2 -4
  1147. package/src/mobile/global-styles-context/utils.native.js +22 -4
  1148. package/src/mobile/image/index.native.js +17 -8
  1149. package/src/mobile/link-picker/link-picker-screen.native.js +12 -4
  1150. package/src/mobile/media-edit/index.native.js +2 -7
  1151. package/src/mobile/picker/index.android.js +10 -4
  1152. package/src/mobile/picker/index.ios.js +16 -0
  1153. package/src/mobile/picker/styles.native.scss +12 -4
  1154. package/src/modal/index.js +1 -2
  1155. package/src/modal/style.scss +5 -1
  1156. package/src/modal/test/index.js +11 -9
  1157. package/src/navigable-container/container.js +12 -18
  1158. package/src/navigable-container/menu.js +3 -7
  1159. package/src/navigable-container/test/menu.js +14 -11
  1160. package/src/navigator/navigator-back-button/hook.ts +0 -3
  1161. package/src/navigator/navigator-button/hook.ts +0 -3
  1162. package/src/notice/list.js +12 -10
  1163. package/src/palette-edit/index.js +1 -0
  1164. package/src/palette-edit/styles.js +6 -5
  1165. package/src/panel/style.scss +4 -1
  1166. package/src/placeholder/README.md +49 -9
  1167. package/src/placeholder/{index.js → index.tsx} +27 -23
  1168. package/src/placeholder/stories/index.tsx +64 -0
  1169. package/src/placeholder/style.scss +65 -24
  1170. package/src/placeholder/test/index.tsx +174 -0
  1171. package/src/placeholder/types.ts +48 -0
  1172. package/src/popover/README.md +7 -0
  1173. package/src/popover/index.js +256 -157
  1174. package/src/popover/stories/index.js +213 -96
  1175. package/src/popover/style.scss +61 -7
  1176. package/src/popover/test/__snapshots__/index.js.snap +6 -6
  1177. package/src/popover/test/index.js +138 -23
  1178. package/src/popover/utils.js +107 -0
  1179. package/src/radio-control/index.tsx +1 -2
  1180. package/src/range-control/README.md +1 -1
  1181. package/src/range-control/index.tsx +3 -0
  1182. package/src/range-control/styles/range-control-styles.ts +9 -16
  1183. package/src/range-control/test/index.tsx +30 -0
  1184. package/src/range-control/types.ts +9 -4
  1185. package/src/range-control/utils.ts +4 -1
  1186. package/src/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +1 -1
  1187. package/src/sandbox/index.native.js +14 -1
  1188. package/src/scroll-lock/README.md +1 -1
  1189. package/src/scroll-lock/{index.js → index.tsx} +34 -7
  1190. package/src/scroll-lock/stories/index.tsx +96 -0
  1191. package/src/scroll-lock/test/index.tsx +26 -0
  1192. package/src/select-control/chevron-down.tsx +25 -0
  1193. package/src/select-control/index.tsx +7 -11
  1194. package/src/select-control/styles/select-control-styles.ts +54 -22
  1195. package/src/select-control/types.ts +1 -0
  1196. package/src/shortcut/{index.js → index.tsx} +5 -9
  1197. package/src/shortcut/test/__snapshots__/index.tsx.snap +15 -0
  1198. package/src/shortcut/test/index.tsx +41 -0
  1199. package/src/shortcut/types.ts +10 -0
  1200. package/src/slot-fill/test/slot.js +5 -5
  1201. package/src/snackbar/list.js +3 -2
  1202. package/src/spacer/component.tsx +3 -1
  1203. package/src/spinner/index.tsx +2 -0
  1204. package/src/style-provider/index.tsx +41 -0
  1205. package/src/style-provider/types.ts +15 -0
  1206. package/src/style.scss +0 -2
  1207. package/src/text/hook.js +5 -3
  1208. package/src/text/styles.js +1 -1
  1209. package/src/text/test/index.tsx +1 -1
  1210. package/src/toggle-group-control/stories/index.tsx +127 -0
  1211. package/src/toggle-group-control/test/__snapshots__/{index.js.snap → index.tsx.snap} +56 -26
  1212. package/src/toggle-group-control/test/{index.js → index.tsx} +2 -4
  1213. package/src/toggle-group-control/toggle-group-control/README.md +2 -0
  1214. package/src/toggle-group-control/toggle-group-control/component.tsx +20 -11
  1215. package/src/toggle-group-control/toggle-group-control/styles.ts +30 -7
  1216. package/src/toggle-group-control/toggle-group-control-option/component.tsx +19 -3
  1217. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +3 -0
  1218. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +17 -3
  1219. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +6 -8
  1220. package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +30 -7
  1221. package/src/toggle-group-control/types.ts +74 -53
  1222. package/src/toolbar/test/index.js +4 -4
  1223. package/src/toolbar-group/test/index.js +9 -15
  1224. package/src/tools-panel/styles.ts +9 -18
  1225. package/src/tools-panel/test/index.js +3 -2
  1226. package/src/tools-panel/tools-panel/README.md +94 -21
  1227. package/src/tools-panel/tools-panel/hook.ts +6 -1
  1228. package/src/tooltip/index.js +57 -15
  1229. package/src/tooltip/stories/index.js +28 -13
  1230. package/src/tooltip/style.scss +1 -1
  1231. package/src/tooltip/test/index.js +188 -172
  1232. package/src/tree-grid/index.js +4 -9
  1233. package/src/tree-select/index.tsx +5 -4
  1234. package/src/tree-select/types.ts +4 -0
  1235. package/src/ui/context/context-connect.ts +3 -2
  1236. package/src/ui/context/test/context-system-provider.js +101 -1
  1237. package/src/ui/context/use-context-system.js +7 -2
  1238. package/src/ui/tooltip/styles.js +1 -0
  1239. package/src/ui/tooltip/test/__snapshots__/index.js.snap +1 -0
  1240. package/src/ui/utils/space.ts +7 -1
  1241. package/src/unit-control/index.tsx +2 -2
  1242. package/src/unit-control/stories/index.tsx +16 -23
  1243. package/src/unit-control/styles/unit-control-styles.ts +100 -46
  1244. package/src/unit-control/test/__snapshots__/index.tsx.snap +4 -4
  1245. package/src/unit-control/types.ts +12 -9
  1246. package/src/utils/base-label.ts +13 -0
  1247. package/src/utils/box-sizing.ts +14 -0
  1248. package/src/utils/colors-values.js +42 -137
  1249. package/src/utils/config-values.js +1 -1
  1250. package/src/utils/input/input-control.js +6 -6
  1251. package/src/utils/rtl.js +6 -2
  1252. package/src/utils/strings.ts +72 -0
  1253. package/src/utils/style-mixins.js +2 -0
  1254. package/src/utils/test/strings.js +15 -0
  1255. package/tsconfig.json +1 -0
  1256. package/tsconfig.tsbuildinfo +1 -1
  1257. package/build/custom-gradient-bar/constants.js.map +0 -1
  1258. package/build/custom-gradient-bar/control-points.js.map +0 -1
  1259. package/build/custom-gradient-bar/index.js.map +0 -1
  1260. package/build/custom-gradient-bar/utils.js.map +0 -1
  1261. package/build/date-time/date/utils.js +0 -34
  1262. package/build/date-time/date/utils.js.map +0 -1
  1263. package/build/swatch/index.js +0 -39
  1264. package/build/swatch/index.js.map +0 -1
  1265. package/build-module/custom-gradient-bar/constants.js.map +0 -1
  1266. package/build-module/custom-gradient-bar/control-points.js.map +0 -1
  1267. package/build-module/custom-gradient-bar/index.js.map +0 -1
  1268. package/build-module/custom-gradient-bar/utils.js.map +0 -1
  1269. package/build-module/date-time/date/utils.js +0 -22
  1270. package/build-module/date-time/date/utils.js.map +0 -1
  1271. package/build-module/swatch/index.js +0 -28
  1272. package/build-module/swatch/index.js.map +0 -1
  1273. package/build-types/date-time/date/test/utils.d.ts +0 -2
  1274. package/build-types/date-time/date/test/utils.d.ts.map +0 -1
  1275. package/build-types/date-time/date/utils.d.ts +0 -15
  1276. package/build-types/date-time/date/utils.d.ts.map +0 -1
  1277. package/build-types/form-token-field/test/lib/fixtures.d.ts +0 -26
  1278. package/build-types/form-token-field/test/lib/fixtures.d.ts.map +0 -1
  1279. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts +0 -21
  1280. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts.map +0 -1
  1281. package/src/card/stories/index.js +0 -209
  1282. package/src/date-time/date/datepicker.scss +0 -863
  1283. package/src/date-time/date/style.scss +0 -85
  1284. package/src/date-time/date/test/utils.ts +0 -32
  1285. package/src/date-time/date/utils.ts +0 -20
  1286. package/src/date-time/style.scss +0 -1
  1287. package/src/disabled/index.js +0 -55
  1288. package/src/disabled/stories/index.js +0 -61
  1289. package/src/disabled/test/index.js +0 -240
  1290. package/src/divider/test/index.js +0 -41
  1291. package/src/elevation/component.js +0 -43
  1292. package/src/elevation/stories/index.js +0 -148
  1293. package/src/elevation/test/index.js +0 -51
  1294. package/src/flex/flex/component.js +0 -60
  1295. package/src/flex/flex-block/component.js +0 -30
  1296. package/src/flex/flex-item/component.js +0 -30
  1297. package/src/flex/stories/index.js +0 -29
  1298. package/src/flex/test/index.js +0 -77
  1299. package/src/form-token-field/test/index.js +0 -411
  1300. package/src/form-token-field/test/lib/fixtures.js +0 -89
  1301. package/src/form-token-field/test/lib/token-field-wrapper.tsx +0 -71
  1302. package/src/menu-group/test/__snapshots__/index.js.snap +0 -23
  1303. package/src/placeholder/stories/index.js +0 -44
  1304. package/src/placeholder/test/index.js +0 -163
  1305. package/src/popover/stories/_utils.js +0 -64
  1306. package/src/scroll-lock/stories/index.js +0 -71
  1307. package/src/scroll-lock/test/index.js +0 -53
  1308. package/src/shortcut/test/index.js +0 -37
  1309. package/src/style-provider/index.js +0 -31
  1310. package/src/swatch/index.js +0 -19
  1311. package/src/swatch/style.scss +0 -21
  1312. package/src/toggle-group-control/stories/index.js +0 -187
  1313. package/src/tools-panel/test/__snapshots__/index.js.snap +0 -219
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.CUSTOM_FONT_SIZE = void 0;
7
7
  exports.getFontSizeOptions = getFontSizeOptions;
8
8
  exports.getSelectedOption = getSelectedOption;
9
+ exports.getToggleGroupOptions = getToggleGroupOptions;
9
10
  exports.isSimpleCssValue = isSimpleCssValue;
10
11
  exports.splitValueAndUnitFromSize = splitValueAndUnitFromSize;
11
12
 
@@ -26,14 +27,22 @@ const CUSTOM_FONT_SIZE_OPTION = {
26
27
  name: (0, _i18n.__)('Custom')
27
28
  };
28
29
  /**
29
- * In case we have at most five font sizes, where at least one the them
30
- * contain a complex css value(clamp, var, etc..) show a incremental sequence
31
- * of numbers as a label of the font size. We do this because complex css values
32
- * cannot be caluclated properly and the incremental sequence of numbers as labels
33
- * can help the user better mentally map the different available font sizes.
30
+ * In case we have at most five font sizes, show a `T-shirt size`
31
+ * alias as a label of the font size. The label assumes that the font sizes
32
+ * are ordered accordingly - from smallest to largest.
34
33
  */
35
34
 
36
- const FONT_SIZES_ALIASES = ['1', '2', '3', '4', '5'];
35
+ const FONT_SIZES_ALIASES = [
36
+ /* translators: S stands for 'small' and is a size label. */
37
+ (0, _i18n.__)('S'),
38
+ /* translators: M stands for 'medium' and is a size label. */
39
+ (0, _i18n.__)('M'),
40
+ /* translators: L stands for 'large' and is a size label. */
41
+ (0, _i18n.__)('L'),
42
+ /* translators: XL stands for 'extra large' and is a size label. */
43
+ (0, _i18n.__)('XL'),
44
+ /* translators: XXL stands for 'extra extra large' and is a size label. */
45
+ (0, _i18n.__)('XXL')];
37
46
  /**
38
47
  * Helper util to split a font size to its numeric value
39
48
  * and its `unit`, if exists.
@@ -68,20 +77,19 @@ function isSimpleCssValue(value) {
68
77
  * Return font size options in the proper format depending
69
78
  * on the currently used control (select, toggle group).
70
79
  *
71
- * @param {boolean} useSelectControl Whether to use a select control.
72
- * @param {Object[]} optionsArray Array of available font sizes objects.
73
- * @param {*} disableCustomFontSizes Flag that indicates if custom font sizes are disabled.
74
- * @param {boolean} optionsContainComplexCssValues Whether font sizes contain at least one complex css value(clamp, var, etc..).
75
- * @return {Object[]|null} Array of font sizes in proper format for the used control.
80
+ * @param {boolean} useSelectControl Whether to use a select control.
81
+ * @param {Object[]} optionsArray Array of available font sizes objects.
82
+ * @param {boolean} disableCustomFontSizes Flag that indicates if custom font sizes are disabled.
83
+ * @return {Object[]|null} Array of font sizes in proper format for the used control.
76
84
  */
77
85
 
78
86
 
79
- function getFontSizeOptions(useSelectControl, optionsArray, disableCustomFontSizes, optionsContainComplexCssValues) {
87
+ function getFontSizeOptions(useSelectControl, optionsArray, disableCustomFontSizes) {
80
88
  if (disableCustomFontSizes && !optionsArray.length) {
81
89
  return null;
82
90
  }
83
91
 
84
- return useSelectControl ? getSelectOptions(optionsArray, disableCustomFontSizes) : getToggleGroupOptions(optionsArray, optionsContainComplexCssValues);
92
+ return useSelectControl ? getSelectOptions(optionsArray, disableCustomFontSizes) : getToggleGroupOptions(optionsArray);
85
93
  }
86
94
 
87
95
  function getSelectOptions(optionsArray, disableCustomFontSizes) {
@@ -100,25 +108,27 @@ function getSelectOptions(optionsArray, disableCustomFontSizes) {
100
108
  };
101
109
  });
102
110
  }
111
+ /**
112
+ * Build options for the toggle group options.
113
+ *
114
+ * @param {Array} optionsArray An array of font size options.
115
+ * @param {string[]} labelAliases An array of alternative labels.
116
+ * @return {Array} Remapped optionsArray.
117
+ */
103
118
 
104
- function getToggleGroupOptions(optionsArray, optionsContainComplexCssValues) {
119
+
120
+ function getToggleGroupOptions(optionsArray) {
121
+ let labelAliases = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : FONT_SIZES_ALIASES;
105
122
  return optionsArray.map((_ref2, index) => {
106
123
  let {
107
124
  slug,
108
125
  size,
109
126
  name
110
127
  } = _ref2;
111
- let label = optionsContainComplexCssValues ? FONT_SIZES_ALIASES[index] : size;
112
-
113
- if (!optionsContainComplexCssValues && typeof size === 'string') {
114
- const [numericValue] = splitValueAndUnitFromSize(size);
115
- label = numericValue;
116
- }
117
-
118
128
  return {
119
129
  key: slug,
120
130
  value: size,
121
- label,
131
+ label: labelAliases[index],
122
132
  name
123
133
  };
124
134
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/font-size-picker/utils.js"],"names":["DEFAULT_FONT_SIZE","DEFAULT_FONT_SIZE_OPTION","slug","name","CUSTOM_FONT_SIZE","CUSTOM_FONT_SIZE_OPTION","FONT_SIZES_ALIASES","splitValueAndUnitFromSize","size","numericValue","unit","match","isNaN","parseFloat","isFinite","isSimpleCssValue","value","sizeRegex","test","getFontSizeOptions","useSelectControl","optionsArray","disableCustomFontSizes","optionsContainComplexCssValues","length","getSelectOptions","getToggleGroupOptions","options","map","key","__experimentalHint","index","label","getSelectedOption","fontSizes","find","font"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\n\nconst DEFAULT_FONT_SIZE = 'default';\nconst DEFAULT_FONT_SIZE_OPTION = {\n\tslug: DEFAULT_FONT_SIZE,\n\tname: __( 'Default' ),\n};\nexport const CUSTOM_FONT_SIZE = 'custom';\nconst CUSTOM_FONT_SIZE_OPTION = {\n\tslug: CUSTOM_FONT_SIZE,\n\tname: __( 'Custom' ),\n};\n\n/**\n * In case we have at most five font sizes, where at least one the them\n * contain a complex css value(clamp, var, etc..) show a incremental sequence\n * of numbers as a label of the font size. We do this because complex css values\n * cannot be caluclated properly and the incremental sequence of numbers as labels\n * can help the user better mentally map the different available font sizes.\n */\nconst FONT_SIZES_ALIASES = [ '1', '2', '3', '4', '5' ];\n\n/**\n * Helper util to split a font size to its numeric value\n * and its `unit`, if exists.\n *\n * @param {string|number} size Font size.\n * @return {[number, string]} An array with the numeric value and the unit if exists.\n */\nexport function splitValueAndUnitFromSize( size ) {\n\tconst [ numericValue, unit ] = `${ size }`.match( /[\\d\\.]+|\\D+/g );\n\n\tif ( ! isNaN( parseFloat( numericValue ) ) && isFinite( numericValue ) ) {\n\t\treturn [ numericValue, unit ];\n\t}\n\n\treturn [];\n}\n\n/**\n * Some themes use css vars for their font sizes, so until we\n * have the way of calculating them don't display them.\n *\n * @param {string|number} value The value that is checked.\n * @return {boolean} Whether the value is a simple css value.\n */\nexport function isSimpleCssValue( value ) {\n\tconst sizeRegex = /^[\\d\\.]+(px|em|rem|vw|vh|%)?$/i;\n\treturn sizeRegex.test( value );\n}\n\n/**\n * Return font size options in the proper format depending\n * on the currently used control (select, toggle group).\n *\n * @param {boolean} useSelectControl Whether to use a select control.\n * @param {Object[]} optionsArray Array of available font sizes objects.\n * @param {*} disableCustomFontSizes Flag that indicates if custom font sizes are disabled.\n * @param {boolean} optionsContainComplexCssValues Whether font sizes contain at least one complex css value(clamp, var, etc..).\n * @return {Object[]|null} Array of font sizes in proper format for the used control.\n */\nexport function getFontSizeOptions(\n\tuseSelectControl,\n\toptionsArray,\n\tdisableCustomFontSizes,\n\toptionsContainComplexCssValues\n) {\n\tif ( disableCustomFontSizes && ! optionsArray.length ) {\n\t\treturn null;\n\t}\n\treturn useSelectControl\n\t\t? getSelectOptions( optionsArray, disableCustomFontSizes )\n\t\t: getToggleGroupOptions( optionsArray, optionsContainComplexCssValues );\n}\n\nfunction getSelectOptions( optionsArray, disableCustomFontSizes ) {\n\tconst options = [\n\t\tDEFAULT_FONT_SIZE_OPTION,\n\t\t...optionsArray,\n\t\t...( disableCustomFontSizes ? [] : [ CUSTOM_FONT_SIZE_OPTION ] ),\n\t];\n\treturn options.map( ( { slug, name, size } ) => ( {\n\t\tkey: slug,\n\t\tname,\n\t\tsize,\n\t\t__experimentalHint:\n\t\t\tsize && isSimpleCssValue( size ) && parseFloat( size ),\n\t} ) );\n}\n\nfunction getToggleGroupOptions( optionsArray, optionsContainComplexCssValues ) {\n\treturn optionsArray.map( ( { slug, size, name }, index ) => {\n\t\tlet label = optionsContainComplexCssValues\n\t\t\t? FONT_SIZES_ALIASES[ index ]\n\t\t\t: size;\n\t\tif ( ! optionsContainComplexCssValues && typeof size === 'string' ) {\n\t\t\tconst [ numericValue ] = splitValueAndUnitFromSize( size );\n\t\t\tlabel = numericValue;\n\t\t}\n\t\treturn { key: slug, value: size, label, name };\n\t} );\n}\n\nexport function getSelectedOption( fontSizes, value ) {\n\tif ( ! value ) {\n\t\treturn DEFAULT_FONT_SIZE_OPTION;\n\t}\n\treturn (\n\t\tfontSizes.find( ( font ) => font.size === value ) ||\n\t\tCUSTOM_FONT_SIZE_OPTION\n\t);\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/font-size-picker/utils.js"],"names":["DEFAULT_FONT_SIZE","DEFAULT_FONT_SIZE_OPTION","slug","name","CUSTOM_FONT_SIZE","CUSTOM_FONT_SIZE_OPTION","FONT_SIZES_ALIASES","splitValueAndUnitFromSize","size","numericValue","unit","match","isNaN","parseFloat","isFinite","isSimpleCssValue","value","sizeRegex","test","getFontSizeOptions","useSelectControl","optionsArray","disableCustomFontSizes","length","getSelectOptions","getToggleGroupOptions","options","map","key","__experimentalHint","labelAliases","index","label","getSelectedOption","fontSizes","find","font"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\n\nconst DEFAULT_FONT_SIZE = 'default';\nconst DEFAULT_FONT_SIZE_OPTION = {\n\tslug: DEFAULT_FONT_SIZE,\n\tname: __( 'Default' ),\n};\nexport const CUSTOM_FONT_SIZE = 'custom';\nconst CUSTOM_FONT_SIZE_OPTION = {\n\tslug: CUSTOM_FONT_SIZE,\n\tname: __( 'Custom' ),\n};\n\n/**\n * In case we have at most five font sizes, show a `T-shirt size`\n * alias as a label of the font size. The label assumes that the font sizes\n * are ordered accordingly - from smallest to largest.\n */\nconst FONT_SIZES_ALIASES = [\n\t/* translators: S stands for 'small' and is a size label. */\n\t__( 'S' ),\n\t/* translators: M stands for 'medium' and is a size label. */\n\t__( 'M' ),\n\t/* translators: L stands for 'large' and is a size label. */\n\t__( 'L' ),\n\t/* translators: XL stands for 'extra large' and is a size label. */\n\t__( 'XL' ),\n\t/* translators: XXL stands for 'extra extra large' and is a size label. */\n\t__( 'XXL' ),\n];\n\n/**\n * Helper util to split a font size to its numeric value\n * and its `unit`, if exists.\n *\n * @param {string|number} size Font size.\n * @return {[number, string]} An array with the numeric value and the unit if exists.\n */\nexport function splitValueAndUnitFromSize( size ) {\n\tconst [ numericValue, unit ] = `${ size }`.match( /[\\d\\.]+|\\D+/g );\n\n\tif ( ! isNaN( parseFloat( numericValue ) ) && isFinite( numericValue ) ) {\n\t\treturn [ numericValue, unit ];\n\t}\n\n\treturn [];\n}\n\n/**\n * Some themes use css vars for their font sizes, so until we\n * have the way of calculating them don't display them.\n *\n * @param {string|number} value The value that is checked.\n * @return {boolean} Whether the value is a simple css value.\n */\nexport function isSimpleCssValue( value ) {\n\tconst sizeRegex = /^[\\d\\.]+(px|em|rem|vw|vh|%)?$/i;\n\treturn sizeRegex.test( value );\n}\n\n/**\n * Return font size options in the proper format depending\n * on the currently used control (select, toggle group).\n *\n * @param {boolean} useSelectControl Whether to use a select control.\n * @param {Object[]} optionsArray Array of available font sizes objects.\n * @param {boolean} disableCustomFontSizes Flag that indicates if custom font sizes are disabled.\n * @return {Object[]|null} Array of font sizes in proper format for the used control.\n */\nexport function getFontSizeOptions(\n\tuseSelectControl,\n\toptionsArray,\n\tdisableCustomFontSizes\n) {\n\tif ( disableCustomFontSizes && ! optionsArray.length ) {\n\t\treturn null;\n\t}\n\treturn useSelectControl\n\t\t? getSelectOptions( optionsArray, disableCustomFontSizes )\n\t\t: getToggleGroupOptions( optionsArray );\n}\n\nfunction getSelectOptions( optionsArray, disableCustomFontSizes ) {\n\tconst options = [\n\t\tDEFAULT_FONT_SIZE_OPTION,\n\t\t...optionsArray,\n\t\t...( disableCustomFontSizes ? [] : [ CUSTOM_FONT_SIZE_OPTION ] ),\n\t];\n\treturn options.map( ( { slug, name, size } ) => ( {\n\t\tkey: slug,\n\t\tname,\n\t\tsize,\n\t\t__experimentalHint:\n\t\t\tsize && isSimpleCssValue( size ) && parseFloat( size ),\n\t} ) );\n}\n\n/**\n * Build options for the toggle group options.\n *\n * @param {Array} optionsArray An array of font size options.\n * @param {string[]} labelAliases An array of alternative labels.\n * @return {Array} Remapped optionsArray.\n */\nexport function getToggleGroupOptions(\n\toptionsArray,\n\tlabelAliases = FONT_SIZES_ALIASES\n) {\n\treturn optionsArray.map( ( { slug, size, name }, index ) => {\n\t\treturn {\n\t\t\tkey: slug,\n\t\t\tvalue: size,\n\t\t\tlabel: labelAliases[ index ],\n\t\t\tname,\n\t\t};\n\t} );\n}\n\nexport function getSelectedOption( fontSizes, value ) {\n\tif ( ! value ) {\n\t\treturn DEFAULT_FONT_SIZE_OPTION;\n\t}\n\treturn (\n\t\tfontSizes.find( ( font ) => font.size === value ) ||\n\t\tCUSTOM_FONT_SIZE_OPTION\n\t);\n}\n"]}
@@ -22,8 +22,6 @@ var _compose = require("@wordpress/compose");
22
22
 
23
23
  var _a11y = require("@wordpress/a11y");
24
24
 
25
- var _keycodes = require("@wordpress/keycodes");
26
-
27
25
  var _isShallowEqual = _interopRequireDefault(require("@wordpress/is-shallow-equal"));
28
26
 
29
27
  var _token = _interopRequireDefault(require("./token"));
@@ -36,6 +34,8 @@ var _suggestionsList = _interopRequireDefault(require("./suggestions-list"));
36
34
 
37
35
  var _flex = require("../flex");
38
36
 
37
+ var _baseControlStyles = require("../base-control/styles/base-control-styles");
38
+
39
39
  /**
40
40
  * External dependencies
41
41
  */
@@ -85,10 +85,12 @@ function FormTokenField(props) {
85
85
  remove: (0, _i18n.__)('Remove item'),
86
86
  __experimentalInvalid: (0, _i18n.__)('Invalid item')
87
87
  },
88
+ __experimentalRenderItem,
88
89
  __experimentalExpandOnFocus = false,
89
90
  __experimentalValidateInput = () => true,
90
91
  __experimentalShowHowTo = true,
91
- __next36pxDefaultSize = false
92
+ __next36pxDefaultSize = false,
93
+ __experimentalAutoSelectFirstMatch = false
92
94
  } = props;
93
95
  const instanceId = (0, _compose.useInstanceId)(FormTokenField); // We reset to these initial values again in the onBlur
94
96
 
@@ -121,6 +123,9 @@ function FormTokenField(props) {
121
123
  (0, _element.useEffect)(() => {
122
124
  updateSuggestions(); // eslint-disable-next-line react-hooks/exhaustive-deps
123
125
  }, [incompleteTokenValue]);
126
+ (0, _element.useEffect)(() => {
127
+ updateSuggestions(); // eslint-disable-next-line react-hooks/exhaustive-deps
128
+ }, [__experimentalAutoSelectFirstMatch]);
124
129
 
125
130
  if (disabled && isActive) {
126
131
  setIsActive(false);
@@ -177,46 +182,45 @@ function FormTokenField(props) {
177
182
 
178
183
  if (event.defaultPrevented) {
179
184
  return;
180
- } // TODO: replace to event.code;
181
-
185
+ }
182
186
 
183
- switch (event.keyCode) {
184
- case _keycodes.BACKSPACE:
187
+ switch (event.code) {
188
+ case 'Backspace':
185
189
  preventDefault = handleDeleteKey(deleteTokenBeforeInput);
186
190
  break;
187
191
 
188
- case _keycodes.ENTER:
192
+ case 'Enter':
189
193
  preventDefault = addCurrentToken();
190
194
  break;
191
195
 
192
- case _keycodes.LEFT:
196
+ case 'ArrowLeft':
193
197
  preventDefault = handleLeftArrowKey();
194
198
  break;
195
199
 
196
- case _keycodes.UP:
200
+ case 'ArrowUp':
197
201
  preventDefault = handleUpArrowKey();
198
202
  break;
199
203
 
200
- case _keycodes.RIGHT:
204
+ case 'ArrowRight':
201
205
  preventDefault = handleRightArrowKey();
202
206
  break;
203
207
 
204
- case _keycodes.DOWN:
208
+ case 'ArrowDown':
205
209
  preventDefault = handleDownArrowKey();
206
210
  break;
207
211
 
208
- case _keycodes.DELETE:
212
+ case 'Delete':
209
213
  preventDefault = handleDeleteKey(deleteTokenAfterInput);
210
214
  break;
211
215
 
212
- case _keycodes.SPACE:
216
+ case 'Space':
213
217
  if (tokenizeOnSpace) {
214
218
  preventDefault = addCurrentToken();
215
219
  }
216
220
 
217
221
  break;
218
222
 
219
- case _keycodes.ESCAPE:
223
+ case 'Escape':
220
224
  preventDefault = handleEscapeKey(event);
221
225
  break;
222
226
 
@@ -406,7 +410,7 @@ function FormTokenField(props) {
406
410
  }
407
411
 
408
412
  function addNewTokens(tokens) {
409
- const tokensToAdd = (0, _lodash.uniq)(tokens.map(saveTransform).filter(Boolean).filter(token => !valueContainsToken(token)));
413
+ const tokensToAdd = [...new Set(tokens.map(saveTransform).filter(Boolean).filter(token => !valueContainsToken(token)))];
410
414
 
411
415
  if (tokensToAdd.length > 0) {
412
416
  const newValue = (0, _lodash.clone)(value);
@@ -474,7 +478,7 @@ function FormTokenField(props) {
474
478
  });
475
479
 
476
480
  if (match.length === 0) {
477
- _suggestions = (0, _lodash.difference)(_suggestions, normalizedValue);
481
+ _suggestions = _suggestions.filter(suggestion => !normalizedValue.includes(suggestion));
478
482
  } else {
479
483
  match = match.toLocaleLowerCase();
480
484
 
@@ -527,11 +531,19 @@ function FormTokenField(props) {
527
531
  const inputHasMinimumChars = incompleteTokenValue.trim().length > 1;
528
532
  const matchingSuggestions = getMatchingSuggestions(incompleteTokenValue);
529
533
  const hasMatchingSuggestions = matchingSuggestions.length > 0;
530
- setIsExpanded(__experimentalExpandOnFocus || inputHasMinimumChars && hasMatchingSuggestions);
534
+
535
+ const shouldExpandIfFocuses = hasFocus() && __experimentalExpandOnFocus;
536
+
537
+ setIsExpanded(shouldExpandIfFocuses || inputHasMinimumChars && hasMatchingSuggestions);
531
538
 
532
539
  if (resetSelectedSuggestion) {
533
- setSelectedSuggestionIndex(-1);
534
- setSelectedSuggestionScroll(false);
540
+ if (__experimentalAutoSelectFirstMatch && inputHasMinimumChars && hasMatchingSuggestions) {
541
+ setSelectedSuggestionIndex(0);
542
+ setSelectedSuggestionScroll(true);
543
+ } else {
544
+ setSelectedSuggestionIndex(-1);
545
+ setSelectedSuggestionScroll(false);
546
+ }
535
547
  }
536
548
 
537
549
  if (inputHasMinimumChars) {
@@ -614,7 +626,7 @@ function FormTokenField(props) {
614
626
  /* eslint-disable jsx-a11y/no-static-element-interactions */
615
627
 
616
628
 
617
- return (0, _element.createElement)("div", tokenFieldProps, (0, _element.createElement)("label", {
629
+ return (0, _element.createElement)("div", tokenFieldProps, (0, _element.createElement)(_baseControlStyles.StyledLabel, {
618
630
  htmlFor: `components-form-token-input-${instanceId}`,
619
631
  className: "components-form-token-field__label"
620
632
  }, label), (0, _element.createElement)("div", {
@@ -638,7 +650,8 @@ function FormTokenField(props) {
638
650
  selectedIndex: selectedSuggestionIndex,
639
651
  scrollIntoView: selectedSuggestionScroll,
640
652
  onHover: onSuggestionHovered,
641
- onSelect: onSuggestionSelected
653
+ onSelect: onSuggestionSelected,
654
+ __experimentalRenderItem: __experimentalRenderItem
642
655
  })), __experimentalShowHowTo && (0, _element.createElement)("p", {
643
656
  id: `components-form-token-suggestions-howto-${instanceId}`,
644
657
  className: "components-form-token-field__help"
@@ -1 +1 @@
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","__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';\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__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<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<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/>\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","__experimentalAutoSelectFirstMatch","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","code","handleDeleteKey","deleteTokenBeforeInput","addCurrentToken","handleLeftArrowKey","handleUpArrowKey","handleRightArrowKey","handleDownArrowKey","deleteTokenAfterInput","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","Set","map","filter","Boolean","valueContainsToken","newValue","splice","newTokens","item","getTokenValue","searchValue","_suggestions","_value","_maxSuggestions","_saveTransform","match","startsWithMatch","containsMatch","normalizedValue","includes","toLocaleLowerCase","forEach","push","concat","resetSelectedSuggestion","inputHasMinimumChars","matchingSuggestions","hasMatchingSuggestions","shouldExpandIfFocuses","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, map, 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 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\t__experimentalAutoSelectFirstMatch = 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\tuseEffect( () => {\n\t\tupdateSuggestions();\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ __experimentalAutoSelectFirstMatch ] );\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\tswitch ( event.code ) {\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 'ArrowLeft':\n\t\t\t\tpreventDefault = handleLeftArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowUp':\n\t\t\t\tpreventDefault = handleUpArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowRight':\n\t\t\t\tpreventDefault = handleRightArrowKey();\n\t\t\t\tbreak;\n\t\t\tcase 'ArrowDown':\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 = [\n\t\t\t...new Set(\n\t\t\t\ttokens\n\t\t\t\t\t.map( saveTransform )\n\t\t\t\t\t.filter( Boolean )\n\t\t\t\t\t.filter( ( token ) => ! valueContainsToken( token ) )\n\t\t\t),\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 = _suggestions.filter(\n\t\t\t\t( suggestion ) => ! normalizedValue.includes( suggestion )\n\t\t\t);\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\tconst shouldExpandIfFocuses = hasFocus() && __experimentalExpandOnFocus;\n\t\tsetIsExpanded(\n\t\t\tshouldExpandIfFocuses ||\n\t\t\t\t( inputHasMinimumChars && hasMatchingSuggestions )\n\t\t);\n\n\t\tif ( resetSelectedSuggestion ) {\n\t\t\tif (\n\t\t\t\t__experimentalAutoSelectFirstMatch &&\n\t\t\t\tinputHasMinimumChars &&\n\t\t\t\thasMatchingSuggestions\n\t\t\t) {\n\t\t\t\tsetSelectedSuggestionIndex( 0 );\n\t\t\t\tsetSelectedSuggestionScroll( true );\n\t\t\t} else {\n\t\t\t\tsetSelectedSuggestionIndex( -1 );\n\t\t\t\tsetSelectedSuggestionScroll( false );\n\t\t\t}\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"]}
@@ -39,7 +39,8 @@ function SuggestionsList(_ref) {
39
39
  onSelect,
40
40
  suggestions = [],
41
41
  displayTransform,
42
- instanceId
42
+ instanceId,
43
+ __experimentalRenderItem
43
44
  } = _ref;
44
45
  const [scrollingIntoView, setScrollingIntoView] = (0, _element.useState)(false);
45
46
  const listRef = (0, _compose.useRefEffect)(listNode => {
@@ -104,8 +105,24 @@ function SuggestionsList(_ref) {
104
105
  const className = (0, _classnames.default)('components-form-token-field__suggestion', {
105
106
  'is-selected': index === selectedIndex
106
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
+ }
107
123
  /* eslint-disable jsx-a11y/click-events-have-key-events */
108
124
 
125
+
109
126
  return (0, _element.createElement)("li", {
110
127
  id: `components-form-token-suggestions-${instanceId}-${index}`,
111
128
  role: "option",
@@ -115,11 +132,7 @@ function SuggestionsList(_ref) {
115
132
  onClick: handleClick(suggestion),
116
133
  onMouseEnter: handleHover(suggestion),
117
134
  "aria-selected": index === selectedIndex
118
- }, matchText ? (0, _element.createElement)("span", {
119
- "aria-label": displayTransform(suggestion)
120
- }, matchText.suggestionBeforeMatch, (0, _element.createElement)("strong", {
121
- className: "components-form-token-field__suggestion-match"
122
- }, matchText.suggestionMatch), matchText.suggestionAfterMatch) : displayTransform(suggestion));
135
+ }, output);
123
136
  /* eslint-enable jsx-a11y/click-events-have-key-events */
124
137
  }));
125
138
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/form-token-field/suggestions-list.tsx"],"names":["handleMouseDown","e","preventDefault","SuggestionsList","selectedIndex","scrollIntoView","match","onHover","onSelect","suggestions","displayTransform","instanceId","scrollingIntoView","setScrollingIntoView","listRef","listNode","id","children","onlyScrollIfNeeded","window","setTimeout","undefined","clearTimeout","handleHover","suggestion","handleClick","computeSuggestionMatch","matchText","toLocaleLowerCase","length","transformedSuggestion","indexOfMatch","indexOf","suggestionBeforeMatch","substring","suggestionMatch","suggestionAfterMatch","index","className","value"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { map } from 'lodash';\nimport scrollView from 'dom-scroll-into-view';\nimport classnames from 'classnames';\nimport type { MouseEventHandler } from 'react';\n\n/**\n * WordPress dependencies\n */\nimport { useState } from '@wordpress/element';\nimport { useRefEffect } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport type { SuggestionsListProps } from './types';\n\nconst handleMouseDown: MouseEventHandler = ( e ) => {\n\t// By preventing default here, we will not lose focus of <input> when clicking a suggestion.\n\te.preventDefault();\n};\n\nexport function SuggestionsList< T extends string | { value: string } >( {\n\tselectedIndex,\n\tscrollIntoView,\n\tmatch,\n\tonHover,\n\tonSelect,\n\tsuggestions = [],\n\tdisplayTransform,\n\tinstanceId,\n}: SuggestionsListProps< T > ) {\n\tconst [ scrollingIntoView, setScrollingIntoView ] = useState( false );\n\n\tconst listRef = useRefEffect< HTMLUListElement >(\n\t\t( listNode ) => {\n\t\t\t// only have to worry about scrolling selected suggestion into view\n\t\t\t// when already expanded.\n\t\t\tlet id: number;\n\t\t\tif (\n\t\t\t\tselectedIndex > -1 &&\n\t\t\t\tscrollIntoView &&\n\t\t\t\tlistNode.children[ selectedIndex ]\n\t\t\t) {\n\t\t\t\tsetScrollingIntoView( true );\n\t\t\t\tscrollView(\n\t\t\t\t\tlistNode.children[ selectedIndex ] as HTMLLIElement,\n\t\t\t\t\tlistNode,\n\t\t\t\t\t{\n\t\t\t\t\t\tonlyScrollIfNeeded: true,\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tid = window.setTimeout( () => {\n\t\t\t\t\tsetScrollingIntoView( false );\n\t\t\t\t}, 100 );\n\t\t\t}\n\n\t\t\treturn () => {\n\t\t\t\tif ( id !== undefined ) {\n\t\t\t\t\twindow.clearTimeout( id );\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\t[ selectedIndex, scrollIntoView ]\n\t);\n\n\tconst handleHover = ( suggestion: T ) => {\n\t\treturn () => {\n\t\t\tif ( ! scrollingIntoView ) {\n\t\t\t\tonHover?.( suggestion );\n\t\t\t}\n\t\t};\n\t};\n\n\tconst handleClick = ( suggestion: T ) => {\n\t\treturn () => {\n\t\t\tonSelect?.( suggestion );\n\t\t};\n\t};\n\n\tconst computeSuggestionMatch = ( suggestion: T ) => {\n\t\tconst matchText = displayTransform( match ).toLocaleLowerCase();\n\t\tif ( matchText.length === 0 ) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst transformedSuggestion = displayTransform( suggestion );\n\t\tconst indexOfMatch = transformedSuggestion\n\t\t\t.toLocaleLowerCase()\n\t\t\t.indexOf( matchText );\n\n\t\treturn {\n\t\t\tsuggestionBeforeMatch: transformedSuggestion.substring(\n\t\t\t\t0,\n\t\t\t\tindexOfMatch\n\t\t\t),\n\t\t\tsuggestionMatch: transformedSuggestion.substring(\n\t\t\t\tindexOfMatch,\n\t\t\t\tindexOfMatch + matchText.length\n\t\t\t),\n\t\t\tsuggestionAfterMatch: transformedSuggestion.substring(\n\t\t\t\tindexOfMatch + matchText.length\n\t\t\t),\n\t\t};\n\t};\n\n\treturn (\n\t\t<ul\n\t\t\tref={ listRef }\n\t\t\tclassName=\"components-form-token-field__suggestions-list\"\n\t\t\tid={ `components-form-token-suggestions-${ instanceId }` }\n\t\t\trole=\"listbox\"\n\t\t>\n\t\t\t{ map( suggestions, ( suggestion, index ) => {\n\t\t\t\tconst matchText = computeSuggestionMatch( suggestion );\n\t\t\t\tconst className = classnames(\n\t\t\t\t\t'components-form-token-field__suggestion',\n\t\t\t\t\t{\n\t\t\t\t\t\t'is-selected': index === selectedIndex,\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\t/* eslint-disable jsx-a11y/click-events-have-key-events */\n\t\t\t\treturn (\n\t\t\t\t\t<li\n\t\t\t\t\t\tid={ `components-form-token-suggestions-${ instanceId }-${ index }` }\n\t\t\t\t\t\trole=\"option\"\n\t\t\t\t\t\tclassName={ className }\n\t\t\t\t\t\tkey={\n\t\t\t\t\t\t\ttypeof suggestion === 'object' &&\n\t\t\t\t\t\t\t'value' in suggestion\n\t\t\t\t\t\t\t\t? suggestion?.value\n\t\t\t\t\t\t\t\t: displayTransform( suggestion )\n\t\t\t\t\t\t}\n\t\t\t\t\t\tonMouseDown={ handleMouseDown }\n\t\t\t\t\t\tonClick={ handleClick( suggestion ) }\n\t\t\t\t\t\tonMouseEnter={ handleHover( suggestion ) }\n\t\t\t\t\t\taria-selected={ index === selectedIndex }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ matchText ? (\n\t\t\t\t\t\t\t<span aria-label={ displayTransform( suggestion ) }>\n\t\t\t\t\t\t\t\t{ matchText.suggestionBeforeMatch }\n\t\t\t\t\t\t\t\t<strong className=\"components-form-token-field__suggestion-match\">\n\t\t\t\t\t\t\t\t\t{ matchText.suggestionMatch }\n\t\t\t\t\t\t\t\t</strong>\n\t\t\t\t\t\t\t\t{ matchText.suggestionAfterMatch }\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\tdisplayTransform( suggestion )\n\t\t\t\t\t\t) }\n\t\t\t\t\t</li>\n\t\t\t\t);\n\t\t\t\t/* eslint-enable jsx-a11y/click-events-have-key-events */\n\t\t\t} ) }\n\t\t</ul>\n\t);\n}\n\nexport default SuggestionsList;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/form-token-field/suggestions-list.tsx"],"names":["handleMouseDown","e","preventDefault","SuggestionsList","selectedIndex","scrollIntoView","match","onHover","onSelect","suggestions","displayTransform","instanceId","__experimentalRenderItem","scrollingIntoView","setScrollingIntoView","listRef","listNode","id","children","onlyScrollIfNeeded","window","setTimeout","undefined","clearTimeout","handleHover","suggestion","handleClick","computeSuggestionMatch","matchText","toLocaleLowerCase","length","transformedSuggestion","indexOfMatch","indexOf","suggestionBeforeMatch","substring","suggestionMatch","suggestionAfterMatch","index","className","output","item","value"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { map } from 'lodash';\nimport scrollView from 'dom-scroll-into-view';\nimport classnames from 'classnames';\nimport type { MouseEventHandler, ReactNode } from 'react';\n\n/**\n * WordPress dependencies\n */\nimport { useState } from '@wordpress/element';\nimport { useRefEffect } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport type { SuggestionsListProps } from './types';\n\nconst handleMouseDown: MouseEventHandler = ( e ) => {\n\t// By preventing default here, we will not lose focus of <input> when clicking a suggestion.\n\te.preventDefault();\n};\n\nexport function SuggestionsList< T extends string | { value: string } >( {\n\tselectedIndex,\n\tscrollIntoView,\n\tmatch,\n\tonHover,\n\tonSelect,\n\tsuggestions = [],\n\tdisplayTransform,\n\tinstanceId,\n\t__experimentalRenderItem,\n}: SuggestionsListProps< T > ) {\n\tconst [ scrollingIntoView, setScrollingIntoView ] = useState( false );\n\n\tconst listRef = useRefEffect< HTMLUListElement >(\n\t\t( listNode ) => {\n\t\t\t// only have to worry about scrolling selected suggestion into view\n\t\t\t// when already expanded.\n\t\t\tlet id: number;\n\t\t\tif (\n\t\t\t\tselectedIndex > -1 &&\n\t\t\t\tscrollIntoView &&\n\t\t\t\tlistNode.children[ selectedIndex ]\n\t\t\t) {\n\t\t\t\tsetScrollingIntoView( true );\n\t\t\t\tscrollView(\n\t\t\t\t\tlistNode.children[ selectedIndex ] as HTMLLIElement,\n\t\t\t\t\tlistNode,\n\t\t\t\t\t{\n\t\t\t\t\t\tonlyScrollIfNeeded: true,\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tid = window.setTimeout( () => {\n\t\t\t\t\tsetScrollingIntoView( false );\n\t\t\t\t}, 100 );\n\t\t\t}\n\n\t\t\treturn () => {\n\t\t\t\tif ( id !== undefined ) {\n\t\t\t\t\twindow.clearTimeout( id );\n\t\t\t\t}\n\t\t\t};\n\t\t},\n\t\t[ selectedIndex, scrollIntoView ]\n\t);\n\n\tconst handleHover = ( suggestion: T ) => {\n\t\treturn () => {\n\t\t\tif ( ! scrollingIntoView ) {\n\t\t\t\tonHover?.( suggestion );\n\t\t\t}\n\t\t};\n\t};\n\n\tconst handleClick = ( suggestion: T ) => {\n\t\treturn () => {\n\t\t\tonSelect?.( suggestion );\n\t\t};\n\t};\n\n\tconst computeSuggestionMatch = ( suggestion: T ) => {\n\t\tconst matchText = displayTransform( match ).toLocaleLowerCase();\n\t\tif ( matchText.length === 0 ) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst transformedSuggestion = displayTransform( suggestion );\n\t\tconst indexOfMatch = transformedSuggestion\n\t\t\t.toLocaleLowerCase()\n\t\t\t.indexOf( matchText );\n\n\t\treturn {\n\t\t\tsuggestionBeforeMatch: transformedSuggestion.substring(\n\t\t\t\t0,\n\t\t\t\tindexOfMatch\n\t\t\t),\n\t\t\tsuggestionMatch: transformedSuggestion.substring(\n\t\t\t\tindexOfMatch,\n\t\t\t\tindexOfMatch + matchText.length\n\t\t\t),\n\t\t\tsuggestionAfterMatch: transformedSuggestion.substring(\n\t\t\t\tindexOfMatch + matchText.length\n\t\t\t),\n\t\t};\n\t};\n\n\treturn (\n\t\t<ul\n\t\t\tref={ listRef }\n\t\t\tclassName=\"components-form-token-field__suggestions-list\"\n\t\t\tid={ `components-form-token-suggestions-${ instanceId }` }\n\t\t\trole=\"listbox\"\n\t\t>\n\t\t\t{ map( suggestions, ( suggestion, index ) => {\n\t\t\t\tconst matchText = computeSuggestionMatch( suggestion );\n\t\t\t\tconst className = classnames(\n\t\t\t\t\t'components-form-token-field__suggestion',\n\t\t\t\t\t{\n\t\t\t\t\t\t'is-selected': index === selectedIndex,\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\tlet output: ReactNode;\n\n\t\t\t\tif ( typeof __experimentalRenderItem === 'function' ) {\n\t\t\t\t\toutput = __experimentalRenderItem( { item: suggestion } );\n\t\t\t\t} else if ( matchText ) {\n\t\t\t\t\toutput = (\n\t\t\t\t\t\t<span aria-label={ displayTransform( suggestion ) }>\n\t\t\t\t\t\t\t{ matchText.suggestionBeforeMatch }\n\t\t\t\t\t\t\t<strong className=\"components-form-token-field__suggestion-match\">\n\t\t\t\t\t\t\t\t{ matchText.suggestionMatch }\n\t\t\t\t\t\t\t</strong>\n\t\t\t\t\t\t\t{ matchText.suggestionAfterMatch }\n\t\t\t\t\t\t</span>\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\toutput = displayTransform( suggestion );\n\t\t\t\t}\n\n\t\t\t\t/* eslint-disable jsx-a11y/click-events-have-key-events */\n\t\t\t\treturn (\n\t\t\t\t\t<li\n\t\t\t\t\t\tid={ `components-form-token-suggestions-${ instanceId }-${ index }` }\n\t\t\t\t\t\trole=\"option\"\n\t\t\t\t\t\tclassName={ className }\n\t\t\t\t\t\tkey={\n\t\t\t\t\t\t\ttypeof suggestion === 'object' &&\n\t\t\t\t\t\t\t'value' in suggestion\n\t\t\t\t\t\t\t\t? suggestion?.value\n\t\t\t\t\t\t\t\t: displayTransform( suggestion )\n\t\t\t\t\t\t}\n\t\t\t\t\t\tonMouseDown={ handleMouseDown }\n\t\t\t\t\t\tonClick={ handleClick( suggestion ) }\n\t\t\t\t\t\tonMouseEnter={ handleHover( suggestion ) }\n\t\t\t\t\t\taria-selected={ index === selectedIndex }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ output }\n\t\t\t\t\t</li>\n\t\t\t\t);\n\t\t\t\t/* eslint-enable jsx-a11y/click-events-have-key-events */\n\t\t\t} ) }\n\t\t</ul>\n\t);\n}\n\nexport default SuggestionsList;\n"]}