Bitcoin thin client for iOS & Android. Built with React Native
Go to file
Marcos Rodriguez Velez 4141b2ca6c
OPS: RN Update
2024-05-06 18:21:47 -04:00
__mocks__ REF: few unit tests to TS 2024-03-10 17:44:22 +00:00
.bundle OPS: Update to RN 67 2022-02-11 11:47:06 +00:00
.circleci chore(deps): update node.js to v16.20.2 2023-08-13 21:26:50 +00:00
.github OPS: bump some CI deps 2024-05-06 15:08:55 +01:00
.tx ADD: add new languages 2023-06-23 14:12:05 +01:00
android OPS: Version bump 2024-04-28 20:10:20 -04:00
blue_modules FIX: ExportMultisigCoordinationSetup: label with / symbol will fail fs write #6484 2024-05-06 14:03:14 +01:00
class ADD: display bip47 payment code contact on tx details screen 2024-05-06 13:13:10 +01:00
components Merge branch 'master' into inter 2024-05-06 14:16:50 +01:00
fastlane/metadata/android/en-US OPS: iOS workflow for GA 2023-12-03 18:09:29 +00:00
helpers ADD: Allow user to cancel reminder in case they are not ready to decide 2024-04-06 16:40:28 -04:00
hooks FIX: is tablet detection 2024-05-05 18:57:41 +01:00
img Merge pull request #6270 from BlueWallet/leftov 2024-03-15 14:03:51 +00:00
ios OPS: RN Update 2024-05-06 18:21:47 -04:00
loc ADD: display bip47 payment code contact on tx details screen 2024-05-06 13:13:10 +01:00
models feat: refactor BlueElectrum to Typescript 2024-04-09 07:48:01 +02:00
screen Merge branch 'master' into inter 2024-05-06 14:16:50 +01:00
scripts DEL: Windows related deps as our RN code is not ready yet 2024-05-04 18:03:14 -04:00
tests ADD: display bip47 payment code contact on tx details screen 2024-05-06 13:13:10 +01:00
typings fix: replace require with import 2024-04-28 10:34:26 +01:00
_editorconfig OPS: Upgrade RN 0.64.2 (#3170) 2021-07-06 10:38:53 +01:00
.detoxrc.json TST: minor e2e refactor 2023-10-22 13:00:20 +01:00
.eslintrc OPS: Update RN 2023-12-18 11:21:42 -04:00
.gitignore OPS: RN Update 2024-05-06 18:21:47 -04:00
.npmrc OPS 2022-06-02 19:38:44 +01:00
.ruby-version OPS: Update RN (#5305) 2023-03-04 17:51:11 +00:00
.watchmanconfig
.xcode-env OPS: Update RN (#5305) 2023-03-04 17:51:11 +00:00
App.js FIX: DeviceQuickActions getEnabled 2024-04-29 18:54:19 -04:00
appcenter-post-build.sh OPS: appcenter builds fix 2023-12-29 11:09:34 +00:00
babel.config.js REF: upgrade react-native-reanimated to v2 2021-05-10 11:59:54 +03:00
BlueComponents.js REF: Header 2024-05-03 19:03:40 -04:00
CODE_OF_CONDUCT.md
CONTRIBUTING.md DOC: Update CONTRIBUTING.md 2023-12-01 18:40:26 +00:00
FAQ.md Update FAQ.md - grammar fixes 2021-10-01 22:03:17 +01:00
Gemfile OPS: Update RN, Revert Realm 2024-03-01 16:53:50 +00:00
Gemfile.lock OPS: Bundle update 2024-04-09 20:41:06 -04:00
index.js FIX: Restore stored fiat preference on launch 2024-04-27 18:20:59 -04:00
LICENSE Update LICENSE 2024-01-18 21:23:46 +00:00
metro.config.js Lint 2024-05-04 18:06:30 -04:00
msbuild.binlog ADD: Windows assets 2021-07-21 10:13:53 -04:00
Navigation.tsx FIX: Lint 2024-05-05 01:03:39 -04:00
NavigationService.ts REF: UnlockWith handle all scenarios of auth (#6169) 2024-02-24 11:08:10 -04:00
package-lock.json OPS: RN Update 2024-05-06 18:21:47 -04:00
package.json OPS: RN Update 2024-05-06 18:21:47 -04:00
react-native.config.js ADD: Search for Wallet in Home screen 2024-01-20 14:06:06 -04:00
README.md Update README.md 2024-03-23 22:22:03 +00:00
RELEASE.md chore: fix some comments 2024-03-15 13:44:00 +00:00
renovate.json OPS: renovate & codeql 2022-03-07 16:25:07 +00:00
SECURITY.md
shim.js REF: update rn-electrum-client to support latest react-native-tcp-socket; delete obsolete code 2024-02-05 19:00:34 +00:00
tsconfig.json Update tsconfig.json 2023-04-26 11:03:14 +01:00
WatchConnectivity.ios.js REF: SettingsContext 2024-04-17 21:05:48 -04:00
WatchConnectivity.js REF: Handoff Component 2021-01-18 22:40:11 -05:00

BlueWallet - A Bitcoin & Lightning Wallet

GitHub tag CircleCI 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-NoLDK. 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.

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!