DownloadSadat's Pizzeria Service(React/Laravel/Mailjet/Stripe)
A pizza ordering react and laravel app
Features For react front-end
-
Show pizza menu
-
Allows admin to store pizza menu with image upload.
-
Allows admin to edit pizza menu with image upload.
-
Allows customers to order pizza while capturing their location(google maps geocoding), quantity, pizza type, total price.
-
Connects to API to send pizza order fulfilment or cancellation emails via mailgun to customers.
-
Authentication for Admin(login and logout).
-
Connects to API to allow Administrators to fulfil or cancel order with notes and emails via mailgun.
-
Allows users to enter credit/debit card via stripe integration for pizza order payments.
Features For API
-
Endpoint to return pizza menu
-
Endpoint store pizza menu with image upload.
-
Endpoint edit pizza menu
-
Endpoint take location, quantity, pizza type, toatl price as a pizza order
-
Endpoint that takes in pizza order fulfilment or cancellation emails via mailgun to customers.
-
API to Authenticate Admin login and logout
-
Endpoint to allow Administrators to fulfil or cancel order with notes and emails via mailgun.
-
take in credit/debit card payments via stripe integration.
Installation for frontend
In the project directory, you can run:
npm install
`set up configs(API URL, stripe and googlemaps API) in src/Helpers/Url.js
npm start
Prerequisites for API
Installation for API
-
Clone the Repository
-
Set up your .env
- Configuring the docker database
Build the images and start the services: docker-compose build --no-cache pizzeria-api
docker-compose up -d
Helper scripts
Running composer , php artisan or phpunit against the php container with helper scripts in the main directory:
container
Running ./container takes you inside the pizzeria-api container under user uid(1000) (same with host user) $ ./container
devuser@8cf37a093502:/var/www/html$
db
Running ./db connects to your database container's daemon using mysql client. $ ./db
mysql>
## Troubleshooting
If you happen to have issues after installing try to
- Install dependencies with composer if the vendor folder doesn't exist or errors related to dependencise are thrown
- Clear config, cache, view and route caches with artisan commands
- Modify permissions for the storage and bootstrap directories
<h2 id="screenshots">Customer Screenshots</h2>
<h6> Customer pizza menu </h6>
data:image/s3,"s3://crabby-images/a5b42/a5b42c486582f6ad3bf6bf7a83e4fe0e131cd9bf" alt=""
<h6> Customer clicks to order a pizza </h6>
data:image/s3,"s3://crabby-images/d281f/d281f1d9647f9d6b9d0906ad35488d5f5fca011a" alt=""
<h6> Customer proceeds to make payment via stripe </h6>
data:image/s3,"s3://crabby-images/504a0/504a070a890b8c5be11b51ed3a963ab6da53041a" alt=""
<h6> Customer payments recorded on stripe </h6>
data:image/s3,"s3://crabby-images/3f6f6/3f6f6cfa89e89d0631fd4946e9ddc8652c106367" alt=""
<h2 id="screenshots">Admin Screenshots</h2>
<h6> Admin login page </h6>
data:image/s3,"s3://crabby-images/bbb13/bbb13e6c25b7b688372234cfbc51f1e1b91728bb" alt=""
<h6> Admin sees all pizza orders </h6>
data:image/s3,"s3://crabby-images/985d7/985d71eb239ae4646e47a1be680ca045a879934f" alt=""
<h6> Admin fulfils order </h6>
data:image/s3,"s3://crabby-images/7afcb/7afcb8453e177664ed1762a949cd65cfb5d98b1f" alt=""
<h6> Fulfilment email sent </h6>
data:image/s3,"s3://crabby-images/d3bd9/d3bd9ae85e1643f9662918f39cc238b1d9582f72" alt=""
<h6> Admin declines order with reason </h6>
data:image/s3,"s3://crabby-images/d61e7/d61e7f1934e2c2f2cafccf147e29d24feffe2c4d" alt=""
<h6> Declinement email sent with reason </h6>
data:image/s3,"s3://crabby-images/66295/66295e4e74547f85d808a6cf98d4b9e00c351402" alt=""
<h6> Admin adds pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/0da7a/0da7acbf96cc446c3de273276df795866291210b" alt=""
<h6> Admin edits pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/cf06c/cf06c3805db23e5c536efaf5aae37b5437af8324" alt=""
|