Skip to content

theranbrig/grown

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Grown

Connecting Communities to their Local Farms Organically.

Logo

Grown is a full-stack JavaScript project built upon React and GraphQL. It is a place for farmers to sell their products online and for consumers to order products online for later pick up at farmer markets. It is built primarily with React and Apollo on the client side, with GraphQL Yoga amd Prisma connected on the backend. Purchasing is done via stripe. All mutations and queries are built with Apollo Client running on Server Side Rendered Next.js React on the front-end.

As of right now the farms are available as stores where users can order products. Markets and search are planned features for the next sprint and are coming later. Also I plan on updating the styling in order to fit in more with the feel of the app and product. It is a work in progress still. I welcome feedback and suggestions.

https://grownfarms.herokuapp.com/

Login: [email protected] Password: password

Screenshots

Home List Farm

Installation

Install Dependencies

Make sure you have Node.js, Prisma, and the Heroku Toolbelt installed.

Download and install dependencies.

git clone [email protected]:theranbrig/grown # or clone your own fork
cd grown
<!-- Be sure to install dependencies in both frontend and backend folders -->
cd frontend
npm install
cd backend
npm install

Prisma Setup

Make sure that you connect your app to a database first. This one is connected to a Prisma test database, but you can connect it to your own SQL database by following the directions at Prisma. Below is a guide to set up your own Prisma Database.

Backend

Make sure you are working in the backend folder of the grown project.

cd backend

First you need to install the Prisma CLI.

npm install -g prisma

After that you may need to login which can be done by using:

prisma login

Next you need to initialize the database by using.

prisma init

Follow the prompts as they are given. I recommend using the Demo Server to test, but you may use any other DB that you want. Follow through with the rest of the steps by naming it and giving it the stage dev. You may also get a prompt asking for the Programming Language. For that you may set it to Don't Generate.

Your Prisma server should be set up. You now need to change the files a bit to work with our project.

Optional - You may also delete the datamodel.prisma file that was created, as our data model will be built using the datamodel.graphql.

In the root directory of the backend folder be sure that you create and set up your own variables.env file with the following information:

cd backend
touch `variables.env`

Fill in the variables.env file with your own information. The PRISMA_ENDPOINT is found in the prisma.yml file.

FRONTEND_URL="http://localhost:7777"
PRISMA_ENDPOINT="YOUR PRISMA ENDPOINT HERE FROM PRISMA.YML FILE THAT WAS CREATED"
PRISMA_SECRET="MAKEUPYOUROWNSECRET"
PORT=4444
STRIPE_SECRET="PRIVATEKEYNEEDEDFORDEPLOY"

In the prisma.yml file be sure to include the following data.

# DEVELOPMENT ENDPOINT - PUT IN VARIABLES.ENV - UNCOMMENT FOR DEVELOPMENT / COMMENT OUT FOR PRODUCTION

endpoint: ${env:PRISMA_ENDPOINT}

# PRODUCTION ENDPOINT - USE YOUR OWN - UNCOMMENT OR REWRITE FOR PRODUCTION
#endpoint: YOUR OWN END POINT

datamodel: datamodel.graphql
secret: ${env:PRISMA_SECRET}
hooks:
  post-deploy:
    - graphql get-schema -p prisma

Finally, you can run the following to deploy the datamodel to the database at any time:

npm run deploy

Once the prisma database is set up you may run the development server with:

npm run dev

Your backend should now be running on localhost:4444.

Frontend

Make sure your dependencies are installed in the frontend folder. You may then use:

npm run dev

Your app should now be visible on localhost:7777.

Make sure you are running both the frontend and backend folders.

Built With

Author

Author

Theran Brigowatz is a Full-stack Web Developer currently out of Seoul, South Korea, but transitioning back to the US. Check him out at the following:

Made with ❤️ and ☕.

About

Connecting Eaters to Farmers

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published