Inji Mobile Wallet is a mobile application specifically created to streamline all types of identification and credentials into one digital wallet. It offers a secure, trustworthy, and dependable mobile Verifiable Credentials wallet designed to fulfil the following functions
- Download and store Verifiable Credentials
- Share Verifiable Credentials
- Enable users to log in to relying parties with their credential
- Generate a QR code for the credential to be shared offline with relying parties.
for more details refer here
Be sure to have the following build tools installed before proceeding:
- React Native 0.74.5
- Hermes Engine enabled
- Expo 51.0.0
- node v18.17.1
- npm 8.19.3
- Java 17
- Gradle 8.2
- Android SDK
- minSdkVersion = 24
- compileSdkVersion = 34
- targetSdkVersion = 34
- ndkVersion = 21.4.7075529
- kotlinVersion = 1.9.0
- XCode = >15
- Minimum Deployment Target = 14.0
- cocoapods > 1.12
- Ruby >= 2.6.10
If you ever want to use something in your local environment based on your customization and in need of using environment files other than default (.env), you can add some variables to your .env.local file.
Create a .env.local
file using .env
as your template in your root directory :
# Mimoto Server
MIMOTO_HOST = https://api.collab.mosip.net/
# ESignet Server
ESIGNET_HOST = https://esignet.collab.mosip.net/
# Telemetry Server
OBSRV_HOST = https://dataset-api.obsrv.mosip.net
Telemetry Dashboard = https://druid.obsrv.mosip.net/unified-console.html#workbench
#Application Theme can be ( gradient | purple ), defaults to gradient theme
APPLICATION_THEME=grdaient
#environment can be changed if it is toggled
CREDENTIAL_REGISTRY_EDIT=true
#Inji Wallet CLIENT ID for Data backup & Restore
GOOGLE_ANDROID_CLIENT_ID='<client_id>'
for more information on the backend services refer here.
Refer to the documentation of Inji Wallet's build and deployment android section for the steps build the android application.
Note: Alternative to building and running app via react native CLI, it can be built via Android Studio. The app is available in this repository's ./android
directory. Open this directory in Android Studio (version
4.1 and above) and the app can be built and run from there.
More info here:
Refer to the documentation of Inji Wallet's build and deployment iOS section for the steps build the iOS application.
More info here:
- React Native - Publishing to the App Store
- Apple Developer - Distributing Your App for Beta Testing and Releases
When application is built via IDE, metro need to be started manually (For instance, if building app via XCode open metro manually, as metro hook has been removed from building via XCode - reference).
However, if app is built via npm commands, metro starts automatically (For instance, npm run android:mosip
or npm run ios
)
-
Terminal Configuration Error
When attempting to build the application using certain terminals via npm commands, you may encounter the following error:
Cannot start server in new windows because no terminal app was specified, use --terminal to specify, or start a dev server manually by running npm start or yarn start in other terminal window.
Cause:
- This issue occurs due to missing or incorrect terminal configuration or environment settings.
Workaround:
- Start the development server manually by running
npm start
in a separate terminal window.
Please refer here for contributing to Inji
Credits listed here
If you can't get this to work, see the Troubleshooting page.
To learn more about React Native, take a look at the following resources:
- React Native Website - learn more about React Native.
- Getting Started - an overview of React Native and how to setup your environment.
- Learn the Basics - a guided tour of the React Native basics.
- Blog - read the latest official React Native Blog posts.
@facebook/react-native
- the Open Source; GitHub repository for
React Native.