Merge pull request #263 from blockworks-foundation/contributors-guide
update readme
This commit is contained in:
commit
667381574a
91
README.md
91
README.md
|
@ -1,57 +1,78 @@
|
|||
This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app).
|
||||
This repo contains the Next.js app for the Mango v4 user interface.
|
||||
|
||||
## Dependency Management
|
||||
## ⚡️ Quickstart
|
||||
|
||||
When updating dependencies, there are various files that must be kept up-to-date. Newly added, or updated dependencies can introduce unwanted/malicious scripts that can introduce risks for users and/or developers. The `lavamoat allow-scripts` feature allows us to deny by default, but adds some additional steps to the usual workflow.
|
||||
To get started, follow these steps:
|
||||
|
||||
`yarn.lock`:
|
||||
|
||||
- Instead of running `yarn` or `yarn install`, run `yarn setup` to ensure the `yarn.lock` file is in sync and that dependency scripts are run according to the `allowScripts` policy (set in `packages.json`)
|
||||
- If `lavamoat` detects new scripts that are not explicitely allowed/denied, it'll throw and error with details (see below)
|
||||
- Running `yarn setup` will also dedupe the `yarn.lock` file to reduce the dependency tree. Note CI will fail if there are dupes in `yarn.lock`!
|
||||
|
||||
The `allowScripts` configuration in `package.json`:
|
||||
|
||||
- There are two ways to configure script policies:
|
||||
1. Update the allow-scripts section manually by adding the missing package in the `allowScripts` section in `package.json`
|
||||
2. Run `yarn allow-scripts auto` to update the `allowScripts` configuration automatically
|
||||
- Review each new package to determine whether the install script needs to run or not, testing if necessary.
|
||||
- Use `npx can-i-ignore-scripts` to help assessing whether scripts are needed
|
||||
|
||||
## Getting Started
|
||||
|
||||
First, run the development server:
|
||||
1. **Clone the repo:** Begin by cloning the repository using the command:
|
||||
|
||||
```bash
|
||||
git clone git@github.com:blockworks-foundation/mango-v4-ui.git
|
||||
```
|
||||
|
||||
2. **Install Dependencies:** Move into the directory and install the dependencies:
|
||||
|
||||
```bash
|
||||
cd mango-v4-ui
|
||||
yarn setup
|
||||
```
|
||||
|
||||
3. **Run the app:**
|
||||
|
||||
```bash
|
||||
npm run dev
|
||||
# or
|
||||
yarn dev
|
||||
```
|
||||
|
||||
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
|
||||
4. Browse to http://localhost:3000
|
||||
|
||||
You can start editing the page by modifying `pages/index.tsx`. The page auto-updates as you edit the file.
|
||||
## ⌨️ Contributor's Guide
|
||||
|
||||
[API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.ts`.
|
||||
### Code quality
|
||||
|
||||
The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages.
|
||||
- Avoid duplication
|
||||
- Consider performance (use useMemo and useCallback where appropriate)
|
||||
- Create logical components and give them descriptive names
|
||||
- Destructure objects and arrays
|
||||
- Define constants for event functions unless they are very simple e.g. a single state update
|
||||
- Create hooks for shared logic
|
||||
- Add translation keys in alphabetical order
|
||||
|
||||
## Learn More
|
||||
### Branching
|
||||
|
||||
To learn more about Next.js, take a look at the following resources:
|
||||
Prefix your branches with your Git username and give them concise and descriptive names
|
||||
e.g. username/branch-name
|
||||
|
||||
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
|
||||
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
|
||||
### Commits
|
||||
|
||||
You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!
|
||||
Add commits for each self-contained change and give your commits clear messages that describe the change. Smaller commits that encompass a specific change are preferred over large commits with many changes
|
||||
|
||||
## Deploy on Vercel
|
||||
### PRs
|
||||
|
||||
The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js.
|
||||
All PRs should have a meaningful name and include a description of what the changes are.
|
||||
|
||||
Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.
|
||||
If there are visual changes, include screenshots in the description.
|
||||
|
||||
## Creating Color Themes
|
||||
If the PR is unfinished include a "TODO" section with work not yet completed. If there are known issues/bugs include a section outlining what they are.
|
||||
|
||||
#### Drafts
|
||||
|
||||
Opening draft PRs is a good way for other contributors to know a feature is being worked on. This is most useful for larger/complex features and is not a requirement. When your feature is at a point where you'd like to gather feedback or it's close to completion open a draft PR and share the preview link in the relevant Discord channel
|
||||
|
||||
Prefix "WIP:" to your draft PR name
|
||||
|
||||
### Reviews
|
||||
|
||||
When your changes are finished, who you request review from depends on the type of changes.
|
||||
|
||||
For complex changes e.g. new transactions, large features, lots of client or backend interactions you should at a minimum include @tlrsssss in your review
|
||||
|
||||
For changes that affect visual elements of the app (including text changes), request a review from @saml33 at a minimum
|
||||
|
||||
If you're unsure, request a review from @tlrssss and @saml33
|
||||
|
||||
If your work involves other parts of the stack (backend, client, etc.) request a review from the relevant person in that area
|
||||
|
||||
## 🎨 Creating Color Themes
|
||||
|
||||
1. Copy one of the other color themes in [tailwind.config.js](https://github.com/blockworks-foundation/mango-v4-ui/blob/main/tailwind.config.js) (starting line 25)
|
||||
2. Modify the colors. For the variables bkg-\* and fgd-\* pick a base color for bkg-1 and fgd-1 then adjust the lightness for 2-4. Use this same process to create dark/hover variations for the colors that have these properties. The base color can be anything that works for your theme.
|
||||
|
|
Loading…
Reference in New Issue