Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nainarazz/gourmetic
Have you ever run out of ideas on what to cook on your next meal? Gourmetic is a simple food recipe app that can help you find a recipe for your next meal.
https://github.com/nainarazz/gourmetic
auth0 codegen cooking express graphql mongodb monorepo nextjs oauth2 progressive-web-app react responsive-design styled-components typescript
Last synced: 2 months ago
JSON representation
Have you ever run out of ideas on what to cook on your next meal? Gourmetic is a simple food recipe app that can help you find a recipe for your next meal.
- Host: GitHub
- URL: https://github.com/nainarazz/gourmetic
- Owner: nainarazz
- License: mit
- Created: 2019-04-07T16:10:32.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-22T12:46:00.000Z (about 2 years ago)
- Last Synced: 2024-08-02T12:51:56.026Z (5 months ago)
- Topics: auth0, codegen, cooking, express, graphql, mongodb, monorepo, nextjs, oauth2, progressive-web-app, react, responsive-design, styled-components, typescript
- Language: TypeScript
- Homepage: https://gourmetic.nainarazz.now.sh
- Size: 4.03 MB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - nainarazz/gourmetic - Have you ever run out of ideas on what to cook on your next meal? Gourmetic is a simple food recipe app that can help you find a recipe for your next meal. (graphql)
README
Gourmetic is a simple side project I have worked on to help me find food to cook. I have had the problem of not knowing what to cook for breakfast, lunch, or supper. Sometimes, I would just repeat the same food multiple times during the week. I have tried looking for recipes online and also used other apps, but they seem to be a little complicated for me. So I decided to create an app for myself.
As it is still a work in progress, here are some of the functionalites at the moment:
- viewing, creating and deleting recipes
- liking a recipe
- viewing your created and liked recipes
- viewing your profile informationTo be added in the future:
- sharing recipe on social media
- commenting on recipes
- menu plannerI hope someone will find it useful.
### Technologies
Gourmetic uses a monorepo architecture. The backend code can be found in the api directory, while the front end code is in the /src directory. The project is fullstack Javascript.
Here is a list of some of the technologies used:
- **Typescript**: Type-safe JavaScript
- **Next.js**: Frontend React app
- **GraphQL**: API, using Apollo toolchain
- **Codegen**: used for giving types to graphql resolvers in the backend
- **MongoDb**: Data storage
- **Auth0**: Authenticaion
- **Now Zeit**: deployment
- **Sentry**: for error trackingSome of the tools used to improve code quality and style are:
- **Prettier**
- **TSLint**### First Time Setup
#### Clone
First, clone the repository.
using https:```sh
https://github.com/nainarazz/gourmetic.git
```using ssh:
```sh
[email protected]:nainarazz/gourmetic.git
```#### Install Dependencies
Then install all dependencies. From the root folder, run `yarn install`.
To run the backend API, create a .env file in the /api directory and add `MONGO_URL=localhost`. You can change localhost to any url that points to your MongoDb database. You can use a cloud like MLab, or you can set up a local mongodb in your machine.
You can also seed recipes collection in database by running `yarn seed`.
### Running App Locally
#### Frontend
To run the front end, open a terminal and run the command `yarn dev:web`.
#### Backend
The command to start the server is `yarn dev:api`.
### Backend Resolver Types
To add typings to the graphql resolvers in the backend api, you can run the command `yarn generate-types`. You can use the generated types for Typescript.
### Development Environment
When developing and testing locally, you will not be able to upload photos online to Cloudinary. It will only be available in production mode.
## License
MIT, see the [LICENSE](./LICENSE) file.