An open API service indexing awesome lists of open source software.

https://github.com/Innovation-Advisory-Links-Foundation/DigitalHandshake-Frontend

The official frontend of DigitalHandshake dApp
https://github.com/Innovation-Advisory-Links-Foundation/DigitalHandshake-Frontend

blockchain digitalization eosio handshake smartcontract

Last synced: 8 months ago
JSON representation

The official frontend of DigitalHandshake dApp

Awesome Lists containing this project

README

          

# DHSLogo

**A blockchain-based solution for making digital handshakes guaranteeing transparency on identity, code and payments.**

- Building a new form of trust in the digital handshake process (from platform to code) through an EOSIO blockchain-based solution.
- Fair and decentralized dispute resolution with a pseudo-random selection of jurors for reducing the cost-benefit ratio.
- Automatic token payments through a decentralized and bulletproof escrow service.

You can learn more about the main challenges of building trust for digital handshakes on the article on our [OverTheBlock Medium](https://medium.com/overtheblock/) page.

## Table of Contents

- [Workflow](#workflow)
- [Frontend](#frontend)
- [Getting Started](#getting-started)
- [Prerequisities](#prerequisities)
- [Configuration](#configuration)
- [Usage](#usage)
- [Screenshoots](#screenshoots)
- [Development Rules](#development-rules)
- [Commit](#commit)
- [Branch](#branch)
- [License](#license)

## Workflow


Workflow

Figure 1. The high-level overview of Digital Handshake workflow.

- **Users**. An individual or entity registered on the platform and uniquely recognized in the blockchain through a human-readable address. The user can have the Dealer's role when it posts a request for a particular service (e.g., I need a website!) or Bidder's role when it proposes itself for satisfying a specific demand. A user can play both roles, one for each handshake.

- **Jurors**. Professionals or legal experts recorded on the platform. They assist the parties in the judgment of a dispute. They do not have a concrete motivation to participate in the handshake but are interested in receiving new dispute assignments to increase earnings.

The on-chain business logic is broken down into three smart contracts, where each solves a particular function:

- **Token**. A standard ERC20 token (DHS) offers price stability when making any form of contactless payment.

- **Service**. All features for making digital handshakes.

- **Escrow**. A service that locks amounts of DHS tokens for automating payments.

You can find more about the on the [Digital Handshake backend repository](https://github.com/Innovation-Advisory-Links-Foundation/DigitalHandshake-Backend).

## Frontend


Architecture

Figure 2. The high-level overview of Digital Handshake architecture.

The frontend is a [React](https://reactjs.org/) web application. To reduce complexity in user access, we have implemented a custom login component with a password. This works like the SoA client-side wallet providers comply with the key's security rules and is easily digestible by the user. Provides a tabular layout that allows users to move quickly between the various handshakes through a sorting and filtering system. The user bar that shows rating, current balance and quantity of tokens locked allows always to keep track of token movements. Communicate directly with the blockchain and the off-chain database through two different ad-hoc services. The [EOSIO](https://eos.io/) blockchain service was implemented from scratch with the [eosjs](https://eos.io/for-developers/build/eosjs/) library to ensure greater freedom in managing transactions.

## Getting Started

### Prerequisities

You need to have the following installed:

- [git](https://git-scm.com/downloads) >= _2.21.0_
- [node](https://nodejs.org/en/download/) >= _10.16.0_
- [npm](https://www.npmjs.com/get-npm) >= _6.14.4_

### Configuration

Clone the repository and install the packages:

```bash
git clone https://github.com/Innovation-Advisory-Links-Foundation/DigitalHandshake-Frontend.git
cd DigitalHandshake-Frontend
npm install
```

```bash
NODE_PATH=src
# absolute path for require()
# DO NOT CHANGE NOR REMOVE THE ABOVE

REACT_APP_EOS_DHS_SERVICE_CONTRACT="dhsservice"
REACT_APP_EOS_DHS_TOKEN_CONTRACT="dhstoken"
REACT_APP_EOS_DHS_ESCROW_CONTRACT="dhsescrow"
REACT_APP_EOS_HTTP_ENDPOINT="http://localhost:8888"
REACT_APP_MONGODB_EXPRESS_NODE_SERVER_ENDPOINT="http://localhost:8080"
REACT_APP_USER_API="api/v1/users"
REACT_APP_NEGOTIATIONS_API="api/v1/negotiations"
REACT_APP_MOTIVATIONS_API="api/v1/motivations"
```

- The `REACT_APP_EOS_DHS_SERVICE_CONTRACT`, `REACT_APP_EOS_DHS_TOKEN_CONTRACT` and `REACT_APP_EOS_DHS_ESCROW_CONTRACT` are the smart contracts names.
- The `REACT_APP_EOS_HTTP_ENDPOINT` is the endpoint of the EOSIO development node.
- The `REACT_APP_MONGODB_EXPRESS_NODE_SERVER_ENDPOINT` is the endpoint of the Express NodeJS server which routes requests to the MongoDB instance.
- The `REACT_APP_USER_API`, `REACT_APP_NEGOTIATIONS_API` and `REACT_APP_MOTIVATIONS_API` are the rest API main routes names.

### Usage

To start the ReactJS application.

```bash
npm start
```

Run ESLint to check the syntax of your TypeScript code.

```bash
npm run code:lint
```

Run ESLint along with Prettier for syntax checking, style and code fix to your TypeScript code.

```bash
npm run code:fix
```

## Screenshoots

### Login


Login

Figure 3. Login page for first access.

### Login with Password


Login with password

Figure 4. Login page for quick access via password (after first access).

### Explore Page


Explore Page

Figure 5. Explore page which shows requests made by other users.

### Requests Page


Requests Page

Figure 6. Requests page which shows the requests made by the logged in user.

### Handshakes Page


Handshakes Page

Figure 7. Handshakes page which shows the handshakes where the logged in user participates as a dealer or bidder.

## Development Rules

### Commit

See how a minor change to your commit message style can make you a better programmer.
Boilerplate
Format: `(): `

`` is optional

#### Example

```
[feat]: add hat wobble
^----^ ^------------^
| |
| +-> Summary in present tense.
|
+-------> Type: chore, docs, feat, fix, refactor, style, or test.
```

More Examples:

- `feat`: (new feature for the user, not a new feature for build script)
- `fix`: (bug fix for the user, not a fix to a build script)
- `docs`: (changes to the documentation)
- `style`: (formatting, missing semicolons, etc.; no production code change)
- `refactor`: (refactoring production code, e.g., renaming a variable)
- `test`: (adding missing tests, refactoring tests; no production code change)
- `chore`: (updating grunt tasks etc.; no production code change)

**References**:

- [Conventional Commits](https://www.conventionalcommits.org/)
- [Semantic Commit Messages](https://seesparkbox.com/foundry/semantic_commit_messages)
- [Git Commit Msg](http://karma-runner.github.io/1.0/dev/git-commit-msg.html)

### Branch

- The _master_ branch must be used for releases only.
- There is a dev branch, used to merge all sub dev branch.
- Avoid long descriptive names for long-lived branches.
- No CamelCase.
- Use grouping tokens (words) at the beginning of your branch names (in a similar way to the `type` of commit).
- Define and use small lead tokens to differentiate branches in a meaningful way to your workflow.
- Use slashes to separate parts of your branch names.
- Remove branch after merge if it is not essential.

Examples:

git branch -b docs/README
git branch -b test/one-function
git branch -b feat/side-bar
git branch -b style/header

## License

This repository is released under the [GNU-GPL3](https://github.com/Innovation-Advisory-Links-Foundation/DigitalHandshake-Frontend/blob/master/LICENSE) License.

---

Digital Handshake Frontend © 2021+, [LINKS Foundation](https://linksfoundation.com/)