GithubHelp home page GithubHelp logo

dcgtc / dgrants Goto Github PK

View Code? Open in Web Editor NEW
83.0 10.0 39.0 9.63 MB

Decentralized Grant platform that implements quadratic funding.

License: GNU Affero General Public License v3.0

JavaScript 1.60% Solidity 8.01% HTML 0.50% Vue 29.32% Shell 0.01% CSS 0.84% TypeScript 59.70% Dockerfile 0.03%

dgrants's Introduction

dgrants

Directory Structure

.
├── app                     # Frontend Vue.js application
├── contracts               # Smart contracts
├── doc                     # Project documentation including the protocol definition
├── lerna.json              # Lerna config
├── package.json            # Root package configuration
├── tsconfig.json           # Typescript configuration
├── tsconfig.settings.json  # Typescript configuration
├── types                   # Shared types
├── vetur.config.js         # Vetur configuration
├── yarn.lock               # Yarn lock file
└── README.md

Contributing Guideline

Checkout the CONTRIBUTING.md if you'd like to help with building dGrants

Development

This project is a monorepo with two packages:

  • contracts/ contains the smart contracts
  • app/ is a frontend

Dependencies

To ensure that everyone is using the same version of nodejs on this project, volta is recommended!

Set your env files

Copy app/.env.template to app/.env and edit, providing your own env vars. You will have to supply a Blocknative API key and an Alchemy API key. Both services have free tiers which are sufficient for development.

cp app/.env.template app/.env

Copy contracts/.env.template to contracts/.env and edit, providing your own env vars

cp contracts/.env.template contracts/.env

You will have to supply an Alchemy API Key. An account with their free tier is sufficient for development. You'll also need a Fleek IPFS endpoint key in your .env file.

Develop

yarn
yarn dev

Lint

yarn lint

Test

yarn test

Build

yarn build

Note: Subdirectory Development

If you are working on one component or the other, you can use workspace aliases to run commands defined in the corresponding package.json independently.

For example, to run smart contract tests only:

yarn contracts test

or to start the frontend locally in development mode:

yarn app dev

Version Management & Changelogs

Versioning and Changelogs are managed by Lerna.

Version Management

Guidance around when to increase versions is coming soon.

To increase the version number and include the short hash of the git commit ID, use the following commands.

$ yarn bump:patch
$ yarn bump:minor
$ yarn bump:major

To promote a pre-release version to release which removes the short hash from the version, use the following commands.

$ yarn release:patch
$ yarn release:minor
$ yarn release:major

Changelog Requirements

In order for merged PRs to be added to the changelog, you must use one of the following tags in Github for each PR.

  • enhancement - A feature or addition to the codebase
  • bug - A fix for a bug
  • breaking - A change that breaks compatability or requires configuration changes
  • documentation - Changes or additions to documentation
  • internal - Changes or updates to build mechanisms

Help Build Decentralized Gitcoin

As of August 2021, Gitcoin Holdings is Hiring Engineers -- Say hi in the #decentralize-gitcoin channel on the Gitcoin Discord to get involve

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.