@bosonprotocol/react-kit 0.32.0-alpha.2 → 0.32.0-alpha.4

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 (125) 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 +2 -2
  4. package/dist/cjs/components/buttons/BaseButton.js.map +1 -1
  5. package/dist/cjs/components/modal/Modal.d.ts.map +1 -1
  6. package/dist/cjs/components/modal/Modal.js +0 -8
  7. package/dist/cjs/components/modal/Modal.js.map +1 -1
  8. package/dist/cjs/components/modal/ModalProvider.d.ts +1 -1
  9. package/dist/cjs/components/modal/ModalProvider.d.ts.map +1 -1
  10. package/dist/cjs/components/modal/ModalProvider.js +3 -2
  11. package/dist/cjs/components/modal/ModalProvider.js.map +1 -1
  12. package/dist/cjs/components/scroll/ScrollToID.d.ts +4 -0
  13. package/dist/cjs/components/scroll/ScrollToID.d.ts.map +1 -0
  14. package/dist/cjs/components/scroll/ScrollToID.js +12 -0
  15. package/dist/cjs/components/scroll/ScrollToID.js.map +1 -0
  16. package/dist/cjs/components/scroll/ScrollToTop.d.ts +2 -0
  17. package/dist/cjs/components/scroll/ScrollToTop.d.ts.map +1 -0
  18. package/dist/cjs/components/scroll/ScrollToTop.js +14 -0
  19. package/dist/cjs/components/scroll/ScrollToTop.js.map +1 -0
  20. package/dist/cjs/components/wallet2/accountDrawer/AuthenticatedHeader.d.ts +4 -3
  21. package/dist/cjs/components/wallet2/accountDrawer/AuthenticatedHeader.d.ts.map +1 -1
  22. package/dist/cjs/components/wallet2/accountDrawer/AuthenticatedHeader.js +4 -39
  23. package/dist/cjs/components/wallet2/accountDrawer/AuthenticatedHeader.js.map +1 -1
  24. package/dist/cjs/components/wallet2/accountDrawer/IconButton.d.ts +2 -1
  25. package/dist/cjs/components/wallet2/accountDrawer/IconButton.d.ts.map +1 -1
  26. package/dist/cjs/components/wallet2/accountDrawer/IconButton.js +6 -6
  27. package/dist/cjs/components/wallet2/accountDrawer/IconButton.js.map +1 -1
  28. package/dist/cjs/components/wallet2/walletModal/Option.d.ts +2 -1
  29. package/dist/cjs/components/wallet2/walletModal/Option.d.ts.map +1 -1
  30. package/dist/cjs/components/wallet2/walletModal/Option.js +3 -3
  31. package/dist/cjs/components/wallet2/walletModal/Option.js.map +1 -1
  32. package/dist/cjs/components/wallet2/walletModal/index.d.ts +4 -1
  33. package/dist/cjs/components/wallet2/walletModal/index.d.ts.map +1 -1
  34. package/dist/cjs/components/wallet2/walletModal/index.js +3 -3
  35. package/dist/cjs/components/wallet2/walletModal/index.js.map +1 -1
  36. package/dist/cjs/components/wallet2/web3Status/index.d.ts.map +1 -1
  37. package/dist/cjs/components/wallet2/web3Status/index.js +1 -54
  38. package/dist/cjs/components/wallet2/web3Status/index.js.map +1 -1
  39. package/dist/cjs/components/widgets/commit/CommitWidgetProviders.d.ts +1 -1
  40. package/dist/cjs/components/widgets/commit/CommitWidgetProviders.d.ts.map +1 -1
  41. package/dist/cjs/components/widgets/commit/CommitWidgetProviders.js +3 -3
  42. package/dist/cjs/components/widgets/commit/CommitWidgetProviders.js.map +1 -1
  43. package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.js +2 -2
  44. package/dist/cjs/components/widgets/finance/FinanceWidgetProviders.js.map +1 -1
  45. package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.js +2 -2
  46. package/dist/cjs/components/widgets/redemption/RedemptionWidgetProviders.js.map +1 -1
  47. package/dist/cjs/hooks/index.d.ts +1 -0
  48. package/dist/cjs/hooks/index.d.ts.map +1 -1
  49. package/dist/cjs/hooks/index.js +1 -0
  50. package/dist/cjs/hooks/index.js.map +1 -1
  51. package/dist/cjs/index.d.ts +4 -0
  52. package/dist/cjs/index.d.ts.map +1 -1
  53. package/dist/cjs/index.js +6 -1
  54. package/dist/cjs/index.js.map +1 -1
  55. package/dist/esm/components/buttons/BaseButton.d.ts +1 -0
  56. package/dist/esm/components/buttons/BaseButton.d.ts.map +1 -1
  57. package/dist/esm/components/buttons/BaseButton.js +2 -2
  58. package/dist/esm/components/buttons/BaseButton.js.map +1 -1
  59. package/dist/esm/components/modal/Modal.d.ts.map +1 -1
  60. package/dist/esm/components/modal/Modal.js +0 -8
  61. package/dist/esm/components/modal/Modal.js.map +1 -1
  62. package/dist/esm/components/modal/ModalProvider.d.ts +1 -1
  63. package/dist/esm/components/modal/ModalProvider.d.ts.map +1 -1
  64. package/dist/esm/components/modal/ModalProvider.js +2 -2
  65. package/dist/esm/components/modal/ModalProvider.js.map +1 -1
  66. package/dist/esm/components/scroll/ScrollToID.d.ts +4 -0
  67. package/dist/esm/components/scroll/ScrollToID.d.ts.map +1 -0
  68. package/dist/esm/components/scroll/ScrollToID.js +8 -0
  69. package/dist/esm/components/scroll/ScrollToID.js.map +1 -0
  70. package/dist/esm/components/scroll/ScrollToTop.d.ts +2 -0
  71. package/dist/esm/components/scroll/ScrollToTop.d.ts.map +1 -0
  72. package/dist/esm/components/scroll/ScrollToTop.js +10 -0
  73. package/dist/esm/components/scroll/ScrollToTop.js.map +1 -0
  74. package/dist/esm/components/wallet2/accountDrawer/AuthenticatedHeader.d.ts +4 -3
  75. package/dist/esm/components/wallet2/accountDrawer/AuthenticatedHeader.d.ts.map +1 -1
  76. package/dist/esm/components/wallet2/accountDrawer/AuthenticatedHeader.js +4 -39
  77. package/dist/esm/components/wallet2/accountDrawer/AuthenticatedHeader.js.map +1 -1
  78. package/dist/esm/components/wallet2/accountDrawer/IconButton.d.ts +2 -1
  79. package/dist/esm/components/wallet2/accountDrawer/IconButton.d.ts.map +1 -1
  80. package/dist/esm/components/wallet2/accountDrawer/IconButton.js +6 -6
  81. package/dist/esm/components/wallet2/accountDrawer/IconButton.js.map +1 -1
  82. package/dist/esm/components/wallet2/walletModal/Option.d.ts +2 -1
  83. package/dist/esm/components/wallet2/walletModal/Option.d.ts.map +1 -1
  84. package/dist/esm/components/wallet2/walletModal/Option.js +3 -3
  85. package/dist/esm/components/wallet2/walletModal/Option.js.map +1 -1
  86. package/dist/esm/components/wallet2/walletModal/index.d.ts +4 -1
  87. package/dist/esm/components/wallet2/walletModal/index.d.ts.map +1 -1
  88. package/dist/esm/components/wallet2/walletModal/index.js +3 -3
  89. package/dist/esm/components/wallet2/walletModal/index.js.map +1 -1
  90. package/dist/esm/components/wallet2/web3Status/index.d.ts.map +1 -1
  91. package/dist/esm/components/wallet2/web3Status/index.js +1 -54
  92. package/dist/esm/components/wallet2/web3Status/index.js.map +1 -1
  93. package/dist/esm/components/widgets/commit/CommitWidgetProviders.d.ts +1 -1
  94. package/dist/esm/components/widgets/commit/CommitWidgetProviders.d.ts.map +1 -1
  95. package/dist/esm/components/widgets/commit/CommitWidgetProviders.js +2 -2
  96. package/dist/esm/components/widgets/commit/CommitWidgetProviders.js.map +1 -1
  97. package/dist/esm/components/widgets/finance/FinanceWidgetProviders.js +1 -1
  98. package/dist/esm/components/widgets/finance/FinanceWidgetProviders.js.map +1 -1
  99. package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.js +1 -1
  100. package/dist/esm/components/widgets/redemption/RedemptionWidgetProviders.js.map +1 -1
  101. package/dist/esm/hooks/index.d.ts +1 -0
  102. package/dist/esm/hooks/index.d.ts.map +1 -1
  103. package/dist/esm/hooks/index.js +1 -0
  104. package/dist/esm/hooks/index.js.map +1 -1
  105. package/dist/esm/index.d.ts +4 -0
  106. package/dist/esm/index.d.ts.map +1 -1
  107. package/dist/esm/index.js +4 -0
  108. package/dist/esm/index.js.map +1 -1
  109. package/package.json +4 -4
  110. package/src/components/buttons/BaseButton.tsx +3 -2
  111. package/src/components/modal/Modal.tsx +0 -8
  112. package/src/components/modal/ModalProvider.tsx +2 -2
  113. package/src/components/scroll/ScrollToID.tsx +7 -0
  114. package/src/components/scroll/ScrollToTop.tsx +12 -0
  115. package/src/components/wallet2/accountDrawer/AuthenticatedHeader.tsx +10 -47
  116. package/src/components/wallet2/accountDrawer/IconButton.tsx +11 -2
  117. package/src/components/wallet2/walletModal/Option.tsx +8 -4
  118. package/src/components/wallet2/walletModal/index.tsx +14 -6
  119. package/src/components/wallet2/web3Status/index.tsx +3 -61
  120. package/src/components/widgets/commit/CommitWidgetProviders.tsx +2 -2
  121. package/src/components/widgets/finance/FinanceWidgetProviders.tsx +1 -1
  122. package/src/components/widgets/redemption/RedemptionWidgetProviders.tsx +1 -1
  123. package/src/hooks/index.ts +1 -0
  124. package/src/index.tsx +4 -0
  125. package/src/stories/ConnectWallet.stories.tsx +63 -28
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EACL,OAAO,IAAI,YAAY,EAEvB,iBAAiB,EAClB,MAAM,8BAA8B,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mCAAmC,CAAC;AAClD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,wCAAwC,CAAC;AACvD,cAAc,0CAA0C,CAAC;AACzD,cAAc,wCAAwC,CAAC;AACvD,cAAc,wCAAwC,CAAC;AACvD,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,mCAAmC,CAAC;AAClD,cAAc,wCAAwC,CAAC;AACvD,cAAc,0CAA0C,CAAC;AACzD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,4CAA4C,CAAC;AAC3D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,wCAAwC,CAAC;AACvD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+CAA+C,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,cAAc,kCAAkC,CAAC;AACjD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,6CAA6C,CAAC;AAC5D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,qDAAqD,CAAC;AACpE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,wDAAwD,CAAC;AACvE,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAC7E,cAAc,4BAA4B,CAAC;AAC3C,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qCAAqC,CAAC;AACpD,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,wFAAwF,CAAC;AACvG,cAAc,mEAAmE,CAAC;AAClF,cAAc,iEAAiE,CAAC;AAChF,cAAc,qEAAqE,CAAC;AACpF,cAAc,0EAA0E,CAAC;AACzF,cAAc,4EAA4E,CAAC;AAC3F,cAAc,sBAAsB,CAAC;AACrC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,6CAA6C,CAAC;AAC5D,cAAc,uCAAuC,CAAC;AACtD,cAAc,yCAAyC,CAAC;AACxD,cAAc,0CAA0C,CAAC;AACzD,cAAc,4BAA4B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,cAAc,yBAAyB,CAAC;AACxC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EACL,OAAO,IAAI,YAAY,EAEvB,iBAAiB,EAClB,MAAM,8BAA8B,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,iCAAiC,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,uCAAuC,CAAC;AACtD,cAAc,mCAAmC,CAAC;AAClD,cAAc,+CAA+C,CAAC;AAC9D,cAAc,wCAAwC,CAAC;AACvD,cAAc,0CAA0C,CAAC;AACzD,cAAc,wCAAwC,CAAC;AACvD,cAAc,wCAAwC,CAAC;AACvD,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,mCAAmC,CAAC;AAClD,cAAc,wCAAwC,CAAC;AACvD,cAAc,0CAA0C,CAAC;AACzD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,4CAA4C,CAAC;AAC3D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,wCAAwC,CAAC;AACvD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,sCAAsC,CAAC;AACrD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+CAA+C,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,cAAc,kCAAkC,CAAC;AACjD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,6CAA6C,CAAC;AAC5D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,qDAAqD,CAAC;AACpE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,8CAA8C,CAAC;AAC7D,cAAc,wDAAwD,CAAC;AACvE,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAC7E,cAAc,4BAA4B,CAAC;AAC3C,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qCAAqC,CAAC;AACpD,cAAc,sCAAsC,CAAC;AACrD,cAAc,oCAAoC,CAAC;AACnD,cAAc,wFAAwF,CAAC;AACvG,cAAc,mEAAmE,CAAC;AAClF,cAAc,iEAAiE,CAAC;AAChF,cAAc,qEAAqE,CAAC;AACpF,cAAc,0EAA0E,CAAC;AACzF,cAAc,4EAA4E,CAAC;AAC3F,cAAc,sBAAsB,CAAC;AACrC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,6CAA6C,CAAC;AAC5D,cAAc,uCAAuC,CAAC;AACtD,cAAc,yCAAyC,CAAC;AACxD,cAAc,0CAA0C,CAAC;AACzD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,iCAAiC,CAAC"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@bosonprotocol/react-kit",
3
3
  "description": "React toolkit with smart components and hooks for building on top of the Boson Protocol.",
4
- "version": "0.32.0-alpha.2",
4
+ "version": "0.32.0-alpha.4",
5
5
  "main": "./dist/cjs/index.js",
6
6
  "module": "./dist/esm/index.js",
7
7
  "types": "./dist/cjs/index.d.ts",
@@ -15,8 +15,8 @@
15
15
  "license": "Apache-2.0",
16
16
  "dependencies": {
17
17
  "@bosonprotocol/chat-sdk": "^1.3.1-alpha.9",
18
- "@bosonprotocol/core-sdk": "^1.40.4-alpha.0",
19
- "@bosonprotocol/ethers-sdk": "^1.14.4-alpha.0",
18
+ "@bosonprotocol/core-sdk": "^1.40.4-alpha.2",
19
+ "@bosonprotocol/ethers-sdk": "^1.14.4-alpha.2",
20
20
  "@bosonprotocol/ipfs-storage": "^1.11.3",
21
21
  "@davatar/react": "1.11.1",
22
22
  "@ethersproject/units": "5.6.0",
@@ -185,5 +185,5 @@
185
185
  "overrides": {
186
186
  "typescript": "^5.1.6"
187
187
  },
188
- "gitHead": "08423f0daa486c2445a61ebd7c922795929651d0"
188
+ "gitHead": "0d0f567f5b192ff030acb4ab68e26afa1583462f"
189
189
  }
@@ -98,7 +98,7 @@ const ChildWrapperButton = styled.div`
98
98
  display: flex;
99
99
  align-items: center;
100
100
  justify-content: center;
101
- gap: 12px;
101
+ gap: ${(props) => props.theme?.gap || "12px"};
102
102
  position: relative;
103
103
  z-index: ${zIndex.Button};
104
104
 
@@ -112,6 +112,7 @@ export type BaseButtonTheme = {
112
112
  borderWidth?: CSSProperties["borderWidth"];
113
113
  color?: CSSProperties["color"];
114
114
  padding?: CSSProperties["padding"];
115
+ gap?: CSSProperties["gap"];
115
116
  hover?: {
116
117
  background?: CSSProperties["backgroundColor"];
117
118
  borderColor?: CSSProperties["borderColor"];
@@ -179,7 +180,7 @@ export const BaseButton = forwardRef<HTMLButtonElement, BaseButtonProps>(
179
180
  {isLoading ? (
180
181
  <Loading />
181
182
  ) : (
182
- <ChildWrapperButton data-child-wrapper-button>
183
+ <ChildWrapperButton data-child-wrapper-button theme={theme}>
183
184
  {children}
184
185
  {step !== 0 && (
185
186
  <Typography>
@@ -134,16 +134,8 @@ const Wrapper = styled.div<{
134
134
  }};
135
135
  ${({ $modalType }) => {
136
136
  switch ($modalType) {
137
- case "PRODUCT_CREATE_SUCCESS":
138
- return css`
139
- max-width: 65.875rem;
140
- `;
141
137
  case "FINANCE_WITHDRAW_MODAL":
142
138
  case "FINANCE_DEPOSIT_MODAL":
143
- case "MANAGE_FUNDS_MODAL":
144
- case "EXPIRE_VOUCHER_MODAL":
145
- case "DISPUTE_RESOLUTION_DECIDE_MODAL":
146
- case "DISPUTE_RESOLUTION_REFUSE_MODAL":
147
139
  return css`
148
140
  ${breakpoint.xs} {
149
141
  max-width: 31.25rem;
@@ -56,8 +56,7 @@ const RenderModalComponent = ({
56
56
  interface Props {
57
57
  children: React.ReactNode;
58
58
  }
59
- export default function ModalProvider({ children }: Props) {
60
- // const { pathname } = useLocation();
59
+ export function ModalProvider({ children }: Props) {
61
60
  const [store, setStore] = useState(initalState.store);
62
61
 
63
62
  const showModal = useCallback(
@@ -100,6 +99,7 @@ export default function ModalProvider({ children }: Props) {
100
99
  }, []);
101
100
 
102
101
  // TODO: check if this is necessary
102
+ // const { pathname } = useLocation();
103
103
  // useEffect(() => {
104
104
  // if (store.modalType !== null) {
105
105
  // hideModal();
@@ -0,0 +1,7 @@
1
+ export const ScrollToID = ({ id }: { id: string }) => {
2
+ const localElement = document.getElementById(id);
3
+ if (localElement) {
4
+ localElement.scrollIntoView({ block: "center" });
5
+ }
6
+ return null;
7
+ };
@@ -0,0 +1,12 @@
1
+ import { useEffect } from "react";
2
+ import { useLocation } from "react-router-dom";
3
+
4
+ export function ScrollToTop() {
5
+ const { pathname } = useLocation();
6
+
7
+ useEffect(() => {
8
+ window.scroll({ top: 0, left: 0 });
9
+ }, [pathname]);
10
+
11
+ return null;
12
+ }
@@ -30,6 +30,7 @@ import {
30
30
  useConnections
31
31
  } from "../../connection/ConnectionsProvider";
32
32
  import { useWeb3React } from "@web3-react/core";
33
+ import { BaseButton, BaseButtonTheme } from "../../buttons/BaseButton";
33
34
  const colors = theme.colors.light;
34
35
  const AuthenticatedHeaderWrapper = styled.div`
35
36
  padding: 20px 16px;
@@ -38,45 +39,6 @@ const AuthenticatedHeaderWrapper = styled.div`
38
39
  flex: 1;
39
40
  `;
40
41
 
41
- const HeaderButton = styled.button<{
42
- $color: CSSProperties["color"];
43
- $backgroundColor: CSSProperties["backgroundColor"];
44
- }>`
45
- color: ${({ $color }) => $color};
46
- background-color: ${({ $backgroundColor }) => $backgroundColor};
47
- width: 100%;
48
- display: flex;
49
- justify-content: center;
50
- align-items: center;
51
- gap: 0.5rem;
52
- border-color: transparent;
53
- border-radius: 12px;
54
- border-style: solid;
55
- border-width: 1px;
56
- height: 40px;
57
- margin-top: 8px;
58
-
59
- position: relative;
60
- z-index: 1;
61
- letter-spacing: 0.5px;
62
- font-style: normal;
63
- font-size: 1rem;
64
- font-weight: 500;
65
- line-height: 24px;
66
-
67
- &:hover:not(:disabled) {
68
- background-color: color-mix(
69
- in srgb,
70
- ${({ $backgroundColor }) => $backgroundColor} 90%,
71
- black
72
- );
73
- transition: 125ms background-color ease-in;
74
- }
75
- &:disabled {
76
- cursor: not-allowed;
77
- opacity: 0.5;
78
- }
79
- `;
80
42
  const IconHoverText = styled.span`
81
43
  color: ${colors.white};
82
44
  position: absolute;
@@ -174,16 +136,16 @@ export type AuthenticatedHeaderProps = {
174
136
  onUserDisconnect?: () => unknown;
175
137
  disconnectColor: CSSProperties["color"];
176
138
  disconnectBackgroundColor: CSSProperties["backgroundColor"];
177
- buyCryptoColor: CSSProperties["color"];
178
- buyCryptoBackgroundColor: CSSProperties["backgroundColor"];
139
+ disconnectBorderRadius: CSSProperties["borderRadius"];
140
+ buyCryptoTheme: BaseButtonTheme;
179
141
  };
180
142
  export function AuthenticatedHeader({
181
143
  account,
182
144
  onUserDisconnect,
183
145
  disconnectColor,
184
146
  disconnectBackgroundColor,
185
- buyCryptoColor,
186
- buyCryptoBackgroundColor
147
+ disconnectBorderRadius,
148
+ buyCryptoTheme
187
149
  }: AuthenticatedHeaderProps) {
188
150
  const { connector } = useWeb3React();
189
151
  const { ENSName } = useENSName(account);
@@ -282,14 +244,15 @@ export function AuthenticatedHeader({
282
244
  dismissOnHoverOut
283
245
  color={disconnectColor}
284
246
  backgroundColor={disconnectBackgroundColor}
247
+ borderRadius={disconnectBorderRadius}
285
248
  />
286
249
  </IconContainer>
287
250
  </HeaderWrapper>
288
251
  <PortfolioDrawerContainer>
289
252
  <FiatLink>
290
- <HeaderButton
291
- $color={buyCryptoColor}
292
- $backgroundColor={buyCryptoBackgroundColor}
253
+ <BaseButton
254
+ fill
255
+ theme={buyCryptoTheme}
293
256
  // onClick={handleBuyCryptoClick}
294
257
  // disabled={disableBuyCryptoButton}
295
258
  disabled={isFiatLoading}
@@ -307,7 +270,7 @@ export function AuthenticatedHeader({
307
270
  Buy crypto
308
271
  </>
309
272
  )}
310
- </HeaderButton>
273
+ </BaseButton>
311
274
  </FiatLink>
312
275
  {Boolean(!fiatOnrampAvailable && fiatOnrampAvailabilityChecked) && (
313
276
  <FiatOnrampNotAvailableText marginTop="8px">
@@ -27,12 +27,13 @@ const IconStyles = css<{
27
27
  $hideHorizontal?: boolean;
28
28
  $color: CSSProperties["color"];
29
29
  $backgroundColor: CSSProperties["backgroundColor"];
30
+ $borderRadius: CSSProperties["borderRadius"];
30
31
  }>`
31
32
  color: ${({ $color }) => $color};
32
33
  /* TODO: background-color: var(--buttonBgColor); */
33
34
  background-color: ${({ $backgroundColor }) => $backgroundColor};
34
35
  transition: ${getWidthTransition};
35
- border-radius: 12px;
36
+ border-radius: ${({ $borderRadius }) => $borderRadius || "12px"};
36
37
  display: flex;
37
38
  padding: 0;
38
39
  cursor: pointer;
@@ -66,6 +67,7 @@ const IconBlockLink = styled.a<{
66
67
  $hideHorizontal?: boolean;
67
68
  $color: CSSProperties["color"];
68
69
  $backgroundColor: CSSProperties["backgroundColor"];
70
+ $borderRadius: CSSProperties["borderRadius"];
69
71
  }>`
70
72
  ${IconStyles};
71
73
  `;
@@ -74,6 +76,7 @@ const IconBlockButton = styled.button<{
74
76
  $hideHorizontal?: boolean;
75
77
  $color: CSSProperties["color"];
76
78
  $backgroundColor: CSSProperties["backgroundColor"];
79
+ $borderRadius: CSSProperties["borderRadius"];
77
80
  }>`
78
81
  ${IconStyles};
79
82
  border: none;
@@ -106,15 +109,17 @@ const IconBlock = forwardRef<
106
109
  IconBlockProps & {
107
110
  color: CSSProperties["color"];
108
111
  backgroundColor: CSSProperties["backgroundColor"];
112
+ borderRadius: CSSProperties["borderRadius"];
109
113
  }
110
114
  >(function IconBlock(props, ref) {
111
- const { color, backgroundColor } = props;
115
+ const { color, backgroundColor, borderRadius } = props;
112
116
  if ("href" in props) {
113
117
  return (
114
118
  <IconBlockLink
115
119
  ref={ref as React.ForwardedRef<HTMLAnchorElement>}
116
120
  $color={color}
117
121
  $backgroundColor={backgroundColor}
122
+ $borderRadius={borderRadius}
118
123
  {...props}
119
124
  />
120
125
  );
@@ -128,6 +133,7 @@ const IconBlock = forwardRef<
128
133
  ref={ref}
129
134
  $color={color}
130
135
  $backgroundColor={backgroundColor}
136
+ $borderRadius={borderRadius}
131
137
  {...props}
132
138
  />
133
139
  );
@@ -141,6 +147,7 @@ type IconWithTextProps = (IconButtonProps | IconLinkProps) & {
141
147
  dismissOnHoverDurationMs?: number;
142
148
  color: CSSProperties["color"];
143
149
  backgroundColor: CSSProperties["backgroundColor"];
150
+ borderRadius: CSSProperties["borderRadius"];
144
151
  };
145
152
 
146
153
  const TextWrapper = styled.div`
@@ -172,6 +179,7 @@ export const IconWithConfirmTextButton = ({
172
179
  dismissOnHoverDurationMs = 500,
173
180
  color,
174
181
  backgroundColor,
182
+ borderRadius,
175
183
  ...rest
176
184
  }: IconWithTextProps) => {
177
185
  const [showText, setShowTextWithoutCallback] = useState(false);
@@ -254,6 +262,7 @@ export const IconWithConfirmTextButton = ({
254
262
  }}
255
263
  color={color}
256
264
  backgroundColor={backgroundColor}
265
+ borderRadius={borderRadius}
257
266
  // eslint-disable-next-line @typescript-eslint/ban-ts-comment
258
267
  // @ts-ignore MouseEvent is valid, its a subset of the two mouse events,
259
268
  // even manually typing this all out more specifically it still gets mad about any casting for some reason
@@ -49,14 +49,16 @@ const HeaderText = styled.div<{ $color: CSSProperties["color"] }>`
49
49
  font-weight: 600;
50
50
  padding: 0 8px;
51
51
  `;
52
- const IconWrapper = styled.div`
52
+ const IconWrapper = styled.div<{
53
+ $borderRadius: CSSProperties["borderRadius"];
54
+ }>`
53
55
  ${flexColumnNoWrap};
54
56
  align-items: center;
55
57
  justify-content: center;
56
58
  img,
57
59
  svg {
58
60
  border: 1px solid ${colors.border};
59
- border-radius: 12px;
61
+ border-radius: ${({ $borderRadius }) => $borderRadius};
60
62
  }
61
63
  & > img,
62
64
  & > svg,
@@ -107,13 +109,15 @@ export interface OptionProps {
107
109
  hoverFocusBackgroundColor: CSSProperties["backgroundColor"];
108
110
  hoverColor: CSSProperties["color"];
109
111
  backgroundColor: CSSProperties["backgroundColor"];
112
+ borderRadius: CSSProperties["borderRadius"];
110
113
  }
111
114
  export function Option({
112
115
  connection,
113
116
  color,
114
117
  hoverFocusBackgroundColor,
115
118
  hoverColor,
116
- backgroundColor
119
+ backgroundColor,
120
+ borderRadius
117
121
  }: OptionProps) {
118
122
  const { activationState, tryActivation } = useActivationState();
119
123
  const toggleAccountDrawer = useToggleAccountDrawer();
@@ -140,7 +144,7 @@ export function Option({
140
144
  data-testid={`wallet-option-${connection.type}`}
141
145
  >
142
146
  <OptionCardLeft>
143
- <IconWrapper>
147
+ <IconWrapper $borderRadius={borderRadius}>
144
148
  <SvgImage
145
149
  src={connection.getIcon?.(false)}
146
150
  alt={connection.getName()}
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import { useWeb3React } from "@web3-react/core";
3
3
  import { useEffect } from "react";
4
- import styled from "styled-components";
4
+ import styled, { CSSProperties } from "styled-components";
5
5
 
6
6
  import { Grid } from "../../ui/Grid";
7
7
  import { flexColumnNoWrap } from "../styles";
@@ -26,11 +26,11 @@ const Wrapper = styled.div`
26
26
  flex: 1;
27
27
  `;
28
28
 
29
- const OptionGrid = styled.div`
29
+ const OptionGrid = styled.div<{ $borderRadius: CSSProperties["borderRadius"] }>`
30
30
  width: 100%;
31
31
  display: grid;
32
32
  grid-gap: 2px;
33
- border-radius: 12px;
33
+ border-radius: ${({ $borderRadius }) => $borderRadius};
34
34
  overflow: hidden;
35
35
  ${breakpoint.m} {
36
36
  grid-template-columns: 1fr;
@@ -42,8 +42,12 @@ export type WalletModalProps = {
42
42
  magicLoginButtonProps: MagicLoginButtonProps;
43
43
  optionProps: Pick<
44
44
  OptionProps,
45
- "color" | "hoverFocusBackgroundColor" | "hoverColor" | "backgroundColor"
46
- >;
45
+ | "color"
46
+ | "hoverFocusBackgroundColor"
47
+ | "hoverColor"
48
+ | "backgroundColor"
49
+ | "borderRadius"
50
+ > & { iconBorderRadius: CSSProperties["borderRadius"] };
47
51
  };
48
52
  export function WalletModal({
49
53
  PrivacyPolicy,
@@ -81,12 +85,16 @@ export function WalletModal({
81
85
  <ConnectionErrorView />
82
86
  ) : (
83
87
  <AutoColumn $gap="16px">
84
- <OptionGrid data-testid="option-grid">
88
+ <OptionGrid
89
+ data-testid="option-grid"
90
+ $borderRadius={optionProps.borderRadius}
91
+ >
85
92
  {connections
86
93
  .filter((connection) => connection.shouldDisplay())
87
94
  .map((connection) => (
88
95
  <Option
89
96
  {...optionProps}
97
+ borderRadius={optionProps.iconBorderRadius}
90
98
  key={connection.getName()}
91
99
  connection={connection}
92
100
  />
@@ -25,65 +25,8 @@ import { Tooltip } from "../../tooltip/Tooltip";
25
25
  import { Grid } from "../../ui/Grid";
26
26
  import { useAccountDrawer } from "../accountDrawer";
27
27
  import StatusIcon from "../identicon/StatusIcon";
28
- import { flexRowNoWrap } from "../styles";
29
-
30
- const Web3StatusGeneric = styled.button`
31
- ${flexRowNoWrap};
32
- width: 100%;
33
- align-items: center;
34
- padding: 0.5rem;
35
- cursor: pointer;
36
- user-select: none;
37
-
38
- margin-right: 2px;
39
- margin-left: 2px;
40
- &:focus {
41
- outline: none;
42
- }
43
- `;
44
28
 
45
29
  const breakpointWhenConnectButtonOverflows = "1300px";
46
- const Web3StatusConnected = styled(Web3StatusGeneric)<{
47
- $color: string;
48
- $backgroundColor: string;
49
- }>`
50
- border: 2px solid transparent;
51
- width: auto;
52
- font-weight: 500;
53
- color: ${({ $color }) => $color};
54
- &:hover,
55
- &:focus {
56
- border: 2px solid
57
- color-mix(
58
- in srgb,
59
- ${({ $backgroundColor }) => $backgroundColor} 90%,
60
- black
61
- );
62
- }
63
- @media (min-width: ${breakpointNumbers.xs}px) and (max-width: ${breakpointNumbers.l -
64
- 1}px) {
65
- background-color: ${({ $backgroundColor }) => $backgroundColor};
66
- border: 2px solid ${({ $backgroundColor }) => $backgroundColor};
67
- }
68
- @media (min-width: ${breakpointWhenConnectButtonOverflows}) {
69
- background-color: ${({ $backgroundColor }) => $backgroundColor};
70
- border: 2px solid ${({ $backgroundColor }) => $backgroundColor};
71
- }
72
- ${breakpoint.xxs} {
73
- border-radius: 8px;
74
- margin: initial;
75
- * {
76
- margin: initial;
77
- }
78
- }
79
- @media (min-width: ${breakpointNumbers.l}px) and (max-width: ${breakpointWhenConnectButtonOverflows}) {
80
- border-radius: 8px;
81
- margin: initial;
82
- * {
83
- margin: initial;
84
- }
85
- }
86
- `;
87
30
 
88
31
  const AddressAndChevronContainer = styled.div`
89
32
  display: flex;
@@ -174,12 +117,11 @@ function Web3StatusInner({
174
117
 
175
118
  if (!connectedToWrongChainId && account) {
176
119
  return (
177
- <Web3StatusConnected
120
+ <BaseButton
178
121
  disabled={Boolean(switchingChain)}
179
122
  data-testid="web3-status-connected"
180
123
  onClick={handleWalletDropdownClick}
181
- $color={successButtonTheme.color}
182
- $backgroundColor={successButtonTheme.background}
124
+ theme={successButtonTheme}
183
125
  >
184
126
  <StatusIcon
185
127
  account={account}
@@ -191,7 +133,7 @@ function Web3StatusInner({
191
133
  <AddressAndChevronContainer>
192
134
  <Text>{ENSName || formatAddress(account)}</Text>
193
135
  </AddressAndChevronContainer>
194
- </Web3StatusConnected>
136
+ </BaseButton>
195
137
  );
196
138
  }
197
139
 
@@ -3,13 +3,14 @@ import { useProvider } from "../../../hooks/connection/connection";
3
3
  import { useIsWindowVisible } from "../../../hooks/uniswap/useIsWindowVisible";
4
4
  import { CONFIG } from "../../../lib/config/config";
5
5
  import { Updaters } from "../../../state/updaters";
6
+ import { BosonProvider, BosonProviderProps } from "../../boson/BosonProvider";
6
7
  import ChatProvider from "../../chat/ChatProvider/ChatProvider";
7
8
  import {
8
9
  ConfigProvider,
9
10
  ConfigProviderProps
10
11
  } from "../../config/ConfigProvider";
11
12
  import { IpfsProvider, IpfsProviderProps } from "../../ipfs/IpfsProvider";
12
- import ModalProvider from "../../modal/ModalProvider";
13
+ import { ModalProvider } from "../../modal/ModalProvider";
13
14
  import { withQueryClientProvider } from "../../queryClient/withQueryClientProvider";
14
15
  import { WalletConnectionProviderProps } from "../../wallet/WalletConnectionProvider";
15
16
  import {
@@ -20,7 +21,6 @@ import {
20
21
  import ConvertionRateProvider, {
21
22
  ConvertionRateProviderProps
22
23
  } from "../finance/convertion-rate/ConvertionRateProvider";
23
- import { BosonProvider, BosonProviderProps } from "../../boson/BosonProvider";
24
24
 
25
25
  export type CommitWidgetProvidersProps = IpfsProviderProps &
26
26
  Omit<ConfigProviderProps, "magicLinkKey" | "infuraKey"> &
@@ -5,7 +5,7 @@ import {
5
5
  ConfigProvider,
6
6
  ConfigProviderProps
7
7
  } from "../../config/ConfigProvider";
8
- import ModalProvider from "../../modal/ModalProvider";
8
+ import { ModalProvider } from "../../modal/ModalProvider";
9
9
  import { withQueryClientProvider } from "../../queryClient/withQueryClientProvider";
10
10
  import { SignerProvider } from "../../signer/SignerProvider";
11
11
  import GlobalStyle from "../../styles/GlobalStyle";
@@ -6,7 +6,7 @@ import {
6
6
  ConfigProviderProps
7
7
  } from "../../config/ConfigProvider";
8
8
  import { IpfsProvider, IpfsProviderProps } from "../../ipfs/IpfsProvider";
9
- import ModalProvider from "../../modal/ModalProvider";
9
+ import { ModalProvider } from "../../modal/ModalProvider";
10
10
  import { withQueryClientProvider } from "../../queryClient/withQueryClientProvider";
11
11
  import { SignerProvider } from "../../signer/SignerProvider";
12
12
  import GlobalStyle from "../../styles/GlobalStyle";
@@ -17,3 +17,4 @@ export * from "./contracts/erc721/useErc721OwnerOf";
17
17
  export * from "./contracts/erc1155/useErc1155Name";
18
18
  export * from "./contracts/erc1155/useErc1155Uris";
19
19
  export * from "./uniswap/useIsWindowVisible";
20
+ export * from "./connection/connection";
package/src/index.tsx CHANGED
@@ -9,6 +9,9 @@ export {
9
9
  } from "./components/ui/ThemedButton";
10
10
  export * from "./components/ui/zIndex";
11
11
  export * from "./components/ui/buttonSize";
12
+ export * from "./components/scroll/ScrollToID";
13
+ export * from "./components/scroll/ScrollToTop";
14
+ export { useConfigContext } from "./components/config/ConfigContext";
12
15
  export * from "./components/buttons/Button";
13
16
  export * from "./components/buttons/BaseButton";
14
17
  export * from "./components/buttons/CommitButtonView";
@@ -78,3 +81,4 @@ export * from "./components/wallet2/web3Status/index";
78
81
  export * from "./components/wallet2/web3Provider/index";
79
82
  export * from "./components/wallet2/accountDrawer/index";
80
83
  export * from "./components/portal/Portal";
84
+ export * from "./components/error/ErrorMessage";