@bosonprotocol/react-kit 0.33.0-alpha.2 → 0.33.0-alpha.20

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 (346) hide show
  1. package/dist/cjs/components/buttons/BaseButton.d.ts +1 -0
  2. package/dist/cjs/components/buttons/BaseButton.d.ts.map +1 -1
  3. package/dist/cjs/components/buttons/BaseButton.js +1 -0
  4. package/dist/cjs/components/buttons/BaseButton.js.map +1 -1
  5. package/dist/cjs/components/error/SimpleError.d.ts +2 -2
  6. package/dist/cjs/components/error/SimpleError.d.ts.map +1 -1
  7. package/dist/cjs/components/error/SimpleError.js.map +1 -1
  8. package/dist/cjs/components/form/BaseCheckbox.d.ts +5 -0
  9. package/dist/cjs/components/form/BaseCheckbox.d.ts.map +1 -0
  10. package/dist/cjs/components/form/BaseCheckbox.js +69 -0
  11. package/dist/cjs/components/form/BaseCheckbox.js.map +1 -0
  12. package/dist/cjs/components/form/Checkbox.d.ts +13 -2
  13. package/dist/cjs/components/form/Checkbox.d.ts.map +1 -1
  14. package/dist/cjs/components/form/Checkbox.js +18 -61
  15. package/dist/cjs/components/form/Checkbox.js.map +1 -1
  16. package/dist/cjs/components/form/CountrySelect.d.ts +26 -11
  17. package/dist/cjs/components/form/CountrySelect.d.ts.map +1 -1
  18. package/dist/cjs/components/form/CountrySelect.js +64 -31
  19. package/dist/cjs/components/form/CountrySelect.js.map +1 -1
  20. package/dist/cjs/components/form/Field.styles.d.ts +36 -2
  21. package/dist/cjs/components/form/Field.styles.d.ts.map +1 -1
  22. package/dist/cjs/components/form/Field.styles.js +83 -24
  23. package/dist/cjs/components/form/Field.styles.js.map +1 -1
  24. package/dist/cjs/components/form/FormField.d.ts +2 -1
  25. package/dist/cjs/components/form/FormField.d.ts.map +1 -1
  26. package/dist/cjs/components/form/FormField.js +14 -2
  27. package/dist/cjs/components/form/FormField.js.map +1 -1
  28. package/dist/cjs/components/form/Select.d.ts +2 -1
  29. package/dist/cjs/components/form/Select.d.ts.map +1 -1
  30. package/dist/cjs/components/form/Select.js +32 -20
  31. package/dist/cjs/components/form/Select.js.map +1 -1
  32. package/dist/cjs/components/form/Upload/BaseUpload.d.ts +71 -0
  33. package/dist/cjs/components/form/Upload/BaseUpload.d.ts.map +1 -0
  34. package/dist/cjs/components/form/Upload/BaseUpload.js +264 -0
  35. package/dist/cjs/components/form/Upload/BaseUpload.js.map +1 -0
  36. package/dist/cjs/components/form/Upload/Upload.d.ts +3 -41
  37. package/dist/cjs/components/form/Upload/Upload.d.ts.map +1 -1
  38. package/dist/cjs/components/form/Upload/Upload.js +7 -258
  39. package/dist/cjs/components/form/Upload/Upload.js.map +1 -1
  40. package/dist/cjs/components/form/Upload/UploadedFile.js +2 -2
  41. package/dist/cjs/components/form/Upload/UploadedFile.js.map +1 -1
  42. package/dist/cjs/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
  43. package/dist/cjs/components/form/Upload/WithUploadToIpfs.js +9 -12
  44. package/dist/cjs/components/form/Upload/WithUploadToIpfs.js.map +1 -1
  45. package/dist/cjs/components/form/index.d.ts +6 -4
  46. package/dist/cjs/components/form/index.d.ts.map +1 -1
  47. package/dist/cjs/components/form/index.js +7 -3
  48. package/dist/cjs/components/form/index.js.map +1 -1
  49. package/dist/cjs/components/form/types.d.ts +31 -3
  50. package/dist/cjs/components/form/types.d.ts.map +1 -1
  51. package/dist/cjs/components/image/Image.js +2 -2
  52. package/dist/cjs/components/image/Image.js.map +1 -1
  53. package/dist/cjs/components/image/Image.styles.d.ts +2 -1
  54. package/dist/cjs/components/image/Image.styles.d.ts.map +1 -1
  55. package/dist/cjs/components/image/Image.styles.js +2 -2
  56. package/dist/cjs/components/image/Image.styles.js.map +1 -1
  57. package/dist/cjs/components/modal/components/Commit/DetailView/InnerCommitDetailView.js +3 -3
  58. package/dist/cjs/components/modal/components/Commit/DetailView/InnerCommitDetailView.js.map +1 -1
  59. package/dist/cjs/components/modal/components/Redeem/ExchangeView/RedeemSuccess.js +3 -3
  60. package/dist/cjs/components/modal/components/Redeem/ExchangeView/RedeemSuccess.js.map +1 -1
  61. package/dist/cjs/components/modal/components/common/OfferFullDescription/DigitalProductData.js +2 -2
  62. package/dist/cjs/components/modal/components/common/OfferFullDescription/DigitalProductData.js.map +1 -1
  63. package/dist/cjs/components/modal/components/common/detail/DetailSlider.js +2 -2
  64. package/dist/cjs/components/modal/components/common/detail/DetailSlider.js.map +1 -1
  65. package/dist/cjs/components/modal/components/common/detail/PhygitalProduct.js +2 -2
  66. package/dist/cjs/components/modal/components/common/detail/PhygitalProduct.js.map +1 -1
  67. package/dist/cjs/components/modal/components/common/detail/SlickSlider.js +2 -2
  68. package/dist/cjs/components/modal/components/common/detail/SlickSlider.js.map +1 -1
  69. package/dist/cjs/components/ui/CardCTA.d.ts +21 -0
  70. package/dist/cjs/components/ui/CardCTA.d.ts.map +1 -0
  71. package/dist/cjs/components/ui/CardCTA.js +77 -0
  72. package/dist/cjs/components/ui/CardCTA.js.map +1 -0
  73. package/dist/cjs/components/ui/Grid.d.ts.map +1 -1
  74. package/dist/cjs/components/ui/Grid.js +22 -21
  75. package/dist/cjs/components/ui/Grid.js.map +1 -1
  76. package/dist/cjs/components/ui/IpfsImage.d.ts +5 -4
  77. package/dist/cjs/components/ui/IpfsImage.d.ts.map +1 -1
  78. package/dist/cjs/components/ui/IpfsImage.js +4 -3
  79. package/dist/cjs/components/ui/IpfsImage.js.map +1 -1
  80. package/dist/cjs/components/ui/Typography.d.ts.map +1 -1
  81. package/dist/cjs/components/ui/Typography.js +29 -28
  82. package/dist/cjs/components/ui/Typography.js.map +1 -1
  83. package/dist/cjs/components/ui/Video.d.ts +3 -3
  84. package/dist/cjs/components/ui/Video.d.ts.map +1 -1
  85. package/dist/cjs/components/ui/Video.js +26 -14
  86. package/dist/cjs/components/ui/Video.js.map +1 -1
  87. package/dist/cjs/components/ui/common.d.ts +2 -0
  88. package/dist/cjs/components/ui/common.d.ts.map +1 -0
  89. package/dist/cjs/components/ui/common.js +6 -0
  90. package/dist/cjs/components/ui/common.js.map +1 -0
  91. package/dist/cjs/components/wallet/ConnectButton.js +2 -2
  92. package/dist/cjs/components/wallet/ConnectButton.js.map +1 -1
  93. package/dist/cjs/components/widgets/finance/convertion-rate/ConvertionRateContext.js +2 -2
  94. package/dist/cjs/components/widgets/finance/convertion-rate/ConvertionRateContext.js.map +1 -1
  95. package/dist/cjs/components/widgets/finance/convertion-rate/ConvertionRateProvider.js +2 -2
  96. package/dist/cjs/components/widgets/finance/convertion-rate/ConvertionRateProvider.js.map +1 -1
  97. package/dist/cjs/components/widgets/finance/useOffersBacked.js +1 -1
  98. package/dist/cjs/components/widgets/finance/useOffersBacked.js.map +1 -1
  99. package/dist/cjs/hooks/core-sdk/useCoreSdk.d.ts.map +1 -1
  100. package/dist/cjs/hooks/core-sdk/useCoreSdk.js +2 -2
  101. package/dist/cjs/hooks/core-sdk/useCoreSdk.js.map +1 -1
  102. package/dist/cjs/hooks/form/useForm.d.ts +55 -0
  103. package/dist/cjs/hooks/form/useForm.d.ts.map +1 -0
  104. package/dist/cjs/hooks/form/useForm.js +11 -0
  105. package/dist/cjs/hooks/form/useForm.js.map +1 -0
  106. package/dist/cjs/hooks/index.d.ts +5 -0
  107. package/dist/cjs/hooks/index.d.ts.map +1 -1
  108. package/dist/cjs/hooks/index.js +5 -0
  109. package/dist/cjs/hooks/index.js.map +1 -1
  110. package/dist/cjs/hooks/ipfs/useIpfsStorage.d.ts +2 -0
  111. package/dist/cjs/hooks/ipfs/useIpfsStorage.d.ts.map +1 -0
  112. package/dist/cjs/hooks/ipfs/useIpfsStorage.js +14 -0
  113. package/dist/cjs/hooks/ipfs/useIpfsStorage.js.map +1 -0
  114. package/dist/cjs/hooks/location/buildUseSearchParams.d.ts +12 -0
  115. package/dist/cjs/hooks/location/buildUseSearchParams.d.ts.map +1 -0
  116. package/dist/cjs/hooks/location/buildUseSearchParams.js +36 -0
  117. package/dist/cjs/hooks/location/buildUseSearchParams.js.map +1 -0
  118. package/dist/cjs/{components/widgets/finance/storage/useLocalStorage.d.ts → hooks/storage/useBosonLocalStorage.d.ts} +3 -3
  119. package/dist/cjs/hooks/storage/useBosonLocalStorage.d.ts.map +1 -0
  120. package/dist/cjs/hooks/storage/useBosonLocalStorage.js +22 -0
  121. package/dist/cjs/hooks/storage/useBosonLocalStorage.js.map +1 -0
  122. package/dist/cjs/hooks/storage/useLocalStorage.d.ts +6 -0
  123. package/dist/cjs/hooks/storage/useLocalStorage.d.ts.map +1 -0
  124. package/dist/cjs/hooks/storage/useLocalStorage.js.map +1 -0
  125. package/dist/cjs/hooks/useIpfsMetadataStorage.d.ts.map +1 -1
  126. package/dist/cjs/hooks/useIpfsMetadataStorage.js +1 -1
  127. package/dist/cjs/hooks/useIpfsMetadataStorage.js.map +1 -1
  128. package/dist/cjs/index.d.ts +6 -0
  129. package/dist/cjs/index.d.ts.map +1 -1
  130. package/dist/cjs/index.js +8 -1
  131. package/dist/cjs/index.js.map +1 -1
  132. package/dist/cjs/lib/bytes/bytesToSize.d.ts +1 -1
  133. package/dist/cjs/lib/bytes/bytesToSize.d.ts.map +1 -1
  134. package/dist/cjs/lib/bytes/bytesToSize.js +2 -1
  135. package/dist/cjs/lib/bytes/bytesToSize.js.map +1 -1
  136. package/dist/cjs/lib/const/chainInfo.d.ts.map +1 -1
  137. package/dist/cjs/lib/const/chainInfo.js +10 -0
  138. package/dist/cjs/lib/const/chainInfo.js.map +1 -1
  139. package/dist/cjs/lib/url/url.d.ts +1 -0
  140. package/dist/cjs/lib/url/url.d.ts.map +1 -1
  141. package/dist/cjs/lib/url/url.js +2 -1
  142. package/dist/cjs/lib/url/url.js.map +1 -1
  143. package/dist/cjs/types/helpers.d.ts +3 -0
  144. package/dist/cjs/types/helpers.d.ts.map +1 -1
  145. package/dist/cjs/types/helpers.js.map +1 -1
  146. package/dist/esm/components/buttons/BaseButton.d.ts +1 -0
  147. package/dist/esm/components/buttons/BaseButton.d.ts.map +1 -1
  148. package/dist/esm/components/buttons/BaseButton.js +1 -0
  149. package/dist/esm/components/buttons/BaseButton.js.map +1 -1
  150. package/dist/esm/components/error/SimpleError.d.ts +2 -2
  151. package/dist/esm/components/error/SimpleError.d.ts.map +1 -1
  152. package/dist/esm/components/error/SimpleError.js.map +1 -1
  153. package/dist/esm/components/form/BaseCheckbox.d.ts +5 -0
  154. package/dist/esm/components/form/BaseCheckbox.d.ts.map +1 -0
  155. package/dist/esm/components/form/BaseCheckbox.js +27 -0
  156. package/dist/esm/components/form/BaseCheckbox.js.map +1 -0
  157. package/dist/esm/components/form/Checkbox.d.ts +13 -2
  158. package/dist/esm/components/form/Checkbox.d.ts.map +1 -1
  159. package/dist/esm/components/form/Checkbox.js +16 -25
  160. package/dist/esm/components/form/Checkbox.js.map +1 -1
  161. package/dist/esm/components/form/CountrySelect.d.ts +26 -11
  162. package/dist/esm/components/form/CountrySelect.d.ts.map +1 -1
  163. package/dist/esm/components/form/CountrySelect.js +97 -67
  164. package/dist/esm/components/form/CountrySelect.js.map +1 -1
  165. package/dist/esm/components/form/Field.styles.d.ts +36 -2
  166. package/dist/esm/components/form/Field.styles.d.ts.map +1 -1
  167. package/dist/esm/components/form/Field.styles.js +58 -20
  168. package/dist/esm/components/form/Field.styles.js.map +1 -1
  169. package/dist/esm/components/form/FormField.d.ts +2 -1
  170. package/dist/esm/components/form/FormField.d.ts.map +1 -1
  171. package/dist/esm/components/form/FormField.js +2 -2
  172. package/dist/esm/components/form/FormField.js.map +1 -1
  173. package/dist/esm/components/form/Select.d.ts +2 -1
  174. package/dist/esm/components/form/Select.d.ts.map +1 -1
  175. package/dist/esm/components/form/Select.js +52 -30
  176. package/dist/esm/components/form/Select.js.map +1 -1
  177. package/dist/esm/components/form/Upload/BaseUpload.d.ts +71 -0
  178. package/dist/esm/components/form/Upload/BaseUpload.d.ts.map +1 -0
  179. package/dist/esm/components/form/Upload/BaseUpload.js +226 -0
  180. package/dist/esm/components/form/Upload/BaseUpload.js.map +1 -0
  181. package/dist/esm/components/form/Upload/Upload.d.ts +3 -41
  182. package/dist/esm/components/form/Upload/Upload.d.ts.map +1 -1
  183. package/dist/esm/components/form/Upload/Upload.js +5 -225
  184. package/dist/esm/components/form/Upload/Upload.js.map +1 -1
  185. package/dist/esm/components/form/Upload/UploadedFile.js +1 -1
  186. package/dist/esm/components/form/Upload/UploadedFile.js.map +1 -1
  187. package/dist/esm/components/form/Upload/WithUploadToIpfs.d.ts.map +1 -1
  188. package/dist/esm/components/form/Upload/WithUploadToIpfs.js +8 -11
  189. package/dist/esm/components/form/Upload/WithUploadToIpfs.js.map +1 -1
  190. package/dist/esm/components/form/index.d.ts +6 -4
  191. package/dist/esm/components/form/index.d.ts.map +1 -1
  192. package/dist/esm/components/form/index.js +4 -2
  193. package/dist/esm/components/form/index.js.map +1 -1
  194. package/dist/esm/components/form/types.d.ts +31 -3
  195. package/dist/esm/components/form/types.d.ts.map +1 -1
  196. package/dist/esm/components/image/Image.js +2 -2
  197. package/dist/esm/components/image/Image.js.map +1 -1
  198. package/dist/esm/components/image/Image.styles.d.ts +2 -1
  199. package/dist/esm/components/image/Image.styles.d.ts.map +1 -1
  200. package/dist/esm/components/image/Image.styles.js +2 -2
  201. package/dist/esm/components/image/Image.styles.js.map +1 -1
  202. package/dist/esm/components/modal/components/Commit/DetailView/InnerCommitDetailView.js +1 -1
  203. package/dist/esm/components/modal/components/Commit/DetailView/InnerCommitDetailView.js.map +1 -1
  204. package/dist/esm/components/modal/components/Redeem/ExchangeView/RedeemSuccess.js +1 -1
  205. package/dist/esm/components/modal/components/Redeem/ExchangeView/RedeemSuccess.js.map +1 -1
  206. package/dist/esm/components/modal/components/common/OfferFullDescription/DigitalProductData.js +1 -1
  207. package/dist/esm/components/modal/components/common/OfferFullDescription/DigitalProductData.js.map +1 -1
  208. package/dist/esm/components/modal/components/common/detail/DetailSlider.js +1 -1
  209. package/dist/esm/components/modal/components/common/detail/DetailSlider.js.map +1 -1
  210. package/dist/esm/components/modal/components/common/detail/PhygitalProduct.js +1 -1
  211. package/dist/esm/components/modal/components/common/detail/PhygitalProduct.js.map +1 -1
  212. package/dist/esm/components/modal/components/common/detail/SlickSlider.js +1 -1
  213. package/dist/esm/components/modal/components/common/detail/SlickSlider.js.map +1 -1
  214. package/dist/esm/components/ui/CardCTA.d.ts +21 -0
  215. package/dist/esm/components/ui/CardCTA.d.ts.map +1 -0
  216. package/dist/esm/components/ui/CardCTA.js +35 -0
  217. package/dist/esm/components/ui/CardCTA.js.map +1 -0
  218. package/dist/esm/components/ui/Grid.d.ts.map +1 -1
  219. package/dist/esm/components/ui/Grid.js +22 -21
  220. package/dist/esm/components/ui/Grid.js.map +1 -1
  221. package/dist/esm/components/ui/IpfsImage.d.ts +5 -4
  222. package/dist/esm/components/ui/IpfsImage.d.ts.map +1 -1
  223. package/dist/esm/components/ui/IpfsImage.js +3 -4
  224. package/dist/esm/components/ui/IpfsImage.js.map +1 -1
  225. package/dist/esm/components/ui/Typography.d.ts.map +1 -1
  226. package/dist/esm/components/ui/Typography.js +29 -28
  227. package/dist/esm/components/ui/Typography.js.map +1 -1
  228. package/dist/esm/components/ui/Video.d.ts +3 -3
  229. package/dist/esm/components/ui/Video.d.ts.map +1 -1
  230. package/dist/esm/components/ui/Video.js +24 -14
  231. package/dist/esm/components/ui/Video.js.map +1 -1
  232. package/dist/esm/components/ui/common.d.ts +2 -0
  233. package/dist/esm/components/ui/common.d.ts.map +1 -0
  234. package/dist/esm/components/ui/common.js +2 -0
  235. package/dist/esm/components/ui/common.js.map +1 -0
  236. package/dist/esm/components/wallet/ConnectButton.js +1 -1
  237. package/dist/esm/components/wallet/ConnectButton.js.map +1 -1
  238. package/dist/esm/components/widgets/finance/convertion-rate/ConvertionRateContext.js +1 -1
  239. package/dist/esm/components/widgets/finance/convertion-rate/ConvertionRateContext.js.map +1 -1
  240. package/dist/esm/components/widgets/finance/convertion-rate/ConvertionRateProvider.js +1 -1
  241. package/dist/esm/components/widgets/finance/convertion-rate/ConvertionRateProvider.js.map +1 -1
  242. package/dist/esm/components/widgets/finance/useOffersBacked.js +1 -1
  243. package/dist/esm/components/widgets/finance/useOffersBacked.js.map +1 -1
  244. package/dist/esm/hooks/core-sdk/useCoreSdk.d.ts.map +1 -1
  245. package/dist/esm/hooks/core-sdk/useCoreSdk.js +3 -3
  246. package/dist/esm/hooks/core-sdk/useCoreSdk.js.map +1 -1
  247. package/dist/esm/hooks/form/useForm.d.ts +55 -0
  248. package/dist/esm/hooks/form/useForm.d.ts.map +1 -0
  249. package/dist/esm/hooks/form/useForm.js +10 -0
  250. package/dist/esm/hooks/form/useForm.js.map +1 -0
  251. package/dist/esm/hooks/index.d.ts +5 -0
  252. package/dist/esm/hooks/index.d.ts.map +1 -1
  253. package/dist/esm/hooks/index.js +5 -0
  254. package/dist/esm/hooks/index.js.map +1 -1
  255. package/dist/esm/hooks/ipfs/useIpfsStorage.d.ts +2 -0
  256. package/dist/esm/hooks/ipfs/useIpfsStorage.d.ts.map +1 -0
  257. package/dist/esm/hooks/ipfs/useIpfsStorage.js +10 -0
  258. package/dist/esm/hooks/ipfs/useIpfsStorage.js.map +1 -0
  259. package/dist/esm/hooks/location/buildUseSearchParams.d.ts +12 -0
  260. package/dist/esm/hooks/location/buildUseSearchParams.d.ts.map +1 -0
  261. package/dist/esm/hooks/location/buildUseSearchParams.js +32 -0
  262. package/dist/esm/hooks/location/buildUseSearchParams.js.map +1 -0
  263. package/dist/esm/{components/widgets/finance/storage/useLocalStorage.d.ts → hooks/storage/useBosonLocalStorage.d.ts} +3 -3
  264. package/dist/esm/hooks/storage/useBosonLocalStorage.d.ts.map +1 -0
  265. package/dist/esm/hooks/storage/useBosonLocalStorage.js +15 -0
  266. package/dist/esm/hooks/storage/useBosonLocalStorage.js.map +1 -0
  267. package/dist/esm/hooks/storage/useLocalStorage.d.ts +6 -0
  268. package/dist/esm/hooks/storage/useLocalStorage.d.ts.map +1 -0
  269. package/dist/esm/hooks/storage/useLocalStorage.js.map +1 -0
  270. package/dist/esm/hooks/useIpfsMetadataStorage.d.ts.map +1 -1
  271. package/dist/esm/hooks/useIpfsMetadataStorage.js +2 -2
  272. package/dist/esm/hooks/useIpfsMetadataStorage.js.map +1 -1
  273. package/dist/esm/index.d.ts +6 -0
  274. package/dist/esm/index.d.ts.map +1 -1
  275. package/dist/esm/index.js +6 -0
  276. package/dist/esm/index.js.map +1 -1
  277. package/dist/esm/lib/bytes/bytesToSize.d.ts +1 -1
  278. package/dist/esm/lib/bytes/bytesToSize.d.ts.map +1 -1
  279. package/dist/esm/lib/bytes/bytesToSize.js +1 -1
  280. package/dist/esm/lib/bytes/bytesToSize.js.map +1 -1
  281. package/dist/esm/lib/const/chainInfo.d.ts.map +1 -1
  282. package/dist/esm/lib/const/chainInfo.js +10 -0
  283. package/dist/esm/lib/const/chainInfo.js.map +1 -1
  284. package/dist/esm/lib/url/url.d.ts +1 -0
  285. package/dist/esm/lib/url/url.d.ts.map +1 -1
  286. package/dist/esm/lib/url/url.js +1 -0
  287. package/dist/esm/lib/url/url.js.map +1 -1
  288. package/dist/esm/types/helpers.d.ts +3 -0
  289. package/dist/esm/types/helpers.d.ts.map +1 -1
  290. package/dist/esm/types/helpers.js.map +1 -1
  291. package/package.json +5 -5
  292. package/src/components/buttons/BaseButton.tsx +4 -0
  293. package/src/components/error/SimpleError.tsx +2 -2
  294. package/src/components/form/BaseCheckbox.tsx +50 -0
  295. package/src/components/form/Checkbox.tsx +17 -40
  296. package/src/components/form/CountrySelect.tsx +178 -130
  297. package/src/components/form/Field.styles.ts +113 -24
  298. package/src/components/form/FormField.tsx +4 -1
  299. package/src/components/form/Select.tsx +65 -34
  300. package/src/components/form/Upload/BaseUpload.tsx +367 -0
  301. package/src/components/form/Upload/Upload.tsx +8 -360
  302. package/src/components/form/Upload/UploadedFile.tsx +1 -1
  303. package/src/components/form/Upload/WithUploadToIpfs.tsx +8 -11
  304. package/src/components/form/index.ts +6 -4
  305. package/src/components/form/types.ts +31 -3
  306. package/src/components/image/Image.styles.ts +7 -5
  307. package/src/components/image/Image.tsx +2 -2
  308. package/src/components/modal/components/Commit/DetailView/InnerCommitDetailView.tsx +1 -1
  309. package/src/components/modal/components/Redeem/ExchangeView/RedeemSuccess.tsx +1 -1
  310. package/src/components/modal/components/common/OfferFullDescription/DigitalProductData.tsx +1 -1
  311. package/src/components/modal/components/common/detail/DetailSlider.tsx +1 -1
  312. package/src/components/modal/components/common/detail/PhygitalProduct.tsx +1 -1
  313. package/src/components/modal/components/common/detail/SlickSlider.tsx +1 -1
  314. package/src/components/ui/CardCTA.tsx +77 -0
  315. package/src/components/ui/Grid.tsx +33 -21
  316. package/src/components/ui/IpfsImage.tsx +14 -7
  317. package/src/components/ui/Typography.tsx +39 -29
  318. package/src/components/ui/Video.tsx +32 -18
  319. package/src/components/ui/common.ts +2 -0
  320. package/src/components/wallet/ConnectButton.tsx +1 -1
  321. package/src/components/widgets/finance/convertion-rate/ConvertionRateContext.tsx +1 -1
  322. package/src/components/widgets/finance/convertion-rate/ConvertionRateProvider.tsx +1 -1
  323. package/src/components/widgets/finance/useOffersBacked.ts +1 -1
  324. package/src/hooks/core-sdk/useCoreSdk.tsx +4 -3
  325. package/src/hooks/form/useForm.ts +12 -0
  326. package/src/hooks/index.ts +5 -0
  327. package/src/hooks/ipfs/useIpfsStorage.ts +16 -0
  328. package/src/hooks/location/buildUseSearchParams.tsx +45 -0
  329. package/src/hooks/storage/useBosonLocalStorage.ts +40 -0
  330. package/src/{components/widgets/finance → hooks}/storage/useLocalStorage.ts +5 -17
  331. package/src/hooks/useIpfsMetadataStorage.tsx +6 -2
  332. package/src/index.tsx +6 -0
  333. package/src/lib/bytes/bytesToSize.ts +1 -1
  334. package/src/lib/const/chainInfo.ts +10 -1
  335. package/src/lib/url/url.ts +3 -0
  336. package/src/stories/buttons/Upload.stories.tsx +8 -0
  337. package/src/stories/form/BaseCheckbox.stories.tsx +113 -0
  338. package/src/stories/selects/CountrySelect.stories.tsx +49 -11
  339. package/src/stories/selects/Select.stories.tsx +117 -0
  340. package/src/types/helpers.ts +4 -0
  341. package/dist/cjs/components/widgets/finance/storage/useLocalStorage.d.ts.map +0 -1
  342. package/dist/cjs/components/widgets/finance/storage/useLocalStorage.js.map +0 -1
  343. package/dist/esm/components/widgets/finance/storage/useLocalStorage.d.ts.map +0 -1
  344. package/dist/esm/components/widgets/finance/storage/useLocalStorage.js.map +0 -1
  345. /package/dist/cjs/{components/widgets/finance → hooks}/storage/useLocalStorage.js +0 -0
  346. /package/dist/esm/{components/widgets/finance → hooks}/storage/useLocalStorage.js +0 -0
@@ -4,18 +4,31 @@ import { GlobeHemisphereWest } from "phosphor-react";
4
4
  import React, { forwardRef, useState, useEffect } from "react";
5
5
  import type { Country as CountryCode } from "react-phone-number-input";
6
6
  import PhoneInput from "react-phone-number-input";
7
- import Select, { GroupBase, StylesConfig, components } from "react-select";
7
+ import Select, {
8
+ CSSObjectWithLabel,
9
+ GroupBase,
10
+ StylesConfig,
11
+ components
12
+ } from "react-select";
8
13
  import styled, { CSSProperties } from "styled-components";
9
14
  import { zIndex } from "../ui/zIndex";
10
15
  import Error from "./Error";
11
16
  import type { InputProps } from "./types";
12
17
  import { SelectDataProps } from "./types";
13
18
  import { theme as importedTheme } from "../../theme";
19
+ import { checkIfValueIsEmpty } from "../../lib/object/checkIfValueIsEmpty";
14
20
  export type { Country as CountryCode } from "react-phone-number-input";
15
21
 
16
22
  const colors = importedTheme.colors.light;
17
- const customStyles = {
18
- control: (provided: any, state: any) => {
23
+ const customStyles = (
24
+ error: unknown,
25
+ customTheme: CountrySelectProps["theme"]
26
+ ): StylesConfig<
27
+ SelectDataProps<string>,
28
+ false,
29
+ GroupBase<SelectDataProps<string>>
30
+ > => ({
31
+ control: (provided, state: any) => {
19
32
  const before = state.selectProps.label
20
33
  ? {
21
34
  ":before": {
@@ -25,26 +38,27 @@ const customStyles = {
25
38
  }
26
39
  }
27
40
  : null;
28
- const { theme } = state;
29
41
  return {
30
42
  ...provided,
31
- borderRadius: theme.borderRadius,
32
- height: theme.controlHeight,
33
43
  alignContent: "center",
34
44
  padding: "0.4rem 1rem",
35
45
  boxShadow: "none",
46
+ background: colors.lightGrey,
47
+ ...customTheme?.control,
48
+ border: state.isFocused
49
+ ? customTheme?.control?.focus?.border ?? `1px solid ${colors.secondary}`
50
+ : !checkIfValueIsEmpty(error)
51
+ ? customTheme?.control?.error?.border ?? `1px solid ${colors.orange}`
52
+ : customTheme?.control?.border ?? `1px solid ${colors.border}`,
36
53
  ":hover": {
37
- borderColor: theme.colors.controlHoverBorderColor,
38
- borderWidth: "1px"
54
+ borderColor: colors.secondary,
55
+ borderWidth: "1px",
56
+ ...customTheme?.control?.hover
39
57
  },
40
- background: theme.colors.controlBackground,
41
- border: state.isFocused
42
- ? `1px solid ${theme.colors.controlFocusBorderColor}`
43
- : `1px solid ${theme.colors.controlUnfocusedBorderColor}`,
44
58
  ...before
45
59
  };
46
60
  },
47
- container: (provided: any, state: any) => {
61
+ container: (provided, state) => {
48
62
  return {
49
63
  ...provided,
50
64
  zIndex: state.isFocused ? zIndex.Select + 1 : zIndex.Select,
@@ -52,34 +66,56 @@ const customStyles = {
52
66
  width: "100%"
53
67
  };
54
68
  },
55
- option: (provided: any, state: any) => {
56
- const { theme } = state;
69
+ option: (provided, state: any) => {
57
70
  return {
58
71
  ...provided,
72
+ ...customTheme?.option,
59
73
  cursor: state.isDisabled ? "not-allowed" : "pointer",
60
- opacity: state.isDisabled ? "0.5" : "1",
74
+ opacity: state.isDisabled
75
+ ? customTheme?.option?.disabled?.opacity ?? "0.5"
76
+ : customTheme?.option?.opacity ?? "1",
61
77
  background:
62
78
  state.isOptionSelected || state.isSelected || state.isFocused
63
- ? theme.colors.selectedOptionBackground
64
- : theme.colors.unselectedOptionBackground,
79
+ ? customTheme?.option?.selected?.background ?? colors.lightGrey
80
+ : customTheme?.option?.background ?? colors.white,
65
81
  color:
66
82
  state.isOptionSelected || state.isSelected
67
- ? theme.colors.selectedOptionColor
68
- : theme.colors.unselectedOptionColor
83
+ ? customTheme?.option?.selected?.color ?? colors.secondary
84
+ : customTheme?.option?.color ?? colors.black,
85
+ ...(state.isDisabled && customTheme?.option?.disabled),
86
+ ...((state.isOptionSelected || state.isSelected) &&
87
+ customTheme?.option?.selected),
88
+ ...(state.isFocused && customTheme?.option?.focus),
89
+ ...(!checkIfValueIsEmpty(error) && customTheme?.option?.error)
90
+ };
91
+ },
92
+ menu: (provided) => {
93
+ return {
94
+ ...provided,
95
+ overflow: "hidden",
96
+ ...customTheme?.menu,
97
+ ...(!checkIfValueIsEmpty(error) && customTheme?.menu?.error)
69
98
  };
70
99
  },
71
- menu: (provided) => ({
72
- ...provided,
73
- overflow: "hidden"
74
- }),
75
100
  indicatorSeparator: () => ({
76
101
  display: "none"
102
+ }),
103
+ placeholder: (provided) => ({
104
+ ...provided,
105
+ ...customTheme?.placeholder,
106
+ ...(!checkIfValueIsEmpty(error) && customTheme?.placeholder?.error)
107
+ }),
108
+ input: (provided) => ({
109
+ ...provided,
110
+ ...customTheme?.input,
111
+ ...(!checkIfValueIsEmpty(error) && customTheme?.input?.error)
112
+ }),
113
+ singleValue: (provided) => ({
114
+ ...provided,
115
+ ...customTheme?.singleValue,
116
+ ...(!checkIfValueIsEmpty(error) && customTheme?.singleValue?.error)
77
117
  })
78
- } satisfies StylesConfig<
79
- SelectDataProps<string>,
80
- false,
81
- GroupBase<SelectDataProps<string>>
82
- >;
118
+ });
83
119
 
84
120
  const ControlGrid = styled.div`
85
121
  display: flex;
@@ -88,6 +124,7 @@ const ControlGrid = styled.div`
88
124
  align-items: center;
89
125
  justify-content: space-between;
90
126
  .PhoneInputCountryIcon {
127
+ max-width: fit-content;
91
128
  min-width: 40px;
92
129
  display: inline;
93
130
  height: 27px;
@@ -95,6 +132,9 @@ const ControlGrid = styled.div`
95
132
  max-width: 40px;
96
133
  }
97
134
  }
135
+ svg {
136
+ max-width: 40px;
137
+ }
98
138
  `;
99
139
  const OptionGrid = styled.div`
100
140
  display: grid;
@@ -122,38 +162,57 @@ const PhoneWrapper = styled.div`
122
162
 
123
163
  export type CountrySelectProps = InputProps & {
124
164
  countries?: CountryCode[];
165
+ fieldValueIsCountryCode?: boolean; // if true, the field.value will be the countryCodeOrName, otherwise the country name
125
166
  theme?: Partial<{
126
- controlHeight: CSSProperties["height"];
127
- borderRadius: CSSProperties["borderRadius"];
128
- controlHoverBorderColor: CSSProperties["borderColor"];
129
- controlBackground: CSSProperties["background"];
130
- controlFocusBorderColor: CSSProperties["borderColor"];
131
- controlUnfocusedBorderColor: CSSProperties["borderColor"];
132
- selectedOptionBackground: CSSProperties["background"];
133
- unselectedOptionBackground: CSSProperties["background"];
134
- selectedOptionColor: CSSProperties["color"];
135
- unselectedOptionColor: CSSProperties["color"];
167
+ control: Partial<CSSProperties> &
168
+ Partial<{
169
+ hover: Partial<CSSProperties>;
170
+ focus: Partial<CSSProperties>;
171
+ error: Partial<CSSProperties>;
172
+ }>;
173
+ option: Partial<CSSProperties> &
174
+ Partial<{
175
+ selected: Partial<CSSProperties>;
176
+ disabled: Partial<CSSProperties>;
177
+ focus: Partial<CSSProperties>;
178
+ error: CSSProperties;
179
+ }>;
180
+ placeholder: Partial<CSSProperties> &
181
+ Partial<{ error: CSSObjectWithLabel }>;
182
+ input: Partial<CSSProperties> & Partial<{ error: CSSObjectWithLabel }>;
183
+ singleValue: Partial<CSSProperties> &
184
+ Partial<{ error: CSSObjectWithLabel }>;
185
+ menu: Partial<CSSProperties> & Partial<{ error: CSSObjectWithLabel }>;
136
186
  }>;
137
187
  };
138
-
188
+ type CountryName = string;
139
189
  export function CountrySelect({
140
190
  name,
141
191
  countries,
142
192
  theme: selectTheme,
193
+ fieldValueIsCountryCode,
143
194
  ...rest
144
195
  }: CountrySelectProps) {
145
196
  const { status } = useFormikContext();
146
197
  const [initialized, setInitialized] = useState<boolean>(false);
147
198
  const [field, meta, helpers] = useField(name);
148
- const errorText = meta.error || status?.[name];
149
- const errorMessage = errorText && meta.touched ? errorText : "";
150
- const displayError = typeof errorMessage === "string" && errorMessage !== "";
199
+ const errorMessage = meta.error || status?.[name];
200
+ const displayErrorMessage =
201
+ meta.error && meta.touched && !errorMessage
202
+ ? meta.error
203
+ : meta.error && meta.touched && errorMessage
204
+ ? errorMessage
205
+ : "";
206
+ const displayError =
207
+ typeof displayErrorMessage === "string" && displayErrorMessage !== "";
151
208
  const [phone, setPhone] = useState<string | undefined>(undefined);
152
- const [countryCode, setCountryCode] = useState<CountryCode | undefined>();
209
+ const [countryCodeOrName, setCountryCodeOrName] = useState<
210
+ CountryCode | CountryName | undefined
211
+ >();
153
212
 
154
213
  useEffect(() => {
155
214
  if (!initialized && field.value) {
156
- setCountryCode(field.value as CountryCode);
215
+ setCountryCodeOrName(field.value);
157
216
  setInitialized(true);
158
217
  }
159
218
  }, [field.value, initialized]); // eslint-disable-line
@@ -167,94 +226,83 @@ export function CountrySelect({
167
226
  <div></div>
168
227
  ))}
169
228
  addInternationalOption={false}
170
- country={countryCode}
229
+ country={countryCodeOrName}
171
230
  value={phone}
172
231
  onChange={(value) => setPhone((value || "").replace(/\+/g, ""))}
173
232
  countries={countries}
174
- countrySelectComponent={({ iconComponent: Icon, ...props }) => (
175
- <>
176
- <div>
177
- <Select
178
- {...rest}
179
- {...props}
180
- isDisabled={rest.disabled}
181
- theme={(theme) => ({
182
- ...theme,
183
- controlHeight: selectTheme?.controlHeight,
184
- borderRadius: selectTheme?.borderRadius || 0,
185
- colors: {
186
- ...theme.colors,
187
- controlHoverBorderColor:
188
- selectTheme?.controlHoverBorderColor ||
189
- colors.secondary,
190
- controlBackground:
191
- selectTheme?.controlBackground || colors.lightGrey,
192
- controlFocusBorderColor:
193
- selectTheme?.controlFocusBorderColor ||
194
- colors.secondary,
195
- controlUnfocusedBorderColor:
196
- selectTheme?.controlUnfocusedBorderColor ||
197
- colors.border,
198
- selectedOptionBackground:
199
- selectTheme?.selectedOptionBackground ||
200
- colors.lightGrey,
201
- unselectedOptionBackground:
202
- selectTheme?.unselectedOptionBackground || colors.white,
203
- selectedOptionColor:
204
- selectTheme?.selectedOptionColor || colors.secondary,
205
- unselectedOptionColor:
206
- selectTheme?.unselectedOptionColor || colors.black
207
- }
208
- })}
209
- styles={customStyles}
210
- name="countrySelect"
211
- value={(props?.options || []).find(
212
- (o: SelectDataProps) => o.value === countryCode
213
- )}
214
- onChange={(o: SelectDataProps) => {
215
- setCountryCode(o.value as CountryCode);
216
- helpers.setValue(o.label);
217
- }}
218
- components={{
219
- Control: (props) => {
220
- const country =
221
- (props?.getValue()[0] as any)?.value || null;
222
- return (
223
- <components.Control {...props}>
224
- <ControlGrid>
225
- {country ? (
226
- <Icon country={country as CountryCode} label="" />
227
- ) : (
228
- <GlobeHemisphereWest />
229
- )}
230
- {props.children as any}
231
- </ControlGrid>
232
- </components.Control>
233
- );
234
- },
235
- Option: (props) => {
236
- const country = (props?.data as any)?.value || null;
237
- return (
238
- <components.Option {...props}>
239
- <OptionGrid>
240
- {country ? (
241
- <Icon
242
- country={country as CountryCode}
243
- label={props.label}
244
- />
245
- ) : (
246
- <GlobeHemisphereWest />
247
- )}
248
- {props.label}
249
- </OptionGrid>
250
- </components.Option>
251
- );
252
- }
253
- }}
254
- />
255
- </div>
256
- </>
257
- )}
233
+ countrySelectComponent={({ iconComponent: Icon, ...props }) => {
234
+ const value = (props?.options || []).find((o: SelectDataProps) =>
235
+ fieldValueIsCountryCode
236
+ ? o.value === countryCodeOrName
237
+ : o.label === countryCodeOrName
238
+ );
239
+ return (
240
+ <>
241
+ <div>
242
+ <Select
243
+ {...rest}
244
+ {...props}
245
+ isDisabled={rest.disabled}
246
+ styles={customStyles(displayErrorMessage, selectTheme)}
247
+ name="countrySelect"
248
+ value={value}
249
+ onChange={(o: SelectDataProps) => {
250
+ if (!meta.touched) {
251
+ helpers.setTouched(true);
252
+ }
253
+ const value = fieldValueIsCountryCode ? o.value : o.label;
254
+ setCountryCodeOrName(value);
255
+ helpers.setValue(value);
256
+ }}
257
+ onBlur={() => {
258
+ if (!meta.touched) {
259
+ helpers.setTouched(true);
260
+ }
261
+ }}
262
+ components={{
263
+ Control: (props) => {
264
+ const country =
265
+ (props?.getValue()[0] as any)?.value || null;
266
+ return (
267
+ <components.Control {...props}>
268
+ <ControlGrid>
269
+ {country ? (
270
+ <Icon
271
+ country={country as CountryCode}
272
+ label=""
273
+ />
274
+ ) : (
275
+ <GlobeHemisphereWest />
276
+ )}
277
+ {props.children as any}
278
+ </ControlGrid>
279
+ </components.Control>
280
+ );
281
+ },
282
+ Option: (props) => {
283
+ const country = (props?.data as any)?.value || null;
284
+ return (
285
+ <components.Option {...props}>
286
+ <OptionGrid>
287
+ {country ? (
288
+ <Icon
289
+ country={country as CountryCode}
290
+ label={props.label}
291
+ />
292
+ ) : (
293
+ <GlobeHemisphereWest />
294
+ )}
295
+ {props.label}
296
+ </OptionGrid>
297
+ </components.Option>
298
+ );
299
+ }
300
+ }}
301
+ />
302
+ </div>
303
+ </>
304
+ );
305
+ }}
258
306
  />
259
307
  </PhoneWrapper>
260
308
  <Error display={!rest.hideError && displayError} message={errorMessage} />
@@ -115,7 +115,21 @@ export const FieldInput = styled.input<{
115
115
  `};
116
116
  `;
117
117
 
118
- export const FileUploadWrapper = styled.div<{ error: any }>`
118
+ export type FileUploadWrapperTheme = Partial<{
119
+ borderColor: CSSProperties["borderColor"];
120
+ borderRadius: CSSProperties["borderRadius"];
121
+ background: CSSProperties["background"];
122
+ focus: Partial<{
123
+ borderColor: CSSProperties["borderColor"];
124
+ }>;
125
+ error: Partial<{
126
+ borderColor: CSSProperties["borderColor"];
127
+ }>;
128
+ }>;
129
+ export const FileUploadWrapper = styled.div<{
130
+ $error: unknown;
131
+ theme: FileUploadWrapperTheme | undefined;
132
+ }>`
119
133
  position: relative;
120
134
  overflow: hidden;
121
135
  display: flex;
@@ -144,28 +158,33 @@ export const FileUploadWrapper = styled.div<{ error: any }>`
144
158
  }
145
159
  }
146
160
 
147
- background: ${colors.lightGrey};
148
- border-radius: 0;
161
+ background: ${({ theme }) => theme?.background || colors.lightGrey};
162
+ ${({ theme }) =>
163
+ theme.borderRadius !== undefined &&
164
+ css`
165
+ border-radius: ${theme.borderRadius};
166
+ `};
149
167
  outline: none;
150
168
 
151
- ${({ error }) =>
152
- !checkIfValueIsEmpty(error)
169
+ ${({ $error, theme }) =>
170
+ !checkIfValueIsEmpty($error)
153
171
  ? css`
154
- border: 1px solid ${colors.orange};
172
+ border: 1px solid ${theme?.error?.borderColor || colors.orange};
155
173
  `
156
174
  : css`
157
- border: 1px solid ${colors.border};
175
+ border: 1px solid ${theme?.borderColor || colors.border};
158
176
  `}
159
177
 
160
178
  ${transition};
161
179
 
162
180
  &:focus,
163
181
  &:hover {
164
- border: 1px solid var(--secondary);
182
+ border: 1px solid
183
+ ${({ theme }) => theme?.hover?.borderColor || colors.lightGrey};
165
184
  }
166
185
 
167
186
  /* prettier-ignore */
168
- [data-disabled=true] {
187
+ :disabled, [data-disabled=true] {
169
188
  cursor: not-allowed;
170
189
  opacity: 0.5;
171
190
  }
@@ -319,7 +338,31 @@ export const FormFieldWrapper = styled(Grid)`
319
338
  }
320
339
  `;
321
340
 
322
- export const CheckboxWrapper = styled.label<{ error: any }>`
341
+ export type CheckboxTheme = Partial<{
342
+ backgroundColor: CSSProperties["backgroundColor"];
343
+ borderColor: CSSProperties["borderColor"];
344
+ borderRadius: CSSProperties["borderRadius"];
345
+ color: CSSProperties["color"];
346
+ hover: Partial<{
347
+ borderColor: CSSProperties["borderColor"];
348
+ backgroundColor: CSSProperties["backgroundColor"];
349
+ color: CSSProperties["color"];
350
+ }>;
351
+ error: Partial<{
352
+ borderColor: CSSProperties["borderColor"];
353
+ backgroundColor: CSSProperties["backgroundColor"];
354
+ color: CSSProperties["color"];
355
+ }>;
356
+ checked: Partial<{
357
+ borderColor: CSSProperties["borderColor"];
358
+ backgroundColor: CSSProperties["backgroundColor"];
359
+ color: CSSProperties["color"];
360
+ }>;
361
+ }>;
362
+ export const CheckboxWrapper = styled.label<{
363
+ $error: unknown;
364
+ theme: CheckboxTheme;
365
+ }>`
323
366
  display: flex;
324
367
  align-items: center;
325
368
  justify-content: flex-start;
@@ -336,7 +379,18 @@ export const CheckboxWrapper = styled.label<{ error: any }>`
336
379
  + div {
337
380
  cursor: pointer;
338
381
  &:hover {
339
- border: 1px solid ${colors.secondary};
382
+ border: 1px solid
383
+ ${({ theme }) => theme?.hover?.borderColor || colors.border};
384
+ ${({ theme }) =>
385
+ theme?.hover?.backgroundColor &&
386
+ css`
387
+ background-color: ${theme?.hover?.backgroundColor};
388
+ `};
389
+ ${({ theme }) =>
390
+ theme?.hover?.color &&
391
+ css`
392
+ color: ${theme?.hover?.color};
393
+ `};
340
394
  svg {
341
395
  opacity: 0.25;
342
396
  }
@@ -356,8 +410,19 @@ export const CheckboxWrapper = styled.label<{ error: any }>`
356
410
  width: 1.5rem;
357
411
  height: 1.5rem;
358
412
 
359
- background: ${colors.lightGrey};
360
-
413
+ background-color: ${({ theme }) =>
414
+ theme?.backgroundColor || colors.lightGrey};
415
+ border: 1px solid ${({ theme }) => theme?.borderColor};
416
+ ${({ theme }) =>
417
+ theme?.color &&
418
+ css`
419
+ color: ${theme?.color};
420
+ `};
421
+ ${({ theme }) =>
422
+ theme?.borderRadius !== undefined &&
423
+ css`
424
+ border-radius: ${theme?.borderRadius};
425
+ `};
361
426
  margin-right: 0.5rem;
362
427
  }
363
428
 
@@ -366,6 +431,23 @@ export const CheckboxWrapper = styled.label<{ error: any }>`
366
431
  + div svg {
367
432
  opacity: 1;
368
433
  }
434
+ + div {
435
+ ${({ theme }) =>
436
+ theme?.checked?.backgroundColor &&
437
+ css`
438
+ background-color: ${theme?.checked?.backgroundColor};
439
+ `};
440
+ ${({ theme }) =>
441
+ theme?.checked?.borderColor &&
442
+ css`
443
+ border: 1px solid ${theme?.checked?.borderColor};
444
+ `};
445
+ ${({ theme }) =>
446
+ theme?.checked?.color &&
447
+ css`
448
+ color: ${theme?.checked?.color};
449
+ `};
450
+ }
369
451
  }
370
452
  &:not(:checked) {
371
453
  + div svg {
@@ -374,17 +456,24 @@ export const CheckboxWrapper = styled.label<{ error: any }>`
374
456
  }
375
457
  }
376
458
 
377
- ${({ error }) =>
378
- !checkIfValueIsEmpty(error)
379
- ? css`
380
- > div {
381
- border: 1px solid ${colors.orange};
382
- }
383
- `
384
- : css`
385
- > div {
386
- border: 1px solid ${colors.border};
387
- }
459
+ ${({ $error, theme }) =>
460
+ !checkIfValueIsEmpty($error) &&
461
+ css`
462
+ > div {
463
+ border: 1px solid ${theme?.error?.borderColor || colors.orange}};
464
+ ${
465
+ theme?.error?.backgroundColor &&
466
+ css`
467
+ background-color: ${theme?.error?.backgroundColor};
468
+ `
469
+ };
470
+ ${
471
+ theme?.error?.color &&
472
+ css`
473
+ color: ${theme?.error?.color};
474
+ `
475
+ };
476
+ }
388
477
  `}
389
478
  `;
390
479
 
@@ -10,6 +10,7 @@ import { Grid } from "../ui/Grid";
10
10
  import { Typography } from "../ui/Typography";
11
11
  import { CopyButton, FormFieldWrapper } from "./Field.styles";
12
12
  import type { FormFieldProps } from "./types";
13
+ export type { FormFieldProps } from "./types";
13
14
 
14
15
  const colors = theme.colors.light;
15
16
 
@@ -22,7 +23,8 @@ export function FormField({
22
23
  children,
23
24
  style = {},
24
25
  valueToCopy,
25
- copyIconColor = colors.secondary
26
+ copyIconColor = colors.secondary,
27
+ ...rest
26
28
  }: FormFieldProps) {
27
29
  return (
28
30
  <FormFieldWrapper
@@ -31,6 +33,7 @@ export function FormField({
31
33
  alignItems="flex-start"
32
34
  flexGrow="1"
33
35
  style={style}
36
+ {...rest}
34
37
  >
35
38
  <>
36
39
  <Grid justifyContent="flex-start" margin="0 0 0.375rem 0">