Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/KATT/shop
ππ Full-stack React/Prisma/TS/GraphQL E-Commerce Example
https://github.com/KATT/shop
circleci graphql jest nextjs nightwatch now prisma react typescript
Last synced: 3 months ago
JSON representation
ππ Full-stack React/Prisma/TS/GraphQL E-Commerce Example
- Host: GitHub
- URL: https://github.com/KATT/shop
- Owner: KATT
- Archived: true
- Created: 2018-02-27T18:51:51.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2021-06-09T08:18:30.000Z (over 3 years ago)
- Last Synced: 2024-08-02T07:11:36.824Z (6 months ago)
- Topics: circleci, graphql, jest, nextjs, nightwatch, now, prisma, react, typescript
- Language: TypeScript
- Homepage: https://shop.kattcorp.co.uk
- Size: 5.31 MB
- Stars: 382
- Watchers: 6
- Forks: 41
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-apollo-graphql - Shop - An E-Commerce Example Project Built with TypeScript, Prisma, Apollo, and Next.js. (Uncategorized / Uncategorized)
README
> **Archived:** This is using Prisma **1** which has been discontinued.
# React/Prisma/TS/GraphQL E-Commerce Example
[![Build Status](https://travis-ci.org/KATT/shop.svg?branch=master)](https://travis-ci.org/KATT/shop) [![Maintainability](https://api.codeclimate.com/v1/badges/073d5e009a2b0cd2d0b9/maintainability)](https://codeclimate.com/github/KATT/shop/maintainability)
Attempt to create a great reference project with an amazing developer experience wherein a lot of common React/Prisma/GraphQL challenges are addressed.
- [shop.kattcorp.co.uk](https://shop.kattcorp.co.uk)
- [shop-api.kattcorp.co.uk](https://shop-api.kattcorp.co.uk)## Tech
- [TypeScript](typescriptlang.org) (we have `*.js` in `.gitignore`!)
- Monorepo setup with a few different projects
- `/api` - [GraphQL](http://graphql.org/) API Gateway in front of [Prisma](https://prismagraphql.com)
- `/web` - [Next.js](https://github.com/zeit/next.js/) [React](https://reactjs.org/) App with [Apollo Client](https://www.apollographql.com/)
- `/e2e` - [Nightwatch.js](http://nightwatchjs.org/) E2E testing
- [Travis CI](https://travis-ci.org) with [Sauce Labs](http://saucelabs.com/) for cross-browser testing### `/web` features
- Server-side rendered React app.
- GraphQL using Apollo with optmistic updates.
- Pessimisticβ’ updates - app works completely **without JS enabled** in the browser (and there's E2E tests for it).
- Creates a shopping cart (`Order`) before page load, reference id saved to cookies
- Add/edit products to/in cart
- Product list from GraphQL
- Open checkout route in modal
- Discount code support (try code "`first`")## Setup
1. Install node 9
1. Install [Homebrew](https://brew.sh/)
1. Install Docker - `brew cask install docker`
1. Install yarn - `npm install -g yarn`
1. Start Docker
1. `yarn install`
- Installs deps for
- `/`
- `/api`
- `/web`
- `/e2e`
1. Start Prisma + seed DB `yarn setup:prisma`## Development
```sh
yarn dev
```Starts the `/api` Gateway, the Next.js `/web`, and a TypeScript watcher for `/e2e` in parallell.
If you prefer separate output, navigate to `/api`, etc in separate shells and run `yarn dev`
If everything goes smoothly you should be able to access the below:
- API Gateway: http://localhost:4000
- Web App: http://localhost:5000## Tests
### API Gateway
Uses [Jest](https://facebook.github.io/jest/).
```sh
yarn test:api
```### Web
`/web` has no tests _(yet)_.
### E2E
#### Install dependencies
```sh
brew install selenium-server-standalone
brew install chromedriver
brew install geckodriver
brew cask install java
```#### Run
1. Run selenium: `yarn selenium`
1. Setup + start apps: `yarn setup && yarn build && yarn dev`
1. Run tests: `yarn start:e2e`
- Will run E2E in Chrome with JS enabled
- To run without js: `yarn start:e2e -- --env chrome:nojs`
- See [nightwatch.ts](./e2e/src/nightwatch.ts) for all envs### Conventions, how to write etc
#### `/web`
- `/mutations` and `/queries` exposes render prop components for easy handling of data loading / rendering
- .. _TBC_## What's next / questions
This is a bit of a playground for web tech for me. I'm still developing it & I gather a list of things I'd like to do in [issues](https://github.com/KATT/shop/issues).
If you have problems running it, ideas of things to add, things you want me to explain / elaborate on, or need help to build a product - [open an issue](https://github.com/KATT/shop/issues/new) or reach out to me [on Twitter](https://twitter.com/alexdotjs).
Feel free to fork it and make a pull request of something cool!
---
```
/ )
/ )__/ )___/ /
( @ . @ ) )
( )
//"//""//"//KATTCORP LTD.
```by [kattcorp.com](https://kattcorp.com)