-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 945bb93
Showing
59 changed files
with
11,833 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
# https://EditorConfig.org | ||
|
||
root = true | ||
|
||
[*] | ||
charset = utf-8 | ||
end_of_line = lf | ||
indent_size = 2 | ||
indent_style = space | ||
insert_final_newline = true | ||
trim_trailing_whitespace = true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# This env file should be checked into source control | ||
# This is the place for default values for all environments | ||
# Values in `.env.local` and `.env.production` will override these values |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
module.exports = { | ||
extends: ["blitz"], | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# dependencies | ||
node_modules | ||
.yarn/cache | ||
.yarn/unplugged | ||
.yarn/build-state.yml | ||
.pnp.* | ||
.npm | ||
web_modules/ | ||
|
||
# blitz | ||
/.blitz/ | ||
/.next/ | ||
*.sqlite | ||
*.sqlite-journal | ||
.now | ||
.blitz-console-history | ||
blitz-log.log | ||
|
||
# misc | ||
.DS_Store | ||
|
||
# local env files | ||
.env.local | ||
.env.*.local | ||
.envrc | ||
|
||
# Logs | ||
logs | ||
*.log | ||
|
||
# Runtime data | ||
pids | ||
*.pid | ||
*.seed | ||
*.pid.lock | ||
|
||
# Testing | ||
.coverage | ||
*.lcov | ||
.nyc_output | ||
lib-cov | ||
|
||
# Caches | ||
*.tsbuildinfo | ||
.eslintcache | ||
.node_repl_history | ||
.yarn-integrity | ||
|
||
# Serverless directories | ||
.serverless/ | ||
|
||
# Stores VSCode versions used for testing VSCode extensions | ||
.vscode-test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
#!/bin/sh | ||
. "$(dirname "$0")/_/husky.sh" | ||
|
||
npx lint-staged | ||
npx pretty-quick --staged |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
#!/bin/sh | ||
. "$(dirname "$0")/_/husky.sh" | ||
|
||
npx tsc | ||
npm run lint | ||
npm run test |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
save-exact=true | ||
legacy-peer-deps=true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
.gitkeep | ||
.env* | ||
*.ico | ||
*.lock | ||
db/migrations | ||
.next | ||
.blitz |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
{ | ||
"recommendations": [ | ||
"dbaeumer.vscode-eslint", | ||
"editorconfig.editorconfig", | ||
"esbenp.prettier-vscode", | ||
"mikestead.dotenv", | ||
"mgmcdermott.vscode-language-babel", | ||
"orta.vscode-jest", | ||
"prisma.prisma" | ||
], | ||
"unwantedRecommendations": [] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
{ | ||
"editor.defaultFormatter": "esbenp.prettier-vscode", | ||
"editor.formatOnSave": true, | ||
"editor.codeActionsOnSave": { | ||
"source.fixAll.eslint": true | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
[![Blitz.js](https://raw.githubusercontent.com/blitz-js/art/master/github-cover-photo.png)](https://blitzjs.com) | ||
|
||
This is a [Blitz.js](https://github.com/blitz-js/blitz) app. | ||
|
||
# **cyberpunk-character-builder** | ||
|
||
## Getting Started | ||
|
||
Run your app in the development mode. | ||
|
||
``` | ||
blitz 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://<YOUR_DB_USERNAME>@localhost:5432/cyberpunk-character-builder | ||
``` | ||
|
||
Ensure the `.env.test.local` file has required environment variables: | ||
|
||
``` | ||
DATABASE_URL=postgresql://<YOUR_DB_USERNAME>@localhost:5432/cyberpunk-character-builder_test | ||
``` | ||
|
||
## Tests | ||
|
||
Runs your tests using Jest. | ||
|
||
``` | ||
yarn test | ||
``` | ||
|
||
Blitz comes with a test setup using [Jest](https://jestjs.io/) and [react-testing-library](https://testing-library.com/). | ||
|
||
## 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. | ||
|
||
## What's included? | ||
|
||
Here is the starting structure of your app. | ||
|
||
``` | ||
cyberpunk-character-builder | ||
├── app/ | ||
│ ├── api/ | ||
│ ├── 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 | ||
│ │ ├── hooks/ | ||
│ │ │ └── useCurrentUser.ts | ||
│ │ └── layouts/ | ||
│ │ └── Layout.tsx | ||
│ ├── pages/ | ||
│ │ ├── 404.tsx | ||
│ │ ├── _app.tsx | ||
│ │ ├── _document.tsx | ||
│ │ ├── index.test.tsx | ||
│ │ └── index.tsx | ||
│ └── users/ | ||
│ └── queries/ | ||
│ └── getCurrentUser.ts | ||
├── db/ | ||
│ ├── index.ts | ||
│ ├── schema.prisma | ||
│ └── seeds.ts | ||
├── integrations/ | ||
├── mailers/ | ||
│ └── forgotPasswordMailer.ts | ||
├── public/ | ||
│ ├── favicon.ico* | ||
│ └── logo.png | ||
├── test/ | ||
│ ├── setup.ts | ||
│ └── utils.tsx | ||
├── README.md | ||
├── babel.config.js | ||
├── blitz.config.js | ||
├── jest.config.js | ||
├── package.json | ||
├── tsconfig.json | ||
├── types.d.ts | ||
├── types.ts | ||
└── yarn.lock | ||
``` | ||
|
||
These files are: | ||
|
||
- The `app/` 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. | ||
|
||
- `.babelrc.js`, `.env`, etc. ("dotfiles") are configuration files for various bits of JavaScript tooling. | ||
|
||
- `blitz.config.js` is for advanced custom configuration of Blitz. It extends [`next.config.js`](https://nextjs.org/docs/api-reference/next.config.js/introduction). | ||
|
||
- `jest.config.js` contains config for Jest tests. You can [customize it if needed](https://jestjs.io/docs/en/configuration). | ||
|
||
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://eslint.org). | ||
- **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://typicode.github.io/husky). | ||
- **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://prettier.io). | ||
|
||
## 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://discord.blitzjs.com/) | ||
- [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) |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
import { AuthenticationError, Link, useMutation, Routes } from "blitz" | ||
import { LabeledTextField } from "app/core/components/LabeledTextField" | ||
import { Form, FORM_ERROR } from "app/core/components/Form" | ||
import login from "app/auth/mutations/login" | ||
import { Login } from "app/auth/validations" | ||
|
||
type LoginFormProps = { | ||
onSuccess?: () => void | ||
} | ||
|
||
export const LoginForm = (props: LoginFormProps) => { | ||
const [loginMutation] = useMutation(login) | ||
|
||
return ( | ||
<div> | ||
<h1>Login</h1> | ||
|
||
<Form | ||
submitText="Login" | ||
schema={Login} | ||
initialValues={{ email: "", password: "" }} | ||
onSubmit={async (values) => { | ||
try { | ||
await loginMutation(values) | ||
props.onSuccess?.() | ||
} catch (error) { | ||
if (error instanceof AuthenticationError) { | ||
return { [FORM_ERROR]: "Sorry, those credentials are invalid" } | ||
} else { | ||
return { | ||
[FORM_ERROR]: | ||
"Sorry, we had an unexpected error. Please try again. - " + error.toString(), | ||
} | ||
} | ||
} | ||
}} | ||
> | ||
<LabeledTextField name="email" label="Email" placeholder="Email" /> | ||
<LabeledTextField name="password" label="Password" placeholder="Password" type="password" /> | ||
<div> | ||
<Link href={Routes.ForgotPasswordPage()}> | ||
<a>Forgot your password?</a> | ||
</Link> | ||
</div> | ||
</Form> | ||
|
||
<div style={{ marginTop: "1rem" }}> | ||
Or <Link href={Routes.SignupPage()}>Sign Up</Link> | ||
</div> | ||
</div> | ||
) | ||
} | ||
|
||
export default LoginForm |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
import { useMutation } from "blitz" | ||
import { LabeledTextField } from "app/core/components/LabeledTextField" | ||
import { Form, FORM_ERROR } from "app/core/components/Form" | ||
import signup from "app/auth/mutations/signup" | ||
import { Signup } from "app/auth/validations" | ||
|
||
type SignupFormProps = { | ||
onSuccess?: () => void | ||
} | ||
|
||
export const SignupForm = (props: SignupFormProps) => { | ||
const [signupMutation] = useMutation(signup) | ||
|
||
return ( | ||
<div> | ||
<h1>Create an Account</h1> | ||
|
||
<Form | ||
submitText="Create Account" | ||
schema={Signup} | ||
initialValues={{ email: "", password: "" }} | ||
onSubmit={async (values) => { | ||
try { | ||
await signupMutation(values) | ||
props.onSuccess?.() | ||
} catch (error) { | ||
if (error.code === "P2002" && error.meta?.target?.includes("email")) { | ||
// This error comes from Prisma | ||
return { email: "This email is already being used" } | ||
} else { | ||
return { [FORM_ERROR]: error.toString() } | ||
} | ||
} | ||
}} | ||
> | ||
<LabeledTextField name="email" label="Email" placeholder="Email" /> | ||
<LabeledTextField name="password" label="Password" placeholder="Password" type="password" /> | ||
</Form> | ||
</div> | ||
) | ||
} | ||
|
||
export default SignupForm |
Oops, something went wrong.