@metamask-previews/design-system-react-native 0.6.0-preview.3dc70e1 → 0.9.0-preview.694a8ed

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 (483) hide show
  1. package/CHANGELOG.md +69 -1
  2. package/dist/components/ActionListItem/ActionListItem.cjs +86 -0
  3. package/dist/components/ActionListItem/ActionListItem.cjs.map +1 -0
  4. package/dist/components/ActionListItem/ActionListItem.d.cts +4 -0
  5. package/dist/components/ActionListItem/ActionListItem.d.cts.map +1 -0
  6. package/dist/components/ActionListItem/ActionListItem.d.mts +4 -0
  7. package/dist/components/ActionListItem/ActionListItem.d.mts.map +1 -0
  8. package/dist/components/ActionListItem/ActionListItem.mjs +66 -0
  9. package/dist/components/ActionListItem/ActionListItem.mjs.map +1 -0
  10. package/dist/components/ActionListItem/ActionListItem.types.cjs +3 -0
  11. package/dist/components/ActionListItem/ActionListItem.types.cjs.map +1 -0
  12. package/dist/components/ActionListItem/ActionListItem.types.d.cts +73 -0
  13. package/dist/components/ActionListItem/ActionListItem.types.d.cts.map +1 -0
  14. package/dist/components/ActionListItem/ActionListItem.types.d.mts +73 -0
  15. package/dist/components/ActionListItem/ActionListItem.types.d.mts.map +1 -0
  16. package/dist/components/ActionListItem/ActionListItem.types.mjs +2 -0
  17. package/dist/components/ActionListItem/ActionListItem.types.mjs.map +1 -0
  18. package/dist/components/ActionListItem/index.cjs +6 -0
  19. package/dist/components/ActionListItem/index.cjs.map +1 -0
  20. package/dist/components/ActionListItem/index.d.cts +3 -0
  21. package/dist/components/ActionListItem/index.d.cts.map +1 -0
  22. package/dist/components/ActionListItem/index.d.mts +3 -0
  23. package/dist/components/ActionListItem/index.d.mts.map +1 -0
  24. package/dist/components/ActionListItem/index.mjs +2 -0
  25. package/dist/components/ActionListItem/index.mjs.map +1 -0
  26. package/dist/components/BadgeCount/BadgeCount.cjs +3 -3
  27. package/dist/components/BadgeCount/BadgeCount.cjs.map +1 -1
  28. package/dist/components/BadgeCount/BadgeCount.constants.cjs +6 -10
  29. package/dist/components/BadgeCount/BadgeCount.constants.cjs.map +1 -1
  30. package/dist/components/BadgeCount/BadgeCount.constants.d.cts +1 -2
  31. package/dist/components/BadgeCount/BadgeCount.constants.d.cts.map +1 -1
  32. package/dist/components/BadgeCount/BadgeCount.constants.d.mts +1 -2
  33. package/dist/components/BadgeCount/BadgeCount.constants.d.mts.map +1 -1
  34. package/dist/components/BadgeCount/BadgeCount.constants.mjs +3 -7
  35. package/dist/components/BadgeCount/BadgeCount.constants.mjs.map +1 -1
  36. package/dist/components/BadgeCount/BadgeCount.d.cts.map +1 -1
  37. package/dist/components/BadgeCount/BadgeCount.d.mts.map +1 -1
  38. package/dist/components/BadgeCount/BadgeCount.mjs +3 -3
  39. package/dist/components/BadgeCount/BadgeCount.mjs.map +1 -1
  40. package/dist/components/BadgeCount/BadgeCount.types.cjs.map +1 -1
  41. package/dist/components/BadgeCount/BadgeCount.types.d.cts +5 -22
  42. package/dist/components/BadgeCount/BadgeCount.types.d.cts.map +1 -1
  43. package/dist/components/BadgeCount/BadgeCount.types.d.mts +5 -22
  44. package/dist/components/BadgeCount/BadgeCount.types.d.mts.map +1 -1
  45. package/dist/components/BadgeCount/BadgeCount.types.mjs.map +1 -1
  46. package/dist/components/BadgeCount/index.cjs +2 -2
  47. package/dist/components/BadgeCount/index.cjs.map +1 -1
  48. package/dist/components/BadgeCount/index.d.cts +1 -1
  49. package/dist/components/BadgeCount/index.d.cts.map +1 -1
  50. package/dist/components/BadgeCount/index.d.mts +1 -1
  51. package/dist/components/BadgeCount/index.d.mts.map +1 -1
  52. package/dist/components/BadgeCount/index.mjs +1 -1
  53. package/dist/components/BadgeCount/index.mjs.map +1 -1
  54. package/dist/components/BadgeStatus/BadgeStatus.types.cjs.map +1 -1
  55. package/dist/components/BadgeStatus/BadgeStatus.types.d.cts +1 -1
  56. package/dist/components/BadgeStatus/BadgeStatus.types.d.cts.map +1 -1
  57. package/dist/components/BadgeStatus/BadgeStatus.types.d.mts +1 -1
  58. package/dist/components/BadgeStatus/BadgeStatus.types.d.mts.map +1 -1
  59. package/dist/components/BadgeStatus/BadgeStatus.types.mjs.map +1 -1
  60. package/dist/components/BannerBase/BannerBase.cjs +63 -0
  61. package/dist/components/BannerBase/BannerBase.cjs.map +1 -0
  62. package/dist/components/BannerBase/BannerBase.d.cts +4 -0
  63. package/dist/components/BannerBase/BannerBase.d.cts.map +1 -0
  64. package/dist/components/BannerBase/BannerBase.d.mts +4 -0
  65. package/dist/components/BannerBase/BannerBase.d.mts.map +1 -0
  66. package/dist/components/BannerBase/BannerBase.mjs +63 -0
  67. package/dist/components/BannerBase/BannerBase.mjs.map +1 -0
  68. package/dist/components/BannerBase/BannerBase.types.cjs +3 -0
  69. package/dist/components/BannerBase/BannerBase.types.cjs.map +1 -0
  70. package/dist/components/BannerBase/BannerBase.types.d.cts +53 -0
  71. package/dist/components/BannerBase/BannerBase.types.d.cts.map +1 -0
  72. package/dist/components/BannerBase/BannerBase.types.d.mts +53 -0
  73. package/dist/components/BannerBase/BannerBase.types.d.mts.map +1 -0
  74. package/dist/components/BannerBase/BannerBase.types.mjs +2 -0
  75. package/dist/components/BannerBase/BannerBase.types.mjs.map +1 -0
  76. package/dist/components/BannerBase/index.cjs +6 -0
  77. package/dist/components/BannerBase/index.cjs.map +1 -0
  78. package/dist/components/BannerBase/index.d.cts +3 -0
  79. package/dist/components/BannerBase/index.d.cts.map +1 -0
  80. package/dist/components/BannerBase/index.d.mts +3 -0
  81. package/dist/components/BannerBase/index.d.mts.map +1 -0
  82. package/dist/components/BannerBase/index.mjs +2 -0
  83. package/dist/components/BannerBase/index.mjs.map +1 -0
  84. package/dist/components/BottomSheetFooter/BottomSheetFooter.cjs +35 -0
  85. package/dist/components/BottomSheetFooter/BottomSheetFooter.cjs.map +1 -0
  86. package/dist/components/BottomSheetFooter/BottomSheetFooter.d.cts +4 -0
  87. package/dist/components/BottomSheetFooter/BottomSheetFooter.d.cts.map +1 -0
  88. package/dist/components/BottomSheetFooter/BottomSheetFooter.d.mts +4 -0
  89. package/dist/components/BottomSheetFooter/BottomSheetFooter.d.mts.map +1 -0
  90. package/dist/components/BottomSheetFooter/BottomSheetFooter.mjs +35 -0
  91. package/dist/components/BottomSheetFooter/BottomSheetFooter.mjs.map +1 -0
  92. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.cjs +12 -0
  93. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.cjs.map +1 -0
  94. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.d.cts +41 -0
  95. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.d.cts.map +1 -0
  96. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.d.mts +41 -0
  97. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.d.mts.map +1 -0
  98. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.mjs +9 -0
  99. package/dist/components/BottomSheetFooter/BottomSheetFooter.types.mjs.map +1 -0
  100. package/dist/components/BottomSheetFooter/index.cjs +8 -0
  101. package/dist/components/BottomSheetFooter/index.cjs.map +1 -0
  102. package/dist/components/BottomSheetFooter/index.d.cts +4 -0
  103. package/dist/components/BottomSheetFooter/index.d.cts.map +1 -0
  104. package/dist/components/BottomSheetFooter/index.d.mts +4 -0
  105. package/dist/components/BottomSheetFooter/index.d.mts.map +1 -0
  106. package/dist/components/BottomSheetFooter/index.mjs +3 -0
  107. package/dist/components/BottomSheetFooter/index.mjs.map +1 -0
  108. package/dist/components/BottomSheetHeader/BottomSheetHeader.cjs +27 -0
  109. package/dist/components/BottomSheetHeader/BottomSheetHeader.cjs.map +1 -0
  110. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.cjs +15 -0
  111. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.cjs.map +1 -0
  112. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.d.cts +7 -0
  113. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.d.cts.map +1 -0
  114. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.d.mts +7 -0
  115. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.d.mts.map +1 -0
  116. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.mjs +12 -0
  117. package/dist/components/BottomSheetHeader/BottomSheetHeader.constants.mjs.map +1 -0
  118. package/dist/components/BottomSheetHeader/BottomSheetHeader.d.cts +4 -0
  119. package/dist/components/BottomSheetHeader/BottomSheetHeader.d.cts.map +1 -0
  120. package/dist/components/BottomSheetHeader/BottomSheetHeader.d.mts +4 -0
  121. package/dist/components/BottomSheetHeader/BottomSheetHeader.d.mts.map +1 -0
  122. package/dist/components/BottomSheetHeader/BottomSheetHeader.mjs +27 -0
  123. package/dist/components/BottomSheetHeader/BottomSheetHeader.mjs.map +1 -0
  124. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.cjs +14 -0
  125. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.cjs.map +1 -0
  126. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.d.cts +50 -0
  127. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.d.cts.map +1 -0
  128. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.d.mts +50 -0
  129. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.d.mts.map +1 -0
  130. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.mjs +11 -0
  131. package/dist/components/BottomSheetHeader/BottomSheetHeader.types.mjs.map +1 -0
  132. package/dist/components/BottomSheetHeader/index.cjs +8 -0
  133. package/dist/components/BottomSheetHeader/index.cjs.map +1 -0
  134. package/dist/components/BottomSheetHeader/index.d.cts +4 -0
  135. package/dist/components/BottomSheetHeader/index.d.cts.map +1 -0
  136. package/dist/components/BottomSheetHeader/index.d.mts +4 -0
  137. package/dist/components/BottomSheetHeader/index.d.mts.map +1 -0
  138. package/dist/components/BottomSheetHeader/index.mjs +3 -0
  139. package/dist/components/BottomSheetHeader/index.mjs.map +1 -0
  140. package/dist/components/ButtonHero/ButtonHero.cjs +37 -0
  141. package/dist/components/ButtonHero/ButtonHero.cjs.map +1 -0
  142. package/dist/components/ButtonHero/ButtonHero.d.cts +13 -0
  143. package/dist/components/ButtonHero/ButtonHero.d.cts.map +1 -0
  144. package/dist/components/ButtonHero/ButtonHero.d.mts +13 -0
  145. package/dist/components/ButtonHero/ButtonHero.d.mts.map +1 -0
  146. package/dist/components/ButtonHero/ButtonHero.mjs +37 -0
  147. package/dist/components/ButtonHero/ButtonHero.mjs.map +1 -0
  148. package/dist/components/ButtonHero/ButtonHero.types.cjs +3 -0
  149. package/dist/components/ButtonHero/ButtonHero.types.cjs.map +1 -0
  150. package/dist/components/ButtonHero/ButtonHero.types.d.cts +3 -0
  151. package/dist/components/ButtonHero/ButtonHero.types.d.cts.map +1 -0
  152. package/dist/components/ButtonHero/ButtonHero.types.d.mts +3 -0
  153. package/dist/components/ButtonHero/ButtonHero.types.d.mts.map +1 -0
  154. package/dist/components/ButtonHero/ButtonHero.types.mjs +2 -0
  155. package/dist/components/ButtonHero/ButtonHero.types.mjs.map +1 -0
  156. package/dist/components/ButtonHero/index.cjs +8 -0
  157. package/dist/components/ButtonHero/index.cjs.map +1 -0
  158. package/dist/components/ButtonHero/index.d.cts +4 -0
  159. package/dist/components/ButtonHero/index.d.cts.map +1 -0
  160. package/dist/components/ButtonHero/index.d.mts +4 -0
  161. package/dist/components/ButtonHero/index.d.mts.map +1 -0
  162. package/dist/components/ButtonHero/index.mjs +3 -0
  163. package/dist/components/ButtonHero/index.mjs.map +1 -0
  164. package/dist/components/ButtonSemantic/ButtonSemantic.cjs +64 -0
  165. package/dist/components/ButtonSemantic/ButtonSemantic.cjs.map +1 -0
  166. package/dist/components/ButtonSemantic/ButtonSemantic.constants.cjs +17 -0
  167. package/dist/components/ButtonSemantic/ButtonSemantic.constants.cjs.map +1 -0
  168. package/dist/components/ButtonSemantic/ButtonSemantic.constants.d.cts +5 -0
  169. package/dist/components/ButtonSemantic/ButtonSemantic.constants.d.cts.map +1 -0
  170. package/dist/components/ButtonSemantic/ButtonSemantic.constants.d.mts +5 -0
  171. package/dist/components/ButtonSemantic/ButtonSemantic.constants.d.mts.map +1 -0
  172. package/dist/components/ButtonSemantic/ButtonSemantic.constants.mjs +14 -0
  173. package/dist/components/ButtonSemantic/ButtonSemantic.constants.mjs.map +1 -0
  174. package/dist/components/ButtonSemantic/ButtonSemantic.d.cts +4 -0
  175. package/dist/components/ButtonSemantic/ButtonSemantic.d.cts.map +1 -0
  176. package/dist/components/ButtonSemantic/ButtonSemantic.d.mts +4 -0
  177. package/dist/components/ButtonSemantic/ButtonSemantic.d.mts.map +1 -0
  178. package/dist/components/ButtonSemantic/ButtonSemantic.mjs +44 -0
  179. package/dist/components/ButtonSemantic/ButtonSemantic.mjs.map +1 -0
  180. package/dist/components/ButtonSemantic/ButtonSemantic.types.cjs +18 -0
  181. package/dist/components/ButtonSemantic/ButtonSemantic.types.cjs.map +1 -0
  182. package/dist/components/ButtonSemantic/ButtonSemantic.types.d.cts +30 -0
  183. package/dist/components/ButtonSemantic/ButtonSemantic.types.d.cts.map +1 -0
  184. package/dist/components/ButtonSemantic/ButtonSemantic.types.d.mts +30 -0
  185. package/dist/components/ButtonSemantic/ButtonSemantic.types.d.mts.map +1 -0
  186. package/dist/components/ButtonSemantic/ButtonSemantic.types.mjs +15 -0
  187. package/dist/components/ButtonSemantic/ButtonSemantic.types.mjs.map +1 -0
  188. package/dist/components/ButtonSemantic/index.cjs +8 -0
  189. package/dist/components/ButtonSemantic/index.cjs.map +1 -0
  190. package/dist/components/ButtonSemantic/index.d.cts +4 -0
  191. package/dist/components/ButtonSemantic/index.d.cts.map +1 -0
  192. package/dist/components/ButtonSemantic/index.d.mts +4 -0
  193. package/dist/components/ButtonSemantic/index.d.mts.map +1 -0
  194. package/dist/components/ButtonSemantic/index.mjs +3 -0
  195. package/dist/components/ButtonSemantic/index.mjs.map +1 -0
  196. package/dist/components/Card/Card.cjs +26 -0
  197. package/dist/components/Card/Card.cjs.map +1 -0
  198. package/dist/components/Card/Card.d.cts +4 -0
  199. package/dist/components/Card/Card.d.cts.map +1 -0
  200. package/dist/components/Card/Card.d.mts +4 -0
  201. package/dist/components/Card/Card.d.mts.map +1 -0
  202. package/dist/components/Card/Card.mjs +26 -0
  203. package/dist/components/Card/Card.mjs.map +1 -0
  204. package/dist/components/Card/Card.types.cjs +3 -0
  205. package/dist/components/Card/Card.types.cjs.map +1 -0
  206. package/dist/components/Card/Card.types.d.cts +25 -0
  207. package/dist/components/Card/Card.types.d.cts.map +1 -0
  208. package/dist/components/Card/Card.types.d.mts +25 -0
  209. package/dist/components/Card/Card.types.d.mts.map +1 -0
  210. package/dist/components/Card/Card.types.mjs +2 -0
  211. package/dist/components/Card/Card.types.mjs.map +1 -0
  212. package/dist/components/Card/index.cjs +6 -0
  213. package/dist/components/Card/index.cjs.map +1 -0
  214. package/dist/components/Card/index.d.cts +3 -0
  215. package/dist/components/Card/index.d.cts.map +1 -0
  216. package/dist/components/Card/index.d.mts +3 -0
  217. package/dist/components/Card/index.d.mts.map +1 -0
  218. package/dist/components/Card/index.mjs +2 -0
  219. package/dist/components/Card/index.mjs.map +1 -0
  220. package/dist/components/HeaderBase/HeaderBase.cjs +132 -0
  221. package/dist/components/HeaderBase/HeaderBase.cjs.map +1 -0
  222. package/dist/components/HeaderBase/HeaderBase.constants.cjs +15 -0
  223. package/dist/components/HeaderBase/HeaderBase.constants.cjs.map +1 -0
  224. package/dist/components/HeaderBase/HeaderBase.constants.d.cts +7 -0
  225. package/dist/components/HeaderBase/HeaderBase.constants.d.cts.map +1 -0
  226. package/dist/components/HeaderBase/HeaderBase.constants.d.mts +7 -0
  227. package/dist/components/HeaderBase/HeaderBase.constants.d.mts.map +1 -0
  228. package/dist/components/HeaderBase/HeaderBase.constants.mjs +12 -0
  229. package/dist/components/HeaderBase/HeaderBase.constants.mjs.map +1 -0
  230. package/dist/components/HeaderBase/HeaderBase.d.cts +4 -0
  231. package/dist/components/HeaderBase/HeaderBase.d.cts.map +1 -0
  232. package/dist/components/HeaderBase/HeaderBase.d.mts +4 -0
  233. package/dist/components/HeaderBase/HeaderBase.d.mts.map +1 -0
  234. package/dist/components/HeaderBase/HeaderBase.mjs +112 -0
  235. package/dist/components/HeaderBase/HeaderBase.mjs.map +1 -0
  236. package/dist/components/HeaderBase/HeaderBase.types.cjs +15 -0
  237. package/dist/components/HeaderBase/HeaderBase.types.cjs.map +1 -0
  238. package/dist/components/HeaderBase/HeaderBase.types.d.cts +87 -0
  239. package/dist/components/HeaderBase/HeaderBase.types.d.cts.map +1 -0
  240. package/dist/components/HeaderBase/HeaderBase.types.d.mts +87 -0
  241. package/dist/components/HeaderBase/HeaderBase.types.d.mts.map +1 -0
  242. package/dist/components/HeaderBase/HeaderBase.types.mjs +12 -0
  243. package/dist/components/HeaderBase/HeaderBase.types.mjs.map +1 -0
  244. package/dist/components/HeaderBase/index.cjs +8 -0
  245. package/dist/components/HeaderBase/index.cjs.map +1 -0
  246. package/dist/components/HeaderBase/index.d.cts +4 -0
  247. package/dist/components/HeaderBase/index.d.cts.map +1 -0
  248. package/dist/components/HeaderBase/index.d.mts +4 -0
  249. package/dist/components/HeaderBase/index.d.mts.map +1 -0
  250. package/dist/components/HeaderBase/index.mjs +3 -0
  251. package/dist/components/HeaderBase/index.mjs.map +1 -0
  252. package/dist/components/Icon/Icon.assets.cjs +2 -0
  253. package/dist/components/Icon/Icon.assets.cjs.map +1 -1
  254. package/dist/components/Icon/Icon.assets.d.cts.map +1 -1
  255. package/dist/components/Icon/Icon.assets.d.mts.map +1 -1
  256. package/dist/components/Icon/Icon.assets.mjs +2 -0
  257. package/dist/components/Icon/Icon.assets.mjs.map +1 -1
  258. package/dist/components/Icon/assets/corporate-fare.svg +1 -0
  259. package/dist/components/Input/Input.cjs +53 -0
  260. package/dist/components/Input/Input.cjs.map +1 -0
  261. package/dist/components/Input/Input.d.cts +10 -0
  262. package/dist/components/Input/Input.d.cts.map +1 -0
  263. package/dist/components/Input/Input.d.mts +10 -0
  264. package/dist/components/Input/Input.d.mts.map +1 -0
  265. package/dist/components/Input/Input.mjs +50 -0
  266. package/dist/components/Input/Input.mjs.map +1 -0
  267. package/dist/components/Input/Input.types.cjs +3 -0
  268. package/dist/components/Input/Input.types.cjs.map +1 -0
  269. package/dist/components/Input/Input.types.d.cts +33 -0
  270. package/dist/components/Input/Input.types.d.cts.map +1 -0
  271. package/dist/components/Input/Input.types.d.mts +33 -0
  272. package/dist/components/Input/Input.types.d.mts.map +1 -0
  273. package/dist/components/Input/Input.types.mjs +2 -0
  274. package/dist/components/Input/Input.types.mjs.map +1 -0
  275. package/dist/components/Input/index.cjs +6 -0
  276. package/dist/components/Input/index.cjs.map +1 -0
  277. package/dist/components/Input/index.d.cts +3 -0
  278. package/dist/components/Input/index.d.cts.map +1 -0
  279. package/dist/components/Input/index.d.mts +3 -0
  280. package/dist/components/Input/index.d.mts.map +1 -0
  281. package/dist/components/Input/index.mjs +2 -0
  282. package/dist/components/Input/index.mjs.map +1 -0
  283. package/dist/components/Label/Label.cjs +11 -0
  284. package/dist/components/Label/Label.cjs.map +1 -0
  285. package/dist/components/Label/Label.d.cts +4 -0
  286. package/dist/components/Label/Label.d.cts.map +1 -0
  287. package/dist/components/Label/Label.d.mts +4 -0
  288. package/dist/components/Label/Label.d.mts.map +1 -0
  289. package/dist/components/Label/Label.mjs +11 -0
  290. package/dist/components/Label/Label.mjs.map +1 -0
  291. package/dist/components/Label/Label.types.cjs +3 -0
  292. package/dist/components/Label/Label.types.cjs.map +1 -0
  293. package/dist/components/Label/Label.types.d.cts +9 -0
  294. package/dist/components/Label/Label.types.d.cts.map +1 -0
  295. package/dist/components/Label/Label.types.d.mts +9 -0
  296. package/dist/components/Label/Label.types.d.mts.map +1 -0
  297. package/dist/components/Label/Label.types.mjs +2 -0
  298. package/dist/components/Label/Label.types.mjs.map +1 -0
  299. package/dist/components/Label/index.cjs +6 -0
  300. package/dist/components/Label/index.cjs.map +1 -0
  301. package/dist/components/Label/index.d.cts +3 -0
  302. package/dist/components/Label/index.d.cts.map +1 -0
  303. package/dist/components/Label/index.d.mts +3 -0
  304. package/dist/components/Label/index.d.mts.map +1 -0
  305. package/dist/components/Label/index.mjs +2 -0
  306. package/dist/components/Label/index.mjs.map +1 -0
  307. package/dist/components/RadioButton/RadioButton.cjs +58 -0
  308. package/dist/components/RadioButton/RadioButton.cjs.map +1 -0
  309. package/dist/components/RadioButton/RadioButton.constants.cjs +12 -0
  310. package/dist/components/RadioButton/RadioButton.constants.cjs.map +1 -0
  311. package/dist/components/RadioButton/RadioButton.constants.d.cts +3 -0
  312. package/dist/components/RadioButton/RadioButton.constants.d.cts.map +1 -0
  313. package/dist/components/RadioButton/RadioButton.constants.d.mts +3 -0
  314. package/dist/components/RadioButton/RadioButton.constants.d.mts.map +1 -0
  315. package/dist/components/RadioButton/RadioButton.constants.mjs +9 -0
  316. package/dist/components/RadioButton/RadioButton.constants.mjs.map +1 -0
  317. package/dist/components/RadioButton/RadioButton.d.cts +4 -0
  318. package/dist/components/RadioButton/RadioButton.d.cts.map +1 -0
  319. package/dist/components/RadioButton/RadioButton.d.mts +4 -0
  320. package/dist/components/RadioButton/RadioButton.d.mts.map +1 -0
  321. package/dist/components/RadioButton/RadioButton.mjs +58 -0
  322. package/dist/components/RadioButton/RadioButton.mjs.map +1 -0
  323. package/dist/components/RadioButton/RadioButton.types.cjs +3 -0
  324. package/dist/components/RadioButton/RadioButton.types.cjs.map +1 -0
  325. package/dist/components/RadioButton/RadioButton.types.d.cts +64 -0
  326. package/dist/components/RadioButton/RadioButton.types.d.cts.map +1 -0
  327. package/dist/components/RadioButton/RadioButton.types.d.mts +64 -0
  328. package/dist/components/RadioButton/RadioButton.types.d.mts.map +1 -0
  329. package/dist/components/RadioButton/RadioButton.types.mjs +2 -0
  330. package/dist/components/RadioButton/RadioButton.types.mjs.map +1 -0
  331. package/dist/components/RadioButton/index.cjs +6 -0
  332. package/dist/components/RadioButton/index.cjs.map +1 -0
  333. package/dist/components/RadioButton/index.d.cts +3 -0
  334. package/dist/components/RadioButton/index.d.cts.map +1 -0
  335. package/dist/components/RadioButton/index.d.mts +3 -0
  336. package/dist/components/RadioButton/index.d.mts.map +1 -0
  337. package/dist/components/RadioButton/index.mjs +2 -0
  338. package/dist/components/RadioButton/index.mjs.map +1 -0
  339. package/dist/components/SensitiveText/SensitiveText.cjs +47 -0
  340. package/dist/components/SensitiveText/SensitiveText.cjs.map +1 -0
  341. package/dist/components/SensitiveText/SensitiveText.constants.cjs +14 -0
  342. package/dist/components/SensitiveText/SensitiveText.constants.cjs.map +1 -0
  343. package/dist/components/SensitiveText/SensitiveText.constants.d.cts +11 -0
  344. package/dist/components/SensitiveText/SensitiveText.constants.d.cts.map +1 -0
  345. package/dist/components/SensitiveText/SensitiveText.constants.d.mts +11 -0
  346. package/dist/components/SensitiveText/SensitiveText.constants.d.mts.map +1 -0
  347. package/dist/components/SensitiveText/SensitiveText.constants.mjs +11 -0
  348. package/dist/components/SensitiveText/SensitiveText.constants.mjs.map +1 -0
  349. package/dist/components/SensitiveText/SensitiveText.d.cts +4 -0
  350. package/dist/components/SensitiveText/SensitiveText.d.cts.map +1 -0
  351. package/dist/components/SensitiveText/SensitiveText.d.mts +4 -0
  352. package/dist/components/SensitiveText/SensitiveText.d.mts.map +1 -0
  353. package/dist/components/SensitiveText/SensitiveText.mjs +27 -0
  354. package/dist/components/SensitiveText/SensitiveText.mjs.map +1 -0
  355. package/dist/components/SensitiveText/SensitiveText.types.cjs +3 -0
  356. package/dist/components/SensitiveText/SensitiveText.types.cjs.map +1 -0
  357. package/dist/components/SensitiveText/SensitiveText.types.d.cts +38 -0
  358. package/dist/components/SensitiveText/SensitiveText.types.d.cts.map +1 -0
  359. package/dist/components/SensitiveText/SensitiveText.types.d.mts +38 -0
  360. package/dist/components/SensitiveText/SensitiveText.types.d.mts.map +1 -0
  361. package/dist/components/SensitiveText/SensitiveText.types.mjs +2 -0
  362. package/dist/components/SensitiveText/SensitiveText.types.mjs.map +1 -0
  363. package/dist/components/SensitiveText/index.cjs +8 -0
  364. package/dist/components/SensitiveText/index.cjs.map +1 -0
  365. package/dist/components/SensitiveText/index.d.cts +4 -0
  366. package/dist/components/SensitiveText/index.d.cts.map +1 -0
  367. package/dist/components/SensitiveText/index.d.mts +4 -0
  368. package/dist/components/SensitiveText/index.d.mts.map +1 -0
  369. package/dist/components/SensitiveText/index.mjs +3 -0
  370. package/dist/components/SensitiveText/index.mjs.map +1 -0
  371. package/dist/components/Skeleton/Skeleton.cjs +86 -0
  372. package/dist/components/Skeleton/Skeleton.cjs.map +1 -0
  373. package/dist/components/Skeleton/Skeleton.d.cts +5 -0
  374. package/dist/components/Skeleton/Skeleton.d.cts.map +1 -0
  375. package/dist/components/Skeleton/Skeleton.d.mts +5 -0
  376. package/dist/components/Skeleton/Skeleton.d.mts.map +1 -0
  377. package/dist/components/Skeleton/Skeleton.mjs +68 -0
  378. package/dist/components/Skeleton/Skeleton.mjs.map +1 -0
  379. package/dist/components/Skeleton/Skeleton.types.cjs +3 -0
  380. package/dist/components/Skeleton/Skeleton.types.cjs.map +1 -0
  381. package/dist/components/Skeleton/Skeleton.types.d.cts +51 -0
  382. package/dist/components/Skeleton/Skeleton.types.d.cts.map +1 -0
  383. package/dist/components/Skeleton/Skeleton.types.d.mts +51 -0
  384. package/dist/components/Skeleton/Skeleton.types.d.mts.map +1 -0
  385. package/dist/components/Skeleton/Skeleton.types.mjs +2 -0
  386. package/dist/components/Skeleton/Skeleton.types.mjs.map +1 -0
  387. package/dist/components/Skeleton/index.cjs +9 -0
  388. package/dist/components/Skeleton/index.cjs.map +1 -0
  389. package/dist/components/Skeleton/index.d.cts +3 -0
  390. package/dist/components/Skeleton/index.d.cts.map +1 -0
  391. package/dist/components/Skeleton/index.d.mts +3 -0
  392. package/dist/components/Skeleton/index.d.mts.map +1 -0
  393. package/dist/components/Skeleton/index.mjs +2 -0
  394. package/dist/components/Skeleton/index.mjs.map +1 -0
  395. package/dist/components/TextField/TextField.cjs +42 -0
  396. package/dist/components/TextField/TextField.cjs.map +1 -0
  397. package/dist/components/TextField/TextField.constants.cjs +13 -0
  398. package/dist/components/TextField/TextField.constants.cjs.map +1 -0
  399. package/dist/components/TextField/TextField.constants.d.cts +6 -0
  400. package/dist/components/TextField/TextField.constants.d.cts.map +1 -0
  401. package/dist/components/TextField/TextField.constants.d.mts +6 -0
  402. package/dist/components/TextField/TextField.constants.d.mts.map +1 -0
  403. package/dist/components/TextField/TextField.constants.mjs +10 -0
  404. package/dist/components/TextField/TextField.constants.mjs.map +1 -0
  405. package/dist/components/TextField/TextField.d.cts +12 -0
  406. package/dist/components/TextField/TextField.d.cts.map +1 -0
  407. package/dist/components/TextField/TextField.d.mts +12 -0
  408. package/dist/components/TextField/TextField.d.mts.map +1 -0
  409. package/dist/components/TextField/TextField.mjs +39 -0
  410. package/dist/components/TextField/TextField.mjs.map +1 -0
  411. package/dist/components/TextField/TextField.types.cjs +13 -0
  412. package/dist/components/TextField/TextField.types.cjs.map +1 -0
  413. package/dist/components/TextField/TextField.types.d.cts +49 -0
  414. package/dist/components/TextField/TextField.types.d.cts.map +1 -0
  415. package/dist/components/TextField/TextField.types.d.mts +49 -0
  416. package/dist/components/TextField/TextField.types.d.mts.map +1 -0
  417. package/dist/components/TextField/TextField.types.mjs +10 -0
  418. package/dist/components/TextField/TextField.types.mjs.map +1 -0
  419. package/dist/components/TextField/index.cjs +8 -0
  420. package/dist/components/TextField/index.cjs.map +1 -0
  421. package/dist/components/TextField/index.d.cts +4 -0
  422. package/dist/components/TextField/index.d.cts.map +1 -0
  423. package/dist/components/TextField/index.d.mts +4 -0
  424. package/dist/components/TextField/index.d.mts.map +1 -0
  425. package/dist/components/TextField/index.mjs +3 -0
  426. package/dist/components/TextField/index.mjs.map +1 -0
  427. package/dist/components/Toast/Toast.cjs +174 -0
  428. package/dist/components/Toast/Toast.cjs.map +1 -0
  429. package/dist/components/Toast/Toast.constants.cjs +12 -0
  430. package/dist/components/Toast/Toast.constants.cjs.map +1 -0
  431. package/dist/components/Toast/Toast.constants.d.cts +8 -0
  432. package/dist/components/Toast/Toast.constants.d.cts.map +1 -0
  433. package/dist/components/Toast/Toast.constants.d.mts +8 -0
  434. package/dist/components/Toast/Toast.constants.d.mts.map +1 -0
  435. package/dist/components/Toast/Toast.constants.mjs +9 -0
  436. package/dist/components/Toast/Toast.constants.mjs.map +1 -0
  437. package/dist/components/Toast/Toast.context.cjs +40 -0
  438. package/dist/components/Toast/Toast.context.cjs.map +1 -0
  439. package/dist/components/Toast/Toast.context.d.cts +7 -0
  440. package/dist/components/Toast/Toast.context.d.cts.map +1 -0
  441. package/dist/components/Toast/Toast.context.d.mts +7 -0
  442. package/dist/components/Toast/Toast.context.d.mts.map +1 -0
  443. package/dist/components/Toast/Toast.context.mjs +20 -0
  444. package/dist/components/Toast/Toast.context.mjs.map +1 -0
  445. package/dist/components/Toast/Toast.d.cts +8 -0
  446. package/dist/components/Toast/Toast.d.cts.map +1 -0
  447. package/dist/components/Toast/Toast.d.mts +8 -0
  448. package/dist/components/Toast/Toast.d.mts.map +1 -0
  449. package/dist/components/Toast/Toast.mjs +156 -0
  450. package/dist/components/Toast/Toast.mjs.map +1 -0
  451. package/dist/components/Toast/Toast.types.cjs +19 -0
  452. package/dist/components/Toast/Toast.types.cjs.map +1 -0
  453. package/dist/components/Toast/Toast.types.d.cts +123 -0
  454. package/dist/components/Toast/Toast.types.d.cts.map +1 -0
  455. package/dist/components/Toast/Toast.types.d.mts +123 -0
  456. package/dist/components/Toast/Toast.types.d.mts.map +1 -0
  457. package/dist/components/Toast/Toast.types.mjs +16 -0
  458. package/dist/components/Toast/Toast.types.mjs.map +1 -0
  459. package/dist/components/Toast/index.cjs +19 -0
  460. package/dist/components/Toast/index.cjs.map +1 -0
  461. package/dist/components/Toast/index.d.cts +6 -0
  462. package/dist/components/Toast/index.d.cts.map +1 -0
  463. package/dist/components/Toast/index.d.mts +6 -0
  464. package/dist/components/Toast/index.d.mts.map +1 -0
  465. package/dist/components/Toast/index.mjs +5 -0
  466. package/dist/components/Toast/index.mjs.map +1 -0
  467. package/dist/components/index.cjs +38 -2
  468. package/dist/components/index.cjs.map +1 -1
  469. package/dist/components/index.d.cts +28 -0
  470. package/dist/components/index.d.cts.map +1 -1
  471. package/dist/components/index.d.mts +28 -0
  472. package/dist/components/index.d.mts.map +1 -1
  473. package/dist/components/index.mjs +14 -0
  474. package/dist/components/index.mjs.map +1 -1
  475. package/dist/types/index.cjs +3 -16
  476. package/dist/types/index.cjs.map +1 -1
  477. package/dist/types/index.d.cts +2 -13
  478. package/dist/types/index.d.cts.map +1 -1
  479. package/dist/types/index.d.mts +2 -13
  480. package/dist/types/index.d.mts.map +1 -1
  481. package/dist/types/index.mjs +2 -14
  482. package/dist/types/index.mjs.map +1 -1
  483. package/package.json +5 -5
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextField.types.mjs","sourceRoot":"","sources":["../../../src/components/TextField/TextField.types.ts"],"names":[],"mappings":"AAKA;;GAEG;AACH,MAAM,CAAN,IAAY,aAIX;AAJD,WAAY,aAAa;IACvB,0BAAS,CAAA;IACT,0BAAS,CAAA;IACT,0BAAS,CAAA;AACX,CAAC,EAJW,aAAa,KAAb,aAAa,QAIxB","sourcesContent":["import type { ReactNode } from 'react';\nimport type { StyleProp, ViewStyle } from 'react-native';\n\nimport type { InputProps } from '../Input/Input.types';\n\n/**\n * TextFieldSize enum.\n */\nexport enum TextFieldSize {\n Sm = 'sm',\n Md = 'md',\n Lg = 'lg',\n}\n\n/**\n * TextField component props.\n */\nexport type TextFieldProps = Omit<\n InputProps,\n 'textVariant' | 'isStateStylesDisabled' | 'style'\n> & {\n /**\n * Optional prop for size of the TextField.\n *\n * @default TextFieldSize.Md\n */\n size?: TextFieldSize;\n /**\n * Optional content to display before the Input.\n */\n startAccessory?: ReactNode;\n /**\n * Optional content to display after the Input.\n */\n endAccessory?: ReactNode;\n /**\n * Optional boolean to show the error state.\n *\n * @default false\n */\n isError?: boolean;\n /**\n * Optional prop to replace the default Input with a custom element.\n */\n inputElement?: ReactNode;\n /**\n * Optional prop to add twrnc overriding classNames.\n */\n twClassName?: string;\n /**\n * Optional prop to customize the container style.\n */\n style?: StyleProp<ViewStyle>;\n};\n"]}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TextFieldSize = exports.TextField = void 0;
4
+ var TextField_1 = require("./TextField.cjs");
5
+ Object.defineProperty(exports, "TextField", { enumerable: true, get: function () { return TextField_1.TextField; } });
6
+ var TextField_types_1 = require("./TextField.types.cjs");
7
+ Object.defineProperty(exports, "TextFieldSize", { enumerable: true, get: function () { return TextField_types_1.TextFieldSize; } });
8
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../../src/components/TextField/index.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AAA/B,sGAAA,SAAS,OAAA;AAClB,yDAAkD;AAAzC,gHAAA,aAAa,OAAA","sourcesContent":["export { TextField } from './TextField';\nexport { TextFieldSize } from './TextField.types';\nexport type { TextFieldProps } from './TextField.types';\n"]}
@@ -0,0 +1,4 @@
1
+ export { TextField } from "./TextField.cjs";
2
+ export { TextFieldSize } from "./TextField.types.cjs";
3
+ export type { TextFieldProps } from "./TextField.types.cjs";
4
+ //# sourceMappingURL=index.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.cts","sourceRoot":"","sources":["../../../src/components/TextField/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,wBAAoB;AACxC,OAAO,EAAE,aAAa,EAAE,8BAA0B;AAClD,YAAY,EAAE,cAAc,EAAE,8BAA0B"}
@@ -0,0 +1,4 @@
1
+ export { TextField } from "./TextField.mjs";
2
+ export { TextFieldSize } from "./TextField.types.mjs";
3
+ export type { TextFieldProps } from "./TextField.types.mjs";
4
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../../src/components/TextField/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,wBAAoB;AACxC,OAAO,EAAE,aAAa,EAAE,8BAA0B;AAClD,YAAY,EAAE,cAAc,EAAE,8BAA0B"}
@@ -0,0 +1,3 @@
1
+ export { TextField } from "./TextField.mjs";
2
+ export { TextFieldSize } from "./TextField.types.mjs";
3
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../../src/components/TextField/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,wBAAoB;AACxC,OAAO,EAAE,aAAa,EAAE,8BAA0B","sourcesContent":["export { TextField } from './TextField';\nexport { TextFieldSize } from './TextField.types';\nexport type { TextFieldProps } from './TextField.types';\n"]}
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ // Third party dependencies.
27
+ const design_system_twrnc_preset_1 = require("@metamask-previews/design-system-twrnc-preset");
28
+ const react_1 = __importStar(require("react"));
29
+ const react_native_1 = require("react-native/index.js");
30
+ // eslint-disable-next-line import-x/default
31
+ const react_native_reanimated_1 = __importStar(require("react-native-reanimated"));
32
+ const react_native_safe_area_context_1 = require("react-native-safe-area-context");
33
+ // External dependencies.
34
+ const AvatarAccount_1 = require("../AvatarAccount/index.cjs");
35
+ const AvatarFavicon_1 = require("../AvatarFavicon/index.cjs");
36
+ const AvatarIcon_1 = require("../AvatarIcon/index.cjs");
37
+ const AvatarNetwork_1 = require("../AvatarNetwork/index.cjs");
38
+ const Button_1 = require("../Button/index.cjs");
39
+ const ButtonIcon_1 = require("../ButtonIcon/index.cjs");
40
+ const Text_1 = require("../Text/index.cjs");
41
+ // Internal dependencies.
42
+ const Toast_constants_1 = require("./Toast.constants.cjs");
43
+ const Toast_types_1 = require("./Toast.types.cjs");
44
+ const screenHeight = react_native_1.Dimensions.get('window').height;
45
+ const Toast = (0, react_1.forwardRef)(({ twClassName, labelsContainerProps, ...props }, ref) => {
46
+ const tw = (0, design_system_twrnc_preset_1.useTailwind)();
47
+ const [toastOptions, setToastOptions] = (0, react_1.useState)(undefined);
48
+ const replacementTimerRef = (0, react_1.useRef)(null);
49
+ const { bottom: bottomNotchSpacing } = (0, react_native_safe_area_context_1.useSafeAreaInsets)();
50
+ const translateYProgress = (0, react_native_reanimated_1.useSharedValue)(screenHeight);
51
+ const bottomOffset = toastOptions?.bottomOffset ?? 0;
52
+ const animatedStyle = (0, react_native_reanimated_1.useAnimatedStyle)(() => ({
53
+ transform: [{ translateY: translateYProgress.value - bottomOffset }],
54
+ }));
55
+ const baseStyle = (0, react_1.useMemo)(() => [
56
+ tw.style('absolute left-4 right-4 bottom-0 bg-background-section border border-border-muted rounded-xl p-3 flex-row items-center', twClassName),
57
+ animatedStyle,
58
+ ], [tw, animatedStyle, twClassName]);
59
+ const resetState = () => setToastOptions(undefined);
60
+ const showToast = (options) => {
61
+ let timeoutDuration = 0;
62
+ if (toastOptions) {
63
+ (0, react_native_reanimated_1.cancelAnimation)(translateYProgress);
64
+ timeoutDuration = 100;
65
+ // Clear existing toast state to prevent animation conflicts when showing rapid successive toasts
66
+ setToastOptions(undefined);
67
+ }
68
+ if (replacementTimerRef.current !== null) {
69
+ clearTimeout(replacementTimerRef.current);
70
+ }
71
+ replacementTimerRef.current = setTimeout(() => {
72
+ replacementTimerRef.current = null;
73
+ setToastOptions(options);
74
+ }, timeoutDuration);
75
+ };
76
+ const closeToast = () => {
77
+ if (replacementTimerRef.current !== null) {
78
+ clearTimeout(replacementTimerRef.current);
79
+ replacementTimerRef.current = null;
80
+ }
81
+ translateYProgress.value = (0, react_native_reanimated_1.withTiming)(screenHeight, { duration: Toast_constants_1.TOAST_ANIMATION_DURATION }, () => {
82
+ (0, react_native_reanimated_1.runOnJS)(resetState)();
83
+ });
84
+ };
85
+ (0, react_1.useImperativeHandle)(ref, () => ({
86
+ showToast,
87
+ closeToast,
88
+ }));
89
+ const onAnimatedViewLayout = (e) => {
90
+ /* istanbul ignore next - guard only; layout fires when toastOptions is set */
91
+ if (toastOptions) {
92
+ const { height } = e.nativeEvent.layout;
93
+ const translateYToValue = -(Toast_constants_1.TOAST_BOTTOM_PADDING + bottomNotchSpacing);
94
+ translateYProgress.value = height;
95
+ if (toastOptions.hasNoTimeout) {
96
+ translateYProgress.value = (0, react_native_reanimated_1.withTiming)(translateYToValue, {
97
+ duration: Toast_constants_1.TOAST_ANIMATION_DURATION,
98
+ });
99
+ }
100
+ else {
101
+ translateYProgress.value = (0, react_native_reanimated_1.withTiming)(translateYToValue, { duration: Toast_constants_1.TOAST_ANIMATION_DURATION }, () => {
102
+ translateYProgress.value = (0, react_native_reanimated_1.withDelay)(Toast_constants_1.TOAST_VISIBILITY_DURATION, (0, react_native_reanimated_1.withTiming)(height, { duration: Toast_constants_1.TOAST_ANIMATION_DURATION }, (0, react_native_reanimated_1.runOnJS)(resetState)));
103
+ });
104
+ }
105
+ }
106
+ };
107
+ const renderLabel = (labelOptions) => (<Text_1.Text variant={Text_1.TextVariant.BodyMd}>
108
+ {labelOptions.map(({ label, isBold }, index) => (<Text_1.Text key={`toast-label-${index}`} variant={Text_1.TextVariant.BodyMd} fontWeight={isBold ? Text_1.FontWeight.Bold : undefined} color={Text_1.TextColor.TextDefault}>
109
+ {label}
110
+ </Text_1.Text>))}
111
+ </Text_1.Text>);
112
+ const renderDescription = (descriptionOptions) => descriptionOptions && (<Text_1.Text variant={Text_1.TextVariant.BodySm} color={Text_1.TextColor.TextAlternative} style={tw.style('mt-1')}>
113
+ {descriptionOptions.description}
114
+ </Text_1.Text>);
115
+ const renderActionButton = (linkButtonOptions) => linkButtonOptions && (<Button_1.Button variant={Button_1.ButtonVariant.Secondary} onPress={linkButtonOptions.onPress} style={tw.style('mt-2')}>
116
+ {linkButtonOptions.label}
117
+ </Button_1.Button>);
118
+ const renderCloseButton = (closeButtonOptions) => {
119
+ if (closeButtonOptions?.variant === Toast_types_1.ButtonIconVariant.Icon) {
120
+ return (<ButtonIcon_1.ButtonIcon onPress={(e) => closeButtonOptions?.onPress?.(e)} iconName={closeButtonOptions?.iconName}/>);
121
+ }
122
+ return (<Button_1.Button variant={Button_1.ButtonVariant.Primary} onPress={(e) => closeButtonOptions?.onPress?.(e)} startIconName={closeButtonOptions?.startIconName} endIconName={closeButtonOptions?.endIconName} style={closeButtonOptions?.style}>
123
+ {closeButtonOptions?.children}
124
+ </Button_1.Button>);
125
+ };
126
+ const renderAvatar = () => {
127
+ switch (toastOptions?.variant) {
128
+ case Toast_types_1.ToastVariant.Plain:
129
+ return null;
130
+ case Toast_types_1.ToastVariant.Account: {
131
+ const { accountAddress, accountAvatarType } = toastOptions;
132
+ return (<AvatarAccount_1.AvatarAccount address={accountAddress} variant={accountAvatarType} size={AvatarAccount_1.AvatarAccountSize.Md} style={tw.style('mr-4')}/>);
133
+ }
134
+ case Toast_types_1.ToastVariant.Network: {
135
+ const { networkImageSource, networkName } = toastOptions;
136
+ return (<AvatarNetwork_1.AvatarNetwork name={networkName} src={networkImageSource} size={AvatarNetwork_1.AvatarNetworkSize.Md} style={tw.style('mr-4')}/>);
137
+ }
138
+ case Toast_types_1.ToastVariant.App: {
139
+ const { appIconSource } = toastOptions;
140
+ return (<AvatarFavicon_1.AvatarFavicon src={appIconSource} size={AvatarFavicon_1.AvatarFaviconSize.Md} style={tw.style('mr-4')}/>);
141
+ }
142
+ case Toast_types_1.ToastVariant.Icon: {
143
+ const { iconName, severity } = toastOptions;
144
+ return (<AvatarIcon_1.AvatarIcon iconName={iconName} severity={severity} size={AvatarIcon_1.AvatarIconSize.Md} style={tw.style('mr-4')}/>);
145
+ }
146
+ /* istanbul ignore next - all variants handled above */
147
+ default:
148
+ return null;
149
+ }
150
+ };
151
+ const renderToastContent = (options) => {
152
+ const { labelOptions, descriptionOptions, linkButtonOptions, closeButtonOptions, startAccessory, } = options;
153
+ const isStartAccessoryValid = startAccessory !== null &&
154
+ startAccessory !== undefined &&
155
+ (0, react_1.isValidElement)(startAccessory);
156
+ return (<>
157
+ {isStartAccessoryValid ? startAccessory : renderAvatar()}
158
+ <react_native_1.View style={tw.style('flex-1 justify-center')} {...labelsContainerProps}>
159
+ {renderLabel(labelOptions)}
160
+ {renderDescription(descriptionOptions)}
161
+ {renderActionButton(linkButtonOptions)}
162
+ </react_native_1.View>
163
+ {closeButtonOptions ? renderCloseButton(closeButtonOptions) : null}
164
+ </>);
165
+ };
166
+ if (!toastOptions) {
167
+ return null;
168
+ }
169
+ return (<react_native_reanimated_1.default.View onLayout={onAnimatedViewLayout} style={baseStyle} {...props}>
170
+ {renderToastContent(toastOptions)}
171
+ </react_native_reanimated_1.default.View>);
172
+ });
173
+ exports.default = Toast;
174
+ //# sourceMappingURL=Toast.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.cjs","sourceRoot":"","sources":["../../../src/components/Toast/Toast.tsx"],"names":[],"mappings":"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","sourcesContent":["// Third party dependencies.\nimport { useTailwind } from '@metamask-previews/design-system-twrnc-preset';\nimport React, {\n forwardRef,\n isValidElement,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { Dimensions, View } from 'react-native';\nimport type { LayoutChangeEvent, StyleProp, ViewStyle } from 'react-native';\n// eslint-disable-next-line import-x/default\nimport Animated, {\n cancelAnimation,\n runOnJS,\n useAnimatedStyle,\n useSharedValue,\n withDelay,\n withTiming,\n} from 'react-native-reanimated';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\n\n// External dependencies.\nimport { AvatarAccount, AvatarAccountSize } from '../AvatarAccount';\nimport { AvatarFavicon, AvatarFaviconSize } from '../AvatarFavicon';\nimport { AvatarIcon, AvatarIconSize } from '../AvatarIcon';\nimport { AvatarNetwork, AvatarNetworkSize } from '../AvatarNetwork';\nimport { Button, ButtonVariant } from '../Button';\nimport { ButtonIcon } from '../ButtonIcon';\nimport { Text, TextVariant, TextColor, FontWeight } from '../Text';\n\n// Internal dependencies.\nimport {\n TOAST_VISIBILITY_DURATION,\n TOAST_ANIMATION_DURATION,\n TOAST_BOTTOM_PADDING,\n} from './Toast.constants';\nimport type {\n ToastCloseButtonOptions,\n ToastDescriptionOptions,\n ToastLabelOptions,\n ToastLinkButtonOptions,\n ToastOptions,\n ToastProps,\n ToastRef,\n} from './Toast.types';\nimport { ButtonIconVariant, ToastVariant } from './Toast.types';\n\nconst screenHeight = Dimensions.get('window').height;\n\nconst Toast = forwardRef<ToastRef, ToastProps>(\n ({ twClassName, labelsContainerProps, ...props }, ref) => {\n const tw = useTailwind();\n const [toastOptions, setToastOptions] = useState<ToastOptions | undefined>(\n undefined,\n );\n const replacementTimerRef = useRef<ReturnType<typeof setTimeout> | null>(\n null,\n );\n const { bottom: bottomNotchSpacing } = useSafeAreaInsets();\n const translateYProgress = useSharedValue(screenHeight);\n const bottomOffset = toastOptions?.bottomOffset ?? 0;\n const animatedStyle = useAnimatedStyle(() => ({\n transform: [{ translateY: translateYProgress.value - bottomOffset }],\n }));\n const baseStyle: StyleProp<ViewStyle> = useMemo(\n () => [\n tw.style(\n 'absolute left-4 right-4 bottom-0 bg-background-section border border-border-muted rounded-xl p-3 flex-row items-center',\n twClassName,\n ),\n animatedStyle,\n ],\n [tw, animatedStyle, twClassName],\n );\n\n const resetState = () => setToastOptions(undefined);\n\n const showToast = (options: ToastOptions) => {\n let timeoutDuration = 0;\n if (toastOptions) {\n cancelAnimation(translateYProgress);\n timeoutDuration = 100;\n // Clear existing toast state to prevent animation conflicts when showing rapid successive toasts\n setToastOptions(undefined);\n }\n if (replacementTimerRef.current !== null) {\n clearTimeout(replacementTimerRef.current);\n }\n replacementTimerRef.current = setTimeout(() => {\n replacementTimerRef.current = null;\n setToastOptions(options);\n }, timeoutDuration);\n };\n\n const closeToast = () => {\n if (replacementTimerRef.current !== null) {\n clearTimeout(replacementTimerRef.current);\n replacementTimerRef.current = null;\n }\n translateYProgress.value = withTiming(\n screenHeight,\n { duration: TOAST_ANIMATION_DURATION },\n () => {\n runOnJS(resetState)();\n },\n );\n };\n\n useImperativeHandle(ref, () => ({\n showToast,\n closeToast,\n }));\n\n const onAnimatedViewLayout = (e: LayoutChangeEvent) => {\n /* istanbul ignore next - guard only; layout fires when toastOptions is set */\n if (toastOptions) {\n const { height } = e.nativeEvent.layout;\n const translateYToValue = -(TOAST_BOTTOM_PADDING + bottomNotchSpacing);\n\n translateYProgress.value = height;\n\n if (toastOptions.hasNoTimeout) {\n translateYProgress.value = withTiming(translateYToValue, {\n duration: TOAST_ANIMATION_DURATION,\n });\n } else {\n translateYProgress.value = withTiming(\n translateYToValue,\n { duration: TOAST_ANIMATION_DURATION },\n () => {\n translateYProgress.value = withDelay(\n TOAST_VISIBILITY_DURATION,\n withTiming(\n height,\n { duration: TOAST_ANIMATION_DURATION },\n runOnJS(resetState),\n ),\n );\n },\n );\n }\n }\n };\n\n const renderLabel = (labelOptions: ToastLabelOptions) => (\n <Text variant={TextVariant.BodyMd}>\n {labelOptions.map(({ label, isBold }, index) => (\n <Text\n key={`toast-label-${index}`}\n variant={TextVariant.BodyMd}\n fontWeight={isBold ? FontWeight.Bold : undefined}\n color={TextColor.TextDefault}\n >\n {label}\n </Text>\n ))}\n </Text>\n );\n\n const renderDescription = (descriptionOptions?: ToastDescriptionOptions) =>\n descriptionOptions && (\n <Text\n variant={TextVariant.BodySm}\n color={TextColor.TextAlternative}\n style={tw.style('mt-1')}\n >\n {descriptionOptions.description}\n </Text>\n );\n\n const renderActionButton = (linkButtonOptions?: ToastLinkButtonOptions) =>\n linkButtonOptions && (\n <Button\n variant={ButtonVariant.Secondary}\n onPress={linkButtonOptions.onPress}\n style={tw.style('mt-2')}\n >\n {linkButtonOptions.label}\n </Button>\n );\n\n const renderCloseButton = (\n closeButtonOptions?: ToastCloseButtonOptions,\n ) => {\n if (closeButtonOptions?.variant === ButtonIconVariant.Icon) {\n return (\n <ButtonIcon\n onPress={(e) => closeButtonOptions?.onPress?.(e)}\n iconName={closeButtonOptions?.iconName}\n />\n );\n }\n return (\n <Button\n variant={ButtonVariant.Primary}\n onPress={(e) => closeButtonOptions?.onPress?.(e)}\n startIconName={closeButtonOptions?.startIconName}\n endIconName={closeButtonOptions?.endIconName}\n style={closeButtonOptions?.style}\n >\n {closeButtonOptions?.children}\n </Button>\n );\n };\n\n const renderAvatar = () => {\n switch (toastOptions?.variant) {\n case ToastVariant.Plain:\n return null;\n case ToastVariant.Account: {\n const { accountAddress, accountAvatarType } = toastOptions;\n return (\n <AvatarAccount\n address={accountAddress}\n variant={accountAvatarType}\n size={AvatarAccountSize.Md}\n style={tw.style('mr-4')}\n />\n );\n }\n case ToastVariant.Network: {\n const { networkImageSource, networkName } = toastOptions;\n return (\n <AvatarNetwork\n name={networkName}\n src={networkImageSource}\n size={AvatarNetworkSize.Md}\n style={tw.style('mr-4')}\n />\n );\n }\n case ToastVariant.App: {\n const { appIconSource } = toastOptions;\n return (\n <AvatarFavicon\n src={appIconSource}\n size={AvatarFaviconSize.Md}\n style={tw.style('mr-4')}\n />\n );\n }\n case ToastVariant.Icon: {\n const { iconName, severity } = toastOptions;\n return (\n <AvatarIcon\n iconName={iconName}\n severity={severity}\n size={AvatarIconSize.Md}\n style={tw.style('mr-4')}\n />\n );\n }\n /* istanbul ignore next - all variants handled above */\n default:\n return null;\n }\n };\n\n const renderToastContent = (options: ToastOptions) => {\n const {\n labelOptions,\n descriptionOptions,\n linkButtonOptions,\n closeButtonOptions,\n startAccessory,\n } = options;\n\n const isStartAccessoryValid =\n startAccessory !== null &&\n startAccessory !== undefined &&\n isValidElement(startAccessory);\n\n return (\n <>\n {isStartAccessoryValid ? startAccessory : renderAvatar()}\n <View\n style={tw.style('flex-1 justify-center')}\n {...labelsContainerProps}\n >\n {renderLabel(labelOptions)}\n {renderDescription(descriptionOptions)}\n {renderActionButton(linkButtonOptions)}\n </View>\n {closeButtonOptions ? renderCloseButton(closeButtonOptions) : null}\n </>\n );\n };\n\n if (!toastOptions) {\n return null;\n }\n\n return (\n <Animated.View\n onLayout={onAnimatedViewLayout}\n style={baseStyle}\n {...props}\n >\n {renderToastContent(toastOptions)}\n </Animated.View>\n );\n },\n);\n\nexport default Toast;\n"]}
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TOAST_BOTTOM_PADDING = exports.TOAST_ANIMATION_DURATION = exports.TOAST_VISIBILITY_DURATION = void 0;
4
+ // External dependencies.
5
+ const design_tokens_1 = require("@metamask-previews/design-tokens");
6
+ /**
7
+ * Animation constants.
8
+ */
9
+ exports.TOAST_VISIBILITY_DURATION = 2750;
10
+ exports.TOAST_ANIMATION_DURATION = design_tokens_1.AnimationDuration.Regularly;
11
+ exports.TOAST_BOTTOM_PADDING = 36;
12
+ //# sourceMappingURL=Toast.constants.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.constants.cjs","sourceRoot":"","sources":["../../../src/components/Toast/Toast.constants.ts"],"names":[],"mappings":";;;AAAA,yBAAyB;AACzB,oEAAqE;AAErE;;GAEG;AACU,QAAA,yBAAyB,GAAG,IAAI,CAAC;AACjC,QAAA,wBAAwB,GAAG,iCAAiB,CAAC,SAAS,CAAC;AACvD,QAAA,oBAAoB,GAAG,EAAE,CAAC","sourcesContent":["// External dependencies.\nimport { AnimationDuration } from '@metamask-previews/design-tokens';\n\n/**\n * Animation constants.\n */\nexport const TOAST_VISIBILITY_DURATION = 2750;\nexport const TOAST_ANIMATION_DURATION = AnimationDuration.Regularly;\nexport const TOAST_BOTTOM_PADDING = 36;\n"]}
@@ -0,0 +1,8 @@
1
+ import { AnimationDuration } from "@metamask-previews/design-tokens";
2
+ /**
3
+ * Animation constants.
4
+ */
5
+ export declare const TOAST_VISIBILITY_DURATION = 2750;
6
+ export declare const TOAST_ANIMATION_DURATION = AnimationDuration.Regularly;
7
+ export declare const TOAST_BOTTOM_PADDING = 36;
8
+ //# sourceMappingURL=Toast.constants.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.constants.d.cts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.constants.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,yCAAyC;AAErE;;GAEG;AACH,eAAO,MAAM,yBAAyB,OAAO,CAAC;AAC9C,eAAO,MAAM,wBAAwB,8BAA8B,CAAC;AACpE,eAAO,MAAM,oBAAoB,KAAK,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { AnimationDuration } from "@metamask-previews/design-tokens";
2
+ /**
3
+ * Animation constants.
4
+ */
5
+ export declare const TOAST_VISIBILITY_DURATION = 2750;
6
+ export declare const TOAST_ANIMATION_DURATION = AnimationDuration.Regularly;
7
+ export declare const TOAST_BOTTOM_PADDING = 36;
8
+ //# sourceMappingURL=Toast.constants.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.constants.d.mts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.constants.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,yCAAyC;AAErE;;GAEG;AACH,eAAO,MAAM,yBAAyB,OAAO,CAAC;AAC9C,eAAO,MAAM,wBAAwB,8BAA8B,CAAC;AACpE,eAAO,MAAM,oBAAoB,KAAK,CAAC"}
@@ -0,0 +1,9 @@
1
+ // External dependencies.
2
+ import { AnimationDuration } from "@metamask-previews/design-tokens";
3
+ /**
4
+ * Animation constants.
5
+ */
6
+ export const TOAST_VISIBILITY_DURATION = 2750;
7
+ export const TOAST_ANIMATION_DURATION = AnimationDuration.Regularly;
8
+ export const TOAST_BOTTOM_PADDING = 36;
9
+ //# sourceMappingURL=Toast.constants.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.constants.mjs","sourceRoot":"","sources":["../../../src/components/Toast/Toast.constants.ts"],"names":[],"mappings":"AAAA,yBAAyB;AACzB,OAAO,EAAE,iBAAiB,EAAE,yCAAyC;AAErE;;GAEG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG,IAAI,CAAC;AAC9C,MAAM,CAAC,MAAM,wBAAwB,GAAG,iBAAiB,CAAC,SAAS,CAAC;AACpE,MAAM,CAAC,MAAM,oBAAoB,GAAG,EAAE,CAAC","sourcesContent":["// External dependencies.\nimport { AnimationDuration } from '@metamask-previews/design-tokens';\n\n/**\n * Animation constants.\n */\nexport const TOAST_VISIBILITY_DURATION = 2750;\nexport const TOAST_ANIMATION_DURATION = AnimationDuration.Regularly;\nexport const TOAST_BOTTOM_PADDING = 36;\n"]}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.ToastContextWrapper = exports.ToastContext = void 0;
27
+ // Third party dependencies.
28
+ const react_1 = __importStar(require("react"));
29
+ exports.ToastContext = (0, react_1.createContext)({
30
+ toastRef: undefined,
31
+ });
32
+ const ToastContextWrapper = ({ children, }) => {
33
+ const toastRef = (0, react_1.useRef)(null);
34
+ // TODO: how to register service?
35
+ return (<exports.ToastContext.Provider value={{ toastRef }}>
36
+ {children}
37
+ </exports.ToastContext.Provider>);
38
+ };
39
+ exports.ToastContextWrapper = ToastContextWrapper;
40
+ //# sourceMappingURL=Toast.context.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.context.cjs","sourceRoot":"","sources":["../../../src/components/Toast/Toast.context.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4BAA4B;AAC5B,+CAAqD;AAKxC,QAAA,YAAY,GAAG,IAAA,qBAAa,EAAqB;IAC5D,QAAQ,EAAE,SAAS;CACpB,CAAC,CAAC;AAEI,MAAM,mBAAmB,GAA4C,CAAC,EAC3E,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,QAAQ,GAAG,IAAA,cAAM,EAAkB,IAAI,CAAC,CAAC;IAE/C,iCAAiC;IAEjC,OAAO,CACL,CAAC,oBAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CACzC;MAAA,CAAC,QAAQ,CACX;IAAA,EAAE,oBAAY,CAAC,QAAQ,CAAC,CACzB,CAAC;AACJ,CAAC,CAAC;AAZW,QAAA,mBAAmB,uBAY9B","sourcesContent":["// Third party dependencies.\nimport React, { createContext, useRef } from 'react';\n\n// Internal dependencies.\nimport type { ToastRef, ToastContextParams } from './Toast.types';\n\nexport const ToastContext = createContext<ToastContextParams>({\n toastRef: undefined,\n});\n\nexport const ToastContextWrapper: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => {\n const toastRef = useRef<ToastRef | null>(null);\n\n // TODO: how to register service?\n\n return (\n <ToastContext.Provider value={{ toastRef }}>\n {children}\n </ToastContext.Provider>\n );\n};\n"]}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import type { ToastContextParams } from "./Toast.types.cjs";
3
+ export declare const ToastContext: React.Context<ToastContextParams>;
4
+ export declare const ToastContextWrapper: React.FC<{
5
+ children: React.ReactNode;
6
+ }>;
7
+ //# sourceMappingURL=Toast.context.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.context.d.cts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.context.tsx"],"names":[],"mappings":"AACA,OAAO,KAAgC,cAAc;AAGrD,OAAO,KAAK,EAAY,kBAAkB,EAAE,0BAAsB;AAElE,eAAO,MAAM,YAAY,mCAEvB,CAAC;AAEH,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAYvE,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import type { ToastContextParams } from "./Toast.types.mjs";
3
+ export declare const ToastContext: React.Context<ToastContextParams>;
4
+ export declare const ToastContextWrapper: React.FC<{
5
+ children: React.ReactNode;
6
+ }>;
7
+ //# sourceMappingURL=Toast.context.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.context.d.mts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.context.tsx"],"names":[],"mappings":"AACA,OAAO,KAAgC,cAAc;AAGrD,OAAO,KAAK,EAAY,kBAAkB,EAAE,0BAAsB;AAElE,eAAO,MAAM,YAAY,mCAEvB,CAAC;AAEH,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,CAYvE,CAAC"}
@@ -0,0 +1,20 @@
1
+ function $importDefault(module) {
2
+ if (module?.__esModule) {
3
+ return module.default;
4
+ }
5
+ return module;
6
+ }
7
+ // Third party dependencies.
8
+ import $React, { createContext, useRef } from "react";
9
+ const React = $importDefault($React);
10
+ export const ToastContext = createContext({
11
+ toastRef: undefined,
12
+ });
13
+ export const ToastContextWrapper = ({ children, }) => {
14
+ const toastRef = useRef(null);
15
+ // TODO: how to register service?
16
+ return (<ToastContext.Provider value={{ toastRef }}>
17
+ {children}
18
+ </ToastContext.Provider>);
19
+ };
20
+ //# sourceMappingURL=Toast.context.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.context.mjs","sourceRoot":"","sources":["../../../src/components/Toast/Toast.context.tsx"],"names":[],"mappings":";;;;;;AAAA,4BAA4B;AAC5B,OAAO,QAAO,EAAE,aAAa,EAAE,MAAM,EAAE,cAAc;;AAKrD,MAAM,CAAC,MAAM,YAAY,GAAG,aAAa,CAAqB;IAC5D,QAAQ,EAAE,SAAS;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,mBAAmB,GAA4C,CAAC,EAC3E,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,QAAQ,GAAG,MAAM,CAAkB,IAAI,CAAC,CAAC;IAE/C,iCAAiC;IAEjC,OAAO,CACL,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CACzC;MAAA,CAAC,QAAQ,CACX;IAAA,EAAE,YAAY,CAAC,QAAQ,CAAC,CACzB,CAAC;AACJ,CAAC,CAAC","sourcesContent":["// Third party dependencies.\nimport React, { createContext, useRef } from 'react';\n\n// Internal dependencies.\nimport type { ToastRef, ToastContextParams } from './Toast.types';\n\nexport const ToastContext = createContext<ToastContextParams>({\n toastRef: undefined,\n});\n\nexport const ToastContextWrapper: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => {\n const toastRef = useRef<ToastRef | null>(null);\n\n // TODO: how to register service?\n\n return (\n <ToastContext.Provider value={{ toastRef }}>\n {children}\n </ToastContext.Provider>\n );\n};\n"]}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import type { ToastRef } from "./Toast.types.cjs";
3
+ declare const Toast: React.ForwardRefExoticComponent<{
4
+ twClassName?: string | undefined;
5
+ labelsContainerProps?: Omit<import("react-native").ViewProps, "style" | "children"> | undefined;
6
+ } & Omit<import("react-native").ViewProps, "style"> & React.RefAttributes<ToastRef>>;
7
+ export default Toast;
8
+ //# sourceMappingURL=Toast.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.d.cts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.tsx"],"names":[],"mappings":"AAEA,OAAO,KAON,cAAc;AA6Bf,OAAO,KAAK,EAOV,QAAQ,EACT,0BAAsB;AAKvB,QAAA,MAAM,KAAK;;;oFA6PV,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import type { ToastRef } from "./Toast.types.mjs";
3
+ declare const Toast: React.ForwardRefExoticComponent<{
4
+ twClassName?: string | undefined;
5
+ labelsContainerProps?: Omit<import("react-native").ViewProps, "style" | "children"> | undefined;
6
+ } & Omit<import("react-native").ViewProps, "style"> & React.RefAttributes<ToastRef>>;
7
+ export default Toast;
8
+ //# sourceMappingURL=Toast.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.d.mts","sourceRoot":"","sources":["../../../src/components/Toast/Toast.tsx"],"names":[],"mappings":"AAEA,OAAO,KAON,cAAc;AA6Bf,OAAO,KAAK,EAOV,QAAQ,EACT,0BAAsB;AAKvB,QAAA,MAAM,KAAK;;;oFA6PV,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,156 @@
1
+ function $importDefault(module) {
2
+ if (module?.__esModule) {
3
+ return module.default;
4
+ }
5
+ return module;
6
+ }
7
+ // Third party dependencies.
8
+ import { useTailwind } from "@metamask-previews/design-system-twrnc-preset";
9
+ import $React, { forwardRef, isValidElement, useImperativeHandle, useMemo, useRef, useState } from "react";
10
+ const React = $importDefault($React);
11
+ import { Dimensions, View } from "react-native/index.js";
12
+ // eslint-disable-next-line import-x/default
13
+ import Animated, { cancelAnimation, runOnJS, useAnimatedStyle, useSharedValue, withDelay, withTiming } from "react-native-reanimated";
14
+ import { useSafeAreaInsets } from "react-native-safe-area-context";
15
+ // External dependencies.
16
+ import { AvatarAccount, AvatarAccountSize } from "../AvatarAccount/index.mjs";
17
+ import { AvatarFavicon, AvatarFaviconSize } from "../AvatarFavicon/index.mjs";
18
+ import { AvatarIcon, AvatarIconSize } from "../AvatarIcon/index.mjs";
19
+ import { AvatarNetwork, AvatarNetworkSize } from "../AvatarNetwork/index.mjs";
20
+ import { Button, ButtonVariant } from "../Button/index.mjs";
21
+ import { ButtonIcon } from "../ButtonIcon/index.mjs";
22
+ import { Text, TextVariant, TextColor, FontWeight } from "../Text/index.mjs";
23
+ // Internal dependencies.
24
+ import { TOAST_VISIBILITY_DURATION, TOAST_ANIMATION_DURATION, TOAST_BOTTOM_PADDING } from "./Toast.constants.mjs";
25
+ import { ButtonIconVariant, ToastVariant } from "./Toast.types.mjs";
26
+ const screenHeight = Dimensions.get('window').height;
27
+ const Toast = forwardRef(({ twClassName, labelsContainerProps, ...props }, ref) => {
28
+ const tw = useTailwind();
29
+ const [toastOptions, setToastOptions] = useState(undefined);
30
+ const replacementTimerRef = useRef(null);
31
+ const { bottom: bottomNotchSpacing } = useSafeAreaInsets();
32
+ const translateYProgress = useSharedValue(screenHeight);
33
+ const bottomOffset = toastOptions?.bottomOffset ?? 0;
34
+ const animatedStyle = useAnimatedStyle(() => ({
35
+ transform: [{ translateY: translateYProgress.value - bottomOffset }],
36
+ }));
37
+ const baseStyle = useMemo(() => [
38
+ tw.style('absolute left-4 right-4 bottom-0 bg-background-section border border-border-muted rounded-xl p-3 flex-row items-center', twClassName),
39
+ animatedStyle,
40
+ ], [tw, animatedStyle, twClassName]);
41
+ const resetState = () => setToastOptions(undefined);
42
+ const showToast = (options) => {
43
+ let timeoutDuration = 0;
44
+ if (toastOptions) {
45
+ cancelAnimation(translateYProgress);
46
+ timeoutDuration = 100;
47
+ // Clear existing toast state to prevent animation conflicts when showing rapid successive toasts
48
+ setToastOptions(undefined);
49
+ }
50
+ if (replacementTimerRef.current !== null) {
51
+ clearTimeout(replacementTimerRef.current);
52
+ }
53
+ replacementTimerRef.current = setTimeout(() => {
54
+ replacementTimerRef.current = null;
55
+ setToastOptions(options);
56
+ }, timeoutDuration);
57
+ };
58
+ const closeToast = () => {
59
+ if (replacementTimerRef.current !== null) {
60
+ clearTimeout(replacementTimerRef.current);
61
+ replacementTimerRef.current = null;
62
+ }
63
+ translateYProgress.value = withTiming(screenHeight, { duration: TOAST_ANIMATION_DURATION }, () => {
64
+ runOnJS(resetState)();
65
+ });
66
+ };
67
+ useImperativeHandle(ref, () => ({
68
+ showToast,
69
+ closeToast,
70
+ }));
71
+ const onAnimatedViewLayout = (e) => {
72
+ /* istanbul ignore next - guard only; layout fires when toastOptions is set */
73
+ if (toastOptions) {
74
+ const { height } = e.nativeEvent.layout;
75
+ const translateYToValue = -(TOAST_BOTTOM_PADDING + bottomNotchSpacing);
76
+ translateYProgress.value = height;
77
+ if (toastOptions.hasNoTimeout) {
78
+ translateYProgress.value = withTiming(translateYToValue, {
79
+ duration: TOAST_ANIMATION_DURATION,
80
+ });
81
+ }
82
+ else {
83
+ translateYProgress.value = withTiming(translateYToValue, { duration: TOAST_ANIMATION_DURATION }, () => {
84
+ translateYProgress.value = withDelay(TOAST_VISIBILITY_DURATION, withTiming(height, { duration: TOAST_ANIMATION_DURATION }, runOnJS(resetState)));
85
+ });
86
+ }
87
+ }
88
+ };
89
+ const renderLabel = (labelOptions) => (<Text variant={TextVariant.BodyMd}>
90
+ {labelOptions.map(({ label, isBold }, index) => (<Text key={`toast-label-${index}`} variant={TextVariant.BodyMd} fontWeight={isBold ? FontWeight.Bold : undefined} color={TextColor.TextDefault}>
91
+ {label}
92
+ </Text>))}
93
+ </Text>);
94
+ const renderDescription = (descriptionOptions) => descriptionOptions && (<Text variant={TextVariant.BodySm} color={TextColor.TextAlternative} style={tw.style('mt-1')}>
95
+ {descriptionOptions.description}
96
+ </Text>);
97
+ const renderActionButton = (linkButtonOptions) => linkButtonOptions && (<Button variant={ButtonVariant.Secondary} onPress={linkButtonOptions.onPress} style={tw.style('mt-2')}>
98
+ {linkButtonOptions.label}
99
+ </Button>);
100
+ const renderCloseButton = (closeButtonOptions) => {
101
+ if (closeButtonOptions?.variant === ButtonIconVariant.Icon) {
102
+ return (<ButtonIcon onPress={(e) => closeButtonOptions?.onPress?.(e)} iconName={closeButtonOptions?.iconName}/>);
103
+ }
104
+ return (<Button variant={ButtonVariant.Primary} onPress={(e) => closeButtonOptions?.onPress?.(e)} startIconName={closeButtonOptions?.startIconName} endIconName={closeButtonOptions?.endIconName} style={closeButtonOptions?.style}>
105
+ {closeButtonOptions?.children}
106
+ </Button>);
107
+ };
108
+ const renderAvatar = () => {
109
+ switch (toastOptions?.variant) {
110
+ case ToastVariant.Plain:
111
+ return null;
112
+ case ToastVariant.Account: {
113
+ const { accountAddress, accountAvatarType } = toastOptions;
114
+ return (<AvatarAccount address={accountAddress} variant={accountAvatarType} size={AvatarAccountSize.Md} style={tw.style('mr-4')}/>);
115
+ }
116
+ case ToastVariant.Network: {
117
+ const { networkImageSource, networkName } = toastOptions;
118
+ return (<AvatarNetwork name={networkName} src={networkImageSource} size={AvatarNetworkSize.Md} style={tw.style('mr-4')}/>);
119
+ }
120
+ case ToastVariant.App: {
121
+ const { appIconSource } = toastOptions;
122
+ return (<AvatarFavicon src={appIconSource} size={AvatarFaviconSize.Md} style={tw.style('mr-4')}/>);
123
+ }
124
+ case ToastVariant.Icon: {
125
+ const { iconName, severity } = toastOptions;
126
+ return (<AvatarIcon iconName={iconName} severity={severity} size={AvatarIconSize.Md} style={tw.style('mr-4')}/>);
127
+ }
128
+ /* istanbul ignore next - all variants handled above */
129
+ default:
130
+ return null;
131
+ }
132
+ };
133
+ const renderToastContent = (options) => {
134
+ const { labelOptions, descriptionOptions, linkButtonOptions, closeButtonOptions, startAccessory, } = options;
135
+ const isStartAccessoryValid = startAccessory !== null &&
136
+ startAccessory !== undefined &&
137
+ isValidElement(startAccessory);
138
+ return (<>
139
+ {isStartAccessoryValid ? startAccessory : renderAvatar()}
140
+ <View style={tw.style('flex-1 justify-center')} {...labelsContainerProps}>
141
+ {renderLabel(labelOptions)}
142
+ {renderDescription(descriptionOptions)}
143
+ {renderActionButton(linkButtonOptions)}
144
+ </View>
145
+ {closeButtonOptions ? renderCloseButton(closeButtonOptions) : null}
146
+ </>);
147
+ };
148
+ if (!toastOptions) {
149
+ return null;
150
+ }
151
+ return (<Animated.View onLayout={onAnimatedViewLayout} style={baseStyle} {...props}>
152
+ {renderToastContent(toastOptions)}
153
+ </Animated.View>);
154
+ });
155
+ export default Toast;
156
+ //# sourceMappingURL=Toast.mjs.map