![]() |
About | Games | Sprint 1 | Sprint 2 | Sprint 3 | Verify w/JS | N@tM |
Take a Byte
Introduction: Take A Byte is a website to find new recipies of many cuisines. Users can spin a wheel to help design or ask the AI chatbot. They can also post their own recipies that aren't on the website to further expand options.
My specific feature I worked on the posting feature. It is accessable through the main page and users can enter data to describe the recipe they are posting
Challenges: Had difficulty figuring out the data tables. Had a lot of errors when running db.init database generating file. I fixed these by asking my groupmates for help and comparing our code in speciic files to make sure everything was up to date and working.
Collaboration: throughout the entire project, I worked closedly with my groupmates to run the webstie. We tired our best to make sure everyone had their features working, and keep each other in check and on track.
Khanman board: Link here
Individual issue (also on the Khanman board):
data:image/s3,"s3://crabby-images/bb8ce/bb8ce1eff7595cbec13924ed374a092ad1847392" alt="checklist"
Checklist for my feature
data:image/s3,"s3://crabby-images/28041/280417cf2ff5e86da363771c31fff6457f818c27" alt="pic of frontend"
issue on video with self grade
My feature: posting
Posting feature frontend: User can enter name, dish, cuisine, link, comments then post it. It requires all fields to be filled out before being able to post. After posting, a button appears which the user can click which redirects them to a new page with all posts (including the one the user just posted). On this new page, the user can also delete a post or go back home.
data:image/s3,"s3://crabby-images/28c4f/28c4f5a7af57188346f1c1ee8318665e95fd34b9" alt="pic of frontend"
data:image/s3,"s3://crabby-images/cbeea/cbeea604673168d9d45f85cc6845e585da7bc274" alt="pic of frontend"
data:image/s3,"s3://crabby-images/09d35/09d352398360e788c7834a6854136d508c65eca7" alt="pic of frontend"
Posting feature backend: 2 users, martha and wayne, have their data stored in backend so far. Currently it is static but working on dynamic data. Their data is acessed through the buttons on the posting page, which displays their data. In backend an API sources the static data and displays it in frontend. They are also integrated into the table created from db.init.
data:image/s3,"s3://crabby-images/613cf/613cf77071bfdf61b0b8e78e7d21e54057f42273" alt="pic of backend"
I have more screenshots of it working below, but I can live demo the API working too!
data:image/s3,"s3://crabby-images/ecfcd/ecfcdd32169bbd9560790dd2168fc787fb275fb2" alt="pic of backend"
backend API code
data:image/s3,"s3://crabby-images/61bf6/61bf65edb8e64596196ac4fe77f2943240d1faa0" alt="pic of backend"
data table with martha and wayne (ignore all the extras please, I was testing a lot and forgot to delete them)
data:image/s3,"s3://crabby-images/7134f/7134f4ae5e948f062483a6c174be9138b20c44b5" alt="pic of backend"
python file for my specific posting feature
data:image/s3,"s3://crabby-images/29e71/29e71708617bbf3bae20739a0b6793052cb7fc39" alt="pic of backend"
data for martha and wayne in data table
Future plans with my feature: Dynamic data where the data inputed by users in the home page goes to backend and is stored there instead of locally. I also want to make it so users can only delte their own posts and not others.
Input/Output requests
API request and respone through frontend
data:image/s3,"s3://crabby-images/332d8/332d828292f9cc82c000c815256b28aa5c61bd98" alt="pic of frontend"
sucessful input in frontend
data:image/s3,"s3://crabby-images/4e7b7/4e7b75a64e832e9b51cc72a4235723f37b036126" alt="pic of frontend"
posted underneath all previous posts, shown in frontend. 200 in backend and appears in table
Using postman to show raw API request and RESTful response: Using the requests (get, post, put, and delete) to check if each feature of crud works.
data:image/s3,"s3://crabby-images/4e475/4e47527395887db0166d4fe4e3b7f0aac6ffb8e4" alt="pic of postman"
successful get, shows all posts data
data:image/s3,"s3://crabby-images/73e95/73e95791390dfb8cb6c19652032caa7ae6ba9115" alt="pic of postman"
unsuccessful delete, shows error types (this case is 500 internal error)
Input/Output requests
API request and response through frontend
data:image/s3,"s3://crabby-images/332d8/332d828292f9cc82c000c815256b28aa5c61bd98" alt="pic of frontend"
Successful input in frontend
data:image/s3,"s3://crabby-images/4e7b7/4e7b75a64e832e9b51cc72a4235723f37b036126" alt="pic of frontend"
Posted underneath all previous posts, shown in frontend. 200 in backend and appears in table
Using Postman to show raw API request and RESTful response: Using the requests (get, post, put, and delete) to check if each feature of CRUD works.
data:image/s3,"s3://crabby-images/4e475/4e47527395887db0166d4fe4e3b7f0aac6ffb8e4" alt="pic of postman"
Successful GET, shows all posts data
data:image/s3,"s3://crabby-images/73e95/73e95791390dfb8cb6c19652032caa7ae6ba9115" alt="pic of postman"
Unsuccessful DELETE, shows error types (this case is 500 internal error)
List requests
data:image/s3,"s3://crabby-images/d6d38/d6d38d7175d7359b9977d155a49242321507ea71" alt="pic"
In model, data is retrieved in lists/rows. Each object under posting (like name, dish, cuisine, etc.) is converted into a dictionary so it can store the user's input data
Discuss formatting response data (JSON) from API into DOM
data:image/s3,"s3://crabby-images/504e2/504e22d2ff062a79998fb6928586f5ff50fb8e49" alt="pic of frontend"
Read method formats the objects into a JSON-compatible dictionary.
data:image/s3,"s3://crabby-images/663ba/663ba69f2c6772087c8322118c2ee0389fc7132c" alt="pic of frontend"
Line 182, fetch API data for create method to add to table. Line 190, updates the DOM
Discuss queries from database where you extract a Python List (rows). Mention how these queries are provided by a 3rd-party library.
data:image/s3,"s3://crabby-images/7d14a/7d14a4a215b78d728d321fbd47199302290e55a9" alt="pic of postman"
Line 109 and 112 are SQLAlchemy methods to retrieve rows from the table. This is an example from read, which filters by name first and if no name, it retrieves all the posts. Then it iterates the posts with the read format in JSON format.
data:image/s3,"s3://crabby-images/1575f/1575f0f45fad858d62f95593c23e574b6a69a86c" alt="pic of postman"
Example of static data using lists
Call to Algorithm request
Discuss the call/request to the method with Algorithm (fetch to endpoint).(how frontend sends data to backend API with fetch)
data:image/s3,"s3://crabby-images/7909c/7909c5e1ddad92e288a2d8761411b5c7e21c7cc0" alt="pic"
fetchstaticposting function recieves the data.Using dynamic data from postername, endpoint is made with that data. The data is fetched from backend with GET requesst, then converted into js.
Discuss the return/response from the method with Algorithm (fetch) and how you handle data: after url called, poster_name looked up in dictionary and if exists get 200. If doesn't exist, 404 error shown.
Show how changing data or method triggers a different response, specifically normal conditions and error conditions.
Trigger is the button. Example is getting data with button. After user clicks, it fetches data of who they clicked and appears underneath
data:image/s3,"s3://crabby-images/6f447/6f447694bfbbdccfa96171a697849e9cd162a490" alt="pic of postman"
data:image/s3,"s3://crabby-images/5739d/5739d677d8dd30a4fbd7d07bf9a41a95e7951ca4" alt="pic of postman"
data:image/s3,"s3://crabby-images/61fd6/61fd65545b83fbc6f8f738c50afb5caf1c7de589" alt="pic of postman"
error to fetch when backend isn't running. When it is and the button is clicked, data appears.