@wordpress/components 19.15.0 → 20.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1313) hide show
  1. package/CHANGELOG.md +161 -0
  2. package/CONTRIBUTING.md +10 -10
  3. package/build/alignment-matrix-control/index.js +1 -1
  4. package/build/alignment-matrix-control/index.js.map +1 -1
  5. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
  6. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  7. package/build/angle-picker-control/index.js +5 -2
  8. package/build/angle-picker-control/index.js.map +1 -1
  9. package/build/angle-picker-control/styles/angle-picker-control-styles.js +14 -4
  10. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  11. package/build/autocomplete/index.js +9 -11
  12. package/build/autocomplete/index.js.map +1 -1
  13. package/build/base-control/index.js +6 -3
  14. package/build/base-control/index.js.map +1 -1
  15. package/build/base-control/styles/base-control-styles.js +8 -8
  16. package/build/base-control/styles/base-control-styles.js.map +1 -1
  17. package/build/base-field/styles.js +5 -5
  18. package/build/base-field/styles.js.map +1 -1
  19. package/build/border-control/border-control/component.js +38 -25
  20. package/build/border-control/border-control/component.js.map +1 -1
  21. package/build/border-control/border-control/hook.js +4 -7
  22. package/build/border-control/border-control/hook.js.map +1 -1
  23. package/build/border-control/border-control-dropdown/component.js +13 -7
  24. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  25. package/build/border-control/border-control-dropdown/hook.js +0 -4
  26. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  27. package/build/border-control/styles.js +29 -60
  28. package/build/border-control/styles.js.map +1 -1
  29. package/build/box-control/all-input-control.js +2 -27
  30. package/build/box-control/all-input-control.js.map +1 -1
  31. package/build/box-control/axial-input-controls.js +1 -1
  32. package/build/box-control/axial-input-controls.js.map +1 -1
  33. package/build/box-control/index.js +10 -5
  34. package/build/box-control/index.js.map +1 -1
  35. package/build/box-control/styles/box-control-styles.js +17 -9
  36. package/build/box-control/styles/box-control-styles.js.map +1 -1
  37. package/build/box-control/styles/box-control-visualizer-styles.js +8 -8
  38. package/build/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  39. package/build/box-control/utils.js +37 -8
  40. package/build/box-control/utils.js.map +1 -1
  41. package/build/card/card/component.js +6 -11
  42. package/build/card/card/component.js.map +1 -1
  43. package/build/card/card/hook.js +0 -10
  44. package/build/card/card/hook.js.map +1 -1
  45. package/build/card/card/index.js.map +1 -1
  46. package/build/card/card-body/component.js +7 -8
  47. package/build/card/card-body/component.js.map +1 -1
  48. package/build/card/card-body/hook.js +0 -4
  49. package/build/card/card-body/hook.js.map +1 -1
  50. package/build/card/card-body/index.js.map +1 -1
  51. package/build/card/card-divider/component.js +7 -8
  52. package/build/card/card-divider/component.js.map +1 -1
  53. package/build/card/card-divider/hook.js +0 -4
  54. package/build/card/card-divider/hook.js.map +1 -1
  55. package/build/card/card-divider/index.js.map +1 -1
  56. package/build/card/card-footer/component.js +7 -8
  57. package/build/card/card-footer/component.js.map +1 -1
  58. package/build/card/card-footer/hook.js +0 -4
  59. package/build/card/card-footer/hook.js.map +1 -1
  60. package/build/card/card-footer/index.js.map +1 -1
  61. package/build/card/card-header/component.js +7 -8
  62. package/build/card/card-header/component.js.map +1 -1
  63. package/build/card/card-header/hook.js +0 -4
  64. package/build/card/card-header/hook.js.map +1 -1
  65. package/build/card/card-header/index.js.map +1 -1
  66. package/build/card/card-media/component.js +7 -7
  67. package/build/card/card-media/component.js.map +1 -1
  68. package/build/card/card-media/hook.js +0 -4
  69. package/build/card/card-media/hook.js.map +1 -1
  70. package/build/card/card-media/index.js.map +1 -1
  71. package/build/card/context.js.map +1 -1
  72. package/build/card/index.js.map +1 -1
  73. package/build/card/styles.js +17 -17
  74. package/build/card/styles.js.map +1 -1
  75. package/build/color-list-picker/index.js +16 -5
  76. package/build/color-list-picker/index.js.map +1 -1
  77. package/build/color-palette/index.js +36 -14
  78. package/build/color-palette/index.js.map +1 -1
  79. package/build/color-palette/index.native.js +3 -3
  80. package/build/color-palette/index.native.js.map +1 -1
  81. package/build/color-picker/hex-input.js +2 -1
  82. package/build/color-picker/hex-input.js.map +1 -1
  83. package/build/color-picker/input-with-slider.js +3 -2
  84. package/build/color-picker/input-with-slider.js.map +1 -1
  85. package/build/color-picker/styles.js +10 -15
  86. package/build/color-picker/styles.js.map +1 -1
  87. package/build/combobox-control/index.js +26 -17
  88. package/build/combobox-control/index.js.map +1 -1
  89. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  90. package/build/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  91. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  92. package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  93. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  94. package/build/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  95. package/build/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  96. package/build/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  97. package/build/custom-gradient-picker/index.js +19 -4
  98. package/build/custom-gradient-picker/index.js.map +1 -1
  99. package/build/custom-select-control/index.js +43 -13
  100. package/build/custom-select-control/index.js.map +1 -1
  101. package/build/custom-select-control/styles.js +34 -0
  102. package/build/custom-select-control/styles.js.map +1 -0
  103. package/build/date-time/constants.js +9 -0
  104. package/build/date-time/constants.js.map +1 -0
  105. package/build/date-time/date/index.js +175 -186
  106. package/build/date-time/date/index.js.map +1 -1
  107. package/build/date-time/date/styles.js +59 -40
  108. package/build/date-time/date/styles.js.map +1 -1
  109. package/build/date-time/date-time/index.js +5 -2
  110. package/build/date-time/date-time/index.js.map +1 -1
  111. package/build/date-time/time/index.js +28 -19
  112. package/build/date-time/time/index.js.map +1 -1
  113. package/build/date-time/time/styles.js +17 -24
  114. package/build/date-time/time/styles.js.map +1 -1
  115. package/build/date-time/utils.js +27 -0
  116. package/build/date-time/utils.js.map +1 -0
  117. package/build/dimension-control/index.js +2 -6
  118. package/build/dimension-control/index.js.map +1 -1
  119. package/build/disabled/index.js +28 -11
  120. package/build/disabled/index.js.map +1 -1
  121. package/build/disabled/styles/disabled-styles.js +3 -3
  122. package/build/disabled/styles/disabled-styles.js.map +1 -1
  123. package/build/disabled/types.js +6 -0
  124. package/build/disabled/types.js.map +1 -0
  125. package/build/divider/component.js +0 -1
  126. package/build/divider/component.js.map +1 -1
  127. package/build/divider/index.js.map +1 -1
  128. package/build/divider/styles.js +5 -5
  129. package/build/divider/styles.js.map +1 -1
  130. package/build/drop-zone/index.js +2 -4
  131. package/build/drop-zone/index.js.map +1 -1
  132. package/build/dropdown/dropdown-content-wrapper.js +60 -0
  133. package/build/dropdown/dropdown-content-wrapper.js.map +1 -0
  134. package/build/dropdown/index.js +5 -6
  135. package/build/dropdown/index.js.map +1 -1
  136. package/build/dropdown/styles.js +42 -0
  137. package/build/dropdown/styles.js.map +1 -0
  138. package/build/dropdown/types.js +6 -0
  139. package/build/dropdown/types.js.map +1 -0
  140. package/build/duotone-picker/custom-duotone-bar.js +2 -2
  141. package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
  142. package/build/duotone-picker/duotone-picker.js +9 -1
  143. package/build/duotone-picker/duotone-picker.js.map +1 -1
  144. package/build/duotone-picker/duotone-swatch.js +13 -3
  145. package/build/duotone-picker/duotone-swatch.js.map +1 -1
  146. package/build/elevation/component.js +15 -15
  147. package/build/elevation/component.js.map +1 -1
  148. package/build/elevation/hook.js +5 -17
  149. package/build/elevation/hook.js.map +1 -1
  150. package/build/elevation/index.js.map +1 -1
  151. package/build/elevation/styles.js +1 -1
  152. package/build/elevation/styles.js.map +1 -1
  153. package/build/external-link/index.js +6 -0
  154. package/build/external-link/index.js.map +1 -1
  155. package/build/flex/flex/component.js +20 -26
  156. package/build/flex/flex/component.js.map +1 -1
  157. package/build/flex/flex/hook.js +6 -16
  158. package/build/flex/flex/hook.js.map +1 -1
  159. package/build/flex/flex/index.js.map +1 -1
  160. package/build/flex/flex-block/component.js +18 -12
  161. package/build/flex/flex-block/component.js.map +1 -1
  162. package/build/flex/flex-block/hook.js +0 -4
  163. package/build/flex/flex-block/hook.js.map +1 -1
  164. package/build/flex/flex-block/index.js.map +1 -1
  165. package/build/flex/flex-item/component.js +18 -12
  166. package/build/flex/flex-item/component.js.map +1 -1
  167. package/build/flex/flex-item/hook.js +1 -5
  168. package/build/flex/flex-item/hook.js.map +1 -1
  169. package/build/flex/flex-item/index.js.map +1 -1
  170. package/build/flex/index.js.map +1 -1
  171. package/build/flex/styles.js +5 -5
  172. package/build/flex/styles.js.map +1 -1
  173. package/build/focal-point-picker/index.js +4 -6
  174. package/build/focal-point-picker/index.js.map +1 -1
  175. package/build/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  176. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  177. package/build/focal-point-picker/styles/focal-point-style.js +5 -5
  178. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  179. package/build/font-size-picker/index.js +56 -18
  180. package/build/font-size-picker/index.js.map +1 -1
  181. package/build/font-size-picker/utils.js +32 -22
  182. package/build/font-size-picker/utils.js.map +1 -1
  183. package/build/form-token-field/index.js +35 -22
  184. package/build/form-token-field/index.js.map +1 -1
  185. package/build/form-token-field/suggestions-list.js +19 -6
  186. package/build/form-token-field/suggestions-list.js.map +1 -1
  187. package/build/gradient-picker/index.js +15 -3
  188. package/build/gradient-picker/index.js.map +1 -1
  189. package/build/guide/index.js +5 -3
  190. package/build/guide/index.js.map +1 -1
  191. package/build/guide/page-control.js +3 -7
  192. package/build/guide/page-control.js.map +1 -1
  193. package/build/index.js +31 -1
  194. package/build/index.js.map +1 -1
  195. package/build/input-control/index.js +7 -0
  196. package/build/input-control/index.js.map +1 -1
  197. package/build/input-control/input-base.js +24 -3
  198. package/build/input-control/input-base.js.map +1 -1
  199. package/build/input-control/input-prefix-wrapper.js +54 -0
  200. package/build/input-control/input-prefix-wrapper.js.map +1 -0
  201. package/build/input-control/input-suffix-wrapper.js +54 -0
  202. package/build/input-control/input-suffix-wrapper.js.map +1 -0
  203. package/build/input-control/reducer/actions.js +3 -1
  204. package/build/input-control/reducer/actions.js.map +1 -1
  205. package/build/input-control/reducer/reducer.js +28 -11
  206. package/build/input-control/reducer/reducer.js.map +1 -1
  207. package/build/input-control/reducer/state.js.map +1 -1
  208. package/build/input-control/styles/input-control-styles.js +61 -42
  209. package/build/input-control/styles/input-control-styles.js.map +1 -1
  210. package/build/item-group/styles.js +10 -10
  211. package/build/item-group/styles.js.map +1 -1
  212. package/build/mobile/bottom-sheet/index.native.js +3 -6
  213. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  214. package/build/mobile/global-styles-context/utils.native.js +26 -4
  215. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  216. package/build/mobile/image/index.native.js +9 -5
  217. package/build/mobile/image/index.native.js.map +1 -1
  218. package/build/mobile/link-picker/link-picker-screen.native.js +10 -4
  219. package/build/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  220. package/build/mobile/media-edit/index.native.js +1 -7
  221. package/build/mobile/media-edit/index.native.js.map +1 -1
  222. package/build/mobile/picker/index.android.js +3 -3
  223. package/build/mobile/picker/index.android.js.map +1 -1
  224. package/build/mobile/picker/index.ios.js +16 -3
  225. package/build/mobile/picker/index.ios.js.map +1 -1
  226. package/build/modal/index.js +1 -3
  227. package/build/modal/index.js.map +1 -1
  228. package/build/navigable-container/container.js +9 -8
  229. package/build/navigable-container/container.js.map +1 -1
  230. package/build/navigable-container/menu.js +3 -9
  231. package/build/navigable-container/menu.js.map +1 -1
  232. package/build/navigator/navigator-back-button/hook.js +0 -4
  233. package/build/navigator/navigator-back-button/hook.js.map +1 -1
  234. package/build/navigator/navigator-button/hook.js +0 -4
  235. package/build/navigator/navigator-button/hook.js.map +1 -1
  236. package/build/notice/list.js +10 -6
  237. package/build/notice/list.js.map +1 -1
  238. package/build/palette-edit/index.js +1 -0
  239. package/build/palette-edit/index.js.map +1 -1
  240. package/build/palette-edit/styles.js +10 -10
  241. package/build/palette-edit/styles.js.map +1 -1
  242. package/build/placeholder/index.js +11 -14
  243. package/build/placeholder/index.js.map +1 -1
  244. package/build/placeholder/types.js +6 -0
  245. package/build/placeholder/types.js.map +1 -0
  246. package/build/popover/index.js +202 -145
  247. package/build/popover/index.js.map +1 -1
  248. package/build/popover/utils.js +178 -0
  249. package/build/popover/utils.js.map +1 -0
  250. package/build/radio-control/index.js +1 -3
  251. package/build/radio-control/index.js.map +1 -1
  252. package/build/range-control/index.js +3 -0
  253. package/build/range-control/index.js.map +1 -1
  254. package/build/range-control/styles/range-control-styles.js +51 -45
  255. package/build/range-control/styles/range-control-styles.js.map +1 -1
  256. package/build/range-control/utils.js +1 -1
  257. package/build/range-control/utils.js.map +1 -1
  258. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  259. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  260. package/build/sandbox/index.native.js +13 -2
  261. package/build/sandbox/index.native.js.map +1 -1
  262. package/build/scroll-lock/index.js +35 -6
  263. package/build/scroll-lock/index.js.map +1 -1
  264. package/build/select-control/chevron-down.js +30 -0
  265. package/build/select-control/chevron-down.js.map +1 -0
  266. package/build/select-control/index.js +8 -10
  267. package/build/select-control/index.js.map +1 -1
  268. package/build/select-control/styles/select-control-styles.js +54 -19
  269. package/build/select-control/styles/select-control-styles.js.map +1 -1
  270. package/build/shortcut/index.js +4 -13
  271. package/build/shortcut/index.js.map +1 -1
  272. package/build/shortcut/types.js +6 -0
  273. package/build/shortcut/types.js.map +1 -0
  274. package/build/snackbar/list.js +5 -3
  275. package/build/snackbar/list.js.map +1 -1
  276. package/build/spacer/component.js +3 -1
  277. package/build/spacer/component.js.map +1 -1
  278. package/build/spinner/index.js +2 -0
  279. package/build/spinner/index.js.map +1 -1
  280. package/build/style-provider/index.js +10 -7
  281. package/build/style-provider/index.js.map +1 -1
  282. package/build/style-provider/types.js +6 -0
  283. package/build/style-provider/types.js.map +1 -0
  284. package/build/text/hook.js +5 -8
  285. package/build/text/hook.js.map +1 -1
  286. package/build/text/styles.js +7 -7
  287. package/build/text/styles.js.map +1 -1
  288. package/build/toggle-group-control/toggle-group-control/component.js +19 -8
  289. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  290. package/build/toggle-group-control/toggle-group-control/styles.js +22 -4
  291. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  292. package/build/toggle-group-control/toggle-group-control-option/component.js +15 -5
  293. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  294. package/build/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  295. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  296. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +20 -9
  297. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  298. package/build/toggle-group-control/toggle-group-control-option-icon/component.js +26 -7
  299. package/build/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  300. package/build/tools-panel/styles.js +13 -10
  301. package/build/tools-panel/styles.js.map +1 -1
  302. package/build/tools-panel/tools-panel/hook.js +1 -1
  303. package/build/tools-panel/tools-panel/hook.js.map +1 -1
  304. package/build/tooltip/index.js +52 -21
  305. package/build/tooltip/index.js.map +1 -1
  306. package/build/tree-grid/index.js +4 -10
  307. package/build/tree-grid/index.js.map +1 -1
  308. package/build/tree-select/index.js +2 -2
  309. package/build/tree-select/index.js.map +1 -1
  310. package/build/ui/context/context-connect.js +1 -3
  311. package/build/ui/context/context-connect.js.map +1 -1
  312. package/build/ui/context/use-context-system.js +7 -2
  313. package/build/ui/context/use-context-system.js.map +1 -1
  314. package/build/ui/tooltip/styles.js +4 -4
  315. package/build/ui/tooltip/styles.js.map +1 -1
  316. package/build/ui/utils/space.js +7 -1
  317. package/build/ui/utils/space.js.map +1 -1
  318. package/build/unit-control/index.js +2 -3
  319. package/build/unit-control/index.js.map +1 -1
  320. package/build/unit-control/styles/unit-control-styles.js +38 -29
  321. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  322. package/build/utils/base-label.js +24 -0
  323. package/build/utils/base-label.js.map +1 -0
  324. package/build/utils/box-sizing.js +22 -0
  325. package/build/utils/box-sizing.js.map +1 -0
  326. package/build/utils/colors-values.js +52 -142
  327. package/build/utils/colors-values.js.map +1 -1
  328. package/build/utils/config-values.js +1 -1
  329. package/build/utils/config-values.js.map +1 -1
  330. package/build/utils/input/input-control.js +1 -1
  331. package/build/utils/input/input-control.js.map +1 -1
  332. package/build/utils/rtl.js +6 -5
  333. package/build/utils/rtl.js.map +1 -1
  334. package/build/utils/strings.js +50 -0
  335. package/build/utils/strings.js.map +1 -0
  336. package/build/utils/style-mixins.js +16 -0
  337. package/build/utils/style-mixins.js.map +1 -1
  338. package/build-module/alignment-matrix-control/index.js +1 -1
  339. package/build-module/alignment-matrix-control/index.js.map +1 -1
  340. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +9 -9
  341. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  342. package/build-module/angle-picker-control/index.js +5 -2
  343. package/build-module/angle-picker-control/index.js.map +1 -1
  344. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +13 -4
  345. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  346. package/build-module/autocomplete/index.js +9 -10
  347. package/build-module/autocomplete/index.js.map +1 -1
  348. package/build-module/base-control/index.js +7 -5
  349. package/build-module/base-control/index.js.map +1 -1
  350. package/build-module/base-control/styles/base-control-styles.js +9 -9
  351. package/build-module/base-control/styles/base-control-styles.js.map +1 -1
  352. package/build-module/base-field/styles.js +5 -5
  353. package/build-module/base-field/styles.js.map +1 -1
  354. package/build-module/border-control/border-control/component.js +37 -25
  355. package/build-module/border-control/border-control/component.js.map +1 -1
  356. package/build-module/border-control/border-control/hook.js +4 -7
  357. package/build-module/border-control/border-control/hook.js.map +1 -1
  358. package/build-module/border-control/border-control-dropdown/component.js +12 -7
  359. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  360. package/build-module/border-control/border-control-dropdown/hook.js +0 -4
  361. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  362. package/build-module/border-control/styles.js +30 -54
  363. package/build-module/border-control/styles.js.map +1 -1
  364. package/build-module/box-control/all-input-control.js +3 -28
  365. package/build-module/box-control/all-input-control.js.map +1 -1
  366. package/build-module/box-control/axial-input-controls.js +1 -1
  367. package/build-module/box-control/axial-input-controls.js.map +1 -1
  368. package/build-module/box-control/index.js +4 -4
  369. package/build-module/box-control/index.js.map +1 -1
  370. package/build-module/box-control/styles/box-control-styles.js +18 -10
  371. package/build-module/box-control/styles/box-control-styles.js.map +1 -1
  372. package/build-module/box-control/styles/box-control-visualizer-styles.js +8 -8
  373. package/build-module/box-control/styles/box-control-visualizer-styles.js.map +1 -1
  374. package/build-module/box-control/utils.js +35 -7
  375. package/build-module/box-control/utils.js.map +1 -1
  376. package/build-module/card/card/component.js +5 -10
  377. package/build-module/card/card/component.js.map +1 -1
  378. package/build-module/card/card/hook.js +0 -9
  379. package/build-module/card/card/hook.js.map +1 -1
  380. package/build-module/card/card/index.js.map +1 -1
  381. package/build-module/card/card-body/component.js +7 -8
  382. package/build-module/card/card-body/component.js.map +1 -1
  383. package/build-module/card/card-body/hook.js +0 -4
  384. package/build-module/card/card-body/hook.js.map +1 -1
  385. package/build-module/card/card-body/index.js.map +1 -1
  386. package/build-module/card/card-divider/component.js +7 -8
  387. package/build-module/card/card-divider/component.js.map +1 -1
  388. package/build-module/card/card-divider/hook.js +0 -4
  389. package/build-module/card/card-divider/hook.js.map +1 -1
  390. package/build-module/card/card-divider/index.js.map +1 -1
  391. package/build-module/card/card-footer/component.js +7 -8
  392. package/build-module/card/card-footer/component.js.map +1 -1
  393. package/build-module/card/card-footer/hook.js +0 -4
  394. package/build-module/card/card-footer/hook.js.map +1 -1
  395. package/build-module/card/card-footer/index.js.map +1 -1
  396. package/build-module/card/card-header/component.js +7 -8
  397. package/build-module/card/card-header/component.js.map +1 -1
  398. package/build-module/card/card-header/hook.js +0 -4
  399. package/build-module/card/card-header/hook.js.map +1 -1
  400. package/build-module/card/card-header/index.js.map +1 -1
  401. package/build-module/card/card-media/component.js +7 -7
  402. package/build-module/card/card-media/component.js.map +1 -1
  403. package/build-module/card/card-media/hook.js +0 -4
  404. package/build-module/card/card-media/hook.js.map +1 -1
  405. package/build-module/card/card-media/index.js.map +1 -1
  406. package/build-module/card/context.js.map +1 -1
  407. package/build-module/card/index.js.map +1 -1
  408. package/build-module/card/styles.js +17 -17
  409. package/build-module/card/styles.js.map +1 -1
  410. package/build-module/color-list-picker/index.js +13 -5
  411. package/build-module/color-list-picker/index.js.map +1 -1
  412. package/build-module/color-palette/index.js +32 -12
  413. package/build-module/color-palette/index.js.map +1 -1
  414. package/build-module/color-palette/index.native.js +4 -4
  415. package/build-module/color-palette/index.native.js.map +1 -1
  416. package/build-module/color-picker/hex-input.js +2 -1
  417. package/build-module/color-picker/hex-input.js.map +1 -1
  418. package/build-module/color-picker/input-with-slider.js +3 -2
  419. package/build-module/color-picker/input-with-slider.js.map +1 -1
  420. package/build-module/color-picker/styles.js +10 -16
  421. package/build-module/color-picker/styles.js.map +1 -1
  422. package/build-module/combobox-control/index.js +24 -15
  423. package/build-module/combobox-control/index.js.map +1 -1
  424. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  425. package/build-module/custom-gradient-picker/gradient-bar/constants.js.map +1 -0
  426. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +34 -41
  427. package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -0
  428. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -1
  429. package/build-module/custom-gradient-picker/gradient-bar/index.js.map +1 -0
  430. package/build-module/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  431. package/build-module/custom-gradient-picker/gradient-bar/utils.js.map +1 -0
  432. package/build-module/custom-gradient-picker/index.js +16 -3
  433. package/build-module/custom-gradient-picker/index.js.map +1 -1
  434. package/build-module/custom-select-control/index.js +41 -16
  435. package/build-module/custom-select-control/index.js.map +1 -1
  436. package/build-module/custom-select-control/styles.js +22 -0
  437. package/build-module/custom-select-control/styles.js.map +1 -0
  438. package/build-module/date-time/constants.js +2 -0
  439. package/build-module/date-time/constants.js.map +1 -0
  440. package/build-module/date-time/date/index.js +178 -184
  441. package/build-module/date-time/date/index.js.map +1 -1
  442. package/build-module/date-time/date/styles.js +47 -38
  443. package/build-module/date-time/date/styles.js.map +1 -1
  444. package/build-module/date-time/date-time/index.js +4 -2
  445. package/build-module/date-time/date-time/index.js.map +1 -1
  446. package/build-module/date-time/time/index.js +26 -19
  447. package/build-module/date-time/time/index.js.map +1 -1
  448. package/build-module/date-time/time/styles.js +15 -21
  449. package/build-module/date-time/time/styles.js.map +1 -1
  450. package/build-module/date-time/utils.js +19 -0
  451. package/build-module/date-time/utils.js.map +1 -0
  452. package/build-module/dimension-control/index.js +1 -5
  453. package/build-module/dimension-control/index.js.map +1 -1
  454. package/build-module/disabled/index.js +28 -11
  455. package/build-module/disabled/index.js.map +1 -1
  456. package/build-module/disabled/styles/disabled-styles.js +3 -3
  457. package/build-module/disabled/styles/disabled-styles.js.map +1 -1
  458. package/build-module/disabled/types.js +2 -0
  459. package/build-module/disabled/types.js.map +1 -0
  460. package/build-module/divider/component.js +0 -1
  461. package/build-module/divider/component.js.map +1 -1
  462. package/build-module/divider/index.js.map +1 -1
  463. package/build-module/divider/styles.js +5 -5
  464. package/build-module/divider/styles.js.map +1 -1
  465. package/build-module/drop-zone/index.js +2 -3
  466. package/build-module/drop-zone/index.js.map +1 -1
  467. package/build-module/dropdown/dropdown-content-wrapper.js +47 -0
  468. package/build-module/dropdown/dropdown-content-wrapper.js.map +1 -0
  469. package/build-module/dropdown/index.js +5 -6
  470. package/build-module/dropdown/index.js.map +1 -1
  471. package/build-module/dropdown/styles.js +31 -0
  472. package/build-module/dropdown/styles.js.map +1 -0
  473. package/build-module/dropdown/types.js +2 -0
  474. package/build-module/dropdown/types.js.map +1 -0
  475. package/build-module/duotone-picker/custom-duotone-bar.js +1 -1
  476. package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
  477. package/build-module/duotone-picker/duotone-picker.js +7 -1
  478. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  479. package/build-module/duotone-picker/duotone-swatch.js +11 -3
  480. package/build-module/duotone-picker/duotone-swatch.js.map +1 -1
  481. package/build-module/elevation/component.js +15 -15
  482. package/build-module/elevation/component.js.map +1 -1
  483. package/build-module/elevation/hook.js +5 -17
  484. package/build-module/elevation/hook.js.map +1 -1
  485. package/build-module/elevation/index.js.map +1 -1
  486. package/build-module/elevation/styles.js +1 -1
  487. package/build-module/elevation/styles.js.map +1 -1
  488. package/build-module/external-link/index.js +6 -0
  489. package/build-module/external-link/index.js.map +1 -1
  490. package/build-module/flex/flex/component.js +20 -26
  491. package/build-module/flex/flex/component.js.map +1 -1
  492. package/build-module/flex/flex/hook.js +6 -15
  493. package/build-module/flex/flex/hook.js.map +1 -1
  494. package/build-module/flex/flex/index.js.map +1 -1
  495. package/build-module/flex/flex-block/component.js +18 -12
  496. package/build-module/flex/flex-block/component.js.map +1 -1
  497. package/build-module/flex/flex-block/hook.js +0 -4
  498. package/build-module/flex/flex-block/hook.js.map +1 -1
  499. package/build-module/flex/flex-block/index.js.map +1 -1
  500. package/build-module/flex/flex-item/component.js +18 -12
  501. package/build-module/flex/flex-item/component.js.map +1 -1
  502. package/build-module/flex/flex-item/hook.js +1 -5
  503. package/build-module/flex/flex-item/hook.js.map +1 -1
  504. package/build-module/flex/flex-item/index.js.map +1 -1
  505. package/build-module/flex/index.js.map +1 -1
  506. package/build-module/flex/styles.js +5 -5
  507. package/build-module/flex/styles.js.map +1 -1
  508. package/build-module/focal-point-picker/index.js +4 -5
  509. package/build-module/focal-point-picker/index.js.map +1 -1
  510. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +22 -22
  511. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  512. package/build-module/focal-point-picker/styles/focal-point-style.js +5 -5
  513. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  514. package/build-module/font-size-picker/index.js +51 -18
  515. package/build-module/font-size-picker/index.js.map +1 -1
  516. package/build-module/font-size-picker/utils.js +31 -23
  517. package/build-module/font-size-picker/utils.js.map +1 -1
  518. package/build-module/form-token-field/index.js +35 -22
  519. package/build-module/form-token-field/index.js.map +1 -1
  520. package/build-module/form-token-field/suggestions-list.js +19 -6
  521. package/build-module/form-token-field/suggestions-list.js.map +1 -1
  522. package/build-module/gradient-picker/index.js +14 -3
  523. package/build-module/gradient-picker/index.js.map +1 -1
  524. package/build-module/guide/index.js +5 -3
  525. package/build-module/guide/index.js.map +1 -1
  526. package/build-module/guide/page-control.js +3 -6
  527. package/build-module/guide/page-control.js.map +1 -1
  528. package/build-module/index.js +4 -1
  529. package/build-module/index.js.map +1 -1
  530. package/build-module/input-control/index.js +6 -0
  531. package/build-module/input-control/index.js.map +1 -1
  532. package/build-module/input-control/input-base.js +25 -5
  533. package/build-module/input-control/input-base.js.map +1 -1
  534. package/build-module/input-control/input-prefix-wrapper.js +41 -0
  535. package/build-module/input-control/input-prefix-wrapper.js.map +1 -0
  536. package/build-module/input-control/input-suffix-wrapper.js +41 -0
  537. package/build-module/input-control/input-suffix-wrapper.js.map +1 -0
  538. package/build-module/input-control/reducer/actions.js +1 -0
  539. package/build-module/input-control/reducer/actions.js.map +1 -1
  540. package/build-module/input-control/reducer/reducer.js +28 -11
  541. package/build-module/input-control/reducer/reducer.js.map +1 -1
  542. package/build-module/input-control/reducer/state.js.map +1 -1
  543. package/build-module/input-control/styles/input-control-styles.js +58 -42
  544. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  545. package/build-module/item-group/styles.js +10 -10
  546. package/build-module/item-group/styles.js.map +1 -1
  547. package/build-module/mobile/bottom-sheet/index.native.js +3 -5
  548. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  549. package/build-module/mobile/global-styles-context/utils.native.js +24 -4
  550. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  551. package/build-module/mobile/image/index.native.js +12 -8
  552. package/build-module/mobile/image/index.native.js.map +1 -1
  553. package/build-module/mobile/link-picker/link-picker-screen.native.js +11 -4
  554. package/build-module/mobile/link-picker/link-picker-screen.native.js.map +1 -1
  555. package/build-module/mobile/media-edit/index.native.js +1 -6
  556. package/build-module/mobile/media-edit/index.native.js.map +1 -1
  557. package/build-module/mobile/picker/index.android.js +3 -3
  558. package/build-module/mobile/picker/index.android.js.map +1 -1
  559. package/build-module/mobile/picker/index.ios.js +14 -3
  560. package/build-module/mobile/picker/index.ios.js.map +1 -1
  561. package/build-module/modal/index.js +1 -2
  562. package/build-module/modal/index.js.map +1 -1
  563. package/build-module/navigable-container/container.js +9 -7
  564. package/build-module/navigable-container/container.js.map +1 -1
  565. package/build-module/navigable-container/menu.js +3 -8
  566. package/build-module/navigable-container/menu.js.map +1 -1
  567. package/build-module/navigator/navigator-back-button/hook.js +0 -4
  568. package/build-module/navigator/navigator-back-button/hook.js.map +1 -1
  569. package/build-module/navigator/navigator-button/hook.js +0 -4
  570. package/build-module/navigator/navigator-button/hook.js.map +1 -1
  571. package/build-module/notice/list.js +10 -5
  572. package/build-module/notice/list.js.map +1 -1
  573. package/build-module/palette-edit/index.js +1 -0
  574. package/build-module/palette-edit/index.js.map +1 -1
  575. package/build-module/palette-edit/styles.js +10 -10
  576. package/build-module/palette-edit/styles.js.map +1 -1
  577. package/build-module/placeholder/index.js +10 -15
  578. package/build-module/placeholder/index.js.map +1 -1
  579. package/build-module/placeholder/types.js +2 -0
  580. package/build-module/placeholder/types.js.map +1 -0
  581. package/build-module/popover/index.js +202 -147
  582. package/build-module/popover/index.js.map +1 -1
  583. package/build-module/popover/utils.js +164 -0
  584. package/build-module/popover/utils.js.map +1 -0
  585. package/build-module/radio-control/index.js +1 -2
  586. package/build-module/radio-control/index.js.map +1 -1
  587. package/build-module/range-control/index.js +3 -0
  588. package/build-module/range-control/index.js.map +1 -1
  589. package/build-module/range-control/styles/range-control-styles.js +51 -45
  590. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  591. package/build-module/range-control/utils.js +1 -1
  592. package/build-module/range-control/utils.js.map +1 -1
  593. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -4
  594. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  595. package/build-module/sandbox/index.native.js +13 -3
  596. package/build-module/sandbox/index.native.js.map +1 -1
  597. package/build-module/scroll-lock/index.js +32 -6
  598. package/build-module/scroll-lock/index.js.map +1 -1
  599. package/build-module/select-control/chevron-down.js +21 -0
  600. package/build-module/select-control/chevron-down.js.map +1 -0
  601. package/build-module/select-control/index.js +8 -9
  602. package/build-module/select-control/index.js.map +1 -1
  603. package/build-module/select-control/styles/select-control-styles.js +48 -17
  604. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  605. package/build-module/shortcut/index.js +4 -13
  606. package/build-module/shortcut/index.js.map +1 -1
  607. package/build-module/shortcut/types.js +2 -0
  608. package/build-module/shortcut/types.js.map +1 -0
  609. package/build-module/snackbar/list.js +5 -2
  610. package/build-module/snackbar/list.js.map +1 -1
  611. package/build-module/spacer/component.js +3 -1
  612. package/build-module/spacer/component.js.map +1 -1
  613. package/build-module/spinner/index.js +2 -0
  614. package/build-module/spinner/index.js.map +1 -1
  615. package/build-module/style-provider/index.js +10 -5
  616. package/build-module/style-provider/index.js.map +1 -1
  617. package/build-module/style-provider/types.js +2 -0
  618. package/build-module/style-provider/types.js.map +1 -0
  619. package/build-module/text/hook.js +5 -7
  620. package/build-module/text/hook.js.map +1 -1
  621. package/build-module/text/styles.js +7 -7
  622. package/build-module/text/styles.js.map +1 -1
  623. package/build-module/toggle-group-control/toggle-group-control/component.js +17 -7
  624. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  625. package/build-module/toggle-group-control/toggle-group-control/styles.js +16 -3
  626. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  627. package/build-module/toggle-group-control/toggle-group-control-option/component.js +17 -3
  628. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -1
  629. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +5 -1
  630. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  631. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +16 -7
  632. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  633. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js +27 -5
  634. package/build-module/toggle-group-control/toggle-group-control-option-icon/component.js.map +1 -1
  635. package/build-module/tools-panel/styles.js +12 -11
  636. package/build-module/tools-panel/styles.js.map +1 -1
  637. package/build-module/tools-panel/tools-panel/hook.js +1 -1
  638. package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
  639. package/build-module/tooltip/index.js +54 -22
  640. package/build-module/tooltip/index.js.map +1 -1
  641. package/build-module/tree-grid/index.js +4 -9
  642. package/build-module/tree-grid/index.js.map +1 -1
  643. package/build-module/tree-select/index.js +3 -3
  644. package/build-module/tree-select/index.js.map +1 -1
  645. package/build-module/ui/context/context-connect.js +1 -2
  646. package/build-module/ui/context/context-connect.js.map +1 -1
  647. package/build-module/ui/context/use-context-system.js +7 -2
  648. package/build-module/ui/context/use-context-system.js.map +1 -1
  649. package/build-module/ui/tooltip/styles.js +4 -4
  650. package/build-module/ui/tooltip/styles.js.map +1 -1
  651. package/build-module/ui/utils/space.js +7 -1
  652. package/build-module/ui/utils/space.js.map +1 -1
  653. package/build-module/unit-control/index.js +2 -2
  654. package/build-module/unit-control/index.js.map +1 -1
  655. package/build-module/unit-control/styles/unit-control-styles.js +39 -30
  656. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  657. package/build-module/utils/base-label.js +18 -0
  658. package/build-module/utils/base-label.js.map +1 -0
  659. package/build-module/utils/box-sizing.js +16 -0
  660. package/build-module/utils/box-sizing.js.map +1 -0
  661. package/build-module/utils/colors-values.js +52 -141
  662. package/build-module/utils/colors-values.js.map +1 -1
  663. package/build-module/utils/config-values.js +1 -1
  664. package/build-module/utils/config-values.js.map +1 -1
  665. package/build-module/utils/input/input-control.js +1 -1
  666. package/build-module/utils/input/input-control.js.map +1 -1
  667. package/build-module/utils/rtl.js +6 -4
  668. package/build-module/utils/rtl.js.map +1 -1
  669. package/build-module/utils/strings.js +37 -0
  670. package/build-module/utils/strings.js.map +1 -0
  671. package/build-module/utils/style-mixins.js +2 -0
  672. package/build-module/utils/style-mixins.js.map +1 -1
  673. package/build-style/style-rtl.css +236 -1281
  674. package/build-style/style.css +237 -1281
  675. package/build-types/base-control/index.d.ts +4 -3
  676. package/build-types/base-control/index.d.ts.map +1 -1
  677. package/build-types/base-control/stories/index.d.ts +1 -1
  678. package/build-types/base-control/stories/index.d.ts.map +1 -1
  679. package/build-types/base-control/styles/base-control-styles.d.ts.map +1 -1
  680. package/build-types/base-control/types.d.ts +0 -1
  681. package/build-types/base-control/types.d.ts.map +1 -1
  682. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  683. package/build-types/border-control/border-control/hook.d.ts +1 -1
  684. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  685. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  686. package/build-types/border-control/border-control-dropdown/hook.d.ts +0 -1
  687. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  688. package/build-types/border-control/stories/index.d.ts.map +1 -1
  689. package/build-types/border-control/styles.d.ts +1 -4
  690. package/build-types/border-control/styles.d.ts.map +1 -1
  691. package/build-types/card/card/component.d.ts +3 -3
  692. package/build-types/card/card/component.d.ts.map +1 -1
  693. package/build-types/card/card/hook.d.ts +7 -2
  694. package/build-types/card/card/hook.d.ts.map +1 -1
  695. package/build-types/card/card/index.d.ts +2 -2
  696. package/build-types/card/card/index.d.ts.map +1 -1
  697. package/build-types/card/card-body/component.d.ts +3 -3
  698. package/build-types/card/card-body/component.d.ts.map +1 -1
  699. package/build-types/card/card-body/hook.d.ts +5 -2
  700. package/build-types/card/card-body/hook.d.ts.map +1 -1
  701. package/build-types/card/card-body/index.d.ts +2 -2
  702. package/build-types/card/card-body/index.d.ts.map +1 -1
  703. package/build-types/card/card-divider/component.d.ts +3 -3
  704. package/build-types/card/card-divider/component.d.ts.map +1 -1
  705. package/build-types/card/card-divider/hook.d.ts +6 -3
  706. package/build-types/card/card-divider/hook.d.ts.map +1 -1
  707. package/build-types/card/card-divider/index.d.ts +2 -2
  708. package/build-types/card/card-divider/index.d.ts.map +1 -1
  709. package/build-types/card/card-footer/component.d.ts +3 -3
  710. package/build-types/card/card-footer/component.d.ts.map +1 -1
  711. package/build-types/card/card-footer/hook.d.ts +5 -2
  712. package/build-types/card/card-footer/hook.d.ts.map +1 -1
  713. package/build-types/card/card-footer/index.d.ts +2 -2
  714. package/build-types/card/card-footer/index.d.ts.map +1 -1
  715. package/build-types/card/card-header/component.d.ts +3 -3
  716. package/build-types/card/card-header/component.d.ts.map +1 -1
  717. package/build-types/card/card-header/hook.d.ts +5 -2
  718. package/build-types/card/card-header/hook.d.ts.map +1 -1
  719. package/build-types/card/card-header/index.d.ts +2 -2
  720. package/build-types/card/card-header/index.d.ts.map +1 -1
  721. package/build-types/card/card-media/component.d.ts +3 -4
  722. package/build-types/card/card-media/component.d.ts.map +1 -1
  723. package/build-types/card/card-media/hook.d.ts +6 -5
  724. package/build-types/card/card-media/hook.d.ts.map +1 -1
  725. package/build-types/card/card-media/index.d.ts +2 -2
  726. package/build-types/card/card-media/index.d.ts.map +1 -1
  727. package/build-types/card/context.d.ts +3 -2
  728. package/build-types/card/context.d.ts.map +1 -1
  729. package/build-types/card/index.d.ts +6 -6
  730. package/build-types/card/index.d.ts.map +1 -1
  731. package/build-types/card/stories/index.d.ts +12 -0
  732. package/build-types/card/stories/index.d.ts.map +1 -0
  733. package/build-types/card/styles.d.ts +20 -22
  734. package/build-types/card/styles.d.ts.map +1 -1
  735. package/build-types/card/test/index.d.ts +2 -0
  736. package/build-types/card/test/index.d.ts.map +1 -0
  737. package/build-types/card/types.d.ts +7 -1
  738. package/build-types/card/types.d.ts.map +1 -1
  739. package/build-types/color-palette/index.d.ts +3 -1
  740. package/build-types/color-palette/index.d.ts.map +1 -1
  741. package/build-types/color-picker/hex-input.d.ts.map +1 -1
  742. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  743. package/build-types/color-picker/styles.d.ts +2 -2
  744. package/build-types/color-picker/styles.d.ts.map +1 -1
  745. package/build-types/date-time/constants.d.ts +2 -0
  746. package/build-types/date-time/constants.d.ts.map +1 -0
  747. package/build-types/date-time/date/index.d.ts +3 -1
  748. package/build-types/date-time/date/index.d.ts.map +1 -1
  749. package/build-types/date-time/date/styles.d.ts +22 -8
  750. package/build-types/date-time/date/styles.d.ts.map +1 -1
  751. package/build-types/date-time/date/test/index.d.ts +1 -1
  752. package/build-types/date-time/date/test/index.d.ts.map +1 -1
  753. package/build-types/date-time/date-time/index.d.ts.map +1 -1
  754. package/build-types/date-time/time/index.d.ts.map +1 -1
  755. package/build-types/date-time/time/styles.d.ts +0 -4
  756. package/build-types/date-time/time/styles.d.ts.map +1 -1
  757. package/build-types/date-time/utils.d.ts +8 -0
  758. package/build-types/date-time/utils.d.ts.map +1 -0
  759. package/build-types/disabled/index.d.ts +35 -28
  760. package/build-types/disabled/index.d.ts.map +1 -1
  761. package/build-types/disabled/stories/index.d.ts +13 -0
  762. package/build-types/disabled/stories/index.d.ts.map +1 -0
  763. package/build-types/disabled/styles/disabled-styles.d.ts +2 -1
  764. package/build-types/disabled/styles/disabled-styles.d.ts.map +1 -1
  765. package/build-types/disabled/test/index.d.ts +2 -0
  766. package/build-types/disabled/test/index.d.ts.map +1 -0
  767. package/build-types/disabled/types.d.ts +14 -0
  768. package/build-types/disabled/types.d.ts.map +1 -0
  769. package/build-types/divider/component.d.ts +2 -3
  770. package/build-types/divider/component.d.ts.map +1 -1
  771. package/build-types/divider/index.d.ts +1 -1
  772. package/build-types/divider/index.d.ts.map +1 -1
  773. package/build-types/divider/styles.d.ts +6 -2
  774. package/build-types/divider/styles.d.ts.map +1 -1
  775. package/build-types/divider/test/index.d.ts +2 -0
  776. package/build-types/divider/test/index.d.ts.map +1 -0
  777. package/build-types/divider/types.d.ts +18 -10
  778. package/build-types/divider/types.d.ts.map +1 -1
  779. package/build-types/dropdown/dropdown-content-wrapper.d.ts +23 -0
  780. package/build-types/dropdown/dropdown-content-wrapper.d.ts.map +1 -0
  781. package/build-types/dropdown/index.d.ts.map +1 -1
  782. package/build-types/dropdown/styles.d.ts +7 -0
  783. package/build-types/dropdown/styles.d.ts.map +1 -0
  784. package/build-types/dropdown/types.d.ts +9 -0
  785. package/build-types/dropdown/types.d.ts.map +1 -0
  786. package/build-types/elevation/component.d.ts +11 -10
  787. package/build-types/elevation/component.d.ts.map +1 -1
  788. package/build-types/elevation/hook.d.ts +6 -7
  789. package/build-types/elevation/hook.d.ts.map +1 -1
  790. package/build-types/elevation/index.d.ts +2 -2
  791. package/build-types/elevation/index.d.ts.map +1 -1
  792. package/build-types/elevation/stories/index.d.ts +22 -0
  793. package/build-types/elevation/stories/index.d.ts.map +1 -0
  794. package/build-types/elevation/styles.d.ts +1 -1
  795. package/build-types/elevation/styles.d.ts.map +1 -1
  796. package/build-types/elevation/test/index.d.ts +2 -0
  797. package/build-types/elevation/test/index.d.ts.map +1 -0
  798. package/build-types/elevation/types.d.ts +12 -19
  799. package/build-types/elevation/types.d.ts.map +1 -1
  800. package/build-types/external-link/index.d.ts.map +1 -1
  801. package/build-types/flex/flex/component.d.ts +16 -21
  802. package/build-types/flex/flex/component.d.ts.map +1 -1
  803. package/build-types/flex/flex/hook.d.ts +5 -2
  804. package/build-types/flex/flex/hook.d.ts.map +1 -1
  805. package/build-types/flex/flex/index.d.ts +2 -2
  806. package/build-types/flex/flex/index.d.ts.map +1 -1
  807. package/build-types/flex/flex-block/component.d.ts +14 -7
  808. package/build-types/flex/flex-block/component.d.ts.map +1 -1
  809. package/build-types/flex/flex-block/hook.d.ts +6 -3
  810. package/build-types/flex/flex-block/hook.d.ts.map +1 -1
  811. package/build-types/flex/flex-block/index.d.ts +2 -2
  812. package/build-types/flex/flex-block/index.d.ts.map +1 -1
  813. package/build-types/flex/flex-item/component.d.ts +14 -7
  814. package/build-types/flex/flex-item/component.d.ts.map +1 -1
  815. package/build-types/flex/flex-item/hook.d.ts +6 -3
  816. package/build-types/flex/flex-item/hook.d.ts.map +1 -1
  817. package/build-types/flex/flex-item/index.d.ts +2 -2
  818. package/build-types/flex/flex-item/index.d.ts.map +1 -1
  819. package/build-types/flex/index.d.ts +3 -3
  820. package/build-types/flex/index.d.ts.map +1 -1
  821. package/build-types/flex/stories/index.d.ts +13 -0
  822. package/build-types/flex/stories/index.d.ts.map +1 -0
  823. package/build-types/flex/styles.d.ts +5 -5
  824. package/build-types/flex/styles.d.ts.map +1 -1
  825. package/build-types/flex/test/index.d.ts +2 -0
  826. package/build-types/flex/test/index.d.ts.map +1 -0
  827. package/build-types/flex/types.d.ts +17 -10
  828. package/build-types/flex/types.d.ts.map +1 -1
  829. package/build-types/form-token-field/index.d.ts.map +1 -1
  830. package/build-types/form-token-field/stories/index.d.ts +7 -0
  831. package/build-types/form-token-field/stories/index.d.ts.map +1 -1
  832. package/build-types/form-token-field/suggestions-list.d.ts +1 -1
  833. package/build-types/form-token-field/suggestions-list.d.ts.map +1 -1
  834. package/build-types/form-token-field/test/index.d.ts +2 -0
  835. package/build-types/form-token-field/test/index.d.ts.map +1 -0
  836. package/build-types/form-token-field/types.d.ts +22 -3
  837. package/build-types/form-token-field/types.d.ts.map +1 -1
  838. package/build-types/input-control/index.d.ts +1 -1
  839. package/build-types/input-control/index.d.ts.map +1 -1
  840. package/build-types/input-control/input-base.d.ts +1 -1
  841. package/build-types/input-control/input-base.d.ts.map +1 -1
  842. package/build-types/input-control/input-prefix-wrapper.d.ts +19 -0
  843. package/build-types/input-control/input-prefix-wrapper.d.ts.map +1 -0
  844. package/build-types/input-control/input-suffix-wrapper.d.ts +19 -0
  845. package/build-types/input-control/input-suffix-wrapper.d.ts.map +1 -0
  846. package/build-types/input-control/reducer/actions.d.ts +3 -1
  847. package/build-types/input-control/reducer/actions.d.ts.map +1 -1
  848. package/build-types/input-control/reducer/reducer.d.ts +2 -2
  849. package/build-types/input-control/reducer/reducer.d.ts.map +1 -1
  850. package/build-types/input-control/reducer/state.d.ts +2 -2
  851. package/build-types/input-control/reducer/state.d.ts.map +1 -1
  852. package/build-types/input-control/stories/index.d.ts +10 -0
  853. package/build-types/input-control/stories/index.d.ts.map +1 -1
  854. package/build-types/input-control/styles/input-control-styles.d.ts +21 -0
  855. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  856. package/build-types/input-control/types.d.ts +45 -3
  857. package/build-types/input-control/types.d.ts.map +1 -1
  858. package/build-types/navigable-container/menu.d.ts.map +1 -1
  859. package/build-types/navigator/navigator-back-button/hook.d.ts +0 -3
  860. package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
  861. package/build-types/navigator/navigator-button/hook.d.ts +0 -3
  862. package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
  863. package/build-types/placeholder/index.d.ts +16 -0
  864. package/build-types/placeholder/index.d.ts.map +1 -0
  865. package/build-types/placeholder/stories/index.d.ts +12 -0
  866. package/build-types/placeholder/stories/index.d.ts.map +1 -0
  867. package/build-types/placeholder/test/index.d.ts +2 -0
  868. package/build-types/placeholder/test/index.d.ts.map +1 -0
  869. package/build-types/placeholder/types.d.ts +47 -0
  870. package/build-types/placeholder/types.d.ts.map +1 -0
  871. package/build-types/popover/index.d.ts +2 -2
  872. package/build-types/popover/index.d.ts.map +1 -1
  873. package/build-types/popover/utils.d.ts +27 -0
  874. package/build-types/popover/utils.d.ts.map +1 -0
  875. package/build-types/radio-control/index.d.ts.map +1 -1
  876. package/build-types/range-control/index.d.ts +2 -2
  877. package/build-types/range-control/index.d.ts.map +1 -1
  878. package/build-types/range-control/styles/range-control-styles.d.ts +5 -2
  879. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  880. package/build-types/range-control/types.d.ts +6 -4
  881. package/build-types/range-control/types.d.ts.map +1 -1
  882. package/build-types/range-control/utils.d.ts.map +1 -1
  883. package/build-types/scroll-lock/index.d.ts +32 -3
  884. package/build-types/scroll-lock/index.d.ts.map +1 -1
  885. package/build-types/scroll-lock/stories/index.d.ts +9 -0
  886. package/build-types/scroll-lock/stories/index.d.ts.map +1 -0
  887. package/build-types/scroll-lock/test/index.d.ts +2 -0
  888. package/build-types/scroll-lock/test/index.d.ts.map +1 -0
  889. package/build-types/select-control/chevron-down.d.ts +4 -0
  890. package/build-types/select-control/chevron-down.d.ts.map +1 -0
  891. package/build-types/select-control/index.d.ts.map +1 -1
  892. package/build-types/select-control/styles/select-control-styles.d.ts +9 -1
  893. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  894. package/build-types/select-control/types.d.ts +1 -1
  895. package/build-types/select-control/types.d.ts.map +1 -1
  896. package/build-types/shortcut/index.d.ts +5 -24
  897. package/build-types/shortcut/index.d.ts.map +1 -1
  898. package/build-types/shortcut/test/index.d.ts +2 -0
  899. package/build-types/shortcut/test/index.d.ts.map +1 -0
  900. package/build-types/shortcut/types.d.ts +14 -0
  901. package/build-types/shortcut/types.d.ts.map +1 -0
  902. package/build-types/spacer/component.d.ts +3 -1
  903. package/build-types/spacer/component.d.ts.map +1 -1
  904. package/build-types/spinner/index.d.ts.map +1 -1
  905. package/build-types/style-provider/index.d.ts +7 -4
  906. package/build-types/style-provider/index.d.ts.map +1 -1
  907. package/build-types/style-provider/types.d.ts +15 -0
  908. package/build-types/style-provider/types.d.ts.map +1 -0
  909. package/build-types/text/hook.d.ts.map +1 -1
  910. package/build-types/toggle-group-control/stories/index.d.ts +25 -0
  911. package/build-types/toggle-group-control/stories/index.d.ts.map +1 -0
  912. package/build-types/toggle-group-control/test/index.d.ts +2 -0
  913. package/build-types/toggle-group-control/test/index.d.ts.map +1 -0
  914. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +6 -3
  915. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  916. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +6 -1
  917. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  918. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +6 -7
  919. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -1
  920. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  921. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +4 -1
  922. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  923. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +11 -9
  924. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts.map +1 -1
  925. package/build-types/toggle-group-control/types.d.ts +27 -8
  926. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  927. package/build-types/tools-panel/styles.d.ts +1 -1
  928. package/build-types/tools-panel/styles.d.ts.map +1 -1
  929. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  930. package/build-types/tooltip/index.d.ts.map +1 -1
  931. package/build-types/tree-select/index.d.ts.map +1 -1
  932. package/build-types/tree-select/types.d.ts +1 -0
  933. package/build-types/tree-select/types.d.ts.map +1 -1
  934. package/build-types/ui/context/context-connect.d.ts +3 -0
  935. package/build-types/ui/context/context-connect.d.ts.map +1 -1
  936. package/build-types/ui/context/use-context-system.d.ts.map +1 -1
  937. package/build-types/ui/form-group/use-form-group.d.ts +2 -2
  938. package/build-types/ui/tooltip/styles.d.ts.map +1 -1
  939. package/build-types/ui/utils/space.d.ts +7 -1
  940. package/build-types/ui/utils/space.d.ts.map +1 -1
  941. package/build-types/unit-control/index.d.ts +4 -3
  942. package/build-types/unit-control/index.d.ts.map +1 -1
  943. package/build-types/unit-control/stories/index.d.ts.map +1 -1
  944. package/build-types/unit-control/styles/unit-control-styles.d.ts +0 -1
  945. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
  946. package/build-types/unit-control/types.d.ts +7 -9
  947. package/build-types/unit-control/types.d.ts.map +1 -1
  948. package/build-types/utils/base-label.d.ts +2 -0
  949. package/build-types/utils/base-label.d.ts.map +1 -0
  950. package/build-types/utils/box-sizing.d.ts +2 -0
  951. package/build-types/utils/box-sizing.d.ts.map +1 -0
  952. package/build-types/utils/colors-values.d.ts +18 -97
  953. package/build-types/utils/colors-values.d.ts.map +1 -1
  954. package/build-types/utils/rtl.d.ts.map +1 -1
  955. package/build-types/utils/strings.d.ts +2 -0
  956. package/build-types/utils/strings.d.ts.map +1 -0
  957. package/build-types/utils/style-mixins.d.ts +2 -0
  958. package/package.json +22 -21
  959. package/src/alignment-matrix-control/index.js +1 -1
  960. package/src/alignment-matrix-control/stories/index.js +49 -24
  961. package/src/alignment-matrix-control/styles/alignment-matrix-control-styles.js +1 -3
  962. package/src/angle-picker-control/index.js +7 -2
  963. package/src/angle-picker-control/stories/index.js +8 -5
  964. package/src/angle-picker-control/styles/angle-picker-control-styles.js +12 -3
  965. package/src/autocomplete/index.js +9 -18
  966. package/src/base-control/index.tsx +5 -3
  967. package/src/base-control/stories/index.tsx +1 -0
  968. package/src/base-control/styles/base-control-styles.ts +11 -2
  969. package/src/base-control/types.ts +0 -1
  970. package/src/base-field/styles.js +1 -1
  971. package/src/base-field/test/__snapshots__/index.js.snap +2 -2
  972. package/src/border-control/border-control/component.tsx +41 -32
  973. package/src/border-control/border-control/hook.ts +4 -9
  974. package/src/border-control/border-control-dropdown/component.tsx +50 -45
  975. package/src/border-control/border-control-dropdown/hook.ts +0 -5
  976. package/src/border-control/stories/index.tsx +3 -0
  977. package/src/border-control/styles.ts +25 -70
  978. package/src/border-control/test/index.js +19 -8
  979. package/src/box-control/all-input-control.js +3 -27
  980. package/src/box-control/axial-input-controls.js +1 -1
  981. package/src/box-control/index.js +5 -6
  982. package/src/box-control/styles/box-control-styles.js +1 -2
  983. package/src/box-control/styles/box-control-visualizer-styles.js +0 -1
  984. package/src/box-control/test/index.js +8 -8
  985. package/src/box-control/utils.js +38 -13
  986. package/src/button/test/index.js +188 -146
  987. package/src/card/card/{component.js → component.tsx} +13 -9
  988. package/src/card/card/{hook.js → hook.ts} +11 -11
  989. package/src/card/card/{index.js → index.ts} +0 -0
  990. package/src/card/card-body/{component.js → component.tsx} +13 -9
  991. package/src/card/card-body/{hook.js → hook.ts} +5 -5
  992. package/src/card/card-body/{index.js → index.ts} +0 -0
  993. package/src/card/card-divider/{component.js → component.tsx} +16 -10
  994. package/src/card/card-divider/{hook.js → hook.ts} +5 -5
  995. package/src/card/card-divider/{index.js → index.ts} +0 -0
  996. package/src/card/card-footer/{component.js → component.tsx} +13 -9
  997. package/src/card/card-footer/{hook.js → hook.ts} +5 -5
  998. package/src/card/card-footer/{index.js → index.ts} +0 -0
  999. package/src/card/card-header/{component.js → component.tsx} +13 -9
  1000. package/src/card/card-header/{hook.js → hook.ts} +5 -5
  1001. package/src/card/card-header/{index.js → index.ts} +0 -0
  1002. package/src/card/card-media/{component.js → component.tsx} +13 -8
  1003. package/src/card/card-media/{hook.js → hook.ts} +5 -5
  1004. package/src/card/card-media/{index.js → index.ts} +0 -0
  1005. package/src/card/{context.js → context.ts} +0 -0
  1006. package/src/card/{index.js → index.ts} +0 -0
  1007. package/src/card/stories/index.tsx +75 -0
  1008. package/src/card/{styles.js → styles.ts} +0 -0
  1009. package/src/card/test/__snapshots__/{index.js.snap → index.tsx.snap} +8 -8
  1010. package/src/card/test/{index.js → index.tsx} +3 -3
  1011. package/src/card/types.ts +8 -1
  1012. package/src/color-list-picker/index.js +15 -3
  1013. package/src/color-list-picker/style.scss +11 -0
  1014. package/src/color-palette/index.js +51 -24
  1015. package/src/color-palette/index.native.js +10 -6
  1016. package/src/color-palette/stories/index.js +1 -1
  1017. package/src/color-palette/style.scss +5 -0
  1018. package/src/color-palette/test/__snapshots__/index.js.snap +17 -3
  1019. package/src/color-palette/test/utils.ts +19 -1
  1020. package/src/color-picker/hex-input.tsx +2 -1
  1021. package/src/color-picker/input-with-slider.tsx +2 -1
  1022. package/src/color-picker/styles.ts +3 -11
  1023. package/src/combobox-control/README.md +7 -0
  1024. package/src/combobox-control/index.js +25 -15
  1025. package/src/combobox-control/stories/index.js +57 -7
  1026. package/src/combobox-control/style.scss +0 -1
  1027. package/src/confirm-dialog/README.md +1 -1
  1028. package/src/confirm-dialog/test/index.js +85 -62
  1029. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/constants.js +0 -0
  1030. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/control-points.js +54 -50
  1031. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/index.js +0 -3
  1032. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/test/utils.js +0 -0
  1033. package/src/{custom-gradient-bar → custom-gradient-picker/gradient-bar}/utils.js +0 -0
  1034. package/src/custom-gradient-picker/index.js +18 -3
  1035. package/src/custom-gradient-picker/stories/index.js +4 -3
  1036. package/src/custom-gradient-picker/style.scss +30 -39
  1037. package/src/custom-select-control/README.md +10 -0
  1038. package/src/custom-select-control/index.js +54 -29
  1039. package/src/custom-select-control/stories/index.js +7 -2
  1040. package/src/custom-select-control/style.scss +2 -43
  1041. package/src/custom-select-control/styles.ts +28 -0
  1042. package/src/custom-select-control/test/index.js +4 -1
  1043. package/src/date-time/constants.ts +1 -0
  1044. package/src/date-time/date/index.tsx +289 -184
  1045. package/src/date-time/date/styles.ts +86 -27
  1046. package/src/date-time/date/test/index.tsx +18 -28
  1047. package/src/date-time/date-time/index.tsx +3 -2
  1048. package/src/date-time/time/index.tsx +30 -24
  1049. package/src/date-time/time/styles.ts +3 -6
  1050. package/src/date-time/utils.ts +17 -0
  1051. package/src/dimension-control/index.js +1 -5
  1052. package/src/disabled/index.tsx +80 -0
  1053. package/src/disabled/stories/index.tsx +87 -0
  1054. package/src/disabled/styles/{disabled-styles.js → disabled-styles.tsx} +0 -0
  1055. package/src/disabled/test/index.tsx +174 -0
  1056. package/src/disabled/types.ts +13 -0
  1057. package/src/divider/README.md +12 -5
  1058. package/src/divider/component.tsx +2 -3
  1059. package/src/divider/index.ts +1 -1
  1060. package/src/divider/stories/index.tsx +4 -4
  1061. package/src/divider/styles.ts +7 -7
  1062. package/src/divider/test/__snapshots__/{index.js.snap → index.tsx.snap} +7 -7
  1063. package/src/divider/test/index.tsx +40 -0
  1064. package/src/divider/types.ts +21 -15
  1065. package/src/draggable/README.md +1 -1
  1066. package/src/drop-zone/index.js +2 -3
  1067. package/src/dropdown/dropdown-content-wrapper.tsx +59 -0
  1068. package/src/dropdown/index.js +3 -5
  1069. package/src/dropdown/stories/index.js +60 -69
  1070. package/src/dropdown/styles.ts +38 -0
  1071. package/src/dropdown/types.ts +8 -0
  1072. package/src/dropdown-menu/stories/index.js +13 -2
  1073. package/src/duotone-picker/custom-duotone-bar.js +1 -1
  1074. package/src/duotone-picker/duotone-picker.js +34 -26
  1075. package/src/duotone-picker/duotone-swatch.js +12 -5
  1076. package/src/duotone-picker/stories/duotone-picker.js +66 -0
  1077. package/src/duotone-picker/stories/duotone-swatch.js +32 -0
  1078. package/src/elevation/README.md +16 -14
  1079. package/src/elevation/component.tsx +48 -0
  1080. package/src/elevation/{hook.js → hook.ts} +20 -17
  1081. package/src/elevation/{index.js → index.ts} +0 -0
  1082. package/src/elevation/stories/index.tsx +85 -0
  1083. package/src/elevation/{styles.js → styles.ts} +0 -0
  1084. package/src/elevation/test/__snapshots__/{index.js.snap → index.tsx.snap} +19 -13
  1085. package/src/elevation/test/index.tsx +64 -0
  1086. package/src/elevation/types.ts +12 -19
  1087. package/src/external-link/index.tsx +10 -0
  1088. package/src/flex/flex/README.md +20 -18
  1089. package/src/flex/flex/component.tsx +59 -0
  1090. package/src/flex/flex/{hook.js → hook.ts} +14 -13
  1091. package/src/flex/flex/{index.js → index.ts} +0 -0
  1092. package/src/flex/flex-block/README.md +3 -7
  1093. package/src/flex/flex-block/component.tsx +41 -0
  1094. package/src/flex/flex-block/{hook.js → hook.ts} +5 -5
  1095. package/src/flex/flex-block/{index.js → index.ts} +0 -0
  1096. package/src/flex/flex-item/README.md +6 -9
  1097. package/src/flex/flex-item/component.tsx +41 -0
  1098. package/src/flex/flex-item/{hook.js → hook.ts} +10 -7
  1099. package/src/flex/flex-item/{index.js → index.ts} +0 -0
  1100. package/src/flex/{index.js → index.ts} +0 -0
  1101. package/src/flex/stories/index.tsx +81 -0
  1102. package/src/flex/{styles.js → styles.ts} +0 -0
  1103. package/src/flex/test/__snapshots__/{index.js.snap → index.tsx.snap} +49 -9
  1104. package/src/flex/test/index.tsx +84 -0
  1105. package/src/flex/types.ts +17 -10
  1106. package/src/focal-point-picker/index.js +10 -5
  1107. package/src/focal-point-picker/styles/focal-point-picker-style.js +0 -5
  1108. package/src/focal-point-picker/styles/focal-point-style.js +0 -2
  1109. package/src/focal-point-picker/test/index.js +78 -45
  1110. package/src/font-size-picker/index.js +160 -132
  1111. package/src/font-size-picker/stories/index.js +7 -0
  1112. package/src/font-size-picker/style.scss +8 -5
  1113. package/src/font-size-picker/test/index.js +13 -6
  1114. package/src/font-size-picker/test/{util.js → utils.js} +77 -1
  1115. package/src/font-size-picker/utils.js +38 -23
  1116. package/src/form-token-field/README.md +3 -1
  1117. package/src/form-token-field/index.tsx +46 -35
  1118. package/src/form-token-field/stories/index.tsx +22 -0
  1119. package/src/form-token-field/style.scss +0 -5
  1120. package/src/form-token-field/suggestions-list.tsx +21 -12
  1121. package/src/form-token-field/test/index.tsx +2106 -0
  1122. package/src/form-token-field/types.ts +23 -2
  1123. package/src/gradient-picker/index.js +22 -7
  1124. package/src/gradient-picker/stories/index.js +56 -81
  1125. package/src/guide/index.js +3 -1
  1126. package/src/guide/page-control.js +1 -6
  1127. package/src/guide/stories/index.js +12 -11
  1128. package/src/guide/test/index.js +54 -37
  1129. package/src/guide/test/page-control.js +14 -17
  1130. package/src/higher-order/with-notices/test/index.js +4 -2
  1131. package/src/higher-order/with-spoken-messages/test/index.js +1 -1
  1132. package/src/index.js +7 -1
  1133. package/src/input-control/index.tsx +6 -0
  1134. package/src/input-control/input-base.tsx +28 -13
  1135. package/src/input-control/input-prefix-wrapper.tsx +48 -0
  1136. package/src/input-control/input-suffix-wrapper.tsx +48 -0
  1137. package/src/input-control/reducer/actions.ts +3 -1
  1138. package/src/input-control/reducer/reducer.ts +27 -10
  1139. package/src/input-control/reducer/state.ts +7 -2
  1140. package/src/input-control/stories/index.tsx +15 -2
  1141. package/src/input-control/styles/input-control-styles.tsx +28 -12
  1142. package/src/input-control/test/index.js +20 -4
  1143. package/src/input-control/types.ts +52 -3
  1144. package/src/item-group/styles.ts +3 -3
  1145. package/src/menu-group/test/index.js +18 -7
  1146. package/src/mobile/bottom-sheet/index.native.js +2 -4
  1147. package/src/mobile/global-styles-context/utils.native.js +22 -4
  1148. package/src/mobile/image/index.native.js +17 -8
  1149. package/src/mobile/link-picker/link-picker-screen.native.js +12 -4
  1150. package/src/mobile/media-edit/index.native.js +2 -7
  1151. package/src/mobile/picker/index.android.js +10 -4
  1152. package/src/mobile/picker/index.ios.js +16 -0
  1153. package/src/mobile/picker/styles.native.scss +12 -4
  1154. package/src/modal/index.js +1 -2
  1155. package/src/modal/style.scss +5 -1
  1156. package/src/modal/test/index.js +11 -9
  1157. package/src/navigable-container/container.js +12 -18
  1158. package/src/navigable-container/menu.js +3 -7
  1159. package/src/navigable-container/test/menu.js +14 -11
  1160. package/src/navigator/navigator-back-button/hook.ts +0 -3
  1161. package/src/navigator/navigator-button/hook.ts +0 -3
  1162. package/src/notice/list.js +12 -10
  1163. package/src/palette-edit/index.js +1 -0
  1164. package/src/palette-edit/styles.js +6 -5
  1165. package/src/panel/style.scss +4 -1
  1166. package/src/placeholder/README.md +49 -9
  1167. package/src/placeholder/{index.js → index.tsx} +27 -23
  1168. package/src/placeholder/stories/index.tsx +64 -0
  1169. package/src/placeholder/style.scss +65 -24
  1170. package/src/placeholder/test/index.tsx +174 -0
  1171. package/src/placeholder/types.ts +48 -0
  1172. package/src/popover/README.md +7 -0
  1173. package/src/popover/index.js +256 -157
  1174. package/src/popover/stories/index.js +213 -96
  1175. package/src/popover/style.scss +61 -7
  1176. package/src/popover/test/__snapshots__/index.js.snap +6 -6
  1177. package/src/popover/test/index.js +138 -23
  1178. package/src/popover/utils.js +107 -0
  1179. package/src/radio-control/index.tsx +1 -2
  1180. package/src/range-control/README.md +1 -1
  1181. package/src/range-control/index.tsx +3 -0
  1182. package/src/range-control/styles/range-control-styles.ts +9 -16
  1183. package/src/range-control/test/index.tsx +30 -0
  1184. package/src/range-control/types.ts +9 -4
  1185. package/src/range-control/utils.ts +4 -1
  1186. package/src/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +1 -1
  1187. package/src/sandbox/index.native.js +14 -1
  1188. package/src/scroll-lock/README.md +1 -1
  1189. package/src/scroll-lock/{index.js → index.tsx} +34 -7
  1190. package/src/scroll-lock/stories/index.tsx +96 -0
  1191. package/src/scroll-lock/test/index.tsx +26 -0
  1192. package/src/select-control/chevron-down.tsx +25 -0
  1193. package/src/select-control/index.tsx +7 -11
  1194. package/src/select-control/styles/select-control-styles.ts +54 -22
  1195. package/src/select-control/types.ts +1 -0
  1196. package/src/shortcut/{index.js → index.tsx} +5 -9
  1197. package/src/shortcut/test/__snapshots__/index.tsx.snap +15 -0
  1198. package/src/shortcut/test/index.tsx +41 -0
  1199. package/src/shortcut/types.ts +10 -0
  1200. package/src/slot-fill/test/slot.js +5 -5
  1201. package/src/snackbar/list.js +3 -2
  1202. package/src/spacer/component.tsx +3 -1
  1203. package/src/spinner/index.tsx +2 -0
  1204. package/src/style-provider/index.tsx +41 -0
  1205. package/src/style-provider/types.ts +15 -0
  1206. package/src/style.scss +0 -2
  1207. package/src/text/hook.js +5 -3
  1208. package/src/text/styles.js +1 -1
  1209. package/src/text/test/index.tsx +1 -1
  1210. package/src/toggle-group-control/stories/index.tsx +127 -0
  1211. package/src/toggle-group-control/test/__snapshots__/{index.js.snap → index.tsx.snap} +56 -26
  1212. package/src/toggle-group-control/test/{index.js → index.tsx} +2 -4
  1213. package/src/toggle-group-control/toggle-group-control/README.md +2 -0
  1214. package/src/toggle-group-control/toggle-group-control/component.tsx +20 -11
  1215. package/src/toggle-group-control/toggle-group-control/styles.ts +30 -7
  1216. package/src/toggle-group-control/toggle-group-control-option/component.tsx +19 -3
  1217. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +3 -0
  1218. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +17 -3
  1219. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +6 -8
  1220. package/src/toggle-group-control/toggle-group-control-option-icon/component.tsx +30 -7
  1221. package/src/toggle-group-control/types.ts +74 -53
  1222. package/src/toolbar/test/index.js +4 -4
  1223. package/src/toolbar-group/test/index.js +9 -15
  1224. package/src/tools-panel/styles.ts +9 -18
  1225. package/src/tools-panel/test/index.js +3 -2
  1226. package/src/tools-panel/tools-panel/README.md +94 -21
  1227. package/src/tools-panel/tools-panel/hook.ts +6 -1
  1228. package/src/tooltip/index.js +57 -15
  1229. package/src/tooltip/stories/index.js +28 -13
  1230. package/src/tooltip/style.scss +1 -1
  1231. package/src/tooltip/test/index.js +188 -172
  1232. package/src/tree-grid/index.js +4 -9
  1233. package/src/tree-select/index.tsx +5 -4
  1234. package/src/tree-select/types.ts +4 -0
  1235. package/src/ui/context/context-connect.ts +3 -2
  1236. package/src/ui/context/test/context-system-provider.js +101 -1
  1237. package/src/ui/context/use-context-system.js +7 -2
  1238. package/src/ui/tooltip/styles.js +1 -0
  1239. package/src/ui/tooltip/test/__snapshots__/index.js.snap +1 -0
  1240. package/src/ui/utils/space.ts +7 -1
  1241. package/src/unit-control/index.tsx +2 -2
  1242. package/src/unit-control/stories/index.tsx +16 -23
  1243. package/src/unit-control/styles/unit-control-styles.ts +100 -46
  1244. package/src/unit-control/test/__snapshots__/index.tsx.snap +4 -4
  1245. package/src/unit-control/types.ts +12 -9
  1246. package/src/utils/base-label.ts +13 -0
  1247. package/src/utils/box-sizing.ts +14 -0
  1248. package/src/utils/colors-values.js +42 -137
  1249. package/src/utils/config-values.js +1 -1
  1250. package/src/utils/input/input-control.js +6 -6
  1251. package/src/utils/rtl.js +6 -2
  1252. package/src/utils/strings.ts +72 -0
  1253. package/src/utils/style-mixins.js +2 -0
  1254. package/src/utils/test/strings.js +15 -0
  1255. package/tsconfig.json +1 -0
  1256. package/tsconfig.tsbuildinfo +1 -1
  1257. package/build/custom-gradient-bar/constants.js.map +0 -1
  1258. package/build/custom-gradient-bar/control-points.js.map +0 -1
  1259. package/build/custom-gradient-bar/index.js.map +0 -1
  1260. package/build/custom-gradient-bar/utils.js.map +0 -1
  1261. package/build/date-time/date/utils.js +0 -34
  1262. package/build/date-time/date/utils.js.map +0 -1
  1263. package/build/swatch/index.js +0 -39
  1264. package/build/swatch/index.js.map +0 -1
  1265. package/build-module/custom-gradient-bar/constants.js.map +0 -1
  1266. package/build-module/custom-gradient-bar/control-points.js.map +0 -1
  1267. package/build-module/custom-gradient-bar/index.js.map +0 -1
  1268. package/build-module/custom-gradient-bar/utils.js.map +0 -1
  1269. package/build-module/date-time/date/utils.js +0 -22
  1270. package/build-module/date-time/date/utils.js.map +0 -1
  1271. package/build-module/swatch/index.js +0 -28
  1272. package/build-module/swatch/index.js.map +0 -1
  1273. package/build-types/date-time/date/test/utils.d.ts +0 -2
  1274. package/build-types/date-time/date/test/utils.d.ts.map +0 -1
  1275. package/build-types/date-time/date/utils.d.ts +0 -15
  1276. package/build-types/date-time/date/utils.d.ts.map +0 -1
  1277. package/build-types/form-token-field/test/lib/fixtures.d.ts +0 -26
  1278. package/build-types/form-token-field/test/lib/fixtures.d.ts.map +0 -1
  1279. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts +0 -21
  1280. package/build-types/form-token-field/test/lib/token-field-wrapper.d.ts.map +0 -1
  1281. package/src/card/stories/index.js +0 -209
  1282. package/src/date-time/date/datepicker.scss +0 -863
  1283. package/src/date-time/date/style.scss +0 -85
  1284. package/src/date-time/date/test/utils.ts +0 -32
  1285. package/src/date-time/date/utils.ts +0 -20
  1286. package/src/date-time/style.scss +0 -1
  1287. package/src/disabled/index.js +0 -55
  1288. package/src/disabled/stories/index.js +0 -61
  1289. package/src/disabled/test/index.js +0 -240
  1290. package/src/divider/test/index.js +0 -41
  1291. package/src/elevation/component.js +0 -43
  1292. package/src/elevation/stories/index.js +0 -148
  1293. package/src/elevation/test/index.js +0 -51
  1294. package/src/flex/flex/component.js +0 -60
  1295. package/src/flex/flex-block/component.js +0 -30
  1296. package/src/flex/flex-item/component.js +0 -30
  1297. package/src/flex/stories/index.js +0 -29
  1298. package/src/flex/test/index.js +0 -77
  1299. package/src/form-token-field/test/index.js +0 -411
  1300. package/src/form-token-field/test/lib/fixtures.js +0 -89
  1301. package/src/form-token-field/test/lib/token-field-wrapper.tsx +0 -71
  1302. package/src/menu-group/test/__snapshots__/index.js.snap +0 -23
  1303. package/src/placeholder/stories/index.js +0 -44
  1304. package/src/placeholder/test/index.js +0 -163
  1305. package/src/popover/stories/_utils.js +0 -64
  1306. package/src/scroll-lock/stories/index.js +0 -71
  1307. package/src/scroll-lock/test/index.js +0 -53
  1308. package/src/shortcut/test/index.js +0 -37
  1309. package/src/style-provider/index.js +0 -31
  1310. package/src/swatch/index.js +0 -19
  1311. package/src/swatch/style.scss +0 -21
  1312. package/src/toggle-group-control/stories/index.js +0 -187
  1313. package/src/tools-panel/test/__snapshots__/index.js.snap +0 -219
@@ -1,7 +1,8 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { find, startsWith, get, camelCase, has } from 'lodash';
4
+ import { camelCase } from 'change-case';
5
+ import { find, get, has } from 'lodash';
5
6
  import { Dimensions } from 'react-native';
6
7
  /**
7
8
  * WordPress dependencies
@@ -20,6 +21,7 @@ const BLOCK_STYLE_ATTRIBUTES_MAPPING = {
20
21
  const PADDING = 12; // $solid-border-space
21
22
 
22
23
  const UNKNOWN_VALUE = 'undefined';
24
+ const DEFAULT_FONT_SIZE = 16;
23
25
  export function getBlockPaddings(mergedStyle, wrapperPropsStyle, blockStyleAttributes, blockColors) {
24
26
  const blockPaddings = {};
25
27
 
@@ -74,8 +76,10 @@ export function getBlockColors(blockStyleAttributes, defaultColors, blockName, b
74
76
 
75
77
 
76
78
  Object.entries(blockStyleAttributes).forEach(_ref2 => {
79
+ var _value$startsWith;
80
+
77
81
  let [key, value] = _ref2;
78
- const isCustomColor = startsWith(value, '#');
82
+ const isCustomColor = value === null || value === void 0 ? void 0 : (_value$startsWith = value.startsWith) === null || _value$startsWith === void 0 ? void 0 : _value$startsWith.call(value, '#');
79
83
  let styleKey = key;
80
84
 
81
85
  if (BLOCK_STYLE_ATTRIBUTES_MAPPING[styleKey]) {
@@ -156,7 +160,7 @@ export function getBlockTypography(blockStyleAttributes, fontSizes, blockName, b
156
160
  }
157
161
  export function parseStylesVariables(styles, mappedValues, customValues) {
158
162
  let stylesBase = styles;
159
- const variables = ['preset', 'custom', 'var'];
163
+ const variables = ['preset', 'custom', 'var', 'fontSize'];
160
164
 
161
165
  if (!stylesBase) {
162
166
  return styles;
@@ -169,6 +173,7 @@ export function parseStylesVariables(styles, mappedValues, customValues) {
169
173
  // var:preset|color|custom-color-2
170
174
  const regex = new RegExp(`var\\(--wp--${variable}--(.*?)\\)`, 'g');
171
175
  const varRegex = /\"var:preset\|color\|(.*?)\"/gm;
176
+ const fontSizeRegex = /"fontSize":"(.*?)"/gm;
172
177
 
173
178
  if (variable === 'preset') {
174
179
  stylesBase = stylesBase.replace(regex, (_$1, $2) => {
@@ -214,6 +219,21 @@ export function parseStylesVariables(styles, mappedValues, customValues) {
214
219
  return UNKNOWN_VALUE;
215
220
  });
216
221
  }
222
+
223
+ if (variable === 'fontSize') {
224
+ const {
225
+ width,
226
+ height
227
+ } = Dimensions.get('window');
228
+ stylesBase = stylesBase.replace(fontSizeRegex, (_$1, $2) => {
229
+ const parsedFontSize = getPxFromCssUnit($2, {
230
+ width,
231
+ height,
232
+ fontSize: DEFAULT_FONT_SIZE
233
+ }) || `${DEFAULT_FONT_SIZE}px`;
234
+ return `"fontSize":"${parsedFontSize}"`;
235
+ });
236
+ }
217
237
  });
218
238
  return JSON.parse(stylesBase);
219
239
  }
@@ -260,7 +280,7 @@ function normalizeFontSizes(fontSizes) {
260
280
  fontSizeObject.sizePx = getPxFromCssUnit(fontSizeObject.size, {
261
281
  width: dimensions.width,
262
282
  height: dimensions.height,
263
- fontSize: 16
283
+ fontSize: DEFAULT_FONT_SIZE
264
284
  });
265
285
  return fontSizeObject;
266
286
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/global-styles-context/utils.native.js"],"names":["find","startsWith","get","camelCase","has","Dimensions","getPxFromCssUnit","useSetting","useMultipleOriginColorsAndGradients","BLOCK_STYLE_ATTRIBUTES","BLOCK_STYLE_ATTRIBUTES_MAPPING","textColor","text","background","link","placeholder","PADDING","UNKNOWN_VALUE","getBlockPaddings","mergedStyle","wrapperPropsStyle","blockStyleAttributes","blockColors","blockPaddings","padding","backgroundColor","undefined","getBlockColors","defaultColors","blockName","baseGlobalStyles","blockStyles","customBlockStyles","style","color","blockGlobalStyles","blocks","Object","entries","forEach","key","value","styleKey","styles","elements","linkColor","isCustomColor","mappedColor","slug","getBlockTypography","fontSizes","typographyStyles","typography","fontSize","lineHeight","parseInt","mappedFontSize","size","parseStylesVariables","mappedValues","customValues","stylesBase","variables","variable","regex","RegExp","varRegex","replace","_$1","$2","path","split","mappedPresetValue","matchedValue","values","customValuesData","JSON","parse","slice","length","getMappedValues","features","palette","colors","theme","custom","default","normalizeFontSizes","normalizedFontSizes","dimensions","map","fontSizeObject","sizePx","width","height","useMobileGlobalStylesColors","type","colorGradientSettings","availableThemeColors","reduce","origin","concat","colorPalette","editorDefaultPalette","getColorsAndGradients","defaultEditorColors","defaultEditorGradients","rawFeatures","__experimentalGlobalStylesBaseStyles","__experimentalFeatures","gradients","defaultPalette","defaultGradients","getGlobalStyles","rawStyles","stringify","globalStyles","customLineHeight"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { find, startsWith, get, camelCase, has } from 'lodash';\nimport { Dimensions } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport {\n\tgetPxFromCssUnit,\n\tuseSetting,\n\tuseMultipleOriginColorsAndGradients,\n} from '@wordpress/block-editor';\n\nexport const BLOCK_STYLE_ATTRIBUTES = [\n\t'textColor',\n\t'backgroundColor',\n\t'style',\n\t'color',\n\t'fontSize',\n];\n\n// Mapping style properties name to native.\nconst BLOCK_STYLE_ATTRIBUTES_MAPPING = {\n\ttextColor: 'color',\n\ttext: 'color',\n\tbackground: 'backgroundColor',\n\tlink: 'linkColor',\n\tplaceholder: 'placeholderColor',\n};\n\nconst PADDING = 12; // $solid-border-space\nconst UNKNOWN_VALUE = 'undefined';\n\nexport function getBlockPaddings(\n\tmergedStyle,\n\twrapperPropsStyle,\n\tblockStyleAttributes,\n\tblockColors\n) {\n\tconst blockPaddings = {};\n\n\tif (\n\t\t! mergedStyle.padding &&\n\t\t( wrapperPropsStyle?.backgroundColor ||\n\t\t\tblockStyleAttributes?.backgroundColor ||\n\t\t\tblockColors?.backgroundColor )\n\t) {\n\t\tblockPaddings.padding = PADDING;\n\t\treturn blockPaddings;\n\t}\n\n\t// Prevent adding extra paddings to inner blocks without background colors.\n\tif (\n\t\tmergedStyle?.padding &&\n\t\t! wrapperPropsStyle?.backgroundColor &&\n\t\t! blockStyleAttributes?.backgroundColor &&\n\t\t! blockColors?.backgroundColor\n\t) {\n\t\tblockPaddings.padding = undefined;\n\t}\n\n\treturn blockPaddings;\n}\n\nexport function getBlockColors(\n\tblockStyleAttributes,\n\tdefaultColors,\n\tblockName,\n\tbaseGlobalStyles\n) {\n\tconst blockStyles = {};\n\tconst customBlockStyles = blockStyleAttributes?.style?.color || {};\n\tconst blockGlobalStyles = baseGlobalStyles?.blocks?.[ blockName ];\n\n\t// Global styles colors.\n\tif ( blockGlobalStyles?.color ) {\n\t\tObject.entries( blockGlobalStyles.color ).forEach(\n\t\t\t( [ key, value ] ) => {\n\t\t\t\tconst styleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING[ key ];\n\n\t\t\t\tif ( styleKey && value !== UNKNOWN_VALUE ) {\n\t\t\t\t\tconst color = customBlockStyles[ key ] ?? value;\n\t\t\t\t\tblockStyles[ styleKey ] = color;\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t} else if ( baseGlobalStyles?.styles?.color?.text ) {\n\t\tblockStyles[ BLOCK_STYLE_ATTRIBUTES_MAPPING.text ] =\n\t\t\tbaseGlobalStyles?.styles?.color?.text;\n\t}\n\n\t// Global styles elements.\n\tif ( blockGlobalStyles?.elements ) {\n\t\tconst linkColor = blockGlobalStyles.elements?.link?.color?.text;\n\t\tconst styleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING.link;\n\n\t\tif ( styleKey && linkColor && linkColor !== UNKNOWN_VALUE ) {\n\t\t\tblockStyles[ styleKey ] = linkColor;\n\t\t}\n\t}\n\n\t// Custom colors.\n\tObject.entries( blockStyleAttributes ).forEach( ( [ key, value ] ) => {\n\t\tconst isCustomColor = startsWith( value, '#' );\n\t\tlet styleKey = key;\n\n\t\tif ( BLOCK_STYLE_ATTRIBUTES_MAPPING[ styleKey ] ) {\n\t\t\tstyleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING[ styleKey ];\n\t\t}\n\n\t\tif ( ! isCustomColor ) {\n\t\t\tconst mappedColor = find( defaultColors, {\n\t\t\t\tslug: value,\n\t\t\t} );\n\n\t\t\tif ( mappedColor ) {\n\t\t\t\tblockStyles[ styleKey ] = mappedColor.color;\n\t\t\t}\n\t\t} else {\n\t\t\tblockStyles[ styleKey ] = value;\n\t\t}\n\t} );\n\n\t// Color placeholder.\n\tif ( blockStyles?.color ) {\n\t\tblockStyles[ BLOCK_STYLE_ATTRIBUTES_MAPPING.placeholder ] =\n\t\t\tblockStyles.color;\n\t}\n\n\treturn blockStyles;\n}\n\nexport function getBlockTypography(\n\tblockStyleAttributes,\n\tfontSizes,\n\tblockName,\n\tbaseGlobalStyles\n) {\n\tconst typographyStyles = {};\n\tconst customBlockStyles = blockStyleAttributes?.style?.typography || {};\n\tconst blockGlobalStyles = baseGlobalStyles?.blocks?.[ blockName ];\n\n\t// Global styles.\n\tif ( blockGlobalStyles?.typography ) {\n\t\tconst fontSize = blockGlobalStyles?.typography?.fontSize;\n\t\tconst lineHeight = blockGlobalStyles?.typography?.lineHeight;\n\n\t\tif ( fontSize ) {\n\t\t\tif ( parseInt( fontSize, 10 ) ) {\n\t\t\t\ttypographyStyles.fontSize = fontSize;\n\t\t\t} else {\n\t\t\t\tconst mappedFontSize = find( fontSizes, {\n\t\t\t\t\tslug: fontSize,\n\t\t\t\t} );\n\n\t\t\t\tif ( mappedFontSize ) {\n\t\t\t\t\ttypographyStyles.fontSize = mappedFontSize?.size;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( lineHeight ) {\n\t\t\ttypographyStyles.lineHeight = lineHeight;\n\t\t}\n\t}\n\n\tif ( blockStyleAttributes?.fontSize && baseGlobalStyles ) {\n\t\tconst mappedFontSize = find( fontSizes, {\n\t\t\tslug: blockStyleAttributes?.fontSize,\n\t\t} );\n\n\t\tif ( mappedFontSize ) {\n\t\t\ttypographyStyles.fontSize = mappedFontSize?.size;\n\t\t}\n\t}\n\n\t// Custom styles.\n\tif ( customBlockStyles?.fontSize ) {\n\t\ttypographyStyles.fontSize = customBlockStyles?.fontSize;\n\t}\n\n\tif ( customBlockStyles?.lineHeight ) {\n\t\ttypographyStyles.lineHeight = customBlockStyles?.lineHeight;\n\t}\n\n\treturn typographyStyles;\n}\n\nexport function parseStylesVariables( styles, mappedValues, customValues ) {\n\tlet stylesBase = styles;\n\tconst variables = [ 'preset', 'custom', 'var' ];\n\n\tif ( ! stylesBase ) {\n\t\treturn styles;\n\t}\n\n\tvariables.forEach( ( variable ) => {\n\t\t// Examples\n\t\t// var(--wp--preset--color--gray)\n\t\t// var(--wp--custom--body--typography--font-family)\n\t\t// var:preset|color|custom-color-2\n\t\tconst regex = new RegExp( `var\\\\(--wp--${ variable }--(.*?)\\\\)`, 'g' );\n\t\tconst varRegex = /\\\"var:preset\\|color\\|(.*?)\\\"/gm;\n\n\t\tif ( variable === 'preset' ) {\n\t\t\tstylesBase = stylesBase.replace( regex, ( _$1, $2 ) => {\n\t\t\t\tconst path = $2.split( '--' );\n\t\t\t\tconst mappedPresetValue = mappedValues[ path[ 0 ] ];\n\t\t\t\tif ( mappedPresetValue && mappedPresetValue.slug ) {\n\t\t\t\t\tconst matchedValue = find( mappedPresetValue.values, {\n\t\t\t\t\t\tslug: path[ 1 ],\n\t\t\t\t\t} );\n\t\t\t\t\treturn matchedValue?.[ mappedPresetValue.slug ];\n\t\t\t\t}\n\t\t\t\treturn UNKNOWN_VALUE;\n\t\t\t} );\n\t\t}\n\t\tif ( variable === 'custom' ) {\n\t\t\tconst customValuesData = customValues ?? JSON.parse( stylesBase );\n\t\t\tstylesBase = stylesBase.replace( regex, ( _$1, $2 ) => {\n\t\t\t\tconst path = $2.split( '--' );\n\t\t\t\tif ( has( customValuesData, path ) ) {\n\t\t\t\t\treturn get( customValuesData, path );\n\t\t\t\t}\n\n\t\t\t\t// Check for camelcase properties.\n\t\t\t\treturn get( customValuesData, [\n\t\t\t\t\t...path.slice( 0, path.length - 1 ),\n\t\t\t\t\tcamelCase( path[ path.length - 1 ] ),\n\t\t\t\t] );\n\t\t\t} );\n\t\t}\n\n\t\tif ( variable === 'var' ) {\n\t\t\tstylesBase = stylesBase.replace( varRegex, ( _$1, $2 ) => {\n\t\t\t\tif ( mappedValues?.color ) {\n\t\t\t\t\tconst matchedValue = find( mappedValues.color?.values, {\n\t\t\t\t\t\tslug: $2,\n\t\t\t\t\t} );\n\t\t\t\t\treturn `\"${ matchedValue?.color }\"`;\n\t\t\t\t}\n\t\t\t\treturn UNKNOWN_VALUE;\n\t\t\t} );\n\t\t}\n\t} );\n\n\treturn JSON.parse( stylesBase );\n}\n\nexport function getMappedValues( features, palette ) {\n\tconst typography = features?.typography;\n\tconst colors = [\n\t\t...( palette?.theme || [] ),\n\t\t...( palette?.custom || [] ),\n\t\t...( palette?.default || [] ),\n\t];\n\n\tconst fontSizes = {\n\t\t...typography?.fontSizes?.theme,\n\t\t...typography?.fontSizes?.custom,\n\t};\n\tconst mappedValues = {\n\t\tcolor: {\n\t\t\tvalues: colors,\n\t\t\tslug: 'color',\n\t\t},\n\t\t'font-size': {\n\t\t\tvalues: fontSizes,\n\t\t\tslug: 'size',\n\t\t},\n\t};\n\treturn mappedValues;\n}\n\n/**\n * Returns the normalized fontSizes to include the sizePx value for each of the different sizes.\n *\n * @param {Object} fontSizes found in global styles.\n * @return {Object} normalized sizes.\n */\nfunction normalizeFontSizes( fontSizes ) {\n\t// Adds normalized PX values for each of the different keys.\n\tif ( ! fontSizes ) {\n\t\treturn fontSizes;\n\t}\n\tconst normalizedFontSizes = {};\n\tconst dimensions = Dimensions.get( 'window' );\n\n\t[ 'default', 'theme', 'custom' ].forEach( ( key ) => {\n\t\tif ( fontSizes[ key ] ) {\n\t\t\tnormalizedFontSizes[ key ] = fontSizes[ key ]?.map(\n\t\t\t\t( fontSizeObject ) => {\n\t\t\t\t\tfontSizeObject.sizePx = getPxFromCssUnit(\n\t\t\t\t\t\tfontSizeObject.size,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\twidth: dimensions.width,\n\t\t\t\t\t\t\theight: dimensions.height,\n\t\t\t\t\t\t\tfontSize: 16,\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t\treturn fontSizeObject;\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\t} );\n\n\treturn normalizedFontSizes;\n}\n\nexport function useMobileGlobalStylesColors( type = 'colors' ) {\n\tconst colorGradientSettings = useMultipleOriginColorsAndGradients();\n\tconst availableThemeColors = colorGradientSettings?.[ type ]?.reduce(\n\t\t( colors, origin ) => colors.concat( origin?.[ type ] ),\n\t\t[]\n\t);\n\t// Default editor colors/gradients if it's not a block-based theme.\n\tconst colorPalette =\n\t\ttype === 'colors' ? 'color.palette' : 'color.gradients';\n\tconst editorDefaultPalette = useSetting( colorPalette );\n\n\treturn availableThemeColors.length >= 1\n\t\t? availableThemeColors\n\t\t: editorDefaultPalette;\n}\n\nexport function getColorsAndGradients(\n\tdefaultEditorColors = [],\n\tdefaultEditorGradients = [],\n\trawFeatures\n) {\n\tconst features = rawFeatures ? JSON.parse( rawFeatures ) : {};\n\n\treturn {\n\t\t__experimentalGlobalStylesBaseStyles: null,\n\t\t__experimentalFeatures: {\n\t\t\tcolor: {\n\t\t\t\t...( ! features?.color\n\t\t\t\t\t? {\n\t\t\t\t\t\t\ttext: true,\n\t\t\t\t\t\t\tbackground: true,\n\t\t\t\t\t\t\tpalette: {\n\t\t\t\t\t\t\t\tdefault: defaultEditorColors,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tgradients: {\n\t\t\t\t\t\t\t\tdefault: defaultEditorGradients,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t }\n\t\t\t\t\t: features?.color ),\n\t\t\t\tdefaultPalette: defaultEditorColors?.length > 0,\n\t\t\t\tdefaultGradients: defaultEditorGradients?.length > 0,\n\t\t\t},\n\t\t},\n\t};\n}\n\nexport function getGlobalStyles( rawStyles, rawFeatures ) {\n\tconst features = rawFeatures ? JSON.parse( rawFeatures ) : {};\n\tconst mappedValues = getMappedValues( features, features?.color?.palette );\n\tconst colors = parseStylesVariables(\n\t\tJSON.stringify( features?.color ),\n\t\tmappedValues\n\t);\n\tconst gradients = parseStylesVariables(\n\t\tJSON.stringify( features?.color?.gradients ),\n\t\tmappedValues\n\t);\n\tconst customValues = parseStylesVariables(\n\t\tJSON.stringify( features?.custom ),\n\t\tmappedValues\n\t);\n\tconst globalStyles = parseStylesVariables(\n\t\trawStyles,\n\t\tmappedValues,\n\t\tcustomValues\n\t);\n\n\tconst fontSizes = normalizeFontSizes( features?.typography?.fontSizes );\n\n\treturn {\n\t\t__experimentalFeatures: {\n\t\t\tcolor: {\n\t\t\t\tpalette: colors?.palette,\n\t\t\t\tgradients,\n\t\t\t\ttext: features?.color?.text ?? true,\n\t\t\t\tbackground: features?.color?.background ?? true,\n\t\t\t\tdefaultPalette: features?.color?.defaultPalette ?? true,\n\t\t\t\tdefaultGradients: features?.color?.defaultGradients ?? true,\n\t\t\t},\n\t\t\ttypography: {\n\t\t\t\tfontSizes,\n\t\t\t\tcustomLineHeight: features?.custom?.[ 'line-height' ],\n\t\t\t},\n\t\t},\n\t\t__experimentalGlobalStylesBaseStyles: globalStyles,\n\t};\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/global-styles-context/utils.native.js"],"names":["camelCase","find","get","has","Dimensions","getPxFromCssUnit","useSetting","useMultipleOriginColorsAndGradients","BLOCK_STYLE_ATTRIBUTES","BLOCK_STYLE_ATTRIBUTES_MAPPING","textColor","text","background","link","placeholder","PADDING","UNKNOWN_VALUE","DEFAULT_FONT_SIZE","getBlockPaddings","mergedStyle","wrapperPropsStyle","blockStyleAttributes","blockColors","blockPaddings","padding","backgroundColor","undefined","getBlockColors","defaultColors","blockName","baseGlobalStyles","blockStyles","customBlockStyles","style","color","blockGlobalStyles","blocks","Object","entries","forEach","key","value","styleKey","styles","elements","linkColor","isCustomColor","startsWith","mappedColor","slug","getBlockTypography","fontSizes","typographyStyles","typography","fontSize","lineHeight","parseInt","mappedFontSize","size","parseStylesVariables","mappedValues","customValues","stylesBase","variables","variable","regex","RegExp","varRegex","fontSizeRegex","replace","_$1","$2","path","split","mappedPresetValue","matchedValue","values","customValuesData","JSON","parse","slice","length","width","height","parsedFontSize","getMappedValues","features","palette","colors","theme","custom","default","normalizeFontSizes","normalizedFontSizes","dimensions","map","fontSizeObject","sizePx","useMobileGlobalStylesColors","type","colorGradientSettings","availableThemeColors","reduce","origin","concat","colorPalette","editorDefaultPalette","getColorsAndGradients","defaultEditorColors","defaultEditorGradients","rawFeatures","__experimentalGlobalStylesBaseStyles","__experimentalFeatures","gradients","defaultPalette","defaultGradients","getGlobalStyles","rawStyles","stringify","globalStyles","customLineHeight"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { camelCase } from 'change-case';\nimport { find, get, has } from 'lodash';\nimport { Dimensions } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport {\n\tgetPxFromCssUnit,\n\tuseSetting,\n\tuseMultipleOriginColorsAndGradients,\n} from '@wordpress/block-editor';\n\nexport const BLOCK_STYLE_ATTRIBUTES = [\n\t'textColor',\n\t'backgroundColor',\n\t'style',\n\t'color',\n\t'fontSize',\n];\n\n// Mapping style properties name to native.\nconst BLOCK_STYLE_ATTRIBUTES_MAPPING = {\n\ttextColor: 'color',\n\ttext: 'color',\n\tbackground: 'backgroundColor',\n\tlink: 'linkColor',\n\tplaceholder: 'placeholderColor',\n};\n\nconst PADDING = 12; // $solid-border-space\nconst UNKNOWN_VALUE = 'undefined';\nconst DEFAULT_FONT_SIZE = 16;\n\nexport function getBlockPaddings(\n\tmergedStyle,\n\twrapperPropsStyle,\n\tblockStyleAttributes,\n\tblockColors\n) {\n\tconst blockPaddings = {};\n\n\tif (\n\t\t! mergedStyle.padding &&\n\t\t( wrapperPropsStyle?.backgroundColor ||\n\t\t\tblockStyleAttributes?.backgroundColor ||\n\t\t\tblockColors?.backgroundColor )\n\t) {\n\t\tblockPaddings.padding = PADDING;\n\t\treturn blockPaddings;\n\t}\n\n\t// Prevent adding extra paddings to inner blocks without background colors.\n\tif (\n\t\tmergedStyle?.padding &&\n\t\t! wrapperPropsStyle?.backgroundColor &&\n\t\t! blockStyleAttributes?.backgroundColor &&\n\t\t! blockColors?.backgroundColor\n\t) {\n\t\tblockPaddings.padding = undefined;\n\t}\n\n\treturn blockPaddings;\n}\n\nexport function getBlockColors(\n\tblockStyleAttributes,\n\tdefaultColors,\n\tblockName,\n\tbaseGlobalStyles\n) {\n\tconst blockStyles = {};\n\tconst customBlockStyles = blockStyleAttributes?.style?.color || {};\n\tconst blockGlobalStyles = baseGlobalStyles?.blocks?.[ blockName ];\n\n\t// Global styles colors.\n\tif ( blockGlobalStyles?.color ) {\n\t\tObject.entries( blockGlobalStyles.color ).forEach(\n\t\t\t( [ key, value ] ) => {\n\t\t\t\tconst styleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING[ key ];\n\n\t\t\t\tif ( styleKey && value !== UNKNOWN_VALUE ) {\n\t\t\t\t\tconst color = customBlockStyles[ key ] ?? value;\n\t\t\t\t\tblockStyles[ styleKey ] = color;\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t} else if ( baseGlobalStyles?.styles?.color?.text ) {\n\t\tblockStyles[ BLOCK_STYLE_ATTRIBUTES_MAPPING.text ] =\n\t\t\tbaseGlobalStyles?.styles?.color?.text;\n\t}\n\n\t// Global styles elements.\n\tif ( blockGlobalStyles?.elements ) {\n\t\tconst linkColor = blockGlobalStyles.elements?.link?.color?.text;\n\t\tconst styleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING.link;\n\n\t\tif ( styleKey && linkColor && linkColor !== UNKNOWN_VALUE ) {\n\t\t\tblockStyles[ styleKey ] = linkColor;\n\t\t}\n\t}\n\n\t// Custom colors.\n\tObject.entries( blockStyleAttributes ).forEach( ( [ key, value ] ) => {\n\t\tconst isCustomColor = value?.startsWith?.( '#' );\n\t\tlet styleKey = key;\n\n\t\tif ( BLOCK_STYLE_ATTRIBUTES_MAPPING[ styleKey ] ) {\n\t\t\tstyleKey = BLOCK_STYLE_ATTRIBUTES_MAPPING[ styleKey ];\n\t\t}\n\n\t\tif ( ! isCustomColor ) {\n\t\t\tconst mappedColor = find( defaultColors, {\n\t\t\t\tslug: value,\n\t\t\t} );\n\n\t\t\tif ( mappedColor ) {\n\t\t\t\tblockStyles[ styleKey ] = mappedColor.color;\n\t\t\t}\n\t\t} else {\n\t\t\tblockStyles[ styleKey ] = value;\n\t\t}\n\t} );\n\n\t// Color placeholder.\n\tif ( blockStyles?.color ) {\n\t\tblockStyles[ BLOCK_STYLE_ATTRIBUTES_MAPPING.placeholder ] =\n\t\t\tblockStyles.color;\n\t}\n\n\treturn blockStyles;\n}\n\nexport function getBlockTypography(\n\tblockStyleAttributes,\n\tfontSizes,\n\tblockName,\n\tbaseGlobalStyles\n) {\n\tconst typographyStyles = {};\n\tconst customBlockStyles = blockStyleAttributes?.style?.typography || {};\n\tconst blockGlobalStyles = baseGlobalStyles?.blocks?.[ blockName ];\n\n\t// Global styles.\n\tif ( blockGlobalStyles?.typography ) {\n\t\tconst fontSize = blockGlobalStyles?.typography?.fontSize;\n\t\tconst lineHeight = blockGlobalStyles?.typography?.lineHeight;\n\n\t\tif ( fontSize ) {\n\t\t\tif ( parseInt( fontSize, 10 ) ) {\n\t\t\t\ttypographyStyles.fontSize = fontSize;\n\t\t\t} else {\n\t\t\t\tconst mappedFontSize = find( fontSizes, {\n\t\t\t\t\tslug: fontSize,\n\t\t\t\t} );\n\n\t\t\t\tif ( mappedFontSize ) {\n\t\t\t\t\ttypographyStyles.fontSize = mappedFontSize?.size;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( lineHeight ) {\n\t\t\ttypographyStyles.lineHeight = lineHeight;\n\t\t}\n\t}\n\n\tif ( blockStyleAttributes?.fontSize && baseGlobalStyles ) {\n\t\tconst mappedFontSize = find( fontSizes, {\n\t\t\tslug: blockStyleAttributes?.fontSize,\n\t\t} );\n\n\t\tif ( mappedFontSize ) {\n\t\t\ttypographyStyles.fontSize = mappedFontSize?.size;\n\t\t}\n\t}\n\n\t// Custom styles.\n\tif ( customBlockStyles?.fontSize ) {\n\t\ttypographyStyles.fontSize = customBlockStyles?.fontSize;\n\t}\n\n\tif ( customBlockStyles?.lineHeight ) {\n\t\ttypographyStyles.lineHeight = customBlockStyles?.lineHeight;\n\t}\n\n\treturn typographyStyles;\n}\n\nexport function parseStylesVariables( styles, mappedValues, customValues ) {\n\tlet stylesBase = styles;\n\tconst variables = [ 'preset', 'custom', 'var', 'fontSize' ];\n\n\tif ( ! stylesBase ) {\n\t\treturn styles;\n\t}\n\n\tvariables.forEach( ( variable ) => {\n\t\t// Examples\n\t\t// var(--wp--preset--color--gray)\n\t\t// var(--wp--custom--body--typography--font-family)\n\t\t// var:preset|color|custom-color-2\n\t\tconst regex = new RegExp( `var\\\\(--wp--${ variable }--(.*?)\\\\)`, 'g' );\n\t\tconst varRegex = /\\\"var:preset\\|color\\|(.*?)\\\"/gm;\n\t\tconst fontSizeRegex = /\"fontSize\":\"(.*?)\"/gm;\n\n\t\tif ( variable === 'preset' ) {\n\t\t\tstylesBase = stylesBase.replace( regex, ( _$1, $2 ) => {\n\t\t\t\tconst path = $2.split( '--' );\n\t\t\t\tconst mappedPresetValue = mappedValues[ path[ 0 ] ];\n\t\t\t\tif ( mappedPresetValue && mappedPresetValue.slug ) {\n\t\t\t\t\tconst matchedValue = find( mappedPresetValue.values, {\n\t\t\t\t\t\tslug: path[ 1 ],\n\t\t\t\t\t} );\n\t\t\t\t\treturn matchedValue?.[ mappedPresetValue.slug ];\n\t\t\t\t}\n\t\t\t\treturn UNKNOWN_VALUE;\n\t\t\t} );\n\t\t}\n\t\tif ( variable === 'custom' ) {\n\t\t\tconst customValuesData = customValues ?? JSON.parse( stylesBase );\n\t\t\tstylesBase = stylesBase.replace( regex, ( _$1, $2 ) => {\n\t\t\t\tconst path = $2.split( '--' );\n\t\t\t\tif ( has( customValuesData, path ) ) {\n\t\t\t\t\treturn get( customValuesData, path );\n\t\t\t\t}\n\n\t\t\t\t// Check for camelcase properties.\n\t\t\t\treturn get( customValuesData, [\n\t\t\t\t\t...path.slice( 0, path.length - 1 ),\n\t\t\t\t\tcamelCase( path[ path.length - 1 ] ),\n\t\t\t\t] );\n\t\t\t} );\n\t\t}\n\n\t\tif ( variable === 'var' ) {\n\t\t\tstylesBase = stylesBase.replace( varRegex, ( _$1, $2 ) => {\n\t\t\t\tif ( mappedValues?.color ) {\n\t\t\t\t\tconst matchedValue = find( mappedValues.color?.values, {\n\t\t\t\t\t\tslug: $2,\n\t\t\t\t\t} );\n\t\t\t\t\treturn `\"${ matchedValue?.color }\"`;\n\t\t\t\t}\n\t\t\t\treturn UNKNOWN_VALUE;\n\t\t\t} );\n\t\t}\n\n\t\tif ( variable === 'fontSize' ) {\n\t\t\tconst { width, height } = Dimensions.get( 'window' );\n\n\t\t\tstylesBase = stylesBase.replace( fontSizeRegex, ( _$1, $2 ) => {\n\t\t\t\tconst parsedFontSize =\n\t\t\t\t\tgetPxFromCssUnit( $2, {\n\t\t\t\t\t\twidth,\n\t\t\t\t\t\theight,\n\t\t\t\t\t\tfontSize: DEFAULT_FONT_SIZE,\n\t\t\t\t\t} ) || `${ DEFAULT_FONT_SIZE }px`;\n\n\t\t\t\treturn `\"fontSize\":\"${ parsedFontSize }\"`;\n\t\t\t} );\n\t\t}\n\t} );\n\n\treturn JSON.parse( stylesBase );\n}\n\nexport function getMappedValues( features, palette ) {\n\tconst typography = features?.typography;\n\tconst colors = [\n\t\t...( palette?.theme || [] ),\n\t\t...( palette?.custom || [] ),\n\t\t...( palette?.default || [] ),\n\t];\n\n\tconst fontSizes = {\n\t\t...typography?.fontSizes?.theme,\n\t\t...typography?.fontSizes?.custom,\n\t};\n\tconst mappedValues = {\n\t\tcolor: {\n\t\t\tvalues: colors,\n\t\t\tslug: 'color',\n\t\t},\n\t\t'font-size': {\n\t\t\tvalues: fontSizes,\n\t\t\tslug: 'size',\n\t\t},\n\t};\n\treturn mappedValues;\n}\n\n/**\n * Returns the normalized fontSizes to include the sizePx value for each of the different sizes.\n *\n * @param {Object} fontSizes found in global styles.\n * @return {Object} normalized sizes.\n */\nfunction normalizeFontSizes( fontSizes ) {\n\t// Adds normalized PX values for each of the different keys.\n\tif ( ! fontSizes ) {\n\t\treturn fontSizes;\n\t}\n\tconst normalizedFontSizes = {};\n\tconst dimensions = Dimensions.get( 'window' );\n\n\t[ 'default', 'theme', 'custom' ].forEach( ( key ) => {\n\t\tif ( fontSizes[ key ] ) {\n\t\t\tnormalizedFontSizes[ key ] = fontSizes[ key ]?.map(\n\t\t\t\t( fontSizeObject ) => {\n\t\t\t\t\tfontSizeObject.sizePx = getPxFromCssUnit(\n\t\t\t\t\t\tfontSizeObject.size,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\twidth: dimensions.width,\n\t\t\t\t\t\t\theight: dimensions.height,\n\t\t\t\t\t\t\tfontSize: DEFAULT_FONT_SIZE,\n\t\t\t\t\t\t}\n\t\t\t\t\t);\n\t\t\t\t\treturn fontSizeObject;\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\t} );\n\n\treturn normalizedFontSizes;\n}\n\nexport function useMobileGlobalStylesColors( type = 'colors' ) {\n\tconst colorGradientSettings = useMultipleOriginColorsAndGradients();\n\tconst availableThemeColors = colorGradientSettings?.[ type ]?.reduce(\n\t\t( colors, origin ) => colors.concat( origin?.[ type ] ),\n\t\t[]\n\t);\n\t// Default editor colors/gradients if it's not a block-based theme.\n\tconst colorPalette =\n\t\ttype === 'colors' ? 'color.palette' : 'color.gradients';\n\tconst editorDefaultPalette = useSetting( colorPalette );\n\n\treturn availableThemeColors.length >= 1\n\t\t? availableThemeColors\n\t\t: editorDefaultPalette;\n}\n\nexport function getColorsAndGradients(\n\tdefaultEditorColors = [],\n\tdefaultEditorGradients = [],\n\trawFeatures\n) {\n\tconst features = rawFeatures ? JSON.parse( rawFeatures ) : {};\n\n\treturn {\n\t\t__experimentalGlobalStylesBaseStyles: null,\n\t\t__experimentalFeatures: {\n\t\t\tcolor: {\n\t\t\t\t...( ! features?.color\n\t\t\t\t\t? {\n\t\t\t\t\t\t\ttext: true,\n\t\t\t\t\t\t\tbackground: true,\n\t\t\t\t\t\t\tpalette: {\n\t\t\t\t\t\t\t\tdefault: defaultEditorColors,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tgradients: {\n\t\t\t\t\t\t\t\tdefault: defaultEditorGradients,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t }\n\t\t\t\t\t: features?.color ),\n\t\t\t\tdefaultPalette: defaultEditorColors?.length > 0,\n\t\t\t\tdefaultGradients: defaultEditorGradients?.length > 0,\n\t\t\t},\n\t\t},\n\t};\n}\n\nexport function getGlobalStyles( rawStyles, rawFeatures ) {\n\tconst features = rawFeatures ? JSON.parse( rawFeatures ) : {};\n\tconst mappedValues = getMappedValues( features, features?.color?.palette );\n\tconst colors = parseStylesVariables(\n\t\tJSON.stringify( features?.color ),\n\t\tmappedValues\n\t);\n\tconst gradients = parseStylesVariables(\n\t\tJSON.stringify( features?.color?.gradients ),\n\t\tmappedValues\n\t);\n\tconst customValues = parseStylesVariables(\n\t\tJSON.stringify( features?.custom ),\n\t\tmappedValues\n\t);\n\tconst globalStyles = parseStylesVariables(\n\t\trawStyles,\n\t\tmappedValues,\n\t\tcustomValues\n\t);\n\n\tconst fontSizes = normalizeFontSizes( features?.typography?.fontSizes );\n\n\treturn {\n\t\t__experimentalFeatures: {\n\t\t\tcolor: {\n\t\t\t\tpalette: colors?.palette,\n\t\t\t\tgradients,\n\t\t\t\ttext: features?.color?.text ?? true,\n\t\t\t\tbackground: features?.color?.background ?? true,\n\t\t\t\tdefaultPalette: features?.color?.defaultPalette ?? true,\n\t\t\t\tdefaultGradients: features?.color?.defaultGradients ?? true,\n\t\t\t},\n\t\t\ttypography: {\n\t\t\t\tfontSizes,\n\t\t\t\tcustomLineHeight: features?.custom?.[ 'line-height' ],\n\t\t\t},\n\t\t},\n\t\t__experimentalGlobalStylesBaseStyles: globalStyles,\n\t};\n}\n"]}
@@ -4,7 +4,7 @@ import { createElement } from "@wordpress/element";
4
4
  /**
5
5
  * External dependencies
6
6
  */
7
- import { Image, Text, View } from 'react-native';
7
+ import { Image as RNImage, Text, View } from 'react-native';
8
8
  import FastImage from 'react-native-fast-image';
9
9
  /**
10
10
  * WordPress dependencies
@@ -14,7 +14,7 @@ import { __ } from '@wordpress/i18n';
14
14
  import { Icon } from '@wordpress/components';
15
15
  import { image as icon } from '@wordpress/icons';
16
16
  import { usePreferredColorSchemeStyle } from '@wordpress/compose';
17
- import { useEffect, useState } from '@wordpress/element';
17
+ import { useEffect, useState, Platform } from '@wordpress/element';
18
18
  /**
19
19
  * Internal dependencies
20
20
  */
@@ -44,6 +44,7 @@ const ImageComponent = _ref => {
44
44
  height: imageHeight,
45
45
  highlightSelected = true,
46
46
  isSelected,
47
+ shouldUseFastImage,
47
48
  isUploadFailed,
48
49
  isUploadInProgress,
49
50
  mediaPickerOptions,
@@ -59,12 +60,15 @@ const ImageComponent = _ref => {
59
60
  width: imageWidth
60
61
  } = _ref;
61
62
  const [imageData, setImageData] = useState(null);
62
- const [containerSize, setContainerSize] = useState(null);
63
+ const [containerSize, setContainerSize] = useState(null); // Disabled for Android due to https://github.com/WordPress/gutenberg/issues/43149
64
+
65
+ const Image = !shouldUseFastImage || Platform.isAndroid ? RNImage : FastImage;
66
+ const imageResizeMode = !shouldUseFastImage || Platform.isAndroid ? resizeMode : FastImage.resizeMode[resizeMode];
63
67
  useEffect(() => {
64
68
  let isCurrent = true;
65
69
 
66
70
  if (url) {
67
- Image.getSize(url, (imgWidth, imgHeight) => {
71
+ RNImage.getSize(url, (imgWidth, imgHeight) => {
68
72
  if (!isCurrent) {
69
73
  return;
70
74
  }
@@ -136,6 +140,8 @@ const ImageComponent = _ref => {
136
140
  const imageStyles = [{
137
141
  opacity: isUploadInProgress ? 0.3 : 1,
138
142
  height: containerSize === null || containerSize === void 0 ? void 0 : containerSize.height
143
+ }, !resizeMode && {
144
+ aspectRatio: imageData === null || imageData === void 0 ? void 0 : imageData.aspectRatio
139
145
  }, focalPoint && styles.focalPoint, focalPoint && getImageWithFocalPointStyles(focalPoint, containerSize, imageData), !focalPoint && imageData && containerSize && {
140
146
  height: (imageData === null || imageData === void 0 ? void 0 : imageData.width) > (containerSize === null || containerSize === void 0 ? void 0 : containerSize.width) ? (containerSize === null || containerSize === void 0 ? void 0 : containerSize.width) / (imageData === null || imageData === void 0 ? void 0 : imageData.aspectRatio) : undefined
141
147
  }, imageHeight && {
@@ -167,9 +173,7 @@ const ImageComponent = _ref => {
167
173
  style: styles.imageUploadingIconContainer
168
174
  }, getIcon(ICON_TYPE.UPLOAD))) : createElement(View, {
169
175
  style: focalPoint && styles.focalPointContent
170
- }, createElement(FastImage, _extends({}, !resizeMode && {
171
- aspectRatio: imageData === null || imageData === void 0 ? void 0 : imageData.aspectRatio
172
- }, {
176
+ }, createElement(Image, _extends({
173
177
  style: imageStyles,
174
178
  source: {
175
179
  uri: url
@@ -177,7 +181,7 @@ const ImageComponent = _ref => {
177
181
  }, !focalPoint && {
178
182
  resizeMethod: 'scale'
179
183
  }, {
180
- resizeMode: FastImage.resizeMode[resizeMode]
184
+ resizeMode: imageResizeMode
181
185
  }))), isUploadFailed && retryMessage && createElement(View, {
182
186
  style: [styles.imageContainer, styles.retryContainer]
183
187
  }, createElement(View, {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/image/index.native.js"],"names":["Image","Text","View","FastImage","__","Icon","image","icon","usePreferredColorSchemeStyle","useEffect","useState","getImageWithFocalPointStyles","styles","SvgIconRetry","ImageEditingButton","ICON_TYPE","PLACEHOLDER","RETRY","UPLOAD","IMAGE_DEFAULT_FOCAL_POINT","x","y","ImageComponent","align","alt","editButton","focalPoint","height","imageHeight","highlightSelected","isSelected","isUploadFailed","isUploadInProgress","mediaPickerOptions","onImageDataLoad","onSelectMediaUploadOption","openMediaOptions","resizeMode","retryMessage","retryIcon","url","shapeStyle","style","width","imageWidth","imageData","setImageData","containerSize","setContainerSize","isCurrent","getSize","imgWidth","imgHeight","metaData","aspectRatio","onContainerLayout","event","nativeEvent","layout","getIcon","iconType","iconStyle","iconRetry","iconPlaceholderStyles","iconUploadStyles","iconPlaceholder","iconPlaceholderDark","iconUpload","iconUploadDark","placeholderStyles","imageContainerUpload","imageContainerUploadDark","imageContainerUploadWithFocalpoint","customWidth","wide","imageContainerStyles","imageContent","focalPointContainer","imageStyles","opacity","undefined","container","alignItems","imageBorder","imageUploadingIconContainer","focalPointContent","uri","resizeMethod","imageContainer","retryContainer","customRetryIcon","uploadFailedText"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { Image, Text, View } from 'react-native';\nimport FastImage from 'react-native-fast-image';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Icon } from '@wordpress/components';\nimport { image as icon } from '@wordpress/icons';\nimport { usePreferredColorSchemeStyle } from '@wordpress/compose';\nimport { useEffect, useState } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { getImageWithFocalPointStyles } from './utils';\nimport styles from './style.scss';\nimport SvgIconRetry from './icon-retry';\nimport ImageEditingButton from './image-editing-button';\n\nconst ICON_TYPE = {\n\tPLACEHOLDER: 'placeholder',\n\tRETRY: 'retry',\n\tUPLOAD: 'upload',\n};\n\nexport const IMAGE_DEFAULT_FOCAL_POINT = { x: 0.5, y: 0.5 };\n\nconst ImageComponent = ( {\n\talign,\n\talt,\n\teditButton = true,\n\tfocalPoint,\n\theight: imageHeight,\n\thighlightSelected = true,\n\tisSelected,\n\tisUploadFailed,\n\tisUploadInProgress,\n\tmediaPickerOptions,\n\tonImageDataLoad,\n\tonSelectMediaUploadOption,\n\topenMediaOptions,\n\tresizeMode,\n\tretryMessage,\n\tretryIcon,\n\turl,\n\tshapeStyle,\n\tstyle,\n\twidth: imageWidth,\n} ) => {\n\tconst [ imageData, setImageData ] = useState( null );\n\tconst [ containerSize, setContainerSize ] = useState( null );\n\n\tuseEffect( () => {\n\t\tlet isCurrent = true;\n\t\tif ( url ) {\n\t\t\tImage.getSize( url, ( imgWidth, imgHeight ) => {\n\t\t\t\tif ( ! isCurrent ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst metaData = {\n\t\t\t\t\taspectRatio: imgWidth / imgHeight,\n\t\t\t\t\twidth: imgWidth,\n\t\t\t\t\theight: imgHeight,\n\t\t\t\t};\n\t\t\t\tsetImageData( metaData );\n\t\t\t\tif ( onImageDataLoad ) {\n\t\t\t\t\tonImageDataLoad( metaData );\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t\treturn () => ( isCurrent = false );\n\t}, [ url ] );\n\n\tconst onContainerLayout = ( event ) => {\n\t\tconst { height, width } = event.nativeEvent.layout;\n\n\t\tif (\n\t\t\twidth !== 0 &&\n\t\t\theight !== 0 &&\n\t\t\t( containerSize?.width !== width ||\n\t\t\t\tcontainerSize?.height !== height )\n\t\t) {\n\t\t\tsetContainerSize( { width, height } );\n\t\t}\n\t};\n\n\tconst getIcon = ( iconType ) => {\n\t\tlet iconStyle;\n\t\tswitch ( iconType ) {\n\t\t\tcase ICON_TYPE.RETRY:\n\t\t\t\treturn (\n\t\t\t\t\t<Icon\n\t\t\t\t\t\ticon={ retryIcon || SvgIconRetry }\n\t\t\t\t\t\t{ ...styles.iconRetry }\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase ICON_TYPE.PLACEHOLDER:\n\t\t\t\ticonStyle = iconPlaceholderStyles;\n\t\t\t\tbreak;\n\t\t\tcase ICON_TYPE.UPLOAD:\n\t\t\t\ticonStyle = iconUploadStyles;\n\t\t\t\tbreak;\n\t\t}\n\t\treturn <Icon icon={ icon } { ...iconStyle } />;\n\t};\n\n\tconst iconPlaceholderStyles = usePreferredColorSchemeStyle(\n\t\tstyles.iconPlaceholder,\n\t\tstyles.iconPlaceholderDark\n\t);\n\n\tconst iconUploadStyles = usePreferredColorSchemeStyle(\n\t\tstyles.iconUpload,\n\t\tstyles.iconUploadDark\n\t);\n\n\tconst placeholderStyles = [\n\t\tusePreferredColorSchemeStyle(\n\t\t\tstyles.imageContainerUpload,\n\t\t\tstyles.imageContainerUploadDark\n\t\t),\n\t\tfocalPoint && styles.imageContainerUploadWithFocalpoint,\n\t\timageHeight && { height: imageHeight },\n\t];\n\n\tconst customWidth =\n\t\timageData?.width < containerSize?.width\n\t\t\t? imageData?.width\n\t\t\t: styles.wide?.width;\n\n\tconst imageContainerStyles = [\n\t\tstyles.imageContent,\n\t\t{\n\t\t\twidth:\n\t\t\t\timageWidth === styles.wide?.width ||\n\t\t\t\t( imageData &&\n\t\t\t\t\timageWidth > 0 &&\n\t\t\t\t\timageWidth < containerSize?.width )\n\t\t\t\t\t? imageWidth\n\t\t\t\t\t: customWidth,\n\t\t},\n\t\tresizeMode && { width: styles.wide?.width },\n\t\tfocalPoint && styles.focalPointContainer,\n\t];\n\n\tconst imageStyles = [\n\t\t{\n\t\t\topacity: isUploadInProgress ? 0.3 : 1,\n\t\t\theight: containerSize?.height,\n\t\t},\n\t\tfocalPoint && styles.focalPoint,\n\t\tfocalPoint &&\n\t\t\tgetImageWithFocalPointStyles(\n\t\t\t\tfocalPoint,\n\t\t\t\tcontainerSize,\n\t\t\t\timageData\n\t\t\t),\n\t\t! focalPoint &&\n\t\t\timageData &&\n\t\t\tcontainerSize && {\n\t\t\t\theight:\n\t\t\t\t\timageData?.width > containerSize?.width\n\t\t\t\t\t\t? containerSize?.width / imageData?.aspectRatio\n\t\t\t\t\t\t: undefined,\n\t\t\t},\n\t\timageHeight && { height: imageHeight },\n\t\tshapeStyle,\n\t];\n\n\treturn (\n\t\t<View\n\t\t\tstyle={ [\n\t\t\t\tstyles.container,\n\t\t\t\t// Only set alignItems if an image exists because alignItems causes the placeholder\n\t\t\t\t// to disappear when an aligned image can't be downloaded\n\t\t\t\t// https://github.com/wordpress-mobile/gutenberg-mobile/issues/1592\n\t\t\t\timageData && align && { alignItems: align },\n\t\t\t\tstyle,\n\t\t\t] }\n\t\t\tonLayout={ onContainerLayout }\n\t\t>\n\t\t\t<View\n\t\t\t\taccessible\n\t\t\t\tdisabled={ ! isSelected }\n\t\t\t\taccessibilityLabel={ alt }\n\t\t\t\taccessibilityHint={ __( 'Double tap and hold to edit' ) }\n\t\t\t\taccessibilityRole={ 'imagebutton' }\n\t\t\t\tkey={ url }\n\t\t\t\tstyle={ imageContainerStyles }\n\t\t\t>\n\t\t\t\t{ isSelected &&\n\t\t\t\t\thighlightSelected &&\n\t\t\t\t\t! ( isUploadInProgress || isUploadFailed ) && (\n\t\t\t\t\t\t<View\n\t\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\t\tstyles.imageBorder,\n\t\t\t\t\t\t\t\t{ height: containerSize?.height },\n\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\n\t\t\t\t{ ! imageData ? (\n\t\t\t\t\t<View style={ placeholderStyles }>\n\t\t\t\t\t\t<View style={ styles.imageUploadingIconContainer }>\n\t\t\t\t\t\t\t{ getIcon( ICON_TYPE.UPLOAD ) }\n\t\t\t\t\t\t</View>\n\t\t\t\t\t</View>\n\t\t\t\t) : (\n\t\t\t\t\t<View style={ focalPoint && styles.focalPointContent }>\n\t\t\t\t\t\t<FastImage\n\t\t\t\t\t\t\t{ ...( ! resizeMode && {\n\t\t\t\t\t\t\t\taspectRatio: imageData?.aspectRatio,\n\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\tstyle={ imageStyles }\n\t\t\t\t\t\t\tsource={ { uri: url } }\n\t\t\t\t\t\t\t{ ...( ! focalPoint && {\n\t\t\t\t\t\t\t\tresizeMethod: 'scale',\n\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\tresizeMode={ FastImage.resizeMode[ resizeMode ] }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</View>\n\t\t\t\t) }\n\n\t\t\t\t{ isUploadFailed && retryMessage && (\n\t\t\t\t\t<View\n\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\tstyles.imageContainer,\n\t\t\t\t\t\t\tstyles.retryContainer,\n\t\t\t\t\t\t] }\n\t\t\t\t\t>\n\t\t\t\t\t\t<View\n\t\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\t\tstyles.retryIcon,\n\t\t\t\t\t\t\t\tretryIcon && styles.customRetryIcon,\n\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ getIcon( ICON_TYPE.RETRY ) }\n\t\t\t\t\t\t</View>\n\t\t\t\t\t\t<Text style={ styles.uploadFailedText }>\n\t\t\t\t\t\t\t{ retryMessage }\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t</View>\n\t\t\t\t) }\n\t\t\t</View>\n\n\t\t\t{ editButton && isSelected && ! isUploadInProgress && (\n\t\t\t\t<ImageEditingButton\n\t\t\t\t\tonSelectMediaUploadOption={ onSelectMediaUploadOption }\n\t\t\t\t\topenMediaOptions={ openMediaOptions }\n\t\t\t\t\turl={ ! isUploadFailed && imageData && url }\n\t\t\t\t\tpickerOptions={ mediaPickerOptions }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</View>\n\t);\n};\n\nexport default ImageComponent;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/image/index.native.js"],"names":["Image","RNImage","Text","View","FastImage","__","Icon","image","icon","usePreferredColorSchemeStyle","useEffect","useState","Platform","getImageWithFocalPointStyles","styles","SvgIconRetry","ImageEditingButton","ICON_TYPE","PLACEHOLDER","RETRY","UPLOAD","IMAGE_DEFAULT_FOCAL_POINT","x","y","ImageComponent","align","alt","editButton","focalPoint","height","imageHeight","highlightSelected","isSelected","shouldUseFastImage","isUploadFailed","isUploadInProgress","mediaPickerOptions","onImageDataLoad","onSelectMediaUploadOption","openMediaOptions","resizeMode","retryMessage","retryIcon","url","shapeStyle","style","width","imageWidth","imageData","setImageData","containerSize","setContainerSize","isAndroid","imageResizeMode","isCurrent","getSize","imgWidth","imgHeight","metaData","aspectRatio","onContainerLayout","event","nativeEvent","layout","getIcon","iconType","iconStyle","iconRetry","iconPlaceholderStyles","iconUploadStyles","iconPlaceholder","iconPlaceholderDark","iconUpload","iconUploadDark","placeholderStyles","imageContainerUpload","imageContainerUploadDark","imageContainerUploadWithFocalpoint","customWidth","wide","imageContainerStyles","imageContent","focalPointContainer","imageStyles","opacity","undefined","container","alignItems","imageBorder","imageUploadingIconContainer","focalPointContent","uri","resizeMethod","imageContainer","retryContainer","customRetryIcon","uploadFailedText"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { Image as RNImage, Text, View } from 'react-native';\nimport FastImage from 'react-native-fast-image';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Icon } from '@wordpress/components';\nimport { image as icon } from '@wordpress/icons';\nimport { usePreferredColorSchemeStyle } from '@wordpress/compose';\nimport { useEffect, useState, Platform } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { getImageWithFocalPointStyles } from './utils';\nimport styles from './style.scss';\nimport SvgIconRetry from './icon-retry';\nimport ImageEditingButton from './image-editing-button';\n\nconst ICON_TYPE = {\n\tPLACEHOLDER: 'placeholder',\n\tRETRY: 'retry',\n\tUPLOAD: 'upload',\n};\n\nexport const IMAGE_DEFAULT_FOCAL_POINT = { x: 0.5, y: 0.5 };\n\nconst ImageComponent = ( {\n\talign,\n\talt,\n\teditButton = true,\n\tfocalPoint,\n\theight: imageHeight,\n\thighlightSelected = true,\n\tisSelected,\n\tshouldUseFastImage,\n\tisUploadFailed,\n\tisUploadInProgress,\n\tmediaPickerOptions,\n\tonImageDataLoad,\n\tonSelectMediaUploadOption,\n\topenMediaOptions,\n\tresizeMode,\n\tretryMessage,\n\tretryIcon,\n\turl,\n\tshapeStyle,\n\tstyle,\n\twidth: imageWidth,\n} ) => {\n\tconst [ imageData, setImageData ] = useState( null );\n\tconst [ containerSize, setContainerSize ] = useState( null );\n\n\t// Disabled for Android due to https://github.com/WordPress/gutenberg/issues/43149\n\tconst Image =\n\t\t! shouldUseFastImage || Platform.isAndroid ? RNImage : FastImage;\n\tconst imageResizeMode =\n\t\t! shouldUseFastImage || Platform.isAndroid\n\t\t\t? resizeMode\n\t\t\t: FastImage.resizeMode[ resizeMode ];\n\n\tuseEffect( () => {\n\t\tlet isCurrent = true;\n\t\tif ( url ) {\n\t\t\tRNImage.getSize( url, ( imgWidth, imgHeight ) => {\n\t\t\t\tif ( ! isCurrent ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst metaData = {\n\t\t\t\t\taspectRatio: imgWidth / imgHeight,\n\t\t\t\t\twidth: imgWidth,\n\t\t\t\t\theight: imgHeight,\n\t\t\t\t};\n\t\t\t\tsetImageData( metaData );\n\t\t\t\tif ( onImageDataLoad ) {\n\t\t\t\t\tonImageDataLoad( metaData );\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\t\treturn () => ( isCurrent = false );\n\t}, [ url ] );\n\n\tconst onContainerLayout = ( event ) => {\n\t\tconst { height, width } = event.nativeEvent.layout;\n\n\t\tif (\n\t\t\twidth !== 0 &&\n\t\t\theight !== 0 &&\n\t\t\t( containerSize?.width !== width ||\n\t\t\t\tcontainerSize?.height !== height )\n\t\t) {\n\t\t\tsetContainerSize( { width, height } );\n\t\t}\n\t};\n\n\tconst getIcon = ( iconType ) => {\n\t\tlet iconStyle;\n\t\tswitch ( iconType ) {\n\t\t\tcase ICON_TYPE.RETRY:\n\t\t\t\treturn (\n\t\t\t\t\t<Icon\n\t\t\t\t\t\ticon={ retryIcon || SvgIconRetry }\n\t\t\t\t\t\t{ ...styles.iconRetry }\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase ICON_TYPE.PLACEHOLDER:\n\t\t\t\ticonStyle = iconPlaceholderStyles;\n\t\t\t\tbreak;\n\t\t\tcase ICON_TYPE.UPLOAD:\n\t\t\t\ticonStyle = iconUploadStyles;\n\t\t\t\tbreak;\n\t\t}\n\t\treturn <Icon icon={ icon } { ...iconStyle } />;\n\t};\n\n\tconst iconPlaceholderStyles = usePreferredColorSchemeStyle(\n\t\tstyles.iconPlaceholder,\n\t\tstyles.iconPlaceholderDark\n\t);\n\n\tconst iconUploadStyles = usePreferredColorSchemeStyle(\n\t\tstyles.iconUpload,\n\t\tstyles.iconUploadDark\n\t);\n\n\tconst placeholderStyles = [\n\t\tusePreferredColorSchemeStyle(\n\t\t\tstyles.imageContainerUpload,\n\t\t\tstyles.imageContainerUploadDark\n\t\t),\n\t\tfocalPoint && styles.imageContainerUploadWithFocalpoint,\n\t\timageHeight && { height: imageHeight },\n\t];\n\n\tconst customWidth =\n\t\timageData?.width < containerSize?.width\n\t\t\t? imageData?.width\n\t\t\t: styles.wide?.width;\n\n\tconst imageContainerStyles = [\n\t\tstyles.imageContent,\n\t\t{\n\t\t\twidth:\n\t\t\t\timageWidth === styles.wide?.width ||\n\t\t\t\t( imageData &&\n\t\t\t\t\timageWidth > 0 &&\n\t\t\t\t\timageWidth < containerSize?.width )\n\t\t\t\t\t? imageWidth\n\t\t\t\t\t: customWidth,\n\t\t},\n\t\tresizeMode && { width: styles.wide?.width },\n\t\tfocalPoint && styles.focalPointContainer,\n\t];\n\n\tconst imageStyles = [\n\t\t{\n\t\t\topacity: isUploadInProgress ? 0.3 : 1,\n\t\t\theight: containerSize?.height,\n\t\t},\n\t\t! resizeMode && {\n\t\t\taspectRatio: imageData?.aspectRatio,\n\t\t},\n\t\tfocalPoint && styles.focalPoint,\n\t\tfocalPoint &&\n\t\t\tgetImageWithFocalPointStyles(\n\t\t\t\tfocalPoint,\n\t\t\t\tcontainerSize,\n\t\t\t\timageData\n\t\t\t),\n\t\t! focalPoint &&\n\t\t\timageData &&\n\t\t\tcontainerSize && {\n\t\t\t\theight:\n\t\t\t\t\timageData?.width > containerSize?.width\n\t\t\t\t\t\t? containerSize?.width / imageData?.aspectRatio\n\t\t\t\t\t\t: undefined,\n\t\t\t},\n\t\timageHeight && { height: imageHeight },\n\t\tshapeStyle,\n\t];\n\n\treturn (\n\t\t<View\n\t\t\tstyle={ [\n\t\t\t\tstyles.container,\n\t\t\t\t// Only set alignItems if an image exists because alignItems causes the placeholder\n\t\t\t\t// to disappear when an aligned image can't be downloaded\n\t\t\t\t// https://github.com/wordpress-mobile/gutenberg-mobile/issues/1592\n\t\t\t\timageData && align && { alignItems: align },\n\t\t\t\tstyle,\n\t\t\t] }\n\t\t\tonLayout={ onContainerLayout }\n\t\t>\n\t\t\t<View\n\t\t\t\taccessible\n\t\t\t\tdisabled={ ! isSelected }\n\t\t\t\taccessibilityLabel={ alt }\n\t\t\t\taccessibilityHint={ __( 'Double tap and hold to edit' ) }\n\t\t\t\taccessibilityRole={ 'imagebutton' }\n\t\t\t\tkey={ url }\n\t\t\t\tstyle={ imageContainerStyles }\n\t\t\t>\n\t\t\t\t{ isSelected &&\n\t\t\t\t\thighlightSelected &&\n\t\t\t\t\t! ( isUploadInProgress || isUploadFailed ) && (\n\t\t\t\t\t\t<View\n\t\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\t\tstyles.imageBorder,\n\t\t\t\t\t\t\t\t{ height: containerSize?.height },\n\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\n\t\t\t\t{ ! imageData ? (\n\t\t\t\t\t<View style={ placeholderStyles }>\n\t\t\t\t\t\t<View style={ styles.imageUploadingIconContainer }>\n\t\t\t\t\t\t\t{ getIcon( ICON_TYPE.UPLOAD ) }\n\t\t\t\t\t\t</View>\n\t\t\t\t\t</View>\n\t\t\t\t) : (\n\t\t\t\t\t<View style={ focalPoint && styles.focalPointContent }>\n\t\t\t\t\t\t<Image\n\t\t\t\t\t\t\tstyle={ imageStyles }\n\t\t\t\t\t\t\tsource={ { uri: url } }\n\t\t\t\t\t\t\t{ ...( ! focalPoint && {\n\t\t\t\t\t\t\t\tresizeMethod: 'scale',\n\t\t\t\t\t\t\t} ) }\n\t\t\t\t\t\t\tresizeMode={ imageResizeMode }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</View>\n\t\t\t\t) }\n\n\t\t\t\t{ isUploadFailed && retryMessage && (\n\t\t\t\t\t<View\n\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\tstyles.imageContainer,\n\t\t\t\t\t\t\tstyles.retryContainer,\n\t\t\t\t\t\t] }\n\t\t\t\t\t>\n\t\t\t\t\t\t<View\n\t\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\t\tstyles.retryIcon,\n\t\t\t\t\t\t\t\tretryIcon && styles.customRetryIcon,\n\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ getIcon( ICON_TYPE.RETRY ) }\n\t\t\t\t\t\t</View>\n\t\t\t\t\t\t<Text style={ styles.uploadFailedText }>\n\t\t\t\t\t\t\t{ retryMessage }\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t</View>\n\t\t\t\t) }\n\t\t\t</View>\n\n\t\t\t{ editButton && isSelected && ! isUploadInProgress && (\n\t\t\t\t<ImageEditingButton\n\t\t\t\t\tonSelectMediaUploadOption={ onSelectMediaUploadOption }\n\t\t\t\t\topenMediaOptions={ openMediaOptions }\n\t\t\t\t\turl={ ! isUploadFailed && imageData && url }\n\t\t\t\t\tpickerOptions={ mediaPickerOptions }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</View>\n\t);\n};\n\nexport default ImageComponent;\n"]}
@@ -5,12 +5,11 @@ import { createElement } from "@wordpress/element";
5
5
  */
6
6
  import { Keyboard } from 'react-native';
7
7
  import { useNavigation, useRoute } from '@react-navigation/native';
8
- import { delay } from 'lodash';
9
8
  /**
10
9
  * WordPress dependencies
11
10
  */
12
11
 
13
- import { useMemo } from '@wordpress/element';
12
+ import { useEffect, useMemo, useRef } from '@wordpress/element';
14
13
  /**
15
14
  * Internal dependencies
16
15
  */
@@ -23,6 +22,8 @@ const LinkPickerScreen = _ref => {
23
22
  } = _ref;
24
23
  const navigation = useNavigation();
25
24
  const route = useRoute();
25
+ const navigateToLinkTimeoutRef = useRef(null);
26
+ const navigateBackTimeoutRef = useRef(null);
26
27
 
27
28
  const onLinkPicked = _ref2 => {
28
29
  let {
@@ -30,7 +31,7 @@ const LinkPickerScreen = _ref => {
30
31
  title
31
32
  } = _ref2;
32
33
  Keyboard.dismiss();
33
- delay(() => {
34
+ navigateToLinkTimeoutRef.current = setTimeout(() => {
34
35
  navigation.navigate(returnScreenName, {
35
36
  inputValue: url,
36
37
  text: title
@@ -40,11 +41,17 @@ const LinkPickerScreen = _ref => {
40
41
 
41
42
  const onCancel = () => {
42
43
  Keyboard.dismiss();
43
- delay(() => {
44
+ navigateBackTimeoutRef.current = setTimeout(() => {
44
45
  navigation.goBack();
45
46
  }, 100);
46
47
  };
47
48
 
49
+ useEffect(() => {
50
+ return () => {
51
+ clearTimeout(navigateToLinkTimeoutRef.current);
52
+ clearTimeout(navigateBackTimeoutRef.current);
53
+ };
54
+ }, []);
48
55
  const {
49
56
  inputValue
50
57
  } = route.params;
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/link-picker/link-picker-screen.native.js"],"names":["Keyboard","useNavigation","useRoute","delay","useMemo","LinkPicker","LinkPickerScreen","returnScreenName","navigation","route","onLinkPicked","url","title","dismiss","navigate","inputValue","text","onCancel","goBack","params"],"mappings":";;AAAA;AACA;AACA;AACA,SAASA,QAAT,QAAyB,cAAzB;AACA,SAASC,aAAT,EAAwBC,QAAxB,QAAwC,0BAAxC;AACA,SAASC,KAAT,QAAsB,QAAtB;AAEA;AACA;AACA;;AACA,SAASC,OAAT,QAAwB,oBAAxB;AAEA;AACA;AACA;;AACA,SAASC,UAAT,QAA2B,IAA3B;;AAEA,MAAMC,gBAAgB,GAAG,QAA4B;AAAA,MAA1B;AAAEC,IAAAA;AAAF,GAA0B;AACpD,QAAMC,UAAU,GAAGP,aAAa,EAAhC;AACA,QAAMQ,KAAK,GAAGP,QAAQ,EAAtB;;AAEA,QAAMQ,YAAY,GAAG,SAAsB;AAAA,QAApB;AAAEC,MAAAA,GAAF;AAAOC,MAAAA;AAAP,KAAoB;AAC1CZ,IAAAA,QAAQ,CAACa,OAAT;AACAV,IAAAA,KAAK,CAAE,MAAM;AACZK,MAAAA,UAAU,CAACM,QAAX,CAAqBP,gBAArB,EAAuC;AACtCQ,QAAAA,UAAU,EAAEJ,GAD0B;AAEtCK,QAAAA,IAAI,EAAEJ;AAFgC,OAAvC;AAIA,KALI,EAKF,GALE,CAAL;AAMA,GARD;;AAUA,QAAMK,QAAQ,GAAG,MAAM;AACtBjB,IAAAA,QAAQ,CAACa,OAAT;AACAV,IAAAA,KAAK,CAAE,MAAM;AACZK,MAAAA,UAAU,CAACU,MAAX;AACA,KAFI,EAEF,GAFE,CAAL;AAGA,GALD;;AAOA,QAAM;AAAEH,IAAAA;AAAF,MAAiBN,KAAK,CAACU,MAA7B;AACA,SAAOf,OAAO,CAAE,MAAM;AACrB,WACC,cAAC,UAAD;AACC,MAAA,KAAK,EAAGW,UADT;AAEC,MAAA,YAAY,EAAGL,YAFhB;AAGC,MAAA,QAAQ,EAAGO;AAHZ,MADD;AAOA,GARa,EAQX,CAAEF,UAAF,CARW,CAAd;AASA,CA/BD;;AAiCA,eAAeT,gBAAf","sourcesContent":["/**\n * External dependencies\n */\nimport { Keyboard } from 'react-native';\nimport { useNavigation, useRoute } from '@react-navigation/native';\nimport { delay } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { useMemo } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { LinkPicker } from './';\n\nconst LinkPickerScreen = ( { returnScreenName } ) => {\n\tconst navigation = useNavigation();\n\tconst route = useRoute();\n\n\tconst onLinkPicked = ( { url, title } ) => {\n\t\tKeyboard.dismiss();\n\t\tdelay( () => {\n\t\t\tnavigation.navigate( returnScreenName, {\n\t\t\t\tinputValue: url,\n\t\t\t\ttext: title,\n\t\t\t} );\n\t\t}, 100 );\n\t};\n\n\tconst onCancel = () => {\n\t\tKeyboard.dismiss();\n\t\tdelay( () => {\n\t\t\tnavigation.goBack();\n\t\t}, 100 );\n\t};\n\n\tconst { inputValue } = route.params;\n\treturn useMemo( () => {\n\t\treturn (\n\t\t\t<LinkPicker\n\t\t\t\tvalue={ inputValue }\n\t\t\t\tonLinkPicked={ onLinkPicked }\n\t\t\t\tonCancel={ onCancel }\n\t\t\t/>\n\t\t);\n\t}, [ inputValue ] );\n};\n\nexport default LinkPickerScreen;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/link-picker/link-picker-screen.native.js"],"names":["Keyboard","useNavigation","useRoute","useEffect","useMemo","useRef","LinkPicker","LinkPickerScreen","returnScreenName","navigation","route","navigateToLinkTimeoutRef","navigateBackTimeoutRef","onLinkPicked","url","title","dismiss","current","setTimeout","navigate","inputValue","text","onCancel","goBack","clearTimeout","params"],"mappings":";;AAAA;AACA;AACA;AACA,SAASA,QAAT,QAAyB,cAAzB;AACA,SAASC,aAAT,EAAwBC,QAAxB,QAAwC,0BAAxC;AAEA;AACA;AACA;;AACA,SAASC,SAAT,EAAoBC,OAApB,EAA6BC,MAA7B,QAA2C,oBAA3C;AAEA;AACA;AACA;;AACA,SAASC,UAAT,QAA2B,IAA3B;;AAEA,MAAMC,gBAAgB,GAAG,QAA4B;AAAA,MAA1B;AAAEC,IAAAA;AAAF,GAA0B;AACpD,QAAMC,UAAU,GAAGR,aAAa,EAAhC;AACA,QAAMS,KAAK,GAAGR,QAAQ,EAAtB;AACA,QAAMS,wBAAwB,GAAGN,MAAM,CAAE,IAAF,CAAvC;AACA,QAAMO,sBAAsB,GAAGP,MAAM,CAAE,IAAF,CAArC;;AAEA,QAAMQ,YAAY,GAAG,SAAsB;AAAA,QAApB;AAAEC,MAAAA,GAAF;AAAOC,MAAAA;AAAP,KAAoB;AAC1Cf,IAAAA,QAAQ,CAACgB,OAAT;AACAL,IAAAA,wBAAwB,CAACM,OAAzB,GAAmCC,UAAU,CAAE,MAAM;AACpDT,MAAAA,UAAU,CAACU,QAAX,CAAqBX,gBAArB,EAAuC;AACtCY,QAAAA,UAAU,EAAEN,GAD0B;AAEtCO,QAAAA,IAAI,EAAEN;AAFgC,OAAvC;AAIA,KAL4C,EAK1C,GAL0C,CAA7C;AAMA,GARD;;AAUA,QAAMO,QAAQ,GAAG,MAAM;AACtBtB,IAAAA,QAAQ,CAACgB,OAAT;AACAJ,IAAAA,sBAAsB,CAACK,OAAvB,GAAiCC,UAAU,CAAE,MAAM;AAClDT,MAAAA,UAAU,CAACc,MAAX;AACA,KAF0C,EAExC,GAFwC,CAA3C;AAGA,GALD;;AAOApB,EAAAA,SAAS,CAAE,MAAM;AAChB,WAAO,MAAM;AACZqB,MAAAA,YAAY,CAAEb,wBAAwB,CAACM,OAA3B,CAAZ;AACAO,MAAAA,YAAY,CAAEZ,sBAAsB,CAACK,OAAzB,CAAZ;AACA,KAHD;AAIA,GALQ,EAKN,EALM,CAAT;AAOA,QAAM;AAAEG,IAAAA;AAAF,MAAiBV,KAAK,CAACe,MAA7B;AACA,SAAOrB,OAAO,CAAE,MAAM;AACrB,WACC,cAAC,UAAD;AACC,MAAA,KAAK,EAAGgB,UADT;AAEC,MAAA,YAAY,EAAGP,YAFhB;AAGC,MAAA,QAAQ,EAAGS;AAHZ,MADD;AAOA,GARa,EAQX,CAAEF,UAAF,CARW,CAAd;AASA,CAxCD;;AA0CA,eAAeb,gBAAf","sourcesContent":["/**\n * External dependencies\n */\nimport { Keyboard } from 'react-native';\nimport { useNavigation, useRoute } from '@react-navigation/native';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useMemo, useRef } from '@wordpress/element';\n\n/**\n * Internal dependencies\n */\nimport { LinkPicker } from './';\n\nconst LinkPickerScreen = ( { returnScreenName } ) => {\n\tconst navigation = useNavigation();\n\tconst route = useRoute();\n\tconst navigateToLinkTimeoutRef = useRef( null );\n\tconst navigateBackTimeoutRef = useRef( null );\n\n\tconst onLinkPicked = ( { url, title } ) => {\n\t\tKeyboard.dismiss();\n\t\tnavigateToLinkTimeoutRef.current = setTimeout( () => {\n\t\t\tnavigation.navigate( returnScreenName, {\n\t\t\t\tinputValue: url,\n\t\t\t\ttext: title,\n\t\t\t} );\n\t\t}, 100 );\n\t};\n\n\tconst onCancel = () => {\n\t\tKeyboard.dismiss();\n\t\tnavigateBackTimeoutRef.current = setTimeout( () => {\n\t\t\tnavigation.goBack();\n\t\t}, 100 );\n\t};\n\n\tuseEffect( () => {\n\t\treturn () => {\n\t\t\tclearTimeout( navigateToLinkTimeoutRef.current );\n\t\t\tclearTimeout( navigateBackTimeoutRef.current );\n\t\t};\n\t}, [] );\n\n\tconst { inputValue } = route.params;\n\treturn useMemo( () => {\n\t\treturn (\n\t\t\t<LinkPicker\n\t\t\t\tvalue={ inputValue }\n\t\t\t\tonLinkPicked={ onLinkPicked }\n\t\t\t\tonCancel={ onCancel }\n\t\t\t/>\n\t\t);\n\t}, [ inputValue ] );\n};\n\nexport default LinkPickerScreen;\n"]}
@@ -1,13 +1,8 @@
1
1
  import { createElement } from "@wordpress/element";
2
2
 
3
- /**
4
- * External dependencies
5
- */
6
- import { compact } from 'lodash';
7
3
  /**
8
4
  * WordPress dependencies
9
5
  */
10
-
11
6
  import { Component } from '@wordpress/element';
12
7
  import { __ } from '@wordpress/i18n';
13
8
  import { Picker } from '@wordpress/components';
@@ -42,7 +37,7 @@ export class MediaEdit extends Component {
42
37
  openReplaceMediaOptions,
43
38
  source
44
39
  } = this.props;
45
- return compact([(source === null || source === void 0 ? void 0 : source.uri) && editOption, openReplaceMediaOptions && replaceOption, ...(pickerOptions ? pickerOptions : [])]);
40
+ return [(source === null || source === void 0 ? void 0 : source.uri) && editOption, openReplaceMediaOptions && replaceOption, ...(pickerOptions ? pickerOptions : [])].filter(Boolean);
46
41
  }
47
42
 
48
43
  getDestructiveButtonIndex() {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/media-edit/index.native.js"],"names":["compact","Component","__","Picker","requestMediaEditor","mediaSources","MEDIA_TYPE_IMAGE","MEDIA_EDITOR","editOption","id","value","label","requiresModal","types","replaceOption","deviceLibrary","MediaEdit","constructor","props","onPickerPresent","bind","onPickerSelect","getMediaOptionsItems","getDestructiveButtonIndex","pickerOptions","openReplaceMediaOptions","source","uri","options","destructiveButtonIndex","findIndex","option","destructiveButton","undefined","picker","presentPicker","onSelect","multiple","media","optionSelected","find","onPress","render","mediaOptions","instance","open"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { compact } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { Component } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { Picker } from '@wordpress/components';\nimport {\n\trequestMediaEditor,\n\tmediaSources,\n} from '@wordpress/react-native-bridge';\n\nexport const MEDIA_TYPE_IMAGE = 'image';\n\nexport const MEDIA_EDITOR = 'MEDIA_EDITOR';\n\nconst editOption = {\n\tid: MEDIA_EDITOR,\n\tvalue: MEDIA_EDITOR,\n\tlabel: __( 'Edit' ),\n\trequiresModal: true,\n\ttypes: [ MEDIA_TYPE_IMAGE ],\n};\n\nconst replaceOption = {\n\tid: mediaSources.deviceLibrary,\n\tvalue: mediaSources.deviceLibrary,\n\tlabel: __( 'Replace' ),\n\ttypes: [ MEDIA_TYPE_IMAGE ],\n};\n\nexport class MediaEdit extends Component {\n\tconstructor( props ) {\n\t\tsuper( props );\n\t\tthis.onPickerPresent = this.onPickerPresent.bind( this );\n\t\tthis.onPickerSelect = this.onPickerSelect.bind( this );\n\t\tthis.getMediaOptionsItems = this.getMediaOptionsItems.bind( this );\n\t\tthis.getDestructiveButtonIndex =\n\t\t\tthis.getDestructiveButtonIndex.bind( this );\n\t}\n\n\tgetMediaOptionsItems() {\n\t\tconst { pickerOptions, openReplaceMediaOptions, source } = this.props;\n\n\t\treturn compact( [\n\t\t\tsource?.uri && editOption,\n\t\t\topenReplaceMediaOptions && replaceOption,\n\t\t\t...( pickerOptions ? pickerOptions : [] ),\n\t\t] );\n\t}\n\n\tgetDestructiveButtonIndex() {\n\t\tconst options = this.getMediaOptionsItems();\n\t\tconst destructiveButtonIndex = options.findIndex(\n\t\t\t( option ) => option?.destructiveButton\n\t\t);\n\n\t\treturn destructiveButtonIndex !== -1\n\t\t\t? destructiveButtonIndex + 1\n\t\t\t: undefined;\n\t}\n\n\tonPickerPresent() {\n\t\tif ( this.picker ) {\n\t\t\tthis.picker.presentPicker();\n\t\t}\n\t}\n\n\tonPickerSelect( value ) {\n\t\tconst {\n\t\t\tonSelect,\n\t\t\tpickerOptions,\n\t\t\tmultiple = false,\n\t\t\topenReplaceMediaOptions,\n\t\t} = this.props;\n\n\t\tswitch ( value ) {\n\t\t\tcase MEDIA_EDITOR:\n\t\t\t\trequestMediaEditor( this.props.source.uri, ( media ) => {\n\t\t\t\t\tif ( ( multiple && media ) || ( media && media.id ) ) {\n\t\t\t\t\t\tonSelect( media );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconst optionSelected =\n\t\t\t\t\tpickerOptions &&\n\t\t\t\t\tpickerOptions.find( ( option ) => option.id === value );\n\n\t\t\t\tif ( optionSelected && optionSelected.onPress ) {\n\t\t\t\t\toptionSelected.onPress();\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif ( openReplaceMediaOptions ) {\n\t\t\t\t\topenReplaceMediaOptions();\n\t\t\t\t}\n\t\t}\n\t}\n\n\trender() {\n\t\tconst mediaOptions = () => (\n\t\t\t<Picker\n\t\t\t\thideCancelButton\n\t\t\t\tref={ ( instance ) => ( this.picker = instance ) }\n\t\t\t\toptions={ this.getMediaOptionsItems() }\n\t\t\t\tleftAlign={ true }\n\t\t\t\tonChange={ this.onPickerSelect }\n\t\t\t\t// translators: %s: block title e.g: \"Paragraph\".\n\t\t\t\ttitle={ __( 'Media options' ) }\n\t\t\t\tdestructiveButtonIndex={ this.getDestructiveButtonIndex() }\n\t\t\t/>\n\t\t);\n\n\t\treturn this.props.render( {\n\t\t\topen: this.onPickerPresent,\n\t\t\tmediaOptions,\n\t\t} );\n\t}\n}\n\nexport default MediaEdit;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/media-edit/index.native.js"],"names":["Component","__","Picker","requestMediaEditor","mediaSources","MEDIA_TYPE_IMAGE","MEDIA_EDITOR","editOption","id","value","label","requiresModal","types","replaceOption","deviceLibrary","MediaEdit","constructor","props","onPickerPresent","bind","onPickerSelect","getMediaOptionsItems","getDestructiveButtonIndex","pickerOptions","openReplaceMediaOptions","source","uri","filter","Boolean","options","destructiveButtonIndex","findIndex","option","destructiveButton","undefined","picker","presentPicker","onSelect","multiple","media","optionSelected","find","onPress","render","mediaOptions","instance","open"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { Component } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { Picker } from '@wordpress/components';\nimport {\n\trequestMediaEditor,\n\tmediaSources,\n} from '@wordpress/react-native-bridge';\n\nexport const MEDIA_TYPE_IMAGE = 'image';\n\nexport const MEDIA_EDITOR = 'MEDIA_EDITOR';\n\nconst editOption = {\n\tid: MEDIA_EDITOR,\n\tvalue: MEDIA_EDITOR,\n\tlabel: __( 'Edit' ),\n\trequiresModal: true,\n\ttypes: [ MEDIA_TYPE_IMAGE ],\n};\n\nconst replaceOption = {\n\tid: mediaSources.deviceLibrary,\n\tvalue: mediaSources.deviceLibrary,\n\tlabel: __( 'Replace' ),\n\ttypes: [ MEDIA_TYPE_IMAGE ],\n};\n\nexport class MediaEdit extends Component {\n\tconstructor( props ) {\n\t\tsuper( props );\n\t\tthis.onPickerPresent = this.onPickerPresent.bind( this );\n\t\tthis.onPickerSelect = this.onPickerSelect.bind( this );\n\t\tthis.getMediaOptionsItems = this.getMediaOptionsItems.bind( this );\n\t\tthis.getDestructiveButtonIndex =\n\t\t\tthis.getDestructiveButtonIndex.bind( this );\n\t}\n\n\tgetMediaOptionsItems() {\n\t\tconst { pickerOptions, openReplaceMediaOptions, source } = this.props;\n\n\t\treturn [\n\t\t\tsource?.uri && editOption,\n\t\t\topenReplaceMediaOptions && replaceOption,\n\t\t\t...( pickerOptions ? pickerOptions : [] ),\n\t\t].filter( Boolean );\n\t}\n\n\tgetDestructiveButtonIndex() {\n\t\tconst options = this.getMediaOptionsItems();\n\t\tconst destructiveButtonIndex = options.findIndex(\n\t\t\t( option ) => option?.destructiveButton\n\t\t);\n\n\t\treturn destructiveButtonIndex !== -1\n\t\t\t? destructiveButtonIndex + 1\n\t\t\t: undefined;\n\t}\n\n\tonPickerPresent() {\n\t\tif ( this.picker ) {\n\t\t\tthis.picker.presentPicker();\n\t\t}\n\t}\n\n\tonPickerSelect( value ) {\n\t\tconst {\n\t\t\tonSelect,\n\t\t\tpickerOptions,\n\t\t\tmultiple = false,\n\t\t\topenReplaceMediaOptions,\n\t\t} = this.props;\n\n\t\tswitch ( value ) {\n\t\t\tcase MEDIA_EDITOR:\n\t\t\t\trequestMediaEditor( this.props.source.uri, ( media ) => {\n\t\t\t\t\tif ( ( multiple && media ) || ( media && media.id ) ) {\n\t\t\t\t\t\tonSelect( media );\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconst optionSelected =\n\t\t\t\t\tpickerOptions &&\n\t\t\t\t\tpickerOptions.find( ( option ) => option.id === value );\n\n\t\t\t\tif ( optionSelected && optionSelected.onPress ) {\n\t\t\t\t\toptionSelected.onPress();\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif ( openReplaceMediaOptions ) {\n\t\t\t\t\topenReplaceMediaOptions();\n\t\t\t\t}\n\t\t}\n\t}\n\n\trender() {\n\t\tconst mediaOptions = () => (\n\t\t\t<Picker\n\t\t\t\thideCancelButton\n\t\t\t\tref={ ( instance ) => ( this.picker = instance ) }\n\t\t\t\toptions={ this.getMediaOptionsItems() }\n\t\t\t\tleftAlign={ true }\n\t\t\t\tonChange={ this.onPickerSelect }\n\t\t\t\t// translators: %s: block title e.g: \"Paragraph\".\n\t\t\t\ttitle={ __( 'Media options' ) }\n\t\t\t\tdestructiveButtonIndex={ this.getDestructiveButtonIndex() }\n\t\t\t/>\n\t\t);\n\n\t\treturn this.props.render( {\n\t\t\topen: this.onPickerPresent,\n\t\t\tmediaOptions,\n\t\t} );\n\t}\n}\n\nexport default MediaEdit;\n"]}
@@ -20,7 +20,7 @@ import BottomSheet from '../bottom-sheet';
20
20
  import styles from './styles.scss';
21
21
 
22
22
  function Separator() {
23
- const separatorStyle = usePreferredColorSchemeStyle(styles.separator, styles.separatorDark);
23
+ const separatorStyle = usePreferredColorSchemeStyle(styles['components-picker__separator'], styles['components-picker__separator--dark']);
24
24
  return createElement(View, {
25
25
  style: separatorStyle
26
26
  });
@@ -70,7 +70,7 @@ export default class Picker extends Component {
70
70
  separatorType: 'none',
71
71
  onPress: () => this.onCellPress(option.value),
72
72
  disabled: option.disabled,
73
- style: option.disabled && styles.disabled
73
+ style: option.disabled && styles['components-picker__button--disabled']
74
74
  })));
75
75
  }
76
76
 
@@ -90,7 +90,7 @@ export default class Picker extends Component {
90
90
  testID: testID
91
91
  }, createElement(PanelBody, {
92
92
  title: title,
93
- style: styles.panelBody
93
+ style: styles['components-picker__panel']
94
94
  }, this.getOptions(), !hideCancelButton && createElement(TextControl, {
95
95
  label: __('Cancel'),
96
96
  onPress: this.onClose,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/picker/index.android.js"],"names":["View","__","Component","Fragment","usePreferredColorSchemeStyle","PanelBody","TextControl","BottomSheet","styles","Separator","separatorStyle","separator","separatorDark","Picker","constructor","arguments","onClose","bind","onCellPress","state","isVisible","presentPicker","setState","value","onChange","props","getOptions","options","leftAlign","map","option","label","length","separated","icon","disabled","render","hideCancelButton","title","testID","panelBody"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { View } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Component, Fragment } from '@wordpress/element';\nimport { usePreferredColorSchemeStyle } from '@wordpress/compose';\nimport { PanelBody, TextControl } from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport BottomSheet from '../bottom-sheet';\nimport styles from './styles.scss';\n\nfunction Separator() {\n\tconst separatorStyle = usePreferredColorSchemeStyle(\n\t\tstyles.separator,\n\t\tstyles.separatorDark\n\t);\n\n\treturn <View style={ separatorStyle } />;\n}\n\nexport default class Picker extends Component {\n\tconstructor() {\n\t\tsuper( ...arguments );\n\t\tthis.onClose = this.onClose.bind( this );\n\t\tthis.onCellPress = this.onCellPress.bind( this );\n\n\t\tthis.state = {\n\t\t\tisVisible: false,\n\t\t};\n\t}\n\n\tpresentPicker() {\n\t\tthis.setState( { isVisible: true } );\n\t}\n\n\tonClose() {\n\t\tthis.setState( { isVisible: false } );\n\t}\n\n\tonCellPress( value ) {\n\t\tconst { onChange } = this.props;\n\t\tonChange( value );\n\t\tthis.onClose();\n\t}\n\n\tgetOptions() {\n\t\tconst { options, leftAlign } = this.props;\n\n\t\treturn options.map( ( option ) => (\n\t\t\t<Fragment key={ `${ option.label }-${ option.value }` }>\n\t\t\t\t{ options.length > 1 && option.separated && <Separator /> }\n\t\t\t\t<BottomSheet.Cell\n\t\t\t\t\ticon={ option.icon }\n\t\t\t\t\tleftAlign={ leftAlign }\n\t\t\t\t\tlabel={ option.label }\n\t\t\t\t\tseparatorType={ 'none' }\n\t\t\t\t\tonPress={ () => this.onCellPress( option.value ) }\n\t\t\t\t\tdisabled={ option.disabled }\n\t\t\t\t\tstyle={ option.disabled && styles.disabled }\n\t\t\t\t/>\n\t\t\t</Fragment>\n\t\t) );\n\t}\n\n\trender() {\n\t\tconst { hideCancelButton, title, testID } = this.props;\n\t\tconst { isVisible } = this.state;\n\n\t\treturn (\n\t\t\t<BottomSheet\n\t\t\t\tisVisible={ isVisible }\n\t\t\t\tonClose={ this.onClose }\n\t\t\t\thideHeader\n\t\t\t\ttestID={ testID }\n\t\t\t>\n\t\t\t\t<PanelBody title={ title } style={ styles.panelBody }>\n\t\t\t\t\t{ this.getOptions() }\n\t\t\t\t\t{ ! hideCancelButton && (\n\t\t\t\t\t\t<TextControl\n\t\t\t\t\t\t\tlabel={ __( 'Cancel' ) }\n\t\t\t\t\t\t\tonPress={ this.onClose }\n\t\t\t\t\t\t\tseparatorType={ 'none' }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</PanelBody>\n\t\t\t</BottomSheet>\n\t\t);\n\t}\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/picker/index.android.js"],"names":["View","__","Component","Fragment","usePreferredColorSchemeStyle","PanelBody","TextControl","BottomSheet","styles","Separator","separatorStyle","Picker","constructor","arguments","onClose","bind","onCellPress","state","isVisible","presentPicker","setState","value","onChange","props","getOptions","options","leftAlign","map","option","label","length","separated","icon","disabled","render","hideCancelButton","title","testID"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { View } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Component, Fragment } from '@wordpress/element';\nimport { usePreferredColorSchemeStyle } from '@wordpress/compose';\nimport { PanelBody, TextControl } from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport BottomSheet from '../bottom-sheet';\nimport styles from './styles.scss';\n\nfunction Separator() {\n\tconst separatorStyle = usePreferredColorSchemeStyle(\n\t\tstyles[ 'components-picker__separator' ],\n\t\tstyles[ 'components-picker__separator--dark' ]\n\t);\n\n\treturn <View style={ separatorStyle } />;\n}\n\nexport default class Picker extends Component {\n\tconstructor() {\n\t\tsuper( ...arguments );\n\t\tthis.onClose = this.onClose.bind( this );\n\t\tthis.onCellPress = this.onCellPress.bind( this );\n\n\t\tthis.state = {\n\t\t\tisVisible: false,\n\t\t};\n\t}\n\n\tpresentPicker() {\n\t\tthis.setState( { isVisible: true } );\n\t}\n\n\tonClose() {\n\t\tthis.setState( { isVisible: false } );\n\t}\n\n\tonCellPress( value ) {\n\t\tconst { onChange } = this.props;\n\t\tonChange( value );\n\t\tthis.onClose();\n\t}\n\n\tgetOptions() {\n\t\tconst { options, leftAlign } = this.props;\n\n\t\treturn options.map( ( option ) => (\n\t\t\t<Fragment key={ `${ option.label }-${ option.value }` }>\n\t\t\t\t{ options.length > 1 && option.separated && <Separator /> }\n\t\t\t\t<BottomSheet.Cell\n\t\t\t\t\ticon={ option.icon }\n\t\t\t\t\tleftAlign={ leftAlign }\n\t\t\t\t\tlabel={ option.label }\n\t\t\t\t\tseparatorType={ 'none' }\n\t\t\t\t\tonPress={ () => this.onCellPress( option.value ) }\n\t\t\t\t\tdisabled={ option.disabled }\n\t\t\t\t\tstyle={\n\t\t\t\t\t\toption.disabled &&\n\t\t\t\t\t\tstyles[ 'components-picker__button--disabled' ]\n\t\t\t\t\t}\n\t\t\t\t/>\n\t\t\t</Fragment>\n\t\t) );\n\t}\n\n\trender() {\n\t\tconst { hideCancelButton, title, testID } = this.props;\n\t\tconst { isVisible } = this.state;\n\n\t\treturn (\n\t\t\t<BottomSheet\n\t\t\t\tisVisible={ isVisible }\n\t\t\t\tonClose={ this.onClose }\n\t\t\t\thideHeader\n\t\t\t\ttestID={ testID }\n\t\t\t>\n\t\t\t\t<PanelBody\n\t\t\t\t\ttitle={ title }\n\t\t\t\t\tstyle={ styles[ 'components-picker__panel' ] }\n\t\t\t\t>\n\t\t\t\t\t{ this.getOptions() }\n\t\t\t\t\t{ ! hideCancelButton && (\n\t\t\t\t\t\t<TextControl\n\t\t\t\t\t\t\tlabel={ __( 'Cancel' ) }\n\t\t\t\t\t\t\tonPress={ this.onClose }\n\t\t\t\t\t\t\tseparatorType={ 'none' }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</PanelBody>\n\t\t\t</BottomSheet>\n\t\t);\n\t}\n}\n"]}
@@ -13,6 +13,12 @@ import { __ } from '@wordpress/i18n';
13
13
  import { Component, forwardRef, useContext } from '@wordpress/element';
14
14
  import { useDispatch, useSelect } from '@wordpress/data';
15
15
  import { BottomSheetContext } from '@wordpress/components';
16
+ import { usePreferredColorScheme } from '@wordpress/compose';
17
+ /**
18
+ * Internal dependencies
19
+ */
20
+
21
+ import styles from './styles.scss';
16
22
 
17
23
  class Picker extends Component {
18
24
  presentPicker() {
@@ -25,7 +31,8 @@ class Picker extends Component {
25
31
  getAnchor,
26
32
  isBottomSheetOpened,
27
33
  closeBottomSheet,
28
- onHandleClosingBottomSheet
34
+ onHandleClosingBottomSheet,
35
+ colorScheme
29
36
  } = this.props;
30
37
  const labels = options.map(_ref => {
31
38
  let {
@@ -34,13 +41,15 @@ class Picker extends Component {
34
41
  return label;
35
42
  });
36
43
  const fullOptions = [__('Cancel')].concat(labels);
44
+ const buttonTitleColor = colorScheme === 'light' ? styles['components-picker__button-title'].color : styles['components-picker__button-title--dark'].color;
37
45
  ActionSheetIOS.showActionSheetWithOptions({
38
46
  title,
39
47
  options: fullOptions,
40
48
  cancelButtonIndex: 0,
41
49
  destructiveButtonIndex,
42
50
  disabledButtonIndices,
43
- anchor: getAnchor && getAnchor()
51
+ anchor: getAnchor && getAnchor(),
52
+ tintColor: buttonTitleColor
44
53
  }, buttonIndex => {
45
54
  if (buttonIndex === 0) {
46
55
  return;
@@ -73,12 +82,14 @@ const PickerComponent = forwardRef((props, ref) => {
73
82
  const {
74
83
  onHandleClosingBottomSheet
75
84
  } = useContext(BottomSheetContext);
85
+ const colorScheme = usePreferredColorScheme();
76
86
  return createElement(Picker, _extends({
77
87
  ref: ref
78
88
  }, props, {
79
89
  isBottomSheetOpened: isBottomSheetOpened,
80
90
  closeBottomSheet: closeGeneralSidebar,
81
- onHandleClosingBottomSheet: onHandleClosingBottomSheet
91
+ onHandleClosingBottomSheet: onHandleClosingBottomSheet,
92
+ colorScheme: colorScheme
82
93
  }));
83
94
  });
84
95
  export default PickerComponent;