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/1d1cc/1d1ccec9eb381fb899b1f19fb603a86165d2c6be" alt=""
<h6> Customer clicks to order a pizza </h6>
data:image/s3,"s3://crabby-images/09b2f/09b2f278a0a066c000553783ae28fc41c25732a2" alt=""
<h6> Customer proceeds to make payment via stripe </h6>
data:image/s3,"s3://crabby-images/709f0/709f012e9740819b31cc4d96c6aa465d801e50ea" alt=""
<h6> Customer payments recorded on stripe </h6>
data:image/s3,"s3://crabby-images/e3435/e3435ce1cf5fa5dbe344adbaaf3fc0b53bab94a0" alt=""
<h2 id="screenshots">Admin Screenshots</h2>
<h6> Admin login page </h6>
data:image/s3,"s3://crabby-images/b3721/b37219b5fa82c5ce5d9adb256f088f73779ccefa" alt=""
<h6> Admin sees all pizza orders </h6>
data:image/s3,"s3://crabby-images/18008/18008b4e825dd15044322b749716556f37a7b928" alt=""
<h6> Admin fulfils order </h6>
data:image/s3,"s3://crabby-images/309c4/309c481dbd48f17a274414c8125e0e3caf8162e9" alt=""
<h6> Fulfilment email sent </h6>
data:image/s3,"s3://crabby-images/69e2f/69e2f208822e25da6f7cf749d1808440743d5d79" alt=""
<h6> Admin declines order with reason </h6>
data:image/s3,"s3://crabby-images/cb796/cb7964ccab10f543aa1f8df14b40a27b8c2c7b4a" alt=""
<h6> Declinement email sent with reason </h6>
data:image/s3,"s3://crabby-images/7e1d5/7e1d5a927588b498e35a1f97163af54d43600502" alt=""
<h6> Admin adds pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/f7f3a/f7f3af063d0a79634bb9c470dc4afde57a1b201b" alt=""
<h6> Admin edits pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/596b5/596b539d71aafdd01a7b1e92acc22ed39550a42d" alt=""
|