The purpose of the Comet Cupboard Inventory Tracking is to
- Provide a streamlined view of the inventory of the food pantry
- Faciliate add/removal of inventory items through restocking and cart checkout
- Provide analytics for the admin about useful statistics such as Comet Cupboard weekly usage or most popular items in a week
- Anyone who is able to login through UTD SSO
- Must be currently enrolled at UT Dallas
- Check out items at the Comet Cupboard (up to 6 item counts/week)
- Verify carts
- Manage inventory
- Check out items at the Comet Cupboard (up to 6 item counts/week)
- Verify carts
- Manage inventory
- Admin privileges such as adding/removing volunteer roles
- Look at data analytics
- The page shall display the item picture, item name, and any existing deal associated with each item for all in-stock items.
- The user shall be able to search for items.
- The user shall be able to filter for items by category and deals.
- The student shall be able to add/remove an item to/from cart.
- The student shall be able to denote the expired count for items in cart.
- The student shall be able to view all cart item information.
- The student shall be able submit cart for verification.
- The student shall be able to accept/decline the Statement of Understanding and Nondiscrimination clause.
- For a pending cart, the volunteer/staff shall be able to view the cart's owner and the adjusted count breakdown dependent on actual item count, applied deals, and applied expired items.
- For a pending cart, the page shall display a notification for the following conditions.
- Cart contains expired items.
- Adjusted cart item count exceeds 6 items.
- Adjusted cart item count for a category exceeds 1 item.
- The volunteer/staff shall be able to accept/reject a cart.
- Upon cart acceptance, the system shall record the cart transaction in the database.
- Upon a cart acceptance/rejection, the corresponding cart owner shall be notified of the result of cart verification.
- The page shall display the item picture, item name, and any existing deal associated with each item for all items.
- The volunteer/staff shall be able to search for items.
- The volunteer/staff shall be able to filter for items by category and deals.
- The volunteer/staff shall be able to modify an item's image, name, category, quantity, or deal.
- The volunteer/staff shall be able to select a source (eg. Community Garden) when modifying item counts.
- The volunteer/staff shall be able to add an item entity to the inventory.
- The staff shall be able to delete an item entity from the inventory.
data and graphs goes crazy here
- The web application must be supported on various devices such as phone, tablet, and PC.
- The user shall sign into the website via UTD SSO.
- The staff shall be able to add/remove volunteer roles from users.
- UTD SSO
- Frontend/Backend - Nuxt.js
- Database - SQLite and Prisma
- Testing - Vitest
N/A
N/A
Ensure Node.js, npm, Visual Studio Code, Git, WSL2 (windows only) are installed. Ensure that everyone is working on the latest Long-Term-Support (LTS) Node.js version.
git clone https://github.com/UTDallasEPICS/Comet-Cupboard.git
cd Comet-Cupboard
npm install
# Fill out the environment variables accordingly
cp .env.example .env
# Initialize the database and test data seeding
npx prisma migrate dev --name init
# Pick your favorite way to run (-o flag will automatically open a new tab)
npx nuxt dev -o
npm run dev
npm run dev -- -o
npm run format
# Prisma GUI to view database
npx prisma studio
Use Postman to test HTTP, SSE, and WebSockets. Keep in mind that some features like SSE do not work on the Postman extension for VSCode, so have the Postman desktop app for full functionality.
See ./notes, ./figma