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

https://github.com/praneetrohida/btc-pilot


https://github.com/praneetrohida/btc-pilot

Last synced: 2 months ago
JSON representation

Awesome Lists containing this project

README

        

# ****BTC Pilot πŸš€****

[btc-pilot.praneet.dev](https://btc-pilot.praneet.dev)

## App Flow
![flow.png](./flow.png)

## Getting Started

Run database migrations on your local database. Make sure your Postgres service is running and the Environment Variables are set correctly

```
yarn migrate:dev
```

Run your app in the development mode.

```
yarn dev
```

Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.

## Environment Variables

Ensure the `.env.local` file has required environment variables:

```
DATABASE_URL=postgresql://@localhost:5432/btc-pilot
CMC_API_KEY=
```

Ensure the `.env.test.local` file has required environment variables:

```
DATABASE_URL=postgresql://@localhost:5432/btc-pilot_test
CMC_API_KEY=
```

[Generate CoinMarketCap API Key](https://coinmarketcap.com/api/)

## Tests

Runs your tests using Vitest.

```
yarn test
```

## Commands

Blitz comes with a powerful CLI that is designed to make development easy and fast. You can install it with `npm i -g blitz`

```
blitz [COMMAND]

dev Start a development server
build Create a production build
start Start a production server
export Export your Blitz app as a static application
prisma Run prisma commands
generate Generate new files for your Blitz project
console Run the Blitz console REPL
install Install a recipe
help Display help for blitz
test Run project tests
```

You can read more about it on the [CLI Overview](https://blitzjs.com/docs/cli-overview) documentation.

## Directory Structure

```
btc-pilot
β”œβ”€β”€ src/
β”‚ β”œβ”€β”€ auth/
β”‚ β”‚ β”œβ”€β”€ components/
β”‚ β”‚ β”‚ β”œβ”€β”€ LoginForm.tsx
β”‚ β”‚ β”‚ └── SignupForm.tsx
β”‚ β”‚ β”œβ”€β”€ mutations/
β”‚ β”‚ β”‚ β”œβ”€β”€ changePassword.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ forgotPassword.test.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ forgotPassword.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ login.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ logout.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ resetPassword.test.ts
β”‚ β”‚ β”‚ β”œβ”€β”€ resetPassword.ts
β”‚ β”‚ β”‚ └── signup.ts
β”‚ β”‚ β”œβ”€β”€ pages/
β”‚ β”‚ β”‚ β”œβ”€β”€ forgot-password.tsx
β”‚ β”‚ β”‚ β”œβ”€β”€ login.tsx
β”‚ β”‚ β”‚ β”œβ”€β”€ reset-password.tsx
β”‚ β”‚ β”‚ └── signup.tsx
β”‚ β”‚ └── validations.ts
β”‚ β”œβ”€β”€ core/
β”‚ β”‚ β”œβ”€β”€ components/
β”‚ β”‚ β”‚ β”œβ”€β”€ Form.tsx
β”‚ β”‚ β”‚ └── LabeledTextField.tsx
β”‚ β”‚ └── layouts/
β”‚ β”‚ └── Layout.tsx
β”‚ β”œβ”€β”€ game/
β”‚ β”‚ β”œβ”€β”€ components/
β”‚ β”‚ β”‚ β”œβ”€β”€ Game.tsx
β”‚ β”‚ β”‚ └── GameInput.tsx
β”‚ β”‚ β”‚ └── GameResult.tsx
β”‚ β”‚ β”‚ └── ...
β”‚ β”‚ └── quries/
β”‚ β”‚ └── ...
β”‚ β”‚ └── mutations/
β”‚ β”‚ └── ...
β”‚ β”œβ”€β”€ pages/
β”‚ β”‚ β”œβ”€β”€ _app.tsx
β”‚ β”‚ β”œβ”€β”€ _document.tsx
β”‚ β”‚ β”œβ”€β”€ 404.tsx
β”‚ β”‚ └── index.tsx
β”‚ β”‚ └── leaderboard.tsx
β”‚ └── users/
β”‚ β”œβ”€β”€ hooks/
β”‚ β”‚ └── useCurrentUser.ts
β”‚ └── queries/
β”‚ └── getCurrentUser.ts
β”œβ”€β”€ db/
β”‚ β”œβ”€β”€ migrations/
β”‚ β”œβ”€β”€ index.ts
β”‚ β”œβ”€β”€ schema.prisma
β”‚ └── seeds.ts
β”œβ”€β”€ integrations/
β”œβ”€β”€ mailers/
β”‚ └── forgotPasswordMailer.ts
β”œβ”€β”€ public/
β”‚ β”œβ”€β”€ favicon.ico
β”‚ └── logo.png
β”œβ”€β”€ test/
β”‚ β”œβ”€β”€ setup.ts
β”‚ └── utils.tsx
β”œβ”€β”€ .eslintrc.js
β”œβ”€β”€ babel.config.js
β”œβ”€β”€ blitz.config.ts
β”œβ”€β”€ vitest.config.ts
β”œβ”€β”€ package.json
β”œβ”€β”€ README.md
β”œβ”€β”€ tsconfig.json
└── types.ts
```

These files are:

- The `src/` folder is a container for most of your project. This is where you’ll put any pages or API routes.

- `db/` is where your database configuration goes. If you’re writing models or checking migrations, this is where to go.

- `public/` is a folder where you will put any static assets. If you have images, files, or videos which you want to use in your app, this is where to put them.

- `integrations/` is a folder to put all third-party integrations like with Stripe, Sentry, etc.

- `test/` is a folder where you can put test utilities and integration tests.

- `package.json` contains information about your dependencies and devDependencies. If you’re using a tool like `npm` or `yarn`, you won’t have to worry about this much.

- `tsconfig.json` is our recommended setup for TypeScript.

- `.babel.config.js`, `.eslintrc.js`, `.env`, etc. ("dotfiles") are configuration files for various bits of JavaScript tooling.

- `blitz.config.ts` is for advanced custom configuration of Blitz. [Here you can learn how to use it](https://blitzjs.com/docs/blitz-config).

- `vitest.config.ts` contains config for Vitest tests. You can [customize it if needed](https://vitejs.dev/config/).

You can read more about it in the [File Structure](https://blitzjs.com/docs/file-structure) section of the documentation.

### Tools included

Blitz comes with a set of tools that corrects and formats your code, facilitating its future maintenance. You can modify their options and even uninstall them.

- **ESLint**: It lints your code: searches for bad practices and tell you about it. You can customize it via the `.eslintrc.js`, and you can install (or even write) plugins to have it the way you like it. It already comes with the [`blitz`](https://github.com/blitz-js/blitz/tree/canary/packages/eslint-config) config, but you can remove it safely. [Learn More](https://blitzjs.com/docs/eslint-config).
- **Husky**: It adds [githooks](https://git-scm.com/docs/githooks), little pieces of code that get executed when certain Git events are triggerd. For example, `pre-commit` is triggered just before a commit is created. You can see the current hooks inside `.husky/`. If are having problems commiting and pushing, check out ther [troubleshooting](https://typicode.github.io/husky/#/?id=troubleshoot) guide. [Learn More](https://blitzjs.com/docs/husky-config).
- **Prettier**: It formats your code to look the same everywhere. You can configure it via the `.prettierrc` file. The `.prettierignore` contains the files that should be ignored by Prettier; useful when you have large files or when you want to keep a custom formatting. [Learn More](https://blitzjs.com/docs/prettier-config).

## Learn more

Read the [Blitz.js Documentation](https://blitzjs.com/docs/getting-started) to learn more.

The Blitz community is warm, safe, diverse, inclusive, and fun! Feel free to reach out to us in any of our communication channels.

- [Website](https://blitzjs.com)
- [Discord](https://blitzjs.com/discord)
- [Report an issue](https://github.com/blitz-js/blitz/issues/new/choose)
- [Forum discussions](https://github.com/blitz-js/blitz/discussions)
- [How to Contribute](https://blitzjs.com/docs/contributing)
- [Sponsor or donate](https://github.com/blitz-js/blitz#sponsors-and-donations)