User Management by react-native
A React Native application which enables the user to list all the user accounts and modify their information. For the backend used Node-Js.
Explanation
This is a React-Native application (using expo) for a administrator user to modify, delete or add a user account. You can use the sign up flow of this application in another application to let the user login and register in that application. On the server side, there are two types of repositories
- In Memory database
- My sql database
Server Installation & Run
for the server side
- Run
yarn
to install the packages. - Run
npm install -g babel-cli
to install babel_node. - Run
npm run start
to start the server.
React native Installation & Run
- Run
yarn
to install the packages. - Run
npm run start
to start the application.
Tests
There are test cases for Redux actions and Redux reducers in ./mobile/src/__tests__
.
- To run the tests simply execute
npm run test
.
Server
Explanation
Server side stack is Node js - Express js. In folder database
there are a number of scripts to create a database with two tables called users
and address
. To insert default data, there are two files in the json format, which insert a number of primary records in these two tables.
Configuration
You can find the server configuration file in the following path: ./server/src/settings.json
.
Options for settings.json
{
"db_type": "in_memory",
"db_config": {
"host": "your_db_ip",
"user": "your_db_username",
"password": "your_db_password",
"database": "user_management"
}
}
key | Description & Values |
---|---|
db_type | in_memory to use a in memory database, db to use a MySql database |
db_config | The connection configuration for database when db_type value is db |
There are two mock data files, one for user and another for address. These mock files will be injected as initialization data into database when the db_type
is in_memory
;
./server/src/components/users/repository/mock.json
./server/src/components/address/repository/mock.json
End points
method | url | Description |
---|---|---|
POST | /api/user/signin |
to sign in |
POST | /api/user/signup |
to sign up |
GET | /api/user/ |
to get the list of users |
GET | /api/user/:id |
to get the user information |
POST | /api/user/ |
to save the user |
POST | /api/user/:id |
to edit the user |
DELETE | /api/user/:id |
to delete the user |
GET | /api/user/checkusername/:username |
to check if the username is already taken |
POST | /api/user/updateaddresses/:id |
to update all the user addresses |
React Native
Explanation
This application has been implemented using Expo. There are 4 main screens in this application:
- SignIn Screen
- SignUp Screen
- Home Screen (Tab screen)
- List screen >> To show the users list
- Sign out
- User Account Edit Screen (Tab screen)
- User Main Information
- User Addresses
- Delete User
Configuration
The program also has the ability to work without connecting to the server. There are some json files which contain with mock data.
You can find these files in the following path: ./mobile/src/store/mock
.
You can find the configuration for this application in ./mobile/src/constants/settings.js
.
To use mock files set the USE_MOCK_SERVICES
in this file to true
;
All urls to call the server endpoints are inside a file in the following path: ./mobile/src/constants/urls/Urls.dev.js
In Urls.dev.js
set the BASE_URL
with the Node-Js server url (IP address is recommended).