mirror of
https://github.com/wassname/Open-Assistant.git
synced 2026-06-30 16:40:05 +08:00
114 lines
4.3 KiB
Markdown
114 lines
4.3 KiB
Markdown
# Open-Assistant NextJS Website
|
|
|
|
## Purpose
|
|
|
|
This provides a comprehensive webapp interface for LAION's Open Assistant
|
|
project. Initially it will support:
|
|
|
|
1. User registration using either Discord or Email.
|
|
1. Adding responses to incomplete Open Assistant tasks.
|
|
1. Rating or Ranking responses to Open Assistant tasks.
|
|
1. Viewing an activity leaderboard.
|
|
1. Tracking community wide updates.
|
|
|
|
This interface compliments the Discord bot and will give access to the same
|
|
underlying tasks.
|
|
|
|
## Contributing
|
|
|
|
### Major Dependencies
|
|
|
|
This website is built using:
|
|
|
|
1. [npm](https://www.npmjs.com/): The node package manager for building.
|
|
1. [React](https://reactjs.org/): The core frontend framework.
|
|
1. [Next.js](https://nextjs.org/): A React scaffolding framework to streamline
|
|
development.
|
|
1. [Prisma](https://www.prisma.io/): An ORM to interact with a web specific
|
|
[Postgres](https://www.postgresql.org/) database.
|
|
1. [NextAuth.js](https://next-auth.js.org/): A user authentication framework
|
|
to ensure we handle accounts with best practices.
|
|
1. [TailwindCSS](https://tailwindcss.com/): A general purpose framework for
|
|
styling any component.
|
|
1. [Chakra-UI](https://chakra-ui.com/): A wide collection of pre-built UI
|
|
components that generally look pretty good.
|
|
|
|
### Set up your environment
|
|
|
|
To contribute to the website, make sure you have the following setup and
|
|
installed:
|
|
|
|
1. [NVM](https://github.com/nvm-sh/nvm): The Node Version Manager makes it
|
|
easy to ensure you have the right NodeJS version installed. Once installed,
|
|
run `nvm use 16` to use Node 16.x. The website is known to be stable with
|
|
NodeJS version 16.x. This will install both Node and NPM.
|
|
1. [Docker](https://www.docker.com/): We use docker to simplify running
|
|
dependent services.
|
|
|
|
### Getting everything up and running
|
|
|
|
If you're doing active development we suggest the following workflow:
|
|
|
|
1. In one tab, navigate to
|
|
`${OPEN_ASSISTANT_ROOT}/scripts/frontend-development`.
|
|
1. Run `docker compose up --build`. You can optionally include `-d` to detach and
|
|
later track the logs if desired.
|
|
1. In another tab navigate to `${OPEN_ASSISTANT_ROOT/website`.
|
|
1. Run `npm install`
|
|
1. Run `npx prisma db push` (This is also needed when you restart the docker
|
|
stack from scratch).
|
|
1. Run `npm run dev`. Now the website is up and running locally at
|
|
`http://localhost:3000`.
|
|
1. To create an account, login via the user using email authentication and
|
|
navigate to `http://localhost:1080`. Check the email listed and click the
|
|
log in link. You're now logged in and authenticated.
|
|
|
|
## Code Layout
|
|
|
|
### React Code
|
|
|
|
All react code is under `src/` with a few sub directories:
|
|
|
|
1. `pages/`: All pages a user could navigate too and API URLs which are under `pages/api/`.
|
|
1. `components/`: All re-usable React components. If something gets used
|
|
twice we should create a component and put it here.
|
|
1. `lib/`: A generic place to store library files that are used anywhere.
|
|
This doesn't have much structure yet.
|
|
|
|
NOTE: `styles/` can be ignored for now.
|
|
|
|
### Database
|
|
|
|
All database configurations are stored in `prisma/schema.prisma`.
|
|
|
|
### Static Content
|
|
|
|
All static images, fonts, svgs, etc are stored in `public/`.
|
|
|
|
### Styles
|
|
|
|
We're not really using CSS styles. `styles/` can be ignored.
|
|
|
|
## Best Practices
|
|
|
|
When writing code for the website, we have a few best practices:
|
|
|
|
1. When importing packages import external dependencies first then local
|
|
dependencies. Order them alphabetically according to the package name.
|
|
1. When trying to implement something new, check if
|
|
[Chakra-UI](https://chakra-ui.com/) has components that are close enough to
|
|
your need. For example Sliders, Radio Buttons, Progress indicators, etc. They
|
|
have a lot and we can save time by re-using what they have and tweaking the
|
|
style as needed.
|
|
1. Format everything with [Prettier](https://prettier.io/). This is done by
|
|
default with pre-submits. We currently don't have any custom settings.
|
|
1. Define functional React components (with types for all properties when
|
|
feasible).
|
|
|
|
## Learn More
|
|
|
|
To learn more about Next.js, take a look at the following resources:
|
|
|
|
- [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.
|