Skip to content

Latest commit

 

History

History
299 lines (214 loc) · 14.3 KB

README.md

File metadata and controls

299 lines (214 loc) · 14.3 KB

Shopping Queue

Description

As a response to current Covid-19 pandemic, we decided to create a web app that helps control the flow of shoppers going to shopping at various store, in response to social distancing policies.

Click the following link to see deployed web app: https://shopping-queue.herokuapp.com/

Software Setup

To run the web app locally, start by cloning the repo:

$ git clone https://github.com/csc309-summer-2020/team21.git

Use terminal and navigate into the folder of the cloned repo, then run

$ npm run setup

which will install required npm packages for the web app.

MongoDB is also required to run the web app, which can be ran locally using:

$ mkdir mongo-data
$ mongod --dbpath mongo-data

To run the express server locally, run

$ npm run build-run

and the website should be running on http://localhost:5000/.

Website Features and Instruction

Features not implemented

For final submission of the project, we were able to implement all features listed in the proposal except for the confirmation feature for shoppers. After doing some research on the possible ways to implement a confirmation system, we decided that the workload and complexity is beyond our current ability with the given time, and we would be better off spending that time making other features better.

Basic User Authentication

For our website, we implemented a basic user authentication system for 3 different types of users. This includes the shoppers, the store owners, and the website admins. For purpose of demoing the project, we will use the following credentials for authentication:

User Type Username Password
shopper user user
shopper user2 user2
shopper user3 user3
store owner store1 store1
store owner store2 store2
store owner store3 store3
store owner store4 store4
store owner store5 store5
admin admin admin

User can select the type of user they want to login as using the LOGIN AS input field shown in screenshot below. If user don't have an account, then they can redirect themselves to register page either user the navigation bar on top, or the sign up link under the SIGN IN button.

login

As for register part of user authentication, user would first need to fill in basic account information such as username and password as seen in screenshot below.

register_home

Then, User will have to choose the type of user they will be registering for. Admin/superuser will not be open for register for obvious security reasons, but instead their credentials will have to be requested from website owners. As for shoppers and store owners, once the user entered and verified basic account information, they will need to fill out basic user profile information listed in project proposal as seen in the screenshot below.

register_profile

Once a user fills out profile information, they can begin using the website. Store owners will need to fill out location using the autocomplete system to allow their store to show up on the map feature which will be explained later.

Home

Before Login

Home This is the landing page of the website, it shows a signup button for easy access to the new users. It also lists various value added services provided by the website.

After Login

Home page is the first page shown after the login. Shoppers will see their view history (the stores they have browsed) and Queue history. Home While for the admin and shop owner; depending on the role of the user different stats are displayed. Home Home

All users will have access to contact admin form to easily send help requests to admins, and a profile button for easy access to user profiles.

Map

A map feature is implemented for the website. The right side of the page is a view-only map where user can see the stores they want to queue in on the map, as shown in the screenshot below.

map

The left side of the page is a list of all the shops registered on the website. The "highlight on map" button will place a marker on the map and re-center the map to show user where the store is, while the "queue here" button will take the user to the store queue page where the user can queue up that store. Detailed information about each store is also listed on the cards to help shoppers decide which store to queue at. A search bar is implemented on top to help filter the store cards by store name.

Store Queue

The hidden page of the website where user can't access from the navigation panel is the store queue page, as shown in screenshot below.

store_queue

Shoppers can pick the date and time in which they would come into the store, as well as their estimated shopping time, and number of shoppers. After filling out the queue information, shopper must press "add to queue" in order to queue up at the store. The website will then verify the entered queue info to make sure there are no conflicts with other shoppers or store restrictions.

My Queues

This page is where the user can view and manage all the queues that they are currently in.

store_queue

The user can view details about the store they are queued for. The user can also choose to edit the day, time, and number of shoppers for their queue. If the user no longer wants to go to a store, they can simply leave the queue.

store_queue

Shopper, Store Owner, and Admin Profiles

Shopper

Once logging in with the correct credentials for a shopper, you can now visit your own profile page! In this profile page, you will be greeted initially with your own information!

This will give you your name, email, and location that you use.

user_profile

Another interaction you can do on this page is edit your information! Once clicking any edit button on the page, you will be able to edit your information and click to save that information for your profile.

user_profile

On the favourite stores section, you will also be able to directly queue up for your favourite stores. This will allow for some quick accessing of your favourite store and enable faster workflow.

user_profile

The shopper profile page is also accompanied by the view and queue history pages. These pages provide you with the stores that you have queued and viewed for. The items in these tables can also be removed from your history on click of the ‘REMOVED’ button.

user_profile user_profile

Store Owner

Once logging in with the correct credentials for a store owner, you can now visit your store profile page. In this profile page, you will be greeted initially with the information of the store!

This will give you your name, email, and location.

user_profile

Another interaction you can do on this page is edit your information! Once clicking any edit button on the page, you will be able to edit your information and click to save that information for your profile.

store_profile

The store owner can view all the shoppers queued at their store and edit queue information if necessary

user_profile

The store owner can view more detailed stats about their store on this page:

user_profile

Admin

Once logging in with the correct credentials for an admin, you can now visit your own profile page. This page gives you basic information about yourself.

user_profile

The admin profile is also accompanied by the User Profiles and Show Owner Profiles page. These will allow you to view other user and store pages and edit them to your will.

user_profile user_profile

The admin can also view all queues at each store and all queues for each shopper.

user_profile user_profile

Messages can be sent to the admin by shoppers and shop owners. These messages can be viewed by the admin here:

user_profile

Express Routes

Note: Admin users have access to all routes, and therefore omitted from most routes access

Admin

Route Type User Access Description Body
/api/admin/profile/:username GET Admin Gets admin profile
/api/admin/profile/:username PATCH Admin Update admin profile "username": username,
"email": email,
"firstName": firstName,
"lastName": lastName,
"address": address
/api/admin/profile DELETE Admin Delete an admin "id": id
/api/admin/messages GET Admin Get all help messages
/api/admin/messages DELETE Admin Resolve/delete a message "id": id
/api/admin/messages POST All Post a message "username": username,
"userType": userType,
"title": title,
"description": description,
"date": date

Authentication

Note: All authentication routes can be accessed by both authenticated and non-authenticated users.

Route Type Description Body
/api/login POST Login and create a session "username" username,
"password": password,
"userType": userType
/api/logout GET Logout by destroying session
/api/check-session GET Get which user is logged in
/api/verifyRegister POST Verify that password is viable and username is not taken "username": username,
"password": password,
"confirmPassword":confirmPassword,
"userType": userType
/api/register/admin POST Register a new admin "username": username,
"password": password,
"userType": userType,
"firstName": firstName,
"lastName": lastName,
"email": email,
"address": address
/api/register POST Register a new shopper or store (body is different for each) Store:
"username": username,
"password": password,
"registerAs": registerAs,
"storeName": storeName,
"email": email,
"location": location,
"coordinate": coordinate,
"storeType": storeType,
"openTime": openTime,
"closeTime": closeTime,
"customerLimit": customerLimit,
"shoppingTimeLimit": shoppingTimeLimit

Shopper:
"username": username,
"firstName": firstName,
"lastName": lastName,
"email": email,
"address": address,
"remindTime": remindTime

Queue

Route Type User Access Description Body
/api/queue POST Shopper Add new queue for shopper "username": username,
"store": store,
"datetime": datetime,
"shopTime": shopTime,
"numCustomers": numCustomers,
"datetimeQueued": datetimeQueued
/api/queue/shopper/:username GET Shopper Get current queues for a shopper
/api/queue DELETE All Remove a queue "id": id
/api/queue/store/:username GET Store Get current queues for a store
/api/queue/:id PATCH All Update a queue "numCustomers": numCustomers,
"shopTime": shopTime,
"datetime": datetime

Shopper

Route Type User Access Description Body
/api/shopper/profile/:username GET Shopper Get profile for a shopper
/api/shopper/profile/:username PATCH Shopper Update profile for a shopper "firstName": firstName,
"lastName": lastName,
"email": email,
"address": address,
"remindTime": remindTime
/api/shopper/favorites/:shopperUsername/:storeUsername PATCH Shopper Add a store to shopper's favorites
/api/shopper/favorites/:username GET Shopper Get favorite stores for a shopper
/api/shopper/viewHistory/:username POST Shopper Add to view history "store": store
/api/shopper/viewHistory/:username GET Shopper Get view history
/api/shopper/viewHistory/:username DELETE Shopper Delete from view history "id": id
/api/shopper/queueHistory/:username GET Shopper Get queue history
/api/shopper/queueHistory/:username DELETE Shopper Delete from queue history "id": id
/api/shopper/favorites/:shopperUsername/:storeUsername DELETE Shopper Delete store from shopper's favorites
/api/shopper/:username DELETE Admin Delete a shopper's account
/api/shoppers GET Admin Get all shoppers

Store

Route Type User Access Description Body
/api/store/profile/:username GET All Get profile for a store
/api/store/profile/:username PATCH Store Update profile info for store "storeName": storeName,
"email": email,
"address": address,
"coordinate": coordinate,
"storeType": storeType,
"openTime": openTime,
"closeTime": closeTime,
"customerLimit": customerLimit,
"customerShopTime": customerShopTime
/api/store/:username DELETE Admin Delete a store's account
/api/stores GET All Get all stores
/api/store/queues/:username GET Store Get all queues for a store "storeName": storeName
/api/store/todayqueues/:username GET Store Get all queues for a store for today "storeName": storeName