Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/merokudao/dapp-store-ref-desktop
dApp Store reference implementation as a webapp. This is a vanilla implementation
https://github.com/merokudao/dapp-store-ref-desktop
dappstore meroku nextjs
Last synced: 2 months ago
JSON representation
dApp Store reference implementation as a webapp. This is a vanilla implementation
- Host: GitHub
- URL: https://github.com/merokudao/dapp-store-ref-desktop
- Owner: merokudao
- Created: 2023-04-18T07:02:09.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-01-04T04:05:43.000Z (about 1 year ago)
- Last Synced: 2024-04-14T08:42:56.085Z (9 months ago)
- Topics: dappstore, meroku, nextjs
- Language: TypeScript
- Homepage:
- Size: 3.83 MB
- Stars: 1
- Watchers: 1
- Forks: 18
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Meroku Dapp store Reference Implementation
This project was bootstrapped with [Next.js](https://nextjs.org/) and [Redux Toolkit](https://redux-toolkit.js.org/) TS template.
---
## Authors
- Akshit Ostwal [Github](https://github.com/AkshitOstwal) [Twitter](https://twitter.com/Akshitostwal)
- Abhimanyu Shekhawat [Github](https://github.com/abhimanyu121) [Twitter](https://twitter.com/sokkkkaaa)
- Rohan Thacker [Github](https://github.com/rohanthacker)## Available Scripts
In the project directory, you can run:
### `npm dev`
Runs the app in the development mode.\
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.The page will reload if you make edits.\
You will also see any lint errors in the console.### `npm run build`
Builds the app for production to the `build` folder.\
It correctly bundles React in production mode and optimizes the build for the best performance.---
### Config
App secrets can be adjusted via the .env file [Read More](https://nextjs.org/docs/pages/building-your-application/configuring/environment-variables) about customising
.env files on Next.js official docsNext.js can be configured using next.config.js [Read More](https://nextjs.org/docs/pages/api-reference/next-config-js)
---
### Steps to host on vercel
- Get Wallet Connect API key from [here](https://cloud.walletconnect.com/sign-in).
- Get Meroku API key by filling this [form](https://form.jotform.com/231576486954067).
- Go to Vercel.
- Select Github Repository.
- Proceed Ahead with default config.
- Let the build run and deployment complete.
- Go to project Settings > Environment Variables.
- Set the following environment variables -
```
NEXT_PUBLIC_WC_PROJECT_ID=
NEXT_PUBLIC_API_HOST=https://api.meroku.store/api/v1
API_HOST=https://api.meroku.store/api/v1
NEXTAUTH_URL=
NEXT_PUBLIC_HOST_PATH=
API_PATH=/
API_VERSION=v1
NEXTAUTH_SECRET=
NEXT_PUBLIC_MEROKU_API_KEY=
```
- Go to Deployments.
- Redploy your last build.### File Structure
- /src/api/api => Redux Query Setup
- /src/api/constants => API Constant Values- /src/app/constants => Application constants such as Site title, Menu etc
- /src/components => UI Components
- /src/features => Application Features
- /src/features/dapp => Integration with the dApp registry- /src/models => Generic Global models
- /src/pages => Public Pages following the Next.js convention [Read More](https://nextjs.org/docs/getting-started/project-structure#pages-routing-conventions)
- /src/store => Redux Store Setup and Middleware Setup
- /src/store/hooks => Typed Hooks for usage within the Application- /src/theme => Application theme public export, export all theme variable from this file
- /src/theme/fonts => Application fonts using Next/font- /public => Public files and Static Assets
### Styling
[Tailwind CSS](https://tailwindcss.com/docs/installation) is used to style individual elements
The global config file is `tailwind.config.js`
### Helpful Links
- [React](https://react.dev/)
- [Typescript](https://www.typescriptlang.org/)
- [Redux](https://redux.js.org/)
- [Redux Toolkit](https://redux-toolkit.js.org/)
- [TailwindCSS](https://tailwindcss.com)### Adding new API endpoints
While adding new API endpoints it is important to call `api.injectEndpoints` and register the builder function with
Redux Toolkit an example of this can be seen in `src/features/dapp/dapp_api.ts`To know more about this [visit](https://redux-toolkit.js.org/rtk-query/usage/code-splitting)