@wordpress/components 19.17.0 → 20.0.2-next.957ca95e4c.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 (916) hide show
  1. package/CHANGELOG.md +96 -1
  2. package/CONTRIBUTING.md +12 -12
  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 +13 -13
  6. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  7. package/build/angle-picker-control/index.js +3 -0
  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/get-default-use-items.js +7 -1
  12. package/build/autocomplete/get-default-use-items.js.map +1 -1
  13. package/build/autocomplete/index.js +12 -12
  14. package/build/autocomplete/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/box-control/styles/box-control-visualizer-styles.js +8 -8
  20. package/build/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  21. package/build/card/card/component.js +6 -11
  22. package/build/card/card/component.js.map +1 -1
  23. package/build/card/card/hook.js +0 -10
  24. package/build/card/card/hook.js.map +1 -1
  25. package/build/card/card/index.js.map +1 -1
  26. package/build/card/card-body/component.js +7 -8
  27. package/build/card/card-body/component.js.map +1 -1
  28. package/build/card/card-body/hook.js +0 -4
  29. package/build/card/card-body/hook.js.map +1 -1
  30. package/build/card/card-body/index.js.map +1 -1
  31. package/build/card/card-divider/component.js +7 -8
  32. package/build/card/card-divider/component.js.map +1 -1
  33. package/build/card/card-divider/hook.js +0 -4
  34. package/build/card/card-divider/hook.js.map +1 -1
  35. package/build/card/card-divider/index.js.map +1 -1
  36. package/build/card/card-footer/component.js +7 -8
  37. package/build/card/card-footer/component.js.map +1 -1
  38. package/build/card/card-footer/hook.js +0 -4
  39. package/build/card/card-footer/hook.js.map +1 -1
  40. package/build/card/card-footer/index.js.map +1 -1
  41. package/build/card/card-header/component.js +7 -8
  42. package/build/card/card-header/component.js.map +1 -1
  43. package/build/card/card-header/hook.js +0 -4
  44. package/build/card/card-header/hook.js.map +1 -1
  45. package/build/card/card-header/index.js.map +1 -1
  46. package/build/card/card-media/component.js +7 -7
  47. package/build/card/card-media/component.js.map +1 -1
  48. package/build/card/card-media/hook.js +0 -4
  49. package/build/card/card-media/hook.js.map +1 -1
  50. package/build/card/card-media/index.js.map +1 -1
  51. package/build/card/context.js.map +1 -1
  52. package/build/card/index.js.map +1 -1
  53. package/build/card/styles.js +17 -17
  54. package/build/card/styles.js.map +1 -1
  55. package/build/clipboard-button/index.js +16 -1
  56. package/build/clipboard-button/index.js.map +1 -1
  57. package/build/color-list-picker/index.js +16 -5
  58. package/build/color-list-picker/index.js.map +1 -1
  59. package/build/color-palette/index.js +28 -14
  60. package/build/color-palette/index.js.map +1 -1
  61. package/build/color-palette/index.native.js +3 -3
  62. package/build/color-palette/index.native.js.map +1 -1
  63. package/build/combobox-control/index.js +7 -4
  64. package/build/combobox-control/index.js.map +1 -1
  65. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  66. package/build/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  67. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  68. package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  69. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  70. package/build/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  71. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  72. package/build/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  73. package/build/custom-gradient-picker/index.js +30 -4
  74. package/build/custom-gradient-picker/index.js.map +1 -1
  75. package/build/custom-select-control/index.js +21 -11
  76. package/build/custom-select-control/index.js.map +1 -1
  77. package/build/custom-select-control/styles.js +34 -0
  78. package/build/custom-select-control/styles.js.map +1 -0
  79. package/build/date-time/constants.js +9 -0
  80. package/build/date-time/constants.js.map +1 -0
  81. package/build/date-time/date/index.js +196 -188
  82. package/build/date-time/date/index.js.map +1 -1
  83. package/build/date-time/date/styles.js +68 -39
  84. package/build/date-time/date/styles.js.map +1 -1
  85. package/build/date-time/date-time/index.js +3 -2
  86. package/build/date-time/date-time/index.js.map +1 -1
  87. package/build/date-time/date-time/styles.js +19 -5
  88. package/build/date-time/date-time/styles.js.map +1 -1
  89. package/build/date-time/time/index.js +22 -17
  90. package/build/date-time/time/index.js.map +1 -1
  91. package/build/date-time/time/styles.js +12 -12
  92. package/build/date-time/time/styles.js.map +1 -1
  93. package/build/date-time/utils.js +27 -0
  94. package/build/date-time/utils.js.map +1 -0
  95. package/build/dimension-control/index.js +2 -6
  96. package/build/dimension-control/index.js.map +1 -1
  97. package/build/disabled/index.js +28 -11
  98. package/build/disabled/index.js.map +1 -1
  99. package/build/disabled/styles/disabled-styles.js +3 -3
  100. package/build/disabled/styles/disabled-styles.js.map +1 -1
  101. package/build/{swatch → disabled}/types.js +0 -0
  102. package/build/{swatch → disabled}/types.js.map +0 -0
  103. package/build/drop-zone/index.js +2 -4
  104. package/build/drop-zone/index.js.map +1 -1
  105. package/build/dropdown/index.js +5 -6
  106. package/build/dropdown/index.js.map +1 -1
  107. package/build/dropdown-menu/index.js +1 -3
  108. package/build/dropdown-menu/index.js.map +1 -1
  109. package/build/dropdown-menu/index.native.js +0 -17
  110. package/build/dropdown-menu/index.native.js.map +1 -1
  111. package/build/duotone-picker/custom-duotone-bar.js +2 -2
  112. package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
  113. package/build/duotone-picker/duotone-picker.js +9 -1
  114. package/build/duotone-picker/duotone-picker.js.map +1 -1
  115. package/build/duotone-picker/duotone-swatch.js +13 -3
  116. package/build/duotone-picker/duotone-swatch.js.map +1 -1
  117. package/build/focal-point-picker/controls.js +4 -4
  118. package/build/focal-point-picker/controls.js.map +1 -1
  119. package/build/focal-point-picker/focal-point.js +4 -6
  120. package/build/focal-point-picker/focal-point.js.map +1 -1
  121. package/build/focal-point-picker/grid.js +6 -35
  122. package/build/focal-point-picker/grid.js.map +1 -1
  123. package/build/focal-point-picker/index.js +164 -336
  124. package/build/focal-point-picker/index.js.map +1 -1
  125. package/build/focal-point-picker/media.js +4 -34
  126. package/build/focal-point-picker/media.js.map +1 -1
  127. package/build/focal-point-picker/styles/focal-point-picker-style.js +14 -14
  128. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  129. package/build/focal-point-picker/styles/focal-point-style.js +4 -4
  130. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  131. package/build/focal-point-picker/utils.js +2 -6
  132. package/build/focal-point-picker/utils.js.map +1 -1
  133. package/build/focusable-iframe/index.js +6 -0
  134. package/build/focusable-iframe/index.js.map +1 -1
  135. package/build/font-size-picker/index.js +43 -14
  136. package/build/font-size-picker/index.js.map +1 -1
  137. package/build/font-size-picker/utils.js +32 -22
  138. package/build/font-size-picker/utils.js.map +1 -1
  139. package/build/form-token-field/index.js +29 -20
  140. package/build/form-token-field/index.js.map +1 -1
  141. package/build/gradient-picker/index.js +25 -2
  142. package/build/gradient-picker/index.js.map +1 -1
  143. package/build/guide/index.js +13 -9
  144. package/build/guide/index.js.map +1 -1
  145. package/build/guide/page-control.js +3 -7
  146. package/build/guide/page-control.js.map +1 -1
  147. package/build/higher-order/with-constrained-tabbing/index.js +1 -1
  148. package/build/higher-order/with-constrained-tabbing/index.js.map +1 -1
  149. package/build/higher-order/with-spoken-messages/index.js +2 -0
  150. package/build/higher-order/with-spoken-messages/index.js.map +1 -1
  151. package/build/isolated-event-container/index.js +4 -0
  152. package/build/isolated-event-container/index.js.map +1 -1
  153. package/build/item-group/styles.js +10 -10
  154. package/build/item-group/styles.js.map +1 -1
  155. package/build/mobile/bottom-sheet/index.native.js +3 -6
  156. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  157. package/build/mobile/global-styles-context/utils.native.js +4 -2
  158. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  159. package/build/mobile/image/index.native.js +6 -26
  160. package/build/mobile/image/index.native.js.map +1 -1
  161. package/build/mobile/picker/index.android.js +3 -3
  162. package/build/mobile/picker/index.android.js.map +1 -1
  163. package/build/modal/index.js +1 -3
  164. package/build/modal/index.js.map +1 -1
  165. package/build/navigable-container/container.js +9 -8
  166. package/build/navigable-container/container.js.map +1 -1
  167. package/build/navigable-container/menu.js +3 -9
  168. package/build/navigable-container/menu.js.map +1 -1
  169. package/build/navigation/menu/menu-title-search.js +1 -3
  170. package/build/navigation/menu/menu-title-search.js.map +1 -1
  171. package/build/navigator/navigator-back-button/hook.js +0 -4
  172. package/build/navigator/navigator-back-button/hook.js.map +1 -1
  173. package/build/navigator/navigator-button/hook.js +0 -4
  174. package/build/navigator/navigator-button/hook.js.map +1 -1
  175. package/build/notice/list.js +10 -6
  176. package/build/notice/list.js.map +1 -1
  177. package/build/palette-edit/index.js +7 -2
  178. package/build/palette-edit/index.js.map +1 -1
  179. package/build/palette-edit/styles.js +10 -10
  180. package/build/palette-edit/styles.js.map +1 -1
  181. package/build/popover/index.js +93 -110
  182. package/build/popover/index.js.map +1 -1
  183. package/build/popover/utils.js +178 -0
  184. package/build/popover/utils.js.map +1 -0
  185. package/build/range-control/index.js +3 -0
  186. package/build/range-control/index.js.map +1 -1
  187. package/build/range-control/styles/range-control-styles.js +43 -37
  188. package/build/range-control/styles/range-control-styles.js.map +1 -1
  189. package/build/select-control/chevron-down.js +30 -0
  190. package/build/select-control/chevron-down.js.map +1 -0
  191. package/build/select-control/index.js +7 -7
  192. package/build/select-control/index.js.map +1 -1
  193. package/build/select-control/styles/select-control-styles.js +30 -15
  194. package/build/select-control/styles/select-control-styles.js.map +1 -1
  195. package/build/snackbar/list.js +5 -3
  196. package/build/snackbar/list.js.map +1 -1
  197. package/build/spinner/index.js +2 -0
  198. package/build/spinner/index.js.map +1 -1
  199. package/build/text/styles.js +7 -7
  200. package/build/text/styles.js.map +1 -1
  201. package/build/text-highlight/index.js +4 -4
  202. package/build/text-highlight/index.js.map +1 -1
  203. package/build/toggle-group-control/toggle-group-control/component.js +17 -9
  204. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  205. package/build/toggle-group-control/toggle-group-control/styles.js +24 -7
  206. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  207. package/build/toggle-group-control/toggle-group-control-option/component.js +15 -5
  208. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  209. package/build/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  210. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  211. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +20 -7
  212. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  213. package/build/toggle-group-control/toggle-group-control-option-icon/component.js +26 -7
  214. package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  215. package/build/tools-panel/styles.js +11 -11
  216. package/build/tools-panel/styles.js.map +1 -1
  217. package/build/tooltip/index.js +1 -7
  218. package/build/tooltip/index.js.map +1 -1
  219. package/build/tree-grid/index.js +4 -10
  220. package/build/tree-grid/index.js.map +1 -1
  221. package/build/ui/context/context-connect.js +1 -3
  222. package/build/ui/context/context-connect.js.map +1 -1
  223. package/build/unit-control/index.js +2 -3
  224. package/build/unit-control/index.js.map +1 -1
  225. package/build/utils/colors-values.js +52 -142
  226. package/build/utils/colors-values.js.map +1 -1
  227. package/build/utils/config-values.js +1 -1
  228. package/build/utils/config-values.js.map +1 -1
  229. package/build/utils/input/input-control.js +1 -1
  230. package/build/utils/input/input-control.js.map +1 -1
  231. package/build/utils/rtl.js +6 -5
  232. package/build/utils/rtl.js.map +1 -1
  233. package/build/utils/strings.js +63 -0
  234. package/build/utils/strings.js.map +1 -0
  235. package/build-module/alignment-matrix-control/index.js +1 -1
  236. package/build-module/alignment-matrix-control/index.js.map +1 -1
  237. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +13 -13
  238. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  239. package/build-module/angle-picker-control/index.js +3 -0
  240. package/build-module/angle-picker-control/index.js.map +1 -1
  241. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +13 -4
  242. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  243. package/build-module/autocomplete/get-default-use-items.js +6 -1
  244. package/build-module/autocomplete/get-default-use-items.js.map +1 -1
  245. package/build-module/autocomplete/index.js +11 -11
  246. package/build-module/autocomplete/index.js.map +1 -1
  247. package/build-module/base-control/styles/base-control-styles.js +8 -8
  248. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  249. package/build-module/base-field/styles.js +5 -5
  250. package/build-module/base-field/styles.js.map +1 -1
  251. package/build-module/box-control/styles/box-control-visualizer-styles.js +8 -8
  252. package/build-module/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  253. package/build-module/card/card/component.js +5 -10
  254. package/build-module/card/card/component.js.map +1 -1
  255. package/build-module/card/card/hook.js +0 -9
  256. package/build-module/card/card/hook.js.map +1 -1
  257. package/build-module/card/card/index.js.map +1 -1
  258. package/build-module/card/card-body/component.js +7 -8
  259. package/build-module/card/card-body/component.js.map +1 -1
  260. package/build-module/card/card-body/hook.js +0 -4
  261. package/build-module/card/card-body/hook.js.map +1 -1
  262. package/build-module/card/card-body/index.js.map +1 -1
  263. package/build-module/card/card-divider/component.js +7 -8
  264. package/build-module/card/card-divider/component.js.map +1 -1
  265. package/build-module/card/card-divider/hook.js +0 -4
  266. package/build-module/card/card-divider/hook.js.map +1 -1
  267. package/build-module/card/card-divider/index.js.map +1 -1
  268. package/build-module/card/card-footer/component.js +7 -8
  269. package/build-module/card/card-footer/component.js.map +1 -1
  270. package/build-module/card/card-footer/hook.js +0 -4
  271. package/build-module/card/card-footer/hook.js.map +1 -1
  272. package/build-module/card/card-footer/index.js.map +1 -1
  273. package/build-module/card/card-header/component.js +7 -8
  274. package/build-module/card/card-header/component.js.map +1 -1
  275. package/build-module/card/card-header/hook.js +0 -4
  276. package/build-module/card/card-header/hook.js.map +1 -1
  277. package/build-module/card/card-header/index.js.map +1 -1
  278. package/build-module/card/card-media/component.js +7 -7
  279. package/build-module/card/card-media/component.js.map +1 -1
  280. package/build-module/card/card-media/hook.js +0 -4
  281. package/build-module/card/card-media/hook.js.map +1 -1
  282. package/build-module/card/card-media/index.js.map +1 -1
  283. package/build-module/card/context.js.map +1 -1
  284. package/build-module/card/index.js.map +1 -1
  285. package/build-module/card/styles.js +17 -17
  286. package/build-module/card/styles.js.map +1 -1
  287. package/build-module/clipboard-button/index.js +17 -1
  288. package/build-module/clipboard-button/index.js.map +1 -1
  289. package/build-module/color-list-picker/index.js +13 -5
  290. package/build-module/color-list-picker/index.js.map +1 -1
  291. package/build-module/color-palette/index.js +27 -13
  292. package/build-module/color-palette/index.js.map +1 -1
  293. package/build-module/color-palette/index.native.js +4 -4
  294. package/build-module/color-palette/index.native.js.map +1 -1
  295. package/build-module/combobox-control/index.js +6 -3
  296. package/build-module/combobox-control/index.js.map +1 -1
  297. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  298. package/build-module/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  299. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  300. package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  301. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  302. package/build-module/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  303. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  304. package/build-module/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  305. package/build-module/custom-gradient-picker/index.js +26 -3
  306. package/build-module/custom-gradient-picker/index.js.map +1 -1
  307. package/build-module/custom-select-control/index.js +20 -12
  308. package/build-module/custom-select-control/index.js.map +1 -1
  309. package/build-module/custom-select-control/styles.js +22 -0
  310. package/build-module/custom-select-control/styles.js.map +1 -0
  311. package/build-module/date-time/constants.js +2 -0
  312. package/build-module/date-time/constants.js.map +1 -0
  313. package/build-module/date-time/date/index.js +199 -186
  314. package/build-module/date-time/date/index.js.map +1 -1
  315. package/build-module/date-time/date/styles.js +61 -36
  316. package/build-module/date-time/date/styles.js.map +1 -1
  317. package/build-module/date-time/date-time/index.js +4 -3
  318. package/build-module/date-time/date-time/index.js.map +1 -1
  319. package/build-module/date-time/date-time/styles.js +20 -1
  320. package/build-module/date-time/date-time/styles.js.map +1 -1
  321. package/build-module/date-time/time/index.js +20 -16
  322. package/build-module/date-time/time/index.js.map +1 -1
  323. package/build-module/date-time/time/styles.js +12 -12
  324. package/build-module/date-time/time/styles.js.map +1 -1
  325. package/build-module/date-time/utils.js +19 -0
  326. package/build-module/date-time/utils.js.map +1 -0
  327. package/build-module/dimension-control/index.js +1 -5
  328. package/build-module/dimension-control/index.js.map +1 -1
  329. package/build-module/disabled/index.js +28 -11
  330. package/build-module/disabled/index.js.map +1 -1
  331. package/build-module/disabled/styles/disabled-styles.js +3 -3
  332. package/build-module/disabled/styles/disabled-styles.js.map +1 -1
  333. package/build-module/{swatch → disabled}/types.js +0 -0
  334. package/build-module/{swatch → disabled}/types.js.map +0 -0
  335. package/build-module/drop-zone/index.js +2 -3
  336. package/build-module/drop-zone/index.js.map +1 -1
  337. package/build-module/dropdown/index.js +5 -6
  338. package/build-module/dropdown/index.js.map +1 -1
  339. package/build-module/dropdown-menu/index.js +1 -2
  340. package/build-module/dropdown-menu/index.js.map +1 -1
  341. package/build-module/dropdown-menu/index.native.js +0 -16
  342. package/build-module/dropdown-menu/index.native.js.map +1 -1
  343. package/build-module/duotone-picker/custom-duotone-bar.js +1 -1
  344. package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
  345. package/build-module/duotone-picker/duotone-picker.js +7 -1
  346. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  347. package/build-module/duotone-picker/duotone-swatch.js +11 -3
  348. package/build-module/duotone-picker/duotone-swatch.js.map +1 -1
  349. package/build-module/focal-point-picker/controls.js +4 -4
  350. package/build-module/focal-point-picker/controls.js.map +1 -1
  351. package/build-module/focal-point-picker/focal-point.js +4 -6
  352. package/build-module/focal-point-picker/focal-point.js.map +1 -1
  353. package/build-module/focal-point-picker/grid.js +6 -34
  354. package/build-module/focal-point-picker/grid.js.map +1 -1
  355. package/build-module/focal-point-picker/index.js +162 -330
  356. package/build-module/focal-point-picker/index.js.map +1 -1
  357. package/build-module/focal-point-picker/media.js +4 -36
  358. package/build-module/focal-point-picker/media.js.map +1 -1
  359. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +13 -14
  360. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  361. package/build-module/focal-point-picker/styles/focal-point-style.js +4 -4
  362. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  363. package/build-module/focal-point-picker/utils.js +2 -6
  364. package/build-module/focal-point-picker/utils.js.map +1 -1
  365. package/build-module/focusable-iframe/index.js +6 -0
  366. package/build-module/focusable-iframe/index.js.map +1 -1
  367. package/build-module/font-size-picker/index.js +39 -14
  368. package/build-module/font-size-picker/index.js.map +1 -1
  369. package/build-module/font-size-picker/utils.js +31 -23
  370. package/build-module/font-size-picker/utils.js.map +1 -1
  371. package/build-module/form-token-field/index.js +30 -20
  372. package/build-module/form-token-field/index.js.map +1 -1
  373. package/build-module/gradient-picker/index.js +23 -2
  374. package/build-module/gradient-picker/index.js.map +1 -1
  375. package/build-module/guide/index.js +13 -8
  376. package/build-module/guide/index.js.map +1 -1
  377. package/build-module/guide/page-control.js +3 -6
  378. package/build-module/guide/page-control.js.map +1 -1
  379. package/build-module/higher-order/with-constrained-tabbing/index.js +1 -1
  380. package/build-module/higher-order/with-constrained-tabbing/index.js.map +1 -1
  381. package/build-module/higher-order/with-spoken-messages/index.js +2 -0
  382. package/build-module/higher-order/with-spoken-messages/index.js.map +1 -1
  383. package/build-module/isolated-event-container/index.js +3 -0
  384. package/build-module/isolated-event-container/index.js.map +1 -1
  385. package/build-module/item-group/styles.js +10 -10
  386. package/build-module/item-group/styles.js.map +1 -1
  387. package/build-module/mobile/bottom-sheet/index.native.js +3 -5
  388. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  389. package/build-module/mobile/global-styles-context/utils.native.js +3 -2
  390. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  391. package/build-module/mobile/image/index.native.js +8 -28
  392. package/build-module/mobile/image/index.native.js.map +1 -1
  393. package/build-module/mobile/picker/index.android.js +3 -3
  394. package/build-module/mobile/picker/index.android.js.map +1 -1
  395. package/build-module/modal/index.js +1 -2
  396. package/build-module/modal/index.js.map +1 -1
  397. package/build-module/navigable-container/container.js +9 -7
  398. package/build-module/navigable-container/container.js.map +1 -1
  399. package/build-module/navigable-container/menu.js +3 -8
  400. package/build-module/navigable-container/menu.js.map +1 -1
  401. package/build-module/navigation/menu/menu-title-search.js +1 -2
  402. package/build-module/navigation/menu/menu-title-search.js.map +1 -1
  403. package/build-module/navigator/navigator-back-button/hook.js +0 -4
  404. package/build-module/navigator/navigator-back-button/hook.js.map +1 -1
  405. package/build-module/navigator/navigator-button/hook.js +0 -4
  406. package/build-module/navigator/navigator-button/hook.js.map +1 -1
  407. package/build-module/notice/list.js +10 -5
  408. package/build-module/notice/list.js.map +1 -1
  409. package/build-module/palette-edit/index.js +7 -2
  410. package/build-module/palette-edit/index.js.map +1 -1
  411. package/build-module/palette-edit/styles.js +10 -10
  412. package/build-module/palette-edit/styles.js.map +1 -1
  413. package/build-module/popover/index.js +93 -111
  414. package/build-module/popover/index.js.map +1 -1
  415. package/build-module/popover/utils.js +164 -0
  416. package/build-module/popover/utils.js.map +1 -0
  417. package/build-module/range-control/index.js +3 -0
  418. package/build-module/range-control/index.js.map +1 -1
  419. package/build-module/range-control/styles/range-control-styles.js +43 -37
  420. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  421. package/build-module/select-control/chevron-down.js +21 -0
  422. package/build-module/select-control/chevron-down.js.map +1 -0
  423. package/build-module/select-control/index.js +7 -7
  424. package/build-module/select-control/index.js.map +1 -1
  425. package/build-module/select-control/styles/select-control-styles.js +24 -13
  426. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  427. package/build-module/snackbar/list.js +5 -2
  428. package/build-module/snackbar/list.js.map +1 -1
  429. package/build-module/spinner/index.js +2 -0
  430. package/build-module/spinner/index.js.map +1 -1
  431. package/build-module/text/styles.js +7 -7
  432. package/build-module/text/styles.js.map +1 -1
  433. package/build-module/text-highlight/index.js +2 -5
  434. package/build-module/text-highlight/index.js.map +1 -1
  435. package/build-module/toggle-group-control/toggle-group-control/component.js +16 -8
  436. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  437. package/build-module/toggle-group-control/toggle-group-control/styles.js +20 -5
  438. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  439. package/build-module/toggle-group-control/toggle-group-control-option/component.js +17 -3
  440. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  441. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  442. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  443. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +16 -6
  444. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  445. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +27 -5
  446. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  447. package/build-module/tools-panel/styles.js +11 -11
  448. package/build-module/tools-panel/styles.js.map +1 -1
  449. package/build-module/tooltip/index.js +1 -6
  450. package/build-module/tooltip/index.js.map +1 -1
  451. package/build-module/tree-grid/index.js +4 -9
  452. package/build-module/tree-grid/index.js.map +1 -1
  453. package/build-module/ui/context/context-connect.js +1 -2
  454. package/build-module/ui/context/context-connect.js.map +1 -1
  455. package/build-module/unit-control/index.js +2 -2
  456. package/build-module/unit-control/index.js.map +1 -1
  457. package/build-module/utils/colors-values.js +52 -141
  458. package/build-module/utils/colors-values.js.map +1 -1
  459. package/build-module/utils/config-values.js +1 -1
  460. package/build-module/utils/config-values.js.map +1 -1
  461. package/build-module/utils/input/input-control.js +1 -1
  462. package/build-module/utils/input/input-control.js.map +1 -1
  463. package/build-module/utils/rtl.js +6 -4
  464. package/build-module/utils/rtl.js.map +1 -1
  465. package/build-module/utils/strings.js +48 -0
  466. package/build-module/utils/strings.js.map +1 -0
  467. package/build-style/style-rtl.css +202 -1272
  468. package/build-style/style.css +202 -1275
  469. package/build-types/animation/index.d.ts +2 -0
  470. package/build-types/{flyout → animation}/index.d.ts.map +1 -1
  471. package/build-types/card/card/component.d.ts +3 -3
  472. package/build-types/card/card/component.d.ts.map +1 -1
  473. package/build-types/card/card/hook.d.ts +7 -2
  474. package/build-types/card/card/hook.d.ts.map +1 -1
  475. package/build-types/card/card/index.d.ts +2 -2
  476. package/build-types/card/card/index.d.ts.map +1 -1
  477. package/build-types/card/card-body/component.d.ts +3 -3
  478. package/build-types/card/card-body/component.d.ts.map +1 -1
  479. package/build-types/card/card-body/hook.d.ts +5 -2
  480. package/build-types/card/card-body/hook.d.ts.map +1 -1
  481. package/build-types/card/card-body/index.d.ts +2 -2
  482. package/build-types/card/card-body/index.d.ts.map +1 -1
  483. package/build-types/card/card-divider/component.d.ts +3 -3
  484. package/build-types/card/card-divider/component.d.ts.map +1 -1
  485. package/build-types/card/card-divider/hook.d.ts +5 -2
  486. package/build-types/card/card-divider/hook.d.ts.map +1 -1
  487. package/build-types/card/card-divider/index.d.ts +2 -2
  488. package/build-types/card/card-divider/index.d.ts.map +1 -1
  489. package/build-types/card/card-footer/component.d.ts +3 -3
  490. package/build-types/card/card-footer/component.d.ts.map +1 -1
  491. package/build-types/card/card-footer/hook.d.ts +5 -2
  492. package/build-types/card/card-footer/hook.d.ts.map +1 -1
  493. package/build-types/card/card-footer/index.d.ts +2 -2
  494. package/build-types/card/card-footer/index.d.ts.map +1 -1
  495. package/build-types/card/card-header/component.d.ts +3 -3
  496. package/build-types/card/card-header/component.d.ts.map +1 -1
  497. package/build-types/card/card-header/hook.d.ts +5 -2
  498. package/build-types/card/card-header/hook.d.ts.map +1 -1
  499. package/build-types/card/card-header/index.d.ts +2 -2
  500. package/build-types/card/card-header/index.d.ts.map +1 -1
  501. package/build-types/card/card-media/component.d.ts +3 -4
  502. package/build-types/card/card-media/component.d.ts.map +1 -1
  503. package/build-types/card/card-media/hook.d.ts +6 -5
  504. package/build-types/card/card-media/hook.d.ts.map +1 -1
  505. package/build-types/card/card-media/index.d.ts +2 -2
  506. package/build-types/card/card-media/index.d.ts.map +1 -1
  507. package/build-types/card/context.d.ts +3 -2
  508. package/build-types/card/context.d.ts.map +1 -1
  509. package/build-types/card/index.d.ts +6 -6
  510. package/build-types/card/index.d.ts.map +1 -1
  511. package/build-types/card/stories/index.d.ts +12 -0
  512. package/build-types/card/stories/index.d.ts.map +1 -0
  513. package/build-types/card/styles.d.ts +20 -22
  514. package/build-types/card/styles.d.ts.map +1 -1
  515. package/build-types/card/test/index.d.ts +2 -0
  516. package/build-types/{flyout/flyout → card/test}/index.d.ts.map +1 -1
  517. package/build-types/card/types.d.ts +7 -1
  518. package/build-types/card/types.d.ts.map +1 -1
  519. package/build-types/clipboard-button/index.d.ts +16 -0
  520. package/build-types/clipboard-button/index.d.ts.map +1 -0
  521. package/build-types/color-palette/index.d.ts +2 -1
  522. package/build-types/color-palette/index.d.ts.map +1 -1
  523. package/build-types/color-picker/styles.d.ts +2 -2
  524. package/build-types/composite/index.d.ts +2 -0
  525. package/build-types/composite/index.d.ts.map +1 -0
  526. package/build-types/date-time/constants.d.ts +2 -0
  527. package/build-types/date-time/constants.d.ts.map +1 -0
  528. package/build-types/date-time/date/index.d.ts +4 -2
  529. package/build-types/date-time/date/index.d.ts.map +1 -1
  530. package/build-types/date-time/date/styles.d.ts +26 -8
  531. package/build-types/date-time/date/styles.d.ts.map +1 -1
  532. package/build-types/date-time/date/test/index.d.ts +1 -1
  533. package/build-types/date-time/date/test/index.d.ts.map +1 -1
  534. package/build-types/date-time/date-time/styles.d.ts +13 -0
  535. package/build-types/date-time/date-time/styles.d.ts.map +1 -1
  536. package/build-types/date-time/time/index.d.ts.map +1 -1
  537. package/build-types/date-time/time/styles.d.ts.map +1 -1
  538. package/build-types/date-time/utils.d.ts +8 -0
  539. package/build-types/date-time/utils.d.ts.map +1 -0
  540. package/build-types/disabled/index.d.ts +35 -28
  541. package/build-types/disabled/index.d.ts.map +1 -1
  542. package/build-types/disabled/stories/index.d.ts +13 -0
  543. package/build-types/disabled/stories/index.d.ts.map +1 -0
  544. package/build-types/disabled/styles/disabled-styles.d.ts +2 -1
  545. package/build-types/disabled/styles/disabled-styles.d.ts.map +1 -1
  546. package/build-types/disabled/test/index.d.ts +2 -0
  547. package/build-types/disabled/test/index.d.ts.map +1 -0
  548. package/build-types/disabled/types.d.ts +14 -0
  549. package/build-types/disabled/types.d.ts.map +1 -0
  550. package/build-types/disclosure/index.d.ts +2 -0
  551. package/build-types/disclosure/index.d.ts.map +1 -0
  552. package/build-types/dropdown/index.d.ts.map +1 -1
  553. package/build-types/dropdown-menu/index.d.ts.map +1 -1
  554. package/build-types/focusable-iframe/index.d.ts +8 -0
  555. package/build-types/focusable-iframe/index.d.ts.map +1 -0
  556. package/build-types/form-token-field/index.d.ts.map +1 -1
  557. package/build-types/form-token-field/stories/index.d.ts +1 -0
  558. package/build-types/form-token-field/stories/index.d.ts.map +1 -1
  559. package/build-types/form-token-field/test/index.d.ts +2 -0
  560. package/build-types/form-token-field/test/index.d.ts.map +1 -0
  561. package/build-types/form-token-field/types.d.ts +7 -0
  562. package/build-types/form-token-field/types.d.ts.map +1 -1
  563. package/build-types/higher-order/with-constrained-tabbing/index.d.ts +3 -0
  564. package/build-types/higher-order/with-constrained-tabbing/index.d.ts.map +1 -0
  565. package/build-types/higher-order/with-spoken-messages/index.d.ts +4 -0
  566. package/build-types/higher-order/with-spoken-messages/index.d.ts.map +1 -0
  567. package/build-types/isolated-event-container/index.d.ts +3 -0
  568. package/build-types/isolated-event-container/index.d.ts.map +1 -0
  569. package/build-types/mobile/inserter-button/sparkles.d.ts +3 -0
  570. package/build-types/mobile/inserter-button/sparkles.d.ts.map +1 -0
  571. package/build-types/navigable-container/menu.d.ts.map +1 -1
  572. package/build-types/navigator/navigator-back-button/hook.d.ts +0 -3
  573. package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
  574. package/build-types/navigator/navigator-button/hook.d.ts +0 -3
  575. package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
  576. package/build-types/placeholder/test/index.d.ts +2 -0
  577. package/build-types/placeholder/test/index.d.ts.map +1 -0
  578. package/build-types/popover/index.d.ts +1 -2
  579. package/build-types/popover/index.d.ts.map +1 -1
  580. package/build-types/popover/utils.d.ts +26 -69
  581. package/build-types/popover/utils.d.ts.map +1 -1
  582. package/build-types/radio-context/index.d.ts +6 -0
  583. package/build-types/radio-context/index.d.ts.map +1 -0
  584. package/build-types/range-control/index.d.ts +2 -2
  585. package/build-types/range-control/index.d.ts.map +1 -1
  586. package/build-types/range-control/styles/range-control-styles.d.ts +5 -2
  587. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  588. package/build-types/range-control/types.d.ts +2 -2
  589. package/build-types/range-control/types.d.ts.map +1 -1
  590. package/build-types/select-control/chevron-down.d.ts +4 -0
  591. package/build-types/select-control/chevron-down.d.ts.map +1 -0
  592. package/build-types/select-control/index.d.ts.map +1 -1
  593. package/build-types/select-control/styles/select-control-styles.d.ts +8 -0
  594. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  595. package/build-types/spinner/index.d.ts.map +1 -1
  596. package/build-types/text-highlight/index.d.ts +0 -3
  597. package/build-types/text-highlight/index.d.ts.map +1 -1
  598. package/build-types/toggle-group-control/stories/index.d.ts +25 -0
  599. package/build-types/toggle-group-control/stories/index.d.ts.map +1 -0
  600. package/build-types/toggle-group-control/test/index.d.ts +2 -0
  601. package/build-types/toggle-group-control/test/index.d.ts.map +1 -0
  602. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +6 -3
  603. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  604. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +5 -0
  605. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  606. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -7
  607. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
  608. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  609. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +4 -0
  610. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  611. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +11 -9
  612. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -1
  613. package/build-types/toggle-group-control/types.d.ts +23 -10
  614. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  615. package/build-types/tooltip/index.d.ts.map +1 -1
  616. package/build-types/ui/context/context-connect.d.ts +3 -0
  617. package/build-types/ui/context/context-connect.d.ts.map +1 -1
  618. package/build-types/ui/form-group/use-form-group.d.ts +2 -2
  619. package/build-types/unit-control/index.d.ts +2 -1
  620. package/build-types/unit-control/index.d.ts.map +1 -1
  621. package/build-types/unit-control/types.d.ts +5 -1
  622. package/build-types/unit-control/types.d.ts.map +1 -1
  623. package/build-types/utils/colors-values.d.ts +18 -97
  624. package/build-types/utils/colors-values.d.ts.map +1 -1
  625. package/build-types/utils/rtl.d.ts.map +1 -1
  626. package/build-types/utils/strings.d.ts +10 -0
  627. package/build-types/utils/strings.d.ts.map +1 -0
  628. package/package.json +22 -21
  629. package/src/alignment-matrix-control/index.js +1 -1
  630. package/src/alignment-matrix-control/stories/index.js +49 -24
  631. package/src/alignment-matrix-control/styles/alignment-matrix-control-styles.js +2 -3
  632. package/src/angle-picker-control/index.js +7 -1
  633. package/src/angle-picker-control/stories/index.js +8 -5
  634. package/src/angle-picker-control/styles/angle-picker-control-styles.js +12 -3
  635. package/src/autocomplete/get-default-use-items.js +6 -1
  636. package/src/autocomplete/index.js +11 -19
  637. package/src/base-control/styles/base-control-styles.ts +1 -1
  638. package/src/base-field/styles.js +1 -1
  639. package/src/base-field/test/__snapshots__/index.js.snap +2 -2
  640. package/src/box-control/styles/box-control-visualizer-styles.js +0 -1
  641. package/src/box-control/test/index.js +8 -8
  642. package/src/button/test/index.js +188 -146
  643. package/src/card/card/{component.js → component.tsx} +13 -9
  644. package/src/card/card/{hook.js → hook.ts} +11 -11
  645. package/src/card/card/{index.js → index.ts} +0 -0
  646. package/src/card/card-body/{component.js → component.tsx} +13 -9
  647. package/src/card/card-body/{hook.js → hook.ts} +5 -5
  648. package/src/card/card-body/{index.js → index.ts} +0 -0
  649. package/src/card/card-divider/{component.js → component.tsx} +16 -10
  650. package/src/card/card-divider/{hook.js → hook.ts} +5 -5
  651. package/src/card/card-divider/{index.js → index.ts} +0 -0
  652. package/src/card/card-footer/{component.js → component.tsx} +13 -9
  653. package/src/card/card-footer/{hook.js → hook.ts} +5 -5
  654. package/src/card/card-footer/{index.js → index.ts} +0 -0
  655. package/src/card/card-header/{component.js → component.tsx} +13 -9
  656. package/src/card/card-header/{hook.js → hook.ts} +5 -5
  657. package/src/card/card-header/{index.js → index.ts} +0 -0
  658. package/src/card/card-media/{component.js → component.tsx} +13 -8
  659. package/src/card/card-media/{hook.js → hook.ts} +5 -5
  660. package/src/card/card-media/{index.js → index.ts} +0 -0
  661. package/src/card/{context.js → context.ts} +0 -0
  662. package/src/card/{index.js → index.ts} +0 -0
  663. package/src/card/stories/index.tsx +75 -0
  664. package/src/card/{styles.js → styles.ts} +0 -0
  665. package/src/card/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
  666. package/src/card/test/{index.js → index.tsx} +3 -3
  667. package/src/card/types.ts +8 -1
  668. package/src/clipboard-button/index.js +13 -0
  669. package/src/color-list-picker/index.js +15 -3
  670. package/src/color-list-picker/style.scss +11 -0
  671. package/src/color-palette/index.js +40 -21
  672. package/src/color-palette/index.native.js +10 -6
  673. package/src/color-palette/stories/index.js +1 -1
  674. package/src/color-palette/style.scss +0 -14
  675. package/src/color-palette/test/__snapshots__/index.js.snap +28 -7
  676. package/src/combobox-control/index.js +6 -5
  677. package/src/combobox-control/stories/index.js +9 -3
  678. package/src/combobox-control/style.scss +0 -1
  679. package/src/confirm-dialog/test/index.js +85 -62
  680. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  681. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +54 -50
  682. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -3
  683. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/test/utils.js +0 -0
  684. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  685. package/src/custom-gradient-picker/index.js +30 -3
  686. package/src/custom-gradient-picker/stories/index.js +6 -2
  687. package/src/custom-gradient-picker/style.scss +30 -27
  688. package/src/custom-select-control/README.md +10 -0
  689. package/src/custom-select-control/index.js +22 -16
  690. package/src/custom-select-control/stories/index.js +1 -1
  691. package/src/custom-select-control/style.scss +0 -12
  692. package/src/custom-select-control/styles.ts +28 -0
  693. package/src/custom-select-control/test/index.js +4 -1
  694. package/src/date-time/constants.ts +1 -0
  695. package/src/date-time/date/index.tsx +310 -185
  696. package/src/date-time/date/styles.ts +92 -27
  697. package/src/date-time/date/test/index.tsx +24 -30
  698. package/src/date-time/date-time/index.tsx +3 -3
  699. package/src/date-time/date-time/styles.ts +9 -0
  700. package/src/date-time/time/index.tsx +23 -19
  701. package/src/date-time/time/styles.ts +1 -0
  702. package/src/date-time/utils.ts +17 -0
  703. package/src/dimension-control/index.js +1 -5
  704. package/src/disabled/index.tsx +80 -0
  705. package/src/disabled/stories/index.tsx +87 -0
  706. package/src/disabled/styles/{disabled-styles.js → disabled-styles.tsx} +0 -0
  707. package/src/disabled/test/index.tsx +174 -0
  708. package/src/disabled/types.ts +13 -0
  709. package/src/drop-zone/index.js +2 -3
  710. package/src/dropdown/index.js +3 -5
  711. package/src/dropdown-menu/index.js +1 -2
  712. package/src/dropdown-menu/index.native.js +0 -13
  713. package/src/dropdown-menu/stories/index.js +13 -2
  714. package/src/dropdown-menu/test/index.js +54 -58
  715. package/src/duotone-picker/custom-duotone-bar.js +1 -1
  716. package/src/duotone-picker/duotone-picker.js +34 -26
  717. package/src/duotone-picker/duotone-swatch.js +12 -5
  718. package/src/duotone-picker/stories/duotone-picker.js +66 -0
  719. package/src/duotone-picker/stories/duotone-swatch.js +32 -0
  720. package/src/focal-point-picker/README.md +3 -6
  721. package/src/focal-point-picker/controls.js +4 -4
  722. package/src/focal-point-picker/focal-point.js +2 -8
  723. package/src/focal-point-picker/grid.js +5 -41
  724. package/src/focal-point-picker/index.js +171 -308
  725. package/src/focal-point-picker/media.js +4 -28
  726. package/src/focal-point-picker/styles/focal-point-picker-style.js +5 -8
  727. package/src/focal-point-picker/styles/focal-point-style.js +0 -1
  728. package/src/focal-point-picker/test/index.js +79 -46
  729. package/src/focal-point-picker/utils.js +2 -6
  730. package/src/focusable-iframe/index.js +5 -0
  731. package/src/font-size-picker/index.js +161 -144
  732. package/src/font-size-picker/stories/index.js +1 -0
  733. package/src/font-size-picker/style.scss +8 -5
  734. package/src/font-size-picker/test/index.js +13 -6
  735. package/src/font-size-picker/test/{util.js → utils.js} +77 -1
  736. package/src/font-size-picker/utils.js +38 -23
  737. package/src/form-token-field/README.md +1 -0
  738. package/src/form-token-field/index.tsx +41 -33
  739. package/src/form-token-field/stories/index.tsx +8 -0
  740. package/src/form-token-field/test/index.tsx +2106 -0
  741. package/src/form-token-field/types.ts +7 -0
  742. package/src/gradient-picker/README.md +9 -0
  743. package/src/gradient-picker/index.js +31 -7
  744. package/src/gradient-picker/stories/index.js +57 -81
  745. package/src/guide/index.js +9 -4
  746. package/src/guide/page-control.js +1 -6
  747. package/src/guide/stories/index.js +12 -11
  748. package/src/guide/test/index.js +191 -37
  749. package/src/higher-order/with-constrained-tabbing/index.js +1 -1
  750. package/src/higher-order/with-notices/test/index.js +4 -2
  751. package/src/higher-order/with-spoken-messages/index.js +2 -0
  752. package/src/higher-order/with-spoken-messages/test/index.js +1 -1
  753. package/src/isolated-event-container/index.js +3 -0
  754. package/src/item-group/styles.ts +3 -3
  755. package/src/menu-group/test/index.js +18 -7
  756. package/src/mobile/bottom-sheet/index.native.js +2 -4
  757. package/src/mobile/global-styles-context/utils.native.js +8 -2
  758. package/src/mobile/image/index.native.js +9 -30
  759. package/src/mobile/picker/index.android.js +10 -4
  760. package/src/mobile/picker/styles.native.scss +4 -4
  761. package/src/modal/index.js +1 -2
  762. package/src/modal/test/index.js +11 -9
  763. package/src/navigable-container/container.js +12 -18
  764. package/src/navigable-container/menu.js +3 -7
  765. package/src/navigable-container/test/menu.js +14 -11
  766. package/src/navigation/menu/menu-title-search.js +1 -2
  767. package/src/navigator/navigator-back-button/hook.ts +0 -3
  768. package/src/navigator/navigator-button/hook.ts +0 -3
  769. package/src/notice/list.js +12 -10
  770. package/src/palette-edit/index.js +15 -10
  771. package/src/palette-edit/style.scss +3 -11
  772. package/src/palette-edit/styles.js +6 -5
  773. package/src/placeholder/README.md +1 -1
  774. package/src/placeholder/style.scss +62 -20
  775. package/src/placeholder/test/index.tsx +174 -0
  776. package/src/popover/index.js +129 -126
  777. package/src/popover/stories/index.js +17 -4
  778. package/src/popover/test/__snapshots__/index.js.snap +6 -6
  779. package/src/popover/test/index.js +129 -36
  780. package/src/popover/utils.js +107 -0
  781. package/src/range-control/index.tsx +3 -0
  782. package/src/range-control/styles/range-control-styles.ts +9 -4
  783. package/src/range-control/types.ts +5 -2
  784. package/src/select-control/chevron-down.tsx +25 -0
  785. package/src/select-control/index.tsx +6 -9
  786. package/src/select-control/styles/select-control-styles.ts +23 -14
  787. package/src/slot-fill/test/slot.js +5 -5
  788. package/src/snackbar/list.js +3 -2
  789. package/src/spinner/index.tsx +2 -0
  790. package/src/style.scss +0 -2
  791. package/src/text/styles.js +1 -1
  792. package/src/text/test/index.tsx +1 -1
  793. package/src/text-highlight/index.tsx +1 -5
  794. package/src/toggle-group-control/stories/index.tsx +127 -0
  795. package/src/toggle-group-control/test/__snapshots__/{index.js.snap → index.tsx.snap} +81 -57
  796. package/src/toggle-group-control/test/{index.js → index.tsx} +2 -4
  797. package/src/toggle-group-control/toggle-group-control/README.md +2 -0
  798. package/src/toggle-group-control/toggle-group-control/component.tsx +21 -11
  799. package/src/toggle-group-control/toggle-group-control/styles.ts +14 -6
  800. package/src/toggle-group-control/toggle-group-control-option/component.tsx +19 -3
  801. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +3 -0
  802. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +18 -0
  803. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +6 -8
  804. package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +30 -7
  805. package/src/toggle-group-control/types.ts +74 -59
  806. package/src/toolbar/test/index.js +4 -4
  807. package/src/toolbar-group/test/index.js +9 -15
  808. package/src/tools-panel/styles.ts +2 -2
  809. package/src/tools-panel/test/index.js +3 -2
  810. package/src/tooltip/index.js +1 -5
  811. package/src/tooltip/test/index.js +188 -172
  812. package/src/tree-grid/index.js +4 -9
  813. package/src/ui/context/context-connect.ts +3 -2
  814. package/src/unit-control/index.tsx +2 -2
  815. package/src/unit-control/types.ts +10 -1
  816. package/src/utils/colors-values.js +42 -137
  817. package/src/utils/config-values.js +1 -1
  818. package/src/utils/input/input-control.js +6 -6
  819. package/src/utils/rtl.js +6 -2
  820. package/src/utils/strings.ts +83 -0
  821. package/src/utils/test/strings.js +15 -0
  822. package/tsconfig.json +45 -77
  823. package/tsconfig.tsbuildinfo +1 -1
  824. package/build/custom-gradient-bar/constants.js.map +0 -1
  825. package/build/custom-gradient-bar/control-points.js.map +0 -1
  826. package/build/custom-gradient-bar/index.js.map +0 -1
  827. package/build/custom-gradient-bar/utils.js.map +0 -1
  828. package/build/date-time/date/utils.js +0 -34
  829. package/build/date-time/date/utils.js.map +0 -1
  830. package/build/swatch/index.js +0 -41
  831. package/build/swatch/index.js.map +0 -1
  832. package/build/ui/__storybook-utils/example-grid.js +0 -88
  833. package/build/ui/__storybook-utils/example-grid.js.map +0 -1
  834. package/build/ui/__storybook-utils/index.js +0 -19
  835. package/build/ui/__storybook-utils/index.js.map +0 -1
  836. package/build/ui/__storybook-utils/page.js +0 -43
  837. package/build/ui/__storybook-utils/page.js.map +0 -1
  838. package/build/utils/keyboard.js +0 -41
  839. package/build/utils/keyboard.js.map +0 -1
  840. package/build-module/custom-gradient-bar/constants.js.map +0 -1
  841. package/build-module/custom-gradient-bar/control-points.js.map +0 -1
  842. package/build-module/custom-gradient-bar/index.js.map +0 -1
  843. package/build-module/custom-gradient-bar/utils.js.map +0 -1
  844. package/build-module/date-time/date/utils.js +0 -22
  845. package/build-module/date-time/date/utils.js.map +0 -1
  846. package/build-module/swatch/index.js +0 -30
  847. package/build-module/swatch/index.js.map +0 -1
  848. package/build-module/ui/__storybook-utils/example-grid.js +0 -69
  849. package/build-module/ui/__storybook-utils/example-grid.js.map +0 -1
  850. package/build-module/ui/__storybook-utils/index.js +0 -2
  851. package/build-module/ui/__storybook-utils/index.js.map +0 -1
  852. package/build-module/ui/__storybook-utils/page.js +0 -32
  853. package/build-module/ui/__storybook-utils/page.js.map +0 -1
  854. package/build-module/utils/keyboard.js +0 -33
  855. package/build-module/utils/keyboard.js.map +0 -1
  856. package/build-types/color-picker/color-display.d.ts +0 -13
  857. package/build-types/color-picker/color-display.d.ts.map +0 -1
  858. package/build-types/date-time/date/test/utils.d.ts +0 -2
  859. package/build-types/date-time/date/test/utils.d.ts.map +0 -1
  860. package/build-types/date-time/date/utils.d.ts +0 -15
  861. package/build-types/date-time/date/utils.d.ts.map +0 -1
  862. package/build-types/flyout/context.d.ts +0 -6
  863. package/build-types/flyout/context.d.ts.map +0 -1
  864. package/build-types/flyout/flyout/component.d.ts +0 -21
  865. package/build-types/flyout/flyout/component.d.ts.map +0 -1
  866. package/build-types/flyout/flyout/hook.d.ts +0 -270
  867. package/build-types/flyout/flyout/hook.d.ts.map +0 -1
  868. package/build-types/flyout/flyout/index.d.ts +0 -3
  869. package/build-types/flyout/flyout-content/component.d.ts +0 -3
  870. package/build-types/flyout/flyout-content/component.d.ts.map +0 -1
  871. package/build-types/flyout/flyout-content/index.d.ts +0 -2
  872. package/build-types/flyout/flyout-content/index.d.ts.map +0 -1
  873. package/build-types/flyout/index.d.ts +0 -2
  874. package/build-types/flyout/styles.d.ts +0 -22
  875. package/build-types/flyout/styles.d.ts.map +0 -1
  876. package/build-types/flyout/types.d.ts +0 -80
  877. package/build-types/flyout/types.d.ts.map +0 -1
  878. package/build-types/flyout/utils.d.ts +0 -8
  879. package/build-types/flyout/utils.d.ts.map +0 -1
  880. package/build-types/form-token-field/test/lib/fixtures.d.ts +0 -26
  881. package/build-types/form-token-field/test/lib/fixtures.d.ts.map +0 -1
  882. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts +0 -21
  883. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts.map +0 -1
  884. package/build-types/swatch/index.d.ts +0 -5
  885. package/build-types/swatch/index.d.ts.map +0 -1
  886. package/build-types/swatch/types.d.ts +0 -11
  887. package/build-types/swatch/types.d.ts.map +0 -1
  888. package/build-types/utils/hooks/use-combined-ref.d.ts +0 -8
  889. package/build-types/utils/hooks/use-combined-ref.d.ts.map +0 -1
  890. package/build-types/utils/keyboard.d.ts +0 -12
  891. package/build-types/utils/keyboard.d.ts.map +0 -1
  892. package/src/card/stories/index.js +0 -209
  893. package/src/date-time/date/datepicker.scss +0 -863
  894. package/src/date-time/date/style.scss +0 -85
  895. package/src/date-time/date/test/utils.ts +0 -32
  896. package/src/date-time/date/utils.ts +0 -20
  897. package/src/date-time/style.scss +0 -1
  898. package/src/disabled/index.js +0 -55
  899. package/src/disabled/stories/index.js +0 -61
  900. package/src/disabled/test/index.js +0 -240
  901. package/src/form-token-field/test/index.js +0 -411
  902. package/src/form-token-field/test/lib/fixtures.js +0 -89
  903. package/src/form-token-field/test/lib/token-field-wrapper.tsx +0 -71
  904. package/src/guide/test/page-control.js +0 -43
  905. package/src/menu-group/test/__snapshots__/index.js.snap +0 -23
  906. package/src/placeholder/test/index.js +0 -163
  907. package/src/swatch/index.tsx +0 -22
  908. package/src/swatch/style.scss +0 -21
  909. package/src/swatch/types.ts +0 -11
  910. package/src/toggle-group-control/stories/index.js +0 -203
  911. package/src/tools-panel/test/__snapshots__/index.js.snap +0 -210
  912. package/src/ui/__storybook-utils/example-grid.js +0 -61
  913. package/src/ui/__storybook-utils/index.js +0 -1
  914. package/src/ui/__storybook-utils/page.js +0 -29
  915. package/src/utils/keyboard.js +0 -28
  916. package/src/utils/test/keyboard.js +0 -34
@@ -10,86 +10,32 @@ exports.default = void 0;
10
10
 
11
11
  var _element = require("@wordpress/element");
12
12
 
13
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+ var _useLilius = require("use-lilius");
14
14
 
15
- var _moment = _interopRequireDefault(require("moment"));
16
-
17
- require("react-dates/initialize");
18
-
19
- var _DayPickerSingleDateController = _interopRequireDefault(require("react-dates/lib/components/DayPickerSingleDateController"));
15
+ var _dateFns = require("date-fns");
20
16
 
21
17
  var _i18n = require("@wordpress/i18n");
22
18
 
23
19
  var _icons = require("@wordpress/icons");
24
20
 
25
- var _utils = require("./utils");
21
+ var _date = require("@wordpress/date");
26
22
 
27
23
  var _styles = require("./styles");
28
24
 
25
+ var _utils = require("../utils");
26
+
27
+ var _button = _interopRequireDefault(require("../../button"));
28
+
29
+ var _constants = require("../constants");
30
+
29
31
  /**
30
32
  * External dependencies
31
33
  */
32
- // Needed to initialise the default datepicker styles.
33
- // See: https://github.com/airbnb/react-dates#initialize
34
- // `react-dates` doesn't tree-shake correctly, so we import from the individual
35
- // component here.
36
34
 
37
35
  /**
38
36
  * WordPress dependencies
39
37
  */
40
38
 
41
- /**
42
- * Internal dependencies
43
- */
44
- const TIMEZONELESS_FORMAT = 'YYYY-MM-DDTHH:mm:ss';
45
- const ARIAL_LABEL_TIME_FORMAT = 'dddd, LL';
46
-
47
- const noop = () => {};
48
-
49
- function DatePickerDay(_ref) {
50
- let {
51
- day,
52
- events = []
53
- } = _ref;
54
- const ref = (0, _element.useRef)(null);
55
- /*
56
- * a11y hack to make the `There is/are n events` string
57
- * available speaking for readers,
58
- * re-defining the aria-label attribute.
59
- * This attribute is handled by the react-dates component.
60
- */
61
-
62
- (0, _element.useEffect)(() => {
63
- var _ref$current;
64
-
65
- // Bail when no parent node.
66
- if (!((ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.parentNode) instanceof Element)) {
67
- return;
68
- }
69
-
70
- const {
71
- parentNode
72
- } = ref.current;
73
- const dayAriaLabel = (0, _moment.default)(day).format(ARIAL_LABEL_TIME_FORMAT);
74
-
75
- if (!events.length) {
76
- // Set aria-label without event description.
77
- parentNode.setAttribute('aria-label', dayAriaLabel);
78
- return;
79
- }
80
-
81
- const dayWithEventsDescription = (0, _i18n.sprintf)( // translators: 1: Calendar day format, 2: Calendar event number.
82
- (0, _i18n._n)('%1$s. There is %2$d event.', '%1$s. There are %2$d events.', events.length), dayAriaLabel, events.length);
83
- parentNode.setAttribute('aria-label', dayWithEventsDescription);
84
- }, [day, events.length]);
85
- return (0, _element.createElement)(_styles.Day, {
86
- ref: ref,
87
- className: "components-datetime__date__day" // Unused, for backwards compatibility.
88
- ,
89
- hasEvents: !!(events !== null && events !== void 0 && events.length),
90
- alignment: "center"
91
- }, day.format('D'));
92
- }
93
39
  /**
94
40
  * DatePicker is a React component that renders a calendar for date selection.
95
41
  *
@@ -109,142 +55,204 @@ function DatePickerDay(_ref) {
109
55
  * };
110
56
  * ```
111
57
  */
112
-
113
-
114
- function DatePicker(_ref2) {
58
+ function DatePicker(_ref) {
115
59
  let {
116
60
  currentDate,
117
61
  onChange,
118
- events,
62
+ events = [],
119
63
  isInvalidDate,
120
64
  onMonthPreviewed,
121
- startOfWeek = 0
122
- } = _ref2;
123
- const nodeRef = (0, _element.useRef)(null);
124
-
125
- const onMonthPreviewedHandler = newMonthDate => {
126
- onMonthPreviewed === null || onMonthPreviewed === void 0 ? void 0 : onMonthPreviewed(newMonthDate.toISOString());
127
- keepFocusInside();
128
- };
129
- /*
130
- * Todo: We should remove this function ASAP.
131
- * It is kept because focus is lost when we click on the previous and next month buttons.
132
- * This focus loss closes the date picker popover.
133
- * Ideally we should add an upstream commit on react-dates to fix this issue.
134
- */
135
-
136
-
137
- const keepFocusInside = () => {
138
- if (!nodeRef.current) {
139
- return;
65
+ startOfWeek: weekStartsOn = 0
66
+ } = _ref;
67
+ const date = currentDate ? (0, _utils.inputToDate)(currentDate) : new Date();
68
+ const {
69
+ calendar,
70
+ viewing,
71
+ setSelected,
72
+ setViewing,
73
+ isSelected,
74
+ viewPreviousMonth,
75
+ viewNextMonth
76
+ } = (0, _useLilius.useLilius)({
77
+ selected: [(0, _dateFns.startOfDay)(date)],
78
+ viewing: (0, _dateFns.startOfDay)(date),
79
+ weekStartsOn
80
+ }); // Used to implement a roving tab index. Tracks the day that receives focus
81
+ // when the user tabs into the calendar.
82
+
83
+ const [focusable, setFocusable] = (0, _element.useState)((0, _dateFns.startOfDay)(date)); // Allows us to only programmatically focus() a day when focus was already
84
+ // within the calendar. This stops us stealing focus from e.g. a TimePicker
85
+ // input.
86
+
87
+ const [isFocusWithinCalendar, setIsFocusWithinCalendar] = (0, _element.useState)(false); // Update internal state when currentDate prop changes.
88
+
89
+ const [prevCurrentDate, setPrevCurrentDate] = (0, _element.useState)(currentDate);
90
+
91
+ if (currentDate !== prevCurrentDate) {
92
+ setPrevCurrentDate(currentDate);
93
+ setSelected([(0, _dateFns.startOfDay)(date)]);
94
+ setViewing((0, _dateFns.startOfDay)(date));
95
+ setFocusable((0, _dateFns.startOfDay)(date));
96
+ }
97
+
98
+ return (0, _element.createElement)(_styles.Wrapper, {
99
+ className: "components-datetime__date",
100
+ role: "application",
101
+ "aria-label": (0, _i18n.__)('Calendar')
102
+ }, (0, _element.createElement)(_styles.Navigator, null, (0, _element.createElement)(_button.default, {
103
+ icon: (0, _i18n.isRTL)() ? _icons.arrowRight : _icons.arrowLeft,
104
+ variant: "tertiary",
105
+ "aria-label": (0, _i18n.__)('View previous month'),
106
+ onClick: () => {
107
+ viewPreviousMonth();
108
+ setFocusable((0, _dateFns.subMonths)(focusable, 1));
109
+ onMonthPreviewed === null || onMonthPreviewed === void 0 ? void 0 : onMonthPreviewed((0, _dateFns.format)((0, _dateFns.subMonths)(viewing, 1), _constants.TIMEZONELESS_FORMAT));
140
110
  }
141
-
142
- const {
143
- ownerDocument
144
- } = nodeRef.current;
145
- const {
146
- activeElement
147
- } = ownerDocument; // If focus was lost.
148
-
149
- if (!activeElement || !nodeRef.current.contains(ownerDocument.activeElement)) {
150
- // Retrieve the focus region div.
151
- const focusRegion = nodeRef.current.querySelector('.DayPicker_focusRegion');
152
-
153
- if (!(focusRegion instanceof HTMLElement)) {
154
- return;
155
- } // Keep the focus on focus region.
156
-
157
-
158
- focusRegion.focus();
111
+ }), (0, _element.createElement)(_styles.NavigatorHeading, {
112
+ level: 3
113
+ }, (0, _element.createElement)("strong", null, (0, _date.dateI18n)('F', viewing, -viewing.getTimezoneOffset())), ' ', (0, _date.dateI18n)('Y', viewing, -viewing.getTimezoneOffset())), (0, _element.createElement)(_button.default, {
114
+ icon: (0, _i18n.isRTL)() ? _icons.arrowLeft : _icons.arrowRight,
115
+ variant: "tertiary",
116
+ "aria-label": (0, _i18n.__)('View next month'),
117
+ onClick: () => {
118
+ viewNextMonth();
119
+ setFocusable((0, _dateFns.addMonths)(focusable, 1));
120
+ onMonthPreviewed === null || onMonthPreviewed === void 0 ? void 0 : onMonthPreviewed((0, _dateFns.format)((0, _dateFns.addMonths)(viewing, 1), _constants.TIMEZONELESS_FORMAT));
159
121
  }
160
- };
161
-
162
- const onChangeMoment = newDate => {
163
- if (!newDate) {
164
- return;
165
- } // If currentDate is null, use now as momentTime to designate hours, minutes, seconds.
166
-
167
-
168
- const momentDate = currentDate ? (0, _moment.default)(currentDate) : (0, _moment.default)();
169
- const momentTime = {
170
- hours: momentDate.hours(),
171
- minutes: momentDate.minutes(),
172
- seconds: 0
173
- };
174
- onChange === null || onChange === void 0 ? void 0 : onChange(newDate.set(momentTime).format(TIMEZONELESS_FORMAT)); // Keep focus on the date picker.
175
-
176
- keepFocusInside();
177
- };
178
-
179
- const getEventsPerDay = day => {
180
- if (!(events !== null && events !== void 0 && events.length)) {
181
- return [];
122
+ })), (0, _element.createElement)(_styles.Calendar, {
123
+ onFocus: () => setIsFocusWithinCalendar(true),
124
+ onBlur: () => setIsFocusWithinCalendar(false)
125
+ }, calendar[0][0].map(day => (0, _element.createElement)(_styles.DayOfWeek, {
126
+ key: day.toString()
127
+ }, (0, _date.dateI18n)('D', day, -day.getTimezoneOffset()))), calendar[0].map(week => week.map((day, index) => {
128
+ if (!(0, _dateFns.isSameMonth)(day, viewing)) {
129
+ return null;
182
130
  }
183
131
 
184
- return events.filter(eventDay => day.isSame(eventDay.date, 'day'));
185
- };
132
+ return (0, _element.createElement)(Day, {
133
+ key: day.toString(),
134
+ day: day,
135
+ column: index + 1,
136
+ isSelected: isSelected(day),
137
+ isFocusable: (0, _dateFns.isEqual)(day, focusable),
138
+ isFocusAllowed: isFocusWithinCalendar,
139
+ isToday: (0, _dateFns.isSameDay)(day, new Date()),
140
+ isInvalid: isInvalidDate ? isInvalidDate(day) : false,
141
+ numEvents: events.filter(event => (0, _dateFns.isSameDay)(event.date, day)).length,
142
+ onClick: () => {
143
+ setSelected([day]);
144
+ setFocusable(day);
145
+ onChange === null || onChange === void 0 ? void 0 : onChange((0, _dateFns.format)( // Don't change the selected date's time fields.
146
+ new Date(day.getFullYear(), day.getMonth(), day.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()), _constants.TIMEZONELESS_FORMAT));
147
+ },
148
+ onKeyDown: event => {
149
+ let nextFocusable;
150
+
151
+ if (event.key === 'ArrowLeft') {
152
+ nextFocusable = (0, _dateFns.addDays)(day, (0, _i18n.isRTL)() ? 1 : -1);
153
+ }
154
+
155
+ if (event.key === 'ArrowRight') {
156
+ nextFocusable = (0, _dateFns.addDays)(day, (0, _i18n.isRTL)() ? -1 : 1);
157
+ }
158
+
159
+ if (event.key === 'ArrowUp') {
160
+ nextFocusable = (0, _dateFns.subWeeks)(day, 1);
161
+ }
162
+
163
+ if (event.key === 'ArrowDown') {
164
+ nextFocusable = (0, _dateFns.addWeeks)(day, 1);
165
+ }
166
+
167
+ if (event.key === 'PageUp') {
168
+ nextFocusable = (0, _dateFns.subMonths)(day, 1);
169
+ }
170
+
171
+ if (event.key === 'PageDown') {
172
+ nextFocusable = (0, _dateFns.addMonths)(day, 1);
173
+ }
174
+
175
+ if (event.key === 'Home') {
176
+ nextFocusable = (0, _dateFns.startOfWeek)(day);
177
+ }
178
+
179
+ if (event.key === 'End') {
180
+ nextFocusable = (0, _dateFns.startOfDay)((0, _dateFns.endOfWeek)(day));
181
+ }
182
+
183
+ if (nextFocusable) {
184
+ event.preventDefault();
185
+ setFocusable(nextFocusable);
186
+
187
+ if (!(0, _dateFns.isSameMonth)(nextFocusable, viewing)) {
188
+ setViewing(nextFocusable);
189
+ onMonthPreviewed === null || onMonthPreviewed === void 0 ? void 0 : onMonthPreviewed((0, _dateFns.format)(nextFocusable, _constants.TIMEZONELESS_FORMAT));
190
+ }
191
+ }
192
+ }
193
+ });
194
+ }))));
195
+ }
186
196
 
187
- const momentDate = (0, _utils.getMomentDate)(currentDate);
188
- return (0, _element.createElement)("div", {
189
- className: "components-datetime__date",
190
- ref: nodeRef
191
- }, (0, _element.createElement)(_DayPickerSingleDateController.default, {
192
- date: momentDate,
193
- initialVisibleMonth: null,
194
- daySize: 30,
195
- horizontalMonthPadding: 0,
196
- focused: true,
197
- hideKeyboardShortcutsPanel: true // This is a hack to force the calendar to update on month or year change
198
- // https://github.com/airbnb/react-dates/issues/240#issuecomment-361776665
197
+ function Day(_ref2) {
198
+ let {
199
+ day,
200
+ column,
201
+ isSelected,
202
+ isFocusable,
203
+ isFocusAllowed,
204
+ isToday,
205
+ isInvalid,
206
+ numEvents,
207
+ onClick,
208
+ onKeyDown
209
+ } = _ref2;
210
+ const ref = (0, _element.useRef)(); // Focus the day when it becomes focusable, e.g. because an arrow key is
211
+ // pressed. Only do this if focus is allowed - this stops us stealing focus
212
+ // from e.g. a TimePicker input.
213
+
214
+ (0, _element.useEffect)(() => {
215
+ if (ref.current && isFocusable && isFocusAllowed) {
216
+ ref.current.focus();
217
+ } // isFocusAllowed is not a dep as there is no point calling focus() on
218
+ // an already focused element.
219
+ // eslint-disable-next-line react-hooks/exhaustive-deps
220
+
221
+ }, [isFocusable]);
222
+ return (0, _element.createElement)(_styles.DayButton, {
223
+ ref: ref,
224
+ className: "components-datetime__date__day" // Unused, for backwards compatibility.
199
225
  ,
200
- key: `datepicker-controller-${momentDate ? momentDate.format('MM-YYYY') : 'null'}`,
201
- noBorder: true,
202
- numberOfMonths: 1,
203
- onDateChange: onChangeMoment,
204
- transitionDuration: 0,
205
- weekDayFormat: "ddd",
206
- dayAriaLabelFormat: ARIAL_LABEL_TIME_FORMAT,
207
- isRTL: (0, _i18n.isRTL)(),
208
- isOutsideRange: date => {
209
- return !!isInvalidDate && isInvalidDate(date.toDate());
210
- },
211
- firstDayOfWeek: startOfWeek,
212
- onPrevMonthClick: onMonthPreviewedHandler,
213
- onNextMonthClick: onMonthPreviewedHandler,
214
- renderDayContents: day => (0, _element.createElement)(DatePickerDay, {
215
- day: day,
216
- events: getEventsPerDay(day)
217
- }),
218
- renderMonthElement: _ref3 => {
219
- let {
220
- month
221
- } = _ref3;
222
- return (0, _element.createElement)(_element.Fragment, null, (0, _element.createElement)("strong", null, month.format('MMMM')), ' ', month.format('YYYY'));
223
- },
224
- renderNavPrevButton: _ref4 => {
225
- let {
226
- ariaLabel,
227
- ...props
228
- } = _ref4;
229
- return (0, _element.createElement)(_styles.NavPrevButton, (0, _extends2.default)({
230
- icon: _icons.arrowLeft,
231
- variant: "tertiary",
232
- "aria-label": ariaLabel
233
- }, props));
234
- },
235
- renderNavNextButton: _ref5 => {
236
- let {
237
- ariaLabel,
238
- ...props
239
- } = _ref5;
240
- return (0, _element.createElement)(_styles.NavNextButton, (0, _extends2.default)({
241
- icon: _icons.arrowRight,
242
- variant: "tertiary",
243
- "aria-label": ariaLabel
244
- }, props));
245
- },
246
- onFocusChange: noop
247
- }));
226
+ disabled: isInvalid,
227
+ tabIndex: isFocusable ? 0 : -1,
228
+ "aria-label": getDayLabel(day, isSelected, numEvents),
229
+ column: column,
230
+ isSelected: isSelected,
231
+ isToday: isToday,
232
+ hasEvents: numEvents > 0,
233
+ onClick: onClick,
234
+ onKeyDown: onKeyDown
235
+ }, (0, _date.dateI18n)('j', day, -day.getTimezoneOffset()));
236
+ }
237
+
238
+ function getDayLabel(date, isSelected, numEvents) {
239
+ const {
240
+ formats
241
+ } = (0, _date.__experimentalGetSettings)();
242
+ const localizedDate = (0, _date.dateI18n)(formats.date, date, -date.getTimezoneOffset());
243
+
244
+ if (isSelected && numEvents > 0) {
245
+ return (0, _i18n.sprintf)( // translators: 1: The calendar date. 2: Number of events on the calendar date.
246
+ (0, _i18n._n)('%1$s. Selected. There is %2$d event', '%1$s. Selected. There are %2$d events', numEvents), localizedDate, numEvents);
247
+ } else if (isSelected) {
248
+ return (0, _i18n.sprintf)( // translators: %s: The calendar date.
249
+ (0, _i18n.__)('%1$s. Selected'), localizedDate);
250
+ } else if (numEvents > 0) {
251
+ return (0, _i18n.sprintf)( // translators: 1: The calendar date. 2: Number of events on the calendar date.
252
+ (0, _i18n._n)('%1$s. There is %2$d event', '%1$s. There are %2$d events', numEvents), localizedDate, numEvents);
253
+ }
254
+
255
+ return localizedDate;
248
256
  }
249
257
 
250
258
  var _default = DatePicker;
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/date-time/date/index.tsx"],"names":["TIMEZONELESS_FORMAT","ARIAL_LABEL_TIME_FORMAT","noop","DatePickerDay","day","events","ref","current","parentNode","Element","dayAriaLabel","format","length","setAttribute","dayWithEventsDescription","DatePicker","currentDate","onChange","isInvalidDate","onMonthPreviewed","startOfWeek","nodeRef","onMonthPreviewedHandler","newMonthDate","toISOString","keepFocusInside","ownerDocument","activeElement","contains","focusRegion","querySelector","HTMLElement","focus","onChangeMoment","newDate","momentDate","momentTime","hours","minutes","seconds","set","getEventsPerDay","filter","eventDay","isSame","date","toDate","month","ariaLabel","props","arrowLeft","arrowRight"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport moment from 'moment';\nimport type { Moment } from 'moment';\n// Needed to initialise the default datepicker styles.\n// See: https://github.com/airbnb/react-dates#initialize\nimport 'react-dates/initialize';\n// `react-dates` doesn't tree-shake correctly, so we import from the individual\n// component here.\nimport DayPickerSingleDateController from 'react-dates/lib/components/DayPickerSingleDateController';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useRef } from '@wordpress/element';\nimport { isRTL, _n, sprintf } from '@wordpress/i18n';\nimport { arrowLeft, arrowRight } from '@wordpress/icons';\n\n/**\n * Internal dependencies\n */\nimport { getMomentDate } from './utils';\nimport type { DatePickerDayProps, DatePickerProps } from '../types';\nimport { Day, NavPrevButton, NavNextButton } from './styles';\n\nconst TIMEZONELESS_FORMAT = 'YYYY-MM-DDTHH:mm:ss';\nconst ARIAL_LABEL_TIME_FORMAT = 'dddd, LL';\nconst noop = () => {};\n\nfunction DatePickerDay( { day, events = [] }: DatePickerDayProps ) {\n\tconst ref = useRef< HTMLDivElement >( null );\n\n\t/*\n\t * a11y hack to make the `There is/are n events` string\n\t * available speaking for readers,\n\t * re-defining the aria-label attribute.\n\t * This attribute is handled by the react-dates component.\n\t */\n\tuseEffect( () => {\n\t\t// Bail when no parent node.\n\t\tif ( ! ( ref?.current?.parentNode instanceof Element ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst { parentNode } = ref.current;\n\t\tconst dayAriaLabel = moment( day ).format( ARIAL_LABEL_TIME_FORMAT );\n\n\t\tif ( ! events.length ) {\n\t\t\t// Set aria-label without event description.\n\t\t\tparentNode.setAttribute( 'aria-label', dayAriaLabel );\n\t\t\treturn;\n\t\t}\n\n\t\tconst dayWithEventsDescription = sprintf(\n\t\t\t// translators: 1: Calendar day format, 2: Calendar event number.\n\t\t\t_n(\n\t\t\t\t'%1$s. There is %2$d event.',\n\t\t\t\t'%1$s. There are %2$d events.',\n\t\t\t\tevents.length\n\t\t\t),\n\t\t\tdayAriaLabel,\n\t\t\tevents.length\n\t\t);\n\n\t\tparentNode.setAttribute( 'aria-label', dayWithEventsDescription );\n\t}, [ day, events.length ] );\n\n\treturn (\n\t\t<Day\n\t\t\tref={ ref }\n\t\t\tclassName=\"components-datetime__date__day\" // Unused, for backwards compatibility.\n\t\t\thasEvents={ !! events?.length }\n\t\t\talignment=\"center\"\n\t\t>\n\t\t\t{ day.format( 'D' ) }\n\t\t</Day>\n\t);\n}\n\n/**\n * DatePicker is a React component that renders a calendar for date selection.\n *\n * ```jsx\n * import { DatePicker } from '@wordpress/components';\n * import { useState } from '@wordpress/element';\n *\n * const MyDatePicker = () => {\n * const [ date, setDate ] = useState( new Date() );\n *\n * return (\n * <DatePicker\n * currentDate={ date }\n * onChange={ ( newDate ) => setDate( newDate ) }\n * />\n * );\n * };\n * ```\n */\nexport function DatePicker( {\n\tcurrentDate,\n\tonChange,\n\tevents,\n\tisInvalidDate,\n\tonMonthPreviewed,\n\tstartOfWeek = 0,\n}: DatePickerProps ) {\n\tconst nodeRef = useRef< HTMLDivElement >( null );\n\n\tconst onMonthPreviewedHandler = ( newMonthDate: Moment ) => {\n\t\tonMonthPreviewed?.( newMonthDate.toISOString() );\n\t\tkeepFocusInside();\n\t};\n\n\t/*\n\t * Todo: We should remove this function ASAP.\n\t * It is kept because focus is lost when we click on the previous and next month buttons.\n\t * This focus loss closes the date picker popover.\n\t * Ideally we should add an upstream commit on react-dates to fix this issue.\n\t */\n\tconst keepFocusInside = () => {\n\t\tif ( ! nodeRef.current ) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst { ownerDocument } = nodeRef.current;\n\t\tconst { activeElement } = ownerDocument;\n\n\t\t// If focus was lost.\n\t\tif (\n\t\t\t! activeElement ||\n\t\t\t! nodeRef.current.contains( ownerDocument.activeElement )\n\t\t) {\n\t\t\t// Retrieve the focus region div.\n\t\t\tconst focusRegion = nodeRef.current.querySelector(\n\t\t\t\t'.DayPicker_focusRegion'\n\t\t\t);\n\t\t\tif ( ! ( focusRegion instanceof HTMLElement ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t// Keep the focus on focus region.\n\t\t\tfocusRegion.focus();\n\t\t}\n\t};\n\n\tconst onChangeMoment = ( newDate: Moment | null ) => {\n\t\tif ( ! newDate ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// If currentDate is null, use now as momentTime to designate hours, minutes, seconds.\n\t\tconst momentDate = currentDate ? moment( currentDate ) : moment();\n\t\tconst momentTime = {\n\t\t\thours: momentDate.hours(),\n\t\t\tminutes: momentDate.minutes(),\n\t\t\tseconds: 0,\n\t\t};\n\n\t\tonChange?.( newDate.set( momentTime ).format( TIMEZONELESS_FORMAT ) );\n\n\t\t// Keep focus on the date picker.\n\t\tkeepFocusInside();\n\t};\n\n\tconst getEventsPerDay = ( day: Moment ) => {\n\t\tif ( ! events?.length ) {\n\t\t\treturn [];\n\t\t}\n\n\t\treturn events.filter( ( eventDay ) =>\n\t\t\tday.isSame( eventDay.date, 'day' )\n\t\t);\n\t};\n\n\tconst momentDate = getMomentDate( currentDate );\n\n\treturn (\n\t\t<div className=\"components-datetime__date\" ref={ nodeRef }>\n\t\t\t<DayPickerSingleDateController\n\t\t\t\tdate={ momentDate }\n\t\t\t\tinitialVisibleMonth={ null }\n\t\t\t\tdaySize={ 30 }\n\t\t\t\thorizontalMonthPadding={ 0 }\n\t\t\t\tfocused\n\t\t\t\thideKeyboardShortcutsPanel\n\t\t\t\t// This is a hack to force the calendar to update on month or year change\n\t\t\t\t// https://github.com/airbnb/react-dates/issues/240#issuecomment-361776665\n\t\t\t\tkey={ `datepicker-controller-${\n\t\t\t\t\tmomentDate ? momentDate.format( 'MM-YYYY' ) : 'null'\n\t\t\t\t}` }\n\t\t\t\tnoBorder\n\t\t\t\tnumberOfMonths={ 1 }\n\t\t\t\tonDateChange={ onChangeMoment }\n\t\t\t\ttransitionDuration={ 0 }\n\t\t\t\tweekDayFormat=\"ddd\"\n\t\t\t\tdayAriaLabelFormat={ ARIAL_LABEL_TIME_FORMAT }\n\t\t\t\tisRTL={ isRTL() }\n\t\t\t\tisOutsideRange={ ( date ) => {\n\t\t\t\t\treturn !! isInvalidDate && isInvalidDate( date.toDate() );\n\t\t\t\t} }\n\t\t\t\tfirstDayOfWeek={ startOfWeek }\n\t\t\t\tonPrevMonthClick={ onMonthPreviewedHandler }\n\t\t\t\tonNextMonthClick={ onMonthPreviewedHandler }\n\t\t\t\trenderDayContents={ ( day ) => (\n\t\t\t\t\t<DatePickerDay\n\t\t\t\t\t\tday={ day }\n\t\t\t\t\t\tevents={ getEventsPerDay( day ) }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\trenderMonthElement={ ( { month } ) => (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<strong>{ month.format( 'MMMM' ) }</strong>{ ' ' }\n\t\t\t\t\t\t{ month.format( 'YYYY' ) }\n\t\t\t\t\t</>\n\t\t\t\t) }\n\t\t\t\trenderNavPrevButton={ ( { ariaLabel, ...props } ) => (\n\t\t\t\t\t<NavPrevButton\n\t\t\t\t\t\ticon={ arrowLeft }\n\t\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\t\taria-label={ ariaLabel }\n\t\t\t\t\t\t{ ...props }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\trenderNavNextButton={ ( { ariaLabel, ...props } ) => (\n\t\t\t\t\t<NavNextButton\n\t\t\t\t\t\ticon={ arrowRight }\n\t\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\t\taria-label={ ariaLabel }\n\t\t\t\t\t\t{ ...props }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\tonFocusChange={ noop }\n\t\t\t/>\n\t\t</div>\n\t);\n}\n\nexport default DatePicker;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/date-time/date/index.tsx"],"names":["DatePicker","currentDate","onChange","events","isInvalidDate","onMonthPreviewed","startOfWeek","weekStartsOn","date","Date","calendar","viewing","setSelected","setViewing","isSelected","viewPreviousMonth","viewNextMonth","selected","focusable","setFocusable","isFocusWithinCalendar","setIsFocusWithinCalendar","prevCurrentDate","setPrevCurrentDate","arrowRight","arrowLeft","TIMEZONELESS_FORMAT","getTimezoneOffset","map","day","toString","week","index","filter","event","length","getFullYear","getMonth","getDate","getHours","getMinutes","getSeconds","getMilliseconds","nextFocusable","key","preventDefault","Day","column","isFocusable","isFocusAllowed","isToday","isInvalid","numEvents","onClick","onKeyDown","ref","current","focus","getDayLabel","formats","localizedDate"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { useLilius } from 'use-lilius';\nimport {\n\tformat,\n\tisSameDay,\n\tsubMonths,\n\taddMonths,\n\tstartOfDay,\n\tisEqual,\n\taddDays,\n\tsubWeeks,\n\taddWeeks,\n\tisSameMonth,\n\tstartOfWeek,\n\tendOfWeek,\n} from 'date-fns';\n\n/**\n * WordPress dependencies\n */\nimport { __, _n, sprintf, isRTL } from '@wordpress/i18n';\nimport { arrowLeft, arrowRight } from '@wordpress/icons';\nimport { dateI18n, __experimentalGetSettings } from '@wordpress/date';\nimport { useState, useRef, useEffect } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport type { DatePickerProps } from '../types';\nimport {\n\tWrapper,\n\tNavigator,\n\tNavigatorHeading,\n\tCalendar,\n\tDayOfWeek,\n\tDayButton,\n} from './styles';\nimport { inputToDate } from '../utils';\nimport Button from '../../button';\nimport { TIMEZONELESS_FORMAT } from '../constants';\n\n/**\n * DatePicker is a React component that renders a calendar for date selection.\n *\n * ```jsx\n * import { DatePicker } from '@wordpress/components';\n * import { useState } from '@wordpress/element';\n *\n * const MyDatePicker = () => {\n * const [ date, setDate ] = useState( new Date() );\n *\n * return (\n * <DatePicker\n * currentDate={ date }\n * onChange={ ( newDate ) => setDate( newDate ) }\n * />\n * );\n * };\n * ```\n */\nexport function DatePicker( {\n\tcurrentDate,\n\tonChange,\n\tevents = [],\n\tisInvalidDate,\n\tonMonthPreviewed,\n\tstartOfWeek: weekStartsOn = 0,\n}: DatePickerProps ) {\n\tconst date = currentDate ? inputToDate( currentDate ) : new Date();\n\n\tconst {\n\t\tcalendar,\n\t\tviewing,\n\t\tsetSelected,\n\t\tsetViewing,\n\t\tisSelected,\n\t\tviewPreviousMonth,\n\t\tviewNextMonth,\n\t} = useLilius( {\n\t\tselected: [ startOfDay( date ) ],\n\t\tviewing: startOfDay( date ),\n\t\tweekStartsOn,\n\t} );\n\n\t// Used to implement a roving tab index. Tracks the day that receives focus\n\t// when the user tabs into the calendar.\n\tconst [ focusable, setFocusable ] = useState( startOfDay( date ) );\n\n\t// Allows us to only programmatically focus() a day when focus was already\n\t// within the calendar. This stops us stealing focus from e.g. a TimePicker\n\t// input.\n\tconst [ isFocusWithinCalendar, setIsFocusWithinCalendar ] =\n\t\tuseState( false );\n\n\t// Update internal state when currentDate prop changes.\n\tconst [ prevCurrentDate, setPrevCurrentDate ] = useState( currentDate );\n\tif ( currentDate !== prevCurrentDate ) {\n\t\tsetPrevCurrentDate( currentDate );\n\t\tsetSelected( [ startOfDay( date ) ] );\n\t\tsetViewing( startOfDay( date ) );\n\t\tsetFocusable( startOfDay( date ) );\n\t}\n\n\treturn (\n\t\t<Wrapper\n\t\t\tclassName=\"components-datetime__date\"\n\t\t\trole=\"application\"\n\t\t\taria-label={ __( 'Calendar' ) }\n\t\t>\n\t\t\t<Navigator>\n\t\t\t\t<Button\n\t\t\t\t\ticon={ isRTL() ? arrowRight : arrowLeft }\n\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\taria-label={ __( 'View previous month' ) }\n\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\tviewPreviousMonth();\n\t\t\t\t\t\tsetFocusable( subMonths( focusable, 1 ) );\n\t\t\t\t\t\tonMonthPreviewed?.(\n\t\t\t\t\t\t\tformat(\n\t\t\t\t\t\t\t\tsubMonths( viewing, 1 ),\n\t\t\t\t\t\t\t\tTIMEZONELESS_FORMAT\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\t\t\t\t\t} }\n\t\t\t\t/>\n\t\t\t\t<NavigatorHeading level={ 3 }>\n\t\t\t\t\t<strong>\n\t\t\t\t\t\t{ dateI18n(\n\t\t\t\t\t\t\t'F',\n\t\t\t\t\t\t\tviewing,\n\t\t\t\t\t\t\t-viewing.getTimezoneOffset()\n\t\t\t\t\t\t) }\n\t\t\t\t\t</strong>{ ' ' }\n\t\t\t\t\t{ dateI18n( 'Y', viewing, -viewing.getTimezoneOffset() ) }\n\t\t\t\t</NavigatorHeading>\n\t\t\t\t<Button\n\t\t\t\t\ticon={ isRTL() ? arrowLeft : arrowRight }\n\t\t\t\t\tvariant=\"tertiary\"\n\t\t\t\t\taria-label={ __( 'View next month' ) }\n\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\tviewNextMonth();\n\t\t\t\t\t\tsetFocusable( addMonths( focusable, 1 ) );\n\t\t\t\t\t\tonMonthPreviewed?.(\n\t\t\t\t\t\t\tformat(\n\t\t\t\t\t\t\t\taddMonths( viewing, 1 ),\n\t\t\t\t\t\t\t\tTIMEZONELESS_FORMAT\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\t\t\t\t\t} }\n\t\t\t\t/>\n\t\t\t</Navigator>\n\t\t\t<Calendar\n\t\t\t\tonFocus={ () => setIsFocusWithinCalendar( true ) }\n\t\t\t\tonBlur={ () => setIsFocusWithinCalendar( false ) }\n\t\t\t>\n\t\t\t\t{ calendar[ 0 ][ 0 ].map( ( day ) => (\n\t\t\t\t\t<DayOfWeek key={ day.toString() }>\n\t\t\t\t\t\t{ dateI18n( 'D', day, -day.getTimezoneOffset() ) }\n\t\t\t\t\t</DayOfWeek>\n\t\t\t\t) ) }\n\t\t\t\t{ calendar[ 0 ].map( ( week ) =>\n\t\t\t\t\tweek.map( ( day, index ) => {\n\t\t\t\t\t\tif ( ! isSameMonth( day, viewing ) ) {\n\t\t\t\t\t\t\treturn null;\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<Day\n\t\t\t\t\t\t\t\tkey={ day.toString() }\n\t\t\t\t\t\t\t\tday={ day }\n\t\t\t\t\t\t\t\tcolumn={ index + 1 }\n\t\t\t\t\t\t\t\tisSelected={ isSelected( day ) }\n\t\t\t\t\t\t\t\tisFocusable={ isEqual( day, focusable ) }\n\t\t\t\t\t\t\t\tisFocusAllowed={ isFocusWithinCalendar }\n\t\t\t\t\t\t\t\tisToday={ isSameDay( day, new Date() ) }\n\t\t\t\t\t\t\t\tisInvalid={\n\t\t\t\t\t\t\t\t\tisInvalidDate ? isInvalidDate( day ) : false\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tnumEvents={\n\t\t\t\t\t\t\t\t\tevents.filter( ( event ) =>\n\t\t\t\t\t\t\t\t\t\tisSameDay( event.date, day )\n\t\t\t\t\t\t\t\t\t).length\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\tsetSelected( [ day ] );\n\t\t\t\t\t\t\t\t\tsetFocusable( day );\n\t\t\t\t\t\t\t\t\tonChange?.(\n\t\t\t\t\t\t\t\t\t\tformat(\n\t\t\t\t\t\t\t\t\t\t\t// Don't change the selected date's time fields.\n\t\t\t\t\t\t\t\t\t\t\tnew Date(\n\t\t\t\t\t\t\t\t\t\t\t\tday.getFullYear(),\n\t\t\t\t\t\t\t\t\t\t\t\tday.getMonth(),\n\t\t\t\t\t\t\t\t\t\t\t\tday.getDate(),\n\t\t\t\t\t\t\t\t\t\t\t\tdate.getHours(),\n\t\t\t\t\t\t\t\t\t\t\t\tdate.getMinutes(),\n\t\t\t\t\t\t\t\t\t\t\t\tdate.getSeconds(),\n\t\t\t\t\t\t\t\t\t\t\t\tdate.getMilliseconds()\n\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t\tTIMEZONELESS_FORMAT\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\tonKeyDown={ ( event ) => {\n\t\t\t\t\t\t\t\t\tlet nextFocusable;\n\t\t\t\t\t\t\t\t\tif ( event.key === 'ArrowLeft' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = addDays(\n\t\t\t\t\t\t\t\t\t\t\tday,\n\t\t\t\t\t\t\t\t\t\t\tisRTL() ? 1 : -1\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'ArrowRight' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = addDays(\n\t\t\t\t\t\t\t\t\t\t\tday,\n\t\t\t\t\t\t\t\t\t\t\tisRTL() ? -1 : 1\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'ArrowUp' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = subWeeks( day, 1 );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'ArrowDown' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = addWeeks( day, 1 );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'PageUp' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = subMonths( day, 1 );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'PageDown' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = addMonths( day, 1 );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'Home' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = startOfWeek( day );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( event.key === 'End' ) {\n\t\t\t\t\t\t\t\t\t\tnextFocusable = startOfDay(\n\t\t\t\t\t\t\t\t\t\t\tendOfWeek( day )\n\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ( nextFocusable ) {\n\t\t\t\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\t\t\t\tsetFocusable( nextFocusable );\n\t\t\t\t\t\t\t\t\t\tif (\n\t\t\t\t\t\t\t\t\t\t\t! isSameMonth(\n\t\t\t\t\t\t\t\t\t\t\t\tnextFocusable,\n\t\t\t\t\t\t\t\t\t\t\t\tviewing\n\t\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\t\t\t\tsetViewing( nextFocusable );\n\t\t\t\t\t\t\t\t\t\t\tonMonthPreviewed?.(\n\t\t\t\t\t\t\t\t\t\t\t\tformat(\n\t\t\t\t\t\t\t\t\t\t\t\t\tnextFocusable,\n\t\t\t\t\t\t\t\t\t\t\t\t\tTIMEZONELESS_FORMAT\n\t\t\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t);\n\t\t\t\t\t} )\n\t\t\t\t) }\n\t\t\t</Calendar>\n\t\t</Wrapper>\n\t);\n}\n\ntype DayProps = {\n\tday: Date;\n\tcolumn: number;\n\tisSelected: boolean;\n\tisFocusable: boolean;\n\tisFocusAllowed: boolean;\n\tisToday: boolean;\n\tnumEvents: number;\n\tisInvalid: boolean;\n\tonClick: () => void;\n\tonKeyDown: ( event: KeyboardEvent ) => void;\n};\n\nfunction Day( {\n\tday,\n\tcolumn,\n\tisSelected,\n\tisFocusable,\n\tisFocusAllowed,\n\tisToday,\n\tisInvalid,\n\tnumEvents,\n\tonClick,\n\tonKeyDown,\n}: DayProps ) {\n\tconst ref = useRef< HTMLButtonElement >();\n\n\t// Focus the day when it becomes focusable, e.g. because an arrow key is\n\t// pressed. Only do this if focus is allowed - this stops us stealing focus\n\t// from e.g. a TimePicker input.\n\tuseEffect( () => {\n\t\tif ( ref.current && isFocusable && isFocusAllowed ) {\n\t\t\tref.current.focus();\n\t\t}\n\t\t// isFocusAllowed is not a dep as there is no point calling focus() on\n\t\t// an already focused element.\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [ isFocusable ] );\n\n\treturn (\n\t\t<DayButton\n\t\t\tref={ ref }\n\t\t\tclassName=\"components-datetime__date__day\" // Unused, for backwards compatibility.\n\t\t\tdisabled={ isInvalid }\n\t\t\ttabIndex={ isFocusable ? 0 : -1 }\n\t\t\taria-label={ getDayLabel( day, isSelected, numEvents ) }\n\t\t\tcolumn={ column }\n\t\t\tisSelected={ isSelected }\n\t\t\tisToday={ isToday }\n\t\t\thasEvents={ numEvents > 0 }\n\t\t\tonClick={ onClick }\n\t\t\tonKeyDown={ onKeyDown }\n\t\t>\n\t\t\t{ dateI18n( 'j', day, -day.getTimezoneOffset() ) }\n\t\t</DayButton>\n\t);\n}\n\nfunction getDayLabel( date: Date, isSelected: boolean, numEvents: number ) {\n\tconst { formats } = __experimentalGetSettings();\n\tconst localizedDate = dateI18n(\n\t\tformats.date,\n\t\tdate,\n\t\t-date.getTimezoneOffset()\n\t);\n\tif ( isSelected && numEvents > 0 ) {\n\t\treturn sprintf(\n\t\t\t// translators: 1: The calendar date. 2: Number of events on the calendar date.\n\t\t\t_n(\n\t\t\t\t'%1$s. Selected. There is %2$d event',\n\t\t\t\t'%1$s. Selected. There are %2$d events',\n\t\t\t\tnumEvents\n\t\t\t),\n\t\t\tlocalizedDate,\n\t\t\tnumEvents\n\t\t);\n\t} else if ( isSelected ) {\n\t\treturn sprintf(\n\t\t\t// translators: %s: The calendar date.\n\t\t\t__( '%1$s. Selected' ),\n\t\t\tlocalizedDate\n\t\t);\n\t} else if ( numEvents > 0 ) {\n\t\treturn sprintf(\n\t\t\t// translators: 1: The calendar date. 2: Number of events on the calendar date.\n\t\t\t_n(\n\t\t\t\t'%1$s. There is %2$d event',\n\t\t\t\t'%1$s. There are %2$d events',\n\t\t\t\tnumEvents\n\t\t\t),\n\t\t\tlocalizedDate,\n\t\t\tnumEvents\n\t\t);\n\t}\n\treturn localizedDate;\n}\n\nexport default DatePicker;\n"]}