diff --git a/adapters/rainbowkit-connector/CHANGELOG.md b/adapters/rainbowkit-connector/CHANGELOG.md index 63560f2b..380e9c44 100644 --- a/adapters/rainbowkit-connector/CHANGELOG.md +++ b/adapters/rainbowkit-connector/CHANGELOG.md @@ -1,5 +1,16 @@ # @blocto/rainbowkit-connector +## 2.0.0 + +### Major Changes + +- ef72999: support rainbowkt v2 + +### Patch Changes + +- Updated dependencies [d120795] + - @blocto/wagmi-connector@2.0.3 + ## 1.0.0 ### Major Changes diff --git a/adapters/rainbowkit-connector/package.json b/adapters/rainbowkit-connector/package.json index 5ef21c2f..79df4b34 100644 --- a/adapters/rainbowkit-connector/package.json +++ b/adapters/rainbowkit-connector/package.json @@ -1,6 +1,6 @@ { "name": "@blocto/rainbowkit-connector", - "version": "1.0.0", + "version": "2.0.0", "description": "blocto wallet connector to use rainbowkit", "author": "Blocto Wallet", "main": "./dist/index.js", @@ -33,8 +33,8 @@ "lint": "eslint src --ext .ts" }, "dependencies": { - "@rainbow-me/rainbowkit": "^1.0.8", - "@blocto/wagmi-connector": "npm:@blocto/wagmi-connector@^1.3.1" + "@rainbow-me/rainbowkit": "^2.0.4", + "@blocto/wagmi-connector": "^2.0.3" }, "devDependencies": { "@types/jest": "^29.5.2", diff --git a/adapters/rainbowkit-connector/src/__tests__/index.test.ts b/adapters/rainbowkit-connector/src/__tests__/index.test.ts index 7315462c..74d9b874 100644 --- a/adapters/rainbowkit-connector/src/__tests__/index.test.ts +++ b/adapters/rainbowkit-connector/src/__tests__/index.test.ts @@ -1,19 +1,8 @@ import { bloctoWallet } from '../index'; describe('rainbowkit-connector', () => { - const chains = [ - { - name: 'Ethereum', - id: 1, - network: 'mainnet', - nativeCurrency: { name: 'Ether', decimals: 18, symbol: 'ETH' }, - rpcUrls: { - default: { http: ['https://mainnet.infura.io/v3/'] }, - public: { http: ['https://mainnet.infura.io/v3/'] }, - }, - }, - ]; - const wallet = bloctoWallet({ chains }); + + const wallet = bloctoWallet(); test('defines name', () => { expect(typeof wallet.name).toBe('string'); @@ -31,7 +20,27 @@ describe('rainbowkit-connector', () => { expect(typeof wallet.createConnector).toBe('function'); }); - const { connector } = wallet.createConnector(); + const { connector } = wallet.createConnector({ + rkDetails: { + id: 'blocto', + name: 'Blocto', + shortName: 'Blocto', + rdns: 'io.blocto', + iconBackground: '#ffffff', + iconUrl: + '', + downloadUrls: { + ios: 'https://apps.apple.com/app/blocto/id1481181682', + android: + 'https://play.google.com/store/apps/details?id=com.portto.blocto', + }, + installed: true, + index: 4, + groupIndex: 2, + groupName: 'Other', + isRainbowKitConnector: true, + }, + }); test('defines account()', () => { expect(typeof connector.connect).toBe('function'); diff --git a/adapters/rainbowkit-connector/src/index.ts b/adapters/rainbowkit-connector/src/index.ts index 1eff77a6..79bf7dec 100644 --- a/adapters/rainbowkit-connector/src/index.ts +++ b/adapters/rainbowkit-connector/src/index.ts @@ -1,29 +1,27 @@ -import { Chain, Wallet } from '@rainbow-me/rainbowkit'; -import { BloctoConnector } from '@blocto/wagmi-connector'; +import { Wallet, WalletDetailsParams } from '@rainbow-me/rainbowkit'; +import { blocto, createConnector } from '@blocto/wagmi-connector'; -export interface BloctoWalletOptions { - chains: Chain[]; - appId?: string; -} - -export const bloctoWallet = ({ - chains, - appId, -}: BloctoWalletOptions): Wallet => ({ - id: 'blocto', - name: 'Blocto', - iconBackground: '#ffffff', - iconUrl: - '', - downloadUrls: { - ios: 'https://apps.apple.com/app/blocto/id1481181682', - android: 'https://play.google.com/store/apps/details?id=com.portto.blocto', - }, - installed: true, - createConnector: (): any => { - const connector = new BloctoConnector({ chains, options: { appId } }); +export const bloctoWallet = + ({ appId } = { appId: undefined }) => + (): Wallet => { return { - connector, + id: 'blocto', + name: 'Blocto', + shortName: 'Blocto', + rdns: 'io.blocto', + iconBackground: '#ffffff', + iconUrl: + '', + downloadUrls: { + ios: 'https://apps.apple.com/app/blocto/id1481181682', + android: + 'https://play.google.com/store/apps/details?id=com.portto.blocto', + }, + installed: true, + createConnector: (walletDetails: WalletDetailsParams) => + createConnector((config) => ({ + ...blocto({ appId })(config), + ...walletDetails, + })), }; - }, -}); + }; diff --git a/adapters/wagmi-connector/CHANGELOG.md b/adapters/wagmi-connector/CHANGELOG.md index ea879fba..e5979c3a 100644 --- a/adapters/wagmi-connector/CHANGELOG.md +++ b/adapters/wagmi-connector/CHANGELOG.md @@ -1,5 +1,11 @@ # @blocto/wagmi-connector +## 2.0.3 + +### Patch Changes + +- d120795: export wagmi createConnector function + ## 2.0.2 ### Patch Changes diff --git a/adapters/wagmi-connector/package.json b/adapters/wagmi-connector/package.json index 3ac6751b..c2dbabe4 100644 --- a/adapters/wagmi-connector/package.json +++ b/adapters/wagmi-connector/package.json @@ -2,7 +2,7 @@ "name": "@blocto/wagmi-connector", "description": "Blocto wallet connector extend from wagmi Connector", "author": "Calvin Chang", - "version": "2.0.2", + "version": "2.0.3", "type": "module", "main": "./dist/index.umd.cjs", "module": "./dist/index.js", diff --git a/adapters/wagmi-connector/src/connector.ts b/adapters/wagmi-connector/src/connector.ts index a58e0b80..1b702ee2 100644 --- a/adapters/wagmi-connector/src/connector.ts +++ b/adapters/wagmi-connector/src/connector.ts @@ -163,3 +163,5 @@ export function blocto({ appId }: BloctoParameters = {}) { }, })); } + +export { createConnector }; \ No newline at end of file diff --git a/adapters/wagmi-connector/src/index.ts b/adapters/wagmi-connector/src/index.ts index 13fa4c2b..a3c60004 100644 --- a/adapters/wagmi-connector/src/index.ts +++ b/adapters/wagmi-connector/src/index.ts @@ -1,2 +1,2 @@ -export { blocto } from './connector'; +export { blocto, createConnector } from './connector'; export type * from './connector'; diff --git a/yarn.lock b/yarn.lock index e5cca977..2e1516e9 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1555,10 +1555,10 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" -"@emotion/hash@^0.8.0": - version "0.8.0" - resolved "https://registry.npmjs.org/@emotion/hash/-/hash-0.8.0.tgz" - integrity sha512-kBJtf7PH6aWwZ6fka3zQ0p6SBYzx4fl1LoZXE2RrnYST9Xljm7WfKJrU4g/Xr3Beg72MLrp1AWNUmuYJTL7Cow== +"@emotion/hash@^0.9.0": + version "0.9.1" + resolved "https://registry.yarnpkg.com/@emotion/hash/-/hash-0.9.1.tgz#4ffb0055f7ef676ebc3a5a91fb621393294e2f43" + integrity sha512-gJB6HLm5rYwSLI6PQa+X1t5CFGrv1J1TWG+sOyMCeKz2ojaj6Fnl/rZEspogG+cvqbt4AE/2eIyD2QfLKTBNlQ== "@emotion/is-prop-valid@^0.8.2": version "0.8.8" @@ -2737,17 +2737,18 @@ resolved "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz" integrity sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg== -"@rainbow-me/rainbowkit@^1.0.8": - version "1.0.11" - resolved "https://registry.npmjs.org/@rainbow-me/rainbowkit/-/rainbowkit-1.0.11.tgz" - integrity sha512-+cm6+WUPG9iPgkfJKbvlowcrSHu266Zk20LVRsYLcmb6v29gVMHcWQvyI4T6EVC9TxNjnyq/jIlen++uiUBmmQ== +"@rainbow-me/rainbowkit@^2.0.4": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@rainbow-me/rainbowkit/-/rainbowkit-2.0.5.tgz#efe34e97ee342b8cd10538384f71e9ca01ab8306" + integrity sha512-JVBgl0J1EvYXrGxDJmqEVMFrjE3gGidHyacFilKu/zJdaHFGXogsmCG51DdaU3gsas0Aqbq9kqK13qk49VSfAg== dependencies: - "@vanilla-extract/css" "1.9.1" - "@vanilla-extract/dynamic" "2.0.2" - "@vanilla-extract/sprinkles" "1.5.0" - clsx "1.1.1" - qrcode "1.5.0" - react-remove-scroll "2.5.4" + "@vanilla-extract/css" "1.14.0" + "@vanilla-extract/dynamic" "2.1.0" + "@vanilla-extract/sprinkles" "1.6.1" + clsx "2.1.0" + qrcode "1.5.3" + react-remove-scroll "2.5.7" + ua-parser-js "^1.0.37" "@rollup/plugin-alias@^5.0.0": version "5.0.0" @@ -3630,27 +3631,27 @@ "@typescript-eslint/types" "5.62.0" eslint-visitor-keys "^3.3.0" -"@vanilla-extract/css@1.9.1": - version "1.9.1" - resolved "https://registry.npmjs.org/@vanilla-extract/css/-/css-1.9.1.tgz" - integrity sha512-pu2SFiff5jRhPwvGoj8cM5l/qIyLvigOmy22ss5DGjwV5pJYezRjDLxWumi2luIwioMWvh9EozCjyfH8nq+7fQ== +"@vanilla-extract/css@1.14.0": + version "1.14.0" + resolved "https://registry.yarnpkg.com/@vanilla-extract/css/-/css-1.14.0.tgz#45fab9c04d893e3e363cf2cde7559d21233b7f63" + integrity sha512-rYfm7JciWZ8PFzBM/HDiE2GLnKI3xJ6/vdmVJ5BSgcCZ5CxRlM9Cjqclni9lGzF3eMOijnUhCd/KV8TOzyzbMA== dependencies: - "@emotion/hash" "^0.8.0" + "@emotion/hash" "^0.9.0" "@vanilla-extract/private" "^1.0.3" - ahocorasick "1.0.2" chalk "^4.1.1" - css-what "^5.0.1" + css-what "^6.1.0" cssesc "^3.0.0" csstype "^3.0.7" - deep-object-diff "^1.1.0" + deep-object-diff "^1.1.9" deepmerge "^4.2.2" media-query-parser "^2.0.2" + modern-ahocorasick "^1.0.0" outdent "^0.8.0" -"@vanilla-extract/dynamic@2.0.2": - version "2.0.2" - resolved "https://registry.npmjs.org/@vanilla-extract/dynamic/-/dynamic-2.0.2.tgz" - integrity sha512-U4nKaEQ8Kuz+exXEr51DUpyaOuzo24/S/k1YbDPQR06cYcNjQqvwFRnwWtZ+9ImocqM1wTKtzrdUgSTtLGIwAg== +"@vanilla-extract/dynamic@2.1.0": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@vanilla-extract/dynamic/-/dynamic-2.1.0.tgz#316d3bd4adfd5f5c9fb080445c41d55abe3b463c" + integrity sha512-8zl0IgBYRtgD1h+56Zu13wHTiMTJSVEa4F7RWX9vTB/5Xe2KtjoiqApy/szHPVFA56c+ex6A4GpCQjT1bKXbYw== dependencies: "@vanilla-extract/private" "^1.0.3" @@ -3659,10 +3660,10 @@ resolved "https://registry.npmjs.org/@vanilla-extract/private/-/private-1.0.3.tgz" integrity sha512-17kVyLq3ePTKOkveHxXuIJZtGYs+cSoev7BlP+Lf4916qfDhk/HBjvlYDe8egrea7LNPHKwSZJK/bzZC+Q6AwQ== -"@vanilla-extract/sprinkles@1.5.0": - version "1.5.0" - resolved "https://registry.npmjs.org/@vanilla-extract/sprinkles/-/sprinkles-1.5.0.tgz" - integrity sha512-W58f2Rzz5lLmk0jbhgStVlZl5wEiPB1Ur3fRvUaBM+MrifZ3qskmFq/CiH//fEYeG5Dh9vF1qRviMMH46cX9Nw== +"@vanilla-extract/sprinkles@1.6.1": + version "1.6.1" + resolved "https://registry.yarnpkg.com/@vanilla-extract/sprinkles/-/sprinkles-1.6.1.tgz#2c8a832757a0d8104dc6bd5d961db2c70d1dbdcb" + integrity sha512-N/RGKwGAAidBupZ436RpuweRQHEFGU+mvAqBo8PRMAjJEmHoPDttV8RObaMLrJHWLqvX+XUMinHUnD0hFRQISw== "@vitest/coverage-v8@^1.2.0": version "1.2.0" @@ -4218,11 +4219,6 @@ agentkeepalive@^4.3.0: dependencies: humanize-ms "^1.2.1" -ahocorasick@1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/ahocorasick/-/ahocorasick-1.0.2.tgz" - integrity sha512-hCOfMzbFx5IDutmWLAt6MZwOUjIfSM9G9FyVxytmE4Rs/5YDPWQrD/+IR1w+FweD9H2oOZEnv36TmkjhNURBVA== - ajv@^6.12.3, ajv@^6.12.4, ajv@~6.12.6: version "6.12.6" resolved "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz" @@ -5263,10 +5259,10 @@ clone@^1.0.2: resolved "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz" integrity sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg== -clsx@1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/clsx/-/clsx-1.1.1.tgz" - integrity sha512-6/bPho624p3S2pMyvP5kKBPXnI3ufHLObBFCfgx+LkeR5lg2XYy2hqZqUf45ypD8COn2bhgGJSUE+l5dhNBieA== +clsx@2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/clsx/-/clsx-2.1.0.tgz#e851283bcb5c80ee7608db18487433f7b23f77cb" + integrity sha512-m3iNNWpd9rl3jvvcBnu70ylMdrXt8Vlq4HYadnU5fwcOtvkSQWPmj7amUcDT2qYI7risszBjI5AUIUox9D16pg== clsx@^1.1.0: version "1.2.1" @@ -5632,10 +5628,10 @@ css-to-react-native@^3.0.0: css-color-keywords "^1.0.0" postcss-value-parser "^4.0.2" -css-what@^5.0.1: - version "5.1.0" - resolved "https://registry.npmjs.org/css-what/-/css-what-5.1.0.tgz" - integrity sha512-arSMRWIIFY0hV8pIxZMEfmMI47Wj3R/aWpZDDxWYCPEiOMv6tfOrnpDtgxBYPEQD4V0Y/958+1TdC3iWTFcUPw== +css-what@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4" + integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== cssesc@^3.0.0: version "3.0.0" @@ -5803,9 +5799,9 @@ deep-is@^0.1.3: resolved "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz" integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== -deep-object-diff@^1.1.0: +deep-object-diff@^1.1.9: version "1.1.9" - resolved "https://registry.npmjs.org/deep-object-diff/-/deep-object-diff-1.1.9.tgz" + resolved "https://registry.yarnpkg.com/deep-object-diff/-/deep-object-diff-1.1.9.tgz#6df7ef035ad6a0caa44479c536ed7b02570f4595" integrity sha512-Rn+RuwkmkDwCi2/oXOFS9Gsr5lJZu/yTGpK7wAaAIE75CC+LCGEZHpY6VQJa/RoJcrmaA/docWJZvYohlNkWPA== deepmerge@^4.2.2: @@ -9730,6 +9726,11 @@ mock-fs@^4.1.0: resolved "https://registry.npmjs.org/mock-fs/-/mock-fs-4.14.0.tgz" integrity sha512-qYvlv/exQ4+svI3UOvPUpLDF0OMX5euvUH0Ny4N5QyRyhNdgAgUrVH3iUINSzEPLvx0kbo/Bp28GJKIqvE7URw== +modern-ahocorasick@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/modern-ahocorasick/-/modern-ahocorasick-1.0.1.tgz#dec373444f51b5458ac05216a8ec376e126dd283" + integrity sha512-yoe+JbhTClckZ67b2itRtistFKf8yPYelHLc7e5xAwtNAXxM6wJTUx2C7QeVSJFDzKT7bCIFyBVybPMKvmB9AA== + morgan@^1.9.1: version "1.10.0" resolved "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz" @@ -10672,16 +10673,6 @@ pure-rand@^6.0.0: resolved "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.3.tgz" integrity sha512-KddyFewCsO0j3+np81IQ+SweXLDnDQTs5s67BOnrYmYe/yNmUhttQyGsYzy8yUnoljGAQ9sl38YB4vH8ur7Y+w== -qrcode@1.5.0: - version "1.5.0" - resolved "https://registry.npmjs.org/qrcode/-/qrcode-1.5.0.tgz" - integrity sha512-9MgRpgVc+/+47dFvQeD6U2s0Z92EsKzcHogtum4QB+UNd025WOJSHvn/hjk9xmzj7Stj95CyUAs31mrjxliEsQ== - dependencies: - dijkstrajs "^1.0.1" - encode-utf8 "^1.0.3" - pngjs "^5.0.0" - yargs "^15.3.1" - qrcode@1.5.3, qrcode@^1.5.0, qrcode@^1.5.1: version "1.5.3" resolved "https://registry.npmjs.org/qrcode/-/qrcode-1.5.3.tgz" @@ -10807,20 +10798,20 @@ react-is@^18.0.0: resolved "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz" integrity sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w== -react-remove-scroll-bar@^2.3.3: - version "2.3.4" - resolved "https://registry.npmjs.org/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.4.tgz" - integrity sha512-63C4YQBUt0m6ALadE9XV56hV8BgJWDmmTPY758iIJjfQKt2nYwoUrPk0LXRXcB/yIj82T1/Ixfdpdk68LwIB0A== +react-remove-scroll-bar@^2.3.4: + version "2.3.6" + resolved "https://registry.yarnpkg.com/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.6.tgz#3e585e9d163be84a010180b18721e851ac81a29c" + integrity sha512-DtSYaao4mBmX+HDo5YWYdBWQwYIQQshUV/dVxFxK+KM26Wjwp1gZ6rv6OC3oujI6Bfu6Xyg3TwK533AQutsn/g== dependencies: react-style-singleton "^2.2.1" tslib "^2.0.0" -react-remove-scroll@2.5.4: - version "2.5.4" - resolved "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.4.tgz" - integrity sha512-xGVKJJr0SJGQVirVFAUZ2k1QLyO6m+2fy0l8Qawbp5Jgrv3DeLalrfMNBFSlmz5kriGGzsVBtGVnf4pTKIhhWA== +react-remove-scroll@2.5.7: + version "2.5.7" + resolved "https://registry.yarnpkg.com/react-remove-scroll/-/react-remove-scroll-2.5.7.tgz#15a1fd038e8497f65a695bf26a4a57970cac1ccb" + integrity sha512-FnrTWO4L7/Bhhf3CYBNArEG/yROV0tKmTv7/3h9QCFvH6sndeFf1wPqOcbFVu5VAulS5dV1wGT3GZZ/1GawqiA== dependencies: - react-remove-scroll-bar "^2.3.3" + react-remove-scroll-bar "^2.3.4" react-style-singleton "^2.2.1" tslib "^2.1.0" use-callback-ref "^1.3.0" @@ -12667,6 +12658,11 @@ typescript@~5.1.3: resolved "https://registry.npmjs.org/typescript/-/typescript-5.1.6.tgz" integrity sha512-zaWCozRZ6DLEWAWFrVDz1H6FVXzUSfTy5FUMWsQlU8Ym5JP9eO4xkTIROFCQvhQf61z6O/G6ugw3SgAnvvm+HA== +ua-parser-js@^1.0.37: + version "1.0.37" + resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-1.0.37.tgz#b5dc7b163a5c1f0c510b08446aed4da92c46373f" + integrity sha512-bhTyI94tZofjo+Dn8SN6Zv8nBDvyXTymAdM3LDI/0IboIUwTu1rEhW7v2TfiVsoYWgkQ4kOVqnI8APUFbIQIFQ== + ufo@^1.3.2: version "1.3.2" resolved "https://registry.yarnpkg.com/ufo/-/ufo-1.3.2.tgz#c7d719d0628a1c80c006d2240e0d169f6e3c0496"