[BREAKGLASS] Bitcoin wallet for iOS & Android. Built with React Native https://bluewallet.io
Go to file
2026-06-11 19:12:45 +00:00
__mocks__ Delete react-native-tor.ts 2024-11-19 23:17:44 -04:00
.bundle OPS: Update to RN 67 2022-02-11 11:47:06 +00:00
.github chore(deps): update ruby/setup-ruby action to v1.313.0 2026-06-11 19:12:45 +00:00
.tx ADD: add new languages 2023-06-23 14:12:05 +01:00
android OPS: Bump version 2026-06-04 22:03:02 +01:00
blue_modules fix(deps): update dependency @noble/secp256k1 to v1.7.2 (#8590) 2026-06-11 17:27:52 +01:00
class Merge pull request #8639 from BlueWallet/perf-hd-fetch-transactions 2026-06-11 14:37:51 +01:00
codegen Update SegmentedControlNativeComponent.ts 2026-04-30 11:19:52 -05:00
components fix: no round corners in qrcode 2026-06-08 22:25:34 +01:00
fastlane REF: bump react native 2026-03-16 21:13:23 +00:00
helpers ref: prompt 2026-05-21 13:29:42 +01:00
hooks OPS: upgrade Arkade SDKs and harden Ark wallet integration (#8585) 2026-06-01 15:22:17 +01:00
img ADD: Redesign txdetail (#8289) 2026-05-11 17:10:49 +01:00
ios OPS: Bump version 2026-06-04 22:03:02 +01:00
loc REF: remove GroundControl server URL option from notification settings 2026-06-10 12:44:18 +01:00
models FIX: better electrum fee estimation 2025-11-20 22:13:07 +00:00
navigation OPS: upgrade Arkade SDKs and harden Ark wallet integration (#8585) 2026-06-01 15:22:17 +01:00
patches FIX: patch react-native-tcp-socket onConnect crash; stabilize iOS e2e 2026-05-21 16:33:43 +01:00
screen ADD: arkade ln pushes (#8634) 2026-06-10 17:35:17 +01:00
scripts REF: split BlueComponents, prune dead/optional props 2026-05-18 12:56:12 +01:00
tests ADD: arkade ln pushes (#8634) 2026-06-10 17:35:17 +01:00
typings Merge pull request #8565 from BlueWallet/deps 2026-05-21 22:56:49 +01:00
util REF: move all utils to the same dir 2026-01-12 19:53:46 +00:00
_editorconfig OPS: Upgrade RN 0.64.2 (#3170) 2021-07-06 10:38:53 +01:00
.detoxrc.json REF: bump react native 2026-03-16 21:13:23 +00:00
.eslintrc REF: bump react native 2026-03-16 21:13:23 +00:00
.gitignore REF: bump react native 2026-03-16 21:13:23 +00:00
.npmrc OPS: Attempt to fix yarn issue (#6867) 2024-08-04 15:41:49 -04:00
.ruby-version fix(deps): update react-navigation monorepo (#8582) 2026-05-22 00:32:17 +01:00
.watchmanconfig ...Android... 2019-01-19 00:40:41 -05:00
.xcode-env OPS: Update RN (#5305) 2023-03-04 17:51:11 +00:00
App.tsx REF: bump react native 2026-03-16 21:13:23 +00:00
babel.config.js fix: comment with the reference 2026-06-11 19:52:13 +01:00
bugsnag.js FIX: startup crash because of bugsnag 2026-02-23 13:25:04 +00:00
CLAUDE.md FIX: patch react-native-tcp-socket onConnect crash; stabilize iOS e2e 2026-05-21 16:33:43 +01:00
CODE_OF_CONDUCT.md DOC: operations 2019-11-29 00:22:57 +00:00
CONTRIBUTING.md REF: bump react native 2026-03-16 21:13:23 +00:00
FAQ.md Update FAQ.md - grammar fixes 2021-10-01 22:03:17 +01:00
Gemfile chore(deps): update dependency fastlane to "~> 2.234.0" 2026-05-21 21:23:19 +00:00
Gemfile.lock chore(deps): update dependency fastlane to "~> 2.234.0" 2026-05-21 21:23:19 +00:00
gesture-handler.js OPS: Upgrade RNav 7 (#7419) 2025-02-17 15:24:05 -04:00
gesture-handler.native.js OPS: Upgrade RNav 7 (#7419) 2025-02-17 15:24:05 -04:00
index.js OPS: upgrade Arkade SDKs and harden Ark wallet integration (#8585) 2026-06-01 15:22:17 +01:00
jest.config.js OPS: upgrade Arkade SDKs and harden Ark wallet integration (#8585) 2026-06-01 15:22:17 +01:00
LICENSE REF: cleanup 2026-02-08 12:49:58 +00:00
metro.config.js OPS: upgrade Arkade SDKs and harden Ark wallet integration (#8585) 2026-06-01 15:22:17 +01:00
msbuild.binlog ADD: Windows assets 2021-07-21 10:13:53 -04:00
NavigationService.ts OPS: Upgrade RNav 7 (#7419) 2025-02-17 15:24:05 -04:00
package-lock.json fix(deps): update dependency @noble/secp256k1 to v1.7.2 (#8590) 2026-06-11 17:27:52 +01:00
package.json fix(deps): update dependency @noble/secp256k1 to v1.7.2 (#8590) 2026-06-11 17:27:52 +01:00
react-native.config.js REF: Update tooltip 2026-03-28 21:26:48 +00:00
README.md ref: localization sweep — translations, lint script, cleanups 2026-05-14 16:27:30 +01:00
RELEASE.md OPS: cleanup appcenter scripts (were used for appetize); some ci & docs fixes 2024-07-30 14:25:29 +01:00
renovate.json OPS: renovate config 2026-03-02 16:08:35 +00:00
SECURITY.md Create SECURITY.md 2019-08-04 18:57:07 +01:00
shim.js ADD: lightning wallet powered by ark 2025-11-16 13:14:27 +00:00
tsconfig.json REF: prune unused deps + stale tsconfig entries 2026-05-20 18:40:25 +01:00

BlueWallet - A Bitcoin & Lightning Wallet

GitHub tag code style: prettier

Thin Bitcoin Wallet. Built with React Native and Electrum.

Appstore Playstore

Website: bluewallet.io

Community: telegram group

  • Private keys never leave your device
  • Lightning Network supported
  • SegWit-first. Replace-By-Fee support
  • Encryption. Plausible deniability
  • And many more features...

BUILD & RUN IT

Please refer to the engines field in package.json file for the minimum required versions of Node and npm. It is preferred that you use an even-numbered version of Node as these are LTS versions.

To view the version of Node and npm in your environment, run the following in your console:

node --version && npm --version
  • In your console:
git clone https://github.com/BlueWallet/BlueWallet.git
cd BlueWallet
npm install

Please make sure that your console is running the most stable versions of npm and node (even-numbered versions).

  • To run on Android:

You will now need to either connect an Android device to your computer or run an emulated Android device using AVD Manager which comes shipped with Android Studio. To run an emulator using AVD Manager:

  1. Download and run Android Studio
  2. Click on "Open an existing Android Studio Project"
  3. Open build.gradle file under BlueWallet/android/ folder
  4. Android Studio will take some time to set things up. Once everything is set up, go to Tools -> AVD Manager.
  5. Click on "Create Virtual Device..." and go through the steps to create a virtual device
  6. Launch your newly created virtual device by clicking the Play button under Actions column

Once you connected an Android device or launched an emulator, run this:

npx react-native run-android

The above command will build the app and install it. Once you launch the app it will take some time for all of the dependencies to load. Once everything loads up, you should have the built app running.

  • To run on iOS:
npx pod-install
npm start

In another terminal window within the BlueWallet folder:

npx react-native run-ios

**To debug BlueWallet on the iOS Simulator, you must choose a Rosetta-compatible iOS Simulator. This can be done by navigating to the Product menu in Xcode, selecting Destination Architectures, and then opting for "Show Both." This action will reveal the simulators that support Rosetta. **

  • To run on macOS using Mac Catalyst:
npx pod-install
npm start

Open ios/BlueWallet.xcworkspace. Once the project loads, select the scheme/target BlueWallet. Click Run.

TESTS

npm run test

LICENSE

MIT

WANT TO CONTRIBUTE?

Grab an issue from the backlog, try to start or submit a PR, any doubts we will try to guide you. Contributors have a private telegram group, request access by email bluewallet@bluewallet.io

Translations

We accept translations via Transifex

To participate you need to:

  1. Sign up to Transifex
  2. Find BlueWallet project
  3. Send join request
  4. After we accept your request you will be able to start translating! That's it!

Please note the values in curly braces should not be translated. These are the names of the variables that will be inserted into the translated string. For example, the original string "{number} of {total}" in Russian will be "{number} из {total}".

Transifex automatically creates Pull Request when language reaches 100% translation. We also trigger this by hand before each release, so don't worry if you can't translate everything, every word counts.

Vocabulary glossaries

loc/vocabulary.md + the per-language files under loc/vocabulary/ are the canonical glossary of Bitcoin/Lightning terms (Wallet, Vault, Seed, Mnemonic, Passphrase, Multisig, Payment Code, Coin Control, …) and their chosen rendering in each locale, with the reasoning behind each choice and ⚠️ anti-meaning callouts (e.g. Passcode ≠ Password, Change-output ≠ verb "to change"). Use them as ground truth when translating by hand or when feeding loc/<lang>.json to an LLM — terminology consistency across screens is the difference between "looks translated" and "is correct for a Bitcoin wallet". When you change a shipped string, update the matching row in the same PR.

Q&A

Builds automated and tested with BrowserStack

Bugs reported via BugSnag

RESPONSIBLE DISCLOSURE

Found critical bugs/vulnerabilities? Please email them bluewallet@bluewallet.io Thanks!