@lifi/widget 3.0.0-alpha.33 → 3.0.0-alpha.35

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 (328) hide show
  1. package/App.tsx +6 -3
  2. package/AppDefault.tsx +3 -3
  3. package/AppDrawer.tsx +3 -5
  4. package/_esm/App.js +6 -3
  5. package/_esm/App.js.map +1 -1
  6. package/_esm/AppDefault.js +3 -3
  7. package/_esm/AppDefault.js.map +1 -1
  8. package/_esm/AppDrawer.js +3 -3
  9. package/_esm/AppDrawer.js.map +1 -1
  10. package/_esm/components/ActiveTransactions/ActiveTransactions.d.ts +2 -2
  11. package/_esm/components/ActiveTransactions/ActiveTransactions.js +1 -1
  12. package/_esm/components/ActiveTransactions/ActiveTransactions.js.map +1 -1
  13. package/_esm/components/ActiveTransactions/ActiveTransactions.style.d.ts +1 -1
  14. package/_esm/components/AmountInput/AmountInput.d.ts +3 -3
  15. package/_esm/components/AmountInput/AmountInput.js +2 -2
  16. package/_esm/components/AmountInput/AmountInput.js.map +1 -1
  17. package/_esm/components/AppContainer.js +3 -2
  18. package/_esm/components/AppContainer.js.map +1 -1
  19. package/_esm/components/Avatar/AccountAvatar.d.ts +3 -1
  20. package/_esm/components/Avatar/AccountAvatar.js +3 -3
  21. package/_esm/components/Avatar/AccountAvatar.js.map +1 -1
  22. package/_esm/components/Avatar/utils.d.ts +1 -1
  23. package/_esm/components/Avatar/utils.js +1 -1
  24. package/_esm/components/Avatar/utils.js.map +1 -1
  25. package/_esm/components/Card/Card.d.ts +7 -19
  26. package/_esm/components/Card/Card.js +36 -42
  27. package/_esm/components/Card/Card.js.map +1 -1
  28. package/_esm/components/Card/CardLabel.js +5 -3
  29. package/_esm/components/Card/CardLabel.js.map +1 -1
  30. package/_esm/components/Card/InputCard.d.ts +4 -0
  31. package/_esm/components/Card/InputCard.js +7 -0
  32. package/_esm/components/Card/InputCard.js.map +1 -0
  33. package/_esm/components/ChainSelect/ChainSelect.js +1 -1
  34. package/_esm/components/ChainSelect/ChainSelect.js.map +1 -1
  35. package/_esm/components/ChainSelect/ChainSelect.style.d.ts +2 -10
  36. package/_esm/components/ContractComponent/ContractComponent.d.ts +2 -2
  37. package/_esm/components/ContractComponent/ContractComponent.js.map +1 -1
  38. package/_esm/components/ContractComponent/ItemPrice.d.ts +8 -0
  39. package/_esm/components/ContractComponent/ItemPrice.js +23 -0
  40. package/_esm/components/ContractComponent/ItemPrice.js.map +1 -0
  41. package/_esm/components/{NFT → ContractComponent/NFT}/NFT.js +5 -11
  42. package/_esm/components/ContractComponent/NFT/NFT.js.map +1 -0
  43. package/_esm/components/ContractComponent/NFT/NFT.style.js.map +1 -0
  44. package/_esm/components/{NFT → ContractComponent/NFT}/NFTBase.js +1 -1
  45. package/_esm/components/ContractComponent/NFT/NFTBase.js.map +1 -0
  46. package/_esm/components/{NFT → ContractComponent/NFT}/types.d.ts +2 -3
  47. package/_esm/components/ContractComponent/NFT/types.js.map +1 -0
  48. package/_esm/components/Dialog.d.ts +2 -9
  49. package/_esm/components/Dialog.js +1 -0
  50. package/_esm/components/Dialog.js.map +1 -1
  51. package/_esm/components/Header/BackButton.d.ts +3 -0
  52. package/_esm/components/Header/BackButton.js +8 -0
  53. package/_esm/components/Header/BackButton.js.map +1 -0
  54. package/_esm/components/Header/CloseDrawerButton.d.ts +5 -1
  55. package/_esm/components/Header/CloseDrawerButton.js +8 -2
  56. package/_esm/components/Header/CloseDrawerButton.js.map +1 -1
  57. package/_esm/components/Header/Header.style.d.ts +4 -1
  58. package/_esm/components/Header/Header.style.js +24 -16
  59. package/_esm/components/Header/Header.style.js.map +1 -1
  60. package/_esm/components/Header/NavigationHeader.js +8 -9
  61. package/_esm/components/Header/NavigationHeader.js.map +1 -1
  62. package/_esm/components/Header/NavigationTabs.js +1 -1
  63. package/_esm/components/Header/NavigationTabs.js.map +1 -1
  64. package/_esm/components/Header/SettingsButton.style.d.ts +1 -1
  65. package/_esm/components/Header/TransactionHistoryButton.js +1 -1
  66. package/_esm/components/Header/TransactionHistoryButton.js.map +1 -1
  67. package/_esm/components/Header/WalletHeader.js +4 -11
  68. package/_esm/components/Header/WalletHeader.js.map +1 -1
  69. package/_esm/components/Header/WalletMenu.js +2 -2
  70. package/_esm/components/Header/WalletMenu.js.map +1 -1
  71. package/_esm/components/Insurance/types.d.ts +3 -3
  72. package/_esm/components/ListItem/ListItem.d.ts +1 -1
  73. package/_esm/components/PageContainer.d.ts +2 -1
  74. package/_esm/components/PageContainer.js +3 -3
  75. package/_esm/components/PageContainer.js.map +1 -1
  76. package/_esm/components/ReverseTokensButton/ReverseTokensButton.js +2 -2
  77. package/_esm/components/ReverseTokensButton/ReverseTokensButton.js.map +1 -1
  78. package/_esm/components/ReverseTokensButton/ReverseTokensButton.style.d.ts +9 -3
  79. package/_esm/components/ReverseTokensButton/ReverseTokensButton.style.js +24 -14
  80. package/_esm/components/ReverseTokensButton/ReverseTokensButton.style.js.map +1 -1
  81. package/_esm/components/RouteCard/RouteCard.js +2 -2
  82. package/_esm/components/RouteCard/RouteCard.js.map +1 -1
  83. package/_esm/components/RouteCard/RouteCardSkeleton.d.ts +2 -2
  84. package/_esm/components/RouteCard/RouteCardSkeleton.js +1 -1
  85. package/_esm/components/RouteCard/RouteCardSkeleton.js.map +1 -1
  86. package/_esm/components/Routes/Routes.d.ts +2 -2
  87. package/_esm/components/Routes/Routes.js +1 -1
  88. package/_esm/components/Routes/Routes.js.map +1 -1
  89. package/_esm/components/Routes/RoutesExpanded.js +9 -3
  90. package/_esm/components/Routes/RoutesExpanded.js.map +1 -1
  91. package/_esm/components/Routes/RoutesExpanded.style.js +1 -0
  92. package/_esm/components/Routes/RoutesExpanded.style.js.map +1 -1
  93. package/_esm/components/SelectChainAndToken.js +3 -6
  94. package/_esm/components/SelectChainAndToken.js.map +1 -1
  95. package/_esm/components/SelectTokenButton/SelectTokenButton.js +9 -10
  96. package/_esm/components/SelectTokenButton/SelectTokenButton.js.map +1 -1
  97. package/_esm/components/SelectTokenButton/SelectTokenButton.style.d.ts +10 -0
  98. package/_esm/components/SelectTokenButton/SelectTokenButton.style.js +41 -1
  99. package/_esm/components/SelectTokenButton/SelectTokenButton.style.js.map +1 -1
  100. package/_esm/components/SendToWallet/SendToWalletButton.d.ts +2 -2
  101. package/_esm/components/SendToWallet/SendToWalletButton.js +2 -2
  102. package/_esm/components/SendToWallet/SendToWalletButton.js.map +1 -1
  103. package/_esm/components/Step/Step.js +8 -8
  104. package/_esm/components/Step/Step.js.map +1 -1
  105. package/_esm/components/Step/StepList.js +1 -1
  106. package/_esm/components/Step/StepList.js.map +1 -1
  107. package/_esm/components/StepActions/StepActions.d.ts +4 -9
  108. package/_esm/components/StepActions/StepActions.js +13 -12
  109. package/_esm/components/StepActions/StepActions.js.map +1 -1
  110. package/_esm/components/StepActions/types.d.ts +8 -2
  111. package/_esm/components/TokenList/TokenList.js +4 -1
  112. package/_esm/components/TokenList/TokenList.js.map +1 -1
  113. package/_esm/components/TokenList/TokenList.style.d.ts +1 -1
  114. package/_esm/components/TokenList/TokenList.style.js +1 -1
  115. package/_esm/components/TokenList/TokenList.style.js.map +1 -1
  116. package/_esm/components/TokenList/VirtualizedTokenList.js +19 -18
  117. package/_esm/components/TokenList/VirtualizedTokenList.js.map +1 -1
  118. package/_esm/components/TokenList/useTokenSelect.js +1 -1
  119. package/_esm/components/TokenList/useTokenSelect.js.map +1 -1
  120. package/_esm/components/TokenList/utils.d.ts +2 -0
  121. package/_esm/components/TokenList/utils.js +35 -0
  122. package/_esm/components/TokenList/utils.js.map +1 -0
  123. package/_esm/config/version.d.ts +1 -1
  124. package/_esm/config/version.js +1 -1
  125. package/_esm/hooks/useAddressValidation.d.ts +1 -1
  126. package/_esm/hooks/useGasRecommendation.d.ts +1 -1
  127. package/_esm/hooks/useProcessMessage.d.ts +2 -2
  128. package/_esm/hooks/useProcessMessage.js +16 -12
  129. package/_esm/hooks/useProcessMessage.js.map +1 -1
  130. package/_esm/hooks/useRoutes.d.ts +2 -2
  131. package/_esm/hooks/useRoutes.js +11 -20
  132. package/_esm/hooks/useRoutes.js.map +1 -1
  133. package/_esm/hooks/useTokenAddressBalance.d.ts +1 -1
  134. package/_esm/hooks/useTokenBalance.d.ts +1 -1
  135. package/_esm/hooks/useTokenBalances.d.ts +1 -1
  136. package/_esm/hooks/useWideVariant.d.ts +1 -0
  137. package/_esm/hooks/{useExpandableVariant.js → useWideVariant.js} +3 -3
  138. package/_esm/hooks/useWideVariant.js.map +1 -0
  139. package/_esm/i18n/en.json +9 -5
  140. package/_esm/i18n/index.js +14 -14
  141. package/_esm/i18n/index.js.map +1 -1
  142. package/_esm/index.d.ts +6 -3
  143. package/_esm/index.js +6 -3
  144. package/_esm/index.js.map +1 -1
  145. package/_esm/pages/ActiveTransactionsPage/ActiveTransactionsPage.js +9 -2
  146. package/_esm/pages/ActiveTransactionsPage/ActiveTransactionsPage.js.map +1 -1
  147. package/_esm/pages/LanguagesPage.js +1 -0
  148. package/_esm/pages/LanguagesPage.js.map +1 -1
  149. package/_esm/pages/MainPage/MainPage.js +4 -4
  150. package/_esm/pages/MainPage/MainPage.js.map +1 -1
  151. package/_esm/pages/MainPage/ReviewButton.js +2 -2
  152. package/_esm/pages/MainPage/ReviewButton.js.map +1 -1
  153. package/_esm/pages/RoutesPage/RoutesPage.js +1 -8
  154. package/_esm/pages/RoutesPage/RoutesPage.js.map +1 -1
  155. package/_esm/pages/RoutesPage/RoutesPage.style.js +1 -1
  156. package/_esm/pages/SelectChainPage/SelectChainPage.js +1 -0
  157. package/_esm/pages/SelectChainPage/SelectChainPage.js.map +1 -1
  158. package/_esm/pages/SelectEnabledToolsPage.js +4 -2
  159. package/_esm/pages/SelectEnabledToolsPage.js.map +1 -1
  160. package/_esm/pages/SelectNativeTokenPage.js +1 -0
  161. package/_esm/pages/SelectNativeTokenPage.js.map +1 -1
  162. package/_esm/pages/SelectTokenPage/SearchTokenInput.js +2 -2
  163. package/_esm/pages/SelectTokenPage/SearchTokenInput.js.map +1 -1
  164. package/_esm/pages/SelectTokenPage/SelectTokenPage.js +1 -1
  165. package/_esm/pages/SelectTokenPage/SelectTokenPage.js.map +1 -1
  166. package/_esm/pages/SelectWalletPage/SelectWalletPage.js +1 -0
  167. package/_esm/pages/SelectWalletPage/SelectWalletPage.js.map +1 -1
  168. package/_esm/pages/SendToWallet/BookmarkAddressSheet.js +1 -1
  169. package/_esm/pages/SendToWallet/BookmarkAddressSheet.js.map +1 -1
  170. package/_esm/pages/SendToWallet/SendToConfiguredWalletPage.js +1 -1
  171. package/_esm/pages/SendToWallet/SendToConfiguredWalletPage.js.map +1 -1
  172. package/_esm/pages/SendToWallet/SendToWalletPage.js +3 -1
  173. package/_esm/pages/SendToWallet/SendToWalletPage.js.map +1 -1
  174. package/_esm/pages/SendToWallet/SendToWalletPage.style.d.ts +2 -10
  175. package/_esm/pages/SendToWallet/SendToWalletPage.style.js +3 -2
  176. package/_esm/pages/SendToWallet/SendToWalletPage.style.js.map +1 -1
  177. package/_esm/pages/SettingsPage/SettingsCard/SettingCard.style.d.ts +1 -1
  178. package/_esm/pages/SettingsPage/SettingsPage.js +1 -1
  179. package/_esm/pages/SettingsPage/SettingsPage.js.map +1 -1
  180. package/_esm/pages/TransactionDetailsPage/TransactionDetailsPage.js +3 -3
  181. package/_esm/pages/TransactionDetailsPage/TransactionDetailsPage.js.map +1 -1
  182. package/_esm/pages/TransactionDetailsPage/TransactionDetailsSkeleton.js +1 -1
  183. package/_esm/pages/TransactionDetailsPage/TransactionDetailsSkeleton.js.map +1 -1
  184. package/_esm/pages/TransactionHistoryPage/TransactionHistoryPage.js +6 -3
  185. package/_esm/pages/TransactionHistoryPage/TransactionHistoryPage.js.map +1 -1
  186. package/_esm/pages/TransactionPage/StatusBottomSheet.d.ts +5 -0
  187. package/_esm/pages/TransactionPage/StatusBottomSheet.js +33 -21
  188. package/_esm/pages/TransactionPage/StatusBottomSheet.js.map +1 -1
  189. package/_esm/pages/TransactionPage/TransactionPage.js +7 -7
  190. package/_esm/pages/TransactionPage/TransactionPage.js.map +1 -1
  191. package/_esm/providers/ThemeProvider/ThemeProvider.js +1 -1
  192. package/_esm/providers/ThemeProvider/ThemeProvider.js.map +1 -1
  193. package/_esm/stores/StoreProvider.js +1 -1
  194. package/_esm/stores/StoreProvider.js.map +1 -1
  195. package/_esm/stores/form/createFormStore.js +1 -6
  196. package/_esm/stores/form/createFormStore.js.map +1 -1
  197. package/_esm/stores/form/types.d.ts +4 -6
  198. package/_esm/stores/form/types.js.map +1 -1
  199. package/_esm/stores/form/useFieldController.d.ts +1 -1
  200. package/_esm/stores/form/useFieldValues.js +1 -1
  201. package/_esm/stores/form/useFieldValues.js.map +1 -1
  202. package/_esm/stores/form/useTouchedFields.d.ts +1 -4
  203. package/_esm/stores/settings/types.d.ts +4 -4
  204. package/_esm/stores/settings/useSettings.d.ts +1 -1
  205. package/_esm/themes/createTheme.d.ts +3 -0
  206. package/_esm/themes/createTheme.js +356 -0
  207. package/_esm/themes/createTheme.js.map +1 -0
  208. package/_esm/themes/jumper.d.ts +2 -0
  209. package/_esm/themes/jumper.js +36 -0
  210. package/_esm/themes/jumper.js.map +1 -0
  211. package/_esm/themes/types.d.ts +49 -0
  212. package/_esm/themes/types.js +2 -0
  213. package/_esm/{components/NFT → themes}/types.js.map +1 -1
  214. package/_esm/themes/utils.d.ts +4 -0
  215. package/_esm/themes/utils.js +9 -0
  216. package/_esm/themes/utils.js.map +1 -0
  217. package/_esm/themes/windows95.d.ts +2 -0
  218. package/_esm/themes/windows95.js +92 -0
  219. package/_esm/themes/windows95.js.map +1 -0
  220. package/_esm/types/events.d.ts +3 -1
  221. package/_esm/types/events.js +1 -0
  222. package/_esm/types/events.js.map +1 -1
  223. package/_esm/types/widget.d.ts +40 -27
  224. package/_esm/types/widget.js.map +1 -1
  225. package/_esm/utils/item.d.ts +1 -1
  226. package/components/ActiveTransactions/ActiveTransactions.tsx +3 -3
  227. package/components/AmountInput/AmountInput.tsx +6 -6
  228. package/components/AppContainer.tsx +2 -2
  229. package/components/Avatar/AccountAvatar.tsx +21 -17
  230. package/components/Avatar/utils.ts +1 -1
  231. package/components/Card/Card.tsx +45 -74
  232. package/components/Card/CardLabel.tsx +15 -3
  233. package/components/Card/InputCard.tsx +7 -0
  234. package/components/ChainSelect/ChainSelect.tsx +6 -2
  235. package/components/ContractComponent/ContractComponent.tsx +2 -2
  236. package/components/ContractComponent/ItemPrice.tsx +33 -0
  237. package/components/{NFT → ContractComponent/NFT}/NFT.tsx +5 -11
  238. package/components/{NFT → ContractComponent/NFT}/NFTBase.tsx +1 -1
  239. package/components/{NFT → ContractComponent/NFT}/types.ts +2 -3
  240. package/components/Dialog.tsx +3 -2
  241. package/components/Header/BackButton.tsx +17 -0
  242. package/components/Header/CloseDrawerButton.tsx +16 -3
  243. package/components/Header/Header.style.ts +25 -16
  244. package/components/Header/NavigationHeader.tsx +8 -11
  245. package/components/Header/NavigationTabs.tsx +1 -1
  246. package/components/Header/TransactionHistoryButton.tsx +0 -1
  247. package/components/Header/WalletHeader.tsx +5 -12
  248. package/components/Header/WalletMenu.tsx +2 -2
  249. package/components/Insurance/types.ts +3 -3
  250. package/components/PageContainer.ts +6 -5
  251. package/components/ReverseTokensButton/ReverseTokensButton.style.tsx +26 -21
  252. package/components/ReverseTokensButton/ReverseTokensButton.tsx +10 -8
  253. package/components/RouteCard/RouteCard.tsx +2 -2
  254. package/components/RouteCard/RouteCardSkeleton.tsx +5 -6
  255. package/components/Routes/Routes.tsx +3 -3
  256. package/components/Routes/RoutesExpanded.style.ts +1 -0
  257. package/components/Routes/RoutesExpanded.tsx +11 -4
  258. package/components/SelectChainAndToken.tsx +7 -13
  259. package/components/SelectTokenButton/SelectTokenButton.style.tsx +51 -1
  260. package/components/SelectTokenButton/SelectTokenButton.tsx +43 -38
  261. package/components/SendToWallet/SendToWalletButton.tsx +8 -8
  262. package/components/Step/Step.tsx +8 -8
  263. package/components/Step/StepList.tsx +1 -1
  264. package/components/StepActions/StepActions.tsx +40 -21
  265. package/components/StepActions/types.ts +12 -2
  266. package/components/TokenList/TokenList.style.tsx +1 -1
  267. package/components/TokenList/TokenList.tsx +9 -6
  268. package/components/TokenList/VirtualizedTokenList.tsx +26 -20
  269. package/components/TokenList/useTokenSelect.ts +1 -1
  270. package/components/TokenList/utils.ts +42 -0
  271. package/config/version.ts +1 -1
  272. package/hooks/useProcessMessage.ts +38 -15
  273. package/hooks/useRoutes.ts +13 -30
  274. package/hooks/{useExpandableVariant.ts → useWideVariant.ts} +2 -2
  275. package/i18n/en.json +9 -5
  276. package/i18n/index.ts +14 -14
  277. package/index.ts +6 -3
  278. package/package.json +15 -15
  279. package/pages/ActiveTransactionsPage/ActiveTransactionsPage.tsx +20 -5
  280. package/pages/LanguagesPage.tsx +1 -0
  281. package/pages/MainPage/MainPage.tsx +12 -10
  282. package/pages/MainPage/ReviewButton.tsx +2 -2
  283. package/pages/RoutesPage/RoutesPage.style.ts +1 -1
  284. package/pages/RoutesPage/RoutesPage.tsx +1 -9
  285. package/pages/SelectChainPage/SelectChainPage.tsx +1 -0
  286. package/pages/SelectEnabledToolsPage.tsx +8 -1
  287. package/pages/SelectNativeTokenPage.tsx +1 -0
  288. package/pages/SelectTokenPage/SearchTokenInput.tsx +3 -3
  289. package/pages/SelectTokenPage/SelectTokenPage.tsx +1 -1
  290. package/pages/SelectWalletPage/SelectWalletPage.tsx +1 -0
  291. package/pages/SendToWallet/BookmarkAddressSheet.tsx +2 -4
  292. package/pages/SendToWallet/SendToConfiguredWalletPage.tsx +1 -0
  293. package/pages/SendToWallet/SendToWalletPage.style.tsx +3 -2
  294. package/pages/SendToWallet/SendToWalletPage.tsx +7 -2
  295. package/pages/SettingsPage/SettingsPage.tsx +1 -1
  296. package/pages/TransactionDetailsPage/TransactionDetailsPage.tsx +7 -8
  297. package/pages/TransactionDetailsPage/TransactionDetailsSkeleton.tsx +1 -1
  298. package/pages/TransactionHistoryPage/TransactionHistoryPage.tsx +19 -16
  299. package/pages/TransactionPage/StatusBottomSheet.tsx +101 -78
  300. package/pages/TransactionPage/TransactionPage.tsx +12 -16
  301. package/providers/ThemeProvider/ThemeProvider.tsx +1 -1
  302. package/stores/StoreProvider.tsx +1 -1
  303. package/stores/form/createFormStore.ts +1 -6
  304. package/stores/form/types.ts +4 -6
  305. package/stores/form/useFieldValues.ts +1 -1
  306. package/stores/settings/types.ts +4 -4
  307. package/themes/createTheme.ts +416 -0
  308. package/themes/jumper.ts +37 -0
  309. package/themes/types.ts +63 -0
  310. package/themes/utils.ts +18 -0
  311. package/themes/windows95.ts +98 -0
  312. package/types/events.ts +2 -0
  313. package/types/widget.ts +54 -32
  314. package/_esm/components/NFT/NFT.js.map +0 -1
  315. package/_esm/components/NFT/NFT.style.js.map +0 -1
  316. package/_esm/components/NFT/NFTBase.js.map +0 -1
  317. package/_esm/config/theme.d.ts +0 -27
  318. package/_esm/config/theme.js +0 -250
  319. package/_esm/config/theme.js.map +0 -1
  320. package/_esm/hooks/useExpandableVariant.d.ts +0 -1
  321. package/_esm/hooks/useExpandableVariant.js.map +0 -1
  322. package/config/theme.ts +0 -321
  323. /package/_esm/components/{NFT → ContractComponent/NFT}/NFT.d.ts +0 -0
  324. /package/_esm/components/{NFT → ContractComponent/NFT}/NFT.style.d.ts +0 -0
  325. /package/_esm/components/{NFT → ContractComponent/NFT}/NFT.style.js +0 -0
  326. /package/_esm/components/{NFT → ContractComponent/NFT}/NFTBase.d.ts +0 -0
  327. /package/_esm/components/{NFT → ContractComponent/NFT}/types.js +0 -0
  328. /package/components/{NFT → ContractComponent/NFT}/NFT.style.ts +0 -0
@@ -0,0 +1,416 @@
1
+ import { loadingButtonClasses } from '@mui/lab';
2
+ import type {} from '@mui/lab/themeAugmentation';
3
+ import type {
4
+ CSSObject,
5
+ PaletteMode,
6
+ Shape,
7
+ SimplePaletteColorOptions,
8
+ } from '@mui/material';
9
+ import {
10
+ alpha,
11
+ createTheme as createMuiTheme,
12
+ css,
13
+ darken,
14
+ dialogActionsClasses,
15
+ getContrastRatio,
16
+ keyframes,
17
+ lighten,
18
+ touchRippleClasses,
19
+ } from '@mui/material';
20
+ import type { WidgetTheme } from '../types/widget.js';
21
+ import type {} from './types.js';
22
+ import { getStyleOverrides } from './utils.js';
23
+
24
+ const palette = {
25
+ primary: {
26
+ main: '#5C67FF',
27
+ light: lighten('#5C67FF', 0.84),
28
+ dark: darken('#5C67FF', 0.2),
29
+ },
30
+ secondary: {
31
+ main: '#F5B5FF',
32
+ light: lighten('#F5B5FF', 0.84),
33
+ dark: darken('#F5B5FF', 0.2),
34
+ },
35
+ success: {
36
+ main: '#0AA65B',
37
+ },
38
+ warning: {
39
+ main: '#FFCC00',
40
+ },
41
+ error: {
42
+ main: '#E5452F',
43
+ },
44
+ info: {
45
+ main: '#297EFF',
46
+ },
47
+ common: {
48
+ black: '#000',
49
+ white: '#fff',
50
+ },
51
+ };
52
+
53
+ const paletteLight = {
54
+ background: {
55
+ // default: '#c0c9d2',
56
+ // paper: '#dfdfdf',
57
+ },
58
+ text: {
59
+ primary: '#000000',
60
+ secondary: '#747474',
61
+ },
62
+ };
63
+
64
+ const paletteDark = {
65
+ background: {
66
+ paper: '#212121',
67
+ },
68
+ };
69
+
70
+ const shape: Shape = {
71
+ borderRadius: 12,
72
+ borderRadiusSecondary: 12,
73
+ borderRadiusTertiary: 24,
74
+ };
75
+
76
+ const enterKeyframe = keyframes`
77
+ 0% {
78
+ transform: scale(0);
79
+ opacity: 0.05;
80
+ }
81
+ 100% {
82
+ transform: scale(1);
83
+ opacity: 0.1;
84
+ }
85
+ `;
86
+
87
+ export const createTheme = (
88
+ mode: PaletteMode,
89
+ widgetTheme: WidgetTheme = {},
90
+ ) => {
91
+ const primaryMainColor =
92
+ (widgetTheme.palette?.primary as SimplePaletteColorOptions)?.main ??
93
+ palette.primary.main;
94
+ const primaryLightColor = lighten(primaryMainColor, 0.84);
95
+ const primaryDarkColor = darken(primaryMainColor, 0.2);
96
+ const secondaryMainColor =
97
+ (widgetTheme.palette?.secondary as SimplePaletteColorOptions)?.main ??
98
+ palette.secondary.main;
99
+ const contrastButtonColor =
100
+ getContrastRatio(palette.common.white, primaryMainColor) >= 3
101
+ ? palette.common.white
102
+ : palette.common.black;
103
+ const contrastTextButtonColor =
104
+ getContrastRatio(palette.common.white, alpha(primaryMainColor, 0.08)) >= 3
105
+ ? palette.common.white
106
+ : palette.common.black;
107
+ const borderRadiusSecondary =
108
+ widgetTheme.shape?.borderRadiusSecondary ?? shape.borderRadiusSecondary;
109
+
110
+ return createMuiTheme({
111
+ container: widgetTheme.container,
112
+ navigation: {
113
+ edge: true,
114
+ dense: true,
115
+ ...widgetTheme.navigation,
116
+ },
117
+ typography: {
118
+ fontFamily: 'Inter var, Inter, sans-serif',
119
+ ...widgetTheme.typography,
120
+ },
121
+ palette: {
122
+ mode,
123
+ ...palette,
124
+ ...(mode === 'light' ? paletteLight : paletteDark),
125
+ ...widgetTheme.palette,
126
+ primary: {
127
+ main: primaryMainColor,
128
+ light: primaryLightColor,
129
+ dark: primaryDarkColor,
130
+ },
131
+ secondary: {
132
+ main: secondaryMainColor,
133
+ light: lighten(secondaryMainColor, 0.84),
134
+ dark: darken(secondaryMainColor, 0.2),
135
+ },
136
+ },
137
+ shape: {
138
+ ...shape,
139
+ ...widgetTheme.shape,
140
+ },
141
+ breakpoints: {
142
+ values: {
143
+ xs: 360,
144
+ sm: 416,
145
+ md: 900,
146
+ lg: 1200,
147
+ xl: 1536,
148
+ },
149
+ },
150
+ components: {
151
+ MuiScopedCssBaseline: {
152
+ styleOverrides: {
153
+ root: {
154
+ fontFamily: 'Inter, sans-serif',
155
+ ...widgetTheme.typography,
156
+ '@supports (font-variation-settings: normal)': {
157
+ fontFamily: 'Inter var, sans-serif',
158
+ ...widgetTheme.typography,
159
+ },
160
+ },
161
+ },
162
+ },
163
+ MuiAppBar: {
164
+ styleOverrides: {
165
+ root: ({ ownerState, theme }) => ({
166
+ minHeight: 40,
167
+ padding: 0,
168
+ ...getStyleOverrides('MuiAppBar', 'root', widgetTheme, ownerState),
169
+ }),
170
+ },
171
+ },
172
+ MuiCard: {
173
+ defaultProps: {
174
+ variant: 'outlined',
175
+ ...widgetTheme.components?.MuiCard?.defaultProps,
176
+ },
177
+ styleOverrides: {
178
+ root: ({ ownerState, theme }) => {
179
+ const root = widgetTheme.components?.MuiCard?.styleOverrides
180
+ ?.root as CSSObject;
181
+ const rootHover = root?.['&:hover'];
182
+ return {
183
+ backgroundColor: theme.palette.background.paper,
184
+ borderRadius: theme.shape.borderRadius,
185
+ overflow: 'hidden',
186
+ position: 'relative',
187
+ boxSizing: 'border-box',
188
+ transition: theme.transitions.create(
189
+ ['background-color', 'filter'],
190
+ {
191
+ duration: theme.transitions.duration.enteringScreen,
192
+ easing: theme.transitions.easing.easeOut,
193
+ },
194
+ ),
195
+ ...(!!ownerState.onClick && {
196
+ '&:hover': {
197
+ cursor: 'pointer',
198
+ },
199
+ }),
200
+ ...(!!ownerState.onClick &&
201
+ (ownerState.variant === 'outlined' ||
202
+ ownerState.variant === 'filled') && {
203
+ '&:hover': {
204
+ cursor: 'pointer',
205
+ backgroundColor:
206
+ theme.palette.mode === 'light'
207
+ ? darken(theme.palette.background.paper, 0.02)
208
+ : lighten(theme.palette.background.paper, 0.02),
209
+ },
210
+ }),
211
+ ...(!!ownerState.onClick &&
212
+ ownerState.variant === 'elevation' && {
213
+ '&:hover': {
214
+ cursor: 'pointer',
215
+ filter: `drop-shadow(0 1px 4px ${alpha(theme.palette.common.black, 0.08)})`,
216
+ },
217
+ }),
218
+ ...(typeof root === 'object' && root),
219
+ ...(!!ownerState.onClick &&
220
+ !!rootHover && {
221
+ '&:hover': {
222
+ ...rootHover,
223
+ },
224
+ }),
225
+ ...(!ownerState.onClick && {
226
+ '&:hover': {},
227
+ }),
228
+ };
229
+ },
230
+ },
231
+ variants: widgetTheme.components?.MuiCard?.variants ?? [
232
+ {
233
+ props: { variant: 'outlined' },
234
+ style: ({ theme }) => ({
235
+ borderWidth: 1,
236
+ borderStyle: 'solid',
237
+ borderColor:
238
+ theme.palette.mode === 'light'
239
+ ? theme.palette.grey[300]
240
+ : theme.palette.grey[800],
241
+ }),
242
+ },
243
+ {
244
+ props: { variant: 'elevation' },
245
+ style: ({ theme }) => ({
246
+ border: 'none',
247
+ boxShadow: 'none',
248
+ filter: `drop-shadow(0 1px 4px ${alpha(theme.palette.common.black, 0.04)})`,
249
+ }),
250
+ },
251
+ {
252
+ props: { variant: 'filled' },
253
+ style: {
254
+ border: 'none',
255
+ },
256
+ },
257
+ ],
258
+ },
259
+ MuiInputCard: {
260
+ ...widgetTheme.components?.MuiInputCard,
261
+ },
262
+ MuiButtonBase: {
263
+ styleOverrides: {
264
+ // This `css()` function invokes keyframes. `styled-components` only supports keyframes
265
+ // in string templates. Do not convert these styles in JS object as it will break.
266
+ root: css`
267
+ &
268
+ .${touchRippleClasses.ripple}.${touchRippleClasses.rippleVisible} {
269
+ opacity: 0.1;
270
+ animation-name: ${enterKeyframe};
271
+ }
272
+ `,
273
+ },
274
+ },
275
+ MuiButton: {
276
+ defaultProps: {
277
+ disableElevation: true,
278
+ ...widgetTheme.components?.MuiButton?.defaultProps,
279
+ },
280
+ styleOverrides: {
281
+ root: ({ theme, ownerState }) => ({
282
+ borderRadius: borderRadiusSecondary,
283
+ textTransform: 'none',
284
+ fontSize: 16,
285
+ fontWeight: 600,
286
+ [`&.Mui-disabled, &.Mui-disabled:hover`]: {
287
+ color: alpha(
288
+ mode === 'light' ? palette.common.black : palette.common.white,
289
+ 0.56,
290
+ ),
291
+ cursor: 'not-allowed',
292
+ pointerEvents: 'auto',
293
+ },
294
+ [`&.${loadingButtonClasses.loading}.Mui-disabled`]: {
295
+ backgroundColor: primaryMainColor,
296
+ color: contrastButtonColor,
297
+ cursor: 'auto',
298
+ pointerEvents: 'auto',
299
+ },
300
+ [`.${loadingButtonClasses.loadingIndicator}`]: {
301
+ color: contrastButtonColor,
302
+ },
303
+ [`&.${loadingButtonClasses.root}.${loadingButtonClasses.loading}`]:
304
+ {
305
+ color: 'transparent',
306
+ },
307
+ ...getStyleOverrides('MuiButton', 'root', widgetTheme, ownerState),
308
+ }),
309
+ text: ({ theme, ownerState }) => ({
310
+ backgroundColor:
311
+ mode === 'light'
312
+ ? alpha(primaryMainColor, 0.08)
313
+ : alpha(primaryMainColor, 0.42),
314
+ '&:hover': {
315
+ backgroundColor:
316
+ mode === 'light'
317
+ ? alpha(primaryMainColor, 0.12)
318
+ : alpha(primaryMainColor, 0.56),
319
+ },
320
+ color:
321
+ mode === 'light' ? primaryMainColor : contrastTextButtonColor,
322
+ ...getStyleOverrides('MuiButton', 'text', widgetTheme, ownerState),
323
+ }),
324
+ contained: ({ theme, ownerState }) => ({
325
+ '&:hover': {
326
+ color: contrastButtonColor,
327
+ },
328
+ ...getStyleOverrides(
329
+ 'MuiButton',
330
+ 'contained',
331
+ widgetTheme,
332
+ ownerState,
333
+ ),
334
+ }),
335
+ sizeMedium: ({ theme, ownerState }) => ({
336
+ padding: '10px 14px',
337
+ [`.${dialogActionsClasses.root} &`]: {
338
+ padding: '6px 12px',
339
+ },
340
+ ...getStyleOverrides(
341
+ 'MuiButton',
342
+ 'sizeMedium',
343
+ widgetTheme,
344
+ ownerState,
345
+ ),
346
+ }),
347
+ },
348
+ },
349
+ MuiIconButton: {
350
+ ...widgetTheme.components?.MuiIconButton,
351
+ styleOverrides: {
352
+ ...widgetTheme.components?.MuiIconButton?.styleOverrides,
353
+ root: ({ theme, ownerState }) => ({
354
+ color: 'inherit',
355
+ '&:hover': {
356
+ color: 'inherit',
357
+ },
358
+ ...getStyleOverrides(
359
+ 'MuiIconButton',
360
+ 'root',
361
+ widgetTheme,
362
+ ownerState,
363
+ ),
364
+ }),
365
+ },
366
+ },
367
+ MuiAvatar: {
368
+ styleOverrides: {
369
+ root: {
370
+ height: 40,
371
+ width: 40,
372
+ },
373
+ img: {
374
+ objectFit: 'contain',
375
+ },
376
+ },
377
+ ...widgetTheme.components?.MuiAvatar,
378
+ },
379
+ MuiListItemText: {
380
+ styleOverrides: {
381
+ primary: ({ theme }) => ({
382
+ fontWeight: 600,
383
+ fontSize: '1.125rem',
384
+ lineHeight: '1.2778',
385
+ color: theme.palette.text.primary,
386
+ }),
387
+ secondary: ({ theme }) => ({
388
+ fontWeight: 500,
389
+ fontSize: '0.75rem',
390
+ color: theme.palette.text.secondary,
391
+ }),
392
+ },
393
+ },
394
+ MuiTooltip: {
395
+ styleOverrides: {
396
+ tooltip: ({ theme }) => ({
397
+ backgroundColor: 'rgb(0 0 0 / 64%)',
398
+ backdropFilter: 'blur(3px)',
399
+ fontSize: '0.75rem',
400
+ padding: theme.spacing(1, 1.5),
401
+ }),
402
+ arrow: {
403
+ color: 'rgb(0 0 0 / 64%)',
404
+ },
405
+ },
406
+ },
407
+ MuiMenu: {
408
+ styleOverrides: {
409
+ paper: ({ theme }) => ({
410
+ backgroundColor: theme.palette.background.default,
411
+ }),
412
+ },
413
+ },
414
+ },
415
+ });
416
+ };
@@ -0,0 +1,37 @@
1
+ import type { WidgetTheme } from '../types/widget.js';
2
+
3
+ export const jumperTheme: WidgetTheme = {
4
+ palette: {},
5
+ // shape: {
6
+ // borderRadius: 0,
7
+ // borderRadiusSecondary: 0,
8
+ // borderRadiusTertiary: 0,
9
+ // },
10
+ container: {},
11
+ playground: {},
12
+ components: {
13
+ MuiIconButton: {
14
+ styleOverrides: {
15
+ // root: ({ theme }) => ({
16
+ // backgroundColor: alpha(
17
+ // theme.palette.mode === 'light'
18
+ // ? theme.palette.common.black
19
+ // : theme.palette.common.white,
20
+ // 0.04,
21
+ // ),
22
+ // color: 'inherit',
23
+ // borderRadius: theme.shape.borderRadiusSecondary,
24
+ // '&:hover': {
25
+ // backgroundColor: alpha(
26
+ // theme.palette.mode === 'light'
27
+ // ? theme.palette.common.black
28
+ // : theme.palette.common.white,
29
+ // 0.08,
30
+ // ),
31
+ // color: 'inherit',
32
+ // },
33
+ // }),
34
+ },
35
+ },
36
+ },
37
+ };
@@ -0,0 +1,63 @@
1
+ import type {} from '@mui/lab/themeAugmentation';
2
+ import type {
3
+ CardProps,
4
+ ComponentsOverrides,
5
+ ComponentsVariants,
6
+ } from '@mui/material';
7
+ import type { CSSProperties } from 'react';
8
+ import type { NavigationProps } from '../types/widget.js';
9
+
10
+ // @mui/icons-material ESM issue
11
+ // https://github.com/mui/material-ui/issues/30671
12
+
13
+ // https://mui.com/customization/palette/
14
+ declare module '@mui/material/styles' {
15
+ interface TypographyVariants {
16
+ '@supports (font-variation-settings: normal)': React.CSSProperties;
17
+ }
18
+ interface TypographyVariantsOptions {
19
+ '@supports (font-variation-settings: normal)'?: React.CSSProperties;
20
+ }
21
+ interface Shape {
22
+ borderRadius: number;
23
+ borderRadiusSecondary: number;
24
+ borderRadiusTertiary: number;
25
+ }
26
+ interface Theme {
27
+ shape: Shape;
28
+ container: CSSProperties;
29
+ navigation: NavigationProps;
30
+ }
31
+ interface ThemeOptions {
32
+ shape?: Partial<Shape>;
33
+ container?: CSSProperties;
34
+ navigation?: NavigationProps;
35
+ }
36
+ interface ComponentNameToClassKey {
37
+ MuiInputCard: 'root';
38
+ }
39
+ interface ComponentsPropsList {
40
+ MuiInputCard: Partial<CardProps>;
41
+ }
42
+ interface Components {
43
+ MuiInputCard?: {
44
+ defaultProps?: ComponentsPropsList['MuiInputCard'];
45
+ styleOverrides?: ComponentsOverrides<
46
+ Omit<Theme, 'components'>
47
+ >['MuiInputCard'];
48
+ variants?: ComponentsVariants['MuiInputCard'];
49
+ };
50
+ }
51
+ }
52
+
53
+ declare module '@mui/material/Paper' {
54
+ interface PaperPropsVariantOverrides {
55
+ filled: true;
56
+ }
57
+ }
58
+
59
+ declare module '@mui/material/Typography' {
60
+ interface TypographyPropsVariantOverrides {
61
+ '@supports (font-variation-settings: normal)': true;
62
+ }
63
+ }
@@ -0,0 +1,18 @@
1
+ import type { WidgetTheme, WidgetThemeComponents } from '../types/widget.js';
2
+
3
+ type ComponentName = keyof WidgetThemeComponents;
4
+
5
+ export const getStyleOverrides = (
6
+ componentName: ComponentName,
7
+ styleOverrideProp: string,
8
+ theme: WidgetTheme,
9
+ ownerState?: any,
10
+ ) => {
11
+ const component = theme.components?.[componentName];
12
+ const property = (component?.styleOverrides as any)?.[styleOverrideProp];
13
+
14
+ if (typeof property === 'function') {
15
+ return property({ theme, ownerState });
16
+ }
17
+ return property;
18
+ };
@@ -0,0 +1,98 @@
1
+ import type { WidgetTheme } from '../types/widget.js';
2
+
3
+ export const windows95Theme: WidgetTheme = {
4
+ palette: {
5
+ primary: {
6
+ main: '#0000ff',
7
+ },
8
+ secondary: {
9
+ main: '#f7c303',
10
+ },
11
+ text: {
12
+ primary: '#30313d',
13
+ secondary: '#6d6e78',
14
+ },
15
+ background: {
16
+ default: '#c0c9d2',
17
+ paper: '#dfdfdf',
18
+ },
19
+ grey: {
20
+ 300: '#bbb',
21
+ },
22
+ },
23
+ shape: {
24
+ borderRadius: 0,
25
+ borderRadiusSecondary: 0,
26
+ borderRadiusTertiary: 0,
27
+ },
28
+ container: {
29
+ border: '1px solid #0a0a0a',
30
+ },
31
+ playground: {
32
+ background: '#008080',
33
+ },
34
+ components: {
35
+ MuiButton: {
36
+ styleOverrides: {
37
+ root: {
38
+ boxShadow:
39
+ 'inset -1px -1px #0a0a0a, inset 1px 1px #ffffff, inset -2px -2px #808080, inset 2px 2px #dfdfdf',
40
+ '&:hover': {
41
+ boxShadow:
42
+ 'inset -1px -1px #0a0a0a, inset 1px 1px #ffffff, inset -2px -2px #808080, inset 2px 2px #dfdfdf',
43
+ },
44
+ },
45
+ },
46
+ },
47
+ MuiCard: {
48
+ defaultProps: {
49
+ variant: 'outlined',
50
+ },
51
+ styleOverrides: {
52
+ root: {
53
+ boxShadow:
54
+ 'inset -1px -1px #0a0a0a, inset 1px 1px #ffffff, inset -2px -2px #808080, inset 2px 2px #dfdfdf',
55
+ borderWidth: 0,
56
+ '&:hover': {
57
+ cursor: 'pointer',
58
+ backgroundColor: '#ccc',
59
+ },
60
+ },
61
+ },
62
+ variants: [
63
+ {
64
+ props: { variant: 'outlined' },
65
+ style: {
66
+ borderWidth: 0,
67
+ },
68
+ },
69
+ ],
70
+ },
71
+ MuiInputCard: {
72
+ styleOverrides: {
73
+ root: {
74
+ backgroundColor: '#fff',
75
+ boxShadow:
76
+ 'inset -1px -1px #ffffff, inset 1px 1px #0a0a0a, inset -2px -2px #dfdfdf, inset 2px 2px #808080',
77
+ },
78
+ },
79
+ },
80
+ MuiIconButton: {
81
+ defaultProps: {
82
+ // disableRipple: true,
83
+ },
84
+ styleOverrides: {
85
+ root: {
86
+ borderRadius: 0,
87
+ boxShadow:
88
+ 'inset -1px -1px #0a0a0a, inset 1px 1px #ffffff, inset -2px -2px #808080, inset 2px 2px #dfdfdf',
89
+ backgroundColor: '#dfdfdf',
90
+ '&:hover': {
91
+ color: 'inherit',
92
+ backgroundColor: '#ccc',
93
+ },
94
+ },
95
+ },
96
+ },
97
+ },
98
+ };
package/types/events.ts CHANGED
@@ -12,6 +12,7 @@ export enum WidgetEvent {
12
12
  SendToWalletToggled = 'sendToWalletToggled',
13
13
  ReviewTransactionPageEntered = 'reviewTransactionPageEntered',
14
14
  WalletConnected = 'walletConnected',
15
+ WidgetExpanded = 'widgetExpanded',
15
16
  }
16
17
 
17
18
  export type WidgetEvents = {
@@ -26,6 +27,7 @@ export type WidgetEvents = {
26
27
  sendToWalletToggled: boolean;
27
28
  reviewTransactionPageEntered?: Route;
28
29
  walletConnected: WalletConnected;
30
+ widgetExpanded: boolean;
29
31
  };
30
32
 
31
33
  export interface ContactSupport {