@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
@@ -13,6 +13,8 @@ exports.getMappedValues = getMappedValues;
13
13
  exports.parseStylesVariables = parseStylesVariables;
14
14
  exports.useMobileGlobalStylesColors = useMobileGlobalStylesColors;
15
15
 
16
+ var _changeCase = require("change-case");
17
+
16
18
  var _lodash = require("lodash");
17
19
 
18
20
  var _reactNative = require("react-native");
@@ -39,6 +41,7 @@ const BLOCK_STYLE_ATTRIBUTES_MAPPING = {
39
41
  const PADDING = 12; // $solid-border-space
40
42
 
41
43
  const UNKNOWN_VALUE = 'undefined';
44
+ const DEFAULT_FONT_SIZE = 16;
42
45
 
43
46
  function getBlockPaddings(mergedStyle, wrapperPropsStyle, blockStyleAttributes, blockColors) {
44
47
  const blockPaddings = {};
@@ -95,8 +98,10 @@ function getBlockColors(blockStyleAttributes, defaultColors, blockName, baseGlob
95
98
 
96
99
 
97
100
  Object.entries(blockStyleAttributes).forEach(_ref2 => {
101
+ var _value$startsWith;
102
+
98
103
  let [key, value] = _ref2;
99
- const isCustomColor = (0, _lodash.startsWith)(value, '#');
104
+ const isCustomColor = value === null || value === void 0 ? void 0 : (_value$startsWith = value.startsWith) === null || _value$startsWith === void 0 ? void 0 : _value$startsWith.call(value, '#');
100
105
  let styleKey = key;
101
106
 
102
107
  if (BLOCK_STYLE_ATTRIBUTES_MAPPING[styleKey]) {
@@ -179,7 +184,7 @@ function getBlockTypography(blockStyleAttributes, fontSizes, blockName, baseGlob
179
184
 
180
185
  function parseStylesVariables(styles, mappedValues, customValues) {
181
186
  let stylesBase = styles;
182
- const variables = ['preset', 'custom', 'var'];
187
+ const variables = ['preset', 'custom', 'var', 'fontSize'];
183
188
 
184
189
  if (!stylesBase) {
185
190
  return styles;
@@ -192,6 +197,7 @@ function parseStylesVariables(styles, mappedValues, customValues) {
192
197
  // var:preset|color|custom-color-2
193
198
  const regex = new RegExp(`var\\(--wp--${variable}--(.*?)\\)`, 'g');
194
199
  const varRegex = /\"var:preset\|color\|(.*?)\"/gm;
200
+ const fontSizeRegex = /"fontSize":"(.*?)"/gm;
195
201
 
196
202
  if (variable === 'preset') {
197
203
  stylesBase = stylesBase.replace(regex, (_$1, $2) => {
@@ -219,7 +225,7 @@ function parseStylesVariables(styles, mappedValues, customValues) {
219
225
  } // Check for camelcase properties.
220
226
 
221
227
 
222
- return (0, _lodash.get)(customValuesData, [...path.slice(0, path.length - 1), (0, _lodash.camelCase)(path[path.length - 1])]);
228
+ return (0, _lodash.get)(customValuesData, [...path.slice(0, path.length - 1), (0, _changeCase.camelCase)(path[path.length - 1])]);
223
229
  });
224
230
  }
225
231
 
@@ -237,6 +243,22 @@ function parseStylesVariables(styles, mappedValues, customValues) {
237
243
  return UNKNOWN_VALUE;
238
244
  });
239
245
  }
246
+
247
+ if (variable === 'fontSize') {
248
+ const {
249
+ width,
250
+ height
251
+ } = _reactNative.Dimensions.get('window');
252
+
253
+ stylesBase = stylesBase.replace(fontSizeRegex, (_$1, $2) => {
254
+ const parsedFontSize = (0, _blockEditor.getPxFromCssUnit)($2, {
255
+ width,
256
+ height,
257
+ fontSize: DEFAULT_FONT_SIZE
258
+ }) || `${DEFAULT_FONT_SIZE}px`;
259
+ return `"fontSize":"${parsedFontSize}"`;
260
+ });
261
+ }
240
262
  });
241
263
  return JSON.parse(stylesBase);
242
264
  }
@@ -287,7 +309,7 @@ function normalizeFontSizes(fontSizes) {
287
309
  fontSizeObject.sizePx = (0, _blockEditor.getPxFromCssUnit)(fontSizeObject.size, {
288
310
  width: dimensions.width,
289
311
  height: dimensions.height,
290
- fontSize: 16
312
+ fontSize: DEFAULT_FONT_SIZE
291
313
  });
292
314
  return fontSizeObject;
293
315
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/global-styles-context/utils.native.js"],"names":["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","Dimensions","get","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":";;;;;;;;;;;;;;;AAGA;;AACA;;AAKA;;AATA;AACA;AACA;;AAIA;AACA;AACA;AAOO,MAAMA,sBAAsB,GAAG,CACrC,WADqC,EAErC,iBAFqC,EAGrC,OAHqC,EAIrC,OAJqC,EAKrC,UALqC,CAA/B,C,CAQP;;;AACA,MAAMC,8BAA8B,GAAG;AACtCC,EAAAA,SAAS,EAAE,OAD2B;AAEtCC,EAAAA,IAAI,EAAE,OAFgC;AAGtCC,EAAAA,UAAU,EAAE,iBAH0B;AAItCC,EAAAA,IAAI,EAAE,WAJgC;AAKtCC,EAAAA,WAAW,EAAE;AALyB,CAAvC;AAQA,MAAMC,OAAO,GAAG,EAAhB,C,CAAoB;;AACpB,MAAMC,aAAa,GAAG,WAAtB;;AAEO,SAASC,gBAAT,CACNC,WADM,EAENC,iBAFM,EAGNC,oBAHM,EAINC,WAJM,EAKL;AACD,QAAMC,aAAa,GAAG,EAAtB;;AAEA,MACC,CAAEJ,WAAW,CAACK,OAAd,KACEJ,iBAAiB,SAAjB,IAAAA,iBAAiB,WAAjB,IAAAA,iBAAiB,CAAEK,eAAnB,IACDJ,oBADC,aACDA,oBADC,eACDA,oBAAoB,CAAEI,eADrB,IAEDH,WAFC,aAEDA,WAFC,eAEDA,WAAW,CAAEG,eAHd,CADD,EAKE;AACDF,IAAAA,aAAa,CAACC,OAAd,GAAwBR,OAAxB;AACA,WAAOO,aAAP;AACA,GAXA,CAaD;;;AACA,MACCJ,WAAW,SAAX,IAAAA,WAAW,WAAX,IAAAA,WAAW,CAAEK,OAAb,IACA,EAAEJ,iBAAF,aAAEA,iBAAF,eAAEA,iBAAiB,CAAEK,eAArB,CADA,IAEA,EAAEJ,oBAAF,aAAEA,oBAAF,eAAEA,oBAAoB,CAAEI,eAAxB,CAFA,IAGA,EAAEH,WAAF,aAAEA,WAAF,eAAEA,WAAW,CAAEG,eAAf,CAJD,EAKE;AACDF,IAAAA,aAAa,CAACC,OAAd,GAAwBE,SAAxB;AACA;;AAED,SAAOH,aAAP;AACA;;AAEM,SAASI,cAAT,CACNN,oBADM,EAENO,aAFM,EAGNC,SAHM,EAINC,gBAJM,EAKL;AAAA;;AACD,QAAMC,WAAW,GAAG,EAApB;AACA,QAAMC,iBAAiB,GAAG,CAAAX,oBAAoB,SAApB,IAAAA,oBAAoB,WAApB,qCAAAA,oBAAoB,CAAEY,KAAtB,gFAA6BC,KAA7B,KAAsC,EAAhE;AACA,QAAMC,iBAAiB,GAAGL,gBAAH,aAAGA,gBAAH,gDAAGA,gBAAgB,CAAEM,MAArB,0DAAG,sBAA4BP,SAA5B,CAA1B,CAHC,CAKD;;AACA,MAAKM,iBAAL,aAAKA,iBAAL,eAAKA,iBAAiB,CAAED,KAAxB,EAAgC;AAC/BG,IAAAA,MAAM,CAACC,OAAP,CAAgBH,iBAAiB,CAACD,KAAlC,EAA0CK,OAA1C,CACC,QAAsB;AAAA,UAApB,CAAEC,GAAF,EAAOC,KAAP,CAAoB;AACrB,YAAMC,QAAQ,GAAGhC,8BAA8B,CAAE8B,GAAF,CAA/C;;AAEA,UAAKE,QAAQ,IAAID,KAAK,KAAKxB,aAA3B,EAA2C;AAAA;;AAC1C,cAAMiB,KAAK,4BAAGF,iBAAiB,CAAEQ,GAAF,CAApB,yEAA+BC,KAA1C;AACAV,QAAAA,WAAW,CAAEW,QAAF,CAAX,GAA0BR,KAA1B;AACA;AACD,KARF;AAUA,GAXD,MAWO,IAAKJ,gBAAL,aAAKA,gBAAL,wCAAKA,gBAAgB,CAAEa,MAAvB,4EAAK,sBAA0BT,KAA/B,mDAAK,uBAAiCtB,IAAtC,EAA6C;AAAA;;AACnDmB,IAAAA,WAAW,CAAErB,8BAA8B,CAACE,IAAjC,CAAX,GACCkB,gBADD,aACCA,gBADD,iDACCA,gBAAgB,CAAEa,MADnB,qFACC,uBAA0BT,KAD3B,2DACC,uBAAiCtB,IADlC;AAEA,GApBA,CAsBD;;;AACA,MAAKuB,iBAAL,aAAKA,iBAAL,eAAKA,iBAAiB,CAAES,QAAxB,EAAmC;AAAA;;AAClC,UAAMC,SAAS,4BAAGV,iBAAiB,CAACS,QAArB,oFAAG,sBAA4B9B,IAA/B,qFAAG,uBAAkCoB,KAArC,2DAAG,uBAAyCtB,IAA3D;AACA,UAAM8B,QAAQ,GAAGhC,8BAA8B,CAACI,IAAhD;;AAEA,QAAK4B,QAAQ,IAAIG,SAAZ,IAAyBA,SAAS,KAAK5B,aAA5C,EAA4D;AAC3Dc,MAAAA,WAAW,CAAEW,QAAF,CAAX,GAA0BG,SAA1B;AACA;AACD,GA9BA,CAgCD;;;AACAR,EAAAA,MAAM,CAACC,OAAP,CAAgBjB,oBAAhB,EAAuCkB,OAAvC,CAAgD,SAAsB;AAAA,QAApB,CAAEC,GAAF,EAAOC,KAAP,CAAoB;AACrE,UAAMK,aAAa,GAAG,wBAAYL,KAAZ,EAAmB,GAAnB,CAAtB;AACA,QAAIC,QAAQ,GAAGF,GAAf;;AAEA,QAAK9B,8BAA8B,CAAEgC,QAAF,CAAnC,EAAkD;AACjDA,MAAAA,QAAQ,GAAGhC,8BAA8B,CAAEgC,QAAF,CAAzC;AACA;;AAED,QAAK,CAAEI,aAAP,EAAuB;AACtB,YAAMC,WAAW,GAAG,kBAAMnB,aAAN,EAAqB;AACxCoB,QAAAA,IAAI,EAAEP;AADkC,OAArB,CAApB;;AAIA,UAAKM,WAAL,EAAmB;AAClBhB,QAAAA,WAAW,CAAEW,QAAF,CAAX,GAA0BK,WAAW,CAACb,KAAtC;AACA;AACD,KARD,MAQO;AACNH,MAAAA,WAAW,CAAEW,QAAF,CAAX,GAA0BD,KAA1B;AACA;AACD,GAnBD,EAjCC,CAsDD;;AACA,MAAKV,WAAL,aAAKA,WAAL,eAAKA,WAAW,CAAEG,KAAlB,EAA0B;AACzBH,IAAAA,WAAW,CAAErB,8BAA8B,CAACK,WAAjC,CAAX,GACCgB,WAAW,CAACG,KADb;AAEA;;AAED,SAAOH,WAAP;AACA;;AAEM,SAASkB,kBAAT,CACN5B,oBADM,EAEN6B,SAFM,EAGNrB,SAHM,EAINC,gBAJM,EAKL;AAAA;;AACD,QAAMqB,gBAAgB,GAAG,EAAzB;AACA,QAAMnB,iBAAiB,GAAG,CAAAX,oBAAoB,SAApB,IAAAA,oBAAoB,WAApB,sCAAAA,oBAAoB,CAAEY,KAAtB,kFAA6BmB,UAA7B,KAA2C,EAArE;AACA,QAAMjB,iBAAiB,GAAGL,gBAAH,aAAGA,gBAAH,iDAAGA,gBAAgB,CAAEM,MAArB,2DAAG,uBAA4BP,SAA5B,CAA1B,CAHC,CAKD;;AACA,MAAKM,iBAAL,aAAKA,iBAAL,eAAKA,iBAAiB,CAAEiB,UAAxB,EAAqC;AAAA;;AACpC,UAAMC,QAAQ,GAAGlB,iBAAH,aAAGA,iBAAH,gDAAGA,iBAAiB,CAAEiB,UAAtB,0DAAG,sBAA+BC,QAAhD;AACA,UAAMC,UAAU,GAAGnB,iBAAH,aAAGA,iBAAH,iDAAGA,iBAAiB,CAAEiB,UAAtB,2DAAG,uBAA+BE,UAAlD;;AAEA,QAAKD,QAAL,EAAgB;AACf,UAAKE,QAAQ,CAAEF,QAAF,EAAY,EAAZ,CAAb,EAAgC;AAC/BF,QAAAA,gBAAgB,CAACE,QAAjB,GAA4BA,QAA5B;AACA,OAFD,MAEO;AACN,cAAMG,cAAc,GAAG,kBAAMN,SAAN,EAAiB;AACvCF,UAAAA,IAAI,EAAEK;AADiC,SAAjB,CAAvB;;AAIA,YAAKG,cAAL,EAAsB;AACrBL,UAAAA,gBAAgB,CAACE,QAAjB,GAA4BG,cAA5B,aAA4BA,cAA5B,uBAA4BA,cAAc,CAAEC,IAA5C;AACA;AACD;AACD;;AAED,QAAKH,UAAL,EAAkB;AACjBH,MAAAA,gBAAgB,CAACG,UAAjB,GAA8BA,UAA9B;AACA;AACD;;AAED,MAAKjC,oBAAoB,SAApB,IAAAA,oBAAoB,WAApB,IAAAA,oBAAoB,CAAEgC,QAAtB,IAAkCvB,gBAAvC,EAA0D;AACzD,UAAM0B,cAAc,GAAG,kBAAMN,SAAN,EAAiB;AACvCF,MAAAA,IAAI,EAAE3B,oBAAF,aAAEA,oBAAF,uBAAEA,oBAAoB,CAAEgC;AADW,KAAjB,CAAvB;;AAIA,QAAKG,cAAL,EAAsB;AACrBL,MAAAA,gBAAgB,CAACE,QAAjB,GAA4BG,cAA5B,aAA4BA,cAA5B,uBAA4BA,cAAc,CAAEC,IAA5C;AACA;AACD,GArCA,CAuCD;;;AACA,MAAKzB,iBAAL,aAAKA,iBAAL,eAAKA,iBAAiB,CAAEqB,QAAxB,EAAmC;AAClCF,IAAAA,gBAAgB,CAACE,QAAjB,GAA4BrB,iBAA5B,aAA4BA,iBAA5B,uBAA4BA,iBAAiB,CAAEqB,QAA/C;AACA;;AAED,MAAKrB,iBAAL,aAAKA,iBAAL,eAAKA,iBAAiB,CAAEsB,UAAxB,EAAqC;AACpCH,IAAAA,gBAAgB,CAACG,UAAjB,GAA8BtB,iBAA9B,aAA8BA,iBAA9B,uBAA8BA,iBAAiB,CAAEsB,UAAjD;AACA;;AAED,SAAOH,gBAAP;AACA;;AAEM,SAASO,oBAAT,CAA+Bf,MAA/B,EAAuCgB,YAAvC,EAAqDC,YAArD,EAAoE;AAC1E,MAAIC,UAAU,GAAGlB,MAAjB;AACA,QAAMmB,SAAS,GAAG,CAAE,QAAF,EAAY,QAAZ,EAAsB,KAAtB,CAAlB;;AAEA,MAAK,CAAED,UAAP,EAAoB;AACnB,WAAOlB,MAAP;AACA;;AAEDmB,EAAAA,SAAS,CAACvB,OAAV,CAAqBwB,QAAF,IAAgB;AAClC;AACA;AACA;AACA;AACA,UAAMC,KAAK,GAAG,IAAIC,MAAJ,CAAa,eAAeF,QAAU,YAAtC,EAAmD,GAAnD,CAAd;AACA,UAAMG,QAAQ,GAAG,gCAAjB;;AAEA,QAAKH,QAAQ,KAAK,QAAlB,EAA6B;AAC5BF,MAAAA,UAAU,GAAGA,UAAU,CAACM,OAAX,CAAoBH,KAApB,EAA2B,CAAEI,GAAF,EAAOC,EAAP,KAAe;AACtD,cAAMC,IAAI,GAAGD,EAAE,CAACE,KAAH,CAAU,IAAV,CAAb;AACA,cAAMC,iBAAiB,GAAGb,YAAY,CAAEW,IAAI,CAAE,CAAF,CAAN,CAAtC;;AACA,YAAKE,iBAAiB,IAAIA,iBAAiB,CAACxB,IAA5C,EAAmD;AAClD,gBAAMyB,YAAY,GAAG,kBAAMD,iBAAiB,CAACE,MAAxB,EAAgC;AACpD1B,YAAAA,IAAI,EAAEsB,IAAI,CAAE,CAAF;AAD0C,WAAhC,CAArB;AAGA,iBAAOG,YAAP,aAAOA,YAAP,uBAAOA,YAAY,CAAID,iBAAiB,CAACxB,IAAtB,CAAnB;AACA;;AACD,eAAO/B,aAAP;AACA,OAVY,CAAb;AAWA;;AACD,QAAK8C,QAAQ,KAAK,QAAlB,EAA6B;AAC5B,YAAMY,gBAAgB,GAAGf,YAAH,aAAGA,YAAH,cAAGA,YAAH,GAAmBgB,IAAI,CAACC,KAAL,CAAYhB,UAAZ,CAAzC;AACAA,MAAAA,UAAU,GAAGA,UAAU,CAACM,OAAX,CAAoBH,KAApB,EAA2B,CAAEI,GAAF,EAAOC,EAAP,KAAe;AACtD,cAAMC,IAAI,GAAGD,EAAE,CAACE,KAAH,CAAU,IAAV,CAAb;;AACA,YAAK,iBAAKI,gBAAL,EAAuBL,IAAvB,CAAL,EAAqC;AACpC,iBAAO,iBAAKK,gBAAL,EAAuBL,IAAvB,CAAP;AACA,SAJqD,CAMtD;;;AACA,eAAO,iBAAKK,gBAAL,EAAuB,CAC7B,GAAGL,IAAI,CAACQ,KAAL,CAAY,CAAZ,EAAeR,IAAI,CAACS,MAAL,GAAc,CAA7B,CAD0B,EAE7B,uBAAWT,IAAI,CAAEA,IAAI,CAACS,MAAL,GAAc,CAAhB,CAAf,CAF6B,CAAvB,CAAP;AAIA,OAXY,CAAb;AAYA;;AAED,QAAKhB,QAAQ,KAAK,KAAlB,EAA0B;AACzBF,MAAAA,UAAU,GAAGA,UAAU,CAACM,OAAX,CAAoBD,QAApB,EAA8B,CAAEE,GAAF,EAAOC,EAAP,KAAe;AACzD,YAAKV,YAAL,aAAKA,YAAL,eAAKA,YAAY,CAAEzB,KAAnB,EAA2B;AAAA;;AAC1B,gBAAMuC,YAAY,GAAG,yCAAMd,YAAY,CAACzB,KAAnB,wDAAM,oBAAoBwC,MAA1B,EAAkC;AACtD1B,YAAAA,IAAI,EAAEqB;AADgD,WAAlC,CAArB;AAGA,iBAAQ,IAAII,YAAL,aAAKA,YAAL,uBAAKA,YAAY,CAAEvC,KAAO,GAAjC;AACA;;AACD,eAAOjB,aAAP;AACA,OARY,CAAb;AASA;AACD,GAhDD;AAkDA,SAAO2D,IAAI,CAACC,KAAL,CAAYhB,UAAZ,CAAP;AACA;;AAEM,SAASmB,eAAT,CAA0BC,QAA1B,EAAoCC,OAApC,EAA8C;AAAA;;AACpD,QAAM9B,UAAU,GAAG6B,QAAH,aAAGA,QAAH,uBAAGA,QAAQ,CAAE7B,UAA7B;AACA,QAAM+B,MAAM,GAAG,CACd,IAAK,CAAAD,OAAO,SAAP,IAAAA,OAAO,WAAP,YAAAA,OAAO,CAAEE,KAAT,KAAkB,EAAvB,CADc,EAEd,IAAK,CAAAF,OAAO,SAAP,IAAAA,OAAO,WAAP,YAAAA,OAAO,CAAEG,MAAT,KAAmB,EAAxB,CAFc,EAGd,IAAK,CAAAH,OAAO,SAAP,IAAAA,OAAO,WAAP,YAAAA,OAAO,CAAEI,OAAT,KAAoB,EAAzB,CAHc,CAAf;AAMA,QAAMpC,SAAS,GAAG,EACjB,IAAGE,UAAH,aAAGA,UAAH,gDAAGA,UAAU,CAAEF,SAAf,0DAAG,sBAAuBkC,KAA1B,CADiB;AAEjB,QAAGhC,UAAH,aAAGA,UAAH,iDAAGA,UAAU,CAAEF,SAAf,2DAAG,uBAAuBmC,MAA1B;AAFiB,GAAlB;AAIA,QAAM1B,YAAY,GAAG;AACpBzB,IAAAA,KAAK,EAAE;AACNwC,MAAAA,MAAM,EAAES,MADF;AAENnC,MAAAA,IAAI,EAAE;AAFA,KADa;AAKpB,iBAAa;AACZ0B,MAAAA,MAAM,EAAExB,SADI;AAEZF,MAAAA,IAAI,EAAE;AAFM;AALO,GAArB;AAUA,SAAOW,YAAP;AACA;AAED;AACA;AACA;AACA;AACA;AACA;;;AACA,SAAS4B,kBAAT,CAA6BrC,SAA7B,EAAyC;AACxC;AACA,MAAK,CAAEA,SAAP,EAAmB;AAClB,WAAOA,SAAP;AACA;;AACD,QAAMsC,mBAAmB,GAAG,EAA5B;;AACA,QAAMC,UAAU,GAAGC,wBAAWC,GAAX,CAAgB,QAAhB,CAAnB;;AAEA,GAAE,SAAF,EAAa,OAAb,EAAsB,QAAtB,EAAiCpD,OAAjC,CAA4CC,GAAF,IAAW;AACpD,QAAKU,SAAS,CAAEV,GAAF,CAAd,EAAwB;AAAA;;AACvBgD,MAAAA,mBAAmB,CAAEhD,GAAF,CAAnB,qBAA6BU,SAAS,CAAEV,GAAF,CAAtC,mDAA6B,eAAkBoD,GAAlB,CAC1BC,cAAF,IAAsB;AACrBA,QAAAA,cAAc,CAACC,MAAf,GAAwB,mCACvBD,cAAc,CAACpC,IADQ,EAEvB;AACCsC,UAAAA,KAAK,EAAEN,UAAU,CAACM,KADnB;AAECC,UAAAA,MAAM,EAAEP,UAAU,CAACO,MAFpB;AAGC3C,UAAAA,QAAQ,EAAE;AAHX,SAFuB,CAAxB;AAQA,eAAOwC,cAAP;AACA,OAX2B,CAA7B;AAaA;AACD,GAhBD;AAkBA,SAAOL,mBAAP;AACA;;AAEM,SAASS,2BAAT,GAAwD;AAAA;;AAAA,MAAlBC,IAAkB,uEAAX,QAAW;AAC9D,QAAMC,qBAAqB,GAAG,uDAA9B;AACA,QAAMC,oBAAoB,GAAGD,qBAAH,aAAGA,qBAAH,gDAAGA,qBAAqB,CAAID,IAAJ,CAAxB,0DAAG,sBAAiCG,MAAjC,CAC5B,CAAElB,MAAF,EAAUmB,MAAV,KAAsBnB,MAAM,CAACoB,MAAP,CAAeD,MAAf,aAAeA,MAAf,uBAAeA,MAAM,CAAIJ,IAAJ,CAArB,CADM,EAE5B,EAF4B,CAA7B,CAF8D,CAM9D;;AACA,QAAMM,YAAY,GACjBN,IAAI,KAAK,QAAT,GAAoB,eAApB,GAAsC,iBADvC;AAEA,QAAMO,oBAAoB,GAAG,6BAAYD,YAAZ,CAA7B;AAEA,SAAOJ,oBAAoB,CAACrB,MAArB,IAA+B,CAA/B,GACJqB,oBADI,GAEJK,oBAFH;AAGA;;AAEM,SAASC,qBAAT,GAIL;AAAA,MAHDC,mBAGC,uEAHqB,EAGrB;AAAA,MAFDC,sBAEC,uEAFwB,EAExB;AAAA,MADDC,WACC;AACD,QAAM5B,QAAQ,GAAG4B,WAAW,GAAGjC,IAAI,CAACC,KAAL,CAAYgC,WAAZ,CAAH,GAA+B,EAA3D;AAEA,SAAO;AACNC,IAAAA,oCAAoC,EAAE,IADhC;AAENC,IAAAA,sBAAsB,EAAE;AACvB7E,MAAAA,KAAK,EAAE,EACN,IAAK,EAAE+C,QAAF,aAAEA,QAAF,eAAEA,QAAQ,CAAE/C,KAAZ,IACF;AACAtB,UAAAA,IAAI,EAAE,IADN;AAEAC,UAAAA,UAAU,EAAE,IAFZ;AAGAqE,UAAAA,OAAO,EAAE;AACRI,YAAAA,OAAO,EAAEqB;AADD,WAHT;AAMAK,UAAAA,SAAS,EAAE;AACV1B,YAAAA,OAAO,EAAEsB;AADC;AANX,SADE,GAWF3B,QAXE,aAWFA,QAXE,uBAWFA,QAAQ,CAAE/C,KAXb,CADM;AAaN+E,QAAAA,cAAc,EAAE,CAAAN,mBAAmB,SAAnB,IAAAA,mBAAmB,WAAnB,YAAAA,mBAAmB,CAAE5B,MAArB,IAA8B,CAbxC;AAcNmC,QAAAA,gBAAgB,EAAE,CAAAN,sBAAsB,SAAtB,IAAAA,sBAAsB,WAAtB,YAAAA,sBAAsB,CAAE7B,MAAxB,IAAiC;AAd7C;AADgB;AAFlB,GAAP;AAqBA;;AAEM,SAASoC,eAAT,CAA0BC,SAA1B,EAAqCP,WAArC,EAAmD;AAAA;;AACzD,QAAM5B,QAAQ,GAAG4B,WAAW,GAAGjC,IAAI,CAACC,KAAL,CAAYgC,WAAZ,CAAH,GAA+B,EAA3D;AACA,QAAMlD,YAAY,GAAGqB,eAAe,CAAEC,QAAF,EAAYA,QAAZ,aAAYA,QAAZ,0CAAYA,QAAQ,CAAE/C,KAAtB,oDAAY,gBAAiBgD,OAA7B,CAApC;AACA,QAAMC,MAAM,GAAGzB,oBAAoB,CAClCkB,IAAI,CAACyC,SAAL,CAAgBpC,QAAhB,aAAgBA,QAAhB,uBAAgBA,QAAQ,CAAE/C,KAA1B,CADkC,EAElCyB,YAFkC,CAAnC;AAIA,QAAMqD,SAAS,GAAGtD,oBAAoB,CACrCkB,IAAI,CAACyC,SAAL,CAAgBpC,QAAhB,aAAgBA,QAAhB,2CAAgBA,QAAQ,CAAE/C,KAA1B,qDAAgB,iBAAiB8E,SAAjC,CADqC,EAErCrD,YAFqC,CAAtC;AAIA,QAAMC,YAAY,GAAGF,oBAAoB,CACxCkB,IAAI,CAACyC,SAAL,CAAgBpC,QAAhB,aAAgBA,QAAhB,uBAAgBA,QAAQ,CAAEI,MAA1B,CADwC,EAExC1B,YAFwC,CAAzC;AAIA,QAAM2D,YAAY,GAAG5D,oBAAoB,CACxC0D,SADwC,EAExCzD,YAFwC,EAGxCC,YAHwC,CAAzC;AAMA,QAAMV,SAAS,GAAGqC,kBAAkB,CAAEN,QAAF,aAAEA,QAAF,+CAAEA,QAAQ,CAAE7B,UAAZ,yDAAE,qBAAsBF,SAAxB,CAApC;AAEA,SAAO;AACN6D,IAAAA,sBAAsB,EAAE;AACvB7E,MAAAA,KAAK,EAAE;AACNgD,QAAAA,OAAO,EAAEC,MAAF,aAAEA,MAAF,uBAAEA,MAAM,CAAED,OADX;AAEN8B,QAAAA,SAFM;AAGNpG,QAAAA,IAAI,0BAAEqE,QAAF,aAAEA,QAAF,2CAAEA,QAAQ,CAAE/C,KAAZ,qDAAE,iBAAiBtB,IAAnB,uEAA2B,IAHzB;AAINC,QAAAA,UAAU,2BAAEoE,QAAF,aAAEA,QAAF,2CAAEA,QAAQ,CAAE/C,KAAZ,qDAAE,iBAAiBrB,UAAnB,yEAAiC,IAJrC;AAKNoG,QAAAA,cAAc,2BAAEhC,QAAF,aAAEA,QAAF,2CAAEA,QAAQ,CAAE/C,KAAZ,qDAAE,iBAAiB+E,cAAnB,yEAAqC,IAL7C;AAMNC,QAAAA,gBAAgB,4BAAEjC,QAAF,aAAEA,QAAF,2CAAEA,QAAQ,CAAE/C,KAAZ,qDAAE,iBAAiBgF,gBAAnB,2EAAuC;AANjD,OADgB;AASvB9D,MAAAA,UAAU,EAAE;AACXF,QAAAA,SADW;AAEXqE,QAAAA,gBAAgB,EAAEtC,QAAF,aAAEA,QAAF,2CAAEA,QAAQ,CAAEI,MAAZ,qDAAE,iBAAoB,aAApB;AAFP;AATW,KADlB;AAeNyB,IAAAA,oCAAoC,EAAEQ;AAfhC,GAAP;AAiBA","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":["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","Dimensions","get","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"]}
@@ -64,6 +64,7 @@ const ImageComponent = _ref => {
64
64
  height: imageHeight,
65
65
  highlightSelected = true,
66
66
  isSelected,
67
+ shouldUseFastImage,
67
68
  isUploadFailed,
68
69
  isUploadInProgress,
69
70
  mediaPickerOptions,
@@ -79,7 +80,10 @@ const ImageComponent = _ref => {
79
80
  width: imageWidth
80
81
  } = _ref;
81
82
  const [imageData, setImageData] = (0, _element.useState)(null);
82
- const [containerSize, setContainerSize] = (0, _element.useState)(null);
83
+ const [containerSize, setContainerSize] = (0, _element.useState)(null); // Disabled for Android due to https://github.com/WordPress/gutenberg/issues/43149
84
+
85
+ const Image = !shouldUseFastImage || _element.Platform.isAndroid ? _reactNative.Image : _reactNativeFastImage.default;
86
+ const imageResizeMode = !shouldUseFastImage || _element.Platform.isAndroid ? resizeMode : _reactNativeFastImage.default.resizeMode[resizeMode];
83
87
  (0, _element.useEffect)(() => {
84
88
  let isCurrent = true;
85
89
 
@@ -156,6 +160,8 @@ const ImageComponent = _ref => {
156
160
  const imageStyles = [{
157
161
  opacity: isUploadInProgress ? 0.3 : 1,
158
162
  height: containerSize === null || containerSize === void 0 ? void 0 : containerSize.height
163
+ }, !resizeMode && {
164
+ aspectRatio: imageData === null || imageData === void 0 ? void 0 : imageData.aspectRatio
159
165
  }, focalPoint && _style.default.focalPoint, focalPoint && (0, _utils.getImageWithFocalPointStyles)(focalPoint, containerSize, imageData), !focalPoint && imageData && containerSize && {
160
166
  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
161
167
  }, imageHeight && {
@@ -187,9 +193,7 @@ const ImageComponent = _ref => {
187
193
  style: _style.default.imageUploadingIconContainer
188
194
  }, getIcon(ICON_TYPE.UPLOAD))) : (0, _element.createElement)(_reactNative.View, {
189
195
  style: focalPoint && _style.default.focalPointContent
190
- }, (0, _element.createElement)(_reactNativeFastImage.default, (0, _extends2.default)({}, !resizeMode && {
191
- aspectRatio: imageData === null || imageData === void 0 ? void 0 : imageData.aspectRatio
192
- }, {
196
+ }, (0, _element.createElement)(Image, (0, _extends2.default)({
193
197
  style: imageStyles,
194
198
  source: {
195
199
  uri: url
@@ -197,7 +201,7 @@ const ImageComponent = _ref => {
197
201
  }, !focalPoint && {
198
202
  resizeMethod: 'scale'
199
203
  }, {
200
- resizeMode: _reactNativeFastImage.default.resizeMode[resizeMode]
204
+ resizeMode: imageResizeMode
201
205
  }))), isUploadFailed && retryMessage && (0, _element.createElement)(_reactNative.View, {
202
206
  style: [_style.default.imageContainer, _style.default.retryContainer]
203
207
  }, (0, _element.createElement)(_reactNative.View, {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/image/index.native.js"],"names":["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","Image","getSize","imgWidth","imgHeight","metaData","aspectRatio","onContainerLayout","event","nativeEvent","layout","getIcon","iconType","iconStyle","SvgIconRetry","styles","iconRetry","iconPlaceholderStyles","iconUploadStyles","icon","iconPlaceholder","iconPlaceholderDark","iconUpload","iconUploadDark","placeholderStyles","imageContainerUpload","imageContainerUploadDark","imageContainerUploadWithFocalpoint","customWidth","wide","imageContainerStyles","imageContent","focalPointContainer","imageStyles","opacity","undefined","container","alignItems","imageBorder","imageUploadingIconContainer","focalPointContent","uri","resizeMethod","FastImage","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":["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","Image","Platform","isAndroid","RNImage","FastImage","imageResizeMode","isCurrent","getSize","imgWidth","imgHeight","metaData","aspectRatio","onContainerLayout","event","nativeEvent","layout","getIcon","iconType","iconStyle","SvgIconRetry","styles","iconRetry","iconPlaceholderStyles","iconUploadStyles","icon","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"]}
@@ -11,8 +11,6 @@ var _reactNative = require("react-native");
11
11
 
12
12
  var _native = require("@react-navigation/native");
13
13
 
14
- var _lodash = require("lodash");
15
-
16
14
  var _ = require("./");
17
15
 
18
16
  /**
@@ -32,6 +30,8 @@ const LinkPickerScreen = _ref => {
32
30
  } = _ref;
33
31
  const navigation = (0, _native.useNavigation)();
34
32
  const route = (0, _native.useRoute)();
33
+ const navigateToLinkTimeoutRef = (0, _element.useRef)(null);
34
+ const navigateBackTimeoutRef = (0, _element.useRef)(null);
35
35
 
36
36
  const onLinkPicked = _ref2 => {
37
37
  let {
@@ -41,7 +41,7 @@ const LinkPickerScreen = _ref => {
41
41
 
42
42
  _reactNative.Keyboard.dismiss();
43
43
 
44
- (0, _lodash.delay)(() => {
44
+ navigateToLinkTimeoutRef.current = setTimeout(() => {
45
45
  navigation.navigate(returnScreenName, {
46
46
  inputValue: url,
47
47
  text: title
@@ -52,11 +52,17 @@ const LinkPickerScreen = _ref => {
52
52
  const onCancel = () => {
53
53
  _reactNative.Keyboard.dismiss();
54
54
 
55
- (0, _lodash.delay)(() => {
55
+ navigateBackTimeoutRef.current = setTimeout(() => {
56
56
  navigation.goBack();
57
57
  }, 100);
58
58
  };
59
59
 
60
+ (0, _element.useEffect)(() => {
61
+ return () => {
62
+ clearTimeout(navigateToLinkTimeoutRef.current);
63
+ clearTimeout(navigateBackTimeoutRef.current);
64
+ };
65
+ }, []);
60
66
  const {
61
67
  inputValue
62
68
  } = route.params;
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/link-picker/link-picker-screen.native.js"],"names":["LinkPickerScreen","returnScreenName","navigation","route","onLinkPicked","url","title","Keyboard","dismiss","navigate","inputValue","text","onCancel","goBack","params"],"mappings":";;;;;;;AAUA;;AAPA;;AACA;;AACA;;AAUA;;AAfA;AACA;AACA;;AAKA;AACA;AACA;;AAGA;AACA;AACA;AAGA,MAAMA,gBAAgB,GAAG,QAA4B;AAAA,MAA1B;AAAEC,IAAAA;AAAF,GAA0B;AACpD,QAAMC,UAAU,GAAG,4BAAnB;AACA,QAAMC,KAAK,GAAG,uBAAd;;AAEA,QAAMC,YAAY,GAAG,SAAsB;AAAA,QAApB;AAAEC,MAAAA,GAAF;AAAOC,MAAAA;AAAP,KAAoB;;AAC1CC,0BAASC,OAAT;;AACA,uBAAO,MAAM;AACZN,MAAAA,UAAU,CAACO,QAAX,CAAqBR,gBAArB,EAAuC;AACtCS,QAAAA,UAAU,EAAEL,GAD0B;AAEtCM,QAAAA,IAAI,EAAEL;AAFgC,OAAvC;AAIA,KALD,EAKG,GALH;AAMA,GARD;;AAUA,QAAMM,QAAQ,GAAG,MAAM;AACtBL,0BAASC,OAAT;;AACA,uBAAO,MAAM;AACZN,MAAAA,UAAU,CAACW,MAAX;AACA,KAFD,EAEG,GAFH;AAGA,GALD;;AAOA,QAAM;AAAEH,IAAAA;AAAF,MAAiBP,KAAK,CAACW,MAA7B;AACA,SAAO,sBAAS,MAAM;AACrB,WACC,4BAAC,YAAD;AACC,MAAA,KAAK,EAAGJ,UADT;AAEC,MAAA,YAAY,EAAGN,YAFhB;AAGC,MAAA,QAAQ,EAAGQ;AAHZ,MADD;AAOA,GARM,EAQJ,CAAEF,UAAF,CARI,CAAP;AASA,CA/BD;;eAiCeV,gB","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":["LinkPickerScreen","returnScreenName","navigation","route","navigateToLinkTimeoutRef","navigateBackTimeoutRef","onLinkPicked","url","title","Keyboard","dismiss","current","setTimeout","navigate","inputValue","text","onCancel","goBack","clearTimeout","params"],"mappings":";;;;;;;AASA;;AANA;;AACA;;AAUA;;AAdA;AACA;AACA;;AAIA;AACA;AACA;;AAGA;AACA;AACA;AAGA,MAAMA,gBAAgB,GAAG,QAA4B;AAAA,MAA1B;AAAEC,IAAAA;AAAF,GAA0B;AACpD,QAAMC,UAAU,GAAG,4BAAnB;AACA,QAAMC,KAAK,GAAG,uBAAd;AACA,QAAMC,wBAAwB,GAAG,qBAAQ,IAAR,CAAjC;AACA,QAAMC,sBAAsB,GAAG,qBAAQ,IAAR,CAA/B;;AAEA,QAAMC,YAAY,GAAG,SAAsB;AAAA,QAApB;AAAEC,MAAAA,GAAF;AAAOC,MAAAA;AAAP,KAAoB;;AAC1CC,0BAASC,OAAT;;AACAN,IAAAA,wBAAwB,CAACO,OAAzB,GAAmCC,UAAU,CAAE,MAAM;AACpDV,MAAAA,UAAU,CAACW,QAAX,CAAqBZ,gBAArB,EAAuC;AACtCa,QAAAA,UAAU,EAAEP,GAD0B;AAEtCQ,QAAAA,IAAI,EAAEP;AAFgC,OAAvC;AAIA,KAL4C,EAK1C,GAL0C,CAA7C;AAMA,GARD;;AAUA,QAAMQ,QAAQ,GAAG,MAAM;AACtBP,0BAASC,OAAT;;AACAL,IAAAA,sBAAsB,CAACM,OAAvB,GAAiCC,UAAU,CAAE,MAAM;AAClDV,MAAAA,UAAU,CAACe,MAAX;AACA,KAF0C,EAExC,GAFwC,CAA3C;AAGA,GALD;;AAOA,0BAAW,MAAM;AAChB,WAAO,MAAM;AACZC,MAAAA,YAAY,CAAEd,wBAAwB,CAACO,OAA3B,CAAZ;AACAO,MAAAA,YAAY,CAAEb,sBAAsB,CAACM,OAAzB,CAAZ;AACA,KAHD;AAIA,GALD,EAKG,EALH;AAOA,QAAM;AAAEG,IAAAA;AAAF,MAAiBX,KAAK,CAACgB,MAA7B;AACA,SAAO,sBAAS,MAAM;AACrB,WACC,4BAAC,YAAD;AACC,MAAA,KAAK,EAAGL,UADT;AAEC,MAAA,YAAY,EAAGR,YAFhB;AAGC,MAAA,QAAQ,EAAGU;AAHZ,MADD;AAOA,GARM,EAQJ,CAAEF,UAAF,CARI,CAAP;AASA,CAxCD;;eA0Ced,gB","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"]}
@@ -7,18 +7,12 @@ exports.default = exports.MediaEdit = exports.MEDIA_TYPE_IMAGE = exports.MEDIA_E
7
7
 
8
8
  var _element = require("@wordpress/element");
9
9
 
10
- var _lodash = require("lodash");
11
-
12
10
  var _i18n = require("@wordpress/i18n");
13
11
 
14
12
  var _components = require("@wordpress/components");
15
13
 
16
14
  var _reactNativeBridge = require("@wordpress/react-native-bridge");
17
15
 
18
- /**
19
- * External dependencies
20
- */
21
-
22
16
  /**
23
17
  * WordPress dependencies
24
18
  */
@@ -55,7 +49,7 @@ class MediaEdit extends _element.Component {
55
49
  openReplaceMediaOptions,
56
50
  source
57
51
  } = this.props;
58
- return (0, _lodash.compact)([(source === null || source === void 0 ? void 0 : source.uri) && editOption, openReplaceMediaOptions && replaceOption, ...(pickerOptions ? pickerOptions : [])]);
52
+ return [(source === null || source === void 0 ? void 0 : source.uri) && editOption, openReplaceMediaOptions && replaceOption, ...(pickerOptions ? pickerOptions : [])].filter(Boolean);
59
53
  }
60
54
 
61
55
  getDestructiveButtonIndex() {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/media-edit/index.native.js"],"names":["MEDIA_TYPE_IMAGE","MEDIA_EDITOR","editOption","id","value","label","requiresModal","types","replaceOption","mediaSources","deviceLibrary","MediaEdit","Component","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":["MEDIA_TYPE_IMAGE","MEDIA_EDITOR","editOption","id","value","label","requiresModal","types","replaceOption","mediaSources","deviceLibrary","MediaEdit","Component","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"]}
@@ -33,7 +33,7 @@ var _styles = _interopRequireDefault(require("./styles.scss"));
33
33
  * Internal dependencies
34
34
  */
35
35
  function Separator() {
36
- const separatorStyle = (0, _compose.usePreferredColorSchemeStyle)(_styles.default.separator, _styles.default.separatorDark);
36
+ const separatorStyle = (0, _compose.usePreferredColorSchemeStyle)(_styles.default['components-picker__separator'], _styles.default['components-picker__separator--dark']);
37
37
  return (0, _element.createElement)(_reactNative.View, {
38
38
  style: separatorStyle
39
39
  });
@@ -83,7 +83,7 @@ class Picker extends _element.Component {
83
83
  separatorType: 'none',
84
84
  onPress: () => this.onCellPress(option.value),
85
85
  disabled: option.disabled,
86
- style: option.disabled && _styles.default.disabled
86
+ style: option.disabled && _styles.default['components-picker__button--disabled']
87
87
  })));
88
88
  }
89
89
 
@@ -103,7 +103,7 @@ class Picker extends _element.Component {
103
103
  testID: testID
104
104
  }, (0, _element.createElement)(_components.PanelBody, {
105
105
  title: title,
106
- style: _styles.default.panelBody
106
+ style: _styles.default['components-picker__panel']
107
107
  }, this.getOptions(), !hideCancelButton && (0, _element.createElement)(_components.TextControl, {
108
108
  label: (0, _i18n.__)('Cancel'),
109
109
  onPress: this.onClose,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/picker/index.android.js"],"names":["Separator","separatorStyle","styles","separator","separatorDark","Picker","Component","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":";;;;;;;;;AASA;;AANA;;AAKA;;AAEA;;AACA;;AAKA;;AACA;;AAjBA;AACA;AACA;;AAGA;AACA;AACA;;AAMA;AACA;AACA;AAIA,SAASA,SAAT,GAAqB;AACpB,QAAMC,cAAc,GAAG,2CACtBC,gBAAOC,SADe,EAEtBD,gBAAOE,aAFe,CAAvB;AAKA,SAAO,4BAAC,iBAAD;AAAM,IAAA,KAAK,EAAGH;AAAd,IAAP;AACA;;AAEc,MAAMI,MAAN,SAAqBC,kBAArB,CAA+B;AAC7CC,EAAAA,WAAW,GAAG;AACb,UAAO,GAAGC,SAAV;AACA,SAAKC,OAAL,GAAe,KAAKA,OAAL,CAAaC,IAAb,CAAmB,IAAnB,CAAf;AACA,SAAKC,WAAL,GAAmB,KAAKA,WAAL,CAAiBD,IAAjB,CAAuB,IAAvB,CAAnB;AAEA,SAAKE,KAAL,GAAa;AACZC,MAAAA,SAAS,EAAE;AADC,KAAb;AAGA;;AAEDC,EAAAA,aAAa,GAAG;AACf,SAAKC,QAAL,CAAe;AAAEF,MAAAA,SAAS,EAAE;AAAb,KAAf;AACA;;AAEDJ,EAAAA,OAAO,GAAG;AACT,SAAKM,QAAL,CAAe;AAAEF,MAAAA,SAAS,EAAE;AAAb,KAAf;AACA;;AAEDF,EAAAA,WAAW,CAAEK,KAAF,EAAU;AACpB,UAAM;AAAEC,MAAAA;AAAF,QAAe,KAAKC,KAA1B;AACAD,IAAAA,QAAQ,CAAED,KAAF,CAAR;AACA,SAAKP,OAAL;AACA;;AAEDU,EAAAA,UAAU,GAAG;AACZ,UAAM;AAAEC,MAAAA,OAAF;AAAWC,MAAAA;AAAX,QAAyB,KAAKH,KAApC;AAEA,WAAOE,OAAO,CAACE,GAAR,CAAeC,MAAF,IACnB,4BAAC,iBAAD;AAAU,MAAA,GAAG,EAAI,GAAGA,MAAM,CAACC,KAAO,IAAID,MAAM,CAACP,KAAO;AAApD,OACGI,OAAO,CAACK,MAAR,GAAiB,CAAjB,IAAsBF,MAAM,CAACG,SAA7B,IAA0C,4BAAC,SAAD,OAD7C,EAEC,4BAAC,oBAAD,CAAa,IAAb;AACC,MAAA,IAAI,EAAGH,MAAM,CAACI,IADf;AAEC,MAAA,SAAS,EAAGN,SAFb;AAGC,MAAA,KAAK,EAAGE,MAAM,CAACC,KAHhB;AAIC,MAAA,aAAa,EAAG,MAJjB;AAKC,MAAA,OAAO,EAAG,MAAM,KAAKb,WAAL,CAAkBY,MAAM,CAACP,KAAzB,CALjB;AAMC,MAAA,QAAQ,EAAGO,MAAM,CAACK,QANnB;AAOC,MAAA,KAAK,EAAGL,MAAM,CAACK,QAAP,IAAmB1B,gBAAO0B;AAPnC,MAFD,CADM,CAAP;AAcA;;AAEDC,EAAAA,MAAM,GAAG;AACR,UAAM;AAAEC,MAAAA,gBAAF;AAAoBC,MAAAA,KAApB;AAA2BC,MAAAA;AAA3B,QAAsC,KAAKd,KAAjD;AACA,UAAM;AAAEL,MAAAA;AAAF,QAAgB,KAAKD,KAA3B;AAEA,WACC,4BAAC,oBAAD;AACC,MAAA,SAAS,EAAGC,SADb;AAEC,MAAA,OAAO,EAAG,KAAKJ,OAFhB;AAGC,MAAA,UAAU,MAHX;AAIC,MAAA,MAAM,EAAGuB;AAJV,OAMC,4BAAC,qBAAD;AAAW,MAAA,KAAK,EAAGD,KAAnB;AAA2B,MAAA,KAAK,EAAG7B,gBAAO+B;AAA1C,OACG,KAAKd,UAAL,EADH,EAEG,CAAEW,gBAAF,IACD,4BAAC,uBAAD;AACC,MAAA,KAAK,EAAG,cAAI,QAAJ,CADT;AAEC,MAAA,OAAO,EAAG,KAAKrB,OAFhB;AAGC,MAAA,aAAa,EAAG;AAHjB,MAHF,CAND,CADD;AAmBA;;AAnE4C","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":["Separator","separatorStyle","styles","Picker","Component","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":";;;;;;;;;AASA;;AANA;;AAKA;;AAEA;;AACA;;AAKA;;AACA;;AAjBA;AACA;AACA;;AAGA;AACA;AACA;;AAMA;AACA;AACA;AAIA,SAASA,SAAT,GAAqB;AACpB,QAAMC,cAAc,GAAG,2CACtBC,gBAAQ,8BAAR,CADsB,EAEtBA,gBAAQ,oCAAR,CAFsB,CAAvB;AAKA,SAAO,4BAAC,iBAAD;AAAM,IAAA,KAAK,EAAGD;AAAd,IAAP;AACA;;AAEc,MAAME,MAAN,SAAqBC,kBAArB,CAA+B;AAC7CC,EAAAA,WAAW,GAAG;AACb,UAAO,GAAGC,SAAV;AACA,SAAKC,OAAL,GAAe,KAAKA,OAAL,CAAaC,IAAb,CAAmB,IAAnB,CAAf;AACA,SAAKC,WAAL,GAAmB,KAAKA,WAAL,CAAiBD,IAAjB,CAAuB,IAAvB,CAAnB;AAEA,SAAKE,KAAL,GAAa;AACZC,MAAAA,SAAS,EAAE;AADC,KAAb;AAGA;;AAEDC,EAAAA,aAAa,GAAG;AACf,SAAKC,QAAL,CAAe;AAAEF,MAAAA,SAAS,EAAE;AAAb,KAAf;AACA;;AAEDJ,EAAAA,OAAO,GAAG;AACT,SAAKM,QAAL,CAAe;AAAEF,MAAAA,SAAS,EAAE;AAAb,KAAf;AACA;;AAEDF,EAAAA,WAAW,CAAEK,KAAF,EAAU;AACpB,UAAM;AAAEC,MAAAA;AAAF,QAAe,KAAKC,KAA1B;AACAD,IAAAA,QAAQ,CAAED,KAAF,CAAR;AACA,SAAKP,OAAL;AACA;;AAEDU,EAAAA,UAAU,GAAG;AACZ,UAAM;AAAEC,MAAAA,OAAF;AAAWC,MAAAA;AAAX,QAAyB,KAAKH,KAApC;AAEA,WAAOE,OAAO,CAACE,GAAR,CAAeC,MAAF,IACnB,4BAAC,iBAAD;AAAU,MAAA,GAAG,EAAI,GAAGA,MAAM,CAACC,KAAO,IAAID,MAAM,CAACP,KAAO;AAApD,OACGI,OAAO,CAACK,MAAR,GAAiB,CAAjB,IAAsBF,MAAM,CAACG,SAA7B,IAA0C,4BAAC,SAAD,OAD7C,EAEC,4BAAC,oBAAD,CAAa,IAAb;AACC,MAAA,IAAI,EAAGH,MAAM,CAACI,IADf;AAEC,MAAA,SAAS,EAAGN,SAFb;AAGC,MAAA,KAAK,EAAGE,MAAM,CAACC,KAHhB;AAIC,MAAA,aAAa,EAAG,MAJjB;AAKC,MAAA,OAAO,EAAG,MAAM,KAAKb,WAAL,CAAkBY,MAAM,CAACP,KAAzB,CALjB;AAMC,MAAA,QAAQ,EAAGO,MAAM,CAACK,QANnB;AAOC,MAAA,KAAK,EACJL,MAAM,CAACK,QAAP,IACAxB,gBAAQ,qCAAR;AATF,MAFD,CADM,CAAP;AAiBA;;AAEDyB,EAAAA,MAAM,GAAG;AACR,UAAM;AAAEC,MAAAA,gBAAF;AAAoBC,MAAAA,KAApB;AAA2BC,MAAAA;AAA3B,QAAsC,KAAKd,KAAjD;AACA,UAAM;AAAEL,MAAAA;AAAF,QAAgB,KAAKD,KAA3B;AAEA,WACC,4BAAC,oBAAD;AACC,MAAA,SAAS,EAAGC,SADb;AAEC,MAAA,OAAO,EAAG,KAAKJ,OAFhB;AAGC,MAAA,UAAU,MAHX;AAIC,MAAA,MAAM,EAAGuB;AAJV,OAMC,4BAAC,qBAAD;AACC,MAAA,KAAK,EAAGD,KADT;AAEC,MAAA,KAAK,EAAG3B,gBAAQ,0BAAR;AAFT,OAIG,KAAKe,UAAL,EAJH,EAKG,CAAEW,gBAAF,IACD,4BAAC,uBAAD;AACC,MAAA,KAAK,EAAG,cAAI,QAAJ,CADT;AAEC,MAAA,OAAO,EAAG,KAAKrB,OAFhB;AAGC,MAAA,aAAa,EAAG;AAHjB,MANF,CAND,CADD;AAsBA;;AAzE4C","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"]}
@@ -19,6 +19,10 @@ var _data = require("@wordpress/data");
19
19
 
20
20
  var _components = require("@wordpress/components");
21
21
 
22
+ var _compose = require("@wordpress/compose");
23
+
24
+ var _styles = _interopRequireDefault(require("./styles.scss"));
25
+
22
26
  /**
23
27
  * External dependencies
24
28
  */
@@ -26,6 +30,10 @@ var _components = require("@wordpress/components");
26
30
  /**
27
31
  * WordPress dependencies
28
32
  */
33
+
34
+ /**
35
+ * Internal dependencies
36
+ */
29
37
  class Picker extends _element.Component {
30
38
  presentPicker() {
31
39
  const {
@@ -37,7 +45,8 @@ class Picker extends _element.Component {
37
45
  getAnchor,
38
46
  isBottomSheetOpened,
39
47
  closeBottomSheet,
40
- onHandleClosingBottomSheet
48
+ onHandleClosingBottomSheet,
49
+ colorScheme
41
50
  } = this.props;
42
51
  const labels = options.map(_ref => {
43
52
  let {
@@ -46,6 +55,7 @@ class Picker extends _element.Component {
46
55
  return label;
47
56
  });
48
57
  const fullOptions = [(0, _i18n.__)('Cancel')].concat(labels);
58
+ const buttonTitleColor = colorScheme === 'light' ? _styles.default['components-picker__button-title'].color : _styles.default['components-picker__button-title--dark'].color;
49
59
 
50
60
  _reactNative.ActionSheetIOS.showActionSheetWithOptions({
51
61
  title,
@@ -53,7 +63,8 @@ class Picker extends _element.Component {
53
63
  cancelButtonIndex: 0,
54
64
  destructiveButtonIndex,
55
65
  disabledButtonIndices,
56
- anchor: getAnchor && getAnchor()
66
+ anchor: getAnchor && getAnchor(),
67
+ tintColor: buttonTitleColor
57
68
  }, buttonIndex => {
58
69
  if (buttonIndex === 0) {
59
70
  return;
@@ -86,12 +97,14 @@ const PickerComponent = (0, _element.forwardRef)((props, ref) => {
86
97
  const {
87
98
  onHandleClosingBottomSheet
88
99
  } = (0, _element.useContext)(_components.BottomSheetContext);
100
+ const colorScheme = (0, _compose.usePreferredColorScheme)();
89
101
  return (0, _element.createElement)(Picker, (0, _extends2.default)({
90
102
  ref: ref
91
103
  }, props, {
92
104
  isBottomSheetOpened: isBottomSheetOpened,
93
105
  closeBottomSheet: closeGeneralSidebar,
94
- onHandleClosingBottomSheet: onHandleClosingBottomSheet
106
+ onHandleClosingBottomSheet: onHandleClosingBottomSheet,
107
+ colorScheme: colorScheme
95
108
  }));
96
109
  });
97
110
  var _default = PickerComponent;
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/mobile/picker/index.ios.js"],"names":["Picker","Component","presentPicker","options","onChange","title","destructiveButtonIndex","disabledButtonIndices","getAnchor","isBottomSheetOpened","closeBottomSheet","onHandleClosingBottomSheet","props","labels","map","label","fullOptions","concat","ActionSheetIOS","showActionSheetWithOptions","cancelButtonIndex","anchor","buttonIndex","selected","requiresModal","value","render","PickerComponent","ref","select","isEditorSidebarOpened","closeGeneralSidebar","BottomSheetContext"],"mappings":";;;;;;;;;AASA;;;;AANA;;AAKA;;AAEA;;AACA;;AAXA;AACA;AACA;;AAGA;AACA;AACA;AAMA,MAAMA,MAAN,SAAqBC,kBAArB,CAA+B;AAC9BC,EAAAA,aAAa,GAAG;AACf,UAAM;AACLC,MAAAA,OADK;AAELC,MAAAA,QAFK;AAGLC,MAAAA,KAHK;AAILC,MAAAA,sBAJK;AAKLC,MAAAA,qBALK;AAMLC,MAAAA,SANK;AAOLC,MAAAA,mBAPK;AAQLC,MAAAA,gBARK;AASLC,MAAAA;AATK,QAUF,KAAKC,KAVT;AAWA,UAAMC,MAAM,GAAGV,OAAO,CAACW,GAAR,CAAa;AAAA,UAAE;AAAEC,QAAAA;AAAF,OAAF;AAAA,aAAiBA,KAAjB;AAAA,KAAb,CAAf;AACA,UAAMC,WAAW,GAAG,CAAE,cAAI,QAAJ,CAAF,EAAmBC,MAAnB,CAA2BJ,MAA3B,CAApB;;AAEAK,gCAAeC,0BAAf,CACC;AACCd,MAAAA,KADD;AAECF,MAAAA,OAAO,EAAEa,WAFV;AAGCI,MAAAA,iBAAiB,EAAE,CAHpB;AAICd,MAAAA,sBAJD;AAKCC,MAAAA,qBALD;AAMCc,MAAAA,MAAM,EAAEb,SAAS,IAAIA,SAAS;AAN/B,KADD,EASGc,WAAF,IAAmB;AAClB,UAAKA,WAAW,KAAK,CAArB,EAAyB;AACxB;AACA;;AACD,YAAMC,QAAQ,GAAGpB,OAAO,CAAEmB,WAAW,GAAG,CAAhB,CAAxB;;AAEA,UAAKC,QAAQ,CAACC,aAAT,IAA0Bf,mBAA/B,EAAqD;AACpDE,QAAAA,0BAA0B,CAAE,MAAM;AACjCP,UAAAA,QAAQ,CAAEmB,QAAQ,CAACE,KAAX,CAAR;AACA,SAFyB,CAA1B;AAGAf,QAAAA,gBAAgB;AAChB,OALD,MAKO;AACNN,QAAAA,QAAQ,CAAEmB,QAAQ,CAACE,KAAX,CAAR;AACA;AACD,KAvBF;AAyBA;;AAEDC,EAAAA,MAAM,GAAG;AACR,WAAO,IAAP;AACA;;AA7C6B;;AAgD/B,MAAMC,eAAe,GAAG,yBAAY,CAAEf,KAAF,EAASgB,GAAT,KAAkB;AACrD,QAAMnB,mBAAmB,GAAG,qBAAaoB,MAAF,IACtCA,MAAM,CAAE,gBAAF,CAAN,CAA2BC,qBAA3B,EAD2B,CAA5B;AAGA,QAAM;AAAEC,IAAAA;AAAF,MAA0B,uBAAa,gBAAb,CAAhC;AACA,QAAM;AAAEpB,IAAAA;AAAF,MAAiC,yBAAYqB,8BAAZ,CAAvC;AAEA,SACC,4BAAC,MAAD;AACC,IAAA,GAAG,EAAGJ;AADP,KAEMhB,KAFN;AAGC,IAAA,mBAAmB,EAAGH,mBAHvB;AAIC,IAAA,gBAAgB,EAAGsB,mBAJpB;AAKC,IAAA,0BAA0B,EAAGpB;AAL9B,KADD;AASA,CAhBuB,CAAxB;eAkBegB,e","sourcesContent":["/**\n * External dependencies\n */\nimport { ActionSheetIOS } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Component, forwardRef, useContext } from '@wordpress/element';\nimport { useDispatch, useSelect } from '@wordpress/data';\nimport { BottomSheetContext } from '@wordpress/components';\n\nclass Picker extends Component {\n\tpresentPicker() {\n\t\tconst {\n\t\t\toptions,\n\t\t\tonChange,\n\t\t\ttitle,\n\t\t\tdestructiveButtonIndex,\n\t\t\tdisabledButtonIndices,\n\t\t\tgetAnchor,\n\t\t\tisBottomSheetOpened,\n\t\t\tcloseBottomSheet,\n\t\t\tonHandleClosingBottomSheet,\n\t\t} = this.props;\n\t\tconst labels = options.map( ( { label } ) => label );\n\t\tconst fullOptions = [ __( 'Cancel' ) ].concat( labels );\n\n\t\tActionSheetIOS.showActionSheetWithOptions(\n\t\t\t{\n\t\t\t\ttitle,\n\t\t\t\toptions: fullOptions,\n\t\t\t\tcancelButtonIndex: 0,\n\t\t\t\tdestructiveButtonIndex,\n\t\t\t\tdisabledButtonIndices,\n\t\t\t\tanchor: getAnchor && getAnchor(),\n\t\t\t},\n\t\t\t( buttonIndex ) => {\n\t\t\t\tif ( buttonIndex === 0 ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst selected = options[ buttonIndex - 1 ];\n\n\t\t\t\tif ( selected.requiresModal && isBottomSheetOpened ) {\n\t\t\t\t\tonHandleClosingBottomSheet( () => {\n\t\t\t\t\t\tonChange( selected.value );\n\t\t\t\t\t} );\n\t\t\t\t\tcloseBottomSheet();\n\t\t\t\t} else {\n\t\t\t\t\tonChange( selected.value );\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t}\n\n\trender() {\n\t\treturn null;\n\t}\n}\n\nconst PickerComponent = forwardRef( ( props, ref ) => {\n\tconst isBottomSheetOpened = useSelect( ( select ) =>\n\t\tselect( 'core/edit-post' ).isEditorSidebarOpened()\n\t);\n\tconst { closeGeneralSidebar } = useDispatch( 'core/edit-post' );\n\tconst { onHandleClosingBottomSheet } = useContext( BottomSheetContext );\n\n\treturn (\n\t\t<Picker\n\t\t\tref={ ref }\n\t\t\t{ ...props }\n\t\t\tisBottomSheetOpened={ isBottomSheetOpened }\n\t\t\tcloseBottomSheet={ closeGeneralSidebar }\n\t\t\tonHandleClosingBottomSheet={ onHandleClosingBottomSheet }\n\t\t/>\n\t);\n} );\n\nexport default PickerComponent;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/mobile/picker/index.ios.js"],"names":["Picker","Component","presentPicker","options","onChange","title","destructiveButtonIndex","disabledButtonIndices","getAnchor","isBottomSheetOpened","closeBottomSheet","onHandleClosingBottomSheet","colorScheme","props","labels","map","label","fullOptions","concat","buttonTitleColor","styles","color","ActionSheetIOS","showActionSheetWithOptions","cancelButtonIndex","anchor","tintColor","buttonIndex","selected","requiresModal","value","render","PickerComponent","ref","select","isEditorSidebarOpened","closeGeneralSidebar","BottomSheetContext"],"mappings":";;;;;;;;;AASA;;;;AANA;;AAKA;;AAEA;;AACA;;AACA;;AAKA;;AAjBA;AACA;AACA;;AAGA;AACA;AACA;;AAOA;AACA;AACA;AAGA,MAAMA,MAAN,SAAqBC,kBAArB,CAA+B;AAC9BC,EAAAA,aAAa,GAAG;AACf,UAAM;AACLC,MAAAA,OADK;AAELC,MAAAA,QAFK;AAGLC,MAAAA,KAHK;AAILC,MAAAA,sBAJK;AAKLC,MAAAA,qBALK;AAMLC,MAAAA,SANK;AAOLC,MAAAA,mBAPK;AAQLC,MAAAA,gBARK;AASLC,MAAAA,0BATK;AAULC,MAAAA;AAVK,QAWF,KAAKC,KAXT;AAYA,UAAMC,MAAM,GAAGX,OAAO,CAACY,GAAR,CAAa;AAAA,UAAE;AAAEC,QAAAA;AAAF,OAAF;AAAA,aAAiBA,KAAjB;AAAA,KAAb,CAAf;AACA,UAAMC,WAAW,GAAG,CAAE,cAAI,QAAJ,CAAF,EAAmBC,MAAnB,CAA2BJ,MAA3B,CAApB;AAEA,UAAMK,gBAAgB,GACrBP,WAAW,KAAK,OAAhB,GACGQ,gBAAQ,iCAAR,EAA4CC,KAD/C,GAEGD,gBAAQ,uCAAR,EAAkDC,KAHtD;;AAKAC,gCAAeC,0BAAf,CACC;AACClB,MAAAA,KADD;AAECF,MAAAA,OAAO,EAAEc,WAFV;AAGCO,MAAAA,iBAAiB,EAAE,CAHpB;AAIClB,MAAAA,sBAJD;AAKCC,MAAAA,qBALD;AAMCkB,MAAAA,MAAM,EAAEjB,SAAS,IAAIA,SAAS,EAN/B;AAOCkB,MAAAA,SAAS,EAAEP;AAPZ,KADD,EAUGQ,WAAF,IAAmB;AAClB,UAAKA,WAAW,KAAK,CAArB,EAAyB;AACxB;AACA;;AACD,YAAMC,QAAQ,GAAGzB,OAAO,CAAEwB,WAAW,GAAG,CAAhB,CAAxB;;AAEA,UAAKC,QAAQ,CAACC,aAAT,IAA0BpB,mBAA/B,EAAqD;AACpDE,QAAAA,0BAA0B,CAAE,MAAM;AACjCP,UAAAA,QAAQ,CAAEwB,QAAQ,CAACE,KAAX,CAAR;AACA,SAFyB,CAA1B;AAGApB,QAAAA,gBAAgB;AAChB,OALD,MAKO;AACNN,QAAAA,QAAQ,CAAEwB,QAAQ,CAACE,KAAX,CAAR;AACA;AACD,KAxBF;AA0BA;;AAEDC,EAAAA,MAAM,GAAG;AACR,WAAO,IAAP;AACA;;AApD6B;;AAuD/B,MAAMC,eAAe,GAAG,yBAAY,CAAEnB,KAAF,EAASoB,GAAT,KAAkB;AACrD,QAAMxB,mBAAmB,GAAG,qBAAayB,MAAF,IACtCA,MAAM,CAAE,gBAAF,CAAN,CAA2BC,qBAA3B,EAD2B,CAA5B;AAGA,QAAM;AAAEC,IAAAA;AAAF,MAA0B,uBAAa,gBAAb,CAAhC;AACA,QAAM;AAAEzB,IAAAA;AAAF,MAAiC,yBAAY0B,8BAAZ,CAAvC;AAEA,QAAMzB,WAAW,GAAG,uCAApB;AAEA,SACC,4BAAC,MAAD;AACC,IAAA,GAAG,EAAGqB;AADP,KAEMpB,KAFN;AAGC,IAAA,mBAAmB,EAAGJ,mBAHvB;AAIC,IAAA,gBAAgB,EAAG2B,mBAJpB;AAKC,IAAA,0BAA0B,EAAGzB,0BAL9B;AAMC,IAAA,WAAW,EAAGC;AANf,KADD;AAUA,CAnBuB,CAAxB;eAqBeoB,e","sourcesContent":["/**\n * External dependencies\n */\nimport { ActionSheetIOS } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { Component, forwardRef, useContext } from '@wordpress/element';\nimport { useDispatch, useSelect } from '@wordpress/data';\nimport { BottomSheetContext } from '@wordpress/components';\nimport { usePreferredColorScheme } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport styles from './styles.scss';\n\nclass Picker extends Component {\n\tpresentPicker() {\n\t\tconst {\n\t\t\toptions,\n\t\t\tonChange,\n\t\t\ttitle,\n\t\t\tdestructiveButtonIndex,\n\t\t\tdisabledButtonIndices,\n\t\t\tgetAnchor,\n\t\t\tisBottomSheetOpened,\n\t\t\tcloseBottomSheet,\n\t\t\tonHandleClosingBottomSheet,\n\t\t\tcolorScheme,\n\t\t} = this.props;\n\t\tconst labels = options.map( ( { label } ) => label );\n\t\tconst fullOptions = [ __( 'Cancel' ) ].concat( labels );\n\n\t\tconst buttonTitleColor =\n\t\t\tcolorScheme === 'light'\n\t\t\t\t? styles[ 'components-picker__button-title' ].color\n\t\t\t\t: styles[ 'components-picker__button-title--dark' ].color;\n\n\t\tActionSheetIOS.showActionSheetWithOptions(\n\t\t\t{\n\t\t\t\ttitle,\n\t\t\t\toptions: fullOptions,\n\t\t\t\tcancelButtonIndex: 0,\n\t\t\t\tdestructiveButtonIndex,\n\t\t\t\tdisabledButtonIndices,\n\t\t\t\tanchor: getAnchor && getAnchor(),\n\t\t\t\ttintColor: buttonTitleColor,\n\t\t\t},\n\t\t\t( buttonIndex ) => {\n\t\t\t\tif ( buttonIndex === 0 ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst selected = options[ buttonIndex - 1 ];\n\n\t\t\t\tif ( selected.requiresModal && isBottomSheetOpened ) {\n\t\t\t\t\tonHandleClosingBottomSheet( () => {\n\t\t\t\t\t\tonChange( selected.value );\n\t\t\t\t\t} );\n\t\t\t\t\tcloseBottomSheet();\n\t\t\t\t} else {\n\t\t\t\t\tonChange( selected.value );\n\t\t\t\t}\n\t\t\t}\n\t\t);\n\t}\n\n\trender() {\n\t\treturn null;\n\t}\n}\n\nconst PickerComponent = forwardRef( ( props, ref ) => {\n\tconst isBottomSheetOpened = useSelect( ( select ) =>\n\t\tselect( 'core/edit-post' ).isEditorSidebarOpened()\n\t);\n\tconst { closeGeneralSidebar } = useDispatch( 'core/edit-post' );\n\tconst { onHandleClosingBottomSheet } = useContext( BottomSheetContext );\n\n\tconst colorScheme = usePreferredColorScheme();\n\n\treturn (\n\t\t<Picker\n\t\t\tref={ ref }\n\t\t\t{ ...props }\n\t\t\tisBottomSheetOpened={ isBottomSheetOpened }\n\t\t\tcloseBottomSheet={ closeGeneralSidebar }\n\t\t\tonHandleClosingBottomSheet={ onHandleClosingBottomSheet }\n\t\t\tcolorScheme={ colorScheme }\n\t\t/>\n\t);\n} );\n\nexport default PickerComponent;\n"]}