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/8aec6/8aec6a2e20871c9ba789c54a494cd696d93bb764" alt=""
<h6> Customer clicks to order a pizza </h6>
data:image/s3,"s3://crabby-images/228f9/228f94cb6a091092901a146ae771f272cb93301b" alt=""
<h6> Customer proceeds to make payment via stripe </h6>
data:image/s3,"s3://crabby-images/7299c/7299c47fc526895e2cfca2b7c296bf05d06df7f2" alt=""
<h6> Customer payments recorded on stripe </h6>
data:image/s3,"s3://crabby-images/65442/6544235b85c1a57e7f9950600ee5143b91716b40" alt=""
<h2 id="screenshots">Admin Screenshots</h2>
<h6> Admin login page </h6>
data:image/s3,"s3://crabby-images/745e7/745e786821d6b60878580c90a3ce689e5b6ff6db" alt=""
<h6> Admin sees all pizza orders </h6>
data:image/s3,"s3://crabby-images/cf752/cf752c267e45e9e5d5bb68ea54b70eb7edcd3580" alt=""
<h6> Admin fulfils order </h6>
data:image/s3,"s3://crabby-images/a545e/a545e6f44f631e070c22e57e2178294e57188aad" alt=""
<h6> Fulfilment email sent </h6>
data:image/s3,"s3://crabby-images/e3257/e32578a32916b44539d2a4d2b284476bcdeec0f0" alt=""
<h6> Admin declines order with reason </h6>
data:image/s3,"s3://crabby-images/ca8a9/ca8a90adf607f69157a7b26afb8d24ccfc93c7e0" alt=""
<h6> Declinement email sent with reason </h6>
data:image/s3,"s3://crabby-images/eeac7/eeac795ec8171c5210fb4c70cb9dfd00b59ea69e" alt=""
<h6> Admin adds pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/84539/8453989e131e76562c75e1c99f01d1987db28d74" alt=""
<h6> Admin edits pizza type with pizza image </h6>
data:image/s3,"s3://crabby-images/1dc31/1dc315c8a18225c0638d4c814457d221f6eab5f8" alt=""
|