From f2b7ebd95d15172c861261436fc123fcd63f60ae Mon Sep 17 00:00:00 2001 From: Misha Sitalov Date: Wed, 9 Oct 2024 17:55:15 +0100 Subject: [PATCH 1/3] Add `sweat-wallet` package --- .../react/contexts/WalletSelectorContext.tsx | 3 +- .../contexts/WalletSelectorExportContext.tsx | 2 + examples/react/project.json | 2 +- package.json | 5 ++- packages/sweat-wallet/.eslintrc.json | 18 ++++++++ packages/sweat-wallet/README.md | 11 +++++ packages/sweat-wallet/jest.config.ts | 10 +++++ packages/sweat-wallet/package.json | 5 +++ packages/sweat-wallet/project.json | 44 +++++++++++++++++++ packages/sweat-wallet/src/index.ts | 1 + packages/sweat-wallet/src/lib/icon.ts | 1 + packages/sweat-wallet/src/lib/sweat-wallet.ts | 25 +++++++++++ packages/sweat-wallet/tsconfig.json | 22 ++++++++++ packages/sweat-wallet/tsconfig.lib.json | 10 +++++ packages/sweat-wallet/tsconfig.spec.json | 14 ++++++ tsconfig.base.json | 3 ++ yarn.lock | 36 ++++----------- 17 files changed, 181 insertions(+), 31 deletions(-) create mode 100644 packages/sweat-wallet/.eslintrc.json create mode 100644 packages/sweat-wallet/README.md create mode 100644 packages/sweat-wallet/jest.config.ts create mode 100644 packages/sweat-wallet/package.json create mode 100644 packages/sweat-wallet/project.json create mode 100644 packages/sweat-wallet/src/index.ts create mode 100644 packages/sweat-wallet/src/lib/icon.ts create mode 100644 packages/sweat-wallet/src/lib/sweat-wallet.ts create mode 100644 packages/sweat-wallet/tsconfig.json create mode 100644 packages/sweat-wallet/tsconfig.lib.json create mode 100644 packages/sweat-wallet/tsconfig.spec.json diff --git a/examples/react/contexts/WalletSelectorContext.tsx b/examples/react/contexts/WalletSelectorContext.tsx index 82a355885..3db6ddcc5 100644 --- a/examples/react/contexts/WalletSelectorContext.tsx +++ b/examples/react/contexts/WalletSelectorContext.tsx @@ -29,6 +29,7 @@ import { setupMintbaseWallet } from "@near-wallet-selector/mintbase-wallet"; import { setupBitteWallet } from "@near-wallet-selector/bitte-wallet"; import { setupOKXWallet } from "@near-wallet-selector/okx-wallet"; import { setupEthereumWallets } from "@near-wallet-selector/ethereum-wallets"; +import { setupSweatWallet } from "@near-wallet-selector/sweat-wallet"; import type { ReactNode } from "react"; import React, { @@ -53,7 +54,6 @@ import { injected, walletConnect } from "@wagmi/connectors"; import { Loading } from "../components/Loading"; import { CONTRACT_ID } from "../constants"; - declare global { interface Window { selector: WalletSelector; @@ -190,6 +190,7 @@ export const WalletSelectorContextProvider: React.FC<{ setupMintbaseWallet({ contractId: CONTRACT_ID }), setupBitteWallet({ contractId: CONTRACT_ID }), setupEthereumWallets({ wagmiConfig, web3Modal }), + setupSweatWallet(), ], }); const _modal = setupModal(_selector, { diff --git a/examples/react/contexts/WalletSelectorExportContext.tsx b/examples/react/contexts/WalletSelectorExportContext.tsx index 012ca0b29..5c0ec5779 100644 --- a/examples/react/contexts/WalletSelectorExportContext.tsx +++ b/examples/react/contexts/WalletSelectorExportContext.tsx @@ -29,6 +29,7 @@ import { setupRamperWallet } from "@near-wallet-selector/ramper-wallet"; import { setupNearMobileWallet } from "@near-wallet-selector/near-mobile-wallet"; import { setupMintbaseWallet } from "@near-wallet-selector/mintbase-wallet"; import { setupBitteWallet } from "@near-wallet-selector/bitte-wallet"; +import { setupSweatWallet } from "@near-wallet-selector/sweat-wallet"; import { CONTRACT_ID } from "../constants"; declare global { @@ -86,6 +87,7 @@ export const ExportAccountSelectorContextProvider: React.FC<{ }, }), setupNearMobileWallet(), + setupSweatWallet(), ], }); /** diff --git a/examples/react/project.json b/examples/react/project.json index c3ded4b03..09fa4d05f 100644 --- a/examples/react/project.json +++ b/examples/react/project.json @@ -137,7 +137,7 @@ "export": { "executor": "@nx/next:export", "options": { - "buildTarget": "next:build:production" + "buildTarget": "react:build:production" } }, "lint": { diff --git a/package.json b/package.json index 3758971b1..0813305de 100644 --- a/package.json +++ b/package.json @@ -26,7 +26,8 @@ "near-mobile-wallet", "mintbase-wallet", "bitte-wallet", - "okx-wallet" + "okx-wallet", + "sweat-wallet" ], "homepage": "https://github.com/near/wallet-selector#README", "bugs": { @@ -72,6 +73,7 @@ "build:wallet-utils": "nx run-many --target=build --projects=wallet-utils --configuration=production", "build:welldone-wallet": "nx run-many --target=build --projects=welldone-wallet --configuration=production", "build:xdefi-wallet": "nx run-many --target=build --projects=xdefi --configuration=production", + "build:sweat-wallet": "nx run-many --target=build --projects=sweat-wallet --configuration=production", "examples:vanillajs:generateimportmap": "(cd examples/vanillajs && jspm link index.html -o index.html)", "find:unused": "ts-prune -p tsprune.json", "postinstall": "yarn build:all", @@ -106,6 +108,7 @@ "@noble/hashes": "1.4.0", "@peersyst/near-mobile-signer": "1.1.4", "@ramper/near": "0.0.30", + "@sweatco/wallet-selector": "1.0.0-alpha.0", "@tanstack/react-query": "5.24.8", "@walletconnect/modal": "2.6.2", "@walletconnect/sign-client": "2.13.0", diff --git a/packages/sweat-wallet/.eslintrc.json b/packages/sweat-wallet/.eslintrc.json new file mode 100644 index 000000000..9d9c0db55 --- /dev/null +++ b/packages/sweat-wallet/.eslintrc.json @@ -0,0 +1,18 @@ +{ + "extends": ["../../.eslintrc.json"], + "ignorePatterns": ["!**/*"], + "overrides": [ + { + "files": ["*.ts", "*.tsx", "*.js", "*.jsx"], + "rules": {} + }, + { + "files": ["*.ts", "*.tsx"], + "rules": {} + }, + { + "files": ["*.js", "*.jsx"], + "rules": {} + } + ] +} diff --git a/packages/sweat-wallet/README.md b/packages/sweat-wallet/README.md new file mode 100644 index 000000000..c2e1cffd9 --- /dev/null +++ b/packages/sweat-wallet/README.md @@ -0,0 +1,11 @@ +# sweat-wallet + +This library was generated with [Nx](https://nx.dev). + +## Building + +Run `nx build sweat-wallet` to build the library. + +## Running unit tests + +Run `nx test sweat-wallet` to execute the unit tests via [Jest](https://jestjs.io). diff --git a/packages/sweat-wallet/jest.config.ts b/packages/sweat-wallet/jest.config.ts new file mode 100644 index 000000000..fb0362c6a --- /dev/null +++ b/packages/sweat-wallet/jest.config.ts @@ -0,0 +1,10 @@ +/* eslint-disable */ +export default { + displayName: "sweat-wallet", + preset: "../../jest.preset.js", + transform: { + "^.+\\.[tj]s$": ["ts-jest", { tsconfig: "/tsconfig.spec.json" }], + }, + moduleFileExtensions: ["ts", "js", "html"], + coverageDirectory: "../../coverage/packages/sweat-wallet", +}; diff --git a/packages/sweat-wallet/package.json b/packages/sweat-wallet/package.json new file mode 100644 index 000000000..fbe9f822b --- /dev/null +++ b/packages/sweat-wallet/package.json @@ -0,0 +1,5 @@ +{ + "name": "@near-wallet-selector/sweat-wallet", + "version": "0.0.1", + "description": "Sweat Wallet package for NEAR Wallet Selector." +} diff --git a/packages/sweat-wallet/project.json b/packages/sweat-wallet/project.json new file mode 100644 index 000000000..efe681b98 --- /dev/null +++ b/packages/sweat-wallet/project.json @@ -0,0 +1,44 @@ +{ + "name": "sweat-wallet", + "$schema": "../../node_modules/nx/schemas/project-schema.json", + "sourceRoot": "packages/sweat-wallet/src", + "projectType": "library", + "targets": { + "build": { + "executor": "@nx/js:tsc", + "outputs": ["{options.outputPath}"], + "options": { + "outputPath": "dist/packages/sweat-wallet", + "main": "packages/sweat-wallet/src/index.ts", + "tsConfig": "packages/sweat-wallet/tsconfig.lib.json", + "assets": ["packages/sweat-wallet/*.md"] + } + }, + "publish": { + "command": "node tools/scripts/publish.mjs sweat-wallet {args.ver} {args.tag}", + "dependsOn": ["build"] + }, + "lint": { + "executor": "@nx/linter:eslint", + "outputs": ["{options.outputFile}"], + "options": { + "lintFilePatterns": ["packages/sweat-wallet/**/*.ts"] + } + }, + "test": { + "executor": "@nx/jest:jest", + "outputs": ["{workspaceRoot}/coverage/{projectRoot}"], + "options": { + "jestConfig": "packages/sweat-wallet/jest.config.ts", + "passWithNoTests": true + }, + "configurations": { + "ci": { + "ci": true, + "codeCoverage": true + } + } + } + }, + "tags": ["injected-wallet"] +} diff --git a/packages/sweat-wallet/src/index.ts b/packages/sweat-wallet/src/index.ts new file mode 100644 index 000000000..6a0d62ba1 --- /dev/null +++ b/packages/sweat-wallet/src/index.ts @@ -0,0 +1 @@ +export * from "./lib/sweat-wallet"; diff --git a/packages/sweat-wallet/src/lib/icon.ts b/packages/sweat-wallet/src/lib/icon.ts new file mode 100644 index 000000000..a2227bc26 --- /dev/null +++ b/packages/sweat-wallet/src/lib/icon.ts @@ -0,0 +1 @@ +export default ""; diff --git a/packages/sweat-wallet/src/lib/sweat-wallet.ts b/packages/sweat-wallet/src/lib/sweat-wallet.ts new file mode 100644 index 000000000..4196f20f5 --- /dev/null +++ b/packages/sweat-wallet/src/lib/sweat-wallet.ts @@ -0,0 +1,25 @@ +import type { + WalletModuleFactory, + InjectedWallet, +} from "@near-wallet-selector/core"; +import { initSweatWallet } from "@sweatco/wallet-selector"; + +import iconUrl from "./icon"; + +export function setupSweatWallet(): WalletModuleFactory { + return async () => { + return { + id: "sweat-wallet", + type: "injected", + metadata: { + iconUrl, + name: "SWEAT Wallet", + description: "SWEAT Wallet for NEAR Protocol", + downloadUrl: "https://sweateconomy.org", + deprecated: false, + available: true, + }, + init: initSweatWallet, + }; + }; +} diff --git a/packages/sweat-wallet/tsconfig.json b/packages/sweat-wallet/tsconfig.json new file mode 100644 index 000000000..f5b85657a --- /dev/null +++ b/packages/sweat-wallet/tsconfig.json @@ -0,0 +1,22 @@ +{ + "extends": "../../tsconfig.base.json", + "compilerOptions": { + "module": "commonjs", + "forceConsistentCasingInFileNames": true, + "strict": true, + "noImplicitOverride": true, + "noPropertyAccessFromIndexSignature": true, + "noImplicitReturns": true, + "noFallthroughCasesInSwitch": true + }, + "files": [], + "include": [], + "references": [ + { + "path": "./tsconfig.lib.json" + }, + { + "path": "./tsconfig.spec.json" + } + ] +} diff --git a/packages/sweat-wallet/tsconfig.lib.json b/packages/sweat-wallet/tsconfig.lib.json new file mode 100644 index 000000000..33eca2c2c --- /dev/null +++ b/packages/sweat-wallet/tsconfig.lib.json @@ -0,0 +1,10 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "declaration": true, + "types": ["node"] + }, + "include": ["src/**/*.ts"], + "exclude": ["jest.config.ts", "src/**/*.spec.ts", "src/**/*.test.ts"] +} diff --git a/packages/sweat-wallet/tsconfig.spec.json b/packages/sweat-wallet/tsconfig.spec.json new file mode 100644 index 000000000..9b2a121d1 --- /dev/null +++ b/packages/sweat-wallet/tsconfig.spec.json @@ -0,0 +1,14 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "outDir": "../../dist/out-tsc", + "module": "commonjs", + "types": ["jest", "node"] + }, + "include": [ + "jest.config.ts", + "src/**/*.test.ts", + "src/**/*.spec.ts", + "src/**/*.d.ts" + ] +} diff --git a/tsconfig.base.json b/tsconfig.base.json index 6d60f7849..218bcb8b6 100644 --- a/tsconfig.base.json +++ b/tsconfig.base.json @@ -42,6 +42,9 @@ "@near-wallet-selector/here-wallet": [ "packages/here-wallet/src/index.ts" ], + "@near-wallet-selector/sweat-wallet": [ + "packages/sweat-wallet/src/index.ts" + ], "@near-wallet-selector/ledger": [ "packages/ledger/src/index.ts" ], diff --git a/yarn.lock b/yarn.lock index 0c202f481..184ec8061 100644 --- a/yarn.lock +++ b/yarn.lock @@ -7270,6 +7270,11 @@ dependencies: "@swc/counter" "^0.1.3" +"@sweatco/wallet-selector@1.0.0-alpha.0": + version "1.0.0-alpha.0" + resolved "https://registry.yarnpkg.com/@sweatco/wallet-selector/-/wallet-selector-1.0.0-alpha.0.tgz#811da97171c1c4bfe25dd2f93a13ce25f89b05db" + integrity sha512-s1oK9kHRLmmvQcIS5gTyaSz1OgFh/sLv9G9ucIX8kTiWyuNTCUcScMUUoQU7T+53KhT1aBLqR6cixZShJqHBeg== + "@tanstack/query-core@5.24.8": version "5.24.8" resolved "https://registry.yarnpkg.com/@tanstack/query-core/-/query-core-5.24.8.tgz#b407546a726ecd4d60b8682dec2ca84ac9eab81e" @@ -21956,16 +21961,7 @@ string-range@~1.2, string-range@~1.2.1: resolved "https://registry.yarnpkg.com/string-range/-/string-range-1.2.2.tgz#a893ed347e72299bc83befbbf2a692a8d239d5dd" integrity sha512-tYft6IFi8SjplJpxCUxyqisD3b+R2CSkomrtJYCkvuf1KuCAWgz7YXt4O0jip7efpfCemwHEzTEAO8EuOYgh3w== -"string-width-cjs@npm:string-width@^4.2.0": - version "4.2.3" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== - dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" - -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +"string-width-cjs@npm:string-width@^4.2.0", "string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -22064,14 +22060,7 @@ string_decoder@~1.1.1: dependencies: safe-buffer "~5.1.0" -"strip-ansi-cjs@npm:strip-ansi@^6.0.1": - version "6.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== - dependencies: - ansi-regex "^5.0.1" - -strip-ansi@^6.0.0, strip-ansi@^6.0.1: +"strip-ansi-cjs@npm:strip-ansi@^6.0.1", strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== @@ -23884,7 +23873,7 @@ wordwrap@^1.0.0: resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" integrity sha512-gvVzJFlPycKc5dZN4yPkP8w7Dc37BtP1yczEneOb4uq34pXZcvrtRTmWV8W+Ume+XCxKgbjM+nevkyFPMybd4Q== -"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0", wrap-ansi@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== @@ -23902,15 +23891,6 @@ wrap-ansi@^6.0.1, wrap-ansi@^6.2.0: string-width "^4.1.0" strip-ansi "^6.0.0" -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - wrap-ansi@^8.1.0: version "8.1.0" resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-8.1.0.tgz#56dc22368ee570face1b49819975d9b9a5ead214" From 043f3269d9db98f850602fc27c5092337e5c7987 Mon Sep 17 00:00:00 2001 From: Igor Sova Date: Fri, 14 Mar 2025 18:05:28 +0000 Subject: [PATCH 2/3] Fix the loading icon import --- packages/modal-ui/src/lib/components/WalletConnecting.tsx | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/packages/modal-ui/src/lib/components/WalletConnecting.tsx b/packages/modal-ui/src/lib/components/WalletConnecting.tsx index 97a98cf20..a68a93b1f 100644 --- a/packages/modal-ui/src/lib/components/WalletConnecting.tsx +++ b/packages/modal-ui/src/lib/components/WalletConnecting.tsx @@ -1,6 +1,5 @@ import React, { Fragment } from "react"; import type { Wallet } from "@near-wallet-selector/core"; -import LoadingIcon from "../images/connecting-loader.png"; import { ModalHeader } from "./ModalHeader"; import { translate } from "@near-wallet-selector/core"; @@ -25,7 +24,10 @@ export const WalletConnecting: React.FC = ({

{wallet?.metadata.name}

- loading-icon + loading-icon
{translate("modal.wallet.connectingTo")} {wallet?.metadata.name} From 3aff8fdcb29a7757e262a8eec7ffacc502291847 Mon Sep 17 00:00:00 2001 From: Igor Sova Date: Thu, 3 Apr 2025 04:27:11 +0100 Subject: [PATCH 3/3] Bump `@sweatco/wallet-selector` to `1.0.0-alpha.3` --- package.json | 2 +- yarn.lock | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index 0813305de..4841586a0 100644 --- a/package.json +++ b/package.json @@ -108,7 +108,7 @@ "@noble/hashes": "1.4.0", "@peersyst/near-mobile-signer": "1.1.4", "@ramper/near": "0.0.30", - "@sweatco/wallet-selector": "1.0.0-alpha.0", + "@sweatco/wallet-selector": "1.0.0-alpha.3", "@tanstack/react-query": "5.24.8", "@walletconnect/modal": "2.6.2", "@walletconnect/sign-client": "2.13.0", diff --git a/yarn.lock b/yarn.lock index 184ec8061..f92ebefb1 100644 --- a/yarn.lock +++ b/yarn.lock @@ -7270,10 +7270,10 @@ dependencies: "@swc/counter" "^0.1.3" -"@sweatco/wallet-selector@1.0.0-alpha.0": - version "1.0.0-alpha.0" - resolved "https://registry.yarnpkg.com/@sweatco/wallet-selector/-/wallet-selector-1.0.0-alpha.0.tgz#811da97171c1c4bfe25dd2f93a13ce25f89b05db" - integrity sha512-s1oK9kHRLmmvQcIS5gTyaSz1OgFh/sLv9G9ucIX8kTiWyuNTCUcScMUUoQU7T+53KhT1aBLqR6cixZShJqHBeg== +"@sweatco/wallet-selector@1.0.0-alpha.3": + version "1.0.0-alpha.3" + resolved "https://registry.yarnpkg.com/@sweatco/wallet-selector/-/wallet-selector-1.0.0-alpha.3.tgz#3f992289e3cfb085942c83e2066d16fe1bb81f90" + integrity sha512-H6WgvEGgv56ordgFU62Df3vC2y1OMoV80WddobNXgC6efZXJyQAtSM8hSm/2A6SWseuUqkzsHrnH+BBX8Yqcpg== "@tanstack/query-core@5.24.8": version "5.24.8"