Hướng Dẫn Di Chuyển
Di Chuyển RainbowKit
Các peer dependencies wagmi và viem đã đạt phiên bản 2.x.x
với các thay đổi phá vỡ.
Làm theo các bước dưới đây để di chuyển.
1. Nâng cấp RainbowKit, wagmi
và viem
lên phiên bản mới nhất
2. Cài đặt peer dependency @tanstack/react-query
Với Wagmi v2, TanStack Query bây giờ là một peer dependency bắt buộc.
Cài đặt nó bằng lệnh sau:
3. Nâng cấp cấu hình RainbowKit và Wagmi của bạn
4. Kiểm tra các thay đổi phá vỡ trong wagmi
và viem
Nếu bạn sử dụng các hooks wagmi
và các actions viem
trong dApp của bạn, bạn sẽ cần theo dõi các hướng dẫn di chuyển cho v2:
1. Cải thiện hành vi cho các ví EIP-6963
Các ví hỗ trợ tiêu chuẩn kết nối EIP-6963 mới (bao gồm Rainbow, MetaMask, và nhiều hơn nữa) bây giờ sẽ tự động xuất hiện trong một phần 'Đã cài đặt' trong quá trình kết nối ví. Điều này đảm bảo rằng người dùng luôn có thể tìm thấy các ví ưa thích của họ và kết nối với dApps mà không gặp xung đột hoặc nút dự phòng.
Các nhà phát triển tiếp tục có toàn quyền kiểm soát Danh sách Ví Tùy chỉnh để nhấn mạnh các ví ưa thích cho người dùng cuối. Khuyến nghị rằng bạn tiếp tục bao gồm injectedWallet
và walletConnectWallet
trong danh sách của bạn để hỗ trợ tất cả các nền tảng.
2. Cấu hình Wagmi với getDefaultConfig
API mới này đơn giản hóa trải nghiệm cấu hình và thay thế nhu cầu sử dụng trực tiếp createConfig
của Wagmi. Cấu hình chuỗi đơn giản hơn, bao gồm các nhà cung cấp công khai được suy luận cho transports
.
Danh sách ví mặc định sẽ được tự động bao gồm, bãi bỏ nhu cầu sử dụng getDefaultWallets
và connectorsForWallets
.
Bạn có thể tạo một Danh sách Ví Tùy chỉnh bằng cách truyền các connector Ví nhập khẩu hoặc Tùy chỉnh vào wallets
. Khởi tạo các connector ví và truyền projectId
và chains
không còn bắt buộc nữa.
3. RainbowKitProvider
Bạn không còn cần truyền chains
vào <RainbowKitProvider>
.
4. Chuỗi Tùy chỉnh
Loại Chain
đã thay đổi theo Wagmi v2 và tiếp tục hỗ trợ siêu dữ liệu iconUrl
và iconBackground
của RainbowKit.
Ví dụ với getDefaultConfig
:
Ví dụ với createConfig
:
5. Ví tùy chỉnh
Các connector ví RainbowKit đã trải qua nhiều thay đổi đáng kể để hỗ trợ Wagmi v2. Tham khảo tài liệu đã được cập nhật và một ví dụ về connector để nâng cấp bất kỳ Kết Nối Ví Tùy Chỉnh nào trong dApp của bạn.
Các connector ví bây giờ cũng hỗ trợ tiêu chuẩn EIP-6963 với thuộc tính rdns
. Đảm bảo rằng điều này được điền để ngăn chặn các tham chiếu trùng lặp tới các ví hỗ trợ EIP-6963 trong danh sách ví của bạn.
Phụ thuộc đồng hành wagmi đã được cập nhật lên 1.x.x
.
Làm theo các bước dưới đây để di chuyển.
**1. Nâng cấp RainbowKit và wagmi
lên phiên bản mới nhất
**2. Cài đặt phụ thuộc viem
wagmi v1 yêu cầu phụ thuộc đồng hành viem
. Cài đặt nó bằng lệnh sau:
**3. Đảm bảo tính tương thích của bundler và polyfill
Trong các phiên bản trước của wagmi dựa vào ethers, các module fs
, net
, và tls
yêu cầu bởi WalletConnect đã được tự động polyfill. Điều này không còn đúng với RainbowKit v1 + wagmi v1, được xây dựng trên viem.
Tham khảo Cấu Hình Webpack của Next.js và các mẫu polyfills của Create React App cho hướng dẫn cấu hình cho dự án của bạn.
Hướng dẫn khung bổ sung cho Vite và Remix có sẵn tại đây.
**4. Kiểm tra thay đổi phá vỡ trong wagmi
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần theo dõi hướng dẫn di chuyển wagmi
lên v1.
Bạn có thể xem hướng dẫn di chuyển của họ tại đây.
Phụ thuộc đồng hành wagmi đã được cập nhật lên 0.12.x
.
RainbowKit đã thông qua kết nối WalletConnectLegacyConnector
trong wagmi
để tiếp tục hỗ trợ WalletConnect v1. Hỗ trợ cho WalletConnect v2 và WalletConnectConnector
sẽ sớm có bản phát hành bản vá mà không có thay đổi phá vỡ.
Ví sẽ được chuyển tự động trong các bản phát hành tương lai.
Mọi dApp bây giờ phải cung cấp một projectId
WalletConnect Cloud để kích hoạt WalletConnect v2. Điều này phải hoàn thành trước khi các máy chủ cầu nối của WalletConnect v1 bị tắt vào ngày 28 tháng 6 năm 2023. RainbowKit sẽ âm thầm ưu tiên v1 cho tất cả các ví nếu projectId
không được chỉ định.
Làm theo các bước dưới đây để di chuyển.
Mỗi dApp dựa vào WalletConnect hiện nay cần phải có projectId
từ WalletConnect Cloud. Việc này hoàn toàn miễn phí và chỉ mất vài phút.
Cung cấp projectId
cho getDefaultWallets
và các kết nối ví RainbowKit cá nhân như sau:
Phụ thuộc đồng hành wagmi đã được cập nhật lên 0.11.x
.
Làm theo các bước dưới đây để di chuyển.
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần kiểm tra xem ứng dụng của mình có bị ảnh hưởng bởi các thay đổi phá vỡ trong wagmi
hay không.
Bạn có thể xem hướng dẫn di chuyển của họ tại đây.
Phụ thuộc đồng hành wagmi đã được cập nhật lên 0.10.x
.
Làm theo các bước dưới đây để di chuyển.
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần kiểm tra xem ứng dụng của mình có bị ảnh hưởng bởi các thay đổi phá vỡ trong wagmi
hay không.
Bạn có thể xem hướng dẫn di chuyển của họ tại đây.
Phụ thuộc đồng hành wagmi đã được cập nhật lên 0.9.x
.
Làm theo các bước dưới đây để di chuyển.
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần kiểm tra xem ứng dụng của mình có bị ảnh hưởng bởi các thay đổi phá vỡ trong wagmi
hay không.
Bạn có thể xem hướng dẫn di chuyển của họ tại đây.
Phụ thuộc đồng hành wagmi đã được cập nhật lên 0.8.x
.
Làm theo các bước dưới đây để di chuyển.
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần kiểm tra xem ứng dụng của mình có bị ảnh hưởng bởi các thay đổi phá vỡ trong wagmi
hay không.
Bạn có thể xem hướng dẫn di chuyển của họ tại đây.
Nếu bạn đang tạo một danh sách ví tùy chỉnh, bây giờ bạn phải import từng ví riêng lẻ để giảm kích thước gói. Lưu ý rằng vì các ví không còn được đặt tên qua object wallet
, tất cả các ví bây giờ có hậu tố Wallet
.
Cũng lưu ý rằng lớp tương thích ngược của Steakwallet đã bị loại bỏ. Nên sử dụng Omni thay thế.
RainbowKit đã cập nhật phụ thuộc đồng hành wagmi
lên 0.5.x
.
Làm theo các bước dưới đây để di chuyển.
Nâng cấp RainbowKit và wagmi lên phiên bản mới nhất
Nếu bạn sử dụng các hook của wagmi
trong ứng dụng của mình, bạn sẽ cần kiểm tra xem ứng dụng của mình có bị ảnh hưởng bởi các thay đổi phá vỡ trong wagmi
hay không.
Bạn có thể xem hướng dẫn di chuyển của họ ở đây.
Đã xóa tham số chainId
khỏi createConnector
trên loại Wallet
.
Lưu ý rằng tất cả các ví tích hợp sẵn đang sử dụng API mới. Hầu hết người dùng sẽ không bị ảnh hưởng. Thay đổi này chỉ ảnh hưởng đến những người dùng đã tạo/tiêu thụ ví tùy chỉnh.
Nếu bạn trước đây đã dẫn xuất các URL RPC từ chainId
trên createConnector
, hiện tại bạn có thể loại bỏ logic đó vì wagmi
hiện xử lý URL RPC nội bộ khi được sử dụng với configureChains
.
RainbowKit đã cập nhật phụ thuộc đối tác wagmi
lên ^0.4
.
Làm theo các bước dưới đây để di chuyển.
Nâng cấp RainbowKit và wagmi lên phiên bản mới nhất
Nhập configureChains
từ wagmi thay vì RainbowKit:
RainbowKit không còn xuất API apiProvider
nữa. Thay thế nó với provider mong muốn của bạn từ wagmi.
Nhập alchemyProvider
từ wagmi/providers/alchemy
.
Nhập infuraProvider
từ wagmi/providers/infura
.
Nhập jsonRpcProvider
từ wagmi/providers/jsonRpc
.
Nhập publicProvider
từ wagmi/providers/public
.
Đổi tên WagmiProvider
thành WagmiConfig
.
Và bạn đã hoàn thành! 🌈