Spork Box
A full-stack web application built for a catering business in Portland, Oregon to facilitate the supply of box meals to local company employees. One of the significant challenges was to create custom eCommerce features to meet the unique business objectives.
data:image/s3,"s3://crabby-images/16708/1670837ce3d85d455246a9b9dc36af65430b6b95" alt="Spork Box's cover image"
Employer:
Tim TaylorContributions:
UI and UX designFrontend developmentBackend development
Tools:
Next.jsNodeJSStripeS3 BucketSendGrid
Production URL:
https://www.sporkbox.appChallenges
This project presented an array of intriguing challenges. One of them was to build a feature that allowed each employee to receive a specific meal reimbursement from their respective companies. This reimbursement had to be tracked meticulously, taking into account how much an employee had used on a given day and shift, how much remained, and any additional expenses they needed to cover personally.
Another complex challenge was to develop features that enabled administrators to schedule a restaurant for multiple shifts across multiple companies. Managing this intricate scheduling system required the creation of a highly efficient data structure. This structure had to facilitate easy identification of which restaurant was scheduled for a particular date, shift, and company.
Solutions
To address the first challenge, I developed a solution to retrieve all the restaurants scheduled for the specific shift an employee was ordering from. I also gathered data on past active orders. With these two pieces of information, I was able to perform calculations to determine the amount of reimbursement an employee had utilized and identify any remaining expenses they needed to cover for a particular order.
For the second challenge, I created a "schedules" schema nested within the "restaurant" schema to effectively keep track of the companies, dates, and shifts for which a restaurant was scheduled. This array of schedules was crucial in creating individual instances of the restaurant, each corresponding to a specific schedule. These instances were then presented in a user-friendly calendar view, allowing employees to easily select their preferred date and shift for orders.
Process
I built this application from the ground up, handling every aspect of its creation. This included the design of the user interface and the user experience, the development of the front end and back end, as well as the design of the database. In crafting the user interface and experience, I drew inspiration from various open-source resources, with the key objective of providing users with an effortless, seamless, and enjoyable experience.
The development process was organized into smaller, manageable sprints. Before each sprint, I engaged in client meetings to thoroughly discuss and comprehend the specific features they needed. To manage these sprints and facilitate feature development and bug tracking, we used Asana as our project management tool.
In terms of the technology stack, I selected TypeScript as the programming language, NextJS as the frontend framework, ExpressJS as the backend framework, and MongoDB as the database. To enhance maintainability and streamline development, I divided the entire application into smaller, reusable components.
Depending on the nature of the features in a given sprint, I followed different development sequences. For instance, I sometimes started working on a feature by building the user interface first and then the API, while in other instances, I reversed this order. I used an excellent VS Code extension called Thunder Client for API testing.
Finally, I integrated and rigorously tested the user interfaces with their respective APIs. Upon successful testing, I delivered the new features to the client for them to test further. Any identified bugs were promptly addressed, and once everything was functioning as expected, the features were rolled out to production.
Feature highlights
- Scalable to host millions of clients
- Pixel-perfect user interface and experience
- Implementation of the latest security standards
- Responsive to all mobile, tablet, and desktop screens
- 98% performance and 100% structure optimized (GTmetrix)
- Takes .9 seconds to load the full website in Google Chrome
Key functionalities
- User authentication
- Restaurant scheduler
- Email notification integration
- Order delivery and cancellation
- Interactive admin and user dashboard
- Complete content management system for the admins
- Calendar view to order meals for a particular day/shift
- Ability to review order review and add an item to the favorite
Snapshots
data:image/s3,"s3://crabby-images/cb55a/cb55af410b7ff76c9027d1e489263288eaa3a401" alt="Sporkbox admin dashboard page"
Admin dashboard page
data:image/s3,"s3://crabby-images/79f52/79f52052d70a1fbe832914d66477c9c9ef77b02a" alt="Sporkbox order details page"
Order details page
data:image/s3,"s3://crabby-images/34a2d/34a2de44b7a7ff9e57e96afcb6490de9257bca89" alt="Sporkbox restaurants page"
Restaurants page
data:image/s3,"s3://crabby-images/9bbf9/9bbf92fb1322e1f0e717e47eaa4613cd74ee211e" alt="Sporkbox restaurant page"
Restaurant page
data:image/s3,"s3://crabby-images/0d8b2/0d8b2e72ee3e8993945c49dbee773df4c675f503" alt="Sporkbox admin item page"
Admin item page
data:image/s3,"s3://crabby-images/5748d/5748deaab8c46f721cac8fa5e6b602f86ed4df06" alt="Sporkbox companies page"
Companies page
data:image/s3,"s3://crabby-images/a965e/a965e542ee8d06350dbb0ba1715a163aa9910d7c" alt="Sporkbox company page"
Company page
data:image/s3,"s3://crabby-images/dd873/dd8733b2f01745b09ca3c7fd87411647e0c007d4" alt="Sporkbox schedule restaurant"
Schedule restaurant
data:image/s3,"s3://crabby-images/738c6/738c6f7e36aad550e3751eeb2c1e53ae40c56221" alt="Sporkbox customer dashboard page"
Customer dashboard page
data:image/s3,"s3://crabby-images/3a16e/3a16eb42c723e16269be0b0630bb40b698544c45" alt="Sporkbox upcoming order page"
Upcoming order page
data:image/s3,"s3://crabby-images/d11bf/d11bf366df902e5bb17246c6c45f7020dd423ae5" alt="Sporkbox profile page"
Profile page
data:image/s3,"s3://crabby-images/372ab/372abf2dff18964202609e5908ff9873d3a475c5" alt="Sporkbox calendar page"
Calendar page
data:image/s3,"s3://crabby-images/6d6a0/6d6a0d348fa0c00c73b221973016f4f744c28bb5" alt="Sporkbox customer item page"
Customer item page
data:image/s3,"s3://crabby-images/233b8/233b8cc68fcb3f17d76b33f65828792e7987c4b0" alt="Sporkbox cart page"
Cart page
data:image/s3,"s3://crabby-images/3af75/3af75786f98bfdf4894ae161fdbc4202ce60a352" alt="Sporkbox favorite page"
Favorite page
data:image/s3,"s3://crabby-images/7eb97/7eb974488fa2977790a6a7c5ddc97a88ee268187" alt="Sporkbox contact page"
Contact page
data:image/s3,"s3://crabby-images/ffb43/ffb43b0570da4b01d4bff91556cfa1a889f98b9c" alt="Sporkbox payment confirmation page"
Payment confirmation page
data:image/s3,"s3://crabby-images/60c38/60c3821f33d86e8f32a62029a5bbe61774615516" alt="Sporkbox add restaurant page"
Add restaurant page
data:image/s3,"s3://crabby-images/cae26/cae264a0a2fa15b7c3358ff5f4aceaa4dc5b6ed5" alt="Sporkbox add item page"
Add item page
data:image/s3,"s3://crabby-images/d38e8/d38e8adb44bec6dea00e6fe5f2211f44e6fdae1f" alt="Sporkbox edit item page"
Edit item page
data:image/s3,"s3://crabby-images/c5924/c5924b0ac0b864fe78f4cbb8e5260030093df7d3" alt="Sporkbox add company page"
Add company page
data:image/s3,"s3://crabby-images/6d6a6/6d6a66b7cb8787b01a84732e030ea7a28a6c0f3f" alt="Sporkbox edit company page"
Edit company page
data:image/s3,"s3://crabby-images/bcce5/bcce5c9bf63c699c75d03d2e5d551cac242a2fcf" alt="Sporkbox add admin page"
Add admin page
data:image/s3,"s3://crabby-images/a6dae/a6dae7ba86a545c8dac7a7ea765ab2f3c6f73aff" alt="Sporkbox register page"
Register page
data:image/s3,"s3://crabby-images/03b65/03b6509249e6168923c6e97e44d419c90cc10e32" alt="Sporkbox sign in page"
Sign in page
data:image/s3,"s3://crabby-images/1a797/1a797eef6448fa0d7b0cbb80abe7685a7bd7c448" alt="Sporkbox forgot password page"
Forgot password page